From 55495d8e8271f9f3b8e10b638932d7ab7b90ed7a Mon Sep 17 00:00:00 2001 From: Gregg Tavares Date: Mon, 29 Apr 2024 18:20:16 +0200 Subject: [PATCH] pre-parse settings --- art/22RaBcCzsbaXEzCh5/art.json | 14 +++++++++++++- art/23ezRZjpZK82TqNJr/art.json | 14 +++++++++++++- art/23rhC2bHw8GtaXfa3/art.json | 14 +++++++++++++- art/25DKYMazYyFB5WS2X/art.json | 14 +++++++++++++- art/27b5AxnyWM3K9MTg4/art.json | 14 +++++++++++++- art/288uBLrF9BKty2gyx/art.json | 14 +++++++++++++- art/28nR5hx2KozuLsk3j/art.json | 14 +++++++++++++- art/296k8Y8nj6kcNxYG9/art.json | 14 +++++++++++++- art/2AAPaBjMMEbZF3peq/art.json | 14 +++++++++++++- art/2DKvftja5hyuk3K5k/art.json | 14 +++++++++++++- art/2DYifmxshFTc2mdD4/art.json | 14 +++++++++++++- art/2EjmDvPyRP8XTRp4G/art.json | 14 +++++++++++++- art/2FpAyYRgGQytFrcAM/art.json | 14 +++++++++++++- art/2GJcwJ2YQaAJsasSb/art.json | 14 +++++++++++++- art/2GcQqCitMWiQ5QRgm/art.json | 14 +++++++++++++- art/2HqTsRPbmvPseZs78/art.json | 14 +++++++++++++- art/2Jk6njpWPmAjyCJv4/art.json | 14 +++++++++++++- art/2KcwnpWC6FyBx5N9S/art.json | 14 +++++++++++++- art/2LCzyt3dGEKL3dcTG/art.json | 14 +++++++++++++- art/2PbekWKKMe8gWdJ3z/art.json | 14 +++++++++++++- art/2QLFrSm3uSxdnEW58/art.json | 14 +++++++++++++- art/2RntyLszQwDn9wi85/art.json | 14 +++++++++++++- art/2WGSa559MiYvnoJZw/art.json | 14 +++++++++++++- art/2WtKojEgxqkRD7ExF/art.json | 14 +++++++++++++- art/2XgSDRuhBYPBvZ9QX/art.json | 14 +++++++++++++- art/2YWRHPyRWHGo6A9My/art.json | 14 +++++++++++++- art/2bWezECppzztDLn4T/art.json | 14 +++++++++++++- art/2cL3kfaKBExkWc5Le/art.json | 14 +++++++++++++- art/2dNusyoCHaevCCYP7/art.json | 14 +++++++++++++- art/2djzoxSxpM9HnRXQH/art.json | 14 +++++++++++++- art/2dq4p8bnavjoyhq6E/art.json | 14 +++++++++++++- art/2dsE7Bcq8iHknqYSm/art.json | 14 +++++++++++++- art/2iJ8ao6MN4Xmw8RKM/art.json | 14 +++++++++++++- art/2iNJXhqJXRjFNZ3K7/art.json | 14 +++++++++++++- art/2ir5RybtZsBG4Hgmr/art.json | 14 +++++++++++++- art/2ivK8La4P8NhKkMDH/art.json | 14 +++++++++++++- art/2jqfBeNCFdBpfJ2RM/art.json | 14 +++++++++++++- art/2n27TgzYcMngCYSTG/art.json | 14 +++++++++++++- art/2nczC2kx9JRxu64gA/art.json | 14 +++++++++++++- art/2oQkSRKgK2ZWmq6LM/art.json | 14 +++++++++++++- art/2pSYjC7BCpjghA8Hu/art.json | 14 +++++++++++++- art/2pccx6pQfk6skHLQG/art.json | 14 +++++++++++++- art/2tNPKyop2hRKFBGz9/art.json | 14 +++++++++++++- art/2wjez5eJ6Ng5tFzSP/art.json | 14 +++++++++++++- art/2wuax4qbM5ZvmBW4r/art.json | 14 +++++++++++++- art/2xJgNnQY5FLgHt6qW/art.json | 14 +++++++++++++- art/2zrDmPHr7XSL9Smeh/art.json | 14 +++++++++++++- art/32DEaMDYx5JAqhWRY/art.json | 14 +++++++++++++- art/349P7R35WtujgHxrw/art.json | 14 +++++++++++++- art/34z5eo3NAr7q87bLk/art.json | 14 +++++++++++++- art/3AsdQHZjxgRSWK2Q4/art.json | 14 +++++++++++++- art/3Csyw9ecsH7rXLkok/art.json | 14 +++++++++++++- art/3DYWqaogssoxpbdKM/art.json | 14 +++++++++++++- art/3EGwvJZ5S8be4wM7t/art.json | 14 +++++++++++++- art/3GfvibHchBkZT4arh/art.json | 14 +++++++++++++- art/3GkC95J3qizbTmiwJ/art.json | 14 +++++++++++++- art/3K4LGxEGgP7MLHZnb/art.json | 14 +++++++++++++- art/3K4d92nvq5JFcZa8K/art.json | 14 +++++++++++++- art/3NDzadNsSWytgiaLt/art.json | 14 +++++++++++++- art/3PKtnXSrJ72kySj5P/art.json | 14 +++++++++++++- art/3PzbsXfXjckRvsRng/art.json | 14 +++++++++++++- art/3QE3h3tQJqzMMqEZw/art.json | 14 +++++++++++++- art/3Qk8RvorqrMH5CCJy/art.json | 14 +++++++++++++- art/3QtDqanQXHR4KXBo2/art.json | 14 +++++++++++++- art/3RibQfbPe3tobLxLw/art.json | 14 +++++++++++++- art/3Szoo7khkBA4exnsR/art.json | 14 +++++++++++++- art/3b3a5MqLTPvBpcvhN/art.json | 14 +++++++++++++- art/3cskmP4veKB962KoC/art.json | 14 +++++++++++++- art/3cvdmf4HtiuwSqeR8/art.json | 14 +++++++++++++- art/3dDfZyr8Pj8Nn2iTq/art.json | 14 +++++++++++++- art/3eX8nyZYKzX3Xf9be/art.json | 14 +++++++++++++- art/3fJgrXgNHKr78pqQs/art.json | 14 +++++++++++++- art/3fg2XtwJcBLhe5bdW/art.json | 14 +++++++++++++- art/3gbxiT43Btfh3sY5q/art.json | 14 +++++++++++++- art/3hNCrCAfmKvR2iKP8/art.json | 14 +++++++++++++- art/3hP9SNbDTX5RFMHT5/art.json | 14 +++++++++++++- art/3hY77qyNdTWqMqYPg/art.json | 14 +++++++++++++- art/3hco2ocM6as2y3HNr/art.json | 14 +++++++++++++- art/3hzz6KuiDcQDi54iA/art.json | 14 +++++++++++++- art/3icxEpds8WvgPmHy7/art.json | 14 +++++++++++++- art/3ii5FCaXjgCQLG3Xd/art.json | 14 +++++++++++++- art/3jq8W6M8gtjRfjRzj/art.json | 14 +++++++++++++- art/3kAd76mhEav7qtrh3/art.json | 14 +++++++++++++- art/3mX3aBsuhf372pLcD/art.json | 14 +++++++++++++- art/3oRDhfqRydMBEWnD5/art.json | 14 +++++++++++++- art/3pFLZ6LMxGuHYkjcr/art.json | 14 +++++++++++++- art/3r5fh3ut8gnwF69zs/art.json | 14 +++++++++++++- art/3rTF3aQTLfnSdwdcW/art.json | 14 +++++++++++++- art/3tnqndpH4hacfPTBd/art.json | 14 +++++++++++++- art/3uB76AAsdqqC2ZEXk/art.json | 14 +++++++++++++- art/3uH92F2f4pCxBydB3/art.json | 14 +++++++++++++- art/3uY49x2aXTxXCB2PD/art.json | 14 +++++++++++++- art/3uytcwyYXxGeEvu4D/art.json | 14 +++++++++++++- art/3vqtTygKuowBwMvu4/art.json | 14 +++++++++++++- art/3yMooDSsPRwxpbiuL/art.json | 14 +++++++++++++- art/42ESv42tR52CEdX63/art.json | 14 +++++++++++++- art/42F8ccc2pFdyw4zJb/art.json | 14 +++++++++++++- art/42pYPNux6r5SL9ebp/art.json | 14 +++++++++++++- art/48D42NwcwPw8inHZG/art.json | 14 +++++++++++++- art/48KMxjggQsHYRm8kC/art.json | 14 +++++++++++++- art/497PBSdmrjWadYpB2/art.json | 14 +++++++++++++- art/4AiWT3LpD8x6Ap7PA/art.json | 14 +++++++++++++- art/4AstrMSCjNWESEJpy/art.json | 14 +++++++++++++- art/4BEqmFyyPkLK4Me6q/art.json | 14 +++++++++++++- art/4BkjXGWjFkBTo7kEJ/art.json | 14 +++++++++++++- art/4FQ77YanjkTRoSWip/art.json | 14 +++++++++++++- art/4FbgY4x8sEM5EQuCT/art.json | 14 +++++++++++++- art/4GQmaka5iAZi5fCbw/art.json | 14 +++++++++++++- art/4JPK5YpSAQRwHtgZX/art.json | 14 +++++++++++++- art/4Jvv5ja6vMDtacCMp/art.json | 14 +++++++++++++- art/4Jy2MhQ54xH4SinZo/art.json | 14 +++++++++++++- art/4LYwmawuudnFoyRng/art.json | 14 +++++++++++++- art/4M55m9674WQP6QQ3E/art.json | 14 +++++++++++++- art/4MXkkkQvDcbZT2bmy/art.json | 14 +++++++++++++- art/4NJ7SwwBpWiHqLjmY/art.json | 14 +++++++++++++- art/4NywnD7ErprEsdfa8/art.json | 14 +++++++++++++- art/4PyDDdmyeAx9MkNKf/art.json | 14 +++++++++++++- art/4QEXMdBaekmPQnFf6/art.json | 14 +++++++++++++- art/4QQxzF25ewQs8T5Kb/art.json | 14 +++++++++++++- art/4SRkNtncZayGZ5xBF/art.json | 14 +++++++++++++- art/4TP9W3xndZ2YW8kAr/art.json | 14 +++++++++++++- art/4X6mJigNvjatDJv4q/art.json | 14 +++++++++++++- art/4a3WBCocrSgn67Cfh/art.json | 14 +++++++++++++- art/4abrmywD84XrJ5dNz/art.json | 14 +++++++++++++- art/4bGAzq9dZbNPyimzo/art.json | 14 +++++++++++++- art/4bXhbExsSEEwHZofJ/art.json | 14 +++++++++++++- art/4bxrvzvhcfEAq6Qzo/art.json | 14 +++++++++++++- art/4cc6928ASXLMQCFWy/art.json | 14 +++++++++++++- art/4d6tRjx7hKBD4t7sJ/art.json | 14 +++++++++++++- art/4e4L6TCCcTrTkKJbh/art.json | 14 +++++++++++++- art/4erk8kqXtJp9XeGP8/art.json | 14 +++++++++++++- art/4fpR5Na5QhyEeF2yw/art.json | 14 +++++++++++++- art/4h35MHPA2dwXFTJHy/art.json | 14 +++++++++++++- art/4mJdoLcvvmmvbPjdB/art.json | 14 +++++++++++++- art/4mMg6kQXSNiEDkuwR/art.json | 14 +++++++++++++- art/4mzMqjbsbYgxDQKFf/art.json | 14 +++++++++++++- art/4qDhPQsi7RfmX6Ncw/art.json | 14 +++++++++++++- art/4rzpKJ43tFQEsLBkP/art.json | 14 +++++++++++++- art/4tdHwGGpfKN7AQpoQ/art.json | 14 +++++++++++++- art/4uB9s4qnD3rioJw9B/art.json | 14 +++++++++++++- art/4uK5xMjmxCZaGBewc/art.json | 14 +++++++++++++- art/4urf28npgTBytwhyv/art.json | 14 +++++++++++++- art/4vag7ndH4zPYNfMML/art.json | 14 +++++++++++++- art/4x6bYtKoRF9gPWHAb/art.json | 14 +++++++++++++- art/4zASqsiiCDuSJRntr/art.json | 14 +++++++++++++- art/4zqMb55NkrGEgRcKc/art.json | 14 +++++++++++++- art/52MHKPZusfZtpjueA/art.json | 14 +++++++++++++- art/54TbvMsANMi2nBuBA/art.json | 14 +++++++++++++- art/54ZGebYmzcwbkmgpF/art.json | 14 +++++++++++++- art/55mQ247kbQXRdrMkJ/art.json | 14 +++++++++++++- art/55nRorvcAYfSEYJhZ/art.json | 14 +++++++++++++- art/57DGNjDnDYwrBWXqD/art.json | 14 +++++++++++++- art/57eTciQiKd6wT2ndd/art.json | 14 +++++++++++++- art/583kqaAomZpfinWXk/art.json | 14 +++++++++++++- art/58JZkbhusNHh4P6CS/art.json | 14 +++++++++++++- art/58gFy9tGHHqJ3JY4m/art.json | 14 +++++++++++++- art/59tQtCvfJrkPnfsbk/art.json | 14 +++++++++++++- art/5A8xZ8XRT4Rujidr9/art.json | 14 +++++++++++++- art/5BPbm4rfCpfS92BKS/art.json | 14 +++++++++++++- art/5CPofs7dnZ8Pd7KNv/art.json | 14 +++++++++++++- art/5EtotDS2NmQ69fxWF/art.json | 14 +++++++++++++- art/5Fphse6X3wyaFosYJ/art.json | 14 +++++++++++++- art/5MbciF3ZFxqF8hyYn/art.json | 14 +++++++++++++- art/5NxpTo5tmZ5jQ3ZE5/art.json | 14 +++++++++++++- art/5PLH8iYP7Rsj5z8NC/art.json | 14 +++++++++++++- art/5RiyKNicAa32rA9YZ/art.json | 14 +++++++++++++- art/5RkZQxjruyDfA9bS7/art.json | 14 +++++++++++++- art/5TC2fdTpuR9MXHMhb/art.json | 14 +++++++++++++- art/5Wmf5qZPP9AhQk7wB/art.json | 14 +++++++++++++- art/5WtmeHpqSmNcvRWAR/art.json | 14 +++++++++++++- art/5YGSiNrquYpFi3Ggo/art.json | 14 +++++++++++++- art/5Yw6GiojcPykGM7p6/art.json | 14 +++++++++++++- art/5bpdGEqpAwiR35mDS/art.json | 14 +++++++++++++- art/5btpWTSD8Kwb767eh/art.json | 14 +++++++++++++- art/5dNDeR4dqCCRvcHCT/art.json | 14 +++++++++++++- art/5eHGg8xT9dKtXnSgu/art.json | 14 +++++++++++++- art/5eLB8us5zfTRPWx49/art.json | 14 +++++++++++++- art/5eNtGMeN2Etw3d5dh/art.json | 14 +++++++++++++- art/5fBJ6mEfnhkJuSFyR/art.json | 14 +++++++++++++- art/5fxiyfRNSgGzTdxZG/art.json | 14 +++++++++++++- art/5gKRQuwx63MAdRePc/art.json | 14 +++++++++++++- art/5hbYiwjeJvx8tCTME/art.json | 14 +++++++++++++- art/5hf6Sm43wvfKW9tvA/art.json | 14 +++++++++++++- art/5kD5fS5JQyTcEzoY8/art.json | 14 +++++++++++++- art/5ppKAhtsPPS3xfam7/art.json | 14 +++++++++++++- art/5rPSkvavMCsT3A4KY/art.json | 14 +++++++++++++- art/5sonvpkQLwAJqGqTk/art.json | 14 +++++++++++++- art/5v2eusj5uxKkdncH3/art.json | 14 +++++++++++++- art/5vBB6qnTBzuES7iu5/art.json | 14 +++++++++++++- art/5vfETRh3Q89xEEMAA/art.json | 14 +++++++++++++- art/5vn8CgvHBoa5KFxpa/art.json | 14 +++++++++++++- art/5wpxiiCkDvE3Wsv5D/art.json | 14 +++++++++++++- art/5y8GykbHCskE8dzPd/art.json | 14 +++++++++++++- art/627rN6vKn3Edv5K5G/art.json | 14 +++++++++++++- art/6329mueSGExenMjbN/art.json | 14 +++++++++++++- art/63qyzzMSCLNjCirhM/art.json | 14 +++++++++++++- art/644CG7p6wywm6hcNt/art.json | 14 +++++++++++++- art/684pim4aQdsJFnh9S/art.json | 14 +++++++++++++- art/6C6jC7cgKsabzRcL8/art.json | 14 +++++++++++++- art/6EhsqQMiTAN8xv9yr/art.json | 14 +++++++++++++- art/6Gubrbbo9gDv8wczK/art.json | 14 +++++++++++++- art/6J7Jj9F2CdctHCkXB/art.json | 14 +++++++++++++- art/6K6qbdqNTrkx589QP/art.json | 14 +++++++++++++- art/6KurZsv36w6xrAoSf/art.json | 14 +++++++++++++- art/6N22GnCbsgYC6faeW/art.json | 14 +++++++++++++- art/6PsFwfvW2tLtoeFiC/art.json | 14 +++++++++++++- art/6QkqTG5zopSEvE5ja/art.json | 14 +++++++++++++- art/6RMx4XYpHck6oZZ4u/art.json | 14 +++++++++++++- art/6RY7TFeo6Q9wmHb5f/art.json | 14 +++++++++++++- art/6RnXzKXyyfu7NWTyb/art.json | 14 +++++++++++++- art/6SDZEZNF7qnXFxx5d/art.json | 14 +++++++++++++- art/6Xdd5o4awYpFcY4QM/art.json | 14 +++++++++++++- art/6XqJX2mnFpa8i9aLH/art.json | 14 +++++++++++++- art/6YpuWT2zbWkg2ocdL/art.json | 14 +++++++++++++- art/6Yx2A7TQ6NnyHhFPQ/art.json | 14 +++++++++++++- art/6bbL3L3PTAdvJyg8n/art.json | 14 +++++++++++++- art/6bpRiTn7zbJ2Birz8/art.json | 14 +++++++++++++- art/6cn4dH3h84zzRHviv/art.json | 14 +++++++++++++- art/6d4uyMnEKnip4oyLR/art.json | 14 +++++++++++++- art/6eSja54pMxXcD9ArN/art.json | 14 +++++++++++++- art/6gGtgPeiwrBx9DC8d/art.json | 14 +++++++++++++- art/6gQQcZm2vuBMyLCkB/art.json | 14 +++++++++++++- art/6hsoh4en6G7rPqjb8/art.json | 14 +++++++++++++- art/6kjKSErWMZSF6xj6c/art.json | 14 +++++++++++++- art/6koiJAeZMvqyq7fpb/art.json | 14 +++++++++++++- art/6nPKwArJkv4Rbz6LX/art.json | 14 +++++++++++++- art/6nxqs9sKqwTpWK2Sf/art.json | 14 +++++++++++++- art/6qenwf5cKgyGLZrXw/art.json | 14 +++++++++++++- art/6qhRHbFn8B6GeD5Ni/art.json | 14 +++++++++++++- art/6t7WhmEDeF7kcGFDh/art.json | 14 +++++++++++++- art/6xC43NutGGXHRTZ9p/art.json | 14 +++++++++++++- art/6xw95t7YcinWhp8Ra/art.json | 14 +++++++++++++- art/6zJfYSooxERRtZtbe/art.json | 14 +++++++++++++- art/6zSLjpCNA7CDQvm9e/art.json | 14 +++++++++++++- art/72Qyo6BcBD6bt9NDW/art.json | 14 +++++++++++++- art/72yf22zZ942pR2Pjn/art.json | 14 +++++++++++++- art/748RN8qRjrDrtSGy2/art.json | 14 +++++++++++++- art/75BKGgPT6J42k7Aax/art.json | 14 +++++++++++++- art/76ZBdQLBg9fxMqXhD/art.json | 14 +++++++++++++- art/7825RZhjGT9xTvEa7/art.json | 14 +++++++++++++- art/78PSuMWSJy9qmzeCm/art.json | 14 +++++++++++++- art/79HqSrQH4meL63aAo/art.json | 14 +++++++++++++- art/7ATa9Lmsc2BxYbkNw/art.json | 14 +++++++++++++- art/7AywqTMXSQtDaa9RW/art.json | 14 +++++++++++++- art/7Bkg55Y8SPEtDJedE/art.json | 14 +++++++++++++- art/7BtREZnTSkBpz7W87/art.json | 14 +++++++++++++- art/7CY4KDf722AkkpwR2/art.json | 14 +++++++++++++- art/7DebjyLHPNMjyBzn3/art.json | 14 +++++++++++++- art/7DtazpcMcdA6fJ4XW/art.json | 14 +++++++++++++- art/7EeTjhnP4EshLL5B2/art.json | 14 +++++++++++++- art/7EmHQKmTWXAwTXS63/art.json | 14 +++++++++++++- art/7F8oEX6xT8qLDdtS2/art.json | 14 +++++++++++++- art/7G88sy7oNibcANkMP/art.json | 14 +++++++++++++- art/7GNBiei7nte4HfQN2/art.json | 14 +++++++++++++- art/7HjknSiL8tp9XXHEa/art.json | 14 +++++++++++++- art/7JTyL7fuENPgA9o2H/art.json | 14 +++++++++++++- art/7M9dkbTrmJYvKMzic/art.json | 14 +++++++++++++- art/7NHz8BY49bR5hCy8h/art.json | 14 +++++++++++++- art/7PpvqJmgJR7ALoJfa/art.json | 14 +++++++++++++- art/7QAPWrZErhyBDRnKb/art.json | 14 +++++++++++++- art/7QLuHLmctdsezmmxr/art.json | 14 +++++++++++++- art/7RXESd6b5ToNrYe9M/art.json | 14 +++++++++++++- art/7TrYkuK4aHzLqvZ7r/art.json | 14 +++++++++++++- art/7W6jf6wm4is8A9o9z/art.json | 14 +++++++++++++- art/7WmeTJSdWymq8FHDN/art.json | 14 +++++++++++++- art/7Xh2ZeThqMgWodKe8/art.json | 14 +++++++++++++- art/7Xo5cox42KeW3chZj/art.json | 14 +++++++++++++- art/7YSTw2WwEmcGS4hYz/art.json | 14 +++++++++++++- art/7YgXgotM2u7EazE58/art.json | 14 +++++++++++++- art/7YksmRJcwQXipHhfx/art.json | 14 +++++++++++++- art/7YtDi4LTcGHk4Rv7A/art.json | 14 +++++++++++++- art/7ZDFThfCsDDXTyMjG/art.json | 14 +++++++++++++- art/7ZTwrYe7Bq7kSQpPb/art.json | 14 +++++++++++++- art/7avdmuC23kYit8KWs/art.json | 14 +++++++++++++- art/7awCXKJWafHYpvqX8/art.json | 14 +++++++++++++- art/7b2mtzWGfut7qG2b4/art.json | 14 +++++++++++++- art/7ckAr5cRAsKG9pHiF/art.json | 14 +++++++++++++- art/7e3M2Sgrztb9vDD7v/art.json | 14 +++++++++++++- art/7eMqSiQ49pzgf7ftE/art.json | 14 +++++++++++++- art/7egbq6CBdGtm5h3dk/art.json | 14 +++++++++++++- art/7fkuNErcdiCoyDFPM/art.json | 14 +++++++++++++- art/7gmHgFYYTRjd3BKEZ/art.json | 14 +++++++++++++- art/7gpAmyAsHMewhZvsN/art.json | 14 +++++++++++++- art/7iyrHWLQT836AWhNg/art.json | 14 +++++++++++++- art/7kchjNSNHczMuXxdj/art.json | 14 +++++++++++++- art/7mLMCX66sxy38mtQZ/art.json | 14 +++++++++++++- art/7myySepW36ywzREow/art.json | 14 +++++++++++++- art/7n2c7BGhSAcg3jA94/art.json | 14 +++++++++++++- art/7nEqpyeYSLJxH3iCZ/art.json | 14 +++++++++++++- art/7pH6w9DYZF7bjFqRC/art.json | 14 +++++++++++++- art/7qXRty5XaAiets5ZL/art.json | 14 +++++++++++++- art/7qtbHrwZAwuFQLxhC/art.json | 14 +++++++++++++- art/7rEgrhT8EQfJ7PDrk/art.json | 14 +++++++++++++- art/7ryyxQd8kXyENxC8q/art.json | 14 +++++++++++++- art/7t6i2kotFzww4sABc/art.json | 14 +++++++++++++- art/7tj2CshkciWxyNNjh/art.json | 14 +++++++++++++- art/7ts7RJwsC7qRdn96W/art.json | 14 +++++++++++++- art/7vbkgbBXwtnj4LbT2/art.json | 14 +++++++++++++- art/7vsaPEdRhNyw6hBKg/art.json | 14 +++++++++++++- art/7wRhp7wraGfXgSkus/art.json | 14 +++++++++++++- art/7wqyFQDCq6cmDzs4H/art.json | 14 +++++++++++++- art/7wueifQeGTg9ubjrp/art.json | 14 +++++++++++++- art/7xeGPqZaZSLDvKWHt/art.json | 14 +++++++++++++- art/83bhi2jnJmLwj89jd/art.json | 14 +++++++++++++- art/84TzMFEGdJQDyrLAw/art.json | 14 +++++++++++++- art/84bqgyYH7r222NZui/art.json | 14 +++++++++++++- art/85e3bGEKFA4Ac7pHh/art.json | 14 +++++++++++++- art/85epXhdc6bNGzc5t4/art.json | 14 +++++++++++++- art/868s25nyWdZFHjukZ/art.json | 14 +++++++++++++- art/87jiR2yJj3v4JHQGX/art.json | 14 +++++++++++++- art/889PvtXA2o7P9ps9Y/art.json | 14 +++++++++++++- art/88BoabSogh4PJQ5XD/art.json | 14 +++++++++++++- art/88XwsAMToJSkDiwaB/art.json | 14 +++++++++++++- art/899AdR5X9eCCv2RAT/art.json | 14 +++++++++++++- art/89PHWvc6bSoMDB4uq/art.json | 14 +++++++++++++- art/8AQFD78CWiZsN4phd/art.json | 14 +++++++++++++- art/8EW4w374gLe9Y8mvS/art.json | 14 +++++++++++++- art/8Ha5WpefzTXhF4Cmr/art.json | 14 +++++++++++++- art/8JCNkReuE5hLqBoNT/art.json | 14 +++++++++++++- art/8LsJgzRWQxy2bJWwJ/art.json | 14 +++++++++++++- art/8MHgqJdpnFiQGkBc2/art.json | 14 +++++++++++++- art/8MRZuPQnb7riyBLat/art.json | 14 +++++++++++++- art/8MxcbeeakhH3Zvjvm/art.json | 14 +++++++++++++- art/8QyjKkpp7q9aGkAn7/art.json | 14 +++++++++++++- art/8Rju8wrtd7ggyiDcZ/art.json | 14 +++++++++++++- art/8SDc8sAwSzpo7GLBM/art.json | 14 +++++++++++++- art/8T4bhdbFF8NqLZ5qJ/art.json | 14 +++++++++++++- art/8TsxtdLjke5zy5qJu/art.json | 14 +++++++++++++- art/8Tuytbjq9XfyxyLSA/art.json | 14 +++++++++++++- art/8Typ5eK6bCd5ziWFf/art.json | 14 +++++++++++++- art/8WsNgnnMn6z7f46sb/art.json | 14 +++++++++++++- art/8XECwReKrWfyzzRsj/art.json | 14 +++++++++++++- art/8YgL5b9rsGLmaeQ9Z/art.json | 14 +++++++++++++- art/8ZyPwCk5HdengqpJK/art.json | 14 +++++++++++++- art/8ZzuRWYAZeNEN3L4m/art.json | 14 +++++++++++++- art/8aEFjza4wNjuhfnvP/art.json | 14 +++++++++++++- art/8bRYb7JjNeomjyGHy/art.json | 14 +++++++++++++- art/8cPTCz9Cm8iRKNmqG/art.json | 14 +++++++++++++- art/8eDsJnksnjrECXGev/art.json | 14 +++++++++++++- art/8eaHZkbv4GqCvTJJs/art.json | 14 +++++++++++++- art/8gvY7dX9pPW8v6jDG/art.json | 14 +++++++++++++- art/8hCgzechTSmvoP4ah/art.json | 14 +++++++++++++- art/8hLNA2ArwHi8mdNZq/art.json | 14 +++++++++++++- art/8ifzGvPttfmfGyATy/art.json | 14 +++++++++++++- art/8jcBYJRBWjDcfHKkH/art.json | 14 +++++++++++++- art/8jiF9r8CqR46bXvXM/art.json | 14 +++++++++++++- art/8miH3KmYkczS5YbjP/art.json | 14 +++++++++++++- art/8oGoGrmBCLx2R4iWz/art.json | 14 +++++++++++++- art/8oJh9QtFGgJksSFFk/art.json | 14 +++++++++++++- art/8qkLM6jJv2xHNnELZ/art.json | 14 +++++++++++++- art/8rEyCeYdp5FF6AwKL/art.json | 14 +++++++++++++- art/8rLJCnxAbmAYifi8S/art.json | 14 +++++++++++++- art/8wMcYNHAvNH4qdgzM/art.json | 14 +++++++++++++- art/8wij3k6mQCLMeYsgw/art.json | 14 +++++++++++++- art/8xXukzezXszWuCGEN/art.json | 14 +++++++++++++- art/8xnYpsyL4ENdb24gk/art.json | 14 +++++++++++++- art/93FoywQqcRMeZNRcz/art.json | 14 +++++++++++++- art/93Y6qkZ7f2SBfAPjM/art.json | 14 +++++++++++++- art/948aadGavoEeSXCac/art.json | 14 +++++++++++++- art/94LjZTzQhciudirXa/art.json | 14 +++++++++++++- art/94o6yb7AZ7dW5Lumb/art.json | 14 +++++++++++++- art/95ZMaZireKi2qhi6L/art.json | 14 +++++++++++++- art/95xHq5YQNNvTEjhsq/art.json | 14 +++++++++++++- art/965mBDin8f5mMFKoZ/art.json | 14 +++++++++++++- art/96HGeYvvkbpZDtRSu/art.json | 14 +++++++++++++- art/97XDDQ5yWEzZhs6cH/art.json | 14 +++++++++++++- art/97zwjZPbGFqPWiYZy/art.json | 14 +++++++++++++- art/97zwxhJNAYAGKPST2/art.json | 14 +++++++++++++- art/982xbF946ivNRShYF/art.json | 14 +++++++++++++- art/98PzHFry4xqmuj7qt/art.json | 14 +++++++++++++- art/99zvCpii8eiTj2fo8/art.json | 14 +++++++++++++- art/9BDdcbJh6rDaD4MBi/art.json | 14 +++++++++++++- art/9C352QniqBDGreXm2/art.json | 14 +++++++++++++- art/9CuFBCB2ddb7NzNRQ/art.json | 14 +++++++++++++- art/9DkMjvaQEsZt6yz86/art.json | 14 +++++++++++++- art/9EJbRaRyPZMpJ9zLk/art.json | 14 +++++++++++++- art/9FnEPTtPhMxdktE4t/art.json | 14 +++++++++++++- art/9GCFDmZiEXGbgKMny/art.json | 14 +++++++++++++- art/9Geyfsezar7Y45X4W/art.json | 14 +++++++++++++- art/9GqsA2ooryruyLSRG/art.json | 14 +++++++++++++- art/9HqeuYzYy5SPwWWzC/art.json | 14 +++++++++++++- art/9JiSBh95g2uDrbJF8/art.json | 14 +++++++++++++- art/9K6tGbtzRXNPPboM5/art.json | 14 +++++++++++++- art/9L4TTn35TGvpgnmg9/art.json | 14 +++++++++++++- art/9LWMct8y82GY9ojKB/art.json | 14 +++++++++++++- art/9LoJ64iLFmQukm5ha/art.json | 14 +++++++++++++- art/9MHkQW36H4sMgEA4e/art.json | 14 +++++++++++++- art/9P4cTdzoK9rwM99kJ/art.json | 14 +++++++++++++- art/9QBfBKazwRDgwzka8/art.json | 14 +++++++++++++- art/9SEaxhmGgtFCn7tXv/art.json | 14 +++++++++++++- art/9Sr9XKEznvoJprDjG/art.json | 14 +++++++++++++- art/9WvFeBhi2eCqodeBQ/art.json | 14 +++++++++++++- art/9Xu5ntQQuktXprwnJ/art.json | 14 +++++++++++++- art/9Yfm7z3uHjctZkyLW/art.json | 14 +++++++++++++- art/9Z8QK2wm2wyThYCTm/art.json | 14 +++++++++++++- art/9adCiEobmkAuj8Gue/art.json | 14 +++++++++++++- art/9auTJQc3nHbaStwyQ/art.json | 14 +++++++++++++- art/9caDdikyJ7k4Q3o2L/art.json | 14 +++++++++++++- art/9dSN7fhb4hT8SrRor/art.json | 14 +++++++++++++- art/9fTeRNSKFtEMd9oAM/art.json | 14 +++++++++++++- art/9fwAKTiyAB7xx9cqz/art.json | 14 +++++++++++++- art/9gAztzKnjeJ3GyrqF/art.json | 14 +++++++++++++- art/9hzmisGQfvWW54XX2/art.json | 14 +++++++++++++- art/9ikkGGKbk6D4k8eRa/art.json | 14 +++++++++++++- art/9j4xGCXLcJQLP9zX2/art.json | 14 +++++++++++++- art/9mHLiL9t8Tdhkt2Nh/art.json | 14 +++++++++++++- art/9mqwFjEipb8pPtcPw/art.json | 14 +++++++++++++- art/9oFBPGkXY6hB2TaHK/art.json | 14 +++++++++++++- art/9s4f49dwx4L8hbbD5/art.json | 14 +++++++++++++- art/9tQdLKqdczvbu3Pp5/art.json | 14 +++++++++++++- art/9tYkByMY9xHJQLM8M/art.json | 14 +++++++++++++- art/9wKMAeACxZ3WoJc2m/art.json | 14 +++++++++++++- art/9xQqPx9YtLs7Zddzb/art.json | 14 +++++++++++++- art/9ydRokp8vXNSApmsq/art.json | 14 +++++++++++++- art/9yoBtz2q3YvMZHhw6/art.json | 14 +++++++++++++- art/9ythNthyPP2w9WbgY/art.json | 14 +++++++++++++- art/9yyh6FdtyTqLN2EgE/art.json | 14 +++++++++++++- art/A4aQeDP9zYwLTXGKd/art.json | 14 +++++++++++++- art/A5Eknh4sb38Hw5pjv/art.json | 14 +++++++++++++- art/A5wHpLQiQydYkB7sg/art.json | 14 +++++++++++++- art/A6KXiR6FwZEbN6Nh5/art.json | 14 +++++++++++++- art/A6iuFb7Tmao4i5avw/art.json | 14 +++++++++++++- art/A8L4hRRwF6WbC5Jxb/art.json | 14 +++++++++++++- art/A8Zc7NFQdTdeKQimv/art.json | 14 +++++++++++++- art/A9DLn3oYKaSRGEPt4/art.json | 14 +++++++++++++- art/A9X62RRorFW5Ys8h7/art.json | 14 +++++++++++++- art/AA2EgkaRKHJ5g74i5/art.json | 14 +++++++++++++- art/ABszkWtBmfrqcHecz/art.json | 14 +++++++++++++- art/AC57qxXZiP5Xt3MPo/art.json | 14 +++++++++++++- art/AGytkw7djFKBPNKZE/art.json | 14 +++++++++++++- art/AHgb5kGbLwEYQjRTn/art.json | 14 +++++++++++++- art/AJ3iLGfbPGRTnZZn6/art.json | 14 +++++++++++++- art/AK7yLDZv8JXbgW25h/art.json | 14 +++++++++++++- art/ALErfYvkmdWzuqg7M/art.json | 14 +++++++++++++- art/AMJYWSdCtDDTehM3C/art.json | 14 +++++++++++++- art/ARpkYYdzGDtKL4BZn/art.json | 14 +++++++++++++- art/ASwcBa7AR4rPpF2Wg/art.json | 14 +++++++++++++- art/AXAuvTYrFKQwTgykw/art.json | 14 +++++++++++++- art/AXjMauM4Aq37fkzLf/art.json | 14 +++++++++++++- art/AZ2KyvbW28MmPCFKA/art.json | 14 +++++++++++++- art/AZFnk3yzLiSZ2KkWS/art.json | 14 +++++++++++++- art/AZS5NEiv5XCb7HrRy/art.json | 14 +++++++++++++- art/Acb8NGnF3tJvv77Ji/art.json | 14 +++++++++++++- art/Ajiknj6GiHKrmZT3Z/art.json | 14 +++++++++++++- art/AnFAYAbcbpuErBvBW/art.json | 14 +++++++++++++- art/AndijhSm4Fuox73p9/art.json | 14 +++++++++++++- art/Ar3JvNPvHx9gCAXTC/art.json | 14 +++++++++++++- art/Av2MKnW2EJCyL2soB/art.json | 14 +++++++++++++- art/Axy2s5b2qtEdfhrhP/art.json | 14 +++++++++++++- art/B2Xb9dHRi7bYyQfjA/art.json | 14 +++++++++++++- art/B3MrHFwyLFjSx8mo4/art.json | 14 +++++++++++++- art/B3fTWQihXfD9t8Q8r/art.json | 14 +++++++++++++- art/B42Ho7bLcyCakLyrD/art.json | 14 +++++++++++++- art/B4Eq6Qa7NTqRG2h7n/art.json | 14 +++++++++++++- art/B5PGbeNcqjZkjn87u/art.json | 14 +++++++++++++- art/B6DFsE8BsdxjmQSeD/art.json | 14 +++++++++++++- art/B6cRz9JjErEA57pG4/art.json | 14 +++++++++++++- art/B6hCMdEJpbdKbEpYp/art.json | 14 +++++++++++++- art/B7XSdPJnstpQRHwMt/art.json | 14 +++++++++++++- art/B8dK4DjfS4gxQ2D6x/art.json | 14 +++++++++++++- art/B9wG9rDf7i77ZyAbL/art.json | 14 +++++++++++++- art/BCqiiXBgBXYHTqw6G/art.json | 14 +++++++++++++- art/BEskWFZM826YNBJAN/art.json | 14 +++++++++++++- art/BGupQRTNK2asdNESp/art.json | 14 +++++++++++++- art/BJohDPg4F2NmwfsEC/art.json | 14 +++++++++++++- art/BKz7wnibraTYy2v8H/art.json | 14 +++++++++++++- art/BLAH5H2ctKjDqzabc/art.json | 14 +++++++++++++- art/BLDrqiy2zPooeqXyA/art.json | 14 +++++++++++++- art/BM7xSvMgutERFmdBd/art.json | 14 +++++++++++++- art/BN8A2f8DcC5htsq6T/art.json | 14 +++++++++++++- art/BQfE2RPMyeRH9tMQn/art.json | 14 +++++++++++++- art/BQuWCvhCBBif7Zzmh/art.json | 14 +++++++++++++- art/BQz5ngcrNuq9dcBHP/art.json | 14 +++++++++++++- art/BRW6CMT6qxyD5Qxs3/art.json | 14 +++++++++++++- art/BSig2nJzr4kavRSF2/art.json | 14 +++++++++++++- art/BTbTTkxMnk4AfcjGJ/art.json | 14 +++++++++++++- art/BWsfEAmCvR9m9NTF8/art.json | 14 +++++++++++++- art/BXfAoqsFbSNtWvJaQ/art.json | 14 +++++++++++++- art/BZMNQR7kcPSCCwyHL/art.json | 14 +++++++++++++- art/BZdvckJFNr53H6kXS/art.json | 14 +++++++++++++- art/BbBW5veDzWe2oqN7F/art.json | 14 +++++++++++++- art/Be7qcEqHTfnXmi3nw/art.json | 14 +++++++++++++- art/BeRGRuNpszfDv7foC/art.json | 14 +++++++++++++- art/BfGdpEhnBZQzXay29/art.json | 14 +++++++++++++- art/BgAawjJRKx45XRyiN/art.json | 14 +++++++++++++- art/BiHH2xPx5dypCCvAu/art.json | 14 +++++++++++++- art/BjFJQPygCx8PB83nv/art.json | 14 +++++++++++++- art/BjmCAYg9AYobxtkG4/art.json | 14 +++++++++++++- art/BkSDKkzkjxLJgHecj/art.json | 14 +++++++++++++- art/BkeSrSoFbRiSfkoBm/art.json | 14 +++++++++++++- art/BkqeZ9ZW84C5tPdoJ/art.json | 14 +++++++++++++- art/BnKrvieHdWaxfjXH8/art.json | 14 +++++++++++++- art/BnhvgAERQC5rcGRoZ/art.json | 14 +++++++++++++- art/BqGPcmKoSdsC4MnLb/art.json | 14 +++++++++++++- art/Br7jzCr5r8jf4kHyx/art.json | 14 +++++++++++++- art/BrGxYaWHdj7D4XZyf/art.json | 14 +++++++++++++- art/BroTxCqjuvDoLEhAY/art.json | 14 +++++++++++++- art/BsMpnBk6kQ8wK8mvy/art.json | 14 +++++++++++++- art/BsrLb5e2Fujc6RvJf/art.json | 14 +++++++++++++- art/Bt5C5fTXArXh3hvqh/art.json | 14 +++++++++++++- art/BtAqcPquWmxhDALFW/art.json | 14 +++++++++++++- art/BtMPmXiuE37mpnQB7/art.json | 14 +++++++++++++- art/BtkrDbo3o9cSAoXeW/art.json | 14 +++++++++++++- art/BtpY4aK6a7rEquy7n/art.json | 14 +++++++++++++- art/BubiakjZKAd7TKT83/art.json | 14 +++++++++++++- art/BuxMxn3MPkCW7BFbc/art.json | 14 +++++++++++++- art/Bv7nLsmSbowtSoGpA/art.json | 14 +++++++++++++- art/BvPCLikPbdwxzJQS2/art.json | 14 +++++++++++++- art/BwFoiT5wD28u9HN5Z/art.json | 14 +++++++++++++- art/BxMWaxP7Sqiz38FgK/art.json | 14 +++++++++++++- art/BxXCFpZxu7eFdhiyP/art.json | 14 +++++++++++++- art/BzwXBknYWjs4nfk9h/art.json | 14 +++++++++++++- art/C27MRCLnDuKJk9TrS/art.json | 14 +++++++++++++- art/C2Kzd3CnpNPtWHjRw/art.json | 14 +++++++++++++- art/C2qmkuPNQvcyp6CGP/art.json | 14 +++++++++++++- art/C4gCacp8eQ337rdFD/art.json | 14 +++++++++++++- art/C549fio274zzAoidn/art.json | 14 +++++++++++++- art/C5XnDd3TxCtHq52Jv/art.json | 14 +++++++++++++- art/C9maC3C6dCdyKmsuH/art.json | 14 +++++++++++++- art/C9riFtXRKgMEZyY7p/art.json | 14 +++++++++++++- art/C9sbwtGje9tjnk7ed/art.json | 14 +++++++++++++- art/CBDvmeprw78fMTgQ4/art.json | 14 +++++++++++++- art/CERRMSf3KtHWagAFx/art.json | 14 +++++++++++++- art/CEmfhvYaGBEGw4vRT/art.json | 14 +++++++++++++- art/CFqwmitinDNdXPsCF/art.json | 14 +++++++++++++- art/CGefenfT6rv2yQ4Bw/art.json | 14 +++++++++++++- art/CHDRiwf7FFqgP2REr/art.json | 14 +++++++++++++- art/CJqnsPPKxz3KGqWSZ/art.json | 14 +++++++++++++- art/CJyTYWu2F352dNTrn/art.json | 14 +++++++++++++- art/CQcbw4k7BmY3egppx/art.json | 14 +++++++++++++- art/CQs9owSvkdHXMQDA8/art.json | 14 +++++++++++++- art/CS58jctRLd3zEqnaB/art.json | 14 +++++++++++++- art/CSXazpyPp2B7cScfa/art.json | 14 +++++++++++++- art/CTgYQer69jnHTKudH/art.json | 14 +++++++++++++- art/CTkvnfE6NaaXSPzzJ/art.json | 14 +++++++++++++- art/CTzsP7M5MfkwZGXy2/art.json | 14 +++++++++++++- art/CXBRMQmfvMpA4bK9H/art.json | 14 +++++++++++++- art/CaPmeZQJn7C9sdRZw/art.json | 14 +++++++++++++- art/CbSdtkRA5gDx7hmXd/art.json | 14 +++++++++++++- art/CbmGerHritwgbEFvY/art.json | 14 +++++++++++++- art/Cc5rgXprLDzaGgDGt/art.json | 14 +++++++++++++- art/Ce87kL3i6r98HePhT/art.json | 14 +++++++++++++- art/CfHhvkT7qoHXgLNx6/art.json | 14 +++++++++++++- art/CfMMZRNPMyGdmeLFX/art.json | 14 +++++++++++++- art/CfPegKAcPj5D6axAW/art.json | 14 +++++++++++++- art/CgmFpc7tyuEKBCKdm/art.json | 14 +++++++++++++- art/Ch3PxmZwN22dkrGCg/art.json | 14 +++++++++++++- art/ChgRzRLbrFD5wzfZk/art.json | 14 +++++++++++++- art/CiTmPsWuiBPzTRgDn/art.json | 14 +++++++++++++- art/Cj2C3bSnE4yoFBfHp/art.json | 14 +++++++++++++- art/CmMYvqXdiTuxgBZZT/art.json | 14 +++++++++++++- art/Cn2Pn9cEKGgg9ZkC5/art.json | 14 +++++++++++++- art/CnETJJi9SW7LPRebg/art.json | 14 +++++++++++++- art/CnGnHHGBHNdY2ZAbG/art.json | 14 +++++++++++++- art/Cou2fm28Bk2J2vbgy/art.json | 14 +++++++++++++- art/CqxWREeQWkFuAtK5d/art.json | 14 +++++++++++++- art/CsHf78qYSxbxGPwhv/art.json | 14 +++++++++++++- art/Csow3AwA4u2Zotovs/art.json | 14 +++++++++++++- art/CtXSFrywWri4egF7m/art.json | 14 +++++++++++++- art/CvsqyaFZq3hPtywor/art.json | 14 +++++++++++++- art/CxkapDDzkpTBvHykF/art.json | 14 +++++++++++++- art/CzKeby46tDXxFsGzL/art.json | 14 +++++++++++++- art/CzzSa7bQ9iZ5f9hNx/art.json | 14 +++++++++++++- art/D2qJoBWBE7X8yWh5D/art.json | 14 +++++++++++++- art/D3DaiYq4ggr7qZEhu/art.json | 14 +++++++++++++- art/D3LC8ea768bS5NfQY/art.json | 14 +++++++++++++- art/D4KsKHDFES8P7NEBc/art.json | 14 +++++++++++++- art/D5f5NhSGgh7gLgnm3/art.json | 14 +++++++++++++- art/D7Qe36Z7PfM2fS6Jg/art.json | 14 +++++++++++++- art/DAbuH7yJ5d3GwDGhw/art.json | 14 +++++++++++++- art/DBf3fehEcDfdz3dT7/art.json | 14 +++++++++++++- art/DCY4ddBCsphoYLARH/art.json | 14 +++++++++++++- art/DCrDjahDxMww73hcZ/art.json | 14 +++++++++++++- art/DCw9SWkLWEFvfGwdW/art.json | 14 +++++++++++++- art/DJE9Th5DjSN3Rhqcw/art.json | 14 +++++++++++++- art/DMsF68oEXEH2wGgAT/art.json | 14 +++++++++++++- art/DMttCm8HavohPe6RY/art.json | 14 +++++++++++++- art/DNj4nZ8MZnj5JZFt2/art.json | 14 +++++++++++++- art/DP7wFzXhDCPCpGfuF/art.json | 14 +++++++++++++- art/DPnrgr43T2RcprHMh/art.json | 14 +++++++++++++- art/DPyrvZcaDSQBadMfb/art.json | 14 +++++++++++++- art/DQtN9os6r9QqLMWeq/art.json | 14 +++++++++++++- art/DRYszuLsxNkzcz9SW/art.json | 14 +++++++++++++- art/DRbySCBiHXiG6DyNE/art.json | 14 +++++++++++++- art/DRvinsX4dNgHKSnSm/art.json | 14 +++++++++++++- art/DS8Yfx4noREuQ6YKi/art.json | 14 +++++++++++++- art/DSH7PskktA2rGgZ6F/art.json | 14 +++++++++++++- art/DSjZ92TYBwkdfi8db/art.json | 14 +++++++++++++- art/DTZTZdm35YfaxuP7k/art.json | 14 +++++++++++++- art/DWwhcFd3xWKC5yjiW/art.json | 14 +++++++++++++- art/DYWEJu3J6uupTuopS/art.json | 14 +++++++++++++- art/DaKrDq99EtHod6jAe/art.json | 14 +++++++++++++- art/DaM7frg7uQNDe7mK2/art.json | 14 +++++++++++++- art/DaN8tYyqjWyHdm6jd/art.json | 14 +++++++++++++- art/DagQjjsyoq4ygNS4K/art.json | 14 +++++++++++++- art/Dbuz4RR9kb9tav5ty/art.json | 14 +++++++++++++- art/DhAP5qwkiBv5JbSuR/art.json | 14 +++++++++++++- art/DiGpLPYqRW3DAtnFc/art.json | 14 +++++++++++++- art/Dj9AtcEn2SdwdS3Y2/art.json | 14 +++++++++++++- art/DjWJQf8DFiu4EnvvZ/art.json | 14 +++++++++++++- art/DkQkxp558QrXdoDTs/art.json | 14 +++++++++++++- art/DoEj3wxxxKrDkxKrZ/art.json | 14 +++++++++++++- art/DpHdSTbEXuhA4ZhTJ/art.json | 14 +++++++++++++- art/DsvE4S4dECyiP9akX/art.json | 14 +++++++++++++- art/DtkxEHAy7rFi4TCjx/art.json | 14 +++++++++++++- art/DvSoWkCTBkqg9aKyY/art.json | 14 +++++++++++++- art/DwqqEvCDpZA7dj9qu/art.json | 14 +++++++++++++- art/DySYKJCWwydRwAsMo/art.json | 14 +++++++++++++- art/DypzytbA2gKkPjKXM/art.json | 14 +++++++++++++- art/DyvcR8jSTEBXSm6J7/art.json | 14 +++++++++++++- art/DznDc4cHyA4yEMyz8/art.json | 14 +++++++++++++- art/Dzq7Xbo9hsf8fwr58/art.json | 14 +++++++++++++- art/E35W32ThAopNcnH4G/art.json | 14 +++++++++++++- art/E3bguY87geHgSFKBW/art.json | 14 +++++++++++++- art/E77bqBL3BGzWQsqBw/art.json | 14 +++++++++++++- art/E7ACzG2zArFipenu9/art.json | 14 +++++++++++++- art/E8jpSws9ybhazxoiu/art.json | 14 +++++++++++++- art/E9ATxH3KR6gczc39H/art.json | 14 +++++++++++++- art/ECyeESjJEpGZwP69a/art.json | 14 +++++++++++++- art/EDJJ9esPSEo3LRLmb/art.json | 14 +++++++++++++- art/EF4WxFMCR2GvFYvTB/art.json | 14 +++++++++++++- art/EFCx8Coh8CuLXJXue/art.json | 14 +++++++++++++- art/EFDPXE3qAdfaPgMT3/art.json | 14 +++++++++++++- art/EFczFa8BRmNtBibqB/art.json | 14 +++++++++++++- art/EG3pbFeZPLiS72ia5/art.json | 14 +++++++++++++- art/EGh5YgqAykhgd7zoM/art.json | 14 +++++++++++++- art/EJEPgF3KWdF9Bysia/art.json | 14 +++++++++++++- art/ENh2Lxp6QPPaotJzF/art.json | 14 +++++++++++++- art/EPyk9Ehrx6dGCJsDY/art.json | 14 +++++++++++++- art/EWTJuKrqGXLji3GwW/art.json | 14 +++++++++++++- art/EXKWEFXxnr6e7Bjch/art.json | 14 +++++++++++++- art/EZG3qh8pDqtEo39W2/art.json | 14 +++++++++++++- art/EZmjdzfcpwjp7MSFM/art.json | 14 +++++++++++++- art/EZzESxRYabyXKSxqw/art.json | 14 +++++++++++++- art/Eb8KT9CKPyKMXSF7L/art.json | 14 +++++++++++++- art/EbKX65r26sjm5sY7t/art.json | 14 +++++++++++++- art/Ec8Lpab7csKeguMAy/art.json | 14 +++++++++++++- art/EdvEpRyeJaKAyAk7K/art.json | 14 +++++++++++++- art/EfjfmMvDH5P2mY3xa/art.json | 14 +++++++++++++- art/EgLk7JDok4GhxPeMH/art.json | 14 +++++++++++++- art/EgwgPafyaLHWPDw2T/art.json | 14 +++++++++++++- art/EhoHuSv6ou8bp9o66/art.json | 14 +++++++++++++- art/EjE5NRrJcWgx7nqze/art.json | 14 +++++++++++++- art/EjqDk64Ezh9aZ2oXN/art.json | 14 +++++++++++++- art/Ekj2CXtjX5YZc76Lk/art.json | 14 +++++++++++++- art/Ekz3YzPYcEQyhT2z7/art.json | 14 +++++++++++++- art/Emf9HTtBkjpcSmC3a/art.json | 14 +++++++++++++- art/Epmt3yx3xHdhspZxB/art.json | 14 +++++++++++++- art/Er8p4bB3vqTs4694p/art.json | 14 +++++++++++++- art/EtY77PNcjnaQtphnu/art.json | 14 +++++++++++++- art/EtZAgACkH5HwhRTKb/art.json | 14 +++++++++++++- art/EwiWN8pkXdNqqJ7tq/art.json | 14 +++++++++++++- art/Ewq6xoiNuJyRhdSo5/art.json | 14 +++++++++++++- art/Ex4L4mExH2paBQBj5/art.json | 14 +++++++++++++- art/F3kKjy86maMCacENb/art.json | 14 +++++++++++++- art/F4CnAXam3PniXCQjt/art.json | 14 +++++++++++++- art/F5nWdazPW5bXmip32/art.json | 14 +++++++++++++- art/F6MddBx2WQCrGct9a/art.json | 14 +++++++++++++- art/F88Ekndwj4ihuRGmt/art.json | 14 +++++++++++++- art/FAi4yHCJC2jr4B4Mj/art.json | 14 +++++++++++++- art/FAsmmhzQ9syJzXwzR/art.json | 14 +++++++++++++- art/FBZkegcALhNaPJL6W/art.json | 14 +++++++++++++- art/FD5KhRKjCLtaEQWHM/art.json | 14 +++++++++++++- art/FDYmXj7L2c7PJjTwe/art.json | 14 +++++++++++++- art/FDoMDz4QxPmpEY7FJ/art.json | 14 +++++++++++++- art/FDqpoXetoxdNjtLYb/art.json | 14 +++++++++++++- art/FEETng4czKpcp3kDg/art.json | 14 +++++++++++++- art/FEuQEawn8qHXvXTbY/art.json | 14 +++++++++++++- art/FF4Q7tpyaSLjicasS/art.json | 14 +++++++++++++- art/FGbfRShZBrEzgsq9v/art.json | 14 +++++++++++++- art/FJRdnZn9mERmk9Yaz/art.json | 14 +++++++++++++- art/FKW2yC28uaYuXntoz/art.json | 14 +++++++++++++- art/FMpo6tgK5xszx7CuS/art.json | 14 +++++++++++++- art/FMq3vpaDGsoEMC7e9/art.json | 14 +++++++++++++- art/FMuoFaTjjywnD7fJm/art.json | 14 +++++++++++++- art/FNFsfgYT3ysjSme2P/art.json | 14 +++++++++++++- art/FNwMYwJ2SdwbbSNAN/art.json | 14 +++++++++++++- art/FPFBuCexgLQpriEoS/art.json | 14 +++++++++++++- art/FWWNQRxd2LXsvsxj5/art.json | 14 +++++++++++++- art/Fc6iHGcLDEtSTqbNG/art.json | 14 +++++++++++++- art/Fc9c7BdBMHwtZfBd4/art.json | 14 +++++++++++++- art/FdyK8FcKsuCHmdq9D/art.json | 14 +++++++++++++- art/FebsjBDDpXSkBLMfb/art.json | 14 +++++++++++++- art/FfHLpZyMW5rXY9aD5/art.json | 14 +++++++++++++- art/FfZFDLCNW6cb8pxEg/art.json | 14 +++++++++++++- art/Ffs2irmibSP7oFuTu/art.json | 14 +++++++++++++- art/FipmX7SNkZ3TqAY5p/art.json | 14 +++++++++++++- art/FjA6DbEL9qbenj778/art.json | 14 +++++++++++++- art/FkZcSiHXEHreJBCH9/art.json | 14 +++++++++++++- art/Fkoesg8YQ6JMJPRDj/art.json | 14 +++++++++++++- art/FomjPf4hmRGox2dnF/art.json | 14 +++++++++++++- art/FozLSgACn56r8QXk5/art.json | 14 +++++++++++++- art/Fpbwg9tJSGnDtFPom/art.json | 14 +++++++++++++- art/FpeWqKvfuhWuYhfuT/art.json | 14 +++++++++++++- art/FqNcEyWQSSAnHAtMY/art.json | 14 +++++++++++++- art/FqSZrJ7rAfB3savC5/art.json | 14 +++++++++++++- art/FsHtLXJDGt87mpMLt/art.json | 14 +++++++++++++- art/FsdFwLEhLHY2TyemA/art.json | 14 +++++++++++++- art/FtWQZjoHxqMK8dS5s/art.json | 14 +++++++++++++- art/FuHqi38wkbaQc4shv/art.json | 14 +++++++++++++- art/FuT3HckGWwv5PxkNP/art.json | 14 +++++++++++++- art/FucZXqgfuHN6wAZop/art.json | 14 +++++++++++++- art/FufiW6ZAC4tzCrSqe/art.json | 14 +++++++++++++- art/FvWzPMiZrdqtgEJHY/art.json | 14 +++++++++++++- art/Fx9jpEFb8X6WPRBT9/art.json | 14 +++++++++++++- art/FxDGfLNG4kMa6DAGa/art.json | 14 +++++++++++++- art/G2qYBmuQs2cA7C4ze/art.json | 14 +++++++++++++- art/G3infoeL8fLc5SiDQ/art.json | 14 +++++++++++++- art/G3kr88RT488uLRBzW/art.json | 14 +++++++++++++- art/G44HeacsoBQDo4MFC/art.json | 14 +++++++++++++- art/G52W2EuQGvzn2m9mT/art.json | 14 +++++++++++++- art/G6MPufoeDCrfmHjqf/art.json | 14 +++++++++++++- art/G6uv6rnTuzAgmHniY/art.json | 14 +++++++++++++- art/G75PEGQA9JzRQKx4s/art.json | 14 +++++++++++++- art/G86ZR9sbc4BB8uW3m/art.json | 14 +++++++++++++- art/GA5AfMNsPaGpaCd7b/art.json | 14 +++++++++++++- art/GBQRjtz2FMC4RcMvC/art.json | 14 +++++++++++++- art/GCHbAzpPAFHCXStCn/art.json | 14 +++++++++++++- art/GDZH8bzPmGJZX56xN/art.json | 14 +++++++++++++- art/GDrWuySq3yExsoNqR/art.json | 14 +++++++++++++- art/GDwqy5yjHyevhi2rK/art.json | 14 +++++++++++++- art/GEtBB56A9P7F4wjdG/art.json | 14 +++++++++++++- art/GG222nK5QwLhaPBqp/art.json | 14 +++++++++++++- art/GKbc4tXKXpku2WT84/art.json | 14 +++++++++++++- art/GKjSeb4FbAngScBTm/art.json | 14 +++++++++++++- art/GMo8BydtF9nZHuqcM/art.json | 14 +++++++++++++- art/GNxuZLXb85Px27uwd/art.json | 14 +++++++++++++- art/GNybZ7r6mDiCQNAfW/art.json | 14 +++++++++++++- art/GPneC8Rz7k8CDKL6i/art.json | 14 +++++++++++++- art/GRZbiaYQ5RXxaKsSA/art.json | 14 +++++++++++++- art/GRmubu72jMXJivdL4/art.json | 14 +++++++++++++- art/GRxBfbR6hkmf9Q3Am/art.json | 14 +++++++++++++- art/GSwqjg58RKKvcPvhZ/art.json | 14 +++++++++++++- art/GSxj99d7zTTT52ZzF/art.json | 14 +++++++++++++- art/GY6bT7gTsHXRvMshg/art.json | 14 +++++++++++++- art/Ga8SGpeNAfnweDCaB/art.json | 14 +++++++++++++- art/GckHF7hRiWi7gJjys/art.json | 14 +++++++++++++- art/GgTexb5kxP7TtFtyP/art.json | 14 +++++++++++++- art/Ghsjg9yjpwFdatBgX/art.json | 14 +++++++++++++- art/GhwS34Ee6m4sZemgY/art.json | 14 +++++++++++++- art/Gi7T5DRKnAnrvCAPp/art.json | 14 +++++++++++++- art/GkEJbHknrmuoDysnp/art.json | 14 +++++++++++++- art/GobkkbXq2nNFAHBdB/art.json | 14 +++++++++++++- art/GoviGkHcqKYCZeJKp/art.json | 14 +++++++++++++- art/Guf53TWBqY43SzNeS/art.json | 14 +++++++++++++- art/GvMwNCPsyjoPaL9fj/art.json | 14 +++++++++++++- art/GwLMiSsyX3jZKW52s/art.json | 14 +++++++++++++- art/GxL6CjaGt3wyQZxyL/art.json | 14 +++++++++++++- art/GxbSZ33B9swmxAmdT/art.json | 14 +++++++++++++- art/GzJvTrF4HxvXiNseC/art.json | 14 +++++++++++++- art/GzxrG8cZEcozSK64v/art.json | 14 +++++++++++++- art/H3mC5F9jwNY2cbBHH/art.json | 14 +++++++++++++- art/H43CgK3XcPByECvuk/art.json | 14 +++++++++++++- art/H45bQs2Q9fsMAjnWt/art.json | 14 +++++++++++++- art/H4mnhb75o8M2FZwGZ/art.json | 14 +++++++++++++- art/H56ztSpxnFf2kZGwv/art.json | 14 +++++++++++++- art/H5bhy6dNpHRiJXWds/art.json | 14 +++++++++++++- art/H65kA6jZ79o5qDjXG/art.json | 14 +++++++++++++- art/H88o3mRfNBBZrnZh7/art.json | 14 +++++++++++++- art/HASGvL8w5vDqzrGQk/art.json | 14 +++++++++++++- art/HCYetf4hAQidqDBdG/art.json | 14 +++++++++++++- art/HDvg7tiSomNBAxKwH/art.json | 14 +++++++++++++- art/HFBbsCKy7Ypjr3eRc/art.json | 14 +++++++++++++- art/HFT5yR2hvCfsLXPbM/art.json | 14 +++++++++++++- art/HFcjWasxbbQroZZt3/art.json | 14 +++++++++++++- art/HKJSL9FWrAxtLhmyf/art.json | 14 +++++++++++++- art/HLctHNLy3GzgrxTpT/art.json | 14 +++++++++++++- art/HMFPmKT8ikt4BTqEy/art.json | 14 +++++++++++++- art/HN9a95yqBMftYAsvC/art.json | 14 +++++++++++++- art/HPKXBexwwKqPATRz5/art.json | 14 +++++++++++++- art/HQT56cNoMzCPpomMD/art.json | 14 +++++++++++++- art/HQrHbHySYQAdvmEGG/art.json | 14 +++++++++++++- art/HS9sJXXJGFwxGjoYe/art.json | 14 +++++++++++++- art/HSGSvjGwQyB6cFQMP/art.json | 14 +++++++++++++- art/HW98dGDbChYw2FjpS/art.json | 14 +++++++++++++- art/HWnhBgCbgrivBDfEY/art.json | 14 +++++++++++++- art/HXMkwYLhCJ3DTXojR/art.json | 14 +++++++++++++- art/HXy6XHHyptoZ9ENeS/art.json | 14 +++++++++++++- art/HXzN44Rci8MBYDQYL/art.json | 14 +++++++++++++- art/HYQNJSjDiWBW4zafP/art.json | 14 +++++++++++++- art/HYa4rqvcqkB5bd4T4/art.json | 14 +++++++++++++- art/Hap5jDJiPwQZ9oJx6/art.json | 14 +++++++++++++- art/Hb6JwdFzxmc36PTuP/art.json | 14 +++++++++++++- art/HckFNtc7tQ7Qg22YA/art.json | 14 +++++++++++++- art/HdvpCSWX4Kv64BoSD/art.json | 14 +++++++++++++- art/HeuBWpdtNd6E9KmQk/art.json | 14 +++++++++++++- art/HfPyQZbSJKZKsqjZ6/art.json | 14 +++++++++++++- art/HfQbodpsdXtRDyJar/art.json | 14 +++++++++++++- art/Hg6xE7LkftDQPNqAW/art.json | 14 +++++++++++++- art/HigFydDgNaipM7SBk/art.json | 14 +++++++++++++- art/HoCy3fHXwDNeCoERy/art.json | 14 +++++++++++++- art/HoKSKN5bu2omsjRi7/art.json | 14 +++++++++++++- art/HoXN7xPc28sQKFiCZ/art.json | 14 +++++++++++++- art/HpXGaca48eDSZRtbx/art.json | 14 +++++++++++++- art/HpoPwexZeHvSos9jB/art.json | 14 +++++++++++++- art/HrZdqpnvqmB6gZw6J/art.json | 14 +++++++++++++- art/HsWepANHmBqbdwzSo/art.json | 14 +++++++++++++- art/Hsmfxt55QrbZxDm4d/art.json | 14 +++++++++++++- art/HtBoKeP3qMfWwH4gB/art.json | 14 +++++++++++++- art/HtZXu6SRZeugBajhN/art.json | 14 +++++++++++++- art/Hv927AXio5i8HPs2J/art.json | 14 +++++++++++++- art/HxBJDEFhjvg9CxYdQ/art.json | 14 +++++++++++++- art/HyBREewYeJJq8kxKa/art.json | 14 +++++++++++++- art/HyfsdJ6JLfMhwDRtz/art.json | 14 +++++++++++++- art/HzJkDk2XHyXcxbpik/art.json | 14 +++++++++++++- art/HzfYepRNGKNTsrgjP/art.json | 14 +++++++++++++- art/J2FKQo6uXQ6EykLPi/art.json | 14 +++++++++++++- art/J3PNfiNPbPxziEh3A/art.json | 14 +++++++++++++- art/J3bwBPducoTXfnDLs/art.json | 14 +++++++++++++- art/J4JLEuTrJFshLPKeg/art.json | 14 +++++++++++++- art/J6Rbdqdhvx7Yjdh59/art.json | 14 +++++++++++++- art/JANswiNfyJnruo62E/art.json | 14 +++++++++++++- art/JDeTHnXLqGLsoocEr/art.json | 14 +++++++++++++- art/JERxBfFS5YwaQptZ2/art.json | 14 +++++++++++++- art/JFFRA5wi7Gc3uCDuP/art.json | 14 +++++++++++++- art/JFtfBxTELcg25TGwJ/art.json | 14 +++++++++++++- art/JG27yEiRBewAYsMxB/art.json | 14 +++++++++++++- art/JGGw63pb4BxyXBqyc/art.json | 14 +++++++++++++- art/JGbg2hhv422MBQhyP/art.json | 14 +++++++++++++- art/JJBEEPXrCubMND6ym/art.json | 14 +++++++++++++- art/JJKZvJyWdK4ukftPz/art.json | 14 +++++++++++++- art/JL7KcqFFMw49BvCca/art.json | 14 +++++++++++++- art/JNDG9tsxtQgJzkkCq/art.json | 14 +++++++++++++- art/JRyewraYLfP9taa98/art.json | 14 +++++++++++++- art/JTAL2t63pEXrPKvru/art.json | 14 +++++++++++++- art/JWMAmcwDeMYh8uSZf/art.json | 14 +++++++++++++- art/JWZRdGqNAqvbskDLS/art.json | 14 +++++++++++++- art/JZBqJBXoyFqb5wyB6/art.json | 14 +++++++++++++- art/JZfSq6roYfXYSQTYs/art.json | 14 +++++++++++++- art/JagMqSrHRchzQAMRB/art.json | 14 +++++++++++++- art/JfcfxquJzYFfZJ5cW/art.json | 14 +++++++++++++- art/JhD7Yeh3NstvQbkhJ/art.json | 14 +++++++++++++- art/JhPkQF3eX4q9YcDML/art.json | 14 +++++++++++++- art/JnRaHZcXYv7WBhq5b/art.json | 14 +++++++++++++- art/Jo7swMZWe4vAuJ9Xk/art.json | 14 +++++++++++++- art/JoWAeXNsfz23C8d8b/art.json | 14 +++++++++++++- art/JokykDr3Qve8hrLQR/art.json | 14 +++++++++++++- art/JovmnYPALtpYmhbx3/art.json | 14 +++++++++++++- art/JpNPSRbwfogR3zWkh/art.json | 14 +++++++++++++- art/Jpg8BhcLNg3DjTpT5/art.json | 14 +++++++++++++- art/Jr5nXxcZNwvx5K4Bd/art.json | 14 +++++++++++++- art/Jrb5gxuyHzqMNukkg/art.json | 14 +++++++++++++- art/JsEv9AaC54NF6cY8Q/art.json | 14 +++++++++++++- art/JscBDhcAFypHdaMCm/art.json | 14 +++++++++++++- art/JtvN2gq9PiiSdwvHG/art.json | 14 +++++++++++++- art/JvvtkuvxB6iKmfBQa/art.json | 14 +++++++++++++- art/JwR5ZvmH2Nkcr3Rnx/art.json | 14 +++++++++++++- art/JwXL4sBud9x3F6iKY/art.json | 14 +++++++++++++- art/Jy4jz9wJ54XyG6hFF/art.json | 14 +++++++++++++- art/K2GTMMGc83q5GQ6Sa/art.json | 14 +++++++++++++- art/K2eiDz74g3k842g37/art.json | 14 +++++++++++++- art/K3dPqehYPJMnZyDBD/art.json | 14 +++++++++++++- art/K4mA9KNyq7jBxdzxc/art.json | 14 +++++++++++++- art/K5ZpsaMBvzDxkvbwo/art.json | 14 +++++++++++++- art/K5xqhTGgRRGkJzitm/art.json | 14 +++++++++++++- art/K84niXFJgvqPCrhF3/art.json | 14 +++++++++++++- art/K8g3Q6ckgSTWZuRPv/art.json | 14 +++++++++++++- art/K8sAwLQqxzqjXN3FT/art.json | 14 +++++++++++++- art/K9kkXT25juoLDcni4/art.json | 14 +++++++++++++- art/KAsduiMs3RKWHDcHk/art.json | 14 +++++++++++++- art/KCTdZhosdnszWh5Co/art.json | 14 +++++++++++++- art/KCb2cGRMiF3zp2P9E/art.json | 14 +++++++++++++- art/KE36FRWxcF7s2qX3i/art.json | 14 +++++++++++++- art/KFvg6n392t9qpC7HD/art.json | 14 +++++++++++++- art/KGbmKNcckp4MMvaNK/art.json | 14 +++++++++++++- art/KGe8YM5pCyu8n6Rhs/art.json | 14 +++++++++++++- art/KGsjT9edDDoFLsK2a/art.json | 14 +++++++++++++- art/KH4u8GjbkXFrDypQh/art.json | 14 +++++++++++++- art/KLtJG7Mcf8FhRihJn/art.json | 14 +++++++++++++- art/KQLkpoBAPGrNrd3XK/art.json | 14 +++++++++++++- art/KRmBguLvKHcjPJHpn/art.json | 14 +++++++++++++- art/KRpCEmbJ2GTTRtxsR/art.json | 14 +++++++++++++- art/KRuXE4SBCi4kRBG6j/art.json | 14 +++++++++++++- art/KRwzSvynXozMTXZ7w/art.json | 14 +++++++++++++- art/KSMjJjpv6c7spHTef/art.json | 14 +++++++++++++- art/KT6E6Ka96dcuzvJKG/art.json | 14 +++++++++++++- art/KTyBEnoxgZWR569eH/art.json | 14 +++++++++++++- art/KYv8eW5R2AYwLSdtm/art.json | 14 +++++++++++++- art/KZdmbdYsnSLLCa4bQ/art.json | 14 +++++++++++++- art/Ka9eWpFE3Yj86HdYN/art.json | 14 +++++++++++++- art/KeA92CgMaurk37juY/art.json | 14 +++++++++++++- art/KeyjGeoFSgZNieLtF/art.json | 14 +++++++++++++- art/KgWfhQ8N9LTWDds2b/art.json | 14 +++++++++++++- art/KgwQJvsXGiER7oBtf/art.json | 14 +++++++++++++- art/KivkeanM6qFjxFhon/art.json | 14 +++++++++++++- art/KjC8ebmWp9gkJC7dp/art.json | 14 +++++++++++++- art/KjuuMXE22tpxPbTLE/art.json | 14 +++++++++++++- art/KmNbwStFkxfRGJ2Bs/art.json | 14 +++++++++++++- art/KmPLGgqiLsMdk7QpB/art.json | 14 +++++++++++++- art/KmzEiJEqjGKKKKFCN/art.json | 14 +++++++++++++- art/KnBXy8WqLABdJzqxA/art.json | 14 +++++++++++++- art/KoGGiKxguyZYonJzH/art.json | 14 +++++++++++++- art/KokxqxAL7cGNXEh47/art.json | 14 +++++++++++++- art/KouaGmh83NF5FCHdM/art.json | 14 +++++++++++++- art/KpCz9hjoFif9i3TvM/art.json | 14 +++++++++++++- art/KpZcShvoy64nZQwG7/art.json | 14 +++++++++++++- art/Kq2X2rn957ZFHdph9/art.json | 14 +++++++++++++- art/KsdyG6xS6Dzvyi2wN/art.json | 14 +++++++++++++- art/KvFyruyQSz6mfh8jg/art.json | 14 +++++++++++++- art/Kwq7Qw7tBHGz5oiy3/art.json | 14 +++++++++++++- art/Kx8LRqN4KEH3xcg9Q/art.json | 14 +++++++++++++- art/Kxv3hXqcQJecCkWdp/art.json | 14 +++++++++++++- art/Kyf3xbtcypvZ4KbPc/art.json | 14 +++++++++++++- art/KzGvbRByeAs6noPkG/art.json | 14 +++++++++++++- art/L2EkNfwTM8yncpYNw/art.json | 14 +++++++++++++- art/L2TarY6jCmDDb2z8r/art.json | 14 +++++++++++++- art/L4yzBqmc6NRwKXSrs/art.json | 14 +++++++++++++- art/L6xDZ78mbnpnMQGQj/art.json | 14 +++++++++++++- art/L7qW9rkYQEWF4AzkK/art.json | 14 +++++++++++++- art/L89txYMotSKb9FLad/art.json | 14 +++++++++++++- art/LAiiJujhpHqHEG35u/art.json | 14 +++++++++++++- art/LDxR3x6bY8ujTYt3M/art.json | 14 +++++++++++++- art/LE2ob3EHvHzjFMK9W/art.json | 14 +++++++++++++- art/LEzaqrf9HzkcvwKea/art.json | 14 +++++++++++++- art/LHZYGPs7pPvxmLMbm/art.json | 14 +++++++++++++- art/LHgS8fK9eqJpbzbLF/art.json | 14 +++++++++++++- art/LHj56pPH8J6ufctmP/art.json | 14 +++++++++++++- art/LJLGx9kqDknzmmmW5/art.json | 14 +++++++++++++- art/LJeqquzeSbtKjtQGN/art.json | 14 +++++++++++++- art/LLTEjXA7Q49X7GMMm/art.json | 14 +++++++++++++- art/LMN6w6vBdQz2DyQdB/art.json | 14 +++++++++++++- art/LPS8BeAeCDomFZXzX/art.json | 14 +++++++++++++- art/LR4nX9WApQc5MZDDq/art.json | 14 +++++++++++++- art/LTuqGKGJGc3bHxGij/art.json | 14 +++++++++++++- art/LWQB7Eh4wa4moh9oa/art.json | 14 +++++++++++++- art/LX4SGokNFQgLciwnK/art.json | 14 +++++++++++++- art/LZvMDxAGHssNSpJ44/art.json | 14 +++++++++++++- art/LbkZcKYz5Z7nbCP4s/art.json | 14 +++++++++++++- art/LcQbjMTCCKXywR2Rb/art.json | 14 +++++++++++++- art/LcpL4rKHDw4JYGvvt/art.json | 14 +++++++++++++- art/LdAPq7RiPQZHYmFbx/art.json | 14 +++++++++++++- art/LdQAN7vDm59Kqcvgs/art.json | 14 +++++++++++++- art/LfMFq222gHE4os9ai/art.json | 14 +++++++++++++- art/LfQCKq93ccXsMC3DD/art.json | 14 +++++++++++++- art/LgRGGzXFTTEZFmP9x/art.json | 14 +++++++++++++- art/LgbwRMagZDAcxeyMF/art.json | 14 +++++++++++++- art/LgcuGRxZ6AGSaGnQE/art.json | 14 +++++++++++++- art/LhgDszKTstGZBHjt7/art.json | 14 +++++++++++++- art/Ljd8Z84mCFeiRwfuy/art.json | 14 +++++++++++++- art/LorQPsDrEHNowrcw5/art.json | 14 +++++++++++++- art/LpSrFozFQa5LHaw8v/art.json | 14 +++++++++++++- art/LpWRC9LAg6ck6rSzf/art.json | 14 +++++++++++++- art/LqFT5m3gwdtNfjFnA/art.json | 14 +++++++++++++- art/LqqzrrF9Dgq3J5Z4P/art.json | 14 +++++++++++++- art/LrWhYy7j7kZTWy5FC/art.json | 14 +++++++++++++- art/LsoEApydzv2sCKs27/art.json | 14 +++++++++++++- art/LuZZ97aigeATvKnsh/art.json | 14 +++++++++++++- art/LubzbLTSn6qdhTHhs/art.json | 14 +++++++++++++- art/LucsLY5k9d68aLNgv/art.json | 14 +++++++++++++- art/LvJLKq69EEcAHDcJh/art.json | 14 +++++++++++++- art/LvcnWcXcAvYeK7Hmf/art.json | 14 +++++++++++++- art/LwRP8tRgdnHBEYtuM/art.json | 14 +++++++++++++- art/LyBvXsiJxi4cJ9T3G/art.json | 14 +++++++++++++- art/M3TQnRJ4QA4c5vpBc/art.json | 14 +++++++++++++- art/M6uEwrn2PMs7yXoRA/art.json | 14 +++++++++++++- art/M8SShtkWcQkZ4XLZ4/art.json | 14 +++++++++++++- art/M922vaDbAxvAZALbx/art.json | 14 +++++++++++++- art/M9HqzgN5qio4LRDxq/art.json | 14 +++++++++++++- art/MA9L7t9wKoSZh4sHG/art.json | 14 +++++++++++++- art/ME2wYxKbBPSRwmXxf/art.json | 14 +++++++++++++- art/MEwKmhHiC3nJoPSyW/art.json | 14 +++++++++++++- art/MFG9beZgKvqHQdo9F/art.json | 14 +++++++++++++- art/MGJ5AcYQq32diSNSW/art.json | 14 +++++++++++++- art/MGn7wAioaMfoXcbmL/art.json | 14 +++++++++++++- art/MJ9q4A2jzk3t8vEsP/art.json | 14 +++++++++++++- art/MK7bag3KKs9CFJdf8/art.json | 14 +++++++++++++- art/MLaWwDHo66XjxhwCc/art.json | 14 +++++++++++++- art/MLdXbo7E4ENYKNQqj/art.json | 14 +++++++++++++- art/MLtascKR4NfzQFhJj/art.json | 14 +++++++++++++- art/MNGReAdLScFwNiZDg/art.json | 14 +++++++++++++- art/MPp2oxLmZsPapDWCv/art.json | 14 +++++++++++++- art/MPxc2mXYAQd5F3JFC/art.json | 14 +++++++++++++- art/MR2L3baykwugQk8qM/art.json | 14 +++++++++++++- art/MRTD3jA6zwi4pa9j6/art.json | 14 +++++++++++++- art/MTJf2S5uhN4Z4Fswj/art.json | 14 +++++++++++++- art/MTW5NGatj8ZLp9cAD/art.json | 14 +++++++++++++- art/MTyhyqrCPDN5Fd7Xr/art.json | 14 +++++++++++++- art/MWD3RYNPkSTxNBnw5/art.json | 14 +++++++++++++- art/MX75C8xPApWmjNBQE/art.json | 14 +++++++++++++- art/MY3AP4cLfmex5ki2b/art.json | 14 +++++++++++++- art/MZedxmNrAz7p828Eu/art.json | 14 +++++++++++++- art/MaN6KTGWG43vyhd68/art.json | 14 +++++++++++++- art/MaT4wjZqPmXjfRqe3/art.json | 14 +++++++++++++- art/MbBmy2fnJsn82TKWm/art.json | 14 +++++++++++++- art/McGjF3J5vvtWpxnDw/art.json | 14 +++++++++++++- art/MdL5GN8abavG8YvBs/art.json | 14 +++++++++++++- art/Mdfu3bDECkPeKcnKH/art.json | 14 +++++++++++++- art/MdhYtpNnJFJv3jXmY/art.json | 14 +++++++++++++- art/MefAhfbtS5ZbYifPi/art.json | 14 +++++++++++++- art/MegMNJwR7hpTYFf2G/art.json | 14 +++++++++++++- art/MfHtgKgYcLYo4gHrB/art.json | 14 +++++++++++++- art/MfQT7AKEmWF7Q35TS/art.json | 14 +++++++++++++- art/Mfirr9f2pxxX9ieik/art.json | 14 +++++++++++++- art/MgC43FZpWMJiPkiAD/art.json | 14 +++++++++++++- art/MgCFmyZHQF4Xy4EsJ/art.json | 14 +++++++++++++- art/MgTTiHeeh58AxqR7D/art.json | 14 +++++++++++++- art/MgkDcnH4JMLmrHeHs/art.json | 14 +++++++++++++- art/MjsCC6T8BoLYtnpKv/art.json | 14 +++++++++++++- art/MkAt4QQ3RgdpxBAtb/art.json | 14 +++++++++++++- art/Mm6CKQSnDcsLCorEL/art.json | 14 +++++++++++++- art/Mn5Lhm33cELxeTJsN/art.json | 14 +++++++++++++- art/MncGu5v3jXSZbE4xh/art.json | 14 +++++++++++++- art/MpkYwsT75rAGCYNQb/art.json | 14 +++++++++++++- art/Mpv9f3xLsHhv58XD9/art.json | 14 +++++++++++++- art/MqRQ3wYqFZLGPAQWd/art.json | 14 +++++++++++++- art/MrwTGnkcE7aQ4y6XX/art.json | 14 +++++++++++++- art/MspbSjFRCRuPmozZy/art.json | 14 +++++++++++++- art/MuxJWoHfp7M47hF8N/art.json | 14 +++++++++++++- art/MvGQHAgKDYs3xAtq6/art.json | 14 +++++++++++++- art/MvaSyANZqpM9Mewxp/art.json | 14 +++++++++++++- art/N22sSoSPGrRpJDyjK/art.json | 14 +++++++++++++- art/N29W9bLojSA4Kv2fq/art.json | 14 +++++++++++++- art/N2YXPmoxfuJSPWjhk/art.json | 14 +++++++++++++- art/N3hXFQfEHwQ9N3TkC/art.json | 14 +++++++++++++- art/N5RMgW9QWmZvX9X2D/art.json | 14 +++++++++++++- art/N9XCgfYxZ2Ffxr7hk/art.json | 14 +++++++++++++- art/N9ij5y2vHTpi6aDYM/art.json | 14 +++++++++++++- art/NAnnyGCyAH9xTsjGs/art.json | 14 +++++++++++++- art/NCmuezkb94xMJ4gtR/art.json | 14 +++++++++++++- art/NDEYmpHPER7Tg3oiu/art.json | 14 +++++++++++++- art/NE74eMsB75DrWvCf2/art.json | 14 +++++++++++++- art/NFPQeRuNoFDunGBxd/art.json | 14 +++++++++++++- art/NFjum54CBQsEgz5sK/art.json | 14 +++++++++++++- art/NHc5v2ZJ5kCQAefNG/art.json | 14 +++++++++++++- art/NJM9uDGaaTJfRnrQC/art.json | 14 +++++++++++++- art/NKCTpuxGSTTQAXHYw/art.json | 14 +++++++++++++- art/NLAbSqYY5BSBZfShB/art.json | 14 +++++++++++++- art/NMXGFyxQwcGWH96PG/art.json | 14 +++++++++++++- art/NP3rRKeHPZeXBhymB/art.json | 14 +++++++++++++- art/NPJKuYxHxpNRWHnid/art.json | 14 +++++++++++++- art/NPRtMLeXooWxf64wn/art.json | 14 +++++++++++++- art/NPjebpJsCc3dqek4y/art.json | 14 +++++++++++++- art/NPohkmBgKdTBhML8P/art.json | 14 +++++++++++++- art/NR42qFZjAfmdmw6oR/art.json | 14 +++++++++++++- art/NTihgba8cFq4fMyQF/art.json | 14 +++++++++++++- art/NTmBiN65MW5gE5nBQ/art.json | 14 +++++++++++++- art/NYiqfuasX6PFoLoQr/art.json | 14 +++++++++++++- art/NZXTQnoGoqztxfJDm/art.json | 14 +++++++++++++- art/NZyPJxqb9KngCnPmj/art.json | 14 +++++++++++++- art/Nd7RLTNMwo9xcqBgZ/art.json | 14 +++++++++++++- art/NdqnSLhc6EZ67TXkP/art.json | 14 +++++++++++++- art/Ndrs3aeC35272f5ku/art.json | 14 +++++++++++++- art/NeGB5oyRfmeMmWodT/art.json | 14 +++++++++++++- art/NfQPZoWHTBFY7AKy5/art.json | 14 +++++++++++++- art/NfsvpqNHppMHhscah/art.json | 14 +++++++++++++- art/NhWzyi4RTkjqEik5t/art.json | 14 +++++++++++++- art/NitinB9Gc5jPZZ4vh/art.json | 14 +++++++++++++- art/Njfu8NkcFaWN4RDAx/art.json | 14 +++++++++++++- art/NkGu9MkBw25Y4yT2Y/art.json | 14 +++++++++++++- art/Nn9NwLg9EkcRu5ySW/art.json | 14 +++++++++++++- art/NnwTMwz27MKZEbr46/art.json | 14 +++++++++++++- art/Nphqdj5rtbnvnS26q/art.json | 14 +++++++++++++- art/NpnhMDf6aivDMB3x9/art.json | 14 +++++++++++++- art/NrcGDcivscB3MHpcB/art.json | 14 +++++++++++++- art/NrwDd6WWDm4WJAvtM/art.json | 14 +++++++++++++- art/Nv4BapXAuEeZYTdNe/art.json | 14 +++++++++++++- art/NwAsyqz4w4XbYrCZv/art.json | 14 +++++++++++++- art/NyEsirDmwdF3Q65i6/art.json | 14 +++++++++++++- art/P4e5h3iG9MkcanmBM/art.json | 14 +++++++++++++- art/P5PC55YtuMYdAYrM8/art.json | 14 +++++++++++++- art/P5RqTvyQgTLzoCwXM/art.json | 14 +++++++++++++- art/P5mpP2Tb9XkwhuTK7/art.json | 14 +++++++++++++- art/P6Gk2AsdD2B7g9Kus/art.json | 14 +++++++++++++- art/P6MCpqz4ahLWemiGr/art.json | 14 +++++++++++++- art/P6oFn7ms5b8ZLioGX/art.json | 14 +++++++++++++- art/P788bkYrZh4KcFHgQ/art.json | 14 +++++++++++++- art/P7xh5mAYe3HWaA4x7/art.json | 14 +++++++++++++- art/P8gqvjnX5d6r53X7y/art.json | 14 +++++++++++++- art/P9XfoFdHfyNDCwh2N/art.json | 14 +++++++++++++- art/PBjvGFAxsjcQZhMod/art.json | 14 +++++++++++++- art/PCd9WgpvsQcj7HXTc/art.json | 14 +++++++++++++- art/PERFs2wtC9jvSqbDY/art.json | 14 +++++++++++++- art/PERaHxC8pvwoBGHMo/art.json | 14 +++++++++++++- art/PF6C8TWcrEB3Mz3NP/art.json | 14 +++++++++++++- art/PFHJfQrt3knT8K8sQ/art.json | 14 +++++++++++++- art/PFcfvGhtiFiKLLvYC/art.json | 14 +++++++++++++- art/PG4Ca7xxyoYxNdTGe/art.json | 14 +++++++++++++- art/PGXc8D9XenBb5xokv/art.json | 14 +++++++++++++- art/PHANwhhRXk62fsaeC/art.json | 14 +++++++++++++- art/PHWvovEcpp6R6yT8K/art.json | 14 +++++++++++++- art/PHjEAtNPJWshykNWj/art.json | 14 +++++++++++++- art/PHxPuJWQiqm9gamRN/art.json | 14 +++++++++++++- art/PJNdD52L3irdZzLDv/art.json | 14 +++++++++++++- art/PJotDZ2XkNc3ut8ok/art.json | 14 +++++++++++++- art/PKKSn3hisqqifLpXX/art.json | 14 +++++++++++++- art/PLaQo2H7Zkft5CLu2/art.json | 14 +++++++++++++- art/PLaynf8Y9S5jEPnGP/art.json | 14 +++++++++++++- art/PMP5Sqmw8vLLrpJgw/art.json | 14 +++++++++++++- art/PMhjdsdCjrLMctssg/art.json | 14 +++++++++++++- art/PNKS5Rcz4wR4JLhcq/art.json | 14 +++++++++++++- art/PNhE8dDWq3i4kPX64/art.json | 14 +++++++++++++- art/PRrsa99yGZN6XannP/art.json | 14 +++++++++++++- art/PSjv6ihn8226ALFCx/art.json | 14 +++++++++++++- art/PTcamNGqbYP3egN7J/art.json | 14 +++++++++++++- art/PXhZibqyymFpz4qCz/art.json | 14 +++++++++++++- art/PXqNQnv5Xc23ek5f2/art.json | 14 +++++++++++++- art/PZbvDng9i2QhrcC3y/art.json | 14 +++++++++++++- art/PaksuLs2j2rAHuzxw/art.json | 14 +++++++++++++- art/PbQ763xTmvvCYLywu/art.json | 14 +++++++++++++- art/PcGaeSXys75hdn3ky/art.json | 14 +++++++++++++- art/PcKwWKK2nMJ7TjaaT/art.json | 14 +++++++++++++- art/Pcb2n3yJfxALCGt2x/art.json | 14 +++++++++++++- art/PdyGqhyQKndEoHwaa/art.json | 14 +++++++++++++- art/PitEvTS6w7WK8RHn8/art.json | 14 +++++++++++++- art/Piyv2py4bQL283mTB/art.json | 14 +++++++++++++- art/PjY2sWZMomTjpuym6/art.json | 14 +++++++++++++- art/PkSbv7TufuWHiNRbd/art.json | 14 +++++++++++++- art/PkkKJZY7bP4Q5oHQQ/art.json | 14 +++++++++++++- art/PmRwSpR6jxkbJgsE4/art.json | 14 +++++++++++++- art/PmW7c9NeLghdwa8S4/art.json | 14 +++++++++++++- art/PnP9nGDCsdg3X8R6u/art.json | 14 +++++++++++++- art/PnfhNHTd9N2nBjoiw/art.json | 14 +++++++++++++- art/PorioQ3ztpHifDuAx/art.json | 14 +++++++++++++- art/PoyGoZL5Lmmn9N5SF/art.json | 14 +++++++++++++- art/PpBTtfY3xx82oxNdo/art.json | 14 +++++++++++++- art/PponkZdtktgJHhipC/art.json | 14 +++++++++++++- art/PpwJ5uNXyzHCnWSZJ/art.json | 14 +++++++++++++- art/Pq8cc68g6sG9jYR6Y/art.json | 14 +++++++++++++- art/PsHuyZzqaS6pheL2D/art.json | 14 +++++++++++++- art/PtvnQNWKfKdFBWHtm/art.json | 14 +++++++++++++- art/PtxL78jLv4jyfZCi9/art.json | 14 +++++++++++++- art/PuJz9tt4xX8z7tBP8/art.json | 14 +++++++++++++- art/Px6gh46SuTaM4EEnF/art.json | 14 +++++++++++++- art/PyWaWYkpMMnc2GQBc/art.json | 14 +++++++++++++- art/PyqCH2QLtx4JYsvAY/art.json | 14 +++++++++++++- art/Pzbk6qLsSg2d38JRq/art.json | 14 +++++++++++++- art/Q2oHwSyr3NpT7jokA/art.json | 14 +++++++++++++- art/Q3Mv3prh5dPis7GsK/art.json | 14 +++++++++++++- art/Q3ckKgYEBkj3MgeLP/art.json | 14 +++++++++++++- art/Q3wB5rKJ8hQm7Qu7Q/art.json | 14 +++++++++++++- art/Q4dpCbhvWMYfDz5Nb/art.json | 14 +++++++++++++- art/Q6WYaT35yY2FLBkgi/art.json | 14 +++++++++++++- art/Q85DLHuNZgXEXPBYw/art.json | 14 +++++++++++++- art/Q8RpzMoMpG8LgruMo/art.json | 14 +++++++++++++- art/Q9DLLK5ZfccWG9Shv/art.json | 14 +++++++++++++- art/QCpubvSnQsitsMWjB/art.json | 14 +++++++++++++- art/QCxSnbduPERK5rQni/art.json | 14 +++++++++++++- art/QDDLhEyNvhc9PFDQo/art.json | 14 +++++++++++++- art/QGXB5e8RAqNJsredQ/art.json | 14 +++++++++++++- art/QH3gSYw84QKSqtGr2/art.json | 14 +++++++++++++- art/QHfQoa4YycdGxqd8r/art.json | 14 +++++++++++++- art/QJskLnkaikLSdkYEs/art.json | 14 +++++++++++++- art/QKr9Zs5phrohEPjCp/art.json | 14 +++++++++++++- art/QLuMqpKa5JSrpLW5B/art.json | 14 +++++++++++++- art/QNRa7fHrHnYWcZoCm/art.json | 14 +++++++++++++- art/QNecaJ5aHf8ckGNJa/art.json | 14 +++++++++++++- art/QPCMC7RgjqG63yQvN/art.json | 14 +++++++++++++- art/QQPfLKd8XLAt6wWQi/art.json | 14 +++++++++++++- art/QQn8ttKsNBFEpfwuE/art.json | 14 +++++++++++++- art/QRwggT8zdiZbYuaXv/art.json | 14 +++++++++++++- art/QTWSXRpNKJ4KJEHur/art.json | 14 +++++++++++++- art/QWNj2ZspFrBLdtsJm/art.json | 14 +++++++++++++- art/QXw5ie5QNXrscXSgX/art.json | 14 +++++++++++++- art/Qa2CxakRKHmYmZgdH/art.json | 14 +++++++++++++- art/Qa3ssdh39M6HGfPqM/art.json | 14 +++++++++++++- art/QcXB9sbhnSW4SxjpP/art.json | 14 +++++++++++++- art/QdJXEkZPWPvB4XKiy/art.json | 14 +++++++++++++- art/Qdhn9CoweLkKbkKLT/art.json | 14 +++++++++++++- art/QfDybr9wdsTip3KZ5/art.json | 14 +++++++++++++- art/QfRkDTHRvsH4cztQA/art.json | 14 +++++++++++++- art/Qg6cjjRRKxsXEEGYB/art.json | 14 +++++++++++++- art/QgXakG4wfDMZ4Au6n/art.json | 14 +++++++++++++- art/Qh7WiD2iwnCrdfCXy/art.json | 14 +++++++++++++- art/Qi72eGRatu7XNwXS3/art.json | 14 +++++++++++++- art/Qkrc49g3Qm8mZHg9J/art.json | 14 +++++++++++++- art/QmSnBFirC9qwWGrrA/art.json | 14 +++++++++++++- art/QmjXyegEDvGDmMNkK/art.json | 14 +++++++++++++- art/QsjAsodRs56HTtASm/art.json | 14 +++++++++++++- art/QukF3gwmKw5pDHhaD/art.json | 14 +++++++++++++- art/QvQL9vkAcj4EawBDk/art.json | 14 +++++++++++++- art/Qx9JCRsXfk5Ajh3t7/art.json | 14 +++++++++++++- art/QyDcaPpdEjfdFhiJZ/art.json | 14 +++++++++++++- art/R24A9rmCwYpy84QtX/art.json | 14 +++++++++++++- art/R2FYLbHWTcCWh5PiE/art.json | 14 +++++++++++++- art/R4LHf9BCLCCDYjbez/art.json | 14 +++++++++++++- art/R4ridvuayrATd6Tgy/art.json | 14 +++++++++++++- art/R5YxJnoTPRwwaJqFz/art.json | 14 +++++++++++++- art/R7mtRmP2cCPdJk6Bv/art.json | 14 +++++++++++++- art/R7yXZW3KoMpDcS5NW/art.json | 14 +++++++++++++- art/R9YtdbpwyPFwwKsix/art.json | 14 +++++++++++++- art/RAEKCeDDfGBmYSyQY/art.json | 14 +++++++++++++- art/RAKtMyYWNoC4Qni29/art.json | 14 +++++++++++++- art/RAbYpopPvqhdXyhM5/art.json | 14 +++++++++++++- art/REkY7MvYAx7KwFMrw/art.json | 14 +++++++++++++- art/RHYaZ3WADZyQo4ypC/art.json | 14 +++++++++++++- art/RJ4Tjj3PSsq4kvDcc/art.json | 14 +++++++++++++- art/RKtpsEbtLZPFtvxRA/art.json | 14 +++++++++++++- art/RLCfXFKZw5SjhED9h/art.json | 14 +++++++++++++- art/RM7eRS2ZAytCwuqj5/art.json | 14 +++++++++++++- art/RNPaQH4DP4FJeTJZi/art.json | 14 +++++++++++++- art/RNvmyLxwWoWWorb59/art.json | 14 +++++++++++++- art/RRi3txAyxdQDsZW35/art.json | 14 +++++++++++++- art/RSCshw9mQCvMmvyzw/art.json | 14 +++++++++++++- art/RWjPnvTPcF45HvKFo/art.json | 14 +++++++++++++- art/RYrCnYygNSqgtTDKi/art.json | 14 +++++++++++++- art/RYzSiASv8yuq6xWHJ/art.json | 14 +++++++++++++- art/RZ3HmsB9XBnW5yn7k/art.json | 14 +++++++++++++- art/RZLFdeaBCJsCmp6Qg/art.json | 14 +++++++++++++- art/RanZJwjv68Hjs5i4d/art.json | 14 +++++++++++++- art/RbbKsGLiEeMtCfCjQ/art.json | 14 +++++++++++++- art/RdimY5SHzK3msAHm4/art.json | 14 +++++++++++++- art/RdipyP4yy3xT5cbP5/art.json | 14 +++++++++++++- art/RedmMGmXH2o8ZDTMQ/art.json | 14 +++++++++++++- art/RfQDsEbCqannGyZe2/art.json | 14 +++++++++++++- art/Rfe9EhWQ5Pe2SD9JR/art.json | 14 +++++++++++++- art/RfnraoGGxrRDND4T8/art.json | 14 +++++++++++++- art/RfrwmKH4fQMA3Pmxf/art.json | 14 +++++++++++++- art/RgpnRrekYqf65qH3v/art.json | 14 +++++++++++++- art/Ri8Y9A63oZsG2BkYf/art.json | 14 +++++++++++++- art/Rj6BcdcHrfFGGfN27/art.json | 14 +++++++++++++- art/RjKNeXgMi8SchMEXg/art.json | 14 +++++++++++++- art/RkS9eZ4fjYjak9w78/art.json | 14 +++++++++++++- art/RkZ8yDec9HRBYHmvX/art.json | 14 +++++++++++++- art/Rkg7vqW56XS6yjEbT/art.json | 14 +++++++++++++- art/RnoNQS8C8DpLZCNWv/art.json | 14 +++++++++++++- art/RnwjSt42YXLcGjsgT/art.json | 14 +++++++++++++- art/RowjyMjajikHuDp7Z/art.json | 14 +++++++++++++- art/Rp7GgqLK79srZtBn3/art.json | 14 +++++++++++++- art/RtPtBzZA48whTSdM4/art.json | 14 +++++++++++++- art/RtuoYT8CXLbyZSsWE/art.json | 14 +++++++++++++- art/Rv7oW8vbcGty8AYPb/art.json | 14 +++++++++++++- art/RvWJ6QMocJKvfzo6E/art.json | 14 +++++++++++++- art/RwniHjBDJSzrREKMm/art.json | 14 +++++++++++++- art/RzDd4oDNK7htc9dqe/art.json | 14 +++++++++++++- art/RzgNiz5tqPwJL9Hzq/art.json | 14 +++++++++++++- art/S24QeFuvJgsKJ3gdB/art.json | 14 +++++++++++++- art/S3G4ckMFZ5kpHq2Gz/art.json | 14 +++++++++++++- art/S3xrtQ73jjKSYCofF/art.json | 14 +++++++++++++- art/S4DRdLKsky7bn3aHH/art.json | 14 +++++++++++++- art/S5Zy3N24yyhKqLNwc/art.json | 14 +++++++++++++- art/S69GThF6s72FaScEz/art.json | 14 +++++++++++++- art/S73z5kLypn9BENeFt/art.json | 14 +++++++++++++- art/S7g7iMY2BZtMTZzuG/art.json | 14 +++++++++++++- art/S7tQLj7rJ3Nyf4q8P/art.json | 14 +++++++++++++- art/S8WjbT3dh5ZHhbpAS/art.json | 14 +++++++++++++- art/SAToMsqc7PybLLEc2/art.json | 14 +++++++++++++- art/SAxr7jfCpJMn2zJyG/art.json | 14 +++++++++++++- art/SBPbXExASm2xdxtmi/art.json | 14 +++++++++++++- art/SDv9RES4wtc8RQbg2/art.json | 14 +++++++++++++- art/SEd9sPy3A6AgCCbWG/art.json | 14 +++++++++++++- art/SEk9EQMb8GksyQBhX/art.json | 14 +++++++++++++- art/SFmNpx7c5RxJxfEnq/art.json | 14 +++++++++++++- art/SGSdWRQtcRJGxt6BP/art.json | 14 +++++++++++++- art/SGm2qQjwmg7NGb4my/art.json | 14 +++++++++++++- art/SHEuL7KCpNnj28Rmn/art.json | 14 +++++++++++++- art/SHK4CEcQDC3SgBnMt/art.json | 14 +++++++++++++- art/SJ68p365upswGjcG9/art.json | 14 +++++++++++++- art/SJYTAAwib5eJy8voP/art.json | 14 +++++++++++++- art/SK2zDKBfJ2tqtnSHS/art.json | 14 +++++++++++++- art/SKXKQkxm2HZHdxdxm/art.json | 14 +++++++++++++- art/SLcJWBndqbG7TnEvr/art.json | 14 +++++++++++++- art/SLdjCgFb5gQiFcuAW/art.json | 14 +++++++++++++- art/SLhB3b923SkZwRno6/art.json | 14 +++++++++++++- art/SMeHXTzP7e6vTniKx/art.json | 14 +++++++++++++- art/SNLk9sRqLuGqWmAYF/art.json | 14 +++++++++++++- art/SNXZQdmk9EFczeXF6/art.json | 14 +++++++++++++- art/SQetEuxWhPcPQc3TJ/art.json | 14 +++++++++++++- art/SRbaWWFNYiYrDmj9H/art.json | 14 +++++++++++++- art/SRpckdENpS5Hpem8o/art.json | 14 +++++++++++++- art/SSfBNBsGgsKWG8SwQ/art.json | 14 +++++++++++++- art/STMhyZ8zrQSiJqi7S/art.json | 14 +++++++++++++- art/STmreATrsBA7GMBzA/art.json | 14 +++++++++++++- art/STvAdbbowvRQ7XfSb/art.json | 14 +++++++++++++- art/SWCEzMNTmvcDAxs3n/art.json | 14 +++++++++++++- art/SYLXTDKJmDrAcAiNE/art.json | 14 +++++++++++++- art/SZgEYFYSHKMqWSBCo/art.json | 14 +++++++++++++- art/SbtAs2XinPEhh4y92/art.json | 14 +++++++++++++- art/ScY8ZMw5DYqe8DXMk/art.json | 14 +++++++++++++- art/ScnXYT2B8gmr2trfw/art.json | 14 +++++++++++++- art/SenDt74iq42gPkfJk/art.json | 14 +++++++++++++- art/SfWoZkJqAcdQ6baq5/art.json | 14 +++++++++++++- art/SgSd9NeMcEY53XNTJ/art.json | 14 +++++++++++++- art/SgsEwB5Ax2ySwLYpd/art.json | 14 +++++++++++++- art/Siq7bKzSywBNKoE5B/art.json | 14 +++++++++++++- art/SnHzmTdr25on3o4Zs/art.json | 14 +++++++++++++- art/SnqDnsfrYzTPyN2BA/art.json | 14 +++++++++++++- art/So6hu3cdGNWJEi8HN/art.json | 14 +++++++++++++- art/SoK3eJipBJGantxyd/art.json | 14 +++++++++++++- art/Soip5jkRuE4MTLibC/art.json | 14 +++++++++++++- art/SqctCGQnp8j6NNnSE/art.json | 14 +++++++++++++- art/Suxnf3g4CqC5dLWw6/art.json | 14 +++++++++++++- art/SvKBPm8HSm9yzW4F2/art.json | 14 +++++++++++++- art/SvkxzENQ5fAgKSxZp/art.json | 14 +++++++++++++- art/Sw2atuBHGBsutNYZf/art.json | 14 +++++++++++++- art/Sx3Sk35wbBx2sGAxM/art.json | 14 +++++++++++++- art/T2fikhe7Y9nsT6rrx/art.json | 14 +++++++++++++- art/T3o69kd5wMtWNCj5k/art.json | 14 +++++++++++++- art/T3rPrhgzehKeaqZc6/art.json | 14 +++++++++++++- art/T4tRxRrwSmzcLthgd/art.json | 14 +++++++++++++- art/T6vQzhdcHjvaZBNuN/art.json | 14 +++++++++++++- art/T9BE9jwspwHzixcM5/art.json | 14 +++++++++++++- art/T9kEQ59LHfbYhaWxj/art.json | 14 +++++++++++++- art/TAL5yA4piTpRpG2Qw/art.json | 14 +++++++++++++- art/TAT9Ad57HDZwRxXnf/art.json | 14 +++++++++++++- art/TCDXMAgg5629wT79d/art.json | 14 +++++++++++++- art/TDjh9ML39vLzhGboy/art.json | 14 +++++++++++++- art/TDswsR4bMAPBnsQLT/art.json | 14 +++++++++++++- art/TFMzciLhhyBhYRKW5/art.json | 14 +++++++++++++- art/TFXxrMbQQXNqtcTE8/art.json | 14 +++++++++++++- art/TFoeAMv4JnW8NxM4N/art.json | 14 +++++++++++++- art/TFqk3nQR5AQxhWWKn/art.json | 14 +++++++++++++- art/TGAHpg3tJBt7nTsRy/art.json | 14 +++++++++++++- art/TGGLggjxQgLPEFHWx/art.json | 14 +++++++++++++- art/TH2CTrKcW6GQ4Y9q9/art.json | 14 +++++++++++++- art/TKku4LqhCCgDpnKTd/art.json | 14 +++++++++++++- art/TMG34LHftperZZKZm/art.json | 14 +++++++++++++- art/TPrujGdAaBfqpYpvT/art.json | 14 +++++++++++++- art/TTsbi8YxPA9GcqRmJ/art.json | 14 +++++++++++++- art/TWsa59dHZ4GX5bsnG/art.json | 14 +++++++++++++- art/TYoTaksHA6DWsP4aD/art.json | 14 +++++++++++++- art/TZ58peuETd4DLzbYC/art.json | 14 +++++++++++++- art/TZBvEoNYkzhB8PtQR/art.json | 14 +++++++++++++- art/Ta4jCjwCjoL5iw4gY/art.json | 14 +++++++++++++- art/TaRwiuErKL5fkN24p/art.json | 14 +++++++++++++- art/TcJgksCcEE95aJXZc/art.json | 14 +++++++++++++- art/TdqvseMQyoJ3ZrjrD/art.json | 14 +++++++++++++- art/TiyZJh7nekQSquxTK/art.json | 14 +++++++++++++- art/Tj6QZbDv6jioYkJtb/art.json | 14 +++++++++++++- art/TjYfbRFifgzMfDFfg/art.json | 14 +++++++++++++- art/TjsWhmhbezg59ibvb/art.json | 14 +++++++++++++- art/TkKCcbsYG7ubBaXDq/art.json | 14 +++++++++++++- art/TkQY6zwRTeGzEqbCb/art.json | 14 +++++++++++++- art/TmsGWvgfvS9T75Fii/art.json | 14 +++++++++++++- art/Tn26s3ARMWt6vkHkk/art.json | 14 +++++++++++++- art/TnA8pckZzDwoPmYvM/art.json | 14 +++++++++++++- art/TnXzsnYqaPym78gQ8/art.json | 14 +++++++++++++- art/ToJKAtGKcN3vg5MJY/art.json | 14 +++++++++++++- art/Toiefpwj7bhJqsYxd/art.json | 14 +++++++++++++- art/TrexNrcNFyQ7FrJjb/art.json | 14 +++++++++++++- art/TrfCHd7Prkiad7Fox/art.json | 14 +++++++++++++- art/TsDPjH9MzsLF4uHdo/art.json | 14 +++++++++++++- art/TtKHBfMCFHuz5PKm7/art.json | 14 +++++++++++++- art/TtKakFtTdMbTCbaQj/art.json | 14 +++++++++++++- art/Tv6txjYWJaTTTbyRp/art.json | 14 +++++++++++++- art/Tw8ymmpoiv7MwrjWv/art.json | 14 +++++++++++++- art/TyWsHgdd6xGj8uYSg/art.json | 14 +++++++++++++- art/W5AaXFFJk2ZggnWEk/art.json | 14 +++++++++++++- art/W5pb4uwKJ9dzEF9oz/art.json | 14 +++++++++++++- art/W5vsi9uadatWRg8XJ/art.json | 14 +++++++++++++- art/W6AZjsv3rqioGwCLa/art.json | 14 +++++++++++++- art/W759Kzfq4jJb5dL5v/art.json | 14 +++++++++++++- art/W7N52DhuhNz27EPxw/art.json | 14 +++++++++++++- art/W9WTPxA9AXtFxZRqq/art.json | 14 +++++++++++++- art/WARdzeaiQZaiSy6Hj/art.json | 14 +++++++++++++- art/WBgJQrq6H2sZ2gzyb/art.json | 14 +++++++++++++- art/WC5fhEkctfmHrGz6m/art.json | 14 +++++++++++++- art/WE4yq93CEqrBtHvQ9/art.json | 14 +++++++++++++- art/WEKX8jLk432REZLJq/art.json | 14 +++++++++++++- art/WGdY3o9Nv6AqRvu5E/art.json | 14 +++++++++++++- art/WHQLcLQnN57rPtGJC/art.json | 14 +++++++++++++- art/WKkAZ9su88ypqH9da/art.json | 14 +++++++++++++- art/WM2T8Fz7ftcgqwgYn/art.json | 14 +++++++++++++- art/WMSNZ3Scdfw2fZJyw/art.json | 14 +++++++++++++- art/WMeytAXb53i6LtrWm/art.json | 14 +++++++++++++- art/WQxKx3Pee7i5gEdzG/art.json | 14 +++++++++++++- art/WRmESL9HBySX6ujn5/art.json | 14 +++++++++++++- art/WWDNZ5h4zR4H9dqPn/art.json | 14 +++++++++++++- art/WWd3sxvrHtZpty96D/art.json | 14 +++++++++++++- art/WXAP9xy4D98Qz6J8f/art.json | 14 +++++++++++++- art/WYLzRpCTKdWsrCPkZ/art.json | 14 +++++++++++++- art/WZ4EToBv8LTc3N3Tn/art.json | 14 +++++++++++++- art/WZNDshPHXJPBR52fb/art.json | 14 +++++++++++++- art/WbN969kWgnCsYXofi/art.json | 14 +++++++++++++- art/WcpXFp2FfMH7gwc6m/art.json | 14 +++++++++++++- art/WfwMFdL3M3qEpW4zy/art.json | 14 +++++++++++++- art/WgAGyf4sc6LfsH2bd/art.json | 14 +++++++++++++- art/WhEz6A2JeXrzqtrhZ/art.json | 14 +++++++++++++- art/Wjh598Fb6DK7AzRda/art.json | 14 +++++++++++++- art/WnMNfRSbiZgpHz3xc/art.json | 14 +++++++++++++- art/Wo2pq9yKds3mQYWaX/art.json | 14 +++++++++++++- art/Wova8i2L3H2AtWPkQ/art.json | 14 +++++++++++++- art/WrX5cRT7BypxGrBFk/art.json | 14 +++++++++++++- art/WriDgXxvrtaB7q77s/art.json | 14 +++++++++++++- art/WsESfm8ByGEmnFBkE/art.json | 14 +++++++++++++- art/WswhQKGQNaZzQhtqz/art.json | 14 +++++++++++++- art/WuRAKg77S8gD366A8/art.json | 14 +++++++++++++- art/WurZPAe5kYjd8bBB6/art.json | 14 +++++++++++++- art/WvKKxjSusH6cFyYcx/art.json | 14 +++++++++++++- art/WwHWSfGf9LMF8vSAs/art.json | 14 +++++++++++++- art/WxF9C4KTpRRskgmYF/art.json | 14 +++++++++++++- art/WxsiG7yWNKj8rH2Qe/art.json | 14 +++++++++++++- art/WyifmdumQtSdpJgcb/art.json | 14 +++++++++++++- art/WzeZofWAP8mZ2aNBz/art.json | 14 +++++++++++++- art/X2DfX3YZvHG8KrEhj/art.json | 14 +++++++++++++- art/X4p3ogDk8g7e5CvmA/art.json | 14 +++++++++++++- art/X74uYKiDLZJmqhLnh/art.json | 14 +++++++++++++- art/XASP5MBqwovRLqzqg/art.json | 14 +++++++++++++- art/XBTFxPgMSdyM7HXum/art.json | 14 +++++++++++++- art/XBmtPpZobE3xxRQ9e/art.json | 14 +++++++++++++- art/XCcCm2KWsWPqG7Puh/art.json | 14 +++++++++++++- art/XDJPeMfrdhMBhw4XD/art.json | 14 +++++++++++++- art/XJecoKnhhsWTTNp4Z/art.json | 14 +++++++++++++- art/XK2y2Cy63Ez45E7pm/art.json | 14 +++++++++++++- art/XLRYpFJ4uH4fWk2Tn/art.json | 14 +++++++++++++- art/XMfocB69HDJbjh5Sf/art.json | 14 +++++++++++++- art/XQQfnaTej5ZuzxNaf/art.json | 14 +++++++++++++- art/XQjMFcAi9qguPBnBG/art.json | 14 +++++++++++++- art/XRdg3Wi744WAEMHKZ/art.json | 14 +++++++++++++- art/XTMgvDzrnXxm3gSZQ/art.json | 14 +++++++++++++- art/XTxHzHEnG5mRTTYnm/art.json | 14 +++++++++++++- art/XW2ueZpHcoWqtkuqD/art.json | 14 +++++++++++++- art/XWzwbcRCDE4ce9oex/art.json | 14 +++++++++++++- art/XXSghCnP6t28ai6cy/art.json | 14 +++++++++++++- art/XXe4P5TiPiesZgiJj/art.json | 14 +++++++++++++- art/XYGETLizFzAGcWS7N/art.json | 14 +++++++++++++- art/XZqZoCpsyifWWi6up/art.json | 14 +++++++++++++- art/XZuNgqyPsK9ePg5Xv/art.json | 14 +++++++++++++- art/XbaHQ2ETsxu6kZKno/art.json | 14 +++++++++++++- art/XcHuNB7GLk9BmQRap/art.json | 14 +++++++++++++- art/XcY8PN835BKPhMe3Z/art.json | 14 +++++++++++++- art/XdrvWYBfFbiFtfmNL/art.json | 14 +++++++++++++- art/Xf8ywY5kqr6qLRr2F/art.json | 14 +++++++++++++- art/Xh6Hmvi8yPW6A6rFG/art.json | 14 +++++++++++++- art/Xhey4x8tEsNyKymgw/art.json | 14 +++++++++++++- art/XjN7HgsDKsJeibek9/art.json | 14 +++++++++++++- art/Xo2HRcvBcs4Q8Cc7v/art.json | 14 +++++++++++++- art/XpfxjsLJWz8DSuALM/art.json | 14 +++++++++++++- art/XqxXcf4LvJjKuyAk6/art.json | 14 +++++++++++++- art/Xr5DemAP52ZcKLRbQ/art.json | 14 +++++++++++++- art/Xr7T9xN4h3JyWhJ4M/art.json | 14 +++++++++++++- art/XreNJG2gcwCcsQqfL/art.json | 14 +++++++++++++- art/XsyLRu9hP28JhAank/art.json | 14 +++++++++++++- art/XszYFmoC9KohYbbBD/art.json | 14 +++++++++++++- art/Xt8cDbEMoZH7W7AFh/art.json | 14 +++++++++++++- art/XtozrhtGYyW42zNSp/art.json | 14 +++++++++++++- art/XuJSbKXb7qtAKJ6AQ/art.json | 14 +++++++++++++- art/XuPDhjysnqKsPCbGK/art.json | 14 +++++++++++++- art/XwLcGCStsrbhX6jFY/art.json | 14 +++++++++++++- art/XwmMeBkJu6Bk2vv9o/art.json | 14 +++++++++++++- art/XxN2enyHa2MMbayT5/art.json | 14 +++++++++++++- art/XxsoGmBRve3XhR5q3/art.json | 14 +++++++++++++- art/XzD6NxAZ99yMTnE2v/art.json | 14 +++++++++++++- art/XzeZ7nA6eLt5GmJfj/art.json | 14 +++++++++++++- art/Xznj9hZq3fxvAtz4c/art.json | 14 +++++++++++++- art/Y3YjiM7wZKEsfDvmw/art.json | 14 +++++++++++++- art/Y3bsPmhHZNkBkDdhQ/art.json | 14 +++++++++++++- art/Y8qbp8kqR8R9rigM7/art.json | 14 +++++++++++++- art/YFECqw3LmKnaojReb/art.json | 14 +++++++++++++- art/YNECMxcrupx4erT4u/art.json | 14 +++++++++++++- art/YNrYu5vLMifYXQAyj/art.json | 14 +++++++++++++- art/YPJmHpa7pwzhxgBkq/art.json | 14 +++++++++++++- art/YQhEmHqKTgrDSD3AM/art.json | 14 +++++++++++++- art/YQrEtnLC8h7QHDNsd/art.json | 14 +++++++++++++- art/YRrZ7fHmFhtoKpyrq/art.json | 14 +++++++++++++- art/YSrCe2ZHmwiB2d6Kz/art.json | 14 +++++++++++++- art/YSzcySDB7rcbwJmTP/art.json | 14 +++++++++++++- art/YTKN84yNr6RB2aDbB/art.json | 14 +++++++++++++- art/YTqaQuCP9GEF532DP/art.json | 14 +++++++++++++- art/YWMRwMd62Rwyig8hP/art.json | 14 +++++++++++++- art/YXfLo5Yw55muQ7MZn/art.json | 14 +++++++++++++- art/YXzZv8FqoYXqAXDdk/art.json | 14 +++++++++++++- art/YazT6iXD9eAmLY6qD/art.json | 14 +++++++++++++- art/YbA3f6xnjbmXzkwHx/art.json | 14 +++++++++++++- art/Yd2HBe825wEYTar8Y/art.json | 14 +++++++++++++- art/YdpjoX8LmWLnbtXQv/art.json | 14 +++++++++++++- art/YfY3PKQ4Mk78so4bP/art.json | 14 +++++++++++++- art/Yg2urWWiE8sAJEo8W/art.json | 14 +++++++++++++- art/Yg9JRZQhtaWe3dpis/art.json | 14 +++++++++++++- art/YgBq9NXqcsYsRmpBe/art.json | 14 +++++++++++++- art/Yhoy3z7NY6qCX3cnx/art.json | 14 +++++++++++++- art/YiboJk6SvJNEAPSGR/art.json | 14 +++++++++++++- art/Ykt3ZLD52Wnphvaak/art.json | 14 +++++++++++++- art/Ym2ek7eMQNEDspKJd/art.json | 14 +++++++++++++- art/Yn396rtWBPwEkd3fo/art.json | 14 +++++++++++++- art/YoyxivmzQMzpahR8j/art.json | 14 +++++++++++++- art/YqNb2nTxxZRYWkJzz/art.json | 14 +++++++++++++- art/Yudd65BQfx92kHBcH/art.json | 14 +++++++++++++- art/YviLasT7Z62qurfRD/art.json | 14 +++++++++++++- art/Yx83njpAunvLW4dyE/art.json | 14 +++++++++++++- art/YyvPGrqSH2HjWTQi9/art.json | 14 +++++++++++++- art/YzsRADN9oob3PHivP/art.json | 14 +++++++++++++- art/Z25sf3c5qKzxzLrXF/art.json | 14 +++++++++++++- art/Z26iq8hKBPX2svsmR/art.json | 14 +++++++++++++- art/Z3SAeG8oMryJKuF8z/art.json | 14 +++++++++++++- art/Z43GXJiragwBynoD3/art.json | 14 +++++++++++++- art/Z4HpJPY5d2PNYRHZA/art.json | 14 +++++++++++++- art/Z7vAdzozZiayT9xtx/art.json | 14 +++++++++++++- art/ZADtvSryHzDYzCtp9/art.json | 14 +++++++++++++- art/ZAHaRXC8kiQBzSkbb/art.json | 14 +++++++++++++- art/ZENPygQSbgzTTXEP8/art.json | 14 +++++++++++++- art/ZFSiQpx33DLDg9hmd/art.json | 14 +++++++++++++- art/ZFd2APbTjP4sginbR/art.json | 14 +++++++++++++- art/ZFhCyFCR3GKn8HkgG/art.json | 14 +++++++++++++- art/ZHKbJh9f2vE6whpYF/art.json | 14 +++++++++++++- art/ZKyW6sGCeKnuju3A2/art.json | 14 +++++++++++++- art/ZMzvpXNMZY9564WHh/art.json | 14 +++++++++++++- art/ZNi2inr6Jmirh6Hgy/art.json | 14 +++++++++++++- art/ZNnRK7kpHZXGz5gT5/art.json | 14 +++++++++++++- art/ZNyqShZSnzXJMjTPX/art.json | 14 +++++++++++++- art/ZPpq2oK4fqmPHJnQn/art.json | 14 +++++++++++++- art/ZRtD3xwsPjHk8vwmS/art.json | 14 +++++++++++++- art/ZSksx2deRsDocFDKT/art.json | 14 +++++++++++++- art/ZTAvJzo5HJdr2FsZK/art.json | 14 +++++++++++++- art/ZTEp3znDaGd9mFj4J/art.json | 14 +++++++++++++- art/ZWM6nHwzqNcfrMCbQ/art.json | 14 +++++++++++++- art/ZXDZSs2JN4hbwdSqr/art.json | 14 +++++++++++++- art/ZXEkPoPaDoTjDqbL7/art.json | 14 +++++++++++++- art/ZXPZby6en2K8C7Fyg/art.json | 14 +++++++++++++- art/ZZ2MBTXKXSRzbure5/art.json | 14 +++++++++++++- art/ZZPtHWkxTWXKxGiJB/art.json | 14 +++++++++++++- art/ZZj9dLPDqjWny5kJW/art.json | 14 +++++++++++++- art/ZZwMR9KfGEza6h9qC/art.json | 14 +++++++++++++- art/ZaEqKDmErTwBskDSt/art.json | 14 +++++++++++++- art/ZaHRJagSTkbt5ERMW/art.json | 14 +++++++++++++- art/ZbFWyvpmE9fXFTeD6/art.json | 14 +++++++++++++- art/ZbRaEcwQdQBWXwaX9/art.json | 14 +++++++++++++- art/ZdjbNTWSNwcCQRwPT/art.json | 14 +++++++++++++- art/ZfE8NGNHiwufD7MPr/art.json | 14 +++++++++++++- art/ZfXn2xm6JJh3o5b7T/art.json | 14 +++++++++++++- art/ZjCyyWmnuKxxTAkvt/art.json | 14 +++++++++++++- art/ZkzFFuHEAaQzd2eGC/art.json | 14 +++++++++++++- art/ZoyrdxZiwDYNfzT53/art.json | 14 +++++++++++++- art/ZpTRRCPeXztEN8eLo/art.json | 14 +++++++++++++- art/ZqGJTgEXDTHA5rBjL/art.json | 14 +++++++++++++- art/ZqvxtvqSYZ8ThiJ3J/art.json | 14 +++++++++++++- art/ZtNG5CW8eJaJncLrk/art.json | 14 +++++++++++++- art/ZvcLBFp3AkteTsGku/art.json | 14 +++++++++++++- art/ZwJTJhgwALcNCeGWC/art.json | 14 +++++++++++++- art/ZyWp3YSber6wbuY8a/art.json | 14 +++++++++++++- art/ZzCgG7HuSE6BLGSKR/art.json | 14 +++++++++++++- art/a2qkLCbs8jJyqJ4sJ/art.json | 14 +++++++++++++- art/a3JBo24QkPxvKYpja/art.json | 14 +++++++++++++- art/a3KvcpoEdK4k9gNxr/art.json | 14 +++++++++++++- art/a3o5rh2HCzLMPnSbn/art.json | 14 +++++++++++++- art/a4eb9XeRsqT78RngR/art.json | 14 +++++++++++++- art/a4rkLdCiX5RnyGq6x/art.json | 14 +++++++++++++- art/a5fepCCbY5AhGFXTT/art.json | 14 +++++++++++++- art/a75Aou3fJGMJjXG5r/art.json | 14 +++++++++++++- art/a9PxcWZgDCKCjv5qK/art.json | 14 +++++++++++++- art/aBnPmDNxFrFDiFvvL/art.json | 14 +++++++++++++- art/aD8f8mi353xWbSHQk/art.json | 14 +++++++++++++- art/aDTiAi7SZ3joeKxKs/art.json | 14 +++++++++++++- art/aDjRo3j6NPWb6isz6/art.json | 14 +++++++++++++- art/aFBig76hWcPDu5Kf5/art.json | 14 +++++++++++++- art/aGMT3RwjTa9BswBkK/art.json | 14 +++++++++++++- art/aHPn3XMX6j7TP3D8i/art.json | 14 +++++++++++++- art/aKTdaStpa8ugaemPs/art.json | 14 +++++++++++++- art/aKaMTCwCLH9Wy2wfG/art.json | 14 +++++++++++++- art/aKsCsvNiRHackMEsj/art.json | 14 +++++++++++++- art/aM9NFXxMSiNnsvi4u/art.json | 14 +++++++++++++- art/aMJHfrjJHMKKy4iNi/art.json | 14 +++++++++++++- art/aNcrtoxiwyPFj9n9k/art.json | 14 +++++++++++++- art/aRahetpEjCSsaLHkX/art.json | 14 +++++++++++++- art/aW3a59fZi6sxhTYBj/art.json | 14 +++++++++++++- art/aW7ux7BBYH5aNYM6h/art.json | 14 +++++++++++++- art/aXiR2fCcooYzoea9L/art.json | 14 +++++++++++++- art/aY78NwrqSDZrC8tRW/art.json | 14 +++++++++++++- art/aZd7ykAPBAnQ9mKSb/art.json | 14 +++++++++++++- art/adr4oWENvpWNLwHJR/art.json | 14 +++++++++++++- art/aeJaBveTxKQ9E6dTm/art.json | 14 +++++++++++++- art/ahsgh32ELS6fLxWcK/art.json | 14 +++++++++++++- art/aigbErpiobPHWcME4/art.json | 14 +++++++++++++- art/aimt699JRJfpBQPGx/art.json | 14 +++++++++++++- art/akox4yJZBcHiLrbKy/art.json | 14 +++++++++++++- art/aqJ9RgEQBu63bvw2o/art.json | 14 +++++++++++++- art/aqgyqr6ASpcsZTeEu/art.json | 14 +++++++++++++- art/aqszowTp3EkLRtdea/art.json | 14 +++++++++++++- art/as29BXy9qihbCbPqA/art.json | 14 +++++++++++++- art/asSnAehpD5b5tuJ27/art.json | 14 +++++++++++++- art/auetPcBpAZ2WyysTb/art.json | 14 +++++++++++++- art/auo92EWvwwyBRak2c/art.json | 14 +++++++++++++- art/awe7tBGAsEHzRYs2D/art.json | 14 +++++++++++++- art/axgq9WTTCr84iSYkv/art.json | 14 +++++++++++++- art/aynW9zWZRGxronmcP/art.json | 14 +++++++++++++- art/b2AspWSvDsXib8Kkc/art.json | 14 +++++++++++++- art/b32w7foxrhZkD9GeR/art.json | 14 +++++++++++++- art/b3HJWpHiePeAo4JrM/art.json | 14 +++++++++++++- art/b3WFbQ4SDWLwXbcSp/art.json | 14 +++++++++++++- art/b5fN5z5ZFYzsQukHD/art.json | 14 +++++++++++++- art/b6di9dPczq6ZikLtM/art.json | 14 +++++++++++++- art/b9J4bEZw9Z2qRJm5f/art.json | 14 +++++++++++++- art/bBkRA4ZZ72cHNA7Xz/art.json | 14 +++++++++++++- art/bD2aNq4oSF5v8z3Q9/art.json | 14 +++++++++++++- art/bFK899aZjrEfnbQAi/art.json | 14 +++++++++++++- art/bG8faYzBsvfvBSwDH/art.json | 14 +++++++++++++- art/bJc832Huv2tEcL58Y/art.json | 14 +++++++++++++- art/bM77A2kSw6eM7YMHh/art.json | 14 +++++++++++++- art/bN3QdqY39pxGw8csG/art.json | 14 +++++++++++++- art/bN6NWErydKPLz62i5/art.json | 14 +++++++++++++- art/bNYRsM3GYemaiam5G/art.json | 14 +++++++++++++- art/bREFug9pGbyBNwXgE/art.json | 14 +++++++++++++- art/bSD87iQ9LnqxJC3cb/art.json | 14 +++++++++++++- art/bSWJchGnG97o3HQfE/art.json | 14 +++++++++++++- art/bWGzwX6udGM4uM7ra/art.json | 14 +++++++++++++- art/bWQMzQA9jpeRKo7dL/art.json | 14 +++++++++++++- art/bbpMGgfF9vceKwYEH/art.json | 14 +++++++++++++- art/bbsF39W6bJo3j4R3j/art.json | 14 +++++++++++++- art/bbx93AtnjNRLNs4hC/art.json | 14 +++++++++++++- art/bcenao9Loe5Xc2Y7T/art.json | 14 +++++++++++++- art/bgNBk3TJvBHtbJ9jB/art.json | 14 +++++++++++++- art/bgatWdfJ85SuY4Fn3/art.json | 14 +++++++++++++- art/bhTaMtEz4j9zuSn7g/art.json | 14 +++++++++++++- art/bi5qETD9A4okpa4oi/art.json | 14 +++++++++++++- art/biFYsrY6uepWwyQN8/art.json | 14 +++++++++++++- art/bjkZzQ6XfJ5Ypu4AX/art.json | 14 +++++++++++++- art/bmeg6H2QQu9rgbn4o/art.json | 14 +++++++++++++- art/bnRnHzDJKpa425887/art.json | 14 +++++++++++++- art/bpN3ufoDGdkJjxFsQ/art.json | 14 +++++++++++++- art/bpX9tBkNhHiF6nHk8/art.json | 14 +++++++++++++- art/bsfzCu524wjbdK79y/art.json | 14 +++++++++++++- art/btdHcA68nwnRPi6G5/art.json | 14 +++++++++++++- art/btkDAJMxJHZR3rK2M/art.json | 14 +++++++++++++- art/bwr53KzdWw7hBTnsA/art.json | 14 +++++++++++++- art/bwv3qCqRiC5rfavvx/art.json | 14 +++++++++++++- art/bySCJHkqxfotHbAzv/art.json | 14 +++++++++++++- art/byf5BfNoi72wvAFDi/art.json | 14 +++++++++++++- art/c2G37xF7rQv9E6DnK/art.json | 14 +++++++++++++- art/c3DBxMMrtv3DhErvP/art.json | 14 +++++++++++++- art/c53eL6yrZ2W47TK9r/art.json | 14 +++++++++++++- art/c5eMNzQN3L9wo8Bp5/art.json | 14 +++++++++++++- art/c65csouQ75h2ArqRF/art.json | 14 +++++++++++++- art/c69i53Jq39GYhaC3n/art.json | 14 +++++++++++++- art/c7BfoLHoLFBdJ5iYy/art.json | 14 +++++++++++++- art/c8gpxWQCgY845YBbg/art.json | 14 +++++++++++++- art/c9GGGN9nw3aPqNYBW/art.json | 14 +++++++++++++- art/cBtDPFjaQQmK8RYXB/art.json | 14 +++++++++++++- art/cCmnbDXAePT5wsvRQ/art.json | 14 +++++++++++++- art/cCpQdXvZsWd8cH6Hw/art.json | 14 +++++++++++++- art/cFiTJq22KeDLreh5x/art.json | 14 +++++++++++++- art/cGrpKmDq9kKCWsLo7/art.json | 14 +++++++++++++- art/cHiMN4E55KKH9p3L3/art.json | 14 +++++++++++++- art/cHuvNCmJmuzYDZwhL/art.json | 14 +++++++++++++- art/cMSxxdiL7gecfonqz/art.json | 14 +++++++++++++- art/cMqY3Hixco2WwFZo6/art.json | 14 +++++++++++++- art/cMzGhMJLeg2FmmwWM/art.json | 14 +++++++++++++- art/cNaBhCSeeqFwhZQw4/art.json | 14 +++++++++++++- art/cQ2oBbxfbCYZLRFtr/art.json | 14 +++++++++++++- art/cRFKCFDgC87Q4M4di/art.json | 14 +++++++++++++- art/cTBcy7LTxJubbEYXF/art.json | 14 +++++++++++++- art/cTjJFwZcBSSW8d9gw/art.json | 14 +++++++++++++- art/cWYEWZbQ3HcWiKgyG/art.json | 14 +++++++++++++- art/cYSbbDEEERcyLekzE/art.json | 14 +++++++++++++- art/cYx2ofpAnLZMY6Xqr/art.json | 14 +++++++++++++- art/cZLahmf6sZpctWKsR/art.json | 14 +++++++++++++- art/cZZ3eyhcr5QzLGrqT/art.json | 14 +++++++++++++- art/cZoyrQ8kQECXDtSTn/art.json | 14 +++++++++++++- art/ccQWyo6KBLufEhq89/art.json | 14 +++++++++++++- art/cdqm4FpNvFdtD7We7/art.json | 14 +++++++++++++- art/cds3yEbDHT2sbnKxa/art.json | 14 +++++++++++++- art/cgHCLAi7mKznjvENd/art.json | 14 +++++++++++++- art/cgibgS9oD8o5yDmqZ/art.json | 14 +++++++++++++- art/chpxsLEkqhZkhLxDD/art.json | 14 +++++++++++++- art/cifFKxGSudzB8CEt6/art.json | 14 +++++++++++++- art/cj62wdtr684imMKtg/art.json | 14 +++++++++++++- art/cjTYyd8z2yEWqYFeg/art.json | 14 +++++++++++++- art/cjw2sg8cHvsk78JBF/art.json | 14 +++++++++++++- art/ckAitsgFTQ4DbFHAC/art.json | 14 +++++++++++++- art/cm7ZiKYPzjYBqPSyQ/art.json | 14 +++++++++++++- art/cmajQzzGy7RWLuWqC/art.json | 14 +++++++++++++- art/cnpLD2E8bCJ8MjaXX/art.json | 14 +++++++++++++- art/coje67XoytKsXMYqF/art.json | 14 +++++++++++++- art/cpo4C8yfRudYYakav/art.json | 14 +++++++++++++- art/cprWonx4tN8nMgQHt/art.json | 14 +++++++++++++- art/cqLtuWkpoZFuj7Aq2/art.json | 14 +++++++++++++- art/cqrpE8sDb6Md6djDh/art.json | 14 +++++++++++++- art/ct6NykQPhqWr3A7aC/art.json | 14 +++++++++++++- art/ctdaXFjXNjTiss8Kh/art.json | 14 +++++++++++++- art/cvLGj6QKvo7uebnbK/art.json | 14 +++++++++++++- art/cvcz6reqzpuyvdjvY/art.json | 14 +++++++++++++- art/cxEbTRudczrikaEBX/art.json | 14 +++++++++++++- art/cxdd3QwD34CZzTpFj/art.json | 14 +++++++++++++- art/cynWXyqSFnWDriqfR/art.json | 14 +++++++++++++- art/cz2CWm8MobiaqYc46/art.json | 14 +++++++++++++- art/cznhWtArrLFqxJgAf/art.json | 14 +++++++++++++- art/d5232ap5Whxh5xE5w/art.json | 14 +++++++++++++- art/d5MYkeFzBcFMQzpQf/art.json | 14 +++++++++++++- art/d5q4WZfHWEwTikN2o/art.json | 14 +++++++++++++- art/d6HHmyLaBsmttvb5b/art.json | 14 +++++++++++++- art/d6J9M7EJyoAgw5NcA/art.json | 14 +++++++++++++- art/d7anES7ef6WrrDwsy/art.json | 14 +++++++++++++- art/d7bnfzEFFTWGyQNaT/art.json | 14 +++++++++++++- art/d8J6rAnjiWz4HntZH/art.json | 14 +++++++++++++- art/d8rzf4Hgtp69tQvrz/art.json | 14 +++++++++++++- art/dAF9Jm3ZxebA7j6wX/art.json | 14 +++++++++++++- art/dAL8F3TW5GN54MCBB/art.json | 14 +++++++++++++- art/dBc4DnM9H4zxHwGcH/art.json | 14 +++++++++++++- art/dCjgtsZXnjdzATJ8P/art.json | 14 +++++++++++++- art/dCwDkmvtYAHzDGrKm/art.json | 14 +++++++++++++- art/dCyrwwNxWC4gmj7zN/art.json | 14 +++++++++++++- art/dDWeHcCfjXZ2qxCji/art.json | 14 +++++++++++++- art/dGD7KhAgWY4qfsmbJ/art.json | 14 +++++++++++++- art/dGs6fdtenLWLjmBEE/art.json | 14 +++++++++++++- art/dJ7LxrXfRuAz7PLaC/art.json | 14 +++++++++++++- art/dJQHunZMaGr5ssiey/art.json | 14 +++++++++++++- art/dJTCRw4XXeXH2rYMd/art.json | 14 +++++++++++++- art/dJZ8nxPG2JKPBwHut/art.json | 14 +++++++++++++- art/dKGqajerwQQwap65w/art.json | 14 +++++++++++++- art/dLkqdiAkHgpKZWw9c/art.json | 14 +++++++++++++- art/dLyBG6jnNceKnhqbB/art.json | 14 +++++++++++++- art/dMRx2bNxuYsRKSHKt/art.json | 14 +++++++++++++- art/dMZsJyyPW2EgjrH4P/art.json | 14 +++++++++++++- art/dMsa7ScyoyExY3Cxk/art.json | 14 +++++++++++++- art/dN7ijsBkvACZ3Nv8B/art.json | 14 +++++++++++++- art/dPFqiAgc3g3evvDtS/art.json | 14 +++++++++++++- art/dPkbvz9nuwNJRn9oB/art.json | 14 +++++++++++++- art/dPsnyuwF6HxdEJMAd/art.json | 14 +++++++++++++- art/dQM2bdFTuo6XKyJ9B/art.json | 14 +++++++++++++- art/dT5B8hrDztDwvmxaK/art.json | 14 +++++++++++++- art/dTLifasffbDKw6x9Q/art.json | 14 +++++++++++++- art/dWK8BJdJy3MCus377/art.json | 14 +++++++++++++- art/dWoGmbWvzsuG5YKwG/art.json | 14 +++++++++++++- art/dXKhFciQLSL49zDPB/art.json | 14 +++++++++++++- art/dY6antnsT68htYfWz/art.json | 14 +++++++++++++- art/dYaXs9CwnzQhAT8Kt/art.json | 14 +++++++++++++- art/dZFJfYQQ8kmuoFFpi/art.json | 14 +++++++++++++- art/daPtAnEfTEnXXXpuZ/art.json | 14 +++++++++++++- art/df3RvcwJQkovKdovf/art.json | 14 +++++++++++++- art/df7Ra8dPPtCwcsrwL/art.json | 14 +++++++++++++- art/dfb54ssJPtsdTbqaj/art.json | 14 +++++++++++++- art/dfek5Y7Cg65RmZeWJ/art.json | 14 +++++++++++++- art/dh3DHrafWfekY5Q5d/art.json | 14 +++++++++++++- art/dhbsE39FZ6S2kKtfm/art.json | 14 +++++++++++++- art/dhnTE8qmLte8dvycB/art.json | 14 +++++++++++++- art/di9ZgJzgbKZDyCan3/art.json | 14 +++++++++++++- art/dk6ee6LN5fC4Dkybg/art.json | 14 +++++++++++++- art/dmBnGPyH5KjJbneie/art.json | 14 +++++++++++++- art/do5csPmmsrqctxz3p/art.json | 14 +++++++++++++- art/dpsBkE3nfEEmeSaC8/art.json | 14 +++++++++++++- art/dtZMYXvfSW4gKJ7Mr/art.json | 14 +++++++++++++- art/duHXW2G4Ct7oCwFdN/art.json | 14 +++++++++++++- art/dufQqpoG5ZrSfdkjf/art.json | 14 +++++++++++++- art/dvzt2TN84y8LGgnsn/art.json | 14 +++++++++++++- art/dw7XrmJjH3mBbHx8u/art.json | 14 +++++++++++++- art/dwJrBDGXGSGAQkzf3/art.json | 14 +++++++++++++- art/dxaRX4ZTW7m76nQzS/art.json | 14 +++++++++++++- art/dxmjSBXBuwTbPjkQZ/art.json | 14 +++++++++++++- art/dxtwYFtYDMAdGgpJm/art.json | 14 +++++++++++++- art/dyCMb2QsTKKjPQptu/art.json | 14 +++++++++++++- art/dzCu7QoEjYiNTWqFD/art.json | 14 +++++++++++++- art/dzGkjTSDwbutqCp57/art.json | 14 +++++++++++++- art/e6LP3FE5P3qePgJk6/art.json | 14 +++++++++++++- art/e96He2kRbxRk7o6N8/art.json | 14 +++++++++++++- art/e9b2X5LXefT2W9oh4/art.json | 14 +++++++++++++- art/eBpxuAodpyWjT6Asr/art.json | 14 +++++++++++++- art/eCTzFjq4bRAxBAC7h/art.json | 14 +++++++++++++- art/eCgwSmrFuafedggBy/art.json | 14 +++++++++++++- art/eCtymAejxmi75Fg78/art.json | 14 +++++++++++++- art/eDqQBCKFjn2a35csa/art.json | 14 +++++++++++++- art/eE6QrFjkFRdezQsuW/art.json | 14 +++++++++++++- art/eGvHvcKj3nHkhw9C6/art.json | 14 +++++++++++++- art/eH67ZJMsPmJWmEdoK/art.json | 14 +++++++++++++- art/eJGcWNyj42atTeXsz/art.json | 14 +++++++++++++- art/eKqemqRBragaEs55Y/art.json | 14 +++++++++++++- art/eLAMSS8iwH7ip3sS6/art.json | 14 +++++++++++++- art/eMAJ5HydzdzbnzduF/art.json | 14 +++++++++++++- art/eN9F6DmmRZpCrr3v4/art.json | 14 +++++++++++++- art/ePRvbCFXEeYiRFk7c/art.json | 14 +++++++++++++- art/ePt2CZtNzQzvEYWAy/art.json | 14 +++++++++++++- art/eQWS62YSydqjQaeSx/art.json | 14 +++++++++++++- art/eQxQuMzXiCEc7rMYz/art.json | 14 +++++++++++++- art/eXXeb2MwbgjMFutev/art.json | 14 +++++++++++++- art/eXepJNmr5e5q3DjWv/art.json | 14 +++++++++++++- art/eY9pGfw52QeELpY2y/art.json | 14 +++++++++++++- art/eYuBQN69mTZCKaGdB/art.json | 14 +++++++++++++- art/easEJ6iaXWeeR99Gj/art.json | 14 +++++++++++++- art/edJC7G3Sd2mixhfmg/art.json | 14 +++++++++++++- art/ef4RfHy9WFPvn43T6/art.json | 14 +++++++++++++- art/efitgBPvLvfEFCPvW/art.json | 14 +++++++++++++- art/eh4QC67q3gssnkYYv/art.json | 14 +++++++++++++- art/ehS7PTfScc8NxvEpP/art.json | 14 +++++++++++++- art/ehyZCh7WmuNeadkky/art.json | 14 +++++++++++++- art/eiJ4hxesSBMicxFyJ/art.json | 14 +++++++++++++- art/eiQJGkMsgvxpx6Ejq/art.json | 14 +++++++++++++- art/ek2r2jAkKe4kBeGaN/art.json | 14 +++++++++++++- art/em6g5TXFWMofu5RHa/art.json | 14 +++++++++++++- art/emCzESvMqeynBHRzP/art.json | 14 +++++++++++++- art/emui4ppu4ZWu8iLwB/art.json | 14 +++++++++++++- art/enNTxR7RgQNk53fmx/art.json | 14 +++++++++++++- art/epH8co5uSwMkCYZGo/art.json | 14 +++++++++++++- art/epNhofNCAKkjo88eT/art.json | 14 +++++++++++++- art/eq2kbtwQE5YiHEkMu/art.json | 14 +++++++++++++- art/eq35fsTk4w4ZA3LQF/art.json | 14 +++++++++++++- art/eqcXviN95rTrGxwyW/art.json | 14 +++++++++++++- art/ercnsAaqXuGhCCCAe/art.json | 14 +++++++++++++- art/ercvafg86xKeMKPY4/art.json | 14 +++++++++++++- art/esptz5bbgn8NtZkbN/art.json | 14 +++++++++++++- art/esyFcPb5cskLWGgGE/art.json | 14 +++++++++++++- art/etLPNmJ9oBq9QDcz6/art.json | 14 +++++++++++++- art/euQ9yLGh4rWre3oqK/art.json | 14 +++++++++++++- art/ev52maygjcBnfCzwC/art.json | 14 +++++++++++++- art/evAAwbGtYJLZKPkMq/art.json | 14 +++++++++++++- art/ewJGvmyLg4AN7sTJA/art.json | 14 +++++++++++++- art/exWL4hKkpkDAwMwS5/art.json | 14 +++++++++++++- art/eyJnMiGS99BJjeDGt/art.json | 14 +++++++++++++- art/eznAa7bmAaN8kBHXd/art.json | 14 +++++++++++++- art/f24WmWznGNdEXEQTu/art.json | 14 +++++++++++++- art/f2btT6XFeFnaFopph/art.json | 14 +++++++++++++- art/f2eQBt4FaMKf9efrz/art.json | 14 +++++++++++++- art/f2knCxK4pMLFDEZWB/art.json | 14 +++++++++++++- art/f5etc59cCAN5qsa9G/art.json | 14 +++++++++++++- art/f6Qou7QNuj5onaJeQ/art.json | 14 +++++++++++++- art/f7oq7MsfTgoAMeXX2/art.json | 14 +++++++++++++- art/f9MztjgyzxAHdqsxy/art.json | 14 +++++++++++++- art/fAnatQu5aZpC5Dmby/art.json | 14 +++++++++++++- art/fDJEaZrfDnKxNGck3/art.json | 14 +++++++++++++- art/fDPvNsyqX8zmv9hxa/art.json | 14 +++++++++++++- art/fFEpFHbdC4ecFLuaB/art.json | 14 +++++++++++++- art/fGCtwoQy8Mc8RK2pY/art.json | 14 +++++++++++++- art/fHqs32thqJc7j2QR3/art.json | 14 +++++++++++++- art/fHwLHN2yrXWfnAnbn/art.json | 14 +++++++++++++- art/fKArPmJPF5sgaDbNK/art.json | 14 +++++++++++++- art/fKPK987qvE5gGHcWS/art.json | 14 +++++++++++++- art/fKYmuHmgGeNTPniPK/art.json | 14 +++++++++++++- art/fLedbHFSXD9E4aMSv/art.json | 14 +++++++++++++- art/fM43AivGvoEWBm7G7/art.json | 14 +++++++++++++- art/fMPBsNwkev8DSYD72/art.json | 14 +++++++++++++- art/fNYWAGT9SkHb3bQrk/art.json | 14 +++++++++++++- art/fNyYuzQ69eREkJCMq/art.json | 14 +++++++++++++- art/fRJj6RxaarH7Lp4HG/art.json | 14 +++++++++++++- art/fRcccsZ7jqFGGPAdJ/art.json | 14 +++++++++++++- art/fRmvmXuk82tiLXCRX/art.json | 14 +++++++++++++- art/fSdF3Y59NoqNegw7y/art.json | 14 +++++++++++++- art/fSom8rCSmFz3LJYiZ/art.json | 14 +++++++++++++- art/fSz8brGjX9TATFZLC/art.json | 14 +++++++++++++- art/fTYSeXRBwwDXJEac4/art.json | 14 +++++++++++++- art/fWTyJ5884wxLdY28e/art.json | 14 +++++++++++++- art/fXX9cns72XG97J3rk/art.json | 14 +++++++++++++- art/fXjL89sHjq7Pkzz5X/art.json | 14 +++++++++++++- art/fcAdcLhQi59meuwEa/art.json | 14 +++++++++++++- art/fcxZGWMjswfrJWNLZ/art.json | 14 +++++++++++++- art/fdRMRscY4Te3iZPBF/art.json | 14 +++++++++++++- art/fe73gvqsKrgRYgqGX/art.json | 14 +++++++++++++- art/fe8yM9E3pBta2SbNa/art.json | 14 +++++++++++++- art/ffWaRfDRtqa8osv3y/art.json | 14 +++++++++++++- art/fh74hqW59nbsQkT6N/art.json | 14 +++++++++++++- art/fhgo4viQjn4Y4cfck/art.json | 14 +++++++++++++- art/fj8P6N2AkQHBBaTmZ/art.json | 14 +++++++++++++- art/fjN25zTwqLYMCNkJ4/art.json | 14 +++++++++++++- art/fmmQsNyrdyjA3226x/art.json | 14 +++++++++++++- art/fnQrnopggmFfZmzMG/art.json | 14 +++++++++++++- art/foJQ7C4rZnwuJSDxD/art.json | 14 +++++++++++++- art/fpcEBXb2uz75rjixv/art.json | 14 +++++++++++++- art/fs6GHW2crknZmzoWy/art.json | 14 +++++++++++++- art/fssfXPCEwPLZfQFqp/art.json | 14 +++++++++++++- art/ftJv2CdwjJ5jJDa3k/art.json | 14 +++++++++++++- art/fvQTW8AHjW54ifFbh/art.json | 14 +++++++++++++- art/fvQbw8FtZzmvQG4Wz/art.json | 14 +++++++++++++- art/fwuLjHMQenJtNXJxZ/art.json | 14 +++++++++++++- art/fxYFNf9d36E5GgBen/art.json | 14 +++++++++++++- art/fxwcEhippPALwji4k/art.json | 14 +++++++++++++- art/fytzNu7M5YR27TpEP/art.json | 14 +++++++++++++- art/g2PZWgGp6YYe9CWwE/art.json | 14 +++++++++++++- art/g4ZutuWewAGLeBJHx/art.json | 14 +++++++++++++- art/g5Ygw3eYNe7DzpA3a/art.json | 14 +++++++++++++- art/g79cZoGhWhgn9tKfr/art.json | 14 +++++++++++++- art/g7wWJ4yKzThxqkmN5/art.json | 14 +++++++++++++- art/gAsFJCDiWiyemHoSX/art.json | 14 +++++++++++++- art/gAx4XYrQhtffjGR2v/art.json | 14 +++++++++++++- art/gBa8KAJTb6MqbNzBK/art.json | 14 +++++++++++++- art/gBqWsGGvjPsKNMGja/art.json | 14 +++++++++++++- art/gCLHvWrWsPsbDjksh/art.json | 14 +++++++++++++- art/gDfmqnLHBbcKghmwL/art.json | 14 +++++++++++++- art/gEkij9HTZTy6b4tRf/art.json | 14 +++++++++++++- art/gFjsSoxA5bwzxPwXc/art.json | 14 +++++++++++++- art/gJPot9c9wsbfuT6Md/art.json | 14 +++++++++++++- art/gKbNhtAK4AqZvFaQM/art.json | 14 +++++++++++++- art/gKzj7CPEr29FdEonW/art.json | 14 +++++++++++++- art/gMC34jEobWC2ofXfB/art.json | 14 +++++++++++++- art/gQ93FbmuckckWhhix/art.json | 14 +++++++++++++- art/gQTuwGmLKEGMHfB3x/art.json | 14 +++++++++++++- art/gTDpcK8Kws8upyKKp/art.json | 14 +++++++++++++- art/gWF8YEaiS44osT2K7/art.json | 14 +++++++++++++- art/gX32iAvezAbinbMJz/art.json | 14 +++++++++++++- art/gZNitbfDuN5pSwLf3/art.json | 14 +++++++++++++- art/gZgDK3bN2z7xtma6A/art.json | 14 +++++++++++++- art/gZjPchBFJAGSk4ZTK/art.json | 14 +++++++++++++- art/gb48Jjp6zYH7bcWGN/art.json | 14 +++++++++++++- art/gb4JMDjdT2iyyCLdE/art.json | 14 +++++++++++++- art/gbv2z926cb7MWF3Gy/art.json | 14 +++++++++++++- art/gfBdkzchpT5DPGwqE/art.json | 14 +++++++++++++- art/ghFixTy38ux4F235T/art.json | 14 +++++++++++++- art/ghH8XPT3kfdig8cXX/art.json | 14 +++++++++++++- art/gkNsynXB23Y8WhASo/art.json | 14 +++++++++++++- art/gkrLbb6TwrbveHw49/art.json | 14 +++++++++++++- art/gqGmyfsEh6zDQWsvA/art.json | 14 +++++++++++++- art/gqJ33JsAWdcuKjJHH/art.json | 14 +++++++++++++- art/grkNAy4oE5JqXxyMr/art.json | 14 +++++++++++++- art/gs5Ttw4zaPA7LZrNS/art.json | 14 +++++++++++++- art/gszWKmYHHf8HxkXiS/art.json | 14 +++++++++++++- art/gue44sXxDW5AceuTX/art.json | 14 +++++++++++++- art/gunbdr7k6M6z5hL8B/art.json | 14 +++++++++++++- art/gxQFmkRMFP6oHs6Qb/art.json | 14 +++++++++++++- art/gxSjsgjmXdmzAwFJY/art.json | 14 +++++++++++++- art/gxfqzX2z6JLPodtww/art.json | 14 +++++++++++++- art/gyyeCLrtNBFwdqzD3/art.json | 14 +++++++++++++- art/gyyfnx8KyXiz9QvWn/art.json | 14 +++++++++++++- art/gztz5WvpLypyur8Ls/art.json | 14 +++++++++++++- art/h2d7j2tEBmEKvpKGQ/art.json | 14 +++++++++++++- art/h3CiR79ZrnrLiiXjZ/art.json | 14 +++++++++++++- art/h3FP6QYiZoQbwACiy/art.json | 14 +++++++++++++- art/h4dmaWw9awheH5EG6/art.json | 14 +++++++++++++- art/h55dGWLy6iRdoRh3j/art.json | 14 +++++++++++++- art/h5s7DzcTgYKsXec6J/art.json | 14 +++++++++++++- art/h6BvsMWiHpgwT5Nhh/art.json | 14 +++++++++++++- art/h8Ao3xWvFcr2BjkPn/art.json | 14 +++++++++++++- art/h8BkWLf8vzaHjSvsv/art.json | 14 +++++++++++++- art/hDFNWtShKnbPxsk5g/art.json | 14 +++++++++++++- art/hDdt5XinuSqDPHKS9/art.json | 14 +++++++++++++- art/hDtJF6ShctCpNfZNt/art.json | 14 +++++++++++++- art/hFWjmNANJteP9NeAy/art.json | 14 +++++++++++++- art/hGb3X2yH769jCbfDy/art.json | 14 +++++++++++++- art/hGiSXNAT8jpQc5o3a/art.json | 14 +++++++++++++- art/hJ9T5D48jyNh2Ziaf/art.json | 14 +++++++++++++- art/hJS9jEgToDSA94vDA/art.json | 14 +++++++++++++- art/hKYwCnTKop5ukPrGH/art.json | 14 +++++++++++++- art/hKjwz37yK8sehZyC2/art.json | 14 +++++++++++++- art/hMGCCTasLLBPQjRCG/art.json | 14 +++++++++++++- art/hNysLh7LeD77n8RsG/art.json | 14 +++++++++++++- art/hQ22f6sNbz8Dczs4G/art.json | 14 +++++++++++++- art/hTATeX2kPux2LeQdD/art.json | 14 +++++++++++++- art/hXDoWkGSTBFBQGXnN/art.json | 14 +++++++++++++- art/hXusy4KBvn6oHTu4Q/art.json | 14 +++++++++++++- art/hXxx7rTq8dZYFKSs5/art.json | 14 +++++++++++++- art/hbcHxbJiDeAnvZ9Bf/art.json | 14 +++++++++++++- art/hdoyK6tHCoauDPZQL/art.json | 14 +++++++++++++- art/hffRc9FH8TMNKECkJ/art.json | 14 +++++++++++++- art/hhDozSmRkW3ExvhoP/art.json | 14 +++++++++++++- art/hhK98FuyYZiyCZfjD/art.json | 14 +++++++++++++- art/hhSEYyu9RaWDJ54wu/art.json | 14 +++++++++++++- art/hhsdvkiJ32bCTcezv/art.json | 14 +++++++++++++- art/hjpDj9NpsfdHuD6Ya/art.json | 14 +++++++++++++- art/hjusZffXbWpbtMDh7/art.json | 14 +++++++++++++- art/hmpjw2dG3vhXJ4Mhu/art.json | 14 +++++++++++++- art/hnZQWotZNLbSjY9bs/art.json | 14 +++++++++++++- art/hppyeGQduA2gx5GYx/art.json | 14 +++++++++++++- art/hrgNyucvZAE9WwRLF/art.json | 14 +++++++++++++- art/hsjAgdurCB49NCkC7/art.json | 14 +++++++++++++- art/huDQEAMcWYoP6hWGS/art.json | 14 +++++++++++++- art/huHtobGCf37pyxqDW/art.json | 14 +++++++++++++- art/hvfx2JX4Hfg7zccE5/art.json | 14 +++++++++++++- art/hwNhHN2Dy2kDpwmBD/art.json | 14 +++++++++++++- art/hwZKXhEqYhJTNoSZX/art.json | 14 +++++++++++++- art/hx3wegzB6mT7kmxAg/art.json | 14 +++++++++++++- art/hx9o8G4NbrqkXa8dd/art.json | 14 +++++++++++++- art/hzwNZWmd4xaC2Z6Wa/art.json | 14 +++++++++++++- art/i2H6FMn7RveYhnm4D/art.json | 14 +++++++++++++- art/i2MzwYgwq9p5mJ42Q/art.json | 14 +++++++++++++- art/i3Zcb8RFiak58hsFx/art.json | 14 +++++++++++++- art/i45xFrKEbpDpjYMW8/art.json | 14 +++++++++++++- art/i47npurSmZHhWuwbZ/art.json | 14 +++++++++++++- art/i6KKW4mstdDQe6aQK/art.json | 14 +++++++++++++- art/i7RCxecdC6AJ3heyF/art.json | 14 +++++++++++++- art/iAGxyHrFa3k6ZJq5k/art.json | 14 +++++++++++++- art/iCRwaQsZvFQ2eLheK/art.json | 14 +++++++++++++- art/iE3Xz7bewdDm3shFC/art.json | 14 +++++++++++++- art/iEqWJsdh8qGqoogEL/art.json | 14 +++++++++++++- art/iGf4owSji9QC6P8yF/art.json | 14 +++++++++++++- art/iHAobXHhdNFgDxEiP/art.json | 14 +++++++++++++- art/iJobHmTq8ahMEWFSG/art.json | 14 +++++++++++++- art/iKJAEsvWRjffu2QnA/art.json | 14 +++++++++++++- art/iLmsLpSgTGLkxKPxP/art.json | 14 +++++++++++++- art/iPNXnwa34wBgSSDGd/art.json | 14 +++++++++++++- art/iPiDjpBYDPGFTGp8Y/art.json | 14 +++++++++++++- art/iQ3Lo8pe7QqDdz8qi/art.json | 14 +++++++++++++- art/iQAtnkJRC8XtvT4tW/art.json | 14 +++++++++++++- art/iQGt7fDGEeR4vD6ez/art.json | 14 +++++++++++++- art/iRS5hcGrNPG5aAf3w/art.json | 14 +++++++++++++- art/iSvLhZ7QzyjMW2uAh/art.json | 14 +++++++++++++- art/iXKHFGqaAHrc6rZg2/art.json | 14 +++++++++++++- art/iZwjTQ6SHPHX7EjSE/art.json | 14 +++++++++++++- art/ibwNoyQhKR6kMmj3j/art.json | 14 +++++++++++++- art/icmkfJD93vQnbZQfB/art.json | 14 +++++++++++++- art/icyvWgd8MgBnNT9rn/art.json | 14 +++++++++++++- art/ieaN3Qkmk29Y5CSpG/art.json | 14 +++++++++++++- art/ig5e2CN4AbunM7REm/art.json | 14 +++++++++++++- art/iiAQmTAWuGuLLKPiP/art.json | 14 +++++++++++++- art/iiz8rMJTpnjWQ9igc/art.json | 14 +++++++++++++- art/ijffwwNcMKiZYCxge/art.json | 14 +++++++++++++- art/iko4zHPGCfdPcBr5s/art.json | 14 +++++++++++++- art/imESwJiuP9QDzXiWF/art.json | 14 +++++++++++++- art/ioLq6J2WDmNXguCmD/art.json | 14 +++++++++++++- art/ipJH3aZcHmkBCGYZC/art.json | 14 +++++++++++++- art/iqkc2EX6jbhg7NbT4/art.json | 14 +++++++++++++- art/ircs8vH9TsNMjuWh4/art.json | 14 +++++++++++++- art/isgED2R7wSztcgg4J/art.json | 14 +++++++++++++- art/it3WZX5QHCABK6s7R/art.json | 14 +++++++++++++- art/itFYHyLvFpbtiqvaP/art.json | 14 +++++++++++++- art/iu7GYL94b7Hm5JyvB/art.json | 14 +++++++++++++- art/iuT7hG7CEXwYqShtA/art.json | 14 +++++++++++++- art/ivFr7kf8D46ckANG4/art.json | 14 +++++++++++++- art/ivk9RqX2vB24mkdwL/art.json | 14 +++++++++++++- art/iw8FH3ButdB4ZzpsQ/art.json | 14 +++++++++++++- art/iwn76AsDsRRmr5bae/art.json | 14 +++++++++++++- art/ixPJFSrp6TMRKW4xF/art.json | 14 +++++++++++++- art/ixr3Pka4ChbtDzobh/art.json | 14 +++++++++++++- art/iycvXPQfzvSbzg9JP/art.json | 14 +++++++++++++- art/iye5kiPcXb3MgKAAN/art.json | 14 +++++++++++++- art/j2TsACSvPYuDJ2t2X/art.json | 14 +++++++++++++- art/j5EHhnBzo2XdxiCTJ/art.json | 14 +++++++++++++- art/j7WftWuJtPTYyhcxG/art.json | 14 +++++++++++++- art/j7geNJncnTGfxf9ZX/art.json | 14 +++++++++++++- art/j7v3Ha4S2hwxhSCi9/art.json | 14 +++++++++++++- art/j83YWD4DHLXrjrvxf/art.json | 14 +++++++++++++- art/j99N9DxvqWDcDFv84/art.json | 14 +++++++++++++- art/j9rdg6agmx5hRCbSu/art.json | 14 +++++++++++++- art/jBYxLqMCJXqt6uG5C/art.json | 14 +++++++++++++- art/jBpixD335L3o2unKj/art.json | 14 +++++++++++++- art/jC6yjCA9eDW8oasNA/art.json | 14 +++++++++++++- art/jDNMJCu4S7DSRconL/art.json | 14 +++++++++++++- art/jDZno8kPiDKAcaZgJ/art.json | 14 +++++++++++++- art/jDrqfnTPaPAoShgv2/art.json | 14 +++++++++++++- art/jETzmmycobJrRvXH9/art.json | 14 +++++++++++++- art/jEoQzSA24YCzYycNu/art.json | 14 +++++++++++++- art/jH6uYuSxKSryZXLT8/art.json | 14 +++++++++++++- art/jKgXdk6mRHxFesr5L/art.json | 14 +++++++++++++- art/jLife2TGRq2pa6fXN/art.json | 14 +++++++++++++- art/jLsTszfmYpHj49XKx/art.json | 14 +++++++++++++- art/jMGgLqSnkaQD9ZYns/art.json | 14 +++++++++++++- art/jSqNQQKbSrqoB8rrP/art.json | 14 +++++++++++++- art/jXYNwHmBj5miEkeS6/art.json | 14 +++++++++++++- art/jY9RXPEf9rZ5Gv89N/art.json | 14 +++++++++++++- art/jYsMzcSq8HDB28JWY/art.json | 14 +++++++++++++- art/jZbLsPiJ43jvcaq7M/art.json | 14 +++++++++++++- art/jaG2f5XtrcpcNSePf/art.json | 14 +++++++++++++- art/jabgpFXjj8umhyfzH/art.json | 14 +++++++++++++- art/japgmuqb6SYNuHBb4/art.json | 14 +++++++++++++- art/jcatqfjkzF3ET7965/art.json | 14 +++++++++++++- art/jdAf5zLP6coQorz8g/art.json | 14 +++++++++++++- art/jg5dRsCi6xDSFyCJ9/art.json | 14 +++++++++++++- art/jgpwL4MjxvpeqZ2QN/art.json | 14 +++++++++++++- art/jgwXiSzEkQzK3X2Fx/art.json | 14 +++++++++++++- art/ji6xYT7wScL9QmPmH/art.json | 14 +++++++++++++- art/jiYAbdiu7oseTcBzg/art.json | 14 +++++++++++++- art/jjFQmoBi82cZBgTCj/art.json | 14 +++++++++++++- art/jjpd8XtJ5nJAcmyLh/art.json | 14 +++++++++++++- art/jmoBvZevCB2QeEtAN/art.json | 14 +++++++++++++- art/jpy7t2fKy3TKStRPG/art.json | 14 +++++++++++++- art/jqQ7JEPy2w8vDnkiC/art.json | 14 +++++++++++++- art/jqRhLrTMA3GFEk2m5/art.json | 14 +++++++++++++- art/jqwWnsecfchT8qKg8/art.json | 14 +++++++++++++- art/jsKeJ8QviCT2KuxC4/art.json | 14 +++++++++++++- art/jtB7xCrYixyTqmxB8/art.json | 14 +++++++++++++- art/jtFAXNm8ngq4kTFhA/art.json | 14 +++++++++++++- art/jtaqrSsdjgWqPPqJ4/art.json | 14 +++++++++++++- art/ju4uMD2zrxMd4z9HK/art.json | 14 +++++++++++++- art/juJGnxZcspgX7dGMB/art.json | 14 +++++++++++++- art/juXJpMEpt8YSWxSWY/art.json | 14 +++++++++++++- art/jvGyFQeYoge2TgFbx/art.json | 14 +++++++++++++- art/k2vXaRzFT8Nqdwfit/art.json | 14 +++++++++++++- art/k4wpsPnafQ4YQs6dJ/art.json | 14 +++++++++++++- art/k5BBCA2vPq6sY6xv5/art.json | 14 +++++++++++++- art/k5hPuKGzdkGEvfoZk/art.json | 14 +++++++++++++- art/k5izvwNxYrHYx6WBr/art.json | 14 +++++++++++++- art/k7w6BKgeSJxKx3Z6L/art.json | 14 +++++++++++++- art/k92jG6hXfdYZmDDxp/art.json | 14 +++++++++++++- art/k9wLKsfTxHABY5b7P/art.json | 14 +++++++++++++- art/kAANx8FwJoSeR9B4c/art.json | 14 +++++++++++++- art/kAmQqozAAzPSXNaps/art.json | 14 +++++++++++++- art/kDijkHtJWk62e82Du/art.json | 14 +++++++++++++- art/kEah2e6FjeaExoiWN/art.json | 14 +++++++++++++- art/kFw99h7A55BoqmFND/art.json | 14 +++++++++++++- art/kFydmLK7cBEcShhrj/art.json | 14 +++++++++++++- art/kHbJM2qswt6BscdP3/art.json | 14 +++++++++++++- art/kJKd3eS8axidSmEcA/art.json | 14 +++++++++++++- art/kJKq7oy8zBvieKhsE/art.json | 14 +++++++++++++- art/kQB2kyZz5geDYpNeo/art.json | 14 +++++++++++++- art/kR26egNf7BwrsJHyM/art.json | 14 +++++++++++++- art/kRDzJyojeaeAei2M4/art.json | 14 +++++++++++++- art/kReqbFTiLEP7PXoRp/art.json | 14 +++++++++++++- art/kRguYk2Yft2HDLmiP/art.json | 14 +++++++++++++- art/kT6fN7Mtscfe8NeGA/art.json | 14 +++++++++++++- art/kTER7eQ7zASKMtkpo/art.json | 14 +++++++++++++- art/kWRaQgwjzbFw55cxw/art.json | 14 +++++++++++++- art/kWmwejucFuShxKNSa/art.json | 14 +++++++++++++- art/kcWfwPALkyhAgj6ET/art.json | 14 +++++++++++++- art/ke5bF6hENE8zphaSp/art.json | 14 +++++++++++++- art/keYAR2P7hmm2ei9uF/art.json | 14 +++++++++++++- art/kga2uesxPaH3HJqyT/art.json | 14 +++++++++++++- art/khayHGH4sQWpPkn92/art.json | 14 +++++++++++++- art/khesbmKPst2TQsnnL/art.json | 14 +++++++++++++- art/khgXvsD296RRokHhE/art.json | 14 +++++++++++++- art/kiZueaqhT8s7yr7Tr/art.json | 14 +++++++++++++- art/kmHZWuJ5wjmz7RQzS/art.json | 14 +++++++++++++- art/kmN3hqhTHv4SCqYcx/art.json | 14 +++++++++++++- art/kmm2Kb8Ti4vcYGQri/art.json | 14 +++++++++++++- art/ko66wgrdNeNbx9WDz/art.json | 14 +++++++++++++- art/koFtCvuibJTEPuswi/art.json | 14 +++++++++++++- art/kpxXuKKj3zwRaQ23J/art.json | 14 +++++++++++++- art/kqeeKhm5BKJ8vexmL/art.json | 14 +++++++++++++- art/kuj37HBHLw5zWqqTD/art.json | 14 +++++++++++++- art/kwFY2DhDLc57jBEKg/art.json | 14 +++++++++++++- art/kwpkNNSAmpsM6G7DB/art.json | 14 +++++++++++++- art/kyrjHeuSM5skDfpNo/art.json | 14 +++++++++++++- art/m64jEsLp4hidcsd7a/art.json | 14 +++++++++++++- art/m6Sw7fXzNji9JqQRk/art.json | 14 +++++++++++++- art/m9FwKSvyF6tR6wxKy/art.json | 14 +++++++++++++- art/mAZixq6fNzd7qSpQs/art.json | 14 +++++++++++++- art/mAic85DgmMrZTGaph/art.json | 14 +++++++++++++- art/mAzBS3pdAM6PxJku9/art.json | 14 +++++++++++++- art/mBEqnn3WYWhAt7vLy/art.json | 14 +++++++++++++- art/mBsFXyLJxoL2yPqjz/art.json | 14 +++++++++++++- art/mCcXsBtD9XZ5LAoW8/art.json | 14 +++++++++++++- art/mD6W2p47kSDX2WqK4/art.json | 14 +++++++++++++- art/mDEaiqSfNT6Lxq4A7/art.json | 14 +++++++++++++- art/mEjRHW328Fknag6wR/art.json | 14 +++++++++++++- art/mFBiFkPxwQ73XQizR/art.json | 14 +++++++++++++- art/mFDp3QZvpN8MbqN9R/art.json | 14 +++++++++++++- art/mFr92RbhPmuJXKXWK/art.json | 14 +++++++++++++- art/mHgyhLsuwpJinyxDH/art.json | 14 +++++++++++++- art/mHhjmNiF2DCevuYMz/art.json | 14 +++++++++++++- art/mJLSnvDjL3N6wkYDR/art.json | 14 +++++++++++++- art/mJadpKnhXS6qgpQ5g/art.json | 14 +++++++++++++- art/mLtQNvFM6AJhHKbYq/art.json | 14 +++++++++++++- art/mM93aaccacmA9o34t/art.json | 14 +++++++++++++- art/mMNQ38uN94rxmoWBh/art.json | 14 +++++++++++++- art/mMtFqJYFAoMttvdnt/art.json | 14 +++++++++++++- art/mNBny7JXpBGwQnMwG/art.json | 14 +++++++++++++- art/mP36iPeKidJ9NCRwX/art.json | 14 +++++++++++++- art/mQ966EQcC2e2h8cjZ/art.json | 14 +++++++++++++- art/mQuMhKJA2PG4x8j7h/art.json | 14 +++++++++++++- art/mSDHF7AjBowN86DnJ/art.json | 14 +++++++++++++- art/mTJbRgMm8M8FK2iEr/art.json | 14 +++++++++++++- art/mTN89iZPCffApkuoc/art.json | 14 +++++++++++++- art/mTt5zkdxxpb2F9px7/art.json | 14 +++++++++++++- art/mYvJWJgSmFTeFydSy/art.json | 14 +++++++++++++- art/maYBia4hupYbN3YjZ/art.json | 14 +++++++++++++- art/mar5ufbpzahGtPyPj/art.json | 14 +++++++++++++- art/mb3aos8CkHBeJdfkt/art.json | 14 +++++++++++++- art/mbkRD28NZpJtGu2af/art.json | 14 +++++++++++++- art/mc9ScBATcEnpry3q2/art.json | 14 +++++++++++++- art/md47PJjYvynaWJqMy/art.json | 14 +++++++++++++- art/mf6PsGZxpSdyu4gkb/art.json | 14 +++++++++++++- art/mfEsB2oGhBqM3k3Rt/art.json | 14 +++++++++++++- art/mhYRaecedTJazqZtJ/art.json | 14 +++++++++++++- art/mhyHwfLBurtz8PKsw/art.json | 14 +++++++++++++- art/mkFSba4s7DTHBu57L/art.json | 14 +++++++++++++- art/mmB8umNE8t5qoNNJo/art.json | 14 +++++++++++++- art/mmn5xXR2yHGyorvsd/art.json | 14 +++++++++++++- art/mmoaXfjg9s32v5Cpw/art.json | 14 +++++++++++++- art/mmxfYzJp3mCehkHcH/art.json | 14 +++++++++++++- art/moFoJGxvvHCxBdedE/art.json | 14 +++++++++++++- art/mp4Z7X2u8Njkoe3Cg/art.json | 14 +++++++++++++- art/mr5e8wZkAskGjnL8z/art.json | 14 +++++++++++++- art/muMdsDzPMxbycuyv8/art.json | 14 +++++++++++++- art/mwEZ5Nk4R35Dsd7eu/art.json | 14 +++++++++++++- art/mwvXDsken4yMnJbxW/art.json | 14 +++++++++++++- art/mxRdBjjLpuHvEjbMu/art.json | 14 +++++++++++++- art/myzkqKCqtFmmhW5sv/art.json | 14 +++++++++++++- art/mzP3C2u6pnBFBmKvu/art.json | 14 +++++++++++++- art/mzuqTuSfSh92e3vBL/art.json | 14 +++++++++++++- art/mzzBJYvnnyvaq6xcD/art.json | 14 +++++++++++++- art/n352wBmDRgQWXEJoN/art.json | 14 +++++++++++++- art/n4dz8Mdn2qsYrcyZq/art.json | 14 +++++++++++++- art/n52WuRHLrJFWonAPp/art.json | 14 +++++++++++++- art/n5oxjfMDGtJusocHH/art.json | 14 +++++++++++++- art/n7ehxG4s62oNWw5S3/art.json | 14 +++++++++++++- art/n7ipvkgkeT93uBRGq/art.json | 14 +++++++++++++- art/n8PMuEQT8BEAXbPgC/art.json | 14 +++++++++++++- art/nA8PWiYuAPACxMYNa/art.json | 14 +++++++++++++- art/nAEy8qdNR79dxXtex/art.json | 14 +++++++++++++- art/nBFQ8eYqePsxmzozA/art.json | 14 +++++++++++++- art/nBtQo8jPpr5y4bKyK/art.json | 14 +++++++++++++- art/nCfNyk6WPr6gn4kSB/art.json | 14 +++++++++++++- art/nCs6tW5ZLeSx7QoHm/art.json | 14 +++++++++++++- art/nDoX6LaHSyK8R6WTL/art.json | 14 +++++++++++++- art/nE9ZSZiLSQQpqKTjE/art.json | 14 +++++++++++++- art/nERwc23zjdTrQfzjD/art.json | 14 +++++++++++++- art/nEpiQXnFSAvRvgwTY/art.json | 14 +++++++++++++- art/nFBJtXmmBdabjqLW9/art.json | 14 +++++++++++++- art/nJ6nKdcJq6zW3SoZs/art.json | 14 +++++++++++++- art/nK3MebRPLrLMMTFab/art.json | 14 +++++++++++++- art/nKFqYp9wtAJ4hM3mF/art.json | 14 +++++++++++++- art/nKrw8457n4cFANsJu/art.json | 14 +++++++++++++- art/nKzNvfJNE5DnDYssR/art.json | 14 +++++++++++++- art/nL6YpkW8YvGKNEKtj/art.json | 14 +++++++++++++- art/nMNG7eAXWv6j4E7cX/art.json | 14 +++++++++++++- art/nNYZMHxiLMR2xAncW/art.json | 14 +++++++++++++- art/nNmmtcBPupGfffRQy/art.json | 14 +++++++++++++- art/nNzkBw7xZnKhutAAz/art.json | 14 +++++++++++++- art/nPZN7YmgWJCMBFrNd/art.json | 14 +++++++++++++- art/nQQ7HMj7XNCMLMMRp/art.json | 14 +++++++++++++- art/nQhGyYPDnC9Sj6iak/art.json | 14 +++++++++++++- art/nQhMRh5xxazydRqaC/art.json | 14 +++++++++++++- art/nRwxhgevXpt2torRC/art.json | 14 +++++++++++++- art/nSFFYqXN2ekMfQBzn/art.json | 14 +++++++++++++- art/nSfY6r4aXmvWBHYyo/art.json | 14 +++++++++++++- art/nTr5zAmYQHMvhjYy4/art.json | 14 +++++++++++++- art/nXTGqimMaXu22Nqjs/art.json | 14 +++++++++++++- art/nZYhMKriEvZQFNh9y/art.json | 14 +++++++++++++- art/na6qJtpJXmYZhkDxM/art.json | 14 +++++++++++++- art/naucTfFjkhTtNMkk4/art.json | 14 +++++++++++++- art/nb7JYJJLQtbayZHzh/art.json | 14 +++++++++++++- art/nbFWWPZ79M6W6WTNB/art.json | 14 +++++++++++++- art/nbFhti5B3jMmZX2Te/art.json | 14 +++++++++++++- art/nbmdLoxbimLhzSeAx/art.json | 14 +++++++++++++- art/ne6ENatKHpRDSgJRv/art.json | 14 +++++++++++++- art/nfh8MJW78b4zW9WWW/art.json | 14 +++++++++++++- art/nfi9NM8Y8gRZNqaEF/art.json | 14 +++++++++++++- art/ng6KBsxeEFsv7tEhG/art.json | 14 +++++++++++++- art/njNz396TwkoZ7JoLd/art.json | 14 +++++++++++++- art/njyWfszRg7gM9YrGs/art.json | 14 +++++++++++++- art/nmasbtKEtxwPRbcSm/art.json | 14 +++++++++++++- art/noguJmpMuwNJdw6Nc/art.json | 14 +++++++++++++- art/norTBstC9KdiXjzoH/art.json | 14 +++++++++++++- art/nqMDDwykATsSM2ABy/art.json | 14 +++++++++++++- art/nr3EiyXWLMpwoouHt/art.json | 14 +++++++++++++- art/nrAECwQ8yDDyTrSit/art.json | 14 +++++++++++++- art/nrNx2zLxLnq4oDubh/art.json | 14 +++++++++++++- art/nrQMSTcrvmsdCH5uD/art.json | 14 +++++++++++++- art/ns6ensiZRZmzyi3of/art.json | 14 +++++++++++++- art/nsh5oH8N9MEBb9AbT/art.json | 14 +++++++++++++- art/ntCWzzdvXfp33a6oz/art.json | 14 +++++++++++++- art/ntwDMXMwDGY8aMF7M/art.json | 14 +++++++++++++- art/nvRC9PH5c7FhYT6vm/art.json | 14 +++++++++++++- art/nw2X8ECBMqrgNbcQL/art.json | 14 +++++++++++++- art/nwiNgNXfwAjCRaYPP/art.json | 14 +++++++++++++- art/nwzXPvrrBth6sRSHi/art.json | 14 +++++++++++++- art/nxDSonR2aWTKY6XYt/art.json | 14 +++++++++++++- art/nxbZAMQjGvme7F55J/art.json | 14 +++++++++++++- art/nxqCRh7kbHBXK4qNn/art.json | 14 +++++++++++++- art/ny5RDoPy8ubuGtKS6/art.json | 14 +++++++++++++- art/nyGuXdDQvXKEPcSGJ/art.json | 14 +++++++++++++- art/nyvAkYFYd4Ffhu7Gz/art.json | 14 +++++++++++++- art/o2p6Z9SdrQn7eafB9/art.json | 14 +++++++++++++- art/o39WoEQsYbe48X2id/art.json | 14 +++++++++++++- art/o3FG9dxvZ25tAQFxj/art.json | 14 +++++++++++++- art/o3iK4vsbQQx2dD4jM/art.json | 14 +++++++++++++- art/o8GYn89ZNMgQTnQut/art.json | 14 +++++++++++++- art/oBkFr7rtycBbgMasK/art.json | 14 +++++++++++++- art/oBmtsD4bYK6h3htfS/art.json | 14 +++++++++++++- art/oEaayNGujJaMMkRSu/art.json | 14 +++++++++++++- art/oG23xNxiPkfCLufzk/art.json | 14 +++++++++++++- art/oJEAooRzirpb8qcPe/art.json | 14 +++++++++++++- art/oJQe4ewvBJqv3RxZX/art.json | 14 +++++++++++++- art/oJdntdCZF5fpa95wk/art.json | 14 +++++++++++++- art/oLoR8sPXf6aPStvw8/art.json | 14 +++++++++++++- art/oMwCvkkRyEiZkio4h/art.json | 14 +++++++++++++- art/oNxBgiL2gw39fW6DS/art.json | 14 +++++++++++++- art/oQwndAmHzdhn3TLGK/art.json | 14 +++++++++++++- art/oQzXFjHPCApgXWGq3/art.json | 14 +++++++++++++- art/oRdsbtoX2Yngp5jeC/art.json | 14 +++++++++++++- art/oX5wEFKffEhvZmeJT/art.json | 14 +++++++++++++- art/oXxzi5z7poEFFGEkQ/art.json | 14 +++++++++++++- art/oYPxM5nT76rkag9tD/art.json | 14 +++++++++++++- art/ob22bGQDdRk6wsWTw/art.json | 14 +++++++++++++- art/obL3NXCsSpjdP4EX9/art.json | 14 +++++++++++++- art/obrPubQ8WrCrbvYfb/art.json | 14 +++++++++++++- art/ocZSLuzxqD2QALRCq/art.json | 14 +++++++++++++- art/odJ6uwG5QzaD47cTh/art.json | 14 +++++++++++++- art/ofYQfSm7FHtddg7on/art.json | 14 +++++++++++++- art/ogZuw7WfJkAypj7nW/art.json | 14 +++++++++++++- art/ohBmRghggdTnjtnNi/art.json | 14 +++++++++++++- art/oiHNm3fKqWoxXW5yJ/art.json | 14 +++++++++++++- art/ojPoZ3NHuEgtAPr3Z/art.json | 14 +++++++++++++- art/omsdK8ycyfF9ofeYS/art.json | 14 +++++++++++++- art/ooyoRuuYEYCGkfLhx/art.json | 14 +++++++++++++- art/opSgihs7RaD5mY8E3/art.json | 14 +++++++++++++- art/owafrZFoFvRzyqEL6/art.json | 14 +++++++++++++- art/oxrytziMEpETXEtcv/art.json | 14 +++++++++++++- art/oyvKbFbwkDRrreeMy/art.json | 14 +++++++++++++- art/ozQWQuhmD57BYJsPh/art.json | 14 +++++++++++++- art/p2AWNesbs8S8c9WaR/art.json | 14 +++++++++++++- art/p2aq6zzbjEuF3wArG/art.json | 14 +++++++++++++- art/p357zGcrjjsz4KYMt/art.json | 14 +++++++++++++- art/p3J4jE3L87RgWNw5f/art.json | 14 +++++++++++++- art/p3XWczEaFrc4XJCKu/art.json | 14 +++++++++++++- art/p4K2Kjnj8QoYLkffM/art.json | 14 +++++++++++++- art/p7CgySg8MmsZK4MDE/art.json | 14 +++++++++++++- art/p8TY2jvG3n6GQFuwT/art.json | 14 +++++++++++++- art/p9DefxpaJdaYTQAWZ/art.json | 14 +++++++++++++- art/p9pecgaEBJ3kz5r7g/art.json | 14 +++++++++++++- art/pAkR8AWie7zgEskjh/art.json | 14 +++++++++++++- art/pAqsg4vT33xiFePoG/art.json | 14 +++++++++++++- art/pCCMuqhftZ6T2yx6X/art.json | 14 +++++++++++++- art/pCWSvcCDfiHokP3jK/art.json | 14 +++++++++++++- art/pCY7S7Ct9Du7rc4LS/art.json | 14 +++++++++++++- art/pDA68wnR6YFYgpH8G/art.json | 14 +++++++++++++- art/pGdr2hxn77WNvKPcH/art.json | 14 +++++++++++++- art/pGvDuYEiAcZ95p7Cw/art.json | 14 +++++++++++++- art/pJM2rdtSkSBnEkMeG/art.json | 14 +++++++++++++- art/pL2zZjniYbicHizRf/art.json | 14 +++++++++++++- art/pPELYFMqZXHXgn5Yx/art.json | 14 +++++++++++++- art/pRZmCzjhGZcbAydiQ/art.json | 14 +++++++++++++- art/pRauSxj3mNSdRas9Y/art.json | 14 +++++++++++++- art/pSfPvCpxgd22izj4C/art.json | 14 +++++++++++++- art/pTwLX9y5LQfFD3iey/art.json | 14 +++++++++++++- art/pXFLLtyZTzr6G4BSt/art.json | 14 +++++++++++++- art/pYmg39piqotd25sYc/art.json | 14 +++++++++++++- art/pcFf7Ynz5GZBSca78/art.json | 14 +++++++++++++- art/pd5cBhZ239NhxnEim/art.json | 14 +++++++++++++- art/pdBhFCkcfrYsBY3P5/art.json | 14 +++++++++++++- art/pdHu6xfHPYi6Yznt5/art.json | 14 +++++++++++++- art/pezdXhrAjHoNYKCWE/art.json | 14 +++++++++++++- art/pfa9757K3NJx6euhN/art.json | 14 +++++++++++++- art/pfvzcjCrHYCpRDiaz/art.json | 14 +++++++++++++- art/pggHYRd53sWWpFR39/art.json | 14 +++++++++++++- art/pgneaCJDnJfFAzhbJ/art.json | 14 +++++++++++++- art/pheZX35Sbfgfj5ZJC/art.json | 14 +++++++++++++- art/pi26Yd2oHdMNecbqi/art.json | 14 +++++++++++++- art/piodzReMZfEvAXgh4/art.json | 14 +++++++++++++- art/pmGvqyPkPbnfcQoLm/art.json | 14 +++++++++++++- art/pnWPM9mLnuLMMHCFy/art.json | 14 +++++++++++++- art/poNyz9Zbo5iQ6HjDH/art.json | 14 +++++++++++++- art/pouFFooTnek4sRsuE/art.json | 14 +++++++++++++- art/pp2M9hcuBjqq4QFPH/art.json | 14 +++++++++++++- art/ppKnynEzM2GHfQfXo/art.json | 14 +++++++++++++- art/prW9D82SGpoazGXyC/art.json | 14 +++++++++++++- art/puW9t4JQ9LnRbMkTK/art.json | 14 +++++++++++++- art/pubHuPRcYrgB8xLXg/art.json | 14 +++++++++++++- art/puvZxbRgEiG2MK4Rp/art.json | 14 +++++++++++++- art/pvmyoREztmWqtKWdC/art.json | 14 +++++++++++++- art/pwG88jNmzsgZMjxxB/art.json | 14 +++++++++++++- art/q2CemJwQMdeCQ7S7P/art.json | 14 +++++++++++++- art/q4fMv7cFv8FYfDYw9/art.json | 14 +++++++++++++- art/q4sbfetgGafn5By2Z/art.json | 14 +++++++++++++- art/q4uaR7yAp5C3rEQ5u/art.json | 14 +++++++++++++- art/q5ixDP7gFemPmYGSG/art.json | 14 +++++++++++++- art/q6CuGQiqZmHzrJ8N3/art.json | 14 +++++++++++++- art/q7EZvDZLoN2EqR9Fa/art.json | 14 +++++++++++++- art/q9BoWL6vYgWMPi8CP/art.json | 14 +++++++++++++- art/q9Fv9bJfBujZM8GFF/art.json | 14 +++++++++++++- art/q9kGY6PexnYDi9oCF/art.json | 14 +++++++++++++- art/q9prYaawf95rZ4Bas/art.json | 14 +++++++++++++- art/qA2y7ctcsE5EDRetu/art.json | 14 +++++++++++++- art/qAx2pkLWXDYQgRtq8/art.json | 14 +++++++++++++- art/qB4krC8RnH5HEFLww/art.json | 14 +++++++++++++- art/qCsikb8WubwZjoq9G/art.json | 14 +++++++++++++- art/qELXXCPFytjJabB9R/art.json | 14 +++++++++++++- art/qF38BqQYdKFFENMag/art.json | 14 +++++++++++++- art/qGALguswrydAHGpCK/art.json | 14 +++++++++++++- art/qGKmWQ4t3CedrMdN2/art.json | 14 +++++++++++++- art/qKGoihMGbyYe64imT/art.json | 14 +++++++++++++- art/qL56Nfe9M96bTaqYj/art.json | 14 +++++++++++++- art/qMttNCuB7HFezcMnW/art.json | 14 +++++++++++++- art/qRGKhfL3wRe3KqPob/art.json | 14 +++++++++++++- art/qRP5HEWEavfkjMpzp/art.json | 14 +++++++++++++- art/qSJ4doZdZD5GW3Y5g/art.json | 14 +++++++++++++- art/qSNjoFSsTFZD2TJcg/art.json | 14 +++++++++++++- art/qSRWCBPJwjsffzsKb/art.json | 14 +++++++++++++- art/qShjbKXDhES9fS66n/art.json | 14 +++++++++++++- art/qXiLEbW6jk6fh9rJj/art.json | 14 +++++++++++++- art/qZCxqkkWDsfd8gqGS/art.json | 14 +++++++++++++- art/qa68ydunsujhkHGZ6/art.json | 14 +++++++++++++- art/qbZNX3pQENCDwdJvA/art.json | 14 +++++++++++++- art/qbg8npmnJ2J23WmBm/art.json | 14 +++++++++++++- art/qbuQhWtriSLNLQhJF/art.json | 14 +++++++++++++- art/qcQGXHYoBo5f2Tn7W/art.json | 14 +++++++++++++- art/qcTbvPRuZkj3tL2jB/art.json | 14 +++++++++++++- art/qcXAqrGwABRk4ge5N/art.json | 14 +++++++++++++- art/qh4PDg5QYbN3rGiXh/art.json | 14 +++++++++++++- art/qividt2tw6AP89Bn7/art.json | 14 +++++++++++++- art/qjLQadWFssvPKLLCN/art.json | 14 +++++++++++++- art/qjkP6BDvEFyD6CfZC/art.json | 14 +++++++++++++- art/qof5bDEpQyu2B6HFC/art.json | 14 +++++++++++++- art/qrDZ3LmPSpDcsogS3/art.json | 14 +++++++++++++- art/qtwQmSqQKkS3ptSYN/art.json | 14 +++++++++++++- art/qvctZ7frDWv9mM6Do/art.json | 14 +++++++++++++- art/qwTpNwa5NsAWRHJvh/art.json | 14 +++++++++++++- art/qx8oB3iGpxgR5q3GB/art.json | 14 +++++++++++++- art/r2tz6uDybuH3HESEN/art.json | 14 +++++++++++++- art/r3aahkgwBNMpNsWRz/art.json | 14 +++++++++++++- art/r7gmxrfBnFMN5mm9r/art.json | 14 +++++++++++++- art/r7tpZqAYFwZsQarPw/art.json | 14 +++++++++++++- art/rABYouScqWKneNWRS/art.json | 14 +++++++++++++- art/rATARASTHX6xvj5Aa/art.json | 14 +++++++++++++- art/rAzqz9fhRarpgzdC2/art.json | 14 +++++++++++++- art/rBjrdN2CvsneEkgEk/art.json | 14 +++++++++++++- art/rBqQqL5j4orqHbrPz/art.json | 14 +++++++++++++- art/rCHrvqDdspQzQoxu9/art.json | 14 +++++++++++++- art/rDnXafrSKJvBn8q89/art.json | 14 +++++++++++++- art/rF2WSQ98F7YxgjTH9/art.json | 14 +++++++++++++- art/rGsksAzL2wfEQZTc9/art.json | 14 +++++++++++++- art/rM3dTWcBEhMiFfgEm/art.json | 14 +++++++++++++- art/rMKz3eBbT4NuADdZY/art.json | 14 +++++++++++++- art/rRHoXfKZBnnwFz4bZ/art.json | 14 +++++++++++++- art/rSBQxzNrXNNi9dKme/art.json | 14 +++++++++++++- art/rSR7ydT97j9GZb8nH/art.json | 14 +++++++++++++- art/rSizteb9kM93uMPS6/art.json | 14 +++++++++++++- art/rSvWfDGEoaa5hqb5j/art.json | 14 +++++++++++++- art/rTaKpcsBkfYB9EWPk/art.json | 14 +++++++++++++- art/rXA7dW2QF9uYGive2/art.json | 14 +++++++++++++- art/rY5QZeD8g5uu2MF75/art.json | 14 +++++++++++++- art/rYnPNYL9sQiTPrSfz/art.json | 14 +++++++++++++- art/rYriGa7yHEJZnvYrG/art.json | 14 +++++++++++++- art/rZXHyphbAzHHHzkAc/art.json | 14 +++++++++++++- art/rZcr6zk3jJKzwJ2mD/art.json | 14 +++++++++++++- art/raCeFgW4uDJ8yZBwD/art.json | 14 +++++++++++++- art/ranzZohyvMMY5qhCs/art.json | 14 +++++++++++++- art/rb2d6ReqHPiEK4ahj/art.json | 14 +++++++++++++- art/rbtQZi9Ks5R8zkRRF/art.json | 14 +++++++++++++- art/rcKFeaikB2g9P6Wf5/art.json | 14 +++++++++++++- art/rdnpitzwjjAHK9Aef/art.json | 14 +++++++++++++- art/rfN5XjXn3a69T3A7z/art.json | 14 +++++++++++++- art/rfTkbTfLZfroxDvEZ/art.json | 14 +++++++++++++- art/rgGNodWBZBJxDsyQx/art.json | 14 +++++++++++++- art/rghHKREPitTaTLiyH/art.json | 14 +++++++++++++- art/rowacMf39CKSm6S8s/art.json | 14 +++++++++++++- art/rpRcyCMh5R2XDbm49/art.json | 14 +++++++++++++- art/rpZQsvErnMxXynuRd/art.json | 14 +++++++++++++- art/rpeFEbrt3ozGdCvBQ/art.json | 14 +++++++++++++- art/rprQ8uGr5rvgeTCMd/art.json | 14 +++++++++++++- art/rpsbSKo8heXFgATpg/art.json | 14 +++++++++++++- art/rr7LMKBcPb7iHAgAT/art.json | 14 +++++++++++++- art/rrbek22fBWSHNDxAE/art.json | 14 +++++++++++++- art/rsQG6eXcgMiDznHzF/art.json | 14 +++++++++++++- art/rsfLpHMoLXeSK4ybu/art.json | 14 +++++++++++++- art/rskYzcp7KQd6MLz3F/art.json | 14 +++++++++++++- art/ruRxM7a7ngW6o8SPY/art.json | 14 +++++++++++++- art/rvBrwrSM6wfvD97BZ/art.json | 14 +++++++++++++- art/rvrqPiwbYYrRPNC6i/art.json | 14 +++++++++++++- art/rvw679Z5He2rieYqy/art.json | 14 +++++++++++++- art/ryGyoqT2E3N7mdJrC/art.json | 14 +++++++++++++- art/rybGugSztRdCtGYet/art.json | 14 +++++++++++++- art/rzriAAzqrAiYpiyWX/art.json | 14 +++++++++++++- art/s3bsdzjr5aaq7n4NR/art.json | 14 +++++++++++++- art/s4PDZP2QnF2WpRZqM/art.json | 14 +++++++++++++- art/s5Zxb4iQj8xZjfB5c/art.json | 14 +++++++++++++- art/s5eywpAoRQGmsD8Dq/art.json | 14 +++++++++++++- art/s62zTw9wPkh2irNpz/art.json | 14 +++++++++++++- art/s7zehgnGsLh5aHkM8/art.json | 14 +++++++++++++- art/s8eghqEX2KWmXy2BZ/art.json | 14 +++++++++++++- art/s8fhTKeFZujEYyKJi/art.json | 14 +++++++++++++- art/s9xXnsxy4wkR3kkSc/art.json | 14 +++++++++++++- art/sA2GkcNB7H2biaXxg/art.json | 14 +++++++++++++- art/sBRAzLRKmk8gYkZgz/art.json | 14 +++++++++++++- art/sBgC7apPnFmiA6GQ8/art.json | 14 +++++++++++++- art/sCPDNvuYTdioSKHL7/art.json | 14 +++++++++++++- art/sEDKEFtcGxZoxbis8/art.json | 14 +++++++++++++- art/sESZsypGtXcTsaupL/art.json | 14 +++++++++++++- art/sEkj67PRA2wdoH6n2/art.json | 14 +++++++++++++- art/sEwzQPsXsfiFvkjuQ/art.json | 14 +++++++++++++- art/sFMa3xreof2dhgyS2/art.json | 14 +++++++++++++- art/sFwDFQhDYuAh6a6r8/art.json | 14 +++++++++++++- art/sHdHwHQ9GTSaJ9j99/art.json | 14 +++++++++++++- art/sK7LiRcHNuXupG5ax/art.json | 14 +++++++++++++- art/sP9meYNADjKewXyNN/art.json | 14 +++++++++++++- art/sPftu8weSr8Ej2krv/art.json | 14 +++++++++++++- art/sQ6ahpp85mA5CcSNJ/art.json | 14 +++++++++++++- art/sS597q4aY9wEpneFz/art.json | 14 +++++++++++++- art/sSEcdoNo3EcbnYphW/art.json | 14 +++++++++++++- art/sSXAMvBdzGHTManZw/art.json | 14 +++++++++++++- art/sTNYDvmznSEKDDQtK/art.json | 14 +++++++++++++- art/sYBECGM9gRBccnwPb/art.json | 14 +++++++++++++- art/sYdAq9WutD8TN6uxp/art.json | 14 +++++++++++++- art/sbPQY2SPAe2cbSP3K/art.json | 14 +++++++++++++- art/sc6jikXkGhP7hihWb/art.json | 14 +++++++++++++- art/sdooECpbs5tTTw7AW/art.json | 14 +++++++++++++- art/seEL2RtaERajKZKbT/art.json | 14 +++++++++++++- art/sfTopMcw7ctmNhjJL/art.json | 14 +++++++++++++- art/sfhL5D5YFCpH6NjJE/art.json | 14 +++++++++++++- art/sfkanHudyxsBjm2BE/art.json | 14 +++++++++++++- art/sgg5X7iFw5d2SLzwX/art.json | 14 +++++++++++++- art/sh2fiodFgyJZRA5kn/art.json | 14 +++++++++++++- art/shSEhMvvTzScwX6xx/art.json | 14 +++++++++++++- art/siFxTFYwYALqTSCib/art.json | 14 +++++++++++++- art/siiR5CkBzKcRp6keX/art.json | 14 +++++++++++++- art/snE4Fu2qG9PmDKDgc/art.json | 14 +++++++++++++- art/snffEbJSrbtrEQvka/art.json | 14 +++++++++++++- art/soQPRE79HZt8hAGAh/art.json | 14 +++++++++++++- art/sofn3Bs4vuERfBH8b/art.json | 14 +++++++++++++- art/sph6PXJZqMbGaLSkY/art.json | 14 +++++++++++++- art/sr2hRa3R2XYEKwJyC/art.json | 14 +++++++++++++- art/srEzQEq8iaczPwERC/art.json | 14 +++++++++++++- art/ssKvHBoYZGXuj88en/art.json | 14 +++++++++++++- art/ssKwqvCp3dNhRbnLa/art.json | 14 +++++++++++++- art/strzQyhv3SnhYWLrs/art.json | 14 +++++++++++++- art/suJcf7jB43TcT8x5X/art.json | 14 +++++++++++++- art/svRerLfafn3PP5Jif/art.json | 14 +++++++++++++- art/swrTgKcxx4aJDe6hD/art.json | 14 +++++++++++++- art/sxuyK3fxSLJbouBDN/art.json | 14 +++++++++++++- art/t6BweGrbMSz3TPJen/art.json | 14 +++++++++++++- art/t9afzWHetyWR3bZSB/art.json | 14 +++++++++++++- art/tBY967FHBHEfJkSwk/art.json | 14 +++++++++++++- art/tBoefnyLiLiAapP2L/art.json | 14 +++++++++++++- art/tDL9nRCoBMvh9R7Zh/art.json | 14 +++++++++++++- art/tDPKDjEBxPf4GXgvv/art.json | 14 +++++++++++++- art/tDZd2w9DsKbz3CHm2/art.json | 14 +++++++++++++- art/tEAGWWrJv76hQhmjy/art.json | 14 +++++++++++++- art/tEPdh34hM3fNGFFsg/art.json | 14 +++++++++++++- art/tF4ynbNrnHawnus9p/art.json | 14 +++++++++++++- art/tGCcoCiv9fi2S5rub/art.json | 14 +++++++++++++- art/tGQbaSaJuQ5gAAcEk/art.json | 14 +++++++++++++- art/tJ9XYE3zGtX8Lp2fm/art.json | 14 +++++++++++++- art/tL9Q5Bx3AuuRT4JTx/art.json | 14 +++++++++++++- art/tMLi8Jfi7Db6YYosv/art.json | 14 +++++++++++++- art/tQEPfhxxjYGjmL6LL/art.json | 14 +++++++++++++- art/tRnGuB6MaPdZJMzmR/art.json | 14 +++++++++++++- art/tSysk55tWkhrkkrEF/art.json | 14 +++++++++++++- art/tTGjfG5qvuESdFcQR/art.json | 14 +++++++++++++- art/tTWmqDWD9Y3Gijkoy/art.json | 14 +++++++++++++- art/tTpdRDPwymLa9i5Mo/art.json | 14 +++++++++++++- art/tW33RrL78zzouNP8o/art.json | 14 +++++++++++++- art/tYmHG6XpcftYrE9DD/art.json | 14 +++++++++++++- art/tZ878XpvmzGfjF3hG/art.json | 14 +++++++++++++- art/tZJWzLbyDQHTztNqY/art.json | 14 +++++++++++++- art/tbgH6FuoT5pxxDgfv/art.json | 14 +++++++++++++- art/tbsksogaFbe66Nn5Q/art.json | 14 +++++++++++++- art/tgnWFwxfEbt64aHfQ/art.json | 14 +++++++++++++- art/tiY4qnEQ7wBnY5XdH/art.json | 14 +++++++++++++- art/tjBqEBhdzGA4XCiWr/art.json | 14 +++++++++++++- art/tkkTQCvYJZZ7rzpLo/art.json | 14 +++++++++++++- art/tn7AoRaD9XwPucwsL/art.json | 14 +++++++++++++- art/tneny66CTjxFbesnu/art.json | 14 +++++++++++++- art/tnmTYzZQNchp9ECC2/art.json | 14 +++++++++++++- art/toqC3cLBCWT32vPb2/art.json | 14 +++++++++++++- art/trsRykwiAHEtSA98a/art.json | 14 +++++++++++++- art/trsmEtfPkaXKti9gH/art.json | 14 +++++++++++++- art/tw3mJeCpEXQ6gMz2q/art.json | 14 +++++++++++++- art/txxXeHf8AFDuZzxWD/art.json | 14 +++++++++++++- art/u2cNzFGq9v9PnRyAM/art.json | 14 +++++++++++++- art/u4Ycc5AWRWWSk23Dt/art.json | 14 +++++++++++++- art/u9hvPc2WxibcTmT6F/art.json | 14 +++++++++++++- art/uAHaEoLE9cg9b7WQL/art.json | 14 +++++++++++++- art/uB888bmYT66k3orcR/art.json | 14 +++++++++++++- art/uBNYQJxs6ta546Y5j/art.json | 14 +++++++++++++- art/uD6PQ38TinznYz4vi/art.json | 14 +++++++++++++- art/uDBqerAHTiHEjQMdR/art.json | 14 +++++++++++++- art/uDDkmQ76JPKLooXHk/art.json | 14 +++++++++++++- art/uF8TFTKpj88nNiuD2/art.json | 14 +++++++++++++- art/uFWQ38ziz2oKNfZZi/art.json | 14 +++++++++++++- art/uGJhdfKrAj8tkovpA/art.json | 14 +++++++++++++- art/uHMnt4GHAXCSCeQyM/art.json | 14 +++++++++++++- art/uKvQ258NCvBLd29xE/art.json | 14 +++++++++++++- art/uNm4pd5oCSruRA832/art.json | 14 +++++++++++++- art/uPZQYGHJDM4trFXcC/art.json | 14 +++++++++++++- art/uProMGMrzma2K7GiG/art.json | 14 +++++++++++++- art/uPu4TCDWfH27uwcgs/art.json | 14 +++++++++++++- art/uPwKetxzwcL2PFZd6/art.json | 14 +++++++++++++- art/uQ6SBCL37HsvsjWYy/art.json | 14 +++++++++++++- art/uQAeKH3AvcwiJJ6AW/art.json | 14 +++++++++++++- art/uQNhYXZtikXJR6MBz/art.json | 14 +++++++++++++- art/uQkpXdAa4ABNPNthi/art.json | 14 +++++++++++++- art/uQsrjwoCeqSersLA9/art.json | 14 +++++++++++++- art/uRPsmf73ZgmHdkDP5/art.json | 14 +++++++++++++- art/uSaN2bccDvQp8857Q/art.json | 14 +++++++++++++- art/uSaQNx4ahiXtBAcB2/art.json | 14 +++++++++++++- art/uTpabmasr6wBTbv3z/art.json | 14 +++++++++++++- art/uWGtoiQdrk49KSPoT/art.json | 14 +++++++++++++- art/uX4j5TjepFCvRZJ7X/art.json | 14 +++++++++++++- art/uXG7SrNumn9NcWxDE/art.json | 14 +++++++++++++- art/uXbjeauxDQaEZBKPg/art.json | 14 +++++++++++++- art/uXzMte5jWZa5aMKgf/art.json | 14 +++++++++++++- art/uYBa5uSws8jiReZXu/art.json | 14 +++++++++++++- art/uZ4ELyQ7j8J8X5xJg/art.json | 14 +++++++++++++- art/uaxNZMjuMEduopGWR/art.json | 14 +++++++++++++- art/ubXN9wpiu8DoS8vjW/art.json | 14 +++++++++++++- art/ud8JyamidCEqTgz7R/art.json | 14 +++++++++++++- art/ueTjuJf66xFbmgcBo/art.json | 14 +++++++++++++- art/uesEjk3MpYeCJCofM/art.json | 14 +++++++++++++- art/umxyfipbWA28PZZu5/art.json | 14 +++++++++++++- art/upTN3YzTRee3FJs4P/art.json | 14 +++++++++++++- art/uqWtxuQpEkfxqWXCK/art.json | 14 +++++++++++++- art/uqyvxTyC4ctpQRYNi/art.json | 14 +++++++++++++- art/ur9ypANXXdW8q9gmW/art.json | 14 +++++++++++++- art/us5PXZuW9emkg2bD4/art.json | 14 +++++++++++++- art/us7EwfYeHRHwZoEsZ/art.json | 14 +++++++++++++- art/ut2hNmEtGzvzi7Rwj/art.json | 14 +++++++++++++- art/ut7msYoHpzuRZjDyc/art.json | 14 +++++++++++++- art/uuHumiKPEiAKNPkEA/art.json | 14 +++++++++++++- art/uvCsxPZo4fAnuhkrZ/art.json | 14 +++++++++++++- art/uw8sFSNiZKdTFYyqd/art.json | 14 +++++++++++++- art/uwSnj6nQHdjH7dR7F/art.json | 14 +++++++++++++- art/uxAPCSmSfNYuW8CJL/art.json | 14 +++++++++++++- art/uxbBoD5jdLBmRbdtE/art.json | 14 +++++++++++++- art/uxqp5gTZsNRKt9SRM/art.json | 14 +++++++++++++- art/uzebvE2bsmjwLjrKY/art.json | 14 +++++++++++++- art/v2n4RsmA4tBEGs7Zy/art.json | 14 +++++++++++++- art/v5YKKxvrTF6dp4WTo/art.json | 14 +++++++++++++- art/v5nH366PBWGH7qqG8/art.json | 14 +++++++++++++- art/v8Q2uDoFCSfa5sQRC/art.json | 14 +++++++++++++- art/v8pJCRw47pMT9EDZk/art.json | 14 +++++++++++++- art/vBDBSAvnH4mCTZ4So/art.json | 14 +++++++++++++- art/vEvaCS9R8ehpnLZPj/art.json | 14 +++++++++++++- art/vFe83XLQLWckPmxFd/art.json | 14 +++++++++++++- art/vFkJ9f33FZrMwjHCH/art.json | 14 +++++++++++++- art/vG8pMALDuaEu8S5oL/art.json | 14 +++++++++++++- art/vLxHHs7vSmLsud4hw/art.json | 14 +++++++++++++- art/vMMTeTmGkJsRT7dg6/art.json | 14 +++++++++++++- art/vNF92j6RWk3FEERkv/art.json | 14 +++++++++++++- art/vQ7wEjJPEkssSR58B/art.json | 14 +++++++++++++- art/vRKQmBo3cooJejSdP/art.json | 14 +++++++++++++- art/vRvb4kJdBxK7WSiSp/art.json | 14 +++++++++++++- art/vSoYhoMHS2k2S8ueR/art.json | 14 +++++++++++++- art/vX6mGDTuwQmga2tvj/art.json | 14 +++++++++++++- art/vXFhLDE2hgAm9bXD8/art.json | 14 +++++++++++++- art/vY9ZdpP3WcoSgySqL/art.json | 14 +++++++++++++- art/vZ4PBCfpqJPJ4eweJ/art.json | 14 +++++++++++++- art/vZtNQowy822RZj6gP/art.json | 14 +++++++++++++- art/vbumqNjcawaLjdiM8/art.json | 14 +++++++++++++- art/vcYrT69DDanvyFBTr/art.json | 14 +++++++++++++- art/vd4wAi9P33ezAYGis/art.json | 14 +++++++++++++- art/ve3x7fM9K77dHgwux/art.json | 14 +++++++++++++- art/vhbgo3kHochQMeb2i/art.json | 14 +++++++++++++- art/vhkrDTrknFZgdQvw5/art.json | 14 +++++++++++++- art/vhrfGAjQ76HJwApnJ/art.json | 14 +++++++++++++- art/viP5QEyt8HBLNEEbD/art.json | 14 +++++++++++++- art/vixRSiPMAiZ6AmgNA/art.json | 14 +++++++++++++- art/vmttH6ixNxK3G3sTG/art.json | 14 +++++++++++++- art/vn7aCRpFmjs6n8XNG/art.json | 14 +++++++++++++- art/vncmkDKkFydMJjG86/art.json | 14 +++++++++++++- art/vqBN6kLpxjBHGRvz8/art.json | 14 +++++++++++++- art/vqWQHJrgtfjyuWZXw/art.json | 14 +++++++++++++- art/vsfaoEsuvT3yZrCRB/art.json | 14 +++++++++++++- art/vtpkyADRpuovJ23AP/art.json | 14 +++++++++++++- art/vtq5MvbFuTd4SDKpR/art.json | 14 +++++++++++++- art/vwQgfZcfrdKFAJLd2/art.json | 14 +++++++++++++- art/vwbP4QH64Pn3EXf3w/art.json | 14 +++++++++++++- art/vycmMsgS7e6fHw5tD/art.json | 14 +++++++++++++- art/vyzW6DRZFHK4tEbft/art.json | 14 +++++++++++++- art/w2wizFHHNsMCjuyvJ/art.json | 14 +++++++++++++- art/w39M6FR7PCQctz5bN/art.json | 14 +++++++++++++- art/w3EKusJyt77LiLh5E/art.json | 14 +++++++++++++- art/w5XY5hp6r86GpTyLE/art.json | 14 +++++++++++++- art/w5qTDiEqtC8Tri6tv/art.json | 14 +++++++++++++- art/w9fNQs5qa7s4CmEvg/art.json | 14 +++++++++++++- art/wAHW2jvdnk46gwycK/art.json | 14 +++++++++++++- art/wCMaWve5ErdStTm5C/art.json | 14 +++++++++++++- art/wFYATkgtzx3PKBDcw/art.json | 14 +++++++++++++- art/wFdw32QXQhDAXDLmi/art.json | 14 +++++++++++++- art/wFtvqKAQ3wB8Hho3p/art.json | 14 +++++++++++++- art/wFxoEvW6hYYYYfiKt/art.json | 14 +++++++++++++- art/wGQZbn4NqJiMq8Rvv/art.json | 14 +++++++++++++- art/wGx3PFi6cT8Dydevv/art.json | 14 +++++++++++++- art/wHYadcJcCHsjn3cvr/art.json | 14 +++++++++++++- art/wHiihz6NHxZhtHDon/art.json | 14 +++++++++++++- art/wJ3ERkQqdQYSY6bnL/art.json | 14 +++++++++++++- art/wJR8MkZGLQe3TZGZD/art.json | 14 +++++++++++++- art/wJtgtpePx8uemptoj/art.json | 14 +++++++++++++- art/wJuenftt4G6XBy8x7/art.json | 14 +++++++++++++- art/wKpLsESkrBXCiRJad/art.json | 14 +++++++++++++- art/wMRQSfRMurn9etwdS/art.json | 14 +++++++++++++- art/wP2mJ5GtGxM69FK8H/art.json | 14 +++++++++++++- art/wP4tHTACwohNdomhd/art.json | 14 +++++++++++++- art/wT4peJdYTS3FSeH9P/art.json | 14 +++++++++++++- art/wTPZJYcFz58zagJqM/art.json | 14 +++++++++++++- art/wTaKE9X796qNFqgEM/art.json | 14 +++++++++++++- art/wXoyv2xNDqkKWzsJE/art.json | 14 +++++++++++++- art/wYJg4JdkufCDkxugR/art.json | 14 +++++++++++++- art/wZu7HgdEpJmXy93Jm/art.json | 14 +++++++++++++- art/wdRcgmKhw55neWGbT/art.json | 14 +++++++++++++- art/wfSM5cyoAJHAg6od5/art.json | 14 +++++++++++++- art/wftsxawoj5iw32a8D/art.json | 14 +++++++++++++- art/whWhE5dshEugnAaBD/art.json | 14 +++++++++++++- art/wjw5e9cStNy6XAxH4/art.json | 14 +++++++++++++- art/wm8Y738CbMGQQkW63/art.json | 14 +++++++++++++- art/wmrGHPZAroXn6EtZz/art.json | 14 +++++++++++++- art/wnJ3yTrs7ZQXEmwRM/art.json | 14 +++++++++++++- art/wrMBc6LyKbu6PqxgL/art.json | 14 +++++++++++++- art/wrTE6KKesztAX6apx/art.json | 14 +++++++++++++- art/wt7dgJfnc9ut9a8tk/art.json | 14 +++++++++++++- art/wuFdtxFYcP6TczAW2/art.json | 14 +++++++++++++- art/wvtQDvQbMrdANuDHh/art.json | 14 +++++++++++++- art/wxCaDvySLwp6dYRto/art.json | 14 +++++++++++++- art/wxPvS64A9HG62L8za/art.json | 14 +++++++++++++- art/wyoNwyHa6hTbkGCKW/art.json | 14 +++++++++++++- art/wzJiTNRsg9cApqfB9/art.json | 14 +++++++++++++- art/x3EiTmLXs7z5qb9Mm/art.json | 14 +++++++++++++- art/x4ozirAYAtKhvZGdo/art.json | 14 +++++++++++++- art/x5Y9YCA8iKiCLHzS6/art.json | 14 +++++++++++++- art/x66X7Pm8wnL8LZHvj/art.json | 14 +++++++++++++- art/x6EMZzZ6px9Mm3iED/art.json | 14 +++++++++++++- art/x6TrSQt9x9ujACqkE/art.json | 14 +++++++++++++- art/x7PnnkNih93Fxm9A6/art.json | 14 +++++++++++++- art/x7fjK2WqJCRmwvnuj/art.json | 14 +++++++++++++- art/x7uRXS3va22ihf8MA/art.json | 14 +++++++++++++- art/x98YWGKkNM6JbW8EJ/art.json | 14 +++++++++++++- art/xAE59mzRZ5zzvXL4b/art.json | 14 +++++++++++++- art/xBRbHkLWdy73NKidY/art.json | 14 +++++++++++++- art/xBdqEmtgfPSxao97G/art.json | 14 +++++++++++++- art/xC9mkxRGvdyco7QbM/art.json | 14 +++++++++++++- art/xCGKaZubja8uuYkJH/art.json | 14 +++++++++++++- art/xCT9GJqCjqMs5Zj3m/art.json | 14 +++++++++++++- art/xDh7mGTSuEc3dohm4/art.json | 14 +++++++++++++- art/xEptEPstqgQAypqks/art.json | 14 +++++++++++++- art/xG6tZRJFAL9i7pWED/art.json | 14 +++++++++++++- art/xJtSaCNJTKWjZF5jp/art.json | 14 +++++++++++++- art/xJxsMsamoRikshwtQ/art.json | 14 +++++++++++++- art/xL2Gh9RJscrvhfwE9/art.json | 14 +++++++++++++- art/xLrHnki5affkbQiFT/art.json | 14 +++++++++++++- art/xMtRaWRFbCx6TD3qF/art.json | 14 +++++++++++++- art/xPP9fDv73GJbsTxGE/art.json | 14 +++++++++++++- art/xPppoX27MZEgtBYyX/art.json | 14 +++++++++++++- art/xTf82BxK4LCcHNgq6/art.json | 14 +++++++++++++- art/xTioxG2q3bibRu5j8/art.json | 14 +++++++++++++- art/xWrTfrQ2whCaGaGWK/art.json | 14 +++++++++++++- art/xX4FaCRBAKRKxwQ5k/art.json | 14 +++++++++++++- art/xXCPLBuMgorE5wvmd/art.json | 14 +++++++++++++- art/xZSZbju6uJBkBHGed/art.json | 14 +++++++++++++- art/xbnz2uAnWG7hSF8jC/art.json | 14 +++++++++++++- art/xc49q3XhWdr4G5g3Y/art.json | 14 +++++++++++++- art/xdFdZbdmwquvYTuRo/art.json | 14 +++++++++++++- art/xdgnE3FvNBNtDFynG/art.json | 14 +++++++++++++- art/xgQQX7WZ4GhGTRqMt/art.json | 14 +++++++++++++- art/xgrH8Ga7yhuDYom6t/art.json | 14 +++++++++++++- art/xizoh3Kx86QeHAyuc/art.json | 14 +++++++++++++- art/xnpXYa6wYgG6TyR5m/art.json | 14 +++++++++++++- art/xqkoSeG72cxgJNEqr/art.json | 14 +++++++++++++- art/xqxGcpS5Ny2RtAwpm/art.json | 14 +++++++++++++- art/xrRijEDXFe2NwH79m/art.json | 14 +++++++++++++- art/xsSZN6pMk7iANGyTE/art.json | 14 +++++++++++++- art/xuJ6P4ivzQ3KERCwG/art.json | 14 +++++++++++++- art/xuuAHAN2frEuP9Tt8/art.json | 14 +++++++++++++- art/xvg4vyvfWjCvKZQfW/art.json | 14 +++++++++++++- art/xvh5kBvczrdcehxxG/art.json | 14 +++++++++++++- art/xxhTPvXjTWPCPLM2v/art.json | 14 +++++++++++++- art/xyMYnHS29GDusyzJp/art.json | 14 +++++++++++++- art/xzFWA2bkiC4v8p9oX/art.json | 14 +++++++++++++- art/y2BcbbWxcksEGQYhq/art.json | 14 +++++++++++++- art/y2RHXZfCXZm9N45hp/art.json | 14 +++++++++++++- art/y2qQtMPftsgG9GmSw/art.json | 14 +++++++++++++- art/y37cKaKLxW7FgiTXm/art.json | 14 +++++++++++++- art/y3CAW8hkHFwKx9Lct/art.json | 14 +++++++++++++- art/y3d4oox3xc3yNEGzi/art.json | 14 +++++++++++++- art/y5x2iTpL5qQdipiKy/art.json | 14 +++++++++++++- art/y6pAr7bDAF5LM9LLi/art.json | 14 +++++++++++++- art/yAwn2hvbxQLFnF3yv/art.json | 14 +++++++++++++- art/yAxcaQPNpt4jDhpQJ/art.json | 14 +++++++++++++- art/yCjeKmDJjLWcwymYt/art.json | 14 +++++++++++++- art/yF4vdFqXorG76fRmR/art.json | 14 +++++++++++++- art/yHrv6nf5GNziSJHX5/art.json | 14 +++++++++++++- art/yJStxdpLgCWHmBA7n/art.json | 14 +++++++++++++- art/yKbsMohpXxZXWLHSm/art.json | 14 +++++++++++++- art/yKgYMBxcoK34ebwHv/art.json | 14 +++++++++++++- art/yLbydHYz2jYr6t9DH/art.json | 14 +++++++++++++- art/yMrRxwDvaoSaokXzo/art.json | 14 +++++++++++++- art/yPDzQv2JwJ9p4NCgQ/art.json | 14 +++++++++++++- art/yQpwAFYqRp4knnezc/art.json | 14 +++++++++++++- art/yQxBYWw4sFSMS2gsp/art.json | 14 +++++++++++++- art/yRohe8v2Duig5qBiY/art.json | 14 +++++++++++++- art/ySwXopuyaNQWbLnt6/art.json | 14 +++++++++++++- art/yWSCEoXnFJxXAZyBo/art.json | 14 +++++++++++++- art/yX9SGHv6RPPqcsXvh/art.json | 14 +++++++++++++- art/yXNXFmLjcRjjYtgze/art.json | 14 +++++++++++++- art/yXyfMG3k8JMQsDgDm/art.json | 14 +++++++++++++- art/yYj8r42nj2y6GRBEi/art.json | 14 +++++++++++++- art/ycNiGDhLy59Wqt9qN/art.json | 14 +++++++++++++- art/yeHYiFzE9scyMHnSv/art.json | 14 +++++++++++++- art/yey7qrMtmhZZhq2K6/art.json | 14 +++++++++++++- art/yfhr4C9ihGC54WwZ4/art.json | 14 +++++++++++++- art/ygbdEzp2iTmLeNyu8/art.json | 14 +++++++++++++- art/yjv7hpNd3R3aGwGPp/art.json | 14 +++++++++++++- art/yjygGt83hjC8LDH7Z/art.json | 14 +++++++++++++- art/ynpWP4AEw3HbibsqM/art.json | 14 +++++++++++++- art/yqxy757eFpwGqJu5k/art.json | 14 +++++++++++++- art/yrXnJnTbLipbKFdcc/art.json | 14 +++++++++++++- art/ysQvrP3pZcBzuC2YL/art.json | 14 +++++++++++++- art/ysh84kFrt5dxksGM9/art.json | 14 +++++++++++++- art/yuDv9cWYxgd33kjQ7/art.json | 14 +++++++++++++- art/yvHEThAy6Yvf5mRjp/art.json | 14 +++++++++++++- art/yva6wZBxMPvZtC8iA/art.json | 14 +++++++++++++- art/ywWngPQ5Zn8DxNM24/art.json | 14 +++++++++++++- art/yxx6Qzd29foXStAvK/art.json | 14 +++++++++++++- art/yz73Hm3Fq5SyrZppP/art.json | 14 +++++++++++++- art/z4BHgWLrPnZbRvude/art.json | 14 +++++++++++++- art/z5Wj5jyFwYiwezjLv/art.json | 14 +++++++++++++- art/z5fvZCjBmkRpsSaxD/art.json | 14 +++++++++++++- art/z7C9Xwr9PtGmofB9B/art.json | 14 +++++++++++++- art/zAa7gfsGaLGjPw6Wt/art.json | 14 +++++++++++++- art/zB3fsZSeqTdYCbzGZ/art.json | 14 +++++++++++++- art/zBAYmes3sMdFCHEcM/art.json | 14 +++++++++++++- art/zBGJ6RhGK6EAJvuHL/art.json | 14 +++++++++++++- art/zFRiazFDjmFNzD8ia/art.json | 14 +++++++++++++- art/zFsctippt7CPRwvWh/art.json | 14 +++++++++++++- art/zGGRYEyPC9E6CWEWD/art.json | 14 +++++++++++++- art/zGqZP2vWAf3ByWFKk/art.json | 14 +++++++++++++- art/zHorsBAipg3PMpwaL/art.json | 14 +++++++++++++- art/zLw84GEutsZbMdZ3e/art.json | 14 +++++++++++++- art/zNMwxDHLmvHRPQBpm/art.json | 14 +++++++++++++- art/zPWNwEXsnYqAjv9as/art.json | 14 +++++++++++++- art/zQMGMroYDChPD5qbu/art.json | 14 +++++++++++++- art/zQsoSnJjbCQY2Zq83/art.json | 14 +++++++++++++- art/zRecXKb9NuCfmnWv4/art.json | 14 +++++++++++++- art/zS5Nx6iwJqiQDQRap/art.json | 14 +++++++++++++- art/zSahx3yerpFqrYbQM/art.json | 14 +++++++++++++- art/zTFEangj5PduTYF4e/art.json | 14 +++++++++++++- art/zWDcosC8feevNhZNA/art.json | 14 +++++++++++++- art/zbFojAK3PQ5p2yLSM/art.json | 14 +++++++++++++- art/zd2E5vCZduc5JeoFz/art.json | 14 +++++++++++++- art/zddxPxkny7JNAE7jK/art.json | 14 +++++++++++++- art/zmcNCBEkGnxZeWcer/art.json | 14 +++++++++++++- art/zqZosvvGRNo8wWQq9/art.json | 14 +++++++++++++- art/zr3rcCnA3sx954XPa/art.json | 14 +++++++++++++- art/zsPkZPEA85uft8ybJ/art.json | 14 +++++++++++++- art/ztNkTPfLtNiNcSG3h/art.json | 14 +++++++++++++- art/zvKXwd6wx6E38aPmf/art.json | 14 +++++++++++++- art/zvyxJBkZ5mMZpXaLk/art.json | 14 +++++++++++++- art/zxb8eWGChrW9wgd55/art.json | 14 +++++++++++++- build/gen-art-json.js | 4 ++++ src/js/main.js | 2 +- 2779 files changed, 36106 insertions(+), 2778 deletions(-) diff --git a/art/22RaBcCzsbaXEzCh5/art.json b/art/22RaBcCzsbaXEzCh5/art.json index b0161c48..54a0d626 100644 --- a/art/22RaBcCzsbaXEzCh5/art.json +++ b/art/22RaBcCzsbaXEzCh5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Jemin.Shin\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux * sin(time), vy * cos(time), 0., 0.5);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 400.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Jemin.Shin\n// Exercise Making A Grid\n// CS250 Spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux * sin(time), vy * cos(time), 0., 0.5);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 400.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-d2fsmpwp2mvlmqnit-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/23ezRZjpZK82TqNJr/art.json b/art/23ezRZjpZK82TqNJr/art.json index 50698476..d12a2d95 100644 --- a/art/23ezRZjpZK82TqNJr/art.json +++ b/art/23ezRZjpZK82TqNJr/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user-811313743/a-charlie-brown-christmas-skating\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.5882352941176471,0.6901960784313725,1],\"shader\":\"/*\\n\\n _____, ____, ___, ___, __ _, \\n(-| | | (-|_, (-|_) (-|_) (-\\\\ | \\n _| | |_, _|__, _| \\\\_, _| \\\\_, \\\\| \\n( ( ( ( (__/ \\n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \\n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\\\_,(-(__`\\n \\\\___, _| |_, _| \\\\_, _|__, ____) _| _| | |_, _| ) ____)\\n ( ( ( ( ( ( ( ( \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\nvoid main() {\\n float vId = vertexId;\\n float numStems = 6.;\\n float quadsPerStem = 5.;\\n float pointsPerStem = quadsPerStem * 6.;\\n float pointsPerFlake = pointsPerStem * numStems;\\n float numFlakes = floor(vertexCount / pointsPerFlake);\\n float quadId = mod(floor(vId / 6.), quadsPerStem);\\n float stemId = floor(vId / pointsPerStem);\\n float flakeId = floor(vId / pointsPerFlake);\\n float stemV = stemId / numStems;\\n float flakeV = flakeId / numFlakes;\\n \\n vec3 p = getQPoint(mod(vId, 6.));\\n \\n vec3 camera = vec3(0, 0, 1);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n float z = hash(flakeId) * -10.;\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 20.);\\n m *= cameraLookAt(camera, target, up);\\n m *= trans(vec3(\\n (z + 1.5) * 1. * m1p1(hash(flakeId * 0.171)) + 0.05 * sin(time * mix(0.91, 0.2, hash(flakeId * 0.951))), \\n mix(1.5, -1.5, fract(hash(flakeId * .654) + time * mix(0.01, 0.03, hash(flakeId * 0.543)))), \\n z));\\n m *= uniformScale(mix(0.05, 0.1, hash(flakeId * 0.243)));\\n m *= rotZ(time * hash(flakeId));\\n m *= rotY(time * hash(flakeId));\\n m *= rotZ(stemV * PI * 2. + mix(1.5, -1.5, fract(time * mix(-0.3, 0.3, hash(flakeId * 0.843)))));\\n m *= scale(vec3(0.1, m1p1(hash(flakeId * 0.123 + quadId * 0.711 + p.x)) * 0.3, 1));\\n m *= trans(vec3(quadId, -0.5, 0));\\n gl_Position = m * vec4(p, 1);\\n \\n v_color = vec4(1);\\n v_color.a = mix(1.0, 0.0, hash(flakeId));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user-811313743/a-charlie-brown-christmas-skating", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.5882352941176471, + 0.6901960784313725, + 1 + ], + "shader": "/*\n\n _____, ____, ___, ___, __ _, \n(-| | | (-|_, (-|_) (-|_) (-\\ | \n _| | |_, _|__, _| \\_, _| \\_, \\| \n( ( ( ( (__/ \n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\_,(-(__`\n \\___, _| |_, _| \\_, _|__, ____) _| _| | |_, _| ) ____)\n ( ( ( ( ( ( ( ( \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\nvoid main() {\n float vId = vertexId;\n float numStems = 6.;\n float quadsPerStem = 5.;\n float pointsPerStem = quadsPerStem * 6.;\n float pointsPerFlake = pointsPerStem * numStems;\n float numFlakes = floor(vertexCount / pointsPerFlake);\n float quadId = mod(floor(vId / 6.), quadsPerStem);\n float stemId = floor(vId / pointsPerStem);\n float flakeId = floor(vId / pointsPerFlake);\n float stemV = stemId / numStems;\n float flakeV = flakeId / numFlakes;\n \n vec3 p = getQPoint(mod(vId, 6.));\n \n vec3 camera = vec3(0, 0, 1);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n float z = hash(flakeId) * -10.;\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 20.);\n m *= cameraLookAt(camera, target, up);\n m *= trans(vec3(\n (z + 1.5) * 1. * m1p1(hash(flakeId * 0.171)) + 0.05 * sin(time * mix(0.91, 0.2, hash(flakeId * 0.951))), \n mix(1.5, -1.5, fract(hash(flakeId * .654) + time * mix(0.01, 0.03, hash(flakeId * 0.543)))), \n z));\n m *= uniformScale(mix(0.05, 0.1, hash(flakeId * 0.243)));\n m *= rotZ(time * hash(flakeId));\n m *= rotY(time * hash(flakeId));\n m *= rotZ(stemV * PI * 2. + mix(1.5, -1.5, fract(time * mix(-0.3, 0.3, hash(flakeId * 0.843)))));\n m *= scale(vec3(0.1, m1p1(hash(flakeId * 0.123 + quadId * 0.711 + p.x)) * 0.3, 1));\n m *= trans(vec3(quadId, -0.5, 0));\n gl_Position = m * vec4(p, 1);\n \n v_color = vec4(1);\n v_color.a = mix(1.0, 0.0, hash(flakeId));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-w1f0zzufayogu5orv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/23rhC2bHw8GtaXfa3/art.json b/art/23rhC2bHw8GtaXfa3/art.json index 89813587..93115867 100644 --- a/art/23rhC2bHw8GtaXfa3/art.json +++ b/art/23rhC2bHw8GtaXfa3/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":20000,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-hv1jz5edj50qxtz7o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/25DKYMazYyFB5WS2X/art.json b/art/25DKYMazYyFB5WS2X/art.json index 11ce2f20..90a7e9d1 100644 --- a/art/25DKYMazYyFB5WS2X/art.json +++ b/art/25DKYMazYyFB5WS2X/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "fractalhq", "avatarUrl": "https://avatars.githubusercontent.com/FractalHQ?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/subjex/richard\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = abs(atan(loc.x, loc.z) / PI);\\n float sv = abs(loc.y);\\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(cos(tm),-sin(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, pow(s, 2.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(0.9, 1.1, s) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n// gl_Position.z = 10000.;\\n }\\n #if 0\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n#endif\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/subjex/richard", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = abs(atan(loc.x, loc.z) / PI);\n float sv = abs(loc.y);\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(cos(tm),-sin(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, pow(s, 2.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(0.9, 1.1, s) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n// gl_Position.z = 10000.;\n }\n #if 0\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n#endif\n}\n\n" + }, "screenshotURL": "data/images/images-7vbk07b2b134ps79p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/27b5AxnyWM3K9MTg4/art.json b/art/27b5AxnyWM3K9MTg4/art.json index b0a89fba..e134498f 100644 --- a/art/27b5AxnyWM3K9MTg4/art.json +++ b/art/27b5AxnyWM3K9MTg4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":70101,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// complex numbers\\n// vec2(real part, complex part)\\nvec2 cProd(vec2 a, vec2 b) {\\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\\n}\\nfloat cModSqrd(vec2 a) {\\n return (a.x*a.x + a.y*a.y);\\n}\\nint mandelbrot(float x, float y) {\\n int n = 0;\\n vec2 z = vec2(0,0);\\n vec2 c = vec2(x,y);\\n \\n // no loops in glsl so jsut repeat 100 times\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n \\n return n;\\n}\\n\\nvoid main() {\\n float resX = resolution.x;\\n float resY = resolution.y;\\n float resArea = resX * resY;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertCountX = floor(resX/vertLen);\\n float vertCountY = floor(resY/vertLen);\\n \\n float u = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\\n float v = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\\n \\n float x = u * resolution.x;\\n float y = v * resolution.y;\\n \\n \\n gl_Position = vec4((u - 0.5)*2., (v - 0.5)*2., 0, 1);\\n gl_PointSize = vertLen*1.05;\\n v_color = vec4(hsv2rgb(vec3((x+y+time)/10., 1., 1.)), 1.);\\n}\"}", + "settings": { + "num": 70101, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// complex numbers\n// vec2(real part, complex part)\nvec2 cProd(vec2 a, vec2 b) {\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\n}\nfloat cModSqrd(vec2 a) {\n return (a.x*a.x + a.y*a.y);\n}\nint mandelbrot(float x, float y) {\n int n = 0;\n vec2 z = vec2(0,0);\n vec2 c = vec2(x,y);\n \n // no loops in glsl so jsut repeat 100 times\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n \n return n;\n}\n\nvoid main() {\n float resX = resolution.x;\n float resY = resolution.y;\n float resArea = resX * resY;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertCountX = floor(resX/vertLen);\n float vertCountY = floor(resY/vertLen);\n \n float u = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\n float v = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\n \n float x = u * resolution.x;\n float y = v * resolution.y;\n \n \n gl_Position = vec4((u - 0.5)*2., (v - 0.5)*2., 0, 1);\n gl_PointSize = vertLen*1.05;\n v_color = vec4(hsv2rgb(vec3((x+y+time)/10., 1., 1.)), 1.);\n}" + }, "screenshotURL": "data/images/images-a99xg0spxd1tgjcc3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/288uBLrF9BKty2gyx/art.json b/art/288uBLrF9BKty2gyx/art.json index 46a5f281..f4253b16 100644 --- a/art/288uBLrF9BKty2gyx/art.json +++ b/art/288uBLrF9BKty2gyx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.027450980392156862,0.07450980392156863,0.3137254901960784,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Audio Reactive Art\\n//course name : CS250\\n//term : Spring 2023\\n\\n#define PI 3.1415\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1; \\n float yoff = 0.; //sin(time * 1.1 + x * 0.2) * 0.2;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs( u - 0.5 ) * 2.;\\n float sv = abs( v - 0.5 ) * 2.;\\n float au = abs(atan(su,sv) ) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n\\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u* 0.1 * snd * 0.2 + time * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.027450980392156862, + 0.07450980392156863, + 0.3137254901960784, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Audio Reactive Art\n//course name : CS250\n//term : Spring 2023\n\n#define PI 3.1415\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1; \n float yoff = 0.; //sin(time * 1.1 + x * 0.2) * 0.2;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs( u - 0.5 ) * 2.;\n float sv = abs( v - 0.5 ) * 2.;\n float au = abs(atan(su,sv) ) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u* 0.1 * snd * 0.2 + time * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-blje0jjvx8pne65t6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/28nR5hx2KozuLsk3j/art.json b/art/28nR5hx2KozuLsk3j/art.json index c9adbe9b..b213636c 100644 --- a/art/28nR5hx2KozuLsk3j/art.json +++ b/art/28nR5hx2KozuLsk3j/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":45000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId ) / (numSections);\\n float v = sv + base;\\n \\n float off = 0.9;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = .5;//texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = 0.5;//texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n #if 0\\n s = .5;\\n s2 = 0.5;\\n #endif\\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 30.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float sideV = sideSectionId / halfSectionsAcross;\\n \\n float lr = mod(vertexId, 2.);\\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n \\n float sv = (sectionId + next * .4) / (numSections - 1.);\\n float v = sv * .2 + base + .1;\\n \\n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 tzaxis = normalize(s1 - s0);\\n vec3 txaxis = normalize(cross(s0, s1));\\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\\n \\n const float height = .05;\\n const float period = 2.;\\n const float speed = 2.;\\n const float lPeriod = 0.5;\\n \\n float sx = (sideV + lr / halfSectionsAcross);\\n float bt = 0.;//sx * period + time * speed + sv * lPeriod;\\n float bh = sin(bt) * height;\\n \\n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\\n float unit = 1. / halfSectionsAcross;\\n \\n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\\n \\n r0 += tzaxis * -.01;\\n \\n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\\n \\n vec3 sb0 = normalize(rb1 - rb0);\\n vec3 sb1 = normalize(rb2 - rb1);\\n \\n vec3 zaxis = normalize(sb1 - sb0);\\n vec3 xaxis = normalize(cross(sb0, sb1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(rb0 * expand, 1)); \\n\\n #if 0\\n s = 1.;\\n s2 = 1.;\\n #endif\\n \\n float su = (sideSectionId + lr) / halfSectionsAcross;\\n\\n float width = 1.; \\n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\\n vec3 nrm = vec3(0, 1, 0);\\n \\n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = 0.3;\\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 1.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n if (id < numTrackPoints) {\\n track(id, numTrackPoints, base, pos, color);\\n } else {\\n id -= numTrackPoints;\\n if (id < numFunkPoints) {\\n //funk(id, numFunkPoints, base, pos, color);\\n } else {\\n id -= numFunkPoints;\\n //sky(id, base, cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 45000, + "mode": "LINES", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId ) / (numSections);\n float v = sv + base;\n \n float off = 0.9;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = .5;//texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = 0.5;//texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n #if 0\n s = .5;\n s2 = 0.5;\n #endif\n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 30.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float sideV = sideSectionId / halfSectionsAcross;\n \n float lr = mod(vertexId, 2.);\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n \n float sv = (sectionId + next * .4) / (numSections - 1.);\n float v = sv * .2 + base + .1;\n \n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 tzaxis = normalize(s1 - s0);\n vec3 txaxis = normalize(cross(s0, s1));\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\n \n const float height = .05;\n const float period = 2.;\n const float speed = 2.;\n const float lPeriod = 0.5;\n \n float sx = (sideV + lr / halfSectionsAcross);\n float bt = 0.;//sx * period + time * speed + sv * lPeriod;\n float bh = sin(bt) * height;\n \n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\n float unit = 1. / halfSectionsAcross;\n \n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\n \n r0 += tzaxis * -.01;\n \n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\n \n vec3 sb0 = normalize(rb1 - rb0);\n vec3 sb1 = normalize(rb2 - rb1);\n \n vec3 zaxis = normalize(sb1 - sb0);\n vec3 xaxis = normalize(cross(sb0, sb1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(rb0 * expand, 1)); \n\n #if 0\n s = 1.;\n s2 = 1.;\n #endif\n \n float su = (sideSectionId + lr) / halfSectionsAcross;\n\n float width = 1.; \n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\n vec3 nrm = vec3(0, 1, 0);\n \n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\n float sat = 0.3;\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 1.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n if (id < numTrackPoints) {\n track(id, numTrackPoints, base, pos, color);\n } else {\n id -= numTrackPoints;\n if (id < numFunkPoints) {\n //funk(id, numFunkPoints, base, pos, color);\n } else {\n id -= numFunkPoints;\n //sky(id, base, cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-y6ifpbg5z45w07j38-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/296k8Y8nj6kcNxYG9/art.json b/art/296k8Y8nj6kcNxYG9/art.json index b38af219..afa416b7 100644 --- a/art/296k8Y8nj6kcNxYG9/art.json +++ b/art/296k8Y8nj6kcNxYG9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":300,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float ID = vertexId;\\n vec4 OutColor = vec4(1,1,1,1);\\n gl_Position=vec4(\\n cos(ID + time) * (ID * ID * 0.01), \\n sin(ID + time) * (40.0),\\n 1.,\\n 60.0 + ID );\\n gl_PointSize= 5.0;\\n float st = step(time,1.0);\\n OutColor.x = time * 0.01 - (ID / 300.0);\\n OutColor = vec4(hsv2rgb(OutColor.xyz),1.0);\\n \\n v_color= OutColor;\\n \\n}\"}", + "settings": { + "num": 300, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float ID = vertexId;\n vec4 OutColor = vec4(1,1,1,1);\n gl_Position=vec4(\n cos(ID + time) * (ID * ID * 0.01), \n sin(ID + time) * (40.0),\n 1.,\n 60.0 + ID );\n gl_PointSize= 5.0;\n float st = step(time,1.0);\n OutColor.x = time * 0.01 - (ID / 300.0);\n OutColor = vec4(hsv2rgb(OutColor.xyz),1.0);\n \n v_color= OutColor;\n \n}" + }, "screenshotURL": "data/images/images-9akdo1qlqwuqrwgfa-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2AAPaBjMMEbZF3peq/art.json b/art/2AAPaBjMMEbZF3peq/art.json index 1955b7a4..223f2e20 100644 --- a/art/2AAPaBjMMEbZF3peq/art.json +++ b/art/2AAPaBjMMEbZF3peq/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":40344,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.113) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = start + 0.5;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \\n mat *= rotZ((0.2 + uvfl.y * PI) * time * 3.);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 40344, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.113) + sin(t * 0.73);\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = start + 0.5;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \n mat *= rotZ((0.2 + uvfl.y * PI) * time * 3.);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-sqyipliizymyk4z74-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2DKvftja5hyuk3K5k/art.json b/art/2DKvftja5hyuk3K5k/art.json index 4e4d1421..954a5fbd 100644 --- a/art/2DKvftja5hyuk3K5k/art.json +++ b/art/2DKvftja5hyuk3K5k/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":26702,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define TAU radians(360.)#define PI radians(180.)\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 1.625 + (time * 30.));\\n float sx = mod(vertexId, pointsPerLoop /2.) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (.85 + pow(texture2D(sound, vec2(sx * 0.0365, sy)).a, 4.) * 2.) * (1. - sy);\\n \\n float x = sin(deg) * radius * 1.9;\\n float y = cos(deg) * radius * 1.9;\\n float z = vertexId * sx * 0.0125;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0.1*mouse.y, 1.-radius-mouse.y, 0,\\n -0.3/radius, -1.1*mouse.x*radius, .1, 0,\\n -0.06, 0.01, 0.31-mouse.y*0.1, 0.1,\\n 0, 0, -0.5, 1)/radius*2.;\\n \\n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\\n v_color = vec4(1, (vertexId / vertexCount) / 2.5 * 12.1, 0.4, 0.41);\\n}\"}", + "settings": { + "num": 26702, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define TAU radians(360.)#define PI radians(180.)\n\nvoid main()\n{\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 1.625 + (time * 30.));\n float sx = mod(vertexId, pointsPerLoop /2.) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (.85 + pow(texture2D(sound, vec2(sx * 0.0365, sy)).a, 4.) * 2.) * (1. - sy);\n \n float x = sin(deg) * radius * 1.9;\n float y = cos(deg) * radius * 1.9;\n float z = vertexId * sx * 0.0125;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0.1*mouse.y, 1.-radius-mouse.y, 0,\n -0.3/radius, -1.1*mouse.x*radius, .1, 0,\n -0.06, 0.01, 0.31-mouse.y*0.1, 0.1,\n 0, 0, -0.5, 1)/radius*2.;\n \n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\n v_color = vec4(1, (vertexId / vertexCount) / 2.5 * 12.1, 0.4, 0.41);\n}" + }, "screenshotURL": "data/images/images-8gom9w3snpbg01t5p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2DYifmxshFTc2mdD4/art.json b/art/2DYifmxshFTc2mdD4/art.json index 5f2a4f20..bac33f8a 100644 --- a/art/2DYifmxshFTc2mdD4/art.json +++ b/art/2DYifmxshFTc2mdD4/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":18836,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -1. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.62, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\\n float sat = 2.9 / circleId;\\n float val = .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 18836, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -1. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.62, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\n float sat = 2.9 / circleId;\n float val = .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-354wyo3gtk55smxm6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2EjmDvPyRP8XTRp4G/art.json b/art/2EjmDvPyRP8XTRp4G/art.json index e4eede32..1bf84a41 100644 --- a/art/2EjmDvPyRP8XTRp4G/art.json +++ b/art/2EjmDvPyRP8XTRp4G/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Motion\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.5;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(sin(time * 0.2), cos(time * 0.5), 1, 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Motion\n// Course Name: CS250\n// Term: Spring 2022\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.5;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(sin(time * 0.2), cos(time * 0.5), 1, 1);\n}" + }, "screenshotURL": "data/images/images-3r7x1uu6utmb7400o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2FpAyYRgGQytFrcAM/art.json b/art/2FpAyYRgGQytFrcAM/art.json index c5c33353..8aa99099 100644 --- a/art/2FpAyYRgGQytFrcAM/art.json +++ b/art/2FpAyYRgGQytFrcAM/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":16265,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//// RESET TIME!\\n\\n// 1. or 2.\\n#define LINES 2.\\n\\n#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n //float phi = 10.166407384630519631619018026484 * idx;\\n float phi = 2.399949895 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nfloat gcd(in float a, in float b) {\\n a = floor(a); b = floor(b);\\n if (b < 1.) { return 1.; }\\n for (int n = 0; n < 10; n++) {\\n if (b < 0.0001) break;\\n float bb = mod(a, b);\\n a = b;\\n b = bb;\\n }\\n return a;\\n}\\n\\nfloat shuffle(float n, float count, float st) {\\n float mult = st + gcd(count, st) / count;\\n float nn = n * mult;\\n return floor(mod(nn, count));\\n}\\n\\n//float shuffles[] = float[](8., 13., 21., 34., 42., 47., 55., 68., 76., 84., 89., 97., 102., 144.);\\nfloat getShuf(float t) {\\n t = mod(floor(t), 10.);\\n return\\n t < 1. ? 8. :\\n t < 2. ? 13. :\\n t < 3. ? 21. :\\n t < 4. ? 34. :\\n t < 5. ? 55. :\\n t < 6. ? 89. :\\n t < 7. ? 144. :\\n t < 8. ? 233. :\\n t < 9. ? 335. :\\n t < 10. ? 568. :\\n 5.\\n ;\\n}\\n\\nvoid main() {\\n float count = min(ceil(time*100.), vertexCount / LINES);\\n if (vertexId / LINES >= count) { return; }\\n float line_id = floor(vertexId / count);\\n float id = shuffle(mod(vertexId, count), count, getShuf(time/(8.) + line_id));\\n //float id = shuffle(vertexId, count, 568.);\\n //float id = shuffle(vertexId, count, ceil(time));\\n //float id = shuffle(vertexId, count, floor((mouse.x+1.)*100.));\\n vec4 vertPos = rotY(time*0.1) * vec4(SampleSpherePos(id, count), 1.0) + vec4(0,0,-3.0,0);\\n\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1.3 + vertPos.z * 0.3);\\n}\"}", + "settings": { + "num": 16265, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//// RESET TIME!\n\n// 1. or 2.\n#define LINES 2.\n\n#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n //float phi = 10.166407384630519631619018026484 * idx;\n float phi = 2.399949895 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nfloat gcd(in float a, in float b) {\n a = floor(a); b = floor(b);\n if (b < 1.) { return 1.; }\n for (int n = 0; n < 10; n++) {\n if (b < 0.0001) break;\n float bb = mod(a, b);\n a = b;\n b = bb;\n }\n return a;\n}\n\nfloat shuffle(float n, float count, float st) {\n float mult = st + gcd(count, st) / count;\n float nn = n * mult;\n return floor(mod(nn, count));\n}\n\n//float shuffles[] = float[](8., 13., 21., 34., 42., 47., 55., 68., 76., 84., 89., 97., 102., 144.);\nfloat getShuf(float t) {\n t = mod(floor(t), 10.);\n return\n t < 1. ? 8. :\n t < 2. ? 13. :\n t < 3. ? 21. :\n t < 4. ? 34. :\n t < 5. ? 55. :\n t < 6. ? 89. :\n t < 7. ? 144. :\n t < 8. ? 233. :\n t < 9. ? 335. :\n t < 10. ? 568. :\n 5.\n ;\n}\n\nvoid main() {\n float count = min(ceil(time*100.), vertexCount / LINES);\n if (vertexId / LINES >= count) { return; }\n float line_id = floor(vertexId / count);\n float id = shuffle(mod(vertexId, count), count, getShuf(time/(8.) + line_id));\n //float id = shuffle(vertexId, count, 568.);\n //float id = shuffle(vertexId, count, ceil(time));\n //float id = shuffle(vertexId, count, floor((mouse.x+1.)*100.));\n vec4 vertPos = rotY(time*0.1) * vec4(SampleSpherePos(id, count), 1.0) + vec4(0,0,-3.0,0);\n\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n v_color = vec4(1.3 + vertPos.z * 0.3);\n}" + }, "screenshotURL": "data/images/images-rqz871idb95ap9wo9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2GJcwJ2YQaAJsasSb/art.json b/art/2GJcwJ2YQaAJsasSb/art.json index d35bfef4..b22e2e31 100644 --- a/art/2GJcwJ2YQaAJsasSb/art.json +++ b/art/2GJcwJ2YQaAJsasSb/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":40000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p){return fract(fract(p*5.3983)*fract(p*.4427)*95.4337);}\\nvec2 r(vec2 p,float a){return vec2(-1,1)*p.yx*sin(a)+p.xy*cos(a);}\\nvoid main(){\\n vec3 p=vec3(h(vertexId),h(vertexId*.731),h(vertexId*1.319))-.5;\\n v_color=vec4(p+.7,1);\\n p.xy=r(p.xy,time);\\n p.xz=r(p.xz,time*2.);\\n gl_Position=vec4(p.x,p.y*resolution.x/resolution.y,p.z,p.z+1.5);\\n gl_PointSize=2.;\\n}\"}", + "settings": { + "num": 40000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p){return fract(fract(p*5.3983)*fract(p*.4427)*95.4337);}\nvec2 r(vec2 p,float a){return vec2(-1,1)*p.yx*sin(a)+p.xy*cos(a);}\nvoid main(){\n vec3 p=vec3(h(vertexId),h(vertexId*.731),h(vertexId*1.319))-.5;\n v_color=vec4(p+.7,1);\n p.xy=r(p.xy,time);\n p.xz=r(p.xz,time*2.);\n gl_Position=vec4(p.x,p.y*resolution.x/resolution.y,p.z,p.z+1.5);\n gl_PointSize=2.;\n}" + }, "screenshotURL": "data/images/images-uvde6385qyy793ucl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2GcQqCitMWiQ5QRgm/art.json b/art/2GcQqCitMWiQ5QRgm/art.json index 48fb649f..b8d7ad4f 100644 --- a/art/2GcQqCitMWiQ5QRgm/art.json +++ b/art/2GcQqCitMWiQ5QRgm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12549019607843137,0.10588235294117647,0.396078431372549,1],\"shader\":\"void main(){\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12549019607843137, + 0.10588235294117647, + 0.396078431372549, + 1 + ], + "shader": "void main(){\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-qzgph2cbzzenpe7cr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2HqTsRPbmvPseZs78/art.json b/art/2HqTsRPbmvPseZs78/art.json index db074434..e479cca2 100644 --- a/art/2HqTsRPbmvPseZs78/art.json +++ b/art/2HqTsRPbmvPseZs78/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "pöstpöp", "avatarUrl": "https://lh3.googleusercontent.com/-JUIeC9mYGbM/AAAAAAAAAAI/AAAAAAAAACE/f6C0Rr97fYs/photo.jpg", - "settings": "{\"num\":25000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n _ \\n _ _ ___ ___| |_ ___ _ _ \\n| | | -_| _| _| -_|_'_|\\n \\\\_/|___|_| |_| |___|_,_|\\n _ _ \\n ___| |_ ___ _| |___ ___ \\n|_ -| | .'| . | -_| _|\\n|___|_|_|__,|___|___|_| \\n _ \\n ___ ___| |_ \\n| .'| _| _| \\n|__,|_| |_| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomBoxPoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n p[2] = mix(-1., 1., step(0., p[2]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n p[0] = mix(-1., 1., step(0., p[0]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomSpherePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319))));\\n}\\n\\nvec3 getRandomSphereVolumePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\\n}\\n\\nvec3 getRandomCubeVolumePoint(float seed) {\\n return vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n}\\n\\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getPoint(float set, float seed) {\\n set = mod(set, 7.);\\n if (set < 1.) \\n {\\n return getRandomCubePoint(seed);\\n }\\n if (set < 2.) \\n {\\n return getRandomSphereVolumePoint(seed);\\n }\\n if (set < 3.) \\n {\\n return getRandomFunkPoint(seed, 3., 3.);\\n }\\n if (set < 4.) \\n {\\n return getRandomSpherePoint(seed);\\n }\\n if (set < 5.) \\n {\\n return getRandomBoxPoint(seed);\\n }\\n if (set < 6.)\\n {\\n return getRandomCubeVolumePoint(seed);\\n }\\n return getRandomFunkOutPoint(seed, 4., 3.);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, 3.);\\n }\\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\\n}\\n\\nvec3 getLerpedPoint(float time, float seed) {\\n float set = mod(time, 7.);\\n vec3 p0 = getPoint(set, seed);\\n vec3 p1 = getPoint(set + 1., seed);\\n return mix(p0, p1, easeInOutCubic(fract(time)));\\n}\\n\\n#define DOTS_PER 4000.\\n\\nvoid main() {\\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n\\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\\n \\n float cameraRadius = 13.;\\n float camAngle = time * 0.3;\\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n\\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(\\n m1p1(hash(thingId * 0.179)) * 6., \\n m1p1(hash(thingId * 0.317)) * 6., \\n m1p1(hash(thingId * 0.251)) * 6.));\\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\\n gl_Position = m * vec4(p, 1);\\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n\\n float hue = 0.2+ v * 0.1;\\n hue = mix(hue, 0.1, mod(floor(time * 60.0), 2.));\\n hue = mix(hue, .0, step(0.9, snd));\\n float sat = 1.;\\n float val = invClipZ * 150.;\\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n gl_PointSize = 18. / gl_Position.z;\\n}\"}", + "settings": { + "num": 25000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n _ \n _ _ ___ ___| |_ ___ _ _ \n| | | -_| _| _| -_|_'_|\n \\_/|___|_| |_| |___|_,_|\n _ _ \n ___| |_ ___ _| |___ ___ \n|_ -| | .'| . | -_| _|\n|___|_|_|__,|___|___|_| \n _ \n ___ ___| |_ \n| .'| _| _| \n|__,|_| |_| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvec3 getRandomBoxPoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n p[1] = mix(-1., 1., step(0., p[1]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n p[2] = mix(-1., 1., step(0., p[2]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n p[0] = mix(-1., 1., step(0., p[0]));\n }\n return p;\n}\n\nvec3 getRandomSpherePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319))));\n}\n\nvec3 getRandomSphereVolumePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\n}\n\nvec3 getRandomCubeVolumePoint(float seed) {\n return vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n}\n\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getPoint(float set, float seed) {\n set = mod(set, 7.);\n if (set < 1.) \n {\n return getRandomCubePoint(seed);\n }\n if (set < 2.) \n {\n return getRandomSphereVolumePoint(seed);\n }\n if (set < 3.) \n {\n return getRandomFunkPoint(seed, 3., 3.);\n }\n if (set < 4.) \n {\n return getRandomSpherePoint(seed);\n }\n if (set < 5.) \n {\n return getRandomBoxPoint(seed);\n }\n if (set < 6.)\n {\n return getRandomCubeVolumePoint(seed);\n }\n return getRandomFunkOutPoint(seed, 4., 3.);\n}\n\nfloat easeInOutCubic(float pos) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, 3.);\n }\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\n}\n\nvec3 getLerpedPoint(float time, float seed) {\n float set = mod(time, 7.);\n vec3 p0 = getPoint(set, seed);\n vec3 p1 = getPoint(set + 1., seed);\n return mix(p0, p1, easeInOutCubic(fract(time)));\n}\n\n#define DOTS_PER 4000.\n\nvoid main() {\n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\n \n float cameraRadius = 13.;\n float camAngle = time * 0.3;\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(\n m1p1(hash(thingId * 0.179)) * 6., \n m1p1(hash(thingId * 0.317)) * 6., \n m1p1(hash(thingId * 0.251)) * 6.));\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\n gl_Position = m * vec4(p, 1);\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n\n float hue = 0.2+ v * 0.1;\n hue = mix(hue, 0.1, mod(floor(time * 60.0), 2.));\n hue = mix(hue, .0, step(0.9, snd));\n float sat = 1.;\n float val = invClipZ * 150.;\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n gl_PointSize = 18. / gl_Position.z;\n}" + }, "screenshotURL": "data/images/images-63rpq4wx22w9aqfug-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2Jk6njpWPmAjyCJv4/art.json b/art/2Jk6njpWPmAjyCJv4/art.json index e52aafd7..2e0d88e3 100644 --- a/art/2Jk6njpWPmAjyCJv4/art.json +++ b/art/2Jk6njpWPmAjyCJv4/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":92153,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/diskore/m4r\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1450980392156863,0.19607843137254902,0.13725490196078433,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 65.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v / 21. - v;}\\n\\nfloat p1m1(float v) {\\n return v * mod(0.1 *time, 6.0) ;\\n}\\n\\nfloat inv(float v) {\\n return 1. + v + 2.;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 1.16 / PI * 5.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = 4.0;\\n pos = vec3(x, y+11.,- 5.); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 1.7) + tan((t *= 0.13) + mouse.y -t) + sin(t - 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles+ 5.;\\n vec3 pos;\\n float inner = mix(0.03, 11.1, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 1.033) + sin(time * 1.83 + circleId) *2.1 *mouse.x);\\n float end = start + 3.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/1.8 - 0.3)*7.) * 0.05, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 5.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) - 1.4;\\n offset.y += goop(circleId + time - 3.13) * 1.31;\\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 21.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 12.;\\n\\n float hue = mix(0.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 /snd));\\n float sat = 1. - snd;\\n float val = 1.9- snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, snd-6.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\\n}\"}", + "settings": { + "num": 92153, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/diskore/m4r", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1450980392156863, + 0.19607843137254902, + 0.13725490196078433, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 65.4337);\n}\n\nfloat m1p1(float v) {\n return v / 21. - v;}\n\nfloat p1m1(float v) {\n return v * mod(0.1 *time, 6.0) ;\n}\n\nfloat inv(float v) {\n return 1. + v + 2.;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 1.16 / PI * 5.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = 4.0;\n pos = vec3(x, y+11.,- 5.); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 1.7) + tan((t *= 0.13) + mouse.y -t) + sin(t - 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles+ 5.;\n vec3 pos;\n float inner = mix(0.03, 11.1, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 1.033) + sin(time * 1.83 + circleId) *2.1 *mouse.x);\n float end = start + 3.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/1.8 - 0.3)*7.) * 0.05, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 5.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) - 1.4;\n offset.y += goop(circleId + time - 3.13) * 1.31;\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 21.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 12.;\n\n float hue = mix(0.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 /snd));\n float sat = 1. - snd;\n float val = 1.9- snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, snd-6.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\n}" + }, "screenshotURL": "data/images/images-fl408ii7nbltbcj3u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2KcwnpWC6FyBx5N9S/art.json b/art/2KcwnpWC6FyBx5N9S/art.json index 45c37747..5f31eea5 100644 --- a/art/2KcwnpWC6FyBx5N9S/art.json +++ b/art/2KcwnpWC6FyBx5N9S/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dom-kolargones/krypton?in=dom-kolargones/sets/elements\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//[commercial] \\n\\n//Another K Machine exposed shader\\n//See it in action in the K Machine v2 on https://vimeo.com/217012333\\n//the 'K beginning' comments allows the K Machine to recognize \\n//and build adapted events controllers\\n//This shader can be copied in a text file with .glsl extension and\\n//uploaded to the K Machine. \\n//For more instructions for K Machine compliance see the doc on\\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\\n//More about the K Machine v2\\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\\n//as the K Machine has it's own relLoopProgress float parameter\\n//corresponding to the progression in the selected loop\\n\\n//[/commercial]\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=1000000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n#define parameter0 0.1//KParameter0 0.>>8.\\n#define parameter1 1.//KParameter1 1.>>8.\\n#define parameter2 0.//KParameter2 0.>>1.\\n#define parameter3 20.//KParameter3 5>>100.\\n#define parameter4 0.1//KParameter4 0.05>>0.2\\n#define parameter5 0.1//KParameter5 0.>>1.\\n#define parameter6 0.6//KParameter6 -3.>>3.\\n#define parameter7 0.//KParameter7 -3.>>3.\\n\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\\n{\\n vec3 u = _triangleVertices0 - _triangleVertices1;\\n vec3 v = _triangleVertices1 - _triangleVertices2;\\n return normalize(cross(v, u));\\n}\\n\\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\\n{\\n float localVid = mod(_vId,_vtn);\\n \\n if(localVid< 1.)\\n {\\n \\n _v = _vt[0];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n \\n }\\n else\\n if(localVid< 2.)\\n {\\n _v = _vt[1];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 3.)\\n {\\n _v = _vt[2];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 4.)\\n {\\n _v = _vt[3];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 5.)\\n {\\n _v = _vt[4];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 6.)\\n {\\n _v = _vt[5];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 7.)\\n {\\n _v = _vt[6];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 8.)\\n {\\n _v = _vt[7];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 9.)\\n {\\n _v = _vt[8];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 10.)\\n {\\n _v = _vt[9];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 11.)\\n {\\n _v = _vt[10];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 12.)\\n {\\n _v = _vt[11];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n \\n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\\n \\n _v = rotY(_v,_rot.y);\\n _n = rotY(_n,_rot.y);\\n \\n \\n _v = rotX(_v,_rot.x);\\n _n = rotX(_n,_rot.x);\\n \\n _v = rotZ(_v,_rot.z);\\n _n = rotZ(_n,_rot.z);\\n \\n _v += _pos;\\n //_n += _pos;\\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n //float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\\n specular = max(0.0, pow(NDoth, _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n \\n //for vsa\\n \\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n \\n //end for vsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops = floor(parameter1);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n \\n \\n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops2 = floor(1.);\\n float subLoopLength2 = 1./numberOfSubLoops2;\\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n vec3 _n = vec3(0.,0.,0.);\\n \\n vec3 shapeVertices[12];\\n float shapeSize = 12.;\\n \\n \\n \\n \\n float maxShapeCount = floor(vertexCount/shapeSize);\\n \\n float shapeId = floor(vertexId/shapeSize);\\n float relShapeId = shapeId/maxShapeCount;\\n float scale = parameter4;\\n \\n \\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\\n float localShapeId = mod(shapeId,numberOfShape);\\n float localRelShapeId = localShapeId/numberOfShape;\\n float radius = 0.1+parameter5*floor(shapeId/numberOfShape);\\n \\n float sf = texture2D(sound, vec2(0., relShapeId)).a ;\\n \\n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),sf);\\n \\n \\n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\\n shapeVertices[1] = vec3(0.5,0.,-0.5);\\n shapeVertices[2] = vec3(0.,1.,0.-factor);\\n shapeVertices[3] = vec3(0.5,0.,-0.5);\\n shapeVertices[4] = vec3(0.5,0.,0.5);\\n shapeVertices[5] = vec3(0.+factor,1.,0.);\\n shapeVertices[6] =vec3(0.5,0.,0.5);\\n shapeVertices[7] =vec3(-0.5,0.,0.5);\\n shapeVertices[8] =vec3(0.,1.,0.+factor);\\n shapeVertices[9] =vec3(-0.5,0.,0.5);\\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\\n shapeVertices[11] =vec3(0.-factor,1.,0.);\\n \\n vec3 shapeColors[4];\\n /*\\n shapeColors[0] = vec3(1.,0.,0.);\\n shapeColors[1] = vec3(0.,1.,0.);\\n shapeColors[2] = vec3(0.,0.,1.);\\n shapeColors[3] = vec3(0.,1.,1.);\\n */\\n shapeColors[0] = vec3(1.,0.,0.+parameter7);\\n shapeColors[1] = vec3(0.,1.-parameter7,1.);\\n shapeColors[2] = vec3(1.-parameter7,0.,0.);\\n shapeColors[3] = vec3(1.-parameter7,1.-parameter7,0.);\\n \\n vec3 rot = vec3(PI/2.,0.,(time*2.*PI)+ (localRelShapeId*PI*2.));\\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, vertexId, shapePos, rot, _n, _v, color, scale);\\n \\n \\n \\n //vec3 eye = vec3(0.0, 0.0, -1.-sin(finalRelLoopProgress2*PI));\\n vec3 eye = vec3(cos(time/50.*2.*PI+0.6), sin(time*0.01*PI+time)*0.5, sin(time/20.*PI));\\n if(parameter6<0.5)\\n {\\n eye = vec3(0.0, 0.0, -1.-sin(finalRelLoopProgress2*PI));\\n }\\n //vec3 eye = vec3(cos(time/50.*2.*PI+0.6), sin(time*0.01*PI+time)*0.5, sin(time/20.*PI));\\n //vec3 eye = vec3(0.02*cos(time/10.*2.*PI), 0., -0.001- abs(sin(time/20.*PI)));//.*sin(time/20.*PI));\\n //vec3 eye = vec3(parameter5, parameter6, parameter7);\\n color = shade(eye, _v, _n, color, 0.9, vec2(64.0, 3.8));\\n \\n vec3 p = lookAt(_v, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n \\n _v.x*=resolution.y/resolution.x;\\n \\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dom-kolargones/krypton?in=dom-kolargones/sets/elements", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//[commercial] \n\n//Another K Machine exposed shader\n//See it in action in the K Machine v2 on https://vimeo.com/217012333\n//the 'K beginning' comments allows the K Machine to recognize \n//and build adapted events controllers\n//This shader can be copied in a text file with .glsl extension and\n//uploaded to the K Machine. \n//For more instructions for K Machine compliance see the doc on\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\n//More about the K Machine v2\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\n//as the K Machine has it's own relLoopProgress float parameter\n//corresponding to the progression in the selected loop\n\n//[/commercial]\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=1000000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n#define parameter0 0.1//KParameter0 0.>>8.\n#define parameter1 1.//KParameter1 1.>>8.\n#define parameter2 0.//KParameter2 0.>>1.\n#define parameter3 20.//KParameter3 5>>100.\n#define parameter4 0.1//KParameter4 0.05>>0.2\n#define parameter5 0.1//KParameter5 0.>>1.\n#define parameter6 0.6//KParameter6 -3.>>3.\n#define parameter7 0.//KParameter7 -3.>>3.\n\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\n{\n vec3 u = _triangleVertices0 - _triangleVertices1;\n vec3 v = _triangleVertices1 - _triangleVertices2;\n return normalize(cross(v, u));\n}\n\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\n{\n float localVid = mod(_vId,_vtn);\n \n if(localVid< 1.)\n {\n \n _v = _vt[0];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n \n }\n else\n if(localVid< 2.)\n {\n _v = _vt[1];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 3.)\n {\n _v = _vt[2];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 4.)\n {\n _v = _vt[3];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 5.)\n {\n _v = _vt[4];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 6.)\n {\n _v = _vt[5];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 7.)\n {\n _v = _vt[6];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 8.)\n {\n _v = _vt[7];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 9.)\n {\n _v = _vt[8];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 10.)\n {\n _v = _vt[9];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 11.)\n {\n _v = _vt[10];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 12.)\n {\n _v = _vt[11];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n \n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\n \n _v = rotY(_v,_rot.y);\n _n = rotY(_n,_rot.y);\n \n \n _v = rotX(_v,_rot.x);\n _n = rotX(_n,_rot.x);\n \n _v = rotZ(_v,_rot.z);\n _n = rotZ(_n,_rot.z);\n \n _v += _pos;\n //_n += _pos;\n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n //float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\n specular = max(0.0, pow(NDoth, _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\n\nvoid main() {\n \n vec3 color = vec3(1.);\n \n //for vsa\n \n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n \n //end for vsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops = floor(parameter1);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n \n \n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops2 = floor(1.);\n float subLoopLength2 = 1./numberOfSubLoops2;\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\n \n vec3 _v = vec3(0.,0.,0.);\n vec3 _n = vec3(0.,0.,0.);\n \n vec3 shapeVertices[12];\n float shapeSize = 12.;\n \n \n \n \n float maxShapeCount = floor(vertexCount/shapeSize);\n \n float shapeId = floor(vertexId/shapeSize);\n float relShapeId = shapeId/maxShapeCount;\n float scale = parameter4;\n \n \n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\n float localShapeId = mod(shapeId,numberOfShape);\n float localRelShapeId = localShapeId/numberOfShape;\n float radius = 0.1+parameter5*floor(shapeId/numberOfShape);\n \n float sf = texture2D(sound, vec2(0., relShapeId)).a ;\n \n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),sf);\n \n \n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\n shapeVertices[1] = vec3(0.5,0.,-0.5);\n shapeVertices[2] = vec3(0.,1.,0.-factor);\n shapeVertices[3] = vec3(0.5,0.,-0.5);\n shapeVertices[4] = vec3(0.5,0.,0.5);\n shapeVertices[5] = vec3(0.+factor,1.,0.);\n shapeVertices[6] =vec3(0.5,0.,0.5);\n shapeVertices[7] =vec3(-0.5,0.,0.5);\n shapeVertices[8] =vec3(0.,1.,0.+factor);\n shapeVertices[9] =vec3(-0.5,0.,0.5);\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\n shapeVertices[11] =vec3(0.-factor,1.,0.);\n \n vec3 shapeColors[4];\n /*\n shapeColors[0] = vec3(1.,0.,0.);\n shapeColors[1] = vec3(0.,1.,0.);\n shapeColors[2] = vec3(0.,0.,1.);\n shapeColors[3] = vec3(0.,1.,1.);\n */\n shapeColors[0] = vec3(1.,0.,0.+parameter7);\n shapeColors[1] = vec3(0.,1.-parameter7,1.);\n shapeColors[2] = vec3(1.-parameter7,0.,0.);\n shapeColors[3] = vec3(1.-parameter7,1.-parameter7,0.);\n \n vec3 rot = vec3(PI/2.,0.,(time*2.*PI)+ (localRelShapeId*PI*2.));\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, vertexId, shapePos, rot, _n, _v, color, scale);\n \n \n \n //vec3 eye = vec3(0.0, 0.0, -1.-sin(finalRelLoopProgress2*PI));\n vec3 eye = vec3(cos(time/50.*2.*PI+0.6), sin(time*0.01*PI+time)*0.5, sin(time/20.*PI));\n if(parameter6<0.5)\n {\n eye = vec3(0.0, 0.0, -1.-sin(finalRelLoopProgress2*PI));\n }\n //vec3 eye = vec3(cos(time/50.*2.*PI+0.6), sin(time*0.01*PI+time)*0.5, sin(time/20.*PI));\n //vec3 eye = vec3(0.02*cos(time/10.*2.*PI), 0., -0.001- abs(sin(time/20.*PI)));//.*sin(time/20.*PI));\n //vec3 eye = vec3(parameter5, parameter6, parameter7);\n color = shade(eye, _v, _n, color, 0.9, vec2(64.0, 3.8));\n \n vec3 p = lookAt(_v, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n \n _v.x*=resolution.y/resolution.x;\n \n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-99r0l8qv1e9so2fsb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2LCzyt3dGEKL3dcTG/art.json b/art/2LCzyt3dGEKL3dcTG/art.json index ab07038a..681ce055 100644 --- a/art/2LCzyt3dGEKL3dcTG/art.json +++ b/art/2LCzyt3dGEKL3dcTG/art.json @@ -35,7 +35,19 @@ "unlisted": false, "username": "재우", "avatarUrl": "https://lh6.googleusercontent.com/-2X_KPdDSJQw/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd6jrLpiakTtViM5yPJkYwfQJhnhQ/mo/photo.jpg", - "settings": "{\"num\":6084,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t: jaewoo choi\\nAssignment Name/Number\\t: Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() \\n{\\n float point = vertexId*3.;\\n \\n gl_Position = vec4(sin(point)*mouse.x,cos(point)*mouse.y,0,1);\\n \\n \\n\\n gl_PointSize =55.;\\n \\n v_color = vec4(sin(time),cos(time),tan(time),1.0);\\n \\n} \"}", + "settings": { + "num": 6084, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t: jaewoo choi\nAssignment Name/Number\t: Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() \n{\n float point = vertexId*3.;\n \n gl_Position = vec4(sin(point)*mouse.x,cos(point)*mouse.y,0,1);\n \n \n\n gl_PointSize =55.;\n \n v_color = vec4(sin(time),cos(time),tan(time),1.0);\n \n} " + }, "screenshotURL": "data/images/images-5gf2z1oixv439ctl6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2PbekWKKMe8gWdJ3z/art.json b/art/2PbekWKKMe8gWdJ3z/art.json index 9eab0b29..9c469777 100644 --- a/art/2PbekWKKMe8gWdJ3z/art.json +++ b/art/2PbekWKKMe8gWdJ3z/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":8752,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Audio Reactive\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 8752, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Audio Reactive\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-dmsaddapo6glocsho-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2QLFrSm3uSxdnEW58/art.json b/art/2QLFrSm3uSxdnEW58/art.json index 11fd886b..b6438ff5 100644 --- a/art/2QLFrSm3uSxdnEW58/art.json +++ b/art/2QLFrSm3uSxdnEW58/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":3182,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bottomforty/bottom-forty-mix-038-chris-camplin\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount));\\n \\tfloat cols = floor(vertexCount / rows);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(time + y * 0.25) * 0.1;\\n \\tfloat yOff = sin(time + x * 0.25) * 0.2;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n \\tfloat soff = sin(time + x * y * 0.05) * 5.5;\\n\\tgl_Position = vec4(ux, vy, 0, 1);\\n \\tgl_PointSize = 10.0 + soff; \\n \\tgl_PointSize *= 20.0 / cols; \\n \\tgl_PointSize *= resolution.x / 600.; \\n \\tv_color = vec4(0.287, 0.666, 0.767, 1);\\n}\"}", + "settings": { + "num": 3182, + "mode": "POINTS", + "sound": "https://soundcloud.com/bottomforty/bottom-forty-mix-038-chris-camplin", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount));\n \tfloat cols = floor(vertexCount / rows);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(time + y * 0.25) * 0.1;\n \tfloat yOff = sin(time + x * 0.25) * 0.2;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n \tfloat soff = sin(time + x * y * 0.05) * 5.5;\n\tgl_Position = vec4(ux, vy, 0, 1);\n \tgl_PointSize = 10.0 + soff; \n \tgl_PointSize *= 20.0 / cols; \n \tgl_PointSize *= resolution.x / 600.; \n \tv_color = vec4(0.287, 0.666, 0.767, 1);\n}" + }, "screenshotURL": "data/images/images-k9is5iiicaar5hz2q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2RntyLszQwDn9wi85/art.json b/art/2RntyLszQwDn9wi85/art.json index de26456c..b935af37 100644 --- a/art/2RntyLszQwDn9wi85/art.json +++ b/art/2RntyLszQwDn9wi85/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":89617,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-0.5, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 89617, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-0.5, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-hmfcwreq0hqaqc48d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2WGSa559MiYvnoJZw/art.json b/art/2WGSa559MiYvnoJZw/art.json index ade1ef47..2510c6ce 100644 --- a/art/2WGSa559MiYvnoJZw/art.json +++ b/art/2WGSa559MiYvnoJZw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(0.4, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 2.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6);\\nfloat gExposure = 0.2;\\nfloat gCubeColorRandom = .5;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 3.6;\\nfloat gFloorHeight = -43.0*mouse.x;\\nfloat g_cameraFar = 105.0 *mouse.y;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 80.3, -50.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.3, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 2.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.25 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 1, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 2.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.25);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\\n float z = vP * down * 11.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 10.);\\n mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \\n pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 0.78;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\\n float ca = 0.01;\\n \\n // get sick!\\n ca = time * 0.7;\\n \\tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(0.4, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 2.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6);\nfloat gExposure = 0.2;\nfloat gCubeColorRandom = .5;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 3.6;\nfloat gFloorHeight = -43.0*mouse.x;\nfloat g_cameraFar = 105.0 *mouse.y;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 80.3, -50.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.3, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 2.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.25 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 1, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 2.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.25);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\n float z = vP * down * 11.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 10.);\n mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \n pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 0.78;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\n \tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\n float ca = 0.01;\n \n // get sick!\n ca = time * 0.7;\n \tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-qii625i7auta418b6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2WtKojEgxqkRD7ExF/art.json b/art/2WtKojEgxqkRD7ExF/art.json index efee314e..e345f192 100644 --- a/art/2WtKojEgxqkRD7ExF/art.json +++ b/art/2WtKojEgxqkRD7ExF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.10588235294117647,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.0, 1.0));\\n vec4 K = vec4(1.0, c.x/ 0.6, 1.0 * 3.-c.z, 3.0);\\n vec3 p = abs(fract(-c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,5./3.03, 1.3), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = tan( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,1, -s*c,c-.4,\\n \\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = fract(tan( angle-1.0*time) );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, c-s , 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, \\n 2.0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 2,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[2,1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][2,1], m[1][1], m[1][0], \\n m[0][2], m[1][0,2], m[2][1,2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[2],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][2,3], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 / a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 * a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 / a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 / a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 - a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 + b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 / b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 / b01 + a22 * b00) /(det -\\n mouse.x);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 2\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target / eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 1.0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.7);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -2.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*4378.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n \\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*5.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 23.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return tan(p.y -4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 1.20*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;\\n (0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, sin(time-mouse.y)- id, step(2.5, id));\\n float ux = floor(outId / id) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(2., fbm(p.xz) ,0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * .666);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, -3., qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1,12));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + .5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 2./ct, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.6 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float ss = texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float pop = step(0.6, ss);\\n val = mix(val, 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 11. - 2.)*6.), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback / cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 5.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.10588235294117647, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.0, 1.0));\n vec4 K = vec4(1.0, c.x/ 0.6, 1.0 * 3.-c.z, 3.0);\n vec3 p = abs(fract(-c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,5./3.03, 1.3), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = tan( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,1, -s*c,c-.4,\n \n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = fract(tan( angle-1.0*time) );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, c-s , 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, \n 2.0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 2,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[2,1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][2,1], m[1][1], m[1][0], \n m[0][2], m[1][0,2], m[2][1,2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[2],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][2,3], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 / a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 * a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 / a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 / a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 - a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 + b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 / b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 / b01 + a22 * b00) /(det -\n mouse.x);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 2\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target / eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 1.0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.7);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -2.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*4378.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n \n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*5.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 23.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return tan(p.y -4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 1.20*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;\n (0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, sin(time-mouse.y)- id, step(2.5, id));\n float ux = floor(outId / id) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(2., fbm(p.xz) ,0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * .666);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, -3., qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1,12));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + .5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 2./ct, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.6 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float ss = texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float pop = step(0.6, ss);\n val = mix(val, 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 11. - 2.)*6.), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback / cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 5.0;\n}" + }, "screenshotURL": "data/images/images-btwsj92fdnd53q1lu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2XgSDRuhBYPBvZ9QX/art.json b/art/2XgSDRuhBYPBvZ9QX/art.json index 8451933a..9918ebf2 100644 --- a/art/2XgSDRuhBYPBvZ9QX/art.json +++ b/art/2XgSDRuhBYPBvZ9QX/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "지수", "avatarUrl": "https://lh3.googleusercontent.com/-tFabpELU8Ek/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rckoLg-TbHvNc6bC2X3qGKF3IrwXQ/mo/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0,0.5019607843137255,1],\"shader\":\"void main()\\n{ \\n float across = 10.0;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.0);\\n float v = y / (across-1.0);\\n \\n float ux = u *2.0 - 1.0;\\n float vy = v *2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0.0, 1.0);\\n \\n v_color = vec4(mouse.x, mouse.y, 0.0, 1.0);\\n \\n gl_PointSize = abs(cos(time)*100.0);\\n}\\n\\n\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0, + 0.5019607843137255, + 1 + ], + "shader": "void main()\n{ \n float across = 10.0;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.0);\n float v = y / (across-1.0);\n \n float ux = u *2.0 - 1.0;\n float vy = v *2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0.0, 1.0);\n \n v_color = vec4(mouse.x, mouse.y, 0.0, 1.0);\n \n gl_PointSize = abs(cos(time)*100.0);\n}\n\n\n" + }, "screenshotURL": "data/images/images-regy1suzhml3tveou-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2YWRHPyRWHGo6A9My/art.json b/art/2YWRHPyRWHGo6A9My/art.json index dc877632..87e80513 100644 --- a/art/2YWRHPyRWHGo6A9My/art.json +++ b/art/2YWRHPyRWHGo6A9My/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"///GLSL\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\\n /*RGB */\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "///GLSL\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\n /*RGB */\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-68l30iugiqfjr92f9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2bWezECppzztDLn4T/art.json b/art/2bWezECppzztDLn4T/art.json index c5046082..a2b67175 100644 --- a/art/2bWezECppzztDLn4T/art.json +++ b/art/2bWezECppzztDLn4T/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "juhye", "avatarUrl": "https://lh5.googleusercontent.com/-WIjF1SYiutc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfjC8iee2cn7usm3MsiloBz79O9-Q/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t: Joohye Son\\nAssignment Name/Number\\t: Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n\\nvoid main() {\\n\\n float Id=vertexId;\\n float x=mouse.x;\\n float y=mouse.y;\\n float xTime=sin(time);\\n float yTime=cos(time);\\n \\n gl_Position=vec4(xTime*x, yTime*y*cos(Id), 0, 1);\\n gl_PointSize=20.;\\n float zTime=tan(time);\\n v_color=vec4(xTime, yTime, zTime, 1);\\n \\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t: Joohye Son\nAssignment Name/Number\t: Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n\nvoid main() {\n\n float Id=vertexId;\n float x=mouse.x;\n float y=mouse.y;\n float xTime=sin(time);\n float yTime=cos(time);\n \n gl_Position=vec4(xTime*x, yTime*y*cos(Id), 0, 1);\n gl_PointSize=20.;\n float zTime=tan(time);\n v_color=vec4(xTime, yTime, zTime, 1);\n \n}" + }, "screenshotURL": "data/images/images-iza6hf1e4zefs8y37-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2cL3kfaKBExkWc5Le/art.json b/art/2cL3kfaKBExkWc5Le/art.json index c371ea60..b9720985 100644 --- a/art/2cL3kfaKBExkWc5Le/art.json +++ b/art/2cL3kfaKBExkWc5Le/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chemlo", "avatarUrl": "https://secure.gravatar.com/avatar/bd1fc3e2f0d77392e06266faedc63267?default=retro&size=200", - "settings": "{\"num\":240,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/neilcic/mouthsilence\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07450980392156863,0.8431372549019608,0.8431372549019608,1],\"shader\":\"#define PI radians(180.)\\n#define GAMMA 0.454545\\n\\n\\nfloat soundIntensity(float frq){\\n\\treturn texture2D(sound, vec2(frq, 0)).a;\\n}\\n\\nfloat meanIntensity(){\\n \\tconst float samples = 50.;\\n \\tfloat intensity;\\n for(float i = 0.; i < samples; i+=1./samples){\\n \\tintensity += soundIntensity(i);\\n }\\n\\treturn intensity/samples;\\n}\\n\\nvec3 getVertexColor(){\\n\\tfloat ratio = vertexId/vertexCount;\\n \\tfloat intensity = soundIntensity(ratio);\\n \\treturn vec3(0.5, 0., 0.5);\\n}\\n\\nvoid main(){\\n \\tfloat aspect = resolution.x / resolution.y;\\n\\tfloat vertexRatio = vertexId/vertexCount;\\n float vertexRadians = vertexRatio * PI * 2.;\\n \\t\\n float x = cos(vertexRadians);\\n float y = sin(vertexRadians);\\n float z = vertexRatio;\\n \\n gl_Position = vec4(\\n x,\\n y*aspect,\\n 1. - z,\\n 3. - meanIntensity()\\n );\\n \\n \\tv_color = vec4(getVertexColor(), 0.5);\\n \\n \\tfloat frequencyScale = 6.;\\n \\tgl_PointSize = pow(soundIntensity(0.075*pow(vertexRatio+0.5,frequencyScale))+1.1, 7.);\\n\\n}\"}", + "settings": { + "num": 240, + "mode": "POINTS", + "sound": "https://soundcloud.com/neilcic/mouthsilence", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07450980392156863, + 0.8431372549019608, + 0.8431372549019608, + 1 + ], + "shader": "#define PI radians(180.)\n#define GAMMA 0.454545\n\n\nfloat soundIntensity(float frq){\n\treturn texture2D(sound, vec2(frq, 0)).a;\n}\n\nfloat meanIntensity(){\n \tconst float samples = 50.;\n \tfloat intensity;\n for(float i = 0.; i < samples; i+=1./samples){\n \tintensity += soundIntensity(i);\n }\n\treturn intensity/samples;\n}\n\nvec3 getVertexColor(){\n\tfloat ratio = vertexId/vertexCount;\n \tfloat intensity = soundIntensity(ratio);\n \treturn vec3(0.5, 0., 0.5);\n}\n\nvoid main(){\n \tfloat aspect = resolution.x / resolution.y;\n\tfloat vertexRatio = vertexId/vertexCount;\n float vertexRadians = vertexRatio * PI * 2.;\n \t\n float x = cos(vertexRadians);\n float y = sin(vertexRadians);\n float z = vertexRatio;\n \n gl_Position = vec4(\n x,\n y*aspect,\n 1. - z,\n 3. - meanIntensity()\n );\n \n \tv_color = vec4(getVertexColor(), 0.5);\n \n \tfloat frequencyScale = 6.;\n \tgl_PointSize = pow(soundIntensity(0.075*pow(vertexRatio+0.5,frequencyScale))+1.1, 7.);\n\n}" + }, "screenshotURL": "data/images/images-fz2si0ijh1jc7vqvw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2dNusyoCHaevCCYP7/art.json b/art/2dNusyoCHaevCCYP7/art.json index 4b9aff31..27497ec2 100644 --- a/art/2dNusyoCHaevCCYP7/art.json +++ b/art/2dNusyoCHaevCCYP7/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":8040,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n \\n float snd = texture2D(sound, vec2(oC, oS)).a;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_PointSize = 3.0;\\n gl_Position = vec4(xy * aspect + 0.1 * 0.1, 0, 1);\\n \\n float hue = (time * 0.01 + count * 1.001) - 2. / snd;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 8040, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n \n float snd = texture2D(sound, vec2(oC, oS)).a;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_PointSize = 3.0;\n gl_Position = vec4(xy * aspect + 0.1 * 0.1, 0, 1);\n \n float hue = (time * 0.01 + count * 1.001) - 2. / snd;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-d028m75nb0x0sxgif-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2djzoxSxpM9HnRXQH/art.json b/art/2djzoxSxpM9HnRXQH/art.json index 03b3753e..04a2259d 100644 --- a/art/2djzoxSxpM9HnRXQH/art.json +++ b/art/2djzoxSxpM9HnRXQH/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "clydepashley", "avatarUrl": "https://avatars.githubusercontent.com/clydepashley?s=200", - "settings": "{\"num\":5912,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/wondem/01-veggie-wondem-ras-g-sd-master01wav\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt (vertexCount));\\n float across = floor (vertexCount / down);\\n \\n //Create Grid\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n //Respace out\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n x = u;\\n y = v;\\n \\n //Move back around origin\\n x = x * 2. - 1.;\\n y = y * 2. - 1.;\\n \\n //Sin\\n x = sin(x/y);\\n y = sin(x/y);\\n \\n float sin_thing = sin(vertexId + time);\\n float snd = texture2D(sound, vec2(u, 0.)).a;\\n \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = sin_thing * 10.;\\n v_color = vec4(snd * 4., sin_thing * 20.,mod(snd,1.),1);\\n //v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\\n}\"}", + "settings": { + "num": 5912, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/wondem/01-veggie-wondem-ras-g-sd-master01wav", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt (vertexCount));\n float across = floor (vertexCount / down);\n \n //Create Grid\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n //Respace out\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n x = u;\n y = v;\n \n //Move back around origin\n x = x * 2. - 1.;\n y = y * 2. - 1.;\n \n //Sin\n x = sin(x/y);\n y = sin(x/y);\n \n float sin_thing = sin(vertexId + time);\n float snd = texture2D(sound, vec2(u, 0.)).a;\n \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = sin_thing * 10.;\n v_color = vec4(snd * 4., sin_thing * 20.,mod(snd,1.),1);\n //v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\n}" + }, "screenshotURL": "data/images/images-ve3qzf2883oofr4j0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2dq4p8bnavjoyhq6E/art.json b/art/2dq4p8bnavjoyhq6E/art.json index 8c7d490c..01735b43 100644 --- a/art/2dq4p8bnavjoyhq6E/art.json +++ b/art/2dq4p8bnavjoyhq6E/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":1073,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Color exercise\\n//2022 spring\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1+ x * 0.3) * 0.2; //may can remove last one\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 1073, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Color exercise\n//2022 spring\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1+ x * 0.3) * 0.2; //may can remove last one\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-fcivbdz6hz01hqvzx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2dsE7Bcq8iHknqYSm/art.json b/art/2dsE7Bcq8iHknqYSm/art.json index 17738a5a..74bed43a 100644 --- a/art/2dsE7Bcq8iHknqYSm/art.json +++ b/art/2dsE7Bcq8iHknqYSm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":5870,\"mode\":\"LINES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define kp0 mod(cos(time*0.60),2.3) //KParameter -5.>>5.\\n#define kp1 cos(-2.10/time)*1.31//KParameter -6.>>5.\\n#define kp2 sin(1.-time*0.30)//KParameter -6.>>5.\\n#define kp3 sin(.6-time*0.930)//KParameter -6.>>5.\\n#define kp4 sin(-time*0.70)//KParameter -6.>>5.\\n#define kp5 sin(-time*.130)//KParameter -6.>>5.\\n//#define kp0 -5.//KParameter -5.>>5.\\n//#define kp1 1.//KParameter -6.>>5.\\n//KVerticesNumber=16622\\n\\n\\n\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.0030;\\n \\tfloat transitionStrength = 1.3*kp5;\\n \\tvec3 colKernel0 = vec3(1,0,1.-kp3);\\n \\tvec3 colKernel1 = vec3(0,kp2,0);\\n \\tvec3 colTransition = vec3(kp0,kp4,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = .5 - kp1* 0.5;\\n\\tfloat ce = -1.5+ kp0* 3.+1.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 1, 0);\\n\\tvec3 up = vec3(0, 0.6,1.);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(33.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = .2 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * 1.23, 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, sin(mouse.y/8.),\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,\\n \\n 2.)*0.3;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye*2.);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 1,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.45); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 5870, + "mode": "LINES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define kp0 mod(cos(time*0.60),2.3) //KParameter -5.>>5.\n#define kp1 cos(-2.10/time)*1.31//KParameter -6.>>5.\n#define kp2 sin(1.-time*0.30)//KParameter -6.>>5.\n#define kp3 sin(.6-time*0.930)//KParameter -6.>>5.\n#define kp4 sin(-time*0.70)//KParameter -6.>>5.\n#define kp5 sin(-time*.130)//KParameter -6.>>5.\n//#define kp0 -5.//KParameter -5.>>5.\n//#define kp1 1.//KParameter -6.>>5.\n//KVerticesNumber=16622\n\n\n\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.0030;\n \tfloat transitionStrength = 1.3*kp5;\n \tvec3 colKernel0 = vec3(1,0,1.-kp3);\n \tvec3 colKernel1 = vec3(0,kp2,0);\n \tvec3 colTransition = vec3(kp0,kp4,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = .5 - kp1* 0.5;\n\tfloat ce = -1.5+ kp0* 3.+1.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 1, 0);\n\tvec3 up = vec3(0, 0.6,1.);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(33.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = .2 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * 1.23, 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, sin(mouse.y/8.),\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,\n \n 2.)*0.3;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye*2.);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 1,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.45); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-h1ad2t1gvr8azkgtj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2iJ8ao6MN4Xmw8RKM/art.json b/art/2iJ8ao6MN4Xmw8RKM/art.json index 00a35b56..0af77bbc 100644 --- a/art/2iJ8ao6MN4Xmw8RKM/art.json +++ b/art/2iJ8ao6MN4Xmw8RKM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "shortwavedave", "avatarUrl": "https://secure.gravatar.com/avatar/5999d47c7003bd60c3f1bfd965a79666?default=retro&size=200", - "settings": "{\"num\":20536,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/col_eco/noir-master\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * .1;\\n float yoff = 0.;//sin(time + x * 0.2) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n \\n float sv = abs(v - 0.5)*2.;\\n float su = abs(u - 0.5)*3.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au*0.05, av*.125)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n \\n float soff = 0.;//sin(time+x*y*0.02) * 5.;\\n \\n \\n gl_PointSize = pow(snd+0.2, 8.) * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u*.1 + snd*.2 + time *.1;//sin(time + v * 20.)*0.05;\\n float sat = mix(0., 1., pump); //step(0.8, snd);;//mix(2.,-10., av);\\n float val = mix(.1, pow(snd + 0.2, 16.), pump);//sin(time + v*u*20.)*.5 +.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 20536, + "mode": "POINTS", + "sound": "https://soundcloud.com/col_eco/noir-master", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * .1;\n float yoff = 0.;//sin(time + x * 0.2) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n \n float sv = abs(v - 0.5)*2.;\n float su = abs(u - 0.5)*3.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au*0.05, av*.125)).a;\n \n gl_Position = vec4(xy,0,1);\n \n \n float soff = 0.;//sin(time+x*y*0.02) * 5.;\n \n \n gl_PointSize = pow(snd+0.2, 8.) * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u*.1 + snd*.2 + time *.1;//sin(time + v * 20.)*0.05;\n float sat = mix(0., 1., pump); //step(0.8, snd);;//mix(2.,-10., av);\n float val = mix(.1, pow(snd + 0.2, 16.), pump);//sin(time + v*u*20.)*.5 +.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-1ei718clezmu2czk0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2iNJXhqJXRjFNZ3K7/art.json b/art/2iNJXhqJXRjFNZ3K7/art.json index cdfa49df..f64fa722 100644 --- a/art/2iNJXhqJXRjFNZ3K7/art.json +++ b/art/2iNJXhqJXRjFNZ3K7/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4610,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, s, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, (sin(time * 3.)));\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 3.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .15));\\n gl_PointSize =pow(sz, s*s/32.\\n ) * resolution.y / 4776. * s* 30.;\\n \\n \\n\\n float hue = sz * 2. + s * 0.953;\\n float sat = 1.;\\n float val = s*2.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 4610, + "mode": "POINTS", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, s, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, (sin(time * 3.)));\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 3.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .15));\n gl_PointSize =pow(sz, s*s/32.\n ) * resolution.y / 4776. * s* 30.;\n \n \n\n float hue = sz * 2. + s * 0.953;\n float sat = 1.;\n float val = s*2.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-28l0nzjsmirdufjpn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2ir5RybtZsBG4Hgmr/art.json b/art/2ir5RybtZsBG4Hgmr/art.json index 2d4ff299..d0fd267a 100644 --- a/art/2ir5RybtZsBG4Hgmr/art.json +++ b/art/2ir5RybtZsBG4Hgmr/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive Art\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive Art\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-6ihf60oluvwa7imit-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2ivK8La4P8NhKkMDH/art.json b/art/2ivK8La4P8NhKkMDH/art.json index 7d908303..a0d96581 100644 --- a/art/2ivK8La4P8NhKkMDH/art.json +++ b/art/2ivK8La4P8NhKkMDH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/reunion-tour?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nmat4 perspectiveCam(){\\n float a = resolution.y / resolution.x;\\n float fov = 0.1;\\n return mat4(\\n a, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, fov, -1,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 translate(vec3 t)\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n t.x, t.y, t.z, 1);\\n}\\n\\nvoid main() {\\n float trix = mod(vertexId, 2.);\\n float triy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n vec2 trixy = vec2(trix * resolution.y / resolution.x, triy);\\n \\n float quadId = floor(vertexId / 6.);\\n float quadCount = quadId / floor(vertexCount / 6.);\\n float quadx = floor(quadId / 4.);\\n float quady = mod(quadId, 8.);\\n vec2 quadxy = vec2(quadx, quady);\\n \\n gl_Position = vec4((trixy + quadxy) * 0.0625, 0, 1);\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/reunion-tour?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nmat4 perspectiveCam(){\n float a = resolution.y / resolution.x;\n float fov = 0.1;\n return mat4(\n a, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, fov, -1,\n 0, 0, 0, 1);\n}\n\nmat4 translate(vec3 t)\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n t.x, t.y, t.z, 1);\n}\n\nvoid main() {\n float trix = mod(vertexId, 2.);\n float triy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n vec2 trixy = vec2(trix * resolution.y / resolution.x, triy);\n \n float quadId = floor(vertexId / 6.);\n float quadCount = quadId / floor(vertexCount / 6.);\n float quadx = floor(quadId / 4.);\n float quady = mod(quadId, 8.);\n vec2 quadxy = vec2(quadx, quady);\n \n gl_Position = vec4((trixy + quadxy) * 0.0625, 0, 1);\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-y01wegzeg5g0vxpog-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2jqfBeNCFdBpfJ2RM/art.json b/art/2jqfBeNCFdBpfJ2RM/art.json index b0c5bc31..5c8aedc0 100644 --- a/art/2jqfBeNCFdBpfJ2RM/art.json +++ b/art/2jqfBeNCFdBpfJ2RM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gregoireciles", "avatarUrl": "https://avatars.githubusercontent.com/GregoireCiles?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.011764705882352941,0,0.1803921568627451,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float soff = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.011764705882352941, + 0, + 0.1803921568627451, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float soff = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-fi0ho5x76bbx8fpit-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2n27TgzYcMngCYSTG/art.json b/art/2n27TgzYcMngCYSTG/art.json index 58d5feb0..170c4f0a 100644 --- a/art/2n27TgzYcMngCYSTG/art.json +++ b/art/2n27TgzYcMngCYSTG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":9704,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Motion\\n//Course : CS250\\n//Spring 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat xoff = sin(time * 2.0 + v * x) * 0.5;\\n \\tfloat yoff = cos(time + u * 3.0) * 0.5;\\n \\n \\tfloat ux = u * 2.0 - 1.0 * xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux - 0.4, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x) * 5.0;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / resolution.y;\\n \\n \\tfloat r = sin(time) + 0.5;\\n \\t\\n \\tv_color = vec4(r, 0.5, 0.5, 1);\\n}\\n\"}", + "settings": { + "num": 9704, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Motion\n//Course : CS250\n//Spring 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat xoff = sin(time * 2.0 + v * x) * 0.5;\n \tfloat yoff = cos(time + u * 3.0) * 0.5;\n \n \tfloat ux = u * 2.0 - 1.0 * xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux - 0.4, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x) * 5.0;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / resolution.y;\n \n \tfloat r = sin(time) + 0.5;\n \t\n \tv_color = vec4(r, 0.5, 0.5, 1);\n}\n" + }, "screenshotURL": "data/images/images-hcqv8rqergkg1iahm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2nczC2kx9JRxu64gA/art.json b/art/2nczC2kx9JRxu64gA/art.json index 436c4d02..4dd146cf 100644 --- a/art/2nczC2kx9JRxu64gA/art.json +++ b/art/2nczC2kx9JRxu64gA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"mic\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV * 0.5)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = invV;// * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 1.0) * 1.0) ;\\n float a = (u * 2. - 1.) * PI + time * 0.1;// * invV * PI;//u * PI * .2 + time * 0. + v * 0. + snd;\\n float c = cos(a);\\n float s = sin(a);\\n mat2 mat = mat2(c, s, -s, c);\\n gl_Position = vec4(mat * (xy * 0.5), v, 1);\\n\\n float s2 = 1. - pow(1. - snd, 5.);\\n float hue = sin(u * PI * 2.) * .0 + time * 0.;\\n float sat = s2;\\n float val = s2;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, 0.);\\n v_color.a = s2;\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "mic", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV * 0.5)).a;\n\n float x = u * 2.0 - 1.0;\n float y = invV;// * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 1.0) * 1.0) ;\n float a = (u * 2. - 1.) * PI + time * 0.1;// * invV * PI;//u * PI * .2 + time * 0. + v * 0. + snd;\n float c = cos(a);\n float s = sin(a);\n mat2 mat = mat2(c, s, -s, c);\n gl_Position = vec4(mat * (xy * 0.5), v, 1);\n\n float s2 = 1. - pow(1. - snd, 5.);\n float hue = sin(u * PI * 2.) * .0 + time * 0.;\n float sat = s2;\n float val = s2;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, 0.);\n v_color.a = s2;\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-13cjwj69rlsajd3xj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2oQkSRKgK2ZWmq6LM/art.json b/art/2oQkSRKgK2ZWmq6LM/art.json index 84fbcb78..42b34724 100644 --- a/art/2oQkSRKgK2ZWmq6LM/art.json +++ b/art/2oQkSRKgK2ZWmq6LM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#45842.1\\nvec2 vertexResolution = resolution;\\nvec4 simFragCoord = vec4(1.,1.,1.,1.);\\n// by @301z\\n// best viewed in 0.5\\n\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n \\n//uniform vec2 vertexResolution;\\n//uniform //float time;\\n\\n\\nvec3 rgb2hsv(vec3 c)\\n{\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define rgb(r,g,b) vec3(float(r) / 255.0, float(g) / 255.0, float(b) / 255.0)\\nfloat borderWidth = 1.0 / vertexResolution.y;\\nvec3 borderColor = rgb(32, 32, 32);\\nvec3 hairColor0 = rgb(151, 200, 234);\\nvec3 hairColor1 = rgb(77, 135, 192);\\nvec3 hairColor2 = rgb(58, 103, 151);\\nvec3 faceColor0 = rgb(247, 223, 204);\\nvec3 faceColor1 = rgb(209, 173, 159);\\nvec3 faceColor2 = rgb(180, 148, 133);\\nvec3 eyeColor0 = rgb(145, 164, 176);\\nvec3 eyeColor1 = rgb(207, 216, 218);\\nvec3 eyeColor2 = rgb(255, 255, 255);\\nvec3 eyeColor3 = rgb(0, 0, 0);\\nvec3 eyeColor4 = hairColor0;\\nvec3 eyeColor5 = hairColor2;\\nvec3 eyeColor6 = hairColor1;\\nvec3 mouthColor0 = rgb(78, 53, 40);\\nvec3 mouthColor1 = rgb(152, 78, 69);\\nvec3 mouthColor2 = rgb(170, 92, 83);\\nvec3 backgroundColor = rgb(51, 124, 221);\\n#undef rgb\\n\\nvec2 position() {\\n return vec2((simFragCoord.x - vertexResolution.x), simFragCoord.y) / vertexResolution.y;\\n}\\n\\nfloat cross2(vec2 v0, vec2 v1) {\\n return v0.x * v1.y - v0.y * v1.x;\\n}\\n\\nfloat circle(vec2 centre, float radius) {\\n return distance(centre, position()) - radius;\\n}\\n\\nfloat ellipse(vec2 focus0, vec2 focus1, float radius) {\\n vec2 p = position();\\n return distance(p, focus0) + distance(p, focus1) - distance(focus0, focus1) * radius ;\\n}\\n\\nbool inside(float f) {\\n return f < -borderWidth;\\n}\\n\\nbool outside(float f) {\\n return f > borderWidth;\\n}\\n\\nbool hair0(out vec3 color) {\\n float upper = circle(vec2(-1.06, 0.795), 0.64);\\n float lower = circle(vec2(-0.851, -0.011), 1.001);\\n float right = circle(vec2(-0.84, 0.74), 0.5);\\n if (outside(upper) || inside(lower) || inside(right))\\n return false;\\n if (!inside(upper) || !outside(lower))\\n color = borderColor;\\n else {\\n float upper = circle(vec2(-1.01, 0.74), 0.6);\\n float lower = circle(vec2(-1.07, 0.13), 0.77);\\n color = (inside(upper) && outside(lower)) ? hairColor1 : hairColor0;\\n }\\n\\tcolor = color ;\\n return true;\\n}\\n\\nbool hair1(out vec3 color) {\\n float upper = circle(vec2(-0.84, 0.74), 0.5);\\n float lower = circle(vec2(-1.8, 1.62), 0.9);\\n if (outside(upper) || outside(lower))\\n return false;\\n color = (inside(upper) && inside(lower)) ? hairColor1 : borderColor;\\n return true;\\n}\\n\\nbool hair2(out vec3 color) {\\n float upper = circle(vec2(-0.695, 0.74), 0.5);\\n float lower = circle(vec2(-3.5, 8.46), 8.1);\\n if (outside(upper) || outside(lower))\\n return false;\\n if (!inside(upper) || !inside(lower))\\n color = borderColor;\\n else {\\n float left = circle(vec2(-0.675, 0.78), 0.502);\\n if (outside(left))\\n color = hairColor0;\\n else {\\n float right = circle(vec2(-1.77, 2.99), 2.4);\\n color = inside(right) ? hairColor1 : hairColor2;\\n }\\n }\\n return true;\\n}\\n\\nbool hair3a(out vec3 color) {\\n float left = circle(vec2(-2.77, 1.86), 2.5);\\n float right = circle(vec2(-1.544, 1.777), 1.44);\\n if (inside(left) || outside(right))\\n return false;\\n color = hairColor1;\\n return true;\\n}\\n\\nbool hair3b(out vec3 color) {\\n float upper = circle(vec2(-2.654, 1.92), 2.39);\\n float lower = circle(vec2(-1.44, 1.777), 1.388);\\n float right = circle(vec2(-0.5, 0.5), 0.515);\\n if (inside(upper) || outside(lower) || outside(right))\\n return false;\\n color = (outside(upper) && inside(lower)) ? hairColor2 : borderColor;\\n return true;\\n}\\n\\nbool hair4a(out vec3 color) {\\n vec2 p0 = vec2(1.332, 0.8), p1 = vec2(-1.5, 0.36);\\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\\n float right = circle(vec2(-0.5, 0.97), 0.78);\\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\\n return false;\\n color = ((upper && inside(left0)) || (!upper && outside(left1))) && inside(right) ? hairColor2 : borderColor;\\n return true;\\n}\\n\\nbool hair4b(out vec3 color) {\\n vec2 p0 = vec2(0.504, 0.91), p1 = vec2(-1.7, 0.25);\\n float r0 = 0.79, r1 = distance(p0, p1) - r0;\\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\\n float right = circle(vec2(-0.62, 0.98), 0.78);\\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\\n return false;\\n color = hairColor1;\\n return true;\\n}\\n\\nbool hair5(out vec3 color) {\\n float left = circle(vec2(1.13, -1.07), 2.02);\\n float right = circle(vec2(-1.505, 1.15), 1.66);\\n if (outside(left) || outside(right))\\n return false;\\n if (!inside(left) || !inside(right))\\n color = borderColor;\\n else {\\n float upper = circle(vec2(1.205, 0.28), 1.58);\\n float lower = circle(vec2(-0.57, 0.78), 0.69);\\n float right = circle(vec2(-1.52, 1.10), 1.6);\\n color = ((inside(upper) && inside(lower)) || outside(right)) ? hairColor2 : hairColor1;\\n }\\n return true;\\n}\\n\\nbool layer0(out vec3 color) {\\n if (hair3a(color))\\n return true;\\n if (hair2(color))\\n return true;\\n if (hair3b(color))\\n return true;\\n if (hair4b(color))\\n return true;\\n if (hair4a(color))\\n return true;\\n if (hair5(color))\\n return true;\\n if (hair1(color))\\n return true;\\n return hair0(color);\\n}\\n\\nbool face0(out vec3 color) {\\n if (inside(circle(vec2(-0.7, 0.0), 0.2)))\\n color = faceColor1;\\n else {\\n vec2 p3 = vec2(-1.02, 0.25);\\n float r3 = 0.41, c3 = circle(p3, r3);\\n vec2 p2 = vec2(-1.12, 0.203);\\n float r2 = r3 - distance(p2, p3), c2 = circle(p2, r2);\\n vec2 p1 = vec2(-2.7, 0.87);\\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\\n vec2 p0 = vec2(-0.5, 0.66);\\n float r0 = distance(p0, p1) - r1, c0 = circle(p0, r0);\\n if (cross2(position() - p0, p1 - p0) > 0.0) {\\n if (outside(c0))\\n return false;\\n color = inside(c0) ? (inside(circle(vec2(-1.8, 1.57), 0.9)) ? faceColor2 : faceColor1) : borderColor;\\n } else if (cross2(position() - p1, p2 - p1) < 0.0) {\\n if (inside(c1))\\n return false;\\n color = outside(c1) ? (((inside(circle(vec2(-0.95, 0.31), 0.49))) && (c1 < 0.035)) ? faceColor0 : faceColor1) : borderColor;\\n } else if (cross2(position() - p2, p3 - p2) < 0.0) {\\n if (outside(c2))\\n return false;\\n color = inside(c2) ? ((c2 > -0.035) ? faceColor0 : faceColor1) : borderColor;\\n } else {\\n if (outside(c3))\\n return false;\\n color = inside(c3) ? ((c3 > -0.035) ? faceColor0 : faceColor1) : borderColor;\\n }\\n }\\n return true;\\n}\\n\\nbool face1(out vec3 color) {\\n float upper = circle(vec2(-0.6, 0.72), 0.5);\\n float lower = circle(vec2(-3.5, 8.004), 7.7);\\n if (outside(upper) || outside(lower))\\n return false;\\n color = faceColor2;\\n return true;\\n}\\n\\nbool face2(out vec3 color) {\\n float upper = circle(vec2(-3.182, 1.75), 2.8);\\n float lower = circle(vec2(-1.44, 1.777), 1.388);\\n if (inside(upper) || outside(lower))\\n return false;\\n color = faceColor2;\\n return true;\\n}\\n\\nbool face3(out vec3 color) {\\n vec2 p0 = vec2(1.332-0.044, 0.8), p1 = vec2(-1.5, 0.36);\\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\\n if ((upper && outside(left0)) || (!upper && inside(left1)))\\n return false;\\n color = faceColor2;\\n return true;\\n}\\n\\nbool layer1(out vec3 color) {\\n if (outside(circle(vec2(-1.2, 0.7), 1.0)))\\n return false;\\n if (face3(color))\\n return true;\\n if (face2(color))\\n return true;\\n if (face1(color))\\n return true;\\n return face0(color);\\n}\\n\\nbool layer2(out vec3 color) {\\n if (inside(circle(vec2(0.0, 0.0), 0.5))) {\\n color = hairColor1;\\n return true;\\n }\\n vec2 p2 = vec2(-0.42, -0.1);\\n float r2 = 1.14, c2 = circle(p2, r2);\\n vec2 p1 = vec2(-3.5, 1.56);\\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\\n bool b1 = inside(circle(vec2(-0.847, 0.5), 0.55));\\n bool b2 = inside(circle(vec2(-0.94, -0.06), 0.56));\\n if (cross2(position() - p1, p2 - p1) < 0.0) {\\n if (inside(c1))\\n return false;\\n color = outside(c1) ? (b1 ? hairColor1 : hairColor0) : borderColor;\\n } else {\\n if (outside(c2))\\n return false;\\n color = inside(c2) ? ((b1 || b2) ? hairColor1 : hairColor0) : borderColor;\\n }\\n return true;\\n}\\n\\nbool leftEye0(out vec3 color) {\\n float top = circle(vec2(-0.866, 0.4899), 0.428);\\n float left = circle(vec2(-0.986, 0.6), 0.3);\\n float bottom = circle(vec2(-1.14, 0.604), 0.2);\\n float right = circle(vec2(-1.54, 0.7), 0.51);\\n if (outside(top) || outside(left) || outside(bottom) || outside(right))\\n return false;\\n if (outside(circle(vec2(-0.919, 0.53), 0.344)))\\n color = borderColor;\\n else if (outside(circle(vec2(-0.918, 0.5), 0.338)))\\n color = eyeColor0;\\n else if (inside(circle(vec2(-1.05, 0.77), 0.1)) && outside(circle(vec2(-1.101, 0.67), 0.08)))\\n color = eyeColor0;\\n else\\n color = eyeColor1;\\n return true;\\n}\\n\\nbool leftEye1(out vec3 color) {\\n if (outside(circle(vec2(-1.0, 0.7), 0.08))\\n || inside(circle(vec2(-1.092, 0.667), 0.1))\\n || inside(circle(vec2(-0.919, 0.8), 0.1)))\\n return false;\\n if (outside(circle(vec2(-1.101, 0.69), 0.1)) && outside(circle(vec2(-0.879, 0.9), 0.2)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool leftEye2(out vec3 color) {\\n if (outside(ellipse(vec2(-1.156, 0.435), vec2(-1.091, 0.75), 1.074)))\\n return false;\\n if (inside(ellipse(vec2(-1.156, 0.636), vec2(-1.122, 0.726), 1.16))) {\\n color = eyeColor2;\\n return true;\\n }\\n if (inside(ellipse(vec2(-1.121, 0.593), vec2(-1.116, 0.614), 1.168))\\n || inside(ellipse(vec2(-1.113, 0.488), vec2(-1.111, 0.505), 1.23))) {\\n color = eyeColor4;\\n return true;\\n }\\n if (inside(ellipse(vec2(-1.154, 0.45), vec2(-1.1, 0.75), 1.05))\\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.552), 1.3))\\n && outside(ellipse(vec2(-1.13, 0.501), vec2(-1.116, 0.614), 1.177))) {\\n color = eyeColor6;\\n return true;\\n } if (inside(ellipse(vec2(-1.152, 0.445), vec2(-1.091, 0.75), 1.067))\\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.565), 1.3))\\n && outside(ellipse(vec2(-1.128, 0.52), vec2(-1.116, 0.614), 1.177))) {\\n color = eyeColor5;\\n return true;\\n }\\n color = eyeColor3;\\n return true;\\n}\\n\\nbool leftEye(out vec3 color) {\\n if (leftEye2(color))\\n return true;\\n if (leftEye1(color))\\n return true;\\n return leftEye0(color);\\n}\\n\\nbool rightEye0(out vec3 color) {\\n if (outside(circle(vec2(-0.609, 0.542), 0.129))\\n && inside(circle(vec2(-0.61, 0.584), 0.101))) {\\n color = borderColor;\\n return true;\\n }\\n if (inside(circle(vec2(-2.654, 1.92), 2.39))\\n || outside(circle(vec2(-0.685, 0.42), 0.285))\\n || inside(circle(vec2(-0.683, 0.432), 0.262))\\n || outside(circle(vec2(-0.638, 0.516), 0.3)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool rightEye1(out vec3 color) {\\n if (outside(circle(vec2(-2.654, 1.92), 2.39))\\n || outside(circle(vec2(-0.627, 0.583), 0.11))\\n || inside(circle(vec2(-0.65, 0.582), 0.11)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool rightEye2(out vec3 color) {\\n if (outside(circle(vec2(-0.57, 0.38), 0.3))\\n || outside(circle(vec2(-0.166, 0.34), 0.59))\\n || outside(circle(vec2(-0.34, 0.6), 0.505))\\n || outside(circle(vec2(-0.47, 0.763), 0.54))\\n || outside(circle(vec2(-0.638, 0.52), 0.3))\\n || outside(circle(vec2(-0.685, 0.42), 0.285)))\\n return false;\\n color = inside(ellipse(vec2(-0.625, 0.23), vec2(-0.59, 0.576), 1.38)) ? eyeColor1 : eyeColor0;\\n return true;\\n}\\n\\nbool rightEye3(out vec3 color) {\\n if (outside(ellipse(vec2(-0.61, 0.29), vec2(-0.538, 0.5844), 1.23)))\\n return false;\\n if (outside(ellipse(vec2(-0.584, 0.355), vec2(-0.56, 0.518), 1.24))\\n && inside(ellipse(vec2(-0.611, 0.31), vec2(-0.574, 0.42), 1.575))\\n && inside(ellipse(vec2(-0.701, 0.09), vec2(-0.58, 0.38), 1.17))) {\\n color = eyeColor6;\\n return true;\\n }\\n if (outside(ellipse(vec2(-0.584, 0.367), vec2(-0.546, 0.518), 1.2))\\n && inside(ellipse(vec2(-0.611, 0.299), vec2(-0.56, 0.48), 1.37))\\n && inside(ellipse(vec2(-0.68, 0.09), vec2(-0.58, 0.42), 1.17))) {\\n color = eyeColor5;\\n return true;\\n }\\n color = eyeColor3;\\n return true;\\n}\\n\\nbool rightEye4(out vec3 color) {\\n if (inside(ellipse(vec2(-0.627, 0.49), vec2(-0.589, 0.583), 1.35))) {\\n color = eyeColor2;\\n return true;\\n }\\n if (inside(circle(vec2(-0.576, 0.445), 0.01)) || inside(circle(vec2(-0.54, 0.32), 0.01))) {\\n color = eyeColor4;\\n return true;\\n }\\n return false;\\n}\\n\\nbool rightEye(out vec3 color) {\\n if (rightEye0(color))\\n return true;\\n if (rightEye1(color))\\n return true;\\n if (rightEye4(color))\\n return true;\\n if (rightEye3(color))\\n return true;\\n return rightEye2(color);\\n}\\n\\nbool layer3(out vec3 color) {\\n if (leftEye(color))\\n return true;\\n return rightEye(color);\\n}\\n\\nbool mouth(out vec3 color) {\\n if (outside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.44)))\\n return false;\\n if (inside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.4))\\n && inside(circle(vec2(-1.04, -0.045), 0.102))) {\\n color = inside(ellipse(vec2(-1.0, -0.09), vec2(-1.092, 0.002), 1.34)) ? mouthColor2 : mouthColor1;\\n return true;\\n }\\n color = mouthColor0;\\n return true;\\n}\\n\\nbool nose(out vec3 color) {\\n if (inside(circle(vec2(-1.061, 0.228), 0.1))\\n && inside(circle(vec2(-1.107, 0.304), 0.019))\\n && outside(circle(vec2(-1.058, 0.29), 0.045))) {\\n color = (inside(circle(vec2(-1.007, 0.31), 0.1)) && outside(circle(vec2(-1.176, 0.379), 0.1))) ? borderColor : faceColor2;\\n return true;\\n }\\n return false;\\n}\\n\\nbool leftEyebrow(out vec3 color) {\\n float c = circle(vec2(-0.85, 0.586), 0.502);\\n if (outside(c) || inside(c) || !inside(circle(vec2(-1.1, 1.072), 0.202)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool rightEyebrow(out vec3 color) {\\n if (inside(circle(vec2(-0.77, 0.42), 0.56)))\\n return false;\\n vec2 p0 = vec2(-0.66, 0.601), p1 = vec2(-0.57, 0.742);\\n float r0 = 0.397, r1 = r0 - distance(p0, p1);\\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\\n float f = cross2(position() - p0, p1 - p0);\\n if ((f < 0.0) ? (outside(c1) || inside(c1)) : (outside(c0) || inside(c0)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool layer4(out vec3 color) {\\n\\n if (leftEyebrow(color))\\n return true;\\n if (rightEyebrow(color))\\n return true;\\n if (mouth(color))\\n return true;\\n return nose(color);\\n}\\n\\nbool ear0(out vec3 color) {\\n vec2 p0 = vec2(-0.249, 0.192), p1 = vec2(-0.09, 0.25);\\n float r0 = 0.202, r1 = r0 - distance(p0, p1);\\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\\n float c = (cross2(position() - p0, p1 - p0) < 0.0) ? c1 : c0;\\n if (outside(c))\\n return false;\\n color = inside(c) ? faceColor1 : borderColor;\\n return true;\\n}\\n\\nbool ear1(out vec3 color) {\\n vec2 p1 = vec2(-0.155, 0.23), p2 = vec2(-0.11, 0.21);\\n float c1 = circle(vec2(-0.14, 0.397), 0.204);\\n float c2 = circle(p1, 0.06);\\n float e = ellipse(vec2(-0.144, 0.16), vec2(-0.099, 0.235), 1.18);\\n if (outside(c1) || outside(e))\\n return false;\\n if (!inside(e))\\n color = borderColor;\\n else {\\n if (outside(c2))\\n return false;\\n color = (inside(c1) && ((cross2(position() - p1, p2 - p1) < 0.0) || inside(c2))) ? faceColor2 : borderColor;\\n }\\n return true;\\n}\\n\\nbool ear2(out vec3 color) {\\n vec2 p1 = vec2(-0.2, -0.155);\\n float r1 = 0.2, c1 = circle(p1, r1);\\n vec2 p2 = vec2(-0.2, 0.1);\\n float r2 = distance(p1, p2) - r1, c2 = circle(p2, r2);\\n if (cross2(position() - p1, p2 - p1) < 0.0) {\\n if (inside(c1))\\n return false;\\n color = outside(c1) ? faceColor2 : borderColor;\\n } else {\\n vec2 p = vec2(-0.144, 0.156);\\n bool e = inside(ellipse(p, vec2(-0.36, -0.1), 1.04)) || inside(ellipse(p, vec2(-0.36, 0.1), 1.04));\\n if ((cross2(position() - p2, vec2(-0.15, 0.075) - p2) < 0.0)) {\\n if (!e)\\n return false;\\n color = faceColor2;\\n } else if (inside(c2)) {\\n if (!e)\\n return false;\\n color = faceColor2;\\n } else {\\n if (outside(c2))\\n return false;\\n color = borderColor;\\n }\\n }\\n return true;\\n}\\n\\nbool ear3(out vec3 color) {\\n if (inside(circle(vec2(-0.2, -0.155), 0.2)))\\n return false;\\n vec2 p1 = vec2(-0.64, 0.28);\\n float r1 = 0.5, c1 = circle(p1, r1);\\n vec2 p2 = vec2(-0.172, 0.144);\\n float r2 = r1 - distance(p1, p2), c2 = circle(p2, r2);\\n float c = (cross2(position() - p1, p2 - p1) < 0.0) ? c2 : c1;\\n if (inside(c) || outside(c))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool layer5(out vec3 color) {\\n if (inside(circle(vec2(-1.505, 1.15), 1.66)))\\n return false;\\n if (ear3(color))\\n return true;\\n if (ear2(color))\\n return true;\\n if (ear1(color))\\n return true;\\n return ear0(color);\\n}\\n\\nbool ikachan(out vec3 color) {\\n if (layer4(color))\\n return true;\\n if (layer0(color))\\n return true;\\n if (layer5(color))\\n return true;\\n if (layer3(color))\\n return true;\\n if (layer1(color))\\n return true;\\n return layer2(color);\\n}\\n\\t\\nvec3 filter(vec3 color) {\\n return color * 0.5 * (2.0 - simFragCoord.x / vertexResolution.x + simFragCoord.y / vertexResolution.y);\\n}\\n\\nvoid main() {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n vec3 color;\\n color = filter(ikachan(color) ? color : backgroundColor) ;\\n vec3 hsv = rgb2hsv(color);\\n hsv.r = mod(hsv.r + time, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#45842.1\nvec2 vertexResolution = resolution;\nvec4 simFragCoord = vec4(1.,1.,1.,1.);\n// by @301z\n// best viewed in 0.5\n\n#ifdef GL_ES\n//precision mediump float;\n#endif\n \n//uniform vec2 vertexResolution;\n//uniform //float time;\n\n\nvec3 rgb2hsv(vec3 c)\n{\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define rgb(r,g,b) vec3(float(r) / 255.0, float(g) / 255.0, float(b) / 255.0)\nfloat borderWidth = 1.0 / vertexResolution.y;\nvec3 borderColor = rgb(32, 32, 32);\nvec3 hairColor0 = rgb(151, 200, 234);\nvec3 hairColor1 = rgb(77, 135, 192);\nvec3 hairColor2 = rgb(58, 103, 151);\nvec3 faceColor0 = rgb(247, 223, 204);\nvec3 faceColor1 = rgb(209, 173, 159);\nvec3 faceColor2 = rgb(180, 148, 133);\nvec3 eyeColor0 = rgb(145, 164, 176);\nvec3 eyeColor1 = rgb(207, 216, 218);\nvec3 eyeColor2 = rgb(255, 255, 255);\nvec3 eyeColor3 = rgb(0, 0, 0);\nvec3 eyeColor4 = hairColor0;\nvec3 eyeColor5 = hairColor2;\nvec3 eyeColor6 = hairColor1;\nvec3 mouthColor0 = rgb(78, 53, 40);\nvec3 mouthColor1 = rgb(152, 78, 69);\nvec3 mouthColor2 = rgb(170, 92, 83);\nvec3 backgroundColor = rgb(51, 124, 221);\n#undef rgb\n\nvec2 position() {\n return vec2((simFragCoord.x - vertexResolution.x), simFragCoord.y) / vertexResolution.y;\n}\n\nfloat cross2(vec2 v0, vec2 v1) {\n return v0.x * v1.y - v0.y * v1.x;\n}\n\nfloat circle(vec2 centre, float radius) {\n return distance(centre, position()) - radius;\n}\n\nfloat ellipse(vec2 focus0, vec2 focus1, float radius) {\n vec2 p = position();\n return distance(p, focus0) + distance(p, focus1) - distance(focus0, focus1) * radius ;\n}\n\nbool inside(float f) {\n return f < -borderWidth;\n}\n\nbool outside(float f) {\n return f > borderWidth;\n}\n\nbool hair0(out vec3 color) {\n float upper = circle(vec2(-1.06, 0.795), 0.64);\n float lower = circle(vec2(-0.851, -0.011), 1.001);\n float right = circle(vec2(-0.84, 0.74), 0.5);\n if (outside(upper) || inside(lower) || inside(right))\n return false;\n if (!inside(upper) || !outside(lower))\n color = borderColor;\n else {\n float upper = circle(vec2(-1.01, 0.74), 0.6);\n float lower = circle(vec2(-1.07, 0.13), 0.77);\n color = (inside(upper) && outside(lower)) ? hairColor1 : hairColor0;\n }\n\tcolor = color ;\n return true;\n}\n\nbool hair1(out vec3 color) {\n float upper = circle(vec2(-0.84, 0.74), 0.5);\n float lower = circle(vec2(-1.8, 1.62), 0.9);\n if (outside(upper) || outside(lower))\n return false;\n color = (inside(upper) && inside(lower)) ? hairColor1 : borderColor;\n return true;\n}\n\nbool hair2(out vec3 color) {\n float upper = circle(vec2(-0.695, 0.74), 0.5);\n float lower = circle(vec2(-3.5, 8.46), 8.1);\n if (outside(upper) || outside(lower))\n return false;\n if (!inside(upper) || !inside(lower))\n color = borderColor;\n else {\n float left = circle(vec2(-0.675, 0.78), 0.502);\n if (outside(left))\n color = hairColor0;\n else {\n float right = circle(vec2(-1.77, 2.99), 2.4);\n color = inside(right) ? hairColor1 : hairColor2;\n }\n }\n return true;\n}\n\nbool hair3a(out vec3 color) {\n float left = circle(vec2(-2.77, 1.86), 2.5);\n float right = circle(vec2(-1.544, 1.777), 1.44);\n if (inside(left) || outside(right))\n return false;\n color = hairColor1;\n return true;\n}\n\nbool hair3b(out vec3 color) {\n float upper = circle(vec2(-2.654, 1.92), 2.39);\n float lower = circle(vec2(-1.44, 1.777), 1.388);\n float right = circle(vec2(-0.5, 0.5), 0.515);\n if (inside(upper) || outside(lower) || outside(right))\n return false;\n color = (outside(upper) && inside(lower)) ? hairColor2 : borderColor;\n return true;\n}\n\nbool hair4a(out vec3 color) {\n vec2 p0 = vec2(1.332, 0.8), p1 = vec2(-1.5, 0.36);\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\n float right = circle(vec2(-0.5, 0.97), 0.78);\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\n return false;\n color = ((upper && inside(left0)) || (!upper && outside(left1))) && inside(right) ? hairColor2 : borderColor;\n return true;\n}\n\nbool hair4b(out vec3 color) {\n vec2 p0 = vec2(0.504, 0.91), p1 = vec2(-1.7, 0.25);\n float r0 = 0.79, r1 = distance(p0, p1) - r0;\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\n float right = circle(vec2(-0.62, 0.98), 0.78);\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\n return false;\n color = hairColor1;\n return true;\n}\n\nbool hair5(out vec3 color) {\n float left = circle(vec2(1.13, -1.07), 2.02);\n float right = circle(vec2(-1.505, 1.15), 1.66);\n if (outside(left) || outside(right))\n return false;\n if (!inside(left) || !inside(right))\n color = borderColor;\n else {\n float upper = circle(vec2(1.205, 0.28), 1.58);\n float lower = circle(vec2(-0.57, 0.78), 0.69);\n float right = circle(vec2(-1.52, 1.10), 1.6);\n color = ((inside(upper) && inside(lower)) || outside(right)) ? hairColor2 : hairColor1;\n }\n return true;\n}\n\nbool layer0(out vec3 color) {\n if (hair3a(color))\n return true;\n if (hair2(color))\n return true;\n if (hair3b(color))\n return true;\n if (hair4b(color))\n return true;\n if (hair4a(color))\n return true;\n if (hair5(color))\n return true;\n if (hair1(color))\n return true;\n return hair0(color);\n}\n\nbool face0(out vec3 color) {\n if (inside(circle(vec2(-0.7, 0.0), 0.2)))\n color = faceColor1;\n else {\n vec2 p3 = vec2(-1.02, 0.25);\n float r3 = 0.41, c3 = circle(p3, r3);\n vec2 p2 = vec2(-1.12, 0.203);\n float r2 = r3 - distance(p2, p3), c2 = circle(p2, r2);\n vec2 p1 = vec2(-2.7, 0.87);\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\n vec2 p0 = vec2(-0.5, 0.66);\n float r0 = distance(p0, p1) - r1, c0 = circle(p0, r0);\n if (cross2(position() - p0, p1 - p0) > 0.0) {\n if (outside(c0))\n return false;\n color = inside(c0) ? (inside(circle(vec2(-1.8, 1.57), 0.9)) ? faceColor2 : faceColor1) : borderColor;\n } else if (cross2(position() - p1, p2 - p1) < 0.0) {\n if (inside(c1))\n return false;\n color = outside(c1) ? (((inside(circle(vec2(-0.95, 0.31), 0.49))) && (c1 < 0.035)) ? faceColor0 : faceColor1) : borderColor;\n } else if (cross2(position() - p2, p3 - p2) < 0.0) {\n if (outside(c2))\n return false;\n color = inside(c2) ? ((c2 > -0.035) ? faceColor0 : faceColor1) : borderColor;\n } else {\n if (outside(c3))\n return false;\n color = inside(c3) ? ((c3 > -0.035) ? faceColor0 : faceColor1) : borderColor;\n }\n }\n return true;\n}\n\nbool face1(out vec3 color) {\n float upper = circle(vec2(-0.6, 0.72), 0.5);\n float lower = circle(vec2(-3.5, 8.004), 7.7);\n if (outside(upper) || outside(lower))\n return false;\n color = faceColor2;\n return true;\n}\n\nbool face2(out vec3 color) {\n float upper = circle(vec2(-3.182, 1.75), 2.8);\n float lower = circle(vec2(-1.44, 1.777), 1.388);\n if (inside(upper) || outside(lower))\n return false;\n color = faceColor2;\n return true;\n}\n\nbool face3(out vec3 color) {\n vec2 p0 = vec2(1.332-0.044, 0.8), p1 = vec2(-1.5, 0.36);\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\n if ((upper && outside(left0)) || (!upper && inside(left1)))\n return false;\n color = faceColor2;\n return true;\n}\n\nbool layer1(out vec3 color) {\n if (outside(circle(vec2(-1.2, 0.7), 1.0)))\n return false;\n if (face3(color))\n return true;\n if (face2(color))\n return true;\n if (face1(color))\n return true;\n return face0(color);\n}\n\nbool layer2(out vec3 color) {\n if (inside(circle(vec2(0.0, 0.0), 0.5))) {\n color = hairColor1;\n return true;\n }\n vec2 p2 = vec2(-0.42, -0.1);\n float r2 = 1.14, c2 = circle(p2, r2);\n vec2 p1 = vec2(-3.5, 1.56);\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\n bool b1 = inside(circle(vec2(-0.847, 0.5), 0.55));\n bool b2 = inside(circle(vec2(-0.94, -0.06), 0.56));\n if (cross2(position() - p1, p2 - p1) < 0.0) {\n if (inside(c1))\n return false;\n color = outside(c1) ? (b1 ? hairColor1 : hairColor0) : borderColor;\n } else {\n if (outside(c2))\n return false;\n color = inside(c2) ? ((b1 || b2) ? hairColor1 : hairColor0) : borderColor;\n }\n return true;\n}\n\nbool leftEye0(out vec3 color) {\n float top = circle(vec2(-0.866, 0.4899), 0.428);\n float left = circle(vec2(-0.986, 0.6), 0.3);\n float bottom = circle(vec2(-1.14, 0.604), 0.2);\n float right = circle(vec2(-1.54, 0.7), 0.51);\n if (outside(top) || outside(left) || outside(bottom) || outside(right))\n return false;\n if (outside(circle(vec2(-0.919, 0.53), 0.344)))\n color = borderColor;\n else if (outside(circle(vec2(-0.918, 0.5), 0.338)))\n color = eyeColor0;\n else if (inside(circle(vec2(-1.05, 0.77), 0.1)) && outside(circle(vec2(-1.101, 0.67), 0.08)))\n color = eyeColor0;\n else\n color = eyeColor1;\n return true;\n}\n\nbool leftEye1(out vec3 color) {\n if (outside(circle(vec2(-1.0, 0.7), 0.08))\n || inside(circle(vec2(-1.092, 0.667), 0.1))\n || inside(circle(vec2(-0.919, 0.8), 0.1)))\n return false;\n if (outside(circle(vec2(-1.101, 0.69), 0.1)) && outside(circle(vec2(-0.879, 0.9), 0.2)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool leftEye2(out vec3 color) {\n if (outside(ellipse(vec2(-1.156, 0.435), vec2(-1.091, 0.75), 1.074)))\n return false;\n if (inside(ellipse(vec2(-1.156, 0.636), vec2(-1.122, 0.726), 1.16))) {\n color = eyeColor2;\n return true;\n }\n if (inside(ellipse(vec2(-1.121, 0.593), vec2(-1.116, 0.614), 1.168))\n || inside(ellipse(vec2(-1.113, 0.488), vec2(-1.111, 0.505), 1.23))) {\n color = eyeColor4;\n return true;\n }\n if (inside(ellipse(vec2(-1.154, 0.45), vec2(-1.1, 0.75), 1.05))\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.552), 1.3))\n && outside(ellipse(vec2(-1.13, 0.501), vec2(-1.116, 0.614), 1.177))) {\n color = eyeColor6;\n return true;\n } if (inside(ellipse(vec2(-1.152, 0.445), vec2(-1.091, 0.75), 1.067))\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.565), 1.3))\n && outside(ellipse(vec2(-1.128, 0.52), vec2(-1.116, 0.614), 1.177))) {\n color = eyeColor5;\n return true;\n }\n color = eyeColor3;\n return true;\n}\n\nbool leftEye(out vec3 color) {\n if (leftEye2(color))\n return true;\n if (leftEye1(color))\n return true;\n return leftEye0(color);\n}\n\nbool rightEye0(out vec3 color) {\n if (outside(circle(vec2(-0.609, 0.542), 0.129))\n && inside(circle(vec2(-0.61, 0.584), 0.101))) {\n color = borderColor;\n return true;\n }\n if (inside(circle(vec2(-2.654, 1.92), 2.39))\n || outside(circle(vec2(-0.685, 0.42), 0.285))\n || inside(circle(vec2(-0.683, 0.432), 0.262))\n || outside(circle(vec2(-0.638, 0.516), 0.3)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool rightEye1(out vec3 color) {\n if (outside(circle(vec2(-2.654, 1.92), 2.39))\n || outside(circle(vec2(-0.627, 0.583), 0.11))\n || inside(circle(vec2(-0.65, 0.582), 0.11)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool rightEye2(out vec3 color) {\n if (outside(circle(vec2(-0.57, 0.38), 0.3))\n || outside(circle(vec2(-0.166, 0.34), 0.59))\n || outside(circle(vec2(-0.34, 0.6), 0.505))\n || outside(circle(vec2(-0.47, 0.763), 0.54))\n || outside(circle(vec2(-0.638, 0.52), 0.3))\n || outside(circle(vec2(-0.685, 0.42), 0.285)))\n return false;\n color = inside(ellipse(vec2(-0.625, 0.23), vec2(-0.59, 0.576), 1.38)) ? eyeColor1 : eyeColor0;\n return true;\n}\n\nbool rightEye3(out vec3 color) {\n if (outside(ellipse(vec2(-0.61, 0.29), vec2(-0.538, 0.5844), 1.23)))\n return false;\n if (outside(ellipse(vec2(-0.584, 0.355), vec2(-0.56, 0.518), 1.24))\n && inside(ellipse(vec2(-0.611, 0.31), vec2(-0.574, 0.42), 1.575))\n && inside(ellipse(vec2(-0.701, 0.09), vec2(-0.58, 0.38), 1.17))) {\n color = eyeColor6;\n return true;\n }\n if (outside(ellipse(vec2(-0.584, 0.367), vec2(-0.546, 0.518), 1.2))\n && inside(ellipse(vec2(-0.611, 0.299), vec2(-0.56, 0.48), 1.37))\n && inside(ellipse(vec2(-0.68, 0.09), vec2(-0.58, 0.42), 1.17))) {\n color = eyeColor5;\n return true;\n }\n color = eyeColor3;\n return true;\n}\n\nbool rightEye4(out vec3 color) {\n if (inside(ellipse(vec2(-0.627, 0.49), vec2(-0.589, 0.583), 1.35))) {\n color = eyeColor2;\n return true;\n }\n if (inside(circle(vec2(-0.576, 0.445), 0.01)) || inside(circle(vec2(-0.54, 0.32), 0.01))) {\n color = eyeColor4;\n return true;\n }\n return false;\n}\n\nbool rightEye(out vec3 color) {\n if (rightEye0(color))\n return true;\n if (rightEye1(color))\n return true;\n if (rightEye4(color))\n return true;\n if (rightEye3(color))\n return true;\n return rightEye2(color);\n}\n\nbool layer3(out vec3 color) {\n if (leftEye(color))\n return true;\n return rightEye(color);\n}\n\nbool mouth(out vec3 color) {\n if (outside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.44)))\n return false;\n if (inside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.4))\n && inside(circle(vec2(-1.04, -0.045), 0.102))) {\n color = inside(ellipse(vec2(-1.0, -0.09), vec2(-1.092, 0.002), 1.34)) ? mouthColor2 : mouthColor1;\n return true;\n }\n color = mouthColor0;\n return true;\n}\n\nbool nose(out vec3 color) {\n if (inside(circle(vec2(-1.061, 0.228), 0.1))\n && inside(circle(vec2(-1.107, 0.304), 0.019))\n && outside(circle(vec2(-1.058, 0.29), 0.045))) {\n color = (inside(circle(vec2(-1.007, 0.31), 0.1)) && outside(circle(vec2(-1.176, 0.379), 0.1))) ? borderColor : faceColor2;\n return true;\n }\n return false;\n}\n\nbool leftEyebrow(out vec3 color) {\n float c = circle(vec2(-0.85, 0.586), 0.502);\n if (outside(c) || inside(c) || !inside(circle(vec2(-1.1, 1.072), 0.202)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool rightEyebrow(out vec3 color) {\n if (inside(circle(vec2(-0.77, 0.42), 0.56)))\n return false;\n vec2 p0 = vec2(-0.66, 0.601), p1 = vec2(-0.57, 0.742);\n float r0 = 0.397, r1 = r0 - distance(p0, p1);\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\n float f = cross2(position() - p0, p1 - p0);\n if ((f < 0.0) ? (outside(c1) || inside(c1)) : (outside(c0) || inside(c0)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool layer4(out vec3 color) {\n\n if (leftEyebrow(color))\n return true;\n if (rightEyebrow(color))\n return true;\n if (mouth(color))\n return true;\n return nose(color);\n}\n\nbool ear0(out vec3 color) {\n vec2 p0 = vec2(-0.249, 0.192), p1 = vec2(-0.09, 0.25);\n float r0 = 0.202, r1 = r0 - distance(p0, p1);\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\n float c = (cross2(position() - p0, p1 - p0) < 0.0) ? c1 : c0;\n if (outside(c))\n return false;\n color = inside(c) ? faceColor1 : borderColor;\n return true;\n}\n\nbool ear1(out vec3 color) {\n vec2 p1 = vec2(-0.155, 0.23), p2 = vec2(-0.11, 0.21);\n float c1 = circle(vec2(-0.14, 0.397), 0.204);\n float c2 = circle(p1, 0.06);\n float e = ellipse(vec2(-0.144, 0.16), vec2(-0.099, 0.235), 1.18);\n if (outside(c1) || outside(e))\n return false;\n if (!inside(e))\n color = borderColor;\n else {\n if (outside(c2))\n return false;\n color = (inside(c1) && ((cross2(position() - p1, p2 - p1) < 0.0) || inside(c2))) ? faceColor2 : borderColor;\n }\n return true;\n}\n\nbool ear2(out vec3 color) {\n vec2 p1 = vec2(-0.2, -0.155);\n float r1 = 0.2, c1 = circle(p1, r1);\n vec2 p2 = vec2(-0.2, 0.1);\n float r2 = distance(p1, p2) - r1, c2 = circle(p2, r2);\n if (cross2(position() - p1, p2 - p1) < 0.0) {\n if (inside(c1))\n return false;\n color = outside(c1) ? faceColor2 : borderColor;\n } else {\n vec2 p = vec2(-0.144, 0.156);\n bool e = inside(ellipse(p, vec2(-0.36, -0.1), 1.04)) || inside(ellipse(p, vec2(-0.36, 0.1), 1.04));\n if ((cross2(position() - p2, vec2(-0.15, 0.075) - p2) < 0.0)) {\n if (!e)\n return false;\n color = faceColor2;\n } else if (inside(c2)) {\n if (!e)\n return false;\n color = faceColor2;\n } else {\n if (outside(c2))\n return false;\n color = borderColor;\n }\n }\n return true;\n}\n\nbool ear3(out vec3 color) {\n if (inside(circle(vec2(-0.2, -0.155), 0.2)))\n return false;\n vec2 p1 = vec2(-0.64, 0.28);\n float r1 = 0.5, c1 = circle(p1, r1);\n vec2 p2 = vec2(-0.172, 0.144);\n float r2 = r1 - distance(p1, p2), c2 = circle(p2, r2);\n float c = (cross2(position() - p1, p2 - p1) < 0.0) ? c2 : c1;\n if (inside(c) || outside(c))\n return false;\n color = borderColor;\n return true;\n}\n\nbool layer5(out vec3 color) {\n if (inside(circle(vec2(-1.505, 1.15), 1.66)))\n return false;\n if (ear3(color))\n return true;\n if (ear2(color))\n return true;\n if (ear1(color))\n return true;\n return ear0(color);\n}\n\nbool ikachan(out vec3 color) {\n if (layer4(color))\n return true;\n if (layer0(color))\n return true;\n if (layer5(color))\n return true;\n if (layer3(color))\n return true;\n if (layer1(color))\n return true;\n return layer2(color);\n}\n\t\nvec3 filter(vec3 color) {\n return color * 0.5 * (2.0 - simFragCoord.x / vertexResolution.x + simFragCoord.y / vertexResolution.y);\n}\n\nvoid main() {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n vec3 color;\n color = filter(ikachan(color) ? color : backgroundColor) ;\n vec3 hsv = rgb2hsv(color);\n hsv.r = mod(hsv.r + time, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-1awfax1pbmenj7yf5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2pSYjC7BCpjghA8Hu/art.json b/art/2pSYjC7BCpjghA8Hu/art.json index 97c32752..93e235fb 100644 --- a/art/2pSYjC7BCpjghA8Hu/art.json +++ b/art/2pSYjC7BCpjghA8Hu/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/platform/carl-cox-45-min-boiler-room\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.7)/20.0;\\n //float lum = floor(v *30.0 + 0.9)/5.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\\n /*vec2 soundTexCoords = vec2(0, 0);\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n*/\\n v_color = vec4(v*lum*0.5,lum*0.1,lum*1.0,1);\\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\\n\\n\\n \\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/platform/carl-cox-45-min-boiler-room", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.7)/20.0;\n //float lum = floor(v *30.0 + 0.9)/5.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\n /*vec2 soundTexCoords = vec2(0, 0);\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n*/\n v_color = vec4(v*lum*0.5,lum*0.1,lum*1.0,1);\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\n\n\n \n}" + }, "screenshotURL": "data/images/images-pzkgqcawjdr4xf2dz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2pccx6pQfk6skHLQG/art.json b/art/2pccx6pQfk6skHLQG/art.json index 4374604f..930a9bd0 100644 --- a/art/2pccx6pQfk6skHLQG/art.json +++ b/art/2pccx6pQfk6skHLQG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n if (vertexId == 0.0) {\\n \\tgl_Position = vec4(-0.05, -0.3, 0, 1); \\n }\\n else if (vertexId == 1.0) {\\n \\tgl_Position = vec4(0.25, 0.3, 0, 1); \\n }\\n else if (vertexId == 2.0) {\\n \\tgl_Position = vec4(0.0125, -0.3, 0, 1); \\n }\\n \\n else if (vertexId == 3.0) {\\n \\tgl_Position = vec4(-0.05, 0.3, 0, 1); \\n }\\n else if (vertexId == 4.0) {\\n \\tgl_Position = vec4(0.25, 0.3, 0, 1); \\n }\\n else if (vertexId == 5.0) {\\n \\tgl_Position = vec4(-0.05, -0.3, 0, 1); \\n }\\n \\n if (vertexId == 1.0 || vertexId == 2.0 || vertexId == 4.0) { \\n \\tv_color = vec4(1, 1, 1, 1);\\n }\\n else {\\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n if (vertexId == 0.0) {\n \tgl_Position = vec4(-0.05, -0.3, 0, 1); \n }\n else if (vertexId == 1.0) {\n \tgl_Position = vec4(0.25, 0.3, 0, 1); \n }\n else if (vertexId == 2.0) {\n \tgl_Position = vec4(0.0125, -0.3, 0, 1); \n }\n \n else if (vertexId == 3.0) {\n \tgl_Position = vec4(-0.05, 0.3, 0, 1); \n }\n else if (vertexId == 4.0) {\n \tgl_Position = vec4(0.25, 0.3, 0, 1); \n }\n else if (vertexId == 5.0) {\n \tgl_Position = vec4(-0.05, -0.3, 0, 1); \n }\n \n if (vertexId == 1.0 || vertexId == 2.0 || vertexId == 4.0) { \n \tv_color = vec4(1, 1, 1, 1);\n }\n else {\n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-40ivsbfnej7f891u6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2tNPKyop2hRKFBGz9/art.json b/art/2tNPKyop2hRKFBGz9/art.json index 0e1ebfab..8fa69ebc 100644 --- a/art/2tNPKyop2hRKFBGz9/art.json +++ b/art/2tNPKyop2hRKFBGz9/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "peraperavrc", "avatarUrl": "https://secure.gravatar.com/avatar/c2c6ce47bf34522d1c334c04923312da?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n // v_color = vec4(b, b, b, 1);\\n v_color = vec4(1.0, 0.0, 0.0 , 1.0);\\n}\"}", + "settings": { + "num": 100, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n // v_color = vec4(b, b, b, 1);\n v_color = vec4(1.0, 0.0, 0.0 , 1.0);\n}" + }, "screenshotURL": "data/images/images-n0ebs4w6ursvnus4o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/2wjez5eJ6Ng5tFzSP/art.json b/art/2wjez5eJ6Ng5tFzSP/art.json index 5071a6de..7b6dc3bf 100644 --- a/art/2wjez5eJ6Ng5tFzSP/art.json +++ b/art/2wjez5eJ6Ng5tFzSP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":73541,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,z,0,0,1,0,0,2,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 3.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.0;\\n \\tvec2 height = vec2(10.,0.);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\\n float rangeInv = 0.2 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -0.043,\\n yAxis, 1.01,\\n zAxis, .10,\\n eye, sin(-0.1*time));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -1,\\n yAxis, 0.2,\\n zAxis, -0.2,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.6); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 73541, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,z,0,0,1,0,0,2,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 3.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.0;\n \tvec2 height = vec2(10.,0.);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\n float rangeInv = 0.2 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -0.043,\n yAxis, 1.01,\n zAxis, .10,\n eye, sin(-0.1*time));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -1,\n yAxis, 0.2,\n zAxis, -0.2,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.6); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-gil2cefpf8dmvypi9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2wuax4qbM5ZvmBW4r/art.json b/art/2wuax4qbM5ZvmBW4r/art.json index 94b1601c..b4e5b2ef 100644 --- a/art/2wuax4qbM5ZvmBW4r/art.json +++ b/art/2wuax4qbM5ZvmBW4r/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cakeller98", "avatarUrl": "https://secure.gravatar.com/avatar/812a8b66a6ed48004ce62d7e88fdaf1f?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*1.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.150;\\n float i = vertexId+sin(vertexId)*200.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -1000.; f < 0.; f++) {\\n\\t ofs += push(t+f*.15,i,ofs,1.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*1.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.150;\n float i = vertexId+sin(vertexId)*200.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -1000.; f < 0.; f++) {\n\t ofs += push(t+f*.15,i,ofs,1.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-pyctxh95fecigjssz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2xJgNnQY5FLgHt6qW/art.json b/art/2xJgNnQY5FLgHt6qW/art.json index 3b599fa8..b135b41b 100644 --- a/art/2xJgNnQY5FLgHt6qW/art.json +++ b/art/2xJgNnQY5FLgHt6qW/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"\\n\\nvoid main() {\\n\\tgl_PointSize = 10.0;\\n \\tvec3 xy = vec3(vertexId / 3.0, 0.0 - vertexId, 0.0);\\n \\tgl_Position = vec4(xy,1.0);\\n \\tv_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "\n\nvoid main() {\n\tgl_PointSize = 10.0;\n \tvec3 xy = vec3(vertexId / 3.0, 0.0 - vertexId, 0.0);\n \tgl_Position = vec4(xy,1.0);\n \tv_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-xfk8uvtu1nj4k6qwu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/2zrDmPHr7XSL9Smeh/art.json b/art/2zrDmPHr7XSL9Smeh/art.json index 9d5322f2..95408c6b 100644 --- a/art/2zrDmPHr7XSL9Smeh/art.json +++ b/art/2zrDmPHr7XSL9Smeh/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat noise(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvoid main() {\\n float u = vertexId / vertexCount;\\n vec2 xy = vec2(\\n noise(u + time),\\n noise(u * 0.6223)) * 2.0 - 1.0;\\n gl_Position = vec4(xy, 0, 1);\\n \\n gl_PointSize = 2.0;\\n v_color = vec4(1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hash function from https://www.shadertoy.com/view/4djSRW\nfloat noise(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvoid main() {\n float u = vertexId / vertexCount;\n vec2 xy = vec2(\n noise(u + time),\n noise(u * 0.6223)) * 2.0 - 1.0;\n gl_Position = vec4(xy, 0, 1);\n \n gl_PointSize = 2.0;\n v_color = vec4(1);\n}" + }, "screenshotURL": "data/images/images-9bkn8e21bzhrh2lsx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/32DEaMDYx5JAqhWRY/art.json b/art/32DEaMDYx5JAqhWRY/art.json index 79f8fbdf..e24ce864 100644 --- a/art/32DEaMDYx5JAqhWRY/art.json +++ b/art/32DEaMDYx5JAqhWRY/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":9923,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - Motion\\n// spring 2022\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 9923, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - Motion\n// spring 2022\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-y56isrtvvcl40snql-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/349P7R35WtujgHxrw/art.json b/art/349P7R35WtujgHxrw/art.json index dfd41342..81972c52 100644 --- a/art/349P7R35WtujgHxrw/art.json +++ b/art/349P7R35WtujgHxrw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16222,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"wired\\\" by kabuto\\n// drawing a smoothed 3d hilbert curve\\n\\n// if this runs too slowly try zooming in\\n// (ctrl + mousewheel up)\\n\\n#define PI 3.14159\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n sin(i*14.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76),\\n sin(i*.79553+2.1) +\\n sin(i*1.1311+2.1) +\\n sin(i*1.353-2.1) +\\n sin(i*.476/2.1) * cos(i * 3.0),\\n sin(i*4.5553-2.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*9.36+2.1)\\n\\t)*1.2;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n tan(i*.553)*.9553 +\\n cos(i) +\\n cos(i*1.53)/1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*4.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*11.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n tan(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*33.2;\\n}\\n\\nvec3 hilbert(float s) {\\n\\t\\t vec3 p;\\n\\t\\t {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,3.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\t\\t p = vec3(xi,yi,zi);\\n\\t\\t }\\n\\tfloat n = 2.;\\n\\t\\t for (int i = 1; i < 7; i++) {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\n\\t \\n\\tif (xi > .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < .5) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*510.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = .5;\\n \\n vec3 colour = vec3(0.);\\n\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n \\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/180.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,-22.);\\n}\"}", + "settings": { + "num": 16222, + "mode": "LINES", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"wired\" by kabuto\n// drawing a smoothed 3d hilbert curve\n\n// if this runs too slowly try zooming in\n// (ctrl + mousewheel up)\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*14.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76),\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476/2.1) * cos(i * 3.0),\n sin(i*4.5553-2.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*9.36+2.1)\n\t)*1.2;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n tan(i*.553)*.9553 +\n cos(i) +\n cos(i*1.53)/1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*4.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*11.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n tan(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*33.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,3.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2.;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < .5) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*510.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = .5;\n \n vec3 colour = vec3(0.);\n\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n \n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/180.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,-22.);\n}" + }, "screenshotURL": "data/images/images-kcmus3r0ksuyyt1qy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/34z5eo3NAr7q87bLk/art.json b/art/34z5eo3NAr7q87bLk/art.json index 2eb10c05..555feaa3 100644 --- a/art/34z5eo3NAr7q87bLk/art.json +++ b/art/34z5eo3NAr7q87bLk/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mol", "avatarUrl": "https://secure.gravatar.com/avatar/fe5b47f4d74c95c9b38908469761a86d?default=retro&size=200", - "settings": "{\"num\":32,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n gl_PointSize = 5.0;\\n \\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n \\n gl_Position.x = sin(time + vertexId / 32.0) / 2.0;\\n gl_Position.y = cos(time + vertexId / 32.0) / 2.0;\\n gl_Position.z = 0.0;\\n gl_Position[3] = 1.0;\\n}\"}", + "settings": { + "num": 32, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n gl_PointSize = 5.0;\n \n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n \n gl_Position.x = sin(time + vertexId / 32.0) / 2.0;\n gl_Position.y = cos(time + vertexId / 32.0) / 2.0;\n gl_Position.z = 0.0;\n gl_Position[3] = 1.0;\n}" + }, "screenshotURL": "data/images/images-qew6lhpxsxjdo6frg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3AsdQHZjxgRSWK2Q4/art.json b/art/3AsdQHZjxgRSWK2Q4/art.json index ce7b8283..8f71816b 100644 --- a/art/3AsdQHZjxgRSWK2Q4/art.json +++ b/art/3AsdQHZjxgRSWK2Q4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=TRIANGLES\\n//KVerticesNumber=1000000\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[1,2][2],\\n m[0][3], m[1][3,2], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[1,0][3,1],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[1][2,3], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[1,3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n // mat *= uniformScale(1.);\\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0.2, 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=TRIANGLES\n//KVerticesNumber=1000000\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[1,2][2],\n m[0][3], m[1][3,2], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[1,0][3,1],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[1][2,3], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[1,3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n // mat *= uniformScale(1.);\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0.2, 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-om7dl4dp3gkdc0gv6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3Csyw9ecsH7rXLkok/art.json b/art/3Csyw9ecsH7rXLkok/art.json index d082562c..e207888d 100644 --- a/art/3Csyw9ecsH7rXLkok/art.json +++ b/art/3Csyw9ecsH7rXLkok/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":47538,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\n//\\n// Move the mouse\\n//\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0* 7., 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\nvoid main() {\\n float tm = cos(time) *20.;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float t = (vertexId* 0.9+mod(vertexId,2.0))*0.03;\\n float phase = -tm*mod(vertexId,2.0);\\n float a = 0.173;\\n float b = 0.3063489;\\n float x = a * exp(b+t*1.3)*cos(t+phase)*0.015;\\n float y = a * exp(-b*1.3)*sin(t*phase)*0.015;\\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.005));\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\\n\\n \\n float hue = (floor(vertexId * -.5) * 0.5 - time * 0.01);\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*0.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0);\\n}\"}", + "settings": { + "num": 47538, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \n//\n// Move the mouse\n//\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0* 7., 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\nvoid main() {\n float tm = cos(time) *20.;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float t = (vertexId* 0.9+mod(vertexId,2.0))*0.03;\n float phase = -tm*mod(vertexId,2.0);\n float a = 0.173;\n float b = 0.3063489;\n float x = a * exp(b+t*1.3)*cos(t+phase)*0.015;\n float y = a * exp(-b*1.3)*sin(t*phase)*0.015;\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.005));\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\n\n \n float hue = (floor(vertexId * -.5) * 0.5 - time * 0.01);\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*0.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0);\n}" + }, "screenshotURL": "data/images/images-e0r0zx2gntwyqw0p2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3DYWqaogssoxpbdKM/art.json b/art/3DYWqaogssoxpbdKM/art.json index 943c9da1..3b83c701 100644 --- a/art/3DYWqaogssoxpbdKM/art.json +++ b/art/3DYWqaogssoxpbdKM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":56478,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define MAXITER 666\\n\\nvoid main() {\\n // more or less random start position\\n vec2 v = vec2(cos(vertexId*23.), cos(vertexId*545.))*3.;\\n\\n // collect ljapunov exponent (derivative) for colouring\\n float dv = 0.;\\n \\n float rnd = vertexId;\\n \\n // Follow a path just along the edge of the mandelbrot set's 2 biggest blobs\\n const float PI = 3.141592653589;\\n float t = fract(time*.06)*2.-1.;\\n t = pow(abs(t),0.7)*sign(t);\\n t = fract(t*.5+.6);\\n t = t*2.5*PI-0.5*PI;\\n vec2 ofs = t < 0.\\n ? vec2(-1,0)+vec2(cos(t*4.),sin(t*4.))*.25\\n : vec2(.25,0)-vec2(cos(t),-sin(t))*(1.+cos(t))*.5;\\n \\n //\\n vec2 norm = t < 0.\\n ? vec2(cos(t*4.),sin(t*4.))*sin(-t*2.)\\n : -vec2(cos(t*1.5),-sin(t*1.5))*sin(t);\\n ofs += norm*(sin(time*.3)+sin(time*.33413)+cos(time*.335)+cos(time*.4534)+1.)*.2;\\n \\n \\n for (int i = 0; i < MAXITER; i++) {\\n // random number update\\n rnd = sin(rnd*1337.+vertexId*.2+sin(time)+float(i));\\n \\n // inverse julia iteration step - subtract offset, then extract square root\\n\\tv -= ofs;\\n \\tv = vec2(sqrt((length(v) + v.x)*.5), sign(v.y)*sqrt((length(v) - v.x)*.5));\\n \\n // The complex square root is ambiguous, so both the value just computed and its inverse are valid.\\n // The most simple approach of just randomly picking a point does not work so well -\\n // it tends to collect points in certain spots (mostly tips of the fractal) while neglecting coves.\\n // Mathematically speaking, coves appear because the square root of near-zero values is computed\\n // and the square root tends to make a big difference around such values.\\n // At the same time point density is decreased too...\\n // To combat this we look ahead to the next step and prefer values that are closer to zero.\\n // This doesn't fix everything - for that we would have to look ahead further,\\n //but complexity would increase too much. So it might not really be feasible for this approach.\\n v *= sign(rnd-(length(v-ofs)-length(-v-ofs))*vertexId/vertexCount*1.3*(1.-exp((float(i-1)-float(MAXITER))*.5)));\\n \\n dv += log(length(v))+.2;\\n }\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v*aspect*.5, 1.-vertexId*.00001, 1);\\n\\n gl_PointSize = min(3.,sqrt(max(1.,-dv*.1)));\\n v_color = vec4(dv,dv*.005+1.,1,1)*.3/gl_PointSize;\\n}\"}", + "settings": { + "num": 56478, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define MAXITER 666\n\nvoid main() {\n // more or less random start position\n vec2 v = vec2(cos(vertexId*23.), cos(vertexId*545.))*3.;\n\n // collect ljapunov exponent (derivative) for colouring\n float dv = 0.;\n \n float rnd = vertexId;\n \n // Follow a path just along the edge of the mandelbrot set's 2 biggest blobs\n const float PI = 3.141592653589;\n float t = fract(time*.06)*2.-1.;\n t = pow(abs(t),0.7)*sign(t);\n t = fract(t*.5+.6);\n t = t*2.5*PI-0.5*PI;\n vec2 ofs = t < 0.\n ? vec2(-1,0)+vec2(cos(t*4.),sin(t*4.))*.25\n : vec2(.25,0)-vec2(cos(t),-sin(t))*(1.+cos(t))*.5;\n \n //\n vec2 norm = t < 0.\n ? vec2(cos(t*4.),sin(t*4.))*sin(-t*2.)\n : -vec2(cos(t*1.5),-sin(t*1.5))*sin(t);\n ofs += norm*(sin(time*.3)+sin(time*.33413)+cos(time*.335)+cos(time*.4534)+1.)*.2;\n \n \n for (int i = 0; i < MAXITER; i++) {\n // random number update\n rnd = sin(rnd*1337.+vertexId*.2+sin(time)+float(i));\n \n // inverse julia iteration step - subtract offset, then extract square root\n\tv -= ofs;\n \tv = vec2(sqrt((length(v) + v.x)*.5), sign(v.y)*sqrt((length(v) - v.x)*.5));\n \n // The complex square root is ambiguous, so both the value just computed and its inverse are valid.\n // The most simple approach of just randomly picking a point does not work so well -\n // it tends to collect points in certain spots (mostly tips of the fractal) while neglecting coves.\n // Mathematically speaking, coves appear because the square root of near-zero values is computed\n // and the square root tends to make a big difference around such values.\n // At the same time point density is decreased too...\n // To combat this we look ahead to the next step and prefer values that are closer to zero.\n // This doesn't fix everything - for that we would have to look ahead further,\n //but complexity would increase too much. So it might not really be feasible for this approach.\n v *= sign(rnd-(length(v-ofs)-length(-v-ofs))*vertexId/vertexCount*1.3*(1.-exp((float(i-1)-float(MAXITER))*.5)));\n \n dv += log(length(v))+.2;\n }\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v*aspect*.5, 1.-vertexId*.00001, 1);\n\n gl_PointSize = min(3.,sqrt(max(1.,-dv*.1)));\n v_color = vec4(dv,dv*.005+1.,1,1)*.3/gl_PointSize;\n}" + }, "screenshotURL": "data/images/images-cw35418rszig29ehv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3EGwvJZ5S8be4wM7t/art.json b/art/3EGwvJZ5S8be4wM7t/art.json index b3df9c66..685dd48f 100644 --- a/art/3EGwvJZ5S8be4wM7t/art.json +++ b/art/3EGwvJZ5S8be4wM7t/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, -1, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, -1, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-i87yt5mo2qdvrbufg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3GfvibHchBkZT4arh/art.json b/art/3GfvibHchBkZT4arh/art.json index 2c85dc91..c0687001 100644 --- a/art/3GfvibHchBkZT4arh/art.json +++ b/art/3GfvibHchBkZT4arh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5415,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, s, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 3.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .15));\\n gl_PointSize =pow(sz, s*s/32.\\n ) * resolution.y / 4776. * s* 30.;\\n \\n \\n\\n float hue = sz * 2. + s * 0.953;\\n float sat = 1.;\\n float val = s*2.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 5415, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, s, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 3.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .15));\n gl_PointSize =pow(sz, s*s/32.\n ) * resolution.y / 4776. * s* 30.;\n \n \n\n float hue = sz * 2. + s * 0.953;\n float sat = 1.;\n float val = s*2.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-9h0vmzgjpsbnaw7yd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3GkC95J3qizbTmiwJ/art.json b/art/3GkC95J3qizbTmiwJ/art.json index 48423ee0..6ac4ceea 100644 --- a/art/3GkC95J3qizbTmiwJ/art.json +++ b/art/3GkC95J3qizbTmiwJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"attribute vec4 vPosition;\\nvoid main() {\\n gl_Position = vPosition;\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "attribute vec4 vPosition;\nvoid main() {\n gl_Position = vPosition;\n}" + }, "screenshotURL": "data/images/images-w31227g1vlsb8ok72-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3K4LGxEGgP7MLHZnb/art.json b/art/3K4LGxEGgP7MLHZnb/art.json index 7704964d..c816a420 100644 --- a/art/3K4LGxEGgP7MLHZnb/art.json +++ b/art/3K4LGxEGgP7MLHZnb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":84301,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\\n \\n vCubeCol.xyz = vec3(0,0,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.1;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0.0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, 25.0),1,1,1), color, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 84301, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\n \n vCubeCol.xyz = vec3(0,0,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.1;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0.0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, 25.0),1,1,1), color, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-ocv7mbst4bbtoey0l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3K4d92nvq5JFcZa8K/art.json b/art/3K4d92nvq5JFcZa8K/art.json index 415e7c79..56c48075 100644 --- a/art/3K4d92nvq5JFcZa8K/art.json +++ b/art/3K4d92nvq5JFcZa8K/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "foxhunt", "avatarUrl": "https://avatars.githubusercontent.com/Foxhunt?s=200", - "settings": "{\"num\":262,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.20784313725490197,1],\"shader\":\"#define PI 3.1415926535897932384626433832795\\n\\nfloat oscillate(float i, float mi, float ma) {\\n float r = ma - mi;\\n float o = mi + abs(mod(i + r, r * 2.) - r);\\n return o;\\n}\\n\\nvoid main() {\\n \\n float x = mod(time * .4 + (vertexId / vertexCount * 2. - 1.), 2.) - 1.;\\n \\n float y = sin(x * PI * 10.) * oscillate(time * .02, -.2, .2);\\n \\n gl_Position = vec4(x, y, 0, 1);\\n \\n gl_PointSize = 3.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 262, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.20784313725490197, + 1 + ], + "shader": "#define PI 3.1415926535897932384626433832795\n\nfloat oscillate(float i, float mi, float ma) {\n float r = ma - mi;\n float o = mi + abs(mod(i + r, r * 2.) - r);\n return o;\n}\n\nvoid main() {\n \n float x = mod(time * .4 + (vertexId / vertexCount * 2. - 1.), 2.) - 1.;\n \n float y = sin(x * PI * 10.) * oscillate(time * .02, -.2, .2);\n \n gl_Position = vec4(x, y, 0, 1);\n \n gl_PointSize = 3.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-eilnjhtsdinc3k5as-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3NDzadNsSWytgiaLt/art.json b/art/3NDzadNsSWytgiaLt/art.json index cef5b3e7..64973404 100644 --- a/art/3NDzadNsSWytgiaLt/art.json +++ b/art/3NDzadNsSWytgiaLt/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":1690,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Seulbin Seo\\n// Exercise Making A Grid with 4 Colors\\n// CS250 Spring 2022\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n if (u < 0.5 && v < 0.5) {\\n v_color = vec4(0.85, 0.1, 0.57, 1);\\n } else if (u >= 0.5 && v < 0.5) {\\n v_color = vec4(0, 1, 0, 1); \\n } else if (u < 0.5 && v >= 0.5) {\\n v_color = vec4(0, 0.4, 1, 1); \\n } else {\\n v_color = vec4(1, 1.4, 0.2, 1);\\n }\\n}\"}", + "settings": { + "num": 1690, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Making A Grid with 4 Colors\n// CS250 Spring 2022\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n if (u < 0.5 && v < 0.5) {\n v_color = vec4(0.85, 0.1, 0.57, 1);\n } else if (u >= 0.5 && v < 0.5) {\n v_color = vec4(0, 1, 0, 1); \n } else if (u < 0.5 && v >= 0.5) {\n v_color = vec4(0, 0.4, 1, 1); \n } else {\n v_color = vec4(1, 1.4, 0.2, 1);\n }\n}" + }, "screenshotURL": "data/images/images-7wspl9i4cfxvvlzh1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3PKtnXSrJ72kySj5P/art.json b/art/3PKtnXSrJ72kySj5P/art.json index 42aa52d4..42a1ad54 100644 --- a/art/3PKtnXSrJ72kySj5P/art.json +++ b/art/3PKtnXSrJ72kySj5P/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":584,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Making A Grid\\n//cs250\\n//spring2023\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n float x = mod(vertexId ,across);\\n float y = floor(vertexId/across);\\n \\n float u= x /(across-1.);\\n float v= y/(across-1.);\\n \\n float ux = u* 2. -1.;\\n float vy = v* 2.-1.;\\n \\n gl_Position = vec4(ux+(sin(time)/50.),vy + cos(time)/12.,0,1);\\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 584, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Making A Grid\n//cs250\n//spring2023\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount /down);\n float x = mod(vertexId ,across);\n float y = floor(vertexId/across);\n \n float u= x /(across-1.);\n float v= y/(across-1.);\n \n float ux = u* 2. -1.;\n float vy = v* 2.-1.;\n \n gl_Position = vec4(ux+(sin(time)/50.),vy + cos(time)/12.,0,1);\n gl_PointSize = 10.0;\n \n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-2gcweptjbxoehd9et-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3PzbsXfXjckRvsRng/art.json b/art/3PzbsXfXjckRvsRng/art.json index a2d5c1fb..4469a011 100644 --- a/art/3PzbsXfXjckRvsRng/art.json +++ b/art/3PzbsXfXjckRvsRng/art.json @@ -31,7 +31,19 @@ "private": true, "unlisted": false, "username": "gman", - "settings": "{\"num\":98304,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/silver-romance/acdc-thunder-struck\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 1024.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat inRange(float v, float low, float high) {\\n return step(low, v) * step(v, high);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(u, historyV)).a;\\n\\n //\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n float target = 0.018;\\n v_color = mix(v_color, vec4(1), inRange(u, target - 0.01, target + 0.01));\\n \\n}\"}", + "settings": { + "num": 98304, + "mode": "LINES", + "sound": "https://soundcloud.com/silver-romance/acdc-thunder-struck", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 1024.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat inRange(float v, float low, float high) {\n return step(low, v) * step(v, high);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(u, historyV)).a;\n\n //\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n float target = 0.018;\n v_color = mix(v_color, vec4(1), inRange(u, target - 0.01, target + 0.01));\n \n}" + }, "screenshotURL": "data/images/images-6w8qil7xubji8w1h9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3QE3h3tQJqzMMqEZw/art.json b/art/3QE3h3tQJqzMMqEZw/art.json index 4d2c18d1..ae33421d 100644 --- a/art/3QE3h3tQJqzMMqEZw/art.json +++ b/art/3QE3h3tQJqzMMqEZw/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":12000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n\\n\\n// mouse axis x => contorl section compelxity\\n// mouse axis y => controe torus complexity\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n\\nvoid main()\\n{\\n \\tgl_PointSize = 3.0;\\n \\n\\tfloat pi = radians(180.);\\n\\tfloat pi2 = radians(360.);\\n\\t\\n\\t// vars\\n\\t// count point : 6 * quadsPerPolygon * countPolygon => here 3600\\n\\tfloat quadsPerPolygon = clamp(floor(10. * (mouse.x*0.5+0.5)), 3., 10.);\\n\\tfloat countPolygon = clamp(floor(200. * (mouse.y*0.5+0.5)), 3., 200.);\\n\\tfloat radius = 20.;\\n\\tfloat thickNess = 5.;\\n\\tfloat zoom = 2.;\\n\\t\\n \\tfloat countMax = 6. * quadsPerPolygon * countPolygon;\\n \\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\tfloat asp = pi * 2.0 / quadsPerPolygon; // angle step polygon\\n\\tfloat ap0 = asp * indexQuad; // angle polygon 0\\n\\tfloat ap1 = asp * (indexQuad + 1.); // angle polygon 0\\n\\t\\n\\tfloat indexPolygon = floor(indexQuad / quadsPerPolygon);\\n\\tfloat ast = pi * 2.0 / countPolygon; // angle step torus\\n\\tfloat at0 = ast * indexPolygon; // angle torus 0\\n\\tfloat at1 = ast * (indexPolygon + 1.); // angle torus 1\\n\\t\\n \\tvec2 st = vec2(0);\\n\\t\\n \\t// triangle 1\\n\\tif (index == 0.) st = vec2(ap0, at0);\\n\\tif (index == 1.) st = vec2(ap1, at0);\\n\\tif (index == 2.) st = vec2(ap1, at1);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) st = vec2(ap0, at0);\\n\\tif (index == 4.) st = vec2(ap1, at1);\\n\\tif (index == 5.) st = vec2(ap0, at1);\\n\\t\\n \\tvec3 p = vec3(cos(st.x),st.y,sin(st.x));\\n\\t\\n \\t// twist\\n\\tfloat ap = st.y - cos(st.y) + time;\\n\\t\\t\\t\\n \\t// polygon\\n\\tp.xz *= thickNess;\\n\\tp.xz *= mat2(cos(ap), sin(ap), -sin(ap), cos(ap));\\n\\t\\n\\t// torus\\n\\tp.x += radius;\\n\\tfloat at = p.y; p.y = 0.0;\\n\\tp.xy *= mat2(cos(at), sin(at), -sin(at), cos(at));\\n\\t\\n\\t// camera\\n\\tfloat ca = 0.5;//time * 0.1;\\n\\tfloat cd = 100.;\\n\\tvec3 eye = vec3(sin(ca), 0., cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n\\tmat4 camera = persp(45. * pi / 180., resolution.x / resolution.y, 0.1, 10000.) * \\n cameraLookAt(eye, target, up);\\n \\n \\t// vertex position\\n \\tif (vertexId < countMax)\\n {\\n \\t\\tgl_Position = camera * vec4(p,1);\\n }\\n \\telse\\n \\t{\\n \\tgl_Position = vec4(0,0,0,0);\\n \\t}\\n \\n\\t// face color\\n\\tindexQuad = mod(indexQuad, quadsPerPolygon);\\n\\tv_color = cos(vec4(10,20,30,1) + indexQuad);\\n\\tv_color = mix(v_color, vec4(normalize(p) * 0.5 + 0.5, 1), .5);\\n \\tv_color.a = 1.0;\\n}\\n\\n//////////////////////////////////////////////////////////////////////////\\n\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 12000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n\n\n// mouse axis x => contorl section compelxity\n// mouse axis y => controe torus complexity\n\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n\nvoid main()\n{\n \tgl_PointSize = 3.0;\n \n\tfloat pi = radians(180.);\n\tfloat pi2 = radians(360.);\n\t\n\t// vars\n\t// count point : 6 * quadsPerPolygon * countPolygon => here 3600\n\tfloat quadsPerPolygon = clamp(floor(10. * (mouse.x*0.5+0.5)), 3., 10.);\n\tfloat countPolygon = clamp(floor(200. * (mouse.y*0.5+0.5)), 3., 200.);\n\tfloat radius = 20.;\n\tfloat thickNess = 5.;\n\tfloat zoom = 2.;\n\t\n \tfloat countMax = 6. * quadsPerPolygon * countPolygon;\n \n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\tfloat asp = pi * 2.0 / quadsPerPolygon; // angle step polygon\n\tfloat ap0 = asp * indexQuad; // angle polygon 0\n\tfloat ap1 = asp * (indexQuad + 1.); // angle polygon 0\n\t\n\tfloat indexPolygon = floor(indexQuad / quadsPerPolygon);\n\tfloat ast = pi * 2.0 / countPolygon; // angle step torus\n\tfloat at0 = ast * indexPolygon; // angle torus 0\n\tfloat at1 = ast * (indexPolygon + 1.); // angle torus 1\n\t\n \tvec2 st = vec2(0);\n\t\n \t// triangle 1\n\tif (index == 0.) st = vec2(ap0, at0);\n\tif (index == 1.) st = vec2(ap1, at0);\n\tif (index == 2.) st = vec2(ap1, at1);\n\t\n\t// triangle 2\n\tif (index == 3.) st = vec2(ap0, at0);\n\tif (index == 4.) st = vec2(ap1, at1);\n\tif (index == 5.) st = vec2(ap0, at1);\n\t\n \tvec3 p = vec3(cos(st.x),st.y,sin(st.x));\n\t\n \t// twist\n\tfloat ap = st.y - cos(st.y) + time;\n\t\t\t\n \t// polygon\n\tp.xz *= thickNess;\n\tp.xz *= mat2(cos(ap), sin(ap), -sin(ap), cos(ap));\n\t\n\t// torus\n\tp.x += radius;\n\tfloat at = p.y; p.y = 0.0;\n\tp.xy *= mat2(cos(at), sin(at), -sin(at), cos(at));\n\t\n\t// camera\n\tfloat ca = 0.5;//time * 0.1;\n\tfloat cd = 100.;\n\tvec3 eye = vec3(sin(ca), 0., cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n\tmat4 camera = persp(45. * pi / 180., resolution.x / resolution.y, 0.1, 10000.) * \n cameraLookAt(eye, target, up);\n \n \t// vertex position\n \tif (vertexId < countMax)\n {\n \t\tgl_Position = camera * vec4(p,1);\n }\n \telse\n \t{\n \tgl_Position = vec4(0,0,0,0);\n \t}\n \n\t// face color\n\tindexQuad = mod(indexQuad, quadsPerPolygon);\n\tv_color = cos(vec4(10,20,30,1) + indexQuad);\n\tv_color = mix(v_color, vec4(normalize(p) * 0.5 + 0.5, 1), .5);\n \tv_color.a = 1.0;\n}\n\n//////////////////////////////////////////////////////////////////////////\n\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-thuo3n4rfsgpwdpni-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3Qk8RvorqrMH5CCJy/art.json b/art/3Qk8RvorqrMH5CCJy/art.json index 4d69c5e6..b5a1140b 100644 --- a/art/3Qk8RvorqrMH5CCJy/art.json +++ b/art/3Qk8RvorqrMH5CCJy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":18766,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n return inverse(lookAt(eye, target, up));\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\nfloat remap(float v, float inMin, float inMax, float outMin, float outMax) {\\n return (v - inMin) / (inMax - inMin) * (outMax - outMin) + outMin;\\n}\\n\\nvoid main() {\\n float pointsPerCircle = 16.0;\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float vId = mod(vertexId, pointsPerCircle);\\n float pointId = vertexId;\\n float u = vId / pointsPerCircle;\\n float v = circleId / numCircles;\\n\\n vec3 loc = fibonacciSphere(numCircles, circleId);\\n\\n float a = u * PI * 2.0 + time * 5.0 + circleId * 25.;\\n vec3 pos = vec3(\\n sin(a),\\n cos(a),\\n 0.);\\n \\n \\n float tm = time * .10;\\n float r = 40.;\\n float fov = radians(100.0);\\n float aspect = resolution.x / resolution.y;\\n float zNear = 1.;\\n float zFar = 100.;\\n mat4 mat = persp(fov, aspect, zNear, zFar);\\n \\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n //mat *= rotX(time * 0.37);\\n //mat *= rotY(time * 0.21);\\n mat *= lookAt(loc, vec3(0), vec3(0,1,0));\\n mat *= trans(vec3(0,0,40.));\\n mat *= scale(vec3(30000. / vertexCount));\\n \\n gl_Position = mat * vec4(pos, 1);\\n\\n // z goes from about 20 to 100\\n float alpha = 1.;//remap(gl_Position.z, 20., 100., 1., 0.); \\n \\n v_color = vec4(1, 0, 0, alpha);\\n v_color.rgb *= v_color.a; \\n \\n gl_PointSize = u * 20000. / vertexCount / (0.01 * gl_Position.z);\\n}\\n\"}", + "settings": { + "num": 18766, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n return inverse(lookAt(eye, target, up));\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\nfloat remap(float v, float inMin, float inMax, float outMin, float outMax) {\n return (v - inMin) / (inMax - inMin) * (outMax - outMin) + outMin;\n}\n\nvoid main() {\n float pointsPerCircle = 16.0;\n float circleId = floor(vertexId / pointsPerCircle);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float vId = mod(vertexId, pointsPerCircle);\n float pointId = vertexId;\n float u = vId / pointsPerCircle;\n float v = circleId / numCircles;\n\n vec3 loc = fibonacciSphere(numCircles, circleId);\n\n float a = u * PI * 2.0 + time * 5.0 + circleId * 25.;\n vec3 pos = vec3(\n sin(a),\n cos(a),\n 0.);\n \n \n float tm = time * .10;\n float r = 40.;\n float fov = radians(100.0);\n float aspect = resolution.x / resolution.y;\n float zNear = 1.;\n float zFar = 100.;\n mat4 mat = persp(fov, aspect, zNear, zFar);\n \n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n //mat *= rotX(time * 0.37);\n //mat *= rotY(time * 0.21);\n mat *= lookAt(loc, vec3(0), vec3(0,1,0));\n mat *= trans(vec3(0,0,40.));\n mat *= scale(vec3(30000. / vertexCount));\n \n gl_Position = mat * vec4(pos, 1);\n\n // z goes from about 20 to 100\n float alpha = 1.;//remap(gl_Position.z, 20., 100., 1., 0.); \n \n v_color = vec4(1, 0, 0, alpha);\n v_color.rgb *= v_color.a; \n \n gl_PointSize = u * 20000. / vertexCount / (0.01 * gl_Position.z);\n}\n" + }, "screenshotURL": "data/images/images-srdtjfr65fynsddco-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3QtDqanQXHR4KXBo2/art.json b/art/3QtDqanQXHR4KXBo2/art.json index 25d3952f..641ae513 100644 --- a/art/3QtDqanQXHR4KXBo2/art.json +++ b/art/3QtDqanQXHR4KXBo2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.10980392156862745,0.10980392156862745,1],\"shader\":\"// Lesson at \\n\\n// L2:\\n//\\n\\n// Every shader needs a main\\n// number of vertices fixed up there\\n\\n// Check the help to know which variables are available around\\n\\n// some code to convert HSV to RGB\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1., 2.0/ 3.0, 1.0/3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // Get x, y coordinates on a grid\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time*1.1 + x * 0.3) * .1;\\n \\n // scale to get a fix number across the width\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n // scale it back to [-1, 1]\\n float ux = u*2. - 1. + xoff;\\n float vy = v*2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1); // x, y, z, (w) (each one from -1 to 1\\n \\n // Adjust size of points by time too\\n float soff = sin(time*1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 12.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 * v * u * 20.) * .5 + .5; // check replace the \\\"+\\\" by a \\\"*\\\" in the sin\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); // v_color is specific to vertexshader.com (it's the gl_FragColor) equivalent\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.10980392156862745, + 0.10980392156862745, + 1 + ], + "shader": "// Lesson at \n\n// L2:\n//\n\n// Every shader needs a main\n// number of vertices fixed up there\n\n// Check the help to know which variables are available around\n\n// some code to convert HSV to RGB\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1., 2.0/ 3.0, 1.0/3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // Get x, y coordinates on a grid\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time*1.1 + x * 0.3) * .1;\n \n // scale to get a fix number across the width\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n // scale it back to [-1, 1]\n float ux = u*2. - 1. + xoff;\n float vy = v*2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1); // x, y, z, (w) (each one from -1 to 1\n \n // Adjust size of points by time too\n float soff = sin(time*1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 12.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 * v * u * 20.) * .5 + .5; // check replace the \"+\" by a \"*\" in the sin\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); // v_color is specific to vertexshader.com (it's the gl_FragColor) equivalent\n\n}" + }, "screenshotURL": "data/images/images-t22lr11684hu770i7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3RibQfbPe3tobLxLw/art.json b/art/3RibQfbPe3tobLxLw/art.json index 4640a6a7..277b8805 100644 --- a/art/3RibQfbPe3tobLxLw/art.json +++ b/art/3RibQfbPe3tobLxLw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n id = mod(id, 16.0);\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\nvec4 getPart0(float id) {\\n if (id == 00.) return hypercube(0.);\\n if (id == 01.) return hypercube(3.);\\n if (id == 02.) return hypercube(3.);\\n if (id == 03.) return hypercube(8.);\\n if (id == 04.) return hypercube(8.);\\n if (id == 05.) return hypercube(2.);\\n if (id == 06.) return hypercube(2.);\\n if (id == 07.) return hypercube(0.);\\n}\\nvec4 getPart1(float id) {\\n if (id == 08.) return hypercube(0.);\\n if (id == 09.) return hypercube(4.);\\n if (id == 10.) return hypercube(4.);\\n if (id == 11.) return hypercube(10.);\\n if (id == 12.) return hypercube(10.);\\n if (id == 13.) return hypercube(3.);\\n if (id == 14.) return hypercube(8.);\\n if (id == 15.) return hypercube(13.);\\n}\\nvec4 getPart2(float id) {\\n if (id == 16.) return hypercube(2.);\\n if (id == 17.) return hypercube(9.);\\n if (id == 18.) return hypercube(4.);\\n if (id == 19.) return hypercube(9.);\\n if (id == 20.) return hypercube(10.);\\n if (id == 21.) return hypercube(13.);\\n if (id == 22.) return hypercube(13.);\\n if (id == 23.) return hypercube(9.);\\n}\\nvec4 getPart3(float id) {\\n if (id == 24.) return hypercube(1.);\\n if (id == 25.) return hypercube(6.);\\n if (id == 26.) return hypercube(6.);\\n if (id == 27.) return hypercube(11.);\\n if (id == 28.) return hypercube(11.);\\n if (id == 29.) return hypercube(5.);\\n if (id == 30.) return hypercube(5.);\\n if (id == 31.) return hypercube(1.);\\n}\\nvec4 getPart4(float id) {\\n if (id == 32.) return hypercube(7.);\\n if (id == 33.) return hypercube(14.);\\n if (id == 34.) return hypercube(14.);\\n if (id == 35.) return hypercube(15.);\\n if (id == 36.) return hypercube(15.);\\n if (id == 37.) return hypercube(12.);\\n if (id == 38.) return hypercube(12.);\\n if (id == 39.) return hypercube(7.);\\n}\\nvec4 getPart5(float id) {\\n if (id == 40.) return hypercube(1.);\\n if (id == 41.) return hypercube(7.);\\n if (id == 42.) return hypercube(6.);\\n if (id == 43.) return hypercube(14.);\\n if (id == 44.) return hypercube(11.);\\n if (id == 45.) return hypercube(15.);\\n if (id == 46.) return hypercube(5.);\\n if (id == 47.) return hypercube(12.);\\n}\\nvec4 getPart6(float id) {\\n if (id == 48.) return hypercube(2.);\\n if (id == 49.) return hypercube(5.);\\n if (id == 50.) return hypercube(8.);\\n if (id == 51.) return hypercube(11.);\\n if (id == 52.) return hypercube(13.);\\n if (id == 53.) return hypercube(15.);\\n if (id == 54.) return hypercube(9.);\\n if (id == 55.) return hypercube(12.);\\n}\\nvec4 getPart7(float id) {\\n if (id == 56.) return hypercube(0.);\\n if (id == 57.) return hypercube(1.);\\n if (id == 58.) return hypercube(3.);\\n if (id == 59.) return hypercube(6.);\\n if (id == 60.) return hypercube(10.);\\n if (id == 61.) return hypercube(14.);\\n if (id == 62.) return hypercube(4.);\\n if (id == 63.) return hypercube(7.);\\n}\\nvec4 hypercube_lines(float id)\\n{\\n id = mod(vertexId, 64.0);\\n \\n if (id >= 0. && id < 8.)\\n return getPart0(id);\\n if (id >= 8. && id < 16.)\\n return getPart1(id);\\n if (id >= 16. && id < 24.)\\n return getPart2(id);\\n if (id >= 24. && id < 32.)\\n return getPart3(id);\\n if (id >= 32. && id < 40.)\\n return getPart4(id);\\n if (id >= 40. && id < 48.)\\n return getPart5(id);\\n if (id >= 48. && id < 56.)\\n return getPart6(id);\\n if (id >= 56. && id < 64.)\\n return getPart7(id);\\n \\n return vec4(0);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 0, 0, 0);\\n vec4 up4 = vec4(0, 1, 0, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(3.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n float theta3 = 45.0 * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.1 * TAU);\\n t4 *= rot4xy(time * 0.05 * TAU);\\n vec4 v4 = hypercube_lines(vertexId);\\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect, 0, 1);\\n v_color = vec4(1,1,1, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n id = mod(id, 16.0);\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\nvec4 getPart0(float id) {\n if (id == 00.) return hypercube(0.);\n if (id == 01.) return hypercube(3.);\n if (id == 02.) return hypercube(3.);\n if (id == 03.) return hypercube(8.);\n if (id == 04.) return hypercube(8.);\n if (id == 05.) return hypercube(2.);\n if (id == 06.) return hypercube(2.);\n if (id == 07.) return hypercube(0.);\n}\nvec4 getPart1(float id) {\n if (id == 08.) return hypercube(0.);\n if (id == 09.) return hypercube(4.);\n if (id == 10.) return hypercube(4.);\n if (id == 11.) return hypercube(10.);\n if (id == 12.) return hypercube(10.);\n if (id == 13.) return hypercube(3.);\n if (id == 14.) return hypercube(8.);\n if (id == 15.) return hypercube(13.);\n}\nvec4 getPart2(float id) {\n if (id == 16.) return hypercube(2.);\n if (id == 17.) return hypercube(9.);\n if (id == 18.) return hypercube(4.);\n if (id == 19.) return hypercube(9.);\n if (id == 20.) return hypercube(10.);\n if (id == 21.) return hypercube(13.);\n if (id == 22.) return hypercube(13.);\n if (id == 23.) return hypercube(9.);\n}\nvec4 getPart3(float id) {\n if (id == 24.) return hypercube(1.);\n if (id == 25.) return hypercube(6.);\n if (id == 26.) return hypercube(6.);\n if (id == 27.) return hypercube(11.);\n if (id == 28.) return hypercube(11.);\n if (id == 29.) return hypercube(5.);\n if (id == 30.) return hypercube(5.);\n if (id == 31.) return hypercube(1.);\n}\nvec4 getPart4(float id) {\n if (id == 32.) return hypercube(7.);\n if (id == 33.) return hypercube(14.);\n if (id == 34.) return hypercube(14.);\n if (id == 35.) return hypercube(15.);\n if (id == 36.) return hypercube(15.);\n if (id == 37.) return hypercube(12.);\n if (id == 38.) return hypercube(12.);\n if (id == 39.) return hypercube(7.);\n}\nvec4 getPart5(float id) {\n if (id == 40.) return hypercube(1.);\n if (id == 41.) return hypercube(7.);\n if (id == 42.) return hypercube(6.);\n if (id == 43.) return hypercube(14.);\n if (id == 44.) return hypercube(11.);\n if (id == 45.) return hypercube(15.);\n if (id == 46.) return hypercube(5.);\n if (id == 47.) return hypercube(12.);\n}\nvec4 getPart6(float id) {\n if (id == 48.) return hypercube(2.);\n if (id == 49.) return hypercube(5.);\n if (id == 50.) return hypercube(8.);\n if (id == 51.) return hypercube(11.);\n if (id == 52.) return hypercube(13.);\n if (id == 53.) return hypercube(15.);\n if (id == 54.) return hypercube(9.);\n if (id == 55.) return hypercube(12.);\n}\nvec4 getPart7(float id) {\n if (id == 56.) return hypercube(0.);\n if (id == 57.) return hypercube(1.);\n if (id == 58.) return hypercube(3.);\n if (id == 59.) return hypercube(6.);\n if (id == 60.) return hypercube(10.);\n if (id == 61.) return hypercube(14.);\n if (id == 62.) return hypercube(4.);\n if (id == 63.) return hypercube(7.);\n}\nvec4 hypercube_lines(float id)\n{\n id = mod(vertexId, 64.0);\n \n if (id >= 0. && id < 8.)\n return getPart0(id);\n if (id >= 8. && id < 16.)\n return getPart1(id);\n if (id >= 16. && id < 24.)\n return getPart2(id);\n if (id >= 24. && id < 32.)\n return getPart3(id);\n if (id >= 32. && id < 40.)\n return getPart4(id);\n if (id >= 40. && id < 48.)\n return getPart5(id);\n if (id >= 48. && id < 56.)\n return getPart6(id);\n if (id >= 56. && id < 64.)\n return getPart7(id);\n \n return vec4(0);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 0, 0, 0);\n vec4 up4 = vec4(0, 1, 0, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(3.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n float theta3 = 45.0 * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.1 * TAU);\n t4 *= rot4xy(time * 0.05 * TAU);\n vec4 v4 = hypercube_lines(vertexId);\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect, 0, 1);\n v_color = vec4(1,1,1, 1);\n}" + }, "screenshotURL": "data/images/images-7xhjal6h6ovvwctxu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3Szoo7khkBA4exnsR/art.json b/art/3Szoo7khkBA4exnsR/art.json index 79acc94a..af55378b 100644 --- a/art/3Szoo7khkBA4exnsR/art.json +++ b/art/3Szoo7khkBA4exnsR/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":662,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ken-ishii-70drums/sulfurex-point-break-ken-ishii\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 1800.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float snd0 = 0.5;//texture2D(sound, vec2(0.13 + lineId * 0.005, quadId / quadCount * 0.01)).a;\\n float snd1 = 0.5;//texture2D(sound, vec2(0.14 + lineId * 0.005, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId * 0.02 + time * 1.1 * (lineId + 1.), pointId, pow(snd0, 7.0) * 0.5, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n \\n vec3 aspect = vec3(resolution.y / resolution.x * 2., 2, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(quadId / quadCount);\\n gl_Position.x += m1p1(lineId / 50.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.0, fract(lineId / 5.3));\\n float sat = 1.;\\n float val = step(0.5, snd1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 662, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ken-ishii-70drums/sulfurex-point-break-ken-ishii", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 1800.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float snd0 = 0.5;//texture2D(sound, vec2(0.13 + lineId * 0.005, quadId / quadCount * 0.01)).a;\n float snd1 = 0.5;//texture2D(sound, vec2(0.14 + lineId * 0.005, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId * 0.02 + time * 1.1 * (lineId + 1.), pointId, pow(snd0, 7.0) * 0.5, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n \n vec3 aspect = vec3(resolution.y / resolution.x * 2., 2, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(quadId / quadCount);\n gl_Position.x += m1p1(lineId / 50.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.0, fract(lineId / 5.3));\n float sat = 1.;\n float val = step(0.5, snd1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-hs5ot0fucno7vm1pj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3b3a5MqLTPvBpcvhN/art.json b/art/3b3a5MqLTPvBpcvhN/art.json index 810d588b..4943e40f 100644 --- a/art/3b3a5MqLTPvBpcvhN/art.json +++ b/art/3b3a5MqLTPvBpcvhN/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":71132,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/whippedcreammusic/popn11yuihuihyuihh\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(0.1, 0.2, 1.4) * 0.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 1.8, 0.1 ) - 1.5;\\n\\nvec3 gCubeColor = vec3(2.1, -0.2, 10.0)*3.;\\nfloat gExposure = 15.3;\\n\\nfloat gCubeColorRandom =0.8;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 2.8;\\nfloat gFloorHeight = -0.5;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 185.0 -(mouse.y * 3. -4.) )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 110.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 14.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-3., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 2.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 0.2)).xyz;\\n \\tv3 = (mat * vec4(v3, 0.5)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 100 );\\n\\n outSceneVertex.fAlpha = 0.2; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 142.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 2,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, s, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 2);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][2], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 - a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 + a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, -up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, -1,\\n zAxis, 0.11,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 3. - 0.5;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.5);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * (2. /mouse.y));\\n}\\n\\nconst float perBlock = 6.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 3.5));\\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z-snd*5.; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 2, cos(time * 1.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(0.37) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.4), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 71132, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/whippedcreammusic/popn11yuihuihyuihh", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(0.1, 0.2, 1.4) * 0.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 1.8, 0.1 ) - 1.5;\n\nvec3 gCubeColor = vec3(2.1, -0.2, 10.0)*3.;\nfloat gExposure = 15.3;\n\nfloat gCubeColorRandom =0.8;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 2.8;\nfloat gFloorHeight = -0.5;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 185.0 -(mouse.y * 3. -4.) )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 110.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 14.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-3., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 2.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 0.2)).xyz;\n \tv3 = (mat * vec4(v3, 0.5)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 100 );\n\n outSceneVertex.fAlpha = 0.2; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 142.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 2,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, s, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 2);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][2], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 - a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 + a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, -up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, -1,\n zAxis, 0.11,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 3. - 0.5;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.5);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * (2. /mouse.y));\n}\n\nconst float perBlock = 6.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 3.5));\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z-snd*5.; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 2, cos(time * 1.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(0.37) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.4), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-oaeo5wqjshrmq1hrm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3cskmP4veKB962KoC/art.json b/art/3cskmP4veKB962KoC/art.json index a3a06c18..46ec2b09 100644 --- a/art/3cskmP4veKB962KoC/art.json +++ b/art/3cskmP4veKB962KoC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 0.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /72. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 0.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /72. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-erbpa9mx81dbxqhdc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3cvdmf4HtiuwSqeR8/art.json b/art/3cvdmf4HtiuwSqeR8/art.json index 63e340fd..f4462183 100644 --- a/art/3cvdmf4HtiuwSqeR8/art.json +++ b/art/3cvdmf4HtiuwSqeR8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Vertexshaderart : Making a Grid\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n float u = x/(across-1.);\\n float v = y/(across -1.);\\n float ux =u*2.-1.;\\n float vy = v*2.-1.;\\n ux = sin(ux+time);\\n vy = cos(vy+time);\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize +=20./across;\\n gl_PointSize += resolution.x / 600.;\\n \\n v_color = vec4(abs(ux),abs(vy),0,1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Vertexshaderart : Making a Grid\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n float u = x/(across-1.);\n float v = y/(across -1.);\n float ux =u*2.-1.;\n float vy = v*2.-1.;\n ux = sin(ux+time);\n vy = cos(vy+time);\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n gl_PointSize +=20./across;\n gl_PointSize += resolution.x / 600.;\n \n v_color = vec4(abs(ux),abs(vy),0,1);\n \n}" + }, "screenshotURL": "data/images/images-00ase1ejdqge7ksql-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3dDfZyr8Pj8Nn2iTq/art.json b/art/3dDfZyr8Pj8Nn2iTq/art.json index 9fbbfaf1..c1bb88b8 100644 --- a/art/3dDfZyr8Pj8Nn2iTq/art.json +++ b/art/3dDfZyr8Pj8Nn2iTq/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 10.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n \\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n \\n float base = time * 1.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //NEW\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n vec4 cbNi;\\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\\n \\n float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\\n \\n cubep*= 0.08+snd;\\n \\n //END NEW\\n track(vertexId, vertexCount, base, pos, color);\\n //TRACK\\n /*\\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(czaxis, 0),\\n vec4(cxaxis, 0),\\n vec4(czaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n color = vec4(1.,1.,1.,1.);\\n*/\\n //END TRACK\\n cubep+= pos;\\n color.xyz = shade(eye, cubep, cbNi.xyz, color.xyz, 0.6, vec2(64.0, .8));\\n \\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 10.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n \n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\nvoid main() {\n \n float base = time * 1.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n \n //NEW\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n vec4 cbNi;\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\n \n float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\n \n cubep*= 0.08+snd;\n \n //END NEW\n track(vertexId, vertexCount, base, pos, color);\n //TRACK\n /*\n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(czaxis, 0),\n vec4(cxaxis, 0),\n vec4(czaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n color = vec4(1.,1.,1.,1.);\n*/\n //END TRACK\n cubep+= pos;\n color.xyz = shade(eye, cubep, cbNi.xyz, color.xyz, 0.6, vec2(64.0, .8));\n \n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-4cgku968vnt30rjm9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3eX8nyZYKzX3Xf9be/art.json b/art/3eX8nyZYKzX3Xf9be/art.json index 4b6f60ee..9809fc6f 100644 --- a/art/3eX8nyZYKzX3Xf9be/art.json +++ b/art/3eX8nyZYKzX3Xf9be/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/victorruiz/robots\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/victorruiz/robots", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-wb4v5i9gxwpptre4h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3fJgrXgNHKr78pqQs/art.json b/art/3fJgrXgNHKr78pqQs/art.json index 0d14d521..72a529bb 100644 --- a/art/3fJgrXgNHKr78pqQs/art.json +++ b/art/3fJgrXgNHKr78pqQs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16005,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n vec3 p = vec3(sin(PI/80.*vertexId),cos(PI/80.*vertexId),0);\\n \\n mat2 rot = mat2(\\n cos(PI/80.*vertexId/40.),sin(PI/80.*vertexId/40.),\\n -sin(PI/80.*vertexId/40.),cos(PI/80.*vertexId/40.)\\n );\\n \\n p.xz = p.xz*rot;\\n vec3 op = p;\\n \\n p.xz = p.xz*mat2(cos(time),sin(time),-sin(time),cos(time));\\n p.xy = p.xy*mat2(cos(time*.5),sin(time*.5),-sin(time*.5),cos(time*.5));\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n p.xy*= aspect;\\n gl_Position = vec4(p/(p.z+2.)*.7, 1);\\n\\n v_color = vec4((op*.5+.5)*max(dot(p,vec3(.5,1,-1)),0.),1);\\n}\"}", + "settings": { + "num": 16005, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n vec3 p = vec3(sin(PI/80.*vertexId),cos(PI/80.*vertexId),0);\n \n mat2 rot = mat2(\n cos(PI/80.*vertexId/40.),sin(PI/80.*vertexId/40.),\n -sin(PI/80.*vertexId/40.),cos(PI/80.*vertexId/40.)\n );\n \n p.xz = p.xz*rot;\n vec3 op = p;\n \n p.xz = p.xz*mat2(cos(time),sin(time),-sin(time),cos(time));\n p.xy = p.xy*mat2(cos(time*.5),sin(time*.5),-sin(time*.5),cos(time*.5));\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n p.xy*= aspect;\n gl_Position = vec4(p/(p.z+2.)*.7, 1);\n\n v_color = vec4((op*.5+.5)*max(dot(p,vec3(.5,1,-1)),0.),1);\n}" + }, "screenshotURL": "data/images/images-ek948z8ppr8qt9880-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3fg2XtwJcBLhe5bdW/art.json b/art/3fg2XtwJcBLhe5bdW/art.json index 6163de0e..c974b8a3 100644 --- a/art/3fg2XtwJcBLhe5bdW/art.json +++ b/art/3fg2XtwJcBLhe5bdW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":10404,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nChallenge: 01\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1, 1, s,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n s, 1, 1, c); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, c, s, 0,\\n s, s, c, 0,\\n 0, 0, 0, c); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, s, s, \\n s, c, 0, 0,\\n s, 0, c, 0,\\n s, 0, 0, c); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, s);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, s,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float faceId = mod(floor(pointId / 6.), 6.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = PI * 1.75;time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.7, sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * .3);\\n// mat *= rotX(time + abs(ca) * 5.);\\n// mat *= rotZ(time + abs(cd) * 6.);\\n float d = length(vec2(ca, cd));\\n mat *= scale(vec3(\\n 1, \\n mix(2., \\n 12., \\n pow(sin(time * -2. + d * PI * 1.) * 0.5 + 0.5, \\n 1.5 + (1. - d) * 2.)), \\n 1));\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(3.3, 0.4, -1));\\n\\n float hue = .15 + mod(faceId + 2., 6.) * 0.17;\\n float sat = 0.3;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val)) * 1.125;\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 10404, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nChallenge: 01\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1, 1, s,\n 0, c, s, 0,\n 0, -s, c, 0,\n s, 1, 1, c); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, c, s, 0,\n s, s, c, 0,\n 0, 0, 0, c); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, s, s, \n s, c, 0, 0,\n s, 0, c, 0,\n s, 0, 0, c); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, s);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, s,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float faceId = mod(floor(pointId / 6.), 6.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = PI * 1.75;time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.7, sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * .3);\n// mat *= rotX(time + abs(ca) * 5.);\n// mat *= rotZ(time + abs(cd) * 6.);\n float d = length(vec2(ca, cd));\n mat *= scale(vec3(\n 1, \n mix(2., \n 12., \n pow(sin(time * -2. + d * PI * 1.) * 0.5 + 0.5, \n 1.5 + (1. - d) * 2.)), \n 1));\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(3.3, 0.4, -1));\n\n float hue = .15 + mod(faceId + 2., 6.) * 0.17;\n float sat = 0.3;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val)) * 1.125;\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-nq9d076rx1x340eir-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3gbxiT43Btfh3sY5q/art.json b/art/3gbxiT43Btfh3sY5q/art.json index de4b106c..40108dfd 100644 --- a/art/3gbxiT43Btfh3sY5q/art.json +++ b/art/3gbxiT43Btfh3sY5q/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "brygo1995", "avatarUrl": "https://avatars.githubusercontent.com/BryGo1995?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n\\t\\n float across = 10.0;\\n \\n float x = mod(vertexId, 10.0);\\n float y = floor(vertexId / 10.0);\\n \\n float u = x / across;\\n float v = y / across;\\n \\n u += sin(time + x);\\n v += sin(time + y);\\n float z = 2.0 * sin(time);\\n \\n gl_Position = vec4(u, v, z, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n\t\n float across = 10.0;\n \n float x = mod(vertexId, 10.0);\n float y = floor(vertexId / 10.0);\n \n float u = x / across;\n float v = y / across;\n \n u += sin(time + x);\n v += sin(time + y);\n float z = 2.0 * sin(time);\n \n gl_Position = vec4(u, v, z, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-txhceaq3xvlc2vtot-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3hNCrCAfmKvR2iKP8/art.json b/art/3hNCrCAfmKvR2iKP8/art.json index 84b2eeb5..89198c34 100644 --- a/art/3hNCrCAfmKvR2iKP8/art.json +++ b/art/3hNCrCAfmKvR2iKP8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES \\n\\n#define KP0 -.50 //KParameter -1.>>1.\\n#define KP1 0.50//Kparameter -1.>>1.\\n#define KP2 2.0//KParameter 0.>>5.\\n\\n#define KP3 1.0//KParameter 0.>>0.5\\n#define KP4 2.0//KParameter 0.>>2.0\\n\\n#define PI radians(180.)\\n#define SIZE 90.0\\n#define NUM_CUBES (SIZE*SIZE*SIZE)\\n#define NUM_TRIANGLES (NUM_CUBES*6)\\n#define NUM_VERTICES (NUM_TRIANGLES*6)\\n#define STEP 80.0\\n\\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nvec3 camPath(float t){\\n \\n //return vec3(0, 0, t); // Straight path.\\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\\n \\n //float s = sin(t/24.)*cos(t/12.);\\n //return vec3(s*12., 0., t);\\n \\n float a = -sin(t * 0.011);\\n float b = cos(t * 0.014);\\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\\n \\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nfloat map(vec3 p){\\n \\n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\\n \\n p *= 0.4;\\n p = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\\n \\n \\n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\\n\\n // It's an easy field to create, but not so great to hone in one. The \\\"1.4\\\" fudge factor\\n // is there to get a little extra distance... Obtained by trial and error.\\n return (n - 1.025)*1.33;\\n \\n}\\n\\n\\nvoid main() {\\n \\n float speed = 10.0;\\n \\n vec3 wpos = vec3(0);\\n \\n vec3 pos = camPath(time*speed)*sin(-1.5*KP1);\\n \\n vec3 lookat = camPath(time*speed+2.0);\\n vec3 forward = normalize(lookat-pos);\\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\\n vec3 up = cross(forward,left);\\n \\n float id = vertexId;\\n \\n float numcube = floor(id/18.0);\\n float numquad = floor(id/6.0);\\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\\n float nori = mod(numquad,3.0);\\n //quadid = quadid ^ diri;\\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\\n \\n \\n vec3 mask;\\n if (nori < 0.5) {\\n mask = vec3(1,0,0);\\n } else if (nori < 1.5) {\\n mask = vec3(0,1,0);\\n } else {\\n mask = vec3(0,0,1);\\n }\\n \\n float size = floor(pow(vertexCount/23.0,1.0/3.0)*KP0)*2.;\\n \\n vec3 blockpos = vec3(\\n mod(floor(numcube),size),\\n mod(floor(numcube/size),size),\\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\\n \\n bool a = map(blockpos) > 0.0;\\n bool b = map(blockpos+mask) > 0.0;\\n \\n float diri;\\n \\n if (a == b) {\\n gl_Position = vec4(0,0,0,1);\\n return;\\n } else {\\n \\n float diri = 1.0;\\n if (b) {\\n diri = -diri;\\n quad.xy = quad.yx;\\n }\\n \\n vec3 nor = mask*(diri*2.0-1.0);\\n\\n wpos += mask.zxy*quad.x;\\n wpos += mask.yzx*quad.y;\\n\\twpos += mask;\\n wpos += blockpos;\\n\\n wpos -= 0.5;\\n\\n //wpos += vec3(data.xyz);\\n //wpos += float(gl_VertexID/6);\\n //wpos += u_centerPosition;\\n\\n\\n\\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\\n \\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\\n \\n p.x *= resolution.y/resolution.x;\\n\\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\\n\\n\\n float hue = (id * 1.001);\\n v_color = vec4(nor*0.5+0.5, 1);\\n }\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES \n\n#define KP0 -.50 //KParameter -1.>>1.\n#define KP1 0.50//Kparameter -1.>>1.\n#define KP2 2.0//KParameter 0.>>5.\n\n#define KP3 1.0//KParameter 0.>>0.5\n#define KP4 2.0//KParameter 0.>>2.0\n\n#define PI radians(180.)\n#define SIZE 90.0\n#define NUM_CUBES (SIZE*SIZE*SIZE)\n#define NUM_TRIANGLES (NUM_CUBES*6)\n#define NUM_VERTICES (NUM_TRIANGLES*6)\n#define STEP 80.0\n\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n//https://www.shadertoy.com/view/4ttGDH\nvec3 camPath(float t){\n \n //return vec3(0, 0, t); // Straight path.\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\n \n //float s = sin(t/24.)*cos(t/12.);\n //return vec3(s*12., 0., t);\n \n float a = -sin(t * 0.011);\n float b = cos(t * 0.014);\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\n \n}\n\n//https://www.shadertoy.com/view/4ttGDH\nfloat map(vec3 p){\n \n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\n \n p *= 0.4;\n p = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\n \n \n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\n\n // It's an easy field to create, but not so great to hone in one. The \"1.4\" fudge factor\n // is there to get a little extra distance... Obtained by trial and error.\n return (n - 1.025)*1.33;\n \n}\n\n\nvoid main() {\n \n float speed = 10.0;\n \n vec3 wpos = vec3(0);\n \n vec3 pos = camPath(time*speed)*sin(-1.5*KP1);\n \n vec3 lookat = camPath(time*speed+2.0);\n vec3 forward = normalize(lookat-pos);\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\n vec3 up = cross(forward,left);\n \n float id = vertexId;\n \n float numcube = floor(id/18.0);\n float numquad = floor(id/6.0);\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\n float nori = mod(numquad,3.0);\n //quadid = quadid ^ diri;\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\n \n \n vec3 mask;\n if (nori < 0.5) {\n mask = vec3(1,0,0);\n } else if (nori < 1.5) {\n mask = vec3(0,1,0);\n } else {\n mask = vec3(0,0,1);\n }\n \n float size = floor(pow(vertexCount/23.0,1.0/3.0)*KP0)*2.;\n \n vec3 blockpos = vec3(\n mod(floor(numcube),size),\n mod(floor(numcube/size),size),\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\n \n bool a = map(blockpos) > 0.0;\n bool b = map(blockpos+mask) > 0.0;\n \n float diri;\n \n if (a == b) {\n gl_Position = vec4(0,0,0,1);\n return;\n } else {\n \n float diri = 1.0;\n if (b) {\n diri = -diri;\n quad.xy = quad.yx;\n }\n \n vec3 nor = mask*(diri*2.0-1.0);\n\n wpos += mask.zxy*quad.x;\n wpos += mask.yzx*quad.y;\n\twpos += mask;\n wpos += blockpos;\n\n wpos -= 0.5;\n\n //wpos += vec3(data.xyz);\n //wpos += float(gl_VertexID/6);\n //wpos += u_centerPosition;\n\n\n\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\n \n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\n \n p.x *= resolution.y/resolution.x;\n\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\n\n\n float hue = (id * 1.001);\n v_color = vec4(nor*0.5+0.5, 1);\n }\n}" + }, "screenshotURL": "data/images/images-vzixo7slv71p6ynx8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3hP9SNbDTX5RFMHT5/art.json b/art/3hP9SNbDTX5RFMHT5/art.json index 7485235d..705b52f3 100644 --- a/art/3hP9SNbDTX5RFMHT5/art.json +++ b/art/3hP9SNbDTX5RFMHT5/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mv10", "avatarUrl": "https://secure.gravatar.com/avatar/ae371690b3859dd1515ccf3e9ddc2ec8?default=retro&size=200", - "settings": "{\"num\":65000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// very long playlist:\\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main () {\\n \\n float norm = (vertexId / vertexCount);\\n float x = (norm - 0.5) * 2.0;\\n \\n float freq = norm * 0.2 + 0.004;\\n float y = (texture2D(sound, vec2(freq, 0.0)).a - 0.5);\\n\\n float vol = texture2D(volume, vec2(0.0, 0.0)).a * 2.0;\\n vec3 hsv = vec3(vol, 1.0, 1.0);\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n\\n gl_PointSize = 5.0;\\n\\n}\"}", + "settings": { + "num": 65000, + "mode": "POINTS", + "sound": "https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// very long playlist:\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main () {\n \n float norm = (vertexId / vertexCount);\n float x = (norm - 0.5) * 2.0;\n \n float freq = norm * 0.2 + 0.004;\n float y = (texture2D(sound, vec2(freq, 0.0)).a - 0.5);\n\n float vol = texture2D(volume, vec2(0.0, 0.0)).a * 2.0;\n vec3 hsv = vec3(vol, 1.0, 1.0);\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n\n gl_PointSize = 5.0;\n\n}" + }, "screenshotURL": "data/images/images-outq0ykfqaj8rxtfr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3hY77qyNdTWqMqYPg/art.json b/art/3hY77qyNdTWqMqYPg/art.json index ecc4f7c1..944f9551 100644 --- a/art/3hY77qyNdTWqMqYPg/art.json +++ b/art/3hY77qyNdTWqMqYPg/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/li-yuchun/old-if-not-wild\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *20.0 + 0.7)/30.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/li-yuchun/old-if-not-wild", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *20.0 + 0.7)/30.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\n}" + }, "screenshotURL": "data/images/images-5m1h23qg1e9ha1afe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3hco2ocM6as2y3HNr/art.json b/art/3hco2ocM6as2y3HNr/art.json index 93b10c75..c19e832d 100644 --- a/art/3hco2ocM6as2y3HNr/art.json +++ b/art/3hco2ocM6as2y3HNr/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":24077,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1450980392156863,0.08627450980392157,0.41568627450980394,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float ux = floor(id / 6.) + mod(id,2.);\\n \\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n \\n\\n}\\n\\nvoid main() {\\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2,5.);\\n \\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *- rotZ(time);\\n mat *= trans(vec3(ux,vy,0));\\n mat *= rotZ(snd * 20.0 * sign(ux));\\n mat *= uniformScale(0.02 * sc);\\n \\n vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\\n \\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\\n\\n\\n float pump = step(0.8,snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1;//+ sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1.,pump);\\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\\n\"}", + "settings": { + "num": 24077, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1450980392156863, + 0.08627450980392157, + 0.41568627450980394, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float ux = floor(id / 6.) + mod(id,2.);\n \n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n \n\n}\n\nvoid main() {\n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2,5.);\n \n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *- rotZ(time);\n mat *= trans(vec3(ux,vy,0));\n mat *= rotZ(snd * 20.0 * sign(ux));\n mat *= uniformScale(0.02 * sc);\n \n vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\n \n \n gl_Position = mat * pos;\n\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\n\n\n float pump = step(0.8,snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1;//+ sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1.,pump);\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-mstetf4qm6ysyjhmb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3hzz6KuiDcQDi54iA/art.json b/art/3hzz6KuiDcQDi54iA/art.json index 0e006ae2..6c738c1a 100644 --- a/art/3hzz6KuiDcQDi54iA/art.json +++ b/art/3hzz6KuiDcQDi54iA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.0, 2.0));\\n vec4 K = vec4(1.0, 4.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 2); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nvec3 triangle(float idx) // vec2:p / float triangleIndex\\n{\\n\\tfloat triangleIndex = floor(idx / 16.);\\n\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 p = vec2(0);\\n\\t\\n\\tif (index == 0.) p = vec2(0,1);\\n\\tif (index == 1.) p = vec2(1,0);\\n\\tif (index == 2.) p = vec2(0,0);\\n\\t\\n\\tif (index == 3.) p = vec2(0,0);\\n\\tif (index == 4.) p = vec2(1,1);\\n\\tif (index == 5.) p = vec2(0,1);\\n\\t\\n\\treturn vec3(p, triangleIndex);\\n}\\n\\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\\n{\\n\\tvec4 res;\\n\\tvec3 pi = triangle(idx);\\n\\t\\n\\tpi.y += floor(pi.z / countQuadsX);\\n pi.x += mod(pi.z, countQuadsX);\\n \\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadsX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\t\\n\\tif (centered == true)\\n\\t{\\n\\t\\tpi.x -= nx * 0.5;\\n\\t\\tpi.y -= ny * 0.5;\\n\\t}\\n\\t\\n\\treturn vec4(pi.xy, nx, ny);\\n}\\n\\n//https://www.shadertoy.com/view/ltK3WD\\nvec4 voronoi(vec2 g )\\n{\\n\\tvec4 f = vec4(9);\\n\\tvec2 p = g /= 200. ; f.x=9.;\\n \\n\\tg += time;\\n\\t\\n float t = time * 0.1;\\n \\n for(int x=-2;x<=2;x++)\\n for(int y=-2;y<=2;y++)\\n {\\t\\n p = vec2(x,y);\\n\\t\\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\\n\\t\\t//f.y = max(abs(p.x), abs(p.y));\\n\\t\\t//f.y = dot(p,p);\\n\\t\\tif (f.y < f.x)\\n {\\n f.x = f.y;\\n f.zw = p;\\n }\\n }\\n\\t\\n vec3 n = vec3(0);\\n \\n if ( f.x == -f.z*.866 * f.w*0.61) \\tn = vec3(1,0,0);\\n\\tif ( f.y== f.z*.866 * tan(f.w*1.5)) vec3(1,1,0);\\n\\tif ( f.x == f.w) \\t\\t\\t\\t\\tn = vec3(1,0,1);\\n\\t\\n return vec4(f.x, n);\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 2.;\\n\\t\\n \\tvec3 uSlider = vec3(50, 5, 1.2);\\n \\n\\tfloat thickNess = uSlider.x;\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat sizeEdge = floor(sqrt(countMax));\\n\\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\\n\\t\\n\\tvec4 voro = voronoi(p.xy * uSlider.y);\\n\\t\\n\\tfloat d = voro.x;\\n\\tvec3 n = voro.yzw;\\n\\t\\n\\tv_color = vec4(n*d,2.-n);\\n\\n\\tmat4 camera = ident();\\n\\t\\n\\tfloat ca = time * 0.1;\\n\\tfloat cd = 160.;\\n\\tfloat ce = PI * mouse.y;\\n\\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(1, 1, 0);\\n \\n\\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.31, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.0, 2.0));\n vec4 K = vec4(1.0, 4.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 2); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nvec3 triangle(float idx) // vec2:p / float triangleIndex\n{\n\tfloat triangleIndex = floor(idx / 16.);\n\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 p = vec2(0);\n\t\n\tif (index == 0.) p = vec2(0,1);\n\tif (index == 1.) p = vec2(1,0);\n\tif (index == 2.) p = vec2(0,0);\n\t\n\tif (index == 3.) p = vec2(0,0);\n\tif (index == 4.) p = vec2(1,1);\n\tif (index == 5.) p = vec2(0,1);\n\t\n\treturn vec3(p, triangleIndex);\n}\n\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\n{\n\tvec4 res;\n\tvec3 pi = triangle(idx);\n\t\n\tpi.y += floor(pi.z / countQuadsX);\n pi.x += mod(pi.z, countQuadsX);\n \n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadsX;\n\tfloat ny = floor(countQuads / nx);\n\t\t\n\tif (centered == true)\n\t{\n\t\tpi.x -= nx * 0.5;\n\t\tpi.y -= ny * 0.5;\n\t}\n\t\n\treturn vec4(pi.xy, nx, ny);\n}\n\n//https://www.shadertoy.com/view/ltK3WD\nvec4 voronoi(vec2 g )\n{\n\tvec4 f = vec4(9);\n\tvec2 p = g /= 200. ; f.x=9.;\n \n\tg += time;\n\t\n float t = time * 0.1;\n \n for(int x=-2;x<=2;x++)\n for(int y=-2;y<=2;y++)\n {\t\n p = vec2(x,y);\n\t\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\n\t\t//f.y = max(abs(p.x), abs(p.y));\n\t\t//f.y = dot(p,p);\n\t\tif (f.y < f.x)\n {\n f.x = f.y;\n f.zw = p;\n }\n }\n\t\n vec3 n = vec3(0);\n \n if ( f.x == -f.z*.866 * f.w*0.61) \tn = vec3(1,0,0);\n\tif ( f.y== f.z*.866 * tan(f.w*1.5)) vec3(1,1,0);\n\tif ( f.x == f.w) \t\t\t\t\tn = vec3(1,0,1);\n\t\n return vec4(f.x, n);\n}\n\nvoid main()\n{\n\tgl_PointSize = 2.;\n\t\n \tvec3 uSlider = vec3(50, 5, 1.2);\n \n\tfloat thickNess = uSlider.x;\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat sizeEdge = floor(sqrt(countMax));\n\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\n\t\n\tvec4 voro = voronoi(p.xy * uSlider.y);\n\t\n\tfloat d = voro.x;\n\tvec3 n = voro.yzw;\n\t\n\tv_color = vec4(n*d,2.-n);\n\n\tmat4 camera = ident();\n\t\n\tfloat ca = time * 0.1;\n\tfloat cd = 160.;\n\tfloat ce = PI * mouse.y;\n\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(1, 1, 0);\n \n\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.31, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\n}" + }, "screenshotURL": "data/images/images-5mjsqkl8z4xhsajcx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3icxEpds8WvgPmHy7/art.json b/art/3icxEpds8WvgPmHy7/art.json index bd3a086b..10ffb8f9 100644 --- a/art/3icxEpds8WvgPmHy7/art.json +++ b/art/3icxEpds8WvgPmHy7/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":13959,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.137;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.13 * cgv + snd * .125);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n\\n \\n float pump = step(.5, snd);\\n float hue = 1.- cgId * 1. + pump * .75;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\\n v_color.rgb *= v_color.a;\\n \\n gl_Position = mat * vec4(pos, .25);\\n gl_PointSize = 2. + hue * 2.;\\n}\\n\\n\"}", + "settings": { + "num": 13959, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.137;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.13 * cgv + snd * .125);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n\n \n float pump = step(.5, snd);\n float hue = 1.- cgId * 1. + pump * .75;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\n v_color.rgb *= v_color.a;\n \n gl_Position = mat * vec4(pos, .25);\n gl_PointSize = 2. + hue * 2.;\n}\n\n" + }, "screenshotURL": "data/images/images-99x8e1vmxjbqq3xyf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3ii5FCaXjgCQLG3Xd/art.json b/art/3ii5FCaXjgCQLG3Xd/art.json index bf1ce7c8..6c354ef8 100644 --- a/art/3ii5FCaXjgCQLG3Xd/art.json +++ b/art/3ii5FCaXjgCQLG3Xd/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jpaquim", "avatarUrl": "https://secure.gravatar.com/avatar/374b09dacab582ca17818a391b59a214?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jpaquim/synth-jam-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\n#define PI radians(180.)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n // float xoff = sin(time + y * .2) * .1;\\n float yoff = 0.;\\n // float yoff = sin(time + x * .3) * .2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;\\n // float soff = sin(time + x * y * .02) * 5.;\\n \\n gl_PointSize = pow(snd + .2, 5.) * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(.8, snd);\\n // float hue = 1.;\\n // float hue = u * .1 + sin(time + v * 20.) * .05;\\n float hue = u * .1 + snd * .2 + time * .1;\\n // float sat = 1.;\\n // float sat = 1. - av;\\n // float sat = mix(1., -10., av);\\n float sat = mix(0., 1., pump);\\n // float val = 1.;\\n // float val = sin(time + u * v * 20.) * .5 + .5;\\n // float val = pow(snd + .2, 5.);\\n float val = mix(.1, pow(snd + .2, 5.), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/jpaquim/synth-jam-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\n#define PI radians(180.)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n // float xoff = sin(time + y * .2) * .1;\n float yoff = 0.;\n // float yoff = sin(time + x * .3) * .2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;\n // float soff = sin(time + x * y * .02) * 5.;\n \n gl_PointSize = pow(snd + .2, 5.) * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(.8, snd);\n // float hue = 1.;\n // float hue = u * .1 + sin(time + v * 20.) * .05;\n float hue = u * .1 + snd * .2 + time * .1;\n // float sat = 1.;\n // float sat = 1. - av;\n // float sat = mix(1., -10., av);\n float sat = mix(0., 1., pump);\n // float val = 1.;\n // float val = sin(time + u * v * 20.) * .5 + .5;\n // float val = pow(snd + .2, 5.);\n float val = mix(.1, pow(snd + .2, 5.), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-q2k1f5vmicqiplxev-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3jq8W6M8gtjRfjRzj/art.json b/art/3jq8W6M8gtjRfjRzj/art.json index a73c0a42..4af615a6 100644 --- a/art/3jq8W6M8gtjRfjRzj/art.json +++ b/art/3jq8W6M8gtjRfjRzj/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "b", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocJS7WEoMqD34s3VOChzOHu7MbbJ8ICzz_MDonG7qEDH=s96-c", - "settings": "{\"num\":49,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.07058823529411765,0.07058823529411765,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define PI radians(180.)\\n\\n#define NN 32.0\\n\\n#define NP 8.0 \\n#define NSEG (vertexCount) \\n//5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nvoid main() {\\n\\n float segCount = vertexCount / NP;\\n \\n float c0 = 0.25+(mod(vertexId, NP)/(NP));\\n float count = mod(vertexId, NP);\\n float point = 0.0;\\n float ratio = 1.0;\\n \\n float t0 = mod( vertexId, NP);\\n float t1 = mod(vertexId, 16.0);\\n \\n float u = floor(vertexId);\\n float m0 = (mod(vertexId, vertexCount)-(t0))*0.25;\\n float m1 = mod(m0, vertexCount);\\n \\n mat4 pr = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0);\\n \\n gl_Position = pr*(vec4(count, \\n m0, \\n mod(m1,NN), \\n 1.)+vec4(0.,0.,-50.,0.) );\\n \\n gl_PointSize = 5.0;\\n \\n v_color = vec4(c0, 1.0, 0.0, 0.);\\n \\n \\n}\"}", + "settings": { + "num": 49, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.07058823529411765, + 0.07058823529411765, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define PI radians(180.)\n\n#define NN 32.0\n\n#define NP 8.0 \n#define NSEG (vertexCount) \n//5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nvoid main() {\n\n float segCount = vertexCount / NP;\n \n float c0 = 0.25+(mod(vertexId, NP)/(NP));\n float count = mod(vertexId, NP);\n float point = 0.0;\n float ratio = 1.0;\n \n float t0 = mod( vertexId, NP);\n float t1 = mod(vertexId, 16.0);\n \n float u = floor(vertexId);\n float m0 = (mod(vertexId, vertexCount)-(t0))*0.25;\n float m1 = mod(m0, vertexCount);\n \n mat4 pr = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0);\n \n gl_Position = pr*(vec4(count, \n m0, \n mod(m1,NN), \n 1.)+vec4(0.,0.,-50.,0.) );\n \n gl_PointSize = 5.0;\n \n v_color = vec4(c0, 1.0, 0.0, 0.);\n \n \n}" + }, "screenshotURL": "data/images/images-dowu4hd9dmt3kiyk7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3kAd76mhEav7qtrh3/art.json b/art/3kAd76mhEav7qtrh3/art.json index 8839d85e..c855682f 100644 --- a/art/3kAd76mhEav7qtrh3/art.json +++ b/art/3kAd76mhEav7qtrh3/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nmat4 persp (float fov, float aspect, float zNear, float zFar)\\n{\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n \\n return mat4(\\n \\tf / aspect, 0, 0, 0,\\n \\t0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n \\t0, 0, zNear * zFar * rangeInv * 2.0, 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n zAxis, 0,\\n xAxis, 0,\\n yAxis, 0,\\n eye , 2\\n );\\n}\\n\\nvec3 pos_point[8];\\nvec3 colors[8];\\nvoid drow_point()\\n{\\n pos_point[0] = vec3(-.5, -.5, .0);\\n pos_point[1] = vec3(-.5 , .5, .0);\\n pos_point[2] = vec3(.5 , -.5, .0);\\n pos_point[3] = vec3(.5 , .5, .0);\\n pos_point[4] = vec3(.5 , -.5, .5);\\n pos_point[5] = vec3(.5 , .5, .5);\\n pos_point[6] = vec3(-.5, -.5, .0);\\n pos_point[7] = vec3(-.5 , .5, .0);\\n \\n colors[0] = vec3(1, 0, 0);\\n colors[1] = vec3(1, 0, 0);\\n colors[2] = vec3(0, 0, 1);\\n colors[3] = vec3(0, 0, 1);\\n colors[4] = vec3(1, 1, 1);\\n colors[5] = vec3(1, 1, 1);\\n colors[6] = vec3(0.2, 1, 0);\\n colors[7] = vec3(0.2, 1, 0);\\n}\\n\\nvoid main() {\\n drow_point();\\n int VD = int(vertexId);\\n vec2 m = mouse;\\n \\n float ct = time *0.3;\\n vec3 p = vec3(0, 0, -1.);\\n vec3 t = vec3(m.x*5., m.y*5., 1.);\\n vec3 u = vec3(0, 1, 0);\\n\\n for( int i=0; i<8; i++)\\n {\\n if(VD == i)\\n {\\n mat4 m = persp(radians(100.), resolution.x / resolution.y, 0.1, 100.);\\n m *= lookAt(p, t, u);\\n gl_Position = m * vec4(pos_point[i], 1);\\n gl_PointSize = 20.;\\n v_color = vec4(colors[i], 1.0);\\n }\\n }\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nmat4 persp (float fov, float aspect, float zNear, float zFar)\n{\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n \n return mat4(\n \tf / aspect, 0, 0, 0,\n \t0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n \t0, 0, zNear * zFar * rangeInv * 2.0, 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\n{\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n \n return mat4(\n zAxis, 0,\n xAxis, 0,\n yAxis, 0,\n eye , 2\n );\n}\n\nvec3 pos_point[8];\nvec3 colors[8];\nvoid drow_point()\n{\n pos_point[0] = vec3(-.5, -.5, .0);\n pos_point[1] = vec3(-.5 , .5, .0);\n pos_point[2] = vec3(.5 , -.5, .0);\n pos_point[3] = vec3(.5 , .5, .0);\n pos_point[4] = vec3(.5 , -.5, .5);\n pos_point[5] = vec3(.5 , .5, .5);\n pos_point[6] = vec3(-.5, -.5, .0);\n pos_point[7] = vec3(-.5 , .5, .0);\n \n colors[0] = vec3(1, 0, 0);\n colors[1] = vec3(1, 0, 0);\n colors[2] = vec3(0, 0, 1);\n colors[3] = vec3(0, 0, 1);\n colors[4] = vec3(1, 1, 1);\n colors[5] = vec3(1, 1, 1);\n colors[6] = vec3(0.2, 1, 0);\n colors[7] = vec3(0.2, 1, 0);\n}\n\nvoid main() {\n drow_point();\n int VD = int(vertexId);\n vec2 m = mouse;\n \n float ct = time *0.3;\n vec3 p = vec3(0, 0, -1.);\n vec3 t = vec3(m.x*5., m.y*5., 1.);\n vec3 u = vec3(0, 1, 0);\n\n for( int i=0; i<8; i++)\n {\n if(VD == i)\n {\n mat4 m = persp(radians(100.), resolution.x / resolution.y, 0.1, 100.);\n m *= lookAt(p, t, u);\n gl_Position = m * vec4(pos_point[i], 1);\n gl_PointSize = 20.;\n v_color = vec4(colors[i], 1.0);\n }\n }\n}" + }, "screenshotURL": "data/images/images-d0s8k3nsbbw5x9ewe-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3mX3aBsuhf372pLcD/art.json b/art/3mX3aBsuhf372pLcD/art.json index 4a9c6de4..cb227c75 100644 --- a/art/3mX3aBsuhf372pLcD/art.json +++ b/art/3mX3aBsuhf372pLcD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":16688,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter 1.>>3.\\n#define parameter1 3.//KParameter 0.1>>3.\\n#define parameter2 1.//KParameter -1.>>1.\\n#define parameter3 -0.1//KParameter -0.5>2.\\n#define parameter4 1.3//KParameter 0.5>>2.\\n#define parameter5 1.//KParameter 0.>>3.\\n#define parameter6 1.//KParameter 0.>>1.\\n#define parameter7 1.//KParameter 0.>>1.\\n#define PI radians(120.)\\n//KVerticesNumber=16666\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /72. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 16688, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter 1.>>3.\n#define parameter1 3.//KParameter 0.1>>3.\n#define parameter2 1.//KParameter -1.>>1.\n#define parameter3 -0.1//KParameter -0.5>2.\n#define parameter4 1.3//KParameter 0.5>>2.\n#define parameter5 1.//KParameter 0.>>3.\n#define parameter6 1.//KParameter 0.>>1.\n#define parameter7 1.//KParameter 0.>>1.\n#define PI radians(120.)\n//KVerticesNumber=16666\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /72. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-v7vfvhlhv7e8q10pv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3oRDhfqRydMBEWnD5/art.json b/art/3oRDhfqRydMBEWnD5/art.json index 8026c62b..fb2b4e71 100644 --- a/art/3oRDhfqRydMBEWnD5/art.json +++ b/art/3oRDhfqRydMBEWnD5/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/globalliquidity/until-that-time\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * ((snd * 0.5) * abs(sin(time *4.5)));\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= -rotateX;\\n p1.position.xz *= -rotateY;\\n p1.position.xy *= -rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/globalliquidity/until-that-time", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * ((snd * 0.5) * abs(sin(time *4.5)));\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= -rotateX;\n p1.position.xz *= -rotateY;\n p1.position.xy *= -rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-0jajj1pmmtcrwr8fw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3pFLZ6LMxGuHYkjcr/art.json b/art/3pFLZ6LMxGuHYkjcr/art.json index 2913a586..19f8ecb0 100644 --- a/art/3pFLZ6LMxGuHYkjcr/art.json +++ b/art/3pFLZ6LMxGuHYkjcr/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":99999,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 7.0\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.1492;\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5;\\n float l = length(posf)*1.45;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float t = time*.10;\\n float i = vertexId+sin(vertexId)*0.10;\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *= 1.;\\n pos.z += 0.7;\\n pos.xy *= 0.6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1.0/pos.z* 0.1;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\\n}\"}", + "settings": { + "num": 99999, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 7.0\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.1492;\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5;\n float l = length(posf)*1.45;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float t = time*.10;\n float i = vertexId+sin(vertexId)*0.10;\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *= 1.;\n pos.z += 0.7;\n pos.xy *= 0.6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1.0/pos.z* 0.1;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\n}" + }, "screenshotURL": "data/images/images-vhmx06rbjk6ibkqhb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3r5fh3ut8gnwF69zs/art.json b/art/3r5fh3ut8gnwF69zs/art.json index 02743fa8..ac318ed5 100644 --- a/art/3r5fh3ut8gnwF69zs/art.json +++ b/art/3r5fh3ut8gnwF69zs/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Vertexshaderart : Colors\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(abs(ux+hue), abs(vy+sat), val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Vertexshaderart : Colors\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(abs(ux+hue), abs(vy+sat), val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-05ub5382o1ix7a5m9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3rTF3aQTLfnSdwdcW/art.json b/art/3rTF3aQTLfnSdwdcW/art.json index 1fe75816..19bb414a 100644 --- a/art/3rTF3aQTLfnSdwdcW/art.json +++ b/art/3rTF3aQTLfnSdwdcW/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main(){\\n float across = 10.;\\n \\n float x = mod(vertexId, across );\\n float y = floor(vertexId / across);\\n \\n float u = x / (across -1.);\\n float v = y / (across -1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main(){\n float across = 10.;\n \n float x = mod(vertexId, across );\n float y = floor(vertexId / across);\n \n float u = x / (across -1.);\n float v = y / (across -1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n \n \n}" + }, "screenshotURL": "data/images/images-ispm3g99fustxhn9h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3tnqndpH4hacfPTBd/art.json b/art/3tnqndpH4hacfPTBd/art.json index 1b83092e..24ff75e4 100644 --- a/art/3tnqndpH4hacfPTBd/art.json +++ b/art/3tnqndpH4hacfPTBd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Vertexshaderart : Making a Grid\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n ux *= sin(ux + time) * 1.6;\\n vy *= abs(sin(vy + time)) *3.0;\\n\\n\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across; \\n gl_PointSize *= resolution.x / 600.;\\n gl_PointSize *= abs(sin(time)) * 2. +0.5;\\n\\n v_color = vec4(abs(sin(time)),0.5,sin(time),1); \\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Vertexshaderart : Making a Grid\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n ux *= sin(ux + time) * 1.6;\n vy *= abs(sin(vy + time)) *3.0;\n\n\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across; \n gl_PointSize *= resolution.x / 600.;\n gl_PointSize *= abs(sin(time)) * 2. +0.5;\n\n v_color = vec4(abs(sin(time)),0.5,sin(time),1); \n \n \n}" + }, "screenshotURL": "data/images/images-d9nxy2tnndobgaftg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/3uB76AAsdqqC2ZEXk/art.json b/art/3uB76AAsdqqC2ZEXk/art.json index c545628c..9ca84a43 100644 --- a/art/3uB76AAsdqqC2ZEXk/art.json +++ b/art/3uB76AAsdqqC2ZEXk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mats", "avatarUrl": "https://lh3.googleusercontent.com/-oRuhWa2k-Mg/AAAAAAAAAAI/AAAAAAAABAM/VJyYs7ET7R4/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16384, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-3z038y6hm8i58nzze-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3uH92F2f4pCxBydB3/art.json b/art/3uH92F2f4pCxBydB3/art.json index e5bc9e79..329d40ff 100644 --- a/art/3uH92F2f4pCxBydB3/art.json +++ b/art/3uH92F2f4pCxBydB3/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":37863,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kemono/hawaiian-hula-blues\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.1568627450980392,0.9372549019607843,0.34901960784313724,1],\"shader\":\"// ,---. ,---. .-''-. .-------. ,---------. .-''-. _____ __ .-'''-. .---. .---. ____ ______ .-''-. .-------. ____ .-------. ,---------. \\n// | / | | .'_ _ \\\\ | _ _ \\\\\\\\ \\\\ .'_ _ \\\\ \\\\ _\\\\ / / / _ \\\\| | |_ _| .' __ `. | _ `''. .'_ _ \\\\ | _ _ \\\\ .' __ `. | _ _ \\\\\\\\ \\\\ \\n// | | | .'/ ( ` ) '| ( ' ) | `--. ,---'/ ( ` ) ' .-./ ). / ' (`' )/`--'| | ( ' ) / ' \\\\ \\\\| _ | ) _ \\\\ / ( ` ) '| ( ' ) | / ' \\\\ \\\\| ( ' ) | `--. ,---' \\n// | | _ | |. (_ o _) ||(_ o _) / | \\\\ . (_ o _) | \\\\ '_ .') .' (_ o _). | '-(_{;}_)|___| / ||( ''_' ) |. (_ o _) ||(_ o _) / |___| / ||(_ o _) / | \\\\ \\n// | _( )_ || (_,_)___|| (_,_).' __ :_ _: | (_,_)___|(_ (_) _) ' (_,_). '. | (_,_) _.-` || . (_) `. || (_,_)___|| (_,_).' __ _.-` || (_,_).' __ :_ _: \\n// \\\\ (_ o._) /' \\\\ .---.| |\\\\ \\\\ | | (_I_) ' \\\\ .---. / \\\\ \\\\ .---. \\\\ :| _ _--. | .' _ ||(_ ._) '' \\\\ .---.| |\\\\ \\\\ | |.' _ || |\\\\ \\\\ | | (_I_) \\n// \\\\ (_,_) / \\\\ `-' /| | \\\\ `' /(_(=)_) \\\\ `-' / `-'`-' \\\\\\\\ `-' ||( ' ) | | | _( )_ || (_.\\\\.' / \\\\ `-' /| | \\\\ `' /| _( )_ || | \\\\ `' /(_(=)_) \\n// \\\\ / \\\\ / | | \\\\ / (_I_) \\\\ / / / \\\\ \\\\\\\\ / (_{;}_)| | \\\\ (_ o _) /| .' \\\\ / | | \\\\ / \\\\ (_ o _) /| | \\\\ / (_I_) \\n// `---` `'-..-' ''-' `'-' '---' `'-..-' '--' '----'`-...-' '(_,_) '---' '.(_,_).' '-----'` `'-..-' ''-' `'-' '.(_,_).' ''-' `'-' '---' \\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_PETAL 19.\\n#define NUM_POINTS_PER_PETAL ((NUM_EDGE_POINTS_PER_PETAL - 1.) * 3.) \\nvoid getPetalPoint(const float flowerId, const float id, out vec3 pos, out float center) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n center = step(0.5, mod(id, 3.));\\n float u = outId / (NUM_EDGE_POINTS_PER_PETAL - 1.);\\n float a = u * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = s * 0.3;\\n float y = c - 1.;\\n float z = u;\\n pos = vec3(x, y, z) * center + vec3(0, mix(-2.0, 1.0, hash(flowerId * 0.33)) * inv(center), 0);\\n \\n}\\n\\n#define NUM_PETALS_PER_FLOWER 5.\\n#define NUM_POINTS_PER_FLOWER (NUM_POINTS_PER_PETAL * NUM_PETALS_PER_FLOWER)\\nvoid getFlowerPoint(const float flowerId, const float id, out vec3 pos, out float center) {\\n float petalId = floor(id / NUM_POINTS_PER_PETAL);\\n float pointId = mod(id, NUM_POINTS_PER_PETAL);\\n vec3 petalPos;\\n getPetalPoint(flowerId, pointId, petalPos, center);\\n mat4 mat = rotZ(petalId / NUM_PETALS_PER_FLOWER * PI * 2.);\\n pos = (mat * vec4(petalPos, 1)).xyz;\\n}\\n\\nvoid main() {\\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 0.0001);\\n float id = vertexId;\\n float numFlowers = floor(vertexCount / NUM_POINTS_PER_FLOWER);\\n float flowerId = floor(vertexId / NUM_POINTS_PER_FLOWER);// + floor(time * 100.);\\n float sOff = 0.0;\\n float sSpread = 0.01;\\n const int numSamples = 5;\\n float snd = 0.;\\n for (int i = 0; i < numSamples; ++i) {\\n vec2 uv = vec2(flowerId / numFlowers * 0.25, sOff + sSpread * float(i));\\n snd += texture2D(sound, uv).a * float(numSamples - i);\\n }\\n snd /= float(numSamples * (numSamples + 1)) / 2.5;\\n vec3 offset = vec3(m1p1(hash(flowerId)) / aspect.x, m1p1(hash(flowerId * 1.37)), -m1p1(flowerId / 10.));\\n vec3 pos;\\n float center;\\n getFlowerPoint(flowerId, id, pos, center);\\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= rotZ(time * mix(-1., 1., hash(flowerId * 1.54)));\\n mat *= uniformScale(mix(0.1, 0.2, hash(flowerId)) + pow(snd, 5.0) * 0.1);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n \\n\\n float hue = mix(-0.2, 0.2, fract(time * 0.1 + flowerId * 0.13 + center * 0.1));\\n float sat = mix(.4, .7, hash(flowerId * 0.7));\\n float val = mix(mix(0.5, 1.0, hash(flowerId * 0.27)), 0.0, center * inv(hash(flowerId * 0.73)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.0 + pow(snd + 0.3, 5.0));\\n v_color = vec4(v_color.xyz * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 37863, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kemono/hawaiian-hula-blues", + "lineSize": "CSS", + "backgroundColor": [ + 0.1568627450980392, + 0.9372549019607843, + 0.34901960784313724, + 1 + ], + "shader": "// ,---. ,---. .-''-. .-------. ,---------. .-''-. _____ __ .-'''-. .---. .---. ____ ______ .-''-. .-------. ____ .-------. ,---------. \n// | / | | .'_ _ \\ | _ _ \\\\ \\ .'_ _ \\ \\ _\\ / / / _ \\| | |_ _| .' __ `. | _ `''. .'_ _ \\ | _ _ \\ .' __ `. | _ _ \\\\ \\ \n// | | | .'/ ( ` ) '| ( ' ) | `--. ,---'/ ( ` ) ' .-./ ). / ' (`' )/`--'| | ( ' ) / ' \\ \\| _ | ) _ \\ / ( ` ) '| ( ' ) | / ' \\ \\| ( ' ) | `--. ,---' \n// | | _ | |. (_ o _) ||(_ o _) / | \\ . (_ o _) | \\ '_ .') .' (_ o _). | '-(_{;}_)|___| / ||( ''_' ) |. (_ o _) ||(_ o _) / |___| / ||(_ o _) / | \\ \n// | _( )_ || (_,_)___|| (_,_).' __ :_ _: | (_,_)___|(_ (_) _) ' (_,_). '. | (_,_) _.-` || . (_) `. || (_,_)___|| (_,_).' __ _.-` || (_,_).' __ :_ _: \n// \\ (_ o._) /' \\ .---.| |\\ \\ | | (_I_) ' \\ .---. / \\ \\ .---. \\ :| _ _--. | .' _ ||(_ ._) '' \\ .---.| |\\ \\ | |.' _ || |\\ \\ | | (_I_) \n// \\ (_,_) / \\ `-' /| | \\ `' /(_(=)_) \\ `-' / `-'`-' \\\\ `-' ||( ' ) | | | _( )_ || (_.\\.' / \\ `-' /| | \\ `' /| _( )_ || | \\ `' /(_(=)_) \n// \\ / \\ / | | \\ / (_I_) \\ / / / \\ \\\\ / (_{;}_)| | \\ (_ o _) /| .' \\ / | | \\ / \\ (_ o _) /| | \\ / (_I_) \n// `---` `'-..-' ''-' `'-' '---' `'-..-' '--' '----'`-...-' '(_,_) '---' '.(_,_).' '-----'` `'-..-' ''-' `'-' '.(_,_).' ''-' `'-' '---' \n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_PETAL 19.\n#define NUM_POINTS_PER_PETAL ((NUM_EDGE_POINTS_PER_PETAL - 1.) * 3.) \nvoid getPetalPoint(const float flowerId, const float id, out vec3 pos, out float center) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n center = step(0.5, mod(id, 3.));\n float u = outId / (NUM_EDGE_POINTS_PER_PETAL - 1.);\n float a = u * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = s * 0.3;\n float y = c - 1.;\n float z = u;\n pos = vec3(x, y, z) * center + vec3(0, mix(-2.0, 1.0, hash(flowerId * 0.33)) * inv(center), 0);\n \n}\n\n#define NUM_PETALS_PER_FLOWER 5.\n#define NUM_POINTS_PER_FLOWER (NUM_POINTS_PER_PETAL * NUM_PETALS_PER_FLOWER)\nvoid getFlowerPoint(const float flowerId, const float id, out vec3 pos, out float center) {\n float petalId = floor(id / NUM_POINTS_PER_PETAL);\n float pointId = mod(id, NUM_POINTS_PER_PETAL);\n vec3 petalPos;\n getPetalPoint(flowerId, pointId, petalPos, center);\n mat4 mat = rotZ(petalId / NUM_PETALS_PER_FLOWER * PI * 2.);\n pos = (mat * vec4(petalPos, 1)).xyz;\n}\n\nvoid main() {\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 0.0001);\n float id = vertexId;\n float numFlowers = floor(vertexCount / NUM_POINTS_PER_FLOWER);\n float flowerId = floor(vertexId / NUM_POINTS_PER_FLOWER);// + floor(time * 100.);\n float sOff = 0.0;\n float sSpread = 0.01;\n const int numSamples = 5;\n float snd = 0.;\n for (int i = 0; i < numSamples; ++i) {\n vec2 uv = vec2(flowerId / numFlowers * 0.25, sOff + sSpread * float(i));\n snd += texture2D(sound, uv).a * float(numSamples - i);\n }\n snd /= float(numSamples * (numSamples + 1)) / 2.5;\n vec3 offset = vec3(m1p1(hash(flowerId)) / aspect.x, m1p1(hash(flowerId * 1.37)), -m1p1(flowerId / 10.));\n vec3 pos;\n float center;\n getFlowerPoint(flowerId, id, pos, center);\n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= rotZ(time * mix(-1., 1., hash(flowerId * 1.54)));\n mat *= uniformScale(mix(0.1, 0.2, hash(flowerId)) + pow(snd, 5.0) * 0.1);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n \n\n float hue = mix(-0.2, 0.2, fract(time * 0.1 + flowerId * 0.13 + center * 0.1));\n float sat = mix(.4, .7, hash(flowerId * 0.7));\n float val = mix(mix(0.5, 1.0, hash(flowerId * 0.27)), 0.0, center * inv(hash(flowerId * 0.73)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.0 + pow(snd + 0.3, 5.0));\n v_color = vec4(v_color.xyz * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-g98mqi3h4mez1wgeo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3uY49x2aXTxXCB2PD/art.json b/art/3uY49x2aXTxXCB2PD/art.json index a17efbc4..ea282116 100644 --- a/art/3uY49x2aXTxXCB2PD/art.json +++ b/art/3uY49x2aXTxXCB2PD/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":600,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wearebigbeat/flo-rida-my-house-jameston-thieves-arkn-remix?in=austin24heck/sets/trap-remixes-of-popular-songs\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Audio Reactive\\n// CS250 \\n// Spring/2022\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / (PI);\\n float av = length(vec2(su, sv));\\n \\n vec4 soundVal = texture2D(sound, vec2(au * 0.05, av * .25));\\n \\n \\n float snd = soundVal.a;\\n\\n float xoff = sin(time*snd*1.5 + y * 0.2) * 0.015;\\n float yoff = sin(time*snd*1.5 + x * 0.3) * 0.02;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0., 2.5*snd);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.1, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\\n}\\n\"}", + "settings": { + "num": 600, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wearebigbeat/flo-rida-my-house-jameston-thieves-arkn-remix?in=austin24heck/sets/trap-remixes-of-popular-songs", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Audio Reactive\n// CS250 \n// Spring/2022\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / (PI);\n float av = length(vec2(su, sv));\n \n vec4 soundVal = texture2D(sound, vec2(au * 0.05, av * .25));\n \n \n float snd = soundVal.a;\n\n float xoff = sin(time*snd*1.5 + y * 0.2) * 0.015;\n float yoff = sin(time*snd*1.5 + x * 0.3) * 0.02;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0., 2.5*snd);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.1, snd);\n \n float hue = u * .1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\n}\n" + }, "screenshotURL": "data/images/images-z4acz8003qyl5giod-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3uytcwyYXxGeEvu4D/art.json b/art/3uytcwyYXxGeEvu4D/art.json index 043554d2..bbf7c850 100644 --- a/art/3uytcwyYXxGeEvu4D/art.json +++ b/art/3uytcwyYXxGeEvu4D/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 12.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 12.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-sk5xcu1tr96n4mhst-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3vqtTygKuowBwMvu4/art.json b/art/3vqtTygKuowBwMvu4/art.json index 634b0404..4201b6fb 100644 --- a/art/3vqtTygKuowBwMvu4/art.json +++ b/art/3vqtTygKuowBwMvu4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 50\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\\n \\n\\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n vec2 p = vec2(ux , vy);\\n //float z = fract(0.86);\\n float z = fract(1.2*snd);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n //p.x+=fract(time);\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n\\n\\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n\\n \\n gl_Position = vec4(vy, ux, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.4;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 50\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\n \n\n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n vec2 p = vec2(ux , vy);\n //float z = fract(0.86);\n float z = fract(1.2*snd);\n int a = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n //p.x+=fract(time);\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n\n\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n\n \n gl_Position = vec4(vy, ux, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.4;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-x2852l27ox69kv18e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/3yMooDSsPRwxpbiuL/art.json b/art/3yMooDSsPRwxpbiuL/art.json index 52983c5c..b2bf58cc 100644 --- a/art/3yMooDSsPRwxpbiuL/art.json +++ b/art/3yMooDSsPRwxpbiuL/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":2986,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.07058823529411765,0.07058823529411765,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Motion exercise\\n//2022 spring\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = floor(sin(time + y * 0.2) * 0.1);\\n float yoff = sin(time + x * 0.3) * 0.2 ;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux +0.5, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time+x*y*0.02) * 5.;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float timeV = sin(time);\\n \\n \\n \\t v_color = vec4(1,sin(time),cos(time),1);\\n \\n}\\n\\n\"}", + "settings": { + "num": 2986, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.07058823529411765, + 0.07058823529411765, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Motion exercise\n//2022 spring\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = floor(sin(time + y * 0.2) * 0.1);\n float yoff = sin(time + x * 0.3) * 0.2 ;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux +0.5, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time+x*y*0.02) * 5.;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float timeV = sin(time);\n \n \n \t v_color = vec4(1,sin(time),cos(time),1);\n \n}\n\n" + }, "screenshotURL": "data/images/images-21t50hwxte569nf71-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/42ESv42tR52CEdX63/art.json b/art/42ESv42tR52CEdX63/art.json index ad522971..98028d52 100644 --- a/art/42ESv42tR52CEdX63/art.json +++ b/art/42ESv42tR52CEdX63/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "targ", "username": "gman", - "settings": "{\"num\":6000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.6980392156862745,0.09019607843137255,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 20.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float snd = texture2D(floatSound, vec2(count / 10000.0, 0)).a; \\n float radius = pow(count * 0.014, 1.0) + snd * 0.03;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = clamp(40.0 + snd, 0.0, 1.0);\\n vec3 bk = vec3(178.0 / 255.0, 23.0 / 255.0, 0);\\n v_color = vec4(mix(bk, vec3(0,0,0), b), 1);\\n}\"}", + "settings": { + "num": 6000, + "mode": "LINES", + "sound": "https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy", + "lineSize": "CSS", + "backgroundColor": [ + 0.6980392156862745, + 0.09019607843137255, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 20.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float snd = texture2D(floatSound, vec2(count / 10000.0, 0)).a; \n float radius = pow(count * 0.014, 1.0) + snd * 0.03;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = clamp(40.0 + snd, 0.0, 1.0);\n vec3 bk = vec3(178.0 / 255.0, 23.0 / 255.0, 0);\n v_color = vec4(mix(bk, vec3(0,0,0), b), 1);\n}" + }, "screenshotDataId": "aJ7GrPx6exum5dpSW", "views": { "$numberInt": "151" diff --git a/art/42F8ccc2pFdyw4zJb/art.json b/art/42F8ccc2pFdyw4zJb/art.json index 92301127..72806153 100644 --- a/art/42F8ccc2pFdyw4zJb/art.json +++ b/art/42F8ccc2pFdyw4zJb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "hyukseung", "avatarUrl": "https://lh5.googleusercontent.com/-ZNMiGaHJfCo/AAAAAAAAAAI/AAAAAAAAIM0/HuoX3r8CVAQ/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09803921568627451,0.1568627450980392,0.23921568627450981,1],\"shader\":\"\\nvoid main() {\\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1, 0, 0, 1)\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09803921568627451, + 0.1568627450980392, + 0.23921568627450981, + 1 + ], + "shader": "\nvoid main() {\n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(1, 0, 0, 1)\n}" + }, "screenshotURL": "data/images/images-j1y3ndnknvnb3r30l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/42pYPNux6r5SL9ebp/art.json b/art/42pYPNux6r5SL9ebp/art.json index 80cf61ca..231a5a4e 100644 --- a/art/42pYPNux6r5SL9ebp/art.json +++ b/art/42pYPNux6r5SL9ebp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.35294117647058826,0.6,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.35294117647058826, + 0.6, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-y7ztecxahkjvlka4l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/48D42NwcwPw8inHZG/art.json b/art/48D42NwcwPw8inHZG/art.json index 17776ff5..fc38f477 100644 --- a/art/48D42NwcwPw8inHZG/art.json +++ b/art/48D42NwcwPw8inHZG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1026,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Making a Grid is due\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - abs(sin(time + 1.)));\\n float v = y / (across - abs(cos(time + 1.)));\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(mouse.x, mouse.y, 1, 1);\\n \\n}\"}", + "settings": { + "num": 1026, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Making a Grid is due\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - abs(sin(time + 1.)));\n float v = y / (across - abs(cos(time + 1.)));\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(mouse.x, mouse.y, 1, 1);\n \n}" + }, "screenshotURL": "data/images/images-mckm7effb8vd74fcs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/48KMxjggQsHYRm8kC/art.json b/art/48KMxjggQsHYRm8kC/art.json index be330dbf..c5ca1d95 100644 --- a/art/48KMxjggQsHYRm8kC/art.json +++ b/art/48KMxjggQsHYRm8kC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 10.;\\n\\nvoid track(float _shapeID, float _shapeCount, float base, out vec3 pos, out vec4 color) {\\n \\n float sv = _shapeID/_shapeCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n \\n float base = time * .5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n \\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //NEW\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n vec4 cbNi;\\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\\n \\n float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\\n \\n cubep*= 0.08;\\n //cubep.y+= snd*3.;\\n //cubep.y+= -1.5;\\n float speedFactor = 25.;\\n shapeId-=mod(time*speedFactor,speedFactor);\\n //END NEW\\n track(shapeId*6., shapeCount, base, pos, color);\\n //TRACK\\n /*\\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(czaxis, 0),\\n vec4(cxaxis, 0),\\n vec4(czaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n color = vec4(1.,1.,1.,1.);\\n*/\\n //END TRACK\\n cubep+= pos;\\n color.xyz = shade(eye, cubep, cbNi.xyz, color.xyz, 0.6, vec2(64.0, .8));\\n \\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 10.;\n\nvoid track(float _shapeID, float _shapeCount, float base, out vec3 pos, out vec4 color) {\n \n float sv = _shapeID/_shapeCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\nvoid main() {\n \n float base = time * .5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n \n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n \n //NEW\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n vec4 cbNi;\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\n \n float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\n \n cubep*= 0.08;\n //cubep.y+= snd*3.;\n //cubep.y+= -1.5;\n float speedFactor = 25.;\n shapeId-=mod(time*speedFactor,speedFactor);\n //END NEW\n track(shapeId*6., shapeCount, base, pos, color);\n //TRACK\n /*\n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(czaxis, 0),\n vec4(cxaxis, 0),\n vec4(czaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n color = vec4(1.,1.,1.,1.);\n*/\n //END TRACK\n cubep+= pos;\n color.xyz = shade(eye, cubep, cbNi.xyz, color.xyz, 0.6, vec2(64.0, .8));\n \n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-jriftklgfyv5fa5nk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/497PBSdmrjWadYpB2/art.json b/art/497PBSdmrjWadYpB2/art.json index a486df16..52a6a285 100644 --- a/art/497PBSdmrjWadYpB2/art.json +++ b/art/497PBSdmrjWadYpB2/art.json @@ -20,7 +20,19 @@ }, "private": true, "username": "-anon-", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28\\n#define PI 3.145191\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nfloat hash12(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n vec2 p;\\n \\n float n = vertexId / vertexCount;\\n float z = vertexId / 2000.;\\n \\n float m = pow (n, 1.01);\\n float k = 1. - m;\\n \\n p = vec2(k * z * 0.7 * cos(0.7 * PI + time) * cos(time), k * z * 0.3 * sin(time));\\n \\n vec2 d = 0.3*vec2(z * cos(vertexId * TAU * 0.0051), z * sin(vertexId * TAU * 0.0051));\\n p += d + d * 0.1 * SmoothNoise(d + vec2(time, time) + hash12(d) * 0.4);\\n \\n p.xy *= resolution.yy / resolution.xy; \\n\\n gl_Position = vec4(p, 0., 1.);\\n \\n vec3 c = hsv2rgb(vec3(10. / 360. * time,mix(.6, 1., m), m));\\n \\n v_color = vec4(c,1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28\n#define PI 3.145191\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nfloat hash12(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n vec2 p;\n \n float n = vertexId / vertexCount;\n float z = vertexId / 2000.;\n \n float m = pow (n, 1.01);\n float k = 1. - m;\n \n p = vec2(k * z * 0.7 * cos(0.7 * PI + time) * cos(time), k * z * 0.3 * sin(time));\n \n vec2 d = 0.3*vec2(z * cos(vertexId * TAU * 0.0051), z * sin(vertexId * TAU * 0.0051));\n p += d + d * 0.1 * SmoothNoise(d + vec2(time, time) + hash12(d) * 0.4);\n \n p.xy *= resolution.yy / resolution.xy; \n\n gl_Position = vec4(p, 0., 1.);\n \n vec3 c = hsv2rgb(vec3(10. / 360. * time,mix(.6, 1., m), m));\n \n v_color = vec4(c,1);\n}" + }, "screenshotURL": "data/images/images-3p5zsweln9yjmka2s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4AiWT3LpD8x6Ap7PA/art.json b/art/4AiWT3LpD8x6Ap7PA/art.json index 9c76c017..b076f27f 100644 --- a/art/4AiWT3LpD8x6Ap7PA/art.json +++ b/art/4AiWT3LpD8x6Ap7PA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":60,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n\\n#define AND(a,x) int(floor(x - (a * 16.0)))\\n#define MASK 1024.0\\n#define SCALE 112.0\\n#define MAX_TRIS 32\\n#define TOTAL_TRI 21\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec3 triangles[MAX_TRIS];\\nmat4 indices[4];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid populate(){ \\n\\ntriangles[0]=vec3(18451.0,7169.0,46.0);\\ntriangles[1]=vec3(46.0,18451.0,22588.0);\\ntriangles[2]=vec3(22588.0,46.0,75.0);\\ntriangles[3]=vec3(75.0,22588.0,18534.0);\\ntriangles[4]=vec3(18534.0,75.0,7288.0);\\ntriangles[5]=vec3(46.0,54525998.0,75.0);\\ntriangles[6]=vec3(54525998.0,54526027.0,75.0);\\ntriangles[7]=vec3(19930228.0,75.0,54526027.0) ;\\ntriangles[8]=vec3(7288.0,19930228.0,75.0);\\ntriangles[9]=vec3(19930116.0,46.0,54525998.0);\\ntriangles[10]=vec3(7169.0,19930116.0,46.0) ;\\ntriangles[11]=vec3(31473724.0,54526027.0,54525998.0) ;\\ntriangles[12]=vec3(31473724.0,22588.0,18534.0) ;\\ntriangles[13]=vec3(31473724.0,18451.0,22588.0) ;\\ntriangles[14]=vec3(31473724.0,18534.0,54526027.0) ;\\ntriangles[15]=vec3(31473724.0,54525998.0,18451.0) ;\\ntriangles[16]=vec3(54526027.0,18534.0,19930228.0) ;\\ntriangles[17]=vec3(54525998.0,18451.0,19930116.0) ;\\ntriangles[18]=vec3(7288.0,18534.0,19930228.0) ;\\ntriangles[19]=vec3(7169.0,18451.0,19930116.0) ;\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTICES_PER_TRI));\\n for(int i=0;i> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*15.)/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 0.9;\\n float tm = 1.5;//*time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/10., 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 3./abs(gl_Position.z);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*15.)/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 0.9;\n float tm = 1.5;//*time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/10., 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 3./abs(gl_Position.z);\n}\n\n" + }, "screenshotURL": "data/images/images-fis5umxs2ms0wxu0w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4BEqmFyyPkLK4Me6q/art.json b/art/4BEqmFyyPkLK4Me6q/art.json index 2885c017..8a5a7a5d 100644 --- a/art/4BEqmFyyPkLK4Me6q/art.json +++ b/art/4BEqmFyyPkLK4Me6q/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "tdhooper", "avatarUrl": "https://avatars.githubusercontent.com/tdhooper?s=200", - "settings": "{\"num\":36659,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// --------------------------------------------------------\\n// Spectrum colour palette\\n// IQ https://www.shadertoy.com/view/ll2GD3\\n// --------------------------------------------------------\\n\\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\\n return a + b*cos( 6.28318*(c*t+d) );\\n}\\n\\nvec3 spectrum(float n) {\\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\\n}\\n\\n\\n// --------------------------------------------------------\\n// HG_SDF https://www.shadertoy.com/view/Xs3GRB\\n// --------------------------------------------------------\\n\\nfloat vmax(vec3 v) {\\n return max(max(v.x, v.y), v.z);\\n}\\n\\n// Box: correct distance to corners\\nfloat fBox(vec3 p, vec3 b) {\\n vec3 d = abs(p) - b;\\n return length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\\n}\\n\\nvoid pR(inout vec2 p, float a) {\\n p = cos(a)*p + sin(a)*vec2(p.y, -p.x);\\n}\\n\\n\\n// --------------------------------------------------------\\n// Geometry\\n// --------------------------------------------------------\\n\\nfloat map(vec3 p) {\\n vec3 offset = vec3(\\n cos(time),\\n sin(time),\\n cos(time * 2.)\\n );\\n p -= offset * .25; \\n pR(p.xy, time);\\n pR(p.zx, time * .5); \\n\\n float d = 1e12;\\n \\n d = min(d, fBox(p, vec3(.7)));\\n d = max(d, -(length(p) - .85));\\n \\n return d;\\n}\\n\\n\\n// --------------------------------------------------------\\n// Raymarch\\n// --------------------------------------------------------\\n\\nconst float MAX_TRACE_DISTANCE = 10.;\\nconst float INTERSECTION_PRECISION = .001;\\nconst int NUM_OF_TRACE_STEPS = 100;\\n\\n\\nstruct Hit {\\n bool isBackground;\\n vec3 pos;\\n};\\n\\n\\nHit trace(vec3 rayOrigin, vec3 rayDir) {\\n\\n float currentDist = INTERSECTION_PRECISION * 2.;\\n float rayLen = 0.;\\n \\n for(int i=0; i< NUM_OF_TRACE_STEPS ; i++ ){\\n if (currentDist < INTERSECTION_PRECISION || rayLen > MAX_TRACE_DISTANCE) {\\n break;\\n }\\n currentDist = map(rayOrigin + rayDir * rayLen);\\n rayLen += currentDist;\\n }\\n \\n if (rayLen > MAX_TRACE_DISTANCE) {\\n return Hit(true, vec3(0));\\n }\\n \\n vec3 pos = rayOrigin + rayDir * rayLen;\\n return Hit(false, pos);\\n}\\n\\n\\n// --------------------------------------------------------\\n// Seed points, camera, and display\\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\\n// --------------------------------------------------------\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nstruct Tri {\\n vec3 a;\\n vec3 b;\\n vec3 c;\\n};\\n \\nvec3 bToC(Tri tri, float a, float b, float c) {\\n return a * tri.a + b * tri.b + c * tri.c;\\n}\\n\\nvec3 bToC(Tri tri, vec3 bary) {\\n return bary.x * tri.a + bary.y * tri.b + bary.z * tri.c;\\n}\\n\\n\\nfloat calcTriRow(float n) {\\n return floor( (1. + sqrt(1. + 8. * n)) / 2. ) - 1.;\\n}\\n\\n\\n// Find point in triangle with n subdivision rows at index\\nvec3 triPoint(Tri tri, float rows, float i) {\\n float firstPass = (rows - 1.) * (rows + 2.) / 2. + 1.;\\n \\n // Sub-tringle vertex index\\n float id = mod(i, 3.);\\n \\n //firstPass = 56.;\\n \\n // Repeat whole triangle\\n ///i = mod(i, rows * rows* 3.);\\n \\n // Sub-triangle index\\n i = floor(i / 3.);\\n \\n \\n // First pass is upwards pointing triangles,\\n // second pass fills in the gaps\\n float doSecondPass = max(0., sign(i - firstPass + 1.));\\n \\n ///doSecondPass = sign(i - firstPass) * .5 + .5;\\n \\n float doFirstPass = 1. - doSecondPass;\\n \\n i -= firstPass * doSecondPass;\\n \\n float row = calcTriRow(i);\\n float startOfRow = row * (row + 1.) / 2.;\\n float column = mod(i - startOfRow, row + 1.);\\n \\n // First pass offsets\\n row += min(id, 1.) * doFirstPass;\\n column += max(id - 1., 0.) * doFirstPass;\\n\\n // Second pass offsets\\n row += max(id, 1.) * doSecondPass;\\n column += min(id, 1.) * doSecondPass;\\n\\n // Cartesian coordinates for column/row\\n float mixA = row / (rows - 0.);\\n float mixB = column / max(row, 1.);\\n return mix(tri.a, mix(tri.b, tri.c, mixB), mixA);\\n}\\n\\n#define PHI (1.618033988749895)\\n // PHI (sqrt(5)*0.5 + 0.5)\\n\\n\\n#define IcoVert0 normalize(vec3(0, PHI, 1))\\n#define IcoVert1 normalize(vec3(0, PHI, -1))\\n#define IcoVert2 normalize(vec3(0, -PHI, 1))\\n#define IcoVert3 normalize(vec3(0, -PHI, -1))\\n#define IcoVert4 normalize(vec3(1, 0, PHI))\\n#define IcoVert5 normalize(vec3(1, 0, -PHI))\\n#define IcoVert6 normalize(vec3(-1, 0, PHI))\\n#define IcoVert7 normalize(vec3(-1, 0, -PHI))\\n#define IcoVert8 normalize(vec3(PHI, 1, 0))\\n#define IcoVert9 normalize(vec3(PHI, -1, 0))\\n#define IcoVert10 normalize(vec3(-PHI, 1, 0))\\n#define IcoVert11 normalize(vec3(-PHI, -1, 0))\\n\\nfloat beat(float i, float loop) {\\n\\treturn 1. - min(mod(i, loop), 1.);\\n} \\n\\nfloat signbeat(float i, float loop) {\\n\\treturn beat(i, loop) * 2. - 1.;\\n}\\n\\n\\nvec3 shift(vec3 v, float offset) {\\n\\toffset = mod(offset, 3.);\\n \\tif (offset == 0.) {\\n return v.xyz;\\n \\t}\\n \\tif (offset == 1.) {\\n return v.zxy;\\n \\t}\\n \\tif (offset == 2.) {\\n return v.yzx;\\n \\t}\\n}\\n\\nfloat round(float a) {\\n\\treturn floor(a + .5);\\n}\\n\\n// Step through each vertex of each icosahedron face\\nvec3 icosahedronFaceVertex(float i) {\\n \\n float stage, stageIndexOffset, stageLength;\\n float a, a0, a1, a2, b, b0, b1, b2, offset, offset0, offset1,offset2;\\n \\n stage = round( log2( floor(i / 6.) + 2.) - 1.);\\n //stage = 0.;\\n stageIndexOffset = 6. * (stage * stage);\\n //stageIndexOffset = 6.;\\n i -= stageIndexOffset;\\n stageLength = 3. * (stage + 1.) * (stage + 2.);\\n \\n float invert = floor(i / stageLength * 2.) * 2. - 1.;\\n \\n // Stage 0\\n a0 = invert;\\n b0 = invert;\\n offset0 = mod(i, 3.);\\n \\n // Stage 1\\n a1 = invert;\\n b1 = signbeat(i, 3.) * -1. * invert;\\n offset1 = mod(floor(i / 3.) - beat(i - 2., 3.), 3.);\\n\\n // Stage 2\\n a2 = b1;\\n b2 = signbeat(i - 2., 3.) * -1. * invert;\\n offset2 = mod(floor(i / 6.) + (1. - beat(i, 3.)) + beat(i - 5., 6.), 3.);\\n \\n // Pick stage to show\\n float blend1 = stage;\\n float blend2 = max(0., stage - 1.);\\n a = mix(mix(a0, a1, blend1), a2, blend2);\\n b = mix(mix(b0, b1, blend1), b2, blend2);\\n offset = mix(mix(offset0, offset1, blend1), offset2, blend2);\\n\\n vec3 icoVert = normalize(vec3(PHI, 1, 0));\\n icoVert *= vec3(a, b, 1.);\\n icoVert = shift(icoVert, offset); \\n //icoVert = normalize(icoVert);\\n return icoVert;\\n}\\n\\nHit trace2(vec3 pos, float invert) {\\n\\treturn trace(pos * sign(1. - invert), pos * invert);\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 100.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n \\n \\n float subdivisionRows = floor(sqrt(vertexCount / 20. / 3.));\\n //subdivisionRows = 2.;\\n float trianglesPerFace = subdivisionRows * subdivisionRows;\\n float maxPoints = trianglesPerFace * 3. * 20.;\\n float i = min(vertexId, maxPoints);\\n float faceIndex = floor(i / (trianglesPerFace * 3.));\\n \\n //faceIndex = 0.;\\n \\n Tri tri = Tri(\\n \\ticosahedronFaceVertex(faceIndex * 3. + 0.),\\n icosahedronFaceVertex(faceIndex * 3. + 1.),\\n icosahedronFaceVertex(faceIndex * 3. + 2.)\\n );\\n \\n i = mod(i, trianglesPerFace * 3.);\\n pos = triPoint(tri, subdivisionRows, i);\\n \\n \\n float triangleIndex = floor(i / 3.);\\n vec3 posA = triPoint(tri, subdivisionRows, (triangleIndex * 3.) + 0.);\\n vec3 posB = triPoint(tri, subdivisionRows, (triangleIndex * 3.) + 1.);\\n vec3 posC = triPoint(tri, subdivisionRows, (triangleIndex * 3.) + 2.);\\n \\n pos = normalize(pos);\\n \\n posA = normalize(posA);\\n posB = normalize(posB);\\n posC = normalize(posC);\\n \\n //tri = Tri(vec3(1,0,0), vec3(0,1,0), vec3(0,0,1));\\n \\n //pos = triPoint(tri, subdivisionRows, 0.);\\n \\n//\\tpos = icosahedronFaceVertex(vertexId);\\n \\n \\n vec3 rayOrigin, rayDir;\\n\\n rayOrigin = vec3(0);\\n\\n float invert = -1.;\\n \\n bool aa = trace2(posA, invert).isBackground;\\n bool bb = trace2(posB, invert).isBackground;\\n bool cc = trace2(posC, invert).isBackground;\\n\\n if (aa || bb || cc) {\\n pos = vec3(0.);\\n } else {\\n pos = trace2(pos, invert).pos;\\n }\\n \\n \\n \\n //pos = trace(rayOrigin, posA).pos;\\n \\n float tm = time * .5;\\n //tm = -2.;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(\\n cos(tm) * rd,\\n cos(tm) * rd,\\n sin(tm) * rd\\n );\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n vec4 pos4 = mat * vec4(pos, 1);\\n //pos4 = vec4(pos, 1.);\\n \\n \\n gl_Position = pos4;\\n gl_PointSize = 4.;\\n\\n vec3 col = vec3(spectrum(vertexId / maxPoints));\\n //col = vec3(.5);\\n col *= smoothstep(rd*3., rd, pos4.z);\\n col += pow((dot(normalize(pos4.xyz), vec3(.5,-.5,0))) * 2., 2.);\\n \\n v_color = vec4(col, 1.);\\n \\n \\n}\"}", + "settings": { + "num": 36659, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// --------------------------------------------------------\n// Spectrum colour palette\n// IQ https://www.shadertoy.com/view/ll2GD3\n// --------------------------------------------------------\n\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\n return a + b*cos( 6.28318*(c*t+d) );\n}\n\nvec3 spectrum(float n) {\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\n}\n\n\n// --------------------------------------------------------\n// HG_SDF https://www.shadertoy.com/view/Xs3GRB\n// --------------------------------------------------------\n\nfloat vmax(vec3 v) {\n return max(max(v.x, v.y), v.z);\n}\n\n// Box: correct distance to corners\nfloat fBox(vec3 p, vec3 b) {\n vec3 d = abs(p) - b;\n return length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\n}\n\nvoid pR(inout vec2 p, float a) {\n p = cos(a)*p + sin(a)*vec2(p.y, -p.x);\n}\n\n\n// --------------------------------------------------------\n// Geometry\n// --------------------------------------------------------\n\nfloat map(vec3 p) {\n vec3 offset = vec3(\n cos(time),\n sin(time),\n cos(time * 2.)\n );\n p -= offset * .25; \n pR(p.xy, time);\n pR(p.zx, time * .5); \n\n float d = 1e12;\n \n d = min(d, fBox(p, vec3(.7)));\n d = max(d, -(length(p) - .85));\n \n return d;\n}\n\n\n// --------------------------------------------------------\n// Raymarch\n// --------------------------------------------------------\n\nconst float MAX_TRACE_DISTANCE = 10.;\nconst float INTERSECTION_PRECISION = .001;\nconst int NUM_OF_TRACE_STEPS = 100;\n\n\nstruct Hit {\n bool isBackground;\n vec3 pos;\n};\n\n\nHit trace(vec3 rayOrigin, vec3 rayDir) {\n\n float currentDist = INTERSECTION_PRECISION * 2.;\n float rayLen = 0.;\n \n for(int i=0; i< NUM_OF_TRACE_STEPS ; i++ ){\n if (currentDist < INTERSECTION_PRECISION || rayLen > MAX_TRACE_DISTANCE) {\n break;\n }\n currentDist = map(rayOrigin + rayDir * rayLen);\n rayLen += currentDist;\n }\n \n if (rayLen > MAX_TRACE_DISTANCE) {\n return Hit(true, vec3(0));\n }\n \n vec3 pos = rayOrigin + rayDir * rayLen;\n return Hit(false, pos);\n}\n\n\n// --------------------------------------------------------\n// Seed points, camera, and display\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\n// --------------------------------------------------------\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nstruct Tri {\n vec3 a;\n vec3 b;\n vec3 c;\n};\n \nvec3 bToC(Tri tri, float a, float b, float c) {\n return a * tri.a + b * tri.b + c * tri.c;\n}\n\nvec3 bToC(Tri tri, vec3 bary) {\n return bary.x * tri.a + bary.y * tri.b + bary.z * tri.c;\n}\n\n\nfloat calcTriRow(float n) {\n return floor( (1. + sqrt(1. + 8. * n)) / 2. ) - 1.;\n}\n\n\n// Find point in triangle with n subdivision rows at index\nvec3 triPoint(Tri tri, float rows, float i) {\n float firstPass = (rows - 1.) * (rows + 2.) / 2. + 1.;\n \n // Sub-tringle vertex index\n float id = mod(i, 3.);\n \n //firstPass = 56.;\n \n // Repeat whole triangle\n ///i = mod(i, rows * rows* 3.);\n \n // Sub-triangle index\n i = floor(i / 3.);\n \n \n // First pass is upwards pointing triangles,\n // second pass fills in the gaps\n float doSecondPass = max(0., sign(i - firstPass + 1.));\n \n ///doSecondPass = sign(i - firstPass) * .5 + .5;\n \n float doFirstPass = 1. - doSecondPass;\n \n i -= firstPass * doSecondPass;\n \n float row = calcTriRow(i);\n float startOfRow = row * (row + 1.) / 2.;\n float column = mod(i - startOfRow, row + 1.);\n \n // First pass offsets\n row += min(id, 1.) * doFirstPass;\n column += max(id - 1., 0.) * doFirstPass;\n\n // Second pass offsets\n row += max(id, 1.) * doSecondPass;\n column += min(id, 1.) * doSecondPass;\n\n // Cartesian coordinates for column/row\n float mixA = row / (rows - 0.);\n float mixB = column / max(row, 1.);\n return mix(tri.a, mix(tri.b, tri.c, mixB), mixA);\n}\n\n#define PHI (1.618033988749895)\n // PHI (sqrt(5)*0.5 + 0.5)\n\n\n#define IcoVert0 normalize(vec3(0, PHI, 1))\n#define IcoVert1 normalize(vec3(0, PHI, -1))\n#define IcoVert2 normalize(vec3(0, -PHI, 1))\n#define IcoVert3 normalize(vec3(0, -PHI, -1))\n#define IcoVert4 normalize(vec3(1, 0, PHI))\n#define IcoVert5 normalize(vec3(1, 0, -PHI))\n#define IcoVert6 normalize(vec3(-1, 0, PHI))\n#define IcoVert7 normalize(vec3(-1, 0, -PHI))\n#define IcoVert8 normalize(vec3(PHI, 1, 0))\n#define IcoVert9 normalize(vec3(PHI, -1, 0))\n#define IcoVert10 normalize(vec3(-PHI, 1, 0))\n#define IcoVert11 normalize(vec3(-PHI, -1, 0))\n\nfloat beat(float i, float loop) {\n\treturn 1. - min(mod(i, loop), 1.);\n} \n\nfloat signbeat(float i, float loop) {\n\treturn beat(i, loop) * 2. - 1.;\n}\n\n\nvec3 shift(vec3 v, float offset) {\n\toffset = mod(offset, 3.);\n \tif (offset == 0.) {\n return v.xyz;\n \t}\n \tif (offset == 1.) {\n return v.zxy;\n \t}\n \tif (offset == 2.) {\n return v.yzx;\n \t}\n}\n\nfloat round(float a) {\n\treturn floor(a + .5);\n}\n\n// Step through each vertex of each icosahedron face\nvec3 icosahedronFaceVertex(float i) {\n \n float stage, stageIndexOffset, stageLength;\n float a, a0, a1, a2, b, b0, b1, b2, offset, offset0, offset1,offset2;\n \n stage = round( log2( floor(i / 6.) + 2.) - 1.);\n //stage = 0.;\n stageIndexOffset = 6. * (stage * stage);\n //stageIndexOffset = 6.;\n i -= stageIndexOffset;\n stageLength = 3. * (stage + 1.) * (stage + 2.);\n \n float invert = floor(i / stageLength * 2.) * 2. - 1.;\n \n // Stage 0\n a0 = invert;\n b0 = invert;\n offset0 = mod(i, 3.);\n \n // Stage 1\n a1 = invert;\n b1 = signbeat(i, 3.) * -1. * invert;\n offset1 = mod(floor(i / 3.) - beat(i - 2., 3.), 3.);\n\n // Stage 2\n a2 = b1;\n b2 = signbeat(i - 2., 3.) * -1. * invert;\n offset2 = mod(floor(i / 6.) + (1. - beat(i, 3.)) + beat(i - 5., 6.), 3.);\n \n // Pick stage to show\n float blend1 = stage;\n float blend2 = max(0., stage - 1.);\n a = mix(mix(a0, a1, blend1), a2, blend2);\n b = mix(mix(b0, b1, blend1), b2, blend2);\n offset = mix(mix(offset0, offset1, blend1), offset2, blend2);\n\n vec3 icoVert = normalize(vec3(PHI, 1, 0));\n icoVert *= vec3(a, b, 1.);\n icoVert = shift(icoVert, offset); \n //icoVert = normalize(icoVert);\n return icoVert;\n}\n\nHit trace2(vec3 pos, float invert) {\n\treturn trace(pos * sign(1. - invert), pos * invert);\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 100.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n \n \n float subdivisionRows = floor(sqrt(vertexCount / 20. / 3.));\n //subdivisionRows = 2.;\n float trianglesPerFace = subdivisionRows * subdivisionRows;\n float maxPoints = trianglesPerFace * 3. * 20.;\n float i = min(vertexId, maxPoints);\n float faceIndex = floor(i / (trianglesPerFace * 3.));\n \n //faceIndex = 0.;\n \n Tri tri = Tri(\n \ticosahedronFaceVertex(faceIndex * 3. + 0.),\n icosahedronFaceVertex(faceIndex * 3. + 1.),\n icosahedronFaceVertex(faceIndex * 3. + 2.)\n );\n \n i = mod(i, trianglesPerFace * 3.);\n pos = triPoint(tri, subdivisionRows, i);\n \n \n float triangleIndex = floor(i / 3.);\n vec3 posA = triPoint(tri, subdivisionRows, (triangleIndex * 3.) + 0.);\n vec3 posB = triPoint(tri, subdivisionRows, (triangleIndex * 3.) + 1.);\n vec3 posC = triPoint(tri, subdivisionRows, (triangleIndex * 3.) + 2.);\n \n pos = normalize(pos);\n \n posA = normalize(posA);\n posB = normalize(posB);\n posC = normalize(posC);\n \n //tri = Tri(vec3(1,0,0), vec3(0,1,0), vec3(0,0,1));\n \n //pos = triPoint(tri, subdivisionRows, 0.);\n \n//\tpos = icosahedronFaceVertex(vertexId);\n \n \n vec3 rayOrigin, rayDir;\n\n rayOrigin = vec3(0);\n\n float invert = -1.;\n \n bool aa = trace2(posA, invert).isBackground;\n bool bb = trace2(posB, invert).isBackground;\n bool cc = trace2(posC, invert).isBackground;\n\n if (aa || bb || cc) {\n pos = vec3(0.);\n } else {\n pos = trace2(pos, invert).pos;\n }\n \n \n \n //pos = trace(rayOrigin, posA).pos;\n \n float tm = time * .5;\n //tm = -2.;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(\n cos(tm) * rd,\n cos(tm) * rd,\n sin(tm) * rd\n );\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n vec4 pos4 = mat * vec4(pos, 1);\n //pos4 = vec4(pos, 1.);\n \n \n gl_Position = pos4;\n gl_PointSize = 4.;\n\n vec3 col = vec3(spectrum(vertexId / maxPoints));\n //col = vec3(.5);\n col *= smoothstep(rd*3., rd, pos4.z);\n col += pow((dot(normalize(pos4.xyz), vec3(.5,-.5,0))) * 2., 2.);\n \n v_color = vec4(col, 1.);\n \n \n}" + }, "screenshotURL": "data/images/images-h4ls34yjxi0fcri9g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4BkjXGWjFkBTo7kEJ/art.json b/art/4BkjXGWjFkBTo7kEJ/art.json index 756c37a2..ab957838 100644 --- a/art/4BkjXGWjFkBTo7kEJ/art.json +++ b/art/4BkjXGWjFkBTo7kEJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * .119)) * 1. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * .119)) * 1. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-add1ry2x6udi4y90o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4FQ77YanjkTRoSWip/art.json b/art/4FQ77YanjkTRoSWip/art.json index ab6b5c0f..06269d7f 100644 --- a/art/4FQ77YanjkTRoSWip/art.json +++ b/art/4FQ77YanjkTRoSWip/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "kessondalef", "avatarUrl": "https://avatars.githubusercontent.com/KessonDalef?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 2D Random\\nfloat random (in vec2 st) {\\n return fract(sin(dot(st.xy,\\n vec2(12.9898,78.233)))\\n * 43758.5453123);\\n}\\n\\n// 2D Noise based on Morgan McGuire @morgan3d\\n// https://www.shadertoy.com/view/4dS3Wd\\nfloat noise (in vec2 st) {\\n vec2 i = floor(st);\\n vec2 f = fract(st);\\n\\n // Four corners in 2D of a tile\\n float a = random(i);\\n float b = random(i + vec2(1.0, 0.0));\\n float c = random(i + vec2(0.0, 1.0));\\n float d = random(i + vec2(1.0, 1.0));\\n\\n // Smooth Interpolation\\n\\n // Cubic Hermine Curve. Same as SmoothStep()\\n vec2 u = f*f*(3.0-2.0*f);\\n // u = smoothstep(0.,1.,f);\\n\\n // Mix 4 coorners percentages\\n return mix(a, b, u.x) +\\n (c - a)* u.y * (1.0 - u.x) +\\n (d - b) * u.x * u.y;\\n}\\n\\nmat4 rotateX(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateY(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotateZ(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n //sin(t+i*.9553) +\\n //sin(t*0.0311+i) +\\n cos(t*.4+i*1.53) +\\n sin(t*1.84+i*.76) + \\n noise(vec2(t, i)),\\n //sin(t+i*.79553+2.1) +\\n //sin(t*1.311+i*1.1311+2.1) +\\n cos(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1) +\\n noise(vec2(t*.3, i)),\\n //sin(t+i*.5553-2.1) +\\n //sin(t*1.311+i*1.1-2.1) +\\n //cos(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)// +\\n //noise(vec2(t, i*))\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.03,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.1;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n \\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos.x *= resolution.y/resolution.x;\\n pos.z *= resolution.y/resolution.x;\\n \\n mat4 rotation = rotateY(time*0.1);\\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\\n \\n\\n pos.z += .5;\\n \\n rot *= 2.0;\\n \\n //pos.xy *= .6/pos.z;\\n \\n //gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_Position = vec4(rot.xyz, 1);\\n gl_PointSize = 1.;\\n\\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 2D Random\nfloat random (in vec2 st) {\n return fract(sin(dot(st.xy,\n vec2(12.9898,78.233)))\n * 43758.5453123);\n}\n\n// 2D Noise based on Morgan McGuire @morgan3d\n// https://www.shadertoy.com/view/4dS3Wd\nfloat noise (in vec2 st) {\n vec2 i = floor(st);\n vec2 f = fract(st);\n\n // Four corners in 2D of a tile\n float a = random(i);\n float b = random(i + vec2(1.0, 0.0));\n float c = random(i + vec2(0.0, 1.0));\n float d = random(i + vec2(1.0, 1.0));\n\n // Smooth Interpolation\n\n // Cubic Hermine Curve. Same as SmoothStep()\n vec2 u = f*f*(3.0-2.0*f);\n // u = smoothstep(0.,1.,f);\n\n // Mix 4 coorners percentages\n return mix(a, b, u.x) +\n (c - a)* u.y * (1.0 - u.x) +\n (d - b) * u.x * u.y;\n}\n\nmat4 rotateX(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateY(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotateZ(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n //sin(t+i*.9553) +\n //sin(t*0.0311+i) +\n cos(t*.4+i*1.53) +\n sin(t*1.84+i*.76) + \n noise(vec2(t, i)),\n //sin(t+i*.79553+2.1) +\n //sin(t*1.311+i*1.1311+2.1) +\n cos(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1) +\n noise(vec2(t*.3, i)),\n //sin(t+i*.5553-2.1) +\n //sin(t*1.311+i*1.1-2.1) +\n //cos(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)// +\n //noise(vec2(t, i*))\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.03,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.1;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n \n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos.x *= resolution.y/resolution.x;\n pos.z *= resolution.y/resolution.x;\n \n mat4 rotation = rotateY(time*0.1);\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\n \n\n pos.z += .5;\n \n rot *= 2.0;\n \n //pos.xy *= .6/pos.z;\n \n //gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_Position = vec4(rot.xyz, 1);\n gl_PointSize = 1.;\n\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-ljx7nl9r2q1vp21md-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4FbgY4x8sEM5EQuCT/art.json b/art/4FbgY4x8sEM5EQuCT/art.json index 1075246c..935a003b 100644 --- a/art/4FbgY4x8sEM5EQuCT/art.json +++ b/art/4FbgY4x8sEM5EQuCT/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "the", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJz8gvj8XWPF_GE6AyStvhxPjTLFoFJM_J9Mxm95=s96-c", - "settings": "{\"num\":1234,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\nconst float TWOPI = radians(360.);\\nfloat aspect = resolution.x / resolution.y;\\n\\nvec3 hsv2rgb(vec3 hsvValue) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(hsvValue.xxx + K.xyz) * 6.0 - K.www);\\n return hsvValue.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), hsvValue.y);\\n}\\n\\nfloat circle1() {\\n\\tfloat x = vertexId - 1.;\\n\\tx *= TWOPI;\\n\\tx /= vertexCount / 5. - 1.;\\n\\treturn x;\\n}\\nfloat circle2() {\\n float edgeRate = 10.;\\n float edgesCount = vertexCount * edgeRate;\\n\\t// return (1. - 0.1 * vertexId / edgesCount) * sin(time + vertexId); // muita giro!\\n\\t//return (1. - 0.1 * vertexId / edgesCount); // lollipop\\n\\t// return (1. - 0.1 * vertexId / edgesCount) * (cos(time) + 3.) / 4.; // pulsing lollipop\\n\\t// return (1. - 0.1 * vertexId / edgesCount) * (cos(time + vertexId) + 3.) / 4.; // flor ?\\n\\t// return (1. - 0.1 * vertexId / edgesCount) - (cos(time + vertexId) + 3.) / 30.; // hypnotic\\n\\t// return (1. - vertexId / vertexCount) - (cos(time + vertexId)) / (vertexId + 1.) / vertexCount / 30.;\\n\\treturn (1. - edgeRate * vertexId / edgesCount) - (cos(time + vertexId)) / (vertexId + 1.) / edgesCount / 30.;\\n\\t// return (7./8.);\\n}\\n\\nvoid main() {\\n\\tint index = int(floor(time));\\n\\tfloat ratio = fract(time);\\n \\n\\n\\tfloat m = step(0.5, float(vertexId)); // vertexId[0] = (0, 0)\\n\\t//m *= (1. - step(floor(time) + 2., float(vertexId))); // clock effect\\n\\n\\tfloat c1 = circle1();\\n\\tfloat c2 = circle2();\\n \\n float divider = 1./vertexCount;\\n\\n\\tvec2 pos = vec2(sin(c1 / divider) / aspect * c2, cos(c1 / divider) * c2);\\n\\n\\tgl_Position = vec4(m * pos, -vertexId / 10000., 1);\\n\\n\\tv_color = m * vec4(hsv2rgb(vec3(float(vertexId) / float(vertexCount), 1., 1.)), 1.) + (1. - m) * vec4(.0);\\n}\"}", + "settings": { + "num": 1234, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\nconst float TWOPI = radians(360.);\nfloat aspect = resolution.x / resolution.y;\n\nvec3 hsv2rgb(vec3 hsvValue) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(hsvValue.xxx + K.xyz) * 6.0 - K.www);\n return hsvValue.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), hsvValue.y);\n}\n\nfloat circle1() {\n\tfloat x = vertexId - 1.;\n\tx *= TWOPI;\n\tx /= vertexCount / 5. - 1.;\n\treturn x;\n}\nfloat circle2() {\n float edgeRate = 10.;\n float edgesCount = vertexCount * edgeRate;\n\t// return (1. - 0.1 * vertexId / edgesCount) * sin(time + vertexId); // muita giro!\n\t//return (1. - 0.1 * vertexId / edgesCount); // lollipop\n\t// return (1. - 0.1 * vertexId / edgesCount) * (cos(time) + 3.) / 4.; // pulsing lollipop\n\t// return (1. - 0.1 * vertexId / edgesCount) * (cos(time + vertexId) + 3.) / 4.; // flor ?\n\t// return (1. - 0.1 * vertexId / edgesCount) - (cos(time + vertexId) + 3.) / 30.; // hypnotic\n\t// return (1. - vertexId / vertexCount) - (cos(time + vertexId)) / (vertexId + 1.) / vertexCount / 30.;\n\treturn (1. - edgeRate * vertexId / edgesCount) - (cos(time + vertexId)) / (vertexId + 1.) / edgesCount / 30.;\n\t// return (7./8.);\n}\n\nvoid main() {\n\tint index = int(floor(time));\n\tfloat ratio = fract(time);\n \n\n\tfloat m = step(0.5, float(vertexId)); // vertexId[0] = (0, 0)\n\t//m *= (1. - step(floor(time) + 2., float(vertexId))); // clock effect\n\n\tfloat c1 = circle1();\n\tfloat c2 = circle2();\n \n float divider = 1./vertexCount;\n\n\tvec2 pos = vec2(sin(c1 / divider) / aspect * c2, cos(c1 / divider) * c2);\n\n\tgl_Position = vec4(m * pos, -vertexId / 10000., 1);\n\n\tv_color = m * vec4(hsv2rgb(vec3(float(vertexId) / float(vertexCount), 1., 1.)), 1.) + (1. - m) * vec4(.0);\n}" + }, "screenshotURL": "data/images/images-e2swxl2b1wtdv707d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4GQmaka5iAZi5fCbw/art.json b/art/4GQmaka5iAZi5fCbw/art.json index 31e6f3fe..17c6ddcc 100644 --- a/art/4GQmaka5iAZi5fCbw/art.json +++ b/art/4GQmaka5iAZi5fCbw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nmat4 persp (float fov, float aspect, float zNear, float zFar)\\n{\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n \\n return mat4(\\n \\tf / aspect, 0, 0, 0,\\n \\t0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n \\t0, 0, zNear * zFar * rangeInv * 2.0, 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n zAxis, 0,\\n xAxis, 0,\\n yAxis, 0,\\n eye , 2\\n );\\n}\\n\\nvec3 pos_point[8];\\nvec3 colors[8];\\nvoid drow_point()\\n{\\n pos_point[0] = vec3(-.5, -.5, .0);\\n pos_point[1] = vec3(-.5 , .5, .0);\\n pos_point[2] = vec3(.5 , -.5, .0);\\n pos_point[3] = vec3(.5 , .5, .0);\\n pos_point[4] = vec3(.5 , -.5, .5);\\n pos_point[5] = vec3(.5 , .5, .5);\\n pos_point[6] = vec3(-.5, -.5, .5);\\n pos_point[7] = vec3(-.5 , .5, .5);\\n \\n colors[0] = vec3(1, 0, 0);\\n colors[1] = vec3(1, 0, 0);\\n colors[2] = vec3(0, 0, 1);\\n colors[3] = vec3(0, 0, 1);\\n colors[4] = vec3(1, 1, 1);\\n colors[5] = vec3(1, 1, 1);\\n colors[6] = vec3(0.2, 1, 0);\\n colors[7] = vec3(0.2, 1, 0);\\n}\\n\\nvoid main() {\\n drow_point();\\n int VD = int(vertexId);\\n vec2 m = mouse;\\n \\n float ct = time *0.3;\\n vec3 p = vec3(0, 0, -2.5);\\n vec3 t = vec3(m.x*5., m.y*5., 1.);\\n vec3 u = vec3(0, 1, 0);\\n\\n for( int i=0; i<8; i++)\\n {\\n if(VD == i)\\n {\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= lookAt(p, t, u);\\n gl_Position = m * vec4(pos_point[i], 1);\\n gl_PointSize = 20.;\\n v_color = vec4(colors[i], 1.0);\\n }\\n }\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nmat4 persp (float fov, float aspect, float zNear, float zFar)\n{\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n \n return mat4(\n \tf / aspect, 0, 0, 0,\n \t0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n \t0, 0, zNear * zFar * rangeInv * 2.0, 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\n{\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n \n return mat4(\n zAxis, 0,\n xAxis, 0,\n yAxis, 0,\n eye , 2\n );\n}\n\nvec3 pos_point[8];\nvec3 colors[8];\nvoid drow_point()\n{\n pos_point[0] = vec3(-.5, -.5, .0);\n pos_point[1] = vec3(-.5 , .5, .0);\n pos_point[2] = vec3(.5 , -.5, .0);\n pos_point[3] = vec3(.5 , .5, .0);\n pos_point[4] = vec3(.5 , -.5, .5);\n pos_point[5] = vec3(.5 , .5, .5);\n pos_point[6] = vec3(-.5, -.5, .5);\n pos_point[7] = vec3(-.5 , .5, .5);\n \n colors[0] = vec3(1, 0, 0);\n colors[1] = vec3(1, 0, 0);\n colors[2] = vec3(0, 0, 1);\n colors[3] = vec3(0, 0, 1);\n colors[4] = vec3(1, 1, 1);\n colors[5] = vec3(1, 1, 1);\n colors[6] = vec3(0.2, 1, 0);\n colors[7] = vec3(0.2, 1, 0);\n}\n\nvoid main() {\n drow_point();\n int VD = int(vertexId);\n vec2 m = mouse;\n \n float ct = time *0.3;\n vec3 p = vec3(0, 0, -2.5);\n vec3 t = vec3(m.x*5., m.y*5., 1.);\n vec3 u = vec3(0, 1, 0);\n\n for( int i=0; i<8; i++)\n {\n if(VD == i)\n {\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= lookAt(p, t, u);\n gl_Position = m * vec4(pos_point[i], 1);\n gl_PointSize = 20.;\n v_color = vec4(colors[i], 1.0);\n }\n }\n}" + }, "screenshotURL": "data/images/images-0b4qpgrdi1k7pmycr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4JPK5YpSAQRwHtgZX/art.json b/art/4JPK5YpSAQRwHtgZX/art.json index e950d535..3612e549 100644 --- a/art/4JPK5YpSAQRwHtgZX/art.json +++ b/art/4JPK5YpSAQRwHtgZX/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/expresswayrecords/axiom-crux-this-is-ubiquity?si=376df53447784541980aeab9b847a63e&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.123 * cgv + snd * .125);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n gl_Position = mat * vec4(pos, .25);\\n gl_PointSize = 1.;\\n \\n float pump = step(.45, snd);\\n float hue = 1.- cgId * 1.05 + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 7.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/expresswayrecords/axiom-crux-this-is-ubiquity?si=376df53447784541980aeab9b847a63e&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.123 * cgv + snd * .125);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n gl_Position = mat * vec4(pos, .25);\n gl_PointSize = 1.;\n \n float pump = step(.45, snd);\n float hue = 1.- cgId * 1.05 + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 7.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-cqkw0b6xoe9tuf2by-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4Jvv5ja6vMDtacCMp/art.json b/art/4Jvv5ja6vMDtacCMp/art.json index f74860d7..47410795 100644 --- a/art/4Jvv5ja6vMDtacCMp/art.json +++ b/art/4Jvv5ja6vMDtacCMp/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":4,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" \\n// shadertoy\\n// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\nconst vec3 ld = vec3(0.,1., .5);\\n\\nfloat t = 0.;\\n\\nfloat fullAtan(vec2 p)\\n{\\n return step(0.0,-p.x)*3.1415926535 + sign(p.x) * atan(p.x, sign(p.x) * p.y);\\n}\\n\\nfloat fractus(vec2 p, vec2 v)\\n{\\n\\tvec2 z = p;\\n vec2 c = v;\\n\\tfloat k = 1., h = 1.0; \\n float t = (sin(time * .5)*.5+.5) * 5.;\\n for (float i=0.;i<5.;i++)\\n {\\n if (i > t) break;\\n h *= 4.*k;\\n\\t\\tk = dot(z,z);\\n if(k > 4.) break;\\n\\t\\tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\\n }\\n float d = sqrt(k/h)*log(k);\\n \\n // next iteration\\n if (k > 4.)\\n \\tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\\n h *= 4.*k;\\n k = dot(z,z);\\n float d1 = sqrt(k/h)*log(k);\\n \\n // df blending\\n\\treturn mix(d, d1, fract(t));\\n}\\n\\nvec4 dfFractus(vec3 p)\\n{\\n\\tfloat a = fullAtan(p.xz); // axis y\\n \\n vec2 c;\\n c.x = mix(0.2, -0.5, sin(a * 2.));\\n c.y = mix(0.5, 0.0, sin(a * 3.));\\n \\n float path = length(p.xz) - 3.;\\n \\n vec2 rev = vec2(path, p.y);\\n float aa = a + time;\\n rev *= mat2(cos(aa),-sin(aa),sin(aa),cos(aa)); // rot near axis y\\n\\t\\n\\treturn vec4(fractus(rev, c) - 0.0, rev, 0);\\n}\\n\\nvec4 df(vec3 p)\\n{\\n\\treturn dfFractus(p); \\n}\\n\\nvec3 nor( vec3 p, float prec )\\n{\\n vec2 e = vec2( prec, 0. );\\n vec3 n = vec3(\\n\\t\\tdf(p+e.xyy).x - df(p-e.xyy).x,\\n\\t\\tdf(p+e.yxy).x - df(p-e.yxy).x,\\n\\t\\tdf(p+e.yyx).x - df(p-e.yyx).x );\\n return normalize(n);\\n}\\n\\n// from iq code\\nfloat softshadow( in vec3 ro, in vec3 rd, in float mint, in float tmax )\\n{\\n\\tfloat res = 1.0;\\n float t = mint;\\n for( int i=0; i<1; i++ )\\n {\\n\\t\\tfloat h = df( ro + rd*t ).x;\\n res = min( res, 8.0*h/t );\\n t += h*.25;\\n if( h<0.001 || t>tmax ) break;\\n }\\n return clamp( res, 0., 1. );\\n}\\n\\n// from iq code\\nfloat calcAO( in vec3 pos, in vec3 nor )\\n{\\n\\tfloat occ = 0.0;\\n float sca = 1.0;\\n for( int i=0; i<10; i++ )\\n {\\n float hr = 0.01 + 0.12*float(i)/4.0;\\n vec3 aopos = nor * hr + pos;\\n float dd = df( aopos ).x;\\n occ += -(dd-hr)*sca;\\n sca *= 0.95;\\n }\\n return clamp( 1.0 - 3.0*occ, 0.0, 1.0 ); \\n}\\n\\n//--------------------------------------------------------------------------\\n// Grab all sky information for a given ray from camera\\n// from Dave Hoskins // https://www.shadertoy.com/view/Xsf3zX\\nvec3 GetSky(in vec3 rd, in vec3 sunDir, in vec3 sunCol)\\n{\\n\\tfloat sunAmount = max( dot( rd, sunDir), 0.0 );\\n\\tfloat v = pow(1.0-max(rd.y,0.0),6.);\\n\\tvec3 sky = mix(vec3(.1, .2, .3), vec3(.32, .32, .32), v);\\n\\tsky = sky + sunCol * sunAmount * sunAmount * .25;\\n\\tsky = sky + sunCol * min(pow(sunAmount, 800.0)*1.5, .3);\\n\\treturn clamp(sky, 0.0, 1.0);\\n}\\n\\n// https://www.vertexshaderart.com/art/TnXzsnYqaPym78gQ8\\n#define width 256.0\\n#define height 384.0\\n\\nvoid main() \\n{\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n /*if (vertexId == 0.) gl_Position = vec4(-1,-1,0,1);\\n if (vertexId == 1.) gl_Position = vec4(1,-1,0,1);\\n if (vertexId == 2.) gl_Position = vec4(1,1,0,1);\\n if (vertexId == 3.) gl_Position = vec4(-1,1,0,1);*/\\n \\n\\n\\n\\n\\n\\n\\n\\tvec4 fragColor = vec4(1);\\n\\t\\n\\tvec2 g = vec2(px+0.5, py+0.5)*100.0;\\n\\tvec2 si = resolution.xy;\\n\\tvec2 uv = (2.*g-si)/min(si.x, si.y);\\n\\t\\n float a = 1.57;\\n\\tvec3 rayOrg = vec3(cos(a),1.5,sin(a)) * 5.;\\n\\tvec3 camUp = vec3(0,1,0);\\n\\tvec3 camOrg = vec3(0,-1.5,0);\\n\\t\\n\\tfloat fov = .5;\\n\\tvec3 axisZ = normalize(camOrg - rayOrg);\\n\\tvec3 axisX = normalize(cross(camUp, axisZ));\\n\\tvec3 axisY = normalize(cross(axisZ, axisX));\\n\\tvec3 rayDir = normalize(axisZ + fov * uv.x * axisX + fov * uv.y * axisY);\\n\\t\\n\\tfloat s = 0.;\\n float d = 0.;\\n\\tfloat dMax = 20.;\\n\\tfloat count = 0.;\\n\\tfor (float i=0.; i<500.; i++)\\n\\t{\\n\\t\\tif (d*d/s>1e6 || d>dMax) break;\\n s = df(rayOrg + rayDir * d).x;\\n\\t\\td += s * 0.2;\\n\\t\\tcount+=1.;\\n\\t}\\n\\t\\n vec3 sky = GetSky(rayDir, ld, vec3(1.5));\\n \\n \\t/*vec4 mat = df(rayOrg + rayDir * d);\\n \\tvec3 tex = texture(iChannel0, mat.yz * 0.8).rgb;\\n d += dot(tex, vec3(0.05));*/\\n\\t\\n\\tif (d t) break;\n h *= 4.*k;\n\t\tk = dot(z,z);\n if(k > 4.) break;\n\t\tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\n }\n float d = sqrt(k/h)*log(k);\n \n // next iteration\n if (k > 4.)\n \tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\n h *= 4.*k;\n k = dot(z,z);\n float d1 = sqrt(k/h)*log(k);\n \n // df blending\n\treturn mix(d, d1, fract(t));\n}\n\nvec4 dfFractus(vec3 p)\n{\n\tfloat a = fullAtan(p.xz); // axis y\n \n vec2 c;\n c.x = mix(0.2, -0.5, sin(a * 2.));\n c.y = mix(0.5, 0.0, sin(a * 3.));\n \n float path = length(p.xz) - 3.;\n \n vec2 rev = vec2(path, p.y);\n float aa = a + time;\n rev *= mat2(cos(aa),-sin(aa),sin(aa),cos(aa)); // rot near axis y\n\t\n\treturn vec4(fractus(rev, c) - 0.0, rev, 0);\n}\n\nvec4 df(vec3 p)\n{\n\treturn dfFractus(p); \n}\n\nvec3 nor( vec3 p, float prec )\n{\n vec2 e = vec2( prec, 0. );\n vec3 n = vec3(\n\t\tdf(p+e.xyy).x - df(p-e.xyy).x,\n\t\tdf(p+e.yxy).x - df(p-e.yxy).x,\n\t\tdf(p+e.yyx).x - df(p-e.yyx).x );\n return normalize(n);\n}\n\n// from iq code\nfloat softshadow( in vec3 ro, in vec3 rd, in float mint, in float tmax )\n{\n\tfloat res = 1.0;\n float t = mint;\n for( int i=0; i<1; i++ )\n {\n\t\tfloat h = df( ro + rd*t ).x;\n res = min( res, 8.0*h/t );\n t += h*.25;\n if( h<0.001 || t>tmax ) break;\n }\n return clamp( res, 0., 1. );\n}\n\n// from iq code\nfloat calcAO( in vec3 pos, in vec3 nor )\n{\n\tfloat occ = 0.0;\n float sca = 1.0;\n for( int i=0; i<10; i++ )\n {\n float hr = 0.01 + 0.12*float(i)/4.0;\n vec3 aopos = nor * hr + pos;\n float dd = df( aopos ).x;\n occ += -(dd-hr)*sca;\n sca *= 0.95;\n }\n return clamp( 1.0 - 3.0*occ, 0.0, 1.0 ); \n}\n\n//--------------------------------------------------------------------------\n// Grab all sky information for a given ray from camera\n// from Dave Hoskins // https://www.shadertoy.com/view/Xsf3zX\nvec3 GetSky(in vec3 rd, in vec3 sunDir, in vec3 sunCol)\n{\n\tfloat sunAmount = max( dot( rd, sunDir), 0.0 );\n\tfloat v = pow(1.0-max(rd.y,0.0),6.);\n\tvec3 sky = mix(vec3(.1, .2, .3), vec3(.32, .32, .32), v);\n\tsky = sky + sunCol * sunAmount * sunAmount * .25;\n\tsky = sky + sunCol * min(pow(sunAmount, 800.0)*1.5, .3);\n\treturn clamp(sky, 0.0, 1.0);\n}\n\n// https://www.vertexshaderart.com/art/TnXzsnYqaPym78gQ8\n#define width 256.0\n#define height 384.0\n\nvoid main() \n{\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n /*if (vertexId == 0.) gl_Position = vec4(-1,-1,0,1);\n if (vertexId == 1.) gl_Position = vec4(1,-1,0,1);\n if (vertexId == 2.) gl_Position = vec4(1,1,0,1);\n if (vertexId == 3.) gl_Position = vec4(-1,1,0,1);*/\n \n\n\n\n\n\n\n\tvec4 fragColor = vec4(1);\n\t\n\tvec2 g = vec2(px+0.5, py+0.5)*100.0;\n\tvec2 si = resolution.xy;\n\tvec2 uv = (2.*g-si)/min(si.x, si.y);\n\t\n float a = 1.57;\n\tvec3 rayOrg = vec3(cos(a),1.5,sin(a)) * 5.;\n\tvec3 camUp = vec3(0,1,0);\n\tvec3 camOrg = vec3(0,-1.5,0);\n\t\n\tfloat fov = .5;\n\tvec3 axisZ = normalize(camOrg - rayOrg);\n\tvec3 axisX = normalize(cross(camUp, axisZ));\n\tvec3 axisY = normalize(cross(axisZ, axisX));\n\tvec3 rayDir = normalize(axisZ + fov * uv.x * axisX + fov * uv.y * axisY);\n\t\n\tfloat s = 0.;\n float d = 0.;\n\tfloat dMax = 20.;\n\tfloat count = 0.;\n\tfor (float i=0.; i<500.; i++)\n\t{\n\t\tif (d*d/s>1e6 || d>dMax) break;\n s = df(rayOrg + rayDir * d).x;\n\t\td += s * 0.2;\n\t\tcount+=1.;\n\t}\n\t\n vec3 sky = GetSky(rayDir, ld, vec3(1.5));\n \n \t/*vec4 mat = df(rayOrg + rayDir * d);\n \tvec3 tex = texture(iChannel0, mat.yz * 0.8).rgb;\n d += dot(tex, vec3(0.05));*/\n\t\n\tif (d snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (snd2 * pow(ringCircle,2.) + 3. * ringCircle /snd) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 3.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (.8 + hexSpace);\\n\\t}\\n\\n\\tp.y *= 3.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.5;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 2.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0.5, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, .01, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 0.3);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,1.5,0.2)*2., vec3(.12,0.18,0.9), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.295 - sin(time * 0.165) * fov+fov)-fov;\\n float rangeInv = 1.02 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\\n 0, 0, zNear * zFar * rangeInv *2., 0.5);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.143*mouse.x,\\n yAxis, 0.18*mouse.y,\\n zAxis, .210,\\n eye, sin(2.51*time));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 * a10 * b09 - a12 * b06,\\n a00 * b09 - a01 / b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) * det;\\n}\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye+(3.*mouse.y), target*2., (up-1.,-up)))\\n\\n;\\n #else\\n vec3 zAxis = normalize(target * eye)/mouse.x;\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -1.,\\n yAxis, 1.2*-snd\\n zAxis, -2.3\\n\\n ,dot(xAxis, 1.-eye)/mouse, *dot(-yAxis, mouse*eye),-dot(zAxis, eye), 1.6); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/tripmonk13/sets/experimental-bass", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),2.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 12.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\n\tfloat hexSpace = 1.0;\n \tvec2 height = vec2(1.,0.4)-(mouse/2.);\n \t\n\tfloat indexQuad = floor(vertexId / 33.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 12.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a *-3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (snd2 * pow(ringCircle,2.) + 3. * ringCircle /snd) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 3.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (.8 + hexSpace);\n\t}\n\n\tp.y *= 3.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.5;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 2.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0.5, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, .01, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 0.3);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,1.5,0.2)*2., vec3(.12,0.18,0.9), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.295 - sin(time * 0.165) * fov+fov)-fov;\n float rangeInv = 1.02 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\n 0, 0, zNear * zFar * rangeInv *2., 0.5);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.143*mouse.x,\n yAxis, 0.18*mouse.y,\n zAxis, .210,\n eye, sin(2.51*time));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 * a10 * b09 - a12 * b06,\n a00 * b09 - a01 / b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) * det;\n}\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye+(3.*mouse.y), target*2., (up-1.,-up)))\n\n;\n #else\n vec3 zAxis = normalize(target * eye)/mouse.x;\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -1.,\n yAxis, 1.2*-snd\n zAxis, -2.3\n\n ,dot(xAxis, 1.-eye)/mouse, *dot(-yAxis, mouse*eye),-dot(zAxis, eye), 1.6); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-f0xrnndvecns2z8yq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4SRkNtncZayGZ5xBF/art.json b/art/4SRkNtncZayGZ5xBF/art.json index de146f7a..d10744bb 100644 --- a/art/4SRkNtncZayGZ5xBF/art.json +++ b/art/4SRkNtncZayGZ5xBF/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "davide", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14Gi490kG9D7UEVvtNX8rZBCH1G4jKhV72cfZuabwxg", - "settings": "{\"num\":6867,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\nvoid main() {\\n\\n \\n \\n float across = floor(sqrt(vertexCount));\\n float down = floor(vertexCount/ across);\\n float x = mod(vertexId,across);\\n float y = floor(vertexId/across);\\n \\n float x1 = x/(across - 1.);\\n float y1 = y/(across - 1.);\\n \\n float x2 = x1 * 2. -1.;\\n float y2 = y1 * 2. -1.;\\n \\n float xSineOff = sin(time + y*0.2)*0.1 ;\\n float ySineOff = sin(time + x*0.3)*0.1 ;\\n\\n \\n float x3 = x2 + xSineOff ;\\n float y3 = y2 + ySineOff;\\n vec2 xy = vec2(x3,y3);\\n \\n\\n \\n gl_Position = vec4(xy,0,0.8);\\n \\n float soff = sin(time);\\n \\n float verticalSize = resolution.y/down +soff;\\n float horizontalSize = resolution.x/across +soff;\\n \\n\\n\\n \\n if(verticalSize>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 4.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.2, 1.5)/cos(time*1.6)*parameter3);\\n vec4 K = vec4(2.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle/cos(time* 0.16 ));\\n float c =cos( angle *32.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2*2.),\\n 1.-s, 0, 2, 0.4,\\n 0, 0, 0, 12); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle * 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0.1, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 0.33, -1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0.5, 0,\\n 0, 1, 0, 2,\\n 1, -1, 0, -0.9,\\n 0, -2, 0, 2.4);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 1,\\n 0, -0.1, 0.5, 2.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, 0.7+s, s-mouse.x, 1.31,\\n s-0.5, 1.3, 0, 1.-s,\\n 2, 0.5, 0.2, 1.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t1.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 12.0);\\n float side = mix(1., 5.3, step(2., mod(circleId, 311.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * 2.1)));\\n float start = fract(hash(circleId * 23.33) + cos(time * .03 + circleId) *0.1 /mouse.x);\\n float end = start * 1.3/vertexCount;\\n start + hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 1.8 *1.3)) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - parameter2 + 0.103) * 0.4;\\n offset.y += goop(circleId * time * 0.13)-pos.x;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 23390, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.06274509803921569, + 0.0784313725490196, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 4.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.2, 1.5)/cos(time*1.6)*parameter3);\n vec4 K = vec4(2.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle/cos(time* 0.16 ));\n float c =cos( angle *32.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2*2.),\n 1.-s, 0, 2, 0.4,\n 0, 0, 0, 12); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle * 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0.1, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 0.33, -1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0.5, 0,\n 0, 1, 0, 2,\n 1, -1, 0, -0.9,\n 0, -2, 0, 2.4);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 1,\n 0, -0.1, 0.5, 2.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, 0.7+s, s-mouse.x, 1.31,\n s-0.5, 1.3, 0, 1.-s,\n 2, 0.5, 0.2, 1.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t1.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 12.0);\n float side = mix(1., 5.3, step(2., mod(circleId, 311.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * 2.1)));\n float start = fract(hash(circleId * 23.33) + cos(time * .03 + circleId) *0.1 /mouse.x);\n float end = start * 1.3/vertexCount;\n start + hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 1.8 *1.3)) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - parameter2 + 0.103) * 0.4;\n offset.y += goop(circleId * time * 0.13)-pos.x;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-hca5rw70td0cmcnl5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4X6mJigNvjatDJv4q/art.json b/art/4X6mJigNvjatDJv4q/art.json index 4aa925ec..d7ecc325 100644 --- a/art/4X6mJigNvjatDJv4q/art.json +++ b/art/4X6mJigNvjatDJv4q/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":97274,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n \\n float inner = 0.9;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 0.8);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n //pos = QUANT(pos,quantize);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 97274, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n \n float inner = 0.9;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 0.8);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n \n //mat = QUANT(mat,mat4(quantize));\n \n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n //pos = QUANT(pos,quantize);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-ypmyuwl2kresc5s6h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4a3WBCocrSgn67Cfh/art.json b/art/4a3WBCocrSgn67Cfh/art.json index c63c5387..d0ed9c2d 100644 --- a/art/4a3WBCocrSgn67Cfh/art.json +++ b/art/4a3WBCocrSgn67Cfh/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":64327,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Circles from Triangles\\n// CS250 Spring 2022\\n\\n\\n\\n/// These helper functions are from https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n///\\n\\n\\nvec2 getCirclePoint(float id, float circleSegmentCount)\\n{\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / circleSegmentCount * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n return vec2(c, s) * radius;\\n}\\n\\n\\nvoid main()\\n{\\n float circleSegmentCount = 12.0;\\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentCount);\\n \\n float pointCountPerCircle = circleSegmentCount * 6.0;\\n float circleId = floor(vertexId / pointCountPerCircle);\\n float circleCount = floor(vertexCount / pointCountPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0);\\n \\n float down = floor(sqrt(circleCount));\\n float across = floor(circleCount / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = 0.0;\\n float yOffset = 0.0;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.0) * mix(1.0, 1.1, oddSlice);\\n sc *= 20.0 / across;\\n \\n vec4 pos = vec4(circleXY, 0.0, 1.0);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy, 0) * 1.4);\\n mat *= rotZ(snd * 20.0 * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n gl_Position = mat * pos;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;\\n float saturation = 1.0;\\n float value = mix(0.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n value += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 64327, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Circles from Triangles\n// CS250 Spring 2022\n\n\n\n/// These helper functions are from https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n///\n\n\nvec2 getCirclePoint(float id, float circleSegmentCount)\n{\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = ux / circleSegmentCount * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n return vec2(c, s) * radius;\n}\n\n\nvoid main()\n{\n float circleSegmentCount = 12.0;\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentCount);\n \n float pointCountPerCircle = circleSegmentCount * 6.0;\n float circleId = floor(vertexId / pointCountPerCircle);\n float circleCount = floor(vertexCount / pointCountPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0);\n \n float down = floor(sqrt(circleCount));\n float across = floor(circleCount / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = 0.0;\n float yOffset = 0.0;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.0) * mix(1.0, 1.1, oddSlice);\n sc *= 20.0 / across;\n \n vec4 pos = vec4(circleXY, 0.0, 1.0);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy, 0) * 1.4);\n mat *= rotZ(snd * 20.0 * sign(ux));\n mat *= uniformScale(0.03 * sc);\n gl_Position = mat * pos;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;\n float saturation = 1.0;\n float value = mix(0.4, pow(snd + 0.2, 5.0), pump);\n \n hue += pump * oddSlice * 0.5 + pump * 0.33;\n value += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-n23av5f69awvcnl6b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4abrmywD84XrJ5dNz/art.json b/art/4abrmywD84XrJ5dNz/art.json index 9a8c5903..3a882026 100644 --- a/art/4abrmywD84XrJ5dNz/art.json +++ b/art/4abrmywD84XrJ5dNz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 5.);\\n float r = sqrt(5. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 5.);\n float r = sqrt(5. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-ogy1d7ofns5q8iwdg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4bGAzq9dZbNPyimzo/art.json b/art/4bGAzq9dZbNPyimzo/art.json index b769cc5e..cb7cdf81 100644 --- a/art/4bGAzq9dZbNPyimzo/art.json +++ b/art/4bGAzq9dZbNPyimzo/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lin", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocItxa3CU8ttId5P4Pmbp6Gb5DFHRbIOODB20e1pJNv5kQ=s96-c", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9568627450980393,0.9411764705882353,0.9411764705882353,1],\"shader\":\"\\nfloat x0 = 0.0;\\nfloat y0 = 0.0;\\n\\nfloat x1 = 0.0;\\nfloat y1 = 0.0;\\n\\nfloat x2 = 0.5;\\nfloat y2 = 0.0;\\n\\nfloat x3 = 0.5;\\nfloat y3 = 0.0;\\n\\n\\n\\n//float x3 = 0.6;\\n//float y3 = 0.3;\\n\\n//float x4 = 0.4;\\n//float y4 = 0.5;\\n\\n// 2 ->6\\n//3 -> 6*(N-1) = 6x2 =12\\n//4 -> 6*3= 18\\n\\n\\nvoid main() {\\n \\n // test 1 :4 vertices, starts from offset:0\\n float offset =0.;\\n \\n float u_thickness = 0.1;\\n \\n \\n float id = vertexId;\\n \\n float line_i = floor(id / 6.);//line index\\n float tri_i = mod(id, 6.);// point index in two triangles\\n \\n \\n // 0 1 2 3 4 5 6 7 ..... 11 12 ......... 17 18 19 20 21 .... 24\\n // 0 0 0 0 0 0 1 1 ......1 2 ..........2 3 3 ..........3 4\\n // 0 1 2 3 4 5\\n \\n vec4 va[4];\\n \\n va[0] = vec4(x0,y0,0,1);\\n va[1] = vec4(x1,y1,0,1);\\n va[2]= vec4(x2,y2,0,1);\\n va[3] = vec4(x3,y3,0,1);\\n \\n vec2 v_line = normalize(va[2].xy-va[1].xy);\\n vec2 nv_line = vec2(-v_line.y, v_line.x);\\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\\n vec2 v_miter1 = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\\n vec2 v_miter2 = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\\n \\n vec4 pos;\\n\\tif (tri_i == 0. || tri_i == 1. || tri_i == 3.)\\n{\\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\\n vec2 v_miter = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\\n\\n pos = va[1];\\n pos.xy += v_miter * u_thickness * (tri_i == 1. ? -0.5 : 0.5) / dot(v_miter, nv_line);\\n}\\nelse\\n{\\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\\n vec2 v_miter = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\\n\\n pos = va[2];\\n pos.xy += v_miter * u_thickness * (tri_i == 5. ? 0.5 : -0.5) / dot(v_miter, nv_line);\\n}\\n \\n \\n gl_Position = vec4(pos.xy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9568627450980393, + 0.9411764705882353, + 0.9411764705882353, + 1 + ], + "shader": "\nfloat x0 = 0.0;\nfloat y0 = 0.0;\n\nfloat x1 = 0.0;\nfloat y1 = 0.0;\n\nfloat x2 = 0.5;\nfloat y2 = 0.0;\n\nfloat x3 = 0.5;\nfloat y3 = 0.0;\n\n\n\n//float x3 = 0.6;\n//float y3 = 0.3;\n\n//float x4 = 0.4;\n//float y4 = 0.5;\n\n// 2 ->6\n//3 -> 6*(N-1) = 6x2 =12\n//4 -> 6*3= 18\n\n\nvoid main() {\n \n // test 1 :4 vertices, starts from offset:0\n float offset =0.;\n \n float u_thickness = 0.1;\n \n \n float id = vertexId;\n \n float line_i = floor(id / 6.);//line index\n float tri_i = mod(id, 6.);// point index in two triangles\n \n \n // 0 1 2 3 4 5 6 7 ..... 11 12 ......... 17 18 19 20 21 .... 24\n // 0 0 0 0 0 0 1 1 ......1 2 ..........2 3 3 ..........3 4\n // 0 1 2 3 4 5\n \n vec4 va[4];\n \n va[0] = vec4(x0,y0,0,1);\n va[1] = vec4(x1,y1,0,1);\n va[2]= vec4(x2,y2,0,1);\n va[3] = vec4(x3,y3,0,1);\n \n vec2 v_line = normalize(va[2].xy-va[1].xy);\n vec2 nv_line = vec2(-v_line.y, v_line.x);\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\n vec2 v_miter1 = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\n vec2 v_miter2 = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\n \n vec4 pos;\n\tif (tri_i == 0. || tri_i == 1. || tri_i == 3.)\n{\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\n vec2 v_miter = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\n\n pos = va[1];\n pos.xy += v_miter * u_thickness * (tri_i == 1. ? -0.5 : 0.5) / dot(v_miter, nv_line);\n}\nelse\n{\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\n vec2 v_miter = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\n\n pos = va[2];\n pos.xy += v_miter * u_thickness * (tri_i == 5. ? 0.5 : -0.5) / dot(v_miter, nv_line);\n}\n \n \n gl_Position = vec4(pos.xy, 0, 1);\n \n gl_PointSize = 10.0;\n\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-abmrx2do8430wlbf0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4bXhbExsSEEwHZofJ/art.json b/art/4bXhbExsSEEwHZofJ/art.json index a206e959..7fea8a15 100644 --- a/art/4bXhbExsSEEwHZofJ/art.json +++ b/art/4bXhbExsSEEwHZofJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mattsonic", "avatarUrl": "https://secure.gravatar.com/avatar/4b4ea9969843f3808dccbabf78ea4289?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richarddevine/strum-modular-patch\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1568627450980392,0.15294117647058825,0.2627450980392157,1],\"shader\":\"// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0);\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time * 1. + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; // sin(time * 1. + x * y * 0.02) * 15.; \\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 50.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd; //sin(time * 1. + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump); // mix(0., 2., av);\\n //float val = 1. - pow(av, 4.) * pow(snd + 0.2, 5.0); // sin(time * 1. + v * u * 20.0) * 0.5 + 0.5;\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richarddevine/strum-modular-patch", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1568627450980392, + 0.15294117647058825, + 0.2627450980392157, + 1 + ], + "shader": "// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0);\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time * 1. + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; // sin(time * 1. + x * y * 0.02) * 15.; \n \n gl_PointSize = pow(snd + 0.2, 5.) * 50.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd; //sin(time * 1. + v * 20.) * 0.05;\n float sat = mix(0., 1., pump); // mix(0., 2., av);\n //float val = 1. - pow(av, 4.) * pow(snd + 0.2, 5.0); // sin(time * 1. + v * u * 20.0) * 0.5 + 0.5;\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-gbsdtp0d3ne2zwsjr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4bxrvzvhcfEAq6Qzo/art.json b/art/4bxrvzvhcfEAq6Qzo/art.json index 17f17234..13b33571 100644 --- a/art/4bxrvzvhcfEAq6Qzo/art.json +++ b/art/4bxrvzvhcfEAq6Qzo/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/zackofficial/zk-x-jw-bom-diggy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.37254901960784315,0.33725490196078434,0.8823529411764706,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.02, u), v * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2.5, s2) * 3.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n \\n \\tfloat r = pow(s2, 30.0);\\n \\tfloat g = pow(snd * time, 20.0);\\n \\tfloat b = pow(s2 * time, 40.0);\\n\\n \\n vCubeCol.rgb = mix(vec3(0.1), vec3(r,g,b), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.5;\\n float hue = 0.5 + over * 0.9;\\n float sat = step(0.55,s2);\\n float val = pow(s2, 16.);\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = time;\\n \\n // get sick!\\n \\t//ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp) * 1.5;\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1.0);\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/zackofficial/zk-x-jw-bom-diggy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.37254901960784315, + 0.33725490196078434, + 0.8823529411764706, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.02, u), v * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2.5, s2) * 3.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n \n \tfloat r = pow(s2, 30.0);\n \tfloat g = pow(snd * time, 20.0);\n \tfloat b = pow(s2 * time, 40.0);\n\n \n vCubeCol.rgb = mix(vec3(0.1), vec3(r,g,b), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.5;\n float hue = 0.5 + over * 0.9;\n float sat = step(0.55,s2);\n float val = pow(s2, 16.);\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = time;\n \n // get sick!\n \t//ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp) * 1.5;\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1.0);\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-iby3m8s70vtn6rg4s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4cc6928ASXLMQCFWy/art.json b/art/4cc6928ASXLMQCFWy/art.json index 3023f4cc..b97816a0 100644 --- a/art/4cc6928ASXLMQCFWy/art.json +++ b/art/4cc6928ASXLMQCFWy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n //float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\tvec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\t\\n\\tfor(float i = 0.5; i < 20.0; i++){\\n\\t\\t\\n\\t\\tfloat s = atan(sin(time / i )) ;\\n\\t\\tfloat c = tan(cos(time + i ));\\n\\t\\tf +=abs(0.0027 / abs(length(5.0* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n\\t//gl_FragColor = vec4(vec3(destColor * f), 1.0);\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(destColor * f), 1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n //float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\tvec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\t\n\tfor(float i = 0.5; i < 20.0; i++){\n\t\t\n\t\tfloat s = atan(sin(time / i )) ;\n\t\tfloat c = tan(cos(time + i ));\n\t\tf +=abs(0.0027 / abs(length(5.0* position *f - vec2(c, s)) -0.5));\n\t}\n\n\t//gl_FragColor = vec4(vec3(destColor * f), 1.0);\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(destColor * f), 1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-ig12z2ftg4rcz2pz4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4d6tRjx7hKBD4t7sJ/art.json b/art/4d6tRjx7hKBD4t7sJ/art.json index 74001371..619c4c07 100644 --- a/art/4d6tRjx7hKBD4t7sJ/art.json +++ b/art/4d6tRjx7hKBD4t7sJ/art.json @@ -17,7 +17,19 @@ "name": "pointsprite plasma", "private": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n \\n //c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n \\n c = (pos.x/2.0)+sin(pos.y/2.0);\\n \\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n \n //c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n \n c = (pos.x/2.0)+sin(pos.y/2.0);\n \n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-trfjx38nloshkd6kw-thumbnail.jpg", "views": { "$numberInt": "164" diff --git a/art/4e4L6TCCcTrTkKJbh/art.json b/art/4e4L6TCCcTrTkKJbh/art.json index a56915c3..8ec54125 100644 --- a/art/4e4L6TCCcTrTkKJbh/art.json +++ b/art/4e4L6TCCcTrTkKJbh/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "evilprofesseur", "avatarUrl": "https://avatars.githubusercontent.com/EvilProfesseur?s=200", - "settings": "{\"num\":62000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n\\n return mat4(\\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n\\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float circleSegmentsCount) {\\n float ux = floor(id /6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id /2.) + floor(id /3.), 2.);\\n\\n float angle = ux / circleSegmentsCount * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y); \\n}\\n\\nvoid main() {\\n float circleSegmentsCount = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentsCount);\\n \\n float pointsPerCircle = circleSegmentsCount * 6.;\\n float circleId = floor(vertexId / pointsPerCircle);\\n float circleCount = floor(vertexCount/ pointsPerCircle);\\n \\n float down = sqrt(circleCount);\\n float across = floor(circleCount / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.); \\n \\n float xOffset = 0.; //sin(time*2.1 + y * 0.2) * 0.1;\\n float yOffset = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xOffset; // switch from 0-1 to -1-1\\n float vy = v * 2. - 1. + yOffset;\\n \\n float su = abs(u- 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au* 0.125, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0 ,1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= rotZ(snd * 10.);\\n mat *= uniformScale(0.03 * sc);\\n \\n vec2 xy = circleXY * 0.02 * sc + vec2(ux, vy) *1.3; \\n \\n gl_Position = mat * pos;\\n \\n float sizeOffset = sin(time*0.7 + x * y * 0.02) * 5. + snd*15.;\\n\\n gl_PointSize = pow(snd + 0.3, 5.) * 10.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + snd *0.3 + time * 0.1;\\n float sat = smoothstep(0.1, 1.0, av);\\n float val = pow(snd + 0.2 , 4.);\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 62000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n\n return mat4(\n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n\n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float circleSegmentsCount) {\n float ux = floor(id /6.) + mod(id, 2.);\n \n float vy = mod(floor(id /2.) + floor(id /3.), 2.);\n\n float angle = ux / circleSegmentsCount * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y); \n}\n\nvoid main() {\n float circleSegmentsCount = 6.;\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentsCount);\n \n float pointsPerCircle = circleSegmentsCount * 6.;\n float circleId = floor(vertexId / pointsPerCircle);\n float circleCount = floor(vertexCount/ pointsPerCircle);\n \n float down = sqrt(circleCount);\n float across = floor(circleCount / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.); \n \n float xOffset = 0.; //sin(time*2.1 + y * 0.2) * 0.1;\n float yOffset = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xOffset; // switch from 0-1 to -1-1\n float vy = v * 2. - 1. + yOffset;\n \n float su = abs(u- 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au* 0.125, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0 ,1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= trans(vec3(ux, vy, 0));\n mat *= rotZ(snd * 10.);\n mat *= uniformScale(0.03 * sc);\n \n vec2 xy = circleXY * 0.02 * sc + vec2(ux, vy) *1.3; \n \n gl_Position = mat * pos;\n \n float sizeOffset = sin(time*0.7 + x * y * 0.02) * 5. + snd*15.;\n\n gl_PointSize = pow(snd + 0.3, 5.) * 10.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + snd *0.3 + time * 0.1;\n float sat = smoothstep(0.1, 1.0, av);\n float val = pow(snd + 0.2 , 4.);\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-ql00txi9pr81ny1h2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4erk8kqXtJp9XeGP8/art.json b/art/4erk8kqXtJp9XeGP8/art.json index 29b57323..0ac1d934 100644 --- a/art/4erk8kqXtJp9XeGP8/art.json +++ b/art/4erk8kqXtJp9XeGP8/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "_", "avatarUrl": "https://lh5.googleusercontent.com/-WhjaBaRQHKg/AAAAAAAAAAI/AAAAAAAAA30/g0IE77SdmOk/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bossfightswe/milky-ways\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t: Eunjin Hong\\nAssignment Name/Number\\t: Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n\\n//Don't know the reason why but the music doesn't work very often...\\n\\nvoid main() {\\n \\n float snd = texture2D(sound, vec2(mouse.x)).a;\\n float x = mod(vertexId, 10.);\\n \\n gl_Position = vec4(snd*mouse.x*x, 0, 0, 1);\\n gl_PointSize = abs(sin(time))*snd*50.+20.;\\n\\n v_color = vec4(abs(sin(snd)),abs(cos(snd)),abs(tan(snd)),1.0);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/bossfightswe/milky-ways", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t: Eunjin Hong\nAssignment Name/Number\t: Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n\n//Don't know the reason why but the music doesn't work very often...\n\nvoid main() {\n \n float snd = texture2D(sound, vec2(mouse.x)).a;\n float x = mod(vertexId, 10.);\n \n gl_Position = vec4(snd*mouse.x*x, 0, 0, 1);\n gl_PointSize = abs(sin(time))*snd*50.+20.;\n\n v_color = vec4(abs(sin(snd)),abs(cos(snd)),abs(tan(snd)),1.0);\n \n}" + }, "screenshotURL": "data/images/images-ws4tvopgjjds46899-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4fpR5Na5QhyEeF2yw/art.json b/art/4fpR5Na5QhyEeF2yw/art.json index 7cc454f5..d84148f4 100644 --- a/art/4fpR5Na5QhyEeF2yw/art.json +++ b/art/4fpR5Na5QhyEeF2yw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":12280,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.08235294117647059,0.08235294117647059,1],\"shader\":\"\\n#define parameter0 0.//KParameter 0.>>6.\\n#define P2 -3.//KParameter -5.>>10.\\n#define P3 0.1//KParameter 0.1>>3.\\n#define P6 9.//KParameter 0.1>>10.\\n#define P5 1.//KParameter -1.>>1.\\n#define P4 0.5//KParameter 0.0>>1.\\n\\n//KVerticesNumber=880\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,0.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.2); \\n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 12. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.25;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 12.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down*3.);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 4.) * r;\\n \\n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mouse.x *3.0) + 2.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *.01;\\n float sat = P4;\\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 12280, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.08235294117647059, + 0.08235294117647059, + 1 + ], + "shader": "\n#define parameter0 0.//KParameter 0.>>6.\n#define P2 -3.//KParameter -5.>>10.\n#define P3 0.1//KParameter 0.1>>3.\n#define P6 9.//KParameter 0.1>>10.\n#define P5 1.//KParameter -1.>>1.\n#define P4 0.5//KParameter 0.0>>1.\n\n//KVerticesNumber=880\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,0.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.2); \n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 12. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.25;\n float down = numQuads / around;\n float quadId = floor(vertexId / 12.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down*3.);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 4.) * r;\n \n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mouse.x *3.0) + 2.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *.01;\n float sat = P4;\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-6i34uti1b0px8ixkb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4h35MHPA2dwXFTJHy/art.json b/art/4h35MHPA2dwXFTJHy/art.json index 24a31a32..91aeee38 100644 --- a/art/4h35MHPA2dwXFTJHy/art.json +++ b/art/4h35MHPA2dwXFTJHy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n vec4 pos = vec4(-1.0, sin(2.0*time + vertexId * 0.005)-0.5 * 0.8, 0.0, 1.0);\\n gl_PointSize = 15.0;\\n gl_Position = pos + vertexId*0.0006;\\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0) + 0.5;\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n vec4 pos = vec4(-1.0, sin(2.0*time + vertexId * 0.005)-0.5 * 0.8, 0.0, 1.0);\n gl_PointSize = 15.0;\n gl_Position = pos + vertexId*0.0006;\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0) + 0.5;\n}" + }, "screenshotURL": "data/images/images-3vwwhlmtxdzqqq6e2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4mJdoLcvvmmvbPjdB/art.json b/art/4mJdoLcvvmmvbPjdB/art.json index 834a2002..0cfcbf11 100644 --- a/art/4mJdoLcvvmmvbPjdB/art.json +++ b/art/4mJdoLcvvmmvbPjdB/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "whiskey-bravo", "avatarUrl": "https://avatars.githubusercontent.com/Whiskey-Bravo?s=200", - "settings": "{\"num\":1185,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\t\\n \\n float xoff = sin(time + y * .2) * .1;\\n float yoff = sin(time + x * .2) * .5;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux , vy) * .3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(u, 1, v, 1);\\n \\n}\"}", + "settings": { + "num": 1185, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\t\n \n float xoff = sin(time + y * .2) * .1;\n float yoff = sin(time + x * .2) * .5;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux , vy) * .3;\n \n gl_Position = vec4(xy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(u, 1, v, 1);\n \n}" + }, "screenshotURL": "data/images/images-oljkelfg99jurrhtu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4mMg6kQXSNiEDkuwR/art.json b/art/4mMg6kQXSNiEDkuwR/art.json index 7562714f..1101ace4 100644 --- a/art/4mMg6kQXSNiEDkuwR/art.json +++ b/art/4mMg6kQXSNiEDkuwR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":1891,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/djipi69/abba-chiquitita?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\\n vec4 K = vec4(3.0, 6.0 / 9.0, 5.0 / 10.0, 9.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float pci = mod(abs(vertexId / STEP) * PI, NUM_POINTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset / pci;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 9.5;\\n float innerRadius = count * .01;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius / pci;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius / pci;\\n\\n vec2 aspect = vec2(-1, resolution.x / resolution.y + pci);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 1891, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/djipi69/abba-chiquitita?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\n vec4 K = vec4(3.0, 6.0 / 9.0, 5.0 / 10.0, 9.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float pci = mod(abs(vertexId / STEP) * PI, NUM_POINTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset / pci;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 9.5;\n float innerRadius = count * .01;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius / pci;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius / pci;\n\n vec2 aspect = vec2(-1, resolution.x / resolution.y + pci);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-3nmwhhmgzxc2wgvv4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4mzMqjbsbYgxDQKFf/art.json b/art/4mzMqjbsbYgxDQKFf/art.json index 656c4281..fcfcd88c 100644 --- a/art/4mzMqjbsbYgxDQKFf/art.json +++ b/art/4mzMqjbsbYgxDQKFf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3(2.+mouse.x*10. , 40.3*mouse.y, 0.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 1.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 10.6, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, -mouse.t );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( mouse.x, 11.0+\\n mouse.y );\\n\\n quadId = floor( vertexIndex / 16.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 1.+time*0.001 - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 10.*time;\\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(3, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 1.;//0.5 + over * 0.7;\\n float sat = step(0.25,s2)*3.;\\n float val = pow(s2*0.01,0.3);\\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 00.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3(2.+mouse.x*10. , 40.3*mouse.y, 0.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 1.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 10.6, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, -mouse.t );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( mouse.x, 11.0+\n mouse.y );\n\n quadId = floor( vertexIndex / 16.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 1.+time*0.001 - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\n \n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 10.*time;\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(3, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 1.;//0.5 + over * 0.7;\n float sat = step(0.25,s2)*3.;\n float val = pow(s2*0.01,0.3);\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 00.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\n \tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-2xyojbjixuplu0e56-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4qDhPQsi7RfmX6Ncw/art.json b/art/4qDhPQsi7RfmX6Ncw/art.json index 0b5faabe..7fcedc09 100644 --- a/art/4qDhPQsi7RfmX6Ncw/art.json +++ b/art/4qDhPQsi7RfmX6Ncw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/platform/carl-cox-45-min-boiler-room\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 20.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.7)/20.0;\\n //float lum = floor(v *30.0 + 0.9)/5.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\\n /*vec2 soundTexCoords = vec2(0, 0);\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n*/\\n v_color = vec4(v*lum*0.5,lum*0.1,lum*1.0,1);\\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\\n\\n\\n \\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/platform/carl-cox-45-min-boiler-room", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 20.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.7)/20.0;\n //float lum = floor(v *30.0 + 0.9)/5.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\n /*vec2 soundTexCoords = vec2(0, 0);\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n*/\n v_color = vec4(v*lum*0.5,lum*0.1,lum*1.0,1);\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\n\n\n \n}" + }, "screenshotURL": "data/images/images-mtwjoodj78egcka1r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4rzpKJ43tFQEsLBkP/art.json b/art/4rzpKJ43tFQEsLBkP/art.json index 59c783d8..e2ab04b6 100644 --- a/art/4rzpKJ43tFQEsLBkP/art.json +++ b/art/4rzpKJ43tFQEsLBkP/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 15.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.7)/30.0;\\n //float lum = floor(v *30.0 + 0.9)/5.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\\n /*vec2 soundTexCoords = vec2(0, 0);\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n*/\\n v_color = vec4(v*lum*0.6,lum*0.2,lum*1.0,1);\\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\\n\\n\\n \\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 15.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.7)/30.0;\n //float lum = floor(v *30.0 + 0.9)/5.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\n /*vec2 soundTexCoords = vec2(0, 0);\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n*/\n v_color = vec4(v*lum*0.6,lum*0.2,lum*1.0,1);\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\n\n\n \n}" + }, "screenshotURL": "data/images/images-0g12c9g892yeeokla-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4tdHwGGpfKN7AQpoQ/art.json b/art/4tdHwGGpfKN7AQpoQ/art.json index c5d576f9..e3567564 100644 --- a/art/4tdHwGGpfKN7AQpoQ/art.json +++ b/art/4tdHwGGpfKN7AQpoQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2524,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8784313725490196,0.9333333333333333,0.8313725490196079,1],\"shader\":\"\\nvoid main(){\\n \\n vec2 xy =vec2(-0.5,0);\\n if (vertexId == 1.0)\\n {\\n xy=vec2(0,0.5);\\n }\\n \\n else if(vertexId == 2.0)\\n {\\n xy = vec2(0.5,0);\\n }\\n xy +=vec2(0,sin(time));\\n gl_Position = vec4(xy,0.0,1.0);\\n gl_PointSize =10.0;\\n \\n v_color = vec4(1.0,0.0,0.0,1.0);\\n \\n \\n }\"}", + "settings": { + "num": 2524, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8784313725490196, + 0.9333333333333333, + 0.8313725490196079, + 1 + ], + "shader": "\nvoid main(){\n \n vec2 xy =vec2(-0.5,0);\n if (vertexId == 1.0)\n {\n xy=vec2(0,0.5);\n }\n \n else if(vertexId == 2.0)\n {\n xy = vec2(0.5,0);\n }\n xy +=vec2(0,sin(time));\n gl_Position = vec4(xy,0.0,1.0);\n gl_PointSize =10.0;\n \n v_color = vec4(1.0,0.0,0.0,1.0);\n \n \n }" + }, "screenshotURL": "data/images/images-xawtx1iyojqtfrxhk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4uB9s4qnD3rioJw9B/art.json b/art/4uB9s4qnD3rioJw9B/art.json index 39ff33da..b2cc2016 100644 --- a/art/4uB9s4qnD3rioJw9B/art.json +++ b/art/4uB9s4qnD3rioJw9B/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alexisrubio96", "avatarUrl": "https://avatars.githubusercontent.com/AlexisRubio96?s=200", - "settings": "{\"num\":8,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n \\n \\tfloat x = floor(vertexId / 2.0); \\n\\tfloat y = mod(vertexId + 1.0, 2.0);\\n \\n \\tvec2 xy = vec2(x,y)*1.0;\\n \\n\\tgl_Position = vec4(x, y, 0.0,10.0);\\t\\t//Posición final de un vertice\\n \\tv_color = vec4(1.0,0.0,0.0,1.0);\\n \\tgl_PointSize = 1.0;\\n\\n}\"}", + "settings": { + "num": 8, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n \n \tfloat x = floor(vertexId / 2.0); \n\tfloat y = mod(vertexId + 1.0, 2.0);\n \n \tvec2 xy = vec2(x,y)*1.0;\n \n\tgl_Position = vec4(x, y, 0.0,10.0);\t\t//Posición final de un vertice\n \tv_color = vec4(1.0,0.0,0.0,1.0);\n \tgl_PointSize = 1.0;\n\n}" + }, "screenshotURL": "data/images/images-237fuub035h1kz3j5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4uK5xMjmxCZaGBewc/art.json b/art/4uK5xMjmxCZaGBewc/art.json index 9d455f9c..3738330c 100644 --- a/art/4uK5xMjmxCZaGBewc/art.json +++ b/art/4uK5xMjmxCZaGBewc/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/majorlazer/major-lazer-dj-snake-lean-on-feat-mo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5019607843137255,1,1,1],\"shader\":\"\\nvoid main() {\\n\\tgl_PointSize = 10.0;\\n \\tgl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "LINES", + "sound": "https://soundcloud.com/majorlazer/major-lazer-dj-snake-lean-on-feat-mo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5019607843137255, + 1, + 1, + 1 + ], + "shader": "\nvoid main() {\n\tgl_PointSize = 10.0;\n \tgl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-gwrffjwcfdyraxj0u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4urf28npgTBytwhyv/art.json b/art/4urf28npgTBytwhyv/art.json index 7f3ba339..926d6fba 100644 --- a/art/4urf28npgTBytwhyv/art.json +++ b/art/4urf28npgTBytwhyv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n \\n //apply fragment logic\\n\\nvec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 uv1=(p.xy*2.-res.xy)/min(res.x,res.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.1),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n \n //apply fragment logic\n\nvec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 uv1=(p.xy*2.-res.xy)/min(res.x,res.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.1),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-o9f6od6dvvhdfluwd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4vag7ndH4zPYNfMML/art.json b/art/4vag7ndH4zPYNfMML/art.json index 6442485c..969c6aff 100644 --- a/art/4vag7ndH4zPYNfMML/art.json +++ b/art/4vag7ndH4zPYNfMML/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n float n = vertexId / vertexCount;\\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \\n float angle = n * 6.28;\\n \\n float avx = 0.5;\\n float axy = 0.5;\\n \\n float dx = cos(angle * time * avx) * vertexId / 1000.0;\\n float dy = sin(angle * time * axy) * vertexId / 1000.0;\\n \\n gl_Position = vec4(dx, dy, 0.0, 1);\\n gl_PointSize = vertexId / 50.0;\\n v_color = vec4(snd.a * snd.b, snd.b * snd.b, n, 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n float n = vertexId / vertexCount;\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \n float angle = n * 6.28;\n \n float avx = 0.5;\n float axy = 0.5;\n \n float dx = cos(angle * time * avx) * vertexId / 1000.0;\n float dy = sin(angle * time * axy) * vertexId / 1000.0;\n \n gl_Position = vec4(dx, dy, 0.0, 1);\n gl_PointSize = vertexId / 50.0;\n v_color = vec4(snd.a * snd.b, snd.b * snd.b, n, 1.0);\n}" + }, "screenshotURL": "data/images/images-u3qblcalfprz1x8uf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4x6bYtKoRF9gPWHAb/art.json b/art/4x6bYtKoRF9gPWHAb/art.json index ba8f404c..cf17c69e 100644 --- a/art/4x6bYtKoRF9gPWHAb/art.json +++ b/art/4x6bYtKoRF9gPWHAb/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "willy", "avatarUrl": "https://graph.facebook.com/10100732765030221/picture?type=large", - "settings": "{\"num\":551,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"\\nvoid main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat ux = u * 2. - 1.;\\n \\tfloat vy = v * 2. - 1.;\\n \\n\\tgl_Position = vec4(ux, vy, 0, 1);\\n \\tgl_PointSize = 10.0;\\n \\tgl_PointSize *= 20./ across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\tv_color = vec4(1.0, 0, 0, 1);\\n}\"}", + "settings": { + "num": 551, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "\nvoid main() {\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.0);\n \n \tfloat ux = u * 2. - 1.;\n \tfloat vy = v * 2. - 1.;\n \n\tgl_Position = vec4(ux, vy, 0, 1);\n \tgl_PointSize = 10.0;\n \tgl_PointSize *= 20./ across;\n \tgl_PointSize *= resolution.x / 600.;\n \tv_color = vec4(1.0, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-dbzsy7oxa24xpr3cn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/4zASqsiiCDuSJRntr/art.json b/art/4zASqsiiCDuSJRntr/art.json index 8ef373d9..e9694034 100644 --- a/art/4zASqsiiCDuSJRntr/art.json +++ b/art/4zASqsiiCDuSJRntr/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":82287,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07450980392156863,0.06666666666666667,0.07058823529411765,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\\n#define STEP 0.10\\n\\nvoid main() {\\n float point = mod(floor(vertexId /9.0) + mod(vertexId,33.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.1) + 1.0;\\n float angle = point * PI * .8 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014,0.8);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle +time) * sin(radius/ 7.);\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s );\\n gl_Position = vec4(xy -aspect - mouse * 0.1, 0.4, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.35 + 0.5, 10.0);\\n b = 0.4;mix(0.6, 0.7, b);\\n v_color = vec4(0.9, sin(b *time), b/3., 1);\\n}\"}", + "settings": { + "num": 82287, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07450980392156863, + 0.06666666666666667, + 0.07058823529411765, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\n#define STEP 0.10\n\nvoid main() {\n float point = mod(floor(vertexId /9.0) + mod(vertexId,33.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.1) + 1.0;\n float angle = point * PI * .8 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014,0.8);\n float c = cos(angle + time) * radius;\n float s = sin(angle +time) * sin(radius/ 7.);\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s );\n gl_Position = vec4(xy -aspect - mouse * 0.1, 0.4, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.35 + 0.5, 10.0);\n b = 0.4;mix(0.6, 0.7, b);\n v_color = vec4(0.9, sin(b *time), b/3., 1);\n}" + }, "screenshotURL": "data/images/images-cvzm7snauyq1yyez6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/4zqMb55NkrGEgRcKc/art.json b/art/4zqMb55NkrGEgRcKc/art.json index 24db167b..4a2ae419 100644 --- a/art/4zqMb55NkrGEgRcKc/art.json +++ b/art/4zqMb55NkrGEgRcKc/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":91125,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/funkstorungofficial/funkstoerung-think-feat?utm_campaign=social_sharing&utm_source=mobi&utm_terms=pfy_plays_part_2.control\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 5.0\\n\\n#define PI 3.1415\\n\\n#define RESOLUTION vec3(45.0)\\n#define SIZE vec3(1.5)\\n\\n// New hash based on hash13() from \\\"Hash without Sine\\\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\\n// 4 in, 1 out\\nfloat Hash41(in vec4 p) {\\n\\tp = fract(p * 0.1031);\\n p += dot(p, p.zwyx + 31.32);\\n return fract((p.x + p.y) * p.z - p.x * p.w);\\n}\\n\\n\\nfloat SmoothNoise4D(in vec4 p) {\\n vec4 cell = floor(p);\\n vec4 local = fract(p);\\n local *= local * (3.0 - 2.0 * local);\\n\\n float ldbq = Hash41(cell);\\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\\n float rufw = Hash41(cell + 1.0);\\n\\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\\n mix(lubq, rubq, local.x),\\n local.y),\\n\\n mix(mix(ldfq, rdfq, local.x),\\n mix(lufq, rufq, local.x),\\n local.y),\\n\\n local.z),\\n\\n mix(mix(mix(ldbw, rdbw, local.x),\\n mix(lubw, rubw, local.x),\\n local.y),\\n\\n mix(mix(ldfw, rdfw, local.x),\\n mix(lufw, rufw, local.x),\\n local.y),\\n\\n local.z),\\n\\n local.w);\\n}\\n\\nfloat FractalNoise4D(in vec4 p) {\\n p *= 2.0;\\n\\n float nscale = 1.0;\\n float tscale = 0.0;\\n float value = 0.0;\\n\\n for (int octave=0; octave < 5; octave++) {\\n value += SmoothNoise4D(p) * nscale;\\n tscale += nscale;\\n nscale *= 0.5;\\n p *= 2.0;\\n }\\n\\n return value / tscale;\\n}\\n\\nfloat mapShape(vec3 p) {\\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\\n}\\n\\nvec3 mapColor(in vec3 p) {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\\n vec2 e = vec2(0.001, 0.0);\\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\\n\\n return vec3(max(0.0, dot(normal, lightDir)) + 0.1);\\n}\\n\\nvoid main() {\\n float t = time * 0.25;\\n\\n float cellId = vertexId;\\n float gridX = mod(cellId, RESOLUTION.x);\\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\\n\\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\\n vec3 color = mapColor(vertex);\\n\\n vec2 mouseRot = mouse * PI;\\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, .80);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 91125, + "mode": "POINTS", + "sound": "https://soundcloud.com/funkstorungofficial/funkstoerung-think-feat?utm_campaign=social_sharing&utm_source=mobi&utm_terms=pfy_plays_part_2.control", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 5.0\n\n#define PI 3.1415\n\n#define RESOLUTION vec3(45.0)\n#define SIZE vec3(1.5)\n\n// New hash based on hash13() from \"Hash without Sine\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\n// 4 in, 1 out\nfloat Hash41(in vec4 p) {\n\tp = fract(p * 0.1031);\n p += dot(p, p.zwyx + 31.32);\n return fract((p.x + p.y) * p.z - p.x * p.w);\n}\n\n\nfloat SmoothNoise4D(in vec4 p) {\n vec4 cell = floor(p);\n vec4 local = fract(p);\n local *= local * (3.0 - 2.0 * local);\n\n float ldbq = Hash41(cell);\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\n float rufw = Hash41(cell + 1.0);\n\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\n mix(lubq, rubq, local.x),\n local.y),\n\n mix(mix(ldfq, rdfq, local.x),\n mix(lufq, rufq, local.x),\n local.y),\n\n local.z),\n\n mix(mix(mix(ldbw, rdbw, local.x),\n mix(lubw, rubw, local.x),\n local.y),\n\n mix(mix(ldfw, rdfw, local.x),\n mix(lufw, rufw, local.x),\n local.y),\n\n local.z),\n\n local.w);\n}\n\nfloat FractalNoise4D(in vec4 p) {\n p *= 2.0;\n\n float nscale = 1.0;\n float tscale = 0.0;\n float value = 0.0;\n\n for (int octave=0; octave < 5; octave++) {\n value += SmoothNoise4D(p) * nscale;\n tscale += nscale;\n nscale *= 0.5;\n p *= 2.0;\n }\n\n return value / tscale;\n}\n\nfloat mapShape(vec3 p) {\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\n}\n\nvec3 mapColor(in vec3 p) {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\n vec2 e = vec2(0.001, 0.0);\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\n\n return vec3(max(0.0, dot(normal, lightDir)) + 0.1);\n}\n\nvoid main() {\n float t = time * 0.25;\n\n float cellId = vertexId;\n float gridX = mod(cellId, RESOLUTION.x);\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\n\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\n vec3 color = mapColor(vertex);\n\n vec2 mouseRot = mouse * PI;\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, .80);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-myy1syb4q8kdohx2s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/52MHKPZusfZtpjueA/art.json b/art/52MHKPZusfZtpjueA/art.json index fc686801..ade69932 100644 --- a/art/52MHKPZusfZtpjueA/art.json +++ b/art/52MHKPZusfZtpjueA/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "tomjakubowski", "avatarUrl": "https://avatars.githubusercontent.com/tomjakubowski?s=200", - "settings": "{\"num\":500,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat line(float id, float count) {\\n // x: 0.0 1/n 2/n 3/n .. n/n n/n\\n float x = id / (count - 1.0);\\n return x;\\n}\\n\\nvec2 grid(float id, float count) {\\n // x: 0.0 0.0 1/n 1/n 2/n 2/n 3/n 3/n .. n/n n/n\\n // y: 0.0 1.0 0.0 1.0 0.0 1.0 0.0 1.0 .. 0.0 1.0\\n // float x = id / (count - 1.0);\\n float d = 2.0;\\n float d_inv = 1.0/d;\\n float x = floor(d_inv * id) / (d_inv * count - 0.5);\\n float y = mod(id, d);\\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n vec2 pos = grid(vertexId, vertexCount);\\n float t = pos.x;\\n gl_Position = vec4(pos.x, 0.1 * pos.y, 0.0, 1.0);\\n gl_PointSize = 8.0;\\n v_color = 0.5 * vec4(hsv2rgb(vec3(t+time, 1.0, 1.0)), 1.0);\\n}\"}", + "settings": { + "num": 500, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat line(float id, float count) {\n // x: 0.0 1/n 2/n 3/n .. n/n n/n\n float x = id / (count - 1.0);\n return x;\n}\n\nvec2 grid(float id, float count) {\n // x: 0.0 0.0 1/n 1/n 2/n 2/n 3/n 3/n .. n/n n/n\n // y: 0.0 1.0 0.0 1.0 0.0 1.0 0.0 1.0 .. 0.0 1.0\n // float x = id / (count - 1.0);\n float d = 2.0;\n float d_inv = 1.0/d;\n float x = floor(d_inv * id) / (d_inv * count - 0.5);\n float y = mod(id, d);\n return vec2(x, y);\n}\n\nvoid main() {\n vec2 pos = grid(vertexId, vertexCount);\n float t = pos.x;\n gl_Position = vec4(pos.x, 0.1 * pos.y, 0.0, 1.0);\n gl_PointSize = 8.0;\n v_color = 0.5 * vec4(hsv2rgb(vec3(t+time, 1.0, 1.0)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ftir3w8jplspdsab6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/54TbvMsANMi2nBuBA/art.json b/art/54TbvMsANMi2nBuBA/art.json index d1d9c524..385eb4bb 100644 --- a/art/54TbvMsANMi2nBuBA/art.json +++ b/art/54TbvMsANMi2nBuBA/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "andres", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mDpq0XfBHMszPefmGBgB79WY81ZkieVhYip5MKu", - "settings": "{\"num\":55853,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.30196078431372547,0.13333333333333333,0.7058823529411765,1],\"shader\":\"\\n\\n\\n\\n// mats\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\nvoid main() {\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount/ down);\\n \\n\\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId / across);\\n\\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n\\n \\tfloat xoff = sin(time + y * .2) * 0.1;\\n \\tfloat yoff = sin(time + x * .3) * 0.2;\\n\\n \\t\\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n\\tvec2 xy = vec2(ux,vy) * 1.3;\\n \\n\\n float sv = abs(v - 0.5) * 2.;\\n \\tfloat su = abs(u - 0.5) * 2.;\\n \\tfloat au = abs(atan(su,sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n\\n\\tfloat snd = texture2D(sound, vec2(su * .125, sv * .25)).a;\\n \\t\\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = snd * 30. + soff;\\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n\\n \\tfloat pump= step(0.8, snd);\\n \\tfloat hue = u * .1 + snd * 0.2 + time; // u * .1 + sin(time + v * 20.) * 0.05;\\n \\tfloat sat = mix(0., 1., pump); // mix(1., -10., av);\\n \\tfloat val = pow(snd + 0.2, 5.); // 1.; // sin(time + v * u *20.0) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n \\n}\\n\"}", + "settings": { + "num": 55853, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.30196078431372547, + 0.13333333333333333, + 0.7058823529411765, + 1 + ], + "shader": "\n\n\n\n// mats\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\nvoid main() {\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount/ down);\n \n\tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId / across);\n\n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n\n \tfloat xoff = sin(time + y * .2) * 0.1;\n \tfloat yoff = sin(time + x * .3) * 0.2;\n\n \t\n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n\tvec2 xy = vec2(ux,vy) * 1.3;\n \n\n float sv = abs(v - 0.5) * 2.;\n \tfloat su = abs(u - 0.5) * 2.;\n \tfloat au = abs(atan(su,sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n\n\tfloat snd = texture2D(sound, vec2(su * .125, sv * .25)).a;\n \t\n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = snd * 30. + soff;\n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n\n \tfloat pump= step(0.8, snd);\n \tfloat hue = u * .1 + snd * 0.2 + time; // u * .1 + sin(time + v * 20.) * 0.05;\n \tfloat sat = mix(0., 1., pump); // mix(1., -10., av);\n \tfloat val = pow(snd + 0.2, 5.); // 1.; // sin(time + v * u *20.0) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n \n}\n" + }, "screenshotURL": "data/images/images-e5zyzgiv4qzkf7kdw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/54ZGebYmzcwbkmgpF/art.json b/art/54ZGebYmzcwbkmgpF/art.json index f82c77a3..99171c61 100644 --- a/art/54ZGebYmzcwbkmgpF/art.json +++ b/art/54ZGebYmzcwbkmgpF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":11263,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 11263, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-6sgri1m9mufzgy74n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/55mQ247kbQXRdrMkJ/art.json b/art/55mQ247kbQXRdrMkJ/art.json index ef4350db..468a09cf 100644 --- a/art/55mQ247kbQXRdrMkJ/art.json +++ b/art/55mQ247kbQXRdrMkJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 20\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n \\n \\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n \\n ///\\n float snd = texture2D(sound, vec2(0.1, 0.)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n vec2 p = vec2(ux , vy);\\n float z = fract(0.1+snd);\\n //float z = fract(0.6*mouse.x);\\n int acc = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n//p.x+=0.5;\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float a = mix(1., 3.75-snd2, trig) + p.x * mix(3., 0.25-snd3, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n acc += (z > p.y && z <= p.y + 1. / resolution.y) ? 1 : 0;\\n z = a * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(acc) / iters;\\n\\n //if(ux>0)\\n //g=1.-g;\\n //fragColor = vec4(g, g /3., g / 8.,1.);\\n ///\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 4.;\\n //gl_PointSize *= 10.0 / across;\\n //gl_PointSize *= resolution.x / 600.0;\\n \\n //v_color = vec4(1, 1, 1, 1);\\n \\n //v_color = vec4(g, g , g , 1.);\\n v_color = vec4(g, g /3., g / 8.,1.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 20\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n \n \n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n \n ///\n float snd = texture2D(sound, vec2(0.1, 0.)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n vec2 p = vec2(ux , vy);\n float z = fract(0.1+snd);\n //float z = fract(0.6*mouse.x);\n int acc = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n//p.x+=0.5;\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float a = mix(1., 3.75-snd2, trig) + p.x * mix(3., 0.25-snd3, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n acc += (z > p.y && z <= p.y + 1. / resolution.y) ? 1 : 0;\n z = a * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(acc) / iters;\n\n //if(ux>0)\n //g=1.-g;\n //fragColor = vec4(g, g /3., g / 8.,1.);\n ///\n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 4.;\n //gl_PointSize *= 10.0 / across;\n //gl_PointSize *= resolution.x / 600.0;\n \n //v_color = vec4(1, 1, 1, 1);\n \n //v_color = vec4(g, g , g , 1.);\n v_color = vec4(g, g /3., g / 8.,1.);\n}" + }, "screenshotURL": "data/images/images-fp2dk7mkrzm3qkmr2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/55nRorvcAYfSEYJhZ/art.json b/art/55nRorvcAYfSEYJhZ/art.json index 69df46c2..c3a27fb1 100644 --- a/art/55nRorvcAYfSEYJhZ/art.json +++ b/art/55nRorvcAYfSEYJhZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.6,1,1],\"shader\":\"#define PI radians(180.5)\\n#define NUM_SEGMENTS 4.50\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0) + 5.0\\n#define STEP 15.6\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle / count + 5.5 + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle / count + time + count * 5.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.6, + 1, + 1 + ], + "shader": "#define PI radians(180.5)\n#define NUM_SEGMENTS 4.50\n#define NUM_POINTS (NUM_SEGMENTS * 2.0) + 5.0\n#define STEP 15.6\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle / count + 5.5 + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle / count + time + count * 5.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ec19nxkvgvj12vj8n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/57DGNjDnDYwrBWXqD/art.json b/art/57DGNjDnDYwrBWXqD/art.json index 9823cf86..f4f5b936 100644 --- a/art/57DGNjDnDYwrBWXqD/art.json +++ b/art/57DGNjDnDYwrBWXqD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/silverdedalus/mechanical\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.984313725490196,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \\n out vec3 pos, out vec3 nrm, out vec2 uv) {\\n float numQuads = floor(vertexCount / 6.);\\n float down = numQuads / around;\\n float quadId = floor(float(vertexId) / 6.);\\n\\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n\\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n\\n float edgeId = mod(float(vertexId), 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\\n\\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n\\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n\\n pos = vec3(x, cos(qv * PI), z);\\n nrm = normalize(pos);\\n uv = vec2(qu, qv);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(0);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n vec2 uv;\\n float around = 12.0;\\n float down = 6.0;\\n float vertsPerSphere = around * down * 6.;\\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\\n float cubeId = floor(pointId / vertsPerSphere);\\n float maxCubes = floor(vertexCount / vertsPerSphere);\\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = (cv);\\n //su = hash(cubeId / maxCubes);\\n float s1 = texture2D(sound, vec2(mix(.05, .00, fract(su + 1.0)), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(.06, .01, fract(su + 0.8)), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(.07, .02, fract(su + 0.6)), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(.08, .03, fract(su + 0.4)), 3. / soundRes.y)).a;\\n \\n float s = max(max(max(s1, s2), s3), s4);mix(0.0, 0.25, s1 + s2 + s3 + s4);\\n \\n float tm = time * .1;\\n float r = 50.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n float r2 = mix(25., 50., sin(cv * PI * 2. + time) * 0.5 + 0.5);\\n mat *= rotX(tm);\\n mat *= lookAt(loc * r2, vec3(0), up);\\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\\n// mat *= trans(vec3(0, 0, 1));\\n// mat *= rotZ(s * PI * 2.);\\n mat *= uniformScale(5.0 + pow(s, 5.) * 5.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = 1.05 + pow(s, 5.) * -.15 + uv.y * .1;\\n float sat = 1.2; + s;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt, 1);\\n// v_color.a = s;\\n v_color.rgb *= v_color.a; \\n// if (s < .2) {\\n// gl_Position.z = 10000.;\\n// }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/silverdedalus/mechanical", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.984313725490196, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \n out vec3 pos, out vec3 nrm, out vec2 uv) {\n float numQuads = floor(vertexCount / 6.);\n float down = numQuads / around;\n float quadId = floor(float(vertexId) / 6.);\n\n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n\n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n\n float edgeId = mod(float(vertexId), 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\n\n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n\n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n\n pos = vec3(x, cos(qv * PI), z);\n nrm = normalize(pos);\n uv = vec2(qu, qv);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(0);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n vec2 uv;\n float around = 12.0;\n float down = 6.0;\n float vertsPerSphere = around * down * 6.;\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\n float cubeId = floor(pointId / vertsPerSphere);\n float maxCubes = floor(vertexCount / vertsPerSphere);\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = (cv);\n //su = hash(cubeId / maxCubes);\n float s1 = texture2D(sound, vec2(mix(.05, .00, fract(su + 1.0)), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(.06, .01, fract(su + 0.8)), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(.07, .02, fract(su + 0.6)), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(.08, .03, fract(su + 0.4)), 3. / soundRes.y)).a;\n \n float s = max(max(max(s1, s2), s3), s4);mix(0.0, 0.25, s1 + s2 + s3 + s4);\n \n float tm = time * .1;\n float r = 50.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n float r2 = mix(25., 50., sin(cv * PI * 2. + time) * 0.5 + 0.5);\n mat *= rotX(tm);\n mat *= lookAt(loc * r2, vec3(0), up);\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\n// mat *= trans(vec3(0, 0, 1));\n// mat *= rotZ(s * PI * 2.);\n mat *= uniformScale(5.0 + pow(s, 5.) * 5.);\n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = 1.05 + pow(s, 5.) * -.15 + uv.y * .1;\n float sat = 1.2; + s;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt, 1);\n// v_color.a = s;\n v_color.rgb *= v_color.a; \n// if (s < .2) {\n// gl_Position.z = 10000.;\n// }\n}\n\n" + }, "screenshotURL": "data/images/images-sj86fly75hzdz7wct-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/57eTciQiKd6wT2ndd/art.json b/art/57eTciQiKd6wT2ndd/art.json index 4936d0c6..72cacfad 100644 --- a/art/57eTciQiKd6wT2ndd/art.json +++ b/art/57eTciQiKd6wT2ndd/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":60,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n\\n#define AND(a,x) int(floor(x - (a * 16.0)))\\n#define MASK 1024.0\\n#define SCALE 112.0\\n#define MAX_TRIS 32\\n#define TOTAL_TRI 21\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec3 triangles[MAX_TRIS];\\nmat4 indices[4];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid populate(){ \\n\\n#define V1 18451.0\\n#define V2 7169.0\\n#define V3 46.0\\n#define V4 22588.0\\n#define V5 75.0\\n#define V6 18534.0\\n#define V7 7288.0\\n#define V8 54525998.0\\n#define V9 54526027.0\\n#define V10 19930228.0\\n#define V11 19930116.0\\n#define V12 31473724.0\\n\\ntriangles[0]=vec3(V1,V2,V3);\\ntriangles[1]=vec3(V3,V1,V4);\\ntriangles[2]=vec3(V4,V3,V5);\\ntriangles[3]=vec3(V5,V4,V6);\\ntriangles[4]=vec3(V6,V5,V7);\\ntriangles[5]=vec3(V3,V8,V5);\\ntriangles[6]=vec3(V8,V9,V5);\\ntriangles[7]=vec3(V10,V5,V9);\\ntriangles[8]=vec3(V7,V10,V5);\\ntriangles[9]=vec3(V11,V3,V8);\\ntriangles[10]=vec3(V2,V11,V3);\\ntriangles[11]=vec3(V12,V9,V8);\\ntriangles[12]=vec3(V12,V4,V6);\\ntriangles[13]=vec3(V12,V1,V4);\\ntriangles[14]=vec3(V12,V6,V9);\\ntriangles[15]=vec3(V12,V8,V1);\\ntriangles[16]=vec3(V9,V6,V10);\\ntriangles[17]=vec3(V8,V1,V11);\\ntriangles[18]=vec3(V7,V6,V10);\\ntriangles[19]=vec3(V2,V1,V11);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTICES_PER_TRI));\\n for(int i=0;i 1.0) return 1.0;\\n if (val < 0.0) return 0.0;\\n return val;\\n}\\n\\n// Takes a point ID and converts it into coordinates\\nvec3 pointOf(float id) {\\n float x = mod(id, SIZE);\\n float y = floor(id / SIZE);\\n \\n return vec3((-SIZE/2.0 + x) * SPACING, heightAt( vec2( x, y ) / SIZE * 4.0), (-SIZE/2.0 + y) * SPACING );\\n}\\n\\n// Entry point of shader\\nvoid main() {\\n // Get the point position, x, y and z, with y being the height\\n vec3 p = pointOf(vertexId);\\n \\n // Based on the height (before rotation) determine colors\\n vec4 ground_colour = mix(DIRT_COLOUR , GRASS_COLOUR, factor(0.2, 0.0, p.y / H_SCALE));\\n \\n vec4 top_colour = mix(STONE_COLOUR, SNOW_COLOUR , factor(1.2, 2.0, p.y / H_SCALE));\\n \\n vec4 colour = mix(ground_colour, top_colour , factor(0.2, 0.3, p.y / H_SCALE));\\n \\n // Rotate the point around the global Y axis\\n p = rotateY(p, time * ROTATE_SPEED);\\n // Move the point down\\n p.z += 16.0;\\n // rotate the point up on the global X axis to simulare the camera looking downwards\\n p = rotateX(p, 0.8);\\n \\n // Set point size based on spacing and the distance (p.z) from the camera\\n gl_PointSize = SPACING * (2048.0 * DOT_SIZE) / (pow(p.z,2.0));\\n \\n // Set the position of the point\\n gl_Position = vec4(p.x, p.y - 9.0, 1.0/p.z, p.z);\\n \\n // Set the color of the point\\n v_color = colour;\\n}\"}", + "settings": { + "num": 27854, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Some code originated from here: https://www.vertexshaderart.com/art/TGGLggjxQgLPEFHWx\n\n\n// Calculates the size of the grid based on total number of points\nfloat SIZE = floor(sqrt(vertexCount));\n\n// The actual points are placed in a 16x16 area, divided by the size gets the distance\n// between points\nfloat SPACING = 22.0 / SIZE;\n\n// How much the mouse changes the position, mouse influence\nfloat DIST = 22.0;\n\n// Detail scale (zoom out)\nfloat SCALE = 1.0;\n\n\n// Height scale, ranges from 0.001 to 1.001. The 0.001 additional is to ensure it stays\n// Positive, so that the calculation of the colors still works.\nfloat H_SCALE = 1.501 + sin(time / 0.09) / 5.0;\n\n// Values used by noise to offset the terrain for interactivity\nfloat x_offset = mouse.x * DIST;\nfloat y_offset = mouse.y * DIST;\n\n// How fast the camera orbits the area\nfloat ROTATE_SPEED = 4.4;\n\n// This value determines the fullness of the display. 1.0 is default\n// Too high and the dots cause interference with each other\n// Too low and it can be hard to see the shape\n// The dots get smaller as they get farther from the camera\nfloat DOT_SIZE = 1.0;\n\n// These colors are used for the color display, and are mixed in main based on height\nvec4 SNOW_COLOUR = vec4(3.0, 1.0, 1.0, 1);\nvec4 STONE_COLOUR = vec4(0.4, 0.4, 0.1, 1);\nvec4 DIRT_COLOUR = vec4(0.1, 2.2, 1.1, 1);\nvec4 GRASS_COLOUR = vec4(0.3, 0.2, 0.3, 2);\n\n// Rotates a point around the global Y axis\n// This is used to rotate the grid\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n// Rotates a point around the global X axis\n// This is used to tile the camera downwards to look at terrain from slightly above\nvec3 rotateX( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.y = ca*p.y + sa*p.z;\n r.x = p.x;\n r.z = -sa*p.y + ca*p.z;\n return r;\n}\n// Hash unction returns a pseudo-random value for a given value\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\n// blends the hash of of 4 points around the given vector smoothly using\n// a cubic hermite interpolation\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\n\n\n// Scaling factor used only in the noise function\nfloat feature_scale = 2.0;\n\n// Fractal Brownian Motion\n\nfloat fbm(in vec2 p, in float size) {\n // How much the influence of each iteration is decreased\n const float lucanarity = 2.0;\n // How much the scale of each iteration is increased\n const float detail = 2.0;\n \n p = p * feature_scale;\n float h = noise(p);\n \n float influence = 1.0;\n \n for (int i = 0; i < 14; i++) {\n p = p * size;\n \th += noise(p) * influence;\n size *= 2.0;\n influence /= lucanarity;\n }\n return h;\n}\n\n// The code that given a position, gives a height, design the terrain here\nfloat heightAt(in vec2 po) {\n po.x = (po.x + x_offset) * SCALE;\n po.y = (po.y + y_offset) * SCALE;\n return (fbm(po, 3.0) * 3.0) * pow(fbm(po, 0.2),3.0) * (0.03 * H_SCALE);\n}\n\n// returns a value 0.0 to 1.0 representing how far between min and max the value is\nfloat factor(float min, float max, float value) {\n float val = (value - min) / (max - min);\n if (val > 1.0) return 1.0;\n if (val < 0.0) return 0.0;\n return val;\n}\n\n// Takes a point ID and converts it into coordinates\nvec3 pointOf(float id) {\n float x = mod(id, SIZE);\n float y = floor(id / SIZE);\n \n return vec3((-SIZE/2.0 + x) * SPACING, heightAt( vec2( x, y ) / SIZE * 4.0), (-SIZE/2.0 + y) * SPACING );\n}\n\n// Entry point of shader\nvoid main() {\n // Get the point position, x, y and z, with y being the height\n vec3 p = pointOf(vertexId);\n \n // Based on the height (before rotation) determine colors\n vec4 ground_colour = mix(DIRT_COLOUR , GRASS_COLOUR, factor(0.2, 0.0, p.y / H_SCALE));\n \n vec4 top_colour = mix(STONE_COLOUR, SNOW_COLOUR , factor(1.2, 2.0, p.y / H_SCALE));\n \n vec4 colour = mix(ground_colour, top_colour , factor(0.2, 0.3, p.y / H_SCALE));\n \n // Rotate the point around the global Y axis\n p = rotateY(p, time * ROTATE_SPEED);\n // Move the point down\n p.z += 16.0;\n // rotate the point up on the global X axis to simulare the camera looking downwards\n p = rotateX(p, 0.8);\n \n // Set point size based on spacing and the distance (p.z) from the camera\n gl_PointSize = SPACING * (2048.0 * DOT_SIZE) / (pow(p.z,2.0));\n \n // Set the position of the point\n gl_Position = vec4(p.x, p.y - 9.0, 1.0/p.z, p.z);\n \n // Set the color of the point\n v_color = colour;\n}" + }, "screenshotURL": "data/images/images-szbazl937ioxoy43y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5Fphse6X3wyaFosYJ/art.json b/art/5Fphse6X3wyaFosYJ/art.json index 04ceab48..0a2d75bf 100644 --- a/art/5Fphse6X3wyaFosYJ/art.json +++ b/art/5Fphse6X3wyaFosYJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":6687,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.25882352941176473,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Circles from Triangles\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n//https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n \\n float ux = floor(id/6.) + mod(id , 2.);\\n // id = \\t\\t0 1 2 3 4 5 6 7 8 9 10 11 12\\n \\n // floor =\\t0 0 0 0 0 0 1 1 1 1 1 1 2\\n // mod =\\t\\t0 1 0 1 0 1 0 1 0 1 0 1 0\\n // + = \\t\\t0 1 0 1 0 1 1 2 1 2 1 2 2\\n \\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n // id = \\t\\t0 1 2 3 4 5 6 7 8 9 10 11 12\\n \\n // floor =\\t0 0 1 1 2 2 3 3 4 4 5 5 6\\n // floor =\\t0 0 0 1 1 1 2 2 2 3 3 3 4\\n // + = \\t\\t0 0 1 2 3 3 5 5 6 7 8 8 10\\n // mod = \\t\\t0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n // result =>\\t{(0,0),(1,0),(0,1)}, \\n //\\t\\t\\t{(1,0),(0,1),(1,1)},\\n //\\t\\t\\t{(1,1),(2,1),(1,0)}, ...\\n \\n\\n // 120 / 6(quad) = 20\\n float angle = ux / numCircleSegments * PI*2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound,vec2(au* 0.05,av*0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1.,1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\\n\\n \\n float pump = step(0.8,snd);\\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\\n float sat = 1.;//mix(0.5, 1.0, pump); //1.0 - av;\\n float val = mix(0.4, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 6687, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.25882352941176473, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Circles from Triangles\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n//https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments){\n \n float ux = floor(id/6.) + mod(id , 2.);\n // id = \t\t0 1 2 3 4 5 6 7 8 9 10 11 12\n \n // floor =\t0 0 0 0 0 0 1 1 1 1 1 1 2\n // mod =\t\t0 1 0 1 0 1 0 1 0 1 0 1 0\n // + = \t\t0 1 0 1 0 1 1 2 1 2 1 2 2\n \n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n // id = \t\t0 1 2 3 4 5 6 7 8 9 10 11 12\n \n // floor =\t0 0 1 1 2 2 3 3 4 4 5 5 6\n // floor =\t0 0 0 1 1 1 2 2 2 3 3 3 4\n // + = \t\t0 0 1 2 3 3 5 5 6 7 8 8 10\n // mod = \t\t0 0 1 0 1 1 1 1 0 1 0 0 0\n \n // result =>\t{(0,0),(1,0),(0,1)}, \n //\t\t\t{(1,0),(0,1),(1,1)},\n //\t\t\t{(1,1),(2,1),(1,0)}, ...\n \n\n // 120 / 6(quad) = 20\n float angle = ux / numCircleSegments * PI*2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound,vec2(au* 0.05,av*0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1.,1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\n\n \n float pump = step(0.8,snd);\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\n float sat = 1.;//mix(0.5, 1.0, pump); //1.0 - av;\n float val = mix(0.4, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-ffy6m3rp4cjj27iq7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5MbciF3ZFxqF8hyYn/art.json b/art/5MbciF3ZFxqF8hyYn/art.json index c657d725..2d733428 100644 --- a/art/5MbciF3ZFxqF8hyYn/art.json +++ b/art/5MbciF3ZFxqF8hyYn/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mohamed-asss-190506039/eminem-godzilla-venom-the-real?si=69025ec7f42140debb0b0fce4d54597c&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.); \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\nvoid main() \\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments); \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n\\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mohamed-asss-190506039/eminem-godzilla-venom-the-real?si=69025ec7f42140debb0b0fce4d54597c&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.); \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\nvoid main() \n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments); \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n\n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * .02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-q0xivl5lns9s3ft4j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5NxpTo5tmZ5jQ3ZE5/art.json b/art/5NxpTo5tmZ5jQ3ZE5/art.json index 689aa063..088eebae 100644 --- a/art/5NxpTo5tmZ5jQ3ZE5/art.json +++ b/art/5NxpTo5tmZ5jQ3ZE5/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":2000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.8901960784313725,0.8431372549019608,1],\"shader\":\"/* \\n \\n \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n .___. \\n [__ | _ . , _ ._. \\n | |(_) \\\\/\\\\/ (/,[ \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n@31/12/2019 \\n*/ \\n#define PI radians(180.)\\n\\n\\nmat4 mAspect = mat4\\n(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n); \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\n/* -------------------------------- separater ------------------------------- */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/* -------------------------------- separater ------------------------------- */\\n\\nvoid main() \\n{\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1 , 20. ); \\n vec3 camera = vec3(0. , 0. , 1. ) ;\\n vec3 target = vec3(0.);\\n vec3 up = vec3(0., 1., 0.); \\n m*= cameraLookAt(camera , target , up);\\n m*= uniformScale(0.4);\\n \\n float radius = 0. ; \\n vec3 pos = vec3(0.) ; \\n \\n if(vertexId < 1000. )\\n {\\n\\tconst float fLength = 10. ; \\n float fy = floor(vertexId / vertexCount);\\n float xOffset = fract(vertexId / vertexCount) * 0.2; \\n float yOffset = sqrt(xOffset) ; \\n \\n pos = vec3(target.x + xOffset, target.y - yOffset , 0. );\\n } \\n else\\n {\\n radius = sin(vertexId * 5.) * .2 ;\\n float xPos = radius * sin(vertexId) ; \\n float yPos = radius * cos(vertexId) ; \\n pos = vec3( xPos, yPos, 0.);\\n }\\n gl_Position = m*vec4(pos + target, 1); \\n gl_PointSize = 2.; \\n v_color = vec4(vec3(0.), 1.); \\n \\n}\\n\\n\\n\\n#pragma region ...\\n\\n#pragma endregion \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\"}", + "settings": { + "num": 2000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.8901960784313725, + 0.8431372549019608, + 1 + ], + "shader": "/* \n \n \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n .___. \n [__ | _ . , _ ._. \n | |(_) \\/\\/ (/,[ \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n \n@31/12/2019 \n*/ \n#define PI radians(180.)\n\n\nmat4 mAspect = mat4\n(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n); \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\n/* -------------------------------- separater ------------------------------- */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* -------------------------------- separater ------------------------------- */\n\nvoid main() \n{\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1 , 20. ); \n vec3 camera = vec3(0. , 0. , 1. ) ;\n vec3 target = vec3(0.);\n vec3 up = vec3(0., 1., 0.); \n m*= cameraLookAt(camera , target , up);\n m*= uniformScale(0.4);\n \n float radius = 0. ; \n vec3 pos = vec3(0.) ; \n \n if(vertexId < 1000. )\n {\n\tconst float fLength = 10. ; \n float fy = floor(vertexId / vertexCount);\n float xOffset = fract(vertexId / vertexCount) * 0.2; \n float yOffset = sqrt(xOffset) ; \n \n pos = vec3(target.x + xOffset, target.y - yOffset , 0. );\n } \n else\n {\n radius = sin(vertexId * 5.) * .2 ;\n float xPos = radius * sin(vertexId) ; \n float yPos = radius * cos(vertexId) ; \n pos = vec3( xPos, yPos, 0.);\n }\n gl_Position = m*vec4(pos + target, 1); \n gl_PointSize = 2.; \n v_color = vec4(vec3(0.), 1.); \n \n}\n\n\n\n#pragma region ...\n\n#pragma endregion \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n" + }, "screenshotURL": "data/images/images-b4xezbqcklxp7b6vz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5PLH8iYP7Rsj5z8NC/art.json b/art/5PLH8iYP7Rsj5z8NC/art.json index f6fef221..e66a812d 100644 --- a/art/5PLH8iYP7Rsj5z8NC/art.json +++ b/art/5PLH8iYP7Rsj5z8NC/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":9357,\"mode\":\"TRI_STRIP\",\"sound\":\"feedback\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 3.//KParameter 0.>>3.\\n#define P6 3.//KParameter 0.1>>10.\\n#define P5 1.//KParameter 0.>>3.\\n//KVerticesNumber=2000\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 1000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 6. *fract(mouse.x-mouse.y)));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos,sin(1.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *1.001;\\n float sat = 0.;\\n float val = vertexCount/(vertexId * 21.)*0.6;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a*2.;\\n}\"}", + "settings": { + "num": 9357, + "mode": "TRI_STRIP", + "sound": "feedback", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 3.//KParameter 0.>>3.\n#define P6 3.//KParameter 0.1>>10.\n#define P5 1.//KParameter 0.>>3.\n//KVerticesNumber=2000\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 1000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 6. *fract(mouse.x-mouse.y)));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos,sin(1.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *1.001;\n float sat = 0.;\n float val = vertexCount/(vertexId * 21.)*0.6;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a*2.;\n}" + }, "screenshotURL": "data/images/images-tw9pww2c9ec1smdz3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5RiyKNicAa32rA9YZ/art.json b/art/5RiyKNicAa32rA9YZ/art.json index 4c0b6a69..ca978993 100644 --- a/art/5RiyKNicAa32rA9YZ/art.json +++ b/art/5RiyKNicAa32rA9YZ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ndyl47gnsfmp51191-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5RkZQxjruyDfA9bS7/art.json b/art/5RkZQxjruyDfA9bS7/art.json index 585d928e..04a56f66 100644 --- a/art/5RkZQxjruyDfA9bS7/art.json +++ b/art/5RkZQxjruyDfA9bS7/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hzktqr", "avatarUrl": "https://secure.gravatar.com/avatar/c5ca7d7d4b527ab960b78f57cfbe61c2?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/casio_official/px-860-off\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/casio_official/px-860-off", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-hqspebs2k98n2mkkx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5TC2fdTpuR9MXHMhb/art.json b/art/5TC2fdTpuR9MXHMhb/art.json index ab9062d4..48e094db 100644 --- a/art/5TC2fdTpuR9MXHMhb/art.json +++ b/art/5TC2fdTpuR9MXHMhb/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":300,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n 01/01/2019 \\n*/ \\n\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#pragma endregion \\n\\n#pragma region Scene_Vertex_Collection \\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n#pragma endregion \\n\\n#pragma region DrawScreen \\n\\n#define g_Height \\t\\t\\t16.\\n#define g_Width\\t\\t\\t\\t16.\\n#define g_Quads \\t\\t\\t( g_Height * g_Width)\\n#define g_VertexCount \\t\\t( g_Quads * 6.)\\n\\nSceneVertex GenerateSTVertex(const float in_fvertexIndex,\\n const vec3 in_vCameraPos)\\n{\\n\\tSceneVertex out_sv ; \\n \\t\\n \\tvec2 vDim = vec2(g_Height, g_Width);\\n\\tvec2 vTileIndex ; \\n \\tvec2 vUV ; \\n \\tGetQuadTileInfo(in_fvertexIndex ,\\n \\tvDim, \\n vTileIndex,\\n vUV);\\n \\t\\n \\tfloat pos = 0. ;\\n \\tfloat Pinch = 1. ; \\n \\t\\n if(vUV.y > 0. )\\n {\\n float t = pow(vUV.y , 1.);\\n float sunRadis = 0.01 ; \\n pos = sunRadis + t * (1. - sunRadis) ; \\n }\\n \\t\\n \\tvec3 vSpherePos ; \\n \\tfloat fElevation = (pos * PI) ; \\n \\tvSpherePos.z = cos(fElevation);\\n \\n \\t\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n\\n\\tmat3 m;\\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n \\n out_sv.vWorldPos = vWorldSpherePos;\\n \\n \\tout_sv.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\tout_sv.fAlpha = 1.0;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\t\\n return out_sv ; \\n}\\n\\n\\nSceneVertex GenTriangle(const float in_fVertexIndex)\\n{\\n\\tSceneVertex sv ; \\n \\tif(in_fVertexIndex < 100.)\\n {\\n sv.vWorldPos = vec3(0.2 , -0.2 , 0.);\\n sv.vColor = vec3(1. , 0. , 0. ); \\n sv.fAlpha = 1. ; \\n }\\n \\telse if(in_fVertexIndex > 100. && in_fVertexIndex < 200. )\\n {\\n sv.vWorldPos = vec3(-0.2 , -0.2, 0. );\\n sv.vColor = vec3(0. , 1. , 0. );\\n sv.fAlpha = 1. ; \\n } \\n \\telse \\n {\\n sv.vWorldPos = vec3(0. , 0.2 , 0.);\\n sv.vColor = vec3(0., 0. , 1.);\\n sv.fAlpha = 1. ; \\n } \\n \\treturn sv; \\n}\\n\\n\\n\\n#pragma endregion \\n\\n/* -------------------------------- display ------------------------------- */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/* -------------------------------- display ------------------------------- */\\n\\t\\nvoid main()\\n{ \\n #pragma region screenSetting \\n\\tSceneVertex sv ; \\n\\tvec2 vMouse = mouse ; \\n \\t\\n #pragma endregion \\n \\n \\n \\n\\n #pragma region Start to draw something\\n \\n float vertexIndex = vertexId; \\n sv = GenTriangle(vertexIndex) ; \\n\\n\\t \\n #pragma endregion \\n \\n \\n #pragma region ProjectionSetUp \\n mat4 m = persp(radians(60.),\\n resolution.x/ resolution.y, \\n NEARCLIPPED , \\n FARCLIPPED); \\n #pragma endregion \\n\\n #pragma region CameraSetUp/ViewSetUp\\n vec3 target = vec3(0. ) ;\\n vec3 up = vec3(0. ,1. , 0. ) ;\\n\\t //target = sv.vWorldPos; \\n vec3 camTarget = target ; \\n vec3 camPos = vec3(0. , 0. ,1. ); \\n vec3 camForward = normalize(camTarget - camPos);\\n m *= cameraLookAt(camPos , camTarget, normalize(up));\\n #pragma endregion \\n\\n #pragma region model \\n m *= uniformScale(0.7);\\n m *= trans(vec3(0.)) ;\\n m *= rotY(1. * time);\\n #pragma endregion \\n \\n \\n #pragma region Light\\n \\t vec3 ambient = vec3(0.) ; \\n \\t vec3 diffuse = vec3(0.) ;\\n \\t vec3 specular = vec3(0.);\\n \\t vec3 result = ambient + diffuse + specular ;\\n #pragma endregion \\n \\n \\n \\n #pragma region add to glsl\\n \\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n #pragma endregion \\n}\"}", + "settings": { + "num": 300, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n 01/01/2019 \n*/ \n\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#pragma endregion \n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n#pragma endregion \n\n#pragma region DrawScreen \n\n#define g_Height \t\t\t16.\n#define g_Width\t\t\t\t16.\n#define g_Quads \t\t\t( g_Height * g_Width)\n#define g_VertexCount \t\t( g_Quads * 6.)\n\nSceneVertex GenerateSTVertex(const float in_fvertexIndex,\n const vec3 in_vCameraPos)\n{\n\tSceneVertex out_sv ; \n \t\n \tvec2 vDim = vec2(g_Height, g_Width);\n\tvec2 vTileIndex ; \n \tvec2 vUV ; \n \tGetQuadTileInfo(in_fvertexIndex ,\n \tvDim, \n vTileIndex,\n vUV);\n \t\n \tfloat pos = 0. ;\n \tfloat Pinch = 1. ; \n \t\n if(vUV.y > 0. )\n {\n float t = pow(vUV.y , 1.);\n float sunRadis = 0.01 ; \n pos = sunRadis + t * (1. - sunRadis) ; \n }\n \t\n \tvec3 vSpherePos ; \n \tfloat fElevation = (pos * PI) ; \n \tvSpherePos.z = cos(fElevation);\n \n \t\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n\n\tmat3 m;\n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n \n out_sv.vWorldPos = vWorldSpherePos;\n \n \tout_sv.vColor = GetBackdropColor( vLocalSpherePos );\n\n \tout_sv.fAlpha = 1.0;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \t\n return out_sv ; \n}\n\n\nSceneVertex GenTriangle(const float in_fVertexIndex)\n{\n\tSceneVertex sv ; \n \tif(in_fVertexIndex < 100.)\n {\n sv.vWorldPos = vec3(0.2 , -0.2 , 0.);\n sv.vColor = vec3(1. , 0. , 0. ); \n sv.fAlpha = 1. ; \n }\n \telse if(in_fVertexIndex > 100. && in_fVertexIndex < 200. )\n {\n sv.vWorldPos = vec3(-0.2 , -0.2, 0. );\n sv.vColor = vec3(0. , 1. , 0. );\n sv.fAlpha = 1. ; \n } \n \telse \n {\n sv.vWorldPos = vec3(0. , 0.2 , 0.);\n sv.vColor = vec3(0., 0. , 1.);\n sv.fAlpha = 1. ; \n } \n \treturn sv; \n}\n\n\n\n#pragma endregion \n\n/* -------------------------------- display ------------------------------- */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* -------------------------------- display ------------------------------- */\n\t\nvoid main()\n{ \n #pragma region screenSetting \n\tSceneVertex sv ; \n\tvec2 vMouse = mouse ; \n \t\n #pragma endregion \n \n \n \n\n #pragma region Start to draw something\n \n float vertexIndex = vertexId; \n sv = GenTriangle(vertexIndex) ; \n\n\t \n #pragma endregion \n \n \n #pragma region ProjectionSetUp \n mat4 m = persp(radians(60.),\n resolution.x/ resolution.y, \n NEARCLIPPED , \n FARCLIPPED); \n #pragma endregion \n\n #pragma region CameraSetUp/ViewSetUp\n vec3 target = vec3(0. ) ;\n vec3 up = vec3(0. ,1. , 0. ) ;\n\t //target = sv.vWorldPos; \n vec3 camTarget = target ; \n vec3 camPos = vec3(0. , 0. ,1. ); \n vec3 camForward = normalize(camTarget - camPos);\n m *= cameraLookAt(camPos , camTarget, normalize(up));\n #pragma endregion \n\n #pragma region model \n m *= uniformScale(0.7);\n m *= trans(vec3(0.)) ;\n m *= rotY(1. * time);\n #pragma endregion \n \n \n #pragma region Light\n \t vec3 ambient = vec3(0.) ; \n \t vec3 diffuse = vec3(0.) ;\n \t vec3 specular = vec3(0.);\n \t vec3 result = ambient + diffuse + specular ;\n #pragma endregion \n \n \n \n #pragma region add to glsl\n \n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n #pragma endregion \n}" + }, "screenshotURL": "data/images/images-8b60h38trqrdr3ixs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5Wmf5qZPP9AhQk7wB/art.json b/art/5Wmf5qZPP9AhQk7wB/art.json index e000d76e..03739f09 100644 --- a/art/5Wmf5qZPP9AhQk7wB/art.json +++ b/art/5Wmf5qZPP9AhQk7wB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n //camera\\n float r = 2.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(pattern(3.*c));;\\n \\n vec4 finalPos = vec4(ux, vy, 0.+1.*snd*v_color.y, 1.);\\n gl_Position = mat * finalPos;\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n //camera\n float r = 2.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(pattern(3.*c));;\n \n vec4 finalPos = vec4(ux, vy, 0.+1.*snd*v_color.y, 1.);\n gl_Position = mat * finalPos;\n}" + }, "screenshotURL": "data/images/images-ay8hyaw7qygvitymv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5WtmeHpqSmNcvRWAR/art.json b/art/5WtmeHpqSmNcvRWAR/art.json index ab410c04..1f1a1edd 100644 --- a/art/5WtmeHpqSmNcvRWAR/art.json +++ b/art/5WtmeHpqSmNcvRWAR/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/platform/carl-cox-45-min-boiler-room\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 1.9)/10.0;\\n //float lum = floor(v *30.0 + 0.9)/5.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\\n /*vec2 soundTexCoords = vec2(0, 0);\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n*/\\n v_color = vec4(v*lum*0.5,lum*0.1,lum*1.0,1);\\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\\n \\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/platform/carl-cox-45-min-boiler-room", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 1.9)/10.0;\n //float lum = floor(v *30.0 + 0.9)/5.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\n /*vec2 soundTexCoords = vec2(0, 0);\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n*/\n v_color = vec4(v*lum*0.5,lum*0.1,lum*1.0,1);\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\n \n}" + }, "screenshotURL": "data/images/images-djrumm9g4nhakd9ie-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5YGSiNrquYpFi3Ggo/art.json b/art/5YGSiNrquYpFi3Ggo/art.json index cf123f24..fc21bf36 100644 --- a/art/5YGSiNrquYpFi3Ggo/art.json +++ b/art/5YGSiNrquYpFi3Ggo/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":94,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/albertryan/never-around\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat rand(float p){\\n \\treturn fract(sin(p*10000./time));\\n}\\n\\nfloat noise(vec2 p)\\n{\\n return rand((p.x + p.y) * 1000.00);\\n}\\n\\nvoid main() {\\n float samp = texture2D(sound,vec2(0.34,0.)).r + texture2D(sound,vec2(0.0,0.)).r;\\n samp /=2.;\\n vec2 uv = vec2(sin(time+ vertexId + time),tan(time + vertexId ));\\n uv *= samp + .5;\\n gl_Position = vec4(uv,0,1);\\n gl_PointSize = 100.;\\n \\n \\n v_color = vec4(1);\\n v_color.a*= noise(uv *time); \\n vec3 gdlw = vec3(texture2D(sound, vec2(0.05,0.)).r * sin(time + vertexId) ,texture2D(sound,vec2(50.*0.005,0.)).r *cos(time * vertexId) , (sin(vertexId - time)));\\n v_color.rgb *= gdlw;\\n }\"}", + "settings": { + "num": 94, + "mode": "POINTS", + "sound": "https://soundcloud.com/albertryan/never-around", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat rand(float p){\n \treturn fract(sin(p*10000./time));\n}\n\nfloat noise(vec2 p)\n{\n return rand((p.x + p.y) * 1000.00);\n}\n\nvoid main() {\n float samp = texture2D(sound,vec2(0.34,0.)).r + texture2D(sound,vec2(0.0,0.)).r;\n samp /=2.;\n vec2 uv = vec2(sin(time+ vertexId + time),tan(time + vertexId ));\n uv *= samp + .5;\n gl_Position = vec4(uv,0,1);\n gl_PointSize = 100.;\n \n \n v_color = vec4(1);\n v_color.a*= noise(uv *time); \n vec3 gdlw = vec3(texture2D(sound, vec2(0.05,0.)).r * sin(time + vertexId) ,texture2D(sound,vec2(50.*0.005,0.)).r *cos(time * vertexId) , (sin(vertexId - time)));\n v_color.rgb *= gdlw;\n }" + }, "screenshotURL": "data/images/images-hfixdl9m7ivz07ekt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5Yw6GiojcPykGM7p6/art.json b/art/5Yw6GiojcPykGM7p6/art.json index 00c305f5..ae9c539e 100644 --- a/art/5Yw6GiojcPykGM7p6/art.json +++ b/art/5Yw6GiojcPykGM7p6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "danieljcage", "avatarUrl": "https://secure.gravatar.com/avatar/ef5524521d4a7c38faa26add1aa18f81?default=retro&size=200", - "settings": "{\"num\":5294,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt (vertexCount)); \\n float across = floor(vertexCount / down);\\n float x = mod (vertexId, across); \\n\\n float y = floor(vertexId / across);\\n\\n float u = x/(across - 1.); \\n float v = y/ (across - 1.);\\n\\n // Offsets\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.2) * 5.3;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n // Scale\\n vec2 xy = vec2(ux, vy) * .5;\\n \\n gl_Position = vec4(xy, 0, 1.);\\n \\n // Off size\\n float soff = sin(time) * 5.;\\n\\n \\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize = 20. / across;\\n gl_PointSize = resolution.x / 600.;\\n v_color = vec4(.1, 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 5294, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt (vertexCount)); \n float across = floor(vertexCount / down);\n float x = mod (vertexId, across); \n\n float y = floor(vertexId / across);\n\n float u = x/(across - 1.); \n float v = y/ (across - 1.);\n\n // Offsets\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.2) * 5.3;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n // Scale\n vec2 xy = vec2(ux, vy) * .5;\n \n gl_Position = vec4(xy, 0, 1.);\n \n // Off size\n float soff = sin(time) * 5.;\n\n \n \n gl_PointSize = 10.0 + soff;\n gl_PointSize = 20. / across;\n gl_PointSize = resolution.x / 600.;\n v_color = vec4(.1, 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-er0p7bgjnkrt7eii5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5bpdGEqpAwiR35mDS/art.json b/art/5bpdGEqpAwiR35mDS/art.json index 63212b85..c7a3f0e2 100644 --- a/art/5bpdGEqpAwiR35mDS/art.json +++ b/art/5bpdGEqpAwiR35mDS/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/yoasobimusic/jqiurhdzp3dy?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n \\treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat ux = u * 2.0 - 1.0;\\n \\tfloat vy = v * 2.0 - 1.0;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\tfloat su = abs(u - 0.5) * 5.0;\\n \\tfloat sv = abs(v - 0.5) * 5.0;\\n \\tfloat au = abs(atan(su, sv)) / PI * 2.0;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.5, av * 0.2)).a;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\\n \\n \\tgl_PointSize = pow(snd + 0.2, 5.0) * 20.0 + soff;\\n \\tgl_PointSize *= 15.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tfloat pump = step(0.5, snd);\\n \\tfloat hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\\n \\tfloat sat = mix(0.0, 1.0, pump);\\n \\tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)).x + 0.5, 0.5, hsv2rgb(vec3(hue, sat, val)).y + 0.5, 0.7);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/yoasobimusic/jqiurhdzp3dy?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n \treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat ux = u * 2.0 - 1.0;\n \tfloat vy = v * 2.0 - 1.0;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \n \tfloat su = abs(u - 0.5) * 5.0;\n \tfloat sv = abs(v - 0.5) * 5.0;\n \tfloat au = abs(atan(su, sv)) / PI * 2.0;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.5, av * 0.2)).a;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\n \n \tgl_PointSize = pow(snd + 0.2, 5.0) * 20.0 + soff;\n \tgl_PointSize *= 15.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tfloat pump = step(0.5, snd);\n \tfloat hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\n \tfloat sat = mix(0.0, 1.0, pump);\n \tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)).x + 0.5, 0.5, hsv2rgb(vec3(hue, sat, val)).y + 0.5, 0.7);\n}" + }, "screenshotURL": "data/images/images-n9vesdi9i27qqjhc7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5btpWTSD8Kwb767eh/art.json b/art/5btpWTSD8Kwb767eh/art.json index 696adcca..88f9efb4 100644 --- a/art/5btpWTSD8Kwb767eh/art.json +++ b/art/5btpWTSD8Kwb767eh/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "plasticrainbow", "avatarUrl": "https://secure.gravatar.com/avatar/6a162c0fed03619171f63772ec1198d1?default=retro&size=200", - "settings": "{\"num\":40000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) { \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n \\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId,\\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleID = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleID , across);\\n float y = floor(circleID / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n vec2 xy = circleXY * 0.1 + vec2(ux, vy) * 1.5;\\n \\n gl_Position = vec4(xy, 0, 1) * vec4(1., aspect, 1., 1.);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 40000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments) { \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n \n}\n\n\nvoid main() {\n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId,\n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleID = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleID , across);\n float y = floor(circleID / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n vec2 xy = circleXY * 0.1 + vec2(ux, vy) * 1.5;\n \n gl_Position = vec4(xy, 0, 1) * vec4(1., aspect, 1., 1.);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-icw649jayc5s2zky9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5dNDeR4dqCCRvcHCT/art.json b/art/5dNDeR4dqCCRvcHCT/art.json index a9566669..7af46367 100644 --- a/art/5dNDeR4dqCCRvcHCT/art.json +++ b/art/5dNDeR4dqCCRvcHCT/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 2.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 2.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-ti1pt9g9uegwhioxt-thumbnail.jpg", "views": { "$numberInt": "137" diff --git a/art/5eHGg8xT9dKtXnSgu/art.json b/art/5eHGg8xT9dKtXnSgu/art.json index b850ad79..7e64270b 100644 --- a/art/5eHGg8xT9dKtXnSgu/art.json +++ b/art/5eHGg8xT9dKtXnSgu/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":1600,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/floatingpoints/egl037-king-bromeliad#t=1m0s\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.13725490196078433,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0/3.0, 1.0/3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\\n vertexId;\\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\\n float x = mod(vertexId, across);\\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; // sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n float szoff = 0.0; // sin(time + x * y * 0.02) * 5.;\\n\\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + szoff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u*.1 + snd * 0.2 + time * .1; // sin(time + v * 20.) * 0.10;\\n float sat = mix(0., 1., pump); // step(0.8, snd); // mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); // sin(time + v * u * 20.) * 0.5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1600, + "mode": "POINTS", + "sound": "https://soundcloud.com/floatingpoints/egl037-king-bromeliad#t=1m0s", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.13725490196078433, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0/3.0, 1.0/3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\n vertexId;\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\n float x = mod(vertexId, across);\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; // sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0., 1.);\n \n float szoff = 0.0; // sin(time + x * y * 0.02) * 5.;\n\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + szoff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u*.1 + snd * 0.2 + time * .1; // sin(time + v * 20.) * 0.10;\n float sat = mix(0., 1., pump); // step(0.8, snd); // mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); // sin(time + v * u * 20.) * 0.5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-9rzftlhp93rqwy4wh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5eLB8us5zfTRPWx49/art.json b/art/5eLB8us5zfTRPWx49/art.json index 515686be..ae62bf61 100644 --- a/art/5eLB8us5zfTRPWx49/art.json +++ b/art/5eLB8us5zfTRPWx49/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "jko", "avatarUrl": "https://lh4.googleusercontent.com/-sTisLKPorfI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdngWBCd0QW-0Ip7SSZ0m-Ahnxndg/mo/photo.jpg", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ukf/current-value-phace-thump\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n \\tfloat id = vertexId;\\n \\n \\tfloat ux = floor(id / 6.); + mod(id, 2.);\\n \\n float x = 0.;\\n float y = 0.;\\n \\n \\tvec2 xy = vec2(x, y);\\n \\n \\tgl_Position = vec4(xy, 0,1);\\n\\n \\tv_color = vec4(0,0,1,1);\\n\\n}\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#if 0 \\nvoid main() {\\n\\tfloat down = floor(sqrt(vertexCount));\\n float across = floor (vertexCount / down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n \\n \\tfloat snd = texture2D(sound, vec2(u, 0)).a;\\n \\tfloat mod3 = snd;\\n \\n \\n \\n float xoff = sin(time*0.8 + y*0.2) * 0.1;\\n float yoff = cos(time*0.1 + x* 0.5) * 0.1;https://soundcloud.com/ukf/current-value-phace-thump\\n\\n float ux = (u * 2. - 1. + snd * 0.1) + xoff;\\n float uy = v * 2. - 1.+ snd * 0.1 + yoff;\\n\\n gl_Position = vec4(ux * 1.4, uy * 1.4, 0 , 1);\\n\\n\\n float soff = cos(time + x / 10. - y * 0.1)*20.;\\n\\n gl_PointSize = 20. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n\\n \\n \\n \\n\\t// ----------------- COLOUR ----------------- //\\n float mod1 = sin(0.2 + time) * 0.4 ;\\n float mod2 = sin(time + 0.3*y + 0.2)*0.4;\\n\\n \\n v_color = vec4(mod1 + 0.4,mod3, mod2 + 0.4 + mod3,0. + mod3);\\n \\n \\n}\\n#endif\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ukf/current-value-phace-thump", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\nvoid main() {\n \tfloat id = vertexId;\n \n \tfloat ux = floor(id / 6.); + mod(id, 2.);\n \n float x = 0.;\n float y = 0.;\n \n \tvec2 xy = vec2(x, y);\n \n \tgl_Position = vec4(xy, 0,1);\n\n \tv_color = vec4(0,0,1,1);\n\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#if 0 \nvoid main() {\n\tfloat down = floor(sqrt(vertexCount));\n float across = floor (vertexCount / down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n \n \tfloat snd = texture2D(sound, vec2(u, 0)).a;\n \tfloat mod3 = snd;\n \n \n \n float xoff = sin(time*0.8 + y*0.2) * 0.1;\n float yoff = cos(time*0.1 + x* 0.5) * 0.1;https://soundcloud.com/ukf/current-value-phace-thump\n\n float ux = (u * 2. - 1. + snd * 0.1) + xoff;\n float uy = v * 2. - 1.+ snd * 0.1 + yoff;\n\n gl_Position = vec4(ux * 1.4, uy * 1.4, 0 , 1);\n\n\n float soff = cos(time + x / 10. - y * 0.1)*20.;\n\n gl_PointSize = 20. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n\n \n \n \n\t// ----------------- COLOUR ----------------- //\n float mod1 = sin(0.2 + time) * 0.4 ;\n float mod2 = sin(time + 0.3*y + 0.2)*0.4;\n\n \n v_color = vec4(mod1 + 0.4,mod3, mod2 + 0.4 + mod3,0. + mod3);\n \n \n}\n#endif\n" + }, "screenshotURL": "data/images/images-tfph0da2u3778szz6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5eNtGMeN2Etw3d5dh/art.json b/art/5eNtGMeN2Etw3d5dh/art.json index aa91d9c9..512edca8 100644 --- a/art/5eNtGMeN2Etw3d5dh/art.json +++ b/art/5eNtGMeN2Etw3d5dh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thenoiseprocess/i-want-my-credit-card\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/1.9/resolution.y*-2.;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *0.5/ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n float snd = texture2D(sound, vec2(0.2, u)).a;\\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\tvec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\t\\n\\tfor(float i = 0.0001; i < (10.0); i++){\\n\\t\\t\\n\\t\\tfloat s = 5.*snd*cos(sin(10. * time / i )) ;\\n\\t\\tfloat c = tan(cos(0.1* time + i ));\\n\\t\\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n\\n \\n \\n \\n gl_PointSize = 1.+snd*22.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(destColor * f), 0.05);\\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\\n v_color = vec4(vec3(1.), 1.0);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thenoiseprocess/i-want-my-credit-card", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/1.9/resolution.y*-2.;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *0.5/ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n float snd = texture2D(sound, vec2(0.2, u)).a;\n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\tvec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\t\n\tfor(float i = 0.0001; i < (10.0); i++){\n\t\t\n\t\tfloat s = 5.*snd*cos(sin(10. * time / i )) ;\n\t\tfloat c = tan(cos(0.1* time + i ));\n\t\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\n\t}\n\n\n \n \n \n gl_PointSize = 1.+snd*22.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(destColor * f), 0.05);\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\n v_color = vec4(vec3(1.), 1.0);\n\n}" + }, "screenshotURL": "data/images/images-zg9kxy1sqmosyx4rh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5fBJ6mEfnhkJuSFyR/art.json b/art/5fBJ6mEfnhkJuSFyR/art.json index afbc5b3b..09f8a8c6 100644 --- a/art/5fBJ6mEfnhkJuSFyR/art.json +++ b/art/5fBJ6mEfnhkJuSFyR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":98310,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kushalputhran/jai-ganesh-jai-ganesh-jai\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,0.6313725490196078,0.43137254901960786,1],\"shader\":\"/*\\n\\n ▌ ▐·▄▄▄ .▄▄▄ ▄▄▄▄▄▄▄▄ .▐▄• ▄ .▄▄ · ▄ .▄ ▄▄▄· ·▄▄▄▄ ▄▄▄ .▄▄▄ ▄▄▄· ▄▄▄ ▄▄▄▄▄\\n▪█·█▌▀▄.▀·▀▄ █·•██ ▀▄.▀· █▌█▌▪▐█ ▀. ██▪▐█▐█ ▀█ ██▪ ██ ▀▄.▀·▀▄ █·▐█ ▀█ ▀▄ █·•██ \\n▐█▐█•▐▀▀▪▄▐▀▀▄ ▐█.▪▐▀▀▪▄ ·██· ▄▀▀▀█▄██▀▐█▄█▀▀█ ▐█· ▐█▌▐▀▀▪▄▐▀▀▄ ▄█▀▀█ ▐▀▀▄ ▐█.▪\\n ███ ▐█▄▄▌▐█•█▌ ▐█▌·▐█▄▄▌▪▐█·█▌▐█▄▪▐███▌▐▀▐█ ▪▐▌██. ██ ▐█▄▄▌▐█•█▌▐█ ▪▐▌▐█•█▌ ▐█▌·\\n. ▀ ▀▀▀ .▀ ▀ ▀▀▀ ▀▀▀ •▀▀ ▀▀ ▀▀▀▀ ▀▀▀ · ▀ ▀ ▀▀▀▀▀• ▀▀▀ .▀ ▀ ▀ ▀ .▀ ▀ ▀▀▀ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define QUADS_PER_LINE 64.\\n#define SUBDIVISIONS_PER_QUAD 16.\\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\\nconst float tension = 0.5;\\n\\nvec2 funky(const float id) {\\n float v = id / QUADS_PER_LINE * 4.;\\n float t = time;\\n vec2 p = vec2(\\n (sin(v + t) * 0.5 + sin(v * .37 + t) * 0.5 + sin(v * 2.951 + t)) / 3.,\\n (cos(v * 9.12 + t) * 0.5 + cos(v * .37 + t) + cos(v * 2.951 + t)) / 3.\\n );\\n p.x *= 0.2;\\n return p;\\n}\\n\\nvec3 getCenterPoint(const float id) {\\n vec4 t = vec4(0);\\n t.xy = funky(id);\\n //t.x = id / QUADS_PER_LINE;\\n //t.y = 0.;\\n return vec3(t.x, t.y, 0);\\n}\\n\\nvec3 getCurvePoint(const float superId) {\\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n vec3 q0 = getCenterPoint(quadId - 1.);\\n vec3 q1 = getCenterPoint(quadId + 0.);\\n vec3 q2 = getCenterPoint(quadId + 1.);\\n vec3 q3 = getCenterPoint(quadId + 2.);\\n vec3 q4 = getCenterPoint(quadId + 3.);\\n vec3 q5 = getCenterPoint(quadId + 4.);\\n \\n float s2 = pow(subV, 2.);\\n float s3 = pow(subV, 3.);\\n \\n float c1 = 2. * s3 - 3. * s2 + 1.;\\n float c2 = -(2. * s3) + 3. * s2; \\n float c3 = s3 - 2. * s2 + subV; \\n float c4 = s3 - s2; \\n\\n vec3 t1 = (q2 - q0) * tension;\\n vec3 t2 = (q3 - q1) * tension;\\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \\n}\\n\\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n \\n vec3 q0 = getCurvePoint(cpId + 0.);\\n vec3 q1 = getCurvePoint(cpId + 1.);\\n vec3 q2 = getCurvePoint(cpId + 2.);\\n vec3 q3 = getCurvePoint(cpId + 3.);\\n vec3 q4 = getCurvePoint(cpId + 4.);\\n vec3 q5 = getCurvePoint(cpId + 5.);\\n\\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n #if 0\\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #else\\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #endif\\n \\n uv = vec2(ux, vy);\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\nvoid main() {\\n float vId = vertexId;\\n if (vId < 6.) {\\n gl_Position = vec4(getQPoint(vId).xy * 2. - 1., 0.99, 1);\\n v_color = vec4(hsv2rgb(0.5 + vec3(time * 0.05, 1, 1)), 1.);\\n return;\\n \\n }\\n vId -= 6.; \\n float lineId = floor(vId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vId, 6.);\\n float quadId = floor(mod(vId, POINTS_PER_LINE) / 6.);\\n float quadV = quadId / quadCount;\\n float invQuadV = inv(quadV);\\n vec3 pos;\\n vec2 uv;\\n\\n float snd0 = texture2D(sound, vec2(fract(quadV * 0.5) * .05, quadV * 0.)).a;\\n float snd1 = texture2D(sound, vec2(0.14, quadV * 0.15)).a;\\n \\n getQuadPoint(quadId, pointId, mix(0.025, 0.30, pow(snd0 + 0.0, 15.)), vec2(0), pos, uv); \\n pos.z = quadV;\\n \\n mat4 mat = ident(); \\n \\n mat *= rotZ(sin(time * 0.4 + quadId * 0.003) + lineId * PI * 0.25);\\n mat *= scale(vec3(\\n mix(1., -1., step(7.5, lineId)),\\n resolution.x / resolution.y,\\n 1));\\n\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.25, snd1) + time * 0.05;\\n float sat = 1.;\\n hue += mix(1.05, 0.0, step(10., mod(quadId, 20.)));\\n float val = mix(1., 0.0, step(35., mod(quadId, 50.)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);//invQuadV);\\n //v_color.a = mix(1.0, 0.5, step(50., mod(quadId, 100.)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n\\n}\\n\\n\"}", + "settings": { + "num": 98310, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kushalputhran/jai-ganesh-jai-ganesh-jai", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 0.6313725490196078, + 0.43137254901960786, + 1 + ], + "shader": "/*\n\n ▌ ▐·▄▄▄ .▄▄▄ ▄▄▄▄▄▄▄▄ .▐▄• ▄ .▄▄ · ▄ .▄ ▄▄▄· ·▄▄▄▄ ▄▄▄ .▄▄▄ ▄▄▄· ▄▄▄ ▄▄▄▄▄\n▪█·█▌▀▄.▀·▀▄ █·•██ ▀▄.▀· █▌█▌▪▐█ ▀. ██▪▐█▐█ ▀█ ██▪ ██ ▀▄.▀·▀▄ █·▐█ ▀█ ▀▄ █·•██ \n▐█▐█•▐▀▀▪▄▐▀▀▄ ▐█.▪▐▀▀▪▄ ·██· ▄▀▀▀█▄██▀▐█▄█▀▀█ ▐█· ▐█▌▐▀▀▪▄▐▀▀▄ ▄█▀▀█ ▐▀▀▄ ▐█.▪\n ███ ▐█▄▄▌▐█•█▌ ▐█▌·▐█▄▄▌▪▐█·█▌▐█▄▪▐███▌▐▀▐█ ▪▐▌██. ██ ▐█▄▄▌▐█•█▌▐█ ▪▐▌▐█•█▌ ▐█▌·\n. ▀ ▀▀▀ .▀ ▀ ▀▀▀ ▀▀▀ •▀▀ ▀▀ ▀▀▀▀ ▀▀▀ · ▀ ▀ ▀▀▀▀▀• ▀▀▀ .▀ ▀ ▀ ▀ .▀ ▀ ▀▀▀ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define QUADS_PER_LINE 64.\n#define SUBDIVISIONS_PER_QUAD 16.\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\nconst float tension = 0.5;\n\nvec2 funky(const float id) {\n float v = id / QUADS_PER_LINE * 4.;\n float t = time;\n vec2 p = vec2(\n (sin(v + t) * 0.5 + sin(v * .37 + t) * 0.5 + sin(v * 2.951 + t)) / 3.,\n (cos(v * 9.12 + t) * 0.5 + cos(v * .37 + t) + cos(v * 2.951 + t)) / 3.\n );\n p.x *= 0.2;\n return p;\n}\n\nvec3 getCenterPoint(const float id) {\n vec4 t = vec4(0);\n t.xy = funky(id);\n //t.x = id / QUADS_PER_LINE;\n //t.y = 0.;\n return vec3(t.x, t.y, 0);\n}\n\nvec3 getCurvePoint(const float superId) {\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n vec3 q0 = getCenterPoint(quadId - 1.);\n vec3 q1 = getCenterPoint(quadId + 0.);\n vec3 q2 = getCenterPoint(quadId + 1.);\n vec3 q3 = getCenterPoint(quadId + 2.);\n vec3 q4 = getCenterPoint(quadId + 3.);\n vec3 q5 = getCenterPoint(quadId + 4.);\n \n float s2 = pow(subV, 2.);\n float s3 = pow(subV, 3.);\n \n float c1 = 2. * s3 - 3. * s2 + 1.;\n float c2 = -(2. * s3) + 3. * s2; \n float c3 = s3 - 2. * s2 + subV; \n float c4 = s3 - s2; \n\n vec3 t1 = (q2 - q0) * tension;\n vec3 t2 = (q3 - q1) * tension;\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \n}\n\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n \n vec3 q0 = getCurvePoint(cpId + 0.);\n vec3 q1 = getCurvePoint(cpId + 1.);\n vec3 q2 = getCurvePoint(cpId + 2.);\n vec3 q3 = getCurvePoint(cpId + 3.);\n vec3 q4 = getCurvePoint(cpId + 4.);\n vec3 q5 = getCurvePoint(cpId + 5.);\n\n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n #if 0\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #else\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #endif\n \n uv = vec2(ux, vy);\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\nvoid main() {\n float vId = vertexId;\n if (vId < 6.) {\n gl_Position = vec4(getQPoint(vId).xy * 2. - 1., 0.99, 1);\n v_color = vec4(hsv2rgb(0.5 + vec3(time * 0.05, 1, 1)), 1.);\n return;\n \n }\n vId -= 6.; \n float lineId = floor(vId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vId, 6.);\n float quadId = floor(mod(vId, POINTS_PER_LINE) / 6.);\n float quadV = quadId / quadCount;\n float invQuadV = inv(quadV);\n vec3 pos;\n vec2 uv;\n\n float snd0 = texture2D(sound, vec2(fract(quadV * 0.5) * .05, quadV * 0.)).a;\n float snd1 = texture2D(sound, vec2(0.14, quadV * 0.15)).a;\n \n getQuadPoint(quadId, pointId, mix(0.025, 0.30, pow(snd0 + 0.0, 15.)), vec2(0), pos, uv); \n pos.z = quadV;\n \n mat4 mat = ident(); \n \n mat *= rotZ(sin(time * 0.4 + quadId * 0.003) + lineId * PI * 0.25);\n mat *= scale(vec3(\n mix(1., -1., step(7.5, lineId)),\n resolution.x / resolution.y,\n 1));\n\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.25, snd1) + time * 0.05;\n float sat = 1.;\n hue += mix(1.05, 0.0, step(10., mod(quadId, 20.)));\n float val = mix(1., 0.0, step(35., mod(quadId, 50.)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);//invQuadV);\n //v_color.a = mix(1.0, 0.5, step(50., mod(quadId, 100.)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n\n}\n\n" + }, "screenshotURL": "data/images/images-1vm3pfdtczwhl2oki-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5fxiyfRNSgGzTdxZG/art.json b/art/5fxiyfRNSgGzTdxZG/art.json index 1a3f5c0e..02e98851 100644 --- a/art/5fxiyfRNSgGzTdxZG/art.json +++ b/art/5fxiyfRNSgGzTdxZG/art.json @@ -27,7 +27,19 @@ "name": "texture", "private": true, "username": "spotline", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/resting-at-the-mainframes-inn-ft-hirundo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define K 1.0594630943592952645618\\n\\nvec4 hueRamp(vec4 col)\\n{\\n vec4 blu = vec4(0.2,0.2,0.8,1.0);\\n vec4 red = vec4(1.0,0.2,0.2,1.0);\\n vec4 orange = vec4(1.0,0.5,0.1,1.0);\\n vec4 yelo = vec4(1.0,1.0,0.2,1.0);\\n vec4 white = vec4(1.0,1.0,1.0,1.0);\\n vec4 result = mix(blu,red,col.a);\\n return result;\\n}\\n\\nvoid main() \\n{\\n float W = 400.0;\\n float H = 250.0;\\n float u = 0.0;\\n float v = 0.0;\\n u = mod(vertexId/W,1.0);\\n v = floor(vertexId/W)/H;\\n float uScaled = pow(2.0,u*0.2)-1.0;\\n float vScaled = pow(abs(v-0.5)*1.3,1.2);\\n \\n v_color = vec4(pow(texture2D(sound,vec2(uScaled,vScaled)).a,4.0));\\n v_color = hueRamp(v_color);\\n \\n float x = v*-2.0 + 1.0;\\n float y;\\n y = u*2.0 - 0.8 + 0.05*pow(x,2.0);\\n gl_PointSize = 12.0;\\n gl_Position = vec4(x,y,0,1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/resting-at-the-mainframes-inn-ft-hirundo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define K 1.0594630943592952645618\n\nvec4 hueRamp(vec4 col)\n{\n vec4 blu = vec4(0.2,0.2,0.8,1.0);\n vec4 red = vec4(1.0,0.2,0.2,1.0);\n vec4 orange = vec4(1.0,0.5,0.1,1.0);\n vec4 yelo = vec4(1.0,1.0,0.2,1.0);\n vec4 white = vec4(1.0,1.0,1.0,1.0);\n vec4 result = mix(blu,red,col.a);\n return result;\n}\n\nvoid main() \n{\n float W = 400.0;\n float H = 250.0;\n float u = 0.0;\n float v = 0.0;\n u = mod(vertexId/W,1.0);\n v = floor(vertexId/W)/H;\n float uScaled = pow(2.0,u*0.2)-1.0;\n float vScaled = pow(abs(v-0.5)*1.3,1.2);\n \n v_color = vec4(pow(texture2D(sound,vec2(uScaled,vScaled)).a,4.0));\n v_color = hueRamp(v_color);\n \n float x = v*-2.0 + 1.0;\n float y;\n y = u*2.0 - 0.8 + 0.05*pow(x,2.0);\n gl_PointSize = 12.0;\n gl_Position = vec4(x,y,0,1);\n}\n" + }, "screenshotURL": "data/images/images-bsnlge8v3nz9bdinq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5gKRQuwx63MAdRePc/art.json b/art/5gKRQuwx63MAdRePc/art.json index ae4a828b..b4167584 100644 --- a/art/5gKRQuwx63MAdRePc/art.json +++ b/art/5gKRQuwx63MAdRePc/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":2439,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/soulkai/sunset-killer\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* Lambmeow */ \\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId/across);\\n \\n float u = x/(across-1.);\\n float v = y/(across- 1.);\\n \\n float xoff = sin(time + y *.2);\\n float yoff = sin(time +x *.2);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * texture2D(sound,vec2(u,v)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float snd = texture2D(sound, vec2(u,v/4.)).a;\\n \\n float soff = sin(time +x * y ) * .5 ;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/ 600.;\\n float h = (u +cos(time * -v))* sin(time * .3) + snd;\\n float s = 1.;\\n float val = v+.8;\\n v_color = vec4(hsv2rgb(vec3(h,s,val)),1);\\n}\"}", + "settings": { + "num": 2439, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/soulkai/sunset-killer", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* Lambmeow */ \n\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId/across);\n \n float u = x/(across-1.);\n float v = y/(across- 1.);\n \n float xoff = sin(time + y *.2);\n float yoff = sin(time +x *.2);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * texture2D(sound,vec2(u,v)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float snd = texture2D(sound, vec2(u,v/4.)).a;\n \n float soff = sin(time +x * y ) * .5 ;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/ 600.;\n float h = (u +cos(time * -v))* sin(time * .3) + snd;\n float s = 1.;\n float val = v+.8;\n v_color = vec4(hsv2rgb(vec3(h,s,val)),1);\n}" + }, "screenshotURL": "data/images/images-a2scx6zv2rhhrm13n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5hbYiwjeJvx8tCTME/art.json b/art/5hbYiwjeJvx8tCTME/art.json index 0887dc76..93dcbad0 100644 --- a/art/5hbYiwjeJvx8tCTME/art.json +++ b/art/5hbYiwjeJvx8tCTME/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "P_Malin", "avatarUrl": "https://pbs.twimg.com/profile_images/2157402471/Profile_200x200.png", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n#define TAU radians(360.0)\\n\\nfloat seed;\\n\\nfloat fhash(float f)\\n{\\n return fract(sin(f*123.456)*234.5678);\\n}\\n\\nfloat fhash()\\n{\\n seed=fhash(seed);\\n return seed;\\n}\\n\\nmat2 Rotate(float b)\\n{\\n float c=cos(b),s=sin(b);\\n return mat2(c,-s,s,c);\\n}\\n\\nfloat saturate( float x ) { return clamp(x,0.,1.); }\\n\\n\\nvoid main() {\\n float starCount = 1000.0;\\n \\n seed = floor(vertexId / starCount);\\n \\n float singlePointCount = 4000.;\\n \\n if (vertexId < singlePointCount)\\n {\\n seed = vertexId / singlePointCount;\\n }\\n \\n vec3 O = vec3(fhash(), fhash(), fhash()) * 2.0 - 1.0;\\n O.z += 1.0;\\n O = O * 500.0;\\n \\n float R = fhash()*TAU;\\n float Q = fhash()*TAU;\\n \\n float A = fhash() * 5.0;\\n \\n vec3 col = vec3(fhash(), fhash(), fhash());\\n col.g = (col.r + col.b) / 2.;\\n \\n seed = mod(vertexId, starCount) / starCount; \\n\\n float s = -log(fhash());\\n \\n float theta=fhash()*TAU + time*.1;\\n vec2 es = vec2(1,.5);\\n vec2 ePos = vec2(sin(theta),cos(theta))*es*s;\\n \\n float rotA = s*A + fhash();\\n \\n ePos = ePos * Rotate(rotA);\\n \\n float D=dot(ePos,ePos) / dot(es,es);\\n float H=((pow(2.7,-D*30.))+2.)*.2;\\n float Z=pow((fhash()*2.0-1.),3.0)*H;\\n \\n vec3 P = vec3(ePos, Z) * 10.;\\n \\n P.yz *= Rotate(R);\\n P.xy *= Rotate(Q);\\n \\n P = P + O;\\n P.z -= time * 20.;\\n P.z = mod(P.z, 1000.0);\\n \\n ePos = P.xy;\\n ePos /= P.z;\\n \\n \\n vec2 screenPos = ePos * (resolution.yx / resolution.x);\\n \\n gl_PointSize = 1. + 500. / P.z;\\n //gl_PointSize = 2.;\\n\\n gl_Position=vec4(screenPos,1.0 / vertexId,1);\\n \\n vec3 col2 = col + fhash();\\n col2 *= .3;\\n \\n float fade = (1000.-P.z) / 1000.0;\\n col2 *= sqrt(fade);\\n \\n v_color=vec4(col2, 0); \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n#define TAU radians(360.0)\n\nfloat seed;\n\nfloat fhash(float f)\n{\n return fract(sin(f*123.456)*234.5678);\n}\n\nfloat fhash()\n{\n seed=fhash(seed);\n return seed;\n}\n\nmat2 Rotate(float b)\n{\n float c=cos(b),s=sin(b);\n return mat2(c,-s,s,c);\n}\n\nfloat saturate( float x ) { return clamp(x,0.,1.); }\n\n\nvoid main() {\n float starCount = 1000.0;\n \n seed = floor(vertexId / starCount);\n \n float singlePointCount = 4000.;\n \n if (vertexId < singlePointCount)\n {\n seed = vertexId / singlePointCount;\n }\n \n vec3 O = vec3(fhash(), fhash(), fhash()) * 2.0 - 1.0;\n O.z += 1.0;\n O = O * 500.0;\n \n float R = fhash()*TAU;\n float Q = fhash()*TAU;\n \n float A = fhash() * 5.0;\n \n vec3 col = vec3(fhash(), fhash(), fhash());\n col.g = (col.r + col.b) / 2.;\n \n seed = mod(vertexId, starCount) / starCount; \n\n float s = -log(fhash());\n \n float theta=fhash()*TAU + time*.1;\n vec2 es = vec2(1,.5);\n vec2 ePos = vec2(sin(theta),cos(theta))*es*s;\n \n float rotA = s*A + fhash();\n \n ePos = ePos * Rotate(rotA);\n \n float D=dot(ePos,ePos) / dot(es,es);\n float H=((pow(2.7,-D*30.))+2.)*.2;\n float Z=pow((fhash()*2.0-1.),3.0)*H;\n \n vec3 P = vec3(ePos, Z) * 10.;\n \n P.yz *= Rotate(R);\n P.xy *= Rotate(Q);\n \n P = P + O;\n P.z -= time * 20.;\n P.z = mod(P.z, 1000.0);\n \n ePos = P.xy;\n ePos /= P.z;\n \n \n vec2 screenPos = ePos * (resolution.yx / resolution.x);\n \n gl_PointSize = 1. + 500. / P.z;\n //gl_PointSize = 2.;\n\n gl_Position=vec4(screenPos,1.0 / vertexId,1);\n \n vec3 col2 = col + fhash();\n col2 *= .3;\n \n float fade = (1000.-P.z) / 1000.0;\n col2 *= sqrt(fade);\n \n v_color=vec4(col2, 0); \n}" + }, "screenshotURL": "data/images/images-ptde8y850tnu02ve0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5hf6Sm43wvfKW9tvA/art.json b/art/5hf6Sm43wvfKW9tvA/art.json index 913b3c16..b237c134 100644 --- a/art/5hf6Sm43wvfKW9tvA/art.json +++ b/art/5hf6Sm43wvfKW9tvA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cjensen93", "avatarUrl": "https://secure.gravatar.com/avatar/0df4239ac208a0c9696c1edd2e895cee?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/100gecs/gec-2-ue-remix-feat-dorian\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n\\n}\\n\\n\\nvoid main(){\\n \\n #define PI 3.14159265;\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2.0 - 1.0 + xOff;\\n float uy = v * 2.0 - 1.0 + yOff;\\n \\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float angleV = length(vec2(su, sv));\\n float angleU = abs(atan(su, sv)) / PI;\\n // changes y value from center\\n //float sound = texture2D(sound, vec2(u * 0.125, sv * 0.125)).a;\\n \\n //Changes x value from center\\n //float sound = texture2D(sound, vec2(su * 0.125, 0.0)).a;\\n \\n float sound = texture2D(sound, vec2(angleU * 0.125, angleV * 0.125)).a;\\n\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n \\n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(sound, 5.0) * 30.0 + sOff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.7, sound);\\n \\n float hue = u * 0.1 + sound * 0.4 + time * 0.1;\\n float sat = mix(0.0, 1.0, pump);//mix(1.0, 0.0, angleV);\\n float value = mix(0.1, pow(sound + 0.2, 5.0), pump);//sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/100gecs/gec-2-ue-remix-feat-dorian", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n\n}\n\n\nvoid main(){\n \n #define PI 3.14159265;\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2.0 - 1.0 + xOff;\n float uy = v * 2.0 - 1.0 + yOff;\n \n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float angleV = length(vec2(su, sv));\n float angleU = abs(atan(su, sv)) / PI;\n // changes y value from center\n //float sound = texture2D(sound, vec2(u * 0.125, sv * 0.125)).a;\n \n //Changes x value from center\n //float sound = texture2D(sound, vec2(su * 0.125, 0.0)).a;\n \n float sound = texture2D(sound, vec2(angleU * 0.125, angleV * 0.125)).a;\n\n \n gl_Position = vec4(xy,0.0,1.0);\n \n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(sound, 5.0) * 30.0 + sOff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.7, sound);\n \n float hue = u * 0.1 + sound * 0.4 + time * 0.1;\n float sat = mix(0.0, 1.0, pump);//mix(1.0, 0.0, angleV);\n float value = mix(0.1, pow(sound + 0.2, 5.0), pump);//sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-tyk8ju4um3dnol4rk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5kD5fS5JQyTcEzoY8/art.json b/art/5kD5fS5JQyTcEzoY8/art.json index 266301b5..fcdd32ce 100644 --- a/art/5kD5fS5JQyTcEzoY8/art.json +++ b/art/5kD5fS5JQyTcEzoY8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat enhance(float v, float freq) {\\n v *= 0.8 + freq; // enhance strength of high-end values\\n v = smoothstep(0.33, 0.7, v);\\n return pow(v, 4.); // enhance enhance enhance\\n}\\n\\nvoid main() {\\n vec2 res = resolution * 0.25;\\n float width = res.x;\\n vec2 vUV = vec2(mod(vertexId, width), floor(vertexId / width)) / res;\\n \\n vec2 sUV = (vUV+0.00)*0.66;\\n float col = texture2D(sound, sUV).a;\\n col = enhance(col, sUV.x);\\n \\n // attempting to use the previous frame of audio to enhance the current\\n float delta = 1./480.;\\n sUV.y += delta;\\n float iterations = 5.;\\n sUV.x -= delta * floor(iterations * 0.5);\\n float col2 = 0.;\\n for(float i = 1.; i <= 5.; i++) {\\n float snd = texture2D(sound, sUV).a;\\n snd = enhance(snd, sUV.x);\\n \\n //average\\n /*\\n float newpercent = 1. / i;\\n col2 = col2 * (1. - newpercent) + snd * newpercent;\\n\\t*/\\n \\n //max\\n col2 = max(col2, snd);\\n \\n sUV.x += delta;\\n }\\n col2 *= 2.;\\n col *= col2;\\n \\n gl_Position = vec4(vUV * 2. - 1., 0.0, 1.0);\\n gl_PointSize = 4.0;\\n v_color = vec4(col);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat enhance(float v, float freq) {\n v *= 0.8 + freq; // enhance strength of high-end values\n v = smoothstep(0.33, 0.7, v);\n return pow(v, 4.); // enhance enhance enhance\n}\n\nvoid main() {\n vec2 res = resolution * 0.25;\n float width = res.x;\n vec2 vUV = vec2(mod(vertexId, width), floor(vertexId / width)) / res;\n \n vec2 sUV = (vUV+0.00)*0.66;\n float col = texture2D(sound, sUV).a;\n col = enhance(col, sUV.x);\n \n // attempting to use the previous frame of audio to enhance the current\n float delta = 1./480.;\n sUV.y += delta;\n float iterations = 5.;\n sUV.x -= delta * floor(iterations * 0.5);\n float col2 = 0.;\n for(float i = 1.; i <= 5.; i++) {\n float snd = texture2D(sound, sUV).a;\n snd = enhance(snd, sUV.x);\n \n //average\n /*\n float newpercent = 1. / i;\n col2 = col2 * (1. - newpercent) + snd * newpercent;\n\t*/\n \n //max\n col2 = max(col2, snd);\n \n sUV.x += delta;\n }\n col2 *= 2.;\n col *= col2;\n \n gl_Position = vec4(vUV * 2. - 1., 0.0, 1.0);\n gl_PointSize = 4.0;\n v_color = vec4(col);\n}" + }, "screenshotURL": "data/images/images-1cxor1idzrh16a8c7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5ppKAhtsPPS3xfam7/art.json b/art/5ppKAhtsPPS3xfam7/art.json index 719d4d09..67d4e7df 100644 --- a/art/5ppKAhtsPPS3xfam7/art.json +++ b/art/5ppKAhtsPPS3xfam7/art.json @@ -21,7 +21,19 @@ "origId": "uQkpXdAa4ABNPNthi", "name": "sillage", "username": "spotline", - "settings": "{\"num\":5009,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/nested-volumes\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12941176470588237,0.27058823529411763,0.8470588235294118,1],\"shader\":\"#define NUM_POINTS 5000.0\\n//#define FIT_VERTICA\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main()\\n{\\n float u = (float(vertexId)/NUM_POINTS) * 2.0 - 1.0;\\n float v = 0.0;\\n float ucoor = log((abs(u)*.5 + 1.0));\\n v+= floor(texture2D(sound,vec2(ucoor,0.0)).a * 15.0)/10.0;\\n float osc = 0.2*cos(1.*(1.1*time+3.0*(abs(u)+1.0)));\\n float osc2 = 0.2*cos(1.*(-1.5*time+10.0*(u+1.0)));\\n float x = u * 2.0;\\n float y = v -0.5 + 0.5*pow(x,2.0) + osc +osc2;\\n gl_Position = vec4(x,y,0,1);\\n float colorfactor = pow(rand(vec2(x,y)),8.);\\n gl_PointSize = v*6.0 + colorfactor*1.0;\\n float r = mix(0.9,1.,colorfactor);\\n float g = mix(0.9,1.,colorfactor);\\n float b = 1.;\\n \\n v_color = vec4(r,g,b,colorfactor+0.5);\\n}\"}", + "settings": { + "num": 5009, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/nested-volumes", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12941176470588237, + 0.27058823529411763, + 0.8470588235294118, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n//#define FIT_VERTICA\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main()\n{\n float u = (float(vertexId)/NUM_POINTS) * 2.0 - 1.0;\n float v = 0.0;\n float ucoor = log((abs(u)*.5 + 1.0));\n v+= floor(texture2D(sound,vec2(ucoor,0.0)).a * 15.0)/10.0;\n float osc = 0.2*cos(1.*(1.1*time+3.0*(abs(u)+1.0)));\n float osc2 = 0.2*cos(1.*(-1.5*time+10.0*(u+1.0)));\n float x = u * 2.0;\n float y = v -0.5 + 0.5*pow(x,2.0) + osc +osc2;\n gl_Position = vec4(x,y,0,1);\n float colorfactor = pow(rand(vec2(x,y)),8.);\n gl_PointSize = v*6.0 + colorfactor*1.0;\n float r = mix(0.9,1.,colorfactor);\n float g = mix(0.9,1.,colorfactor);\n float b = 1.;\n \n v_color = vec4(r,g,b,colorfactor+0.5);\n}" + }, "screenshotURL": "data/images/images-u6al664te3f7x9h0z-thumbnail.jpg", "views": { "$numberInt": "196" diff --git a/art/5rPSkvavMCsT3A4KY/art.json b/art/5rPSkvavMCsT3A4KY/art.json index 687817cb..a7d87897 100644 --- a/art/5rPSkvavMCsT3A4KY/art.json +++ b/art/5rPSkvavMCsT3A4KY/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "정학", "avatarUrl": "https://lh6.googleusercontent.com/-OMiZ3nksbAM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd4iIW6pXdqajwjPLfViARoXXTGxg/mo/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float across = 10.;\\n \\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / across;\\n float v = y / across;\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float across = 10.;\n \n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / across;\n float v = y / across;\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-qtgtr2eeoi2ejcmyh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5sonvpkQLwAJqGqTk/art.json b/art/5sonvpkQLwAJqGqTk/art.json index 667799e6..bac6ee6e 100644 --- a/art/5sonvpkQLwAJqGqTk/art.json +++ b/art/5sonvpkQLwAJqGqTk/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jonaced", "avatarUrl": "https://secure.gravatar.com/avatar/4afc7bbaa73d3ae5795519659259854b?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"mat4 rotX(float divTime) {\\n float seno = sin(time / divTime);\\n float coseno = cos(time / divTime);\\n mat4 rotX = mat4(\\n 1.0,\\t0.0,\\t0.0,\\t0.0,\\n 0.0,\\tcoseno,\\t-seno,\\t0.0,\\n 0.0,\\tseno,\\tcoseno,\\t0.0,\\n 0.0,\\t0.0,\\t0.0,\\t1.0);\\n return rotX;\\n}\\n\\nmat4 rotY(float divTime) {\\n float seno = sin(time / divTime);\\n float coseno = cos(time / divTime);\\n mat4 rotX = mat4(\\n coseno,\\t0.0,\\tseno,\\t0.0,\\n 0.0,\\t1.0,\\t0.0,\\t0.0,\\n -seno,\\t0.0,\\tcoseno,\\t0.0,\\n 0.0,\\t0.0,\\t0.0,\\t1.0);\\n return rotX;\\n}\\n\\nmat4 rotZ(float divTime) {\\n float seno = sin(time / divTime);\\n float coseno = cos(time / divTime);\\n mat4 rotZ = mat4(\\n coseno,\\t-seno,\\t0.0, \\t0.0,\\n seno,\\tcoseno,\\t0.0, \\t0.0,\\n 0.0,\\t0.0,\\t1.0, \\t0.0,\\n 0.0,\\t0.0,\\t0.0, \\t1.0);\\n return rotZ;\\n}\\n\\nvoid main()\\n{\\n float pointsPerCircle = 10000.;\\n float xyLen = sin(vertexId / pointsPerCircle * radians(180.0));\\n float xPos = sin(vertexId) * xyLen;\\n float yPos = cos(vertexId / pointsPerCircle * radians(180.0));\\n float zPos = cos(vertexId) * xyLen;\\n vec4 pos = vec4(xPos, yPos, zPos, 1.0);\\n pos = rotX(8.0) * rotY(6.0) * rotZ(4.0) * pos;\\n gl_Position = pos;\\n gl_PointSize = 2.0;\\n v_color = vec4(0.0, 0.5, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "mat4 rotX(float divTime) {\n float seno = sin(time / divTime);\n float coseno = cos(time / divTime);\n mat4 rotX = mat4(\n 1.0,\t0.0,\t0.0,\t0.0,\n 0.0,\tcoseno,\t-seno,\t0.0,\n 0.0,\tseno,\tcoseno,\t0.0,\n 0.0,\t0.0,\t0.0,\t1.0);\n return rotX;\n}\n\nmat4 rotY(float divTime) {\n float seno = sin(time / divTime);\n float coseno = cos(time / divTime);\n mat4 rotX = mat4(\n coseno,\t0.0,\tseno,\t0.0,\n 0.0,\t1.0,\t0.0,\t0.0,\n -seno,\t0.0,\tcoseno,\t0.0,\n 0.0,\t0.0,\t0.0,\t1.0);\n return rotX;\n}\n\nmat4 rotZ(float divTime) {\n float seno = sin(time / divTime);\n float coseno = cos(time / divTime);\n mat4 rotZ = mat4(\n coseno,\t-seno,\t0.0, \t0.0,\n seno,\tcoseno,\t0.0, \t0.0,\n 0.0,\t0.0,\t1.0, \t0.0,\n 0.0,\t0.0,\t0.0, \t1.0);\n return rotZ;\n}\n\nvoid main()\n{\n float pointsPerCircle = 10000.;\n float xyLen = sin(vertexId / pointsPerCircle * radians(180.0));\n float xPos = sin(vertexId) * xyLen;\n float yPos = cos(vertexId / pointsPerCircle * radians(180.0));\n float zPos = cos(vertexId) * xyLen;\n vec4 pos = vec4(xPos, yPos, zPos, 1.0);\n pos = rotX(8.0) * rotY(6.0) * rotZ(4.0) * pos;\n gl_Position = pos;\n gl_PointSize = 2.0;\n v_color = vec4(0.0, 0.5, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-prxm6gu300o8roan7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5v2eusj5uxKkdncH3/art.json b/art/5v2eusj5uxKkdncH3/art.json index 02d437e9..1c5e7e43 100644 --- a/art/5v2eusj5uxKkdncH3/art.json +++ b/art/5v2eusj5uxKkdncH3/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "manicacci", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mDyfFoqitxTWo-qZKhCHoB-NGUHXoLZQXHkfafGQA", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#ifndef GL_ES\\nprecision mediump float;\\n#endif\\n\\nvoid main() {\\n \\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#ifndef GL_ES\nprecision mediump float;\n#endif\n\nvoid main() {\n \n}" + }, "screenshotURL": "data/images/images-iap57hz9j570r2k0e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5vBB6qnTBzuES7iu5/art.json b/art/5vBB6qnTBzuES7iu5/art.json index cbb57fd1..da0ff352 100644 --- a/art/5vBB6qnTBzuES7iu5/art.json +++ b/art/5vBB6qnTBzuES7iu5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 3.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 3.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-bdss1thlfdt3mj4gr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5vfETRh3Q89xEEMAA/art.json b/art/5vfETRh3Q89xEEMAA/art.json index c274055a..1023a360 100644 --- a/art/5vfETRh3Q89xEEMAA/art.json +++ b/art/5vfETRh3Q89xEEMAA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n //float t = float(vertexId) / float(vertexCount);\\n \\n //vec3 xyz = vec3(cos(t), sin(t), 1.0);\\n \\n //gl_Position = vec4(xyz * 50.0, 1.0);\\n //v_color = min(vec4(2.),vec4(xyz.x,xyz.y,2,1))/max(0.,(-xyz.z*5.+5.));\\n float phi = vertexId / vertexCount * 3.14159265*2.0;\\n \\n float x = cos(phi);\\n float y = sin(phi);\\n float z = 0.0;\\n \\n float theta = 5.0 * sin(sign(y)*cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\\n \\n //x *= cos(theta);\\n y *= cos(theta);\\n z = sin(theta);\\n \\n vec4 pos = vec4(x, y, z, 1.0);\\n \\n \\n vec3 eye = vec3(sin(time), 0, cos(time));\\n vec3 right = vec3(-eye.z, 0, eye.x);\\n vec3 look = -eye;\\n /*\\nm[0]=right.x\\nm[1]=right.y\\nm[2]=right.z\\n\\nm[4]=up.x\\nm[5]=up.y\\nm[6]=up.z\\n\\nm[8]=look.x\\nm[9]=look.y\\nm[10]=look.z\\n*/\\n \\n mat4 L = mat4(vec4(right, 0), vec4(0, 1, 0, 0), vec4(look, 0), vec4(0, 0, 0, 1));\\n \\n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\\n v_color = vec4(sin(theta) *0.5 + 0.5,\\n cos(phi) *0.5 + 0.5,\\n sin(time) * 0.5 + 0.5,\\n 1.0);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n //float t = float(vertexId) / float(vertexCount);\n \n //vec3 xyz = vec3(cos(t), sin(t), 1.0);\n \n //gl_Position = vec4(xyz * 50.0, 1.0);\n //v_color = min(vec4(2.),vec4(xyz.x,xyz.y,2,1))/max(0.,(-xyz.z*5.+5.));\n float phi = vertexId / vertexCount * 3.14159265*2.0;\n \n float x = cos(phi);\n float y = sin(phi);\n float z = 0.0;\n \n float theta = 5.0 * sin(sign(y)*cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\n \n //x *= cos(theta);\n y *= cos(theta);\n z = sin(theta);\n \n vec4 pos = vec4(x, y, z, 1.0);\n \n \n vec3 eye = vec3(sin(time), 0, cos(time));\n vec3 right = vec3(-eye.z, 0, eye.x);\n vec3 look = -eye;\n /*\nm[0]=right.x\nm[1]=right.y\nm[2]=right.z\n\nm[4]=up.x\nm[5]=up.y\nm[6]=up.z\n\nm[8]=look.x\nm[9]=look.y\nm[10]=look.z\n*/\n \n mat4 L = mat4(vec4(right, 0), vec4(0, 1, 0, 0), vec4(look, 0), vec4(0, 0, 0, 1));\n \n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\n v_color = vec4(sin(theta) *0.5 + 0.5,\n cos(phi) *0.5 + 0.5,\n sin(time) * 0.5 + 0.5,\n 1.0);\n}" + }, "screenshotURL": "data/images/images-6gzwme8a2ssu6s0f4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5vn8CgvHBoa5KFxpa/art.json b/art/5vn8CgvHBoa5KFxpa/art.json index 73a30d9c..21d3755d 100644 --- a/art/5vn8CgvHBoa5KFxpa/art.json +++ b/art/5vn8CgvHBoa5KFxpa/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jluethi", "avatarUrl": "https://secure.gravatar.com/avatar/21e93db3614e6e91a28d7f82b4e44433?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.14901960784313725,0.12941176470588237,0.27058823529411763,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\nc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0/ 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n \\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across) ;\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.3;\\n \\n float ux = u * 2. -1. +xoff;\\n float vy = v * 2. -1. +yoff;\\n \\n vec2 xy =vec2(ux, vy)* 1.3;\\n \\n float soff = sin(time*2. + x * y * 0.02) * 25.;\\n \\n \\ngl_Position = vec4(xy,0,1);\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\nfloat hue = u * .1 + sin(time + v *20.) *0.05;\\nfloat sat = 1.;\\nfloat val = sin(time + v * u * 20.0) * 0.5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.14901960784313725, + 0.12941176470588237, + 0.27058823529411763, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\nc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0/ 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n \n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across) ;\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.3;\n \n float ux = u * 2. -1. +xoff;\n float vy = v * 2. -1. +yoff;\n \n vec2 xy =vec2(ux, vy)* 1.3;\n \n float soff = sin(time*2. + x * y * 0.02) * 25.;\n \n \ngl_Position = vec4(xy,0,1);\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \nfloat hue = u * .1 + sin(time + v *20.) *0.05;\nfloat sat = 1.;\nfloat val = sin(time + v * u * 20.0) * 0.5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-40cn2f0t4crjlh8s1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/5wpxiiCkDvE3Wsv5D/art.json b/art/5wpxiiCkDvE3Wsv5D/art.json index ecd36de6..186ed218 100644 --- a/art/5wpxiiCkDvE3Wsv5D/art.json +++ b/art/5wpxiiCkDvE3Wsv5D/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx,0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n //v_color.rgb = vec3(v_color.r, min(v_color.r*v_color.g, 1.0), min(v_color.b*v_color.g, 1.0));\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx,0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n //v_color.rgb = vec3(v_color.r, min(v_color.r*v_color.g, 1.0), min(v_color.b*v_color.g, 1.0));\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-5uges3daa81g028l4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/5y8GykbHCskE8dzPd/art.json b/art/5y8GykbHCskE8dzPd/art.json index e80f8443..2275733c 100644 --- a/art/5y8GykbHCskE8dzPd/art.json +++ b/art/5y8GykbHCskE8dzPd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "leon", "avatarUrl": "https://secure.gravatar.com/avatar/f317f07c8ac4ad3d72b708a2cb4070e3?default=retro&size=200", - "settings": "{\"num\":609,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nconst float pi = 3.1415;\\nconst float tau = 6.283;\\n#define ss(a,b,t) (smoothstep(a,b,t))\\n#define wr(a) (a*.5+.5)\\nmat2 rot(float a) { float c=cos(a), s=sin(a); return mat2(c,-s,s,c); }\\n\\nvoid main()\\n{\\n // element indices\\n float i = floor(vertexId/3.) / vertexCount * 3.;\\n float layers = 14.;\\n float ii = floor(i*layers);\\n float il = ii/layers;\\n i = i*layers;\\n float ia = i * tau;\\n vec2 circle = vec2(cos(ia),sin(ia));\\n \\n // triangle indices\\n float tri = fract(vertexId/3.);\\n float tria = tri * tau;\\n float top = step(mod(vertexId, 3.), 0.5);\\n \\n // parameters\\n float speed = 0.5;\\n float size = 0.05;\\n float radius = 0.5;\\n float height = 0.1;\\n \\n // fade size\\n float anim = fract(time*speed-il);\\n size *= sin(anim*pi);\\n height *= sin(anim*pi);\\n \\n // triangle shape\\n vec2 uv = vec2(cos(tria + ia),sin(tria + ia));\\n vec3 pos = vec3(0);\\n pos.xy += uv * size * (1.-top);\\n pos.z -= top * height;\\n \\n // translate\\n pos.z -= ((anim)*2.-1.)*.5;\\n \\n // circle distribution\\n pos.xy += circle*radius;\\n \\n // camera rotation\\n pos.xz *= rot(sin(time*speed)*.3);\\n pos.yz *= rot(cos(time*speed)*.3);\\n \\n // origin offset\\n pos.z += 1.;\\n \\n // perspective\\n pos.xy = pos.xy / max(0.01,pos.z);\\n pos.x *= resolution.y/resolution.x;\\n \\n // result\\n gl_Position = vec4(pos.xy, 0, 1);\\n v_color = vec4(1.-top);\\n}\"}", + "settings": { + "num": 609, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nconst float pi = 3.1415;\nconst float tau = 6.283;\n#define ss(a,b,t) (smoothstep(a,b,t))\n#define wr(a) (a*.5+.5)\nmat2 rot(float a) { float c=cos(a), s=sin(a); return mat2(c,-s,s,c); }\n\nvoid main()\n{\n // element indices\n float i = floor(vertexId/3.) / vertexCount * 3.;\n float layers = 14.;\n float ii = floor(i*layers);\n float il = ii/layers;\n i = i*layers;\n float ia = i * tau;\n vec2 circle = vec2(cos(ia),sin(ia));\n \n // triangle indices\n float tri = fract(vertexId/3.);\n float tria = tri * tau;\n float top = step(mod(vertexId, 3.), 0.5);\n \n // parameters\n float speed = 0.5;\n float size = 0.05;\n float radius = 0.5;\n float height = 0.1;\n \n // fade size\n float anim = fract(time*speed-il);\n size *= sin(anim*pi);\n height *= sin(anim*pi);\n \n // triangle shape\n vec2 uv = vec2(cos(tria + ia),sin(tria + ia));\n vec3 pos = vec3(0);\n pos.xy += uv * size * (1.-top);\n pos.z -= top * height;\n \n // translate\n pos.z -= ((anim)*2.-1.)*.5;\n \n // circle distribution\n pos.xy += circle*radius;\n \n // camera rotation\n pos.xz *= rot(sin(time*speed)*.3);\n pos.yz *= rot(cos(time*speed)*.3);\n \n // origin offset\n pos.z += 1.;\n \n // perspective\n pos.xy = pos.xy / max(0.01,pos.z);\n pos.x *= resolution.y/resolution.x;\n \n // result\n gl_Position = vec4(pos.xy, 0, 1);\n v_color = vec4(1.-top);\n}" + }, "screenshotURL": "data/images/images-ansonix1pnrfdgif8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/627rN6vKn3Edv5K5G/art.json b/art/627rN6vKn3Edv5K5G/art.json index 70e4f391..d11ad03b 100644 --- a/art/627rN6vKn3Edv5K5G/art.json +++ b/art/627rN6vKn3Edv5K5G/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/wigae/pilot?si=fadac0229014470bae0ae92399497b80&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//Name : Jemin.Shin\\n//assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Coruse : CS250\\n//Date : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff * sin(time);\\n float vy = v * 2. - 1. + yoff * cos(time);\\n \\n vec2 xy = vec2(ux, vy) * abs(tan(time)) ;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 10.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.3, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/wigae/pilot?si=fadac0229014470bae0ae92399497b80&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//Name : Jemin.Shin\n//assignment : Exercise - Vertexshaderart : Audio Reactive\n//Coruse : CS250\n//Date : 2023 Fall\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff * sin(time);\n float vy = v * 2. - 1. + yoff * cos(time);\n \n vec2 xy = vec2(ux, vy) * abs(tan(time)) ;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 10.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.3, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-ev8y7305t1miq9dw6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6329mueSGExenMjbN/art.json b/art/6329mueSGExenMjbN/art.json index 40cdb9b1..945958a8 100644 --- a/art/6329mueSGExenMjbN/art.json +++ b/art/6329mueSGExenMjbN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":99940,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/didrec/ken-ishii-malfunction-10\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n // vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .17);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s +.1, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\\n float sat = .0;//step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb *= v_color.a;\\n \\n float super = .0;step(0.99, s);\\n v_color = mix(v_color, vec4(1,0,0,1), super);\\n \\n}\\n\"}", + "settings": { + "num": 99940, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/didrec/ken-ishii-malfunction-10", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n // vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .17);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s +.1, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\n float sat = .0;//step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb *= v_color.a;\n \n float super = .0;step(0.99, s);\n v_color = mix(v_color, vec4(1,0,0,1), super);\n \n}\n" + }, "screenshotURL": "data/images/images-n9yitjbwphsnnxikq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/63qyzzMSCLNjCirhM/art.json b/art/63qyzzMSCLNjCirhM/art.json index 52a9a2a4..626a523c 100644 --- a/art/63qyzzMSCLNjCirhM/art.json +++ b/art/63qyzzMSCLNjCirhM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.027450980392156862,0.011764705882352941,0.0196078431372549,1],\"shader\":\"\\n\\n\\nvoid main() {\\n gl_PointSize = 15.0;\\n v_color = vec4(0.0,0.0,0.0,1.0);\\n gl_Position = vec4(0.0,0.0,0.0,1.0);\\n \\n\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.027450980392156862, + 0.011764705882352941, + 0.0196078431372549, + 1 + ], + "shader": "\n\n\nvoid main() {\n gl_PointSize = 15.0;\n v_color = vec4(0.0,0.0,0.0,1.0);\n gl_Position = vec4(0.0,0.0,0.0,1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-d4fibv7djvebcag69-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/644CG7p6wywm6hcNt/art.json b/art/644CG7p6wywm6hcNt/art.json index 272a19d7..91d988ca 100644 --- a/art/644CG7p6wywm6hcNt/art.json +++ b/art/644CG7p6wywm6hcNt/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .5//KParameter 0.>>5.\\n#define PointSizeValue 2.//KParameter 1.>>4.\\n#define colorFactorR 0.//KParameter 0.>>1.\\n#define colorFactorG 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79553//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n\\nvec3 posf2(float t, float i) {\\n //return vec3(sin(t+i*.9553),cos(t+i*.9553),sin(t+i*.79553));\\n return vec3(sin(t+i*posFactorX),cos(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*posComp0;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\\n \\n // more or less random movement\\n float t = time*timeFactor;\\n float i = localVertexId;//+sin(localVertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(colorFactorR,colorFactorG,0.);\\n \\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\\n //v_color = vec4(0.,0.,0.,1.);//abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .5//KParameter 0.>>5.\n#define PointSizeValue 2.//KParameter 1.>>4.\n#define colorFactorR 0.//KParameter 0.>>1.\n#define colorFactorG 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79553//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n\nvec3 posf2(float t, float i) {\n //return vec3(sin(t+i*.9553),cos(t+i*.9553),sin(t+i*.79553));\n return vec3(sin(t+i*posFactorX),cos(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*posComp0;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\n \n // more or less random movement\n float t = time*timeFactor;\n float i = localVertexId;//+sin(localVertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(colorFactorR,colorFactorG,0.);\n \n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\n //v_color = vec4(0.,0.,0.,1.);//abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\n}" + }, "screenshotURL": "data/images/images-l9scl6phqc1uqietv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/684pim4aQdsJFnh9S/art.json b/art/684pim4aQdsJFnh9S/art.json index 3f9c36c6..9c5adc3d 100644 --- a/art/684pim4aQdsJFnh9S/art.json +++ b/art/684pim4aQdsJFnh9S/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.35294117647058826,0.6,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.35294117647058826, + 0.6, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-5b3rlwn57y8ad9fzz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6C6jC7cgKsabzRcL8/art.json b/art/6C6jC7cgKsabzRcL8/art.json index 8a93c460..ceff742e 100644 --- a/art/6C6jC7cgKsabzRcL8/art.json +++ b/art/6C6jC7cgKsabzRcL8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":56134,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 15.//KParameter0 -15.>>20.\\n#define parameter1 5.//KParameter1 -15.>>20.\\n#define parameter2 1.5//KParameter2 0.>> 5.\\n\\n\\n#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; cx-sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. + soundTexCoords0.x) + 0.1 /parameter2;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 56134, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 15.//KParameter0 -15.>>20.\n#define parameter1 5.//KParameter1 -15.>>20.\n#define parameter2 1.5//KParameter2 0.>> 5.\n\n\n#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; cx-sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. + soundTexCoords0.x) + 0.1 /parameter2;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-apbhfy2twat19fyy3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6EhsqQMiTAN8xv9yr/art.json b/art/6EhsqQMiTAN8xv9yr/art.json index 26e2d506..767f6472 100644 --- a/art/6EhsqQMiTAN8xv9yr/art.json +++ b/art/6EhsqQMiTAN8xv9yr/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/pornographicrecordings/ken-ishii-play-biting-original\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n\\n\\n\\nvec3 getCenterPoint(const float id, vec2 seed, float time) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n cos(0.01* id * time) * (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n sin(0.01*id * time) * (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + 0.0, seed, time);\\n vec3 p1 = getCenterPoint(quadId + 0.1, seed, time);\\n vec3 p2 = getCenterPoint(quadId + 0.2, seed, time);\\n vec3 p3 = getCenterPoint(quadId + 0.3, seed, time);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(0,0);//vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 1800.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float snd0 = 0.4; //0.5*sin(time); //texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n float snd1 = 0.0;//*cos(lineId*0.1); //texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId * 0.02 + time * (lineId + 1.), \\n pointId, \\n 0.01, \\n vec2(0, 0), \\n pos, \\n uv); \\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(quadId / quadCount);\\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.5, lineId * 0.1);\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/pornographicrecordings/ken-ishii-play-biting-original", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n\n\n\nvec3 getCenterPoint(const float id, vec2 seed, float time) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n cos(0.01* id * time) * (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n sin(0.01*id * time) * (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + 0.0, seed, time);\n vec3 p1 = getCenterPoint(quadId + 0.1, seed, time);\n vec3 p2 = getCenterPoint(quadId + 0.2, seed, time);\n vec3 p3 = getCenterPoint(quadId + 0.3, seed, time);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(0,0);//vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 1800.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float snd0 = 0.4; //0.5*sin(time); //texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n float snd1 = 0.0;//*cos(lineId*0.1); //texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId * 0.02 + time * (lineId + 1.), \n pointId, \n 0.01, \n vec2(0, 0), \n pos, \n uv); \n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(quadId / quadCount);\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.5, lineId * 0.1);\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-9fmpvfxmbrdgrznt6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6Gubrbbo9gDv8wczK/art.json b/art/6Gubrbbo9gDv8wczK/art.json index 832069e6..a01d8fed 100644 --- a/art/6Gubrbbo9gDv8wczK/art.json +++ b/art/6Gubrbbo9gDv8wczK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2731,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hugdealer/every-freakin-night-dj-0-0001-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, s, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, (sin(time * 3.)));\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 3.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .15));\\n gl_PointSize =pow(sz, s*s/32.\\n ) * resolution.y / 4776. * s* 30.;\\n \\n \\n\\n float hue = sz * 2. + s * 0.953;\\n float sat = 1.;\\n float val = s*2.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 2731, + "mode": "POINTS", + "sound": "https://soundcloud.com/hugdealer/every-freakin-night-dj-0-0001-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, s, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, (sin(time * 3.)));\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 3.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .15));\n gl_PointSize =pow(sz, s*s/32.\n ) * resolution.y / 4776. * s* 30.;\n \n \n\n float hue = sz * 2. + s * 0.953;\n float sat = 1.;\n float val = s*2.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-ad9tgxgftubtr19hb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6J7Jj9F2CdctHCkXB/art.json b/art/6J7Jj9F2CdctHCkXB/art.json index 6c5bc782..41baebed 100644 --- a/art/6J7Jj9F2CdctHCkXB/art.json +++ b/art/6J7Jj9F2CdctHCkXB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3514,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.1 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 3514, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.1 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-69rzkf81e9bp2b4hd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6K6qbdqNTrkx589QP/art.json b/art/6K6qbdqNTrkx589QP/art.json index 49f01e2c..a16b1a78 100644 --- a/art/6K6qbdqNTrkx589QP/art.json +++ b/art/6K6qbdqNTrkx589QP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":83035,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hug-life/freek-it-remaster\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 2);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 10.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 2.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * .33) + sin(time * .3 + circleId) * .1);\\n float end = start - 1.3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) -1.4;\\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.5, 6.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .32)).xyz, 1.2);\\n gl_PointSize = tan(2. *-snd);\\n float hue = mix(1.3*snd, 4.6/snd, fract(circleId -21.79)*3.);\\n float sat = 45.2 * circleId/snd;\\n float val = .29;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-=2.0);\\n}\"}", + "settings": { + "num": 83035, + "mode": "POINTS", + "sound": "https://soundcloud.com/hug-life/freek-it-remaster", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 2);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 10.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 2.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * .33) + sin(time * .3 + circleId) * .1);\n float end = start - 1.3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) -1.4;\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.5, 6.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .32)).xyz, 1.2);\n gl_PointSize = tan(2. *-snd);\n float hue = mix(1.3*snd, 4.6/snd, fract(circleId -21.79)*3.);\n float sat = 45.2 * circleId/snd;\n float val = .29;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-=2.0);\n}" + }, "screenshotURL": "data/images/images-vl1zk7phrwll58lxa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6KurZsv36w6xrAoSf/art.json b/art/6KurZsv36w6xrAoSf/art.json index 00e8993d..0d829052 100644 --- a/art/6KurZsv36w6xrAoSf/art.json +++ b/art/6KurZsv36w6xrAoSf/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":1681,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = time;\\n float sat = 1.;\\n float val = 1. / (length(vec2(mouse.x, mouse.y) - vec2(ux, vy))) * (sin(time * 10.) * .5 + .5);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1681, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = time;\n float sat = 1.;\n float val = 1. / (length(vec2(mouse.x, mouse.y) - vec2(ux, vy))) * (sin(time * 10.) * .5 + .5);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-pn2ypxa14pobtgdau-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6N22GnCbsgYC6faeW/art.json b/art/6N22GnCbsgYC6faeW/art.json index cee8e333..1213cad8 100644 --- a/art/6N22GnCbsgYC6faeW/art.json +++ b/art/6N22GnCbsgYC6faeW/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "철짜", "avatarUrl": "https://lh5.googleusercontent.com/-Ms9fjf33Cc0/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reZGVnMGsJP55FG1NwfwQX9im-L6Q/mo/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t = chulseung.lee\\nAssignment Name/Number = Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t= CS230\\nTerm\\t\\t\\t\\t\\t= Spring 2019\\n------------------------------------------------------------------------*/\\n\\nvoid main() {\\n gl_Position = vec4(mouse.x, mouse.y, 0, 1);\\n gl_PointSize = 300.0;\\n \\n gl_PointSize *= abs(mouse.x)+abs(mouse.y);\\n \\n v_color = vec4(sin(time*10.0), mouse.x * mouse.y, 1.0, 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t = chulseung.lee\nAssignment Name/Number = Shader/3 (Extra Credit)\nCourse Name\t\t\t\t= CS230\nTerm\t\t\t\t\t= Spring 2019\n------------------------------------------------------------------------*/\n\nvoid main() {\n gl_Position = vec4(mouse.x, mouse.y, 0, 1);\n gl_PointSize = 300.0;\n \n gl_PointSize *= abs(mouse.x)+abs(mouse.y);\n \n v_color = vec4(sin(time*10.0), mouse.x * mouse.y, 1.0, 1);\n}" + }, "screenshotURL": "data/images/images-6fzgwn9evvfhol9hv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6PsFwfvW2tLtoeFiC/art.json b/art/6PsFwfvW2tLtoeFiC/art.json index d64a18b5..631b7ac8 100644 --- a/art/6PsFwfvW2tLtoeFiC/art.json +++ b/art/6PsFwfvW2tLtoeFiC/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":12000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float sumCircleSegments) {\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n // create a horizontal triangle strip\\n\\n float angle = ux / sumCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float sumCircleSegments = 6.0;\\n vec2 circleXY = getCirclePoint(vertexId, sumCircleSegments);\\n \\n float numPointsPerCircle = sumCircleSegments * 6.0;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.0) / 9.0;\\n \\n vec4 pos = vec4(circleXY, 0.0, 1.0);\\n mat4 mat = ident();\\n mat *= scale(vec3(1.0, aspect, 1.0));\\n // mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0.0) * 1.5);\\n mat *= rotZ(snd * 2.0 * sign(ux));\\n mat *= uniformScale(0.1 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = 1.0; mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 12000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float sumCircleSegments) {\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n // create a horizontal triangle strip\n\n float angle = ux / sumCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float sumCircleSegments = 6.0;\n vec2 circleXY = getCirclePoint(vertexId, sumCircleSegments);\n \n float numPointsPerCircle = sumCircleSegments * 6.0;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.0) / 9.0;\n \n vec4 pos = vec4(circleXY, 0.0, 1.0);\n mat4 mat = ident();\n mat *= scale(vec3(1.0, aspect, 1.0));\n // mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0.0) * 1.5);\n mat *= rotZ(snd * 2.0 * sign(ux));\n mat *= uniformScale(0.1 * sc);\n \n gl_Position = mat * pos;\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = 1.0; mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ffo5auzlqu1idri48-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6QkqTG5zopSEvE5ja/art.json b/art/6QkqTG5zopSEvE5ja/art.json index 84c05d86..c1d9bdd4 100644 --- a/art/6QkqTG5zopSEvE5ja/art.json +++ b/art/6QkqTG5zopSEvE5ja/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":15,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n \\n // E2\\n /*\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n */\\n \\n // E1\\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 15, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n \n // E2\n /*\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n */\n \n // E1\n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-e94v10qtkilfhe6a8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6RMx4XYpHck6oZZ4u/art.json b/art/6RMx4XYpHck6oZZ4u/art.json index e72177f5..911061a8 100644 --- a/art/6RMx4XYpHck6oZZ4u/art.json +++ b/art/6RMx4XYpHck6oZZ4u/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":91125,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 5.0\\n\\n#define PI 3.1415\\n#define TAU PI * 2.0\\n\\n#define RESOLUTION vec2(45.0)\\n#define SIZE vec2(TAU, TAU)\\n\\n#define r 0.75 // Radius\\n#define t 0.4 // Thickness\\n\\nvec3 ParametricSurface(float u, float v) {\\n float cu = cos(u), su = sin(u);\\n float cv = cos(v), sv = sin(v);\\n return vec3(r * cv + t * cv * cu, t * su, r * sv + t * sv * cu);\\n}\\n\\nvec3 getNormal(in vec3 v) {\\n return normalize(v - vec3(normalize(v.xz) * r, 0.0).xzy);\\n}\\n\\nvoid main() {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\\n\\n float u = mod(vertexId, RESOLUTION.x);\\n float v = (vertexId - u) / RESOLUTION.x;\\n u = u / RESOLUTION.x * SIZE.x; v = v / RESOLUTION.y * SIZE.y;\\n\\n vec3 vertex = ParametricSurface(u, v);\\n vec3 color = vec3(max(0.0, dot(getNormal(vertex), lightDir)));\\n\\n vec2 rot = vec2(time, -0.5); // mouse * PI;\\n float cy = cos(rot.x), sy = sin(rot.x);\\n float cp = cos(rot.y), sp = sin(rot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 91125, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 5.0\n\n#define PI 3.1415\n#define TAU PI * 2.0\n\n#define RESOLUTION vec2(45.0)\n#define SIZE vec2(TAU, TAU)\n\n#define r 0.75 // Radius\n#define t 0.4 // Thickness\n\nvec3 ParametricSurface(float u, float v) {\n float cu = cos(u), su = sin(u);\n float cv = cos(v), sv = sin(v);\n return vec3(r * cv + t * cv * cu, t * su, r * sv + t * sv * cu);\n}\n\nvec3 getNormal(in vec3 v) {\n return normalize(v - vec3(normalize(v.xz) * r, 0.0).xzy);\n}\n\nvoid main() {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\n\n float u = mod(vertexId, RESOLUTION.x);\n float v = (vertexId - u) / RESOLUTION.x;\n u = u / RESOLUTION.x * SIZE.x; v = v / RESOLUTION.y * SIZE.y;\n\n vec3 vertex = ParametricSurface(u, v);\n vec3 color = vec3(max(0.0, dot(getNormal(vertex), lightDir)));\n\n vec2 rot = vec2(time, -0.5); // mouse * PI;\n float cy = cos(rot.x), sy = sin(rot.x);\n float cp = cos(rot.y), sp = sin(rot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-er4jpe4h70m8a7186-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6RY7TFeo6Q9wmHb5f/art.json b/art/6RY7TFeo6Q9wmHb5f/art.json index 65446c04..26f764bc 100644 --- a/art/6RY7TFeo6Q9wmHb5f/art.json +++ b/art/6RY7TFeo6Q9wmHb5f/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.01568627450980392,0.10588235294117647,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvarying float soundValues[50];\\nconst int windowSize = 50;\\nfloat movingAverage(float value) {\\n // Add the new value to the soundValues array\\n for (int i = windowSize - 1; i > 0; i--) {\\n soundValues[i] = soundValues[i-1];\\n }\\n soundValues[0] = value; \\n\\n // Calculate the moving average\\n float sum = 0.0;\\n float peak = 0.0;\\n for (int i = 0; i < windowSize; i++) {\\n sum += soundValues[i];\\n if (soundValues[i]>peak)\\n {\\n peak = soundValues[i];\\n }\\n }\\n float average = sum / float(windowSize);\\n\\n\\n return average;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i, float soundValue) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(soundValue, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.350;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n //float smoothSound = movingAverage();\\n float soundValue = texture2D(sound, vec2(0.005, 0.025)).a * 0.8;\\n \\n \\tpoint p1 = getPoint(vertexId / vertexCount,soundValue);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n \\n float soundAmp = 0.1;\\n\\n p1.position.yz *= rotateX * (soundValue * soundAmp);\\n p1.position.xz *= rotateY * (soundValue * soundAmp);\\n p1.position.xy *= rotateZ * (soundValue * soundAmp);\\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * movingAverage(p1.snd)) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.01568627450980392, + 0.10588235294117647, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvarying float soundValues[50];\nconst int windowSize = 50;\nfloat movingAverage(float value) {\n // Add the new value to the soundValues array\n for (int i = windowSize - 1; i > 0; i--) {\n soundValues[i] = soundValues[i-1];\n }\n soundValues[0] = value; \n\n // Calculate the moving average\n float sum = 0.0;\n float peak = 0.0;\n for (int i = 0; i < windowSize; i++) {\n sum += soundValues[i];\n if (soundValues[i]>peak)\n {\n peak = soundValues[i];\n }\n }\n float average = sum / float(windowSize);\n\n\n return average;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i, float soundValue) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(soundValue, 4.);\n\n float rad = 0.35; \n rad += spike * 0.350;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n //float smoothSound = movingAverage();\n float soundValue = texture2D(sound, vec2(0.005, 0.025)).a * 0.8;\n \n \tpoint p1 = getPoint(vertexId / vertexCount,soundValue);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n \n float soundAmp = 0.1;\n\n p1.position.yz *= rotateX * (soundValue * soundAmp);\n p1.position.xz *= rotateY * (soundValue * soundAmp);\n p1.position.xy *= rotateZ * (soundValue * soundAmp);\n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * movingAverage(p1.snd)) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-ohwid9l3xn9dladj5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6RnXzKXyyfu7NWTyb/art.json b/art/6RnXzKXyyfu7NWTyb/art.json index aa6a5b02..04c958d9 100644 --- a/art/6RnXzKXyyfu7NWTyb/art.json +++ b/art/6RnXzKXyyfu7NWTyb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),16,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),(a*0.6),0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(-1,2,1,1.-z,0,1,0,x,x*8.,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 3.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.0;\\n \\tvec2 height = vec2(10.,0.);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 3.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),16,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),(a*0.6),0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(-1,2,1,1.-z,0,1,0,x,x*8.,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 3.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.0;\n \tvec2 height = vec2(10.,0.);\n \t\n\tfloat indexQuad = floor(vertexId / 3.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-aauvtmyex59nv1a21-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6SDZEZNF7qnXFxx5d/art.json b/art/6SDZEZNF7qnXFxx5d/art.json index c0d59001..eeb6bbd6 100644 --- a/art/6SDZEZNF7qnXFxx5d/art.json +++ b/art/6SDZEZNF7qnXFxx5d/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 5\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./100.;\\n float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n \\n //LOGISTIC\\n \\n //vec2 p = vec2(fragCoord.x / iResolution.x, fragCoord.y / iResolution.y);\\n \\n \\n vec2 vp = vec2(0.,0.);\\n float z = fract(0.2+time/20.);//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n int acc = 0;\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n //acc += (z > p.y && z <= p.y + 1. / iResolution.y) ? 1 : 0;\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n float g = 25. * float(acc) / iters;\\n\\n cubep.y+= z;\\n cubep.x+= shapeRelId;\\n cubep.z = 0.;//shapeRelId*10.;\\n //cubep.z+= snd*10.;\\n //fragColor = vec4(g, g /3., g / 8.,1.);\\n\\n\\n //END LOGISTIC\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n vec3 eye = vec3(0.5, 0.5, 1.5);\\n \\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 5\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./100.;\n float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n \n //LOGISTIC\n \n //vec2 p = vec2(fragCoord.x / iResolution.x, fragCoord.y / iResolution.y);\n \n \n vec2 vp = vec2(0.,0.);\n float z = fract(0.2+time/20.);//sin(shapeRelId+fract(time/100.));//fract(0.02);\n int acc = 0;\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n //acc += (z > p.y && z <= p.y + 1. / iResolution.y) ? 1 : 0;\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n float g = 25. * float(acc) / iters;\n\n cubep.y+= z;\n cubep.x+= shapeRelId;\n cubep.z = 0.;//shapeRelId*10.;\n //cubep.z+= snd*10.;\n //fragColor = vec4(g, g /3., g / 8.,1.);\n\n\n //END LOGISTIC\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n vec3 eye = vec3(0.5, 0.5, 1.5);\n \n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-s8p169713zslnz65u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6Xdd5o4awYpFcY4QM/art.json b/art/6Xdd5o4awYpFcY4QM/art.json index cdd2c3f6..fc602aba 100644 --- a/art/6Xdd5o4awYpFcY4QM/art.json +++ b/art/6Xdd5o4awYpFcY4QM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ehrling/ehrling-lounge\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.058823529411764705,0.12156862745098039,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float s = texture2D(sound, vec2(u,v)).a ;\\n float xoff = cos(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v ) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a ;\\n\\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x* y* 0.02) * 5.;\\n \\n gl_PointSize = pow(snd+0.2,s + 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 2000.0;\\n\\n float pump = step(0.8,snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1;//+ sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1.,pump);\\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\\n\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)).xy,hue, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ehrling/ehrling-lounge", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.058823529411764705, + 0.12156862745098039, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float s = texture2D(sound, vec2(u,v)).a ;\n float xoff = cos(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v ) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a ;\n\n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x* y* 0.02) * 5.;\n \n gl_PointSize = pow(snd+0.2,s + 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 2000.0;\n\n float pump = step(0.8,snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1;//+ sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1.,pump);\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\n\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)).xy,hue, 1);\n}" + }, "screenshotURL": "data/images/images-1pznhqz90v4rapoh8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6XqJX2mnFpa8i9aLH/art.json b/art/6XqJX2mnFpa8i9aLH/art.json index 63c94f65..8aef7014 100644 --- a/art/6XqJX2mnFpa8i9aLH/art.json +++ b/art/6XqJX2mnFpa8i9aLH/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "refactorized", "avatarUrl": "https://avatars.githubusercontent.com/refactorized?s=200", - "settings": "{\"num\":457,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const float tau = 6.28318530718;\\nconst float cycles = 42.0;\\nconst float wrap = 17.0;\\n\\nvoid main() {\\n float ratio = vertexId / vertexCount;\\n float modio = mod((ratio * wrap), 1.0);\\n float theta = ratio * tau * cycles;\\n float tmod = modio * tau * cycles;\\n gl_Position = vec4(sin(tmod) * ratio, cos(tmod) * ratio, 0, 1);\\n gl_PointSize = 22.0;\\n v_color = vec4(\\n 0.5 + sin(theta) / 2.0, \\n 0.5 + sin(theta + tau/3.0) / 2.0, \\n 0.5 + sin(theta + 2.0 * tau / 3.0) / 2.0, \\n 0.0 ) * 1.2 * (1.0 - ratio);\\n}\"}", + "settings": { + "num": 457, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const float tau = 6.28318530718;\nconst float cycles = 42.0;\nconst float wrap = 17.0;\n\nvoid main() {\n float ratio = vertexId / vertexCount;\n float modio = mod((ratio * wrap), 1.0);\n float theta = ratio * tau * cycles;\n float tmod = modio * tau * cycles;\n gl_Position = vec4(sin(tmod) * ratio, cos(tmod) * ratio, 0, 1);\n gl_PointSize = 22.0;\n v_color = vec4(\n 0.5 + sin(theta) / 2.0, \n 0.5 + sin(theta + tau/3.0) / 2.0, \n 0.5 + sin(theta + 2.0 * tau / 3.0) / 2.0, \n 0.0 ) * 1.2 * (1.0 - ratio);\n}" + }, "screenshotURL": "data/images/images-qnik4bc3ubzvij8m0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6YpuWT2zbWkg2ocdL/art.json b/art/6YpuWT2zbWkg2ocdL/art.json index 47d5443b..2d1aac63 100644 --- a/art/6YpuWT2zbWkg2ocdL/art.json +++ b/art/6YpuWT2zbWkg2ocdL/art.json @@ -31,7 +31,19 @@ }, "private": false, "username": "visy", - "settings": "{\"num\":14786,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nconst int max_iterations = 255;\\n\\nvec2 complex_square( vec2 v ) {\\n\\treturn vec2(\\n\\t\\tv.x * v.x - v.y * v.y,\\n\\t\\tv.x * v.y * 2.0\\n\\t);\\n}\\n\\n\\nvoid main() {\\n float localTime = time*0.02 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float offset = count * 0.02;\\n\\n \\tvec2 cc = vec2(point*0.001+sin(count*0.01+localTime*0.05)*1.,cos(point*0.001+localTime*0.5)*1.1);\\n\\tvec2 v = vec2( 0.0 );\\n\\tfloat scale = 0.06;\\n\\t\\n\\tint count2 = max_iterations;\\n\\t\\n\\tfor ( int i = 0 ; i < max_iterations; i++ ) {\\n\\t\\tv = cc + complex_square( v );\\n\\t\\tif ( dot( v, v ) > 4.0 ) {\\n\\t\\t\\tcount2 = i;\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t}\\n\\n \\n float c3 = float(count2);\\n float angle = point * c3 * 1.0 / NUM_SEGMENTS + offset-c3;\\n \\n float radius = 0.2-(c3*0.0002);\\n float c = cos(angle + localTime) * radius-c3*0.005;\\n float s = sin(angle + localTime) * radius-c3*0.005;\\n float orbitAngle = count * 0.1*cos(c3);\\n float oC = cos(c3*orbitAngle)*cos(orbitAngle + localTime * count * 0.01-c3) * sin(orbitAngle+c3);\\n float oS = sin(orbitAngle + localTime * count * 0.01-c3) * sin(orbitAngle+c3);\\n\\t\\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n \\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(0.4, hue*0.0003, hue*0.003)), 1);\\n}\"}", + "settings": { + "num": 14786, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nconst int max_iterations = 255;\n\nvec2 complex_square( vec2 v ) {\n\treturn vec2(\n\t\tv.x * v.x - v.y * v.y,\n\t\tv.x * v.y * 2.0\n\t);\n}\n\n\nvoid main() {\n float localTime = time*0.02 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n\n float offset = count * 0.02;\n\n \tvec2 cc = vec2(point*0.001+sin(count*0.01+localTime*0.05)*1.,cos(point*0.001+localTime*0.5)*1.1);\n\tvec2 v = vec2( 0.0 );\n\tfloat scale = 0.06;\n\t\n\tint count2 = max_iterations;\n\t\n\tfor ( int i = 0 ; i < max_iterations; i++ ) {\n\t\tv = cc + complex_square( v );\n\t\tif ( dot( v, v ) > 4.0 ) {\n\t\t\tcount2 = i;\n\t\t\tbreak;\n\t\t}\n\t}\n\n \n float c3 = float(count2);\n float angle = point * c3 * 1.0 / NUM_SEGMENTS + offset-c3;\n \n float radius = 0.2-(c3*0.0002);\n float c = cos(angle + localTime) * radius-c3*0.005;\n float s = sin(angle + localTime) * radius-c3*0.005;\n float orbitAngle = count * 0.1*cos(c3);\n float oC = cos(c3*orbitAngle)*cos(orbitAngle + localTime * count * 0.01-c3) * sin(orbitAngle+c3);\n float oS = sin(orbitAngle + localTime * count * 0.01-c3) * sin(orbitAngle+c3);\n\t\n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n \n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(0.4, hue*0.0003, hue*0.003)), 1);\n}" + }, "screenshotURL": "data/images/images-0zn8qm26g2pg9xn5r-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6Yx2A7TQ6NnyHhFPQ/art.json b/art/6Yx2A7TQ6NnyHhFPQ/art.json index 5a05a875..be4aa6d3 100644 --- a/art/6Yx2A7TQ6NnyHhFPQ/art.json +++ b/art/6Yx2A7TQ6NnyHhFPQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10404,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nChallenge: 01\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float faceId = mod(floor(pointId / 6.), 6.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = PI * 1.75;time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.7, sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * .3);\\n// mat *= rotX(time + abs(ca) * 5.);\\n// mat *= rotZ(time + abs(cd) * 6.);\\n float d = length(vec2(ca, cd));\\n mat *= scale(vec3(\\n 1, \\n mix(2., \\n 12., \\n pow(sin(time * -2. + d * PI * 1.) * 0.5 + 0.5, \\n 1.5 + (1. - d) * 2.)), \\n 1));\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(3.3, 0.4, -1));\\n\\n float hue = .15 + mod(faceId + 2., 6.) * 0.17;\\n float sat = 0.3;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val)) * 1.125;\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 10404, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nChallenge: 01\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float faceId = mod(floor(pointId / 6.), 6.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = PI * 1.75;time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.7, sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * .3);\n// mat *= rotX(time + abs(ca) * 5.);\n// mat *= rotZ(time + abs(cd) * 6.);\n float d = length(vec2(ca, cd));\n mat *= scale(vec3(\n 1, \n mix(2., \n 12., \n pow(sin(time * -2. + d * PI * 1.) * 0.5 + 0.5, \n 1.5 + (1. - d) * 2.)), \n 1));\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(3.3, 0.4, -1));\n\n float hue = .15 + mod(faceId + 2., 6.) * 0.17;\n float sat = 0.3;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val)) * 1.125;\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-lpsla0pcwtlv15g92-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6bbL3L3PTAdvJyg8n/art.json b/art/6bbL3L3PTAdvJyg8n/art.json index 35e1bb99..b84049af 100644 --- a/art/6bbL3L3PTAdvJyg8n/art.json +++ b/art/6bbL3L3PTAdvJyg8n/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/index-marcel-fengler/marcel-fengler-scion-imf04\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.9921568627450981,1,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 200.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = gv + cu * 9. + time * .05;// + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.2)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n float r = 2.;\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .1 + 1., sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n mat *= p4;\\n mat *= rotZ(hash(gv * 0.132));\\n mat *= rotX(hash(gv));\\n mat *= trans(vec3(0,0.2,0));\\n mat *= uniformScale(mix(0.01, 0.5, pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .0 + time * .0;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = mix(0.2, 2.0, pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(-2.5, 5., s);\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/index-marcel-fengler/marcel-fengler-scion-imf04", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.9921568627450981, + 1, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 200.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = gv + cu * 9. + time * .05;// + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.2)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n float r = 2.;\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .1 + 1., sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n mat *= p4;\n mat *= rotZ(hash(gv * 0.132));\n mat *= rotX(hash(gv));\n mat *= trans(vec3(0,0.2,0));\n mat *= uniformScale(mix(0.01, 0.5, pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .0 + time * .0;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = mix(0.2, 2.0, pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(-2.5, 5., s);\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-895yhf4dvzto6fti5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6bpRiTn7zbJ2Birz8/art.json b/art/6bpRiTn7zbJ2Birz8/art.json index 16f68645..50e29930 100644 --- a/art/6bpRiTn7zbJ2Birz8/art.json +++ b/art/6bpRiTn7zbJ2Birz8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_STRIP\\n#define PI 3.141594\\n#define FIT_VERTICAL\\n#define KP1 3.//KParameter 0.>>10.\\nvec3 computeVert(float angle, float H) {\\n float STEP = (time*0.7*smoothstep(0.1,KP1,1.),KP1);\\n float R = (cos(H * 2.6 + STEP * 2.5 + sin(STEP * 14.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\\n R *= sin((H + 4.0) * 0.175);\\n \\n float Q = cos(STEP * 0.54 + H * 0.7);\\n float dX = cos(H * 1.4) * Q * 1.5;\\n float dY = sin(H * 0.75) * Q * 0.4;\\n float dZ = sin(H * 0.5) * Q * 0.15;\\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\\n}\\n\\nvec3 computeNorm(float angle, float H) {\\n float dA = 0.01;\\n float dH = 0.1;\\n vec3 A = computeVert(angle, H *2.);\\n vec3 B = computeVert(angle + dA, H);\\n vec3 C = computeVert(angle, H + dH);\\n return normalize(-cross((B-A)/dA,(C-A)/dH));\\n}\\n\\nvoid main() {\\n int NUM_ROT =76;\\n float dH = 0.05;\\n \\n float STEP = time*0.7;\\n \\n int base = int(vertexId) /5;\\n int level = int(base) / NUM_ROT;\\n int idx = int(mod(vertexId,8.0*sin(time*min(mouse.x+1.5,3.))));\\n vec3 xyz = vec3(0,0,0);\\n vec3 N = normalize(vec3(1,0,0));\\n \\n float dA = 2.0 * PI / float(NUM_ROT);\\n\\n float H = float(level) * dH - 5.0;\\n float angle = float(base) * dA;\\n \\n if (idx == 0) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n if (idx == 1) {\\n \\txyz = computeVert(angle + dA, H);\\n \\tN = computeNorm(angle + dA, H);\\n }\\n if (idx == 2) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n \\n if (idx == 3) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n if (idx == 4) {\\n \\txyz = computeVert(angle, H + dH);\\n \\tN = computeNorm(angle, H * dH);\\n }\\n if (idx == 5) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n \\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y *2. / resolution.x, (1.+mouse.y*2.));\\n #else\\n vec2 aspect = vec2((1.+mouse.x*2.), resolution.x / resolution.y);\\n #endif\\n \\n float Cs = cos(STEP);\\n float Si = sin(STEP);\\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\\n xyz *= 0.23;\\n xyz *= rot;\\n N *= rot;\\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\\n \\n vec3 light = normalize(vec3(1,1,-1));\\n vec3 V = vec3(0,0,1);\\n float A = 0.8 + cos(xyz.y * 0.6 / STEP);\\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\\n vec3 A_col = vec3(1,1,1) * N * rot2;\\n vec3 D_col = vec3(1,1,1) * N;\\n vec3 S_col = vec3(1,1,2);\\n vec3 LUM = A * A_col + D * D_col +S * S_col;\\n v_color = vec4(LUM, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_STRIP\n#define PI 3.141594\n#define FIT_VERTICAL\n#define KP1 3.//KParameter 0.>>10.\nvec3 computeVert(float angle, float H) {\n float STEP = (time*0.7*smoothstep(0.1,KP1,1.),KP1);\n float R = (cos(H * 2.6 + STEP * 2.5 + sin(STEP * 14.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\n R *= sin((H + 4.0) * 0.175);\n \n float Q = cos(STEP * 0.54 + H * 0.7);\n float dX = cos(H * 1.4) * Q * 1.5;\n float dY = sin(H * 0.75) * Q * 0.4;\n float dZ = sin(H * 0.5) * Q * 0.15;\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\n}\n\nvec3 computeNorm(float angle, float H) {\n float dA = 0.01;\n float dH = 0.1;\n vec3 A = computeVert(angle, H *2.);\n vec3 B = computeVert(angle + dA, H);\n vec3 C = computeVert(angle, H + dH);\n return normalize(-cross((B-A)/dA,(C-A)/dH));\n}\n\nvoid main() {\n int NUM_ROT =76;\n float dH = 0.05;\n \n float STEP = time*0.7;\n \n int base = int(vertexId) /5;\n int level = int(base) / NUM_ROT;\n int idx = int(mod(vertexId,8.0*sin(time*min(mouse.x+1.5,3.))));\n vec3 xyz = vec3(0,0,0);\n vec3 N = normalize(vec3(1,0,0));\n \n float dA = 2.0 * PI / float(NUM_ROT);\n\n float H = float(level) * dH - 5.0;\n float angle = float(base) * dA;\n \n if (idx == 0) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n if (idx == 1) {\n \txyz = computeVert(angle + dA, H);\n \tN = computeNorm(angle + dA, H);\n }\n if (idx == 2) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n \n if (idx == 3) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n if (idx == 4) {\n \txyz = computeVert(angle, H + dH);\n \tN = computeNorm(angle, H * dH);\n }\n if (idx == 5) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n \n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y *2. / resolution.x, (1.+mouse.y*2.));\n #else\n vec2 aspect = vec2((1.+mouse.x*2.), resolution.x / resolution.y);\n #endif\n \n float Cs = cos(STEP);\n float Si = sin(STEP);\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\n xyz *= 0.23;\n xyz *= rot;\n N *= rot;\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\n \n vec3 light = normalize(vec3(1,1,-1));\n vec3 V = vec3(0,0,1);\n float A = 0.8 + cos(xyz.y * 0.6 / STEP);\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\n vec3 A_col = vec3(1,1,1) * N * rot2;\n vec3 D_col = vec3(1,1,1) * N;\n vec3 S_col = vec3(1,1,2);\n vec3 LUM = A * A_col + D * D_col +S * S_col;\n v_color = vec4(LUM, 1);\n}" + }, "screenshotURL": "data/images/images-lo96stiq0vumtr0gq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6cn4dH3h84zzRHviv/art.json b/art/6cn4dH3h84zzRHviv/art.json index bf35ecf2..32f68c00 100644 --- a/art/6cn4dH3h84zzRHviv/art.json +++ b/art/6cn4dH3h84zzRHviv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "chuck", "avatarUrl": "https://lh4.googleusercontent.com/-M2l823dVzS4/AAAAAAAAAAI/AAAAAAAABaM/2SfesIQoVCw/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chuckleone/prototype\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/chuckleone/prototype", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-i71sbfzxzh53pevjl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6d4uyMnEKnip4oyLR/art.json b/art/6d4uyMnEKnip4oyLR/art.json index 6263b7ed..da97f2c9 100644 --- a/art/6d4uyMnEKnip4oyLR/art.json +++ b/art/6d4uyMnEKnip4oyLR/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "eugene", "avatarUrl": "https://lh4.googleusercontent.com/-1W0Zx2V2YBo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuck7HOEHYTKOuOYfO3JNASLLHC1T0A/s96-c/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.06666666666666667,0.25882352941176473,1],\"shader\":\"void main() {\\n\\n float across = 31.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.06666666666666667, + 0.25882352941176473, + 1 + ], + "shader": "void main() {\n\n float across = 31.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-kojbfpi2e4kkm5mfu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6eSja54pMxXcD9ArN/art.json b/art/6eSja54pMxXcD9ArN/art.json index ffd1a3ad..0f4a2b06 100644 --- a/art/6eSja54pMxXcD9ArN/art.json +++ b/art/6eSja54pMxXcD9ArN/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sndmtk", "avatarUrl": "https://secure.gravatar.com/avatar/d8578cd9a21a108c45c309f02504b6ae?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.043137254901960784,0.043137254901960784,0.043137254901960784,1],\"shader\":\"void main() {\\n //点を正方形に並べた場合の1辺あたりの点の個数\\n // 100 -> 10, 200->14.1423->14\\n float down = floor(sqrt(vertexCount));\\n // 1辺あたりの点の個数\\n float across = floor(vertexCount / down);\\n \\n // 点nのx座標を 0 to (across-1) に割り当てる\\n float x = mod(vertexId, across);\\n // 点nのy座標を 0 to (across-1) に割り当てる\\n float y = floor(vertexId / across);\\n \\n float xoff = sin(time + y * 0.2) * 0.3;\\n float yoff = cos(time + x * 0.3) * 0.2;\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.); \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.8;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n \\n float soff = sin(time+x*y*0.6) * 10.;\\n gl_PointSize = 10. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(xoff, yoff, 0.3, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.043137254901960784, + 0.043137254901960784, + 0.043137254901960784, + 1 + ], + "shader": "void main() {\n //点を正方形に並べた場合の1辺あたりの点の個数\n // 100 -> 10, 200->14.1423->14\n float down = floor(sqrt(vertexCount));\n // 1辺あたりの点の個数\n float across = floor(vertexCount / down);\n \n // 点nのx座標を 0 to (across-1) に割り当てる\n float x = mod(vertexId, across);\n // 点nのy座標を 0 to (across-1) に割り当てる\n float y = floor(vertexId / across);\n \n float xoff = sin(time + y * 0.2) * 0.3;\n float yoff = cos(time + x * 0.3) * 0.2;\n \n float u = x / (across - 1.);\n float v = y / (across - 1.); \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.8;\n \n gl_Position = vec4(xy, 0, 1);\n\n \n float soff = sin(time+x*y*0.6) * 10.;\n gl_PointSize = 10. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(xoff, yoff, 0.3, 1);\n \n}" + }, "screenshotURL": "data/images/images-qzkv2xnrom6ndgtsu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6gGtgPeiwrBx9DC8d/art.json b/art/6gGtgPeiwrBx9DC8d/art.json index 90cfc91a..54515691 100644 --- a/art/6gGtgPeiwrBx9DC8d/art.json +++ b/art/6gGtgPeiwrBx9DC8d/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":3447,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - Color\\n// spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) + 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 100.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(time * hue, sat, val)) * 3., 1);\\n}\\n\"}", + "settings": { + "num": 3447, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - Color\n// spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) + 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 100.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(time * hue, sat, val)) * 3., 1);\n}\n" + }, "screenshotURL": "data/images/images-8zkf7nwm55gqsg54e-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6gQQcZm2vuBMyLCkB/art.json b/art/6gQQcZm2vuBMyLCkB/art.json index 49287646..78d097db 100644 --- a/art/6gQQcZm2vuBMyLCkB/art.json +++ b/art/6gQQcZm2vuBMyLCkB/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres colored", "private": false, "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.9,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n\\n pos.z += .9;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\\n gl_PointSize = pos.z*1.5;\\n\\n v_color = vec4(abs(normalize(ofs))-ofs.z,1.);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.9,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n\n pos.z += .9;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\n gl_PointSize = pos.z*1.5;\n\n v_color = vec4(abs(normalize(ofs))-ofs.z,1.);\n}" + }, "screenshotURL": "data/images/images-mw5ssi4xtryhttjbl-thumbnail.jpg", "views": { "$numberInt": "336" diff --git a/art/6hsoh4en6G7rPqjb8/art.json b/art/6hsoh4en6G7rPqjb8/art.json index b5ec6972..aada3f86 100644 --- a/art/6hsoh4en6G7rPqjb8/art.json +++ b/art/6hsoh4en6G7rPqjb8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":38729,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// complex numbers\\n// vec2(real part, complex part)\\nvec2 cProd(vec2 a, vec2 b) {\\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\\n}\\nfloat cModSqrd(vec2 a) {\\n return (a.x*a.x + a.y*a.y);\\n}\\nint mandelbrot(float x, float y) {\\n int n = 0;\\n vec2 z = vec2(0,0);\\n vec2 c = vec2(x,y);\\n \\n // no loops in glsl so jsut repeat 100 times\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n \\n return n;\\n}\\n\\nvoid main() {\\n float resArea = resolution.x * resolution.y;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertAcrossX = floor(resolution.x/vertLen);\\n float vertAcrossY = floor(resolution.y/vertLen);\\n \\n float u = (mod(vertexId, vertAcrossX))/(vertAcrossX);\\n u = (u - 0.5) * 2.;\\n float v = (floor(vertexId / vertAcrossX))/(vertAcrossY);\\n v = (v - 0.5) * 2.;\\n \\n float x = u * (resolution.x/resolution.y) / v;\\n float y = v * (resolution.y/resolution.x) / vertLen;\\n \\n gl_Position = vec4(u, v, 0, 1);\\n gl_PointSize = vertLen*1.05/2.;\\n \\n \\n v_color = vec4(hsv2rgb(vec3((x+y)/vertLen+time/10., 1., 1.)), 1.);\\n}\"}", + "settings": { + "num": 38729, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// complex numbers\n// vec2(real part, complex part)\nvec2 cProd(vec2 a, vec2 b) {\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\n}\nfloat cModSqrd(vec2 a) {\n return (a.x*a.x + a.y*a.y);\n}\nint mandelbrot(float x, float y) {\n int n = 0;\n vec2 z = vec2(0,0);\n vec2 c = vec2(x,y);\n \n // no loops in glsl so jsut repeat 100 times\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n \n return n;\n}\n\nvoid main() {\n float resArea = resolution.x * resolution.y;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertAcrossX = floor(resolution.x/vertLen);\n float vertAcrossY = floor(resolution.y/vertLen);\n \n float u = (mod(vertexId, vertAcrossX))/(vertAcrossX);\n u = (u - 0.5) * 2.;\n float v = (floor(vertexId / vertAcrossX))/(vertAcrossY);\n v = (v - 0.5) * 2.;\n \n float x = u * (resolution.x/resolution.y) / v;\n float y = v * (resolution.y/resolution.x) / vertLen;\n \n gl_Position = vec4(u, v, 0, 1);\n gl_PointSize = vertLen*1.05/2.;\n \n \n v_color = vec4(hsv2rgb(vec3((x+y)/vertLen+time/10., 1., 1.)), 1.);\n}" + }, "screenshotURL": "data/images/images-tpmyek6qpvxczrk3j-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6kjKSErWMZSF6xj6c/art.json b/art/6kjKSErWMZSF6xj6c/art.json index 09f62584..72049c8b 100644 --- a/art/6kjKSErWMZSF6xj6c/art.json +++ b/art/6kjKSErWMZSF6xj6c/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":449,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float id = vertexId;\\n \\n float ux = floor(id / 4.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 4.), 2.);\\n \\n float angle = ux * radians(318.0) / cos(time* 20.2)*(vertexCount * 0.00333333);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy * 2.;\\n \\n float a = resolution.x / resolution.y-mouse.y;\\n \\n float x = c * radius / (.1 -a);\\n float y = s * radius;\\n \\n vec2 xy = vec2(x,y);\\n gl_Position = vec4(xy* .5, 0.1, 0.6);\\n v_color = vec4(1, sin(time*8.), tan(12.00/time)*23., 1);\\n}\"}", + "settings": { + "num": 449, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float id = vertexId;\n \n float ux = floor(id / 4.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 4.), 2.);\n \n float angle = ux * radians(318.0) / cos(time* 20.2)*(vertexCount * 0.00333333);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy * 2.;\n \n float a = resolution.x / resolution.y-mouse.y;\n \n float x = c * radius / (.1 -a);\n float y = s * radius;\n \n vec2 xy = vec2(x,y);\n gl_Position = vec4(xy* .5, 0.1, 0.6);\n v_color = vec4(1, sin(time*8.), tan(12.00/time)*23., 1);\n}" + }, "screenshotURL": "data/images/images-ntrk7jrj1606vppx2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6koiJAeZMvqyq7fpb/art.json b/art/6koiJAeZMvqyq7fpb/art.json index beaf55f8..5f257207 100644 --- a/art/6koiJAeZMvqyq7fpb/art.json +++ b/art/6koiJAeZMvqyq7fpb/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":21600,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/lazerhawk/skull-and-shark\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// _ _ _ _ \\n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \\n// \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__/ _` | '__| __|\\n// \\\\ V / __/ | | || __/> <\\\\__ \\\\ | | | (_| | (_| | __/ | | (_| | | | |_ \\n// \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\\\__,_|_| \\\\__|\\n//\\n//\\n\\n\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\\n \\n float across = 32.;\\n float down = 20.;\\n float u = mod(fCubeId, across) / across;\\n float v = floor(fCubeId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), abs(v - 0.5) * 0.5)).a;\\n \\n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.32;\\n \\n mat = ident();\\n \\tmat *= rotZ(lng);\\n \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= uniformScale(fScale);\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n float s3 = pow(snd + 0.1, 50.);\\n vCubeCol = mix(hsv2rgb(vec3(1,s3,s3)), vec3(0,0,0), pow(s2, 40.0)); \\n vCubeCol = mix(vCubeCol, vec3(1,1,1), step(0.95,s2));\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n mat4 mCube;\\n vec3 vCubeCol;\\n\\n GetCubePosition( fCubeId, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 21600, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/lazerhawk/skull-and-shark", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// _ _ _ _ \n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \n// \\ \\ / / _ \\ '__| __/ _ \\ \\/ / __| '_ \\ / _` |/ _` |/ _ \\ '__/ _` | '__| __|\n// \\ V / __/ | | || __/> <\\__ \\ | | | (_| | (_| | __/ | | (_| | | | |_ \n// \\_/ \\___|_| \\__\\___/_/\\_\\___/_| |_|\\__,_|\\__,_|\\___|_| \\__,_|_| \\__|\n//\n//\n\n\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\n \n float across = 32.;\n float down = 20.;\n float u = mod(fCubeId, across) / across;\n float v = floor(fCubeId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), abs(v - 0.5) * 0.5)).a;\n \n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.32;\n \n mat = ident();\n \tmat *= rotZ(lng);\n \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= uniformScale(fScale);\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n float s3 = pow(snd + 0.1, 50.);\n vCubeCol = mix(hsv2rgb(vec3(1,s3,s3)), vec3(0,0,0), pow(s2, 40.0)); \n vCubeCol = mix(vCubeCol, vec3(1,1,1), step(0.95,s2));\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n mat4 mCube;\n vec3 vCubeCol;\n\n GetCubePosition( fCubeId, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-cktdl62s7v2cwradt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6nPKwArJkv4Rbz6LX/art.json b/art/6nPKwArJkv4Rbz6LX/art.json index 43b6e2c7..7578736c 100644 --- a/art/6nPKwArJkv4Rbz6LX/art.json +++ b/art/6nPKwArJkv4Rbz6LX/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "feathj", "avatarUrl": "https://secure.gravatar.com/avatar/7cb271d20d843ec2bb42e83f693a2a6a?default=retro&size=200", - "settings": "{\"num\":920,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float snd = texture2D(sound, vec2(u, v)).a;\\n\\n gl_Position = vec4(0.0, 0.1 * snd, 0.0, 1.0);\\n gl_PointSize = 50.0;\\n \\n v_color = vec4(hsv2rgb(vec3(1.0, 1.0, snd)), 1.0);\\n}\\n\"}", + "settings": { + "num": 920, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float snd = texture2D(sound, vec2(u, v)).a;\n\n gl_Position = vec4(0.0, 0.1 * snd, 0.0, 1.0);\n gl_PointSize = 50.0;\n \n v_color = vec4(hsv2rgb(vec3(1.0, 1.0, snd)), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-1jjw7crgw6fdi4tl9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6nxqs9sKqwTpWK2Sf/art.json b/art/6nxqs9sKqwTpWK2Sf/art.json index e229b457..84d5b82c 100644 --- a/art/6nxqs9sKqwTpWK2Sf/art.json +++ b/art/6nxqs9sKqwTpWK2Sf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":5320,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=5400\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.7, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, (0.5 - mouse.x), (s * 0.3)); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0.3, 0, 1, 0,\\n 0, 0.2, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 0.65);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0.0)/f;\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b04) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.5)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,00);\\n \\n mat4 p4 = lookAt(p2 * 2.5, p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * 1.1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 1.5 + 0.5), 2);\\n}\\n\\n\"}", + "settings": { + "num": 5320, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=5400\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.7, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, (0.5 - mouse.x), (s * 0.3)); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0.3, 0, 1, 0,\n 0, 0.2, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 0.65);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0.0)/f;\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b04) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.5)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,00);\n \n mat4 p4 = lookAt(p2 * 2.5, p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * 1.1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 1.5 + 0.5), 2);\n}\n\n" + }, "screenshotURL": "data/images/images-zly24ubsbuydlpeku-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6qenwf5cKgyGLZrXw/art.json b/art/6qenwf5cKgyGLZrXw/art.json index 00d2b8dd..d9b0fbd8 100644 --- a/art/6qenwf5cKgyGLZrXw/art.json +++ b/art/6qenwf5cKgyGLZrXw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Color\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = cos(time + x * 0.2) * 0.1;\\n float yoff = cos(time * 1.1 + y * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * (cos(time + 1.) / 2.) + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = v;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Color\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = cos(time + x * 0.2) * 0.1;\n float yoff = cos(time * 1.1 + y * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * (cos(time + 1.) / 2.) + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = v;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-au76xhcx3ycv6satg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/6qhRHbFn8B6GeD5Ni/art.json b/art/6qhRHbFn8B6GeD5Ni/art.json index 5fdbe430..048edaa3 100644 --- a/art/6qhRHbFn8B6GeD5Ni/art.json +++ b/art/6qhRHbFn8B6GeD5Ni/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "unnamed2", "username": "-anon-", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 2.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 2.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-6ne2eg69apigwgclz-thumbnail.jpg", "views": { "$numberInt": "169" diff --git a/art/6t7WhmEDeF7kcGFDh/art.json b/art/6t7WhmEDeF7kcGFDh/art.json index bcd37c74..1af724fb 100644 --- a/art/6t7WhmEDeF7kcGFDh/art.json +++ b/art/6t7WhmEDeF7kcGFDh/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "benjamin", "avatarUrl": "https://lh5.googleusercontent.com/-TspaDzxOSSM/AAAAAAAAAAI/AAAAAAAABnc/aiT2HEkNbJo/photo.jpg", - "settings": "{\"num\":34504,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.5019607843137255,1,1],\"shader\":\"\\n\\nvoid main() {\\n \\tfloat across = 7.;\\n \\n\\tfloat x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\tfloat u = x / 10.;\\n float v = y / 10.;\\n \\n gl_Position = vec4(u, v, 0, 1.0);\\n \\tv_color = vec4(1,0,0,1);\\n\\n}\\n\"}", + "settings": { + "num": 34504, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.5019607843137255, + 1, + 1 + ], + "shader": "\n\nvoid main() {\n \tfloat across = 7.;\n \n\tfloat x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \tfloat u = x / 10.;\n float v = y / 10.;\n \n gl_Position = vec4(u, v, 0, 1.0);\n \tv_color = vec4(1,0,0,1);\n\n}\n" + }, "screenshotURL": "data/images/images-1aq8c033lqv78fzft-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/6xC43NutGGXHRTZ9p/art.json b/art/6xC43NutGGXHRTZ9p/art.json index 3ede7efc..54b6c533 100644 --- a/art/6xC43NutGGXHRTZ9p/art.json +++ b/art/6xC43NutGGXHRTZ9p/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\nconst int max_v = 12;\\nvec3 poi_v[max_v];\\nvec3 point[max_v+2];\\nvec3 color[max_v+2];\\n\\nfloat z[2];\\n\\n\\nmat4 persp (float fov, float aspect, float zNear, float zFar)\\n{\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n \\n return mat4(\\n \\tf / aspect, 0, 0, 0,\\n \\t0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n \\t0, 0, zNear * zFar * rangeInv * 2.0, 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n zAxis, 0,\\n xAxis, 0,\\n yAxis, 0,\\n eye , 2\\n );\\n}\\n\\nvoid drow_point()\\n{\\n z[0] = 0.;\\n z[1] = 1.;\\n \\n for(int i=0; i 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, sv) ; \\n vertexIndex -= floorTileCount ; \\n */\\n /*draw the sphere*/ \\n \\tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo, camPos,\\n sv);\\n }\\n \\tvertexIndex -= fSphereVertexCount ; \\n \\n #pragma endregion \\n \\n \\n #pragma region add to glsl\\n \\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n #pragma endregion \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n01/01/2019\n@BestRegard \n*/ \n\n#define COLOR_PASTEL\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t\n\t \n vec3 vOrigin;\n float fRadius ; \n \n \n \n float fSlices ; \n float fSegments ; \n }; \n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, sv) ; \n vertexIndex -= floorTileCount ; \n */\n /*draw the sphere*/ \n \tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo, camPos,\n sv);\n }\n \tvertexIndex -= fSphereVertexCount ; \n \n #pragma endregion \n \n \n #pragma region add to glsl\n \n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n #pragma endregion \n}" + }, "screenshotURL": "data/images/images-hs0mc10gayrazpxni-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/72yf22zZ942pR2Pjn/art.json b/art/72yf22zZ942pR2Pjn/art.json index 960bfaa5..3093ac36 100644 --- a/art/72yf22zZ942pR2Pjn/art.json +++ b/art/72yf22zZ942pR2Pjn/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.29411764705882354,0.5882352941176471,0.9450980392156862,1],\"shader\":\"\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0,0.0,0.0,1.0);\\n v_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.29411764705882354, + 0.5882352941176471, + 0.9450980392156862, + 1 + ], + "shader": "\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0,0.0,0.0,1.0);\n v_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-3y7bvwlpocp9i4yg1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/748RN8qRjrDrtSGy2/art.json b/art/748RN8qRjrDrtSGy2/art.json index fbd81a01..75f6ca72 100644 --- a/art/748RN8qRjrDrtSGy2/art.json +++ b/art/748RN8qRjrDrtSGy2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":19,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float width = 10.0;\\n \\n float y = -floor(vertexId/ 2.0);\\n float x = mod(vertexId, 2.0);\\n \\n vec2 xy = vec2(x,y)*0.1;\\n \\n //float xOffset = cos(time + y * 0.05);\\n //float yOffset = sin(time + x * 0.05);\\n \\n //float ux = u * 2.0 -1.0;\\n //float vy = v * 2.0 -1.0;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(1.0,0.4,0.1,1.0);\\n \\n \\n}\"}", + "settings": { + "num": 19, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float width = 10.0;\n \n float y = -floor(vertexId/ 2.0);\n float x = mod(vertexId, 2.0);\n \n vec2 xy = vec2(x,y)*0.1;\n \n //float xOffset = cos(time + y * 0.05);\n //float yOffset = sin(time + x * 0.05);\n \n //float ux = u * 2.0 -1.0;\n //float vy = v * 2.0 -1.0;\n \n gl_Position = vec4(xy,0.0,1.0);\n gl_PointSize = 20.0;\n v_color = vec4(1.0,0.4,0.1,1.0);\n \n \n}" + }, "screenshotURL": "data/images/images-tkvdkjui9l6ilbml3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/75BKGgPT6J42k7Aax/art.json b/art/75BKGgPT6J42k7Aax/art.json index 05e0959d..36dd9053 100644 --- a/art/75BKGgPT6J42k7Aax/art.json +++ b/art/75BKGgPT6J42k7Aax/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":6065,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n\\n#define PI radians(180.0)\\n//KDrawmode=GL_TRIANGLES\\n//KVertexCount=6666\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, s, 0, 0, \\n s, 0, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n 1 -dot(xAxis, eye), dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.3, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5); // soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * 1.2;\\n s *= 0.15;\\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 1.1;\\n\\tf = 0.00100*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n //vec3 cameraPos = vec3(4., mix(5., 1., p1m1(1.)), 2.);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\\n float val = mix(.05, 1., l);\\n\\n float ss = \\n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float pop = step(0.6, ss);\\n val = mix(max(val,pop), 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.)*ss;\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 6065, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n\n#define PI radians(180.0)\n//KDrawmode=GL_TRIANGLES\n//KVertexCount=6666\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, s, 0, 0, \n s, 0, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n 1 -dot(xAxis, eye), dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.3, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5); // soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * 1.2;\n s *= 0.15;\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 1.1;\n\tf = 0.00100*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n //vec3 cameraPos = vec3(4., mix(5., 1., p1m1(1.)), 2.);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\n float val = mix(.05, 1., l);\n\n float ss = \n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float pop = step(0.6, ss);\n val = mix(max(val,pop), 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.)*ss;\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-omjckgd9j5r3w23gh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/76ZBdQLBg9fxMqXhD/art.json b/art/76ZBdQLBg9fxMqXhD/art.json index b16fc987..30eb2dd0 100644 --- a/art/76ZBdQLBg9fxMqXhD/art.json +++ b/art/76ZBdQLBg9fxMqXhD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/guigoo-official/acido\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const int maxIter = 10;\\nfloat df(vec3 p, float power) {\\n vec3 z = p;\\n float r = 0.0;\\n float dr = 1.0;\\n for(int i = 0; i < maxIter; i++) {\\n r = length(z);\\n if(r > 100.0) break;\\n \\n float theta = acos(z.z/r);\\n float phi = atan(z.y, z.x);\\n \\n dr = power*pow(r, power-1.0)*dr + 1.0;\\n \\n r = pow(r, power);\\n theta *= power;\\n phi *= power;\\n \\n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\\n z += p;\\n }\\n return 0.5*log(r)*r/dr;\\n}\\n\\n\\nstruct Ray {\\n bool hit;\\n vec3 hitPos;\\n float t;\\n int steps;\\n};\\nconst int maxSteps = 50;\\n\\nRay trace(vec3 camPos, vec3 rayDir, float _factor) {\\n vec3 p = vec3(0);\\n float t = 0.0; \\n int steps = 0;\\n bool hit = false;\\n for(int i = 0; i < maxSteps; i++) {\\n p = camPos + t*rayDir;\\n float d = df(p, 8.0*abs(sin(0.5*_factor)) + 1.0);\\n if(d < 0.001) {\\n hit = true;\\n steps = i;\\n break;\\n }\\n t += d*0.9;\\n }\\n return Ray(hit, p, t, steps);\\n}\\n\\n\\nvec3 shading(Ray tr) {\\n if(tr.hit) {\\n \\treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\\n }\\n else {\\n return vec3(0);\\n }\\n}\\n\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n //we want to keep the resolution.xresolution.y ratio\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //deduce from finalMaxVertexCount the number of possible lines with the given across\\n float down = floor(finalMaxVertexCount / across);\\n \\n //Now we have the across and down number of elements, we can now calculate the final number of vertices\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n\\n \\n //vec2 fragCoord = vec2(ux,vy);\\n \\n //apply fragment logic\\n\\n\\tvec2 fragCoord = vec2(x,y);\\n \\n\\tvec2 iResolution = vec2(across, down);\\n float iTime = time;\\n \\n\\tvec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\\n \\n //vec2 uv = vec2(u,v);\\n \\n //vec3 camPos = vec3(-2, 0, 0);\\n //vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\\n vec3 camPos = 2.0*vec3(cos(0.), 0, sin(0.));\\n vec3 camFront = normalize(-camPos);\\n vec3 camUp = vec3(0, 1, 0);\\n vec3 camRight = cross(camFront, camUp);\\n float focus = 1.0;\\n \\n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float sndFactor = texture2D(sound, vec2(udnd, 0.2)).a;\\n Ray tr = trace(camPos, rayDir, 1.+sndFactor);\\n \\n\\t//fragColor = vec4(shading(tr), 1.0);\\n\\t\\n v_color = vec4(shading(tr), 1.0);\\n gl_Position = vec4(ux*v_color.x*5.*pow(2.*sndFactor,10.), vy*v_color.y *5., 0, 1);\\n //gl_Position = vec4(ux , vy , 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n \\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/guigoo-official/acido", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const int maxIter = 10;\nfloat df(vec3 p, float power) {\n vec3 z = p;\n float r = 0.0;\n float dr = 1.0;\n for(int i = 0; i < maxIter; i++) {\n r = length(z);\n if(r > 100.0) break;\n \n float theta = acos(z.z/r);\n float phi = atan(z.y, z.x);\n \n dr = power*pow(r, power-1.0)*dr + 1.0;\n \n r = pow(r, power);\n theta *= power;\n phi *= power;\n \n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\n z += p;\n }\n return 0.5*log(r)*r/dr;\n}\n\n\nstruct Ray {\n bool hit;\n vec3 hitPos;\n float t;\n int steps;\n};\nconst int maxSteps = 50;\n\nRay trace(vec3 camPos, vec3 rayDir, float _factor) {\n vec3 p = vec3(0);\n float t = 0.0; \n int steps = 0;\n bool hit = false;\n for(int i = 0; i < maxSteps; i++) {\n p = camPos + t*rayDir;\n float d = df(p, 8.0*abs(sin(0.5*_factor)) + 1.0);\n if(d < 0.001) {\n hit = true;\n steps = i;\n break;\n }\n t += d*0.9;\n }\n return Ray(hit, p, t, steps);\n}\n\n\nvec3 shading(Ray tr) {\n if(tr.hit) {\n \treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\n }\n else {\n return vec3(0);\n }\n}\n\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n //we want to keep the resolution.xresolution.y ratio\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //deduce from finalMaxVertexCount the number of possible lines with the given across\n float down = floor(finalMaxVertexCount / across);\n \n //Now we have the across and down number of elements, we can now calculate the final number of vertices\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n\n \n //vec2 fragCoord = vec2(ux,vy);\n \n //apply fragment logic\n\n\tvec2 fragCoord = vec2(x,y);\n \n\tvec2 iResolution = vec2(across, down);\n float iTime = time;\n \n\tvec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\n \n //vec2 uv = vec2(u,v);\n \n //vec3 camPos = vec3(-2, 0, 0);\n //vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\n vec3 camPos = 2.0*vec3(cos(0.), 0, sin(0.));\n vec3 camFront = normalize(-camPos);\n vec3 camUp = vec3(0, 1, 0);\n vec3 camRight = cross(camFront, camUp);\n float focus = 1.0;\n \n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float sndFactor = texture2D(sound, vec2(udnd, 0.2)).a;\n Ray tr = trace(camPos, rayDir, 1.+sndFactor);\n \n\t//fragColor = vec4(shading(tr), 1.0);\n\t\n v_color = vec4(shading(tr), 1.0);\n gl_Position = vec4(ux*v_color.x*5.*pow(2.*sndFactor,10.), vy*v_color.y *5., 0, 1);\n //gl_Position = vec4(ux , vy , 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n \n \n //v_color = vec4(1.,1.,1.,1.);\n}" + }, "screenshotURL": "data/images/images-gcbh4z1dozx3hznog-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7825RZhjGT9xTvEa7/art.json b/art/7825RZhjGT9xTvEa7/art.json index 2164ff68..8e7e97c3 100644 --- a/art/7825RZhjGT9xTvEa7/art.json +++ b/art/7825RZhjGT9xTvEa7/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":2439,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId/across);\\n \\n float u = x/(across-1.);\\n float v = y/(across- 1.);\\n \\n float xoff = sin(time + y *.2);\\n float yoff = sin(time +x *.2);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 0.2;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time +x * y ) * .5;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/ 600.;\\n v_color = vec4(u,v,0,1);\\n}\"}", + "settings": { + "num": 2439, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId/across);\n \n float u = x/(across-1.);\n float v = y/(across- 1.);\n \n float xoff = sin(time + y *.2);\n float yoff = sin(time +x *.2);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 0.2;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time +x * y ) * .5;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/ 600.;\n v_color = vec4(u,v,0,1);\n}" + }, "screenshotURL": "data/images/images-2e7pykz7i7t4aek6v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/78PSuMWSJy9qmzeCm/art.json b/art/78PSuMWSJy9qmzeCm/art.json index fd742ee6..48359e69 100644 --- a/art/78PSuMWSJy9qmzeCm/art.json +++ b/art/78PSuMWSJy9qmzeCm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/itsbrillz/sets/world-wide-weirdos-vol-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#29475.0\\n\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\nvec2 project(vec2 position, vec2 a, vec2 b); \\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 4.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n\\tfor(int i = 0; i < 48; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\tb += box(p, vec2(.5));\\n\\t\\tt += triangle(p, vec2(.5));\\n\\t\\tp *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\t\\n\\t//gl_FragColor = result;\\n \\n gl_Position = vec4(ux, vy*snd, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = result;\\n \\n\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.73205080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t*= .86602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(t);\\n\\treturn mat2(c, s, -s, c);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/itsbrillz/sets/world-wide-weirdos-vol-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#29475.0\n\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\nvec2 project(vec2 position, vec2 a, vec2 b); \nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 4.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n\tfor(int i = 0; i < 48; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\tb += box(p, vec2(.5));\n\t\tt += triangle(p, vec2(.5));\n\t\tp *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\t\n\t//gl_FragColor = result;\n \n gl_Position = vec4(ux, vy*snd, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = result;\n \n\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.73205080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t*= .86602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(t);\n\treturn mat2(c, s, -s, c);\n}\n" + }, "screenshotURL": "data/images/images-20qewxa1u8eb5h6m8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/79HqSrQH4meL63aAo/art.json b/art/79HqSrQH4meL63aAo/art.json index 62f1d55f..0751b702 100644 --- a/art/79HqSrQH4meL63aAo/art.json +++ b/art/79HqSrQH4meL63aAo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n if (gl_Position.x < 0.) {\\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n if (gl_Position.x < 0.) {\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n}\n\n" + }, "screenshotURL": "data/images/images-4pfkik8qiixjgvijv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7ATa9Lmsc2BxYbkNw/art.json b/art/7ATa9Lmsc2BxYbkNw/art.json index 41a8e89a..970a9a77 100644 --- a/art/7ATa9Lmsc2BxYbkNw/art.json +++ b/art/7ATa9Lmsc2BxYbkNw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .5//KParameter 0.>>5.\\n#define PointSizeValue 2.//KParameter 1.>>4.\\n#define colorFactorR 0.//KParameter 0.>>1.\\n#define colorFactorG 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79553//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n\\nvec3 osc3(float t, float i)\\n{\\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 osc3Comb(float t, float i) {\\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\\n}\\n\\nvec3 incr(float t, float i, vec3 ofs, float lerpEnd)\\n{\\n vec3 pos = osc3Comb(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\\n \\n\\n float t = time*timeFactor;\\n float i = localVertexId;//+sin(localVertexId)*100.;\\n\\n vec3 pos = osc3Comb(t,i);\\n vec3 posDelta = vec3(colorFactorR,colorFactorG,0.);\\n \\n \\n for (float f = 0.; f < 10.; f++) \\n {\\n\\t posDelta += incr(t+f*.05,i,posDelta,0.2);\\n }\\n \\n posDelta += incr(t,i,posDelta,0.2);\\n \\n pos -= osc3(t,-1.)*posComp0;\\n \\n pos += posDelta;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n /*\\n if(gl_Position.x<-1.)\\n {\\n gl_Position.x+=2.;\\n }\\n if(gl_Position.x>1.)\\n {\\n gl_Position.x-=2.;\\n }\\n \\n if(gl_Position.y>1.)\\n {\\n gl_Position.y-=2.;\\n }\\n if(gl_Position.y<1.)\\n {\\n gl_Position.y+=2.;\\n }\\n */\\n \\n if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\\n //v_color = vec4(0.,0.,0.,1.);//abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .5//KParameter 0.>>5.\n#define PointSizeValue 2.//KParameter 1.>>4.\n#define colorFactorR 0.//KParameter 0.>>1.\n#define colorFactorG 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79553//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n\nvec3 osc3(float t, float i)\n{\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 osc3Comb(float t, float i) {\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\n}\n\nvec3 incr(float t, float i, vec3 ofs, float lerpEnd)\n{\n vec3 pos = osc3Comb(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\n \n\n float t = time*timeFactor;\n float i = localVertexId;//+sin(localVertexId)*100.;\n\n vec3 pos = osc3Comb(t,i);\n vec3 posDelta = vec3(colorFactorR,colorFactorG,0.);\n \n \n for (float f = 0.; f < 10.; f++) \n {\n\t posDelta += incr(t+f*.05,i,posDelta,0.2);\n }\n \n posDelta += incr(t,i,posDelta,0.2);\n \n pos -= osc3(t,-1.)*posComp0;\n \n pos += posDelta;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n /*\n if(gl_Position.x<-1.)\n {\n gl_Position.x+=2.;\n }\n if(gl_Position.x>1.)\n {\n gl_Position.x-=2.;\n }\n \n if(gl_Position.y>1.)\n {\n gl_Position.y-=2.;\n }\n if(gl_Position.y<1.)\n {\n gl_Position.y+=2.;\n }\n */\n \n if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\n //v_color = vec4(0.,0.,0.,1.);//abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\n}" + }, "screenshotURL": "data/images/images-adysrrlt2msy5jbax-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7AywqTMXSQtDaa9RW/art.json b/art/7AywqTMXSQtDaa9RW/art.json index 60f71f28..44e3e14d 100644 --- a/art/7AywqTMXSQtDaa9RW/art.json +++ b/art/7AywqTMXSQtDaa9RW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":12190,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*a ) + exp( -k*b );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.00270;\\n \\tfloat transitionStrength = 1.3;\\n \\tvec3 colKernel0 = vec3(1,0,1);\\n \\tvec3 colKernel1 = vec3(0,0 ,0);\\n \\tvec3 colTransition = vec3(1,1,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.1)).x*1.5;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = .5 - mouse.x * 0.5;\\n\\tfloat ce = -1.5+mouse.y * 3.+1.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(76.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = 1.0 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,1.\\n \\n -mouse.x);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, -1,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.945); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 12190, + "mode": "LINES", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*a ) + exp( -k*b );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.00270;\n \tfloat transitionStrength = 1.3;\n \tvec3 colKernel0 = vec3(1,0,1);\n \tvec3 colKernel1 = vec3(0,0 ,0);\n \tvec3 colTransition = vec3(1,1,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.1)).x*1.5;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = .5 - mouse.x * 0.5;\n\tfloat ce = -1.5+mouse.y * 3.+1.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(76.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = 1.0 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,1.\n \n -mouse.x);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, -1,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.945); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-wcw9fnibtq36hw919-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7Bkg55Y8SPEtDJedE/art.json b/art/7Bkg55Y8SPEtDJedE/art.json index a26691a5..b7a5d854 100644 --- a/art/7Bkg55Y8SPEtDJedE/art.json +++ b/art/7Bkg55Y8SPEtDJedE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":96768,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/jubyphonic-p/ponponpon-english-cover\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertsPerBlob = 1728.0;\\n float blobId = floor(vertexId / vertsPerBlob);\\n float numBlobs = floor(vertexCount / vertsPerBlob);\\n float bv = blobId / numBlobs;\\n float id = mod(vertexId, vertsPerBlob);\\n float numQuads = floor(vertsPerBlob / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(id / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(id, 6.);\\n float ux = floor(id / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n vec3 nrm = pos;\\n \\n float tm = time * 0.1 * 1.;\\n float rd = 3.;\\n mat4 pmat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float groupId = floor(blobId / 2.);\\n float numGroups = floor(numBlobs / 2.);\\n float gv = groupId / numGroups;\\n float odd = mod(blobId, 2.);\\n \\n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, gv), 0.)).a;\\n float s1 = texture2D(sound, vec2(mix(0.5, 0.5, gv), qv)).a;\\n \\n mat4 cmat = lookAt(eye, target, up); \\n mat4 vmat = inverse(cmat);\\n \\n float t = time * 50.;\\n float t0 = floor(t + groupId + gv);\\n float t1 = floor(t + groupId + gv + 1.);\\n vec3 p0 = vec3(\\n t2m1(hash(t0 * 0.123)), \\n t2m1(hash(t0 * 0.617)), \\n t2m1(hash(t0 * 0.371))) * 2.;\\n vec3 p1 = vec3(\\n t2m1(hash(t1 * 0.123)), \\n t2m1(hash(t1 * 0.617)), \\n t2m1(hash(t1 * 0.371))) * 2.;\\n \\n #if 1\\n mat4 wmat = ident();\\n wmat *= trans(t2m1(s0) * .0 + \\n mix(p0, p1, fract(time)) +\\n cmat[2].xyz * -odd * 0.1);\\n #endif\\n wmat *= rotX(time + qv);\\n wmat *= rotY(time * .77);\\n wmat *= uniformScale(mix(0.2, .6, pow(s0 + .2, 1.)) + odd * 0.0);\\n// wmat *= scale(vec3(1, 1, 1. - odd));\\n// mat *= uniformScale(0.4);\\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .0 + id * 0.0 + bv * 1.;\\n float sat = 1.;\\n float val = 1. - odd;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), s0);\\n \\n vec3 n = (cmat * wmat * vec4(nrm, 0)).xyz;\\n float l = dot(normalize(vec3(.5,1,-3)), n) * .3 + .7;\\n v_color.rgb *= mix(l, 1., pow(s0, .5));\\n \\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 96768, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/jubyphonic-p/ponponpon-english-cover", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertsPerBlob = 1728.0;\n float blobId = floor(vertexId / vertsPerBlob);\n float numBlobs = floor(vertexCount / vertsPerBlob);\n float bv = blobId / numBlobs;\n float id = mod(vertexId, vertsPerBlob);\n float numQuads = floor(vertsPerBlob / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(id / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(id, 6.);\n float ux = floor(id / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n vec3 nrm = pos;\n \n float tm = time * 0.1 * 1.;\n float rd = 3.;\n mat4 pmat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float groupId = floor(blobId / 2.);\n float numGroups = floor(numBlobs / 2.);\n float gv = groupId / numGroups;\n float odd = mod(blobId, 2.);\n \n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, gv), 0.)).a;\n float s1 = texture2D(sound, vec2(mix(0.5, 0.5, gv), qv)).a;\n \n mat4 cmat = lookAt(eye, target, up); \n mat4 vmat = inverse(cmat);\n \n float t = time * 50.;\n float t0 = floor(t + groupId + gv);\n float t1 = floor(t + groupId + gv + 1.);\n vec3 p0 = vec3(\n t2m1(hash(t0 * 0.123)), \n t2m1(hash(t0 * 0.617)), \n t2m1(hash(t0 * 0.371))) * 2.;\n vec3 p1 = vec3(\n t2m1(hash(t1 * 0.123)), \n t2m1(hash(t1 * 0.617)), \n t2m1(hash(t1 * 0.371))) * 2.;\n \n #if 1\n mat4 wmat = ident();\n wmat *= trans(t2m1(s0) * .0 + \n mix(p0, p1, fract(time)) +\n cmat[2].xyz * -odd * 0.1);\n #endif\n wmat *= rotX(time + qv);\n wmat *= rotY(time * .77);\n wmat *= uniformScale(mix(0.2, .6, pow(s0 + .2, 1.)) + odd * 0.0);\n// wmat *= scale(vec3(1, 1, 1. - odd));\n// mat *= uniformScale(0.4);\n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .0 + id * 0.0 + bv * 1.;\n float sat = 1.;\n float val = 1. - odd;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), s0);\n \n vec3 n = (cmat * wmat * vec4(nrm, 0)).xyz;\n float l = dot(normalize(vec3(.5,1,-3)), n) * .3 + .7;\n v_color.rgb *= mix(l, 1., pow(s0, .5));\n \n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-0006xsweyopsb2bcg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7BtREZnTSkBpz7W87/art.json b/art/7BtREZnTSkBpz7W87/art.json index 40455610..60663345 100644 --- a/art/7BtREZnTSkBpz7W87/art.json +++ b/art/7BtREZnTSkBpz7W87/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":20526,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00392156862745098,0.07450980392156863,0.49019607843137253,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n float v = id + time;\\n float outV = fract(time * 10. + vertexId * 0.01);\\n vec3 pos = normalize(vec3(\\n m1p1(hash(v * 0.012)), \\n m1p1(hash(v * 0.127)), \\n m1p1(hash(v * 0.213)))); \\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1) * 0.4;\\n if (id >= 18000.) {\\n pos = normalize(vec3(m1p1(hash(vertexId)), m1p1(hash(vertexId * 0.123)), 0));\\n pos *= mix(1., 1.1, outV);\\n }\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n // mat *= rotZ(lineV * PI * 2. + t * 1000.1);\\n // mat *= rotY(lineV * PI * 1. + t * 1000.1);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = (resolution.x / 1600.) * mix(0., 20., abs(cos(p1m1(pos.z) * PI)));\\n\\n if (id < 18000.) {\\n float edge = inv(abs(dot(pos, vec3(0,0,1))));\\n float hue = mix(0.95, 1.1, edge);\\n float sat = 1.;\\n float val = p1m1(dot(pos, normalize(vec3(-0.3, 0.6, -1))));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1) \\n + 0.4 * pow(val, 51.)\\n + vec4(1,1,1,1) * pow(edge, 15.);\\n v_color.a *= mix(1.0, 2., mod(time * 60., 2.));\\n } else {\\n v_color = vec4(1,1,1,inv(outV));\\n gl_PointSize = inv(outV) * 4.;\\n// v_color.a *= mix(1.0, 1., mod(time * 60., 2.));\\n }\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 20526, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00392156862745098, + 0.07450980392156863, + 0.49019607843137253, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid main() {\n float id = vertexId;\n float v = id + time;\n float outV = fract(time * 10. + vertexId * 0.01);\n vec3 pos = normalize(vec3(\n m1p1(hash(v * 0.012)), \n m1p1(hash(v * 0.127)), \n m1p1(hash(v * 0.213)))); \n vec3 aspect = vec3(1, resolution.x / resolution.y, 1) * 0.4;\n if (id >= 18000.) {\n pos = normalize(vec3(m1p1(hash(vertexId)), m1p1(hash(vertexId * 0.123)), 0));\n pos *= mix(1., 1.1, outV);\n }\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n // mat *= rotZ(lineV * PI * 2. + t * 1000.1);\n // mat *= rotY(lineV * PI * 1. + t * 1000.1);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = (resolution.x / 1600.) * mix(0., 20., abs(cos(p1m1(pos.z) * PI)));\n\n if (id < 18000.) {\n float edge = inv(abs(dot(pos, vec3(0,0,1))));\n float hue = mix(0.95, 1.1, edge);\n float sat = 1.;\n float val = p1m1(dot(pos, normalize(vec3(-0.3, 0.6, -1))));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1) \n + 0.4 * pow(val, 51.)\n + vec4(1,1,1,1) * pow(edge, 15.);\n v_color.a *= mix(1.0, 2., mod(time * 60., 2.));\n } else {\n v_color = vec4(1,1,1,inv(outV));\n gl_PointSize = inv(outV) * 4.;\n// v_color.a *= mix(1.0, 1., mod(time * 60., 2.));\n }\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-nwndr3snp0jra482x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7CY4KDf722AkkpwR2/art.json b/art/7CY4KDf722AkkpwR2/art.json index 295926e4..a18ab4d4 100644 --- a/art/7CY4KDf722AkkpwR2/art.json +++ b/art/7CY4KDf722AkkpwR2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7121,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n gl_Position = vec4(0,0,0,0);\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 7121, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\nvoid main() {\n gl_Position = vec4(0,0,0,0);\n gl_PointSize = 3.0; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-lzoz3krf047zlu2dk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7DebjyLHPNMjyBzn3/art.json b/art/7DebjyLHPNMjyBzn3/art.json index 7af56201..846d25ff 100644 --- a/art/7DebjyLHPNMjyBzn3/art.json +++ b/art/7DebjyLHPNMjyBzn3/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chicagosymphony/vivaldi-mandolin-concerto-in-c\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n float u = mod(vertexId, across) / across; // 0 <-> 1 across line\\n float v = floor(vertexId / across) / down; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/20th of the sound texture\\n float historyX = u * 0.05;\\n // Match each line to a specific row in the sound texture\\n float historyV = v;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(x, y);\\n \\n float sp = time * .1;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n vec3 eye = vec3(mouse.x, mouse.y, 1);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n gl_Position = pmat * vmat * vec4(xy * 0.5, pow(snd, 5.) * .2, 1);\\n gl_PointSize = 5.0;\\n\\n float hue = u * .1 + time * 0.02;\\n float sat = .5;\\n float val = mix(0.5, 1., snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chicagosymphony/vivaldi-mandolin-concerto-in-c", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n float u = mod(vertexId, across) / across; // 0 <-> 1 across line\n float v = floor(vertexId / across) / down; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/20th of the sound texture\n float historyX = u * 0.05;\n // Match each line to a specific row in the sound texture\n float historyV = v;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(x, y);\n \n float sp = time * .1;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n vec3 eye = vec3(mouse.x, mouse.y, 1);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n gl_Position = pmat * vmat * vec4(xy * 0.5, pow(snd, 5.) * .2, 1);\n gl_PointSize = 5.0;\n\n float hue = u * .1 + time * 0.02;\n float sat = .5;\n float val = mix(0.5, 1., snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-lf3w9ac4aclo4abcu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7DtazpcMcdA6fJ4XW/art.json b/art/7DtazpcMcdA6fJ4XW/art.json index c6626c68..5d0299b6 100644 --- a/art/7DtazpcMcdA6fJ4XW/art.json +++ b/art/7DtazpcMcdA6fJ4XW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/zweiklang/sets/sdr017-wesley-monteiro\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 10.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n vec3 pos;\\n float inner = mix(0.0, 0.1, p1m1(sin(goop(groupId) + time * 0.0)));\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd = texture2D(sound, vec2(mix(0.01, 0.14, su), cgv * 0.05)).a;\\n snd = pow(snd, mix(2., 0.5, su));\\n \\n\\n // ----\\n float gDown = floor(sqrt(numGroups));\\n float gAcross = floor(numGroups / gDown);\\n vec3 offset0 = vec3(\\n mod(groupId, gAcross) - (gAcross - 1.) / 2.,\\n floor(groupId / gAcross) - (gDown - 1.) / 2.,\\n 0) * 0.3;\\n \\n // ----\\n float ang = gv * 10.0;\\n vec3 offset1 = vec3(cos(ang), sin(ang), 0) * gv * 0.5;\\n\\n // ----\\n vec3 offset2 = (vec3(hash(groupId), hash(groupId * 0.37), 0) * 2. - 1.) * 0.8;\\n \\n // ----\\n ang = gv * 20.0;\\n float rad = floor(groupId / pow(2., gv + 3.));\\n vec3 offset3 = vec3(cos(ang), sin(ang), 0) * mix(0.3, 0.7, rad);\\n \\n // 0-6 \\n float m = tm; //mod(tm, 4. * 3.);\\n float mix01 = mixer(m, 0., 3.);\\n float mix23 = mixer(m, 0., 3.);\\n float mix0123 = mixer(m, 0., 6.);\\n vec3 offset = \\n mix(\\n mix(offset0, offset1, mix01),\\n mix(offset2, offset3, mix23),\\n mix0123);\\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= rotZ(tm);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(1.0, 1., ncgv) * mix(0.05, 0.05, hash(groupId)) + pow(snd + 0.1, 5.0) * 0.1 + sliceId * 0.0);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = tm * 0.1 + mix(0., 0.2, hash(groupId * 0.23));\\n float sat = 1. - pow(snd, 5.);\\n float val = 1.;//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), ncgv);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/zweiklang/sets/sdr017-wesley-monteiro", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 10.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n vec3 pos;\n float inner = mix(0.0, 0.1, p1m1(sin(goop(groupId) + time * 0.0)));\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd = texture2D(sound, vec2(mix(0.01, 0.14, su), cgv * 0.05)).a;\n snd = pow(snd, mix(2., 0.5, su));\n \n\n // ----\n float gDown = floor(sqrt(numGroups));\n float gAcross = floor(numGroups / gDown);\n vec3 offset0 = vec3(\n mod(groupId, gAcross) - (gAcross - 1.) / 2.,\n floor(groupId / gAcross) - (gDown - 1.) / 2.,\n 0) * 0.3;\n \n // ----\n float ang = gv * 10.0;\n vec3 offset1 = vec3(cos(ang), sin(ang), 0) * gv * 0.5;\n\n // ----\n vec3 offset2 = (vec3(hash(groupId), hash(groupId * 0.37), 0) * 2. - 1.) * 0.8;\n \n // ----\n ang = gv * 20.0;\n float rad = floor(groupId / pow(2., gv + 3.));\n vec3 offset3 = vec3(cos(ang), sin(ang), 0) * mix(0.3, 0.7, rad);\n \n // 0-6 \n float m = tm; //mod(tm, 4. * 3.);\n float mix01 = mixer(m, 0., 3.);\n float mix23 = mixer(m, 0., 3.);\n float mix0123 = mixer(m, 0., 6.);\n vec3 offset = \n mix(\n mix(offset0, offset1, mix01),\n mix(offset2, offset3, mix23),\n mix0123);\n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= rotZ(tm);\n mat *= trans(offset);\n mat *= uniformScale(mix(1.0, 1., ncgv) * mix(0.05, 0.05, hash(groupId)) + pow(snd + 0.1, 5.0) * 0.1 + sliceId * 0.0);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = tm * 0.1 + mix(0., 0.2, hash(groupId * 0.23));\n float sat = 1. - pow(snd, 5.);\n float val = 1.;//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), ncgv);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-tj2yixd6koe03tp5s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7EeTjhnP4EshLL5B2/art.json b/art/7EeTjhnP4EshLL5B2/art.json index da2739ad..a2595b0c 100644 --- a/art/7EeTjhnP4EshLL5B2/art.json +++ b/art/7EeTjhnP4EshLL5B2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "paul-jan", "avatarUrl": "https://secure.gravatar.com/avatar/40d0673cb04e3c59ed5f9086f215bb8d?default=retro&size=200", - "settings": "{\"num\":4000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + 0.2 * y) * 0.1 * 1000. / vertexCount;\\n float yoff = sin(time * 1.1 + 0.3 * x) * 0.2 * 1000. / vertexCount;\\n \\n float ux = 2.0 * u - 1.0 + xoff;\\n float uy = 2.0 * v - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float hue = 0.5 + 0.1 * u + 0.1 * sin(time * 1.3 + v * 20.);\\n float sat = 0.5;\\n float val = .8 + sin(time * 1.4 + u * v * 20.0) * 0.5;\\n \\n gl_Position = vec4(xy, 0, 1);\\n gl_PointSize = 15.0 * 20.0 / across + soff;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 4000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float across = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + 0.2 * y) * 0.1 * 1000. / vertexCount;\n float yoff = sin(time * 1.1 + 0.3 * x) * 0.2 * 1000. / vertexCount;\n \n float ux = 2.0 * u - 1.0 + xoff;\n float uy = 2.0 * v - 1.0 + yoff;\n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float hue = 0.5 + 0.1 * u + 0.1 * sin(time * 1.3 + v * 20.);\n float sat = 0.5;\n float val = .8 + sin(time * 1.4 + u * v * 20.0) * 0.5;\n \n gl_Position = vec4(xy, 0, 1);\n gl_PointSize = 15.0 * 20.0 / across + soff;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-d4t4mlp8jh9l7wl49-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7EmHQKmTWXAwTXS63/art.json b/art/7EmHQKmTWXAwTXS63/art.json index f18503f5..2be6f9cd 100644 --- a/art/7EmHQKmTWXAwTXS63/art.json +++ b/art/7EmHQKmTWXAwTXS63/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/protector-101/protector-101-a-dancing-comet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 02, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 12); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 12, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 12); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/protector-101/protector-101-a-dancing-comet", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 02, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 12); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 12, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 12); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-2avr79rlrav34fenh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7F8oEX6xT8qLDdtS2/art.json b/art/7F8oEX6xT8qLDdtS2/art.json index 6e1627dc..7d4ce500 100644 --- a/art/7F8oEX6xT8qLDdtS2/art.json +++ b/art/7F8oEX6xT8qLDdtS2/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cjensen93", "avatarUrl": "https://secure.gravatar.com/avatar/0df4239ac208a0c9696c1edd2e895cee?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.058823529411764705,0.4117647058823529,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n\\n}\\n\\n\\nvoid main(){\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOff = sin(time * 1.1 + y * 0.2) * 0.1;\\n float yOff = sin(time * 1.5 + x * 0.3) * 0.2;\\n\\n float ux = u * 2.0 - 1.0 + xOff;\\n float uy = v * 2.0 - 1.0 + yOff;\\n \\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n \\n float sOff = sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sOff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 1.7 + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float value = sin(time * 1.3 * v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.058823529411764705, + 0.4117647058823529, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n\n}\n\n\nvoid main(){\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOff = sin(time * 1.1 + y * 0.2) * 0.1;\n float yOff = sin(time * 1.5 + x * 0.3) * 0.2;\n\n float ux = u * 2.0 - 1.0 + xOff;\n float uy = v * 2.0 - 1.0 + yOff;\n \n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n gl_Position = vec4(xy,0.0,1.0);\n \n float sOff = sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sOff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 1.7 + v * 20.0) * 0.05;\n float sat = 1.0;\n float value = sin(time * 1.3 * v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-8zz3lt3lyjo40j3iq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7G88sy7oNibcANkMP/art.json b/art/7G88sy7oNibcANkMP/art.json index e7299890..3c8b5fad 100644 --- a/art/7G88sy7oNibcANkMP/art.json +++ b/art/7G88sy7oNibcANkMP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-jyume-18-phantasm-plus-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n🍩\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0.4,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy * vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 125.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(0., 1., vy);\\n \\n float gv = (groupId + vy) / numGroups; \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n float s = texture2D(sound, vec2(mix(0.1, 0.15, abs(gv * 2. - 1.)), 0)).a;\\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE /2., ux, inner, start, end, pos); \\n vec3 nrm = pos;\\n \\n float r = 4.;\\n float ct = time * .15;\\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\\n vec3 target = vec3(0, -3, 0);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.7, 13.); \\n mat *= cameraLookAt(eye, target, up);\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotY(gv * PI * 2.);\\n mat *= trans(vec3(5,0,0));\\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n vec3 n = (mat * vec4(nrm, 0)).xyz;\\n\\n float hue = ct + sin(gv * PI) * 0.1;\\n float sat = 1. - pow(s + .45, 15.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5)/tan(time);\\n \\n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\\n float l = dot(n, lightDir) * 1.5 + .5;\\n \\n v_color.rgb *= mix(1., l, sat);\\n v_color.rgb *= v_color.a;\\n \\n //v_color.rgb = n * .5 + .5;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-jyume-18-phantasm-plus-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n🍩\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0.4,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy * vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 125.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(0., 1., vy);\n \n float gv = (groupId + vy) / numGroups; \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n float s = texture2D(sound, vec2(mix(0.1, 0.15, abs(gv * 2. - 1.)), 0)).a;\n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE /2., ux, inner, start, end, pos); \n vec3 nrm = pos;\n \n float r = 4.;\n float ct = time * .15;\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\n vec3 target = vec3(0, -3, 0);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.7, 13.); \n mat *= cameraLookAt(eye, target, up);\n float sp = pow(snd, 5.0);\n\n mat *= rotY(gv * PI * 2.);\n mat *= trans(vec3(5,0,0));\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n vec3 n = (mat * vec4(nrm, 0)).xyz;\n\n float hue = ct + sin(gv * PI) * 0.1;\n float sat = 1. - pow(s + .45, 15.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5)/tan(time);\n \n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\n float l = dot(n, lightDir) * 1.5 + .5;\n \n v_color.rgb *= mix(1., l, sat);\n v_color.rgb *= v_color.a;\n \n //v_color.rgb = n * .5 + .5;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-azmro6hs7xmivnb6u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7GNBiei7nte4HfQN2/art.json b/art/7GNBiei7nte4HfQN2/art.json index 80a92e45..c0a00e66 100644 --- a/art/7GNBiei7nte4HfQN2/art.json +++ b/art/7GNBiei7nte4HfQN2/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "langtoner", "avatarUrl": "https://secure.gravatar.com/avatar/dceb35cad80ced6f55f55cf8d2fd8971?default=retro&size=200", - "settings": "{\"num\":10,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float x = vertexId /20.;\\ngl_Position = vec4(x,0,0,1);\\ngl_PointSize = 10.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 10, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float x = vertexId /20.;\ngl_Position = vec4(x,0,0,1);\ngl_PointSize = 10.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-1rg5m93rrrb3umzj5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7HjknSiL8tp9XXHEa/art.json b/art/7HjknSiL8tp9XXHEa/art.json index e108780a..dd125f60 100644 --- a/art/7HjknSiL8tp9XXHEa/art.json +++ b/art/7HjknSiL8tp9XXHEa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 1.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 15.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n //xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n //lineId+=mod(time*10.,1.);\\n //lineId/=numberOfElement;\\n\\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n \\n vec3 circleCenter = vec3(-1.5,0.,0.);\\n \\n //float xcircleRadius = 0.4;\\n //circleCenter.x -= 1.;\\n\\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\\n //cubep.z += sin(lineId*2.*PI);\\n //cubep = rot(circleCenter,PI/10.);\\n //cubep.x -= circleCenter.x;\\n \\n cubep.x += cos(xPos*2.*PI)/10.;\\n cubep.y += sin(xPos*2.*PI)/10.;\\n cubep += circleCenter;\\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines);\\n cubep -= circleCenter;\\n\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n //cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 0., .2);//29./2.*abs(cos(time/5.))\\n //eye = vec3(-1., 3., -1.);\\n //cubep += distance(cubep, eye)/7.;\\n \\n //cubep.x += 0.2;\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 1.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 15.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n //xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n //lineId+=mod(time*10.,1.);\n //lineId/=numberOfElement;\n\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n \n vec3 circleCenter = vec3(-1.5,0.,0.);\n \n //float xcircleRadius = 0.4;\n //circleCenter.x -= 1.;\n\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\n //cubep.z += sin(lineId*2.*PI);\n //cubep = rot(circleCenter,PI/10.);\n //cubep.x -= circleCenter.x;\n \n cubep.x += cos(xPos*2.*PI)/10.;\n cubep.y += sin(xPos*2.*PI)/10.;\n cubep += circleCenter;\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines);\n cubep -= circleCenter;\n\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n //cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 0., .2);//29./2.*abs(cos(time/5.))\n //eye = vec3(-1., 3., -1.);\n //cubep += distance(cubep, eye)/7.;\n \n //cubep.x += 0.2;\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-628tfkdpsrat8lhfx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7JTyL7fuENPgA9o2H/art.json b/art/7JTyL7fuENPgA9o2H/art.json index 6edaaa4d..6c8d9742 100644 --- a/art/7JTyL7fuENPgA9o2H/art.json +++ b/art/7JTyL7fuENPgA9o2H/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/deardeermusic/free-download-depeche-mode-strangelove-warung-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 0., 0);\\n return pos;\\n}\\n\\nvec3 grad(float v) {\\n v = fract(v) * 4.0;\\n vec3 c = step(v, 1.) * mix(vec3(1, 1, 1), vec3(0, 0, 1), clamp(v - 0., 0., 1.));\\n c += mix(vec3(0, 0, 1), vec3(1, 0, 0), clamp(v - 1., 0., 1.));\\n return c;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n \\n float s = 16. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, vec3(0));\\n// p = vec3(qx, 0, qz);\\n \\n// float ss = texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float ss = texture2D(sound, vec2(qu * 0.5, qv * 0.5)).a * -200.;\\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n m *= trans(q * s);\\n mat4 m2 = rotY(sin(time * 1.114 + qu) + sin((time * 0.94 + qu * 3.0) * 0.73)+ sin((time + qv * 4.7) * 0.211)\\n + qv);\\n// m *= inverse(trans(q));\\n\\n m2 *= trans(vec3(\\n sin((time + qu * 0.913)) * 105. + \\n sin((time * 0.23 + qu * 2.713)) * 55. +\\n sin((time * 0.51 + qu * 4.317)) * 23. +\\n sin((time * 0.78 + qu * 8.111)) * 17. +\\n sin((time * 1.37 + qu * 15.111)) * 6. ,\\n qu + ss,\\n cos((time + qv * 1.177)) * 66. + \\n cos((time * 1.03 + qv * 2.177)) * 33. + \\n cos((time * 0.91 + qv * 4.177)) * 16. + \\n cos((time * 0.76 + qv * 8.177)) * 8. + \\n cos((time * 0.37 + qv * 16.177)) * 4. \\n ) * 0.01);\\n /*\\n let smat = m3.translation(4, 6);\\n smat = m3.multiply(smat, mat);\\n setTransform(smat);\\n ctx.fillStyle = '#000';\\n ctx.fillRect(-2, -2, cellSize + 4, cellSize + 6);\\n const d = m3.distance(mat[6], mat[7], xBase, yBase) / dist;\\n \\n */\\n \\n \\n gl_Position = m * m2 * vec4(p, 1);\\n \\n float d = length(vec3(m2[3]));\\n float hue = d * 0.2;0.6 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\\n float sat = 1.;pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = 1.; mix(0.05, 1., l);\\n \\n float pop = step(0.6, ss);\\n// val = mix(val, 1., pop);\\n// hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n v_color.rgb = grad(d);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/deardeermusic/free-download-depeche-mode-strangelove-warung-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 0., 0);\n return pos;\n}\n\nvec3 grad(float v) {\n v = fract(v) * 4.0;\n vec3 c = step(v, 1.) * mix(vec3(1, 1, 1), vec3(0, 0, 1), clamp(v - 0., 0., 1.));\n c += mix(vec3(0, 0, 1), vec3(1, 0, 0), clamp(v - 1., 0., 1.));\n return c;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n \n float s = 16. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, vec3(0));\n// p = vec3(qx, 0, qz);\n \n// float ss = texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float ss = texture2D(sound, vec2(qu * 0.5, qv * 0.5)).a * -200.;\n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n m *= trans(q * s);\n mat4 m2 = rotY(sin(time * 1.114 + qu) + sin((time * 0.94 + qu * 3.0) * 0.73)+ sin((time + qv * 4.7) * 0.211)\n + qv);\n// m *= inverse(trans(q));\n\n m2 *= trans(vec3(\n sin((time + qu * 0.913)) * 105. + \n sin((time * 0.23 + qu * 2.713)) * 55. +\n sin((time * 0.51 + qu * 4.317)) * 23. +\n sin((time * 0.78 + qu * 8.111)) * 17. +\n sin((time * 1.37 + qu * 15.111)) * 6. ,\n qu + ss,\n cos((time + qv * 1.177)) * 66. + \n cos((time * 1.03 + qv * 2.177)) * 33. + \n cos((time * 0.91 + qv * 4.177)) * 16. + \n cos((time * 0.76 + qv * 8.177)) * 8. + \n cos((time * 0.37 + qv * 16.177)) * 4. \n ) * 0.01);\n /*\n let smat = m3.translation(4, 6);\n smat = m3.multiply(smat, mat);\n setTransform(smat);\n ctx.fillStyle = '#000';\n ctx.fillRect(-2, -2, cellSize + 4, cellSize + 6);\n const d = m3.distance(mat[6], mat[7], xBase, yBase) / dist;\n \n */\n \n \n gl_Position = m * m2 * vec4(p, 1);\n \n float d = length(vec3(m2[3]));\n float hue = d * 0.2;0.6 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\n float sat = 1.;pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = 1.; mix(0.05, 1., l);\n \n float pop = step(0.6, ss);\n// val = mix(val, 1., pop);\n// hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n v_color.rgb = grad(d);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-8js557ky0nikp5pu1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7M9dkbTrmJYvKMzic/art.json b/art/7M9dkbTrmJYvKMzic/art.json index 9dc48e0f..f6bb2962 100644 --- a/art/7M9dkbTrmJYvKMzic/art.json +++ b/art/7M9dkbTrmJYvKMzic/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "taejukwon-digipen", "avatarUrl": "https://avatars.githubusercontent.com/taejuKwon-digipen?s=200", - "settings": "{\"num\":7192,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Taeju Kwon\\n//CS250\\n//2022_Spring\\n//03_Color\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3 (c.x, clamp(c.yz, 0.0,1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p-K.xxx , 0.0, 1.0) , c.y);\\n}\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * 1. + sin(time * 1.3 + v * 20.) * 0.05;\\n float nat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0 ) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, nat, val)),1);\\n}\"}", + "settings": { + "num": 7192, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Taeju Kwon\n//CS250\n//2022_Spring\n//03_Color\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3 (c.x, clamp(c.yz, 0.0,1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p-K.xxx , 0.0, 1.0) , c.y);\n}\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * 1. + sin(time * 1.3 + v * 20.) * 0.05;\n float nat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0 ) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, nat, val)),1);\n}" + }, "screenshotURL": "data/images/images-6a121029h1esyktq7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7NHz8BY49bR5hCy8h/art.json b/art/7NHz8BY49bR5hCy8h/art.json index b77e52f5..7f7812ce 100644 --- a/art/7NHz8BY49bR5hCy8h/art.json +++ b/art/7NHz8BY49bR5hCy8h/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":2792,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Seulbin Seo\\n// Exercise Color\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main ()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy)* 1.3;\\n\\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 2792, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Color\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main ()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy)* 1.3;\n\n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-id3q0oscmslt20ky1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7PpvqJmgJR7ALoJfa/art.json b/art/7PpvqJmgJR7ALoJfa/art.json index 9d5bb4a2..c6710886 100644 --- a/art/7PpvqJmgJR7ALoJfa/art.json +++ b/art/7PpvqJmgJR7ALoJfa/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//vertex shader:\\nvoid main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.75;\\n float rightBottom = 0.0125;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 0, 0, 1);\\n }\\n else {\\n v_color = vec4(0, 0, 1, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//vertex shader:\nvoid main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.75;\n float rightBottom = 0.0125;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 0, 0, 1);\n }\n else {\n v_color = vec4(0, 0, 1, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-jbfdh5g32wc9zcooo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7QAPWrZErhyBDRnKb/art.json b/art/7QAPWrZErhyBDRnKb/art.json index 9125bd63..3060ed0c 100644 --- a/art/7QAPWrZErhyBDRnKb/art.json +++ b/art/7QAPWrZErhyBDRnKb/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/peter-jeong-284275317/last-minute-of-party?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Circles from Triangles\\n// Course : CS250\\n// Spring 2023\\n\\n//\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u -.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .0, av * .15)).g;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n // [0, 1)\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \\n float sat = 1.;//mix(0.5, 1., pump);//mix(1., -10., 1. - av);\\n float val = mix(.4, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n //\\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n} \"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/peter-jeong-284275317/last-minute-of-party?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Circles from Triangles\n// Course : CS250\n// Spring 2023\n\n//\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u -.5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .0, av * .15)).g;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n // [0, 1)\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \n float sat = 1.;//mix(0.5, 1., pump);//mix(1., -10., 1. - av);\n float val = mix(.4, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n //\n hue += pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n} " + }, "screenshotURL": "data/images/images-tc4m3dizar1e7zcw8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7QLuHLmctdsezmmxr/art.json b/art/7QLuHLmctdsezmmxr/art.json index 184a7531..9c4ed19d 100644 --- a/art/7QLuHLmctdsezmmxr/art.json +++ b/art/7QLuHLmctdsezmmxr/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n//Super Simple dot example\\n//Very simple vertex shader initiation with comments (work in progress)\\n////////////////////////////////////////////////////////////\\n\\n//Vertices number (top menu) is on \\\"1\\\" means we are drawing only one vertice/dot (maximum would be 100000 on vertexshaderart.com)\\n//Render mode (top menu) is on \\\"POINTS\\\" means we are interpreting consecutive vertices as simple points.\\n//All lines starting with \\\"//\\\" are only here for comments and do not affect the final shader program\\n\\nvoid main(){ \\n\\n //1. SETTING THE DOT SIZE: \\n //Exercise : try to change the value 15.0 to 30.0 and see the size of the point changes\\n\\n gl_PointSize = 15.0;\\n\\n\\n //2. SETTING THE DOT POSITION : vec4(horizontal position, vertical position, depth position, 1.);\\n //Note: values range from -1. to 1. : for first component -1. would be top left of the screen and 1. would be top right of the screen.\\n\\n //Exercise : Try to change the FIRST 0. in vec4(0., 0., -1., 1.) to vec4(0.5, 0., -1., 1.) and see the position of the point changes HORIZONTALLY\\n //Exercise : Try to change the SECOND 0. in vec4(0., 0., -1., 1.) to vec4(0., 0.5, -1., 1.) and see the position of the point changes VERTICALLY\\n\\n gl_Position = vec4(0., 0., 0., 1.); \\n\\n\\n //3. SETTING THE DOT COLOR : \\n //Each number in the vec4() below is for vec4(red, green, blue, alpha) hence, vec4(1., 1., 1., 1.0) is for white color\\n //Note: values range from 0. to 1. \\n\\n //Exercise : try to change vec4(1., 1., 1., 1.0) to vec4(1., 0., 0., 1.0) and see the point is now red\\n //Exercise : try to change vec4(1., 1., 1., 1.0) to vec4(0., 1., 0., 1.0) and see the point is now green\\n //Exercise : try to change vec4(1., 1., 1., 1.0) to vec4(0., 0., 1., 1.0) and see the point is now blue\\n \\n v_color = vec4(1., 1., 1., 1.);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n//Super Simple dot example\n//Very simple vertex shader initiation with comments (work in progress)\n////////////////////////////////////////////////////////////\n\n//Vertices number (top menu) is on \"1\" means we are drawing only one vertice/dot (maximum would be 100000 on vertexshaderart.com)\n//Render mode (top menu) is on \"POINTS\" means we are interpreting consecutive vertices as simple points.\n//All lines starting with \"//\" are only here for comments and do not affect the final shader program\n\nvoid main(){ \n\n //1. SETTING THE DOT SIZE: \n //Exercise : try to change the value 15.0 to 30.0 and see the size of the point changes\n\n gl_PointSize = 15.0;\n\n\n //2. SETTING THE DOT POSITION : vec4(horizontal position, vertical position, depth position, 1.);\n //Note: values range from -1. to 1. : for first component -1. would be top left of the screen and 1. would be top right of the screen.\n\n //Exercise : Try to change the FIRST 0. in vec4(0., 0., -1., 1.) to vec4(0.5, 0., -1., 1.) and see the position of the point changes HORIZONTALLY\n //Exercise : Try to change the SECOND 0. in vec4(0., 0., -1., 1.) to vec4(0., 0.5, -1., 1.) and see the position of the point changes VERTICALLY\n\n gl_Position = vec4(0., 0., 0., 1.); \n\n\n //3. SETTING THE DOT COLOR : \n //Each number in the vec4() below is for vec4(red, green, blue, alpha) hence, vec4(1., 1., 1., 1.0) is for white color\n //Note: values range from 0. to 1. \n\n //Exercise : try to change vec4(1., 1., 1., 1.0) to vec4(1., 0., 0., 1.0) and see the point is now red\n //Exercise : try to change vec4(1., 1., 1., 1.0) to vec4(0., 1., 0., 1.0) and see the point is now green\n //Exercise : try to change vec4(1., 1., 1., 1.0) to vec4(0., 0., 1., 1.0) and see the point is now blue\n \n v_color = vec4(1., 1., 1., 1.);\n}" + }, "screenshotURL": "data/images/images-k27bazx3rp2qmxpyl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7RXESd6b5ToNrYe9M/art.json b/art/7RXESd6b5ToNrYe9M/art.json index e4b257b3..93cefd3d 100644 --- a/art/7RXESd6b5ToNrYe9M/art.json +++ b/art/7RXESd6b5ToNrYe9M/art.json @@ -28,7 +28,19 @@ "name": "unnamed 3", "private": false, "username": "andrea", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\\n#define STEP 8.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 1.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 60.0;\\n float point = mod(floor(vertexId / 8.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 3.14 / NUM_SEGMENTS + offset;\\n float radius = 0.1;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.004;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\n#define STEP 8.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 1.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 60.0;\n float point = mod(floor(vertexId / 8.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 3.14 / NUM_SEGMENTS + offset;\n float radius = 0.1;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.004;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-psv9cjtjtc802nw70-thumbnail.jpg", "views": { "$numberInt": "221" diff --git a/art/7TrYkuK4aHzLqvZ7r/art.json b/art/7TrYkuK4aHzLqvZ7r/art.json index 2cfcf060..dae0f1f4 100644 --- a/art/7TrYkuK4aHzLqvZ7r/art.json +++ b/art/7TrYkuK4aHzLqvZ7r/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":97200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) / around * PI * 2.)\\n );\\n \\n float tm = time * 1.1;\\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(0.001, .5, hash(qu+qv)), mix(0., .012, hash(qv)))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.5, 1.5, pow(s, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float odd = mod(floor(quadId / 2.), 2.);\\n float hue = time * .1 +s * .15 + odd * .5;\\n float sat = mix(1., 1., odd);\\n float val = mix(0.25, 1., odd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 97200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) / around * PI * 2.)\n );\n \n float tm = time * 1.1;\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(0.001, .5, hash(qu+qv)), mix(0., .012, hash(qv)))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.5, 1.5, pow(s, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float odd = mod(floor(quadId / 2.), 2.);\n float hue = time * .1 +s * .15 + odd * .5;\n float sat = mix(1., 1., odd);\n float val = mix(0.25, 1., odd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-at6mlyyftky2ptmmy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7W6jf6wm4is8A9o9z/art.json b/art/7W6jf6wm4is8A9o9z/art.json index 7f03211e..6218eb2f 100644 --- a/art/7W6jf6wm4is8A9o9z/art.json +++ b/art/7W6jf6wm4is8A9o9z/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2,0,0,1],\"shader\":\"void main() {\\n gl_Position = vec4(1, 0, 0, 1);\\n gl_PointSize = 40.;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(1, 0, 0, 1);\n gl_PointSize = 40.;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-vder76ip51y0s5voo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7WmeTJSdWymq8FHDN/art.json b/art/7WmeTJSdWymq8FHDN/art.json index b2063bc6..baec55c2 100644 --- a/art/7WmeTJSdWymq8FHDN/art.json +++ b/art/7WmeTJSdWymq8FHDN/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n 01/01/2019 \\n*/ \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n }\\n/*\\n vec3 getQPoint(const float id) \\n {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n }\\n*/\\n void GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n {\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n }\\n#pragma endregion \\n\\n/* -------------------------------- separator ------------------------------- */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/* -------------------------------- separator ------------------------------- */\\n\\t\\nvoid main()\\n{ \\n #pragma region ProjectionSetUp \\n mat4 m = persp(radians(45.),\\n resolution.x/ resolution.y, \\n NEARCLIPPED , \\n FARCLIPPED); \\n #pragma endregion \\n\\n #pragma region CameraSetUp/ViewSetUp\\n vec3 target = vec3(0. ) ;\\n vec3 up = vec3(0. ,1. , 0. ) ; \\n vec3 camTarget = target ; \\n vec3 camPos = vec3(1.); \\n vec3 camForward = normalize(camTarget - camPos);\\n m *= cameraLookAt(camPos , camTarget, normalize(up));\\n #pragma endregion \\n\\n #pragma region model \\n m *= uniformScale(0.7);\\n m *= trans(vec3(1.)) ;\\n m *= rotY(0.2);\\n #pragma endregion \\n \\n \\n #pragma region Light\\n \\t vec3 ambient = vec3(0.) ; \\n \\t vec3 diffuse = vec3(0.) ;\\n \\t vec3 specular = vec3(0.);\\n \\t vec3 result = ambient + diffuse + specular ;\\n #pragma endregion \\n \\n #pragma region PostProcessing\\n \\n \\n #pragma endregion\\n \\n #pragma region outPutElement\\n gl_Position = m * vec4(1.) ; \\n gl_PointSize *= (vec4(1.0 , 0., 0., 0.)* uniformScale(10.)).x ; \\n v_color = vec4(result, 1. ) ;\\n #pragma endregion \\n \\n \\n}\\n\\n\\n //常见的光照模型计算: \\n /*\\ngl_Position = projection * view * model * vec4(position, 1.0f ) ; \\n\\n模型对象转换 \\n\\n \\n\\n//在这里处理Gourauad shading \\n\\nvec3 t_fragPos = vec3(model * vec4(position, 1.0f) ) ; \\n\\nvec3 t_Normal = mat3(transpose(inverse(model))) * normal ; \\n\\n获取基本数据 , 这里面作为 法线和受光对象在世界空间中的位置向量(模不为1) \\n\\n \\n\\n//ambient 环境光 \\n\\nfloat ambientStrength = 0.1f ; \\n\\nvec3 ambient = ambientStrength * lightColor ; \\n\\n环境光设置, 直接设置光来源的大小 。 \\n\\n \\n\\n//diffuse 漫反射 \\n\\nvec3 norm = normalize(t_Normal); \\n\\nvec3 lightDir = normalize(lightPos - t_fragPos) ; \\n\\nfloat diff = max(dot(norm, lightDir), 0.0) ; \\n\\nvec3 diffuse = diff * lightColor ; \\n\\n漫反射 通过光线与法线的点乘进行比较 (注意这里要直接大于0 。 不然颜色错乱) \\n\\n \\n\\n//specular 镜面反色 \\n\\nfloat specularStrength = 2.0f ; \\n\\nvec3 viewDir = normalize(viewPos - t_fragPos) ; \\n\\nvec3 reflectDir = reflect(-lightDir , norm) ; \\n\\nfloat spec = pow(max(dot(viewDir, reflectDir) , 0.0 ) , 32); \\n\\nvec3 specular = specularStrength * spec * lightColor ; \\n\\n镜面反射 通过反射光线 与 观察者的点乘比较, 然后乘以shininess(注意所有的点乘,形成高光 \\n\\n \\n\\n最后形成结果颜色: \\n\\nresultColor = ambient + diffuse + specular ; \\n*/\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n 01/01/2019 \n*/ \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n }\n/*\n vec3 getQPoint(const float id) \n {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n }\n*/\n void GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n {\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n }\n#pragma endregion \n\n/* -------------------------------- separator ------------------------------- */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* -------------------------------- separator ------------------------------- */\n\t\nvoid main()\n{ \n #pragma region ProjectionSetUp \n mat4 m = persp(radians(45.),\n resolution.x/ resolution.y, \n NEARCLIPPED , \n FARCLIPPED); \n #pragma endregion \n\n #pragma region CameraSetUp/ViewSetUp\n vec3 target = vec3(0. ) ;\n vec3 up = vec3(0. ,1. , 0. ) ; \n vec3 camTarget = target ; \n vec3 camPos = vec3(1.); \n vec3 camForward = normalize(camTarget - camPos);\n m *= cameraLookAt(camPos , camTarget, normalize(up));\n #pragma endregion \n\n #pragma region model \n m *= uniformScale(0.7);\n m *= trans(vec3(1.)) ;\n m *= rotY(0.2);\n #pragma endregion \n \n \n #pragma region Light\n \t vec3 ambient = vec3(0.) ; \n \t vec3 diffuse = vec3(0.) ;\n \t vec3 specular = vec3(0.);\n \t vec3 result = ambient + diffuse + specular ;\n #pragma endregion \n \n #pragma region PostProcessing\n \n \n #pragma endregion\n \n #pragma region outPutElement\n gl_Position = m * vec4(1.) ; \n gl_PointSize *= (vec4(1.0 , 0., 0., 0.)* uniformScale(10.)).x ; \n v_color = vec4(result, 1. ) ;\n #pragma endregion \n \n \n}\n\n\n //常见的光照模型计算: \n /*\ngl_Position = projection * view * model * vec4(position, 1.0f ) ; \n\n模型对象转换 \n\n \n\n//在这里处理Gourauad shading \n\nvec3 t_fragPos = vec3(model * vec4(position, 1.0f) ) ; \n\nvec3 t_Normal = mat3(transpose(inverse(model))) * normal ; \n\n获取基本数据 , 这里面作为 法线和受光对象在世界空间中的位置向量(模不为1) \n\n \n\n//ambient 环境光 \n\nfloat ambientStrength = 0.1f ; \n\nvec3 ambient = ambientStrength * lightColor ; \n\n环境光设置, 直接设置光来源的大小 。 \n\n \n\n//diffuse 漫反射 \n\nvec3 norm = normalize(t_Normal); \n\nvec3 lightDir = normalize(lightPos - t_fragPos) ; \n\nfloat diff = max(dot(norm, lightDir), 0.0) ; \n\nvec3 diffuse = diff * lightColor ; \n\n漫反射 通过光线与法线的点乘进行比较 (注意这里要直接大于0 。 不然颜色错乱) \n\n \n\n//specular 镜面反色 \n\nfloat specularStrength = 2.0f ; \n\nvec3 viewDir = normalize(viewPos - t_fragPos) ; \n\nvec3 reflectDir = reflect(-lightDir , norm) ; \n\nfloat spec = pow(max(dot(viewDir, reflectDir) , 0.0 ) , 32); \n\nvec3 specular = specularStrength * spec * lightColor ; \n\n镜面反射 通过反射光线 与 观察者的点乘比较, 然后乘以shininess(注意所有的点乘,形成高光 \n\n \n\n最后形成结果颜色: \n\nresultColor = ambient + diffuse + specular ; \n*/" + }, "screenshotURL": "data/images/images-q7kzfjvfxtxxpsr93-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7Xh2ZeThqMgWodKe8/art.json b/art/7Xh2ZeThqMgWodKe8/art.json index cabb1e95..97254436 100644 --- a/art/7Xh2ZeThqMgWodKe8/art.json +++ b/art/7Xh2ZeThqMgWodKe8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n//KDrawmode=GL_\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0.2, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.2,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.81;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.*s;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf -= 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 0.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 3.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, qu, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\\n vec3 n0 = getQuadPoint(nId + 0.1, s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.*-mouse.x);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, s, 0.5+s));\\n \\n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-s*(mouse.x*0.5));\\n \\n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 4.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y);\\n v_color = mix(v_color, background, 0.2 * cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n//KDrawmode=GL_\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0.2, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.2,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.81;\n\tf = 0.5000*noise( p ); p = mr*p*2.*s;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf -= 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 0.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 3.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, qu, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\n vec3 n0 = getQuadPoint(nId + 0.1, s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.*-mouse.x);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, s, 0.5+s));\n \n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-s*(mouse.x*0.5));\n \n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 4.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y);\n v_color = mix(v_color, background, 0.2 * cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-at47w8ysu6wyzyagt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7Xo5cox42KeW3chZj/art.json b/art/7Xo5cox42KeW3chZj/art.json index 97c5825c..7bfa484c 100644 --- a/art/7Xo5cox42KeW3chZj/art.json +++ b/art/7Xo5cox42KeW3chZj/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\n//KDrawmode=GL_TRIANGLES\\n//KDrawmode=GL_TRIANGLES\\n#define kindOfRotation 0.1//KParameter0 0.1>>10.\\n#define theScale 0.7//KParameter1 0.05>>0.7\\n#define tmFactor 0.//KParameter2 0.>>10.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nmat4 mixm(mat4 m1, mat4 m2, float m) {\\n return mat4(\\n mix(m1[0], m2[0], m),\\n mix(m1[1], m2[1], m),\\n mix(m1[2], m2[2], m),\\n mix(m1[3], m2[3], m));\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes) * .5);\\n float across = floor(numCubes / down);\\n float cv = cubeId / numCubes;\\n\\n float uu = mod(cubeId, across);\\n float vv = floor(cubeId / across);\\n vec2 uv = vec2(uu, vv) / vec2(across, down);\\n \\n// const int hist = 10;\\n// float s = 0.;\\n// for (int i = 0; i < hist; ++i) {\\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n// 1.;//float(hist - i);\\n// }\\n//// s /= float(hist * (hist - 1)) / 2.;\\n// s /= float(hist);\\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\\n \\n float tm = time * tmFactor;\\n float rd = 9.;\\n mat4 pmat = persp(radians(130.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up); \\n \\n mat4 mat = rotY(time * kindOfRotation);\\n mat *= lookAt(\\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \\n mix(20., 24.1, s),\\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\\n vec3(0, 1, 0));\\n \\n mat4 mvmat = vmat * mat;\\n \\n vec3 npos = normalize(mvmat[3].xyz);\\n \\n //float hue = mix(.0, time * 10., step(.8, s));\\n float hue = mix(.0, time * 10., step(.8, s));\\n float sat = mix(-1.0, 2.2, s);\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n\\n \\n float areaS = 1. - (npos.z * .5 + .5);\\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\\n smat *= uniformScale(theScale);\\n smat *= trans(vec3(0, 0, -1));\\n \\n \\n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1, 0.1, 1));\\n\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(0., 2., s);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\n//KDrawmode=GL_TRIANGLES\n//KDrawmode=GL_TRIANGLES\n#define kindOfRotation 0.1//KParameter0 0.1>>10.\n#define theScale 0.7//KParameter1 0.05>>0.7\n#define tmFactor 0.//KParameter2 0.>>10.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nmat4 mixm(mat4 m1, mat4 m2, float m) {\n return mat4(\n mix(m1[0], m2[0], m),\n mix(m1[1], m2[1], m),\n mix(m1[2], m2[2], m),\n mix(m1[3], m2[3], m));\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes) * .5);\n float across = floor(numCubes / down);\n float cv = cubeId / numCubes;\n\n float uu = mod(cubeId, across);\n float vv = floor(cubeId / across);\n vec2 uv = vec2(uu, vv) / vec2(across, down);\n \n// const int hist = 10;\n// float s = 0.;\n// for (int i = 0; i < hist; ++i) {\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n// 1.;//float(hist - i);\n// }\n//// s /= float(hist * (hist - 1)) / 2.;\n// s /= float(hist);\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\n \n float tm = time * tmFactor;\n float rd = 9.;\n mat4 pmat = persp(radians(130.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up); \n \n mat4 mat = rotY(time * kindOfRotation);\n mat *= lookAt(\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \n mix(20., 24.1, s),\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\n vec3(0, 1, 0));\n \n mat4 mvmat = vmat * mat;\n \n vec3 npos = normalize(mvmat[3].xyz);\n \n //float hue = mix(.0, time * 10., step(.8, s));\n float hue = mix(.0, time * 10., step(.8, s));\n float sat = mix(-1.0, 2.2, s);\n float val = 1.;//mix(1., 1., step(0.8, s));\n\n \n float areaS = 1. - (npos.z * .5 + .5);\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\n smat *= uniformScale(theScale);\n smat *= trans(vec3(0, 0, -1));\n \n \n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1, 0.1, 1));\n\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(0., 2., s);\n}\n\n" + }, "screenshotURL": "data/images/images-2dx1a0dl4uwskrwqm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7YSTw2WwEmcGS4hYz/art.json b/art/7YSTw2WwEmcGS4hYz/art.json index 60f1d09c..12c5585c 100644 --- a/art/7YSTw2WwEmcGS4hYz/art.json +++ b/art/7YSTw2WwEmcGS4hYz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n\\n float gap = 10.; //vertexCount / resolution;\\n float x = mod(vertexId, gap) / gap;\\n float y = floor(vertexId / gap) / gap;\\n\\n gl_Position = vec4(x, y, 0, 1);\\n\\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n\n float gap = 10.; //vertexCount / resolution;\n float x = mod(vertexId, gap) / gap;\n float y = floor(vertexId / gap) / gap;\n\n gl_Position = vec4(x, y, 0, 1);\n\n gl_PointSize = 10.0;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-tbn3vr7niedv7xvrz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7YgXgotM2u7EazE58/art.json b/art/7YgXgotM2u7EazE58/art.json index 0448c4a7..480a5ba1 100644 --- a/art/7YgXgotM2u7EazE58/art.json +++ b/art/7YgXgotM2u7EazE58/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10800,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/massc4line/massc4line-diamonds\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// add-em-up\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(\\n const float numEdgePointsPerCircle, \\n const float id, \\n const float inner, \\n const float start, \\n const float end, \\n out vec3 pos,\\n out vec2 cuv) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n cuv = vec2(u, v);\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 300.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cv = circleId / numCircles;\\n \\n vec3 pos;\\n vec2 uv;\\n float inner = 0.5;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, vertexId, inner, start, end, pos, uv);\\n\\n float t = time * 0.03;\\n float snd = texture2D(\\n sound, \\n vec2(mix(cv * 0.1 + 0.1, cv * 0.1 + 0.2, fract(uv.x)), \\n 0)).a;\\n\\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.5);\\n mat *= rotZ(time * -cv);\\n mat *= trans(vec3(vec2(snd, snd) * 0.05, -cv));\\n mat *= uniformScale(mix(0.2, 3.8, pow(snd, 2.)));\\n gl_Position = mat * vec4(pos, 1);\\n\\n float hue = circleId * 0.33;\\n float sat = 1.; //mix(0., 1., mod(circleId, 3.) / 3.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. / numCircles);\\n}\\n\"}", + "settings": { + "num": 10800, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/massc4line/massc4line-diamonds", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// add-em-up\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(\n const float numEdgePointsPerCircle, \n const float id, \n const float inner, \n const float start, \n const float end, \n out vec3 pos,\n out vec2 cuv) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n cuv = vec2(u, v);\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 300.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cv = circleId / numCircles;\n \n vec3 pos;\n vec2 uv;\n float inner = 0.5;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, vertexId, inner, start, end, pos, uv);\n\n float t = time * 0.03;\n float snd = texture2D(\n sound, \n vec2(mix(cv * 0.1 + 0.1, cv * 0.1 + 0.2, fract(uv.x)), \n 0)).a;\n\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.5);\n mat *= rotZ(time * -cv);\n mat *= trans(vec3(vec2(snd, snd) * 0.05, -cv));\n mat *= uniformScale(mix(0.2, 3.8, pow(snd, 2.)));\n gl_Position = mat * vec4(pos, 1);\n\n float hue = circleId * 0.33;\n float sat = 1.; //mix(0., 1., mod(circleId, 3.) / 3.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. / numCircles);\n}\n" + }, "screenshotURL": "data/images/images-gyo1d9v2nciaq91e8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7YksmRJcwQXipHhfx/art.json b/art/7YksmRJcwQXipHhfx/art.json index 7deee3d0..f94af23e 100644 --- a/art/7YksmRJcwQXipHhfx/art.json +++ b/art/7YksmRJcwQXipHhfx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-sjdzoc1qexc1z55r1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7YtDi4LTcGHk4Rv7A/art.json b/art/7YtDi4LTcGHk4Rv7A/art.json index da1c29e7..6b165bce 100644 --- a/art/7YtDi4LTcGHk4Rv7A/art.json +++ b/art/7YtDi4LTcGHk4Rv7A/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5725490196078431,0.2549019607843137,0.7450980392156863,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos, float w, float h)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n float newRe = 1.5 * (pos.x - w / 2.0) / (0.5 * w);\\n float newIm = (pos.y - h / 2.0) / (0.5 * h);\\n float oldRe;\\n float oldIm;\\n float j = 0.0;\\n for(int i = 0; i < 128; i++)\\n {\\n j+=1.0;\\n oldRe = newRe;\\n oldIm = newIm;\\n newRe = oldRe * oldRe - oldIm * oldIm + 0.4;\\n newIm = 2.0 * oldRe * oldIm + sin(time/1.0);\\n if((newRe * newRe + newIm * newIm) > 4.0) break;\\n }\\n return j/64.0;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px+0.5, py+0.5)*100.0,px+w/2.0,py+h/2.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5725490196078431, + 0.2549019607843137, + 0.7450980392156863, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos, float w, float h)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n float newRe = 1.5 * (pos.x - w / 2.0) / (0.5 * w);\n float newIm = (pos.y - h / 2.0) / (0.5 * h);\n float oldRe;\n float oldIm;\n float j = 0.0;\n for(int i = 0; i < 128; i++)\n {\n j+=1.0;\n oldRe = newRe;\n oldIm = newIm;\n newRe = oldRe * oldRe - oldIm * oldIm + 0.4;\n newIm = 2.0 * oldRe * oldIm + sin(time/1.0);\n if((newRe * newRe + newIm * newIm) > 4.0) break;\n }\n return j/64.0;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px+0.5, py+0.5)*100.0,px+w/2.0,py+h/2.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-4w32gpqpqn1t5yikr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7ZDFThfCsDDXTyMjG/art.json b/art/7ZDFThfCsDDXTyMjG/art.json index 8f35bada..7de8212c 100644 --- a/art/7ZDFThfCsDDXTyMjG/art.json +++ b/art/7ZDFThfCsDDXTyMjG/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 89.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 89.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-qam4olvdkjs8klpfd-thumbnail.jpg", "views": { "$numberInt": "174" diff --git a/art/7ZTwrYe7Bq7kSQpPb/art.json b/art/7ZTwrYe7Bq7kSQpPb/art.json index 2918eb88..59a981aa 100644 --- a/art/7ZTwrYe7Bq7kSQpPb/art.json +++ b/art/7ZTwrYe7Bq7kSQpPb/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caravan-palace-official/lone-digger?in=caravan-palace-official%2Fsets%2Freleases\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//\\n#define PI radians(180.0)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float numShapes = vertexCount / NUM_POINTS;\\n float cv = count / numShapes;\\n float offset = count * 0.02;\\n float ev = point / NUM_SEGMENTS;\\n float angle = ev * PI * 2.0 + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n \\n float snd = texture2D(sound, vec2(cv * 0.1, ev * .1)).x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\\n\\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\\n vec2 xy = vec2(\\n c,\\n s);\\n gl_Position = vec4(xy * aspect * scale, 0, 1);\\n\\n float hue = cv * 0.2;\\n float unf = step(0.9, snd);\\n v_color = vec4(hsv2rgb(vec3(0, unf, hue + unf)), unf);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/caravan-palace-official/lone-digger?in=caravan-palace-official%2Fsets%2Freleases", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//\n#define PI radians(180.0)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float numShapes = vertexCount / NUM_POINTS;\n float cv = count / numShapes;\n float offset = count * 0.02;\n float ev = point / NUM_SEGMENTS;\n float angle = ev * PI * 2.0 + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n \n float snd = texture2D(sound, vec2(cv * 0.1, ev * .1)).x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\n\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\n vec2 xy = vec2(\n c,\n s);\n gl_Position = vec4(xy * aspect * scale, 0, 1);\n\n float hue = cv * 0.2;\n float unf = step(0.9, snd);\n v_color = vec4(hsv2rgb(vec3(0, unf, hue + unf)), unf);\n}" + }, "screenshotURL": "data/images/images-now6d6u2gzj77364a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7avdmuC23kYit8KWs/art.json b/art/7avdmuC23kYit8KWs/art.json index beefdb87..b5dadeed 100644 --- a/art/7avdmuC23kYit8KWs/art.json +++ b/art/7avdmuC23kYit8KWs/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\n//\\tClassic Perlin 3D Noise \\n//\\tby Stefan Gustavson\\n//\\nvec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\\n\\nfloat cnoise(vec3 P){\\n vec3 Pi0 = floor(P); // Integer part for indexing\\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\\n Pi0 = mod(Pi0, 289.0);\\n Pi1 = mod(Pi1, 289.0);\\n vec3 Pf0 = fract(P); // Fractional part for interpolation\\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\\n vec4 iz0 = Pi0.zzzz;\\n vec4 iz1 = Pi1.zzzz;\\n\\n vec4 ixy = permute(permute(ix) + iy);\\n vec4 ixy0 = permute(ixy + iz0);\\n vec4 ixy1 = permute(ixy + iz1);\\n\\n vec4 gx0 = ixy0 / 7.0;\\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\\n gx0 = fract(gx0);\\n vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\\n vec4 sz0 = step(gz0, vec4(0.0));\\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\\n\\n vec4 gx1 = ixy1 / 7.0;\\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\\n gx1 = fract(gx1);\\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\\n vec4 sz1 = step(gz1, vec4(0.0));\\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\\n\\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\\n\\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\\n g000 *= norm0.x;\\n g010 *= norm0.y;\\n g100 *= norm0.z;\\n g110 *= norm0.w;\\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\\n g001 *= norm1.x;\\n g011 *= norm1.y;\\n g101 *= norm1.z;\\n g111 *= norm1.w;\\n\\n float n000 = dot(g000, Pf0);\\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\\n float n111 = dot(g111, Pf1);\\n\\n vec3 fade_xyz = fade(Pf0);\\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \\n return 2.2 * n_xyz;\\n}\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount));\\n \\tfloat cols = floor(vertexCount / rows);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\tfloat a = atan(x, y);\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\\n \\tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\\n \\tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n vec4 pos = vec4(ux, vy, 0, 1);\\n \\tvec3 n = vec3(cnoise(pos.xyz*.51));\\n \\t//pos.x += n.x*1.9762*sin(n.x+time);\\n \\t//pos.y += n.y*.62;\\n \\t//pos.z += n.z*.9762;\\n \\t//pos*=rotY(PI*time*.125);\\n \\t//pos*=rotX(PI*time*.0125);\\n\\tgl_Position = pos;\\n \\tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \\n \\t//gl_PointSize *= 20.0 / cols; \\n \\t//gl_PointSize *= resolution.x / 600.; \\n float hue = s;\\n hue = smoothstep(x, y, xOff);\\n float sat = v * xOff;\\n float val = u;\\n \\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(-PI * soff);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n\\n v_color = finalColor;\\n }\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\n//\tClassic Perlin 3D Noise \n//\tby Stefan Gustavson\n//\nvec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\n\nfloat cnoise(vec3 P){\n vec3 Pi0 = floor(P); // Integer part for indexing\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\n Pi0 = mod(Pi0, 289.0);\n Pi1 = mod(Pi1, 289.0);\n vec3 Pf0 = fract(P); // Fractional part for interpolation\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\n vec4 iz0 = Pi0.zzzz;\n vec4 iz1 = Pi1.zzzz;\n\n vec4 ixy = permute(permute(ix) + iy);\n vec4 ixy0 = permute(ixy + iz0);\n vec4 ixy1 = permute(ixy + iz1);\n\n vec4 gx0 = ixy0 / 7.0;\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\n gx0 = fract(gx0);\n vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\n vec4 sz0 = step(gz0, vec4(0.0));\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\n\n vec4 gx1 = ixy1 / 7.0;\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\n gx1 = fract(gx1);\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\n vec4 sz1 = step(gz1, vec4(0.0));\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\n\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\n\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\n g000 *= norm0.x;\n g010 *= norm0.y;\n g100 *= norm0.z;\n g110 *= norm0.w;\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\n g001 *= norm1.x;\n g011 *= norm1.y;\n g101 *= norm1.z;\n g111 *= norm1.w;\n\n float n000 = dot(g000, Pf0);\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\n float n111 = dot(g111, Pf1);\n\n vec3 fade_xyz = fade(Pf0);\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \n return 2.2 * n_xyz;\n}\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount));\n \tfloat cols = floor(vertexCount / rows);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\tfloat a = atan(x, y);\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\n \tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\n \tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n vec4 pos = vec4(ux, vy, 0, 1);\n \tvec3 n = vec3(cnoise(pos.xyz*.51));\n \t//pos.x += n.x*1.9762*sin(n.x+time);\n \t//pos.y += n.y*.62;\n \t//pos.z += n.z*.9762;\n \t//pos*=rotY(PI*time*.125);\n \t//pos*=rotX(PI*time*.0125);\n\tgl_Position = pos;\n \tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \n \t//gl_PointSize *= 20.0 / cols; \n \t//gl_PointSize *= resolution.x / 600.; \n float hue = s;\n hue = smoothstep(x, y, xOff);\n float sat = v * xOff;\n float val = u;\n \n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(-PI * soff);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n\n v_color = finalColor;\n }" + }, "screenshotURL": "data/images/images-r91ci666qv30l3sgz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7awCXKJWafHYpvqX8/art.json b/art/7awCXKJWafHYpvqX8/art.json index a8bd3e5d..c605ec40 100644 --- a/art/7awCXKJWafHYpvqX8/art.json +++ b/art/7awCXKJWafHYpvqX8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":23099,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sicxoo/plan-b-paint-it-blacker-feat-the-rolling-stones\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 3.//KParameter0 0.>>10.\\n#define parameter1 1.//KParameter1 0.>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>1.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.03 * c.y) , 8.0 /(c.x * 4.0, 8.0, .01 * parameter7), .9 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www * 20.);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 7.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 0, 2, 0, 0,\\n 0, c, s, 0,\\n parameter3, -s, c, 2,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1,-0.5, parameter5,\\n 0, 1, 0, 0,\\n s, 0, c, 1,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target + eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 +100.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 5.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 16.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 0.1);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.10, 0.1, pow(s + .12 *parameter2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 1)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 23099, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sicxoo/plan-b-paint-it-blacker-feat-the-rolling-stones", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 3.//KParameter0 0.>>10.\n#define parameter1 1.//KParameter1 0.>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>1.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.03 * c.y) , 8.0 /(c.x * 4.0, 8.0, .01 * parameter7), .9 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www * 20.);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 7.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 0, 2, 0, 0,\n 0, c, s, 0,\n parameter3, -s, c, 2,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1,-0.5, parameter5,\n 0, 1, 0, 0,\n s, 0, c, 1,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target + eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 +100.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 5.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 16.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 0.1);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.10, 0.1, pow(s + .12 *parameter2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 1)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-05jqoyh2sjga1bfz9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7b2mtzWGfut7qG2b4/art.json b/art/7b2mtzWGfut7qG2b4/art.json index 8a7cebac..ed431e30 100644 --- a/art/7b2mtzWGfut7qG2b4/art.json +++ b/art/7b2mtzWGfut7qG2b4/art.json @@ -28,7 +28,19 @@ "name": "cubes", "private": false, "username": "matt", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rotr3(float x, float n) {\\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.0);\\n}\\n\\nvec3 cubePos(float x) {\\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n float near = -1.0;\\n float far = 0.99;\\n float aspectRatio = resolution.y / resolution.x;\\n float cubeIdx = floor(vertexId / 36.0);\\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\\n float faceDiv3 = floor(faceIdx / 3.0);\\n float faceMod3 = mod(faceIdx, 3.0);\\n float quadIdx = mod(vertexId, 6.0);\\n float baseIdx = faceIdx * 6.0;\\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\\n pos -= 0.5;\\n pos *= 0.02;\\n \\n float ct = time + mod(cubeIdx, 20.0);\\n float ct1 = time + floor(cubeIdx / 20.0);\\n float s = sin(ct*0.37), c = cos(ct*0.37);\\n float s1 = sin(ct1), c1 = cos(ct1);\\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n gl_Position = vec4(pos, 1.0) * rot * rot2;\\n\\n gl_Position.x += (mod(cubeIdx, 20.0) - 10.0) * 0.05;\\n gl_Position.y += (floor(cubeIdx / 20.0) - 10.0) * 0.05;\\n \\n gl_Position.y /= aspectRatio;\\n float zDist = gl_Position.z - near;\\n gl_Position.w = zDist;\\n\\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rotr3(float x, float n) {\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.0);\n}\n\nvec3 cubePos(float x) {\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n float near = -1.0;\n float far = 0.99;\n float aspectRatio = resolution.y / resolution.x;\n float cubeIdx = floor(vertexId / 36.0);\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\n float faceDiv3 = floor(faceIdx / 3.0);\n float faceMod3 = mod(faceIdx, 3.0);\n float quadIdx = mod(vertexId, 6.0);\n float baseIdx = faceIdx * 6.0;\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\n pos -= 0.5;\n pos *= 0.02;\n \n float ct = time + mod(cubeIdx, 20.0);\n float ct1 = time + floor(cubeIdx / 20.0);\n float s = sin(ct*0.37), c = cos(ct*0.37);\n float s1 = sin(ct1), c1 = cos(ct1);\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n gl_Position = vec4(pos, 1.0) * rot * rot2;\n\n gl_Position.x += (mod(cubeIdx, 20.0) - 10.0) * 0.05;\n gl_Position.y += (floor(cubeIdx / 20.0) - 10.0) * 0.05;\n \n gl_Position.y /= aspectRatio;\n float zDist = gl_Position.z - near;\n gl_Position.w = zDist;\n\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\n}" + }, "screenshotURL": "data/images/images-saf6p9b07856qu8th-thumbnail.jpg", "views": { "$numberInt": "1491" diff --git a/art/7ckAr5cRAsKG9pHiF/art.json b/art/7ckAr5cRAsKG9pHiF/art.json index 03ac7817..13ef7751 100644 --- a/art/7ckAr5cRAsKG9pHiF/art.json +++ b/art/7ckAr5cRAsKG9pHiF/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "pgan", "avatarUrl": "https://secure.gravatar.com/avatar/b786c3cea88eff238ced38e7ee896997?default=retro&size=200", - "settings": "{\"num\":633,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n // gl_PointSize = 10.0;\\n gl_PointSize = 5.0;\\n\\n float magic = vertexCount;\\n vec2 adjust = vec2(-magic / 2.0, -magic / 2.0);\\n\\n // float x = mod(vertexId, magic);\\n float x = 2.0 * (vertexId / vertexCount) - 1.0;\\n // float y = floor(vertexId / magic);\\n float y = vertexId / vertexCount;\\n \\n float s = sin(mod(vertexId / 100.0, 100.0) - 0.5);\\n \\n // gl_Position = vec4(x, y, 0.0, 1.0);\\n gl_Position = vec4(x, s, 0.0, 1.0);\\n \\n // v_color = vec4(0.0, 1.0, 0.0, 1.0);\\n v_color = vec4(s, mod(time * 0.25, 1.0), 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 633, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n // gl_PointSize = 10.0;\n gl_PointSize = 5.0;\n\n float magic = vertexCount;\n vec2 adjust = vec2(-magic / 2.0, -magic / 2.0);\n\n // float x = mod(vertexId, magic);\n float x = 2.0 * (vertexId / vertexCount) - 1.0;\n // float y = floor(vertexId / magic);\n float y = vertexId / vertexCount;\n \n float s = sin(mod(vertexId / 100.0, 100.0) - 0.5);\n \n // gl_Position = vec4(x, y, 0.0, 1.0);\n gl_Position = vec4(x, s, 0.0, 1.0);\n \n // v_color = vec4(0.0, 1.0, 0.0, 1.0);\n v_color = vec4(s, mod(time * 0.25, 1.0), 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-ggymf4qqxf7ro310l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7e3M2Sgrztb9vDD7v/art.json b/art/7e3M2Sgrztb9vDD7v/art.json index 063f83a9..e1399baf 100644 --- a/art/7e3M2Sgrztb9vDD7v/art.json +++ b/art/7e3M2Sgrztb9vDD7v/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":150,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.26666666666666666,0.3176470588235294,0.16470588235294117,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Colors\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.0;//sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x)*0.005;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.0;\\t//sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = sin(time*0.5+x*y)*0.5+0.5;\\t// Hue(Color difference)\\t\\n float sat = 0.7;\\t\\t\\t\\t\\t\\t\\t// Saturation(Colorfulness)\\t\\n float val = 1.0;\\t\\t\\t\\t\\t\\t\\t// Lightness(Brightness)\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n\\n}\"}", + "settings": { + "num": 150, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.26666666666666666, + 0.3176470588235294, + 0.16470588235294117, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Colors\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.0;//sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x)*0.005;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.0;\t//sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = sin(time*0.5+x*y)*0.5+0.5;\t// Hue(Color difference)\t\n float sat = 0.7;\t\t\t\t\t\t\t// Saturation(Colorfulness)\t\n float val = 1.0;\t\t\t\t\t\t\t// Lightness(Brightness)\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n\n}" + }, "screenshotURL": "data/images/images-pmg6z0ubtfbg0x5hf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7eMqSiQ49pzgf7ftE/art.json b/art/7eMqSiQ49pzgf7ftE/art.json index c9ae2985..8bde5081 100644 --- a/art/7eMqSiQ49pzgf7ftE/art.json +++ b/art/7eMqSiQ49pzgf7ftE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=40000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>30.\\n#define parameter1 1.1//KParameter1 0.>>1.\\n#define parameter2 0.1//KParameter2 0.>>1.\\n#define parameter3 0.5//KParameter3 0.>>0.5\\n#define parameter4 0.//KParameter4 0.>>1.\\n#define parameter5 0.//KParameter5 0.>>1.\\n#define parameter6 0.//KParameter6 0.>>1.\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 1,-s, 1,\\n 0, 1, 1, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 0); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 0, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 1, 1, 1,\\n 1, 1, 1, 1,\\n 1, 1, 1, 1,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 0, 0, 0, 0,\\n 0, 0, 0, 0,\\n 0, 0, 0, 0,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 1, 1, 1,\\n 2, s[1], 1, 1,\\n 2, 2, s[2], 1,\\n 2, 2, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 1, 0, 0,\\n 0, s, 0, 2,\\n 0, 0, s, \\n 2,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n //snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = 0.8;//mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount/2. / NUM_POINTS_PER_DIVISION);\\n float fVertexId = mod(vertexId,vertexCount/2.);\\n float circleId = floor(fVertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(fVertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = parameter3;\\n float start = 0.0;\\n float end = start + parameter2;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \\n mat *= rotZ((parameter0 + uvfl.y * PI) * time * parameter1);\\n \\n /*\\n if(vertexId>vertexCount/2.)\\n pos.x += 0.5;\\n */\\n if(vertexId>vertexCount/2.)\\n pos.x += (0.5-pos.x);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n \\n \\n v_color = vec4(parameter4,parameter5, parameter6, 1.);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=40000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>30.\n#define parameter1 1.1//KParameter1 0.>>1.\n#define parameter2 0.1//KParameter2 0.>>1.\n#define parameter3 0.5//KParameter3 0.>>0.5\n#define parameter4 0.//KParameter4 0.>>1.\n#define parameter5 0.//KParameter5 0.>>1.\n#define parameter6 0.//KParameter6 0.>>1.\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 1,-s, 1,\n 0, 1, 1, 0,\n s, 0, c, 0,\n 0, 0, 0, 0); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 0, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 1, 1, 1,\n 1, 1, 1, 1,\n 1, 1, 1, 1,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 0, 0, 0, 0,\n 0, 0, 0, 0,\n 0, 0, 0, 0,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 1, 1, 1,\n 2, s[1], 1, 1,\n 2, 2, s[2], 1,\n 2, 2, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 1, 0, 0,\n 0, s, 0, 2,\n 0, 0, s, \n 2,\n 0, 0, 0, 2);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n //snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = 0.8;//mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount/2. / NUM_POINTS_PER_DIVISION);\n float fVertexId = mod(vertexId,vertexCount/2.);\n float circleId = floor(fVertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(fVertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = parameter3;\n float start = 0.0;\n float end = start + parameter2;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \n mat *= rotZ((parameter0 + uvfl.y * PI) * time * parameter1);\n \n /*\n if(vertexId>vertexCount/2.)\n pos.x += 0.5;\n */\n if(vertexId>vertexCount/2.)\n pos.x += (0.5-pos.x);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n \n \n v_color = vec4(parameter4,parameter5, parameter6, 1.);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-vwnaoos5ms2b3p01u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7egbq6CBdGtm5h3dk/art.json b/art/7egbq6CBdGtm5h3dk/art.json index b7a000f3..1e642694 100644 --- a/art/7egbq6CBdGtm5h3dk/art.json +++ b/art/7egbq6CBdGtm5h3dk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//functions for the shader\\n//----------------------------------------------------------------\\n// Koleidoscope by ackleyrc: https://www.shadertoy.com/view/llXcRl \\n//----------------------------------------------------------------\\n\\nconst float NUM_SIDES = 7.0; // set your favorite mirror factor here\\n\\nconst float PI = 3.14159265359;\\n\\nconst float KA = PI / NUM_SIDES;\\n\\n//----------------------------------------------------------------\\n// transformation to koleidoscopic coordinates\\n//----------------------------------------------------------------\\nvoid koleidoscope(inout vec2 uv)\\n{\\n // get the angle in radians of the current coords relative to origin (i.e. center of screen)\\n float angle = atan (uv.y, uv.x);\\n // repeat image over evenly divided rotations around the center\\n angle = mod (angle, 2.0 * KA);\\n // reflect the image within each subdivision to create a tilelable appearance\\n angle = abs (angle - KA);\\n // rotate image over time\\n angle += 0.1*time;\\n // get the distance of the coords from the uv origin (i.e. center of the screen)\\n float d = length(uv); \\n // map the calculated angle to the uv coordinate system at the given distance\\n uv = d * vec2(cos(angle), sin(angle));\\n}\\n//----------------------------------------------------------------\\n// equal to koleidoscope, but more compact \\n//----------------------------------------------------------------\\nvoid smallKoleidoscope(inout vec2 uv)\\n{\\n float angle = abs (mod (atan (uv.y, uv.x), 2.0 * KA) - KA) + 0.1*time;\\n uv = length(uv) * vec2(cos(angle), sin(angle));\\n}\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n//\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(ux,vy);//fragcoord.xy/resolution.xy;\\n \\n //vec2 uv = 12.0*(2.0 * gl_FragCoord.xy / resolution.xy - 1.0);\\n uv.x *= resolution.x / resolution.y;\\n //uv.x += 0.4*sin(0.2*time);\\n\\t\\n koleidoscope(uv);\\n\\n // Fractal Colors by Robert Schütze (trirop): http://glslsandbox.com/e#29611\\n //vec3 p = vec3 (uv, mouse.x);\\n \\n snd = snd*.2 - 1.;\\n vec3 p = vec3 (uv, snd);\\n for (int i = 0; i < 44; i++)\\n p.xzy = vec3(1.3,0.999,0.678)*(abs((abs(p)/dot(p,p)-vec3(1.0,1.02,snd*0.4))));\\n \\n //gl_FragColor = vec4(p,1.0);\\n v_color = vec4(p,1.0);\\n\\t\\n //camera\\n float r = 0.7;\\n float tm = 1.5*time/10.;\\n float tm2 = 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 2.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n if(depth>=0.5)\\n {\\n depthFactor = depth/10.;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, depth*0.1, 1.);\\n \\n gl_Position = mat*finalPos;\\n}\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//functions for the shader\n//----------------------------------------------------------------\n// Koleidoscope by ackleyrc: https://www.shadertoy.com/view/llXcRl \n//----------------------------------------------------------------\n\nconst float NUM_SIDES = 7.0; // set your favorite mirror factor here\n\nconst float PI = 3.14159265359;\n\nconst float KA = PI / NUM_SIDES;\n\n//----------------------------------------------------------------\n// transformation to koleidoscopic coordinates\n//----------------------------------------------------------------\nvoid koleidoscope(inout vec2 uv)\n{\n // get the angle in radians of the current coords relative to origin (i.e. center of screen)\n float angle = atan (uv.y, uv.x);\n // repeat image over evenly divided rotations around the center\n angle = mod (angle, 2.0 * KA);\n // reflect the image within each subdivision to create a tilelable appearance\n angle = abs (angle - KA);\n // rotate image over time\n angle += 0.1*time;\n // get the distance of the coords from the uv origin (i.e. center of the screen)\n float d = length(uv); \n // map the calculated angle to the uv coordinate system at the given distance\n uv = d * vec2(cos(angle), sin(angle));\n}\n//----------------------------------------------------------------\n// equal to koleidoscope, but more compact \n//----------------------------------------------------------------\nvoid smallKoleidoscope(inout vec2 uv)\n{\n float angle = abs (mod (atan (uv.y, uv.x), 2.0 * KA) - KA) + 0.1*time;\n uv = length(uv) * vec2(cos(angle), sin(angle));\n}\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n//\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(ux,vy);//fragcoord.xy/resolution.xy;\n \n //vec2 uv = 12.0*(2.0 * gl_FragCoord.xy / resolution.xy - 1.0);\n uv.x *= resolution.x / resolution.y;\n //uv.x += 0.4*sin(0.2*time);\n\t\n koleidoscope(uv);\n\n // Fractal Colors by Robert Schütze (trirop): http://glslsandbox.com/e#29611\n //vec3 p = vec3 (uv, mouse.x);\n \n snd = snd*.2 - 1.;\n vec3 p = vec3 (uv, snd);\n for (int i = 0; i < 44; i++)\n p.xzy = vec3(1.3,0.999,0.678)*(abs((abs(p)/dot(p,p)-vec3(1.0,1.02,snd*0.4))));\n \n //gl_FragColor = vec4(p,1.0);\n v_color = vec4(p,1.0);\n\t\n //camera\n float r = 0.7;\n float tm = 1.5*time/10.;\n float tm2 = 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 2.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n if(depth>=0.5)\n {\n depthFactor = depth/10.;\n }\n \n vec4 finalPos = vec4(ux, vy, depth*0.1, 1.);\n \n gl_Position = mat*finalPos;\n}\n\n\n" + }, "screenshotURL": "data/images/images-n6urtexu42vw8b6nj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7fkuNErcdiCoyDFPM/art.json b/art/7fkuNErcdiCoyDFPM/art.json index 0dd3d90f..9df2e137 100644 --- a/art/7fkuNErcdiCoyDFPM/art.json +++ b/art/7fkuNErcdiCoyDFPM/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. + soundTexCoords0.x) + 0.1;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale(1. / 11.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. + soundTexCoords0.x) + 0.1;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale(1. / 11.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-qkrbt9r1bq0zqvtzb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7gmHgFYYTRjd3BKEZ/art.json b/art/7gmHgFYYTRjd3BKEZ/art.json index 33062667..9e893675 100644 --- a/art/7gmHgFYYTRjd3BKEZ/art.json +++ b/art/7gmHgFYYTRjd3BKEZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "viktor", "avatarUrl": "https://lh4.googleusercontent.com/-agHxneCMuTE/AAAAAAAAAAI/AAAAAAAAINA/hVIl1amY4To/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nstruct Ori {\\n vec3 a_;\\n vec3 b_;\\n};\\n\\n\\n\\nvoid main() {\\n \\tint idx = int(vertexId);\\n \\tvec3 rpos;\\n \\tvec3 rcol = vec3(1,0,0);\\n \\n Ori src = Ori(vec3(0,0,1), vec3(0,1,0));\\n \\tOri dst = Ori(normalize(vec3(0,0,1)), normalize(vec3(1,1,0)));\\n \\n \\n if(idx == 1) { rpos = src.a_; }\\n if(idx == 3) { rpos = src.b_; }\\n \\n if(idx >= 4) rcol = vec3(0,1,0);\\n if(idx == 5) { rpos = dst.a_; }\\n if(idx == 7) { rpos = dst.b_; }\\n \\n \\tgl_Position = vec4(rpos, 1);\\n \\tv_color = vec4(rcol, 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nstruct Ori {\n vec3 a_;\n vec3 b_;\n};\n\n\n\nvoid main() {\n \tint idx = int(vertexId);\n \tvec3 rpos;\n \tvec3 rcol = vec3(1,0,0);\n \n Ori src = Ori(vec3(0,0,1), vec3(0,1,0));\n \tOri dst = Ori(normalize(vec3(0,0,1)), normalize(vec3(1,1,0)));\n \n \n if(idx == 1) { rpos = src.a_; }\n if(idx == 3) { rpos = src.b_; }\n \n if(idx >= 4) rcol = vec3(0,1,0);\n if(idx == 5) { rpos = dst.a_; }\n if(idx == 7) { rpos = dst.b_; }\n \n \tgl_Position = vec4(rpos, 1);\n \tv_color = vec4(rcol, 1);\n}" + }, "screenshotURL": "data/images/images-d5g0qe24xlbk9lw1k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7gpAmyAsHMewhZvsN/art.json b/art/7gpAmyAsHMewhZvsN/art.json index e1ab7ee1..ca935757 100644 --- a/art/7gpAmyAsHMewhZvsN/art.json +++ b/art/7gpAmyAsHMewhZvsN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 0.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 0.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-9v1wilhjotfsafjck-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7iyrHWLQT836AWhNg/art.json b/art/7iyrHWLQT836AWhNg/art.json index 45eb5aaf..04552c94 100644 --- a/art/7iyrHWLQT836AWhNg/art.json +++ b/art/7iyrHWLQT836AWhNg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = (fract(pos+.5)-.5);\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId*.13;\\n\\n vec3 pos = posf(t,i);\\t\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += 1.7;\\n \\n pos.xy *= (3.-pos.z)*.7;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.1;\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = (fract(pos+.5)-.5);\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId*.13;\n\n vec3 pos = posf(t,i);\t\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += 1.7;\n \n pos.xy *= (3.-pos.z)*.7;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.1;\n}" + }, "screenshotURL": "data/images/images-inakop1j9bieq21k5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7kchjNSNHczMuXxdj/art.json b/art/7kchjNSNHczMuXxdj/art.json index f6cc1b4c..efdb8866 100644 --- a/art/7kchjNSNHczMuXxdj/art.json +++ b/art/7kchjNSNHczMuXxdj/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ xxx \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(0.6-mouse.y, 1.2-mouse.x, 0.) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.1, \\t0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 0.70, 0.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 1.0-mouse.x, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -1.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.8 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.7, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, -1, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.5 + quant(over, 3.) * 0.7;\\n float sat = step(0.75,s2);\\n float val = 1.;\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -0.);\\n float ca = 0.0001;\\n \\n // get sick!\\n ca =ca * 81.0* time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), tan(ca),2. );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 16384, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ xxx \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(0.6-mouse.y, 1.2-mouse.x, 0.) * 10.0; \n\nvec3 gSkyTop = vec3( 1.1, \t0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 0.70, 0.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 1.0-mouse.x, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -1.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.8 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.7, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, -1, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.5 + quant(over, 3.) * 0.7;\n float sat = step(0.75,s2);\n float val = 1.;\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -0.);\n float ca = 0.0001;\n \n // get sick!\n ca =ca * 81.0* time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), tan(ca),2. );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-h5xf560dk9v7aauaq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7mLMCX66sxy38mtQZ/art.json b/art/7mLMCX66sxy38mtQZ/art.json index c3cca64c..fc0e6d70 100644 --- a/art/7mLMCX66sxy38mtQZ/art.json +++ b/art/7mLMCX66sxy38mtQZ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "duhochoi", "avatarUrl": "https://secure.gravatar.com/avatar/3a2a5d4b2ecd66c69241bc6b3e1e34e6?default=retro&size=200", - "settings": "{\"num\":1887,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Duho Choi\\n// Assignment : Exercise - Vertexshaderart : Making a Grid\\n// Course : CS250\\n// Term : Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4 (1, 0, 0, 1);\\n \\n}\\n\"}", + "settings": { + "num": 1887, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Duho Choi\n// Assignment : Exercise - Vertexshaderart : Making a Grid\n// Course : CS250\n// Term : Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4 (1, 0, 0, 1);\n \n}\n" + }, "screenshotURL": "data/images/images-abo1h6yb231gxbf1h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7myySepW36ywzREow/art.json b/art/7myySepW36ywzREow/art.json index 68a74651..d80bd872 100644 --- a/art/7myySepW36ywzREow/art.json +++ b/art/7myySepW36ywzREow/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\n\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\n\n}" + }, "screenshotURL": "data/images/images-h32085hdcxi6iwcef-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7n2c7BGhSAcg3jA94/art.json b/art/7n2c7BGhSAcg3jA94/art.json index c2f7ec32..7a4f844c 100644 --- a/art/7n2c7BGhSAcg3jA94/art.json +++ b/art/7n2c7BGhSAcg3jA94/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "yongsoo", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJxAP2U5XZ3Yo0Ih8_cGbAfFM0t2hQaAn-l4uUpW=s96-c", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.0;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = time;\\n float sat = 1.;\\n float val = v;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.0;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = time;\n float sat = 1.;\n float val = v;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-3x4kh5u4dip9h08y6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7nEqpyeYSLJxH3iCZ/art.json b/art/7nEqpyeYSLJxH3iCZ/art.json index 1f8f71f1..653fdaab 100644 --- a/art/7nEqpyeYSLJxH3iCZ/art.json +++ b/art/7nEqpyeYSLJxH3iCZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":72863,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.141594\\n//#define FIT_VERTICAL\\n\\nvec3 computeVert(float angle, float H) {\\n float STEP = time*0.7;\\n float R = (cos(H * 2.6 + STEP * 1.5 + sin(STEP * 4.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\\n R *= sin((H + 4.0) * 0.375);\\n \\n float Q = cos(STEP * 0.54 + H * 0.7);\\n float dX = cos(H * 1.4) * Q * 1.5;\\n float dY = sin(H * 0.75) * Q * 0.4;\\n float dZ = sin(H * 0.5) * Q * 0.5;\\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\\n}\\n\\nvec3 computeNorm(float angle, float H) {\\n float dA = 0.01;\\n float dH = 0.01;\\n vec3 A = computeVert(angle, H);\\n vec3 B = computeVert(angle + dA, H);\\n vec3 C = computeVert(angle, H + dH);\\n return normalize(-cross((B-A)/dA,(C-A)/dH));\\n}\\n\\nvoid main() {\\n int NUM_ROT = 64;\\n float dH = 0.05;\\n \\n float STEP = time*0.7;\\n \\n int base = int(vertexId) / 6;\\n int level = int(base) / NUM_ROT;\\n int idx = int(mod(vertexId,6.0));\\n vec3 xyz = vec3(0,0,0);\\n vec3 N = normalize(vec3(1,0,0));\\n \\n float dA = 2.0 * PI / float(NUM_ROT);\\n\\n float H = float(level) * dH - 4.0;\\n float angle = float(base) * dA;\\n \\n if (idx == 0) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n if (idx == 1) {\\n \\txyz = computeVert(angle + dA, H);\\n \\tN = computeNorm(angle + dA, H);\\n }\\n if (idx == 2) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n \\n if (idx == 3) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n if (idx == 4) {\\n \\txyz = computeVert(angle, H + dH);\\n \\tN = computeNorm(angle, H + dH);\\n }\\n if (idx == 5) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n \\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n \\n float Cs = cos(STEP);\\n float Si = sin(STEP);\\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\\n xyz *= 0.3;\\n //xyz *= rot;\\n //N *= rot;\\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\\n \\n vec3 light = normalize(vec3(1,1,-1));\\n vec3 V = vec3(0,0,1);\\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\\n vec3 A_col = vec3(1,1,1) * N * rot2;\\n vec3 D_col = vec3(1,1,1) * N;\\n vec3 S_col = vec3(1,1,1);\\n vec3 LUM = A * A_col + D * D_col +S * S_col;\\n v_color = vec4(LUM, 1);\\n}\"}", + "settings": { + "num": 72863, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.141594\n//#define FIT_VERTICAL\n\nvec3 computeVert(float angle, float H) {\n float STEP = time*0.7;\n float R = (cos(H * 2.6 + STEP * 1.5 + sin(STEP * 4.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\n R *= sin((H + 4.0) * 0.375);\n \n float Q = cos(STEP * 0.54 + H * 0.7);\n float dX = cos(H * 1.4) * Q * 1.5;\n float dY = sin(H * 0.75) * Q * 0.4;\n float dZ = sin(H * 0.5) * Q * 0.5;\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\n}\n\nvec3 computeNorm(float angle, float H) {\n float dA = 0.01;\n float dH = 0.01;\n vec3 A = computeVert(angle, H);\n vec3 B = computeVert(angle + dA, H);\n vec3 C = computeVert(angle, H + dH);\n return normalize(-cross((B-A)/dA,(C-A)/dH));\n}\n\nvoid main() {\n int NUM_ROT = 64;\n float dH = 0.05;\n \n float STEP = time*0.7;\n \n int base = int(vertexId) / 6;\n int level = int(base) / NUM_ROT;\n int idx = int(mod(vertexId,6.0));\n vec3 xyz = vec3(0,0,0);\n vec3 N = normalize(vec3(1,0,0));\n \n float dA = 2.0 * PI / float(NUM_ROT);\n\n float H = float(level) * dH - 4.0;\n float angle = float(base) * dA;\n \n if (idx == 0) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n if (idx == 1) {\n \txyz = computeVert(angle + dA, H);\n \tN = computeNorm(angle + dA, H);\n }\n if (idx == 2) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n \n if (idx == 3) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n if (idx == 4) {\n \txyz = computeVert(angle, H + dH);\n \tN = computeNorm(angle, H + dH);\n }\n if (idx == 5) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n \n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n \n float Cs = cos(STEP);\n float Si = sin(STEP);\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\n xyz *= 0.3;\n //xyz *= rot;\n //N *= rot;\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\n \n vec3 light = normalize(vec3(1,1,-1));\n vec3 V = vec3(0,0,1);\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\n vec3 A_col = vec3(1,1,1) * N * rot2;\n vec3 D_col = vec3(1,1,1) * N;\n vec3 S_col = vec3(1,1,1);\n vec3 LUM = A * A_col + D * D_col +S * S_col;\n v_color = vec4(LUM, 1);\n}" + }, "screenshotURL": "data/images/images-bbqcgc7alazjab09v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7pH6w9DYZF7bjFqRC/art.json b/art/7pH6w9DYZF7bjFqRC/art.json index d402c6e9..e18a0d3f 100644 --- a/art/7pH6w9DYZF7bjFqRC/art.json +++ b/art/7pH6w9DYZF7bjFqRC/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":55675,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/wearebigbeat/flo-rida-my-house-jameston-thieves-arkn-remix?in=austin24heck/sets/trap-remixes-of-popular-songs\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n \\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\n\\nvoid main() {\\n \\n //\\n vec4 soundVal = texture2D(sound, vec2(0.));\\n //\\n \\n // more or less random movement\\n float t = time*.20 ;\\n float i = vertexId+sin(vertexId)*100.;\\n \\n vec3 pos = posf(t,i);\\n soundVal = texture2D(sound, vec2(pos));\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t+soundVal.a*10.,i,ofs+soundVal.a*10.,.999);\\n \\n //ofs*=soundVal.a * 2.;\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 55675, + "mode": "POINTS", + "sound": "https://soundcloud.com/wearebigbeat/flo-rida-my-house-jameston-thieves-arkn-remix?in=austin24heck/sets/trap-remixes-of-popular-songs", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n \n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\n\nvoid main() {\n \n //\n vec4 soundVal = texture2D(sound, vec2(0.));\n //\n \n // more or less random movement\n float t = time*.20 ;\n float i = vertexId+sin(vertexId)*100.;\n \n vec3 pos = posf(t,i);\n soundVal = texture2D(sound, vec2(pos));\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t+soundVal.a*10.,i,ofs+soundVal.a*10.,.999);\n \n //ofs*=soundVal.a * 2.;\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-mizs7z5eofdo91xr8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7qXRty5XaAiets5ZL/art.json b/art/7qXRty5XaAiets5ZL/art.json index 51e12e67..3c5ac1ed 100644 --- a/art/7qXRty5XaAiets5ZL/art.json +++ b/art/7qXRty5XaAiets5ZL/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":42665,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/geotheorymusic/work-it-girl\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5019607843137255,0.5019607843137255,0.7529411764705882,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 2.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 1,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = mix(inner, 1., level);\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.5;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += 10.;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n mat *= scale(vec3(0.25, 0.25, -20.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(.65, 1., step(0.75, snd));\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n v_color.a = 1.0 - uvf.y;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 42665, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/geotheorymusic/work-it-girl", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5019607843137255, + 0.5019607843137255, + 0.7529411764705882, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 2.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 1,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = mix(inner, 1., level);\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.5;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += 10.;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n mat *= scale(vec3(0.25, 0.25, -20.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = mix(.65, 1., step(0.75, snd));\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n v_color.a = 1.0 - uvf.y;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-oia5cupcs3b0x38ns-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7qtbHrwZAwuFQLxhC/art.json b/art/7qtbHrwZAwuFQLxhC/art.json index 1ad7e5cc..8392f957 100644 --- a/art/7qtbHrwZAwuFQLxhC/art.json +++ b/art/7qtbHrwZAwuFQLxhC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":24579,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.403921568627451,0.403921568627451,0.403921568627451,1],\"shader\":\"\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 1.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region Scene_Vertex_Collection \\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n\\n struct SurfaceInfo \\n {\\n vec3 vPos;\\n vec3 vNormal;\\n float fGloss;\\n };\\n struct SphereInfo\\n {\\t \\n vec3 vOrigin;\\n float fRadius ; \\n \\n float fSlices ; \\n float fSegments ; \\n }; \\n \\n struct Material \\n {\\n vec4 diffuseAlebdo;\\n vec3 FresenlR0 ;\\n float Roughness ;\\n mat4 MatTransform ; \\n }; \\n struct Light\\n {\\n\\n vec3 vStrength ; \\n float FalloffStart ; \\n vec3 vDirection ; \\n float FalloffEnd ; \\n vec3 vPosition ; \\n float SpotPower ; \\n };\\n#pragma endregion \\n \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, DirLight,\\n sv) ; \\n vertexIndex -= floorVertexCount ; \\n #pragma endregion \\n \\n #pragma region Sphere\\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo,\\n DirLight, \\n camPos,\\n sv);\\n m *= uniformScale(1.5);\\n m *= trans(vec3(0. , 4. , 0. )) ; \\n }\\n vertexIndex -= fSphereVertexCount ; \\n #pragma endregion \\n#pragma endregion \\n \\n \\n#pragma region PostEffect\\n // PE_Vignette(sv) ;\\n#pragma endregion \\n \\n#pragma region ApplySetting\\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n#pragma endregion \\n}\"}", + "settings": { + "num": 24579, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 1.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t \n vec3 vOrigin;\n float fRadius ; \n \n float fSlices ; \n float fSegments ; \n }; \n \n struct Material \n {\n vec4 diffuseAlebdo;\n vec3 FresenlR0 ;\n float Roughness ;\n mat4 MatTransform ; \n }; \n struct Light\n {\n\n vec3 vStrength ; \n float FalloffStart ; \n vec3 vDirection ; \n float FalloffEnd ; \n vec3 vPosition ; \n float SpotPower ; \n };\n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, DirLight,\n sv) ; \n vertexIndex -= floorVertexCount ; \n #pragma endregion \n \n #pragma region Sphere\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo,\n DirLight, \n camPos,\n sv);\n m *= uniformScale(1.5);\n m *= trans(vec3(0. , 4. , 0. )) ; \n }\n vertexIndex -= fSphereVertexCount ; \n #pragma endregion \n#pragma endregion \n \n \n#pragma region PostEffect\n // PE_Vignette(sv) ;\n#pragma endregion \n \n#pragma region ApplySetting\n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n#pragma endregion \n}" + }, "screenshotURL": "data/images/images-5mu2m6nmgsugez4ov-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7rEgrhT8EQfJ7PDrk/art.json b/art/7rEgrhT8EQfJ7PDrk/art.json index 9fc2fa7e..a5d4d127 100644 --- a/art/7rEgrhT8EQfJ7PDrk/art.json +++ b/art/7rEgrhT8EQfJ7PDrk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// hash functions\\n\\n\\n\\nvoid main() {\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// hash functions\n\n\n\nvoid main() {\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-nftqfsshw18rawtkl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7ryyxQd8kXyENxC8q/art.json b/art/7ryyxQd8kXyENxC8q/art.json index 7d260ee2..f75387ed 100644 --- a/art/7ryyxQd8kXyENxC8q/art.json +++ b/art/7ryyxQd8kXyENxC8q/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":72773,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(2.4, 1.2, 0.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\\n\\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * 3.;\\nfloat gExposure = 0.2;\\nfloat gCubeColorRandom = .5;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 3.6;\\nfloat gFloorHeight = -43.0*mouse.x;\\nfloat g_cameraFar = 105.0 *mouse.y;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 30.0, 80.3, -50.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 1.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 5.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = (v2- mouse.y);\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3, mouse.x;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\\n}\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 1.25 + .6;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 1, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 2.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.25);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\\n float z = vP * down * 11.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 10.);\\n mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \\n pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 0.78;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\\n float ca = 0.01;\\n \\n // get sick!\\n ca = time * 0.7;\\n \\tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 72773, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(2.4, 1.2, 0.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\n\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * 3.;\nfloat gExposure = 0.2;\nfloat gCubeColorRandom = .5;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 3.6;\nfloat gFloorHeight = -43.0*mouse.x;\nfloat g_cameraFar = 105.0 *mouse.y;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 30.0, 80.3, -50.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 1.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 5.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = (v2- mouse.y);\n }\n \telse\n {\n\t \tvWorldPos = v3, mouse.x;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\n}\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 1.25 + .6;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 1, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 2.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.25);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\n float z = vP * down * 11.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 10.);\n mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \n pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 0.78;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\n \tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\n float ca = 0.01;\n \n // get sick!\n ca = time * 0.7;\n \tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-hiag1mhf1szods2ef-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7t6i2kotFzww4sABc/art.json b/art/7t6i2kotFzww4sABc/art.json index 72952a7f..8c9bd249 100644 --- a/art/7t6i2kotFzww4sABc/art.json +++ b/art/7t6i2kotFzww4sABc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":16332,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Circles from Triangles own variation\\n//course name : CS250\\n//term : Spring 2023\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1); \\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 s){\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1); \\n}\\nmat4 uniformScale(float s){\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n float ux = floor(id /6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\n \\n\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 3.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //cos(time* 0.2 + x *0.3); \\n float yoff = tan(time * 0.5 + y * 0.2) * 0.5;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs( u - 0.5 ) * 2.;\\n float sv = abs( v - 0.5 ) * 2.;\\n float au = abs(atan(su,sv) ) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix( 1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.01 * sc);\\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u* 0.1 * snd * 0.2 + time * 0.1 + sliceId * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.; mix(0., 1., pump);\\n float val = mix(.3, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n sat += oddSlice * pump * ux;\\n val += oddSlice * pump * vy;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 16332, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Circles from Triangles own variation\n//course name : CS250\n//term : Spring 2023\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1); \n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 s){\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1); \n}\nmat4 uniformScale(float s){\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1); \n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n float ux = floor(id /6.) + mod(id, 2.);\n \n float vy = mod(floor(id/2.) + floor(id / 3.), 2.);\n \n\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 3.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //cos(time* 0.2 + x *0.3); \n float yoff = tan(time * 0.5 + y * 0.2) * 0.5;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs( u - 0.5 ) * 2.;\n float sv = abs( v - 0.5 ) * 2.;\n float au = abs(atan(su,sv) ) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix( 1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.01 * sc);\n \n gl_Position = mat * pos;\n\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u* 0.1 * snd * 0.2 + time * 0.1 + sliceId * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.; mix(0., 1., pump);\n float val = mix(.3, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n sat += oddSlice * pump * ux;\n val += oddSlice * pump * vy;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-8a8yhv4zvmkrj6mdd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7tj2CshkciWxyNNjh/art.json b/art/7tj2CshkciWxyNNjh/art.json index 5b99a777..0623462d 100644 --- a/art/7tj2CshkciWxyNNjh/art.json +++ b/art/7tj2CshkciWxyNNjh/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "abjeni", "avatarUrl": "https://secure.gravatar.com/avatar/91501fff291d7e034ce6fecaebc60854?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.00784313725490196,0.00784313725490196,1],\"shader\":\"#define PI radians(180.)\\n#define SIZE 15.0\\n#define NUM_CUBES (SIZE*SIZE*SIZE)\\n#define NUM_TRIANGLES (NUM_CUBES*18)\\n#define NUM_VERTICES (NUM_TRIANGLES*6)\\n#define STEP 5.0\\n\\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nvec3 camPath(float t){\\n \\n //return vec3(0, 0, t); // Straight path.\\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\\n \\n //float s = sin(t/24.)*cos(t/12.);\\n //return vec3(s*12., 0., t);\\n \\n float a = sin(t * 0.11);\\n float b = cos(t * 0.14);\\n return vec3(a*4. -b*1.5, b*1.7 + a*1.5, t);\\n \\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nfloat map(vec3 p){\\n \\n p.xy -= camPath(p.z).xy; // Perturb the object around the camera path.\\n \\n p *= 0.4;\\n \\n\\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\\n \\n \\n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\\n\\n // It's an easy field to create, but not so great to hone in one. The \\\"1.4\\\" fudge factor\\n // is there to get a little extra distance... Obtained by trial and error.\\n return (n - 1.025)*1.33;\\n \\n}\\n\\n\\nvoid main() {\\n \\n float speed = 10.0;\\n \\n vec3 wpos = vec3(0);\\n \\n vec3 pos = camPath(time*speed);\\n \\n vec3 lookat = camPath(time*speed+2.0);\\n vec3 forward = normalize(lookat-pos);\\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\\n vec3 up = cross(forward,left);\\n \\n float id = vertexId;\\n \\n float numcube = floor(id/18.0);\\n float numquad = floor(id/6.0);\\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\\n float nori = mod(numquad,3.0);\\n //quadid = quadid ^ diri;\\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\\n \\n \\n vec3 mask;\\n if (nori < 0.5) {\\n mask = vec3(1,0,0);\\n } else if (nori < 1.5) {\\n mask = vec3(0,1,0);\\n } else {\\n mask = vec3(0,0,1);\\n }\\n \\n float size = floor(pow(vertexCount/18.0,1.0/3.0));\\n \\n vec3 blockpos = vec3(\\n mod(floor(numcube),size),\\n mod(floor(numcube/size),size),\\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\\n \\n bool a = map(blockpos) > 0.0;\\n bool b = map(blockpos+mask) > 0.0;\\n \\n float diri;\\n \\n if (a == b) {\\n gl_Position = vec4(0,0,0,1);\\n return;\\n } else {\\n \\n float diri = 1.0;\\n if (b) {\\n diri = -diri;\\n quad.xy = quad.yx;\\n }\\n \\n vec3 nor = mask*(diri*2.0-1.0);\\n\\n wpos += mask.zxy*quad.x;\\n wpos += mask.yzx*quad.y;\\n\\twpos += mask;\\n wpos += blockpos;\\n\\n wpos -= 0.5;\\n\\n //wpos += vec3(data.xyz);\\n //wpos += float(gl_VertexID/6);\\n //wpos += u_centerPosition;\\n\\n\\n\\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\\n \\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\\n \\n p.x *= resolution.y/resolution.x;\\n\\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\\n\\n\\n float hue = (id * 1.001);\\n v_color = vec4(nor*0.5+0.5, 1);\\n }\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.00784313725490196, + 0.00784313725490196, + 1 + ], + "shader": "#define PI radians(180.)\n#define SIZE 15.0\n#define NUM_CUBES (SIZE*SIZE*SIZE)\n#define NUM_TRIANGLES (NUM_CUBES*18)\n#define NUM_VERTICES (NUM_TRIANGLES*6)\n#define STEP 5.0\n\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n//https://www.shadertoy.com/view/4ttGDH\nvec3 camPath(float t){\n \n //return vec3(0, 0, t); // Straight path.\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\n \n //float s = sin(t/24.)*cos(t/12.);\n //return vec3(s*12., 0., t);\n \n float a = sin(t * 0.11);\n float b = cos(t * 0.14);\n return vec3(a*4. -b*1.5, b*1.7 + a*1.5, t);\n \n}\n\n//https://www.shadertoy.com/view/4ttGDH\nfloat map(vec3 p){\n \n p.xy -= camPath(p.z).xy; // Perturb the object around the camera path.\n \n p *= 0.4;\n \n\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\n \n \n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\n\n // It's an easy field to create, but not so great to hone in one. The \"1.4\" fudge factor\n // is there to get a little extra distance... Obtained by trial and error.\n return (n - 1.025)*1.33;\n \n}\n\n\nvoid main() {\n \n float speed = 10.0;\n \n vec3 wpos = vec3(0);\n \n vec3 pos = camPath(time*speed);\n \n vec3 lookat = camPath(time*speed+2.0);\n vec3 forward = normalize(lookat-pos);\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\n vec3 up = cross(forward,left);\n \n float id = vertexId;\n \n float numcube = floor(id/18.0);\n float numquad = floor(id/6.0);\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\n float nori = mod(numquad,3.0);\n //quadid = quadid ^ diri;\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\n \n \n vec3 mask;\n if (nori < 0.5) {\n mask = vec3(1,0,0);\n } else if (nori < 1.5) {\n mask = vec3(0,1,0);\n } else {\n mask = vec3(0,0,1);\n }\n \n float size = floor(pow(vertexCount/18.0,1.0/3.0));\n \n vec3 blockpos = vec3(\n mod(floor(numcube),size),\n mod(floor(numcube/size),size),\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\n \n bool a = map(blockpos) > 0.0;\n bool b = map(blockpos+mask) > 0.0;\n \n float diri;\n \n if (a == b) {\n gl_Position = vec4(0,0,0,1);\n return;\n } else {\n \n float diri = 1.0;\n if (b) {\n diri = -diri;\n quad.xy = quad.yx;\n }\n \n vec3 nor = mask*(diri*2.0-1.0);\n\n wpos += mask.zxy*quad.x;\n wpos += mask.yzx*quad.y;\n\twpos += mask;\n wpos += blockpos;\n\n wpos -= 0.5;\n\n //wpos += vec3(data.xyz);\n //wpos += float(gl_VertexID/6);\n //wpos += u_centerPosition;\n\n\n\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\n \n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\n \n p.x *= resolution.y/resolution.x;\n\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\n\n\n float hue = (id * 1.001);\n v_color = vec4(nor*0.5+0.5, 1);\n }\n}" + }, "screenshotURL": "data/images/images-omb48439vokffgmec-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7ts7RJwsC7qRdn96W/art.json b/art/7ts7RJwsC7qRdn96W/art.json index b3a4e4f3..1b62b373 100644 --- a/art/7ts7RJwsC7qRdn96W/art.json +++ b/art/7ts7RJwsC7qRdn96W/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "der", "avatarUrl": "https://secure.gravatar.com/avatar/3edd222097c4b36118a8d5f5ab65ddb6?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float across = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, across) / (across - 1.0) * 2.0 - 1.0;\\n float y = floor(vertexId / across) / (across - 1.0) * 2.0 - 1.0;\\n \\n float dist = distance(vec2(x, y), vec2(0.0, 0.0));\\n \\n if(dist > 1.0) {\\n return;\\n }\\n \\n float aspect = resolution.y / resolution.x;\\n \\n gl_Position = vec4(x * aspect, y, 0.0, 1.0);\\n \\n float snd = texture2D(sound, vec2(0.0, dist)).a;\\n \\n gl_PointSize = 25.0 * pow(snd, 4.0);\\n \\n v_color = vec4(0.0, mix(0.3, 0.9, sin(time / 5.0) * 0.5 + 0.5), 1.0, 1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float across = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, across) / (across - 1.0) * 2.0 - 1.0;\n float y = floor(vertexId / across) / (across - 1.0) * 2.0 - 1.0;\n \n float dist = distance(vec2(x, y), vec2(0.0, 0.0));\n \n if(dist > 1.0) {\n return;\n }\n \n float aspect = resolution.y / resolution.x;\n \n gl_Position = vec4(x * aspect, y, 0.0, 1.0);\n \n float snd = texture2D(sound, vec2(0.0, dist)).a;\n \n gl_PointSize = 25.0 * pow(snd, 4.0);\n \n v_color = vec4(0.0, mix(0.3, 0.9, sin(time / 5.0) * 0.5 + 0.5), 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-vqn34i97jhlq6wclq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7vbkgbBXwtnj4LbT2/art.json b/art/7vbkgbBXwtnj4LbT2/art.json index bd5e58ec..bb9d69b6 100644 --- a/art/7vbkgbBXwtnj4LbT2/art.json +++ b/art/7vbkgbBXwtnj4LbT2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":60,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 3.0\\n#define Z_NEAR 1.0\\n#define Z_FAR -1.0\\n\\n// Data from: https://people.sc.fsu.edu/~jburkardt/data/obj/icosahedron.obj\\n// There's a bug with indexing\\nvec3 getVertex(int index) {\\n if ( index == 0 ) return vec3( 0.0, -0.525731, 0.850651 );\\n if ( index == 1 ) return vec3( 0.850651, 0.0, 0.525731 );\\n if ( index == 2 ) return vec3( 0.850651, 0.0, -0.525731 );\\n if ( index == 3 ) return vec3( -0.850651, 0.0, -0.525731 );\\n if ( index == 4 ) return vec3( -0.850651, 0.0, 0.525731 );\\n if ( index == 5 ) return vec3( -0.525731, 0.850651, 0.0 );\\n if ( index == 6 ) return vec3( 0.525731, 0.850651, 0.0 );\\n if ( index == 7 ) return vec3( 0.525731, -0.850651, 0.0 );\\n if ( index == 8 ) return vec3( -0.525731, -0.850651, 0.0 );\\n if ( index == 9 ) return vec3( 0.0, -0.525731, -0.850651 );\\n if ( index == 10 ) return vec3( 0.0, 0.525731, -0.850651 );\\n if ( index == 11 ) return vec3( 0.0, 0.525731, 0.850651 );\\n}\\n\\nivec3 getTriangle(int index) {\\n if ( index == 0 ) return ivec3( 1, 2, 6 );\\n if ( index == 1 ) return ivec3( 1, 7, 2 );\\n if ( index == 2 ) return ivec3( 3, 4, 5 );\\n if ( index == 3 ) return ivec3( 4, 3, 8 );\\n if ( index == 4 ) return ivec3( 6, 5, 11 );\\n if ( index == 5 ) return ivec3( 5, 6, 10 );\\n if ( index == 6 ) return ivec3( 9, 10, 2 );\\n if ( index == 7 ) return ivec3( 10, 9, 3 );\\n if ( index == 8 ) return ivec3( 7, 8, 9 );\\n if ( index == 9 ) return ivec3( 8, 7, 0 );\\n if ( index == 10 ) return ivec3( 11, 0, 1 );\\n if ( index == 11 ) return ivec3( 0, 11, 4 );\\n if ( index == 12 ) return ivec3( 6, 2, 10 );\\n if ( index == 13 ) return ivec3( 1, 6, 11 );\\n if ( index == 14 ) return ivec3( 3, 5, 10 );\\n if ( index == 15 ) return ivec3( 5, 4, 11 );\\n if ( index == 16 ) return ivec3( 2, 7, 9 );\\n if ( index == 17 ) return ivec3( 7, 1, 0 );\\n if ( index == 18 ) return ivec3( 3, 9, 8 );\\n if ( index == 19 ) return ivec3( 4, 8, 0 );\\n}\\n\\nint getVertexIndex(ivec3 triangle, int index) {\\n if ( index == 0 ) return triangle[0];\\n if ( index == 1 ) return triangle[1];\\n if ( index == 2 ) return triangle[2];\\n}\\n\\nvoid main() {\\n int triIndex = int(vertexId / 3.0);\\n int vertIndex = int(mod(vertexId, 3.0));\\n ivec3 triangle = getTriangle(triIndex);\\n vec3 vertex = getVertex(getVertexIndex(triangle, vertIndex));\\n\\n float c = cos(time), s = sin(time);\\n vertex.xz *= mat2(c, s, -s, c);\\n vertex.yz *= mat2(c, s, -s, c);\\n\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\\n vec3 normal = normalize(vertex);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n float diffuse = max(0.0, dot(normal, lightDir));\\n v_color = vec4(vec3(diffuse), 1.0);\\n}\"}", + "settings": { + "num": 60, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 3.0\n#define Z_NEAR 1.0\n#define Z_FAR -1.0\n\n// Data from: https://people.sc.fsu.edu/~jburkardt/data/obj/icosahedron.obj\n// There's a bug with indexing\nvec3 getVertex(int index) {\n if ( index == 0 ) return vec3( 0.0, -0.525731, 0.850651 );\n if ( index == 1 ) return vec3( 0.850651, 0.0, 0.525731 );\n if ( index == 2 ) return vec3( 0.850651, 0.0, -0.525731 );\n if ( index == 3 ) return vec3( -0.850651, 0.0, -0.525731 );\n if ( index == 4 ) return vec3( -0.850651, 0.0, 0.525731 );\n if ( index == 5 ) return vec3( -0.525731, 0.850651, 0.0 );\n if ( index == 6 ) return vec3( 0.525731, 0.850651, 0.0 );\n if ( index == 7 ) return vec3( 0.525731, -0.850651, 0.0 );\n if ( index == 8 ) return vec3( -0.525731, -0.850651, 0.0 );\n if ( index == 9 ) return vec3( 0.0, -0.525731, -0.850651 );\n if ( index == 10 ) return vec3( 0.0, 0.525731, -0.850651 );\n if ( index == 11 ) return vec3( 0.0, 0.525731, 0.850651 );\n}\n\nivec3 getTriangle(int index) {\n if ( index == 0 ) return ivec3( 1, 2, 6 );\n if ( index == 1 ) return ivec3( 1, 7, 2 );\n if ( index == 2 ) return ivec3( 3, 4, 5 );\n if ( index == 3 ) return ivec3( 4, 3, 8 );\n if ( index == 4 ) return ivec3( 6, 5, 11 );\n if ( index == 5 ) return ivec3( 5, 6, 10 );\n if ( index == 6 ) return ivec3( 9, 10, 2 );\n if ( index == 7 ) return ivec3( 10, 9, 3 );\n if ( index == 8 ) return ivec3( 7, 8, 9 );\n if ( index == 9 ) return ivec3( 8, 7, 0 );\n if ( index == 10 ) return ivec3( 11, 0, 1 );\n if ( index == 11 ) return ivec3( 0, 11, 4 );\n if ( index == 12 ) return ivec3( 6, 2, 10 );\n if ( index == 13 ) return ivec3( 1, 6, 11 );\n if ( index == 14 ) return ivec3( 3, 5, 10 );\n if ( index == 15 ) return ivec3( 5, 4, 11 );\n if ( index == 16 ) return ivec3( 2, 7, 9 );\n if ( index == 17 ) return ivec3( 7, 1, 0 );\n if ( index == 18 ) return ivec3( 3, 9, 8 );\n if ( index == 19 ) return ivec3( 4, 8, 0 );\n}\n\nint getVertexIndex(ivec3 triangle, int index) {\n if ( index == 0 ) return triangle[0];\n if ( index == 1 ) return triangle[1];\n if ( index == 2 ) return triangle[2];\n}\n\nvoid main() {\n int triIndex = int(vertexId / 3.0);\n int vertIndex = int(mod(vertexId, 3.0));\n ivec3 triangle = getTriangle(triIndex);\n vec3 vertex = getVertex(getVertexIndex(triangle, vertIndex));\n\n float c = cos(time), s = sin(time);\n vertex.xz *= mat2(c, s, -s, c);\n vertex.yz *= mat2(c, s, -s, c);\n\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\n vec3 normal = normalize(vertex);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n float diffuse = max(0.0, dot(normal, lightDir));\n v_color = vec4(vec3(diffuse), 1.0);\n}" + }, "screenshotURL": "data/images/images-slu79te05jep9jpm9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7vsaPEdRhNyw6hBKg/art.json b/art/7vsaPEdRhNyw6hBKg/art.json index ebf5e3cf..0dacd956 100644 --- a/art/7vsaPEdRhNyw6hBKg/art.json +++ b/art/7vsaPEdRhNyw6hBKg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6007,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/dan-hekate-1/i-am-the-captain-of-my-soul\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 1, 0,\\n 0, f, -1, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1.56,\\n 0, 0, zNear * zFar * rangeInv * -1., 1);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, -1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = -2.0 /texture2D(sound,vec2(mix(0.001, 1., exp(atan(offset.x, offset.y) / PI )), length(offset) * .01)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner =.9+snd;\\t\\n float start = -.1;\\n float end = 3.*mouse.x;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 2., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .25));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.55, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.*snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(0.6,mouse), pump);\\n v_color.rgb *= v_color.a*0.3;\\n}\\n\\n\"}", + "settings": { + "num": 6007, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/dan-hekate-1/i-am-the-captain-of-my-soul", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 1, 0,\n 0, f, -1, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1.56,\n 0, 0, zNear * zFar * rangeInv * -1., 1);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, -1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = -2.0 /texture2D(sound,vec2(mix(0.001, 1., exp(atan(offset.x, offset.y) / PI )), length(offset) * .01)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner =.9+snd;\t\n float start = -.1;\n float end = 3.*mouse.x;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 2., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .25));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.55, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.*snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(0.6,mouse), pump);\n v_color.rgb *= v_color.a*0.3;\n}\n\n" + }, "screenshotURL": "data/images/images-0u7stxmmpvixhbckf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7wRhp7wraGfXgSkus/art.json b/art/7wRhp7wraGfXgSkus/art.json index b59f5e60..76023011 100644 --- a/art/7wRhp7wraGfXgSkus/art.json +++ b/art/7wRhp7wraGfXgSkus/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "abhijit", "avatarUrl": "https://lh5.googleusercontent.com/-i3qvQNrpbfU/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd3L2Osg3Ys5HSXRn6QArB46T_mBA/photo.jpg", - "settings": "{\"num\":3581,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7529411764705882,0.7529411764705882,0.7529411764705882,1],\"shader\":\"#define PI radians(180.0)\\nvec2 getCirclePoint(float id, float numcircle) {\\n\\n// float id = vertexId;\\n \\n float ux = floor(id/6.)+mod(id,2.);\\n \\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux / numcircle * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius =vy +1.0;\\n \\n float x =c * radius;\\n float y = s * radius;\\n \\n// vec2 xy = vec2(x ,y); \\n // gl_Position = vec4(xy*0.1, 0, 1); \\n // v_color = vec4(1, 0, 0, 1); \\n \\n return vec2(x, y);\\n \\n}\\n\\nvoid main() {\\n \\n float numcir = 20.;\\n \\n vec2 circleXY = getCirclePoint(vertexId, numcir);\\n \\n float numPointsPerCircle = numcir * 6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor (vertexCount / numPointsPerCircle);\\n \\n \\n float vcount = floor(sqrt(numCircles ));\\n float across = floor(numCircles /vcount) ;\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.3) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vx = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy =circleXY * 0.1 + vec2(ux ,vx) * 1.3;\\n \\n //float ux = u * 2.0 - 1.0 + xoff;\\n // float vx = v * 2.0 - 1.0 + yoff;\\n \\n// vec2 xy = vec2(ux ,vx) * 0.7;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02 ) * 1.0;\\n \\n gl_PointSize = 1.0 + soff;\\n gl_PointSize += 20. / across;\\n gl_PointSize += resolution.x /600.;\\n \\n v_color = vec4(ux, vx, 0, 1); \\n}\"}", + "settings": { + "num": 3581, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7529411764705882, + 0.7529411764705882, + 0.7529411764705882, + 1 + ], + "shader": "#define PI radians(180.0)\nvec2 getCirclePoint(float id, float numcircle) {\n\n// float id = vertexId;\n \n float ux = floor(id/6.)+mod(id,2.);\n \n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux / numcircle * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius =vy +1.0;\n \n float x =c * radius;\n float y = s * radius;\n \n// vec2 xy = vec2(x ,y); \n // gl_Position = vec4(xy*0.1, 0, 1); \n // v_color = vec4(1, 0, 0, 1); \n \n return vec2(x, y);\n \n}\n\nvoid main() {\n \n float numcir = 20.;\n \n vec2 circleXY = getCirclePoint(vertexId, numcir);\n \n float numPointsPerCircle = numcir * 6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor (vertexCount / numPointsPerCircle);\n \n \n float vcount = floor(sqrt(numCircles ));\n float across = floor(numCircles /vcount) ;\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.3) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vx = v * 2.0 - 1.0 + yoff;\n \n vec2 xy =circleXY * 0.1 + vec2(ux ,vx) * 1.3;\n \n //float ux = u * 2.0 - 1.0 + xoff;\n // float vx = v * 2.0 - 1.0 + yoff;\n \n// vec2 xy = vec2(ux ,vx) * 0.7;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02 ) * 1.0;\n \n gl_PointSize = 1.0 + soff;\n gl_PointSize += 20. / across;\n gl_PointSize += resolution.x /600.;\n \n v_color = vec4(ux, vx, 0, 1); \n}" + }, "screenshotURL": "data/images/images-gesomhsa9gxj22xuv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/7wqyFQDCq6cmDzs4H/art.json b/art/7wqyFQDCq6cmDzs4H/art.json index 65089207..7c1c990e 100644 --- a/art/7wqyFQDCq6cmDzs4H/art.json +++ b/art/7wqyFQDCq6cmDzs4H/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "pentan", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n\\nfloat hash(float x) {\\n return fract(sin(x) * 43758.5453123);\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x;\\n rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nmat4 lookat(vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float t = vertexId + time;\\n vec4 p = vec4(0.0, 0.0, 0.0, 1.0);\\n p.xyz = fract(sin(vec3(t, 0.0, t+0.25)) * 12345.6789);\\n \\n float snd = texture2D(sound, p.xz * vec2(0.75, 1.0)).a;\\n \\n p.y = pow(snd, 2.0);\\n p.xz = p.xz * 2.0 - 1.0;\\n \\n float rt = time * 0.25;\\n mat4 m = lookat(vec3(cos(rt) * 2.5, 1.0, sin(rt) * 1.5), vec3(0.0, 0.25, 0.0), vec3(0.0, 1.0, 0.0));\\n p = m * p;\\n \\n vec4 pp = perspective(p.xyz, 60.0, 0.2, 4.0);\\n \\n gl_Position = pp;\\n gl_PointSize = 10.0 / length(p.xyz);\\n \\n v_color = vec4(hsv2rgb(vec3(snd, 1.0, 1.0)), 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n\nfloat hash(float x) {\n return fract(sin(x) * 43758.5453123);\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x;\n rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nmat4 lookat(vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float t = vertexId + time;\n vec4 p = vec4(0.0, 0.0, 0.0, 1.0);\n p.xyz = fract(sin(vec3(t, 0.0, t+0.25)) * 12345.6789);\n \n float snd = texture2D(sound, p.xz * vec2(0.75, 1.0)).a;\n \n p.y = pow(snd, 2.0);\n p.xz = p.xz * 2.0 - 1.0;\n \n float rt = time * 0.25;\n mat4 m = lookat(vec3(cos(rt) * 2.5, 1.0, sin(rt) * 1.5), vec3(0.0, 0.25, 0.0), vec3(0.0, 1.0, 0.0));\n p = m * p;\n \n vec4 pp = perspective(p.xyz, 60.0, 0.2, 4.0);\n \n gl_Position = pp;\n gl_PointSize = 10.0 / length(p.xyz);\n \n v_color = vec4(hsv2rgb(vec3(snd, 1.0, 1.0)), 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-z75y7zsy3kcmdtw68-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7wueifQeGTg9ubjrp/art.json b/art/7wueifQeGTg9ubjrp/art.json index 89003314..a45d1156 100644 --- a/art/7wueifQeGTg9ubjrp/art.json +++ b/art/7wueifQeGTg9ubjrp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/official-rezz/spun?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"/*\\n\\nWait for the music to pump \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 0.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 14.;\\n float across = 14.;\\n float back = 14.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float cz = floor(cubeId / across / back);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (back - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n float cc = cw * 2. - 1.;\\n \\n float s1 = texture2D(sound, vec2(abs(0.1), length(vec3(ca, cb, cc)) * .1)).a;\\n float s2 = texture2D(sound, vec2(abs(0.2), length(vec3(ca, cb, cc)) * .1)).a;\\n float s = max(s1, s2) * 1.3;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= uniformScale(mix(0., 1.9, pow(s1, 1.)));\\n mat *= trans(vec3(ca, cc, cb) * down * 0.65);\\n mat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 0.;//abs(ca * cc) * 2.;\\n float sat = mix(0.9, 1., step(0.8, s));\\n float val = mix(1., 1., step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/official-rezz/spun?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "/*\n\nWait for the music to pump \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 0.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 14.;\n float across = 14.;\n float back = 14.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float cz = floor(cubeId / across / back);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (back - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n float cc = cw * 2. - 1.;\n \n float s1 = texture2D(sound, vec2(abs(0.1), length(vec3(ca, cb, cc)) * .1)).a;\n float s2 = texture2D(sound, vec2(abs(0.2), length(vec3(ca, cb, cc)) * .1)).a;\n float s = max(s1, s2) * 1.3;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= uniformScale(mix(0., 1.9, pow(s1, 1.)));\n mat *= trans(vec3(ca, cc, cb) * down * 0.65);\n mat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 0.;//abs(ca * cc) * 2.;\n float sat = mix(0.9, 1., step(0.8, s));\n float val = mix(1., 1., step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-fvhma6k85fm0y3xqy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/7xeGPqZaZSLDvKWHt/art.json b/art/7xeGPqZaZSLDvKWHt/art.json index 647d00fe..f30cf16b 100644 --- a/art/7xeGPqZaZSLDvKWHt/art.json +++ b/art/7xeGPqZaZSLDvKWHt/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// --------------------------------------------------------\\n// Spectrum colour palette\\n// IQ https://www.shadertoy.com/view/ll2GD3\\n// --------------------------------------------------------\\n\\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\\n return a + b*cos( 6.28318*(c*t+d) );\\n}\\n\\nvec3 spectrum(float n) {\\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\\n}\\n\\n\\n// --------------------------------------------------------\\n// HG_SDF https://www.shadertoy.com/view/Xs3GRB\\n// --------------------------------------------------------\\n\\nfloat vmax(vec3 v) {\\n\\treturn max(max(v.x, v.y), v.z);\\n}\\n\\n// Box: correct distance to corners\\nfloat fBox(vec3 p, vec3 b) {\\n\\tvec3 d = abs(p) - b;\\n\\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\\n}\\n\\nvoid pR(inout vec2 p, float a) {\\n\\tp = cos(a)*p + sin(a)*vec2(p.y, -p.x);\\n}\\n\\n\\n// --------------------------------------------------------\\n// Geometry\\n// --------------------------------------------------------\\n\\nfloat map(vec3 p) {\\n \\tvec3 offset = vec3(\\n \\tcos(time),\\n \\tsin(time),\\n \\tcos(time * 2.)\\n );\\n \\tp -= offset * .25; \\n \\tpR(p.xy, time);\\n \\tpR(p.zx, time * .5); \\t\\n\\n \\treturn -fBox(p, vec3(.7));\\n}\\n\\n\\n// --------------------------------------------------------\\n// Raymarch\\n// --------------------------------------------------------\\n\\nconst float MAX_TRACE_DISTANCE = 10.;\\nconst float INTERSECTION_PRECISION = .001;\\nconst int NUM_OF_TRACE_STEPS = 10;\\n\\n\\nfloat trace(vec3 rayDir) {\\n\\n \\tfloat currentDist = INTERSECTION_PRECISION * 2.;\\n \\tfloat rayLen = 0.;\\n \\n\\tfor(int i=0; i< NUM_OF_TRACE_STEPS ; i++ ){\\n\\t\\tif (currentDist < INTERSECTION_PRECISION || rayLen > MAX_TRACE_DISTANCE) {\\n break;\\n }\\n \\tcurrentDist = map(rayDir * rayLen);\\n \\trayLen += currentDist;\\n\\t}\\n \\n \\treturn rayLen;\\n}\\n\\n\\n// --------------------------------------------------------\\n// Seed points, camera, and display\\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\\n// --------------------------------------------------------\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 100.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n \\n pos *= trace(pos);\\n \\n float tm = time * .5;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(\\n cos(tm) * rd,\\n cos(tm) * rd,\\n sin(tm) * rd\\n );\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n vec4 pos4 = mat * vec4(pos, 1);\\n \\n gl_Position = pos4;\\n gl_PointSize = 4.;\\n\\n vec3 col = vec3(spectrum(vertexId / vertexCount));\\n col *= smoothstep(rd*2., rd, pos4.z);\\n v_color = vec4(col, 1.);\\n \\n \\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// --------------------------------------------------------\n// Spectrum colour palette\n// IQ https://www.shadertoy.com/view/ll2GD3\n// --------------------------------------------------------\n\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\n return a + b*cos( 6.28318*(c*t+d) );\n}\n\nvec3 spectrum(float n) {\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\n}\n\n\n// --------------------------------------------------------\n// HG_SDF https://www.shadertoy.com/view/Xs3GRB\n// --------------------------------------------------------\n\nfloat vmax(vec3 v) {\n\treturn max(max(v.x, v.y), v.z);\n}\n\n// Box: correct distance to corners\nfloat fBox(vec3 p, vec3 b) {\n\tvec3 d = abs(p) - b;\n\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\n}\n\nvoid pR(inout vec2 p, float a) {\n\tp = cos(a)*p + sin(a)*vec2(p.y, -p.x);\n}\n\n\n// --------------------------------------------------------\n// Geometry\n// --------------------------------------------------------\n\nfloat map(vec3 p) {\n \tvec3 offset = vec3(\n \tcos(time),\n \tsin(time),\n \tcos(time * 2.)\n );\n \tp -= offset * .25; \n \tpR(p.xy, time);\n \tpR(p.zx, time * .5); \t\n\n \treturn -fBox(p, vec3(.7));\n}\n\n\n// --------------------------------------------------------\n// Raymarch\n// --------------------------------------------------------\n\nconst float MAX_TRACE_DISTANCE = 10.;\nconst float INTERSECTION_PRECISION = .001;\nconst int NUM_OF_TRACE_STEPS = 10;\n\n\nfloat trace(vec3 rayDir) {\n\n \tfloat currentDist = INTERSECTION_PRECISION * 2.;\n \tfloat rayLen = 0.;\n \n\tfor(int i=0; i< NUM_OF_TRACE_STEPS ; i++ ){\n\t\tif (currentDist < INTERSECTION_PRECISION || rayLen > MAX_TRACE_DISTANCE) {\n break;\n }\n \tcurrentDist = map(rayDir * rayLen);\n \trayLen += currentDist;\n\t}\n \n \treturn rayLen;\n}\n\n\n// --------------------------------------------------------\n// Seed points, camera, and display\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\n// --------------------------------------------------------\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 100.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n \n pos *= trace(pos);\n \n float tm = time * .5;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(\n cos(tm) * rd,\n cos(tm) * rd,\n sin(tm) * rd\n );\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n vec4 pos4 = mat * vec4(pos, 1);\n \n gl_Position = pos4;\n gl_PointSize = 4.;\n\n vec3 col = vec3(spectrum(vertexId / vertexCount));\n col *= smoothstep(rd*2., rd, pos4.z);\n v_color = vec4(col, 1.);\n \n \n}" + }, "screenshotURL": "data/images/images-cki246ynuklbc9fxo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/83bhi2jnJmLwj89jd/art.json b/art/83bhi2jnJmLwj89jd/art.json index fd3d1e5c..d4cbea05 100644 --- a/art/83bhi2jnJmLwj89jd/art.json +++ b/art/83bhi2jnJmLwj89jd/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "unnamed", "username": "-anon-", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 8.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.9));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 200.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 8.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.9));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 200.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "daCGZux4fcKPwC2RQ", "views": { "$numberInt": "102" diff --git a/art/84TzMFEGdJQDyrLAw/art.json b/art/84TzMFEGdJQDyrLAw/art.json index d3f8f21d..a49df80b 100644 --- a/art/84TzMFEGdJQDyrLAw/art.json +++ b/art/84TzMFEGdJQDyrLAw/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thesoftmoon/exister?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12549019607843137,0.11372549019607843,0.11372549019607843,1],\"shader\":\"void main() {\\n \\n float x = vertexId / 100.;\\n float y = vertexId / 100.;\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 3.0;\\n v_color = vec4(0., 1., 0., 1.);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/thesoftmoon/exister?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12549019607843137, + 0.11372549019607843, + 0.11372549019607843, + 1 + ], + "shader": "void main() {\n \n float x = vertexId / 100.;\n float y = vertexId / 100.;\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 3.0;\n v_color = vec4(0., 1., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-u440m7onbbu59kd7v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/84bqgyYH7r222NZui/art.json b/art/84bqgyYH7r222NZui/art.json index cb9b43ed..98f5e409 100644 --- a/art/84bqgyYH7r222NZui/art.json +++ b/art/84bqgyYH7r222NZui/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6829,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/rrhizomee/chunky-from-the-front-ft-lotic-and-sami-baha\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-0.5, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu *2. + gv *2.06 * time * .13 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv * .13),\\n crv(cv * .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(45.0), resolution.x / resolution.y, 0.21, 666.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0.0 - gv);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * (tm * 2.), tm - gv * up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 4.5);\\n mat *= p4;\\n mat *= uniformScale(mix(0.1, 0.301, pow(s + gv + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 6829, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/rrhizomee/chunky-from-the-front-ft-lotic-and-sami-baha", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-0.5, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu *2. + gv *2.06 * time * .13 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv * .13),\n crv(cv * .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(45.0), resolution.x / resolution.y, 0.21, 666.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0.0 - gv);\n \n mat4 p4 = lookAt(p2 * 2., p3 * (tm * 2.), tm - gv * up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 4.5);\n mat *= p4;\n mat *= uniformScale(mix(0.1, 0.301, pow(s + gv + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-2446ff2syxt0szhly-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/85e3bGEKFA4Ac7pHh/art.json b/art/85e3bGEKFA4Ac7pHh/art.json index 367f19fe..deea8d87 100644 --- a/art/85e3bGEKFA4Ac7pHh/art.json +++ b/art/85e3bGEKFA4Ac7pHh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = 0.;//time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 55., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(vec3(lt), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = 0.;//time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 55., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(vec3(lt), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-i9xq2a4msxc62rurp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/85epXhdc6bNGzc5t4/art.json b/art/85epXhdc6bNGzc5t4/art.json index 21eabce5..0f221e23 100644 --- a/art/85epXhdc6bNGzc5t4/art.json +++ b/art/85epXhdc6bNGzc5t4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":78553,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5725490196078431,0.5725490196078431,0.5725490196078431,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hash3(vec3 v) {\\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x;\\n rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\\n * vec4(p, 1.0);\\n return pp.xyz;\\n}\\n\\nvec3 lissajous(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\\n#define kCubeVertexCount 36.0\\nvec3 cubeVertex(float vid, out vec4 ni) {\\n float faceId = floor(vid / 6.0);\\n float vtxId = mod(vid, 6.0);\\n vec2 fp;\\n vec3 p;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n // front\\n p = vec3(fp.x, fp.y, 1.0);\\n ni = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n // back\\n p = vec3(-fp.x, fp.y, -1.0);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n // top\\n p = vec3(fp.x, 1.0, -fp.y);\\n ni = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n // bottom\\n p = vec3(fp.x, -1.0, fp.y);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n // right\\n p = vec3(-1.0, fp.y, -fp.x);\\n ni = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n // left\\n p = vec3(1.0, fp.y, fp.x);\\n ni = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return p;\\n}\\n\\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(n, lit)) * (1.0 - amb) + amb;\\n \\n vec3 h = normalize(normalize(eye - p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.0, pow(dot(n, h), spec.x));\\n }\\n \\n rgb = diffuse * dfscol + specular * spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kCubeVertexCount);\\n float shapeId = floor(vertexId / kCubeVertexCount);\\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\\n float lineId = mod(shapeId, 3.0);\\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 0.0) {\\n lineFactor = vec3(0.1, 6.7, 2.3);\\n color = vec3(1.0, 0.0, 0.0);\\n }\\n else if(lineId == 1.0) {\\n lineFactor = vec3(.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(0.0, 0.0, 1.0);\\n }\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 cubeni;\\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.04;\\n \\n vec3 cubeHash = hash3(vec3(log(shapeId)));\\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\\n \\n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\\n \\n cubep = lissajous(lineFactor, (t + time * 0.1) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\\n \\n /*\\n if(cubeni.w == 0.0) {\\n color = vec3(1.0, 0.0, 0.0);\\n }\\n else if(cubeni.w == 1.0) {\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else if(cubeni.w == 2.0) {\\n color = vec3(0.0, 0.0, 1.0);\\n }\\n else if(cubeni.w == 3.0) {\\n color = vec3(1.0, 1.0, 0.0);\\n }\\n else if(cubeni.w == 4.0) {\\n color = vec3(1.0, 0.0, 1.0);\\n }\\n else {\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n */\\n \\n //vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.0), -mouse.x * 2.0), mouse.y);\\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.05), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 78553, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5725490196078431, + 0.5725490196078431, + 0.5725490196078431, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hash3(vec3 v) {\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x;\n rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\n * vec4(p, 1.0);\n return pp.xyz;\n}\n\nvec3 lissajous(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\n#define kCubeVertexCount 36.0\nvec3 cubeVertex(float vid, out vec4 ni) {\n float faceId = floor(vid / 6.0);\n float vtxId = mod(vid, 6.0);\n vec2 fp;\n vec3 p;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n // front\n p = vec3(fp.x, fp.y, 1.0);\n ni = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n // back\n p = vec3(-fp.x, fp.y, -1.0);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n // top\n p = vec3(fp.x, 1.0, -fp.y);\n ni = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n // bottom\n p = vec3(fp.x, -1.0, fp.y);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 4.0) {\n // right\n p = vec3(-1.0, fp.y, -fp.x);\n ni = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n // left\n p = vec3(1.0, fp.y, fp.x);\n ni = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return p;\n}\n\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(n, lit)) * (1.0 - amb) + amb;\n \n vec3 h = normalize(normalize(eye - p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.0, pow(dot(n, h), spec.x));\n }\n \n rgb = diffuse * dfscol + specular * spec.y;\n \n return rgb;\n}\n\nvoid main() {\n float shapeCount = floor(vertexCount / kCubeVertexCount);\n float shapeId = floor(vertexId / kCubeVertexCount);\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\n float lineId = mod(shapeId, 3.0);\n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 0.0) {\n lineFactor = vec3(0.1, 6.7, 2.3);\n color = vec3(1.0, 0.0, 0.0);\n }\n else if(lineId == 1.0) {\n lineFactor = vec3(.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(0.0, 0.0, 1.0);\n }\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 cubeni;\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.04;\n \n vec3 cubeHash = hash3(vec3(log(shapeId)));\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\n \n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\n \n cubep = lissajous(lineFactor, (t + time * 0.1) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\n \n /*\n if(cubeni.w == 0.0) {\n color = vec3(1.0, 0.0, 0.0);\n }\n else if(cubeni.w == 1.0) {\n color = vec3(0.0, 1.0, 0.0);\n }\n else if(cubeni.w == 2.0) {\n color = vec3(0.0, 0.0, 1.0);\n }\n else if(cubeni.w == 3.0) {\n color = vec3(1.0, 1.0, 0.0);\n }\n else if(cubeni.w == 4.0) {\n color = vec3(1.0, 0.0, 1.0);\n }\n else {\n color = vec3(0.0, 1.0, 1.0);\n }\n */\n \n //vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.0), -mouse.x * 2.0), mouse.y);\n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.05), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-gx46ouixvfo8q5lzs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/868s25nyWdZFHjukZ/art.json b/art/868s25nyWdZFHjukZ/art.json index 14afb3c0..2195456b 100644 --- a/art/868s25nyWdZFHjukZ/art.json +++ b/art/868s25nyWdZFHjukZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n// hyunjin Kim\\n// cs250 exercise - Audio Reactive\\n// spring 2022\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float oh = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., oh);\\n float val = mix(.1, pow(snd + 0.2, 5.0), oh);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n// hyunjin Kim\n// cs250 exercise - Audio Reactive\n// spring 2022\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float oh = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., oh);\n float val = mix(.1, pow(snd + 0.2, 5.0), oh);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-bq7wgk8kja3kei3vi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/87jiR2yJj3v4JHQGX/art.json b/art/87jiR2yJj3v4JHQGX/art.json index fa897cd5..f54025e8 100644 --- a/art/87jiR2yJj3v4JHQGX/art.json +++ b/art/87jiR2yJj3v4JHQGX/art.json @@ -27,7 +27,19 @@ "name": "residualfillattack", "private": false, "username": "spotline", - "settings": "{\"num\":3000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(4.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\\n float x = (u*60.0)-1.0;\\n float y = ((v+vold)*0.5);//*osc;\\n gl_PointSize = 10.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\\n v_color = vec4((lum-lumOld*1.5)*0.6,(lum-lumOld)*0.6,(lum-lumOld*0.2)*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(4.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\n float x = (u*60.0)-1.0;\n float y = ((v+vold)*0.5);//*osc;\n gl_PointSize = 10.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\n v_color = vec4((lum-lumOld*1.5)*0.6,(lum-lumOld)*0.6,(lum-lumOld*0.2)*1.0,v);\n}" + }, "screenshotURL": "data/images/images-c1cot7l4qyo0zrntr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/889PvtXA2o7P9ps9Y/art.json b/art/889PvtXA2o7P9ps9Y/art.json index 25cdad8d..204a5dad 100644 --- a/art/889PvtXA2o7P9ps9Y/art.json +++ b/art/889PvtXA2o7P9ps9Y/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":8660,\"mode\":\"TRIANGLES\",\"sound\":\"feedback\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 5.//KParameter -5.>>10.\\n#define P3 1.1//KParameter 0.1>>3.\\n#define P6 2.//KParameter 0.1>>10.\\n#define P5 -1.//KParameter -1.>>1.\\n#define P4 0.//KParameter 0.0>>1.\\n\\n//KVerticesNumber=10000\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 33.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 1.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 6. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 4.*P5);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy - vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P4) + mouse.y * r;\\n float y = sin(qu * PI * .3) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos,sin(1.5+P5));\\n gl_PointSize = 1. ;\\n\\n float hue = quadId *12.001;\\n float sat = P4*2.52;\\n float val = vertexCount/(vertexId \\n +5. * P6)*0.6;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 8660, + "mode": "TRIANGLES", + "sound": "feedback", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 5.//KParameter -5.>>10.\n#define P3 1.1//KParameter 0.1>>3.\n#define P6 2.//KParameter 0.1>>10.\n#define P5 -1.//KParameter -1.>>1.\n#define P4 0.//KParameter 0.0>>1.\n\n//KVerticesNumber=10000\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 33.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 1.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 6. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 4.*P5);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy - vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P4) + mouse.y * r;\n float y = sin(qu * PI * .3) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos,sin(1.5+P5));\n gl_PointSize = 1. ;\n\n float hue = quadId *12.001;\n float sat = P4*2.52;\n float val = vertexCount/(vertexId \n +5. * P6)*0.6;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-epqdq9qkvrct3ztcw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/88BoabSogh4PJQ5XD/art.json b/art/88BoabSogh4PJQ5XD/art.json index 73eff6fa..d20524a5 100644 --- a/art/88BoabSogh4PJQ5XD/art.json +++ b/art/88BoabSogh4PJQ5XD/art.json @@ -35,7 +35,19 @@ "unlisted": false, "username": "daichi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GjMaxlfFVjXtrXdoYmcGbecHkO6WD328dyQCe8i", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.2) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 10.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.2) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 10.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-7gndbh76rwesmhg00-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/88XwsAMToJSkDiwaB/art.json b/art/88XwsAMToJSkDiwaB/art.json index 6d07bfd1..85eaf35c 100644 --- a/art/88XwsAMToJSkDiwaB/art.json +++ b/art/88XwsAMToJSkDiwaB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10042,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat anim(float t) {\\n float st = sin(t);\\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvec3 SampleCubePos(float idx, float num) {\\n float side = floor(pow(num, 1.0/3.0)+0.5);\\n vec3 res;\\n res.x = mod(idx, side);\\n res.y = floor( mod(idx, side*side)/side );\\n res.z = floor( mod(idx, side*side*side)/side/side );\\n res -= vec3(side * 0.5);\\n res *= 1.5/side;\\n return res;\\n}\\n\\n\\n\\nvoid main() {\\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = sin(time*4.+20.*samplePos.x*samplePos.y*samplePos.z)*4.+4.; \\n\\n\\n v_color = vec4(samplePos.y*samplePos.y + 0.5,samplePos.x*samplePos.x + 0.5,samplePos.z*samplePos.z + 0.5,1);\\n}\"}", + "settings": { + "num": 10042, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat anim(float t) {\n float st = sin(t);\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvec3 SampleCubePos(float idx, float num) {\n float side = floor(pow(num, 1.0/3.0)+0.5);\n vec3 res;\n res.x = mod(idx, side);\n res.y = floor( mod(idx, side*side)/side );\n res.z = floor( mod(idx, side*side*side)/side/side );\n res -= vec3(side * 0.5);\n res *= 1.5/side;\n return res;\n}\n\n\n\nvoid main() {\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\n \n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = sin(time*4.+20.*samplePos.x*samplePos.y*samplePos.z)*4.+4.; \n\n\n v_color = vec4(samplePos.y*samplePos.y + 0.5,samplePos.x*samplePos.x + 0.5,samplePos.z*samplePos.z + 0.5,1);\n}" + }, "screenshotURL": "data/images/images-t5oietkd48e36kkdn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/899AdR5X9eCCv2RAT/art.json b/art/899AdR5X9eCCv2RAT/art.json index 282a7ffe..6d05c46f 100644 --- a/art/899AdR5X9eCCv2RAT/art.json +++ b/art/899AdR5X9eCCv2RAT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mtoutside", "avatarUrl": "https://avatars.githubusercontent.com/mtoutside?s=200", - "settings": "{\"num\":54179,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/adultswimsingles/sleep\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.1607843137254902,0.3254901960784314,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 \\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId,\\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * .1;\\n float yoff = 0.; //sin(time + x * 0.2) * .2;\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + .2, 5.) * mix(1., 1.1, oddSlice);\\n \\n vec4 pos = vec4(circleXY, 0., 1.);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1.));\\n mat *= rotZ(time * .1);\\n mat *= trans(vec3(ux, vy, 0.) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(.005 * sc);\\n vec2 xy = circleXY * .1 * sc + vec2(ux, vy) * 1.3;\\n \\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.; // sin(time + x * y * .002) * 5.;\\n \\n gl_PointSize = pow(snd + .2, 5.) * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(.8, snd); \\n float hue = u * .1 + snd * .2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = 1.; //mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\\n\"}", + "settings": { + "num": 54179, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/adultswimsingles/sleep", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.1607843137254902, + 0.3254901960784314, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 \n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId,\n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float xoff = 0.; //sin(time + y * 0.2) * .1;\n float yoff = 0.; //sin(time + x * 0.2) * .2;\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + .2, 5.) * mix(1., 1.1, oddSlice);\n \n vec4 pos = vec4(circleXY, 0., 1.);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1.));\n mat *= rotZ(time * .1);\n mat *= trans(vec3(ux, vy, 0.) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(.005 * sc);\n vec2 xy = circleXY * .1 * sc + vec2(ux, vy) * 1.3;\n \n \n gl_Position = mat * pos;\n \n float soff = 0.; // sin(time + x * y * .002) * 5.;\n \n gl_PointSize = pow(snd + .2, 5.) * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(.8, snd); \n float hue = u * .1 + snd * .2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = 1.; //mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-cqmuhjvc3egnop6hw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/89PHWvc6bSoMDB4uq/art.json b/art/89PHWvc6bSoMDB4uq/art.json index 52d367d7..65b80109 100644 --- a/art/89PHWvc6bSoMDB4uq/art.json +++ b/art/89PHWvc6bSoMDB4uq/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "pgan", "avatarUrl": "https://secure.gravatar.com/avatar/b786c3cea88eff238ced38e7ee896997?default=retro&size=200", - "settings": "{\"num\":50,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n // gl_PointSize = 10.0;\\n gl_PointSize = 5.0;\\n\\n float magic = vertexCount;\\n vec2 adjust = vec2(-magic / 2.0, -magic / 2.0);\\n\\n // float x = mod(vertexId, magic);\\n float x = 2.0 * (vertexId / vertexCount) - 1.0;\\n // float y = floor(vertexId / magic);\\n float y = vertexId / vertexCount;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n \\n v_color = vec4(0.0, 1.0, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 50, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n // gl_PointSize = 10.0;\n gl_PointSize = 5.0;\n\n float magic = vertexCount;\n vec2 adjust = vec2(-magic / 2.0, -magic / 2.0);\n\n // float x = mod(vertexId, magic);\n float x = 2.0 * (vertexId / vertexCount) - 1.0;\n // float y = floor(vertexId / magic);\n float y = vertexId / vertexCount;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n \n v_color = vec4(0.0, 1.0, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-iv2387829f8jf5mli-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8AQFD78CWiZsN4phd/art.json b/art/8AQFD78CWiZsN4phd/art.json index a42d57f7..fdb4e9a3 100644 --- a/art/8AQFD78CWiZsN4phd/art.json +++ b/art/8AQFD78CWiZsN4phd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "morimea", "avatarUrl": "https://secure.gravatar.com/avatar/8ff4b4cacdf52d8d31a020cd244c5269?default=retro&size=200", - "settings": "{\"num\":99360,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.050980392156862744,0.050980392156862744,1],\"shader\":\"/*\\n\\n Created by Danil (2020+) https://github.com/danilw\\n\\n Mouse rotation - Left mouse key and move mouse to rotate.\\n\\n\\n This is port to vertex shader my old code, old code can be found here https://youtu.be/405yudjksDA\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n// num lines\\n// NUM_SEGMENTS 100. 100*2*360 = 72000\\n// NUM_SEGMENTS 138. 138*2*360 = 99360\\n#define NUM_SEGMENTS 138.\\n\\n// anim speed\\n#define speed 0.95\\n\\n\\n// debug\\n\\n//#define debug\\nconst int debug_fid = 0;\\n\\n\\nvec3 findaxis();\\nvec3 get_color(vec3 rotate);\\nvec4 get_func(int fid, float x);\\nvec3 my_normalize(vec3 v);\\nmat4 rotationAxisAngle(vec3 v, float angle);\\nvec3 encodeSRGB(vec3 linearRGB);\\n\\n#ifdef debug\\n#define time (((mouse.x + 1.) * 27.05 * 0.5) / speed)\\n#endif\\n\\nvoid main() {\\n const float pi = 3.1415926;\\n vec4 iMouse = texture2DLod(touch, vec2(0., 0.), 0.);\\n int fid = int(mod(speed * time / (27.05 + .05), 14.));\\n #ifdef debug\\n fid = debug_fid;\\n #endif\\n float vert_z = mod(vertexId, NUM_SEGMENTS) / (NUM_SEGMENTS);\\n float idx = floor((vertexId / 2.) / NUM_SEGMENTS);\\n float slength = 1. / (NUM_SEGMENTS);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float vert_s = floor(vertexId / 2.) * slength;\\n float ecolf = (((int(mod(vertexId, NUM_SEGMENTS)) == 0) || (int(mod(vertexId, NUM_SEGMENTS)) == int(NUM_SEGMENTS - 1.))) ? 0. : 1.);\\n\\n vec4 val = get_func(fid, (vert_z));\\n vec3 rotate = findaxis();\\n vec4 col = vec4(get_color(rotate), 1.);\\n col.rgb = sqrt(encodeSRGB(col.rgb));\\n col.rgb += 0.05 * (dot(col.rgb, vec3(1.)));\\n col.rgb *= val.z * val.w * ecolf;\\n rotate = my_normalize(rotate);\\n\\n vec2 xy = val.yx * vec2(0.06);\\n\\n gl_Position = vec4(xy + 0.000001, 0.000001, 1.);\\n gl_Position = gl_Position * rotationAxisAngle(rotate.xyz, ((2. * pi) / 360.) * idx);\\n if (iMouse.z > 0.15) gl_Position = gl_Position * rotationAxisAngle(vec3(0., 1., 0.), iMouse.x * pi / 1.) * rotationAxisAngle(vec3(1., 0., 0.), iMouse.y * pi / 1.);\\n gl_Position.xy *= aspect;\\n gl_Position.z = (gl_Position.z) * 0.1 + abs(gl_Position.x) * 1. / aspect.y + vert_z * 0.1 + 10.*(1. - val.z) + (1. - ecolf);\\n gl_Position.w = 1.;\\n gl_PointSize = 3.;\\n\\n v_color = col;\\n v_color.a = 0.;\\n}\\n\\nbool isNan(float val) {\\n return (val <= 0.0 || 0.0 <= val) ? false : true;\\n}\\nbool isInf(float val) {\\n return (val + 1. != val) ? false : true;\\n}\\n\\nfloat get_xt(float xpi, float px) {\\n return xpi * px;\\n}\\n\\nfloat get_x(float xpi, float px) {\\n const float pi = 3.1415926;\\n return -pi * xpi + xpi * 2. * pi * px;\\n}\\n\\n//return [x,y]-positions [z,w] color fix\\nvec4 get_func(int fid, float x) {\\n const float pi = 3.1415926;\\n float ret = 0.;\\n float rety = ((x - 0.5) * 4.) * (1. / 0.2);\\n float cpw = 0.15;\\n float t = 0.;\\n const float maxh = 15.;\\n if (fid == 0) {t = get_x(1., x);ret = tan(t);} else\\n if (fid == 1) {t = get_x(1., x);ret = t * t * t;} else\\n if (fid == 2) {t = get_x(2., x);ret = (6. * sin(t)) / 2.;} else\\n if (fid == 3) {t = get_x(1., x);ret = 1. / tan(t);} else\\n if (fid == 4) {t = get_x(2., x);ret = abs(t) * sin(t);} else\\n if (fid == 5) {t = get_x(2., x);ret = t / (t * t);} else\\n if (fid == 6) {t = get_x(2., x);ret = -t * sin(t);} else\\n if (fid == 7) {cpw = 0.05;t = get_xt(1., rety);rety = 2.5 * (2. * cos(t) + cos(2. * t));ret = 2.5 * (2. * sin(t) - sin(2. * t));} else\\n if (fid == 8) {cpw = 0.05;t = get_xt(1., rety);rety = 1.5 * (4. * (cos(t) + cos(5. * t) / 5.));ret = 1.5 * (4. * (sin(t) - sin(5. * t) / 5.));} else\\n if (fid == 9) {cpw = 0.075;t = get_xt(1., rety);rety = 1.5 * (3. * (1. + cos(t)) * cos(t));ret = 1.5 * (3. * (1. + cos(t)) * sin(t));} else\\n if (fid == 10) {cpw = 0.05;t = get_xt(1., rety);rety = 2.5 * (3. * sin(t + pi / 2.));ret = 2.5 * (3. * sin(2. * t));} else\\n if (fid == 11) {cpw = 0.075;t = get_xt(1., rety);rety = 2.5 * ((16. * pow(sin(t), 3.)) / 4.);ret = 2.5 * ((13. * cos(t) - 5. * cos(2. * t) - 2. * cos(3. * t) - cos(4. * t)) / 4.);} else\\n if (fid == 12) {t = get_x(1., x);rety = 1.5 * (5. * sin(t));ret = 1.5 * (5. * cos(t));} else\\n if (fid == 13) {cpw = 0.1;t = get_x(1., x);rety = 2.5 * (3. * cos(t) * (1. - 2. * pow(sin(t), 2.)));ret = 2.5 * (3. * sin(t) * (1. - 2. * pow(cos(t), 2.)));} else \\n {t = get_x(1., x);ret = sin(t * 3.);}\\n float cfix = 1.;\\n if (isInf(ret)) {ret = maxh;cfix = 0.;} else {\\n if (isNan(ret)) {ret = 0.;cfix = 0.;} else {\\n if (abs(ret) > maxh) {ret = maxh * sign(ret);cfix = 0.;}\\n }\\n }\\n if (isInf(rety)) {rety = maxh;cfix = 0.;} else {\\n if (isNan(rety)) {rety = 0.001;cfix = 0.;} else {\\n if (abs(rety) > maxh) {rety = maxh * sign(rety);cfix = 0.;} else {\\n if (rety == 0.) rety = 0.001;\\n }\\n }\\n }\\n\\n return vec4(ret, rety, cfix, cpw);\\n}\\n\\n//return axis\\nvec3 findaxis() {\\n vec3 rotate = vec3(0.);\\n const vec4 static_timers1 = vec4(2.33333, 4.7, 7.05, 9.41666);\\n const vec4 static_timers2 = vec4(11.76666, 14.11666, 16.4666, 18.8166);\\n const vec4 static_timers3 = vec4(21.16666, 23.51666, 25.866, 27.05);\\n\\n float time_l = mod(time * speed, static_timers3[3] + .05);\\n\\n rotate.x = smoothstep(static_timers1[0], static_timers1[1], time_l) *\\n (1. - smoothstep(static_timers1[1], static_timers1[2], time_l));\\n rotate.x += -smoothstep(static_timers1[2], static_timers1[3], time_l) *\\n (1. - smoothstep(static_timers2[1], static_timers2[2], time_l));\\n rotate.x += smoothstep(static_timers2[2], static_timers2[3], time_l) *\\n (1. - smoothstep(static_timers3[1], static_timers3[2], time_l));\\n\\n rotate.y = smoothstep(0., static_timers1[0], time_l) *\\n (1. - smoothstep(static_timers1[0], static_timers1[1], time_l));\\n rotate.y += -smoothstep(static_timers1[2], static_timers1[3], time_l) *\\n (1. - smoothstep(static_timers1[3], static_timers2[0], time_l));\\n rotate.y += smoothstep(static_timers2[0], static_timers2[1], time_l) *\\n (1. - smoothstep(static_timers2[1], static_timers2[2], time_l));\\n rotate.y += -smoothstep(static_timers2[2], static_timers2[3], time_l) *\\n (1. - smoothstep(static_timers2[3], static_timers3[0], time_l));\\n rotate.y += smoothstep(static_timers3[0], static_timers3[1], time_l) *\\n (1. - smoothstep(static_timers3[1], static_timers3[2], time_l));\\n\\n rotate.z = smoothstep(static_timers1[1], static_timers1[2], time_l) *\\n (1. - smoothstep(static_timers1[2], static_timers1[3], time_l));\\n rotate.z += -smoothstep(static_timers1[3], static_timers2[0], time_l) *\\n (1. - smoothstep(static_timers2[0], static_timers2[1], time_l));\\n rotate.z += smoothstep(static_timers2[1], static_timers2[2], time_l) *\\n (1. - smoothstep(static_timers2[2], static_timers2[3], time_l));\\n rotate.z += -smoothstep(static_timers2[3], static_timers3[0], time_l) *\\n (1. - smoothstep(static_timers3[0], static_timers3[1], time_l));\\n rotate.z += smoothstep(static_timers3[1], static_timers3[2], time_l) *\\n (1. - smoothstep(static_timers3[2], static_timers3[3], time_l));\\n\\n return rotate;\\n}\\n\\nvec3 get_color(vec3 rotate) {\\n return abs(rotate * 7.) / 14.0;\\n}\\n\\nvec3 my_normalize(vec3 v) {\\n float len = length(v);\\n if (len == 0.0) return vec3(0., 1., 0.);\\n return v / len;\\n}\\n\\nmat4 rotationAxisAngle(vec3 v, float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n float ic = 1.0 - c;\\n\\n return mat4(vec4(v.x * v.x * ic + c, v.y * v.x * ic - s * v.z, v.z * v.x * ic + s * v.y, 0.0),\\n vec4(v.x * v.y * ic + s * v.z, v.y * v.y * ic + c, v.z * v.y * ic - s * v.x, 0.0),\\n vec4(v.x * v.z * ic - s * v.y, v.y * v.z * ic + s * v.x, v.z * v.z * ic + c, 0.0),\\n vec4(0.0, 0.0, 0.0, 1.0));\\n}\\n\\nvec3 encodeSRGB(vec3 linearRGB) {\\n vec3 a = 12.92 * linearRGB;\\n vec3 b = 1.055 * pow(linearRGB, vec3(1.0 / 2.4)) - 0.055;\\n vec3 c = step(vec3(0.0031308), linearRGB);\\n return mix(a, b, c);\\n}\\n\"}", + "settings": { + "num": 99360, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.050980392156862744, + 0.050980392156862744, + 1 + ], + "shader": "/*\n\n Created by Danil (2020+) https://github.com/danilw\n\n Mouse rotation - Left mouse key and move mouse to rotate.\n\n\n This is port to vertex shader my old code, old code can be found here https://youtu.be/405yudjksDA\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n// num lines\n// NUM_SEGMENTS 100. 100*2*360 = 72000\n// NUM_SEGMENTS 138. 138*2*360 = 99360\n#define NUM_SEGMENTS 138.\n\n// anim speed\n#define speed 0.95\n\n\n// debug\n\n//#define debug\nconst int debug_fid = 0;\n\n\nvec3 findaxis();\nvec3 get_color(vec3 rotate);\nvec4 get_func(int fid, float x);\nvec3 my_normalize(vec3 v);\nmat4 rotationAxisAngle(vec3 v, float angle);\nvec3 encodeSRGB(vec3 linearRGB);\n\n#ifdef debug\n#define time (((mouse.x + 1.) * 27.05 * 0.5) / speed)\n#endif\n\nvoid main() {\n const float pi = 3.1415926;\n vec4 iMouse = texture2DLod(touch, vec2(0., 0.), 0.);\n int fid = int(mod(speed * time / (27.05 + .05), 14.));\n #ifdef debug\n fid = debug_fid;\n #endif\n float vert_z = mod(vertexId, NUM_SEGMENTS) / (NUM_SEGMENTS);\n float idx = floor((vertexId / 2.) / NUM_SEGMENTS);\n float slength = 1. / (NUM_SEGMENTS);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float vert_s = floor(vertexId / 2.) * slength;\n float ecolf = (((int(mod(vertexId, NUM_SEGMENTS)) == 0) || (int(mod(vertexId, NUM_SEGMENTS)) == int(NUM_SEGMENTS - 1.))) ? 0. : 1.);\n\n vec4 val = get_func(fid, (vert_z));\n vec3 rotate = findaxis();\n vec4 col = vec4(get_color(rotate), 1.);\n col.rgb = sqrt(encodeSRGB(col.rgb));\n col.rgb += 0.05 * (dot(col.rgb, vec3(1.)));\n col.rgb *= val.z * val.w * ecolf;\n rotate = my_normalize(rotate);\n\n vec2 xy = val.yx * vec2(0.06);\n\n gl_Position = vec4(xy + 0.000001, 0.000001, 1.);\n gl_Position = gl_Position * rotationAxisAngle(rotate.xyz, ((2. * pi) / 360.) * idx);\n if (iMouse.z > 0.15) gl_Position = gl_Position * rotationAxisAngle(vec3(0., 1., 0.), iMouse.x * pi / 1.) * rotationAxisAngle(vec3(1., 0., 0.), iMouse.y * pi / 1.);\n gl_Position.xy *= aspect;\n gl_Position.z = (gl_Position.z) * 0.1 + abs(gl_Position.x) * 1. / aspect.y + vert_z * 0.1 + 10.*(1. - val.z) + (1. - ecolf);\n gl_Position.w = 1.;\n gl_PointSize = 3.;\n\n v_color = col;\n v_color.a = 0.;\n}\n\nbool isNan(float val) {\n return (val <= 0.0 || 0.0 <= val) ? false : true;\n}\nbool isInf(float val) {\n return (val + 1. != val) ? false : true;\n}\n\nfloat get_xt(float xpi, float px) {\n return xpi * px;\n}\n\nfloat get_x(float xpi, float px) {\n const float pi = 3.1415926;\n return -pi * xpi + xpi * 2. * pi * px;\n}\n\n//return [x,y]-positions [z,w] color fix\nvec4 get_func(int fid, float x) {\n const float pi = 3.1415926;\n float ret = 0.;\n float rety = ((x - 0.5) * 4.) * (1. / 0.2);\n float cpw = 0.15;\n float t = 0.;\n const float maxh = 15.;\n if (fid == 0) {t = get_x(1., x);ret = tan(t);} else\n if (fid == 1) {t = get_x(1., x);ret = t * t * t;} else\n if (fid == 2) {t = get_x(2., x);ret = (6. * sin(t)) / 2.;} else\n if (fid == 3) {t = get_x(1., x);ret = 1. / tan(t);} else\n if (fid == 4) {t = get_x(2., x);ret = abs(t) * sin(t);} else\n if (fid == 5) {t = get_x(2., x);ret = t / (t * t);} else\n if (fid == 6) {t = get_x(2., x);ret = -t * sin(t);} else\n if (fid == 7) {cpw = 0.05;t = get_xt(1., rety);rety = 2.5 * (2. * cos(t) + cos(2. * t));ret = 2.5 * (2. * sin(t) - sin(2. * t));} else\n if (fid == 8) {cpw = 0.05;t = get_xt(1., rety);rety = 1.5 * (4. * (cos(t) + cos(5. * t) / 5.));ret = 1.5 * (4. * (sin(t) - sin(5. * t) / 5.));} else\n if (fid == 9) {cpw = 0.075;t = get_xt(1., rety);rety = 1.5 * (3. * (1. + cos(t)) * cos(t));ret = 1.5 * (3. * (1. + cos(t)) * sin(t));} else\n if (fid == 10) {cpw = 0.05;t = get_xt(1., rety);rety = 2.5 * (3. * sin(t + pi / 2.));ret = 2.5 * (3. * sin(2. * t));} else\n if (fid == 11) {cpw = 0.075;t = get_xt(1., rety);rety = 2.5 * ((16. * pow(sin(t), 3.)) / 4.);ret = 2.5 * ((13. * cos(t) - 5. * cos(2. * t) - 2. * cos(3. * t) - cos(4. * t)) / 4.);} else\n if (fid == 12) {t = get_x(1., x);rety = 1.5 * (5. * sin(t));ret = 1.5 * (5. * cos(t));} else\n if (fid == 13) {cpw = 0.1;t = get_x(1., x);rety = 2.5 * (3. * cos(t) * (1. - 2. * pow(sin(t), 2.)));ret = 2.5 * (3. * sin(t) * (1. - 2. * pow(cos(t), 2.)));} else \n {t = get_x(1., x);ret = sin(t * 3.);}\n float cfix = 1.;\n if (isInf(ret)) {ret = maxh;cfix = 0.;} else {\n if (isNan(ret)) {ret = 0.;cfix = 0.;} else {\n if (abs(ret) > maxh) {ret = maxh * sign(ret);cfix = 0.;}\n }\n }\n if (isInf(rety)) {rety = maxh;cfix = 0.;} else {\n if (isNan(rety)) {rety = 0.001;cfix = 0.;} else {\n if (abs(rety) > maxh) {rety = maxh * sign(rety);cfix = 0.;} else {\n if (rety == 0.) rety = 0.001;\n }\n }\n }\n\n return vec4(ret, rety, cfix, cpw);\n}\n\n//return axis\nvec3 findaxis() {\n vec3 rotate = vec3(0.);\n const vec4 static_timers1 = vec4(2.33333, 4.7, 7.05, 9.41666);\n const vec4 static_timers2 = vec4(11.76666, 14.11666, 16.4666, 18.8166);\n const vec4 static_timers3 = vec4(21.16666, 23.51666, 25.866, 27.05);\n\n float time_l = mod(time * speed, static_timers3[3] + .05);\n\n rotate.x = smoothstep(static_timers1[0], static_timers1[1], time_l) *\n (1. - smoothstep(static_timers1[1], static_timers1[2], time_l));\n rotate.x += -smoothstep(static_timers1[2], static_timers1[3], time_l) *\n (1. - smoothstep(static_timers2[1], static_timers2[2], time_l));\n rotate.x += smoothstep(static_timers2[2], static_timers2[3], time_l) *\n (1. - smoothstep(static_timers3[1], static_timers3[2], time_l));\n\n rotate.y = smoothstep(0., static_timers1[0], time_l) *\n (1. - smoothstep(static_timers1[0], static_timers1[1], time_l));\n rotate.y += -smoothstep(static_timers1[2], static_timers1[3], time_l) *\n (1. - smoothstep(static_timers1[3], static_timers2[0], time_l));\n rotate.y += smoothstep(static_timers2[0], static_timers2[1], time_l) *\n (1. - smoothstep(static_timers2[1], static_timers2[2], time_l));\n rotate.y += -smoothstep(static_timers2[2], static_timers2[3], time_l) *\n (1. - smoothstep(static_timers2[3], static_timers3[0], time_l));\n rotate.y += smoothstep(static_timers3[0], static_timers3[1], time_l) *\n (1. - smoothstep(static_timers3[1], static_timers3[2], time_l));\n\n rotate.z = smoothstep(static_timers1[1], static_timers1[2], time_l) *\n (1. - smoothstep(static_timers1[2], static_timers1[3], time_l));\n rotate.z += -smoothstep(static_timers1[3], static_timers2[0], time_l) *\n (1. - smoothstep(static_timers2[0], static_timers2[1], time_l));\n rotate.z += smoothstep(static_timers2[1], static_timers2[2], time_l) *\n (1. - smoothstep(static_timers2[2], static_timers2[3], time_l));\n rotate.z += -smoothstep(static_timers2[3], static_timers3[0], time_l) *\n (1. - smoothstep(static_timers3[0], static_timers3[1], time_l));\n rotate.z += smoothstep(static_timers3[1], static_timers3[2], time_l) *\n (1. - smoothstep(static_timers3[2], static_timers3[3], time_l));\n\n return rotate;\n}\n\nvec3 get_color(vec3 rotate) {\n return abs(rotate * 7.) / 14.0;\n}\n\nvec3 my_normalize(vec3 v) {\n float len = length(v);\n if (len == 0.0) return vec3(0., 1., 0.);\n return v / len;\n}\n\nmat4 rotationAxisAngle(vec3 v, float angle) {\n float s = sin(angle);\n float c = cos(angle);\n float ic = 1.0 - c;\n\n return mat4(vec4(v.x * v.x * ic + c, v.y * v.x * ic - s * v.z, v.z * v.x * ic + s * v.y, 0.0),\n vec4(v.x * v.y * ic + s * v.z, v.y * v.y * ic + c, v.z * v.y * ic - s * v.x, 0.0),\n vec4(v.x * v.z * ic - s * v.y, v.y * v.z * ic + s * v.x, v.z * v.z * ic + c, 0.0),\n vec4(0.0, 0.0, 0.0, 1.0));\n}\n\nvec3 encodeSRGB(vec3 linearRGB) {\n vec3 a = 12.92 * linearRGB;\n vec3 b = 1.055 * pow(linearRGB, vec3(1.0 / 2.4)) - 0.055;\n vec3 c = step(vec3(0.0031308), linearRGB);\n return mix(a, b, c);\n}\n" + }, "screenshotURL": "data/images/images-icfdnj1z1gcwact4x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8EW4w374gLe9Y8mvS/art.json b/art/8EW4w374gLe9Y8mvS/art.json index c4397a07..4508f763 100644 --- a/art/8EW4w374gLe9Y8mvS/art.json +++ b/art/8EW4w374gLe9Y8mvS/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI2 6.28\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float col = mod(vertexId, time * 0.1); \\n float row = floor(vertexId / 5.0);\\n \\n float theta = col / 10.0 * PI2;\\n float radius = row * 0.0004;\\n \\n float x = cos(theta) * radius;\\n float y = sin(theta) * radius;\\n float z = 0.0;\\n \\n float dist = distance(vec2(0.0, 0.0), vec2(x, y));\\n float damp = 0.1;\\n vec2 ease = (vec2(mouse.x, mouse.y) - vec2(x, y)) * damp;\\n \\n gl_Position = vec4(x + ease.x, y + ease.y, z, 1.0);\\n gl_PointSize = dist * 10.0;\\n v_color = vec4(dist, 0.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI2 6.28\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float col = mod(vertexId, time * 0.1); \n float row = floor(vertexId / 5.0);\n \n float theta = col / 10.0 * PI2;\n float radius = row * 0.0004;\n \n float x = cos(theta) * radius;\n float y = sin(theta) * radius;\n float z = 0.0;\n \n float dist = distance(vec2(0.0, 0.0), vec2(x, y));\n float damp = 0.1;\n vec2 ease = (vec2(mouse.x, mouse.y) - vec2(x, y)) * damp;\n \n gl_Position = vec4(x + ease.x, y + ease.y, z, 1.0);\n gl_PointSize = dist * 10.0;\n v_color = vec4(dist, 0.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-2y1tfqzklm7s6fn9t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8Ha5WpefzTXhF4Cmr/art.json b/art/8Ha5WpefzTXhF4Cmr/art.json index ff465774..01570197 100644 --- a/art/8Ha5WpefzTXhF4Cmr/art.json +++ b/art/8Ha5WpefzTXhF4Cmr/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":14867,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/wigae/pilot?si=fadac0229014470bae0ae92399497b80&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n//Name : Jemin.Shin\\n//assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Coruse : CS250\\n//Date : 2023 Fall\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 14867, + "mode": "POINTS", + "sound": "https://soundcloud.com/wigae/pilot?si=fadac0229014470bae0ae92399497b80&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n//Name : Jemin.Shin\n//assignment : Exercise - Vertexshaderart : Audio Reactive\n//Coruse : CS250\n//Date : 2023 Fall\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-hq22icsr4v1tw9v2f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8JCNkReuE5hLqBoNT/art.json b/art/8JCNkReuE5hLqBoNT/art.json index df0d0daf..a145fea0 100644 --- a/art/8JCNkReuE5hLqBoNT/art.json +++ b/art/8JCNkReuE5hLqBoNT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thesoftmoon/stupid-child?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.11372549019607843,0.32941176470588235,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float scale = .9;\\n vec2 xy = vec2(ux, vy) * scale;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(0., 1., 0., 1.);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thesoftmoon/stupid-child?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.11372549019607843, + 0.32941176470588235, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float scale = .9;\n vec2 xy = vec2(ux, vy) * scale;\n \n gl_Position = vec4(xy, 0., 1.);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(0., 1., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-gs02wa77y7babtvx3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8LsJgzRWQxy2bJWwJ/art.json b/art/8LsJgzRWQxy2bJWwJ/art.json index 8052c040..722c0ba1 100644 --- a/art/8LsJgzRWQxy2bJWwJ/art.json +++ b/art/8LsJgzRWQxy2bJWwJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n#define PI radians(180.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n} \\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\n\\nvec2 getFragCoord(in float _finalDesiredPointSize, out float _finalVertexCount, out float _finalVertexId, out vec2 _finalResolution )\\n{\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n _finalVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n _finalResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n _finalResolution.y = floor(_finalVertexCount / _finalResolution.x);\\n _finalVertexId = mod(vertexId,_finalVertexCount);\\n return vec2(0.,0.);\\n}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n vec2 vertexResolution = vec2(0.);\\n \\n //first the number of elements in a line\\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n\\n //then the number of possible lines with the given vertexCount\\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n //cordinates in 0..1 referential\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n vec2 vfragCoord = vec2(u,v);\\n \\n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\\n \\n //cordinates in -1...1 referential\\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\\n float vy = v0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\\n \\n //optional for symetry\\n //if(u>0.5)\\n //u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n \\n vec2 st = uv;\\n\\tst.x *= resolution.x / resolution.y;\\n\\n\\tvec2 pos = st.yx* vec2(10.0, 3.0);\\n\\t\\n\\tfloat pattern = pos.x;\\n\\t\\n\\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\\n\\t\\n\\tpattern = lines(pos, 0.5);\\n\\t\\n\\t\\n\\n //camera\\n float r = 2.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(vec3(pattern), 1.0);\\n \\n vec4 finalPos = vec4(ux, vy, 0., 1.);\\n \\n gl_Position = finalPos;\\n}\\n*/\\n\\n\\n\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n\\n#extension GL_OES_standard_derivatives : enable\\n\\n//Step 1 >> comment uniforms\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 resolution;\\n\\nfloat zoom = 0.1;\\nfloat pi = 3.14159265359;\\n\\nvoid main( void ) {\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 5.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n vec2 vertexResolution = vec2(0.);\\n \\n //first the number of elements in a line\\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n\\n //then the number of possible lines with the given vertexCount\\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n vec2 vfragCoord = vec2(u,v);\\n \\n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\\n \\n //calculate vertex coordinates\\n //float ux = u0 - 0.5*u0/u;//(vertexResolution.x*finalDesiredPointSize/resolution.x);\\n float vy = v0 - 0.5*v0/v;//(vertexResolution.x*finalDesiredPointSize/resolution.x);;\\n \\n float ux = 2.* u*(vertexResolution.x*finalDesiredPointSize/resolution.x) - 1.;\\n vy = v*(vertexResolution.x*finalDesiredPointSize/resolution.x) - 1.;\\n \\n\\t//vec2 position = ( gl_FragCoord.xy / resolution.xy ) / 4.0;\\n //vec2 position = ( vfragCoord.xy / vertexResolution.xy ) / 4.0;\\n \\n vec2 position = vec2(ux,vy);\\n \\n\\t//position = resolution.xy / min( resolution.x, resolution.y ) * ( position + vec2( -0.125, -0.125 ) ) / zoom;\\n //position = vertexResolution.xy / min( vertexResolution.x, vertexResolution.y ) * ( position + vec2( -0.125, -0.125 ) ) / zoom;\\n\\t\\n float r = 0.0;\\n\\tfloat g = 0.0;\\n\\tfloat b = 0.0;\\n\\t\\n\\t//CIRCLE\\n\\tfloat theta = floor( sin( atan( position.y / position.x ) * 20.0 + 120.0*10.*abs(cos(time*4.)) / sqrt( pow( position.x, 2.0 ) + pow( position.y, 2.0 ) ) + time * 3.0 ) + 1.0 ) ;\\n\\tr = theta;\\n\\tg = theta;\\n\\tb = theta;\\n\\t\\n\\t//FADE\\n\\tfloat alpha = sqrt( pow( position.x, 2.0 ) + pow( position.y, 2.0 ) ) / 3.0 - .01;\\n\\tr = 0.0 + (r - 0.0) * alpha;\\n\\tg = 0.0 + (g - 0.0) * alpha;\\n\\tb = 0.0 + (b - 0.0) * alpha;\\n\\n //Step 3 >> set points colors replacing gl_FragColor\\n \\n\\tv_color = vec4( vec3( r, g, b ), 1.0 );\\n \\n \\n //set pointsize\\n gl_PointSize = finalDesiredPointSize;\\n \\n //Step 6 >> set the point positions\\n //vec4 finalPos = vec4(ux, vy, 0., 1.);\\n vec4 finalPos = vec4(ux, vy, 0., 1.);\\n gl_Position = finalPos;\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n#define PI radians(180.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n} \n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\n\nvec2 getFragCoord(in float _finalDesiredPointSize, out float _finalVertexCount, out float _finalVertexId, out vec2 _finalResolution )\n{\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n _finalVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n _finalResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n _finalResolution.y = floor(_finalVertexCount / _finalResolution.x);\n _finalVertexId = mod(vertexId,_finalVertexCount);\n return vec2(0.,0.);\n}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n vec2 vertexResolution = vec2(0.);\n \n //first the number of elements in a line\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n\n //then the number of possible lines with the given vertexCount\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n //cordinates in 0..1 referential\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n vec2 vfragCoord = vec2(u,v);\n \n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\n \n //cordinates in -1...1 referential\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\n float vy = v0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\n \n //optional for symetry\n //if(u>0.5)\n //u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n \n vec2 st = uv;\n\tst.x *= resolution.x / resolution.y;\n\n\tvec2 pos = st.yx* vec2(10.0, 3.0);\n\t\n\tfloat pattern = pos.x;\n\t\n\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\n\t\n\tpattern = lines(pos, 0.5);\n\t\n\t\n\n //camera\n float r = 2.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(vec3(pattern), 1.0);\n \n vec4 finalPos = vec4(ux, vy, 0., 1.);\n \n gl_Position = finalPos;\n}\n*/\n\n\n\n#ifdef GL_ES\nprecision mediump float;\n#endif\n\n#extension GL_OES_standard_derivatives : enable\n\n//Step 1 >> comment uniforms\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 resolution;\n\nfloat zoom = 0.1;\nfloat pi = 3.14159265359;\n\nvoid main( void ) {\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 5.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n vec2 vertexResolution = vec2(0.);\n \n //first the number of elements in a line\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n\n //then the number of possible lines with the given vertexCount\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n vec2 vfragCoord = vec2(u,v);\n \n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\n \n //calculate vertex coordinates\n //float ux = u0 - 0.5*u0/u;//(vertexResolution.x*finalDesiredPointSize/resolution.x);\n float vy = v0 - 0.5*v0/v;//(vertexResolution.x*finalDesiredPointSize/resolution.x);;\n \n float ux = 2.* u*(vertexResolution.x*finalDesiredPointSize/resolution.x) - 1.;\n vy = v*(vertexResolution.x*finalDesiredPointSize/resolution.x) - 1.;\n \n\t//vec2 position = ( gl_FragCoord.xy / resolution.xy ) / 4.0;\n //vec2 position = ( vfragCoord.xy / vertexResolution.xy ) / 4.0;\n \n vec2 position = vec2(ux,vy);\n \n\t//position = resolution.xy / min( resolution.x, resolution.y ) * ( position + vec2( -0.125, -0.125 ) ) / zoom;\n //position = vertexResolution.xy / min( vertexResolution.x, vertexResolution.y ) * ( position + vec2( -0.125, -0.125 ) ) / zoom;\n\t\n float r = 0.0;\n\tfloat g = 0.0;\n\tfloat b = 0.0;\n\t\n\t//CIRCLE\n\tfloat theta = floor( sin( atan( position.y / position.x ) * 20.0 + 120.0*10.*abs(cos(time*4.)) / sqrt( pow( position.x, 2.0 ) + pow( position.y, 2.0 ) ) + time * 3.0 ) + 1.0 ) ;\n\tr = theta;\n\tg = theta;\n\tb = theta;\n\t\n\t//FADE\n\tfloat alpha = sqrt( pow( position.x, 2.0 ) + pow( position.y, 2.0 ) ) / 3.0 - .01;\n\tr = 0.0 + (r - 0.0) * alpha;\n\tg = 0.0 + (g - 0.0) * alpha;\n\tb = 0.0 + (b - 0.0) * alpha;\n\n //Step 3 >> set points colors replacing gl_FragColor\n \n\tv_color = vec4( vec3( r, g, b ), 1.0 );\n \n \n //set pointsize\n gl_PointSize = finalDesiredPointSize;\n \n //Step 6 >> set the point positions\n //vec4 finalPos = vec4(ux, vy, 0., 1.);\n vec4 finalPos = vec4(ux, vy, 0., 1.);\n gl_Position = finalPos;\n\n}" + }, "screenshotURL": "data/images/images-7r1xe2d9vxqemps47-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8MHgqJdpnFiQGkBc2/art.json b/art/8MHgqJdpnFiQGkBc2/art.json index 1592fb4c..55b93b61 100644 --- a/art/8MHgqJdpnFiQGkBc2/art.json +++ b/art/8MHgqJdpnFiQGkBc2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.2) + mod(vertexId, 2.3) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.4), fract(count / 20000.5))).a;\\n float offset = count * 6.2;\\n float angle = point * PI * 2.7 / NUM_SEGMENTS + offset;\\n float radius = .2 * pow(snd, 5.8);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 9.10;\\n float innerRadius = count * .001;\\n float oC = cos(orbitAngle + time * 2.4 + count * 3.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 4.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.2) + mod(vertexId, 2.3) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.4), fract(count / 20000.5))).a;\n float offset = count * 6.2;\n float angle = point * PI * 2.7 / NUM_SEGMENTS + offset;\n float radius = .2 * pow(snd, 5.8);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 9.10;\n float innerRadius = count * .001;\n float oC = cos(orbitAngle + time * 2.4 + count * 3.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 4.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-cgzgm91pfd954lthz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8MRZuPQnb7riyBLat/art.json b/art/8MRZuPQnb7riyBLat/art.json index e3c3ea3c..e9285e42 100644 --- a/art/8MRZuPQnb7riyBLat/art.json +++ b/art/8MRZuPQnb7riyBLat/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":25722,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmagasia/audio-asia-masaki-sakamoto-ken-ishii-the-small-hours\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1.41421356237, vy);\\n float a = mix(start, end, u) * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float line = mod(circleId, 1.); // 1 if line, 0 if point\\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = line * .1;\\n \\n \\n float g0 = (groupId ) / numGroups;\\n float g1 = (groupId + 1.) / numGroups;\\n \\n float s0 = texture2D(sound, vec2(mix(.01, .5, g0), 0)).a;\\n float s1 = texture2D(sound, vec2(mix(.01, .5, g1), gv * .25)).a;\\n \\n #if 0\\n float t = time * 0.1;\\n s0 = sin(t + g0 * 20.) * .5;\\n s1 = sin(t + g1 * 20.) * .5;\\n #endif\\n \\n vec2 p0 = vec2(t2m1(mod(pointId, 2.)), t2m1(gv));\\n vec2 p1 = vec2(t2m1(mod(pointId, 2.)), t2m1(gv));\\n vec2 dif = p1 - p0;\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 mat = scale(vec3(1, 1, 1));\\n \\n float dotSize = 2.95 / numGroups * gv * 2. * pow(s1 + .25, 2.);\\n const float lineWidth = 0.01;\\n \\n mat *= trans(vec3(p0, 0));\\n mat *= rotZ(atan(dif.x, dif.y) * line);\\n mat *= scale(mix(vec3(dotSize, dotSize, 1), vec3(lineWidth, length(dif) * .5, 1), line));\\n mat *= trans(vec3(0, line * 1.0, 0));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n //float pump = mix(0., 1., step(0.9, s0));\\n float hue = (s0 + s1) * .5 + time * .1 + gv * .20;\\n float sat = pow(1. - s0 + .2, 2.);\\n float val = pow(s0 + .2, 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 25722, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmagasia/audio-asia-masaki-sakamoto-ken-ishii-the-small-hours", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1.41421356237, vy);\n float a = mix(start, end, u) * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float line = mod(circleId, 1.); // 1 if line, 0 if point\n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = line * .1;\n \n \n float g0 = (groupId ) / numGroups;\n float g1 = (groupId + 1.) / numGroups;\n \n float s0 = texture2D(sound, vec2(mix(.01, .5, g0), 0)).a;\n float s1 = texture2D(sound, vec2(mix(.01, .5, g1), gv * .25)).a;\n \n #if 0\n float t = time * 0.1;\n s0 = sin(t + g0 * 20.) * .5;\n s1 = sin(t + g1 * 20.) * .5;\n #endif\n \n vec2 p0 = vec2(t2m1(mod(pointId, 2.)), t2m1(gv));\n vec2 p1 = vec2(t2m1(mod(pointId, 2.)), t2m1(gv));\n vec2 dif = p1 - p0;\n \n float aspect = resolution.x / resolution.y;\n mat4 mat = scale(vec3(1, 1, 1));\n \n float dotSize = 2.95 / numGroups * gv * 2. * pow(s1 + .25, 2.);\n const float lineWidth = 0.01;\n \n mat *= trans(vec3(p0, 0));\n mat *= rotZ(atan(dif.x, dif.y) * line);\n mat *= scale(mix(vec3(dotSize, dotSize, 1), vec3(lineWidth, length(dif) * .5, 1), line));\n mat *= trans(vec3(0, line * 1.0, 0));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n //float pump = mix(0., 1., step(0.9, s0));\n float hue = (s0 + s1) * .5 + time * .1 + gv * .20;\n float sat = pow(1. - s0 + .2, 2.);\n float val = pow(s0 + .2, 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-ha3nym2bem840p30p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8MxcbeeakhH3Zvjvm/art.json b/art/8MxcbeeakhH3Zvjvm/art.json index 552b2f31..9cd55838 100644 --- a/art/8MxcbeeakhH3Zvjvm/art.json +++ b/art/8MxcbeeakhH3Zvjvm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\n// Jack-o'-lantern\\n// @P_Malin\\n\\n//\\n\\n#define kRaymarchMaxIter 64\\n\\n#define kBounceCount 1\\n\\n// Enable this to use POINTS primitive type\\n//#define POINTS_VERSION\\n\\nfloat g_AlphaBlend = 1.0;\\n\\n//#define SCENE_DOMAIN_REPEAT\\n\\nfloat kFarClip=100.0;\\n\\nvec2 GetWindowCoord( const in vec2 vUV );\\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget );\\nvec3 GetSceneColour( in vec3 vRayOrigin, in vec3 vRayDir );\\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput );\\n\\nfloat GetCarving2dDistance(const in vec2 vPos );\\n\\nvec3 vLightPos = vec3(0.0, -0.5, 0.0);\\t\\t\\t\\nvec3 vLightColour = vec3(1.0, 0.8, 0.4);\\n\\nfloat fCarving = 1.0;\\n\\n// from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// CAMERA\\n\\nvec2 GetWindowCoord( const in vec2 vUV )\\n{\\n\\tvec2 vWindow = vUV * 2.0 - 1.0;\\n\\tvWindow.x *= resolution.x / resolution.y;\\n\\n\\treturn vWindow;\\t\\n}\\n\\n\\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget )\\n{\\n\\tvec3 vForward = normalize(vCameraTarget - vCameraPos);\\n\\tvec3 vRight = normalize(cross(vec3(0.0, 1.0, 0.0), vForward));\\n\\tvec3 vUp = normalize(cross(vForward, vRight));\\n\\t\\t\\t\\t\\t\\t\\t \\n\\tvec3 vDir = normalize(vWindow.x * vRight + vWindow.y * vUp + vForward * 1.5);\\n\\n\\treturn vDir;\\n}\\n\\n// POSTFX\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.19) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvec3 ApplyTonemap( const in vec3 vLinear )\\n{\\n\\tfloat kExposure = 1.9;\\n \\n\\treturn 1.0 - exp2(vLinear * -kExposure);\\t\\n}\\n\\nvec3 ApplyGamma( const in vec3 vLinear )\\n{\\n\\tconst float kGamma = 2.2;\\n\\n\\treturn pow(vLinear, vec3(1.0/kGamma));\\t\\n}\\n\\nvec3 ApplyBlackLevel( const in vec3 vColour )\\n{\\n float fBlackLevel = 0.1;\\n return vColour / (1.0 - fBlackLevel) - fBlackLevel;\\n}\\n\\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec3 vTemp = ApplyVignetting( vUV, vInput );\\t\\n\\t\\n\\tvTemp = ApplyTonemap(vTemp);\\n\\t\\n\\tvTemp = ApplyGamma(vTemp);\\t\\t\\n \\n vTemp = ApplyBlackLevel(vTemp);\\n \\n return vTemp;\\n}\\n\\t\\n// RAYTRACE\\n\\nstruct C_Intersection\\n{\\n\\tvec3 vPos;\\n\\tfloat fDist;\\t\\n\\tvec3 vNormal;\\n\\tvec3 vUVW;\\n\\tfloat fObjectId;\\n};\\n\\nfloat GetCarving2dDistance(const in vec2 vPos )\\n{\\n if(fCarving < 0.0)\\n return 10.0;\\n \\n\\tfloat fMouthDist = length(vPos.xy + vec2(0.0, -0.5)) - 1.5;\\n\\tfloat fMouthDist2 = length(vPos.xy + vec2(0.0, -1.1 - 0.5)) - 2.0;\\n\\t\\n\\tif(-fMouthDist2 > fMouthDist )\\n\\t{\\n\\t\\tfMouthDist = -fMouthDist2;\\n\\t}\\n\\n float fFaceDist = fMouthDist;\\n\\n vec2 vNosePos = vPos.xy + vec2(0.0, -0.5);\\n vNosePos.x = abs(vNosePos.x);\\n float fNoseDist = dot(vNosePos.xy, normalize(vec2(1.0, 0.5)));\\n fNoseDist = max(fNoseDist, -(vNosePos.y + 0.5));\\n if(fNoseDist < fFaceDist)\\n {\\n fFaceDist = fNoseDist;\\n }\\n\\n\\n vec2 vEyePos = vPos.xy;\\n vEyePos.x = abs(vEyePos.x);\\n vEyePos.x -= 1.0;\\n vEyePos.y -= 1.0;\\n float fEyeDist = dot(vEyePos.xy, normalize(vec2(-1.0, 1.5)));\\n fEyeDist = max(fEyeDist, dot(vEyePos.xy, normalize(vec2(1.0, 0.5))));\\n fEyeDist = max(fEyeDist, -0.5+dot(vEyePos.xy, normalize(vec2(0.0, -1.0))));\\n if(fEyeDist < fFaceDist)\\n {\\n fFaceDist = fEyeDist;\\n }\\n \\n return fFaceDist;\\n}\\n\\nfloat GetCarvingDistance(const in vec3 vPos )\\n{\\n\\tfloat fDist = (length(vPos * vec3(1.0, 1.4, 1.0)) - 2.7) / 1.5;\\n\\n float fFaceDist = GetCarving2dDistance(vPos.xy);\\n \\n\\tfloat fRearDist = vPos.z;\\n\\t\\n\\tif(fRearDist > fFaceDist)\\n\\t{\\n\\t\\tfFaceDist = fRearDist;\\n\\t}\\t\\n\\t\\n\\tif(fFaceDist < fDist )\\n\\t{\\n\\t\\tfDist = fFaceDist;\\n\\t}\\n\\n float fR = length(vPos.xz);\\n \\n float fLidDist = dot( vec2(fR, vPos.y), normalize(vec2(1.0, -1.5)));\\n \\n fLidDist = abs(fLidDist) - 0.03;\\n\\tif(fLidDist < fDist )\\n\\t{\\n\\t\\tfDist = fLidDist;\\n\\t}\\n \\n\\treturn fDist;\\n}\\n\\nfloat GetPumpkinDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\\n{\\n vec3 vSphereOrigin = vec3(0.0, 0.0, 0.0);\\n float fSphereRadius = 3.0;\\n\\n\\tvec3 vOffset = vPos - vSphereOrigin;\\n\\tfloat fFirstDist = length(vOffset);\\n\\t\\n\\tfloat fOutDist;\\n\\tif(fFirstDist > 3.5)\\n\\t{\\n\\t\\tfOutDist = fFirstDist - fSphereRadius;\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tfloat fAngle1 = atan(vOffset.x, vOffset.z);\\n\\t\\tfloat fSin = sin(fAngle1 * 10.0);\\n\\t\\tfSin = 1.0 - sqrt(abs(fSin));\\n\\t\\tvOffset *= 1.0 + fSin * vec3(0.05, 0.025, 0.05);\\n\\t\\tvOffset.y *= 1.0 + 0.5 * (fSphereRadius - length(vOffset.xz)) / fSphereRadius;\\n\\t\\tfOutDist = length(vOffset) - fSphereRadius;\\n\\t}\\n\\t\\n\\n\\tvec4 vSphere1UVW_Id = vec4(normalize(vPos - vSphereOrigin), 3.0);\\n\\tvOutUVW_Id = vSphere1UVW_Id;\\n\\t\\n\\tvec3 vStalkOffset = vPos;\\n\\tvStalkOffset.x += -(vStalkOffset.y - fSphereRadius) * 0.1;\\n\\tfloat fDist2d = length(vStalkOffset.xz);\\n\\tfloat fStalkDist = fDist2d - 0.2;\\n\\tfStalkDist = max(fStalkDist, vPos.y - 2.5 + vPos.x * 0.25);\\n\\tfStalkDist = max(fStalkDist, -vPos.y);\\n\\tif( fStalkDist < fOutDist )\\n\\t{\\n\\t\\tfOutDist = fStalkDist;\\n\\t\\tvOutUVW_Id = vSphere1UVW_Id;\\n\\t\\tvOutUVW_Id.w = 22.0;\\n\\t}\\n\\n\\treturn fOutDist;\\n}\\n\\nfloat GetSceneDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\\n{\\n\\tfloat fFloorDist = vPos.y + 2.0;\\n\\tvec4 vFloorUVW_Id = vec4(vPos.xz, 0.0, 1.0);\\n\\n\\t\\n\\tvec3 vPumpkinDomain = vPos;\\n\\n#ifdef SCENE_DOMAIN_REPEAT\\n\\tfloat fRepeat = 12.0;\\n\\tfloat fOffset = (fRepeat * 0.95);\\n\\tvPumpkinDomain.xz = fract((vPos.xz + fOffset) / fRepeat) * fRepeat - fOffset;\\n#endif \\n \\n\\tfloat fOutDist = fFloorDist;\\n\\tvOutUVW_Id = vFloorUVW_Id;\\n\\n\\tvec4 vPumpkinUVW_Id;\\n\\tfloat fPumpkinDist = GetPumpkinDistance( vPumpkinUVW_Id, vPumpkinDomain );\\n\\n\\tfloat fCarvingDist = GetCarvingDistance( vPumpkinDomain );\\n\\t\\n\\tif(-fCarvingDist > fPumpkinDist)\\n\\t{\\n\\t\\tfPumpkinDist = -fCarvingDist;\\n\\t\\tvPumpkinUVW_Id = vec4(4.0);\\n\\t}\\n\\n\\t\\n\\tif(fPumpkinDist < fOutDist)\\n\\t{\\n\\t\\tfOutDist = fPumpkinDist;\\n\\t\\tvOutUVW_Id = vPumpkinUVW_Id;\\n\\t}\\n\\t\\n\\treturn fOutDist;\\n}\\n\\nvec3 GetSceneNormal(const in vec3 vPos)\\n{\\n const float fDelta = 0.001;\\n\\n vec3 vDir1 = vec3( 1.0, -1.0, -1.0);\\n vec3 vDir2 = vec3(-1.0, -1.0, 1.0);\\n vec3 vDir3 = vec3(-1.0, 1.0, -1.0);\\n vec3 vDir4 = vec3( 1.0, 1.0, 1.0);\\n\\t\\n vec3 vOffset1 = vDir1 * fDelta;\\n vec3 vOffset2 = vDir2 * fDelta;\\n vec3 vOffset3 = vDir3 * fDelta;\\n vec3 vOffset4 = vDir4 * fDelta;\\n\\n\\tvec4 vUnused;\\n float f1 = GetSceneDistance( vUnused, vPos + vOffset1 );\\n float f2 = GetSceneDistance( vUnused, vPos + vOffset2 );\\n float f3 = GetSceneDistance( vUnused, vPos + vOffset3 );\\n float f4 = GetSceneDistance( vUnused, vPos + vOffset4 );\\n\\t\\n vec3 vNormal = vDir1 * f1 + vDir2 * f2 + vDir3 * f3 + vDir4 * f4;\\t\\n\\t\\t\\n return normalize( vNormal );\\n}\\n\\nvoid TraceScene( out C_Intersection outIntersection, const in vec3 vOrigin, const in vec3 vDir )\\n{\\t\\n\\tvec4 vUVW_Id = vec4(0.0);\\t\\t\\n\\tvec3 vPos = vec3(0.0);\\n\\t\\n\\tfloat t = 0.01;\\n\\tfor(int i=0; i 99900.0)\\n\\t\\t{\\n\\t\\t\\tt = kFarClip;\\n\\t\\t\\tvPos = vOrigin + vDir * t;\\n\\t\\t\\tvUVW_Id = vec4(0.0);\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t}\\n\\t\\n\\toutIntersection.fDist = t;\\n\\toutIntersection.vPos = vPos;\\n\\toutIntersection.vNormal = GetSceneNormal(vPos);\\n\\toutIntersection.vUVW = vUVW_Id.xyz;\\n\\toutIntersection.fObjectId = vUVW_Id.w;\\n}\\n\\n\\nfloat TraceShadow( const in vec3 vOrigin, const in vec3 vDir, const in float fDist )\\n{\\n C_Intersection shadowIntersection;\\n\\tTraceScene(shadowIntersection, vOrigin, vDir);\\n\\tif(shadowIntersection.fDist < fDist) \\n\\t{\\n\\t\\treturn 0.0;\\t\\t\\n\\t}\\n\\t\\n\\treturn 1.0;\\n}\\n\\nfloat GetSSS( const in vec3 vPos, const in vec3 vLightPos )\\n{\\n vec3 vLightToPos = vPos - vLightPos;\\n vec3 vDir = normalize(vLightToPos);\\n \\n\\tC_Intersection intersection;\\n\\tTraceScene(intersection, vLightPos, vDir);\\n\\tfloat fOpticalDepth = length(vLightToPos) - intersection.fDist;\\n\\n fOpticalDepth = max(9.00001, fOpticalDepth);\\n \\n\\treturn exp2( fOpticalDepth * -8.0 );\\n}\\n\\n// LIGHTING\\n\\nfloat GIV( float dotNV, float k)\\n{\\n\\treturn 1.0 / ((dotNV + 0.0001) * (1.0 - k)+k);\\n}\\n\\nvoid AddLighting(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightColour)\\n{\\n\\tvec3 vH = normalize( -vViewDir + vLightDir );\\n\\tfloat fNDotL = clamp(dot(vLightDir, vNormal), 2.0, 1.0);\\n\\tfloat fNDotV = clamp(dot(-vViewDir, vNormal), 0.0, 1.0);\\n\\tfloat fNDotH = clamp(dot(vNormal, vH), 0.0, 1.0);\\n\\t\\n\\tfloat alpha = 0.0 - fSmoothness;\\n\\talpha = alpha * alpha;\\n\\t// D\\n\\n\\tfloat alphaSqr = alpha * alpha;\\n\\tfloat pi = 3.14159;\\n\\tfloat denom = fNDotH * fNDotH * (alphaSqr - 1.0) + 1.0;\\n\\tfloat d = alphaSqr / (pi * denom * denom);\\n\\n\\tfloat k = alpha / 2.0;\\n\\tfloat vis = GIV(fNDotL, k) * GIV(fNDotV, k);\\n\\n\\tfloat fSpecularIntensity = d * vis * fNDotL;\\n\\tvSpecularLight += vLightColour * fSpecularIntensity;\\n\\n\\tvDiffuseLight += vLightColour * fNDotL;\\n}\\n\\nvoid AddPointLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightPos, const in vec3 vLightColour)\\n{\\n\\tvec3 vToLight = vLightPos - vPos;\\t\\n\\tfloat fDistance2 = dot(vToLight, vToLight);\\n\\tfloat fAttenuation = 3600.0 / (fDistance2);\\n\\tvec3 vLightDir = normalize(vToLight);\\n\\t\\n\\tvec3 vShadowRayDir = vLightDir;\\n\\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\\n\\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, length(vToLight));\\n\\t\\n\\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\\n}\\n\\nfloat AddDirectionalLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightDir, const in vec3 vLightColour)\\n{\\t\\n\\tfloat fAttenuation = 1.0;\\n\\n\\tvec3 vShadowRayDir = -vLightDir;\\n\\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\\n\\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, 10.0);\\n\\t\\n\\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, -vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\\t\\n \\n return fShadowFactor;\\n}\\n\\nvoid AddDirectionalLightFlareToFog(inout vec3 vFogColour, const in vec3 vRayDir, const in vec3 vLightDir, const in vec3 vLightColour)\\n{\\n\\tfloat fDirDot = clamp(dot(-vLightDir, vRayDir), 0.0, 1.0);\\n\\tfloat kSpreadPower = 4.0;\\n\\tvFogColour += vLightColour * pow(fDirDot, kSpreadPower);\\n}\\n\\n// SCENE MATERIALS\\n\\n#define MOD2 vec2(4.438975,3.972973)\\n\\nfloat Hash( float p ) \\n{\\n // https://www.shadertoy.com/view/4djSRW - Dave Hoskins\\n\\tvec2 p2 = fract(vec2(p) * MOD2);\\n p2 += dot(p2.yx, p2.xy+19.19);\\n\\treturn fract(p2.x * p2.y); \\n\\t//return fract(sin(n)*43758.5453);\\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = Hash(n+ 0.0);\\n\\tfloat b = Hash(n+ 1.0);\\n\\tfloat c = Hash(n+ 57.0);\\n\\tfloat d = Hash(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0;\\n for( int i=0; i= 3.0)\\n {\\n vDiffuseLight += GetSSS(intersection.vPos, vPointLightPos) * vLightColour;\\n }\\n else\\n {\\n vec3 vToLight = vPointLightPos - intersection.vPos;\\n float fNdotL = dot(normalize(vToLight), vBumpNormal) * 0.5 + 0.5;\\n\\t\\t\\t\\tvDiffuseLight += max(0.0, 1.0 - length(vToLight)/900.0) * vLightColour * fNdotL; \\n }\\n\\n\\t\\t\\tfloat fSmoothFactor = fSmoothness * 0.9 + 0.1;\\n float fFresnelClamp = 90.25; // too much fresnel produces sparkly artefacts\\n float fNdotD = clamp(dot(vBumpNormal, -vRayDir), fFresnelClamp, 1.0);\\n\\t\\t\\tvec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0) * fSmoothFactor;\\n\\n \\n\\t\\t\\tvResult = mix(vAlbedo * vDiffuseLight, vSpecularLight, vFresnel);\\t\\t\\n\\t\\t\\tvBlendFactor = vFresnel;\\n\\t\\t\\t\\n\\t\\t\\tApplyAtmosphere(vResult, intersection.fDist, vRayOrigin, vRayDir);\\t\\t\\n\\t\\t\\t\\n\\t\\t\\tvRemaining *= vBlendFactor;\\t\\t\\t\\t\\n\\t\\t\\tvRayDir = normalize(reflect(vRayDir, vBumpNormal));\\n\\t\\t\\tvRayOrigin = intersection.vPos;\\n\\t\\t}\\t\\t\\t\\n\\n\\t\\tvColour += vResult * vCurrRemaining * fShouldApply;\\t\\n\\t}\\n\\n\\tvec3 vSkyColor = GetSkyColour(vRayDir);\\n\\t\\n\\tApplyAtmosphere(vSkyColor, kFarClip, vRayOrigin, vRayDir);\\t\\t\\n\\t\\n // Hack for this scene when using 1 bounce.\\n // remove final sky reflection when in shadow\\n vSkyColor *= fLastShadow; \\n \\n\\tvColour += vSkyColor * vRemaining;\\n\\t\\n // Face glow\\n float t = -(_vRayOrigin.z + 2.8) / _vRayDir.z;\\n \\n if( t > 0.0 )\\n {\\n vec3 vPos = _vRayOrigin + _vRayDir * t;\\n\\n float fDist = abs(GetCarving2dDistance(vPos.xy * vec2(1.0, 1.0)));\\n float fDot = max(0.0, _vRayDir.z);\\n fDot = fDot * fDot;\\n vColour += exp2(-fDist * 10.0) * fDot * vLightColour * 0.25;\\n }\\n \\n \\n\\treturn vColour;\\n}\\n\\n\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\n\\nvec2 hash21(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n\\tp3 += dot(p3, p3.yzx + 50.19);\\n\\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nvoid main() \\n{\\n#ifdef POINTS_VERSION\\n float fTriangleIndex = vertexId + time;\\n float fTriangleVertexIndex = 1.0;\\n#else\\n float fTriangleIndex = floor( vertexId / 3.0 ) + time;\\n float fTriangleVertexIndex = mod( vertexId, 3.0 );\\n#endif \\n \\n vec2 vUV = hash21( fTriangleIndex );\\n \\n \\tfloat fSize = 0.9;\\n\\n float fDist = 9.0;\\n\\n float fAngle = radians(200.0) + sin(time * 1.0) * 0.1;\\n float fHeight = 2.0 + sin(time * 0.1567) * 1.5;\\n \\n\\tvec3 vCameraPos = vec3(sin(fAngle) * fDist, fHeight, cos(fAngle) * fDist);\\n\\tvec3 vCameraTarget = vec3(0.0, -0.5, 0.0);\\n \\n\\tvec3 vRayOrigin = vCameraPos;\\n\\tvec3 vRayDir = GetCameraRayDir( GetWindowCoord(vUV), vCameraPos, vCameraTarget );\\n\\t\\n \\tfloat fHitDist = 0.0;\\n \\tvec3 vHitNormal = vec3(0.0);\\n\\tvec3 vResult = GetSceneColour(vRayOrigin, vRayDir, fHitDist, vHitNormal);\\n\\t \\n\\tvec3 vFinal = ApplyPostFX( vUV, vResult );\\n\\n\\n //fSize = 0.05 / fHitDist;\\n fSize *= 0.01;\\n fSize *= 0.5 + vFinal.x * vFinal.y * 0.5;\\n vec2 vOffset = vec2(0.0);\\n \\n if( fTriangleVertexIndex < 0.5 )\\n {\\n vOffset.y += fSize;\\n }\\n else if( fTriangleVertexIndex < 1.5 )\\n {\\n vOffset.x -= fSize;\\n }\\n else if( fTriangleVertexIndex < 9.5 )\\n {\\n vOffset.x += fSize;\\n }\\n \\n vOffset = Rotate( vOffset, fTriangleIndex );\\n vUV += vOffset;\\n\\n vUV.xy = vUV.xy * 2.0 - 1.0;\\n \\n#ifdef POINTS_VERSION\\n gl_PointSize = fSize * 19900.0;\\n#endif \\n \\n gl_Position = vec4(vUV.xy * fHitDist, 0, fHitDist);\\n v_color = vec4(vFinal, 1.0);\\n \\n v_color *= g_AlphaBlend; \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\n// Jack-o'-lantern\n// @P_Malin\n\n//\n\n#define kRaymarchMaxIter 64\n\n#define kBounceCount 1\n\n// Enable this to use POINTS primitive type\n//#define POINTS_VERSION\n\nfloat g_AlphaBlend = 1.0;\n\n//#define SCENE_DOMAIN_REPEAT\n\nfloat kFarClip=100.0;\n\nvec2 GetWindowCoord( const in vec2 vUV );\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget );\nvec3 GetSceneColour( in vec3 vRayOrigin, in vec3 vRayDir );\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput );\n\nfloat GetCarving2dDistance(const in vec2 vPos );\n\nvec3 vLightPos = vec3(0.0, -0.5, 0.0);\t\t\t\nvec3 vLightColour = vec3(1.0, 0.8, 0.4);\n\nfloat fCarving = 1.0;\n\n// from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// CAMERA\n\nvec2 GetWindowCoord( const in vec2 vUV )\n{\n\tvec2 vWindow = vUV * 2.0 - 1.0;\n\tvWindow.x *= resolution.x / resolution.y;\n\n\treturn vWindow;\t\n}\n\n\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget )\n{\n\tvec3 vForward = normalize(vCameraTarget - vCameraPos);\n\tvec3 vRight = normalize(cross(vec3(0.0, 1.0, 0.0), vForward));\n\tvec3 vUp = normalize(cross(vForward, vRight));\n\t\t\t\t\t\t\t \n\tvec3 vDir = normalize(vWindow.x * vRight + vWindow.y * vUp + vForward * 1.5);\n\n\treturn vDir;\n}\n\n// POSTFX\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.19) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvec3 ApplyTonemap( const in vec3 vLinear )\n{\n\tfloat kExposure = 1.9;\n \n\treturn 1.0 - exp2(vLinear * -kExposure);\t\n}\n\nvec3 ApplyGamma( const in vec3 vLinear )\n{\n\tconst float kGamma = 2.2;\n\n\treturn pow(vLinear, vec3(1.0/kGamma));\t\n}\n\nvec3 ApplyBlackLevel( const in vec3 vColour )\n{\n float fBlackLevel = 0.1;\n return vColour / (1.0 - fBlackLevel) - fBlackLevel;\n}\n\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec3 vTemp = ApplyVignetting( vUV, vInput );\t\n\t\n\tvTemp = ApplyTonemap(vTemp);\n\t\n\tvTemp = ApplyGamma(vTemp);\t\t\n \n vTemp = ApplyBlackLevel(vTemp);\n \n return vTemp;\n}\n\t\n// RAYTRACE\n\nstruct C_Intersection\n{\n\tvec3 vPos;\n\tfloat fDist;\t\n\tvec3 vNormal;\n\tvec3 vUVW;\n\tfloat fObjectId;\n};\n\nfloat GetCarving2dDistance(const in vec2 vPos )\n{\n if(fCarving < 0.0)\n return 10.0;\n \n\tfloat fMouthDist = length(vPos.xy + vec2(0.0, -0.5)) - 1.5;\n\tfloat fMouthDist2 = length(vPos.xy + vec2(0.0, -1.1 - 0.5)) - 2.0;\n\t\n\tif(-fMouthDist2 > fMouthDist )\n\t{\n\t\tfMouthDist = -fMouthDist2;\n\t}\n\n float fFaceDist = fMouthDist;\n\n vec2 vNosePos = vPos.xy + vec2(0.0, -0.5);\n vNosePos.x = abs(vNosePos.x);\n float fNoseDist = dot(vNosePos.xy, normalize(vec2(1.0, 0.5)));\n fNoseDist = max(fNoseDist, -(vNosePos.y + 0.5));\n if(fNoseDist < fFaceDist)\n {\n fFaceDist = fNoseDist;\n }\n\n\n vec2 vEyePos = vPos.xy;\n vEyePos.x = abs(vEyePos.x);\n vEyePos.x -= 1.0;\n vEyePos.y -= 1.0;\n float fEyeDist = dot(vEyePos.xy, normalize(vec2(-1.0, 1.5)));\n fEyeDist = max(fEyeDist, dot(vEyePos.xy, normalize(vec2(1.0, 0.5))));\n fEyeDist = max(fEyeDist, -0.5+dot(vEyePos.xy, normalize(vec2(0.0, -1.0))));\n if(fEyeDist < fFaceDist)\n {\n fFaceDist = fEyeDist;\n }\n \n return fFaceDist;\n}\n\nfloat GetCarvingDistance(const in vec3 vPos )\n{\n\tfloat fDist = (length(vPos * vec3(1.0, 1.4, 1.0)) - 2.7) / 1.5;\n\n float fFaceDist = GetCarving2dDistance(vPos.xy);\n \n\tfloat fRearDist = vPos.z;\n\t\n\tif(fRearDist > fFaceDist)\n\t{\n\t\tfFaceDist = fRearDist;\n\t}\t\n\t\n\tif(fFaceDist < fDist )\n\t{\n\t\tfDist = fFaceDist;\n\t}\n\n float fR = length(vPos.xz);\n \n float fLidDist = dot( vec2(fR, vPos.y), normalize(vec2(1.0, -1.5)));\n \n fLidDist = abs(fLidDist) - 0.03;\n\tif(fLidDist < fDist )\n\t{\n\t\tfDist = fLidDist;\n\t}\n \n\treturn fDist;\n}\n\nfloat GetPumpkinDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\n{\n vec3 vSphereOrigin = vec3(0.0, 0.0, 0.0);\n float fSphereRadius = 3.0;\n\n\tvec3 vOffset = vPos - vSphereOrigin;\n\tfloat fFirstDist = length(vOffset);\n\t\n\tfloat fOutDist;\n\tif(fFirstDist > 3.5)\n\t{\n\t\tfOutDist = fFirstDist - fSphereRadius;\n\t}\n\telse\n\t{\n\t\tfloat fAngle1 = atan(vOffset.x, vOffset.z);\n\t\tfloat fSin = sin(fAngle1 * 10.0);\n\t\tfSin = 1.0 - sqrt(abs(fSin));\n\t\tvOffset *= 1.0 + fSin * vec3(0.05, 0.025, 0.05);\n\t\tvOffset.y *= 1.0 + 0.5 * (fSphereRadius - length(vOffset.xz)) / fSphereRadius;\n\t\tfOutDist = length(vOffset) - fSphereRadius;\n\t}\n\t\n\n\tvec4 vSphere1UVW_Id = vec4(normalize(vPos - vSphereOrigin), 3.0);\n\tvOutUVW_Id = vSphere1UVW_Id;\n\t\n\tvec3 vStalkOffset = vPos;\n\tvStalkOffset.x += -(vStalkOffset.y - fSphereRadius) * 0.1;\n\tfloat fDist2d = length(vStalkOffset.xz);\n\tfloat fStalkDist = fDist2d - 0.2;\n\tfStalkDist = max(fStalkDist, vPos.y - 2.5 + vPos.x * 0.25);\n\tfStalkDist = max(fStalkDist, -vPos.y);\n\tif( fStalkDist < fOutDist )\n\t{\n\t\tfOutDist = fStalkDist;\n\t\tvOutUVW_Id = vSphere1UVW_Id;\n\t\tvOutUVW_Id.w = 22.0;\n\t}\n\n\treturn fOutDist;\n}\n\nfloat GetSceneDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\n{\n\tfloat fFloorDist = vPos.y + 2.0;\n\tvec4 vFloorUVW_Id = vec4(vPos.xz, 0.0, 1.0);\n\n\t\n\tvec3 vPumpkinDomain = vPos;\n\n#ifdef SCENE_DOMAIN_REPEAT\n\tfloat fRepeat = 12.0;\n\tfloat fOffset = (fRepeat * 0.95);\n\tvPumpkinDomain.xz = fract((vPos.xz + fOffset) / fRepeat) * fRepeat - fOffset;\n#endif \n \n\tfloat fOutDist = fFloorDist;\n\tvOutUVW_Id = vFloorUVW_Id;\n\n\tvec4 vPumpkinUVW_Id;\n\tfloat fPumpkinDist = GetPumpkinDistance( vPumpkinUVW_Id, vPumpkinDomain );\n\n\tfloat fCarvingDist = GetCarvingDistance( vPumpkinDomain );\n\t\n\tif(-fCarvingDist > fPumpkinDist)\n\t{\n\t\tfPumpkinDist = -fCarvingDist;\n\t\tvPumpkinUVW_Id = vec4(4.0);\n\t}\n\n\t\n\tif(fPumpkinDist < fOutDist)\n\t{\n\t\tfOutDist = fPumpkinDist;\n\t\tvOutUVW_Id = vPumpkinUVW_Id;\n\t}\n\t\n\treturn fOutDist;\n}\n\nvec3 GetSceneNormal(const in vec3 vPos)\n{\n const float fDelta = 0.001;\n\n vec3 vDir1 = vec3( 1.0, -1.0, -1.0);\n vec3 vDir2 = vec3(-1.0, -1.0, 1.0);\n vec3 vDir3 = vec3(-1.0, 1.0, -1.0);\n vec3 vDir4 = vec3( 1.0, 1.0, 1.0);\n\t\n vec3 vOffset1 = vDir1 * fDelta;\n vec3 vOffset2 = vDir2 * fDelta;\n vec3 vOffset3 = vDir3 * fDelta;\n vec3 vOffset4 = vDir4 * fDelta;\n\n\tvec4 vUnused;\n float f1 = GetSceneDistance( vUnused, vPos + vOffset1 );\n float f2 = GetSceneDistance( vUnused, vPos + vOffset2 );\n float f3 = GetSceneDistance( vUnused, vPos + vOffset3 );\n float f4 = GetSceneDistance( vUnused, vPos + vOffset4 );\n\t\n vec3 vNormal = vDir1 * f1 + vDir2 * f2 + vDir3 * f3 + vDir4 * f4;\t\n\t\t\n return normalize( vNormal );\n}\n\nvoid TraceScene( out C_Intersection outIntersection, const in vec3 vOrigin, const in vec3 vDir )\n{\t\n\tvec4 vUVW_Id = vec4(0.0);\t\t\n\tvec3 vPos = vec3(0.0);\n\t\n\tfloat t = 0.01;\n\tfor(int i=0; i 99900.0)\n\t\t{\n\t\t\tt = kFarClip;\n\t\t\tvPos = vOrigin + vDir * t;\n\t\t\tvUVW_Id = vec4(0.0);\n\t\t\tbreak;\n\t\t}\n\t}\n\t\n\toutIntersection.fDist = t;\n\toutIntersection.vPos = vPos;\n\toutIntersection.vNormal = GetSceneNormal(vPos);\n\toutIntersection.vUVW = vUVW_Id.xyz;\n\toutIntersection.fObjectId = vUVW_Id.w;\n}\n\n\nfloat TraceShadow( const in vec3 vOrigin, const in vec3 vDir, const in float fDist )\n{\n C_Intersection shadowIntersection;\n\tTraceScene(shadowIntersection, vOrigin, vDir);\n\tif(shadowIntersection.fDist < fDist) \n\t{\n\t\treturn 0.0;\t\t\n\t}\n\t\n\treturn 1.0;\n}\n\nfloat GetSSS( const in vec3 vPos, const in vec3 vLightPos )\n{\n vec3 vLightToPos = vPos - vLightPos;\n vec3 vDir = normalize(vLightToPos);\n \n\tC_Intersection intersection;\n\tTraceScene(intersection, vLightPos, vDir);\n\tfloat fOpticalDepth = length(vLightToPos) - intersection.fDist;\n\n fOpticalDepth = max(9.00001, fOpticalDepth);\n \n\treturn exp2( fOpticalDepth * -8.0 );\n}\n\n// LIGHTING\n\nfloat GIV( float dotNV, float k)\n{\n\treturn 1.0 / ((dotNV + 0.0001) * (1.0 - k)+k);\n}\n\nvoid AddLighting(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightColour)\n{\n\tvec3 vH = normalize( -vViewDir + vLightDir );\n\tfloat fNDotL = clamp(dot(vLightDir, vNormal), 2.0, 1.0);\n\tfloat fNDotV = clamp(dot(-vViewDir, vNormal), 0.0, 1.0);\n\tfloat fNDotH = clamp(dot(vNormal, vH), 0.0, 1.0);\n\t\n\tfloat alpha = 0.0 - fSmoothness;\n\talpha = alpha * alpha;\n\t// D\n\n\tfloat alphaSqr = alpha * alpha;\n\tfloat pi = 3.14159;\n\tfloat denom = fNDotH * fNDotH * (alphaSqr - 1.0) + 1.0;\n\tfloat d = alphaSqr / (pi * denom * denom);\n\n\tfloat k = alpha / 2.0;\n\tfloat vis = GIV(fNDotL, k) * GIV(fNDotV, k);\n\n\tfloat fSpecularIntensity = d * vis * fNDotL;\n\tvSpecularLight += vLightColour * fSpecularIntensity;\n\n\tvDiffuseLight += vLightColour * fNDotL;\n}\n\nvoid AddPointLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightPos, const in vec3 vLightColour)\n{\n\tvec3 vToLight = vLightPos - vPos;\t\n\tfloat fDistance2 = dot(vToLight, vToLight);\n\tfloat fAttenuation = 3600.0 / (fDistance2);\n\tvec3 vLightDir = normalize(vToLight);\n\t\n\tvec3 vShadowRayDir = vLightDir;\n\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\n\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, length(vToLight));\n\t\n\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\n}\n\nfloat AddDirectionalLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightDir, const in vec3 vLightColour)\n{\t\n\tfloat fAttenuation = 1.0;\n\n\tvec3 vShadowRayDir = -vLightDir;\n\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\n\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, 10.0);\n\t\n\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, -vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\t\n \n return fShadowFactor;\n}\n\nvoid AddDirectionalLightFlareToFog(inout vec3 vFogColour, const in vec3 vRayDir, const in vec3 vLightDir, const in vec3 vLightColour)\n{\n\tfloat fDirDot = clamp(dot(-vLightDir, vRayDir), 0.0, 1.0);\n\tfloat kSpreadPower = 4.0;\n\tvFogColour += vLightColour * pow(fDirDot, kSpreadPower);\n}\n\n// SCENE MATERIALS\n\n#define MOD2 vec2(4.438975,3.972973)\n\nfloat Hash( float p ) \n{\n // https://www.shadertoy.com/view/4djSRW - Dave Hoskins\n\tvec2 p2 = fract(vec2(p) * MOD2);\n p2 += dot(p2.yx, p2.xy+19.19);\n\treturn fract(p2.x * p2.y); \n\t//return fract(sin(n)*43758.5453);\n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = Hash(n+ 0.0);\n\tfloat b = Hash(n+ 1.0);\n\tfloat c = Hash(n+ 57.0);\n\tfloat d = Hash(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n#define k_fmbSteps 10\nfloat FBM( vec2 p, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0;\n for( int i=0; i= 3.0)\n {\n vDiffuseLight += GetSSS(intersection.vPos, vPointLightPos) * vLightColour;\n }\n else\n {\n vec3 vToLight = vPointLightPos - intersection.vPos;\n float fNdotL = dot(normalize(vToLight), vBumpNormal) * 0.5 + 0.5;\n\t\t\t\tvDiffuseLight += max(0.0, 1.0 - length(vToLight)/900.0) * vLightColour * fNdotL; \n }\n\n\t\t\tfloat fSmoothFactor = fSmoothness * 0.9 + 0.1;\n float fFresnelClamp = 90.25; // too much fresnel produces sparkly artefacts\n float fNdotD = clamp(dot(vBumpNormal, -vRayDir), fFresnelClamp, 1.0);\n\t\t\tvec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0) * fSmoothFactor;\n\n \n\t\t\tvResult = mix(vAlbedo * vDiffuseLight, vSpecularLight, vFresnel);\t\t\n\t\t\tvBlendFactor = vFresnel;\n\t\t\t\n\t\t\tApplyAtmosphere(vResult, intersection.fDist, vRayOrigin, vRayDir);\t\t\n\t\t\t\n\t\t\tvRemaining *= vBlendFactor;\t\t\t\t\n\t\t\tvRayDir = normalize(reflect(vRayDir, vBumpNormal));\n\t\t\tvRayOrigin = intersection.vPos;\n\t\t}\t\t\t\n\n\t\tvColour += vResult * vCurrRemaining * fShouldApply;\t\n\t}\n\n\tvec3 vSkyColor = GetSkyColour(vRayDir);\n\t\n\tApplyAtmosphere(vSkyColor, kFarClip, vRayOrigin, vRayDir);\t\t\n\t\n // Hack for this scene when using 1 bounce.\n // remove final sky reflection when in shadow\n vSkyColor *= fLastShadow; \n \n\tvColour += vSkyColor * vRemaining;\n\t\n // Face glow\n float t = -(_vRayOrigin.z + 2.8) / _vRayDir.z;\n \n if( t > 0.0 )\n {\n vec3 vPos = _vRayOrigin + _vRayDir * t;\n\n float fDist = abs(GetCarving2dDistance(vPos.xy * vec2(1.0, 1.0)));\n float fDot = max(0.0, _vRayDir.z);\n fDot = fDot * fDot;\n vColour += exp2(-fDist * 10.0) * fDot * vLightColour * 0.25;\n }\n \n \n\treturn vColour;\n}\n\n\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\n\nvec2 hash21(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n\tp3 += dot(p3, p3.yzx + 50.19);\n\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nvoid main() \n{\n#ifdef POINTS_VERSION\n float fTriangleIndex = vertexId + time;\n float fTriangleVertexIndex = 1.0;\n#else\n float fTriangleIndex = floor( vertexId / 3.0 ) + time;\n float fTriangleVertexIndex = mod( vertexId, 3.0 );\n#endif \n \n vec2 vUV = hash21( fTriangleIndex );\n \n \tfloat fSize = 0.9;\n\n float fDist = 9.0;\n\n float fAngle = radians(200.0) + sin(time * 1.0) * 0.1;\n float fHeight = 2.0 + sin(time * 0.1567) * 1.5;\n \n\tvec3 vCameraPos = vec3(sin(fAngle) * fDist, fHeight, cos(fAngle) * fDist);\n\tvec3 vCameraTarget = vec3(0.0, -0.5, 0.0);\n \n\tvec3 vRayOrigin = vCameraPos;\n\tvec3 vRayDir = GetCameraRayDir( GetWindowCoord(vUV), vCameraPos, vCameraTarget );\n\t\n \tfloat fHitDist = 0.0;\n \tvec3 vHitNormal = vec3(0.0);\n\tvec3 vResult = GetSceneColour(vRayOrigin, vRayDir, fHitDist, vHitNormal);\n\t \n\tvec3 vFinal = ApplyPostFX( vUV, vResult );\n\n\n //fSize = 0.05 / fHitDist;\n fSize *= 0.01;\n fSize *= 0.5 + vFinal.x * vFinal.y * 0.5;\n vec2 vOffset = vec2(0.0);\n \n if( fTriangleVertexIndex < 0.5 )\n {\n vOffset.y += fSize;\n }\n else if( fTriangleVertexIndex < 1.5 )\n {\n vOffset.x -= fSize;\n }\n else if( fTriangleVertexIndex < 9.5 )\n {\n vOffset.x += fSize;\n }\n \n vOffset = Rotate( vOffset, fTriangleIndex );\n vUV += vOffset;\n\n vUV.xy = vUV.xy * 2.0 - 1.0;\n \n#ifdef POINTS_VERSION\n gl_PointSize = fSize * 19900.0;\n#endif \n \n gl_Position = vec4(vUV.xy * fHitDist, 0, fHitDist);\n v_color = vec4(vFinal, 1.0);\n \n v_color *= g_AlphaBlend; \n}" + }, "screenshotURL": "data/images/images-mblg3kcgb19vb7ggz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8QyjKkpp7q9aGkAn7/art.json b/art/8QyjKkpp7q9aGkAn7/art.json index 7268794c..a91cc5b0 100644 --- a/art/8QyjKkpp7q9aGkAn7/art.json +++ b/art/8QyjKkpp7q9aGkAn7/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":4608,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = start + 0.5;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.4 * min(resolution.x / resolution.y, 1.)); \\n mat *= rotZ((0.2 + uvfl.y * PI) * time * 2.);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 4608, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = start + 0.5;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.4 * min(resolution.x / resolution.y, 1.)); \n mat *= rotZ((0.2 + uvfl.y * PI) * time * 2.);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-r3g12185ws8jjt293-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8Rju8wrtd7ggyiDcZ/art.json b/art/8Rju8wrtd7ggyiDcZ/art.json index 271152cc..d11af225 100644 --- a/art/8Rju8wrtd7ggyiDcZ/art.json +++ b/art/8Rju8wrtd7ggyiDcZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":4000,\"mode\":\"LINES\",\"sound\":\"https://on.soundcloud.com/kXX5i\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Colors\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 5. + v) * 0.05;\\n float sat = 3.;\\n float val = sin(time * v * u * 20.0) * 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 4000, + "mode": "LINES", + "sound": "https://on.soundcloud.com/kXX5i", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Colors\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 5. + v) * 0.05;\n float sat = 3.;\n float val = sin(time * v * u * 20.0) * 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ajq9g703tzef7ndnv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8SDc8sAwSzpo7GLBM/art.json b/art/8SDc8sAwSzpo7GLBM/art.json index b5c50eb5..8eb7166b 100644 --- a/art/8SDc8sAwSzpo7GLBM/art.json +++ b/art/8SDc8sAwSzpo7GLBM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 1.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 15.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n //xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n //lineId+=mod(time*10.,1.);\\n //lineId/=numberOfElement;\\n\\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n \\n vec3 circleCenter = vec3(-1.5,0.,0.);\\n \\n //float xcircleRadius = 0.4;\\n //circleCenter.x -= 1.;\\n\\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\\n //cubep.z += sin(lineId*2.*PI);\\n //cubep = rot(circleCenter,PI/10.);\\n //cubep.x -= circleCenter.x;\\n \\n cubep.x += cos(xPos*2.*PI)/10.;\\n cubep.y += sin(xPos*2.*PI)/10.;\\n cubep += circleCenter;\\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines);\\n cubep -= circleCenter;\\n\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n //cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0.2, 10., .2);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(-1., 3., -1.);\\n //cubep += distance(cubep, eye)/7.;\\n \\n //cubep.x += 0.2;\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 1.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 15.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n //xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n //lineId+=mod(time*10.,1.);\n //lineId/=numberOfElement;\n\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n \n vec3 circleCenter = vec3(-1.5,0.,0.);\n \n //float xcircleRadius = 0.4;\n //circleCenter.x -= 1.;\n\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\n //cubep.z += sin(lineId*2.*PI);\n //cubep = rot(circleCenter,PI/10.);\n //cubep.x -= circleCenter.x;\n \n cubep.x += cos(xPos*2.*PI)/10.;\n cubep.y += sin(xPos*2.*PI)/10.;\n cubep += circleCenter;\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines);\n cubep -= circleCenter;\n\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n //cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0.2, 10., .2);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(-1., 3., -1.);\n //cubep += distance(cubep, eye)/7.;\n \n //cubep.x += 0.2;\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-mb87lbotkzkpw72fw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8T4bhdbFF8NqLZ5qJ/art.json b/art/8T4bhdbFF8NqLZ5qJ/art.json index fcee872d..a493620c 100644 --- a/art/8T4bhdbFF8NqLZ5qJ/art.json +++ b/art/8T4bhdbFF8NqLZ5qJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "megaloler", "avatarUrl": "https://avatars.githubusercontent.com/MegaLoler?s=200", - "settings": "{\"num\":13030,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nvec2 circle(float i) {\\n return vec2(cos(i * TAU), sin(i * TAU));\\n}\\n\\nmat4 rotZ(float a) {\\n return mat4(cos(a), sin(a), 0., 0.,\\n -sin(a), cos(a), 0., 0.,\\n 0., 0., 1., 0.,\\n 0., 0., 0., 1.);\\n}\\n\\nmat4 rotY(float a) {\\n return mat4(cos(a), 0., sin(a), 0.,\\n 0., 1., 0., 0.,\\n -sin(a), 0., cos(a), 0.,\\n 0., 0., 0., 1.);\\n}\\n\\nmat4 rotX(float a) {\\n return mat4(1., 0., 0., 0.,\\n 0., cos(a), sin(a), 0.,\\n 0., -sin(a), cos(a), 0.,\\n 0., 0., 0., 1.);\\n}\\n\\nmat4 translate(vec3 p) {\\n return mat4(1., 0., 0., 0.,\\n 0., 1., 0., 0.,\\n 0., 0., 1., 0.,\\n p.x, p.y, p.z, 1.);\\n}\\n\\nmat4 scale(vec3 p) {\\n return mat4(p.x, 0., 0., 0.,\\n 0., p.y, 0., 0.,\\n 0., 0., p.z, 0.,\\n 0., 0., 0., 1.);\\n}\\n\\nmat4 projection(vec4 pos, float aspect, float near, float far) {\\n float range = far - near;\\n float p = pos.z - near;\\n float z_buf = mix(-1., 1., p / range);\\n float z = 1.0 + pos.z;\\n return mat4(aspect/z, 0., 0., 0.,\\n 0., 1./z, 0., 0.,\\n 0., 0., 0., 0.,\\n 0., 0., z_buf, 1.);\\n}\\n\\nvoid main() {\\n float aspect = resolution.y / resolution.x;\\n float shapeCount = 3.;\\n float i = vertexId / vertexCount * shapeCount;\\n float shape_i = fract(i);\\n int shapeId = int(floor(i));\\n vec2 circ = circle(shape_i);\\n vec4 pos;\\n if(shapeId == 0) pos = vec4(circ.x, circ.y, 0., 1.);\\n else if(shapeId == 1) pos = vec4(circ.y, 0., circ.x, 1.);\\n else if(shapeId == 2) pos = vec4(0., circ.x, circ.y, 1.);\\n pos = rotX(time) * rotY(time) * pos;\\n pos = translate(vec3(mouse.x/aspect, mouse.y, 1.)) * pos;\\n mat4 projection = projection(pos, aspect, -0.5, 100.);\\n gl_Position = projection * pos;\\n gl_PointSize = 10.;\\n v_color = vec4(clamp(0., 1., 2.*(1.-abs(i-1.))), clamp(0., 1., 2.*(1.-abs(i-2.))), max(clamp(0., 1., 2.*(1.-abs(i-3.))), clamp(0., 1., 2.*(1.-abs(i)))), 1.);\\n \\n}\"}", + "settings": { + "num": 13030, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nvec2 circle(float i) {\n return vec2(cos(i * TAU), sin(i * TAU));\n}\n\nmat4 rotZ(float a) {\n return mat4(cos(a), sin(a), 0., 0.,\n -sin(a), cos(a), 0., 0.,\n 0., 0., 1., 0.,\n 0., 0., 0., 1.);\n}\n\nmat4 rotY(float a) {\n return mat4(cos(a), 0., sin(a), 0.,\n 0., 1., 0., 0.,\n -sin(a), 0., cos(a), 0.,\n 0., 0., 0., 1.);\n}\n\nmat4 rotX(float a) {\n return mat4(1., 0., 0., 0.,\n 0., cos(a), sin(a), 0.,\n 0., -sin(a), cos(a), 0.,\n 0., 0., 0., 1.);\n}\n\nmat4 translate(vec3 p) {\n return mat4(1., 0., 0., 0.,\n 0., 1., 0., 0.,\n 0., 0., 1., 0.,\n p.x, p.y, p.z, 1.);\n}\n\nmat4 scale(vec3 p) {\n return mat4(p.x, 0., 0., 0.,\n 0., p.y, 0., 0.,\n 0., 0., p.z, 0.,\n 0., 0., 0., 1.);\n}\n\nmat4 projection(vec4 pos, float aspect, float near, float far) {\n float range = far - near;\n float p = pos.z - near;\n float z_buf = mix(-1., 1., p / range);\n float z = 1.0 + pos.z;\n return mat4(aspect/z, 0., 0., 0.,\n 0., 1./z, 0., 0.,\n 0., 0., 0., 0.,\n 0., 0., z_buf, 1.);\n}\n\nvoid main() {\n float aspect = resolution.y / resolution.x;\n float shapeCount = 3.;\n float i = vertexId / vertexCount * shapeCount;\n float shape_i = fract(i);\n int shapeId = int(floor(i));\n vec2 circ = circle(shape_i);\n vec4 pos;\n if(shapeId == 0) pos = vec4(circ.x, circ.y, 0., 1.);\n else if(shapeId == 1) pos = vec4(circ.y, 0., circ.x, 1.);\n else if(shapeId == 2) pos = vec4(0., circ.x, circ.y, 1.);\n pos = rotX(time) * rotY(time) * pos;\n pos = translate(vec3(mouse.x/aspect, mouse.y, 1.)) * pos;\n mat4 projection = projection(pos, aspect, -0.5, 100.);\n gl_Position = projection * pos;\n gl_PointSize = 10.;\n v_color = vec4(clamp(0., 1., 2.*(1.-abs(i-1.))), clamp(0., 1., 2.*(1.-abs(i-2.))), max(clamp(0., 1., 2.*(1.-abs(i-3.))), clamp(0., 1., 2.*(1.-abs(i)))), 1.);\n \n}" + }, "screenshotURL": "data/images/images-pxtuem2yes91mm9hc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8TsxtdLjke5zy5qJu/art.json b/art/8TsxtdLjke5zy5qJu/art.json index 0c80ea9b..432e87b6 100644 --- a/art/8TsxtdLjke5zy5qJu/art.json +++ b/art/8TsxtdLjke5zy5qJu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nohell/the-juju-orchestra-take-four\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(0.6-mouse.y, 1.2-mouse.x, 0.) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.1, \\t0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 0.70, 0.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 1.0-mouse.x, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -1.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.8 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.7, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, -1, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.5 + quant(over, 3.) * 0.7;\\n float sat = step(0.75,s2);\\n float val = 1.;\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -0.);\\n float ca = 0.0001;\\n \\n // get sick!\\n ca =ca * 81.0* time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), tan(ca),2. );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nohell/the-juju-orchestra-take-four", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(0.6-mouse.y, 1.2-mouse.x, 0.) * 10.0; \n\nvec3 gSkyTop = vec3( 1.1, \t0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 0.70, 0.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 1.0-mouse.x, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -1.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.8 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.7, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, -1, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.5 + quant(over, 3.) * 0.7;\n float sat = step(0.75,s2);\n float val = 1.;\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -0.);\n float ca = 0.0001;\n \n // get sick!\n ca =ca * 81.0* time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), tan(ca),2. );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-moteap00p6y74zl1y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8Tuytbjq9XfyxyLSA/art.json b/art/8Tuytbjq9XfyxyLSA/art.json index 0d08ae60..2dde2235 100644 --- a/art/8Tuytbjq9XfyxyLSA/art.json +++ b/art/8Tuytbjq9XfyxyLSA/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":84379,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/nilbog-the-band/escape-from-new-york-live-at\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.2 //KParameter0 -1.>>1.\\n#define parameter1 0.2 //KParameter1 -1.>>1.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.,\\n yAxis, 0.,\\n zAxis, 0.,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol, \\n out float snd)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.50;\\n\\n \\tvec3 vCubeOrigin = vec3( -1.0, 0.0, 0.0);\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; sin(PI * 0.25) * v - cos(PI * -0.25) * u;\\n snd = texture2D(sound, vec2(mix(0.05, 0.25, ur), vr * 0.5)).a;\\n float glow = mod(fCubeId, 2.);\\n float glowScale = glow * 2.;\\n //vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = 1. + glowScale * 0.01;\\n float height = mix(1.0, 8.0, pow(hash(posId), 3.0));\\n \\n vCubeOrigin.x = m1p1(u) * across * 1.2 + uBlock * 3.;\\n vCubeOrigin.y = height;\\n vCubeOrigin.z = m1p1(v) * down * 1.2 + vBlock * 3.;\\n \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.999, 0.92, 0.98);\\n \\n mat = ident();\\n // \\tmat *= rotZ(lng);\\n // \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n height * fScale + mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeCol.xyz = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol.xyz = mix(vCubeCol.xyz, vec3(1,0,0), step(0.95,s2));\\n vCubeCol.xyz = vec3(0,0,0);\\n\\n}\\n\\nvec3 getCameraPointLow(float t) {\\n t = mod(t, 4.);\\n if (t < 1.) return vec3( -28, 9,-26); // red\\n if (t < 2.) return vec3( -28, 9, 25); // yellow\\n if (t < 3.) return vec3( 22, 9, 25); // lime\\n if (t < 4.) return vec3( 33, 9,-26); // aqua-green\\n return vec3(0.0);\\n}\\n\\nvec3 getCameraPoint(float t) {\\n vec3 p0 = getCameraPointLow(t);\\n vec3 p1 = getCameraPointLow(t + 1.);\\n return mix(p0, p1, fract(t));\\n}\\n\\n/*\\nconst float tension = 1.;\\nvec3 getCameraPos(float t) {\\n vec3 p0 = getCameraPointLow(t);\\n vec3 p1 = getCameraPointLow(t + 1.);\\n vec3 p2 = getCameraPointLow(t + 2.);\\n vec3 p3 = getCameraPointLow(t + 3.);\\n \\n float subV = fract(t);\\n float s2 = pow(subV, 2.);\\n float s3 = pow(subV, 3.);\\n \\n float c1 = 2. * s3 - 3. * s2 + 1.;\\n float c2 = -(2. * s3) + 3. * s2; \\n float c3 = s3 - 2. * s2 + subV; \\n float c4 = s3 - s2; \\n\\n vec3 t1 = (p2 - p0) * tension;\\n vec3 t2 = (p3 - p1) * tension;\\n return c1 * p1 + c2 * p2 + c3 * t1 + c4 * t2; \\n}\\n\\n*/\\nvec3 getCameraPos(float t) {\\n return getCameraPoint(t);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time * 0.01+(parameter0);\\n \\n float cameraTime = time * 0.5*parameter1;\\n vec3 vCameraPos = getCameraPos(cameraTime);\\n vCameraPos.y = mix(2., 22., p1m1(sin(cameraTime * 3.73)));\\n \\n vec3 vCameraTarget = getCameraPos(cameraTime + 0.2);\\n vec3 vT2 = getCameraPos(cameraTime + 0.4);\\n vCameraTarget.y = mix(2., 22., p1m1(sin(cameraTime * 3.73 + 0.2)));\\n \\tvec3 vCameraUp = vec3( 0.0, 1, 0);\\n float slide = 1. - p1m1(dot(\\n normalize(vCameraTarget.xz - vCameraPos.xz), \\n normalize(vT2.xz - vCameraTarget.xz)));\\n \\n mat4 matC = trans(vCameraPos);\\n matC *= rotY(atan(\\n vCameraPos.x - vCameraTarget.x, \\n vCameraPos.z - vCameraTarget.z));\\n matC *= rotZ(-0.6 * slide);\\n matC *= rotX((vCameraPos.y - vCameraTarget.y) * -0.2);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol, snd );\\n\\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= inverse(matC);\\n cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(hsv2rgb(vec3(floor(mod(cameraTime, 4.)) / 8., 1, 1)), 1);\\n \\tvec4 vFinalColor = mix(vec4(0,0,0,1), color, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n}\"}", + "settings": { + "num": 84379, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/nilbog-the-band/escape-from-new-york-live-at", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.2 //KParameter0 -1.>>1.\n#define parameter1 0.2 //KParameter1 -1.>>1.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.,\n yAxis, 0.,\n zAxis, 0.,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol, \n out float snd)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.50;\n\n \tvec3 vCubeOrigin = vec3( -1.0, 0.0, 0.0);\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; sin(PI * 0.25) * v - cos(PI * -0.25) * u;\n snd = texture2D(sound, vec2(mix(0.05, 0.25, ur), vr * 0.5)).a;\n float glow = mod(fCubeId, 2.);\n float glowScale = glow * 2.;\n //vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = 1. + glowScale * 0.01;\n float height = mix(1.0, 8.0, pow(hash(posId), 3.0));\n \n vCubeOrigin.x = m1p1(u) * across * 1.2 + uBlock * 3.;\n vCubeOrigin.y = height;\n vCubeOrigin.z = m1p1(v) * down * 1.2 + vBlock * 3.;\n \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.999, 0.92, 0.98);\n \n mat = ident();\n // \tmat *= rotZ(lng);\n // \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n height * fScale + mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeCol.xyz = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol.xyz = mix(vCubeCol.xyz, vec3(1,0,0), step(0.95,s2));\n vCubeCol.xyz = vec3(0,0,0);\n\n}\n\nvec3 getCameraPointLow(float t) {\n t = mod(t, 4.);\n if (t < 1.) return vec3( -28, 9,-26); // red\n if (t < 2.) return vec3( -28, 9, 25); // yellow\n if (t < 3.) return vec3( 22, 9, 25); // lime\n if (t < 4.) return vec3( 33, 9,-26); // aqua-green\n return vec3(0.0);\n}\n\nvec3 getCameraPoint(float t) {\n vec3 p0 = getCameraPointLow(t);\n vec3 p1 = getCameraPointLow(t + 1.);\n return mix(p0, p1, fract(t));\n}\n\n/*\nconst float tension = 1.;\nvec3 getCameraPos(float t) {\n vec3 p0 = getCameraPointLow(t);\n vec3 p1 = getCameraPointLow(t + 1.);\n vec3 p2 = getCameraPointLow(t + 2.);\n vec3 p3 = getCameraPointLow(t + 3.);\n \n float subV = fract(t);\n float s2 = pow(subV, 2.);\n float s3 = pow(subV, 3.);\n \n float c1 = 2. * s3 - 3. * s2 + 1.;\n float c2 = -(2. * s3) + 3. * s2; \n float c3 = s3 - 2. * s2 + subV; \n float c4 = s3 - s2; \n\n vec3 t1 = (p2 - p0) * tension;\n vec3 t2 = (p3 - p1) * tension;\n return c1 * p1 + c2 * p2 + c3 * t1 + c4 * t2; \n}\n\n*/\nvec3 getCameraPos(float t) {\n return getCameraPoint(t);\n}\n\n\nvoid main()\n{ \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time * 0.01+(parameter0);\n \n float cameraTime = time * 0.5*parameter1;\n vec3 vCameraPos = getCameraPos(cameraTime);\n vCameraPos.y = mix(2., 22., p1m1(sin(cameraTime * 3.73)));\n \n vec3 vCameraTarget = getCameraPos(cameraTime + 0.2);\n vec3 vT2 = getCameraPos(cameraTime + 0.4);\n vCameraTarget.y = mix(2., 22., p1m1(sin(cameraTime * 3.73 + 0.2)));\n \tvec3 vCameraUp = vec3( 0.0, 1, 0);\n float slide = 1. - p1m1(dot(\n normalize(vCameraTarget.xz - vCameraPos.xz), \n normalize(vT2.xz - vCameraTarget.xz)));\n \n mat4 matC = trans(vCameraPos);\n matC *= rotY(atan(\n vCameraPos.x - vCameraTarget.x, \n vCameraPos.z - vCameraTarget.z));\n matC *= rotZ(-0.6 * slide);\n matC *= rotX((vCameraPos.y - vCameraTarget.y) * -0.2);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol, snd );\n\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= inverse(matC);\n cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(hsv2rgb(vec3(floor(mod(cameraTime, 4.)) / 8., 1, 1)), 1);\n \tvec4 vFinalColor = mix(vec4(0,0,0,1), color, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n}" + }, "screenshotURL": "data/images/images-g9heg3i7jn504abqx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8Typ5eK6bCd5ziWFf/art.json b/art/8Typ5eK6bCd5ziWFf/art.json index b52f078b..d9b12e40 100644 --- a/art/8Typ5eK6bCd5ziWFf/art.json +++ b/art/8Typ5eK6bCd5ziWFf/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":624,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Making a Grid, own variation\\n//course name : CS250\\n//term : Spring 2023\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux * cos(time/4.) ,vy * cos(time), 0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n v_color += vec4(ux * cos(time),vy * cos(time * 2.), u * cos(time * 3.),1);\\n \\n}\"}", + "settings": { + "num": 624, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Making a Grid, own variation\n//course name : CS250\n//term : Spring 2023\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux * cos(time/4.) ,vy * cos(time), 0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n v_color += vec4(ux * cos(time),vy * cos(time * 2.), u * cos(time * 3.),1);\n \n}" + }, "screenshotURL": "data/images/images-p0441clrslbiupp9y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8WsNgnnMn6z7f46sb/art.json b/art/8WsNgnnMn6z7f46sb/art.json index 66971978..dcfd099c 100644 --- a/art/8WsNgnnMn6z7f46sb/art.json +++ b/art/8WsNgnnMn6z7f46sb/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":99999,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wigae/pilot?si=ef4d51074d414114a40fab77e121ae5d&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// Name : Jemin.Shin\\n// Exercise: Circles from Triangles\\n// Course : CS250\\n// Spring 2023\\n\\n\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u -.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;\\n \\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;\\n float sat = 1.;\\n float val = mix(.4, pow(snd + .2, 5.), pump);\\n \\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n} \"}", + "settings": { + "num": 99999, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wigae/pilot?si=ef4d51074d414114a40fab77e121ae5d&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// Name : Jemin.Shin\n// Exercise: Circles from Triangles\n// Course : CS250\n// Spring 2023\n\n\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u -.5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;\n \n\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;\n float sat = 1.;\n float val = mix(.4, pow(snd + .2, 5.), pump);\n \n hue += pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n} " + }, "screenshotURL": "data/images/images-fa38yc7s4vgr2k4m5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8XECwReKrWfyzzRsj/art.json b/art/8XECwReKrWfyzzRsj/art.json index a7d860ef..58e2210e 100644 --- a/art/8XECwReKrWfyzzRsj/art.json +++ b/art/8XECwReKrWfyzzRsj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":21443,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n#define KP0 3.//KParameter0 0.>>10.\\n#define KP1 3.//Kparameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>5.\\n#define KP3 0.//KParameter3 0.>>0.5\\n#define KP4 2.//KParameter4 0.>>2.0\\n#define KP5 22222.//KParameter5 4000.>>100000.\\n//KVerticesNumber=KP5\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0 -KP4), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1) ; \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n float VC = vertexCount;\\n VC= KP5 /s2;\\n \\n vec3 pos;\\n float inner = sin(-1.3-KP2);\\n float start = 0.5- 0.03 -s2;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 1. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.5);\\n gl_PointSize = 2.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s2, 2.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat+s, val)), (0.3 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 21443, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n#define KP0 3.//KParameter0 0.>>10.\n#define KP1 3.//Kparameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>5.\n#define KP3 0.//KParameter3 0.>>0.5\n#define KP4 2.//KParameter4 0.>>2.0\n#define KP5 22222.//KParameter5 4000.>>100000.\n//KVerticesNumber=KP5\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0 -KP4), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1) ; \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n float VC = vertexCount;\n VC= KP5 /s2;\n \n vec3 pos;\n float inner = sin(-1.3-KP2);\n float start = 0.5- 0.03 -s2;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 1. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.5);\n gl_PointSize = 2.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s2, 2.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat+s, val)), (0.3 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-6gxty3rh2mv80eerb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8YgL5b9rsGLmaeQ9Z/art.json b/art/8YgL5b9rsGLmaeQ9Z/art.json index d3f663f1..00190e27 100644 --- a/art/8YgL5b9rsGLmaeQ9Z/art.json +++ b/art/8YgL5b9rsGLmaeQ9Z/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mol", "avatarUrl": "https://secure.gravatar.com/avatar/fe5b47f4d74c95c9b38908469761a86d?default=retro&size=200", - "settings": "{\"num\":14944,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n gl_PointSize = 5.0;\\n \\n v_color = vec4(\\n abs(sin(vertexId * 0.1 - time * 8.0)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\\n 1.0);\\n \\n gl_Position.x = sin(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\\n gl_Position.y = cos(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\\n gl_Position.z = 0.0;\\n gl_Position[3] = 1.0;\\n}\"}", + "settings": { + "num": 14944, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n gl_PointSize = 5.0;\n \n v_color = vec4(\n abs(sin(vertexId * 0.1 - time * 8.0)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\n 1.0);\n \n gl_Position.x = sin(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\n gl_Position.y = cos(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\n gl_Position.z = 0.0;\n gl_Position[3] = 1.0;\n}" + }, "screenshotURL": "data/images/images-nfm87fpv0x37v7uuh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8ZyPwCk5HdengqpJK/art.json b/art/8ZyPwCk5HdengqpJK/art.json index 2545497a..dfec012f 100644 --- a/art/8ZyPwCk5HdengqpJK/art.json +++ b/art/8ZyPwCk5HdengqpJK/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":97272,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/scrubber-fox/squarepusher-4001-scrubber-fox\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n __ __ ______ ______ ______ ______ __ __ ______ __ __ ______ _____ ______ ______ ______ ______ ______ \\n/\\\\ \\\\ / / /\\\\ ___\\\\ /\\\\ == \\\\ /\\\\__ _\\\\ /\\\\ ___\\\\ /\\\\_\\\\_\\\\_\\\\ /\\\\ ___\\\\ /\\\\ \\\\_\\\\ \\\\ /\\\\ __ \\\\ /\\\\ __-. /\\\\ ___\\\\ /\\\\ == \\\\ /\\\\ __ \\\\ /\\\\ == \\\\ /\\\\__ _\\\\ \\n\\\\ \\\\ \\\\'/ \\\\ \\\\ __\\\\ \\\\ \\\\ __< \\\\/_/\\\\ \\\\/ \\\\ \\\\ __\\\\ \\\\/_/\\\\_\\\\/_ \\\\ \\\\___ \\\\ \\\\ \\\\ __ \\\\ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\/\\\\ \\\\ \\\\ \\\\ __\\\\ \\\\ \\\\ __< \\\\ \\\\ __ \\\\ \\\\ \\\\ __< \\\\/_/\\\\ \\\\/ \\n \\\\ \\\\__| \\\\ \\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\ \\\\_____\\\\ /\\\\_\\\\/\\\\_\\\\ \\\\/\\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\____- \\\\ \\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\n \\\\/_/ \\\\/_____/ \\\\/_/ /_/ \\\\/_/ \\\\/_____/ \\\\/_/\\\\/_/ \\\\/_____/ \\\\/_/\\\\/_/ \\\\/_/\\\\/_/ \\\\/____/ \\\\/_____/ \\\\/_/ /_/ \\\\/_/\\\\/_/ \\\\/_/ /_/ \\\\/_/ \\n \\n\\n\\n\\n*/\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\nvoid main() {\\n float size = floor(pow(vertexCount, 1./3.));\\n float div = size - 1.;\\n vec3 p = vec3(\\n mod(vertexId, size),\\n mod(floor(vertexId / size), size),\\n floor(floor(vertexId / size) / size));\\n \\n vec3 snd = vec3(\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.1) * 0.25, 0.0)).a,\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.2) * 0.25, 0.0)).a,\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.3) * 0.25, 0.0)).a);\\n \\n float a = time * 0.01;\\n float r = 1.0;\\n float c = cos(a) * r;\\n float s = sin(a) * r;\\n float y = sin(time * 0.011);\\n \\n vec3 target = vec3(0,0,0);\\n vec3 up = vec3(0,1,0);\\n vec3 eye = vec3(c, y, s);\\n \\n \\n mat4 m = ident();\\n m *= persp(radians(45.), resolution.x / resolution.y, 0.1, 2.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(-1, -1, -1));\\n m *= uniformScale(2. / div);\\n \\n vec3 sp = snd * snd * snd * snd * snd * snd * snd * snd * snd;\\n gl_Position = m * vec4(p + sp * .4, 1);\\n\\n float z = gl_Position.z * 0.5 + 0.5;\\n float sm = max(max(sp.x, sp.y), sp.z);\\n float hue = 1.;//(time * 0.01 + count * 1.001);\\n v_color = vec4(mix(p / div * vec3(0,1,1) * z, vec3(1,0,0), step(0.7, sm)), mix(0.8,1.5, mod(floor(vertexId * 0.33 + time * 30.0), 2.)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n gl_PointSize = mix(10.0, 0.0, z) + step(0.7, sm) * 2.;\\n}\"}", + "settings": { + "num": 97272, + "mode": "POINTS", + "sound": "https://soundcloud.com/scrubber-fox/squarepusher-4001-scrubber-fox", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n __ __ ______ ______ ______ ______ __ __ ______ __ __ ______ _____ ______ ______ ______ ______ ______ \n/\\ \\ / / /\\ ___\\ /\\ == \\ /\\__ _\\ /\\ ___\\ /\\_\\_\\_\\ /\\ ___\\ /\\ \\_\\ \\ /\\ __ \\ /\\ __-. /\\ ___\\ /\\ == \\ /\\ __ \\ /\\ == \\ /\\__ _\\ \n\\ \\ \\'/ \\ \\ __\\ \\ \\ __< \\/_/\\ \\/ \\ \\ __\\ \\/_/\\_\\/_ \\ \\___ \\ \\ \\ __ \\ \\ \\ __ \\ \\ \\ \\/\\ \\ \\ \\ __\\ \\ \\ __< \\ \\ __ \\ \\ \\ __< \\/_/\\ \\/ \n \\ \\__| \\ \\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\ \\_____\\ /\\_\\/\\_\\ \\/\\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\____- \\ \\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\_\\ \n \\/_/ \\/_____/ \\/_/ /_/ \\/_/ \\/_____/ \\/_/\\/_/ \\/_____/ \\/_/\\/_/ \\/_/\\/_/ \\/____/ \\/_____/ \\/_/ /_/ \\/_/\\/_/ \\/_/ /_/ \\/_/ \n \n\n\n\n*/\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\nvoid main() {\n float size = floor(pow(vertexCount, 1./3.));\n float div = size - 1.;\n vec3 p = vec3(\n mod(vertexId, size),\n mod(floor(vertexId / size), size),\n floor(floor(vertexId / size) / size));\n \n vec3 snd = vec3(\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.1) * 0.25, 0.0)).a,\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.2) * 0.25, 0.0)).a,\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.3) * 0.25, 0.0)).a);\n \n float a = time * 0.01;\n float r = 1.0;\n float c = cos(a) * r;\n float s = sin(a) * r;\n float y = sin(time * 0.011);\n \n vec3 target = vec3(0,0,0);\n vec3 up = vec3(0,1,0);\n vec3 eye = vec3(c, y, s);\n \n \n mat4 m = ident();\n m *= persp(radians(45.), resolution.x / resolution.y, 0.1, 2.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(-1, -1, -1));\n m *= uniformScale(2. / div);\n \n vec3 sp = snd * snd * snd * snd * snd * snd * snd * snd * snd;\n gl_Position = m * vec4(p + sp * .4, 1);\n\n float z = gl_Position.z * 0.5 + 0.5;\n float sm = max(max(sp.x, sp.y), sp.z);\n float hue = 1.;//(time * 0.01 + count * 1.001);\n v_color = vec4(mix(p / div * vec3(0,1,1) * z, vec3(1,0,0), step(0.7, sm)), mix(0.8,1.5, mod(floor(vertexId * 0.33 + time * 30.0), 2.)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n gl_PointSize = mix(10.0, 0.0, z) + step(0.7, sm) * 2.;\n}" + }, "screenshotURL": "data/images/images-9dn4sdakaj2ih294w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8ZzuRWYAZeNEN3L4m/art.json b/art/8ZzuRWYAZeNEN3L4m/art.json index 65316e94..776a71db 100644 --- a/art/8ZzuRWYAZeNEN3L4m/art.json +++ b/art/8ZzuRWYAZeNEN3L4m/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hamad", "avatarUrl": "https://lh3.googleusercontent.com/-0-rND5YdliE/AAAAAAAAAAI/AAAAAAAAABk/oFPiwkQOhY4/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () { \\n\\tgl_Position = vec4(0, 0, 0, 1); //normalized device coordinate\\n\\t\\n \\tgl_PointSize = 10.0;\\n \\n \\tv_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () { \n\tgl_Position = vec4(0, 0, 0, 1); //normalized device coordinate\n\t\n \tgl_PointSize = 10.0;\n \n \tv_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-7r9ebwhehh18sl4l0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8aEFjza4wNjuhfnvP/art.json b/art/8aEFjza4wNjuhfnvP/art.json index 336bba65..e430db5c 100644 --- a/art/8aEFjza4wNjuhfnvP/art.json +++ b/art/8aEFjza4wNjuhfnvP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n\\nvoid main() \\n{\\n vec2 xy = vec2(0.0, 0.0);\\n \\n if(vertexId == 0.0)\\n {\\n \\n xy = vec2(0.5, 0.0);\\n \\n }\\n \\n if(vertexId == 1.0)\\n {\\n \\n xy = vec2(-0.5, 0.0);\\n \\n }\\n \\n if(vertexId == 2.0)\\n {\\n \\n xy = vec2(0.0, 0.5);\\n \\n }\\n xy += vec2(0.0,-0.2);\\n xy += vec2(0.0, sin(time)/20.0*10.0); \\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n \\n \\n \\n}\"}", + "settings": { + "num": 3, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n\nvoid main() \n{\n vec2 xy = vec2(0.0, 0.0);\n \n if(vertexId == 0.0)\n {\n \n xy = vec2(0.5, 0.0);\n \n }\n \n if(vertexId == 1.0)\n {\n \n xy = vec2(-0.5, 0.0);\n \n }\n \n if(vertexId == 2.0)\n {\n \n xy = vec2(0.0, 0.5);\n \n }\n xy += vec2(0.0,-0.2);\n xy += vec2(0.0, sin(time)/20.0*10.0); \n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n \n \n \n}" + }, "screenshotURL": "data/images/images-7xg8kg3io7j9a0k9d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8bRYb7JjNeomjyGHy/art.json b/art/8bRYb7JjNeomjyGHy/art.json index ba10353b..18b64145 100644 --- a/art/8bRYb7JjNeomjyGHy/art.json +++ b/art/8bRYb7JjNeomjyGHy/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "dominique", "avatarUrl": "https://graph.facebook.com/1571607909560772/picture?type=large", - "settings": "{\"num\":3000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec2 Crear(float vertexId){\\n float sqrTotal = floor(sqrt(vertexCount));\\n float width = sqrTotal;\\n \\n float uxf = floor(vertexId/ 6.0) + mod(vertexId, 2.0);\\n float vyf = mod(floor(vertexId / 2.0) + floor(vertexId / 1.0), 2.0);\\n \\n float angle = uxf/ 10.0 * radians(180.0) * 2.0; //el 20 es como la resolucion convertir, pi radianes por 2( gados de un circulo) , entre 20(ocupar 20 segmentos), lo que necesitas para formar un circulo \\n float radius = vyf + 1.0; // el radio del circulo es uno, va a ir girando, centro vacio 1\\n // ux mas a la derecha , 0, 1 ,2 ,3 ...\\n \\n float x =radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n\\n float uxpri = u * 2.0 - 1.0 + xOffset;\\n float vypri = v * 2.0 - 1.0 + yOffset;\\n \\n // x = radius * cos(angle) funcionan en radianes \\n // y = radius * sin(angle)\\n \\n vec2 xy = vec2(uxpri, vypri) * 6.0;\\n return xy; \\n}\\n\\nvoid main() \\n{ \\n \\n \\n \\n float circulo = floor(vertexId/(20.0*6.0));\\n float numeCir = floor(vertexCount / (20.0*6.0));\\n \\n float a = floor(sqrt(numeCir));\\n float b = floor(numeCir / a);\\n \\n float x = mod(circulo, b);\\n float y = floor(circulo / b);\\n \\n float u = x / (b - 2.0);\\n float v = y / (b - 2.0);\\n \\n float ux = u * 2.0 - 0.5;\\n float vy = v * 2.0 - 0.5;\\n \\n vec2 xy = Crear(vertexId) * 0.1 + vec2(ux,vy)*0.7;\\n \\n gl_Position= vec4(xy , 0.0, 1.0);\\n v_color = vec4(0.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec2 Crear(float vertexId){\n float sqrTotal = floor(sqrt(vertexCount));\n float width = sqrTotal;\n \n float uxf = floor(vertexId/ 6.0) + mod(vertexId, 2.0);\n float vyf = mod(floor(vertexId / 2.0) + floor(vertexId / 1.0), 2.0);\n \n float angle = uxf/ 10.0 * radians(180.0) * 2.0; //el 20 es como la resolucion convertir, pi radianes por 2( gados de un circulo) , entre 20(ocupar 20 segmentos), lo que necesitas para formar un circulo \n float radius = vyf + 1.0; // el radio del circulo es uno, va a ir girando, centro vacio 1\n // ux mas a la derecha , 0, 1 ,2 ,3 ...\n \n float x =radius * cos(angle);\n float y = radius * sin(angle);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n\n float uxpri = u * 2.0 - 1.0 + xOffset;\n float vypri = v * 2.0 - 1.0 + yOffset;\n \n // x = radius * cos(angle) funcionan en radianes \n // y = radius * sin(angle)\n \n vec2 xy = vec2(uxpri, vypri) * 6.0;\n return xy; \n}\n\nvoid main() \n{ \n \n \n \n float circulo = floor(vertexId/(20.0*6.0));\n float numeCir = floor(vertexCount / (20.0*6.0));\n \n float a = floor(sqrt(numeCir));\n float b = floor(numeCir / a);\n \n float x = mod(circulo, b);\n float y = floor(circulo / b);\n \n float u = x / (b - 2.0);\n float v = y / (b - 2.0);\n \n float ux = u * 2.0 - 0.5;\n float vy = v * 2.0 - 0.5;\n \n vec2 xy = Crear(vertexId) * 0.1 + vec2(ux,vy)*0.7;\n \n gl_Position= vec4(xy , 0.0, 1.0);\n v_color = vec4(0.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-s0vjk1kx0n9wdz555-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8cPTCz9Cm8iRKNmqG/art.json b/art/8cPTCz9Cm8iRKNmqG/art.json index e39e6e69..b1876ad3 100644 --- a/art/8cPTCz9Cm8iRKNmqG/art.json +++ b/art/8cPTCz9Cm8iRKNmqG/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "다은", "avatarUrl": "https://lh3.googleusercontent.com/--VGFNmU3UuQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rekfGpN6byv9fIvs3pAjQAlrfA__A/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// your name (daeun Jeong)\\n// the assignment number (03)\\n// the course name (CS230)\\n// the term (Spring 2019)\\n\\nvoid main() \\n{ \\n float xOff = sin(time) * 0.2;\\n \\n float yOff = cos(time) * 0.2;\\n \\n float blueOff = abs(cos(time));\\n \\n float alphaOff = abs(sin(time)) + 0.5;\\n \\n float sizeOff = abs(sin(time)) * 10.0 + 10.0;\\n \\n vec4 pos = vec4(mouse.x + xOff, mouse.y + yOff, 0.0, 1.0);\\n \\n gl_Position = pos;\\n \\n gl_PointSize = sizeOff;\\n \\n v_color = vec4(0.1, 0.1, blueOff, alphaOff);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// your name (daeun Jeong)\n// the assignment number (03)\n// the course name (CS230)\n// the term (Spring 2019)\n\nvoid main() \n{ \n float xOff = sin(time) * 0.2;\n \n float yOff = cos(time) * 0.2;\n \n float blueOff = abs(cos(time));\n \n float alphaOff = abs(sin(time)) + 0.5;\n \n float sizeOff = abs(sin(time)) * 10.0 + 10.0;\n \n vec4 pos = vec4(mouse.x + xOff, mouse.y + yOff, 0.0, 1.0);\n \n gl_Position = pos;\n \n gl_PointSize = sizeOff;\n \n v_color = vec4(0.1, 0.1, blueOff, alphaOff);\n}" + }, "screenshotURL": "data/images/images-7pojgvmcnc9vxltsc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8eDsJnksnjrECXGev/art.json b/art/8eDsJnksnjrECXGev/art.json index c952378d..9c6ea4c5 100644 --- a/art/8eDsJnksnjrECXGev/art.json +++ b/art/8eDsJnksnjrECXGev/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":30765,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/orbital-4/04-lush-3-2\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float pointV = point / NUM_SEGMENTS;\\n float circleId = floor(vertexId / NUM_POINTS);\\n float numCircles = floor(vertexCount / NUM_POINTS);\\n float circleV = circleId / numCircles;\\n \\n const int numSamples = 20;\\n float snd = 0.0;\\n for (int i = 0; i < numSamples; ++i) {\\n float l = float(i) / float(numSamples - 1);\\n snd = max(snd, texture2D(sound, vec2(mix(0.0, 0.2, l), circleV * 1.0)).a);\\n }\\n float angle = pointV * PI * 2.0 + PI * 0.25;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n vec3 p = vec3(c, s, -fract(time * -0.01 + circleV) * 100. + snd);\\n mat4 m = persp(radians(12.), resolution.x / resolution.y, 0.1, 100.);\\n m *= rotZ(mod(circleId, 2.) * PI * 0.5 + PI * 0.25 + pow(snd, 2.5) * 2.5);\\n m *= trans(vec3(0, 0, -2));\\n m *= scale(vec3(0.2, 1, 1));\\n gl_Position = m * vec4(p, 1);\\n\\n float b = 1.0;\\n v_color.a = mix(100., 0., gl_Position.z / gl_Position.w);\\n v_color.rgb = mix(vec3(0,0,1), vec3(1,0,0), step(0.80, pow(snd, 1.)));\\n v_color.rgb *= v_color.a;\\n \\n gl_PointSize = 4.0;\\n gl_PointSize *= resolution.x / 1600.0;\\n}\"}", + "settings": { + "num": 30765, + "mode": "LINES", + "sound": "https://soundcloud.com/orbital-4/04-lush-3-2", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float pointV = point / NUM_SEGMENTS;\n float circleId = floor(vertexId / NUM_POINTS);\n float numCircles = floor(vertexCount / NUM_POINTS);\n float circleV = circleId / numCircles;\n \n const int numSamples = 20;\n float snd = 0.0;\n for (int i = 0; i < numSamples; ++i) {\n float l = float(i) / float(numSamples - 1);\n snd = max(snd, texture2D(sound, vec2(mix(0.0, 0.2, l), circleV * 1.0)).a);\n }\n float angle = pointV * PI * 2.0 + PI * 0.25;\n float c = cos(angle);\n float s = sin(angle);\n \n vec3 p = vec3(c, s, -fract(time * -0.01 + circleV) * 100. + snd);\n mat4 m = persp(radians(12.), resolution.x / resolution.y, 0.1, 100.);\n m *= rotZ(mod(circleId, 2.) * PI * 0.5 + PI * 0.25 + pow(snd, 2.5) * 2.5);\n m *= trans(vec3(0, 0, -2));\n m *= scale(vec3(0.2, 1, 1));\n gl_Position = m * vec4(p, 1);\n\n float b = 1.0;\n v_color.a = mix(100., 0., gl_Position.z / gl_Position.w);\n v_color.rgb = mix(vec3(0,0,1), vec3(1,0,0), step(0.80, pow(snd, 1.)));\n v_color.rgb *= v_color.a;\n \n gl_PointSize = 4.0;\n gl_PointSize *= resolution.x / 1600.0;\n}" + }, "screenshotURL": "data/images/images-pw75id1swgnn7izm9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8eaHZkbv4GqCvTJJs/art.json b/art/8eaHZkbv4GqCvTJJs/art.json index 702cb33b..621d5d48 100644 --- a/art/8eaHZkbv4GqCvTJJs/art.json +++ b/art/8eaHZkbv4GqCvTJJs/art.json @@ -21,7 +21,19 @@ "origId": "hhsdvkiJ32bCTcezv", "name": "eswng", "username": "gman", - "settings": "{\"num\":5000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/fnkypanda/electroswing-11-acorn-lane-spend-my-time-with-you-electro-swing-remix\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n#define ACROSS 100.0\\n#define TOTAL 5000.0\\n#define DOWN (TOTAL / ACROSS)\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float count = mod(vertexId, TOTAL) + time * 0.0;\\n float xId = mod(vertexId, ACROSS);\\n float yId = floor(vertexId / ACROSS);\\n float xr = xId / ACROSS;\\n float yr = yId / DOWN;\\n float invX = 1.0 - xr;\\n float invY = 1.0 - yr;\\n float x = xr * 2.0 - 1.0;\\n float y = yr * 2.0 - 1.0;\\n \\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n\\n vec2 xy = vec2(x, y);\\n\\n float dd = length(xy);\\n float x2 = xr;\\n float y2 = yr;\\n float snd = pow(texture2D(sound, vec2(abs(dd) * 0.2, dd * 0.05)).a, 5.0);\\n gl_PointSize = pow(snd, 1.0) * 20.0;\\n \\n// xy = xy + xy * snd ;\\n gl_Position = vec4(xy * aspect * pow(snd + 0.4, 2.0), 0, 1);\\n \\n float hue = (snd * 0.2) + time;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 1, 1)), vec3(1,1,1), pow(snd, 0.5)), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/fnkypanda/electroswing-11-acorn-lane-spend-my-time-with-you-electro-swing-remix", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n#define ACROSS 100.0\n#define TOTAL 5000.0\n#define DOWN (TOTAL / ACROSS)\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float count = mod(vertexId, TOTAL) + time * 0.0;\n float xId = mod(vertexId, ACROSS);\n float yId = floor(vertexId / ACROSS);\n float xr = xId / ACROSS;\n float yr = yId / DOWN;\n float invX = 1.0 - xr;\n float invY = 1.0 - yr;\n float x = xr * 2.0 - 1.0;\n float y = yr * 2.0 - 1.0;\n \n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n\n vec2 xy = vec2(x, y);\n\n float dd = length(xy);\n float x2 = xr;\n float y2 = yr;\n float snd = pow(texture2D(sound, vec2(abs(dd) * 0.2, dd * 0.05)).a, 5.0);\n gl_PointSize = pow(snd, 1.0) * 20.0;\n \n// xy = xy + xy * snd ;\n gl_Position = vec4(xy * aspect * pow(snd + 0.4, 2.0), 0, 1);\n \n float hue = (snd * 0.2) + time;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 1, 1)), vec3(1,1,1), pow(snd, 0.5)), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-kuoxs8iblkjgbtu6l-thumbnail.jpg", "views": { "$numberInt": "3779" diff --git a/art/8gvY7dX9pPW8v6jDG/art.json b/art/8gvY7dX9pPW8v6jDG/art.json index 4af7b926..6ec87ef5 100644 --- a/art/8gvY7dX9pPW8v6jDG/art.json +++ b/art/8gvY7dX9pPW8v6jDG/art.json @@ -27,7 +27,19 @@ "name": "cubez", "private": true, "username": "torokati44", - "settings": "{\"num\":1084,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localVertexId = mod(vertexId, 36.0);\\n float triangleVertexId = mod(localVertexId, 6.0);\\n float faceId = (localVertexId - triangleVertexId);\\n float cubeId = (vertexId - localVertexId) / 36.0;\\n \\n\\n gl_Position = vec4(cubeId/100.0, (faceId * 1.0 + localVertexId)/100.0, 0.0, 1.0);\\n\\n v_color = vec4(hsv2rgb(vec3(faceId/10.0, 1.0, 1.0)), 1.0);\\n}\"}", + "settings": { + "num": 1084, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localVertexId = mod(vertexId, 36.0);\n float triangleVertexId = mod(localVertexId, 6.0);\n float faceId = (localVertexId - triangleVertexId);\n float cubeId = (vertexId - localVertexId) / 36.0;\n \n\n gl_Position = vec4(cubeId/100.0, (faceId * 1.0 + localVertexId)/100.0, 0.0, 1.0);\n\n v_color = vec4(hsv2rgb(vec3(faceId/10.0, 1.0, 1.0)), 1.0);\n}" + }, "screenshotURL": "data/images/images-tfdol5bkc2nomub1m-thumbnail.jpg", "views": { "$numberInt": "2" diff --git a/art/8hCgzechTSmvoP4ah/art.json b/art/8hCgzechTSmvoP4ah/art.json index 52f2e70d..dc1de888 100644 --- a/art/8hCgzechTSmvoP4ah/art.json +++ b/art/8hCgzechTSmvoP4ah/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/clg-2/ambient-sleep-music-astral\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nconst float kPI = 3.1415926535;\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float row_freq_amp = texture2D(sound, vec2( 1.0/240.0, 0.0)).a;\\n float high_freq_amp = texture2D(sound, vec2( 239.0/240.0, 0.0)).a;\\n float a = -1.4 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0005) * time + 0.5 * mouse.x + 0.05 * row_freq_amp)));\\n float b = 1.6;\\n float c = 1.0 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0007) * time + 0.5 * mouse.y + 0.01 * high_freq_amp)));;\\n float d = 0.7;\\n float x = 0.0;\\n float y = 0.0;\\n \\n for(int i = 1; i >= 0; ++i)\\n {\\n if (i >= int(vertexId)) break;\\n \\tfloat x_tmp = x;\\n x = sin(a * y) + c * cos(a * x);\\n y = sin(b * x_tmp) + d * cos(b * y);\\n }\\n x *= 0.3 * (resolution.y / resolution.x);\\n y *= 0.3;\\n gl_Position = vec4(x, y, 0.0, 1.0);\\n\\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1.0, 1.0)), 0.1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/clg-2/ambient-sleep-music-astral", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nconst float kPI = 3.1415926535;\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float row_freq_amp = texture2D(sound, vec2( 1.0/240.0, 0.0)).a;\n float high_freq_amp = texture2D(sound, vec2( 239.0/240.0, 0.0)).a;\n float a = -1.4 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0005) * time + 0.5 * mouse.x + 0.05 * row_freq_amp)));\n float b = 1.6;\n float c = 1.0 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0007) * time + 0.5 * mouse.y + 0.01 * high_freq_amp)));;\n float d = 0.7;\n float x = 0.0;\n float y = 0.0;\n \n for(int i = 1; i >= 0; ++i)\n {\n if (i >= int(vertexId)) break;\n \tfloat x_tmp = x;\n x = sin(a * y) + c * cos(a * x);\n y = sin(b * x_tmp) + d * cos(b * y);\n }\n x *= 0.3 * (resolution.y / resolution.x);\n y *= 0.3;\n gl_Position = vec4(x, y, 0.0, 1.0);\n\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1.0, 1.0)), 0.1);\n}" + }, "screenshotURL": "data/images/images-va1mcilzkwh4yvpuw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8hLNA2ArwHi8mdNZq/art.json b/art/8hLNA2ArwHi8mdNZq/art.json index 99b6158f..39af3016 100644 --- a/art/8hLNA2ArwHi8mdNZq/art.json +++ b/art/8hLNA2ArwHi8mdNZq/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":9935,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-961665354/yt5scom-bondhu-kala-chanponkoj-roy-jk-shanto-bangla-new-dance-video-2021-320-kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat anim(float t) {\\n float st = sin(t);\\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n float snd = pow(texture2D(sound, vec2(th_cs,th_sn)).a, 5.0);\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs * (snd / 0.5 * time) );\\n}\\n\\nvec3 SampleCubePos(float idx, float num) {\\n float side = floor(pow(num, 1.0/3.0)+0.5);\\n vec3 res;\\n res.x = mod(idx, side);\\n float snd = pow(texture2D(sound, vec2(res.x,side + time)).a * time , 5.0);\\n \\n res.y = floor( mod(idx, side*side)/side ) + snd;\\n res.z = floor( mod(idx, side*side*side)/side/side ) + anim(2.0 * snd);\\n res.y += pow(sin(snd * PI / 4.0), 1.5);\\n res -= vec3(side * 0.5);\\n res *= 2./side;\\n return res;\\n}\\n\\nvoid main() {\\n \\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\\n \\n \\n \\n gl_Position = persp(PI*0.35, resolution.x/resolution.y, 0.1, 1000.0) * vertPos;\\n gl_PointSize = 2.5; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 9935, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-961665354/yt5scom-bondhu-kala-chanponkoj-roy-jk-shanto-bangla-new-dance-video-2021-320-kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat anim(float t) {\n float st = sin(t);\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n float snd = pow(texture2D(sound, vec2(th_cs,th_sn)).a, 5.0);\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs * (snd / 0.5 * time) );\n}\n\nvec3 SampleCubePos(float idx, float num) {\n float side = floor(pow(num, 1.0/3.0)+0.5);\n vec3 res;\n res.x = mod(idx, side);\n float snd = pow(texture2D(sound, vec2(res.x,side + time)).a * time , 5.0);\n \n res.y = floor( mod(idx, side*side)/side ) + snd;\n res.z = floor( mod(idx, side*side*side)/side/side ) + anim(2.0 * snd);\n res.y += pow(sin(snd * PI / 4.0), 1.5);\n res -= vec3(side * 0.5);\n res *= 2./side;\n return res;\n}\n\nvoid main() {\n \n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\n \n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\n \n \n \n gl_Position = persp(PI*0.35, resolution.x/resolution.y, 0.1, 1000.0) * vertPos;\n gl_PointSize = 2.5; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-3day105410hz56zyz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8ifzGvPttfmfGyATy/art.json b/art/8ifzGvPttfmfGyATy/art.json index 5121f09e..599e42c1 100644 --- a/art/8ifzGvPttfmfGyATy/art.json +++ b/art/8ifzGvPttfmfGyATy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "yejin-shin", "avatarUrl": "https://avatars.githubusercontent.com/yejin-shin?s=200", - "settings": "{\"num\":7272,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/tramyy/yerin-baek-love-on-top-by-beyonce\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Yejin Shin\\n//Assignment : Circles from Triangles\\n//Course : CS250\\n//Spring, 2023\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotz(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n\\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0, \\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident()\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0, \\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0, \\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n\\n float radius = vy + 1.;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n return vec2(x, y);\\n}\\n\\nvoid main() \\n{\\n float numCircleSegments = 36.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n\\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleID = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n\\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n\\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n float x = mod(circleID, across);\\n float y = floor(circleID / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotz(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotz(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc); \\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd + 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = mix(.5, pow(snd + 0.2, 5.0), pump);\\n\\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 7272, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/tramyy/yerin-baek-love-on-top-by-beyonce", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Yejin Shin\n//Assignment : Circles from Triangles\n//Course : CS250\n//Spring, 2023\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotz(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n\n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0, \n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident()\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s)\n{\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0, \n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0, \n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n\n float radius = vy + 1.;\n\n float x = c * radius;\n float y = s * radius;\n\n return vec2(x, y);\n}\n\nvoid main() \n{\n float numCircleSegments = 36.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n\n float numPointsPerCircle = numCircleSegments * 6.;\n float circleID = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n\n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n\n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n float x = mod(circleID, across);\n float y = floor(circleID / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotz(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotz(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc); \n \n gl_Position = mat * pos;\n\n float soff = 0.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd + 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = mix(.5, pow(snd + 0.2, 5.0), pump);\n\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-xlza353lvncnx0x4v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8jcBYJRBWjDcfHKkH/art.json b/art/8jcBYJRBWjDcfHKkH/art.json index 60c54063..df1aab57 100644 --- a/art/8jcBYJRBWjDcfHKkH/art.json +++ b/art/8jcBYJRBWjDcfHKkH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user-977421934/the-phoenix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1450980392156863,0.08627450980392157,0.41568627450980394,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float ux = floor(id / 6.) + mod(id,2.);\\n \\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n \\n\\n}\\n\\nvoid main() {\\n float numCircleSegments = 3.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/ 6.0);\\n float oddSlice = mod(sliceId,2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\\n float yoff = texture2D(sound,vec2(v,u)).a;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2,5.) * mix(1.0,1.1,oddSlice);\\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= trans(vec3(ux,vy,0));\\n mat *= rotZ(snd * 20.0 * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n vec2 xy = circleXY * 0.01 * sc + vec2(ux,vy) * 1.3;\\n \\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\\n\\n\\n float pump = step(.8,snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1 + sliceId * 0.01;//+ sin(time + v * 20.) * 0.05;\\n float sat = 1.;mix(0.6,1.,pump);\\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user-977421934/the-phoenix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1450980392156863, + 0.08627450980392157, + 0.41568627450980394, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float ux = floor(id / 6.) + mod(id,2.);\n \n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n \n\n}\n\nvoid main() {\n float numCircleSegments = 3.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId/ 6.0);\n float oddSlice = mod(sliceId,2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\n float yoff = texture2D(sound,vec2(v,u)).a;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2,5.) * mix(1.0,1.1,oddSlice);\n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= trans(vec3(ux,vy,0));\n mat *= rotZ(snd * 20.0 * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n vec2 xy = circleXY * 0.01 * sc + vec2(ux,vy) * 1.3;\n \n \n gl_Position = mat * pos;\n\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\n\n\n float pump = step(.8,snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1 + sliceId * 0.01;//+ sin(time + v * 20.) * 0.05;\n float sat = 1.;mix(0.6,1.,pump);\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-x2p34b55pxj7wtuhp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8jiF9r8CqR46bXvXM/art.json b/art/8jiF9r8CqR46bXvXM/art.json index a270f032..8046ab67 100644 --- a/art/8jiF9r8CqR46bXvXM/art.json +++ b/art/8jiF9r8CqR46bXvXM/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "도영", "avatarUrl": "https://lh4.googleusercontent.com/-U1yoYVQNRaI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdPOWnx_PVuWVFfdWUFWnYSBIUGSQ/mo/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() \\n{\\n \\tfloat value = vertexId*10.0;\\n \\n\\tfloat x =mouse.x;\\n\\tfloat y = mouse.y;\\n \\n \\tfloat snd = texture2D(sound, vec2(0, 0)).a;\\n \\tgl_Position = vec4(cos(value), sin(value), 0, abs(snd*2.0));\\n \\n \\tgl_PointSize = 50.0;\\n \\n \\tv_color = vec4(cos(x), sin(y), tan(x*y), 1);\\n}\\n\\n \"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() \n{\n \tfloat value = vertexId*10.0;\n \n\tfloat x =mouse.x;\n\tfloat y = mouse.y;\n \n \tfloat snd = texture2D(sound, vec2(0, 0)).a;\n \tgl_Position = vec4(cos(value), sin(value), 0, abs(snd*2.0));\n \n \tgl_PointSize = 50.0;\n \n \tv_color = vec4(cos(x), sin(y), tan(x*y), 1);\n}\n\n " + }, "screenshotURL": "data/images/images-fviyv80ibkbu9gvbn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8miH3KmYkczS5YbjP/art.json b/art/8miH3KmYkczS5YbjP/art.json index cc7408b3..3fc8a6d9 100644 --- a/art/8miH3KmYkczS5YbjP/art.json +++ b/art/8miH3KmYkczS5YbjP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/powerglove/telecom\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.0)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float numShapes = vertexCount / NUM_POINTS;\\n float cv = count / numShapes;\\n float offset = count * 0.02;\\n float ev = point / NUM_SEGMENTS;\\n float angle = ev * PI * 2.0 + offset * 0.1;\\n float radius = 0.2;\\n float c = cos(angle + time * 0.11) * radius;\\n float s = sin(angle + time * 0.11) * radius;\\n float orbitAngle = count * 0.01;\\n \\n float snd = texture2D(sound, vec2(ev * 0.1, cv * .1)).x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\\n\\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\\n vec2 xy = vec2(\\n c,\\n s);\\n gl_Position = vec4(xy * aspect * scale, 0, 1);\\n\\n float hue = cv * 0.2;\\n float unf = step(0.8, snd);\\n v_color = vec4(hsv2rgb(vec3(ev * 0.1 + 0.95, unf, unf + hue)), unf);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/powerglove/telecom", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.0)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float numShapes = vertexCount / NUM_POINTS;\n float cv = count / numShapes;\n float offset = count * 0.02;\n float ev = point / NUM_SEGMENTS;\n float angle = ev * PI * 2.0 + offset * 0.1;\n float radius = 0.2;\n float c = cos(angle + time * 0.11) * radius;\n float s = sin(angle + time * 0.11) * radius;\n float orbitAngle = count * 0.01;\n \n float snd = texture2D(sound, vec2(ev * 0.1, cv * .1)).x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\n\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\n vec2 xy = vec2(\n c,\n s);\n gl_Position = vec4(xy * aspect * scale, 0, 1);\n\n float hue = cv * 0.2;\n float unf = step(0.8, snd);\n v_color = vec4(hsv2rgb(vec3(ev * 0.1 + 0.95, unf, unf + hue)), unf);\n}" + }, "screenshotURL": "data/images/images-9e2sq60d3uqjuctbl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8oGoGrmBCLx2R4iWz/art.json b/art/8oGoGrmBCLx2R4iWz/art.json index d1015db6..4371707d 100644 --- a/art/8oGoGrmBCLx2R4iWz/art.json +++ b/art/8oGoGrmBCLx2R4iWz/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Color\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Color\n// Course Name: CS250\n// Term: Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-hj7khhjdm23knojw1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8oJh9QtFGgJksSFFk/art.json b/art/8oJh9QtFGgJksSFFk/art.json index 3eedec2d..485f9532 100644 --- a/art/8oJh9QtFGgJksSFFk/art.json +++ b/art/8oJh9QtFGgJksSFFk/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "dreadkyller", "avatarUrl": "https://lh6.googleusercontent.com/-G0dmKLFbiYU/AAAAAAAAAAI/AAAAAAAAAF8/mdxszvvxhOo/photo.jpg", - "settings": "{\"num\":23571,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Some code originated from here: https://www.vertexshaderart.com/art/TGGLggjxQgLPEFHWx\\n\\n// Calculates the size of the grid based on total number of points\\nfloat SIZE = floor(sqrt(vertexCount));\\n\\n// The actual points are placed in a 16x16 area, divided by the size gets the distance\\n// between points\\nfloat SPACING = 16.0 / SIZE;\\n\\n// How much the mouse changes the position, mouse influence\\nfloat DIST = 16.0;\\n\\n// Detail scale (zoom out)\\nfloat SCALE = 1.0;\\n\\n// Height scale, ranges from 0.001 to 1.001. The 0.001 additional is to ensure it stays\\n// Positive, so that the calculation of the colors still works.\\nfloat H_SCALE = 0.501 + sin(time / 1.0) / 2.0;\\n\\n// Values used by noise to offset the terrain for interactivity\\nfloat x_offset = mouse.x * DIST;\\nfloat y_offset = mouse.y * DIST;\\n\\n// How fast the camera orbits the area\\nfloat ROTATE_SPEED = 0.1;\\n\\n// This value determines the fullness of the display. 1.0 is default\\n// Too high and the dots cause interference with each other\\n// Too low and it can be hard to see the shape\\n// The dots get smaller as they get farther from the camera\\nfloat DOT_SIZE = 1.0;\\n\\n// These colors are used for the color display, and are mixed in main based on height\\nvec4 SNOW_COLOUR = vec4(1.0, 1.0, 1.0, 1);\\nvec4 STONE_COLOUR = vec4(0.4, 0.4, 0.4, 1);\\nvec4 DIRT_COLOUR = vec4(0.4, 0.2, 0.1, 1);\\nvec4 GRASS_COLOUR = vec4(0.1, 0.4, 0.1, 1);\\n\\n// Rotates a point around the global Y axis\\n// This is used to rotate the grid\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n// Rotates a point around the global X axis\\n// This is used to tile the camera downwards to look at terrain from slightly above\\nvec3 rotateX( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.y = ca*p.y + sa*p.z;\\n r.x = p.x;\\n r.z = -sa*p.y + ca*p.z;\\n return r;\\n}\\n// Hash unction returns a pseudo-random value for a given value\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\n// blends the hash of of 4 points around the given vector smoothly using\\n// a cubic hermite interpolation\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\n\\n\\n// Scaling factor used only in the noise function\\nfloat feature_scale = 2.0;\\n\\n// Fractal Brownian Motion\\n\\nfloat fbm(in vec2 p, in float size) {\\n // How much the influence of each iteration is decreased\\n const float lucanarity = 2.0;\\n // How much the scale of each iteration is increased\\n const float detail = 2.0;\\n \\n p = p * feature_scale;\\n float h = noise(p);\\n \\n float influence = 1.0;\\n \\n for (int i = 0; i < 14; i++) {\\n p = p * size;\\n \\th += noise(p) * influence;\\n size *= 2.0;\\n influence /= lucanarity;\\n }\\n return h;\\n}\\n\\n// The code that given a position, gives a height, design the terrain here\\nfloat heightAt(in vec2 po) {\\n po.x = (po.x + x_offset) * SCALE;\\n po.y = (po.y + y_offset) * SCALE;\\n return (fbm(po, 3.0) * 3.0) * pow(fbm(po, 0.2),3.0) * (0.03 * H_SCALE);\\n}\\n\\n// returns a value 0.0 to 1.0 representing how far between min and max the value is\\nfloat factor(float min, float max, float value) {\\n float val = (value - min) / (max - min);\\n if (val > 1.0) return 1.0;\\n if (val < 0.0) return 0.0;\\n return val;\\n}\\n\\n// Takes a point ID and converts it into coordinates\\nvec3 pointOf(float id) {\\n float x = mod(id, SIZE);\\n float y = floor(id / SIZE);\\n \\n return vec3((-SIZE/2.0 + x) * SPACING, heightAt( vec2( x, y ) / SIZE * 4.0), (-SIZE/2.0 + y) * SPACING );\\n}\\n\\n// Entry point of shader\\nvoid main() {\\n // Get the point position, x, y and z, with y being the height\\n vec3 p = pointOf(vertexId);\\n \\n // Based on the height (before rotation) determine colors\\n vec4 ground_colour = mix(DIRT_COLOUR , GRASS_COLOUR, factor(0.2, 0.0, p.y / H_SCALE));\\n \\n vec4 top_colour = mix(STONE_COLOUR, SNOW_COLOUR , factor(1.2, 2.0, p.y / H_SCALE));\\n \\n vec4 colour = mix(ground_colour, top_colour , factor(0.2, 0.3, p.y / H_SCALE));\\n \\n // Rotate the point around the global Y axis\\n p = rotateY(p, time * ROTATE_SPEED);\\n // Move the point down\\n p.z += 16.0;\\n // rotate the point up on the global X axis to simulare the camera looking downwards\\n p = rotateX(p, 0.8);\\n \\n // Set point size based on spacing and the distance (p.z) from the camera\\n gl_PointSize = SPACING * (2048.0 * DOT_SIZE) / (pow(p.z,2.0));\\n \\n // Set the position of the point\\n gl_Position = vec4(p.x, p.y - 9.0, 1.0/p.z, p.z);\\n \\n // Set the color of the point\\n v_color = colour;\\n}\"}", + "settings": { + "num": 23571, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Some code originated from here: https://www.vertexshaderart.com/art/TGGLggjxQgLPEFHWx\n\n// Calculates the size of the grid based on total number of points\nfloat SIZE = floor(sqrt(vertexCount));\n\n// The actual points are placed in a 16x16 area, divided by the size gets the distance\n// between points\nfloat SPACING = 16.0 / SIZE;\n\n// How much the mouse changes the position, mouse influence\nfloat DIST = 16.0;\n\n// Detail scale (zoom out)\nfloat SCALE = 1.0;\n\n// Height scale, ranges from 0.001 to 1.001. The 0.001 additional is to ensure it stays\n// Positive, so that the calculation of the colors still works.\nfloat H_SCALE = 0.501 + sin(time / 1.0) / 2.0;\n\n// Values used by noise to offset the terrain for interactivity\nfloat x_offset = mouse.x * DIST;\nfloat y_offset = mouse.y * DIST;\n\n// How fast the camera orbits the area\nfloat ROTATE_SPEED = 0.1;\n\n// This value determines the fullness of the display. 1.0 is default\n// Too high and the dots cause interference with each other\n// Too low and it can be hard to see the shape\n// The dots get smaller as they get farther from the camera\nfloat DOT_SIZE = 1.0;\n\n// These colors are used for the color display, and are mixed in main based on height\nvec4 SNOW_COLOUR = vec4(1.0, 1.0, 1.0, 1);\nvec4 STONE_COLOUR = vec4(0.4, 0.4, 0.4, 1);\nvec4 DIRT_COLOUR = vec4(0.4, 0.2, 0.1, 1);\nvec4 GRASS_COLOUR = vec4(0.1, 0.4, 0.1, 1);\n\n// Rotates a point around the global Y axis\n// This is used to rotate the grid\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n// Rotates a point around the global X axis\n// This is used to tile the camera downwards to look at terrain from slightly above\nvec3 rotateX( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.y = ca*p.y + sa*p.z;\n r.x = p.x;\n r.z = -sa*p.y + ca*p.z;\n return r;\n}\n// Hash unction returns a pseudo-random value for a given value\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\n// blends the hash of of 4 points around the given vector smoothly using\n// a cubic hermite interpolation\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\n\n\n// Scaling factor used only in the noise function\nfloat feature_scale = 2.0;\n\n// Fractal Brownian Motion\n\nfloat fbm(in vec2 p, in float size) {\n // How much the influence of each iteration is decreased\n const float lucanarity = 2.0;\n // How much the scale of each iteration is increased\n const float detail = 2.0;\n \n p = p * feature_scale;\n float h = noise(p);\n \n float influence = 1.0;\n \n for (int i = 0; i < 14; i++) {\n p = p * size;\n \th += noise(p) * influence;\n size *= 2.0;\n influence /= lucanarity;\n }\n return h;\n}\n\n// The code that given a position, gives a height, design the terrain here\nfloat heightAt(in vec2 po) {\n po.x = (po.x + x_offset) * SCALE;\n po.y = (po.y + y_offset) * SCALE;\n return (fbm(po, 3.0) * 3.0) * pow(fbm(po, 0.2),3.0) * (0.03 * H_SCALE);\n}\n\n// returns a value 0.0 to 1.0 representing how far between min and max the value is\nfloat factor(float min, float max, float value) {\n float val = (value - min) / (max - min);\n if (val > 1.0) return 1.0;\n if (val < 0.0) return 0.0;\n return val;\n}\n\n// Takes a point ID and converts it into coordinates\nvec3 pointOf(float id) {\n float x = mod(id, SIZE);\n float y = floor(id / SIZE);\n \n return vec3((-SIZE/2.0 + x) * SPACING, heightAt( vec2( x, y ) / SIZE * 4.0), (-SIZE/2.0 + y) * SPACING );\n}\n\n// Entry point of shader\nvoid main() {\n // Get the point position, x, y and z, with y being the height\n vec3 p = pointOf(vertexId);\n \n // Based on the height (before rotation) determine colors\n vec4 ground_colour = mix(DIRT_COLOUR , GRASS_COLOUR, factor(0.2, 0.0, p.y / H_SCALE));\n \n vec4 top_colour = mix(STONE_COLOUR, SNOW_COLOUR , factor(1.2, 2.0, p.y / H_SCALE));\n \n vec4 colour = mix(ground_colour, top_colour , factor(0.2, 0.3, p.y / H_SCALE));\n \n // Rotate the point around the global Y axis\n p = rotateY(p, time * ROTATE_SPEED);\n // Move the point down\n p.z += 16.0;\n // rotate the point up on the global X axis to simulare the camera looking downwards\n p = rotateX(p, 0.8);\n \n // Set point size based on spacing and the distance (p.z) from the camera\n gl_PointSize = SPACING * (2048.0 * DOT_SIZE) / (pow(p.z,2.0));\n \n // Set the position of the point\n gl_Position = vec4(p.x, p.y - 9.0, 1.0/p.z, p.z);\n \n // Set the color of the point\n v_color = colour;\n}" + }, "screenshotURL": "data/images/images-p7cx82na0xgz3tqbm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8qkLM6jJv2xHNnELZ/art.json b/art/8qkLM6jJv2xHNnELZ/art.json index 6e3eb1cb..505d0166 100644 --- a/art/8qkLM6jJv2xHNnELZ/art.json +++ b/art/8qkLM6jJv2xHNnELZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n //float width = 10.0;\\n \\n float x = floor(vertexId / 2.0) * 0.1;\\n float y = mod(vertexId + 1.0, 2.0) * 0.1;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n \\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 3, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n //float width = 10.0;\n \n float x = floor(vertexId / 2.0) * 0.1;\n float y = mod(vertexId + 1.0, 2.0) * 0.1;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n \n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-b9d3audrv9u6uhur2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8rEyCeYdp5FF6AwKL/art.json b/art/8rEyCeYdp5FF6AwKL/art.json index 58dbc12b..dd76fcd1 100644 --- a/art/8rEyCeYdp5FF6AwKL/art.json +++ b/art/8rEyCeYdp5FF6AwKL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":3860,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Init file\\n\\n//KDrawmode=GL_POINTS\\n\\n//KVerticesNumber=3860\\n\\n// **** K Parameters **********\\n// **** parameter 0 is General Scale/Zoom\\n#define parameter0 200.0//KParameter0 1.0>>100.0\\n// **** parameter 1 is Sound Sensitivity\\n#define parameter1 5.0//KParameter1 1.0>>2.0\\n// **** parameter 2 is x offset mod\\n#define parameter2 0.3//KParameter2 1.0>>2.0\\n// **** parameter 3 is y offset mod\\n#define parameter3 0.3//KParameter3 1.0>>2.0\\n// **** parameter 4 is x mod factor\\n#define parameter4 100.0//KParameter4 10.0>>100.0\\n// **** parameter 5 is y mod factor\\n#define parameter5 100.0//KParameter5 10.0>>100.0\\n\\n\\nvoid main () {\\n float v = vertexId;\\n \\n float grid = floor(vertexCount / 10.0);\\n float scale = parameter0 * 2.0 / (grid);\\n \\n float x = sin(v/100.0); //comod(v, grid); \\n float y = cos(v/100.0); //mod(floor(v / grid), grid);\\n\\n float xoff = parameter2 / 2.0;\\n float yoff = parameter3 / 2.0;\\n \\n float xsound = 0.3; //range of values in sound \\n float ysound = floor((v*240.0) / vertexCount) / 240.0; \\n \\n float sndFactor = texture2D(sound, vec2(xsound , ysound)).a;\\n \\n float xmod = (1.0 - (parameter4 * v / (vertexCount * 100.0)));\\n float ymod = (1.0 - (parameter5 * v / (vertexCount * 100.0)));\\n \\n float ux = (x * xmod * scale - xoff);\\n float uy = (y * ymod * scale - yoff);\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = sndFactor * 10.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 3860, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Init file\n\n//KDrawmode=GL_POINTS\n\n//KVerticesNumber=3860\n\n// **** K Parameters **********\n// **** parameter 0 is General Scale/Zoom\n#define parameter0 200.0//KParameter0 1.0>>100.0\n// **** parameter 1 is Sound Sensitivity\n#define parameter1 5.0//KParameter1 1.0>>2.0\n// **** parameter 2 is x offset mod\n#define parameter2 0.3//KParameter2 1.0>>2.0\n// **** parameter 3 is y offset mod\n#define parameter3 0.3//KParameter3 1.0>>2.0\n// **** parameter 4 is x mod factor\n#define parameter4 100.0//KParameter4 10.0>>100.0\n// **** parameter 5 is y mod factor\n#define parameter5 100.0//KParameter5 10.0>>100.0\n\n\nvoid main () {\n float v = vertexId;\n \n float grid = floor(vertexCount / 10.0);\n float scale = parameter0 * 2.0 / (grid);\n \n float x = sin(v/100.0); //comod(v, grid); \n float y = cos(v/100.0); //mod(floor(v / grid), grid);\n\n float xoff = parameter2 / 2.0;\n float yoff = parameter3 / 2.0;\n \n float xsound = 0.3; //range of values in sound \n float ysound = floor((v*240.0) / vertexCount) / 240.0; \n \n float sndFactor = texture2D(sound, vec2(xsound , ysound)).a;\n \n float xmod = (1.0 - (parameter4 * v / (vertexCount * 100.0)));\n float ymod = (1.0 - (parameter5 * v / (vertexCount * 100.0)));\n \n float ux = (x * xmod * scale - xoff);\n float uy = (y * ymod * scale - yoff);\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = sndFactor * 10.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-gh5c1zvlsf53qxrg0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8rLJCnxAbmAYifi8S/art.json b/art/8rLJCnxAbmAYifi8S/art.json index 785b2782..9276a9c3 100644 --- a/art/8rLJCnxAbmAYifi8S/art.json +++ b/art/8rLJCnxAbmAYifi8S/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(1, 1, 1, 1);\\n v_color = vec4(1, 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(1, 1, 1, 1);\n v_color = vec4(1, 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-fvqg1obfpoipl07bj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8wMcYNHAvNH4qdgzM/art.json b/art/8wMcYNHAvNH4qdgzM/art.json index a9f7316b..729520f9 100644 --- a/art/8wMcYNHAvNH4qdgzM/art.json +++ b/art/8wMcYNHAvNH4qdgzM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user6017377/6n5vosmj8t2h?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\nmat4 rotZ(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n return mat4(\\n c,-s,0,0,\\n s,c,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\n\\nmat4 trans(vec3 trans){\\n return mat4(\\n \\t1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n trans,1);\\n}\\nmat4 ident(){\\n return mat4(\\n \\t1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n \\ts[0],0,0,0,\\n 0,s[1],0,0,\\n 0,0,s[2],0,\\n 0,0,0,1);\\n}\\nmat4 uniformScale(float s){\\n return mat4(\\n \\ts,0,0,0,\\n 0,s,0,0,\\n 0,0,s,0,\\n 0,0,0,1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n float ux = floor(id / 6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id / 3.),2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy +1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\n return vec2(x,y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId/ numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/ 6.0);\\n float oddSlice = mod(sliceId,2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au* .05, av * .25)).a;\\n\\n \\n float sc = pow(snd+0.2,5.) * mix(1., 1.1, oddSlice);\\n float aspect = resolution.x / resolution.y;\\n \\n sc *= (20. * abs(sin(time*10.))) / (across*2.);\\n \\n \\n vec4 pos = vec4(circleXY , 0 ,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.05 * sc );\\n \\n \\n gl_Position = mat * pos;\\n \\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n\\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice *0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user6017377/6n5vosmj8t2h?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\nmat4 rotZ(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n return mat4(\n c,-s,0,0,\n s,c,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\n\nmat4 trans(vec3 trans){\n return mat4(\n \t1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n trans,1);\n}\nmat4 ident(){\n return mat4(\n \t1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\nmat4 scale(vec3 s)\n{\n return mat4(\n \ts[0],0,0,0,\n 0,s[1],0,0,\n 0,0,s[2],0,\n 0,0,0,1);\n}\nmat4 uniformScale(float s){\n return mat4(\n \ts,0,0,0,\n 0,s,0,0,\n 0,0,s,0,\n 0,0,0,1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n float ux = floor(id / 6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id / 3.),2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy +1.;\n \n float x = c * radius;\n float y = s * radius;\n\n return vec2(x,y);\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId/ numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId/ 6.0);\n float oddSlice = mod(sliceId,2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au* .05, av * .25)).a;\n\n \n float sc = pow(snd+0.2,5.) * mix(1., 1.1, oddSlice);\n float aspect = resolution.x / resolution.y;\n \n sc *= (20. * abs(sin(time*10.))) / (across*2.);\n \n \n vec4 pos = vec4(circleXY , 0 ,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.05 * sc );\n \n \n gl_Position = mat * pos;\n \n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n\n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice *0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-kmh4quhap8i18borm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8wij3k6mQCLMeYsgw/art.json b/art/8wij3k6mQCLMeYsgw/art.json index 7cf9cac6..e10fe92e 100644 --- a/art/8wij3k6mQCLMeYsgw/art.json +++ b/art/8wij3k6mQCLMeYsgw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 15.0\\n\\n//\\tClassic Perlin 3D Noise \\n//\\tby Stefan Gustavson\\n//\\nvec4 permute(vec4 x){return mod(((x*6.0)+1.0)*x, 289.0);}\\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\\n\\nfloat cnoise(vec3 P){\\n vec3 Pi0 = floor(P); // Integer part for indexing\\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\\n Pi0 = mod(Pi0, 289.0);\\n Pi1 = mod(Pi1, 289.0);\\n vec3 Pf0 = fract(P); // Fractional part for interpolation\\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\\n vec4 iz0 = Pi0.zzzz;\\n vec4 iz1 = Pi1.zzzz;\\n\\n vec4 ixy = permute(permute(ix) + iy);\\n vec4 ixy0 = permute(ixy + iz0);\\n vec4 ixy1 = permute(ixy + iz1);\\n\\n vec4 gx0 = ixy0 / 7.0;\\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\\n gx0 = fract(gx0);\\n vec4 gz0 = vec4(0.2) - abs(gx0) - abs(gy0);\\n vec4 sz0 = step(gz0, vec4(0.0));\\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\\n\\n vec4 gx1 = ixy1 / 7.0;\\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\\n gx1 = fract(gx1);\\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\\n vec4 sz1 = step(gz1, vec4(0.0));\\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\\n\\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\\n\\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\\n g000 *= norm0.x;\\n g010 *= norm0.y;\\n g100 *= norm0.z;\\n g110 *= norm0.w;\\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\\n g001 *= norm1.x;\\n g011 *= norm1.y;\\n g101 *= norm1.z;\\n g111 *= norm1.w;\\n\\n float n000 = dot(g000, Pf0);\\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\\n float n111 = dot(g111, Pf1);\\n\\n vec3 fade_xyz = fade(Pf0);\\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \\n return 2.2 * n_xyz;\\n}\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angle) {\\nfloat Snd =texture2D(sound,vec2(1)).a;\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, Snd, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount))+33.;\\n \\tfloat cols = floor(vertexCount / rows)/33.;\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\tfloat a = atan(x, y);\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\\n \\tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\\n \\tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\\n float Snd =texture2D(sound,vec2(0)).a;\\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n vec4 pos = vec4(ux, vy, 0, 1);\\n \\tvec3 n = vec3(cnoise(pos.xyz*.51));\\n \\tpos.x += n.x*1.9762*sin(n.x+time);\\n \\t//pos.y += n.y*.62;\\n \\t//pos.z += n.z*.9762;\\n \\t//pos*=rotY(PI*time*.125);\\n \\t//pos*=rotX(PI*time*.0125);\\n\\tgl_Position = pos;\\n \\tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \\n \\n float S =texture2D(volume,vec2(0)).a;\\n// 72.0 /Snd+cols; \\n \\tgl_PointSize *= resolution.x / 33.-S; \\n float hue = s;\\n hue = smoothstep(x, y-S, xOff);\\n float sat = v * xOff;\\n float val = u;\\nint vertexCount =+ 36;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(-PI * soff);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n\\n v_color = finalColor;\\n }\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 15.0\n\n//\tClassic Perlin 3D Noise \n//\tby Stefan Gustavson\n//\nvec4 permute(vec4 x){return mod(((x*6.0)+1.0)*x, 289.0);}\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\n\nfloat cnoise(vec3 P){\n vec3 Pi0 = floor(P); // Integer part for indexing\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\n Pi0 = mod(Pi0, 289.0);\n Pi1 = mod(Pi1, 289.0);\n vec3 Pf0 = fract(P); // Fractional part for interpolation\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\n vec4 iz0 = Pi0.zzzz;\n vec4 iz1 = Pi1.zzzz;\n\n vec4 ixy = permute(permute(ix) + iy);\n vec4 ixy0 = permute(ixy + iz0);\n vec4 ixy1 = permute(ixy + iz1);\n\n vec4 gx0 = ixy0 / 7.0;\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\n gx0 = fract(gx0);\n vec4 gz0 = vec4(0.2) - abs(gx0) - abs(gy0);\n vec4 sz0 = step(gz0, vec4(0.0));\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\n\n vec4 gx1 = ixy1 / 7.0;\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\n gx1 = fract(gx1);\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\n vec4 sz1 = step(gz1, vec4(0.0));\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\n\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\n\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\n g000 *= norm0.x;\n g010 *= norm0.y;\n g100 *= norm0.z;\n g110 *= norm0.w;\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\n g001 *= norm1.x;\n g011 *= norm1.y;\n g101 *= norm1.z;\n g111 *= norm1.w;\n\n float n000 = dot(g000, Pf0);\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\n float n111 = dot(g111, Pf1);\n\n vec3 fade_xyz = fade(Pf0);\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \n return 2.2 * n_xyz;\n}\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angle) {\nfloat Snd =texture2D(sound,vec2(1)).a;\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, Snd, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount))+33.;\n \tfloat cols = floor(vertexCount / rows)/33.;\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\tfloat a = atan(x, y);\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\n \tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\n \tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\n float Snd =texture2D(sound,vec2(0)).a;\n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n vec4 pos = vec4(ux, vy, 0, 1);\n \tvec3 n = vec3(cnoise(pos.xyz*.51));\n \tpos.x += n.x*1.9762*sin(n.x+time);\n \t//pos.y += n.y*.62;\n \t//pos.z += n.z*.9762;\n \t//pos*=rotY(PI*time*.125);\n \t//pos*=rotX(PI*time*.0125);\n\tgl_Position = pos;\n \tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \n \n float S =texture2D(volume,vec2(0)).a;\n// 72.0 /Snd+cols; \n \tgl_PointSize *= resolution.x / 33.-S; \n float hue = s;\n hue = smoothstep(x, y-S, xOff);\n float sat = v * xOff;\n float val = u;\nint vertexCount =+ 36;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(-PI * soff);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n\n v_color = finalColor;\n }" + }, "screenshotURL": "data/images/images-68xxgigumfvm0qyrg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/8xXukzezXszWuCGEN/art.json b/art/8xXukzezXszWuCGEN/art.json index aae272b6..37328cb7 100644 --- a/art/8xXukzezXszWuCGEN/art.json +++ b/art/8xXukzezXszWuCGEN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/666gangstaz/sets/triplesisi\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.10196078431372549,0.10196078431372549,1],\"shader\":\"// terrain\\n#define parameter1 0.22 //KParameter0 -1.>>1.\\n#define parameter2 0.9 //KParameter1 -1.>>1.\\n#define parameter3 -0.5 //KParameter2 -1.>>1.\\n#define PI radians(180.0)\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5);// / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.00100*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n vec3 cameraPos = vec3(parameter1 * 4., mix(5., 1., p1m1(parameter2)), 2.);\\n // vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);//.3;abs(n.z);\\n float val = mix(.05, 1., l);\\n//parameter3* mouse.y;\\n float ss = \\n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5*parameter3), 0.-parameter3)).a;\\n float pop = step(0.6, ss);\\n val = mix(max(val,pop)*parameter2, 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.)*ss;\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/666gangstaz/sets/triplesisi", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.10196078431372549, + 0.10196078431372549, + 1 + ], + "shader": "// terrain\n#define parameter1 0.22 //KParameter0 -1.>>1.\n#define parameter2 0.9 //KParameter1 -1.>>1.\n#define parameter3 -0.5 //KParameter2 -1.>>1.\n#define PI radians(180.0)\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5);// / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.00100*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n vec3 cameraPos = vec3(parameter1 * 4., mix(5., 1., p1m1(parameter2)), 2.);\n // vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);//.3;abs(n.z);\n float val = mix(.05, 1., l);\n//parameter3* mouse.y;\n float ss = \n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5*parameter3), 0.-parameter3)).a;\n float pop = step(0.6, ss);\n val = mix(max(val,pop)*parameter2, 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.)*ss;\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-lich1uojpvhd34g8k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/8xnYpsyL4ENdb24gk/art.json b/art/8xnYpsyL4ENdb24gk/art.json index 0837e0aa..b1694519 100644 --- a/art/8xnYpsyL4ENdb24gk/art.json +++ b/art/8xnYpsyL4ENdb24gk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId ) / (numSections);\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n\\n\\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n //float su = (sideSectionId);// / halfSectionsAcross;\\n\\n float width = 0.5; \\n\\n vec3 pre = mix(\\n vec3(sideSectionId, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5., 0), \\n vert); \\n \\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 1.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n \\n track(id, numTrackPoints, base, pos, color);\\n \\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId ) / (numSections);\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n\n\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n //float su = (sideSectionId);// / halfSectionsAcross;\n\n float width = 0.5; \n\n vec3 pre = mix(\n vec3(sideSectionId, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5., 0), \n vert); \n \n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 1.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n \n track(id, numTrackPoints, base, pos, color);\n \n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-kptg6x04bdsgl4uy7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/93FoywQqcRMeZNRcz/art.json b/art/93FoywQqcRMeZNRcz/art.json index d5cc5bc0..d974c3d3 100644 --- a/art/93FoywQqcRMeZNRcz/art.json +++ b/art/93FoywQqcRMeZNRcz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/rukunetsu/alpha-beat-office-shenmue-rmix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 3.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n vec3 pos = vec3(ca, ce, cd);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 0.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n\\n \\n vec3 center = vec3(sin(time), sin(time * 0.33), sin(time * 0.66));\\n float radius = 1.2;\\n float dist = distance(center, pos);\\n if (dist < radius) {\\n gl_Position = vec4(2, 2, 2, 1);\\n }\\n\\n float sp = pow(s + 0.3, 5.0);\\n float e = pow(clamp(1.0 - (dist - radius), 0.0, 1.0), 5.0);\\n gl_PointSize = mix(1.0, 5.0, e + sp); \\n// gl_PointSize = mix(1.0, 5.0, e + e * sp); \\n \\n float hue = 1.;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color = mix(vec4(vec3(0.2), 1), v_color, e);\\n}\\n \\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/rukunetsu/alpha-beat-office-shenmue-rmix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 3.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n \n vec3 pos = vec3(ca, ce, cd);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 0.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n\n \n vec3 center = vec3(sin(time), sin(time * 0.33), sin(time * 0.66));\n float radius = 1.2;\n float dist = distance(center, pos);\n if (dist < radius) {\n gl_Position = vec4(2, 2, 2, 1);\n }\n\n float sp = pow(s + 0.3, 5.0);\n float e = pow(clamp(1.0 - (dist - radius), 0.0, 1.0), 5.0);\n gl_PointSize = mix(1.0, 5.0, e + sp); \n// gl_PointSize = mix(1.0, 5.0, e + e * sp); \n \n float hue = 1.;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color = mix(vec4(vec3(0.2), 1), v_color, e);\n}\n \n" + }, "screenshotURL": "data/images/images-9amu7dqnevio0ji6c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/93Y6qkZ7f2SBfAPjM/art.json b/art/93Y6qkZ7f2SBfAPjM/art.json index 136c3437..3b10371c 100644 --- a/art/93Y6qkZ7f2SBfAPjM/art.json +++ b/art/93Y6qkZ7f2SBfAPjM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":2065,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Seulbin Seo\\n// Exercise Color2\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main ()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = cos(time * 4.1 + x * 0.2) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy)* 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x + y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 - soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(-time * 1.3 + v * 20.) * 0.05;\\n float sat = cos(time * 1.4 + v * u * 10.0) * 10.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 2065, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Color2\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main ()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = cos(time * 4.1 + x * 0.2) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy)* 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x + y * 0.02) * 5.;\n \n gl_PointSize = 15.0 - soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(-time * 1.3 + v * 20.) * 0.05;\n float sat = cos(time * 1.4 + v * u * 10.0) * 10.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-wfggrg2kw0il8rwtk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/948aadGavoEeSXCac/art.json b/art/948aadGavoEeSXCac/art.json index 60e48427..bb82791f 100644 --- a/art/948aadGavoEeSXCac/art.json +++ b/art/948aadGavoEeSXCac/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.01568627450980392,0.10588235294117647,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = 0.; //pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.350;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.01568627450980392, + 0.10588235294117647, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = 0.; //pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.350;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-83qkjl0slgbybwxms-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/94LjZTzQhciudirXa/art.json b/art/94LjZTzQhciudirXa/art.json index ff38e7d4..ac57ceee 100644 --- a/art/94LjZTzQhciudirXa/art.json +++ b/art/94LjZTzQhciudirXa/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Circles from Triangles\\n// CS250 Spring 2022\\n\\n\\n\\n/// These helper functions are from https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n///\\n\\n\\nvec2 getCirclePoint(float id, float circleSegmentCount)\\n{\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / circleSegmentCount * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n return vec2(c, s) * radius;\\n}\\n\\n\\nvoid main()\\n{\\n float circleSegmentCount = 12.0;\\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentCount);\\n \\n float pointCountPerCircle = circleSegmentCount * 6.0;\\n float circleId = floor(vertexId / pointCountPerCircle);\\n float circleCount = floor(vertexCount / pointCountPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0);\\n \\n float down = floor(sqrt(circleCount));\\n float across = floor(circleCount / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = 0.0;\\n float yOffset = 0.0;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.0) * mix(1.0, 1.1, oddSlice);\\n sc *= 20.0 / across;\\n \\n vec4 pos = vec4(circleXY, 0.0, 1.0);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy, 0) * 1.4);\\n mat *= rotZ(snd * 20.0 * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n gl_Position = mat * pos;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;\\n float saturation = 1.0;\\n float value = mix(0.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n value += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Circles from Triangles\n// CS250 Spring 2022\n\n\n\n/// These helper functions are from https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n///\n\n\nvec2 getCirclePoint(float id, float circleSegmentCount)\n{\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = ux / circleSegmentCount * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n return vec2(c, s) * radius;\n}\n\n\nvoid main()\n{\n float circleSegmentCount = 12.0;\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentCount);\n \n float pointCountPerCircle = circleSegmentCount * 6.0;\n float circleId = floor(vertexId / pointCountPerCircle);\n float circleCount = floor(vertexCount / pointCountPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0);\n \n float down = floor(sqrt(circleCount));\n float across = floor(circleCount / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = 0.0;\n float yOffset = 0.0;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.0) * mix(1.0, 1.1, oddSlice);\n sc *= 20.0 / across;\n \n vec4 pos = vec4(circleXY, 0.0, 1.0);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy, 0) * 1.4);\n mat *= rotZ(snd * 20.0 * sign(ux));\n mat *= uniformScale(0.03 * sc);\n gl_Position = mat * pos;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;\n float saturation = 1.0;\n float value = mix(0.4, pow(snd + 0.2, 5.0), pump);\n \n hue += pump * oddSlice * 0.5 + pump * 0.33;\n value += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-8yuyerekrzm4btwo6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/94o6yb7AZ7dW5Lumb/art.json b/art/94o6yb7AZ7dW5Lumb/art.json index 38116ab2..832abd60 100644 --- a/art/94o6yb7AZ7dW5Lumb/art.json +++ b/art/94o6yb7AZ7dW5Lumb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-kdrsu1k8v0pc6sm58-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/95ZMaZireKi2qhi6L/art.json b/art/95ZMaZireKi2qhi6L/art.json index d2c49b36..1288bb9f 100644 --- a/art/95ZMaZireKi2qhi6L/art.json +++ b/art/95ZMaZireKi2qhi6L/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float x = floor(vertexId/2.0);\\n float y = mod(vertexId, 2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n float radius = y + 1.0;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n vec2 xy = vec2(u, v) * 0.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(1.0, 0.0, 0.5, 1.0);\\n}\"}", + "settings": { + "num": 7, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float x = floor(vertexId/2.0);\n float y = mod(vertexId, 2.0);\n \n float angle = x / 20.0 * radians(360.0);\n float radius = y + 1.0;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n vec2 xy = vec2(u, v) * 0.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(1.0, 0.0, 0.5, 1.0);\n}" + }, "screenshotURL": "data/images/images-zigubmm0a5gmrurfv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/95xHq5YQNNvTEjhsq/art.json b/art/95xHq5YQNNvTEjhsq/art.json index f0ad55b7..f984c618 100644 --- a/art/95xHq5YQNNvTEjhsq/art.json +++ b/art/95xHq5YQNNvTEjhsq/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":333,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n#define KP0 2.//KParameter -2.>>2.\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.5//KParameter 0.3>>7.\\n#define KP2 .3//KParameter 0.4>>2.\\n//KVerticesNumber=333\\n\\n\\n#define PI radians(180.)\\n#define VERTICES_PER_TRI 4\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.198,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 333, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n#define KP0 2.//KParameter -2.>>2.\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.5//KParameter 0.3>>7.\n#define KP2 .3//KParameter 0.4>>2.\n//KVerticesNumber=333\n\n\n#define PI radians(180.)\n#define VERTICES_PER_TRI 4\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.198,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-1ds11efn17xbnz11h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/965mBDin8f5mMFKoZ/art.json b/art/965mBDin8f5mMFKoZ/art.json index 951f216e..f59655d9 100644 --- a/art/965mBDin8f5mMFKoZ/art.json +++ b/art/965mBDin8f5mMFKoZ/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "재우", "avatarUrl": "https://lh6.googleusercontent.com/-2X_KPdDSJQw/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd6jrLpiakTtViM5yPJkYwfQJhnhQ/mo/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n gl_Position = vec4(0, 1, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n gl_Position = vec4(0, 1, 0, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n\n}" + }, "screenshotURL": "data/images/images-y5qtfeqiyyv437k5d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/96HGeYvvkbpZDtRSu/art.json b/art/96HGeYvvkbpZDtRSu/art.json index 70c32bdd..cf6a2023 100644 --- a/art/96HGeYvvkbpZDtRSu/art.json +++ b/art/96HGeYvvkbpZDtRSu/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * .1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 2.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n float st = time; //-0.5 * PI * 10.;\\n float minRez = min(resolution.x, resolution.y);\\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 2000., sin(st * .2) * .5 + .5);\\n gl_PointSize = max(gl_PointSize, 1.0);\\n \\n float z = gl_Position.w / gl_Position.z * .5 + .5;\\n float hue = 1.1;// + mix(.4, .9, sin(st * .1) * .5 + .5);\\n float sat = 1.;\\n float val = 1. ;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * .1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 2.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n float st = time; //-0.5 * PI * 10.;\n float minRez = min(resolution.x, resolution.y);\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 2000., sin(st * .2) * .5 + .5);\n gl_PointSize = max(gl_PointSize, 1.0);\n \n float z = gl_Position.w / gl_Position.z * .5 + .5;\n float hue = 1.1;// + mix(.4, .9, sin(st * .1) * .5 + .5);\n float sat = 1.;\n float val = 1. ;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-8wi7qfhlmr0vlhwvl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/97XDDQ5yWEzZhs6cH/art.json b/art/97XDDQ5yWEzZhs6cH/art.json index 40109b80..5c5b1b79 100644 --- a/art/97XDDQ5yWEzZhs6cH/art.json +++ b/art/97XDDQ5yWEzZhs6cH/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "athega", "avatarUrl": "https://secure.gravatar.com/avatar/ac866057ea99c21292a071d08fadd152?default=retro&size=200", - "settings": "{\"num\":72279,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/bufirolas/bananarama-venus-bufi-edit\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// tobbo\\n\\n#define NUM_SEGMENTS 50.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 3.0, 4.0 / 3.0, 4.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown - 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 72279, + "mode": "LINES", + "sound": "https://soundcloud.com/bufirolas/bananarama-venus-bufi-edit", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// tobbo\n\n#define NUM_SEGMENTS 50.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 3.0, 4.0 / 3.0, 4.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown - 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-fb2enihda8gxtsg24-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/97zwjZPbGFqPWiYZy/art.json b/art/97zwjZPbGFqPWiYZy/art.json index 9305120c..788d9df6 100644 --- a/art/97zwjZPbGFqPWiYZy/art.json +++ b/art/97zwjZPbGFqPWiYZy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n \\n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n \n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-n8m70gchg930xlsxq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/97zwxhJNAYAGKPST2/art.json b/art/97zwxhJNAYAGKPST2/art.json index 5fc4fa38..0a24a8f9 100644 --- a/art/97zwxhJNAYAGKPST2/art.json +++ b/art/97zwxhJNAYAGKPST2/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daniel.shenkutie", "avatarUrl": "https://secure.gravatar.com/avatar/a88931f888921daebbcd2858d5dc3258?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/allaboutthebeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.0784313725490196,0.0784313725490196,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n \\n \\n float accros = down;\\n float x = mod(vertexId,accros);\\n float y = floor(vertexId/accros);\\n float u = x/(accros -1.0);\\n float v = y/(accros -1.0);\\n \\n float snd = texture2D(sound, vec2(u ,0)).a;\\n\\n \\n float xoff = 0.0 ;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0;//sin(time + x * 0.2) * 0.1;\\n\\n \\n float ux = 2.0*u -1.0 +xoff;\\n //float vy = 2.0*v - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, 0);\\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.0;// sin(time + x * y * 0.02) * 5.0;\\n gl_PointSize = snd * 30.0 + soff;\\n gl_PointSize = 20.0;\\n // gl_PointSize *= resolution.x/600.0;\\n \\n float mul = 10.* pow(snd, 5.0);\\n \\n float lum = float(mul * 10.0 + 1.9)/10.;\\n \\n float hue= lum * mul * 0.4;\\n float sat = lum * 0.2;\\n float val = lum;\\n v_color=vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/allaboutthebeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.0784313725490196, + 0.0784313725490196, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n \n \n float accros = down;\n float x = mod(vertexId,accros);\n float y = floor(vertexId/accros);\n float u = x/(accros -1.0);\n float v = y/(accros -1.0);\n \n float snd = texture2D(sound, vec2(u ,0)).a;\n\n \n float xoff = 0.0 ;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.0;//sin(time + x * 0.2) * 0.1;\n\n \n float ux = 2.0*u -1.0 +xoff;\n //float vy = 2.0*v - 1.0 + yoff;\n \n vec2 xy = vec2(ux, 0);\n gl_Position = vec4(xy,0,1);\n \n float soff = 0.0;// sin(time + x * y * 0.02) * 5.0;\n gl_PointSize = snd * 30.0 + soff;\n gl_PointSize = 20.0;\n // gl_PointSize *= resolution.x/600.0;\n \n float mul = 10.* pow(snd, 5.0);\n \n float lum = float(mul * 10.0 + 1.9)/10.;\n \n float hue= lum * mul * 0.4;\n float sat = lum * 0.2;\n float val = lum;\n v_color=vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-e4c3shvkhh697d2yi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/982xbF946ivNRShYF/art.json b/art/982xbF946ivNRShYF/art.json index cc2ff374..f2912c92 100644 --- a/art/982xbF946ivNRShYF/art.json +++ b/art/982xbF946ivNRShYF/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres", "private": false, "username": "-anon-", - "settings": "{\"num\":51903,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.89);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 51903, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.89);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-jh2yp1i2ketxnsdaf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/98PzHFry4xqmuj7qt/art.json b/art/98PzHFry4xqmuj7qt/art.json index ddc149a7..cb06aa32 100644 --- a/art/98PzHFry4xqmuj7qt/art.json +++ b/art/98PzHFry4xqmuj7qt/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "rudy2", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJxjrAjHwwN61-aEd5Ck_NAnP9iTFLqowFJNDG0m=s96-c", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Rudy Castan\\n// Exercise Making A Grid with Colors\\n// CS250 Spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 800.;\\n \\n \\n v_color = 0.5*(vec4(1,0,0,1)+vec4(ux*ux, 1.0-vy, u*u * 2.0 - 1., 1));\\n \\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Rudy Castan\n// Exercise Making A Grid with Colors\n// CS250 Spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 800.;\n \n \n v_color = 0.5*(vec4(1,0,0,1)+vec4(ux*ux, 1.0-vy, u*u * 2.0 - 1., 1));\n \n}" + }, "screenshotURL": "data/images/images-whjiddwcq1iztyf03-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/99zvCpii8eiTj2fo8/art.json b/art/99zvCpii8eiTj2fo8/art.json index 03ca78d2..b96035da 100644 --- a/art/99zvCpii8eiTj2fo8/art.json +++ b/art/99zvCpii8eiTj2fo8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":5320,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/guccimenmusic/pnoid\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=5400\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, mouse.x-.27, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, (0.5 - mouse.x), (s * 0.3)); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0.3, 0, 1, 0,\\n 0, 0.2, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 0.65);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0.0)/f;\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b04) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123*mouse.x);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.5)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,00);\\n \\n mat4 p4 = lookAt(p2 * 2.5, p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * 1.1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 1.5 + 0.5), 2);\\n}\\n\\n\"}", + "settings": { + "num": 5320, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/guccimenmusic/pnoid", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=5400\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, mouse.x-.27, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, (0.5 - mouse.x), (s * 0.3)); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0.3, 0, 1, 0,\n 0, 0.2, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 0.65);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0.0)/f;\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b04) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123*mouse.x);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.5)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,00);\n \n mat4 p4 = lookAt(p2 * 2.5, p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * 1.1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 1.5 + 0.5), 2);\n}\n\n" + }, "screenshotURL": "data/images/images-fkeiuzqtr2so05eqx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9BDdcbJh6rDaD4MBi/art.json b/art/9BDdcbJh6rDaD4MBi/art.json index 0df9e146..1214a1a6 100644 --- a/art/9BDdcbJh6rDaD4MBi/art.json +++ b/art/9BDdcbJh6rDaD4MBi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, -1, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n v_color = vec4(1) - v_color;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, -1, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n v_color = vec4(1) - v_color;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-ljqz9tg2e96biba0y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9C352QniqBDGreXm2/art.json b/art/9C352QniqBDGreXm2/art.json index 127ae1a4..079fd6ed 100644 --- a/art/9C352QniqBDGreXm2/art.json +++ b/art/9C352QniqBDGreXm2/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/fnkypanda/electroswing-11-acorn-lane-spend-my-time-with-you-electro-swing-remix\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n#define ACROSS 100.0\\n#define TOTAL 5000.0\\n#define DOWN (TOTAL / ACROSS)\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float count = mod(vertexId, TOTAL) + time * 0.0;\\n float xId = mod(vertexId, ACROSS);\\n float yId = floor(vertexId / ACROSS);\\n float xr = xId / ACROSS;\\n float yr = yId / DOWN;\\n float invX = 1.0 - xr;\\n float invY = 1.0 - yr;\\n float x = xr * 2.0 - 1.0;\\n float y = yr * 2.0 - 1.0;\\n \\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n\\n vec2 xy = vec2(x, y);\\n\\n float dd = length(xy);\\n float x2 = xr;\\n float y2 = yr;\\n float snd = pow(texture2D(sound, vec2(abs(dd) * 0.2, dd * 0.05)).a, 5.0);\\n gl_PointSize = pow(snd, 1.0) * 20.0;\\n \\n// xy = xy + xy * snd ;\\n gl_Position = vec4(xy * aspect * pow(snd + 0.4, 2.0), 0, 1);\\n \\n float hue = (snd * 0.2) + time;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 1, 1)), vec3(1,1,1), pow(snd, 0.5)), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}//nice lines spike\"}", + "settings": { + "num": 5000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/fnkypanda/electroswing-11-acorn-lane-spend-my-time-with-you-electro-swing-remix", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n#define ACROSS 100.0\n#define TOTAL 5000.0\n#define DOWN (TOTAL / ACROSS)\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float count = mod(vertexId, TOTAL) + time * 0.0;\n float xId = mod(vertexId, ACROSS);\n float yId = floor(vertexId / ACROSS);\n float xr = xId / ACROSS;\n float yr = yId / DOWN;\n float invX = 1.0 - xr;\n float invY = 1.0 - yr;\n float x = xr * 2.0 - 1.0;\n float y = yr * 2.0 - 1.0;\n \n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n\n vec2 xy = vec2(x, y);\n\n float dd = length(xy);\n float x2 = xr;\n float y2 = yr;\n float snd = pow(texture2D(sound, vec2(abs(dd) * 0.2, dd * 0.05)).a, 5.0);\n gl_PointSize = pow(snd, 1.0) * 20.0;\n \n// xy = xy + xy * snd ;\n gl_Position = vec4(xy * aspect * pow(snd + 0.4, 2.0), 0, 1);\n \n float hue = (snd * 0.2) + time;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 1, 1)), vec3(1,1,1), pow(snd, 0.5)), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}//nice lines spike" + }, "screenshotURL": "data/images/images-xtta21qjsf4zi2n5h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9CuFBCB2ddb7NzNRQ/art.json b/art/9CuFBCB2ddb7NzNRQ/art.json index c7eded99..bb7c220b 100644 --- a/art/9CuFBCB2ddb7NzNRQ/art.json +++ b/art/9CuFBCB2ddb7NzNRQ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "vtastek", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GhEZNzAJ1BiVlu4lTAGq0z7AxbDLImlvKBpKcU_rA=s96-c", - "settings": "{\"num\":24571,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const mat4 ModelViewProjection = mat4(\\n 0.974278, 0.000000,\\t 0.000000, 0.000000,\\n 0.000000, 1.326827, -0.643173, -0.642787,\\n 0.000000,\\t 1.113340,\\t 0.766504,\\t 0.766044,\\n-14.614178,\\t-9.836445,\\t23.760851,\\t24.346418\\n);\\n\\nvec3 BezierCurve (vec3 a, vec3 b, vec3 c, vec3 d, float t)\\n{\\n float x = a.x * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.x * t * (1.0 - t) * (1.0 - t) + 3.0 * c.x * t * t * (1.0 - t) + d.x * t * t * t;\\n float y = a.y * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.y * t * (1.0 - t) * (1.0 - t) + 3.0 * c.y * t * t * (1.0 - t) + d.y * t * t * t;\\n float z = a.z * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.z * t * (1.0 - t) * (1.0 - t) + 3.0 * c.z * t * t * (1.0 - t) + d.z * t * t * t;\\n return vec3 (x, y, z);\\n}\\n\\nvec3 BezierPatch (float u, float v)\\n{\\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\\n return BezierCurve(a, b, c, d, v);\\n}\\n\\nvec3 BezierPatchNormal (float u, float v)\\n{\\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\\n vec3 dv = -3.0 * (1.0 - v) * (1.0 - v) * a + (3.0 * (1.0 - v) * (1.0 - v) - 6.0 * v * (1.0 - v)) * b + (6.0 * v * (1.0 - v) - 3.0 * v * v) * c + 3.0 * v * v * d;\\n vec3 e = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(00.0, 00.0, 10.0), vec3(00.0, 00.0, 20.0), vec3(00.0, 00.0, 30.0), v);\\n vec3 f = BezierCurve (vec3(10.0, 00.0, 00.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(10.0, 00.0, 30.0), v);\\n vec3 g = BezierCurve (vec3(20.0, 00.0, 00.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(20.0, 00.0, 30.0), v);\\n vec3 h = BezierCurve (vec3(30.0, 00.0, 00.0), vec3(30.0, 00.0, 10.0), vec3(30.0, 00.0, 20.0), vec3(30.0, 00.0, 30.0), v); \\n vec3 du = -3.0 * (1.0 - u) * (1.0 - u) * e + (3.0 * (1.0 - u) * (1.0 - u) - 6.0 * u * (1.0 - u)) * f + (6.0 * u * (1.0 - u) - 3.0 * u * u) * g + 3.0 * u * u * h;\\n return normalize(cross(dv, du));\\n}\\n\\nvec3 hash(float p)\\n{\\n vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973));\\n p3 += dot(p3, p3.yzx+33.33);\\n return fract((p3.xxy+p3.yzz)*p3.zyx); \\n}\\n\\nvoid main() \\n{ \\n int tessellationFactor = 64; // vertex count = _TessellationFactor * _TessellationFactor * 6\\n int instance = int(floor(vertexId / 6.0));\\n float x = sign(mod(float(vertexId), 2.0));\\n float y = sign(mod(126.0, mod(float(vertexId), 6.0) + 6.0));\\n float u = (float(instance / tessellationFactor) + x) / float(tessellationFactor);\\n float v = (mod(float(instance), float(tessellationFactor)) + y) / float(tessellationFactor); \\n gl_Position = ModelViewProjection * vec4(BezierPatch(u,v) , 1); \\n vec3 lightDir = normalize(vec3(10,10,-10));\\n vec3 normalDir = BezierPatchNormal(u,v);\\n float d = max(dot(lightDir, normalDir), 0.2);\\n v_color = vec4(hash(float(instance + 123)), 1.0) * vec4(d, d, d, 1.0);\\n}\"}", + "settings": { + "num": 24571, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const mat4 ModelViewProjection = mat4(\n 0.974278, 0.000000,\t 0.000000, 0.000000,\n 0.000000, 1.326827, -0.643173, -0.642787,\n 0.000000,\t 1.113340,\t 0.766504,\t 0.766044,\n-14.614178,\t-9.836445,\t23.760851,\t24.346418\n);\n\nvec3 BezierCurve (vec3 a, vec3 b, vec3 c, vec3 d, float t)\n{\n float x = a.x * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.x * t * (1.0 - t) * (1.0 - t) + 3.0 * c.x * t * t * (1.0 - t) + d.x * t * t * t;\n float y = a.y * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.y * t * (1.0 - t) * (1.0 - t) + 3.0 * c.y * t * t * (1.0 - t) + d.y * t * t * t;\n float z = a.z * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.z * t * (1.0 - t) * (1.0 - t) + 3.0 * c.z * t * t * (1.0 - t) + d.z * t * t * t;\n return vec3 (x, y, z);\n}\n\nvec3 BezierPatch (float u, float v)\n{\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\n return BezierCurve(a, b, c, d, v);\n}\n\nvec3 BezierPatchNormal (float u, float v)\n{\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\n vec3 dv = -3.0 * (1.0 - v) * (1.0 - v) * a + (3.0 * (1.0 - v) * (1.0 - v) - 6.0 * v * (1.0 - v)) * b + (6.0 * v * (1.0 - v) - 3.0 * v * v) * c + 3.0 * v * v * d;\n vec3 e = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(00.0, 00.0, 10.0), vec3(00.0, 00.0, 20.0), vec3(00.0, 00.0, 30.0), v);\n vec3 f = BezierCurve (vec3(10.0, 00.0, 00.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(10.0, 00.0, 30.0), v);\n vec3 g = BezierCurve (vec3(20.0, 00.0, 00.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(20.0, 00.0, 30.0), v);\n vec3 h = BezierCurve (vec3(30.0, 00.0, 00.0), vec3(30.0, 00.0, 10.0), vec3(30.0, 00.0, 20.0), vec3(30.0, 00.0, 30.0), v); \n vec3 du = -3.0 * (1.0 - u) * (1.0 - u) * e + (3.0 * (1.0 - u) * (1.0 - u) - 6.0 * u * (1.0 - u)) * f + (6.0 * u * (1.0 - u) - 3.0 * u * u) * g + 3.0 * u * u * h;\n return normalize(cross(dv, du));\n}\n\nvec3 hash(float p)\n{\n vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973));\n p3 += dot(p3, p3.yzx+33.33);\n return fract((p3.xxy+p3.yzz)*p3.zyx); \n}\n\nvoid main() \n{ \n int tessellationFactor = 64; // vertex count = _TessellationFactor * _TessellationFactor * 6\n int instance = int(floor(vertexId / 6.0));\n float x = sign(mod(float(vertexId), 2.0));\n float y = sign(mod(126.0, mod(float(vertexId), 6.0) + 6.0));\n float u = (float(instance / tessellationFactor) + x) / float(tessellationFactor);\n float v = (mod(float(instance), float(tessellationFactor)) + y) / float(tessellationFactor); \n gl_Position = ModelViewProjection * vec4(BezierPatch(u,v) , 1); \n vec3 lightDir = normalize(vec3(10,10,-10));\n vec3 normalDir = BezierPatchNormal(u,v);\n float d = max(dot(lightDir, normalDir), 0.2);\n v_color = vec4(hash(float(instance + 123)), 1.0) * vec4(d, d, d, 1.0);\n}" + }, "screenshotURL": "data/images/images-c4580x30auzhavrx6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9DkMjvaQEsZt6yz86/art.json b/art/9DkMjvaQEsZt6yz86/art.json index 9bd4ddcf..9b62b0bd 100644 --- a/art/9DkMjvaQEsZt6yz86/art.json +++ b/art/9DkMjvaQEsZt6yz86/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "noah", "avatarUrl": "https://lh6.googleusercontent.com/-hKeVEDw-dKI/AAAAAAAAAAI/AAAAAAAAAEI/Y7P2dQVbzrs/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float aspect = resolution.y / resolution.x;\\n float columns = floor(sqrt(vertexCount / aspect));\\n float rows = floor(vertexCount / columns);\\n \\n float x = mod(vertexId, columns);\\n float y = (vertexId - x) / columns;\\n gl_Position = vec4(-1. + 2. * x / columns, -1. + 2. * y / rows, 0, 1);\\n gl_PointSize = 4.0;\\n \\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float aspect = resolution.y / resolution.x;\n float columns = floor(sqrt(vertexCount / aspect));\n float rows = floor(vertexCount / columns);\n \n float x = mod(vertexId, columns);\n float y = (vertexId - x) / columns;\n gl_Position = vec4(-1. + 2. * x / columns, -1. + 2. * y / rows, 0, 1);\n gl_PointSize = 4.0;\n \n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-ynv55jlg9dhdjhx0d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9EJbRaRyPZMpJ9zLk/art.json b/art/9EJbRaRyPZMpJ9zLk/art.json index 30610f29..37aad284 100644 --- a/art/9EJbRaRyPZMpJ9zLk/art.json +++ b/art/9EJbRaRyPZMpJ9zLk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "athega", "avatarUrl": "https://secure.gravatar.com/avatar/ac866057ea99c21292a071d08fadd152?default=retro&size=200", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"plasma grid\\\" by johanberonius\\n\\nvoid main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"plasma grid\" by johanberonius\n\nvoid main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-v0qo9zidfn0r1lnri-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9FnEPTtPhMxdktE4t/art.json b/art/9FnEPTtPhMxdktE4t/art.json index 1cb408e7..b3a5bd41 100644 --- a/art/9FnEPTtPhMxdktE4t/art.json +++ b/art/9FnEPTtPhMxdktE4t/art.json @@ -27,7 +27,19 @@ "name": "sleep", "private": true, "username": "spotline", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/unpeuderepos\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float x = vertexId * 0.025;\\n x = mod(x,2.0);\\n x-= 1.0;\\n float y = texture2D(sound,vec2(vertexId/soundRes.x,0.0)).a*0.5;\\n y*= 1.0 + vertexId * 0.02;\\n float instantY = y;\\n int smoothCount = 10;\\n for ( int i=0; i <= 10; i++)\\n {\\n y+=texture2D(sound,vec2(vertexId/soundRes.x,float(i)/float(smoothCount)/128.0)).a;\\n }\\n y/=float(smoothCount+1);\\n float lum = clamp(instantY-y,0.0,1.0)*1.0;\\n\\n y = pow(y,2.0)-0.5;\\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = 15.0;\\n v_color = vec4((0.2+lum)*instantY,(0.2+lum)*instantY,(0.8+lum)*instantY,instantY);\\n}\\n\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/unpeuderepos", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float x = vertexId * 0.025;\n x = mod(x,2.0);\n x-= 1.0;\n float y = texture2D(sound,vec2(vertexId/soundRes.x,0.0)).a*0.5;\n y*= 1.0 + vertexId * 0.02;\n float instantY = y;\n int smoothCount = 10;\n for ( int i=0; i <= 10; i++)\n {\n y+=texture2D(sound,vec2(vertexId/soundRes.x,float(i)/float(smoothCount)/128.0)).a;\n }\n y/=float(smoothCount+1);\n float lum = clamp(instantY-y,0.0,1.0)*1.0;\n\n y = pow(y,2.0)-0.5;\n gl_Position = vec4(x,y,0,1);\n gl_PointSize = 15.0;\n v_color = vec4((0.2+lum)*instantY,(0.2+lum)*instantY,(0.8+lum)*instantY,instantY);\n}\n" + }, "screenshotURL": "data/images/images-yk7uu9kmgu0tonf12-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9GCFDmZiEXGbgKMny/art.json b/art/9GCFDmZiEXGbgKMny/art.json index 9bbafc99..791b4ebe 100644 --- a/art/9GCFDmZiEXGbgKMny/art.json +++ b/art/9GCFDmZiEXGbgKMny/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\nMaking a grid\\n2022 spring\\n*/\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\nMaking a grid\n2022 spring\n*/\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-f30p5xu549kqo9029-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9Geyfsezar7Y45X4W/art.json b/art/9Geyfsezar7Y45X4W/art.json index 995419ab..d54e63fe 100644 --- a/art/9Geyfsezar7Y45X4W/art.json +++ b/art/9Geyfsezar7Y45X4W/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "masoud", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocKduENtgZ5YgN-oFXWds5z6iD7S4GtlK8DMGCULeb3_jNsAvHg=s96-c", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/manon-ariza/tortuga-deities\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nfloat radius = 0.15;\\nfloat amount = 100.;\\nfloat len = vertexCount / amount;\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (4.0 - 3.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, 1.0, 3.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + 1.0);\\n\\n vec4 o1 = fract(k3 * (1.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (1.0 - d.y);\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float seg = floor(vertexId/len);\\n float segId = mod(vertexId,len);\\n float v = texture2D(volume, vec2(1., (1.+seg)/amount*240.)).a;\\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\\n float n = noise(p);\\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\\n \\n x += cos(n * PI*4.) * segId * 0.000002 * s;\\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\\n \\n gl_Position = vec4(x, y, 0, 1);\\n\\n float b = 0.3 / mod(vertexId/len,1.);\\n v_color = vec4(vec3(b), 0.5);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/manon-ariza/tortuga-deities", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nfloat radius = 0.15;\nfloat amount = 100.;\nfloat len = vertexCount / amount;\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (4.0 - 3.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, 1.0, 3.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + 1.0);\n\n vec4 o1 = fract(k3 * (1.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (1.0 - d.y);\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float seg = floor(vertexId/len);\n float segId = mod(vertexId,len);\n float v = texture2D(volume, vec2(1., (1.+seg)/amount*240.)).a;\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\n float n = noise(p);\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\n \n x += cos(n * PI*4.) * segId * 0.000002 * s;\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\n \n gl_Position = vec4(x, y, 0, 1);\n\n float b = 0.3 / mod(vertexId/len,1.);\n v_color = vec4(vec3(b), 0.5);\n}" + }, "screenshotURL": "data/images/images-hab4ufgz0c3ptb08c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9GqsA2ooryruyLSRG/art.json b/art/9GqsA2ooryruyLSRG/art.json index 64c6ee93..0b1a7a30 100644 --- a/art/9GqsA2ooryruyLSRG/art.json +++ b/art/9GqsA2ooryruyLSRG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":2048,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define PHI_A (3.-sqrt(5.))* PI\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float scale = .5; // repeats/extends\\n float size = 0.001; // stretch/squeeze\\n float rad_max = (vertexCount * size);\\n \\n float theta = PHI_A * vertexId;// * PHI_A;\\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\\n float snd = texture2D(sound, vec2(fract(theta / 128.0), fract(theta / 20000.0))).a;\\n float radius = sqrt(vertexId * size) + snd;\\n \\n radius = radius * scale;\\n \\n float xoff = sin(time*0.8) * 0.8;\\n float yoff = sin(time*1.3) * 0.1;\\n gl_Position = vec4(cos(theta) * radius,\\n sin(theta) * radius,\\n 0, 1);\\n gl_PointSize = 5. * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\\n\\n float hue = snd*0.01 + time * 0.1;\\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\\n mix(1., 0., step(snd, 0.8))\\n )), 1);\\n}\"}", + "settings": { + "num": 2048, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define PHI_A (3.-sqrt(5.))* PI\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float scale = .5; // repeats/extends\n float size = 0.001; // stretch/squeeze\n float rad_max = (vertexCount * size);\n \n float theta = PHI_A * vertexId;// * PHI_A;\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\n float snd = texture2D(sound, vec2(fract(theta / 128.0), fract(theta / 20000.0))).a;\n float radius = sqrt(vertexId * size) + snd;\n \n radius = radius * scale;\n \n float xoff = sin(time*0.8) * 0.8;\n float yoff = sin(time*1.3) * 0.1;\n gl_Position = vec4(cos(theta) * radius,\n sin(theta) * radius,\n 0, 1);\n gl_PointSize = 5. * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\n\n float hue = snd*0.01 + time * 0.1;\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\n mix(1., 0., step(snd, 0.8))\n )), 1);\n}" + }, "screenshotURL": "data/images/images-p5leujhh7v4dpq7tk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9HqeuYzYy5SPwWWzC/art.json b/art/9HqeuYzYy5SPwWWzC/art.json index 3fb25c3b..9a8f38d2 100644 --- a/art/9HqeuYzYy5SPwWWzC/art.json +++ b/art/9HqeuYzYy5SPwWWzC/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Color\\n//Course : CS250\\n//Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n \\treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2.0 - 1.0 + xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time * 1.2 + x * y * 0.02) * 0.5;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tfloat hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n \\tfloat sat = 1.0;\\n \\tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Color\n//Course : CS250\n//Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n \treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2.0 - 1.0 + xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time * 1.2 + x * y * 0.02) * 0.5;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tfloat hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\n \tfloat sat = 1.0;\n \tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-kfi330moddrvvhtjn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9JiSBh95g2uDrbJF8/art.json b/art/9JiSBh95g2uDrbJF8/art.json index f6da9374..0a9c3c22 100644 --- a/art/9JiSBh95g2uDrbJF8/art.json +++ b/art/9JiSBh95g2uDrbJF8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0.0, 0.0, 0.0, 0.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0.0, 0.0, 0.0, 0.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-w23o9pd6e8esszawt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9K6tGbtzRXNPPboM5/art.json b/art/9K6tGbtzRXNPPboM5/art.json index 7fb835e0..f820063b 100644 --- a/art/9K6tGbtzRXNPPboM5/art.json +++ b/art/9K6tGbtzRXNPPboM5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":23736,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hema_singer/o-sajna-live-movie-parakh\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.9882352941176471,0.4745098039215686,1],\"shader\":\"/*\\n\\n _ \\n | | \\n __ _____ _ __| |_ _____ __ \\n \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / \\n \\\\ V / __/ | | || __/> < \\n \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\ \\n | | | | \\n ___| |__ __ _ __| | ___ _ __ \\n / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__|\\n \\\\__ \\\\ | | | (_| | (_| | __/ | \\n |___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\n | | \\n __ _ _ __| |_ \\n / _` | '__| __| \\n | (_| | | | |_ \\n \\\\__,_|_| \\\\__| \\n \\n \\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[3][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_PARTS_PER_PETAL 20.\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 4.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float circleId, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = 0.;//texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n float z = mix(inner, 1., level);\\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. + sin(time * 1. + (circleId + z) * 0.1) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return (sin(t) + sin(t * 0.27) + sin(t * 1.53) + sin(t * 1.73)) / 4.;\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float petalId = floor(circleId / NUM_PARTS_PER_PETAL);\\n circleId = mod(circleId, NUM_PARTS_PER_PETAL);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE / 12.);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.0;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, circleId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += circleId * 2.6;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n float edgeId = circleId + pos.z * 0.76;\\n \\n float ss = texture2D(sound, vec2(0.053, edgeId / numCircles * 1.)).a;\\n \\n vec3 camera = vec3(0, 50., -0.01);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65. * resolution.y / resolution.x), resolution.x / resolution.y, 0.1, 100.);\\n mat *= rotZ(sin(time * 0.1));\\n mat *= cameraLookAt(camera, target, up);\\n mat *= rotY(petalId / 12. * PI * 2. + sin(time * 0.4 + 3. + edgeId * mix(0.1, 0.5, p1m1(sin(time * 0.1)))) * 0.3);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n float sc = mix(0.5, 5., mix(1., 2., pow(edgeId / numCircles, 10.))\\n * (pow(ss + 0.2, 5.0) + pow(goop((time * 0.1 + 38. + edgeId) * 0.1), 3.)));\\n mat *= scale(vec3(sc, sc, 2.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float hue = mix(0.0, 0.5, mod(uvf.z, 2.)) + time * 0.1;\\n float sat = 1.; mod(uvf.z, 2.);\\n float val = mix(0.5, 1., fract((edgeId)* 0.25 - time));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), );\\n}\"}", + "settings": { + "num": 23736, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hema_singer/o-sajna-live-movie-parakh", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.9882352941176471, + 0.4745098039215686, + 1 + ], + "shader": "/*\n\n _ \n | | \n __ _____ _ __| |_ _____ __ \n \\ \\ / / _ \\ '__| __/ _ \\ \\/ / \n \\ V / __/ | | || __/> < \n \\_/ \\___|_| \\__\\___/_/\\_\\ \n | | | | \n ___| |__ __ _ __| | ___ _ __ \n / __| '_ \\ / _` |/ _` |/ _ \\ '__|\n \\__ \\ | | | (_| | (_| | __/ | \n |___/_| |_|\\__,_|\\__,_|\\___|_| \n | | \n __ _ _ __| |_ \n / _` | '__| __| \n | (_| | | | |_ \n \\__,_|_| \\__| \n \n \n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[3][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_PARTS_PER_PETAL 20.\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 4.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float circleId, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = 0.;//texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n float z = mix(inner, 1., level);\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. + sin(time * 1. + (circleId + z) * 0.1) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return (sin(t) + sin(t * 0.27) + sin(t * 1.53) + sin(t * 1.73)) / 4.;\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float petalId = floor(circleId / NUM_PARTS_PER_PETAL);\n circleId = mod(circleId, NUM_PARTS_PER_PETAL);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE / 12.);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.0;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, circleId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += circleId * 2.6;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n float edgeId = circleId + pos.z * 0.76;\n \n float ss = texture2D(sound, vec2(0.053, edgeId / numCircles * 1.)).a;\n \n vec3 camera = vec3(0, 50., -0.01);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = ident(); \n mat *= persp(radians(65. * resolution.y / resolution.x), resolution.x / resolution.y, 0.1, 100.);\n mat *= rotZ(sin(time * 0.1));\n mat *= cameraLookAt(camera, target, up);\n mat *= rotY(petalId / 12. * PI * 2. + sin(time * 0.4 + 3. + edgeId * mix(0.1, 0.5, p1m1(sin(time * 0.1)))) * 0.3);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n float sc = mix(0.5, 5., mix(1., 2., pow(edgeId / numCircles, 10.))\n * (pow(ss + 0.2, 5.0) + pow(goop((time * 0.1 + 38. + edgeId) * 0.1), 3.)));\n mat *= scale(vec3(sc, sc, 2.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float hue = mix(0.0, 0.5, mod(uvf.z, 2.)) + time * 0.1;\n float sat = 1.; mod(uvf.z, 2.);\n float val = mix(0.5, 1., fract((edgeId)* 0.25 - time));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), );\n}" + }, "screenshotURL": "data/images/images-d1p9f1pwgfqv1xhlr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9L4TTn35TGvpgnmg9/art.json b/art/9L4TTn35TGvpgnmg9/art.json index 299399e4..6c94063f 100644 --- a/art/9L4TTn35TGvpgnmg9/art.json +++ b/art/9L4TTn35TGvpgnmg9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"plasma grid\\\" by johanberonius\\n\\nvoid main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 12.63 + v * 2.9) * 0.9 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"plasma grid\" by johanberonius\n\nvoid main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 12.63 + v * 2.9) * 0.9 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-8rsdimycn88z4qzny-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9LWMct8y82GY9ojKB/art.json b/art/9LWMct8y82GY9ojKB/art.json index 7032bc39..87709050 100644 --- a/art/9LWMct8y82GY9ojKB/art.json +++ b/art/9LWMct8y82GY9ojKB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Audio Reactive\\n// CS250 Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nuniform float u_time;\\nvec3 permute(vec3 x) { return mod(((x*34.0)+1.0)*x, 289.0); }\\n\\nfloat noise(vec2 v){\\n const vec4 C = vec4(0.2113247, 0.36602784439,\\n -0.5773526, 0.0243902439);\\n vec2 i = floor(v + dot(v, C.yy) );\\n vec2 x0 = v - i + dot(i, C.xx);\\n\\n vec2 i1;\\n i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);\\n vec4 x12 = x0.xyxy + C.xxzz;\\n x12.xy -= i1;\\n\\n i = mod(i, 289.0);\\n vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))\\n + i.x + vec3(0.0, i1.x, 1.0 ));\\n\\n vec3 m = max(0.5 - vec3(dot(x0,x0), dot(x12.xy,x12.xy),\\n dot(x12.zw,x12.zw)), 0.0);\\n m = m*m ;\\n m = m*m ;\\n\\n vec3 x = 2.0 * fract(p * C.www) - 1.0;\\n vec3 h = abs(x) - 0.5;\\n vec3 ox = floor(x + 0.5);\\n vec3 a0 = x - ox;\\n\\n m *= 1.792842 - 0.153734 * ( a0*a0 + h*h );\\n\\n vec3 g;\\n g.x = a0.x * x0.x + h.x * x0.y;\\n g.yz = a0.yz * x12.xz + h.yz * x12.yw;\\n return 130.0 * dot(m, g);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5);\\n float sv = abs(v - 0.1);\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float n = noise(vec2(u, v) + u_time * 0.1);\\n \\n vec2 xy = vec2( u * 2. - 1., v * 2. - 1.) * 1.3;\\n float z = snd * 2.0 - 1.0;\\n \\n gl_Position = vec4(xy, z, 1);\\n \\n float soff = 1.;\\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n\\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + u_time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(n *hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Audio Reactive\n// CS250 Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nuniform float u_time;\nvec3 permute(vec3 x) { return mod(((x*34.0)+1.0)*x, 289.0); }\n\nfloat noise(vec2 v){\n const vec4 C = vec4(0.2113247, 0.36602784439,\n -0.5773526, 0.0243902439);\n vec2 i = floor(v + dot(v, C.yy) );\n vec2 x0 = v - i + dot(i, C.xx);\n\n vec2 i1;\n i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);\n vec4 x12 = x0.xyxy + C.xxzz;\n x12.xy -= i1;\n\n i = mod(i, 289.0);\n vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))\n + i.x + vec3(0.0, i1.x, 1.0 ));\n\n vec3 m = max(0.5 - vec3(dot(x0,x0), dot(x12.xy,x12.xy),\n dot(x12.zw,x12.zw)), 0.0);\n m = m*m ;\n m = m*m ;\n\n vec3 x = 2.0 * fract(p * C.www) - 1.0;\n vec3 h = abs(x) - 0.5;\n vec3 ox = floor(x + 0.5);\n vec3 a0 = x - ox;\n\n m *= 1.792842 - 0.153734 * ( a0*a0 + h*h );\n\n vec3 g;\n g.x = a0.x * x0.x + h.x * x0.y;\n g.yz = a0.yz * x12.xz + h.yz * x12.yw;\n return 130.0 * dot(m, g);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5);\n float sv = abs(v - 0.1);\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float n = noise(vec2(u, v) + u_time * 0.1);\n \n vec2 xy = vec2( u * 2. - 1., v * 2. - 1.) * 1.3;\n float z = snd * 2.0 - 1.0;\n \n gl_Position = vec4(xy, z, 1);\n \n float soff = 1.;\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n\n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + u_time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(n *hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-9wokw46w0pb4tfj80-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9LoJ64iLFmQukm5ha/art.json b/art/9LoJ64iLFmQukm5ha/art.json index f3b28ecb..ff0c6dc3 100644 --- a/art/9LoJ64iLFmQukm5ha/art.json +++ b/art/9LoJ64iLFmQukm5ha/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":69139,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.027450980392156862,0.027450980392156862,0.19215686274509805,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : color own variation\\n//course name : CS250\\n//term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = (x*y) / (across - 1.);\\n float v = (x*y) / (across - 1.);\\n \\n float xoff = sin(time + x + y ) * 0.3 ; \\n float yoff = 0.1;\\n\\n \\n float ux = xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 100.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 69139, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.027450980392156862, + 0.027450980392156862, + 0.19215686274509805, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : color own variation\n//course name : CS250\n//term : Spring 2023\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = (x*y) / (across - 1.);\n float v = (x*y) / (across - 1.);\n \n float xoff = sin(time + x + y ) * 0.3 ; \n float yoff = 0.1;\n\n \n float ux = xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 100.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-n4ukdvlgz1qknotfq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9MHkQW36H4sMgEA4e/art.json b/art/9MHkQW36H4sMgEA4e/art.json index 3aab95af..0795296f 100644 --- a/art/9MHkQW36H4sMgEA4e/art.json +++ b/art/9MHkQW36H4sMgEA4e/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/yellow-sunshine-explosion/hi-profile-machines-in-heaven\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,0,0,1],\"shader\":\"/*\\n\\n\\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \\n /_/\\\\ /\\\\_\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\_______)\\\\ /\\\\_____\\\\/\\\\ /\\\\ /\\\\/ ____/\\\\ /\\\\_\\\\ /_/\\\\ /\\\\___/\\\\ /\\\\ __/\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\___/\\\\ /_/\\\\__/\\\\ /\\\\_______)\\\\ \\n ) ) ) ( (( (_____/) ) ) ) )\\\\(___ __\\\\/( (_____/\\\\ \\\\ \\\\/ / /) ) __\\\\/( ( (_) ) ) / / _ \\\\ \\\\ ) ) \\\\ \\\\( (_____/) ) ) ) ) / / _ \\\\ \\\\ ) ) ) ) )\\\\(___ __\\\\/ \\n/_/ / \\\\ \\\\_\\\\\\\\ \\\\__\\\\ /_/ /_/_/ / / / \\\\ \\\\__\\\\ \\\\ \\\\ / / \\\\ \\\\ \\\\ \\\\ \\\\___/ / \\\\ \\\\(_)/ // / /\\\\ \\\\ \\\\\\\\ \\\\__\\\\ /_/ /_/_/ \\\\ \\\\(_)/ //_/ /_/_/ / / / \\n\\\\ \\\\ \\\\_/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( / /__/_ / / \\\\ \\\\ _\\\\ \\\\ \\\\ / / _ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( \\n \\\\ \\\\ / /( (_____\\\\)_) ) \\\\ \\\\ \\\\ \\\\ \\\\ ( (_____\\\\/ / /\\\\ \\\\ \\\\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\\\)_) ) \\\\ \\\\( (_( )_) ))_) ) \\\\ \\\\ \\\\ \\\\ \\\\ \\n \\\\_\\\\_/_/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ /_/_/ \\\\/_____/\\\\/__\\\\/__\\\\/\\\\____\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/___\\\\/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\_\\\\/ \\\\_\\\\/ /_/_/ \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 256.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 2.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n pos = vec3(c, v, s); \\n uv = vec2(u, v);//vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float edgeId = mod(vertexId, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float u2 = floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE;\\n float st = fract(cu + time);\\n float invSt = 1.0 - st;\\n float inner = 0.0;//mix(0.5, 1.0, pow(snd + .3, 5.0));//0.9; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\\n float start = fract(hash(circleId * 0.33));\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2(mix(0.0, 0.25, uv.x), st * 0.25)).a;\\n \\n vec3 offset = vec3(t2m1(hash(circleId * floor(time * 1.2) * 0.123)), t2m1(hash(circleId * 0.37)), -t2m1(circleId / numCircles));\\n //offset = vec3(0);\\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = persp(radians(45.0), aspect, 0.1, 1000.0); \\n vec3 eye = vec3(0, 2, 7);\\n vec3 target = vec3(0, -1, 0);\\n vec3 up = vec3(0, 1, 0);\\n mat4 view = cameraLookAt(eye, target, up);\\n \\n mat *= view; \\n// mat *= trans(offset);\\n //float sc = (1. - pow(invSt, 1.2)) * 6.;\\n float sc = st * 6.;\\n mat *= scale(vec3(sc, snd * invSt, sc));\\n mat *= trans(vec3(0, -0.5, 0));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = fract(circleId);//, 1., step(0.75, snd));\\n float sat = 1.;\\n float val = mod(circleId, 2.0);// 1.0;pow(snd + .2, 5.) * invSt;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invSt * 2.);\\n //v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/yellow-sunshine-explosion/hi-profile-machines-in-heaven", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \n /_/\\ /\\_\\ /\\_____\\/_/\\__/\\ /\\_______)\\ /\\_____\\/\\ /\\ /\\/ ____/\\ /\\_\\ /_/\\ /\\___/\\ /\\ __/\\ /\\_____\\/_/\\__/\\ /\\___/\\ /_/\\__/\\ /\\_______)\\ \n ) ) ) ( (( (_____/) ) ) ) )\\(___ __\\/( (_____/\\ \\ \\/ / /) ) __\\/( ( (_) ) ) / / _ \\ \\ ) ) \\ \\( (_____/) ) ) ) ) / / _ \\ \\ ) ) ) ) )\\(___ __\\/ \n/_/ / \\ \\_\\\\ \\__\\ /_/ /_/_/ / / / \\ \\__\\ \\ \\ / / \\ \\ \\ \\ \\___/ / \\ \\(_)/ // / /\\ \\ \\\\ \\__\\ /_/ /_/_/ \\ \\(_)/ //_/ /_/_/ / / / \n\\ \\ \\_/ / // /__/_\\ \\ \\ \\ \\ ( ( ( / /__/_ / / \\ \\ _\\ \\ \\ / / _ \\ \\ / / _ \\ \\\\ \\ \\/ / // /__/_\\ \\ \\ \\ \\ / / _ \\ \\\\ \\ \\ \\ \\ ( ( ( \n \\ \\ / /( (_____\\)_) ) \\ \\ \\ \\ \\ ( (_____\\/ / /\\ \\ \\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\)_) ) \\ \\( (_( )_) ))_) ) \\ \\ \\ \\ \\ \n \\_\\_/_/ \\/_____/\\_\\/ \\_\\/ /_/_/ \\/_____/\\/__\\/__\\/\\____\\/ \\/_/ \\_\\/ \\/_/ \\_\\/ \\/___\\/ \\/_____/\\_\\/ \\_\\/ \\/_/ \\_\\/ \\_\\/ \\_\\/ /_/_/ \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 256.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 2.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n pos = vec3(c, v, s); \n uv = vec2(u, v);//vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float edgeId = mod(vertexId, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float u2 = floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE;\n float st = fract(cu + time);\n float invSt = 1.0 - st;\n float inner = 0.0;//mix(0.5, 1.0, pow(snd + .3, 5.0));//0.9; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\n float start = fract(hash(circleId * 0.33));\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2(mix(0.0, 0.25, uv.x), st * 0.25)).a;\n \n vec3 offset = vec3(t2m1(hash(circleId * floor(time * 1.2) * 0.123)), t2m1(hash(circleId * 0.37)), -t2m1(circleId / numCircles));\n //offset = vec3(0);\n float aspect = resolution.x / resolution.y;\n \n mat4 mat = persp(radians(45.0), aspect, 0.1, 1000.0); \n vec3 eye = vec3(0, 2, 7);\n vec3 target = vec3(0, -1, 0);\n vec3 up = vec3(0, 1, 0);\n mat4 view = cameraLookAt(eye, target, up);\n \n mat *= view; \n// mat *= trans(offset);\n //float sc = (1. - pow(invSt, 1.2)) * 6.;\n float sc = st * 6.;\n mat *= scale(vec3(sc, snd * invSt, sc));\n mat *= trans(vec3(0, -0.5, 0));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = fract(circleId);//, 1., step(0.75, snd));\n float sat = 1.;\n float val = mod(circleId, 2.0);// 1.0;pow(snd + .2, 5.) * invSt;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invSt * 2.);\n //v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-azltyxz5vxaifg3ud-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9P4cTdzoK9rwM99kJ/art.json b/art/9P4cTdzoK9rwM99kJ/art.json index fed120f5..7e82e8f1 100644 --- a/art/9P4cTdzoK9rwM99kJ/art.json +++ b/art/9P4cTdzoK9rwM99kJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.10196078431372549,0.10196078431372549,1],\"shader\":\"// terrain\\n#define parameter1 0.22 //KParameter0 -1.>>1.\\n#define parameter2 0.9 //KParameter1 -1.>>1.\\n#define parameter3 -0.5 //KParameter2 -1.>>1.\\n#define PI radians(180.0)\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5);// / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.00100*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n vec3 cameraPos = vec3(parameter1 * 4., mix(5., 1., p1m1(parameter2)), 2.);\\n // vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);//.3;abs(n.z);\\n float val = mix(.05, 1., l);\\n//parameter3* mouse.y;\\n float ss = \\n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5*parameter3), 0.-parameter3)).a;\\n float pop = step(0.6, ss);\\n val = mix(max(val,pop)*parameter2, 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.)*ss;\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.10196078431372549, + 0.10196078431372549, + 1 + ], + "shader": "// terrain\n#define parameter1 0.22 //KParameter0 -1.>>1.\n#define parameter2 0.9 //KParameter1 -1.>>1.\n#define parameter3 -0.5 //KParameter2 -1.>>1.\n#define PI radians(180.0)\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5);// / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.00100*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n vec3 cameraPos = vec3(parameter1 * 4., mix(5., 1., p1m1(parameter2)), 2.);\n // vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);//.3;abs(n.z);\n float val = mix(.05, 1., l);\n//parameter3* mouse.y;\n float ss = \n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5*parameter3), 0.-parameter3)).a;\n float pop = step(0.6, ss);\n val = mix(max(val,pop)*parameter2, 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.)*ss;\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-4ki14b4tsiaqocbor-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9QBfBKazwRDgwzka8/art.json b/art/9QBfBKazwRDgwzka8/art.json index 0e0353c0..d110deac 100644 --- a/art/9QBfBKazwRDgwzka8/art.json +++ b/art/9QBfBKazwRDgwzka8/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/feuerhaus/donauwalzer-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7372549019607844,0.7372549019607844,0.7372549019607844,1],\"shader\":\"// Planet Polygon - @P_Malin\\n\\n// Switch the primitive type to LINES to see how the background sun flare is rendered!\\n\\nfloat g_cameraFar = 2000.0;\\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\n\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\nfloat GetCosSunRadius( vec3 vCameraPos )\\n{\\n \\tfloat d = length( vCameraPos - GetSunPosition() );\\n \\treturn 100.0 / d;\\n}\\n\\nfloat GetSunIntensity( vec3 vCameraPos )\\n{\\n \\tfloat d = length( vCameraPos - GetSunPosition() );\\n \\treturn 1000.0 / (d * d);\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n\\tfloat fGloss;\\n};\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = surfaceInfo.fGloss;\\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\\n}\\n\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n AddDirectionalLight( GetSunDir(vCameraPos), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor, float fExposure )\\n{\\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n\\tfloat fAlpha;\\n};\\n\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir(vCameraPos) );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity( vCameraPos ) / pow(fShade, 1.5);\\n \\n return vec3( fShade * g_sunColor ); \\n}\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t32.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(vCameraPos), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos, vCameraPos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0.0) && (fMinDist < 100.0 ) )\\n {\\n \\tfShadowAttn = (fClosestDist2 - fSphereRadius2) + 10.0;\\n \\tfShadowAttn *= 0.025;\\n \\tfShadowAttn = clamp( fShadowAttn, 0.0, 1.0);\\n }\\n\\t} \\n \\n \\treturn fShadowAttn;\\n}\\n\\n#define g_ringSegments \\t\\t\\t128.0\\n#define g_ringQuads \\t\\t\\t( g_ringSegments * 3.0 )\\n#define g_ringVertexCount \\t\\t( g_ringQuads * 6.0 )\\n\\nvoid GenerateRingVertex( const float vertexIndex, const vec3 vCameraPos, PlanetInfo planetInfo, out SceneVertex outSceneVertex, float fInnerRadius, float fOuterRadius, float fRandom )\\n{\\n vec2 vDim = vec2( g_ringSegments, 3 );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vUV );\\n\\n \\tvec3 vRingPos;\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\n \\tfloat fRadiusPos = vUV.y;\\n \\n \\tif( vUV.y < 0.5 ) fRadiusPos = 0.0; else fRadiusPos = 1.0;\\n\\n \\n \\tfloat fRadius = fInnerRadius + fRadiusPos * (fOuterRadius - fInnerRadius);\\n\\n \\tif ( vUV.y < 0.01 ) fRadius-= 0.02;\\n \\tif ( vUV.y > 0.99 ) fRadius+= 0.02;\\n \\n \\tvRingPos.y = 0.0;\\n \\tvRingPos.x = sin( fHeading ) * fRadius;\\n \\tvRingPos.z = cos( fHeading ) * fRadius;\\n \\n outSceneVertex.vWorldPos = PlanetPosToWorld( planetInfo, vRingPos );\\n \\n \\tfloat fShadow = GetPlanetShadow( outSceneVertex.vWorldPos, vCameraPos, planetInfo );\\n \\n \\tfloat fAlpha = ( fRandom * 0.5 + 0.5);\\n\\tfAlpha = fAlpha * fAlpha;\\n \\n \\tvec3 vAlbedo = mix( planetInfo.vRingColor0, planetInfo.vRingColor1, fRandom );\\n \\n \\tSurfaceInfo surfaceInfo;\\n \\tsurfaceInfo.vPos = outSceneVertex.vWorldPos;\\n \\tsurfaceInfo.vNormal = PlanetNormalToWorld( planetInfo, vec3(0.0, 1.0, 0.0) );\\n \\tsurfaceInfo.fGloss = 20.0;\\n\\n outSceneVertex.vColor = LightSurface( surfaceInfo, vCameraPos, vAlbedo, fShadow );\\n\\n \\t// Hack lighting from other side\\n \\tvec3 vCameraDir = vCameraPos - surfaceInfo.vPos;\\n \\tvCameraDir = reflect( vCameraDir, surfaceInfo.vNormal );\\n \\tvec3 otherSideCameraPos = vCameraDir + surfaceInfo.vPos;\\n outSceneVertex.vColor += LightSurface( surfaceInfo, otherSideCameraPos, vAlbedo, fShadow ) * 0.1;\\n\\n \\tfAlpha *= 1.0 - abs( vUV.y * 2.0 - 1.0 );\\n \\n \\tfloat NdotV = normalize(vCameraPos).y;\\n \\tfAlpha = mix( fAlpha, 1.0, exp2( abs(NdotV) * -5.0 ) );\\n \\n \\toutSceneVertex.fAlpha = fAlpha;\\n} \\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\tfloat orbitAngle = time * 0.4 + 2.5;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tPlanetInfo planetInfo;\\n \\n#if 1\\n \\tplanetInfo.vSurfaceColor0 = vec3(0.36, 0.16, 0.0001);\\n \\tplanetInfo.vSurfaceColor1 = vec3(1.0, 0.36, 0.000001);\\n \\n \\tplanetInfo.textureScale = 100.0;\\n planetInfo.texturePersistence = 0.5;\\n \\tplanetInfo.surfaceType = 0.3;\\n \\n \\n \\tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n \\tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n \\n \\tplanetInfo.hasRings = true;\\n \\n \\tplanetInfo.vOrigin = vec3(0.0);\\n \\tplanetInfo.fRadius = 5.0;\\n \\n \\tplanetInfo.fSegments = 32.0;\\n \\tplanetInfo.fSlices = 48.0;\\n \\n \\tplanetInfo.iMoonCount = 10;\\n#else\\n \\tplanetInfo.vSurfaceColor0 = vec3(0.01, 0.01, 0.5);\\n \\tplanetInfo.vSurfaceColor1 = vec3(0.01, 1.0, 0.01);\\n \\n \\tplanetInfo.textureScale = 16.0;\\n planetInfo.texturePersistence = 0.5;\\n \\tplanetInfo.surfaceType = 0.8;\\n \\n \\n \\tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n \\tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n \\n \\tplanetInfo.hasRings = false;\\n \\n \\tplanetInfo.vOrigin = vec3(0.0);\\n \\tplanetInfo.fRadius = 0.1;\\n \\n \\tplanetInfo.fSegments = 32.0;\\n \\tplanetInfo.fSlices = 48.0;\\n \\n \\tplanetInfo.iMoonCount = 1;\\n#endif \\n \\n \\tfloat fOrbitDistance = (planetInfo.fRadius * 2.0) + exp2( fMouseX * 20.0 );\\n \\n \\tvec3 vCameraPos = vec3( sin(orbitAngle), 0.2 + vMouse.y * 0.5, cos(orbitAngle) ) * fOrbitDistance;\\n \\tvec3 vCameraTarget = vec3( 0.0, planetInfo.fRadius * 0.2, 0.0 );\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\t// Backdrop\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n\\n \\t// Stars\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_starVertexCount )\\n {\\n \\tGenerateStarVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_starVertexCount;\\n \\n \\t// Planet\\n \\tfloat fPlanetVertexCount = GetPlanetVertexCount(planetInfo);\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < fPlanetVertexCount )\\n {\\n \\tGeneratePlanetVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex );\\n }\\n \\tvertexIndex -= fPlanetVertexCount;\\n\\n \\t// Moon \\n \\tconst int kMaxMoonCount = 5;\\n \\tfloat fMoonDist = planetInfo.fRadius * 6.0;\\n \\tfor( int moonIndex=0; moonIndex < kMaxMoonCount; moonIndex++ )\\n {\\n \\tif(moonIndex < planetInfo.iMoonCount)\\n {\\n PlanetInfo moonInfo;\\n\\n moonInfo.vSurfaceColor0 = vec3(0.7);\\n moonInfo.vSurfaceColor1 = vec3(0.5);\\n\\n moonInfo.textureScale = 100.0;\\n moonInfo.texturePersistence = 0.5;\\n moonInfo.surfaceType = 0.9;\\n\\n\\n moonInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n moonInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n\\n moonInfo.hasRings = false;\\n\\n float fAngle = hash11(fMoonDist) * 12.345 + time * 0.1 / fMoonDist;\\n moonInfo.vOrigin = vec3(sin(fAngle), 0.0, cos(fAngle)) * fMoonDist;\\n moonInfo.fRadius = planetInfo.fRadius * 0.025;\\n fMoonDist = fMoonDist * 1.8;\\n\\n moonInfo.fSegments = 16.0;\\n moonInfo.fSlices = 16.0;\\n\\n moonInfo.iMoonCount = 0;\\n \\n float fMoonVertexCount = GetPlanetVertexCount(moonInfo);\\n if ( vertexIndex >= 0.0 && vertexIndex < fMoonVertexCount )\\n {\\n GeneratePlanetVertex( vertexIndex, vCameraPos, moonInfo, sceneVertex );\\n }\\n vertexIndex -= fMoonVertexCount;\\n \\n } \\n }\\n \\n \\n \\t// Ring\\n \\tif ( planetInfo.hasRings )\\n {\\n float fRingInner = 8.0;\\n float fRingSize = 2.0;\\n float fRingSeed = 0.0; \\t\\n for ( int ringIndex = 0; ringIndex < 6; ringIndex++ )\\n {\\n if ( vertexIndex >= 0.0 && vertexIndex < g_ringVertexCount )\\n {\\n GenerateRingVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex, fRingInner, fRingInner + fRingSize, hash11(fRingInner) );\\n }\\n vertexIndex -= g_ringVertexCount;\\n\\n fRingInner += fRingSize;\\n fRingInner += 0.02 + (sin( fRingSeed * 123.432 ) * 0.5 + 0.5) * 0.25;\\n float fSizeRandom = sin( fRingSeed * 423.432 ) * 0.5 + 0.5;\\n fRingSize = 0.1 + fSizeRandom * fSizeRandom * 2.0;\\n fRingSeed += 1.0;\\n }\\n }\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n sceneVertex.vWorldPos = vec3(0.0);\\n sceneVertex.vColor = vec3(0.0);\\n sceneVertex.fAlpha = 0.0;\\n }\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tvec3 vFinalColor = sceneVertex.vColor;\\n \\n \\tvFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \\n \\n \\tfloat VdotL = dot( vCameraForwards, -GetSunDir(vCameraPos) );\\n \\n \\t// Adjust exposure if we are looking towards the sun\\n \\tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\\n \\n \\tfExposure /= GetSunIntensity( vCameraPos ) * 100000.0;\\n \\n \\tfExposure += 0.5;\\n \\n \\tfExposure *= min( 1.0, time / 5.0 );\\n \\n \\tvFinalColor = PostProcess( vFinalColor, fExposure );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/feuerhaus/donauwalzer-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7372549019607844, + 0.7372549019607844, + 0.7372549019607844, + 1 + ], + "shader": "// Planet Polygon - @P_Malin\n\n// Switch the primitive type to LINES to see how the background sun flare is rendered!\n\nfloat g_cameraFar = 2000.0;\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\n\n\n#define PI radians( 180.0 )\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\n\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\nfloat GetCosSunRadius( vec3 vCameraPos )\n{\n \tfloat d = length( vCameraPos - GetSunPosition() );\n \treturn 100.0 / d;\n}\n\nfloat GetSunIntensity( vec3 vCameraPos )\n{\n \tfloat d = length( vCameraPos - GetSunPosition() );\n \treturn 1000.0 / (d * d);\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n\tfloat fGloss;\n};\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = surfaceInfo.fGloss;\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\n}\n\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n AddDirectionalLight( GetSunDir(vCameraPos), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor, float fExposure )\n{\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n\tfloat fAlpha;\n};\n\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir(vCameraPos) );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity( vCameraPos ) / pow(fShade, 1.5);\n \n return vec3( fShade * g_sunColor ); \n}\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t32.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(vCameraPos), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos, vCameraPos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0.0) && (fMinDist < 100.0 ) )\n {\n \tfShadowAttn = (fClosestDist2 - fSphereRadius2) + 10.0;\n \tfShadowAttn *= 0.025;\n \tfShadowAttn = clamp( fShadowAttn, 0.0, 1.0);\n }\n\t} \n \n \treturn fShadowAttn;\n}\n\n#define g_ringSegments \t\t\t128.0\n#define g_ringQuads \t\t\t( g_ringSegments * 3.0 )\n#define g_ringVertexCount \t\t( g_ringQuads * 6.0 )\n\nvoid GenerateRingVertex( const float vertexIndex, const vec3 vCameraPos, PlanetInfo planetInfo, out SceneVertex outSceneVertex, float fInnerRadius, float fOuterRadius, float fRandom )\n{\n vec2 vDim = vec2( g_ringSegments, 3 );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vUV );\n\n \tvec3 vRingPos;\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \n \tfloat fRadiusPos = vUV.y;\n \n \tif( vUV.y < 0.5 ) fRadiusPos = 0.0; else fRadiusPos = 1.0;\n\n \n \tfloat fRadius = fInnerRadius + fRadiusPos * (fOuterRadius - fInnerRadius);\n\n \tif ( vUV.y < 0.01 ) fRadius-= 0.02;\n \tif ( vUV.y > 0.99 ) fRadius+= 0.02;\n \n \tvRingPos.y = 0.0;\n \tvRingPos.x = sin( fHeading ) * fRadius;\n \tvRingPos.z = cos( fHeading ) * fRadius;\n \n outSceneVertex.vWorldPos = PlanetPosToWorld( planetInfo, vRingPos );\n \n \tfloat fShadow = GetPlanetShadow( outSceneVertex.vWorldPos, vCameraPos, planetInfo );\n \n \tfloat fAlpha = ( fRandom * 0.5 + 0.5);\n\tfAlpha = fAlpha * fAlpha;\n \n \tvec3 vAlbedo = mix( planetInfo.vRingColor0, planetInfo.vRingColor1, fRandom );\n \n \tSurfaceInfo surfaceInfo;\n \tsurfaceInfo.vPos = outSceneVertex.vWorldPos;\n \tsurfaceInfo.vNormal = PlanetNormalToWorld( planetInfo, vec3(0.0, 1.0, 0.0) );\n \tsurfaceInfo.fGloss = 20.0;\n\n outSceneVertex.vColor = LightSurface( surfaceInfo, vCameraPos, vAlbedo, fShadow );\n\n \t// Hack lighting from other side\n \tvec3 vCameraDir = vCameraPos - surfaceInfo.vPos;\n \tvCameraDir = reflect( vCameraDir, surfaceInfo.vNormal );\n \tvec3 otherSideCameraPos = vCameraDir + surfaceInfo.vPos;\n outSceneVertex.vColor += LightSurface( surfaceInfo, otherSideCameraPos, vAlbedo, fShadow ) * 0.1;\n\n \tfAlpha *= 1.0 - abs( vUV.y * 2.0 - 1.0 );\n \n \tfloat NdotV = normalize(vCameraPos).y;\n \tfAlpha = mix( fAlpha, 1.0, exp2( abs(NdotV) * -5.0 ) );\n \n \toutSceneVertex.fAlpha = fAlpha;\n} \n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \tfloat orbitAngle = time * 0.4 + 2.5;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tPlanetInfo planetInfo;\n \n#if 1\n \tplanetInfo.vSurfaceColor0 = vec3(0.36, 0.16, 0.0001);\n \tplanetInfo.vSurfaceColor1 = vec3(1.0, 0.36, 0.000001);\n \n \tplanetInfo.textureScale = 100.0;\n planetInfo.texturePersistence = 0.5;\n \tplanetInfo.surfaceType = 0.3;\n \n \n \tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n \tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n \n \tplanetInfo.hasRings = true;\n \n \tplanetInfo.vOrigin = vec3(0.0);\n \tplanetInfo.fRadius = 5.0;\n \n \tplanetInfo.fSegments = 32.0;\n \tplanetInfo.fSlices = 48.0;\n \n \tplanetInfo.iMoonCount = 10;\n#else\n \tplanetInfo.vSurfaceColor0 = vec3(0.01, 0.01, 0.5);\n \tplanetInfo.vSurfaceColor1 = vec3(0.01, 1.0, 0.01);\n \n \tplanetInfo.textureScale = 16.0;\n planetInfo.texturePersistence = 0.5;\n \tplanetInfo.surfaceType = 0.8;\n \n \n \tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n \tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n \n \tplanetInfo.hasRings = false;\n \n \tplanetInfo.vOrigin = vec3(0.0);\n \tplanetInfo.fRadius = 0.1;\n \n \tplanetInfo.fSegments = 32.0;\n \tplanetInfo.fSlices = 48.0;\n \n \tplanetInfo.iMoonCount = 1;\n#endif \n \n \tfloat fOrbitDistance = (planetInfo.fRadius * 2.0) + exp2( fMouseX * 20.0 );\n \n \tvec3 vCameraPos = vec3( sin(orbitAngle), 0.2 + vMouse.y * 0.5, cos(orbitAngle) ) * fOrbitDistance;\n \tvec3 vCameraTarget = vec3( 0.0, planetInfo.fRadius * 0.2, 0.0 );\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \t// Backdrop\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n\n \t// Stars\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_starVertexCount )\n {\n \tGenerateStarVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_starVertexCount;\n \n \t// Planet\n \tfloat fPlanetVertexCount = GetPlanetVertexCount(planetInfo);\n \tif ( vertexIndex >= 0.0 && vertexIndex < fPlanetVertexCount )\n {\n \tGeneratePlanetVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex );\n }\n \tvertexIndex -= fPlanetVertexCount;\n\n \t// Moon \n \tconst int kMaxMoonCount = 5;\n \tfloat fMoonDist = planetInfo.fRadius * 6.0;\n \tfor( int moonIndex=0; moonIndex < kMaxMoonCount; moonIndex++ )\n {\n \tif(moonIndex < planetInfo.iMoonCount)\n {\n PlanetInfo moonInfo;\n\n moonInfo.vSurfaceColor0 = vec3(0.7);\n moonInfo.vSurfaceColor1 = vec3(0.5);\n\n moonInfo.textureScale = 100.0;\n moonInfo.texturePersistence = 0.5;\n moonInfo.surfaceType = 0.9;\n\n\n moonInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n moonInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n\n moonInfo.hasRings = false;\n\n float fAngle = hash11(fMoonDist) * 12.345 + time * 0.1 / fMoonDist;\n moonInfo.vOrigin = vec3(sin(fAngle), 0.0, cos(fAngle)) * fMoonDist;\n moonInfo.fRadius = planetInfo.fRadius * 0.025;\n fMoonDist = fMoonDist * 1.8;\n\n moonInfo.fSegments = 16.0;\n moonInfo.fSlices = 16.0;\n\n moonInfo.iMoonCount = 0;\n \n float fMoonVertexCount = GetPlanetVertexCount(moonInfo);\n if ( vertexIndex >= 0.0 && vertexIndex < fMoonVertexCount )\n {\n GeneratePlanetVertex( vertexIndex, vCameraPos, moonInfo, sceneVertex );\n }\n vertexIndex -= fMoonVertexCount;\n \n } \n }\n \n \n \t// Ring\n \tif ( planetInfo.hasRings )\n {\n float fRingInner = 8.0;\n float fRingSize = 2.0;\n float fRingSeed = 0.0; \t\n for ( int ringIndex = 0; ringIndex < 6; ringIndex++ )\n {\n if ( vertexIndex >= 0.0 && vertexIndex < g_ringVertexCount )\n {\n GenerateRingVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex, fRingInner, fRingInner + fRingSize, hash11(fRingInner) );\n }\n vertexIndex -= g_ringVertexCount;\n\n fRingInner += fRingSize;\n fRingInner += 0.02 + (sin( fRingSeed * 123.432 ) * 0.5 + 0.5) * 0.25;\n float fSizeRandom = sin( fRingSeed * 423.432 ) * 0.5 + 0.5;\n fRingSize = 0.1 + fSizeRandom * fSizeRandom * 2.0;\n fRingSeed += 1.0;\n }\n }\n \n \tif ( vertexIndex >= 0.0 )\n {\n sceneVertex.vWorldPos = vec3(0.0);\n sceneVertex.vColor = vec3(0.0);\n sceneVertex.fAlpha = 0.0;\n }\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tvec3 vFinalColor = sceneVertex.vColor;\n \n \tvFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \n \n \tfloat VdotL = dot( vCameraForwards, -GetSunDir(vCameraPos) );\n \n \t// Adjust exposure if we are looking towards the sun\n \tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\n \n \tfExposure /= GetSunIntensity( vCameraPos ) * 100000.0;\n \n \tfExposure += 0.5;\n \n \tfExposure *= min( 1.0, time / 5.0 );\n \n \tvFinalColor = PostProcess( vFinalColor, fExposure );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}\n" + }, "screenshotURL": "data/images/images-u32rohw6qzdepbopb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9SEaxhmGgtFCn7tXv/art.json b/art/9SEaxhmGgtFCn7tXv/art.json index d1328e4b..736306f5 100644 --- a/art/9SEaxhmGgtFCn7tXv/art.json +++ b/art/9SEaxhmGgtFCn7tXv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/victorruiz/robots\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.6 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/victorruiz/robots", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.6 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-c348psbz7l0z9sg95-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9Sr9XKEznvoJprDjG/art.json b/art/9Sr9XKEznvoJprDjG/art.json index 568acc1b..ffa27b50 100644 --- a/art/9Sr9XKEznvoJprDjG/art.json +++ b/art/9Sr9XKEznvoJprDjG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "ray7551", "avatarUrl": "https://avatars.githubusercontent.com/ray7551?s=200", - "settings": "{\"num\":289,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float gridWidth = floor((vertexCount - floor(sqrt(vertexCount))) / floor(sqrt(vertexCount)));\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / gridWidth;\\n // gl_PointSize *= resolution.x / 400.;\\n vec2 realPointSize = vec2(gl_PointSize) / resolution;\\n \\n vec2 p = vec2(\\n mod(vertexId, gridWidth),\\n floor(vertexId / gridWidth)\\n );\\n // p = (p / (gridWidth - 1.) ) * 2. - vec2(1., 1.)\\n // + vec2(gl_PointSize / resolution / 2.);\\n p = (p) / (gridWidth - 1.) * 2.\\n - vec2(1., 1.);// + realPointSize;\\n \\n gl_Position = vec4(p, 0., 1.);\\n \\n \\n v_color = vec4(1. * sin(time), 1., 0.8 * cos(time), 1.);\\n}\"}", + "settings": { + "num": 289, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float gridWidth = floor((vertexCount - floor(sqrt(vertexCount))) / floor(sqrt(vertexCount)));\n \n gl_PointSize = 10.;\n gl_PointSize *= 20. / gridWidth;\n // gl_PointSize *= resolution.x / 400.;\n vec2 realPointSize = vec2(gl_PointSize) / resolution;\n \n vec2 p = vec2(\n mod(vertexId, gridWidth),\n floor(vertexId / gridWidth)\n );\n // p = (p / (gridWidth - 1.) ) * 2. - vec2(1., 1.)\n // + vec2(gl_PointSize / resolution / 2.);\n p = (p) / (gridWidth - 1.) * 2.\n - vec2(1., 1.);// + realPointSize;\n \n gl_Position = vec4(p, 0., 1.);\n \n \n v_color = vec4(1. * sin(time), 1., 0.8 * cos(time), 1.);\n}" + }, "screenshotURL": "data/images/images-aafyiixjpik60ezs9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9WvFeBhi2eCqodeBQ/art.json b/art/9WvFeBhi2eCqodeBQ/art.json index a46ac082..6cecb0a5 100644 --- a/art/9WvFeBhi2eCqodeBQ/art.json +++ b/art/9WvFeBhi2eCqodeBQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/merzbow/pulse-vegan-part-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n\\n#define soundFactor 1.0//KParameter 1.0>>5.\\n#define screenSizeRation 0.5//KParameter 0.5>>1.\\n\\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n //vec2 desiredPixelResolution = vec2(floor(resolution.x*screenSizeRation),floor(resolution.y*screenSizeRation));\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n //can't use all vertices\\n //need to find the max value compatible with our ratio\\n //we need to resolve\\n //1. finalVertexCount = finalVertexResolution.x * finalVertexResolution.y\\n //2. finalVertexResolution.x/finalVertexResolution.y = ratioXforY\\n\\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalVertexResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n //position vertices indexes\\n float x = mod(finalVertexId, finalVertexResolution.x);\\n float y = floor(finalVertexId / finalVertexResolution.y);\\n \\n //positions 0.>>1.\\n float u = (x / finalVertexResolution.x);\\n float v = (y / finalVertexResolution.y);\\n \\n //positions -1.>>1.\\n float ux = ( u * 2.0 - 1.0) * (finalVertexResolution.x/resolution.x);\\n float vy = ( v * 2.0 - 1.0)* (finalVertexResolution.y/resolution.y);\\n \\n vec2 p = vec2(x,y);\\n \\n \\n\\tvec2 uv1= vec2(ux,vy);//(p.xy*2.-desiredPixelResolution.xy)/min(desiredPixelResolution.x,desiredPixelResolution.y); \\n\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n\\n gl_PointSize = 1.;//desiredPixelResolution.x/desiredPixelResolution.x;//(resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/merzbow/pulse-vegan-part-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n\n#define soundFactor 1.0//KParameter 1.0>>5.\n#define screenSizeRation 0.5//KParameter 0.5>>1.\n\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n //vec2 desiredPixelResolution = vec2(floor(resolution.x*screenSizeRation),floor(resolution.y*screenSizeRation));\n \n float ratioXforY = resolution.x/resolution.y;\n \n //can't use all vertices\n //need to find the max value compatible with our ratio\n //we need to resolve\n //1. finalVertexCount = finalVertexResolution.x * finalVertexResolution.y\n //2. finalVertexResolution.x/finalVertexResolution.y = ratioXforY\n\n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalVertexResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n //position vertices indexes\n float x = mod(finalVertexId, finalVertexResolution.x);\n float y = floor(finalVertexId / finalVertexResolution.y);\n \n //positions 0.>>1.\n float u = (x / finalVertexResolution.x);\n float v = (y / finalVertexResolution.y);\n \n //positions -1.>>1.\n float ux = ( u * 2.0 - 1.0) * (finalVertexResolution.x/resolution.x);\n float vy = ( v * 2.0 - 1.0)* (finalVertexResolution.y/resolution.y);\n \n vec2 p = vec2(x,y);\n \n \n\tvec2 uv1= vec2(ux,vy);//(p.xy*2.-desiredPixelResolution.xy)/min(desiredPixelResolution.x,desiredPixelResolution.y); \n\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n\n gl_PointSize = 1.;//desiredPixelResolution.x/desiredPixelResolution.x;//(resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n\n}" + }, "screenshotURL": "data/images/images-mfz9nifj6u4fr68x2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9Xu5ntQQuktXprwnJ/art.json b/art/9Xu5ntQQuktXprwnJ/art.json index 910c6119..3c7b2198 100644 --- a/art/9Xu5ntQQuktXprwnJ/art.json +++ b/art/9Xu5ntQQuktXprwnJ/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "sendi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GiA4oVEHO7tNcUpxHud7p60dl8Gb-TqVLeqG_Q1=s96-c", - "settings": "{\"num\":94161,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/rudy-normale/incubificio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0.25098039215686274,0.25098039215686274,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 1, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.7 - 0.3 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 01, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 64.0;\\n float pointsPerCircle = segmentsPerCircle * 2.0;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n \\n float vId = mod(vertexId, pointsPerCircle);\\n float cId = floor(vertexId / pointsPerCircle);\\n float cv = cId / numCircles;\\n float u = floor(vId / 2.0) + mod(vId, 2.0);\\n float v = u / segmentsPerCircle;\\n float a = v * PI * 2.0 + cv;\\n\\n vec2 p = vec2(\\n cos(a),\\n sin(a));\\n \\n float distFromCenter = length(p);\\n\\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.1, abs(v * 2. - 1.)),\\n abs(cv * 2. - 1.) * 1.0)\\n ).r;\\n \\n \\n float cvv = cv * 2. - 1.;\\n vec3 pos = vec3(\\n sin(cvv * PI * 0.5),\\n p * mix(0., 1., sin(cv * PI)) * s);\\n \\n \\n \\n float ct = time * 0.1;\\n vec3 eye = vec3(sin(ct), 0, cos(ct)) * 2.5;\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \\n mat *= cameraLookAt(eye, target, up);\\n gl_Position = mat * vec4(pos, 1);\\n\\n\\n float boost = step(0.7, s);\\n \\n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\\n float val = mix(0.25, 2.0, pow(s, 2.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 94161, + "mode": "LINES", + "sound": "https://soundcloud.com/rudy-normale/incubificio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0.25098039215686274, + 0.25098039215686274, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 1, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.7 - 0.3 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 01, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid main() {\n float segmentsPerCircle = 64.0;\n float pointsPerCircle = segmentsPerCircle * 2.0;\n float numCircles = floor(vertexCount / pointsPerCircle);\n \n float vId = mod(vertexId, pointsPerCircle);\n float cId = floor(vertexId / pointsPerCircle);\n float cv = cId / numCircles;\n float u = floor(vId / 2.0) + mod(vId, 2.0);\n float v = u / segmentsPerCircle;\n float a = v * PI * 2.0 + cv;\n\n vec2 p = vec2(\n cos(a),\n sin(a));\n \n float distFromCenter = length(p);\n\n float s = texture2D(sound, vec2(\n mix(0.01, 0.1, abs(v * 2. - 1.)),\n abs(cv * 2. - 1.) * 1.0)\n ).r;\n \n \n float cvv = cv * 2. - 1.;\n vec3 pos = vec3(\n sin(cvv * PI * 0.5),\n p * mix(0., 1., sin(cv * PI)) * s);\n \n \n \n float ct = time * 0.1;\n vec3 eye = vec3(sin(ct), 0, cos(ct)) * 2.5;\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \n mat *= cameraLookAt(eye, target, up);\n gl_Position = mat * vec4(pos, 1);\n\n\n float boost = step(0.7, s);\n \n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\n float val = mix(0.25, 2.0, pow(s, 2.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-j6n2q6nykjtioebxa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9Yfm7z3uHjctZkyLW/art.json b/art/9Yfm7z3uHjctZkyLW/art.json index 34f1ab27..ef2ede9d 100644 --- a/art/9Yfm7z3uHjctZkyLW/art.json +++ b/art/9Yfm7z3uHjctZkyLW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = resolution.y;//floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n \\n //apply fragment logic\\n\\nvec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 uv1=(p.xy*2.-res.xy)/min(res.x,res.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = resolution.y;//floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n \n //apply fragment logic\n\nvec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 uv1=(p.xy*2.-res.xy)/min(res.x,res.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-tpfyo8lqp5bhvdbii-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9Z8QK2wm2wyThYCTm/art.json b/art/9Z8QK2wm2wyThYCTm/art.json index a7250015..e3f39e25 100644 --- a/art/9Z8QK2wm2wyThYCTm/art.json +++ b/art/9Z8QK2wm2wyThYCTm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n //float width = 10.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n \\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 3, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n //float width = 10.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n \n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-vi971qnbauumrvml3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9adCiEobmkAuj8Gue/art.json b/art/9adCiEobmkAuj8Gue/art.json index 9204a779..4124cf8d 100644 --- a/art/9adCiEobmkAuj8Gue/art.json +++ b/art/9adCiEobmkAuj8Gue/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.611764705882353,1,1,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.1, 1.2));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.5, 3.0 / 5.3);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background / snd, v / snd * v / snd);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.611764705882353, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.1, 1.2));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.5, 3.0 / 5.3);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background / snd, v / snd * v / snd);\n}" + }, "screenshotURL": "data/images/images-kj403tp8c1m3o7gib-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9auTJQc3nHbaStwyQ/art.json b/art/9auTJQc3nHbaStwyQ/art.json index ab38e6c8..e903dc59 100644 --- a/art/9auTJQc3nHbaStwyQ/art.json +++ b/art/9auTJQc3nHbaStwyQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-r9rngjvxv6cb119nd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9caDdikyJ7k4Q3o2L/art.json b/art/9caDdikyJ7k4Q3o2L/art.json index 8278693c..af5b972c 100644 --- a/art/9caDdikyJ7k4Q3o2L/art.json +++ b/art/9caDdikyJ7k4Q3o2L/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "의진", "avatarUrl": "https://lh3.googleusercontent.com/-qluvRnEYs7k/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc-ybddM4LQHc0g0BGvplkyZtwpJg/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*your name : uijin.lee\\nthe assignment number : assignment 3 extra credit\\nthe course name : CS230\\nthe term : Spring 2019\\n*/\\n \\n#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float m = vertexId ;\\n\\n gl_Position = vec4(m*mouse.x,m*mouse.y,0, 1);\\n gl_PointSize = 5.0;\\n \\n v_color = vec4(sin(time), cos(time), tan(time), 1.0);\\n \\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*your name : uijin.lee\nthe assignment number : assignment 3 extra credit\nthe course name : CS230\nthe term : Spring 2019\n*/\n \n#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float m = vertexId ;\n\n gl_Position = vec4(m*mouse.x,m*mouse.y,0, 1);\n gl_PointSize = 5.0;\n \n v_color = vec4(sin(time), cos(time), tan(time), 1.0);\n \n}" + }, "screenshotURL": "data/images/images-j396wc846nwx3xipg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9dSN7fhb4hT8SrRor/art.json b/art/9dSN7fhb4hT8SrRor/art.json index cc0a5fb5..14be7bc6 100644 --- a/art/9dSN7fhb4hT8SrRor/art.json +++ b/art/9dSN7fhb4hT8SrRor/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "rolf", "avatarUrl": "https://lh3.googleusercontent.com/a/AEdFTp77n-4HSiD1U4oeq3eAYwguAOrnvGzhzULeLrdH=s96-c", - "settings": "{\"num\":4000,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define tau 6.28318530718\\n#define res resolution\\n#define rot( x ) mat2( cos( x*tau ), -sin( x*tau ), sin( x*tau ), cos( x*tau ) )\\n#define pos gl_Position.xy\\n#define pSize gl_PointSize\\n#define id ( vertexId - vertexCount/2. )\\n#define cnt vertexCount\\n#define nsin( x ) ( sin( x )*.5 + .5 )\\n#define flip( x ) ( 1. - ( x ) ) \\n#define inv( x ) ( 1. / ( x ) )\\n\\nvec3 c = vec3( 0. );\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n gl_Position.xyzw = vec4( 0., 0., 0., 1. );\\n \\n pos = vec2( 0., 0. ); \\n float yoff = step( mod( vertexId, 2. ), 0.0 );\\n float x = cnt;\\n pos.x = 2.*( id + 0.5 )/( cnt/4.0 );\\n \\n float w = nsin( 2.*time + 4.*pos.x ); \\n pSize = 64. * w;\\n pos.y = yoff*.5+.5*nsin( 2.*time + 32.*pos.x*.2*sin( time/2. )*2. ); \\n c = hsv2rgb( vec3( w/2., 1., 1. ) );\\n pos += mouse; \\n \\n v_color = vec4( c, 1. );\\n}\"}", + "settings": { + "num": 4000, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define tau 6.28318530718\n#define res resolution\n#define rot( x ) mat2( cos( x*tau ), -sin( x*tau ), sin( x*tau ), cos( x*tau ) )\n#define pos gl_Position.xy\n#define pSize gl_PointSize\n#define id ( vertexId - vertexCount/2. )\n#define cnt vertexCount\n#define nsin( x ) ( sin( x )*.5 + .5 )\n#define flip( x ) ( 1. - ( x ) ) \n#define inv( x ) ( 1. / ( x ) )\n\nvec3 c = vec3( 0. );\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n gl_Position.xyzw = vec4( 0., 0., 0., 1. );\n \n pos = vec2( 0., 0. ); \n float yoff = step( mod( vertexId, 2. ), 0.0 );\n float x = cnt;\n pos.x = 2.*( id + 0.5 )/( cnt/4.0 );\n \n float w = nsin( 2.*time + 4.*pos.x ); \n pSize = 64. * w;\n pos.y = yoff*.5+.5*nsin( 2.*time + 32.*pos.x*.2*sin( time/2. )*2. ); \n c = hsv2rgb( vec3( w/2., 1., 1. ) );\n pos += mouse; \n \n v_color = vec4( c, 1. );\n}" + }, "screenshotURL": "data/images/images-dtnnkjtvslzvs5dgn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9fTeRNSKFtEMd9oAM/art.json b/art/9fTeRNSKFtEMd9oAM/art.json index 0668c073..5094ea0b 100644 --- a/art/9fTeRNSKFtEMd9oAM/art.json +++ b/art/9fTeRNSKFtEMd9oAM/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "plasticrainbow", "avatarUrl": "https://secure.gravatar.com/avatar/6a162c0fed03619171f63772ec1198d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-ojo5a51yncg6jaxun-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9fwAKTiyAB7xx9cqz/art.json b/art/9fwAKTiyAB7xx9cqz/art.json index 1821195f..25d143f8 100644 --- a/art/9fwAKTiyAB7xx9cqz/art.json +++ b/art/9fwAKTiyAB7xx9cqz/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":4608,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n//\\n*/\\n\\n\\n//\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = start + 0.5;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.4 * min(resolution.x / resolution.y, 1.)); \\n mat *= rotZ((0.2 + uvfl.y * PI) * time * 2.);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 4608, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n//\n*/\n\n\n//\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = start + 0.5;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.4 * min(resolution.x / resolution.y, 1.)); \n mat *= rotZ((0.2 + uvfl.y * PI) * time * 2.);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-5kjvyqyvb8qcwuzyf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9gAztzKnjeJ3GyrqF/art.json b/art/9gAztzKnjeJ3GyrqF/art.json index b02a5569..44f53ac1 100644 --- a/art/9gAztzKnjeJ3GyrqF/art.json +++ b/art/9gAztzKnjeJ3GyrqF/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "gman", - "settings": "{\"num\":4444,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.001) * 1.;\\n \\n \\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x,\\n y + pow(snd, 5.0) * 1.0);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = u;\\n float sat = 0.;\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 4444, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.001) * 1.;\n \n \n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x,\n y + pow(snd, 5.0) * 1.0);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = u;\n float sat = 0.;\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-dmd8z2rkr11miiowl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9hzmisGQfvWW54XX2/art.json b/art/9hzmisGQfvWW54XX2/art.json index fc6a436a..aebdcfae 100644 --- a/art/9hzmisGQfvWW54XX2/art.json +++ b/art/9hzmisGQfvWW54XX2/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":1200,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Audio Reactive\\n//cs250\\n//spring2023\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount /down);\\n \\n \\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float su = abs(u -0.5) * 2.;\\n float sv = abs(v-0.5)*2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound,vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.)*30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x /600.;\\n \\n float pump = step(0.8,snd);\\n float hue = u * .1 + time * .1;\\n float sat = mix(0., 1.,pump);\\n float val = mix(.1, pow(snd + 0.2,5.), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 1200, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Audio Reactive\n//cs250\n//spring2023\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount /down);\n \n \tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float su = abs(u -0.5) * 2.;\n float sv = abs(v-0.5)*2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound,vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;\n \n gl_PointSize = pow(snd + 0.2, 5.)*30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x /600.;\n \n float pump = step(0.8,snd);\n float hue = u * .1 + time * .1;\n float sat = mix(0., 1.,pump);\n float val = mix(.1, pow(snd + 0.2,5.), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-n4wr837x158qtpns6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9ikkGGKbk6D4k8eRa/art.json b/art/9ikkGGKbk6D4k8eRa/art.json index ffe9e3eb..7429bd8f 100644 --- a/art/9ikkGGKbk6D4k8eRa/art.json +++ b/art/9ikkGGKbk6D4k8eRa/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":99225,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define iResolution vec2(315.0)\\n#define iMouse mouse\\n#define iTime time\\n\\n#define renderSize vec2(1.0)\\n\\n\\n\\n/***************************************************************************/\\n\\n\\n\\nfloat sdBox(in vec3 p, in vec3 d) {\\n vec3 q = abs(p) - d;\\n return length(max(q, 0.0)) + min(max(q.x, max(q.y, q.z)), 0.0);\\n}\\n\\nfloat sdBox2D(in vec2 p, in vec2 d) {\\n vec2 q = abs(p) - d;\\n return length(max(q, 0.0)) + min(max(q.x, q.y), 0.0);\\n}\\n\\nvec2 pModPolar(in vec2 p, in float offs, in float reps) {\\n float rep = 6.28 / reps, hRep = 0.5 * rep;\\n return sin(mod(atan(p.y, p.x) + offs + hRep, rep) - hRep + vec2(1.57, 0.0)) * length(p);\\n}\\n\\nfloat mapScene(in vec3 p) {\\n float turn = iTime;\\n\\n float c = cos(turn), s = sin(turn);\\n vec3 p1 = p, p2 = p;\\n\\n float cell = mod(floor(atan(p1.z, p1.x) / 6.28 * 6.0 + 0.5), 2.0);\\n float dir = cell * 2.0 - 1.0, lock = cell * 0.157;\\n p1.xz = pModPolar(p1.xz, 0.0, 6.0) - vec2(3.0, 0.0);\\n p1.xy *= mat2(c, -s, s, c);\\n\\n float teeth1 = sdBox(vec3(pModPolar(p1.xz, turn * dir + lock, 20.0), p1.y).xzy - vec3(1.35, 0.0, 0.0), vec3(0.25, 0.175, 0.075));\\n float ring1 = sdBox2D(vec2(length(p1.xz) - 1.1, p1.y), vec2(0.25));\\n float gears1 = min(ring1, teeth1);\\n\\n cell = mod(floor(atan(p2.z, p2.x) / 6.28 * 6.0), 2.0);\\n dir = cell * 2.0 - 1.0, lock = cell * 0.157;\\n p2.xz = pModPolar(p2.xz, 0.52, 6.0) - vec2(2.75, 0.0);\\n p2.xy *= mat2(c, -s, s, c);\\n p2.xy = p2.yx;\\n\\n float teeth2 = sdBox(vec3(pModPolar(p2.xz, turn * dir + lock, 20.0), p2.y).xzy - vec3(1.35, 0.0, 0.0), vec3(0.25, 0.175, 0.075));\\n float ring2 = sdBox2D(vec2(length(p2.xz) - 1.1, p2.y), vec2(0.25));\\n float gears2 = min(ring2, teeth2);\\n\\n return min(gears1, gears2) - 0.025;\\n}\\n\\nvec3 getNormal(in vec3 p) {\\n vec3 e = vec3(0.01, 0.0, 0.0);\\n return normalize(vec3(mapScene(p + e.xyy) - mapScene(p - e.xyy),\\n mapScene(p + e.yxy) - mapScene(p - e.yxy),\\n mapScene(p + e.yyx) - mapScene(p - e.yyx)));\\n}\\n\\nvoid mainImage(out vec4 fragColor, in vec2 fragCoord) {\\n vec2 screenCenter = 0.5 * iResolution.xy;\\n\\n vec2 mouse = (iMouse.xy - screenCenter) / iResolution.y * 3.14;\\n vec2 uv = (fragCoord.xy - screenCenter) / iResolution.y;\\n fragColor = vec4(0.0, 0.0, 0.0, 1.0);\\n\\n vec3 ro = vec3(0.0, 0.0, 10.0);\\n vec3 rd = normalize(vec3(uv, -1.0));\\n\\n vec2 rot = vec2(iTime, -0.6);\\n\\n float cy = cos(rot.x), sy = sin(rot.x);\\n float cp = cos(rot.y), sp = sin(rot.y);\\n\\n ro.yz *= mat2(cp, -sp, sp, cp);\\n rd.yz *= mat2(cp, -sp, sp, cp);\\n\\n ro.xz *= mat2(cy, -sy, sy, cy);\\n rd.xz *= mat2(cy, -sy, sy, cy);\\n\\n float t = 0.0;\\n for (float i=0.0; i < 100.0; i++) {\\n vec3 p = ro + rd * t;\\n float d = mapScene(p);\\n if (d < 0.001) {\\n vec3 n = getNormal(p);\\n vec3 l = vec3(-0.58, 0.58, 0.58);\\n\\n l.yz *= mat2(cp, -sp, sp, cp);\\n l.xz *= mat2(cy, -sy, sy, cy);\\n\\n fragColor.rgb += max(0.0, dot(n, l));\\n break;\\n }\\n\\n if (t > 50.0) {\\n fragColor.rgb = mix(vec3(0.25, 0.25, 1.0), vec3(1.0), 0.5 + 0.5 * rd.y);\\n break;\\n }\\n\\n t += d;\\n }\\n}\\n\\n\\n\\n/***************************************************************************/\\n\\n\\nvoid main() {\\n float x = mod(vertexId, iResolution.x);\\n float y = (vertexId - x) / iResolution.y;\\n vec2 point = vec2(x, y) / iResolution * renderSize - 0.5 * renderSize;\\n gl_Position = vec4(point, 0.0, 1.0);\\n gl_Position.x *= resolution.y / resolution.x;\\n gl_PointSize = 1.0;\\n mainImage(v_color, vec2(x, y));\\n}\"}", + "settings": { + "num": 99225, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define iResolution vec2(315.0)\n#define iMouse mouse\n#define iTime time\n\n#define renderSize vec2(1.0)\n\n\n\n/***************************************************************************/\n\n\n\nfloat sdBox(in vec3 p, in vec3 d) {\n vec3 q = abs(p) - d;\n return length(max(q, 0.0)) + min(max(q.x, max(q.y, q.z)), 0.0);\n}\n\nfloat sdBox2D(in vec2 p, in vec2 d) {\n vec2 q = abs(p) - d;\n return length(max(q, 0.0)) + min(max(q.x, q.y), 0.0);\n}\n\nvec2 pModPolar(in vec2 p, in float offs, in float reps) {\n float rep = 6.28 / reps, hRep = 0.5 * rep;\n return sin(mod(atan(p.y, p.x) + offs + hRep, rep) - hRep + vec2(1.57, 0.0)) * length(p);\n}\n\nfloat mapScene(in vec3 p) {\n float turn = iTime;\n\n float c = cos(turn), s = sin(turn);\n vec3 p1 = p, p2 = p;\n\n float cell = mod(floor(atan(p1.z, p1.x) / 6.28 * 6.0 + 0.5), 2.0);\n float dir = cell * 2.0 - 1.0, lock = cell * 0.157;\n p1.xz = pModPolar(p1.xz, 0.0, 6.0) - vec2(3.0, 0.0);\n p1.xy *= mat2(c, -s, s, c);\n\n float teeth1 = sdBox(vec3(pModPolar(p1.xz, turn * dir + lock, 20.0), p1.y).xzy - vec3(1.35, 0.0, 0.0), vec3(0.25, 0.175, 0.075));\n float ring1 = sdBox2D(vec2(length(p1.xz) - 1.1, p1.y), vec2(0.25));\n float gears1 = min(ring1, teeth1);\n\n cell = mod(floor(atan(p2.z, p2.x) / 6.28 * 6.0), 2.0);\n dir = cell * 2.0 - 1.0, lock = cell * 0.157;\n p2.xz = pModPolar(p2.xz, 0.52, 6.0) - vec2(2.75, 0.0);\n p2.xy *= mat2(c, -s, s, c);\n p2.xy = p2.yx;\n\n float teeth2 = sdBox(vec3(pModPolar(p2.xz, turn * dir + lock, 20.0), p2.y).xzy - vec3(1.35, 0.0, 0.0), vec3(0.25, 0.175, 0.075));\n float ring2 = sdBox2D(vec2(length(p2.xz) - 1.1, p2.y), vec2(0.25));\n float gears2 = min(ring2, teeth2);\n\n return min(gears1, gears2) - 0.025;\n}\n\nvec3 getNormal(in vec3 p) {\n vec3 e = vec3(0.01, 0.0, 0.0);\n return normalize(vec3(mapScene(p + e.xyy) - mapScene(p - e.xyy),\n mapScene(p + e.yxy) - mapScene(p - e.yxy),\n mapScene(p + e.yyx) - mapScene(p - e.yyx)));\n}\n\nvoid mainImage(out vec4 fragColor, in vec2 fragCoord) {\n vec2 screenCenter = 0.5 * iResolution.xy;\n\n vec2 mouse = (iMouse.xy - screenCenter) / iResolution.y * 3.14;\n vec2 uv = (fragCoord.xy - screenCenter) / iResolution.y;\n fragColor = vec4(0.0, 0.0, 0.0, 1.0);\n\n vec3 ro = vec3(0.0, 0.0, 10.0);\n vec3 rd = normalize(vec3(uv, -1.0));\n\n vec2 rot = vec2(iTime, -0.6);\n\n float cy = cos(rot.x), sy = sin(rot.x);\n float cp = cos(rot.y), sp = sin(rot.y);\n\n ro.yz *= mat2(cp, -sp, sp, cp);\n rd.yz *= mat2(cp, -sp, sp, cp);\n\n ro.xz *= mat2(cy, -sy, sy, cy);\n rd.xz *= mat2(cy, -sy, sy, cy);\n\n float t = 0.0;\n for (float i=0.0; i < 100.0; i++) {\n vec3 p = ro + rd * t;\n float d = mapScene(p);\n if (d < 0.001) {\n vec3 n = getNormal(p);\n vec3 l = vec3(-0.58, 0.58, 0.58);\n\n l.yz *= mat2(cp, -sp, sp, cp);\n l.xz *= mat2(cy, -sy, sy, cy);\n\n fragColor.rgb += max(0.0, dot(n, l));\n break;\n }\n\n if (t > 50.0) {\n fragColor.rgb = mix(vec3(0.25, 0.25, 1.0), vec3(1.0), 0.5 + 0.5 * rd.y);\n break;\n }\n\n t += d;\n }\n}\n\n\n\n/***************************************************************************/\n\n\nvoid main() {\n float x = mod(vertexId, iResolution.x);\n float y = (vertexId - x) / iResolution.y;\n vec2 point = vec2(x, y) / iResolution * renderSize - 0.5 * renderSize;\n gl_Position = vec4(point, 0.0, 1.0);\n gl_Position.x *= resolution.y / resolution.x;\n gl_PointSize = 1.0;\n mainImage(v_color, vec2(x, y));\n}" + }, "screenshotURL": "data/images/images-4cwrlsae2orwwpycc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9j4xGCXLcJQLP9zX2/art.json b/art/9j4xGCXLcJQLP9zX2/art.json index d942070a..c7895469 100644 --- a/art/9j4xGCXLcJQLP9zX2/art.json +++ b/art/9j4xGCXLcJQLP9zX2/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=36000\\n\\n\\n#define slideSpeed 5. //KParameter 0.>>30.\\n\\n#define fakeVerticeNumber 72000.\\n\\n\\n#define PI radians( 180.0 )\\n\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\\n float f = tan(PI * 0.5 - 0.5 * _fov);\\n float rInv = 1.0 / (_zNear - _zFar);\\n\\n return mat4(\\n f / _aspect, 0., 0., 0.,\\n 0., f, 0., 0.,\\n 0., 0., (_zNear + _zFar) * rInv, -1.,\\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\\n}\\n\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.2);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 0.0, 2.9, 0.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI, in vec3 _sizes)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n\\n\\n//#define MOVING_SHAPES\\n#define SOUND_ON\\nvoid main() \\n{\\n \\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\\n \\n //shape\\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\\n float shapeId = floor(finalVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n float xCount, zCount;\\n xCount = floor(sqrt(shapeCount));\\n zCount = xCount;\\n \\n\\n\\n float xIndex = mod(shapeId,xCount);\\n float zIndex = floor(shapeId/xCount);\\n float relx = xIndex/xCount;\\n float relz = zIndex/zCount;\\n \\n #ifdef SOUND_ON\\n float snd = 10.*texture2D(sound, vec2(1. - relx, 1. -relz)).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n vec4 cNorm;\\n \\n vec3 sizes = vec3(1.,1.,1.);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm, sizes);\\n \\n float scaleFact = 2./xCount;\\n mat4 scaleMat = scale(vec3(scaleFact,(1.+snd)*scaleFact,scaleFact));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n \\n float marginSize = 0.1;\\n float cubeSize = scaleFact + marginSize;\\n\\n #ifdef MOVING_SHAPES\\n cubep += vec3(zIndex*cubeSize - (zCount*cubeSize)/2., 0., mod(xIndex - time*slideSpeed,xCount)*cubeSize - (xCount*cubeSize)/2.); \\n #else\\n cubep += vec3(xIndex*cubeSize - (xCount*cubeSize)/2., 0., zIndex*cubeSize - (zCount*cubeSize)/2.);\\n #endif\\n \\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = cubep;\\n surfaceInfo.vNormal = cNorm.xyz;\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n \\n vec3 vAlbedo = vec3(1.0);\\n\\n float dim = 1.;\\n\\n float pos = xCount*scaleFact/2.;\\n \\n \\n float eyePosY = cos(time*0.22);//10.*texture2D(sound, vec2(relcol, 0.)).a; \\n vec3 eye = vec3(pos, eyePosY, -1.3+sin(time*0.22))*dim;\\n //vec3 eye = vec3(pos+sin(time*1.57), 0.6, pos+cos(time*0.2))*dim;\\n vec3 target = vec3(pos, 0., pos)*dim;\\n vec3 up = vec3(0., 1., 0.);\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n \\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n \\n vAlbedo = vec3(1.0, 1.0, 1.0);\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=36000\n\n\n#define slideSpeed 5. //KParameter 0.>>30.\n\n#define fakeVerticeNumber 72000.\n\n\n#define PI radians( 180.0 )\n\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\n float f = tan(PI * 0.5 - 0.5 * _fov);\n float rInv = 1.0 / (_zNear - _zFar);\n\n return mat4(\n f / _aspect, 0., 0., 0.,\n 0., f, 0., 0.,\n 0., 0., (_zNear + _zFar) * rInv, -1.,\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\n}\n\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.2);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 0.0, 2.9, 0.5), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI, in vec3 _sizes)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n\n\n//#define MOVING_SHAPES\n#define SOUND_ON\nvoid main() \n{\n \n float finalVertexId = mod(vertexId,fakeVerticeNumber);\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\n \n //shape\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\n float shapeId = floor(finalVertexId / kShapeVertexCount);\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n float xCount, zCount;\n xCount = floor(sqrt(shapeCount));\n zCount = xCount;\n \n\n\n float xIndex = mod(shapeId,xCount);\n float zIndex = floor(shapeId/xCount);\n float relx = xIndex/xCount;\n float relz = zIndex/zCount;\n \n #ifdef SOUND_ON\n float snd = 10.*texture2D(sound, vec2(1. - relx, 1. -relz)).a;\n #else\n float snd = 1.;\n #endif\n \n vec4 cNorm;\n \n vec3 sizes = vec3(1.,1.,1.);\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm, sizes);\n \n float scaleFact = 2./xCount;\n mat4 scaleMat = scale(vec3(scaleFact,(1.+snd)*scaleFact,scaleFact));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n \n float marginSize = 0.1;\n float cubeSize = scaleFact + marginSize;\n\n #ifdef MOVING_SHAPES\n cubep += vec3(zIndex*cubeSize - (zCount*cubeSize)/2., 0., mod(xIndex - time*slideSpeed,xCount)*cubeSize - (xCount*cubeSize)/2.); \n #else\n cubep += vec3(xIndex*cubeSize - (xCount*cubeSize)/2., 0., zIndex*cubeSize - (zCount*cubeSize)/2.);\n #endif\n \n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = cubep;\n surfaceInfo.vNormal = cNorm.xyz;\n\n vec3 vViewPos = surfaceInfo.vPos;\n \n vec3 vAlbedo = vec3(1.0);\n\n float dim = 1.;\n\n float pos = xCount*scaleFact/2.;\n \n \n float eyePosY = cos(time*0.22);//10.*texture2D(sound, vec2(relcol, 0.)).a; \n vec3 eye = vec3(pos, eyePosY, -1.3+sin(time*0.22))*dim;\n //vec3 eye = vec3(pos+sin(time*1.57), 0.6, pos+cos(time*0.2))*dim;\n vec3 target = vec3(pos, 0., pos)*dim;\n vec3 up = vec3(0., 1., 0.);\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n \n gl_Position = pmat * vmat * vec4(cubep, 1);\n \n vAlbedo = vec3(1.0, 1.0, 1.0);\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\n\n" + }, "screenshotURL": "data/images/images-72dzpww21ivi6trlv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9mHLiL9t8Tdhkt2Nh/art.json b/art/9mHLiL9t8Tdhkt2Nh/art.json index ca9a9fef..08a91326 100644 --- a/art/9mHLiL9t8Tdhkt2Nh/art.json +++ b/art/9mHLiL9t8Tdhkt2Nh/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":7772,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0784313725490196,0.058823529411764705,0.027450980392156862,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 getSquarePoint(float id) { \\n float x = mod(id, 2.0) + floor(id / 6.0);\\n float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n return vec2(x, y);\\n}\\n\\nvec2 getCirclePoint(float id, float numSegments) { \\n // Each square is made of 2 triangles, 6 points\\n vec2 uv = getSquarePoint(id);\\n\\n // Calculate angle and radial values\\n float angle = uv.x / numSegments * 2.0 * PI;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n // Translate back to x y\\n float radius = uv.y;\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numSegments = 20.0;\\n float numPointsPerCircle = numSegments * 6.0;\\n \\n float numCircles = floor(vertexCount / numPointsPerCircle) - 1.0;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n \\n float aspect = resolution.x / resolution.y; \\n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1;\\n \\n float scaledTime = time * 0.1;\\n \\n float cX = 2.0 * (circleId / numCircles) - 1.0;\\n \\n float nearness = abs(cos((scaledTime + circleId) / 2.0));\\n \\n gl_Position = vec4(xy.x + cX + sin(scaledTime * 5.0 + circleId) * 0.2, xy.y + sin(scaledTime + circleId)*0.5, 0.0, 1);\\n gl_PointSize = 2.0 * nearness + 1.0;\\n \\n // Circle color\\n float hue = sin(circleId * 0.1 + scaledTime * .1) * 0.8;\\n float sat = 0.4;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n \\n}\"}", + "settings": { + "num": 7772, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.058823529411764705, + 0.027450980392156862, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 getSquarePoint(float id) { \n float x = mod(id, 2.0) + floor(id / 6.0);\n float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n return vec2(x, y);\n}\n\nvec2 getCirclePoint(float id, float numSegments) { \n // Each square is made of 2 triangles, 6 points\n vec2 uv = getSquarePoint(id);\n\n // Calculate angle and radial values\n float angle = uv.x / numSegments * 2.0 * PI;\n float c = cos(angle);\n float s = sin(angle);\n \n // Translate back to x y\n float radius = uv.y;\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numSegments = 20.0;\n float numPointsPerCircle = numSegments * 6.0;\n \n float numCircles = floor(vertexCount / numPointsPerCircle) - 1.0;\n float circleId = floor(vertexId / numPointsPerCircle);\n \n float aspect = resolution.x / resolution.y; \n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1;\n \n float scaledTime = time * 0.1;\n \n float cX = 2.0 * (circleId / numCircles) - 1.0;\n \n float nearness = abs(cos((scaledTime + circleId) / 2.0));\n \n gl_Position = vec4(xy.x + cX + sin(scaledTime * 5.0 + circleId) * 0.2, xy.y + sin(scaledTime + circleId)*0.5, 0.0, 1);\n gl_PointSize = 2.0 * nearness + 1.0;\n \n // Circle color\n float hue = sin(circleId * 0.1 + scaledTime * .1) * 0.8;\n float sat = 0.4;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n \n}" + }, "screenshotURL": "data/images/images-oh2dc37vgbwmyn45y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9mqwFjEipb8pPtcPw/art.json b/art/9mqwFjEipb8pPtcPw/art.json index b7ac1997..9eaa2130 100644 --- a/art/9mqwFjEipb8pPtcPw/art.json +++ b/art/9mqwFjEipb8pPtcPw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/substruk-records/sub032-sixis-orbital-substruk\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float a = atan(u - 0.5, v - .5);\\n float r = length(vec2(u - 0.5, v - .5));\\n float snd = texture2D(sound, vec2(mix(0.0, 0.0135, abs(a / PI)), r * 0.3)).a;\\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(u) * across * 1.0 + bxId * 0. ;\\n float vSpace = numRows * 2.0 + numBlocks * 0.;\\n float z = v * down * 2.0 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 0.1 + pow(snd, 5.) * 7.0;\\n vCubeOrigin.y += height;pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = mix(\\n hsv2rgb(vec3(time * 0.1,0.7,0.8)), hsv2rgb(vec3(time * 0.1 + 0.5,1,1)), smoothstep(0.50,1., snd));\\n // hsv2rgb(vec3(\\n // mix(1., 1.5, pow(snd, 5.)) + fract(time * 0.1), // + 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1, \\n // 0.5 + snd * 0.5, \\n // 1));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( sin(time) * 700., -600.6 + cos(time) * 100., 1000.0 );\\n \\tvec3 vCameraPos = vec3(sin(time) * -45.1, 40., -10.);\\n float ca = 0.;\\n \\n // get sick!\\n // ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/substruk-records/sub032-sixis-orbital-substruk", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float a = atan(u - 0.5, v - .5);\n float r = length(vec2(u - 0.5, v - .5));\n float snd = texture2D(sound, vec2(mix(0.0, 0.0135, abs(a / PI)), r * 0.3)).a;\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(u) * across * 1.0 + bxId * 0. ;\n float vSpace = numRows * 2.0 + numBlocks * 0.;\n float z = v * down * 2.0 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 0.1 + pow(snd, 5.) * 7.0;\n vCubeOrigin.y += height;pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = mix(\n hsv2rgb(vec3(time * 0.1,0.7,0.8)), hsv2rgb(vec3(time * 0.1 + 0.5,1,1)), smoothstep(0.50,1., snd));\n // hsv2rgb(vec3(\n // mix(1., 1.5, pow(snd, 5.)) + fract(time * 0.1), // + 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1, \n // 0.5 + snd * 0.5, \n // 1));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( sin(time) * 700., -600.6 + cos(time) * 100., 1000.0 );\n \tvec3 vCameraPos = vec3(sin(time) * -45.1, 40., -10.);\n float ca = 0.;\n \n // get sick!\n // ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-646wcqea4omf0wrks-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9oFBPGkXY6hB2TaHK/art.json b/art/9oFBPGkXY6hB2TaHK/art.json index 50d71827..baf6ebd6 100644 --- a/art/9oFBPGkXY6hB2TaHK/art.json +++ b/art/9oFBPGkXY6hB2TaHK/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "pöstpöp", "avatarUrl": "https://lh3.googleusercontent.com/-JUIeC9mYGbM/AAAAAAAAAAI/AAAAAAAAACE/f6C0Rr97fYs/photo.jpg", - "settings": "{\"num\":25000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n _ \\n _ _ ___ ___| |_ ___ _ _ \\n| | | -_| _| _| -_|_'_|\\n \\\\_/|___|_| |_| |___|_,_|\\n _ _ \\n ___| |_ ___ _| |___ ___ \\n|_ -| | .'| . | -_| _|\\n|___|_|_|__,|___|___|_| \\n _ \\n ___ ___| |_ \\n| .'| _| _| \\n|__,|_| |_| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomBoxPoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n p[2] = mix(-1., 1., step(0., p[2]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n p[0] = mix(-1., 1., step(0., p[0]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomSpherePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319))));\\n}\\n\\nvec3 getRandomSphereVolumePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\\n}\\n\\nvec3 getRandomCubeVolumePoint(float seed) {\\n return vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n}\\n\\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getPoint(float set, float seed) {\\n set = mod(set, 7.);\\n if (set < 1.) \\n {\\n return getRandomCubePoint(seed);\\n }\\n if (set < 2.) \\n {\\n return getRandomSphereVolumePoint(seed);\\n }\\n if (set < 3.) \\n {\\n return getRandomFunkPoint(seed, 3., 3.);\\n }\\n if (set < 4.) \\n {\\n return getRandomSpherePoint(seed);\\n }\\n if (set < 5.) \\n {\\n return getRandomBoxPoint(seed);\\n }\\n if (set < 6.)\\n {\\n return getRandomCubeVolumePoint(seed);\\n }\\n return getRandomFunkOutPoint(seed, 4., 3.);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, 3.);\\n }\\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\\n}\\n\\nvec3 getLerpedPoint(float time, float seed) {\\n float set = mod(time, 7.);\\n vec3 p0 = getPoint(set, seed);\\n vec3 p1 = getPoint(set + 1., seed);\\n return mix(p0, p1, easeInOutCubic(fract(time)));\\n}\\n\\n#define DOTS_PER 4000.\\n\\nvoid main() {\\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n\\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\\n \\n float cameraRadius = 13.;\\n float camAngle = time * 0.3;\\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n\\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(\\n m1p1(hash(thingId * 0.179)) * 6., \\n m1p1(hash(thingId * 0.317)) * 6., \\n m1p1(hash(thingId * 0.251)) * 6.));\\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\\n gl_Position = m * vec4(p, 1);\\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n\\n float hue = 0.3+ v * 0.1;\\n hue = mix(hue, 0.2, mod(floor(time * 60.0), 2.));\\n hue = mix(hue, .0, step(0.9, snd));\\n float sat = 1.;\\n float val = invClipZ * 150.;\\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n gl_PointSize = 18. / gl_Position.z;\\n}\"}", + "settings": { + "num": 25000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n _ \n _ _ ___ ___| |_ ___ _ _ \n| | | -_| _| _| -_|_'_|\n \\_/|___|_| |_| |___|_,_|\n _ _ \n ___| |_ ___ _| |___ ___ \n|_ -| | .'| . | -_| _|\n|___|_|_|__,|___|___|_| \n _ \n ___ ___| |_ \n| .'| _| _| \n|__,|_| |_| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvec3 getRandomBoxPoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n p[1] = mix(-1., 1., step(0., p[1]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n p[2] = mix(-1., 1., step(0., p[2]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n p[0] = mix(-1., 1., step(0., p[0]));\n }\n return p;\n}\n\nvec3 getRandomSpherePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319))));\n}\n\nvec3 getRandomSphereVolumePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\n}\n\nvec3 getRandomCubeVolumePoint(float seed) {\n return vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n}\n\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getPoint(float set, float seed) {\n set = mod(set, 7.);\n if (set < 1.) \n {\n return getRandomCubePoint(seed);\n }\n if (set < 2.) \n {\n return getRandomSphereVolumePoint(seed);\n }\n if (set < 3.) \n {\n return getRandomFunkPoint(seed, 3., 3.);\n }\n if (set < 4.) \n {\n return getRandomSpherePoint(seed);\n }\n if (set < 5.) \n {\n return getRandomBoxPoint(seed);\n }\n if (set < 6.)\n {\n return getRandomCubeVolumePoint(seed);\n }\n return getRandomFunkOutPoint(seed, 4., 3.);\n}\n\nfloat easeInOutCubic(float pos) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, 3.);\n }\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\n}\n\nvec3 getLerpedPoint(float time, float seed) {\n float set = mod(time, 7.);\n vec3 p0 = getPoint(set, seed);\n vec3 p1 = getPoint(set + 1., seed);\n return mix(p0, p1, easeInOutCubic(fract(time)));\n}\n\n#define DOTS_PER 4000.\n\nvoid main() {\n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\n \n float cameraRadius = 13.;\n float camAngle = time * 0.3;\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(\n m1p1(hash(thingId * 0.179)) * 6., \n m1p1(hash(thingId * 0.317)) * 6., \n m1p1(hash(thingId * 0.251)) * 6.));\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\n gl_Position = m * vec4(p, 1);\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n\n float hue = 0.3+ v * 0.1;\n hue = mix(hue, 0.2, mod(floor(time * 60.0), 2.));\n hue = mix(hue, .0, step(0.9, snd));\n float sat = 1.;\n float val = invClipZ * 150.;\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n gl_PointSize = 18. / gl_Position.z;\n}" + }, "screenshotURL": "data/images/images-zyjdvhf87kq698k9e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9s4f49dwx4L8hbbD5/art.json b/art/9s4f49dwx4L8hbbD5/art.json index 7f41e972..bf5dd9d3 100644 --- a/art/9s4f49dwx4L8hbbD5/art.json +++ b/art/9s4f49dwx4L8hbbD5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "visa-valtteri", "avatarUrl": "https://lh4.googleusercontent.com/-LZnRtqD3Cf4/AAAAAAAAAAI/AAAAAAAAEyw/CB7DLj_ThQA/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/daataa/mitch-murder-breeze\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 1.+time*0.001 - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 10.*time;\\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(3, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 1.;//0.5 + over * 0.7;\\n float sat = step(0.25,s2)*3.;\\n float val = pow(s2*0.01,0.3);\\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/daataa/mitch-murder-breeze", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 1.+time*0.001 - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\n \n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 10.*time;\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(3, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 1.;//0.5 + over * 0.7;\n float sat = step(0.25,s2)*3.;\n float val = pow(s2*0.01,0.3);\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\n \tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-zzp5cmodbt9n3rv37-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9tQdLKqdczvbu3Pp5/art.json b/art/9tQdLKqdczvbu3Pp5/art.json index 87453a4d..9b0eb016 100644 --- a/art/9tQdLKqdczvbu3Pp5/art.json +++ b/art/9tQdLKqdczvbu3Pp5/art.json @@ -29,7 +29,19 @@ }, "private": false, "username": "sap", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28\\n#define PI 3.145191\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nfloat hash12(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float n = vertexId / vertexCount;\\n float z = vertexId / 2000.;\\n \\n float m = pow (n, 1.12);\\n float k = 1. - m;\\n \\n vec2 p;\\n\\n p = vec2(k * z * 0.7 * cos(0.7 * PI + time) * cos(time), k * z * 0.3 * sin(time));\\n \\n vec2 d = 0.3*vec2(z * cos(vertexId * TAU * 0.0051), z * sin(vertexId * TAU * 0.0051));\\n p += d + d * 0.1 * SmoothNoise(d + vec2(time, time) + hash12(d) * 0.4);\\n \\n p.xy *= resolution.yy / resolution.xy; \\n\\n gl_Position = vec4(p, 0., 1.);\\n \\n vec3 c = hsv2rgb(vec3(10. / 360. * time,mix(.6, 1., m), m));\\n \\n v_color = vec4(c,1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28\n#define PI 3.145191\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nfloat hash12(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float n = vertexId / vertexCount;\n float z = vertexId / 2000.;\n \n float m = pow (n, 1.12);\n float k = 1. - m;\n \n vec2 p;\n\n p = vec2(k * z * 0.7 * cos(0.7 * PI + time) * cos(time), k * z * 0.3 * sin(time));\n \n vec2 d = 0.3*vec2(z * cos(vertexId * TAU * 0.0051), z * sin(vertexId * TAU * 0.0051));\n p += d + d * 0.1 * SmoothNoise(d + vec2(time, time) + hash12(d) * 0.4);\n \n p.xy *= resolution.yy / resolution.xy; \n\n gl_Position = vec4(p, 0., 1.);\n \n vec3 c = hsv2rgb(vec3(10. / 360. * time,mix(.6, 1., m), m));\n \n v_color = vec4(c,1);\n}" + }, "screenshotURL": "data/images/images-1264nzzay2lndrqku-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9tYkByMY9xHJQLM8M/art.json b/art/9tYkByMY9xHJQLM8M/art.json index b662f7bf..22c355ab 100644 --- a/art/9tYkByMY9xHJQLM8M/art.json +++ b/art/9tYkByMY9xHJQLM8M/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 aspect = mat4(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 2, 1,\\n 0, 0, 1, 1,\\n 0, 0, 0, 1);\\n\\nmat4 scale(float s) {\\n return mat4(\\n s, 0, 0, s,\\n 0, s, s, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, s);\\n}\\n\\nmat4 rotY() {\\n float s = sin(time / 4.);\\n float c = cos(time / 4.);\\n return mat4(\\n c, 0, c-s, 0,\\n 0, c, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, c);\\n}\\n\\nmat4 rotX() {\\n float deg = radians((-0.5 * (mouse.y + 1.)) * 360.);\\n float s = sin(deg);\\n float c = cos(deg);\\n return mat4(\\n 1, 0, 0, c,\\n 0, c, c/s, 0,\\n 0, s, c, 0,\\n s, 0, 0, 1);\\n}\\n\\nvoid main()\\n{\\n float pointsPerCircle = 5000.;\\n if(vertexId < pointsPerCircle) {\\n float yPos = cos(vertexId / pointsPerCircle * PI);\\n float xyLen = sin(vertexId / pointsPerCircle * PI);\\n float xPos = sin(vertexId) * xyLen;\\n float zPos = cos(vertexId) * xyLen;\\n vec4 pos = vec4(xPos, yPos, zPos, 1);\\n pos = aspect * scale(0.5) * rotX() * rotY() * pos;\\n \\tgl_Position = pos;\\n gl_PointSize = (-pos.z + 0.5) * 8.;\\n \\tv_color = mix(vec4(1, 0, 0, 1), vec4(0, 0, 1, 1), vertexId / pointsPerCircle);\\n }\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 aspect = mat4(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 2, 1,\n 0, 0, 1, 1,\n 0, 0, 0, 1);\n\nmat4 scale(float s) {\n return mat4(\n s, 0, 0, s,\n 0, s, s, 0,\n 0, 0, s, 0,\n 0, 0, 0, s);\n}\n\nmat4 rotY() {\n float s = sin(time / 4.);\n float c = cos(time / 4.);\n return mat4(\n c, 0, c-s, 0,\n 0, c, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, c);\n}\n\nmat4 rotX() {\n float deg = radians((-0.5 * (mouse.y + 1.)) * 360.);\n float s = sin(deg);\n float c = cos(deg);\n return mat4(\n 1, 0, 0, c,\n 0, c, c/s, 0,\n 0, s, c, 0,\n s, 0, 0, 1);\n}\n\nvoid main()\n{\n float pointsPerCircle = 5000.;\n if(vertexId < pointsPerCircle) {\n float yPos = cos(vertexId / pointsPerCircle * PI);\n float xyLen = sin(vertexId / pointsPerCircle * PI);\n float xPos = sin(vertexId) * xyLen;\n float zPos = cos(vertexId) * xyLen;\n vec4 pos = vec4(xPos, yPos, zPos, 1);\n pos = aspect * scale(0.5) * rotX() * rotY() * pos;\n \tgl_Position = pos;\n gl_PointSize = (-pos.z + 0.5) * 8.;\n \tv_color = mix(vec4(1, 0, 0, 1), vec4(0, 0, 1, 1), vertexId / pointsPerCircle);\n }\n}" + }, "screenshotURL": "data/images/images-2gphq0lzasd8zeijw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/9wKMAeACxZ3WoJc2m/art.json b/art/9wKMAeACxZ3WoJc2m/art.json index f0fbeabc..608c823f 100644 --- a/art/9wKMAeACxZ3WoJc2m/art.json +++ b/art/9wKMAeACxZ3WoJc2m/art.json @@ -28,7 +28,19 @@ "name": "Spiral", "private": false, "username": "Axesider", - "settings": "{\"num\":16384,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.01;\\n float phase = -time+mod(vertexId,2.0);\\n float a = 0.5;\\n float b = 0.3063489;\\n float x = a * exp(b*t)*cos(t+phase)*0.015;\\n float y = a * exp(b*t)*sin(t+phase)*0.015;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n \\n float hue = floor(time*0.0) / 0.23;\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.01;\n float phase = -time+mod(vertexId,2.0);\n float a = 0.5;\n float b = 0.3063489;\n float x = a * exp(b*t)*cos(t+phase)*0.015;\n float y = a * exp(b*t)*sin(t+phase)*0.015;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n \n float hue = floor(time*0.0) / 0.23;\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-2a5m4wethnw41mqcy-thumbnail.jpg", "views": { "$numberInt": "987" diff --git a/art/9xQqPx9YtLs7Zddzb/art.json b/art/9xQqPx9YtLs7Zddzb/art.json index 1ea01749..78563d26 100644 --- a/art/9xQqPx9YtLs7Zddzb/art.json +++ b/art/9xQqPx9YtLs7Zddzb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=36000\\n\\n\\n#define slideSpeed 5. //KParameter 0.>>30.\\n\\n#define fakeVerticeNumber 72000.\\n\\n\\n#define PI radians( 180.0 )\\n\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\\n float f = tan(PI * 0.5 - 0.5 * _fov);\\n float rInv = 1.0 / (_zNear - _zFar);\\n\\n return mat4(\\n f / _aspect, 0., 0., 0.,\\n 0., f, 0., 0.,\\n 0., 0., (_zNear + _zFar) * rInv, -1.,\\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\\n}\\n\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo, const vec2 _sceneSize)\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.2);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n float center = _sceneSize.x/2.;\\n AddPointLight( vec3(0.0, center, 10.0), vec3( 1., 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 0.0, 2.9, 0.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI, in vec3 _sizes)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(0.5, 0.5);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-0.5, 0.5);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(0.5, -0.5);\\n }\\n else {\\n fp = vec2(-0.5, -0.5);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 0.5);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -0.5);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 0.5, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -0.5, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-0.5, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(0.50, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n\\n\\n//#define MOVING_SHAPES\\n#define SOUND_ON\\n#define EYE_STYLE 0\\nvoid main() \\n{\\n \\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\\n \\n //shape\\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\\n float shapeId = floor(finalVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n float xCount, zCount;\\n xCount = floor(sqrt(shapeCount));\\n zCount = xCount;\\n \\n vec2 gridDim = vec2(10.,10.);\\n float marginSize = 0.02;\\n\\n float xIndex = mod(shapeId,xCount);\\n float zIndex = floor(shapeId/xCount);\\n float relx = xIndex/xCount;\\n float relz = zIndex/zCount;\\n \\n #ifdef SOUND_ON\\n float snd = 10.*texture2D(sound, vec2(1. - relx, 1. -relz)).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n vec4 cNorm;\\n \\n vec3 sizes = vec3(1.,1.,1.);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm, sizes);\\n \\n float lineWidth = gridDim.x/xCount; //the shape 'line' size including margins\\n float cubeWidth = lineWidth - marginSize;//the shape size\\n mat4 scaleMat = scale(vec3(cubeWidth,(1.+snd)*cubeWidth,cubeWidth));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n\\n #ifdef MOVING_SHAPES\\n cubep += vec3(zIndex*lineWidth, 0., mod(xIndex - time*slideSpeed,xCount)*cubeSize); \\n #else\\n cubep += vec3(xIndex*lineWidth, 0., zIndex*lineWidth);\\n #endif\\n \\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = cubep;\\n surfaceInfo.vNormal = cNorm.xyz;\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n \\n float dim = 1.;\\n\\n float pos = xCount*lineWidth;\\n \\n \\n float eyePosY = 1.2;//10.*texture2D(sound, vec2(relcol, 0.)).a; \\n float eyeSpeedFactor = 0.2;\\n #if EYE_STYLE == 0\\n vec3 eye = vec3(gridDim.x/2.+gridDim.x/2.*cos(time*eyeSpeedFactor), eyePosY, gridDim.x/2.+gridDim.x/2.*sin(time*eyeSpeedFactor))*dim;\\n #else\\n vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\\n #endif\\n //vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\\n //vec3 eye = vec3(pos+sin(time*1.57), 0.6, pos+cos(time*0.2))*dim;\\n vec3 target = vec3(gridDim.x/2., 0., gridDim.x/2.)*dim;\\n vec3 up = vec3(0., 1., 0.);\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n \\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n \\n vec3 vAlbedo = vec3(1.0, 1.0, 1.0);\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo, gridDim ); \\n\\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=36000\n\n\n#define slideSpeed 5. //KParameter 0.>>30.\n\n#define fakeVerticeNumber 72000.\n\n\n#define PI radians( 180.0 )\n\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\n float f = tan(PI * 0.5 - 0.5 * _fov);\n float rInv = 1.0 / (_zNear - _zFar);\n\n return mat4(\n f / _aspect, 0., 0., 0.,\n 0., f, 0., 0.,\n 0., 0., (_zNear + _zFar) * rInv, -1.,\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\n}\n\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo, const vec2 _sceneSize)\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.2);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n float center = _sceneSize.x/2.;\n AddPointLight( vec3(0.0, center, 10.0), vec3( 1., 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 0.0, 2.9, 0.5), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI, in vec3 _sizes)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(0.5, 0.5);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-0.5, 0.5);\n }\n else if(vtxId == 3.0) {\n fp = vec2(0.5, -0.5);\n }\n else {\n fp = vec2(-0.5, -0.5);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 0.5);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -0.5);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 0.5, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -0.5, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-0.5, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(0.50, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n\n\n//#define MOVING_SHAPES\n#define SOUND_ON\n#define EYE_STYLE 0\nvoid main() \n{\n \n float finalVertexId = mod(vertexId,fakeVerticeNumber);\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\n \n //shape\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\n float shapeId = floor(finalVertexId / kShapeVertexCount);\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n float xCount, zCount;\n xCount = floor(sqrt(shapeCount));\n zCount = xCount;\n \n vec2 gridDim = vec2(10.,10.);\n float marginSize = 0.02;\n\n float xIndex = mod(shapeId,xCount);\n float zIndex = floor(shapeId/xCount);\n float relx = xIndex/xCount;\n float relz = zIndex/zCount;\n \n #ifdef SOUND_ON\n float snd = 10.*texture2D(sound, vec2(1. - relx, 1. -relz)).a;\n #else\n float snd = 1.;\n #endif\n \n vec4 cNorm;\n \n vec3 sizes = vec3(1.,1.,1.);\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm, sizes);\n \n float lineWidth = gridDim.x/xCount; //the shape 'line' size including margins\n float cubeWidth = lineWidth - marginSize;//the shape size\n mat4 scaleMat = scale(vec3(cubeWidth,(1.+snd)*cubeWidth,cubeWidth));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n\n #ifdef MOVING_SHAPES\n cubep += vec3(zIndex*lineWidth, 0., mod(xIndex - time*slideSpeed,xCount)*cubeSize); \n #else\n cubep += vec3(xIndex*lineWidth, 0., zIndex*lineWidth);\n #endif\n \n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = cubep;\n surfaceInfo.vNormal = cNorm.xyz;\n\n vec3 vViewPos = surfaceInfo.vPos;\n \n float dim = 1.;\n\n float pos = xCount*lineWidth;\n \n \n float eyePosY = 1.2;//10.*texture2D(sound, vec2(relcol, 0.)).a; \n float eyeSpeedFactor = 0.2;\n #if EYE_STYLE == 0\n vec3 eye = vec3(gridDim.x/2.+gridDim.x/2.*cos(time*eyeSpeedFactor), eyePosY, gridDim.x/2.+gridDim.x/2.*sin(time*eyeSpeedFactor))*dim;\n #else\n vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\n #endif\n //vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\n //vec3 eye = vec3(pos+sin(time*1.57), 0.6, pos+cos(time*0.2))*dim;\n vec3 target = vec3(gridDim.x/2., 0., gridDim.x/2.)*dim;\n vec3 up = vec3(0., 1., 0.);\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n \n gl_Position = pmat * vmat * vec4(cubep, 1);\n \n vec3 vAlbedo = vec3(1.0, 1.0, 1.0);\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo, gridDim ); \n\n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\n\n" + }, "screenshotURL": "data/images/images-9ecd6onfkaadvcgx8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9ydRokp8vXNSApmsq/art.json b/art/9ydRokp8vXNSApmsq/art.json index 8c2ac63e..2ff8dc7f 100644 --- a/art/9ydRokp8vXNSApmsq/art.json +++ b/art/9ydRokp8vXNSApmsq/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2862,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.0120;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 2862, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.0120;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-3p4e60ngudxsxynq8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9yoBtz2q3YvMZHhw6/art.json b/art/9yoBtz2q3YvMZHhw6/art.json index 63d7c86d..842d0b80 100644 --- a/art/9yoBtz2q3YvMZHhw6/art.json +++ b/art/9yoBtz2q3YvMZHhw6/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":21600,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/thrillkillkult/07-bella-piranha\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.1568627450980392,0.7803921568627451,1],\"shader\":\"// _ _ _ _ \\n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \\n// \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__/ _` | '__| __|\\n// \\\\ V / __/ | | || __/> <\\\\__ \\\\ | | | (_| | (_| | __/ | | (_| | | | |_ \\n// \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\\\__,_|_| \\\\__|\\n//\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 6.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\\n \\n float across = 32.;\\n float down = 20.;\\n float u = mod(fCubeId, across) / across;\\n float v = floor(fCubeId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.02;\\n \\n mat = ident();\\n \\tmat *= rotZ(lng);\\n \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= uniformScale(fScale);\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeCol = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol = mix(vCubeCol, vec3(1,0,0), step(0.95,s2));\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n mat4 mCube;\\n vec3 vCubeCol;\\n\\n GetCubePosition( fCubeId, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 21600, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/thrillkillkult/07-bella-piranha", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.1568627450980392, + 0.7803921568627451, + 1 + ], + "shader": "// _ _ _ _ \n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \n// \\ \\ / / _ \\ '__| __/ _ \\ \\/ / __| '_ \\ / _` |/ _` |/ _ \\ '__/ _` | '__| __|\n// \\ V / __/ | | || __/> <\\__ \\ | | | (_| | (_| | __/ | | (_| | | | |_ \n// \\_/ \\___|_| \\__\\___/_/\\_\\___/_| |_|\\__,_|\\__,_|\\___|_| \\__,_|_| \\__|\n//\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 6.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\n \n float across = 32.;\n float down = 20.;\n float u = mod(fCubeId, across) / across;\n float v = floor(fCubeId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.02;\n \n mat = ident();\n \tmat *= rotZ(lng);\n \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= uniformScale(fScale);\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeCol = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol = mix(vCubeCol, vec3(1,0,0), step(0.95,s2));\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n mat4 mCube;\n vec3 vCubeCol;\n\n GetCubePosition( fCubeId, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-fsrbpulj0ksqp5agy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9ythNthyPP2w9WbgY/art.json b/art/9ythNthyPP2w9WbgY/art.json index 56f2fd1f..b2ce654d 100644 --- a/art/9ythNthyPP2w9WbgY/art.json +++ b/art/9ythNthyPP2w9WbgY/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Exercise - Vertexshaderart : Making a Grid\\n// Course : CS250\\n// Term & Year : 2023 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down );\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\t\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Exercise - Vertexshaderart : Making a Grid\n// Course : CS250\n// Term & Year : 2023 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down );\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \t\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}\n" + }, "screenshotURL": "data/images/images-fdnjls0vf4ulnhdqw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/9yyh6FdtyTqLN2EgE/art.json b/art/9yyh6FdtyTqLN2EgE/art.json index e988800e..e4329117 100644 --- a/art/9yyh6FdtyTqLN2EgE/art.json +++ b/art/9yyh6FdtyTqLN2EgE/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":88350,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/discobelle/discobelle-mix-098-siete-catorce\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define parameter0 3.//KParameter0 -1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.03, 0.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, sin(22.0 -1.0) * 3.0, 0.2);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 116.0 / K.www / parameter0);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20 * parameter1, 0.8), c.x +c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, parameter3,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, parameter3,\\n 0, 1, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -0.2, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 1, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target +parameter5);\\n vec3 xAxis = normalize(cross(up, zAxis -parameter4));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 34.3137 * parameter5));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3. *parameter6), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 22.4)))*3758.5453123*parameter7);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5* parameter1;\\n// v += noise(p*2.)*.125;\\n// v += noise(p*4.)*.1125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 3.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + 4.6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 2.57));\\n}\\n\\nconst float expand = 80.;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float numStars = floor(vertexCount / 3.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n float s = texture2D(sound, vec2(\\n mix(0.02, 0.5, h),\\n mix(0.0, 0.05, starV))).a;\\n \\n \\n float pId = mod(vertexId, 3.);\\n float sz = pow(s + 0.25, 5.) * 10.;\\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(0.5, pId);\\n \\n float hue = time * .1 + h * 1.2;\\n float sat = 1.;\\n float val = pow(s + 0.8, 5.);\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n float pump = step(0.38, s);\\n color = mix(color, vec4(1, -1, 0, 1), pump);\\n color.a = mix(sin(1.2 / time * s)-parameter5, 0.2, pow(s, parameter6));\\n color.rgb *= color.a;\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 3000.0;\\n const float numFunkPoints = 4500.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.125;\\n\\n const float coff = 0.4;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(16.0), resolution.x / resolution.y, .01, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\\n \\n gl_Position = pmat * vmat * vec4(pos, 1. * parameter2);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0.26, cz)); \\n \\n}\\n\"}", + "settings": { + "num": 88350, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/discobelle/discobelle-mix-098-siete-catorce", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define parameter0 3.//KParameter0 -1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.03, 0.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, sin(22.0 -1.0) * 3.0, 0.2);\n vec3 p = abs(fract(c.xxx + K.xyz) * 116.0 / K.www / parameter0);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20 * parameter1, 0.8), c.x +c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, parameter3,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, parameter3,\n 0, 1, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -0.2, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 1, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target +parameter5);\n vec3 xAxis = normalize(cross(up, zAxis -parameter4));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 34.3137 * parameter5));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3. *parameter6), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 22.4)))*3758.5453123*parameter7);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5* parameter1;\n// v += noise(p*2.)*.125;\n// v += noise(p*4.)*.1125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 3.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + 4.6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 2.57));\n}\n\nconst float expand = 80.;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float numStars = floor(vertexCount / 3.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n float s = texture2D(sound, vec2(\n mix(0.02, 0.5, h),\n mix(0.0, 0.05, starV))).a;\n \n \n float pId = mod(vertexId, 3.);\n float sz = pow(s + 0.25, 5.) * 10.;\n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(0.5, pId);\n \n float hue = time * .1 + h * 1.2;\n float sat = 1.;\n float val = pow(s + 0.8, 5.);\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n float pump = step(0.38, s);\n color = mix(color, vec4(1, -1, 0, 1), pump);\n color.a = mix(sin(1.2 / time * s)-parameter5, 0.2, pow(s, parameter6));\n color.rgb *= color.a;\n}\n\nvoid main() {\n const float numTrackPoints = 3000.0;\n const float numFunkPoints = 4500.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.125;\n\n const float coff = 0.4;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(16.0), resolution.x / resolution.y, .01, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\n \n gl_Position = pmat * vmat * vec4(pos, 1. * parameter2);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0.26, cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-onnzqftc74oignlom-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A4aQeDP9zYwLTXGKd/art.json b/art/A4aQeDP9zYwLTXGKd/art.json index ff0cb4e1..29ebb3cd 100644 --- a/art/A4aQeDP9zYwLTXGKd/art.json +++ b/art/A4aQeDP9zYwLTXGKd/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 100;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 100;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-gzeted81ngf963e9n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A5Eknh4sb38Hw5pjv/art.json b/art/A5Eknh4sb38Hw5pjv/art.json index 9332f8e4..0c7a79f9 100644 --- a/art/A5Eknh4sb38Hw5pjv/art.json +++ b/art/A5Eknh4sb38Hw5pjv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.10588235294117647,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5);// / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.4 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float ss = 0.5;//texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float pop = step(0.6, ss);\\n val = mix(val, 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.10588235294117647, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5);// / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.4 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float ss = 0.5;//texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float pop = step(0.6, ss);\n val = mix(val, 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-h22546ujw1qq12heo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A5wHpLQiQydYkB7sg/art.json b/art/A5wHpLQiQydYkB7sg/art.json index 09432a40..4052d8e5 100644 --- a/art/A5wHpLQiQydYkB7sg/art.json +++ b/art/A5wHpLQiQydYkB7sg/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sergioerick", "avatarUrl": "https://lh6.googleusercontent.com/-6mWCYE7e8JE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcnyCK5B6N4hdhN62pAcPOwiFeA5g/mo/photo.jpg", - "settings": "{\"num\":6000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n\\tfloat width = 10.0;\\n\\tfloat circumPoints = 60.0;\\n\\n\\tfloat gridId = floor(vertexId/(circumPoints));\\n \\n\\tfloat xGrid = mod(gridId, width);\\n\\tfloat yGrid = floor(gridId / width);\\n\\n\\tfloat uGrid = xGrid / (width - 1.0);\\n\\tfloat vGrid = yGrid / (width - 1.0);\\n\\n\\tfloat circleId = mod(vertexId, circumPoints);\\n\\n\\tfloat xCircle = floor(circleId/ 2.0);\\n\\tfloat yCircle = mod(circleId + 1.0, 2.0);\\n \\n\\tfloat angle = xCircle / ((circumPoints-2.0)/2.0) * radians(360.0);\\n\\tfloat radius = 2.0 - yCircle;\\n \\n\\tfloat uCircle = radius * cos(angle);\\n\\tfloat vCircle = radius * sin(angle);\\n\\n \\n\\tfloat xOffset = cos(time + yGrid * 0.2) * 0.1;\\n\\tfloat yOffset = cos(time + xGrid * 0.3) * 0.2;\\n \\n\\tfloat ux = uGrid * 2.0 - 1.0 + xOffset + uCircle*0.05;\\n\\tfloat vy = vGrid * 2.0 - 1.0 + yOffset + vCircle*0.05;\\n \\n\\tvec2 xy = vec2(ux, vy) * 0.8;\\n \\n\\tgl_Position = vec4(xy, 0.0, 1.0);\\n\\tgl_PointSize = 5.0;\\n\\tv_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 6000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n\tfloat width = 10.0;\n\tfloat circumPoints = 60.0;\n\n\tfloat gridId = floor(vertexId/(circumPoints));\n \n\tfloat xGrid = mod(gridId, width);\n\tfloat yGrid = floor(gridId / width);\n\n\tfloat uGrid = xGrid / (width - 1.0);\n\tfloat vGrid = yGrid / (width - 1.0);\n\n\tfloat circleId = mod(vertexId, circumPoints);\n\n\tfloat xCircle = floor(circleId/ 2.0);\n\tfloat yCircle = mod(circleId + 1.0, 2.0);\n \n\tfloat angle = xCircle / ((circumPoints-2.0)/2.0) * radians(360.0);\n\tfloat radius = 2.0 - yCircle;\n \n\tfloat uCircle = radius * cos(angle);\n\tfloat vCircle = radius * sin(angle);\n\n \n\tfloat xOffset = cos(time + yGrid * 0.2) * 0.1;\n\tfloat yOffset = cos(time + xGrid * 0.3) * 0.2;\n \n\tfloat ux = uGrid * 2.0 - 1.0 + xOffset + uCircle*0.05;\n\tfloat vy = vGrid * 2.0 - 1.0 + yOffset + vCircle*0.05;\n \n\tvec2 xy = vec2(ux, vy) * 0.8;\n \n\tgl_Position = vec4(xy, 0.0, 1.0);\n\tgl_PointSize = 5.0;\n\tv_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-h9z89ludv5oki86cn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A6KXiR6FwZEbN6Nh5/art.json b/art/A6KXiR6FwZEbN6Nh5/art.json index a6083fab..7d9dd3e4 100644 --- a/art/A6KXiR6FwZEbN6Nh5/art.json +++ b/art/A6KXiR6FwZEbN6Nh5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "ilyadorosh", "avatarUrl": "https://avatars.githubusercontent.com/ilyadorosh?s=200", - "settings": "{\"num\":22957,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec3 inv(vec3 a){return 1.-a;}\\n\\nvoid main() {\\n\\n float width = 40.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.2;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n //* length(mouse.x)\\n \\n float ux = u *1.3 - 1.0 + xOffset ;\\n float uy = v * 2.0 - 1.0 + mouse.y;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n float a = 1.-20.*vertexId /vertexCount;\\n \\n vec3 color = vec3(a, -a, abs(a));\\n color = inv(color); \\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(color, 1.0);\\n gl_PointSize = 40.0;\\n}\"}", + "settings": { + "num": 22957, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec3 inv(vec3 a){return 1.-a;}\n\nvoid main() {\n\n float width = 40.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.2;\n float yOffset = sin(time + x * 0.3) * 0.1;\n //* length(mouse.x)\n \n float ux = u *1.3 - 1.0 + xOffset ;\n float uy = v * 2.0 - 1.0 + mouse.y;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n float a = 1.-20.*vertexId /vertexCount;\n \n vec3 color = vec3(a, -a, abs(a));\n color = inv(color); \n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(color, 1.0);\n gl_PointSize = 40.0;\n}" + }, "screenshotURL": "data/images/images-kceokoahu4az3kspb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/A6iuFb7Tmao4i5avw/art.json b/art/A6iuFb7Tmao4i5avw/art.json index 39121748..472cea55 100644 --- a/art/A6iuFb7Tmao4i5avw/art.json +++ b/art/A6iuFb7Tmao4i5avw/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/sunrizer-mantra\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n float v = vertexId;\\n //float sndFactor = texture2D(sound, vec2(;\\n float off = .1;\\n \\n float spiral = 1. - 1.7 * vertexId / (vertexCount+vertexCount);\\n float scale = 1.;\\n float grid = floor(vertexCount / 1000.);\\n float sndFactor = texture2D(sound, vec2(mod(v, 20.), 0)).a;\\n\\n \\n float x = sin(v / 100. + sndFactor) * spiral;\\n float y = cos(v / 100.) * spiral;\\n \\n float ux = x * scale - off;\\n float uy = y * scale - off;\\n \\n gl_Position =vec4(ux, uy, 0, 1);\\n gl_PointSize = 5. ;// grid;\\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\\n v_color = vec4(sin(spiral * 5. +time), 0.1, 0.5, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/sunrizer-mantra", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n float v = vertexId;\n //float sndFactor = texture2D(sound, vec2(;\n float off = .1;\n \n float spiral = 1. - 1.7 * vertexId / (vertexCount+vertexCount);\n float scale = 1.;\n float grid = floor(vertexCount / 1000.);\n float sndFactor = texture2D(sound, vec2(mod(v, 20.), 0)).a;\n\n \n float x = sin(v / 100. + sndFactor) * spiral;\n float y = cos(v / 100.) * spiral;\n \n float ux = x * scale - off;\n float uy = y * scale - off;\n \n gl_Position =vec4(ux, uy, 0, 1);\n gl_PointSize = 5. ;// grid;\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\n v_color = vec4(sin(spiral * 5. +time), 0.1, 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-3tce7mo4qqdazdt98-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A8L4hRRwF6WbC5Jxb/art.json b/art/A8L4hRRwF6WbC5Jxb/art.json index 40af9e99..f3c94b35 100644 --- a/art/A8L4hRRwF6WbC5Jxb/art.json +++ b/art/A8L4hRRwF6WbC5Jxb/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jonaced", "avatarUrl": "https://secure.gravatar.com/avatar/4afc7bbaa73d3ae5795519659259854b?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"mat4 rotX(float divTime) {\\n float seno = sin(time / divTime);\\n float coseno = cos(time / divTime);\\n mat4 rotX = mat4(\\n 1.0,\\t0.0,\\t0.0,\\t0.0,\\n 0.0,\\tcoseno,\\t-seno,\\t0.0,\\n 0.0,\\tseno,\\tcoseno,\\t0.0,\\n 0.0,\\t0.0,\\t0.0,\\t1.0);\\n return rotX;\\n}\\n\\nmat4 rotY(float divTime) {\\n float seno = sin(time / divTime);\\n float coseno = cos(time / divTime);\\n mat4 rotX = mat4(\\n coseno,\\t0.0,\\tseno,\\t0.0,\\n 0.0,\\t1.0,\\t0.0,\\t0.0,\\n -seno,\\t0.0,\\tcoseno,\\t0.0,\\n 0.0,\\t0.0,\\t0.0,\\t1.0);\\n return rotX;\\n}\\n\\nmat4 rotZ(float divTime) {\\n float seno = sin(time / divTime);\\n float coseno = cos(time / divTime);\\n mat4 rotZ = mat4(\\n coseno,\\t-seno,\\t0.0, \\t0.0,\\n seno,\\tcoseno,\\t0.0, \\t0.0,\\n 0.0,\\t0.0,\\t1.0, \\t0.0,\\n 0.0,\\t0.0,\\t0.0, \\t1.0);\\n return rotZ;\\n}\\n\\n\\nvoid main() {\\n float pRara = 0.85;\\n float tridenteRaro = radians(floor(vertexId / 180.0)) * 2.0;\\n float ceroCortado = radians(mod(vertexId, 360.0)) * 2.0;\\n float x = pRara * sin(tridenteRaro) * cos(ceroCortado);\\n float y = pRara * sin(tridenteRaro) * sin(ceroCortado);\\n float z = pRara * cos(tridenteRaro) ;\\n vec4 pos = vec4(x, y, z, 1.0);\\n pos = rotX(8.0) * rotY(6.0) * rotZ(4.0) * pos;\\n gl_Position = pos;\\n v_color = vec4(0, 0, 0, 1);\\n v_color = vec4(0.0, 0.5, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "mat4 rotX(float divTime) {\n float seno = sin(time / divTime);\n float coseno = cos(time / divTime);\n mat4 rotX = mat4(\n 1.0,\t0.0,\t0.0,\t0.0,\n 0.0,\tcoseno,\t-seno,\t0.0,\n 0.0,\tseno,\tcoseno,\t0.0,\n 0.0,\t0.0,\t0.0,\t1.0);\n return rotX;\n}\n\nmat4 rotY(float divTime) {\n float seno = sin(time / divTime);\n float coseno = cos(time / divTime);\n mat4 rotX = mat4(\n coseno,\t0.0,\tseno,\t0.0,\n 0.0,\t1.0,\t0.0,\t0.0,\n -seno,\t0.0,\tcoseno,\t0.0,\n 0.0,\t0.0,\t0.0,\t1.0);\n return rotX;\n}\n\nmat4 rotZ(float divTime) {\n float seno = sin(time / divTime);\n float coseno = cos(time / divTime);\n mat4 rotZ = mat4(\n coseno,\t-seno,\t0.0, \t0.0,\n seno,\tcoseno,\t0.0, \t0.0,\n 0.0,\t0.0,\t1.0, \t0.0,\n 0.0,\t0.0,\t0.0, \t1.0);\n return rotZ;\n}\n\n\nvoid main() {\n float pRara = 0.85;\n float tridenteRaro = radians(floor(vertexId / 180.0)) * 2.0;\n float ceroCortado = radians(mod(vertexId, 360.0)) * 2.0;\n float x = pRara * sin(tridenteRaro) * cos(ceroCortado);\n float y = pRara * sin(tridenteRaro) * sin(ceroCortado);\n float z = pRara * cos(tridenteRaro) ;\n vec4 pos = vec4(x, y, z, 1.0);\n pos = rotX(8.0) * rotY(6.0) * rotZ(4.0) * pos;\n gl_Position = pos;\n v_color = vec4(0, 0, 0, 1);\n v_color = vec4(0.0, 0.5, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-uiihi6g7840fvkftb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/A8Zc7NFQdTdeKQimv/art.json b/art/A8Zc7NFQdTdeKQimv/art.json index 22863d28..6e464b90 100644 --- a/art/A8Zc7NFQdTdeKQimv/art.json +++ b/art/A8Zc7NFQdTdeKQimv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":97200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) / around * PI * 2.)\\n );\\n \\n float tm = time * 1.1;\\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.5, 2.5, pow(s + .15, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float odd = mod(floor(quadId / 2.), 2.);\\n float hue = time * .1 +s * .15;\\n float sat = mix(0., 3., pow(s, 5.));\\n float val = mix(0.1, 1., pow(s + .4, 15.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 97200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) / around * PI * 2.)\n );\n \n float tm = time * 1.1;\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.5, 2.5, pow(s + .15, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float odd = mod(floor(quadId / 2.), 2.);\n float hue = time * .1 +s * .15;\n float sat = mix(0., 3., pow(s, 5.));\n float val = mix(0.1, 1., pow(s + .4, 15.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-dscqkvp0vbpyv74mf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A9DLn3oYKaSRGEPt4/art.json b/art/A9DLn3oYKaSRGEPt4/art.json index b6c3c5ae..fbb83146 100644 --- a/art/A9DLn3oYKaSRGEPt4/art.json +++ b/art/A9DLn3oYKaSRGEPt4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":95182,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/uheplugins/bora\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.592156862745098,0.8980392156862745,0.7372549019607844,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 100.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float pointV = point / NUM_SEGMENTS;\\n float circleId = floor(vertexId / NUM_POINTS);\\n float numCircles = floor(vertexCount / NUM_POINTS);\\n float circleV = circleId / numCircles;\\n \\n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\\n \\n float angle = pointV * PI * 2.0 +snd*5.;\\n float c = cos(angle) * mix(0.1, 1., circleV);\\n float s = sin(angle) * mix(0.25, 0.5, circleV);\\n \\n float r = mix(0., PI, circleV) + pow(snd, 5.0);\\n float rc = cos(r + sin(time * 4. + circleV * 4.));\\n float rs = sin(r + sin(time * 4. + circleV * 4.));\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\\n vec2 xy = vec2(\\n rc * c + rs * s,\\n -rs * c + rc * s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n float b = 1.0;\\n v_color.a = 1.;\\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\\n \\n gl_PointSize = 4.0;\\n gl_PointSize *= resolution.x / 1600.0;\\n}\"}", + "settings": { + "num": 95182, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/uheplugins/bora", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.592156862745098, + 0.8980392156862745, + 0.7372549019607844, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 100.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float pointV = point / NUM_SEGMENTS;\n float circleId = floor(vertexId / NUM_POINTS);\n float numCircles = floor(vertexCount / NUM_POINTS);\n float circleV = circleId / numCircles;\n \n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\n \n float angle = pointV * PI * 2.0 +snd*5.;\n float c = cos(angle) * mix(0.1, 1., circleV);\n float s = sin(angle) * mix(0.25, 0.5, circleV);\n \n float r = mix(0., PI, circleV) + pow(snd, 5.0);\n float rc = cos(r + sin(time * 4. + circleV * 4.));\n float rs = sin(r + sin(time * 4. + circleV * 4.));\n \n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\n vec2 xy = vec2(\n rc * c + rs * s,\n -rs * c + rc * s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n float b = 1.0;\n v_color.a = 1.;\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\n \n gl_PointSize = 4.0;\n gl_PointSize *= resolution.x / 1600.0;\n}" + }, "screenshotURL": "data/images/images-xh384v4zhbezzra79-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/A9X62RRorFW5Ys8h7/art.json b/art/A9X62RRorFW5Ys8h7/art.json index 2695a791..d36350d9 100644 --- a/art/A9X62RRorFW5Ys8h7/art.json +++ b/art/A9X62RRorFW5Ys8h7/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "marcoisaac", "avatarUrl": "https://lh6.googleusercontent.com/-jsbJZMoV7aw/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rczbGrsWSlymdrCUasJ8WzEUV3Ptg/mo/photo.jpg", - "settings": "{\"num\":2638,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec2 drawCircleXY(float id);\\n\\nvoid main()\\n{\\n \\n float circleCount = floor(vertexCount / 360.0);\\n float circleId = floor(vertexId / 120.0);\\n \\n float sqrTotal = floor(sqrt(circleCount));\\n float width = sqrTotal;\\n \\n float x = mod(circleId, width); // [0, width - 1]\\n float y = floor(circleId / width); // [0, inf]\\n\\n \\n float angle = x / 20.0 * radians(180.0) * 2.0 ;\\n float radius = y + 1.0;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n \\n float xOffset = cos(time * 2.0) * 0.2 ;\\n float yOffset = cos(time * 3.0) * 1.0 ;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy)* 0.4;\\n //vec2 xyy = vec2(ux, vy);\\n\\n gl_Position = vec4(xy + (drawCircleXY(vertexId) * 0.05) , 0.0, 1.0);\\n \\n gl_PointSize = 15.0 ;\\n gl_PointSize *= 32.0 / width;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n}\\n\\n\\n\\nvec2 drawCircleXY(float id)\\n{\\n \\n float x = floor(id / 6.0) + mod(id, 2.0);\\n float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = x / 20.0 * radians(180.0) * 2.0 ;\\n float radius = y + 1.0;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n vec2 xy = vec2(u, v);\\n \\n return xy;\\n}\"}", + "settings": { + "num": 2638, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec2 drawCircleXY(float id);\n\nvoid main()\n{\n \n float circleCount = floor(vertexCount / 360.0);\n float circleId = floor(vertexId / 120.0);\n \n float sqrTotal = floor(sqrt(circleCount));\n float width = sqrTotal;\n \n float x = mod(circleId, width); // [0, width - 1]\n float y = floor(circleId / width); // [0, inf]\n\n \n float angle = x / 20.0 * radians(180.0) * 2.0 ;\n float radius = y + 1.0;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n \n float xOffset = cos(time * 2.0) * 0.2 ;\n float yOffset = cos(time * 3.0) * 1.0 ;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy)* 0.4;\n //vec2 xyy = vec2(ux, vy);\n\n gl_Position = vec4(xy + (drawCircleXY(vertexId) * 0.05) , 0.0, 1.0);\n \n gl_PointSize = 15.0 ;\n gl_PointSize *= 32.0 / width;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n}\n\n\n\nvec2 drawCircleXY(float id)\n{\n \n float x = floor(id / 6.0) + mod(id, 2.0);\n float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = x / 20.0 * radians(180.0) * 2.0 ;\n float radius = y + 1.0;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n vec2 xy = vec2(u, v);\n \n return xy;\n}" + }, "screenshotURL": "data/images/images-bmemxdi48zakxhobr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/AA2EgkaRKHJ5g74i5/art.json b/art/AA2EgkaRKHJ5g74i5/art.json index 51fc3018..9a1fcfa3 100644 --- a/art/AA2EgkaRKHJ5g74i5/art.json +++ b/art/AA2EgkaRKHJ5g74i5/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "isaín", "avatarUrl": "https://lh6.googleusercontent.com/-PShsQ2rITQc/AAAAAAAAAAI/AAAAAAAAARc/ffHK8TazFeI/photo.jpg", - "settings": "{\"num\":4608,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8392156862745098,0.9450980392156862,1,1],\"shader\":\"void main(){\\n float pi = 3.14159;\\n \\n float y = mod(vertexId,2.0);\\n float x = floor(vertexId/2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n \\n float r = 2.0 - y;\\n \\n x = r*cos(angle);\\n y = r*sin(angle);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(sin(time*x), cos(time*y), cos(x*y), 1.0);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 4608, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8392156862745098, + 0.9450980392156862, + 1, + 1 + ], + "shader": "void main(){\n float pi = 3.14159;\n \n float y = mod(vertexId,2.0);\n float x = floor(vertexId/2.0);\n \n float angle = x / 20.0 * radians(360.0);\n \n float r = 2.0 - y;\n \n x = r*cos(angle);\n y = r*sin(angle);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(sin(time*x), cos(time*y), cos(x*y), 1.0);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-p16pjni8su7pyodk0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ABszkWtBmfrqcHecz/art.json b/art/ABszkWtBmfrqcHecz/art.json index 6b24bacd..5897d809 100644 --- a/art/ABszkWtBmfrqcHecz/art.json +++ b/art/ABszkWtBmfrqcHecz/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9764705882352941,1,0.8980392156862745,1],\"shader\":\"/* \\n \\n .___ __ . \\n [__ . , _ ._ / `|_ _ ._ \\n [___ \\\\/ (/,[ )____\\\\__.[ )(/,[ ) \\n \\n . . , .__ . \\n | * _ |_ -+- *._ [__)*\\\\./ _ | \\n |___|(_][ ) | |[ ) | |/'\\\\(/,| \\n ._| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n20/12/2019\\n\\n*/ \\n//Best Regard, @gman \\n\\n#define PI radians(180.)\\n\\n\\nmat4 mAspect = mat4\\n(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n); \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid main ()\\n{\\n float pointsPerSphere = vertexCount;\\n float pointsPerLoop = 1.;\\n float sphereId = floor(vertexId / pointsPerSphere);\\n float spherePointId = mod(vertexId, pointsPerSphere);\\n float aspectR = resolution.x / resolution.y ; \\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 20.); \\n vec3 camera = vec3(0., 0., 1);\\n vec3 target = vec3(0.);\\n vec3 up = vec3(0.,1.,0.);\\n \\n float radius = 0.5 ; \\n \\n #pragma region ViewMatrix\\n //camera \\n float animTime = time;\\n float orbitAngle = animTime * 0.3456 + 4.0;\\n float elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n float fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n\\n vec3 vCameraTarget = target;\\n\\n vec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle),\\n sin(elevation),\\n 1.);\\n vec3 vCameraUp = vec3( 0., 1., 0. );\\n vec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n\\n \\tm*= cameraLookAt(vCameraPos , vCameraTarget , normalize(vCameraUp));\\n\\n #pragma endregion \\n \\n \\n #pragma region modelSetup \\n m*= uniformScale(0.7);\\n #pragma endregion \\n \\n #pragma region CubeSetUp\\n float yPos = cos(spherePointId / pointsPerSphere * PI) * radius;\\n float xyLen = sin(spherePointId / pointsPerSphere * PI) * radius; \\n float xPos = sin(spherePointId ) * xyLen;\\n float zPos = cos(spherePointId ) * xyLen;\\n\\n vec4 pos = vec4(xPos, yPos, zPos, 1) + vec4(target, 0.);\\n vec3 objectC = vec3(0. , 0. , 0.); \\n #pragma endregion\\n \\n vec3 normal = normalize(vec3(xPos , yPos , zPos));\\n float lZoffSet = ((abs(mouse.x * aspectR) > radius) && (abs(mouse.y * aspectR) > radius))? 1. : 0. ; \\n \\n vec3 lightP = vec3(10. , 10. ,10.+ pos.z); \\n vec3 lightC = vec3(1.0) ; \\n \\n float aStrength = 0.1 ; \\n vec3 ambient = lightC * aStrength ; \\n float dStrength = 1.; \\n \\n vec3 l2SD = normalize(lightP - vec3(pos)) ; \\n float diff = max(dot(normal , l2SD) , 0. ); \\n vec3 diffuse = dStrength* diff * lightC; \\n \\n float sStrength = 0.001 ; \\n vec3 viewP = vec3(1.) ;\\n vec3 viewD = normalize(viewP - vec3(pos));\\n vec3 refDir = reflect(-l2SD , normal);\\n float spec = pow(max(dot(refDir , viewP) , 0.), 10.);\\n vec3 specular = spec * sStrength * lightC ; \\n \\n\\n vec3 resultC = vec3(1.) ; \\n resultC = ambient + diffuse + specular; \\n \\n gl_Position = m * pos ; ; \\n gl_PointSize *= (vec4(1.0 , 0., 0., 0.)* uniformScale(10.)).x ; \\n \\n v_color = vec4(objectC + resultC , 1. ) ; \\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9764705882352941, + 1, + 0.8980392156862745, + 1 + ], + "shader": "/* \n \n .___ __ . \n [__ . , _ ._ / `|_ _ ._ \n [___ \\/ (/,[ )____\\__.[ )(/,[ ) \n \n . . , .__ . \n | * _ |_ -+- *._ [__)*\\./ _ | \n |___|(_][ ) | |[ ) | |/'\\(/,| \n ._| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n20/12/2019\n\n*/ \n//Best Regard, @gman \n\n#define PI radians(180.)\n\n\nmat4 mAspect = mat4\n(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n); \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid main ()\n{\n float pointsPerSphere = vertexCount;\n float pointsPerLoop = 1.;\n float sphereId = floor(vertexId / pointsPerSphere);\n float spherePointId = mod(vertexId, pointsPerSphere);\n float aspectR = resolution.x / resolution.y ; \n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 20.); \n vec3 camera = vec3(0., 0., 1);\n vec3 target = vec3(0.);\n vec3 up = vec3(0.,1.,0.);\n \n float radius = 0.5 ; \n \n #pragma region ViewMatrix\n //camera \n float animTime = time;\n float orbitAngle = animTime * 0.3456 + 4.0;\n float elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n float fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n\n vec3 vCameraTarget = target;\n\n vec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle),\n sin(elevation),\n 1.);\n vec3 vCameraUp = vec3( 0., 1., 0. );\n vec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n\n \tm*= cameraLookAt(vCameraPos , vCameraTarget , normalize(vCameraUp));\n\n #pragma endregion \n \n \n #pragma region modelSetup \n m*= uniformScale(0.7);\n #pragma endregion \n \n #pragma region CubeSetUp\n float yPos = cos(spherePointId / pointsPerSphere * PI) * radius;\n float xyLen = sin(spherePointId / pointsPerSphere * PI) * radius; \n float xPos = sin(spherePointId ) * xyLen;\n float zPos = cos(spherePointId ) * xyLen;\n\n vec4 pos = vec4(xPos, yPos, zPos, 1) + vec4(target, 0.);\n vec3 objectC = vec3(0. , 0. , 0.); \n #pragma endregion\n \n vec3 normal = normalize(vec3(xPos , yPos , zPos));\n float lZoffSet = ((abs(mouse.x * aspectR) > radius) && (abs(mouse.y * aspectR) > radius))? 1. : 0. ; \n \n vec3 lightP = vec3(10. , 10. ,10.+ pos.z); \n vec3 lightC = vec3(1.0) ; \n \n float aStrength = 0.1 ; \n vec3 ambient = lightC * aStrength ; \n float dStrength = 1.; \n \n vec3 l2SD = normalize(lightP - vec3(pos)) ; \n float diff = max(dot(normal , l2SD) , 0. ); \n vec3 diffuse = dStrength* diff * lightC; \n \n float sStrength = 0.001 ; \n vec3 viewP = vec3(1.) ;\n vec3 viewD = normalize(viewP - vec3(pos));\n vec3 refDir = reflect(-l2SD , normal);\n float spec = pow(max(dot(refDir , viewP) , 0.), 10.);\n vec3 specular = spec * sStrength * lightC ; \n \n\n vec3 resultC = vec3(1.) ; \n resultC = ambient + diffuse + specular; \n \n gl_Position = m * pos ; ; \n gl_PointSize *= (vec4(1.0 , 0., 0., 0.)* uniformScale(10.)).x ; \n \n v_color = vec4(objectC + resultC , 1. ) ; \n \n}" + }, "screenshotURL": "data/images/images-apjt23vk7540lp76i-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/AC57qxXZiP5Xt3MPo/art.json b/art/AC57qxXZiP5Xt3MPo/art.json index 0ae0385e..c77d5d3a 100644 --- a/art/AC57qxXZiP5Xt3MPo/art.json +++ b/art/AC57qxXZiP5Xt3MPo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n //float density = 2.;\\n float density = floor(vertexCount / 1000.) + 1.;\\n \\n //float xoff = -0.5* (density / 20.);\\n //float yoff = -0.5 * (density / 20.);\\n \\n float xoff = -1. * (density / 50.);\\n float yoff = -1. * (density / 50.);\\n float ux = 0.1 * (20. / density);\\n float uy = 0.1 * (20. / density);\\n float x = mod(vertexId , density);\\n float y = mod(floor(vertexId / density), density);\\n \\n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n //gl_PointSize = mod(vertexId, density * density) / 5.;\\n gl_PointSize = 200. / density;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n //float density = 2.;\n float density = floor(vertexCount / 1000.) + 1.;\n \n //float xoff = -0.5* (density / 20.);\n //float yoff = -0.5 * (density / 20.);\n \n float xoff = -1. * (density / 50.);\n float yoff = -1. * (density / 50.);\n float ux = 0.1 * (20. / density);\n float uy = 0.1 * (20. / density);\n float x = mod(vertexId , density);\n float y = mod(floor(vertexId / density), density);\n \n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n //gl_PointSize = mod(vertexId, density * density) / 5.;\n gl_PointSize = 200. / density;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-qhpv2y82xr67layx0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/AGytkw7djFKBPNKZE/art.json b/art/AGytkw7djFKBPNKZE/art.json index 12d375cd..75fc159c 100644 --- a/art/AGytkw7djFKBPNKZE/art.json +++ b/art/AGytkw7djFKBPNKZE/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "unnamed", "username": "-anon-", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 10.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 10.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "ZWGwTmTqyW4P5mnLc", "views": { "$numberInt": "90" diff --git a/art/AHgb5kGbLwEYQjRTn/art.json b/art/AHgb5kGbLwEYQjRTn/art.json index de241865..f3e9e587 100644 --- a/art/AHgb5kGbLwEYQjRTn/art.json +++ b/art/AHgb5kGbLwEYQjRTn/art.json @@ -22,7 +22,19 @@ "origId": null, "name": "rings_1", "username": "mark", - "settings": "{\"num\":15000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/nicolasgodinmusic/bachoff\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n\\nvoid main () {\\n \\n float i = vertexId / 2.0;\\n if (mod(vertexId, 2.0) > 0.) {\\n float snd = texture2D(sound, vec2(i * 1e-4, 0.)).a;\\n\\n float ang = mod(1e-3 * i, 3.14159 * 2.) + time * .3;\\n float rad = .7 * sin(i + time) * snd;\\n\\n float x = rad * cos(ang);\\n float y = rad * sin(ang);\\n \\n gl_Position = vec4(x, y, 0, 1);\\n \\n float r, g, b;\\n \\n r = .01 + snd * mod(i, 2.) * .8;\\n g = .01 + snd * .8;\\n b = .01 + snd * sin(time * 1e-3) * .8;\\n \\n \\tv_color = vec4(r, g, b, 1);\\n } else { \\n float snd = texture2D(sound, vec2(1./20., 0.)).a;\\n float ring = mod(i, 10.);\\n \\n float rad = 1. - .5 * ring * .05 * sin(time * 5. * i) * snd;\\n float ang = mod(1e-3 * i, 3.14159 * 2.);\\n \\n \\n float x = rad * cos(ang);\\n float y = rad * sin(ang);\\n \\n float g = sin(ang) * snd;\\n float b = snd * .05;\\n \\n gl_Position = vec4(x, y, 0, 1);\\n v_color = vec4(.1, g, b, 1);\\n }\\n}\"}", + "settings": { + "num": 15000, + "mode": "POINTS", + "sound": "https://soundcloud.com/nicolasgodinmusic/bachoff", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n\nvoid main () {\n \n float i = vertexId / 2.0;\n if (mod(vertexId, 2.0) > 0.) {\n float snd = texture2D(sound, vec2(i * 1e-4, 0.)).a;\n\n float ang = mod(1e-3 * i, 3.14159 * 2.) + time * .3;\n float rad = .7 * sin(i + time) * snd;\n\n float x = rad * cos(ang);\n float y = rad * sin(ang);\n \n gl_Position = vec4(x, y, 0, 1);\n \n float r, g, b;\n \n r = .01 + snd * mod(i, 2.) * .8;\n g = .01 + snd * .8;\n b = .01 + snd * sin(time * 1e-3) * .8;\n \n \tv_color = vec4(r, g, b, 1);\n } else { \n float snd = texture2D(sound, vec2(1./20., 0.)).a;\n float ring = mod(i, 10.);\n \n float rad = 1. - .5 * ring * .05 * sin(time * 5. * i) * snd;\n float ang = mod(1e-3 * i, 3.14159 * 2.);\n \n \n float x = rad * cos(ang);\n float y = rad * sin(ang);\n \n float g = sin(ang) * snd;\n float b = snd * .05;\n \n gl_Position = vec4(x, y, 0, 1);\n v_color = vec4(.1, g, b, 1);\n }\n}" + }, "screenshotURL": "data/images/images-c34clv5phyill6115-thumbnail.jpg", "views": { "$numberInt": "99" diff --git a/art/AJ3iLGfbPGRTnZZn6/art.json b/art/AJ3iLGfbPGRTnZZn6/art.json index 43a902d3..5e477483 100644 --- a/art/AJ3iLGfbPGRTnZZn6/art.json +++ b/art/AJ3iLGfbPGRTnZZn6/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":99647,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/qumumusic/super-mario-galaxy-gusty-garden-galaxy-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec2 rotate(vec2 point, float degree, vec2 pivot)\\n{\\n float radAngle = -radians(degree);// \\\"-\\\" - clockwise\\n float x = point.x;\\n float y = point.y;\\n\\n float rX = pivot.x + (x - pivot.x) * cos(radAngle) - (y - pivot.y) * sin(radAngle);\\n float rY = pivot.y + (x - pivot.x) * sin(radAngle) + (y - pivot.y) * cos(radAngle);\\n\\n return vec2(rX, rY);\\n}\\n\\nvoid pond() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.; // center u and create symmetry;\\n float sv = v;//abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .250, av * .25)).a; // Only using parts of the spectrum and 1 second of data.\\n \\n float x_offset = 0.; // sin(time + y * 0.01) * .4;\\n float y_offset = 0.; // sin(time + x * 0.01) * .1;\\n \\n float ux = u * 2. - 1. + x_offset;\\n float vy = v * 2. - 1. + y_offset;\\n \\n \\n vec2 xy = rotate(vec2(ux, vy) * 0.6, time * snd, vec2(0, 0));\\n \\n gl_Position = vec4(xy, 0, 1); \\n \\n\\n \\n float s_offset = 0.; // sin(time + x * y * 0.03) * 2.;\\n \\n \\n gl_PointSize = snd * 10.0 + s_offset;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float hue = abs(sin(snd)*1.);\\n float sat = 1.;\\n float val = pow(snd + 0.3, 5.0);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); \\n}\\n\\n\\nvoid main() {\\n pond();\\n}\"}", + "settings": { + "num": 99647, + "mode": "POINTS", + "sound": "https://soundcloud.com/qumumusic/super-mario-galaxy-gusty-garden-galaxy-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec2 rotate(vec2 point, float degree, vec2 pivot)\n{\n float radAngle = -radians(degree);// \"-\" - clockwise\n float x = point.x;\n float y = point.y;\n\n float rX = pivot.x + (x - pivot.x) * cos(radAngle) - (y - pivot.y) * sin(radAngle);\n float rY = pivot.y + (x - pivot.x) * sin(radAngle) + (y - pivot.y) * cos(radAngle);\n\n return vec2(rX, rY);\n}\n\nvoid pond() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.; // center u and create symmetry;\n float sv = v;//abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .250, av * .25)).a; // Only using parts of the spectrum and 1 second of data.\n \n float x_offset = 0.; // sin(time + y * 0.01) * .4;\n float y_offset = 0.; // sin(time + x * 0.01) * .1;\n \n float ux = u * 2. - 1. + x_offset;\n float vy = v * 2. - 1. + y_offset;\n \n \n vec2 xy = rotate(vec2(ux, vy) * 0.6, time * snd, vec2(0, 0));\n \n gl_Position = vec4(xy, 0, 1); \n \n\n \n float s_offset = 0.; // sin(time + x * y * 0.03) * 2.;\n \n \n gl_PointSize = snd * 10.0 + s_offset;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float hue = abs(sin(snd)*1.);\n float sat = 1.;\n float val = pow(snd + 0.3, 5.0);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); \n}\n\n\nvoid main() {\n pond();\n}" + }, "screenshotURL": "data/images/images-6b7gooaa9elc8ervf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/AK7yLDZv8JXbgW25h/art.json b/art/AK7yLDZv8JXbgW25h/art.json index a4904120..fc25fb7a 100644 --- a/art/AK7yLDZv8JXbgW25h/art.json +++ b/art/AK7yLDZv8JXbgW25h/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/powerglove/telecom\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// bleep bloop\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float numShapes = vertexCount / NUM_POINTS;\\n float cv = count / numShapes;\\n float offset = count * 0.02;\\n float ev = point / NUM_SEGMENTS;\\n float angle = ev * PI * 2.0 + offset * 0.1;\\n float radius = 0.2;\\n float c = cos(angle + time * 0.11) * radius;\\n float s = sin(angle + time * 0.11) * radius;\\n float orbitAngle = count * 0.01;\\n \\n float snd = texture2D(sound, vec2(ev * 0.1, cv * .1)).x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\\n\\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\\n vec2 xy = vec2(\\n c,\\n s);\\n gl_Position = vec4(xy * aspect * scale, 0, 1);\\n\\n float hue = cv * 0.2;\\n float unf = step(0.8, snd);\\n v_color = vec4(hsv2rgb(vec3(ev * 0.1 + 0.95, unf, unf)), unf);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/powerglove/telecom", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// bleep bloop\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float numShapes = vertexCount / NUM_POINTS;\n float cv = count / numShapes;\n float offset = count * 0.02;\n float ev = point / NUM_SEGMENTS;\n float angle = ev * PI * 2.0 + offset * 0.1;\n float radius = 0.2;\n float c = cos(angle + time * 0.11) * radius;\n float s = sin(angle + time * 0.11) * radius;\n float orbitAngle = count * 0.01;\n \n float snd = texture2D(sound, vec2(ev * 0.1, cv * .1)).x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\n\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\n vec2 xy = vec2(\n c,\n s);\n gl_Position = vec4(xy * aspect * scale, 0, 1);\n\n float hue = cv * 0.2;\n float unf = step(0.8, snd);\n v_color = vec4(hsv2rgb(vec3(ev * 0.1 + 0.95, unf, unf)), unf);\n}" + }, "screenshotURL": "data/images/images-2lea08o7mwykito11-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ALErfYvkmdWzuqg7M/art.json b/art/ALErfYvkmdWzuqg7M/art.json index 229961cc..c70f1932 100644 --- a/art/ALErfYvkmdWzuqg7M/art.json +++ b/art/ALErfYvkmdWzuqg7M/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1283,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n \\n float Pos = vertexId/vertexCount;\\n\\n gl_Position = vec4(Pos, 0, 0.5,0.5);\\n\\n \\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 1283, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n \n float Pos = vertexId/vertexCount;\n\n gl_Position = vec4(Pos, 0, 0.5,0.5);\n\n \n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-1zie0rskjasq8mekq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/AMJYWSdCtDDTehM3C/art.json b/art/AMJYWSdCtDDTehM3C/art.json index 8fdc2a27..79df02f8 100644 --- a/art/AMJYWSdCtDDTehM3C/art.json +++ b/art/AMJYWSdCtDDTehM3C/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// seongryul.park\\n// CS250 spring 2023\\n// Making A Grid\\n\\n\\nvoid main() \\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// seongryul.park\n// CS250 spring 2023\n// Making A Grid\n\n\nvoid main() \n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-aireatrhto76o1zhz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ARpkYYdzGDtKL4BZn/art.json b/art/ARpkYYdzGDtKL4BZn/art.json index 477a1a4f..f8be66e1 100644 --- a/art/ARpkYYdzGDtKL4BZn/art.json +++ b/art/ARpkYYdzGDtKL4BZn/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":36069,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.12156862745098039,0.12156862745098039,0.12156862745098039,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n cos(t/i-16.9553) +\\n sin(t*1.311*i) +\\n sin(t*1.4+i*16.53) +\\n cos(t*1.84+sin(i*1.76)),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311/12.1) +\\n sin(t*1.4+i*1.353/2.1) /\\n tan(t*1.84+i*.476* 12.1),\\n sin(t/i*.5553-2.1)*\\n cos(t/2.3-i*1.1-32.1) +\\n sin(t-3.4*t-1.23+2.1) -\\n sin(t*cos(.88-i*12.0)*t)\\n\\t)*1.002;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)-3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*3.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)-ofs;\\n \\n vec3 posf = fract(pos-0.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(9.4-smoothstep(lerpEnd, 11.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.020;\\n float i = vertexId+sin(vertexId)-120.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 1.6; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.001));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,1.8);\\n pos.xz *= mat2(.8,.6,10.6, mouse.x* 111.8);\\n \\n pos *= 0.8;\\n \\n\\n pos.z += .37;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 0.1/pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs)*mouse.y/6.,1e-9))- 2.01- 0.7,0.03);\\n}\"}", + "settings": { + "num": 36069, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "CSS", + "backgroundColor": [ + 0.12156862745098039, + 0.12156862745098039, + 0.12156862745098039, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n cos(t/i-16.9553) +\n sin(t*1.311*i) +\n sin(t*1.4+i*16.53) +\n cos(t*1.84+sin(i*1.76)),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311/12.1) +\n sin(t*1.4+i*1.353/2.1) /\n tan(t*1.84+i*.476* 12.1),\n sin(t/i*.5553-2.1)*\n cos(t/2.3-i*1.1-32.1) +\n sin(t-3.4*t-1.23+2.1) -\n sin(t*cos(.88-i*12.0)*t)\n\t)*1.002;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)-3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*3.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)-ofs;\n \n vec3 posf = fract(pos-0.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(9.4-smoothstep(lerpEnd, 11.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.020;\n float i = vertexId+sin(vertexId)-120.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 1.6; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.001));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,1.8);\n pos.xz *= mat2(.8,.6,10.6, mouse.x* 111.8);\n \n pos *= 0.8;\n \n\n pos.z += .37;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 0.1/pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs)*mouse.y/6.,1e-9))- 2.01- 0.7,0.03);\n}" + }, "screenshotURL": "data/images/images-0w31bted45sqlnvyz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ASwcBa7AR4rPpF2Wg/art.json b/art/ASwcBa7AR4rPpF2Wg/art.json index a775f385..3929d8d4 100644 --- a/art/ASwcBa7AR4rPpF2Wg/art.json +++ b/art/ASwcBa7AR4rPpF2Wg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 8;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.5 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 8;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.5 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\n}\n" + }, "screenshotURL": "data/images/images-x7kta8c90i2oyagvl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/AXAuvTYrFKQwTgykw/art.json b/art/AXAuvTYrFKQwTgykw/art.json index da267dce..4ac24d6e 100644 --- a/art/AXAuvTYrFKQwTgykw/art.json +++ b/art/AXAuvTYrFKQwTgykw/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":3834,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define PHI_A (3.-sqrt(5.))* PI\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float phi = ((sin(0.08*time)*0.5+0.5)*3./resolution.x-sqrt(5.))* PI;\\n float scale = 0.35; // repeats/extends\\n float size = 0.001; // stretch/squeeze\\n float rad_max = (vertexCount * size);\\n \\n float theta = phi * vertexId;// * PHI_A * vertexId;\\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\\n float snd = texture2D(sound, vec2(fract(theta / 35.0), fract(theta / 80000.0))).a;\\n float radius = sqrt(vertexId * size) + snd*0.1;\\n \\n radius = radius * scale;\\n \\n float xoff = sin(time*0.8) * 0.8;\\n float yoff = sin(time*1.3) * 0.1;\\n gl_Position = vec4(cos(theta) * radius,\\n sin(theta) * radius,\\n 0, 1);\\n float soff = pow(snd + 0.2, 8.);\\n gl_PointSize = (soff + 2.) * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\\n\\n float hue = snd*0.01 + time * 0.1;\\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\\n 1. // change step to 0. (all pass) for no blackening\\n )), pow(snd, 5.));\\n}\"}", + "settings": { + "num": 3834, + "mode": "POINTS", + "sound": "https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define PHI_A (3.-sqrt(5.))* PI\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float phi = ((sin(0.08*time)*0.5+0.5)*3./resolution.x-sqrt(5.))* PI;\n float scale = 0.35; // repeats/extends\n float size = 0.001; // stretch/squeeze\n float rad_max = (vertexCount * size);\n \n float theta = phi * vertexId;// * PHI_A * vertexId;\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\n float snd = texture2D(sound, vec2(fract(theta / 35.0), fract(theta / 80000.0))).a;\n float radius = sqrt(vertexId * size) + snd*0.1;\n \n radius = radius * scale;\n \n float xoff = sin(time*0.8) * 0.8;\n float yoff = sin(time*1.3) * 0.1;\n gl_Position = vec4(cos(theta) * radius,\n sin(theta) * radius,\n 0, 1);\n float soff = pow(snd + 0.2, 8.);\n gl_PointSize = (soff + 2.) * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\n\n float hue = snd*0.01 + time * 0.1;\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\n 1. // change step to 0. (all pass) for no blackening\n )), pow(snd, 5.));\n}" + }, "screenshotURL": "data/images/images-sx4do50fj8hbfutpg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/AXjMauM4Aq37fkzLf/art.json b/art/AXjMauM4Aq37fkzLf/art.json index 2af52423..4300392c 100644 --- a/art/AXjMauM4Aq37fkzLf/art.json +++ b/art/AXjMauM4Aq37fkzLf/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "attila", "avatarUrl": "https://lh5.googleusercontent.com/-x0sWnYltj1w/AAAAAAAAAAI/AAAAAAAAFOw/6xAGpro1JhI/photo.jpg", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 quad(vec3 origin, vec3 center, vec3 tangent, int vert_of_quad) {\\n vec3 bitangent = cross(center, tangent);\\n center += origin;\\n if (vert_of_quad == 0)\\n return center + tangent + bitangent;\\n else if (vert_of_quad == 1)\\n return center + tangent - bitangent;\\n else if (vert_of_quad == 2)\\n return center - tangent + bitangent;\\n else if (vert_of_quad == 3)\\n return center - tangent - bitangent;\\n else if (vert_of_quad == 4)\\n return center + tangent - bitangent;\\n else if (vert_of_quad == 5)\\n return center - tangent + bitangent;\\n return center;\\n}\\n\\nvec3 cube_quad(vec3 center, vec3 tangent, int vert_of_quad) {\\n return quad(vec3(0.0), center, tangent, vert_of_quad);\\n}\\n\\nstruct Quad {\\n vec3 v0, v1, v2, v3;\\n vec3 nor;\\n int mat_id;\\n};\\n \\nvec3 vert_of_quad(Quad q, int vert_of_quad) {\\n if (vert_of_quad == 0)\\n return q.v0;\\n else if (vert_of_quad == 1)\\n return q.v1;\\n else if (vert_of_quad == 2)\\n return q.v2;\\n else if (vert_of_quad == 3)\\n return q.v0;\\n else if (vert_of_quad == 4)\\n return q.v2;\\n else if (vert_of_quad == 5)\\n return q.v3;\\n return q.v0;\\n}\\n\\n \\nvec3 norm_of_quad(Quad q, int vert_of_quad) {\\n return normalize((vert_of_quad < 3)\\n ? cross(q.v0 - q.v1, q.v2 - q.v1)\\n : cross(q.v0 - q.v2, q.v3 - q.v2));\\n}\\n\\n\\nstruct Ring {\\n vec3 s0, s1, s2, s3;\\n vec3 e0, e1, e2, e3;\\n};\\n\\nQuad quad_of_ring(Ring r, int quad_in_ring)\\n{ \\n Quad q;\\n \\n if (quad_in_ring == 0) {\\n q.v0 = r.s0;\\n q.v1 = r.s1;\\n q.v2 = r.e1;\\n q.v3 = r.e0;\\n q.nor = normalize(r.s1 - r.s2);\\n } else if (quad_in_ring == 1) {\\n q.v0 = r.s1;\\n q.v1 = r.s2;\\n q.v2 = r.e2;\\n q.v3 = r.e1;\\n q.nor = normalize(r.s2 - r.s3);\\n } else if (quad_in_ring == 2) {\\n q.v0 = r.s2;\\n q.v1 = r.s3;\\n q.v2 = r.e3;\\n q.v3 = r.e2;\\n q.nor = normalize(r.s3 - r.s0);\\n } else if (quad_in_ring == 3) {\\n q.v0 = r.s3;\\n q.v1 = r.s0;\\n q.v2 = r.e0;\\n q.v3 = r.e3;\\n q.nor = normalize(r.s0 - r.s1);\\n }\\n \\n q.mat_id = quad_in_ring;\\n \\n return q;\\n}\\n\\nstruct Segment {\\n vec3 d0, d1;\\n vec3 p0, p1;\\n vec3 n0, n1;\\n};\\n\\nRing ring_from_segment(Segment s) { \\n vec3 b0 = normalize(cross(s.d0, s.n0)) * 0.5;\\n vec3 b1 = normalize(cross(s.d1, s.n1)) * 0.5;\\n \\n vec3 n0 = normalize(s.n0) * 0.25;\\n vec3 n1 = normalize(s.n1) * 0.25;\\n \\n Ring r;\\n \\n r.s0 = s.p0 + n0 - b0;\\n r.s1 = s.p0 + n0 + b0;\\n r.s2 = s.p0 - n0 + b0;\\n r.s3 = s.p0 - n0 - b0;\\n \\n r.e0 = s.p1 + n1 - b1;\\n r.e1 = s.p1 + n1 + b1;\\n r.e2 = s.p1 - n1 + b1;\\n r.e3 = s.p1 - n1 - b1;\\n \\n return r;\\n}\\n\\nvec3 curve_x_pos(float t) {\\n float alpha = smoothstep(0.3, 0.4, t);\\n float beta = smoothstep(0.3, 0.4, t) - smoothstep(0.5, 0.75, t);\\n \\n float phi = alpha * PI - time;\\n \\n float d = 5.0 * t;\\n \\n float A = alpha * d;\\n \\n float delta_x = -beta * (sin(time/2.0) * 0.5 + 0.5);\\n float delta_y = -beta*2.0 * (-sin(time));\\n float delta_z = -beta*3.0 * sin(time);\\n \\n return vec3(A + delta_x * 2.0, delta_y, delta_z);\\n}\\n\\nvec3 curve_x_nor(float t) {\\n float r = t;//abs(t - 0.5) * 2.0;\\n float angle = 0.0;//-smoothstep(0.3, 0.6, r) * PI;\\n \\n return vec3(sin(angle), 0.0, cos(angle));\\n}\\n\\nvec3 curve_y_pos(float t) {\\n return vec3(0.0);//, -10.0 + 20.0 * t, 0.0);\\n}\\nvec3 curve_y_nor(float t) {\\n return vec3(0.0);//sin(t*10.0), 0.0, cos(t*10.0));\\n}\\n\\nvec3 curve_z_pos(float t) {\\n return vec3(0.0);//, 0.0, -10.0 + 20.0 * t);\\n}\\nvec3 curve_z_nor(float t) {\\n return vec3(sin(t*10.0), cos(t*10.0), 0.0);\\n}\\n\\nSegment segment_x(float t1, float t2) {\\n Segment s;\\n \\n float d = (t2 - t1) * 0.1;\\n \\n s.d0 = curve_x_pos(t1+d) - curve_x_pos(t1-d);\\n s.d1 = curve_x_pos(t2+d) - curve_x_pos(t2-d);\\n \\n s.p0 = curve_x_pos(t1);\\n s.p1 = curve_x_pos(t2);\\n \\n s.n0 = curve_x_nor(t1);\\n s.n1 = curve_x_nor(t2);\\n \\n return s;\\n}\\n\\nSegment segment_y(float t1, float t2) {\\n Segment s;\\n \\n \\n float d = (t2 - t1) * 0.1;\\n \\n s.d0 = curve_y_pos(t1+d) - curve_y_pos(t1-d);\\n s.d1 = curve_y_pos(t2+d) - curve_y_pos(t2-d);\\n \\n s.p0 = curve_y_pos(t1);\\n s.p1 = curve_y_pos(t2);\\n \\n s.n0 = curve_y_nor(t1);\\n s.n1 = curve_y_nor(t2);\\n \\n return s;\\n}\\n\\nSegment segment_z(float t1, float t2) {\\n Segment s;\\n \\n \\n float d = (t2 - t1) * 0.1;\\n \\n s.d0 = curve_z_pos(t1+d) - curve_z_pos(t1-d);\\n s.d1 = curve_z_pos(t2+d) - curve_z_pos(t2-d);\\n \\n s.p0 = curve_z_pos(t1);\\n s.p1 = curve_z_pos(t2);\\n \\n s.n0 = curve_z_nor(t1);\\n s.n1 = curve_z_nor(t2);\\n \\n return s;\\n}\\n\\nQuad quad_of_strip(int strip_id, int i, int n) {\\n int num_rings = n / 4;\\n int ring_id = i / 4;\\n int quad_in_ring = i - 4 * ring_id;\\n \\n Segment s;\\n \\n float t1 = float(ring_id) / float(num_rings);\\n float t2 = (float(ring_id) + 1.0) / float(num_rings);\\n \\n if (strip_id == 0)\\n \\ts = segment_x(t1, t2);\\n else if (strip_id == 1)\\n \\ts = segment_y(t1, t2);\\n else if (strip_id == 2)\\n \\ts = segment_z(t1, t2);\\n \\n Ring r = ring_from_segment(s);\\n \\n Quad q = quad_of_ring(r, quad_in_ring);\\n q.nor = (s.n0 + s.n1) / 2.0;\\n return q;\\n}\\n\\nvoid main() {\\n vec3 pos = vec3(0.0);\\n vec3 nor = vec3(0.0, 0.0, 0.0);\\n \\n int tri_id = int(floor(vertexId / 3.0));\\n int vert_in_tri = int(vertexId) - 3 * tri_id;\\n \\n int quad_id = tri_id / 2;\\n int tri_in_quad = int(tri_id) - 2 * quad_id;\\n \\n int mat_id = 0;\\n \\n vec3 cube_x = vec3(cos(time), sin(time), 0.0);\\n vec3 cube_y = vec3(-sin(time), cos(time), 0.0);\\n \\n if (quad_id < 6) {\\n int dim_id = quad_id / 2;\\n int side_in_dim = quad_id - 2 * dim_id;\\n \\n if (dim_id == 0) {\\n pos = cube_quad(vec3(0.0, 0.0, 1.0), cube_x, vert_in_tri + tri_in_quad*3);\\n nor = vec3(0.0, 0.0, 1.0);\\n } else if (dim_id == 1) {\\n pos = cube_quad(cube_y, cube_x, vert_in_tri + tri_in_quad*3);\\n nor = cube_y;\\n } else if (dim_id == 2) {\\n pos = cube_quad(cube_x, cube_y, vert_in_tri + tri_in_quad*3);\\n nor = cube_x;\\n }\\n mat_id = dim_id;\\n \\n if (side_in_dim == 1)\\n pos *= -1.0;\\n \\n }\\n else {\\n int vert_remaining = int(vertexCount) - 36;\\n int vert_per_strip = vert_remaining / 3;\\n int quad_per_strip = vert_per_strip / 6;\\n \\n int lvi = int(vertexId) - 36;\\n \\n int strip = lvi / vert_per_strip;\\n int first_vert_of_strip = 36 + strip * vert_per_strip;\\n int vert_in_strip = int(vertexId) - first_vert_of_strip;\\n \\n int quad_in_strip = vert_in_strip / 6;\\n int vert_in_quad = vert_in_strip - quad_in_strip * 6;\\n \\n Quad q;\\n \\n q = quad_of_strip(strip, quad_in_strip, quad_per_strip);\\n \\n /*\\n q.center = vec3(2.0, 0.0, 1.0);\\n q.tangent = vec3(1.0, 0.0, 0.0);\\n q.bitangent = vec3(0.0, 0.0, 1.0);\\n q.normal = vec3(0.0, 1.0, 0.0);\\n */\\n pos = vert_of_quad(q, vert_in_quad);\\n nor = q.nor;//norm_of_quad(q, vert_in_quad);\\n mat_id = q.mat_id;\\n }\\n \\n \\n vec3 base_x = vec3(cos(mouse.x*3.0), 1.0, sin(mouse.x*3.0));\\n vec3 base_y = vec3(sin(mouse.x*3.0), 1.0, -cos(mouse.x*3.0));\\n \\n base_x *= vec3(cos(mouse.y*3.0), sin(mouse.y*3.0), cos(mouse.y * 3.0));\\n base_y *= vec3(cos(mouse.y*3.0), sin(mouse.y*3.0), cos(mouse.y * 3.0));\\n \\n \\n vec3 base_z = cross(base_x, base_y);\\n base_x = cross(base_z, base_y);\\n \\n base_x = normalize(base_x) * 0.1;\\n base_y = normalize(base_y) * 0.1;\\n base_z = normalize(base_z) * 0.1;\\n \\n vec3 nor_mapped = normalize(nor.x * base_x + nor.y * base_y + nor.z * base_z);\\n \\n vec3 col = hsv2rgb(vec3(0.08 + float(mat_id) * 0.25, 1, 1));\\n \\n vec3 lightdir = normalize(vec3(-1, 1, -1));\\n \\n float diff = 0.25 + 0.75 * abs(dot(nor_mapped, lightdir));\\n v_color = vec4(col * diff, 1.0);\\n \\n vec3 pos_mapped = pos.x * base_x + pos.y * base_y + pos.z * base_z;\\n pos_mapped.x /= 1.0 + pos_mapped.z * 0.75;\\n pos_mapped.y /= 1.0 + pos_mapped.z * 0.75;\\n pos_mapped.x /= (resolution.x / resolution.y);\\n gl_Position = vec4(pos_mapped, 1.0);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 quad(vec3 origin, vec3 center, vec3 tangent, int vert_of_quad) {\n vec3 bitangent = cross(center, tangent);\n center += origin;\n if (vert_of_quad == 0)\n return center + tangent + bitangent;\n else if (vert_of_quad == 1)\n return center + tangent - bitangent;\n else if (vert_of_quad == 2)\n return center - tangent + bitangent;\n else if (vert_of_quad == 3)\n return center - tangent - bitangent;\n else if (vert_of_quad == 4)\n return center + tangent - bitangent;\n else if (vert_of_quad == 5)\n return center - tangent + bitangent;\n return center;\n}\n\nvec3 cube_quad(vec3 center, vec3 tangent, int vert_of_quad) {\n return quad(vec3(0.0), center, tangent, vert_of_quad);\n}\n\nstruct Quad {\n vec3 v0, v1, v2, v3;\n vec3 nor;\n int mat_id;\n};\n \nvec3 vert_of_quad(Quad q, int vert_of_quad) {\n if (vert_of_quad == 0)\n return q.v0;\n else if (vert_of_quad == 1)\n return q.v1;\n else if (vert_of_quad == 2)\n return q.v2;\n else if (vert_of_quad == 3)\n return q.v0;\n else if (vert_of_quad == 4)\n return q.v2;\n else if (vert_of_quad == 5)\n return q.v3;\n return q.v0;\n}\n\n \nvec3 norm_of_quad(Quad q, int vert_of_quad) {\n return normalize((vert_of_quad < 3)\n ? cross(q.v0 - q.v1, q.v2 - q.v1)\n : cross(q.v0 - q.v2, q.v3 - q.v2));\n}\n\n\nstruct Ring {\n vec3 s0, s1, s2, s3;\n vec3 e0, e1, e2, e3;\n};\n\nQuad quad_of_ring(Ring r, int quad_in_ring)\n{ \n Quad q;\n \n if (quad_in_ring == 0) {\n q.v0 = r.s0;\n q.v1 = r.s1;\n q.v2 = r.e1;\n q.v3 = r.e0;\n q.nor = normalize(r.s1 - r.s2);\n } else if (quad_in_ring == 1) {\n q.v0 = r.s1;\n q.v1 = r.s2;\n q.v2 = r.e2;\n q.v3 = r.e1;\n q.nor = normalize(r.s2 - r.s3);\n } else if (quad_in_ring == 2) {\n q.v0 = r.s2;\n q.v1 = r.s3;\n q.v2 = r.e3;\n q.v3 = r.e2;\n q.nor = normalize(r.s3 - r.s0);\n } else if (quad_in_ring == 3) {\n q.v0 = r.s3;\n q.v1 = r.s0;\n q.v2 = r.e0;\n q.v3 = r.e3;\n q.nor = normalize(r.s0 - r.s1);\n }\n \n q.mat_id = quad_in_ring;\n \n return q;\n}\n\nstruct Segment {\n vec3 d0, d1;\n vec3 p0, p1;\n vec3 n0, n1;\n};\n\nRing ring_from_segment(Segment s) { \n vec3 b0 = normalize(cross(s.d0, s.n0)) * 0.5;\n vec3 b1 = normalize(cross(s.d1, s.n1)) * 0.5;\n \n vec3 n0 = normalize(s.n0) * 0.25;\n vec3 n1 = normalize(s.n1) * 0.25;\n \n Ring r;\n \n r.s0 = s.p0 + n0 - b0;\n r.s1 = s.p0 + n0 + b0;\n r.s2 = s.p0 - n0 + b0;\n r.s3 = s.p0 - n0 - b0;\n \n r.e0 = s.p1 + n1 - b1;\n r.e1 = s.p1 + n1 + b1;\n r.e2 = s.p1 - n1 + b1;\n r.e3 = s.p1 - n1 - b1;\n \n return r;\n}\n\nvec3 curve_x_pos(float t) {\n float alpha = smoothstep(0.3, 0.4, t);\n float beta = smoothstep(0.3, 0.4, t) - smoothstep(0.5, 0.75, t);\n \n float phi = alpha * PI - time;\n \n float d = 5.0 * t;\n \n float A = alpha * d;\n \n float delta_x = -beta * (sin(time/2.0) * 0.5 + 0.5);\n float delta_y = -beta*2.0 * (-sin(time));\n float delta_z = -beta*3.0 * sin(time);\n \n return vec3(A + delta_x * 2.0, delta_y, delta_z);\n}\n\nvec3 curve_x_nor(float t) {\n float r = t;//abs(t - 0.5) * 2.0;\n float angle = 0.0;//-smoothstep(0.3, 0.6, r) * PI;\n \n return vec3(sin(angle), 0.0, cos(angle));\n}\n\nvec3 curve_y_pos(float t) {\n return vec3(0.0);//, -10.0 + 20.0 * t, 0.0);\n}\nvec3 curve_y_nor(float t) {\n return vec3(0.0);//sin(t*10.0), 0.0, cos(t*10.0));\n}\n\nvec3 curve_z_pos(float t) {\n return vec3(0.0);//, 0.0, -10.0 + 20.0 * t);\n}\nvec3 curve_z_nor(float t) {\n return vec3(sin(t*10.0), cos(t*10.0), 0.0);\n}\n\nSegment segment_x(float t1, float t2) {\n Segment s;\n \n float d = (t2 - t1) * 0.1;\n \n s.d0 = curve_x_pos(t1+d) - curve_x_pos(t1-d);\n s.d1 = curve_x_pos(t2+d) - curve_x_pos(t2-d);\n \n s.p0 = curve_x_pos(t1);\n s.p1 = curve_x_pos(t2);\n \n s.n0 = curve_x_nor(t1);\n s.n1 = curve_x_nor(t2);\n \n return s;\n}\n\nSegment segment_y(float t1, float t2) {\n Segment s;\n \n \n float d = (t2 - t1) * 0.1;\n \n s.d0 = curve_y_pos(t1+d) - curve_y_pos(t1-d);\n s.d1 = curve_y_pos(t2+d) - curve_y_pos(t2-d);\n \n s.p0 = curve_y_pos(t1);\n s.p1 = curve_y_pos(t2);\n \n s.n0 = curve_y_nor(t1);\n s.n1 = curve_y_nor(t2);\n \n return s;\n}\n\nSegment segment_z(float t1, float t2) {\n Segment s;\n \n \n float d = (t2 - t1) * 0.1;\n \n s.d0 = curve_z_pos(t1+d) - curve_z_pos(t1-d);\n s.d1 = curve_z_pos(t2+d) - curve_z_pos(t2-d);\n \n s.p0 = curve_z_pos(t1);\n s.p1 = curve_z_pos(t2);\n \n s.n0 = curve_z_nor(t1);\n s.n1 = curve_z_nor(t2);\n \n return s;\n}\n\nQuad quad_of_strip(int strip_id, int i, int n) {\n int num_rings = n / 4;\n int ring_id = i / 4;\n int quad_in_ring = i - 4 * ring_id;\n \n Segment s;\n \n float t1 = float(ring_id) / float(num_rings);\n float t2 = (float(ring_id) + 1.0) / float(num_rings);\n \n if (strip_id == 0)\n \ts = segment_x(t1, t2);\n else if (strip_id == 1)\n \ts = segment_y(t1, t2);\n else if (strip_id == 2)\n \ts = segment_z(t1, t2);\n \n Ring r = ring_from_segment(s);\n \n Quad q = quad_of_ring(r, quad_in_ring);\n q.nor = (s.n0 + s.n1) / 2.0;\n return q;\n}\n\nvoid main() {\n vec3 pos = vec3(0.0);\n vec3 nor = vec3(0.0, 0.0, 0.0);\n \n int tri_id = int(floor(vertexId / 3.0));\n int vert_in_tri = int(vertexId) - 3 * tri_id;\n \n int quad_id = tri_id / 2;\n int tri_in_quad = int(tri_id) - 2 * quad_id;\n \n int mat_id = 0;\n \n vec3 cube_x = vec3(cos(time), sin(time), 0.0);\n vec3 cube_y = vec3(-sin(time), cos(time), 0.0);\n \n if (quad_id < 6) {\n int dim_id = quad_id / 2;\n int side_in_dim = quad_id - 2 * dim_id;\n \n if (dim_id == 0) {\n pos = cube_quad(vec3(0.0, 0.0, 1.0), cube_x, vert_in_tri + tri_in_quad*3);\n nor = vec3(0.0, 0.0, 1.0);\n } else if (dim_id == 1) {\n pos = cube_quad(cube_y, cube_x, vert_in_tri + tri_in_quad*3);\n nor = cube_y;\n } else if (dim_id == 2) {\n pos = cube_quad(cube_x, cube_y, vert_in_tri + tri_in_quad*3);\n nor = cube_x;\n }\n mat_id = dim_id;\n \n if (side_in_dim == 1)\n pos *= -1.0;\n \n }\n else {\n int vert_remaining = int(vertexCount) - 36;\n int vert_per_strip = vert_remaining / 3;\n int quad_per_strip = vert_per_strip / 6;\n \n int lvi = int(vertexId) - 36;\n \n int strip = lvi / vert_per_strip;\n int first_vert_of_strip = 36 + strip * vert_per_strip;\n int vert_in_strip = int(vertexId) - first_vert_of_strip;\n \n int quad_in_strip = vert_in_strip / 6;\n int vert_in_quad = vert_in_strip - quad_in_strip * 6;\n \n Quad q;\n \n q = quad_of_strip(strip, quad_in_strip, quad_per_strip);\n \n /*\n q.center = vec3(2.0, 0.0, 1.0);\n q.tangent = vec3(1.0, 0.0, 0.0);\n q.bitangent = vec3(0.0, 0.0, 1.0);\n q.normal = vec3(0.0, 1.0, 0.0);\n */\n pos = vert_of_quad(q, vert_in_quad);\n nor = q.nor;//norm_of_quad(q, vert_in_quad);\n mat_id = q.mat_id;\n }\n \n \n vec3 base_x = vec3(cos(mouse.x*3.0), 1.0, sin(mouse.x*3.0));\n vec3 base_y = vec3(sin(mouse.x*3.0), 1.0, -cos(mouse.x*3.0));\n \n base_x *= vec3(cos(mouse.y*3.0), sin(mouse.y*3.0), cos(mouse.y * 3.0));\n base_y *= vec3(cos(mouse.y*3.0), sin(mouse.y*3.0), cos(mouse.y * 3.0));\n \n \n vec3 base_z = cross(base_x, base_y);\n base_x = cross(base_z, base_y);\n \n base_x = normalize(base_x) * 0.1;\n base_y = normalize(base_y) * 0.1;\n base_z = normalize(base_z) * 0.1;\n \n vec3 nor_mapped = normalize(nor.x * base_x + nor.y * base_y + nor.z * base_z);\n \n vec3 col = hsv2rgb(vec3(0.08 + float(mat_id) * 0.25, 1, 1));\n \n vec3 lightdir = normalize(vec3(-1, 1, -1));\n \n float diff = 0.25 + 0.75 * abs(dot(nor_mapped, lightdir));\n v_color = vec4(col * diff, 1.0);\n \n vec3 pos_mapped = pos.x * base_x + pos.y * base_y + pos.z * base_z;\n pos_mapped.x /= 1.0 + pos_mapped.z * 0.75;\n pos_mapped.y /= 1.0 + pos_mapped.z * 0.75;\n pos_mapped.x /= (resolution.x / resolution.y);\n gl_Position = vec4(pos_mapped, 1.0);\n}" + }, "screenshotURL": "data/images/images-dk6k6p544c74c44vi-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/AZ2KyvbW28MmPCFKA/art.json b/art/AZ2KyvbW28MmPCFKA/art.json index a7e1403c..b8f77d86 100644 --- a/art/AZ2KyvbW28MmPCFKA/art.json +++ b/art/AZ2KyvbW28MmPCFKA/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "rlmp", "avatarUrl": "https://lh5.googleusercontent.com/-1YJFhJaN2os/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBxbo3PsL2Sc2M4RzI-xvJgVZlbxg/photo.jpg", - "settings": "{\"num\":13087,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.15294117647058825,0.12941176470588237,0.43529411764705883,1],\"shader\":\"void main() {\\n float down= floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n \\n float xoff = sin(time+y*0.1) * 0.5 ;\\n float yoff = cos(time+x*0.2)*0.05;\\n \\n float ux = 2.*u-1.+xoff;\\n float vy = 2.*v-1.+yoff;\\n \\n vec2 xy = vec2(ux,vy)*0.8;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n gl_PointSize = 10.0 +sin(time)+cos(y*x*0.5)*5.;\\n gl_PointSize*=20./across;\\n gl_PointSize*=resolution.x/600.;\\n \\n v_color = vec4(1,0,0,1)\\n\\n} \"}", + "settings": { + "num": 13087, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.15294117647058825, + 0.12941176470588237, + 0.43529411764705883, + 1 + ], + "shader": "void main() {\n float down= floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n float u = x/(across-1.);\n float v = y/(across-1.);\n \n \n float xoff = sin(time+y*0.1) * 0.5 ;\n float yoff = cos(time+x*0.2)*0.05;\n \n float ux = 2.*u-1.+xoff;\n float vy = 2.*v-1.+yoff;\n \n vec2 xy = vec2(ux,vy)*0.8;\n \n gl_Position = vec4(xy,0,1);\n \n gl_PointSize = 10.0 +sin(time)+cos(y*x*0.5)*5.;\n gl_PointSize*=20./across;\n gl_PointSize*=resolution.x/600.;\n \n v_color = vec4(1,0,0,1)\n\n} " + }, "screenshotURL": "data/images/images-pyo2mxqcyvshtdmig-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/AZFnk3yzLiSZ2KkWS/art.json b/art/AZFnk3yzLiSZ2KkWS/art.json index c439a2c1..0c614320 100644 --- a/art/AZFnk3yzLiSZ2KkWS/art.json +++ b/art/AZFnk3yzLiSZ2KkWS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cybass/stranger-things-rmx\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"/* 👻 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat easeInOutCubic(float pos, float power) {\\n pos *= 2.;\\n if (pos < 1.) {\\n return 0.5 * pow(pos, power);\\n }\\n return 0.5 * (pow(pos - 2., power) + 2.);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments, float snd) {\\n id = mod(id, numCircleSegments * 6.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float a = snd;//sin(time) * 0.5 + 0.5;\\n float angle = ux / numCircleSegments * PI * mix(2., 12., a);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(mix(0.75, 0.9, a), 1.0, vy) + ux * -0.004;\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 200.0;\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n float circleV = circleId / numCircles;\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = 0.;//mod(sliceId, 2.);\\n \\n float segmentId = mod(sliceId, numCircleSegments);\\n float segmentV = segmentId / numCircleSegments;\\n float pointId = mod(vertexId, numPointsPerCircle);\\n float pointV = pointId / numPointsPerCircle;\\n float edgeId = floor(pointId / 6.) + mod(pointId, 2.);\\n float edgeV = edgeId / (numPointsPerCircle / 6.); \\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (down - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(mix(0.01, 0.5, hash(circleV)), edgeV)).a;\\n float sn2 = 0.;//texture2D(sound, vec2(au * 0.05, (1. - segmentV) * .9)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd + 0., 5.0) ;\\n float aspect = resolution.x / resolution.y;\\n \\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments, mix(.05, 1., .2)); \\n \\n float odd = mod(circleId, 2.);\\n float dir = mix(-1., 1., odd);\\n float st = time * .1 + circleV;\\n float sz = floor(st);\\n float sw = fract(st);\\n float fd = sin(sw * PI);\\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.1);\\n// mat *= trans(vec3(ux, vy, 0.) * 1.);\\n mat *= trans(vec3(hash(circleId * 0.123 + sz), hash(circleId * 0.719 + sz), 0.) * 2. - 1.);\\n float ss = .25 * snd;\\n mat *= scale(vec3(ss, ss * dir, 1));\\n mat *= rotZ(hash(circleV) * PI * 2. + time * 2.5);\\n //mat *= rotZ(time * -10.);// + snd * 10. * sign(ux));\\n\\n gl_Position = mat * pos;\\n gl_Position.z = -sin(sw);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.8, snd);\\n float pmp2 = step(0.8, sn2);\\n \\n float hue = odd * 0.5 + .2;\\n float sat = 0.;//mix(0.75, 1., pump);\\n float val = 0.;//mix(.5, pow(snd + 0.2, 5.0), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n v_color.a = sin(sw * PI);\\n \\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cybass/stranger-things-rmx", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "/* 👻 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat easeInOutCubic(float pos, float power) {\n pos *= 2.;\n if (pos < 1.) {\n return 0.5 * pow(pos, power);\n }\n return 0.5 * (pow(pos - 2., power) + 2.);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments, float snd) {\n id = mod(id, numCircleSegments * 6.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float a = snd;//sin(time) * 0.5 + 0.5;\n float angle = ux / numCircleSegments * PI * mix(2., 12., a);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(mix(0.75, 0.9, a), 1.0, vy) + ux * -0.004;\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 200.0;\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n float circleV = circleId / numCircles;\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = 0.;//mod(sliceId, 2.);\n \n float segmentId = mod(sliceId, numCircleSegments);\n float segmentV = segmentId / numCircleSegments;\n float pointId = mod(vertexId, numPointsPerCircle);\n float pointV = pointId / numPointsPerCircle;\n float edgeId = floor(pointId / 6.) + mod(pointId, 2.);\n float edgeV = edgeId / (numPointsPerCircle / 6.); \n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (down - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(mix(0.01, 0.5, hash(circleV)), edgeV)).a;\n float sn2 = 0.;//texture2D(sound, vec2(au * 0.05, (1. - segmentV) * .9)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd + 0., 5.0) ;\n float aspect = resolution.x / resolution.y;\n \n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments, mix(.05, 1., .2)); \n \n float odd = mod(circleId, 2.);\n float dir = mix(-1., 1., odd);\n float st = time * .1 + circleV;\n float sz = floor(st);\n float sw = fract(st);\n float fd = sin(sw * PI);\n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.1);\n// mat *= trans(vec3(ux, vy, 0.) * 1.);\n mat *= trans(vec3(hash(circleId * 0.123 + sz), hash(circleId * 0.719 + sz), 0.) * 2. - 1.);\n float ss = .25 * snd;\n mat *= scale(vec3(ss, ss * dir, 1));\n mat *= rotZ(hash(circleV) * PI * 2. + time * 2.5);\n //mat *= rotZ(time * -10.);// + snd * 10. * sign(ux));\n\n gl_Position = mat * pos;\n gl_Position.z = -sin(sw);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.8, snd);\n float pmp2 = step(0.8, sn2);\n \n float hue = odd * 0.5 + .2;\n float sat = 0.;//mix(0.75, 1., pump);\n float val = 0.;//mix(.5, pow(snd + 0.2, 5.0), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n v_color.a = sin(sw * PI);\n \n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-dq7s7cqwp0bna81g2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/AZS5NEiv5XCb7HrRy/art.json b/art/AZS5NEiv5XCb7HrRy/art.json index 92e4aca0..4b20dc68 100644 --- a/art/AZS5NEiv5XCb7HrRy/art.json +++ b/art/AZS5NEiv5XCb7HrRy/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "인간", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxYYUG6kDNkKCZn_0f6fHp8qT4Likq-_iAzteMRA=s96-c", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Rudy Castan\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Rudy Castan\n// Exercise Making A Grid\n// CS250 Spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-wgb5y512zk34e46zk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Acb8NGnF3tJvv77Ji/art.json b/art/Acb8NGnF3tJvv77Ji/art.json index 07370f9c..a8a571a6 100644 --- a/art/Acb8NGnF3tJvv77Ji/art.json +++ b/art/Acb8NGnF3tJvv77Ji/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":91919,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 65.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.1 + 1.1;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2.6 + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 1.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 1.27) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *12.1 *mouse.x);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 0.3)-7.) * 0.05, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId - time * 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 0.1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 3.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(0.01 *snd , 0.9 *mouse.x/ circleId*snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 1.0 * snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.51, snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 91919, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 65.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.1 + 1.1;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2.6 + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 1.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 1.27) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *12.1 *mouse.x);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 0.3)-7.) * 0.05, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId - time * 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 0.1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 3.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(0.01 *snd , 0.9 *mouse.x/ circleId*snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 1.0 * snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.51, snd*6.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-yxe5lj2v02ggkh2sz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ajiknj6GiHKrmZT3Z/art.json b/art/Ajiknj6GiHKrmZT3Z/art.json index 3a23c84c..8ad1b143 100644 --- a/art/Ajiknj6GiHKrmZT3Z/art.json +++ b/art/Ajiknj6GiHKrmZT3Z/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "eugene", "avatarUrl": "https://lh4.googleusercontent.com/-1W0Zx2V2YBo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuck7HOEHYTKOuOYfO3JNASLLHC1T0A/s96-c/photo.jpg", - "settings": "{\"num\":8330,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.06666666666666667,0.25882352941176473,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.2 + x * 0.2) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.3 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.4 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.5 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n\\n}\"}", + "settings": { + "num": 8330, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.06666666666666667, + 0.25882352941176473, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.2 + x * 0.2) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.3 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.4 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.5 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n\n}" + }, "screenshotURL": "data/images/images-g0mp0wep89063xfnl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/AnFAYAbcbpuErBvBW/art.json b/art/AnFAYAbcbpuErBvBW/art.json index 9cb88076..81ffc3c3 100644 --- a/art/AnFAYAbcbpuErBvBW/art.json +++ b/art/AnFAYAbcbpuErBvBW/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "山ん", "avatarUrl": "https://lh3.googleusercontent.com/a/ALm5wu09xCAkradsOw1xY6nU5FV5jRgli9RGVQZipU4g=s96-c", - "settings": "{\"num\":2416,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ZOOM (1.1)\\n#define SCALE (1.0/(vertexCount))\\n#define SIDE (sqrt(vertexCount))\\n#define TAU (6.283185307179586476925286766559)\\n#define SPEED (10.)\\n#define AMP (sqrt(SIDE)*0.002)\\nvoid main()\\n{\\n float x = -1.1 + ZOOM * 2. * floor(fract(vertexId/SIDE) * SIDE + 0.5) / SIDE;\\n float y = -1.1 + ZOOM * 2. * floor(vertexId / SIDE) / SIDE;\\n \\n x += AMP * sin(SPEED * time + x * TAU);\\n y -= AMP * cos(SPEED * time + y * TAU);\\n\\n gl_PointSize = 2.0;\\n gl_Position = vec4(x,y,0.0,1.0);\\n v_color = vec4(1.0,1.0,1.0,1.0);\\n}\\n\\n\\n/*\\nvertexId : float : number of the vertex 0, 1, 2\\nvertexCount : float : total number of vertices\\nresolution : vec2 : resolution of the art\\nmouse : vec2 : mouse position normalized (-1 to 1)\\ntouch : sampler2D : touch history 32x240 (4sec @60fps)\\n : : x = x, y = y, z = pressure, w = time\\n : : column 0 is mouse or first finger.\\n : : column 1 is second finger ...\\ntime : float : time in seconds\\nvolume : sampler2D : volume for music 1x240 alpha only\\nsound : sampler2D : data from the music Nx240, alpha only\\n : : 240 rows of history (4secs @60fps)\\nfloatSound : sampler2D : data from the music Nx240, alpha only\\n : : 240 rows of history (4secs @60fps)\\n : : see spec for difference between\\n : : getFloatFrequencyData and\\n : : getByteFrenquencyData.\\nsoundRes : vec2 : resolution of sound\\nbackground : vec4 : background color\\n\\n\\ngl_Position : vec4 : standard GLSL vertex shader output\\nv_color : vec4 : color to output from fragment shader\\n*/\"}", + "settings": { + "num": 2416, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ZOOM (1.1)\n#define SCALE (1.0/(vertexCount))\n#define SIDE (sqrt(vertexCount))\n#define TAU (6.283185307179586476925286766559)\n#define SPEED (10.)\n#define AMP (sqrt(SIDE)*0.002)\nvoid main()\n{\n float x = -1.1 + ZOOM * 2. * floor(fract(vertexId/SIDE) * SIDE + 0.5) / SIDE;\n float y = -1.1 + ZOOM * 2. * floor(vertexId / SIDE) / SIDE;\n \n x += AMP * sin(SPEED * time + x * TAU);\n y -= AMP * cos(SPEED * time + y * TAU);\n\n gl_PointSize = 2.0;\n gl_Position = vec4(x,y,0.0,1.0);\n v_color = vec4(1.0,1.0,1.0,1.0);\n}\n\n\n/*\nvertexId : float : number of the vertex 0, 1, 2\nvertexCount : float : total number of vertices\nresolution : vec2 : resolution of the art\nmouse : vec2 : mouse position normalized (-1 to 1)\ntouch : sampler2D : touch history 32x240 (4sec @60fps)\n : : x = x, y = y, z = pressure, w = time\n : : column 0 is mouse or first finger.\n : : column 1 is second finger ...\ntime : float : time in seconds\nvolume : sampler2D : volume for music 1x240 alpha only\nsound : sampler2D : data from the music Nx240, alpha only\n : : 240 rows of history (4secs @60fps)\nfloatSound : sampler2D : data from the music Nx240, alpha only\n : : 240 rows of history (4secs @60fps)\n : : see spec for difference between\n : : getFloatFrequencyData and\n : : getByteFrenquencyData.\nsoundRes : vec2 : resolution of sound\nbackground : vec4 : background color\n\n\ngl_Position : vec4 : standard GLSL vertex shader output\nv_color : vec4 : color to output from fragment shader\n*/" + }, "screenshotURL": "data/images/images-j6yu3m9yv5s3eyd9x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/AndijhSm4Fuox73p9/art.json b/art/AndijhSm4Fuox73p9/art.json index 72f25e9a..fb9ea6f8 100644 --- a/art/AndijhSm4Fuox73p9/art.json +++ b/art/AndijhSm4Fuox73p9/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "athega", "avatarUrl": "https://secure.gravatar.com/avatar/ac866057ea99c21292a071d08fadd152?default=retro&size=200", - "settings": "{\"num\":25957,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/iamtheelephante/katy-perry-dark-horse-ft-juicy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.058823529411764705,0.058823529411764705,0.058823529411764705,1],\"shader\":\"// chrillo\\n\\n#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n\\nvoid main () {\\n float i = hash(vertexId);\\n float f = hash(i);\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 2.);\\n \\n float ang = vertexId / 1000.;\\n float perspective = .5 * (1. - mouse.y);\\n float t = time * (f + .5) - mouse.x;\\n float x = i * sin(ang + t) * .8;\\n float y = i * cos(ang + t);\\n y += .1 * snd * (1. - y);\\n y *= perspective;\\n \\n float vis = snd / (y + 1.);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 5. * vis;\\n \\n v_color = vec4(\\n snd * .7 * (2. - f),\\n snd * .8 * cos(f * PI),\\n snd * 2.,\\n vis);\\n}\"}", + "settings": { + "num": 25957, + "mode": "POINTS", + "sound": "https://soundcloud.com/iamtheelephante/katy-perry-dark-horse-ft-juicy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.058823529411764705, + 0.058823529411764705, + 0.058823529411764705, + 1 + ], + "shader": "// chrillo\n\n#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n\nvoid main () {\n float i = hash(vertexId);\n float f = hash(i);\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 2.);\n \n float ang = vertexId / 1000.;\n float perspective = .5 * (1. - mouse.y);\n float t = time * (f + .5) - mouse.x;\n float x = i * sin(ang + t) * .8;\n float y = i * cos(ang + t);\n y += .1 * snd * (1. - y);\n y *= perspective;\n \n float vis = snd / (y + 1.);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 5. * vis;\n \n v_color = vec4(\n snd * .7 * (2. - f),\n snd * .8 * cos(f * PI),\n snd * 2.,\n vis);\n}" + }, "screenshotURL": "data/images/images-548dozbpo5173sw20-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ar3JvNPvHx9gCAXTC/art.json b/art/Ar3JvNPvHx9gCAXTC/art.json index e20e6008..ce0748c1 100644 --- a/art/Ar3JvNPvHx9gCAXTC/art.json +++ b/art/Ar3JvNPvHx9gCAXTC/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "plasticrainbow", "avatarUrl": "https://secure.gravatar.com/avatar/6a162c0fed03619171f63772ec1198d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-vx3u2hm5710y3ny0e-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Av2MKnW2EJCyL2soB/art.json b/art/Av2MKnW2EJCyL2soB/art.json index 9ed00546..be573041 100644 --- a/art/Av2MKnW2EJCyL2soB/art.json +++ b/art/Av2MKnW2EJCyL2soB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6496,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/katabatik/dj-atlea-musick-of-barrett-clark-vol-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.4823529411764706,0.23529411764705882,0.20392156862745098,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( -1.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, .0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 2.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 37.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.*mouse.y;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 1.))));\\n \\n vCubeCol.xyz = vec3(1.-mouse.x,mouse.r,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.1;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0.0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\nfloat sndx = texture2D(sound, vec2(hash(11.-fCubeId) * mouse.y*8.125, 10.*mouse)).a;\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * mouse.y*1.125, 0)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId*snd*22., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos-snd, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,0,0,1); \\n // hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, .07770),1,-1,-1.+snd*sin(time*3.)), color*4.*sndx, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 6496, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/katabatik/dj-atlea-musick-of-barrett-clark-vol-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.4823529411764706, + 0.23529411764705882, + 0.20392156862745098, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( -1.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, .0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 2.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 37.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.*mouse.y;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 1.))));\n \n vCubeCol.xyz = vec3(1.-mouse.x,mouse.r,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.1;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0.0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\nfloat sndx = texture2D(sound, vec2(hash(11.-fCubeId) * mouse.y*8.125, 10.*mouse)).a;\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * mouse.y*1.125, 0)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId*snd*22., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos-snd, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,0,0,1); \n // hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, .07770),1,-1,-1.+snd*sin(time*3.)), color*4.*sndx, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-0cuc94aul8wdawmwt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Axy2s5b2qtEdfhrhP/art.json b/art/Axy2s5b2qtEdfhrhP/art.json index 0b9fa075..4d3ff8c0 100644 --- a/art/Axy2s5b2qtEdfhrhP/art.json +++ b/art/Axy2s5b2qtEdfhrhP/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "dzozef", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// retro flag\\n\\n\\n#define POINTSIZE 1.00\\nfloat SCALE = 10.0;// * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) ) / 2.;\\nfloat TSCALE = 0.05 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvoid rotateX(inout vec3 p, float a) {\\n\\tfloat c,s;vec3 q=p;\\n\\tc = cos(a); s = sin(a);\\n\\tp.y = c * q.y - s * q.z;\\n\\tp.z = s * q.y + c * q.z;\\n}\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 0., 268., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE; // 4 more vertexes per 'cell'\\n float quad = floor( vertexid / 4. );\\n float qv = mod( vertexid, 4. );\\n // SIZE-1 quads on side\\n float qx = mod( quad, SIZE-1. );\\n float qy = floor( quad / (SIZE-1.) );\\n \\n float x = qx + mod( qv, 2. );\\n float y = qy + floor( qv / 2. );\\n// if (mod(y,2.)>0.0)\\n// {\\n // odd - change direction\\n// x = qx + 1. - mod( qv, 4. );\\n// }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, (-SIZE/2.0 + y) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE * smoothstep( SIZE, 0., x ) );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*0.2-0.2 );\\n rotateX( p, -mouse.y*0.2 );\\n float origz = p.z;\\n p += vec3( 0.0, 0.0, 10.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n if ( vertexId / SIZE > SIZE/2.) v_color = vec4( 1.0 );\\n else v_color = vec4( 1.0, 0.0, 0.0, 1.0 );\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// retro flag\n\n\n#define POINTSIZE 1.00\nfloat SCALE = 10.0;// * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) ) / 2.;\nfloat TSCALE = 0.05 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvoid rotateX(inout vec3 p, float a) {\n\tfloat c,s;vec3 q=p;\n\tc = cos(a); s = sin(a);\n\tp.y = c * q.y - s * q.z;\n\tp.z = s * q.y + c * q.z;\n}\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 0., 268., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE; // 4 more vertexes per 'cell'\n float quad = floor( vertexid / 4. );\n float qv = mod( vertexid, 4. );\n // SIZE-1 quads on side\n float qx = mod( quad, SIZE-1. );\n float qy = floor( quad / (SIZE-1.) );\n \n float x = qx + mod( qv, 2. );\n float y = qy + floor( qv / 2. );\n// if (mod(y,2.)>0.0)\n// {\n // odd - change direction\n// x = qx + 1. - mod( qv, 4. );\n// }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, (-SIZE/2.0 + y) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE * smoothstep( SIZE, 0., x ) );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*0.2-0.2 );\n rotateX( p, -mouse.y*0.2 );\n float origz = p.z;\n p += vec3( 0.0, 0.0, 10.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n if ( vertexId / SIZE > SIZE/2.) v_color = vec4( 1.0 );\n else v_color = vec4( 1.0, 0.0, 0.0, 1.0 );\n}" + }, "screenshotURL": "data/images/images-xgzq7zfj6zmjbspri-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/B2Xb9dHRi7bYyQfjA/art.json b/art/B2Xb9dHRi7bYyQfjA/art.json index 5b207fe3..43727e29 100644 --- a/art/B2Xb9dHRi7bYyQfjA/art.json +++ b/art/B2Xb9dHRi7bYyQfjA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 1000.);\\n float r = sqrt(1000. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 1000.);\n float r = sqrt(1000. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-u3f4kbdnhro8b0mg7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B3MrHFwyLFjSx8mo4/art.json b/art/B3MrHFwyLFjSx8mo4/art.json index ad859cf0..7f6f512c 100644 --- a/art/B3MrHFwyLFjSx8mo4/art.json +++ b/art/B3MrHFwyLFjSx8mo4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":10095,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/meehanperkinsduo/nagoya-marimbas-steve-reich\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0,0.25098039215686274,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0.8) * flip;\\n float lr = mod(sideId, 3.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float height = 11.;\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n \\n float cv = cubeId / (numCubes - 1.);\\n float cy = 2. * cv - 1.;\\n \\n\\n float s = texture2D(sound, vec2(mix(0.25, 0.05, cv), 0)).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(30.0), resolution.x / resolution.y, 0.81, 101.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(1.);\\n vec3 up = vec3(0,1.*mouse.x,1.3);\\n\\n float sc = s * 10.;\\n mat *= cameraLookAt(eye, target, up);\\n //mat *= rotZ(0.5 * PI);\\n mat *= trans(vec3(1, cy * height, 1));\\n mat *= scale(vec3(sc, height / numCubes * 2., sc));\\n \\n \\n gl_Position = mat * vec4(pos, 2);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, .4, -1));\\n\\n float hue = mix(0.4, 0.8, s);\\n // abs(ca * cc) * 2.;\\n float sat = mix(0.1, 5., pow(s, 3.));//mix(0.0, 1., step(10.8, s));\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 1.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 10095, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/meehanperkinsduo/nagoya-marimbas-steve-reich", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0, + 0.25098039215686274, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0.8) * flip;\n float lr = mod(sideId, 3.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float height = 11.;\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n \n float cv = cubeId / (numCubes - 1.);\n float cy = 2. * cv - 1.;\n \n\n float s = texture2D(sound, vec2(mix(0.25, 0.05, cv), 0)).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(30.0), resolution.x / resolution.y, 0.81, 101.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(1.);\n vec3 up = vec3(0,1.*mouse.x,1.3);\n\n float sc = s * 10.;\n mat *= cameraLookAt(eye, target, up);\n //mat *= rotZ(0.5 * PI);\n mat *= trans(vec3(1, cy * height, 1));\n mat *= scale(vec3(sc, height / numCubes * 2., sc));\n \n \n gl_Position = mat * vec4(pos, 2);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, .4, -1));\n\n float hue = mix(0.4, 0.8, s);\n // abs(ca * cc) * 2.;\n float sat = mix(0.1, 5., pow(s, 3.));//mix(0.0, 1., step(10.8, s));\n float val = 1.;//mix(1., 1., step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 1.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-7b525rl7j8ggtnsht-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B3fTWQihXfD9t8Q8r/art.json b/art/B3fTWQihXfD9t8Q8r/art.json index 90240ea8..4683999e 100644 --- a/art/B3fTWQihXfD9t8Q8r/art.json +++ b/art/B3fTWQihXfD9t8Q8r/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-3q616twm76vtdzbh8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B42Ho7bLcyCakLyrD/art.json b/art/B42Ho7bLcyCakLyrD/art.json index d07126a2..0345f914 100644 --- a/art/B42Ho7bLcyCakLyrD/art.json +++ b/art/B42Ho7bLcyCakLyrD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : jemin.Shin\\n//Exerciese : Circles from Triangles_twist\\n//Course CS250\\n//Date : 2023 Spring\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 5.0);\\n float a = pointId * PI * 2. / 4. + PI * 3.5;\\n vec3 p = vec3(cos(a), 4.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 1.0 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.1 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.5);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : jemin.Shin\n//Exerciese : Circles from Triangles_twist\n//Course CS250\n//Date : 2023 Spring\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 5.0);\n float a = pointId * PI * 2. / 4. + PI * 3.5;\n vec3 p = vec3(cos(a), 4.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 1.0 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.1 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.5);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-36b5ouc6yyfv9n9v4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/B4Eq6Qa7NTqRG2h7n/art.json b/art/B4Eq6Qa7NTqRG2h7n/art.json index 03883b03..8fa36b8c 100644 --- a/art/B4Eq6Qa7NTqRG2h7n/art.json +++ b/art/B4Eq6Qa7NTqRG2h7n/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(vertexId, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(vertexId, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-hylujrosugfnm5il1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/B5PGbeNcqjZkjn87u/art.json b/art/B5PGbeNcqjZkjn87u/art.json index b8d44be1..9226fb91 100644 --- a/art/B5PGbeNcqjZkjn87u/art.json +++ b/art/B5PGbeNcqjZkjn87u/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":95256,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/duodiscomusic/duodisco-gaba-just-going-snippet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float su = abs(atan(ca, cb)) / PI;\\n float sv = length(vec2(ca, cb));\\n sv = mod(faceId, 2.) < 0.5 ? sv : 1. - sv; \\n float ff = floor(mod(faceId + time * 0., 6.0));\\n float s = texture2D(sound, vec2(mix(0.02, 0.05, su) + ff * 0.05, (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, mix(1.4, 2., faceId / 6.), s);\\n \\n float tm = time * 0.3;\\n float r = mix(20., 50., step(7., mod(time, 14.)));\\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip * 1.05, cb) * down * 1.);\\n mat *= uniformScale(1.);//mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2.2, s) + faceId * 0.15;\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0., 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), val);\\n gl_Position.z = mix(10000., gl_Position.z, val);\\n}\\n\\n\"}", + "settings": { + "num": 95256, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/duodiscomusic/duodisco-gaba-just-going-snippet", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float su = abs(atan(ca, cb)) / PI;\n float sv = length(vec2(ca, cb));\n sv = mod(faceId, 2.) < 0.5 ? sv : 1. - sv; \n float ff = floor(mod(faceId + time * 0., 6.0));\n float s = texture2D(sound, vec2(mix(0.02, 0.05, su) + ff * 0.05, (sv) / 2. * .2)).a;\n \n s = mix(0.0, mix(1.4, 2., faceId / 6.), s);\n \n float tm = time * 0.3;\n float r = mix(20., 50., step(7., mod(time, 14.)));\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip * 1.05, cb) * down * 1.);\n mat *= uniformScale(1.);//mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2.2, s) + faceId * 0.15;\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0., 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), val);\n gl_Position.z = mix(10000., gl_Position.z, val);\n}\n\n" + }, "screenshotURL": "data/images/images-hmoh27wp6816c98av-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B6DFsE8BsdxjmQSeD/art.json b/art/B6DFsE8BsdxjmQSeD/art.json index 3dd162be..abaf57c8 100644 --- a/art/B6DFsE8BsdxjmQSeD/art.json +++ b/art/B6DFsE8BsdxjmQSeD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\n}" + }, "screenshotURL": "data/images/images-3tv0d984russ0ojiz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B6cRz9JjErEA57pG4/art.json b/art/B6cRz9JjErEA57pG4/art.json index c19a644f..76bbe44d 100644 --- a/art/B6cRz9JjErEA57pG4/art.json +++ b/art/B6cRz9JjErEA57pG4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2158,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 11.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = 0.02;\\n float angle = point * PI * 1.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle ) * radius;\\n float s = sin(angle ) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 2158, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 11.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = 0.02;\n float angle = point * PI * 1.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle ) * radius;\n float s = sin(angle ) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-fmbfyrv01kuremsjx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B6hCMdEJpbdKbEpYp/art.json b/art/B6hCMdEJpbdKbEpYp/art.json index 0f3aee88..14d43f6b 100644 --- a/art/B6hCMdEJpbdKbEpYp/art.json +++ b/art/B6hCMdEJpbdKbEpYp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":3337,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/dan-hekate-1/mercury-in-stasis\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.08235294117647059,0.08235294117647059,1],\"shader\":\"\\n#define parameter0 0.//KParameter 0.>>6.\\n#define P2 -3.//KParameter -5.>>10.\\n#define P3 0.1//KParameter 0.1>>3.\\n#define P6 9.//KParameter 0.1>>10.\\n#define P5 1.//KParameter -1.>>1.\\n#define P4 0.5//KParameter 0.0>>1.\\n#define mx -.18//KParameter -1.0>>1.0\\n#define my -.9//KParameter -1.0>>1.0\\n//KVerticesNumber=3880\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0],\\n m[0][1], m[1][1], m[2][1],\\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0],\\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0],\\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mx,\\n zAxis,0.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\nvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\nreturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION)\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.2); \\n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 12. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.25;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 12.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down*3.);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6);\\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + my * r;\\n float y = sin(qu * PI * 4.) * r;\\n \\n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\\n \\n float tm = time * 1.02 +mx* qv;\\n float rd = 3.;\\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mx *3.0) + 2.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *.01;\\n float sat = P4;\\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 3337, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/dan-hekate-1/mercury-in-stasis", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.08235294117647059, + 0.08235294117647059, + 1 + ], + "shader": "\n#define parameter0 0.//KParameter 0.>>6.\n#define P2 -3.//KParameter -5.>>10.\n#define P3 0.1//KParameter 0.1>>3.\n#define P6 9.//KParameter 0.1>>10.\n#define P5 1.//KParameter -1.>>1.\n#define P4 0.5//KParameter 0.0>>1.\n#define mx -.18//KParameter -1.0>>1.0\n#define my -.9//KParameter -1.0>>1.0\n//KVerticesNumber=3880\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0],\n m[0][1], m[1][1], m[2][1],\n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0],\n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0],\n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mx,\n zAxis,0.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\nvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\nreturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION)\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.2); \n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 12. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.25;\n float down = numQuads / around;\n float quadId = floor(vertexId / 12.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down*3.);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6);\n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + my * r;\n float y = sin(qu * PI * 4.) * r;\n \n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\n \n float tm = time * 1.02 +mx* qv;\n float rd = 3.;\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mx *3.0) + 2.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *.01;\n float sat = P4;\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-pxbrux6rjc5r6igxi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B7XSdPJnstpQRHwMt/art.json b/art/B7XSdPJnstpQRHwMt/art.json index 0887deda..d2c469af 100644 --- a/art/B7XSdPJnstpQRHwMt/art.json +++ b/art/B7XSdPJnstpQRHwMt/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":4987,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Motion Assignment\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.2) * 0.1;\\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. -1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 4987, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Motion Assignment\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.2) * 0.1;\n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. -1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-acu58ifavewbul2or-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/B8dK4DjfS4gxQ2D6x/art.json b/art/B8dK4DjfS4gxQ2D6x/art.json index fc013a92..75fa621c 100644 --- a/art/B8dK4DjfS4gxQ2D6x/art.json +++ b/art/B8dK4DjfS4gxQ2D6x/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/loulourecords/pimpo-gama-zacchi-go-loulou-records-preview-llr082-release-date-06-august\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 0\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\\n\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() {\\n float numCircles = 8.;\\n float numPointsPerCircle = floor(vertexCount / numCircles);\\n float id = mod(vertexId, numPointsPerCircle);\\n float u = id / numPointsPerCircle;\\n \\n float cId = floor(vertexId / numPointsPerCircle);\\n float cv = cId / numCircles;\\n\\n float a = u * PI * 2.;\\n vec3 pos = vec3(cos(a), 0, sin(a));\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 mat = persp(PI * 0.25, aspect, 1., 15.);\\n \\n float cs = time * 0.5;\\n float r = 8.;\\n vec3 eye = vec3(cos(cs) * r, sin(cs * .7) * r * .5, sin(cs) * r);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.25, fract(time + cv)),\\n 0.)).a;\\n float pump = step(0.70, s);\\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n mat *= rotZ(cv * PI * 2. + time * 0.05);\\n mat *= trans(vec3(0, mix(2.5, 2.5, pow(s, 5.)), 0));\\n \\n float sp = cv + time * 0.1;\\n mat *= rotZ(PI * 0.5); //sin(u * PI * 2.) * cos(sp) * 1.);\\n mat *= rotX(sin(u * PI * 1.) * PI * sin(sp * PI) * 80. * pow(s, 5.));\\n mat *= uniformScale(mix(0.7, 0.7, pump));\\n \\n\\n gl_Position = mat * vec4(pos, 1);\\n float z = gl_Position.z / gl_Position.w * .5 + .5;\\n z = pow(z, 8.);\\n z = 1. - z;\\n \\n float hue = mix(0.5, 8.5, s) + sin(u * PI * 2.) * .1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n// v_color = mix(v_color, vec4(1,0,0,1), pump);\\n \\n gl_PointSize = z * (5. * pow(s + .2, 5.) * 5.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/loulourecords/pimpo-gama-zacchi-go-loulou-records-preview-llr082-release-date-06-august", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 0\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif\n\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() {\n float numCircles = 8.;\n float numPointsPerCircle = floor(vertexCount / numCircles);\n float id = mod(vertexId, numPointsPerCircle);\n float u = id / numPointsPerCircle;\n \n float cId = floor(vertexId / numPointsPerCircle);\n float cv = cId / numCircles;\n\n float a = u * PI * 2.;\n vec3 pos = vec3(cos(a), 0, sin(a));\n \n float aspect = resolution.x / resolution.y;\n mat4 mat = persp(PI * 0.25, aspect, 1., 15.);\n \n float cs = time * 0.5;\n float r = 8.;\n vec3 eye = vec3(cos(cs) * r, sin(cs * .7) * r * .5, sin(cs) * r);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n float s = texture2D(sound, vec2(\n mix(0.01, 0.25, fract(time + cv)),\n 0.)).a;\n float pump = step(0.70, s);\n \n mat *= cameraLookAt(eye, target, up);\n \n mat *= rotZ(cv * PI * 2. + time * 0.05);\n mat *= trans(vec3(0, mix(2.5, 2.5, pow(s, 5.)), 0));\n \n float sp = cv + time * 0.1;\n mat *= rotZ(PI * 0.5); //sin(u * PI * 2.) * cos(sp) * 1.);\n mat *= rotX(sin(u * PI * 1.) * PI * sin(sp * PI) * 80. * pow(s, 5.));\n mat *= uniformScale(mix(0.7, 0.7, pump));\n \n\n gl_Position = mat * vec4(pos, 1);\n float z = gl_Position.z / gl_Position.w * .5 + .5;\n z = pow(z, 8.);\n z = 1. - z;\n \n float hue = mix(0.5, 8.5, s) + sin(u * PI * 2.) * .1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n// v_color = mix(v_color, vec4(1,0,0,1), pump);\n \n gl_PointSize = z * (5. * pow(s + .2, 5.) * 5.);\n}" + }, "screenshotURL": "data/images/images-ke3zyjtdbin0oes3w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/B9wG9rDf7i77ZyAbL/art.json b/art/B9wG9rDf7i77ZyAbL/art.json index 2a8a77de..76cc3744 100644 --- a/art/B9wG9rDf7i77ZyAbL/art.json +++ b/art/B9wG9rDf7i77ZyAbL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":330,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float id = vertexId;\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux * radians(180.0) / (vertexCount * sin(time*0.1) * 0.005);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy;\\n \\n float a = resolution.x / resolution.y;\\n \\n float x = c * radius / a;\\n float y = s * radius;\\n \\n vec2 xy = vec2(x,y);\\n gl_Position = vec4(xy* .5, 0, 1);\\n v_color = vec4(cos(id/y), sin(id/x), sin(id), 1);\\n}\"}", + "settings": { + "num": 330, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float id = vertexId;\n \n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux * radians(180.0) / (vertexCount * sin(time*0.1) * 0.005);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy;\n \n float a = resolution.x / resolution.y;\n \n float x = c * radius / a;\n float y = s * radius;\n \n vec2 xy = vec2(x,y);\n gl_Position = vec4(xy* .5, 0, 1);\n v_color = vec4(cos(id/y), sin(id/x), sin(id), 1);\n}" + }, "screenshotURL": "data/images/images-hcw1cvqla6p0qvk8p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BCqiiXBgBXYHTqw6G/art.json b/art/BCqiiXBgBXYHTqw6G/art.json index 509e8909..94bc6a66 100644 --- a/art/BCqiiXBgBXYHTqw6G/art.json +++ b/art/BCqiiXBgBXYHTqw6G/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Making a Grid\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n // Calculate color based on time\\n float red = sin(time);\\n float green = cos(time);\\n float blue = sin(time + 1.0);\\n \\n v_color = vec4(red, green, blue, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Making a Grid\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n // Calculate color based on time\n float red = sin(time);\n float green = cos(time);\n float blue = sin(time + 1.0);\n \n v_color = vec4(red, green, blue, 1);\n}" + }, "screenshotURL": "data/images/images-e2m7r0pwzdx2wc2kd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BEskWFZM826YNBJAN/art.json b/art/BEskWFZM826YNBJAN/art.json index ef4e2783..8917a119 100644 --- a/art/BEskWFZM826YNBJAN/art.json +++ b/art/BEskWFZM826YNBJAN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":1440,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,0,1],\"shader\":\"// -----[ shader missing! ] -----\\n\\n#define NUM 15.0\\n#define NUMP 2.1\\nvoid main() {\\n gl_PointSize = 64.0;\\n float col = mod(vertexId, NUM + 1.0);\\n float row = mod(floor(vertexId / NUMP), NUMP + 1.0); \\n float x = col / NUM * 2.0 - 1.0;\\n float y = row / NUM * 2.0 - 1.0;\\n gl_Position = vec4(x, y, 0, 1);\\n v_color = vec4(fract(time + col / NUM + sin(row) / NUMP), 0, 0, 6);\\n}\"}", + "settings": { + "num": 1440, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 0, + 1 + ], + "shader": "// -----[ shader missing! ] -----\n\n#define NUM 15.0\n#define NUMP 2.1\nvoid main() {\n gl_PointSize = 64.0;\n float col = mod(vertexId, NUM + 1.0);\n float row = mod(floor(vertexId / NUMP), NUMP + 1.0); \n float x = col / NUM * 2.0 - 1.0;\n float y = row / NUM * 2.0 - 1.0;\n gl_Position = vec4(x, y, 0, 1);\n v_color = vec4(fract(time + col / NUM + sin(row) / NUMP), 0, 0, 6);\n}" + }, "screenshotURL": "data/images/images-8kk1q0vbaljeoqim3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BGupQRTNK2asdNESp/art.json b/art/BGupQRTNK2asdNESp/art.json index 897c4672..ab190d5e 100644 --- a/art/BGupQRTNK2asdNESp/art.json +++ b/art/BGupQRTNK2asdNESp/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sergioerick", "avatarUrl": "https://lh6.googleusercontent.com/-6mWCYE7e8JE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcnyCK5B6N4hdhN62pAcPOwiFeA5g/mo/photo.jpg", - "settings": "{\"num\":7000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main(){\\n\\tfloat width = 10.0;\\n\\tfloat circumPoints = 40.0;\\n \\tfloat PI = 3.14159;\\n\\n\\tfloat gridId = floor(vertexId/(circumPoints));\\n \\n\\tfloat xGrid = mod(gridId, width);\\n\\tfloat yGrid = floor(gridId / width);\\n\\n\\tfloat uGrid = xGrid / (width - 1.0);\\n\\tfloat vGrid = yGrid / (width - 1.0);\\n\\n\\tfloat circleId = mod(vertexId, circumPoints);\\n\\n\\tfloat xCircle = floor(circleId/ 2.0);\\n\\tfloat yCircle = mod(vertexId, 2.0);\\n \\n\\tfloat angle = xCircle / ((circumPoints-2.0)/2.0) * radians(360.0);\\n\\n\\tfloat radius = 2.0 - yCircle;\\n \\n\\tfloat uCircle = radius * cos(angle);\\n\\tfloat vCircle = radius * sin(angle);\\n \\n\\tfloat xOffset = cos(time + yGrid * 0.2) * 0.1;\\n\\tfloat yOffset = cos(time + xGrid * 0.3) * 0.2;\\n \\n\\tfloat ux = uGrid * 2.0 - 1.0 + xOffset + uCircle*0.05;\\n\\tfloat vy = vGrid * 2.0 - 1.0 + yOffset + vCircle*0.05;\\n \\n\\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\tgl_Position = vec4(xy, 0.0, 1.0);\\n\\tgl_PointSize = 5.0;\\n\\tv_color = vec4(1.0, 0.0, 0.0,1.0);\\n}\"}", + "settings": { + "num": 7000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main(){\n\tfloat width = 10.0;\n\tfloat circumPoints = 40.0;\n \tfloat PI = 3.14159;\n\n\tfloat gridId = floor(vertexId/(circumPoints));\n \n\tfloat xGrid = mod(gridId, width);\n\tfloat yGrid = floor(gridId / width);\n\n\tfloat uGrid = xGrid / (width - 1.0);\n\tfloat vGrid = yGrid / (width - 1.0);\n\n\tfloat circleId = mod(vertexId, circumPoints);\n\n\tfloat xCircle = floor(circleId/ 2.0);\n\tfloat yCircle = mod(vertexId, 2.0);\n \n\tfloat angle = xCircle / ((circumPoints-2.0)/2.0) * radians(360.0);\n\n\tfloat radius = 2.0 - yCircle;\n \n\tfloat uCircle = radius * cos(angle);\n\tfloat vCircle = radius * sin(angle);\n \n\tfloat xOffset = cos(time + yGrid * 0.2) * 0.1;\n\tfloat yOffset = cos(time + xGrid * 0.3) * 0.2;\n \n\tfloat ux = uGrid * 2.0 - 1.0 + xOffset + uCircle*0.05;\n\tfloat vy = vGrid * 2.0 - 1.0 + yOffset + vCircle*0.05;\n \n\tvec2 xy = vec2(ux, vy) * 1.3;\n \n\tgl_Position = vec4(xy, 0.0, 1.0);\n\tgl_PointSize = 5.0;\n\tv_color = vec4(1.0, 0.0, 0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-6tntp9polvckce7ew-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BJohDPg4F2NmwfsEC/art.json b/art/BJohDPg4F2NmwfsEC/art.json index 42ebef48..3f8c1b71 100644 --- a/art/BJohDPg4F2NmwfsEC/art.json +++ b/art/BJohDPg4F2NmwfsEC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.9921568627450981,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize);// *resolution.x/resolution.y);\\n \\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);// * (across/resolution.x);// (across - 1.0);\\n float v = (y /down);// * (across/resolution.x);// (down - 1.0);\\n \\n float ux = ((u * (across/resolution.x))* 2.0 - 1.0* (across/resolution.x));//(u * 2.0 - 1.0) * (across/resolution.x);\\n float vy = (v * (across/resolution.x )* 2.0 - 1.0* (across/resolution.x));//(v * 2.0 - 1.0) * (across/resolution.x);\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n //apply fragment logic\\n\\n\\t//float colorCount = 8.;//+ snd/10.;\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n \\n /*\\n if(v>0.5)\\n {\\n\\n position.x = mod(position.x,0.5);\\n }\\n*/\\n if(v>0.5)\\n position.y = (1. -position.y);\\n \\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\t//j *= 1.;\\n\\tj = mod(j + time, 1.0);\\n\\t\\n\\tfloat i = mod(position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\\n\\t\\n i = mod(position.y * 7. * j, i / j);\\n \\n\\ti *= 5.;\\n\\t\\n\\t//i = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 1.;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\\n \\n //if(v_color == vec4(1.,1.,1.,1.))\\n //gl_Position.x = distance(vec2(ux,vy), vec2(0.,0.));\\n //gl_Position.y = distance(vec2(vy,ux), vec2(0.,0.));\\n //if(v>0.5)\\n // v_color = vec4( vec3(0.,0.,0.), 1.0 );\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.9921568627450981, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize);// *resolution.x/resolution.y);\n \n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);// * (across/resolution.x);// (across - 1.0);\n float v = (y /down);// * (across/resolution.x);// (down - 1.0);\n \n float ux = ((u * (across/resolution.x))* 2.0 - 1.0* (across/resolution.x));//(u * 2.0 - 1.0) * (across/resolution.x);\n float vy = (v * (across/resolution.x )* 2.0 - 1.0* (across/resolution.x));//(v * 2.0 - 1.0) * (across/resolution.x);\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n //apply fragment logic\n\n\t//float colorCount = 8.;//+ snd/10.;\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n \n /*\n if(v>0.5)\n {\n\n position.x = mod(position.x,0.5);\n }\n*/\n if(v>0.5)\n position.y = (1. -position.y);\n \n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\t//j *= 1.;\n\tj = mod(j + time, 1.0);\n\t\n\tfloat i = mod(position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\n\t\n i = mod(position.y * 7. * j, i / j);\n \n\ti *= 5.;\n\t\n\t//i = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 1.;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\n \n //if(v_color == vec4(1.,1.,1.,1.))\n //gl_Position.x = distance(vec2(ux,vy), vec2(0.,0.));\n //gl_Position.y = distance(vec2(vy,ux), vec2(0.,0.));\n //if(v>0.5)\n // v_color = vec4( vec3(0.,0.,0.), 1.0 );\n\n}" + }, "screenshotURL": "data/images/images-dvwb9p0uzwcrngetg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BKz7wnibraTYy2v8H/art.json b/art/BKz7wnibraTYy2v8H/art.json index 0877bc85..cab2eb28 100644 --- a/art/BKz7wnibraTYy2v8H/art.json +++ b/art/BKz7wnibraTYy2v8H/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "floppafilms google emails", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocIuaBwUR9c6Zno3BImNS0s8sMlZcGj0gBrDxanr22L0IECUEO0=s96-c", - "settings": "{\"num\":28423,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user-458550313/whats-up\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nV V SSSSSS A\\n V V S A A\\n V V S A A\\n V V S AAAAAAA\\n V SSSSS A A\\n\\nvsa is awesome\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n\\tvec3 cameraEyeVec = vec3(0,0,0);\\n \\tfloat snd = texture2D(sound,vec2(mix(0.1,0.25,time),(vertexId/vertexCount)*.2)).a;\\n \\tv_color = vec4(1,snd,0,1);\\n}\"}", + "settings": { + "num": 28423, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user-458550313/whats-up", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nV V SSSSSS A\n V V S A A\n V V S A A\n V V S AAAAAAA\n V SSSSS A A\n\nvsa is awesome\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\nvoid main() {\n\tvec3 cameraEyeVec = vec3(0,0,0);\n \tfloat snd = texture2D(sound,vec2(mix(0.1,0.25,time),(vertexId/vertexCount)*.2)).a;\n \tv_color = vec4(1,snd,0,1);\n}" + }, "screenshotURL": "data/images/images-n19d4nevatvlfabzc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BLAH5H2ctKjDqzabc/art.json b/art/BLAH5H2ctKjDqzabc/art.json index 626e50d3..2d6e502c 100644 --- a/art/BLAH5H2ctKjDqzabc/art.json +++ b/art/BLAH5H2ctKjDqzabc/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jemin.Shin\\n//Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Date : 2023 Spring \\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2.0 - 1.0 * xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux , vy);\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x * y * .02) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time +v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.0);\\n\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jemin.Shin\n//Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Date : 2023 Spring \n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2.0 - 1.0 * xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux , vy);\n \n \tgl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x * y * .02) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time +v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time + v * u * 20.0);\n\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-sveqeipcvgu3a9nzf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BLDrqiy2zPooeqXyA/art.json b/art/BLDrqiy2zPooeqXyA/art.json index 8580bb6e..7a1c96ff 100644 --- a/art/BLDrqiy2zPooeqXyA/art.json +++ b/art/BLDrqiy2zPooeqXyA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":70652,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/charliebeale/charlie-beale-planet-funk\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19607843137254902,0.2627450980392157,0.49411764705882355,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define parameter0 3.//KParameter0 -1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.03, 0.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, sin(22.0 -1.0) * 3.0, 0.2);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 116.0 / K.www / parameter0);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20 * parameter1, 0.8), c.x +c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, parameter3,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target +parameter5);\\n vec3 xAxis = normalize(cross(up, zAxis -parameter4));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137 * parameter5));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3. *parameter6), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123*parameter7);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5* parameter1;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float numStars = floor(vertexCount / 3.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n float s = texture2D(sound, vec2(\\n mix(0.02, 0.5, h),\\n mix(0.0, 0.05, starV))).a;\\n \\n \\n float pId = mod(vertexId, 3.);\\n float sz = pow(s + 0.25, 5.) * 10.;\\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n \\n float hue = time * .1 + h * .2;\\n float sat = 1.;\\n float val = pow(s + 0.4, 5.);\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n float pump = step(.8, s);\\n color = mix(color, vec4(1, 0, 0, 1), pump);\\n color.a = mix(1., 0.2, pow(s, 5.));\\n color.rgb *= color.a;\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.125;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 70652, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/charliebeale/charlie-beale-planet-funk", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19607843137254902, + 0.2627450980392157, + 0.49411764705882355, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define parameter0 3.//KParameter0 -1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.03, 0.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, sin(22.0 -1.0) * 3.0, 0.2);\n vec3 p = abs(fract(c.xxx + K.xyz) * 116.0 / K.www / parameter0);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20 * parameter1, 0.8), c.x +c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, parameter3,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target +parameter5);\n vec3 xAxis = normalize(cross(up, zAxis -parameter4));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137 * parameter5));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3. *parameter6), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123*parameter7);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5* parameter1;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float numStars = floor(vertexCount / 3.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n float s = texture2D(sound, vec2(\n mix(0.02, 0.5, h),\n mix(0.0, 0.05, starV))).a;\n \n \n float pId = mod(vertexId, 3.);\n float sz = pow(s + 0.25, 5.) * 10.;\n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n \n float hue = time * .1 + h * .2;\n float sat = 1.;\n float val = pow(s + 0.4, 5.);\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n float pump = step(.8, s);\n color = mix(color, vec4(1, 0, 0, 1), pump);\n color.a = mix(1., 0.2, pow(s, 5.));\n color.rgb *= color.a;\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.125;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-c2u33n1eb4xw2bic4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BM7xSvMgutERFmdBd/art.json b/art/BM7xSvMgutERFmdBd/art.json index 621669ea..35e4b971 100644 --- a/art/BM7xSvMgutERFmdBd/art.json +++ b/art/BM7xSvMgutERFmdBd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bottomforty/bottom-forty-mix-038-chris-camplin\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n \\t// \\n \\tfloat cols = floor(sqrt(vertexCount));\\n \\tfloat rows = floor(vertexCount / cols);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = 0.;//sin(PI * time * 1.5 + y * 0.25) * 0.1;\\n \\tfloat yOff = 0.; //sin(time + x * 0.25) * 0.2;\\n \\tfloat soff = 0.; //sin(time * x * y * 0.0005) * 0.5;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\\\\\n \\t// sound\\n\\n float ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.25;\\n\\n \\t// concentrate on center\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\n // circular - atan returns values between PI & -PI\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tvec4 pos = vec4(xy, 0, 1);\\n \\t//pos *= rotX(PI * snd * 0.1);\\n \\t//pos *= rotY(PI * snd * 0.1);\\n \\n\\tgl_Position = pos;\\n \\tgl_PointSize = snd * 45.0 + soff; \\n \\tgl_PointSize *= 20.0 / cols * 0.05 + snd; \\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tfloat pump = step(0.8, snd);\\n float hue = u * 0.1 * snd + 0.2 + time * 0.1;\\n hue = smoothstep(x, y, pump);\\n float sat = mix(0., 1.0, pump);\\n \\t// add more impact using pow\\n float val = pow(snd + 0.1, 5.0);\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(PI * snd);\\n //background += 0.1;\\n //vec4 finalColor = mix(color, background, s);\\n\\n v_color = color;\\n }\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/bottomforty/bottom-forty-mix-038-chris-camplin", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n \t// \n \tfloat cols = floor(sqrt(vertexCount));\n \tfloat rows = floor(vertexCount / cols);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = 0.;//sin(PI * time * 1.5 + y * 0.25) * 0.1;\n \tfloat yOff = 0.; //sin(time + x * 0.25) * 0.2;\n \tfloat soff = 0.; //sin(time * x * y * 0.0005) * 0.5;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\\\n \t// sound\n\n float ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n \n \tvec2 xy = vec2(ux, vy) * 1.25;\n\n \t// concentrate on center\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat su = abs(u - 0.5) * 2.0;\n \n // circular - atan returns values between PI & -PI\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tvec4 pos = vec4(xy, 0, 1);\n \t//pos *= rotX(PI * snd * 0.1);\n \t//pos *= rotY(PI * snd * 0.1);\n \n\tgl_Position = pos;\n \tgl_PointSize = snd * 45.0 + soff; \n \tgl_PointSize *= 20.0 / cols * 0.05 + snd; \n \tgl_PointSize *= resolution.x / 600.;\n \n \tfloat pump = step(0.8, snd);\n float hue = u * 0.1 * snd + 0.2 + time * 0.1;\n hue = smoothstep(x, y, pump);\n float sat = mix(0., 1.0, pump);\n \t// add more impact using pow\n float val = pow(snd + 0.1, 5.0);\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(PI * snd);\n //background += 0.1;\n //vec4 finalColor = mix(color, background, s);\n\n v_color = color;\n }" + }, "screenshotURL": "data/images/images-i8zmax80yl0ji8k4b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BN8A2f8DcC5htsq6T/art.json b/art/BN8A2f8DcC5htsq6T/art.json index 6812bc83..6282677b 100644 --- a/art/BN8A2f8DcC5htsq6T/art.json +++ b/art/BN8A2f8DcC5htsq6T/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":679,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.11372549019607843,0.3843137254901961,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / across;\\n float v = y / across;\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 679, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.11372549019607843, + 0.3843137254901961, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / across;\n float v = y / across;\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-kzeo5244lld5esh30-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BQfE2RPMyeRH9tMQn/art.json b/art/BQfE2RPMyeRH9tMQn/art.json index 25fd9d83..a8d5d692 100644 --- a/art/BQfE2RPMyeRH9tMQn/art.json +++ b/art/BQfE2RPMyeRH9tMQn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nfloat segment(vec2 p, vec2 a, vec2 b) {\\n vec2 ab = b - a;\\n vec2 ap = p - a;\\n float k = clamp(dot(ap, ab)/dot(ab, ab), 0.0, 1.0);\\n return smoothstep(0.0, 5.0/resolution.y, length(ap - k*ab) - 0.001);\\n}\\n\\nfloat shape(float u,vec2 p, float angle) {\\n float d = 100.0;\\n vec2 a = vec2(1.0, 0.0), b;\\n vec2 rot = vec2(cos(angle), sin(angle)*u);\\n \\n for (int i = 0; i < 6; ++i) {\\n b = a;\\n for (int j = 0; j < 18; ++j) {\\n \\tb = vec2(b.x*rot.x - b.y*rot.y, b.x*rot.y + b.y*rot.x);\\n \\td = min(d, segment(p, a, b));\\n }\\n a = vec2(a.x*rot.x - a.y*rot.y, a.x*rot.y + a.y*rot.x);\\n }\\n return d;\\n}\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n \\n //apply fragment logic\\n\\n\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\t\\tvec2 uv = p.xy / res.xy;\\n vec2 cc = (-res.xy + 2.0*p.xy) / res.y;\\n \\n float numPhases=1114.5;\\n float u1;\\n float t;\\n float SpeedReal=0.2532;\\n u1=0.005+(snd/1.*2.2);\\n t = snd/1./res.x * numPhases;\\n\\n float col = shape(u1,abs(cc), t+cos(0.01*(time*SpeedReal))*TAU);\\n col *= 0.5 + 1.5*pow(uv.x*uv.y*(1.0-uv.x)*(1.0-uv.y), 0.3);\\n \\n \\n\\t//gl_FragColor = vec4(vec3(pow(1.0-col, 2.15)),1.0);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(pow(1.0-col, 2.15)),1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nfloat segment(vec2 p, vec2 a, vec2 b) {\n vec2 ab = b - a;\n vec2 ap = p - a;\n float k = clamp(dot(ap, ab)/dot(ab, ab), 0.0, 1.0);\n return smoothstep(0.0, 5.0/resolution.y, length(ap - k*ab) - 0.001);\n}\n\nfloat shape(float u,vec2 p, float angle) {\n float d = 100.0;\n vec2 a = vec2(1.0, 0.0), b;\n vec2 rot = vec2(cos(angle), sin(angle)*u);\n \n for (int i = 0; i < 6; ++i) {\n b = a;\n for (int j = 0; j < 18; ++j) {\n \tb = vec2(b.x*rot.x - b.y*rot.y, b.x*rot.y + b.y*rot.x);\n \td = min(d, segment(p, a, b));\n }\n a = vec2(a.x*rot.x - a.y*rot.y, a.x*rot.y + a.y*rot.x);\n }\n return d;\n}\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n \n //apply fragment logic\n\n\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\t\tvec2 uv = p.xy / res.xy;\n vec2 cc = (-res.xy + 2.0*p.xy) / res.y;\n \n float numPhases=1114.5;\n float u1;\n float t;\n float SpeedReal=0.2532;\n u1=0.005+(snd/1.*2.2);\n t = snd/1./res.x * numPhases;\n\n float col = shape(u1,abs(cc), t+cos(0.01*(time*SpeedReal))*TAU);\n col *= 0.5 + 1.5*pow(uv.x*uv.y*(1.0-uv.x)*(1.0-uv.y), 0.3);\n \n \n\t//gl_FragColor = vec4(vec3(pow(1.0-col, 2.15)),1.0);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(pow(1.0-col, 2.15)),1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-9jpkgzkukpbkypabl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BQuWCvhCBBif7Zzmh/art.json b/art/BQuWCvhCBBif7Zzmh/art.json index 8c4df25d..f9a4dc2e 100644 --- a/art/BQuWCvhCBBif7Zzmh/art.json +++ b/art/BQuWCvhCBBif7Zzmh/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "sergio", "avatarUrl": "https://lh3.googleusercontent.com/-ucGyGVQ6Moo/AAAAAAAAAAI/AAAAAAAAAAA/LuTuKwPIKbA/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() \\n{\\n\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor (vertexId /3.0), 2.0);\\n \\n float angle = ux /20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n vec2 xy = vec2(x,y);\\n \\n gl_Position= vec4(xy * 0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() \n{\n\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor (vertexId /3.0), 2.0);\n \n float angle = ux /20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n vec2 xy = vec2(x,y);\n \n gl_Position= vec4(xy * 0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-klahmu0tk9exauxep-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BQz5ngcrNuq9dcBHP/art.json b/art/BQz5ngcrNuq9dcBHP/art.json index 9ea5af8f..79040464 100644 --- a/art/BQz5ngcrNuq9dcBHP/art.json +++ b/art/BQz5ngcrNuq9dcBHP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 5.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float sizeFactor = 1./20.;\\n float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n vec3 eye = vec3(0., 2., -1.2);\\n \\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 5.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float sizeFactor = 1./20.;\n float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n vec3 eye = vec3(0., 2., -1.2);\n \n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-gk2nw385rlwmcr8j6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BRW6CMT6qxyD5Qxs3/art.json b/art/BRW6CMT6qxyD5Qxs3/art.json index ee671840..e4257ffe 100644 --- a/art/BRW6CMT6qxyD5Qxs3/art.json +++ b/art/BRW6CMT6qxyD5Qxs3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/doornrecords/david-tort-our-love\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️ */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float maxPoints = vertexCount;\\n float numPoints = mix(2030., maxPoints, sin(time * .1) * .5 + .5);\\n float pointId = vertexId; \\n float mv = numPoints / maxPoints;\\n \\n if (pointId > numPoints) {\\n gl_Position = vec4(0, 1., 100, 1);\\n return;\\n }\\n\\n vec3 loc = fibonacciSphere(numPoints, pointId);\\n\\n float cv = pointId / numPoints;\\n float su = fract(cv + -time);\\n //su = hash(cubeId / maxCubes);\\n \\n float tm = time * .0;\\n float r = 30.;\\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - cv, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(time * 0.37);\\n mat *= rotY(time * 0.21);\\n \\n float s2 = texture2D(sound, vec2(0.5, 0.)).a * 2.;\\n \\n float s = texture2D(sound, vec2(fract(cv * mix(3., 20., fract(s2))),0)).a;\\n \\n \\n gl_Position = mat * vec4(loc * mix(25., 35., pow(s, 5.)), 1);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float pm = step(0.5, s);\\n\\n float hue = .4 + floor(pow(s, 5.) * 20.) * .33 + time * 0.1;\\n float sat = 1.0 + pow(s + .5, 5.);\\n float val = pm;\\n v_color.rgb = hsv2rgb(vec3(hue, sat, val));\\n v_color.a = 1.;\\n v_color.rgb *= v_color.a; \\n \\n gl_PointSize = mix(6., 0.1, 1. - pow(1. - mv, 1.5));\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/doornrecords/david-tort-our-love", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️ */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float maxPoints = vertexCount;\n float numPoints = mix(2030., maxPoints, sin(time * .1) * .5 + .5);\n float pointId = vertexId; \n float mv = numPoints / maxPoints;\n \n if (pointId > numPoints) {\n gl_Position = vec4(0, 1., 100, 1);\n return;\n }\n\n vec3 loc = fibonacciSphere(numPoints, pointId);\n\n float cv = pointId / numPoints;\n float su = fract(cv + -time);\n //su = hash(cubeId / maxCubes);\n \n float tm = time * .0;\n float r = 30.;\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - cv, 10.));\n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(time * 0.37);\n mat *= rotY(time * 0.21);\n \n float s2 = texture2D(sound, vec2(0.5, 0.)).a * 2.;\n \n float s = texture2D(sound, vec2(fract(cv * mix(3., 20., fract(s2))),0)).a;\n \n \n gl_Position = mat * vec4(loc * mix(25., 35., pow(s, 5.)), 1);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float pm = step(0.5, s);\n\n float hue = .4 + floor(pow(s, 5.) * 20.) * .33 + time * 0.1;\n float sat = 1.0 + pow(s + .5, 5.);\n float val = pm;\n v_color.rgb = hsv2rgb(vec3(hue, sat, val));\n v_color.a = 1.;\n v_color.rgb *= v_color.a; \n \n gl_PointSize = mix(6., 0.1, 1. - pow(1. - mv, 1.5));\n}\n\n" + }, "screenshotURL": "data/images/images-3xf5ovy992aqezssq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BSig2nJzr4kavRSF2/art.json b/art/BSig2nJzr4kavRSF2/art.json index 34761402..4e249395 100644 --- a/art/BSig2nJzr4kavRSF2/art.json +++ b/art/BSig2nJzr4kavRSF2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Vertexshaderart : Making a Grid\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n float u = x/(across-1.);\\n float v = y/(across -1.);\\n float ux =u*2.-1.;\\n float vy = v*2.-1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize +=20./across;\\n gl_PointSize += resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Vertexshaderart : Making a Grid\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n float u = x/(across-1.);\n float v = y/(across -1.);\n float ux =u*2.-1.;\n float vy = v*2.-1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n gl_PointSize +=20./across;\n gl_PointSize += resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-btltjypsix9rayu7h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BTbTTkxMnk4AfcjGJ/art.json b/art/BTbTTkxMnk4AfcjGJ/art.json index 58ec227e..357a9194 100644 --- a/art/BTbTTkxMnk4AfcjGJ/art.json +++ b/art/BTbTTkxMnk4AfcjGJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Exercise - VertexShaderart : Motion\\n// Course : CS250\\n// Term & Year : 2023 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 5. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.5;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.05) * 5.;\\n \\n gl_PointSize = abs(sin(time)) * 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 400.;\\n \\n v_color = vec4(0.5, abs(cos(time)), sin(time), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Exercise - VertexShaderart : Motion\n// Course : CS250\n// Term & Year : 2023 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 5. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.5;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.05) * 5.;\n \n gl_PointSize = abs(sin(time)) * 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 400.;\n \n v_color = vec4(0.5, abs(cos(time)), sin(time), 1);\n}" + }, "screenshotURL": "data/images/images-axufmrhgzptx3fjz8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BWsfEAmCvR9m9NTF8/art.json b/art/BWsfEAmCvR9m9NTF8/art.json index 6eb18848..3481d995 100644 --- a/art/BWsfEAmCvR9m9NTF8/art.json +++ b/art/BWsfEAmCvR9m9NTF8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":95021,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09019607843137255,0.08235294117647059,0.09019607843137255,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], -3.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -1. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.12, mod(circleId, 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.0203) * 1.4;\\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 2.79));\\n float sat = 0.9 - circleId;\\n float val = .75;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - 1.9, -22.20));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 95021, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09019607843137255, + 0.08235294117647059, + 0.09019607843137255, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], -3.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -1. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.12, mod(circleId, 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.0203) * 1.4;\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 2.79));\n float sat = 0.9 - circleId;\n float val = .75;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - 1.9, -22.20));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-a7f0eppbouk5nbshe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BXfAoqsFbSNtWvJaQ/art.json b/art/BXfAoqsFbSNtWvJaQ/art.json index 07fa1cff..4c21c85d 100644 --- a/art/BXfAoqsFbSNtWvJaQ/art.json +++ b/art/BXfAoqsFbSNtWvJaQ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"// Taking control - the moving grid\\n\\nvoid main() {\\n float scale = 1.5;\\n float modi = 0.5 * (sin(time)+1.);\\n float grid = floor(modi * 50.) + 50.;\\n float xoff = -0.5 * scale;\\n float yoff = -0.5 * scale;\\n float x = mod(vertexId , grid);\\n float y = mod(floor(vertexId / grid), grid);\\n float ux = x * scale / grid + xoff;\\n float uy = y * scale / grid + yoff;\\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = 300./grid;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "// Taking control - the moving grid\n\nvoid main() {\n float scale = 1.5;\n float modi = 0.5 * (sin(time)+1.);\n float grid = floor(modi * 50.) + 50.;\n float xoff = -0.5 * scale;\n float yoff = -0.5 * scale;\n float x = mod(vertexId , grid);\n float y = mod(floor(vertexId / grid), grid);\n float ux = x * scale / grid + xoff;\n float uy = y * scale / grid + yoff;\n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = 300./grid;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ffg3aodtuqi7gu0zs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BZMNQR7kcPSCCwyHL/art.json b/art/BZMNQR7kcPSCCwyHL/art.json index 38032272..e057bb89 100644 --- a/art/BZMNQR7kcPSCCwyHL/art.json +++ b/art/BZMNQR7kcPSCCwyHL/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via SoShade\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nfloat df(vec2 p)\\n{\\n\\treturn length(p) - 0.5;\\n}\\n\\nvec3 getQuad(float idx)\\n{\\n\\tfloat quadIndex = floor(idx / 6.);\\n\\t\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 pos = vec2(0);\\n\\tif (index == 0.) pos = vec2(0,0);\\n\\tif (index == 1.) pos = vec2(1,0);\\n\\tif (index == 2.) pos = vec2(1,1);\\n\\t\\n\\tif (index == 3.) pos = vec2(0,0);\\n\\tif (index == 4.) pos = vec2(1,1);\\n\\tif (index == 5.) pos = vec2(0,1);\\n\\t\\n\\treturn vec3(pos, quadIndex);\\n}\\n\\nvec2 getGridMesh(float idx, float countQuadX)\\n{\\n\\tvec3 pi = getQuad(idx);\\n\\t\\n\\tpi.x += mod(pi.z, countQuadX);\\n\\tpi.y += floor(pi.z / countQuadX);\\n\\t\\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\n\\tpi.x -= nx * 0.5;\\n\\tpi.y -= ny * 0.5;\\n\\t\\n\\treturn pi.xy;\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 3.;\\n\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat edgeSize = floor( sqrt(countMax) );\\n\\tvec2 pg = getGridMesh(vertexId, edgeSize);\\n\\t\\n\\tfloat t = time;\\n\\t\\n\\tfloat r = length(pg);\\n\\tvec3 p = vec3(pg.x, cos(t*10.+r) * 5., pg.y);\\n\\tp.xz += df(p.xz) * sign(p.xz);\\n\\tfloat a = r * 0.04 * sin(t * 0.3);\\n\\tp.xz *= mat2(cos(a),-sin(a),sin(a),cos(a));\\n\\t\\n\\tv_color = vec4(0.8, p.y, 0.5, 1);\\n\\t\\n\\tp.y -= r*cos(r*0.05);\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 0.;\\n\\tfloat cd = 500.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tgl_Position = camera * vec4(p, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via SoShade\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nfloat df(vec2 p)\n{\n\treturn length(p) - 0.5;\n}\n\nvec3 getQuad(float idx)\n{\n\tfloat quadIndex = floor(idx / 6.);\n\t\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 pos = vec2(0);\n\tif (index == 0.) pos = vec2(0,0);\n\tif (index == 1.) pos = vec2(1,0);\n\tif (index == 2.) pos = vec2(1,1);\n\t\n\tif (index == 3.) pos = vec2(0,0);\n\tif (index == 4.) pos = vec2(1,1);\n\tif (index == 5.) pos = vec2(0,1);\n\t\n\treturn vec3(pos, quadIndex);\n}\n\nvec2 getGridMesh(float idx, float countQuadX)\n{\n\tvec3 pi = getQuad(idx);\n\t\n\tpi.x += mod(pi.z, countQuadX);\n\tpi.y += floor(pi.z / countQuadX);\n\t\n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadX;\n\tfloat ny = floor(countQuads / nx);\n\t\n\tpi.x -= nx * 0.5;\n\tpi.y -= ny * 0.5;\n\t\n\treturn pi.xy;\n}\n\nvoid main()\n{\n\tgl_PointSize = 3.;\n\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat edgeSize = floor( sqrt(countMax) );\n\tvec2 pg = getGridMesh(vertexId, edgeSize);\n\t\n\tfloat t = time;\n\t\n\tfloat r = length(pg);\n\tvec3 p = vec3(pg.x, cos(t*10.+r) * 5., pg.y);\n\tp.xz += df(p.xz) * sign(p.xz);\n\tfloat a = r * 0.04 * sin(t * 0.3);\n\tp.xz *= mat2(cos(a),-sin(a),sin(a),cos(a));\n\t\n\tv_color = vec4(0.8, p.y, 0.5, 1);\n\t\n\tp.y -= r*cos(r*0.05);\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 0.;\n\tfloat cd = 500.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tgl_Position = camera * vec4(p, 1);\n}" + }, "screenshotURL": "data/images/images-fzjtedu0vb343va4k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BZdvckJFNr53H6kXS/art.json b/art/BZdvckJFNr53H6kXS/art.json index 598503e9..a3d68393 100644 --- a/art/BZdvckJFNr53H6kXS/art.json +++ b/art/BZdvckJFNr53H6kXS/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float uy = v * 2. - 1.;\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n \\n gl_Position = vec4(ux,uy,0,1);\\n \\n v_color = vec4(1,0,0,1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float uy = v * 2. - 1.;\n \n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n \n gl_Position = vec4(ux,uy,0,1);\n \n v_color = vec4(1,0,0,1);\n}\n" + }, "screenshotURL": "data/images/images-qbd29ztvxq5om2m08-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BbBW5veDzWe2oqN7F/art.json b/art/BbBW5veDzWe2oqN7F/art.json index 81cc0e89..f3766386 100644 --- a/art/BbBW5veDzWe2oqN7F/art.json +++ b/art/BbBW5veDzWe2oqN7F/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "다은", "avatarUrl": "https://lh3.googleusercontent.com/--VGFNmU3UuQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rekfGpN6byv9fIvs3pAjQAlrfA__A/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// your name (daeun Jeong)\\n// the assignment number (03)\\n// the course name (CS230)\\n// the term (Spring 2019)\\n\\nvoid main() \\n{ \\n float xOff = sin(time) * 0.2;\\n \\n float yOff = cos(time) * 0.2;\\n \\n float blueOff = abs(cos(time));\\n \\n float alphaOff = abs(sin(time)) + 0.5;\\n \\n float sizeOff = abs(sin(time)) * 10.0 + 10.0;\\n \\n vec4 pos = vec4(mouse.x + xOff, mouse.y + yOff, 0.0, 1.0);\\n \\n gl_Position = pos;\\n \\n gl_PointSize = sizeOff;\\n \\n v_color = vec4(0.1, 0.1, blueOff, alphaOff);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// your name (daeun Jeong)\n// the assignment number (03)\n// the course name (CS230)\n// the term (Spring 2019)\n\nvoid main() \n{ \n float xOff = sin(time) * 0.2;\n \n float yOff = cos(time) * 0.2;\n \n float blueOff = abs(cos(time));\n \n float alphaOff = abs(sin(time)) + 0.5;\n \n float sizeOff = abs(sin(time)) * 10.0 + 10.0;\n \n vec4 pos = vec4(mouse.x + xOff, mouse.y + yOff, 0.0, 1.0);\n \n gl_Position = pos;\n \n gl_PointSize = sizeOff;\n \n v_color = vec4(0.1, 0.1, blueOff, alphaOff);\n}" + }, "screenshotURL": "data/images/images-6k5lpd957exe7mumy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Be7qcEqHTfnXmi3nw/art.json b/art/Be7qcEqHTfnXmi3nw/art.json index a0746a74..41da10b3 100644 --- a/art/Be7qcEqHTfnXmi3nw/art.json +++ b/art/Be7qcEqHTfnXmi3nw/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":94567,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09019607843137255,0.08235294117647059,0.09019607843137255,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], -3.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -1. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.12, mod(circleId, 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.0203) * 1.4;\\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 2.79));\\n float sat = 0.9 - circleId;\\n float val = .75;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9, 0.2));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 94567, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09019607843137255, + 0.08235294117647059, + 0.09019607843137255, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], -3.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -1. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.12, mod(circleId, 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.0203) * 1.4;\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 2.79));\n float sat = 0.9 - circleId;\n float val = .75;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9, 0.2));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-4larhn5wdg273mplj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BeRGRuNpszfDv7foC/art.json b/art/BeRGRuNpszfDv7foC/art.json index 283897c8..5966e8b8 100644 --- a/art/BeRGRuNpszfDv7foC/art.json +++ b/art/BeRGRuNpszfDv7foC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6829,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/rrhizomee/chunky-from-the-front-ft-lotic-and-sami-baha\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-0.5, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu *2. + gv *2.06 * time * .13 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv * .13),\\n crv(cv * .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(45.0), resolution.x / resolution.y, 0.21, 666.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0.0 - gv);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * (tm * 2.), tm - gv * up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 4.5);\\n mat *= p4;\\n mat *= uniformScale(mix(0.1, 0.301, pow(s + gv + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 6829, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/rrhizomee/chunky-from-the-front-ft-lotic-and-sami-baha", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-0.5, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu *2. + gv *2.06 * time * .13 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv * .13),\n crv(cv * .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(45.0), resolution.x / resolution.y, 0.21, 666.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0.0 - gv);\n \n mat4 p4 = lookAt(p2 * 2., p3 * (tm * 2.), tm - gv * up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 4.5);\n mat *= p4;\n mat *= uniformScale(mix(0.1, 0.301, pow(s + gv + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-y9ltgun6bjv5b3wx0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BfGdpEhnBZQzXay29/art.json b/art/BfGdpEhnBZQzXay29/art.json index 0381ebe0..55621f8c 100644 --- a/art/BfGdpEhnBZQzXay29/art.json +++ b/art/BfGdpEhnBZQzXay29/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":12004,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/plu-collective/circuitry\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Lesson 05a\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / 20. * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n \\n return vec2(x, y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId, \\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .09, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.1 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 12004, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/plu-collective/circuitry", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Lesson 05a\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / 20. * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n \n return vec2(x, y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId, \n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .09, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.1 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-msy3lmfgyfzvwafip-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BgAawjJRKx45XRyiN/art.json b/art/BgAawjJRKx45XRyiN/art.json index 05cb1106..fa54ce29 100644 --- a/art/BgAawjJRKx45XRyiN/art.json +++ b/art/BgAawjJRKx45XRyiN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "taejukwon-digipen", "avatarUrl": "https://avatars.githubusercontent.com/taejuKwon-digipen?s=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Taeju Kwon\\n//02_Motion\\n//Spring_2022\\n//CS250\\n\\n\\nvoid main()\\n{\\n float down = floor (sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n \\n float x = mod (vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0,1);\\n \\n float soff = sin(time + x) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Taeju Kwon\n//02_Motion\n//Spring_2022\n//CS250\n\n\nvoid main()\n{\n float down = floor (sqrt(vertexCount));\n float across = floor(vertexCount /down);\n \n float x = mod (vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0,1);\n \n float soff = sin(time + x) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-gvlkrjic9678ybnf6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BiHH2xPx5dypCCvAu/art.json b/art/BiHH2xPx5dypCCvAu/art.json index 20b17396..fd77ec4c 100644 --- a/art/BiHH2xPx5dypCCvAu/art.json +++ b/art/BiHH2xPx5dypCCvAu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wigae/pilot?si=ef4d51074d414114a40fab77e121ae5d&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// Name : Jemin.Shin\\n// Exercise: Circles from Triangles\\n// Course : CS250\\n// Spring 2023\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = cos(time + y) * 0.3;\\n float yoff = cos(time + x * 0.3) ;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u -.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;\\n \\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;\\n float sat = 1.;\\n float val = mix(.4, pow(snd + .2, 5.), pump);\\n \\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n} \"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wigae/pilot?si=ef4d51074d414114a40fab77e121ae5d&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// Name : Jemin.Shin\n// Exercise: Circles from Triangles\n// Course : CS250\n// Spring 2023\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = cos(time + y) * 0.3;\n float yoff = cos(time + x * 0.3) ;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u -.5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;\n \n\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;\n float sat = 1.;\n float val = mix(.4, pow(snd + .2, 5.), pump);\n \n hue += pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n} " + }, "screenshotURL": "data/images/images-rgkoju8v69vq1th3p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BjFJQPygCx8PB83nv/art.json b/art/BjFJQPygCx8PB83nv/art.json index a6c0fa9e..0b2a64ff 100644 --- a/art/BjFJQPygCx8PB83nv/art.json +++ b/art/BjFJQPygCx8PB83nv/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mayugeman", "avatarUrl": "https://secure.gravatar.com/avatar/1573e2224f853b4df80c89ebf36a159c?default=retro&size=200", - "settings": "{\"num\":612,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3137254901960784,0.3137254901960784,0.3137254901960784,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( s -angle *2.);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n/*\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n*/\\nmat4 trans(vec3 t) {\\n return mat4(\\n 1, 0, 0, t[0],\\n 0, 1, 0, t[1],\\n 0, 0, 1, t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1)*2.5;\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 1, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 2)*1.5;\\n}\\n\\nvec3 circlePoint(float id, float count, float radius, float rings){\\n float ringPtCount = count / rings;\\n float x = mod(id, ringPtCount);\\t\\t// =リング内番号\\n float y = floor(id / ringPtCount);\\t// =リング番号\\n\\n float angle = x / ringPtCount * PI * 2.;\\n float u = cos(angle) * radius * y / (rings - 1.);\\n float v = sin(angle) * radius * y / (rings - 1.);\\n\\n return vec3(u, v, 0);\\n}\\n\\nvec3 donutPoint(float ptId, float ptCount, float radius, float ringCount, float width){\\n float ringPtCount = ptCount / ringCount;\\n float x = mod(ptId, ringPtCount);\\t\\t// =リング内番号\\n float y = floor(ptId / ringPtCount);\\t// =リング番号\\n\\n float angle = x / ringPtCount * PI * 2.;\\n float r = (y / (ringCount - 1.)) * width + (1.-width);\\n float u = cos(angle) * radius * r;\\n float v = sin(angle) * radius * r;\\n \\n return vec3(u, v, 0);\\n}\\n\\nvoid main() {\\n/*\\n float ac = floor(vertexCount / sqrt(vertexCount));\\n\\n float x = fract(vertexId / ac);\\n float y = floor(vertexId / ac) / (ac - 1.); \\n\\n x = x * 2. - 1.;\\n y = y * 2. - 1.;\\n\\n mat4 rotation = rotZ(sin(time*0.5)*PI); \\n*/\\n mat4 rotation = rotZ(sin(time*0.5)*PI*2.); \\n mat4 trans = trans(vec3(sin(time), 0.1, 0));\\n \\n vec3 pos = donutPoint(vertexId, vertexCount,.3, 10., .4);\\n \\n gl_Position = vec4(pos,1) * trans;\\n gl_PointSize = 4.;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 612, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3137254901960784, + 0.3137254901960784, + 0.3137254901960784, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( s -angle *2.);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n/*\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n*/\nmat4 trans(vec3 t) {\n return mat4(\n 1, 0, 0, t[0],\n 0, 1, 0, t[1],\n 0, 0, 1, t[2],\n 0, 0, 0, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1)*2.5;\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, 0, 0, 2);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 1, 0,\n 0, 0, s, 0,\n 0, 0, 0, 2)*1.5;\n}\n\nvec3 circlePoint(float id, float count, float radius, float rings){\n float ringPtCount = count / rings;\n float x = mod(id, ringPtCount);\t\t// =リング内番号\n float y = floor(id / ringPtCount);\t// =リング番号\n\n float angle = x / ringPtCount * PI * 2.;\n float u = cos(angle) * radius * y / (rings - 1.);\n float v = sin(angle) * radius * y / (rings - 1.);\n\n return vec3(u, v, 0);\n}\n\nvec3 donutPoint(float ptId, float ptCount, float radius, float ringCount, float width){\n float ringPtCount = ptCount / ringCount;\n float x = mod(ptId, ringPtCount);\t\t// =リング内番号\n float y = floor(ptId / ringPtCount);\t// =リング番号\n\n float angle = x / ringPtCount * PI * 2.;\n float r = (y / (ringCount - 1.)) * width + (1.-width);\n float u = cos(angle) * radius * r;\n float v = sin(angle) * radius * r;\n \n return vec3(u, v, 0);\n}\n\nvoid main() {\n/*\n float ac = floor(vertexCount / sqrt(vertexCount));\n\n float x = fract(vertexId / ac);\n float y = floor(vertexId / ac) / (ac - 1.); \n\n x = x * 2. - 1.;\n y = y * 2. - 1.;\n\n mat4 rotation = rotZ(sin(time*0.5)*PI); \n*/\n mat4 rotation = rotZ(sin(time*0.5)*PI*2.); \n mat4 trans = trans(vec3(sin(time), 0.1, 0));\n \n vec3 pos = donutPoint(vertexId, vertexCount,.3, 10., .4);\n \n gl_Position = vec4(pos,1) * trans;\n gl_PointSize = 4.;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-bn4atedzqfel67yvg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BjmCAYg9AYobxtkG4/art.json b/art/BjmCAYg9AYobxtkG4/art.json index b7a81429..237a164a 100644 --- a/art/BjmCAYg9AYobxtkG4/art.json +++ b/art/BjmCAYg9AYobxtkG4/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "przemyslawzaworski", "avatarUrl": "https://secure.gravatar.com/avatar/3a3abcfa29dc9b0fa9fd2fb25ff10892?default=retro&size=200", - "settings": "{\"num\":24576,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const mat4 ModelViewProjection = mat4(\\n 0.974278, 0.000000,\\t 0.000000, 0.000000,\\n 0.000000, 1.326827, -0.643173, -0.642787,\\n 0.000000,\\t 1.113340,\\t 0.766504,\\t 0.766044,\\n-14.614178,\\t-9.836445,\\t23.760851,\\t24.346418\\n);\\n\\nvec3 BezierCurve (vec3 a, vec3 b, vec3 c, vec3 d, float t)\\n{\\n float x = a.x * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.x * t * (1.0 - t) * (1.0 - t) + 3.0 * c.x * t * t * (1.0 - t) + d.x * t * t * t;\\n float y = a.y * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.y * t * (1.0 - t) * (1.0 - t) + 3.0 * c.y * t * t * (1.0 - t) + d.y * t * t * t;\\n float z = a.z * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.z * t * (1.0 - t) * (1.0 - t) + 3.0 * c.z * t * t * (1.0 - t) + d.z * t * t * t;\\n return vec3 (x, y, z);\\n}\\n\\nvec3 BezierPatch (float u, float v)\\n{\\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\\n return BezierCurve(a, b, c, d, v);\\n}\\n\\nvec3 BezierPatchNormal (float u, float v)\\n{\\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\\n vec3 dv = -3.0 * (1.0 - v) * (1.0 - v) * a + (3.0 * (1.0 - v) * (1.0 - v) - 6.0 * v * (1.0 - v)) * b + (6.0 * v * (1.0 - v) - 3.0 * v * v) * c + 3.0 * v * v * d;\\n vec3 e = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(00.0, 00.0, 10.0), vec3(00.0, 00.0, 20.0), vec3(00.0, 00.0, 30.0), v);\\n vec3 f = BezierCurve (vec3(10.0, 00.0, 00.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(10.0, 00.0, 30.0), v);\\n vec3 g = BezierCurve (vec3(20.0, 00.0, 00.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(20.0, 00.0, 30.0), v);\\n vec3 h = BezierCurve (vec3(30.0, 00.0, 00.0), vec3(30.0, 00.0, 10.0), vec3(30.0, 00.0, 20.0), vec3(30.0, 00.0, 30.0), v); \\n vec3 du = -3.0 * (1.0 - u) * (1.0 - u) * e + (3.0 * (1.0 - u) * (1.0 - u) - 6.0 * u * (1.0 - u)) * f + (6.0 * u * (1.0 - u) - 3.0 * u * u) * g + 3.0 * u * u * h;\\n return normalize(cross(dv, du));\\n}\\n\\nvec3 hash(float p)\\n{\\n vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973));\\n p3 += dot(p3, p3.yzx+33.33);\\n return fract((p3.xxy+p3.yzz)*p3.zyx); \\n}\\n\\nvoid main() \\n{ \\n int tessellationFactor = 64; // vertex count = _TessellationFactor * _TessellationFactor * 6\\n int instance = int(floor(vertexId / 6.0));\\n float x = sign(mod(float(vertexId), 2.0));\\n float y = sign(mod(126.0, mod(float(vertexId), 6.0) + 6.0));\\n float u = (float(instance / tessellationFactor) + x) / float(tessellationFactor);\\n float v = (mod(float(instance), float(tessellationFactor)) + y) / float(tessellationFactor); \\n gl_Position = ModelViewProjection * vec4(BezierPatch(u,v) , 1); \\n vec3 lightDir = normalize(vec3(10,10,-10));\\n vec3 normalDir = BezierPatchNormal(u,v);\\n float d = max(dot(lightDir, normalDir), 0.2); \\n v_color = vec4(hash(float(instance + 123)), 1.0) * vec4(d, d, d, 1.0);\\n}\"}", + "settings": { + "num": 24576, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const mat4 ModelViewProjection = mat4(\n 0.974278, 0.000000,\t 0.000000, 0.000000,\n 0.000000, 1.326827, -0.643173, -0.642787,\n 0.000000,\t 1.113340,\t 0.766504,\t 0.766044,\n-14.614178,\t-9.836445,\t23.760851,\t24.346418\n);\n\nvec3 BezierCurve (vec3 a, vec3 b, vec3 c, vec3 d, float t)\n{\n float x = a.x * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.x * t * (1.0 - t) * (1.0 - t) + 3.0 * c.x * t * t * (1.0 - t) + d.x * t * t * t;\n float y = a.y * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.y * t * (1.0 - t) * (1.0 - t) + 3.0 * c.y * t * t * (1.0 - t) + d.y * t * t * t;\n float z = a.z * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.z * t * (1.0 - t) * (1.0 - t) + 3.0 * c.z * t * t * (1.0 - t) + d.z * t * t * t;\n return vec3 (x, y, z);\n}\n\nvec3 BezierPatch (float u, float v)\n{\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\n return BezierCurve(a, b, c, d, v);\n}\n\nvec3 BezierPatchNormal (float u, float v)\n{\n vec3 a = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(10.0, 00.0, 00.0), vec3(20.0, 00.0, 00.0), vec3(30.0, 00.0, 00.0), u);\n vec3 b = BezierCurve (vec3(00.0, 00.0, 10.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(30.0, 00.0, 10.0), u);\n vec3 c = BezierCurve (vec3(00.0, 00.0, 20.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(30.0, 00.0, 20.0), u);\n vec3 d = BezierCurve (vec3(00.0, 00.0, 30.0), vec3(10.0, 00.0, 30.0), vec3(20.0, 00.0, 30.0), vec3(30.0, 00.0, 30.0), u);\n vec3 dv = -3.0 * (1.0 - v) * (1.0 - v) * a + (3.0 * (1.0 - v) * (1.0 - v) - 6.0 * v * (1.0 - v)) * b + (6.0 * v * (1.0 - v) - 3.0 * v * v) * c + 3.0 * v * v * d;\n vec3 e = BezierCurve (vec3(00.0, 00.0, 00.0), vec3(00.0, 00.0, 10.0), vec3(00.0, 00.0, 20.0), vec3(00.0, 00.0, 30.0), v);\n vec3 f = BezierCurve (vec3(10.0, 00.0, 00.0), vec3(10.0, 30.0 * cos(time * 0.5), 10.0), vec3(10.0, 30.0 * sin(time * 0.9), 20.0), vec3(10.0, 00.0, 30.0), v);\n vec3 g = BezierCurve (vec3(20.0, 00.0, 00.0), vec3(20.0, 40.0 * cos(time * 0.6), 10.0), vec3(20.0, 20.0 * sin(time * 0.7), 20.0), vec3(20.0, 00.0, 30.0), v);\n vec3 h = BezierCurve (vec3(30.0, 00.0, 00.0), vec3(30.0, 00.0, 10.0), vec3(30.0, 00.0, 20.0), vec3(30.0, 00.0, 30.0), v); \n vec3 du = -3.0 * (1.0 - u) * (1.0 - u) * e + (3.0 * (1.0 - u) * (1.0 - u) - 6.0 * u * (1.0 - u)) * f + (6.0 * u * (1.0 - u) - 3.0 * u * u) * g + 3.0 * u * u * h;\n return normalize(cross(dv, du));\n}\n\nvec3 hash(float p)\n{\n vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973));\n p3 += dot(p3, p3.yzx+33.33);\n return fract((p3.xxy+p3.yzz)*p3.zyx); \n}\n\nvoid main() \n{ \n int tessellationFactor = 64; // vertex count = _TessellationFactor * _TessellationFactor * 6\n int instance = int(floor(vertexId / 6.0));\n float x = sign(mod(float(vertexId), 2.0));\n float y = sign(mod(126.0, mod(float(vertexId), 6.0) + 6.0));\n float u = (float(instance / tessellationFactor) + x) / float(tessellationFactor);\n float v = (mod(float(instance), float(tessellationFactor)) + y) / float(tessellationFactor); \n gl_Position = ModelViewProjection * vec4(BezierPatch(u,v) , 1); \n vec3 lightDir = normalize(vec3(10,10,-10));\n vec3 normalDir = BezierPatchNormal(u,v);\n float d = max(dot(lightDir, normalDir), 0.2); \n v_color = vec4(hash(float(instance + 123)), 1.0) * vec4(d, d, d, 1.0);\n}" + }, "screenshotURL": "data/images/images-fe8ok31uvn2xo8njy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BkSDKkzkjxLJgHecj/art.json b/art/BkSDKkzkjxLJgHecj/art.json index 76e1a073..870b9dcb 100644 --- a/art/BkSDKkzkjxLJgHecj/art.json +++ b/art/BkSDKkzkjxLJgHecj/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "ale", "avatarUrl": "https://lh6.googleusercontent.com/-A2JcKOXWDHc/AAAAAAAAAAI/AAAAAAAAAcE/deS0m5oEnec/photo.jpg", - "settings": "{\"num\":120,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Tarea: Llenar la siguiente tabla y graficar (UX, VY)\\n// vertexId: 0 1 2 3 ... 10 11 12 13 ... 20 21 22 23\\n// floor UX: 0 0 0 0 ... 1 1 2 2 ... 3 3\\t 3 3\\n// mod UX: 0 1 0 1 ... 0 1 0 1 ... 0 1 0 1\\n// UX: 0 1 0 1 ... 1 2 2 3 ... 3 4 3 4\\n// floor1 VY: 0 0 1 1 ... 5 5 6 6 ... 10 10 11 11\\n// floor2 VY: 0 0 0 1 ... 3 3 4 4 ... 6 7 7 7\\n// mod VY: 0 0 1 0 ... 0 0 0 0 ... 0 1 0 0\\n// VY: 0 0 1 0 ... 0 0 0 0 ... 0 1 0 0\\n\\n//Siguiendo las fórmulas de float ux y vy se llegó a la conclusión de que:\\n//floor UX --> se obtuvo al dividir VertexId entre 6.0\\n//mod UX --> es el residuo de la división de VertexId entre 2.0\\n//floor 1 VY --> se obtuvo al dividir VertexId entre 2.0\\n//floor 2 VY --> se obtuvo al dividir VertexId entre 3.0\\n//mod VY --> es el residuo de la división de la suma de floor 1 + floor 2 entre 2.0\\n\\nvoid main()\\n{\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = ux / 20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n // x = radius * cos(angle)\\n // y = radius * sin(angle)\\n \\n vec2 xy = vec2(x,y);\\n \\n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 120, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Tarea: Llenar la siguiente tabla y graficar (UX, VY)\n// vertexId: 0 1 2 3 ... 10 11 12 13 ... 20 21 22 23\n// floor UX: 0 0 0 0 ... 1 1 2 2 ... 3 3\t 3 3\n// mod UX: 0 1 0 1 ... 0 1 0 1 ... 0 1 0 1\n// UX: 0 1 0 1 ... 1 2 2 3 ... 3 4 3 4\n// floor1 VY: 0 0 1 1 ... 5 5 6 6 ... 10 10 11 11\n// floor2 VY: 0 0 0 1 ... 3 3 4 4 ... 6 7 7 7\n// mod VY: 0 0 1 0 ... 0 0 0 0 ... 0 1 0 0\n// VY: 0 0 1 0 ... 0 0 0 0 ... 0 1 0 0\n\n//Siguiendo las fórmulas de float ux y vy se llegó a la conclusión de que:\n//floor UX --> se obtuvo al dividir VertexId entre 6.0\n//mod UX --> es el residuo de la división de VertexId entre 2.0\n//floor 1 VY --> se obtuvo al dividir VertexId entre 2.0\n//floor 2 VY --> se obtuvo al dividir VertexId entre 3.0\n//mod VY --> es el residuo de la división de la suma de floor 1 + floor 2 entre 2.0\n\nvoid main()\n{\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = ux / 20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n // x = radius * cos(angle)\n // y = radius * sin(angle)\n \n vec2 xy = vec2(x,y);\n \n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-n83qo4xv3bp0j2c06-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BkeSrSoFbRiSfkoBm/art.json b/art/BkeSrSoFbRiSfkoBm/art.json index fac41e30..690fd834 100644 --- a/art/BkeSrSoFbRiSfkoBm/art.json +++ b/art/BkeSrSoFbRiSfkoBm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ptit-babas/23-nat-king-cole-the-christmas\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.5882352941176471,0.6901960784313725,1],\"shader\":\"/*\\n\\n _____, ____, ___, ___, __ _, \\n(-| | | (-|_, (-|_) (-|_) (-\\\\ | \\n _| | |_, _|__, _| \\\\_, _| \\\\_, \\\\| \\n( ( ( ( (__/ \\n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \\n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\\\_,(-(__`\\n \\\\___, _| |_, _| \\\\_, _|__, ____) _| _| | |_, _| ) ____)\\n ( ( ( ( ( ( ( ( \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\nvoid getPos0(const int depth, float bits, float range, float percent, inout mat4 m) {\\n float bit = mod(bits, 2.);\\n m *= rotZ(m1p1(hash(float(depth) * 0.123 + bit * 0.345)) * range);\\n}\\n\\nvoid getPos1(const int depth, float bits, float range, float percent, inout mat4 m) { \\n float bit = mod(bits, 2.);\\n float rest = floor(bits / 2.);\\n m *= rotZ(m1p1(hash(float(depth) * 0.123 + bit * 0.345)) * range);\\n if (depth > 0) {\\n getPos0(depth - 1, rest, range * percent, percent, m); \\n }\\n}\\n\\nvoid getPos2(const int depth, float bits, float range, float percent, inout mat4 m) { \\n float bit = mod(bits, 2.);\\n float rest = floor(bits / 2.);\\n m *= rotZ(m1p1(hash(float(depth) * 0.123 + bit * 0.345)) * 0.4);\\n if (depth > 0) {\\n getPos1(depth - 1, rest, range * percent, percent, m); \\n }\\n}\\n\\n\\nvoid main() {\\n float vId = vertexId;\\n float numStems = 6.;\\n float quadsPerStem = 5.;\\n float pointsPerStem = quadsPerStem * 6.;\\n float pointsPerFlake = pointsPerStem * numStems;\\n float numFlakes = floor(vertexCount / pointsPerFlake);\\n float quadId = mod(floor(vId / 6.), quadsPerStem);\\n float stemId = floor(vId / pointsPerStem);\\n float flakeId = floor(vId / pointsPerFlake);\\n float stemV = stemId / numStems;\\n float flakeV = flakeId / numFlakes;\\n \\n mat4 r = ident(); \\n getPos2(2, quadId, 0.4, 1., r);\\n vec3 p = getQPoint(mod(vId, 6.));\\n \\n vec3 camera = vec3(0, 0, 1);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n float z = hash(flakeId) * -10.;\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 20.);\\n m *= cameraLookAt(camera, target, up);\\n m *= trans(vec3(\\n (z + 1.5) * 1. * m1p1(hash(flakeId * 0.171)) + 0.05 * sin(time * mix(0.91, 0.2, hash(flakeId * 0.951))), \\n mix(1.5, -1.5, fract(hash(flakeId * .654) + time * mix(0.01, 0.03, hash(flakeId * 0.543)))), \\n z));\\n m *= uniformScale(mix(0.05, 0.1, hash(flakeId * 0.243)));\\n // m *= rotZ(time * hash(flakeId));\\n // m *= rotY(time * hash(flakeId));\\n // m *= rotZ(stemV * PI * 2. + mix(1.5, -1.5, fract(time * mix(-0.3, 0.3, hash(flakeId * 0.843)))));\\n // m *= scale(vec3(0.1, m1p1(hash(flakeId * 0.123 + quadId * 0.711 + p.x)) * 0.3, 1));\\n m *= r;\\n m *= trans(vec3(quadId, -0.5, 0));\\n gl_Position = m * vec4(p, 1);\\n \\n v_color = vec4(1);\\n v_color.a = mix(1.0, 0.0, hash(flakeId));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ptit-babas/23-nat-king-cole-the-christmas", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.5882352941176471, + 0.6901960784313725, + 1 + ], + "shader": "/*\n\n _____, ____, ___, ___, __ _, \n(-| | | (-|_, (-|_) (-|_) (-\\ | \n _| | |_, _|__, _| \\_, _| \\_, \\| \n( ( ( ( (__/ \n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\_,(-(__`\n \\___, _| |_, _| \\_, _|__, ____) _| _| | |_, _| ) ____)\n ( ( ( ( ( ( ( ( \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\nvoid getPos0(const int depth, float bits, float range, float percent, inout mat4 m) {\n float bit = mod(bits, 2.);\n m *= rotZ(m1p1(hash(float(depth) * 0.123 + bit * 0.345)) * range);\n}\n\nvoid getPos1(const int depth, float bits, float range, float percent, inout mat4 m) { \n float bit = mod(bits, 2.);\n float rest = floor(bits / 2.);\n m *= rotZ(m1p1(hash(float(depth) * 0.123 + bit * 0.345)) * range);\n if (depth > 0) {\n getPos0(depth - 1, rest, range * percent, percent, m); \n }\n}\n\nvoid getPos2(const int depth, float bits, float range, float percent, inout mat4 m) { \n float bit = mod(bits, 2.);\n float rest = floor(bits / 2.);\n m *= rotZ(m1p1(hash(float(depth) * 0.123 + bit * 0.345)) * 0.4);\n if (depth > 0) {\n getPos1(depth - 1, rest, range * percent, percent, m); \n }\n}\n\n\nvoid main() {\n float vId = vertexId;\n float numStems = 6.;\n float quadsPerStem = 5.;\n float pointsPerStem = quadsPerStem * 6.;\n float pointsPerFlake = pointsPerStem * numStems;\n float numFlakes = floor(vertexCount / pointsPerFlake);\n float quadId = mod(floor(vId / 6.), quadsPerStem);\n float stemId = floor(vId / pointsPerStem);\n float flakeId = floor(vId / pointsPerFlake);\n float stemV = stemId / numStems;\n float flakeV = flakeId / numFlakes;\n \n mat4 r = ident(); \n getPos2(2, quadId, 0.4, 1., r);\n vec3 p = getQPoint(mod(vId, 6.));\n \n vec3 camera = vec3(0, 0, 1);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n float z = hash(flakeId) * -10.;\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 20.);\n m *= cameraLookAt(camera, target, up);\n m *= trans(vec3(\n (z + 1.5) * 1. * m1p1(hash(flakeId * 0.171)) + 0.05 * sin(time * mix(0.91, 0.2, hash(flakeId * 0.951))), \n mix(1.5, -1.5, fract(hash(flakeId * .654) + time * mix(0.01, 0.03, hash(flakeId * 0.543)))), \n z));\n m *= uniformScale(mix(0.05, 0.1, hash(flakeId * 0.243)));\n // m *= rotZ(time * hash(flakeId));\n // m *= rotY(time * hash(flakeId));\n // m *= rotZ(stemV * PI * 2. + mix(1.5, -1.5, fract(time * mix(-0.3, 0.3, hash(flakeId * 0.843)))));\n // m *= scale(vec3(0.1, m1p1(hash(flakeId * 0.123 + quadId * 0.711 + p.x)) * 0.3, 1));\n m *= r;\n m *= trans(vec3(quadId, -0.5, 0));\n gl_Position = m * vec4(p, 1);\n \n v_color = vec4(1);\n v_color.a = mix(1.0, 0.0, hash(flakeId));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-otogylnd9yx7687f2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BkqeZ9ZW84C5tPdoJ/art.json b/art/BkqeZ9ZW84C5tPdoJ/art.json index d63f30f1..5d25e711 100644 --- a/art/BkqeZ9ZW84C5tPdoJ/art.json +++ b/art/BkqeZ9ZW84C5tPdoJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kim-kimsinho/epic-sax-guy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= rotZ(snd * 10. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n \\n gl_Position = mat * pos;\\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.; //mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kim-kimsinho/epic-sax-guy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0));\n mat *= rotZ(snd * 10. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n \n gl_Position = mat * pos;\n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.; //mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-jv0hylbi5a4s7cxli-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BnKrvieHdWaxfjXH8/art.json b/art/BnKrvieHdWaxfjXH8/art.json index feacdb20..08bb4928 100644 --- a/art/BnKrvieHdWaxfjXH8/art.json +++ b/art/BnKrvieHdWaxfjXH8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":26654,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/dj-wonkar/easy-funk-edit\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define ACROSS 14.\\n#define DOWN 7.\\n#define PER_AREA ((ACROSS * .13) * (DOWN * 3.) * 11.1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 1.0, 2.0));\\n vec4 K = vec4(1.0, 2.0 / 2.0, 1.0 / 3.0, 6.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -1.14, 0.7), c.y);\\n}\\n\\nvec4 area(float vertexId, float areaId) {\\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\\n float pointId = mod((floor(vertexId / 3.) + mod(vertexId, 2.0)) * 2., 1.);\\n float thingId = floor(vertexId - 1.);\\n float col = mod(thingId, ACROSS + 0.5);\\n float row = floor(thingId / (ACROSS / 1.5));\\n float u = col / ACROSS;\\n float v = row / DOWN;\\n float x = u * 1. - 2.;\\n float y = v * 2. - 1.;\\n \\n float d = length(vec2(x, y) *0.3);\\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / -11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\\n float sv = d * 0.1;\\n float snd = texture2D(sound, vec2(su * 1.25 / 8. * areaId, sv)).a;\\n \\n float r = 0.4 + pow(snd, 12.) * 2.15;\\n float a = pointId / 5. * PI * (2. + thingId * 0.05 + time) / 32.;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = cs * y / r *d;\\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\\n \\n float hue = (time * 0.1) + areaId - 2.;\\n \\n return vec4(\\n vec2(x * snd, y + snd) * 0.5 - xy / aspect,\\n snd,\\n hue) * 2.5 ;\\n}\\n\\nvoid main() {\\n gl_PointSize = 1.0;\\n\\n float areaId = floor(vertexId / PER_AREA);\\n float aCol = mod(areaId, 3.);\\n float aRow = floor(areaId / 4.)/3.2;\\n float ax = (aCol - 0.5) - (0.4 / 2.) - 2.;\\n float ay = (aRow + 0.5) / 2. * 1.8 - 0.9;\\n float avId = mod(vertexId, PER_AREA)-3.; \\n \\n vec4 a = area(avId, areaId);\\n \\n gl_Position = vec4(a.xy *- vec2(0.125, -0.4) + vec2(ax, ay), 0, 1);\\n float snd = a.z;\\n float hue = a.w;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 26654, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/dj-wonkar/easy-funk-edit", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define ACROSS 14.\n#define DOWN 7.\n#define PER_AREA ((ACROSS * .13) * (DOWN * 3.) * 11.1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 1.0, 2.0));\n vec4 K = vec4(1.0, 2.0 / 2.0, 1.0 / 3.0, 6.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -1.14, 0.7), c.y);\n}\n\nvec4 area(float vertexId, float areaId) {\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\n float pointId = mod((floor(vertexId / 3.) + mod(vertexId, 2.0)) * 2., 1.);\n float thingId = floor(vertexId - 1.);\n float col = mod(thingId, ACROSS + 0.5);\n float row = floor(thingId / (ACROSS / 1.5));\n float u = col / ACROSS;\n float v = row / DOWN;\n float x = u * 1. - 2.;\n float y = v * 2. - 1.;\n \n float d = length(vec2(x, y) *0.3);\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / -11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\n float sv = d * 0.1;\n float snd = texture2D(sound, vec2(su * 1.25 / 8. * areaId, sv)).a;\n \n float r = 0.4 + pow(snd, 12.) * 2.15;\n float a = pointId / 5. * PI * (2. + thingId * 0.05 + time) / 32.;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = cs * y / r *d;\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\n \n float hue = (time * 0.1) + areaId - 2.;\n \n return vec4(\n vec2(x * snd, y + snd) * 0.5 - xy / aspect,\n snd,\n hue) * 2.5 ;\n}\n\nvoid main() {\n gl_PointSize = 1.0;\n\n float areaId = floor(vertexId / PER_AREA);\n float aCol = mod(areaId, 3.);\n float aRow = floor(areaId / 4.)/3.2;\n float ax = (aCol - 0.5) - (0.4 / 2.) - 2.;\n float ay = (aRow + 0.5) / 2. * 1.8 - 0.9;\n float avId = mod(vertexId, PER_AREA)-3.; \n \n vec4 a = area(avId, areaId);\n \n gl_Position = vec4(a.xy *- vec2(0.125, -0.4) + vec2(ax, ay), 0, 1);\n float snd = a.z;\n float hue = a.w;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-2hbyxnib9rp2osjqq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BnhvgAERQC5rcGRoZ/art.json b/art/BnhvgAERQC5rcGRoZ/art.json index a2d0ecdc..beec1cc3 100644 --- a/art/BnhvgAERQC5rcGRoZ/art.json +++ b/art/BnhvgAERQC5rcGRoZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 1.0;\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\n// sea\\nconst int ITER_GEOMETRY = 3;\\nconst int ITER_FRAGMENT = 5;\\nconst float SEA_HEIGHT = 0.6;\\nconst float SEA_CHOPPY = 4.0;\\nconst float SEA_SPEED = 0.8;\\nconst float SEA_FREQ = 0.16;\\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\\n#define SEA_TIME (1.0 + iTime * SEA_SPEED)\\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54031230, -0.84147 );\\n\\n\\nfloat hash( vec2 p ) {\\n\\tfloat h = dot(p,vec2(127.1,311.7));\\t\\n return fract(sin(h)*43758.5453123);\\n}\\nfloat noise( in vec2 p ) {\\n vec2 i = floor( p );\\n vec2 f = fract( p );\\t\\n\\tvec2 u = f*f*(3.0-2.0*f);\\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \\n hash( i + vec2(1.0,0.0) ), u.x),\\n mix( hash( i + vec2(0.0,1.0) ), \\n hash( i + vec2(1.0,1.0) ), u.x), u.y);\\n}\\nfloat fbm( vec2 uv, float choppy )\\n{\\n uv += noise(uv); \\n vec2 wv = 1.0-abs(sin(uv));\\n vec2 swv = abs(cos(uv)); \\n wv = mix(wv,swv,wv);\\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\\n}\\n\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans, SEA_CHOPPY ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 1.0;\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\n// sea\nconst int ITER_GEOMETRY = 3;\nconst int ITER_FRAGMENT = 5;\nconst float SEA_HEIGHT = 0.6;\nconst float SEA_CHOPPY = 4.0;\nconst float SEA_SPEED = 0.8;\nconst float SEA_FREQ = 0.16;\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\n#define SEA_TIME (1.0 + iTime * SEA_SPEED)\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54031230, -0.84147 );\n\n\nfloat hash( vec2 p ) {\n\tfloat h = dot(p,vec2(127.1,311.7));\t\n return fract(sin(h)*43758.5453123);\n}\nfloat noise( in vec2 p ) {\n vec2 i = floor( p );\n vec2 f = fract( p );\t\n\tvec2 u = f*f*(3.0-2.0*f);\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \n hash( i + vec2(1.0,0.0) ), u.x),\n mix( hash( i + vec2(0.0,1.0) ), \n hash( i + vec2(1.0,1.0) ), u.x), u.y);\n}\nfloat fbm( vec2 uv, float choppy )\n{\n uv += noise(uv); \n vec2 wv = 1.0-abs(sin(uv));\n vec2 swv = abs(cos(uv)); \n wv = mix(wv,swv,wv);\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\n}\n\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans, SEA_CHOPPY ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-knvd0q6ni7tain02o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BqGPcmKoSdsC4MnLb/art.json b/art/BqGPcmKoSdsC4MnLb/art.json index e54e6549..852d2094 100644 --- a/art/BqGPcmKoSdsC4MnLb/art.json +++ b/art/BqGPcmKoSdsC4MnLb/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":11065,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/thomashayden/genie\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.25882352941176473,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Circles from Triangles\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n//https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n \\n float ux = floor(id/6.) + mod(id , 2.);\\n // id = \\t\\t0 1 2 3 4 5 6 7 8 9 10 11 12\\n \\n // floor =\\t0 0 0 0 0 0 1 1 1 1 1 1 2\\n // mod =\\t\\t0 1 0 1 0 1 0 1 0 1 0 1 0\\n // + = \\t\\t0 1 0 1 0 1 1 2 1 2 1 2 2\\n \\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n // id = \\t\\t0 1 2 3 4 5 6 7 8 9 10 11 12\\n \\n // floor =\\t0 0 1 1 2 2 3 3 4 4 5 5 6\\n // floor =\\t0 0 0 1 1 1 2 2 2 3 3 3 4\\n // + = \\t\\t0 0 1 2 3 3 5 5 6 7 8 8 10\\n // mod = \\t\\t0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n // result =>\\t{(0,0),(1,0),(0,1)}, \\n //\\t\\t\\t{(1,0),(0,1),(1,1)},\\n //\\t\\t\\t{(1,1),(2,1),(1,0)}, ...\\n \\n\\n // 120 / 6(quad) = 20\\n float angle = ux / numCircleSegments * PI*2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\nvoid main()\\n{\\n float numCircleSegments = 4.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound,vec2(au* 0.05,av*0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(0.5,1., oddSlice);\\n \\n sc *= 10. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\\n\\n \\n float pump = step(0.8,snd);\\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\\n float sat = 1.;//mix(0.5, 1.0, pump); //1.0 - av;\\n float val = mix(0.4, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 11065, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/thomashayden/genie", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.25882352941176473, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Circles from Triangles\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n//https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments){\n \n float ux = floor(id/6.) + mod(id , 2.);\n // id = \t\t0 1 2 3 4 5 6 7 8 9 10 11 12\n \n // floor =\t0 0 0 0 0 0 1 1 1 1 1 1 2\n // mod =\t\t0 1 0 1 0 1 0 1 0 1 0 1 0\n // + = \t\t0 1 0 1 0 1 1 2 1 2 1 2 2\n \n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n // id = \t\t0 1 2 3 4 5 6 7 8 9 10 11 12\n \n // floor =\t0 0 1 1 2 2 3 3 4 4 5 5 6\n // floor =\t0 0 0 1 1 1 2 2 2 3 3 3 4\n // + = \t\t0 0 1 2 3 3 5 5 6 7 8 8 10\n // mod = \t\t0 0 1 0 1 1 1 1 0 1 0 0 0\n \n // result =>\t{(0,0),(1,0),(0,1)}, \n //\t\t\t{(1,0),(0,1),(1,1)},\n //\t\t\t{(1,1),(2,1),(1,0)}, ...\n \n\n // 120 / 6(quad) = 20\n float angle = ux / numCircleSegments * PI*2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\nvoid main()\n{\n float numCircleSegments = 4.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound,vec2(au* 0.05,av*0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(0.5,1., oddSlice);\n \n sc *= 10. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\n\n \n float pump = step(0.8,snd);\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\n float sat = 1.;//mix(0.5, 1.0, pump); //1.0 - av;\n float val = mix(0.4, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-cghdl2nb4pmq93goj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Br7jzCr5r8jf4kHyx/art.json b/art/Br7jzCr5r8jf4kHyx/art.json index f0199c44..e3bfc618 100644 --- a/art/Br7jzCr5r8jf4kHyx/art.json +++ b/art/Br7jzCr5r8jf4kHyx/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gerrygoo", "avatarUrl": "https://avatars.githubusercontent.com/gerrygoo?s=200", - "settings": "{\"num\":1,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width = 10.0;\\n \\n float tot = 30.0;\\n \\n float pi = 3.141592654;\\n float ang = tot/pi;\\n \\n float w = 0.1;\\n float h = 0.1;\\n \\n float vid = vertexId;\\n \\n float x = w * floor(vid / 2.0) + cos(ang * vid);\\n float y = h * mod(vid, 2.0) - sin(ang * vid);\\n\\n gl_Position = vec4(x, y, 0.0, 1.0);\\n \\n v_color = vec4(sin(time * vid), 1.0, cos(time * vid), 1.0);\\n gl_PointSize = 10.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 1, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width = 10.0;\n \n float tot = 30.0;\n \n float pi = 3.141592654;\n float ang = tot/pi;\n \n float w = 0.1;\n float h = 0.1;\n \n float vid = vertexId;\n \n float x = w * floor(vid / 2.0) + cos(ang * vid);\n float y = h * mod(vid, 2.0) - sin(ang * vid);\n\n gl_Position = vec4(x, y, 0.0, 1.0);\n \n v_color = vec4(sin(time * vid), 1.0, cos(time * vid), 1.0);\n gl_PointSize = 10.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-efqndcbwqe2d590e3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BrGxYaWHdj7D4XZyf/art.json b/art/BrGxYaWHdj7D4XZyf/art.json index 95452b06..5a4da063 100644 --- a/art/BrGxYaWHdj7D4XZyf/art.json +++ b/art/BrGxYaWHdj7D4XZyf/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":37844,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// complex numbers\\n// vec2(real part, complex part)\\nvec2 cProd(vec2 a, vec2 b) {\\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\\n}\\nfloat cModSqrd(vec2 a) {\\n return (a.x*a.x + a.y*a.y);\\n}\\nint mandelbrot(float x, float y) {\\n int n = 0;\\n vec2 z = vec2(0,0);\\n vec2 c = vec2(x,y);\\n \\n // no loops in glsl so jsut repeat 100 times\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n \\n return n;\\n}\\n\\nvoid main() {\\n float resX = resolution.x;\\n float resY = resolution.y;\\n float resArea = resX * resY;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertCountX = floor(resX/vertLen);\\n float vertCountY = floor(resY/vertLen);\\n \\n float u = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\\n u = (u - 0.5)*2.;\\n float v = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\\n v = (v - 0.5)*2.;\\n \\n float x = u * (resolution.x/2.);\\n float y = v * (resolution.y/2.);\\n \\n gl_Position = vec4(u, v, 0, 1);\\n gl_PointSize = vertLen*1.05;\\n \\n \\n float black = 1.;\\n if( y>0. || x>0. )\\n black = 0.;\\n v_color = vec4(hsv2rgb(vec3((x+y)/vertLen+time/10., 1., black)), 1.);\\n}\"}", + "settings": { + "num": 37844, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// complex numbers\n// vec2(real part, complex part)\nvec2 cProd(vec2 a, vec2 b) {\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\n}\nfloat cModSqrd(vec2 a) {\n return (a.x*a.x + a.y*a.y);\n}\nint mandelbrot(float x, float y) {\n int n = 0;\n vec2 z = vec2(0,0);\n vec2 c = vec2(x,y);\n \n // no loops in glsl so jsut repeat 100 times\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n \n return n;\n}\n\nvoid main() {\n float resX = resolution.x;\n float resY = resolution.y;\n float resArea = resX * resY;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertCountX = floor(resX/vertLen);\n float vertCountY = floor(resY/vertLen);\n \n float u = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\n u = (u - 0.5)*2.;\n float v = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\n v = (v - 0.5)*2.;\n \n float x = u * (resolution.x/2.);\n float y = v * (resolution.y/2.);\n \n gl_Position = vec4(u, v, 0, 1);\n gl_PointSize = vertLen*1.05;\n \n \n float black = 1.;\n if( y>0. || x>0. )\n black = 0.;\n v_color = vec4(hsv2rgb(vec3((x+y)/vertLen+time/10., 1., black)), 1.);\n}" + }, "screenshotURL": "data/images/images-91spbh2szewga46zo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BroTxCqjuvDoLEhAY/art.json b/art/BroTxCqjuvDoLEhAY/art.json index 8bcdb5aa..809a1960 100644 --- a/art/BroTxCqjuvDoLEhAY/art.json +++ b/art/BroTxCqjuvDoLEhAY/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lizell", "avatarUrl": "https://secure.gravatar.com/avatar/8cbc7cccd5a415ae64aab0284832279b?default=retro&size=200", - "settings": "{\"num\":25957,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/iamtheelephante/katy-perry-dark-horse-ft-juicy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.058823529411764705,0.058823529411764705,0.058823529411764705,1],\"shader\":\"#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n\\nvoid main () {\\n float i = hash(vertexId);\\n float f = hash(i);\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 2.);\\n \\n float ang = vertexId / 1000.;\\n float perspective = .5 * (1. - mouse.y);\\n float t = time * (f + .5) - mouse.x;\\n float x = i * sin(ang + t) * .8;\\n float y = i * cos(ang + t);\\n y += .1 * snd * (1. - y);\\n y *= perspective;\\n \\n float vis = snd / (y + 1.);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 5. * vis;\\n \\n v_color = vec4(\\n snd * .7 * (2. - f),\\n snd * .8 * cos(f * PI),\\n snd * 2.,\\n vis);\\n}\"}", + "settings": { + "num": 25957, + "mode": "POINTS", + "sound": "https://soundcloud.com/iamtheelephante/katy-perry-dark-horse-ft-juicy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.058823529411764705, + 0.058823529411764705, + 0.058823529411764705, + 1 + ], + "shader": "#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n\nvoid main () {\n float i = hash(vertexId);\n float f = hash(i);\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 2.);\n \n float ang = vertexId / 1000.;\n float perspective = .5 * (1. - mouse.y);\n float t = time * (f + .5) - mouse.x;\n float x = i * sin(ang + t) * .8;\n float y = i * cos(ang + t);\n y += .1 * snd * (1. - y);\n y *= perspective;\n \n float vis = snd / (y + 1.);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 5. * vis;\n \n v_color = vec4(\n snd * .7 * (2. - f),\n snd * .8 * cos(f * PI),\n snd * 2.,\n vis);\n}" + }, "screenshotURL": "data/images/images-55e7z915wlyth6qn4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BsMpnBk6kQ8wK8mvy/art.json b/art/BsMpnBk6kQ8wK8mvy/art.json index 65d31484..02b972cf 100644 --- a/art/BsMpnBk6kQ8wK8mvy/art.json +++ b/art/BsMpnBk6kQ8wK8mvy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jorenvo", "avatarUrl": "https://avatars.githubusercontent.com/jorenvo?s=200", - "settings": "{\"num\":65536,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/sappheirosmusic/dawn\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float size = floor(sqrt(vertexCount));\\n \\n vec2 c = vec2(mod(vertexId, size),\\n floor(vertexId / size));\\n \\n // float loginess = 1.02;\\n float ampl_sample_x = c.x;\\n // ampl_sample_x = pow(loginess, ampl_sample_x) / pow(loginess, size);\\n \\n // divide by the maximum to normalize to [0, 1]\\n float normalizer_x = size - 1.0;\\n float normalizer_y = floor((vertexCount - 1.0) / size);\\n c /= vec2(normalizer_x, normalizer_y);\\n \\n // no ampl past this\\n const float FREQUENCY_NORMALIZE = .75;\\n float sound_x = pow(c.x, 3.) * FREQUENCY_NORMALIZE; \\n float ampl = texture2D(sound, vec2(sound_x, c.y)).a;\\n vec3 color = vec3(ampl, 0, 0);\\n \\n // wide percussion\\n /*\\n const float WIDE_SAMPLES = 32.;\\n float amplitude = 0.;\\n for (float i = 0.; i < WIDE_SAMPLES; i++) {\\n amplitude += texture2D(sound,\\n vec2((i / WIDE_SAMPLES) * FREQUENCY_NORMALIZE, c.y)).a;\\n }\\n amplitude /= WIDE_SAMPLES;\\n\\n if (amplitude > .4) {\\n color = vec3(0, 0, ampl); \\n } else\\n */\\n if (ampl > .8) { // trigger\\n const float TOTAL_S = 4.;\\n const float HISTORIC_SAMPLES = 10.;\\n const float HISTORIC_SAMPLE_TIME_S = .1;\\n float sample_interval =\\n TOTAL_S / HISTORIC_SAMPLE_TIME_S / HISTORIC_SAMPLES;\\n\\n float historic_ampl = 0.;\\n for (float i = 1.; i <= HISTORIC_SAMPLES; i++) {\\n historic_ampl += texture2D(sound,\\n vec2(sound_x,\\n c.y + i * sample_interval)).a;\\n }\\n\\n historic_ampl /= HISTORIC_SAMPLES;\\n\\n // continuation\\n if (historic_ampl > .3) {\\n color = vec3(ampl, ampl, 0); \\n }\\n }\\n \\n // go from [0,1] -> [0,2]\\n c *= 2.0;\\n \\n // go from [0,2] -> [-1, 1]\\n c -= 1.0;\\n \\n gl_Position = vec4(c, 0, 1.);\\n gl_PointSize = 10.;\\n \\n v_color = vec4(color, 1);\\n}\"}", + "settings": { + "num": 65536, + "mode": "POINTS", + "sound": "https://soundcloud.com/sappheirosmusic/dawn", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float size = floor(sqrt(vertexCount));\n \n vec2 c = vec2(mod(vertexId, size),\n floor(vertexId / size));\n \n // float loginess = 1.02;\n float ampl_sample_x = c.x;\n // ampl_sample_x = pow(loginess, ampl_sample_x) / pow(loginess, size);\n \n // divide by the maximum to normalize to [0, 1]\n float normalizer_x = size - 1.0;\n float normalizer_y = floor((vertexCount - 1.0) / size);\n c /= vec2(normalizer_x, normalizer_y);\n \n // no ampl past this\n const float FREQUENCY_NORMALIZE = .75;\n float sound_x = pow(c.x, 3.) * FREQUENCY_NORMALIZE; \n float ampl = texture2D(sound, vec2(sound_x, c.y)).a;\n vec3 color = vec3(ampl, 0, 0);\n \n // wide percussion\n /*\n const float WIDE_SAMPLES = 32.;\n float amplitude = 0.;\n for (float i = 0.; i < WIDE_SAMPLES; i++) {\n amplitude += texture2D(sound,\n vec2((i / WIDE_SAMPLES) * FREQUENCY_NORMALIZE, c.y)).a;\n }\n amplitude /= WIDE_SAMPLES;\n\n if (amplitude > .4) {\n color = vec3(0, 0, ampl); \n } else\n */\n if (ampl > .8) { // trigger\n const float TOTAL_S = 4.;\n const float HISTORIC_SAMPLES = 10.;\n const float HISTORIC_SAMPLE_TIME_S = .1;\n float sample_interval =\n TOTAL_S / HISTORIC_SAMPLE_TIME_S / HISTORIC_SAMPLES;\n\n float historic_ampl = 0.;\n for (float i = 1.; i <= HISTORIC_SAMPLES; i++) {\n historic_ampl += texture2D(sound,\n vec2(sound_x,\n c.y + i * sample_interval)).a;\n }\n\n historic_ampl /= HISTORIC_SAMPLES;\n\n // continuation\n if (historic_ampl > .3) {\n color = vec3(ampl, ampl, 0); \n }\n }\n \n // go from [0,1] -> [0,2]\n c *= 2.0;\n \n // go from [0,2] -> [-1, 1]\n c -= 1.0;\n \n gl_Position = vec4(c, 0, 1.);\n gl_PointSize = 10.;\n \n v_color = vec4(color, 1);\n}" + }, "screenshotURL": "data/images/images-xtukeedavwtk3jsa0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BsrLb5e2Fujc6RvJf/art.json b/art/BsrLb5e2Fujc6RvJf/art.json index 92dbfeed..aac44c0b 100644 --- a/art/BsrLb5e2Fujc6RvJf/art.json +++ b/art/BsrLb5e2Fujc6RvJf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":65536,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Simple Fractal - @P_Malin\\n \\nvoid main() \\n{ \\n \\tfloat fRotation = time * 0.5;\\n \\tvec2 vTranslation = vec2( 0.2, 0.2 );\\n \\tfloat fScale = 0.6;\\n\\n \\tfloat fSinRot = sin(fRotation);\\n \\tfloat fCosRot = cos(fRotation);\\n\\n \\tmat3 m = mat3( fCosRot * fScale, fSinRot * fScale, vTranslation.x, -fSinRot * fScale, fCosRot * fScale, vTranslation.y, 0.0, 0.0, 1.0 );\\n \\n \\tvec2 vPos = vec2( 0.0 );\\n \\tvec2 vMin = vec2( 100.0 ); \\t\\n \\tfloat fPassId = vertexId;\\n \\n \\tfor ( int i=0; i<8; i++ )\\n { \\n \\tvPos = (vec3(vPos, 1.0) * m).xy;\\n\\n \\tfPassId = fPassId / 4.0;\\n \\n \\tif ( fract( fPassId * 2.0 ) < 0.5 ) vPos.x = -vPos.x;\\n \\tif ( fract( fPassId ) < 0.5 ) vPos.y = -vPos.y;\\n \\tfPassId = floor( fPassId );\\n \\n \\tvMin = min( vMin, abs( vPos ) );\\n }\\n \\n \\tgl_PointSize = 6.0;\\n \\tgl_Position = vec4(vPos * vec2( 1.0, resolution.x / resolution.y) , 1.0/vertexId, 1);\\n\\n \\tvec3 vColor;\\n \\tvColor.x = sin( vMin.x * 10.0 + time * 1.234 ) * 0.5 + 0.5;\\n \\tvColor.y = sin( vMin.y * 10.0 + time * 2.345 ) * 0.5 + 0.5;\\n \\tvColor.z = sin( (vMin.x + vMin.y) * 5.0 + time * 3.456 ) * 0.5 + 0.5;\\n \\n \\tvColor = normalize(vColor);\\n \\n \\tvColor = 1.0 - exp2( vColor * -length( vMin ) * 2.0 );\\n \\tv_color = vec4( vColor, 0.0 );\\n}\"}", + "settings": { + "num": 65536, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Simple Fractal - @P_Malin\n \nvoid main() \n{ \n \tfloat fRotation = time * 0.5;\n \tvec2 vTranslation = vec2( 0.2, 0.2 );\n \tfloat fScale = 0.6;\n\n \tfloat fSinRot = sin(fRotation);\n \tfloat fCosRot = cos(fRotation);\n\n \tmat3 m = mat3( fCosRot * fScale, fSinRot * fScale, vTranslation.x, -fSinRot * fScale, fCosRot * fScale, vTranslation.y, 0.0, 0.0, 1.0 );\n \n \tvec2 vPos = vec2( 0.0 );\n \tvec2 vMin = vec2( 100.0 ); \t\n \tfloat fPassId = vertexId;\n \n \tfor ( int i=0; i<8; i++ )\n { \n \tvPos = (vec3(vPos, 1.0) * m).xy;\n\n \tfPassId = fPassId / 4.0;\n \n \tif ( fract( fPassId * 2.0 ) < 0.5 ) vPos.x = -vPos.x;\n \tif ( fract( fPassId ) < 0.5 ) vPos.y = -vPos.y;\n \tfPassId = floor( fPassId );\n \n \tvMin = min( vMin, abs( vPos ) );\n }\n \n \tgl_PointSize = 6.0;\n \tgl_Position = vec4(vPos * vec2( 1.0, resolution.x / resolution.y) , 1.0/vertexId, 1);\n\n \tvec3 vColor;\n \tvColor.x = sin( vMin.x * 10.0 + time * 1.234 ) * 0.5 + 0.5;\n \tvColor.y = sin( vMin.y * 10.0 + time * 2.345 ) * 0.5 + 0.5;\n \tvColor.z = sin( (vMin.x + vMin.y) * 5.0 + time * 3.456 ) * 0.5 + 0.5;\n \n \tvColor = normalize(vColor);\n \n \tvColor = 1.0 - exp2( vColor * -length( vMin ) * 2.0 );\n \tv_color = vec4( vColor, 0.0 );\n}" + }, "screenshotURL": "data/images/images-n0zaf10qbmxx47g7g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Bt5C5fTXArXh3hvqh/art.json b/art/Bt5C5fTXArXh3hvqh/art.json index 701e1c22..35ad5d19 100644 --- a/art/Bt5C5fTXArXh3hvqh/art.json +++ b/art/Bt5C5fTXArXh3hvqh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10093,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_POINTS 180.\\n#define GRID 10.\\n#define NUM_ITEMS 5.\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat bezier(float A, float B, float C, float D, float t) {\\n float E = mix(A, B, t);\\n float F = mix(B, C, t);\\n float G = mix(C, D, t);\\n\\n float H = mix(E, F, t);\\n float I = mix(F, G, t);\\n\\n return mix(H, I, t);\\n}\\n\\nvec2 circle(float eid) {\\n\\tfloat vid = floor(eid/2.);\\n\\tfloat edge = floor(mod(eid,2.));\\n float angle = mod(vid+edge, NUM_POINTS*2.)/NUM_POINTS*2.*PI*2.;\\n \\treturn vec2(cos(angle),sin(angle));\\n}\\n\\nvec2 circle(float eid, float start, float arclen) {\\n\\tfloat vid = floor(eid/2.);\\n\\tfloat edge = floor(mod(eid,2.));\\n float angle = start + (mod(vid+edge, NUM_POINTS*2.)/NUM_POINTS*2.*arclen);\\n \\treturn vec2(cos(angle),sin(angle));\\n}\\n\\n\\nvoid main() {\\n \\tfloat layerVid = mod(vertexId,NUM_POINTS*NUM_ITEMS*NUM_ITEMS);\\n \\tfloat layer = floor(vertexId/(NUM_POINTS*NUM_ITEMS*NUM_ITEMS));\\n \\tfloat instance = floor(layerVid / NUM_POINTS);\\n float instanceVid = floor( mod(vertexId,NUM_POINTS) );\\n \\tfloat even = mod(instance,2.);\\n \\tfloat odd = 1.-even;\\n \\tfloat edge = floor(mod(instanceVid,4.)/2.);//1.;//cos(mod(layerVid,4.));\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\tvec2 offs = vec2( mod(instance,NUM_ITEMS)-2.2, floor(instance/NUM_ITEMS)-2. )*vec2(0.4,0.39);\\n\\tvec2 xy;\\n\\n if (layer == 1.) {\\n\\txy = offs+circle(instanceVid) * (0.2 + even*0.04);\\n// float alpha = instanceVid/NUM_POINTS;\\n// xy = vec2(alpha,bezier(0.,1.,0.,1.,alpha))*0.2;//*2.-1.,bezier(.8,0.,0.,.8,alpha)*0.1);\\n \\n v_color = vec4(0.5*edge,0.5*edge,0.5*edge,1); \\n //v_color = vec4(1,0,0,1);\\n } else {\\n\\n float angle = mod(time + instance,PI*2.);\\n float speed = 1.+floor(even);\\n\\n float arcStart = mod(angle*speed+PI*even+0.8,PI*2.);\\n\\tfloat arcPart = arcStart/(PI*2.);\\n float arcSeg = mod(arcPart,0.25);\\n arcPart = bezier(0.,1.,0.,1.,arcSeg/0.25)*0.25 + arcPart - arcSeg;\\n\\n\\n arcStart = arcPart * PI * 2.;\\n \\n xy = offs+circle(instanceVid,arcStart,PI*0.5/*1.6*/) * (0.2 + even*0.04);\\n v_color = vec4(0.,0.2+clamp(even*cos(arcStart-0.5),0.,1.) + clamp(odd*sin(arcStart+PI),0.,1.),0,1); \\n }\\n\\n \\n \\tgl_Position = vec4(xy * aspect, 0, 1);\\n \\n}\\n\\n\\n /*\\nfloat point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n // float hue = (time * 0.01 + instance * 1.001);\\n //v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n\\n*/\\n\"}", + "settings": { + "num": 10093, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_POINTS 180.\n#define GRID 10.\n#define NUM_ITEMS 5.\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat bezier(float A, float B, float C, float D, float t) {\n float E = mix(A, B, t);\n float F = mix(B, C, t);\n float G = mix(C, D, t);\n\n float H = mix(E, F, t);\n float I = mix(F, G, t);\n\n return mix(H, I, t);\n}\n\nvec2 circle(float eid) {\n\tfloat vid = floor(eid/2.);\n\tfloat edge = floor(mod(eid,2.));\n float angle = mod(vid+edge, NUM_POINTS*2.)/NUM_POINTS*2.*PI*2.;\n \treturn vec2(cos(angle),sin(angle));\n}\n\nvec2 circle(float eid, float start, float arclen) {\n\tfloat vid = floor(eid/2.);\n\tfloat edge = floor(mod(eid,2.));\n float angle = start + (mod(vid+edge, NUM_POINTS*2.)/NUM_POINTS*2.*arclen);\n \treturn vec2(cos(angle),sin(angle));\n}\n\n\nvoid main() {\n \tfloat layerVid = mod(vertexId,NUM_POINTS*NUM_ITEMS*NUM_ITEMS);\n \tfloat layer = floor(vertexId/(NUM_POINTS*NUM_ITEMS*NUM_ITEMS));\n \tfloat instance = floor(layerVid / NUM_POINTS);\n float instanceVid = floor( mod(vertexId,NUM_POINTS) );\n \tfloat even = mod(instance,2.);\n \tfloat odd = 1.-even;\n \tfloat edge = floor(mod(instanceVid,4.)/2.);//1.;//cos(mod(layerVid,4.));\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \tvec2 offs = vec2( mod(instance,NUM_ITEMS)-2.2, floor(instance/NUM_ITEMS)-2. )*vec2(0.4,0.39);\n\tvec2 xy;\n\n if (layer == 1.) {\n\txy = offs+circle(instanceVid) * (0.2 + even*0.04);\n// float alpha = instanceVid/NUM_POINTS;\n// xy = vec2(alpha,bezier(0.,1.,0.,1.,alpha))*0.2;//*2.-1.,bezier(.8,0.,0.,.8,alpha)*0.1);\n \n v_color = vec4(0.5*edge,0.5*edge,0.5*edge,1); \n //v_color = vec4(1,0,0,1);\n } else {\n\n float angle = mod(time + instance,PI*2.);\n float speed = 1.+floor(even);\n\n float arcStart = mod(angle*speed+PI*even+0.8,PI*2.);\n\tfloat arcPart = arcStart/(PI*2.);\n float arcSeg = mod(arcPart,0.25);\n arcPart = bezier(0.,1.,0.,1.,arcSeg/0.25)*0.25 + arcPart - arcSeg;\n\n\n arcStart = arcPart * PI * 2.;\n \n xy = offs+circle(instanceVid,arcStart,PI*0.5/*1.6*/) * (0.2 + even*0.04);\n v_color = vec4(0.,0.2+clamp(even*cos(arcStart-0.5),0.,1.) + clamp(odd*sin(arcStart+PI),0.,1.),0,1); \n }\n\n \n \tgl_Position = vec4(xy * aspect, 0, 1);\n \n}\n\n\n /*\nfloat point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n // float hue = (time * 0.01 + instance * 1.001);\n //v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n\n*/\n" + }, "screenshotURL": "data/images/images-p1gp7ox4oa5ehuxl3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BtAqcPquWmxhDALFW/art.json b/art/BtAqcPquWmxhDALFW/art.json index 3a347ee6..bc98feab 100644 --- a/art/BtAqcPquWmxhDALFW/art.json +++ b/art/BtAqcPquWmxhDALFW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":94761,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define KP0 1.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 195.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 3.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 0.3, vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 1.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(0.3, -4.0,-step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 56. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, -0.3) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 3.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 2.);\\n float numStars = floor(vertexCount / 2.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.17);\\n \\n \\n float pId = mod(vertexId, 3.);\\n //float sz = h * 2.;\\n float sz = clamp(50.0 / min(resolution.x, resolution.y), 12., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 5.627)))) * 500. + cmat[1].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * 12.4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * .1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 2.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 1.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 10.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 3.1, 4000.0);\\n\\n vec2 ms = vec2(0); texture2D(touch, vec2(0, 0)).xy + vec2(0, 0); \\n \\n \\n float sp = time * .015;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * 1.82) * 1000. , cos(sp) * 1000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 1., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 1., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1.0);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 3.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(6.1, 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 94761, + "mode": "POINTS", + "sound": "https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define KP0 1.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 195.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 3.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 0.3, vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 1.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(0.3, -4.0,-step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 56. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, -0.3) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 3.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 2.);\n float numStars = floor(vertexCount / 2.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.17);\n \n \n float pId = mod(vertexId, 3.);\n //float sz = h * 2.;\n float sz = clamp(50.0 / min(resolution.x, resolution.y), 12., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 5.627)))) * 500. + cmat[1].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * 12.4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * .1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 2.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 1.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 10.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 3.1, 4000.0);\n\n vec2 ms = vec2(0); texture2D(touch, vec2(0, 0)).xy + vec2(0, 0); \n \n \n float sp = time * .015;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * 1.82) * 1000. , cos(sp) * 1000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 1., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 1., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1.0);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 3.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(6.1, 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-pv06s23x98h7f05xl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BtMPmXiuE37mpnQB7/art.json b/art/BtMPmXiuE37mpnQB7/art.json index bc1dc135..ae1adb41 100644 --- a/art/BtMPmXiuE37mpnQB7/art.json +++ b/art/BtMPmXiuE37mpnQB7/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user6017377/6n5vosmj8t2h?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive\\n//Course Name: CS250\\n//Term&Year: 2022&Fall\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(0, av)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n vec2 xy = vec2(ux, vy);\\n \\n gl_Position = vec4(ux,vy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd, 5.0) * 30.0*(abs(sin(time))+0.5) + soff;\\n\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user6017377/6n5vosmj8t2h?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive\n//Course Name: CS250\n//Term&Year: 2022&Fall\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(0, av)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n vec2 xy = vec2(ux, vy);\n \n gl_Position = vec4(ux,vy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd, 5.0) * 30.0*(abs(sin(time))+0.5) + soff;\n\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-1px40mof4pmgm3a6t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BtkrDbo3o9cSAoXeW/art.json b/art/BtkrDbo3o9cSAoXeW/art.json index 38bee9dc..c95cb527 100644 --- a/art/BtkrDbo3o9cSAoXeW/art.json +++ b/art/BtkrDbo3o9cSAoXeW/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// hash functions\\n#define HASHSCALE1 .1031\\n#define HASHSCALE3 vec3(.1031, .1030, .0973)\\n#define HASHSCALE4 vec4(.1031, .1030, .0973, .1099)\\n\\nfloat hash11(float p) {\\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n // write the position\\n float vertex_id = vertexId;\\n float quad_id = vertexId;\\n float quad_count = vertexCount;\\n float quad_pct = quad_id / quad_count;\\n float quads_per_trail = 1000.0;\\n float trail_id = floor(quad_id / quads_per_trail);\\n float trail_count = floor(quad_count / quads_per_trail);\\n float trail_pct = trail_id / trail_count;\\n float quad_trail_pct = quad_id / quads_per_trail - trail_id;\\n float quad_size = 1.0;\\n float trail_length = 1.0; //2.0*hash11(trail_id + 0.9872);\\n\\n float x = -1.0 + 2.0*quad_trail_pct*trail_length + 0.05*hash11(trail_id + 0.5123)*time;\\n x = mod(x + 1.0, 2.0) - 1.0;\\n float quad_x_pct = (x + 1.0) / 2.0;\\n float toggle = 0.2; //smoothstep(0.3, 1.0, 0.5 * (sin(iTime) + 1.0));\\n float how_much_quad = 0.3*(hash11(trail_id + 0.734)) * toggle;\\n float y = 1.0*mix(\\n 0.2*hash11(trail_id + 0.1353)*sin(10.0*(x - trail_id)),\\n how_much_quad*(2.0 * hash11(quad_id) - 1.0) + (1.0 - how_much_quad)*(2.0 * hash11(trail_id) - 1.0), smoothstep(0.1, 0.5, quad_x_pct) - smoothstep(0.2, 0.9 - 0.1*hash11(trail_id + 0.223), quad_x_pct));\\n float z = 0.0;\\n\\n gl_Position = vec4(x,y,z,1.0);\\n gl_PointSize = quad_size;\\n\\n // write the color\\n vec3 hsv = vec3(mix(0.6 + 0.3*trail_pct, 0.5 + 0.1*trail_pct, quad_x_pct), 1.0, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// hash functions\n#define HASHSCALE1 .1031\n#define HASHSCALE3 vec3(.1031, .1030, .0973)\n#define HASHSCALE4 vec4(.1031, .1030, .0973, .1099)\n\nfloat hash11(float p) {\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n // write the position\n float vertex_id = vertexId;\n float quad_id = vertexId;\n float quad_count = vertexCount;\n float quad_pct = quad_id / quad_count;\n float quads_per_trail = 1000.0;\n float trail_id = floor(quad_id / quads_per_trail);\n float trail_count = floor(quad_count / quads_per_trail);\n float trail_pct = trail_id / trail_count;\n float quad_trail_pct = quad_id / quads_per_trail - trail_id;\n float quad_size = 1.0;\n float trail_length = 1.0; //2.0*hash11(trail_id + 0.9872);\n\n float x = -1.0 + 2.0*quad_trail_pct*trail_length + 0.05*hash11(trail_id + 0.5123)*time;\n x = mod(x + 1.0, 2.0) - 1.0;\n float quad_x_pct = (x + 1.0) / 2.0;\n float toggle = 0.2; //smoothstep(0.3, 1.0, 0.5 * (sin(iTime) + 1.0));\n float how_much_quad = 0.3*(hash11(trail_id + 0.734)) * toggle;\n float y = 1.0*mix(\n 0.2*hash11(trail_id + 0.1353)*sin(10.0*(x - trail_id)),\n how_much_quad*(2.0 * hash11(quad_id) - 1.0) + (1.0 - how_much_quad)*(2.0 * hash11(trail_id) - 1.0), smoothstep(0.1, 0.5, quad_x_pct) - smoothstep(0.2, 0.9 - 0.1*hash11(trail_id + 0.223), quad_x_pct));\n float z = 0.0;\n\n gl_Position = vec4(x,y,z,1.0);\n gl_PointSize = quad_size;\n\n // write the color\n vec3 hsv = vec3(mix(0.6 + 0.3*trail_pct, 0.5 + 0.1*trail_pct, quad_x_pct), 1.0, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-qleasf6nnaggwvev5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BtpY4aK6a7rEquy7n/art.json b/art/BtpY4aK6a7rEquy7n/art.json index c8237333..5b54a2aa 100644 --- a/art/BtpY4aK6a7rEquy7n/art.json +++ b/art/BtpY4aK6a7rEquy7n/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "martinpalko", "avatarUrl": "https://avatars.githubusercontent.com/MartinPalko?s=200", - "settings": "{\"num\":4677,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cosmomedia/thunderstorm-sounds-of-nature\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Defines to compile the HLSL code with GLSL\\n#define float4 vec4\\n#define float3 vec3\\n#define float2 vec2\\n#define float4x4 mat4\\n#define float3x3 mat3\\n#define mul(x, y) y * x\\n#define lerp mix\\n#define static\\n#define saturate(x) clamp(x, 0.0, 1.0)\\n\\nfloat Rand(float2 seed)\\n{\\n return fract(sin(dot(seed.xy ,float2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nstruct RainParams\\n{\\n float minSpeed;\\n\\tfloat maxSpeed;\\n float groundHeight;\\n float fallDistance;\\n float2 minBounds;\\n float2 maxBounds;\\n float2 windDirectionAndStrength;\\n};\\n\\nstruct Raindrop\\n{\\n float size;\\n float3 position;\\n float3 velocity;\\n};\\n\\nfloat Wrap(float value, float minimum, float maximum, out float offset)\\n{\\n float maxMinusMin = maximum - minimum;\\n float valueMinusMin = value - minimum;\\n offset = floor(valueMinusMin / maxMinusMin);\\n return minimum + mod(valueMinusMin, maxMinusMin);\\n}\\n\\nfloat Wrap(float value, float minimum, float maximum)\\n{\\n float dummy;\\n return Wrap(value, minimum, maximum, dummy);\\n}\\n\\nRaindrop GenerateRaindrop(RainParams params, float time, float seed)\\n{\\n \\tfloat3 boundsSize;\\n \\tboundsSize.xy = params.maxBounds - params.minBounds;\\n \\tboundsSize.z = params.fallDistance;\\n \\n \\tfloat seed2 = 0.0;\\n \\n float3 initialOffset = boundsSize * float3(Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)));\\n \\n float3 velocity = float3(0.0, 0, -1.0) * lerp(params.minSpeed, params.maxSpeed, Rand(float2(seed, seed2++)));\\n \\n velocity.xy += params.windDirectionAndStrength;\\n \\n Raindrop drop;\\n drop.size = 0.002;\\n drop.position = initialOffset + (velocity * time);\\n \\n float wrapOffset;\\n drop.position.z = Wrap(drop.position.z, params.groundHeight, params.groundHeight + params.fallDistance, wrapOffset);\\n \\n\\tdrop.position.x += Rand(float2(wrapOffset, 0.0)) * (params.maxBounds.x - params.minBounds.x);\\n drop.position.x = Wrap(drop.position.x, params.minBounds.x, params.maxBounds.x);\\n drop.position.y += Rand(float2(wrapOffset, 1.0)) * (params.maxBounds.y - params.minBounds.y);\\n drop.position.y = Wrap(drop.position.y, params.minBounds.y, params.maxBounds.y);\\n \\n drop.velocity = velocity;\\n \\n return drop;\\n}\\n\\n#define TRIANGLES_PER_DROP 2.0\\nvoid RenderRaindrop(Raindrop drop, RainParams params, float triangle, float triVert, out float4 outPos, out float4 outColor)\\n{\\n // Super brute-force. Lets do something nicer later. \\n outPos.yz = float2(0.0, 0.0);\\n \\n float alpha = 0.4;\\n \\n if (triangle == 0.0)\\n {\\n if (triVert == 0.0)\\n {\\n outPos.xy = float2(-1.0, 0.0);\\n }\\n else if (triVert == 1.0)\\n {\\n outPos.xy = float2(1.0, 0.0);\\n }\\n else\\n {\\n outPos.xy = float2(0.0, -1.0);\\n }\\n }\\n else // triange == 1\\n {\\n if (triVert == 0.0)\\n {\\n outPos.xy = float2(-1.0, 0.0);\\n }\\n else if (triVert == 1.0)\\n {\\n outPos.xy = float2(1.0, 0.0);\\n }\\n else\\n {\\n alpha = 0.;\\n outPos.xy = float2(0.0, 150.0);\\n }\\n }\\n \\n outPos.xyz *= drop.size;\\n \\n outColor = float4(0.8, 0.9, 1.0, alpha);\\n outColor.rgb *= alpha;\\n \\n // Drop is currently in local space. Translate to world space\\n outPos.xyz *= drop.position.y;\\n \\n outPos.xyz += drop.position.xzy * drop.position.y; \\n}\\n\\nfloat GetThunderBrightness(float2 uv)\\n{\\n float2 lookupCoord = float2(0.0005, 0.0 + uv.x);\\n float sample = texture2D(sound, lookupCoord).a;\\n return pow(saturate((sample - 0.5) * 2.0), 6.0) * 5.0;\\n \\n}\\n\\n#define BACKGROUND_QUADS_X 20.0\\n#define BACKGROUND_QUADS_Y 20.0\\n#define TRIANGLES_FOR_BACKGROUND BACKGROUND_QUADS_X * BACKGROUND_QUADS_X * 2.0\\nvoid RenderBackground(float triangle, float triVert, out float4 outPos, out float4 outColor)\\n{\\n float quad = floor(triangle / 2.0);\\n float2 quadCoord = float2(\\n (mod(quad, BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_X,\\n (floor(quad / BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_Y\\n );\\n \\n float2 quadSize = float2(1.0 / BACKGROUND_QUADS_X, 1.0 / BACKGROUND_QUADS_Y);\\n \\n outPos.zw = float2(0.0, 1.0);\\n \\n \\n if (floor(mod(triangle, 2.0)) == 0.0)\\n {\\n if (triVert == 0.0)\\n outPos.xy = float2(0.0, 0.0);\\n else if (triVert == 1.0)\\n outPos.xy = float2(1.0, 0.0);\\n else\\n outPos.xy = float2(1.0, 1.0);\\n }\\n else\\n {\\n if (triVert == 0.0)\\n outPos.xy = float2(0.0, 0.0);\\n else if (triVert == 1.0)\\n outPos.xy = float2(0.0, 1.0);\\n else\\n outPos.xy = float2(1.0, 1.0);\\n }\\n \\n float2 uv = outPos.xy * quadSize - quadCoord;\\n outPos.xy = uv * 2.0 + 1.0;\\n \\n outColor.a = 0.0;\\n float thunder = GetThunderBrightness(uv);\\n outColor.rgb = float3(thunder, thunder, thunder);\\n \\n}\\n\\n\\nvoid main()\\n{ \\n float triangleId = floor(vertexId / 3.0);\\n float vertIndex = floor(mod(vertexId, 3.0));\\n \\n float backgroundTriangleStart = vertexCount / 3.0 - TRIANGLES_FOR_BACKGROUND;\\n \\n if (triangleId >= backgroundTriangleStart)\\n {\\n RenderBackground(triangleId - backgroundTriangleStart, vertIndex, gl_Position, v_color);\\n }\\n else\\n {\\n float dropId = floor(triangleId / TRIANGLES_PER_DROP);\\n \\n RainParams params;\\n params.minSpeed = 8.1;\\n params.maxSpeed = 10.1;\\n params.groundHeight = -2.0;\\n params.fallDistance = 4.0;\\n params.minBounds = float2(-2.0, 0.3);\\n params.maxBounds = float2(2.0, 1.0);\\n params.windDirectionAndStrength = float2(0.0, 0.0);\\n \\n Raindrop drop = GenerateRaindrop(params, time, dropId);\\n \\n \\n gl_Position = float4(0.0, 0.0, 0.0, 1.0);\\n v_color = float4(1.0, 1.0, 1.0, 1.0);\\n \\n RenderRaindrop(drop, params, triangleId, vertIndex, gl_Position, v_color);\\n }\\n}\"}", + "settings": { + "num": 4677, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cosmomedia/thunderstorm-sounds-of-nature", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Defines to compile the HLSL code with GLSL\n#define float4 vec4\n#define float3 vec3\n#define float2 vec2\n#define float4x4 mat4\n#define float3x3 mat3\n#define mul(x, y) y * x\n#define lerp mix\n#define static\n#define saturate(x) clamp(x, 0.0, 1.0)\n\nfloat Rand(float2 seed)\n{\n return fract(sin(dot(seed.xy ,float2(12.9898,78.233))) * 43758.5453);\n}\n\nstruct RainParams\n{\n float minSpeed;\n\tfloat maxSpeed;\n float groundHeight;\n float fallDistance;\n float2 minBounds;\n float2 maxBounds;\n float2 windDirectionAndStrength;\n};\n\nstruct Raindrop\n{\n float size;\n float3 position;\n float3 velocity;\n};\n\nfloat Wrap(float value, float minimum, float maximum, out float offset)\n{\n float maxMinusMin = maximum - minimum;\n float valueMinusMin = value - minimum;\n offset = floor(valueMinusMin / maxMinusMin);\n return minimum + mod(valueMinusMin, maxMinusMin);\n}\n\nfloat Wrap(float value, float minimum, float maximum)\n{\n float dummy;\n return Wrap(value, minimum, maximum, dummy);\n}\n\nRaindrop GenerateRaindrop(RainParams params, float time, float seed)\n{\n \tfloat3 boundsSize;\n \tboundsSize.xy = params.maxBounds - params.minBounds;\n \tboundsSize.z = params.fallDistance;\n \n \tfloat seed2 = 0.0;\n \n float3 initialOffset = boundsSize * float3(Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)));\n \n float3 velocity = float3(0.0, 0, -1.0) * lerp(params.minSpeed, params.maxSpeed, Rand(float2(seed, seed2++)));\n \n velocity.xy += params.windDirectionAndStrength;\n \n Raindrop drop;\n drop.size = 0.002;\n drop.position = initialOffset + (velocity * time);\n \n float wrapOffset;\n drop.position.z = Wrap(drop.position.z, params.groundHeight, params.groundHeight + params.fallDistance, wrapOffset);\n \n\tdrop.position.x += Rand(float2(wrapOffset, 0.0)) * (params.maxBounds.x - params.minBounds.x);\n drop.position.x = Wrap(drop.position.x, params.minBounds.x, params.maxBounds.x);\n drop.position.y += Rand(float2(wrapOffset, 1.0)) * (params.maxBounds.y - params.minBounds.y);\n drop.position.y = Wrap(drop.position.y, params.minBounds.y, params.maxBounds.y);\n \n drop.velocity = velocity;\n \n return drop;\n}\n\n#define TRIANGLES_PER_DROP 2.0\nvoid RenderRaindrop(Raindrop drop, RainParams params, float triangle, float triVert, out float4 outPos, out float4 outColor)\n{\n // Super brute-force. Lets do something nicer later. \n outPos.yz = float2(0.0, 0.0);\n \n float alpha = 0.4;\n \n if (triangle == 0.0)\n {\n if (triVert == 0.0)\n {\n outPos.xy = float2(-1.0, 0.0);\n }\n else if (triVert == 1.0)\n {\n outPos.xy = float2(1.0, 0.0);\n }\n else\n {\n outPos.xy = float2(0.0, -1.0);\n }\n }\n else // triange == 1\n {\n if (triVert == 0.0)\n {\n outPos.xy = float2(-1.0, 0.0);\n }\n else if (triVert == 1.0)\n {\n outPos.xy = float2(1.0, 0.0);\n }\n else\n {\n alpha = 0.;\n outPos.xy = float2(0.0, 150.0);\n }\n }\n \n outPos.xyz *= drop.size;\n \n outColor = float4(0.8, 0.9, 1.0, alpha);\n outColor.rgb *= alpha;\n \n // Drop is currently in local space. Translate to world space\n outPos.xyz *= drop.position.y;\n \n outPos.xyz += drop.position.xzy * drop.position.y; \n}\n\nfloat GetThunderBrightness(float2 uv)\n{\n float2 lookupCoord = float2(0.0005, 0.0 + uv.x);\n float sample = texture2D(sound, lookupCoord).a;\n return pow(saturate((sample - 0.5) * 2.0), 6.0) * 5.0;\n \n}\n\n#define BACKGROUND_QUADS_X 20.0\n#define BACKGROUND_QUADS_Y 20.0\n#define TRIANGLES_FOR_BACKGROUND BACKGROUND_QUADS_X * BACKGROUND_QUADS_X * 2.0\nvoid RenderBackground(float triangle, float triVert, out float4 outPos, out float4 outColor)\n{\n float quad = floor(triangle / 2.0);\n float2 quadCoord = float2(\n (mod(quad, BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_X,\n (floor(quad / BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_Y\n );\n \n float2 quadSize = float2(1.0 / BACKGROUND_QUADS_X, 1.0 / BACKGROUND_QUADS_Y);\n \n outPos.zw = float2(0.0, 1.0);\n \n \n if (floor(mod(triangle, 2.0)) == 0.0)\n {\n if (triVert == 0.0)\n outPos.xy = float2(0.0, 0.0);\n else if (triVert == 1.0)\n outPos.xy = float2(1.0, 0.0);\n else\n outPos.xy = float2(1.0, 1.0);\n }\n else\n {\n if (triVert == 0.0)\n outPos.xy = float2(0.0, 0.0);\n else if (triVert == 1.0)\n outPos.xy = float2(0.0, 1.0);\n else\n outPos.xy = float2(1.0, 1.0);\n }\n \n float2 uv = outPos.xy * quadSize - quadCoord;\n outPos.xy = uv * 2.0 + 1.0;\n \n outColor.a = 0.0;\n float thunder = GetThunderBrightness(uv);\n outColor.rgb = float3(thunder, thunder, thunder);\n \n}\n\n\nvoid main()\n{ \n float triangleId = floor(vertexId / 3.0);\n float vertIndex = floor(mod(vertexId, 3.0));\n \n float backgroundTriangleStart = vertexCount / 3.0 - TRIANGLES_FOR_BACKGROUND;\n \n if (triangleId >= backgroundTriangleStart)\n {\n RenderBackground(triangleId - backgroundTriangleStart, vertIndex, gl_Position, v_color);\n }\n else\n {\n float dropId = floor(triangleId / TRIANGLES_PER_DROP);\n \n RainParams params;\n params.minSpeed = 8.1;\n params.maxSpeed = 10.1;\n params.groundHeight = -2.0;\n params.fallDistance = 4.0;\n params.minBounds = float2(-2.0, 0.3);\n params.maxBounds = float2(2.0, 1.0);\n params.windDirectionAndStrength = float2(0.0, 0.0);\n \n Raindrop drop = GenerateRaindrop(params, time, dropId);\n \n \n gl_Position = float4(0.0, 0.0, 0.0, 1.0);\n v_color = float4(1.0, 1.0, 1.0, 1.0);\n \n RenderRaindrop(drop, params, triangleId, vertIndex, gl_Position, v_color);\n }\n}" + }, "screenshotURL": "data/images/images-co8m1t5s7llqelahe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BubiakjZKAd7TKT83/art.json b/art/BubiakjZKAd7TKT83/art.json index 15a0f6fe..5efe5e67 100644 --- a/art/BubiakjZKAd7TKT83/art.json +++ b/art/BubiakjZKAd7TKT83/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n float spd = 0.3;\\n float tm = time * spd-mouse.x;\\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px*2.5, py) * 4.0)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y /c + c * 0.15) / py, 0.0, 1);\\n gl_PointSize = c *c + 46.0* mouse.x;\\n\\n \\n v_color = vec4(2.2 + c, 0.24 + c, 1.7 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n float spd = 0.3;\n float tm = time * spd-mouse.x;\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px*2.5, py) * 4.0)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y /c + c * 0.15) / py, 0.0, 1);\n gl_PointSize = c *c + 46.0* mouse.x;\n\n \n v_color = vec4(2.2 + c, 0.24 + c, 1.7 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-icvbc0r2osc7or8pv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BuxMxn3MPkCW7BFbc/art.json b/art/BuxMxn3MPkCW7BFbc/art.json index a3b1c750..9a947524 100644 --- a/art/BuxMxn3MPkCW7BFbc/art.json +++ b/art/BuxMxn3MPkCW7BFbc/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n//\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n//\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-jo6efa2jh37uui7j6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Bv7nLsmSbowtSoGpA/art.json b/art/Bv7nLsmSbowtSoGpA/art.json index 593d83a6..29d8d472 100644 --- a/art/Bv7nLsmSbowtSoGpA/art.json +++ b/art/Bv7nLsmSbowtSoGpA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/roush-label/luuk-van-dijk-seduction\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n🍩\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.00)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n #define TRIS_AROUND_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 2.)\\n float cTriId = mod(floor(vertexId / 3.), TRIS_AROUND_CIRCLE);\\n float cTriV = cTriId / TRIS_AROUND_CIRCLE;\\n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(0., 1., vy);\\n \\n float gv = (groupId + vy) / numGroups; \\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; \\n float s = texture2D(sound, vec2(mix(0.1, mix(.1, .5, t5p5(sin(time * .1))), abs(cu * 2. - 1.)), abs(cu * 2. - 1.) * .1 + abs(cTriV * 2. - 1.) * .1)).a;\\n\\n float a = ux / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;\\n vec3 pos = vec3(cos(a), sin(a), 0);\\n vec3 nrm = pos;\\n \\n float r = 4.;\\n float ct = time * .15 * .0;\\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\\n vec3 target = vec3(0, -3, 0);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n\\n mat *= rotY(gv * PI * 2.);\\n mat *= trans(vec3(5,0,0));\\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n vec3 n = (mat * vec4(nrm, 0)).xyz;\\n\\n float hue = time * .1 + sin(gv) * 0.1 + cTriV * .1;\\n float sat = pow(s, 1.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\\n float l = dot(n, lightDir) * .5 + .5;\\n \\n v_color.rgb *= mix(1., l, sat);\\n v_color.rgb *= v_color.a;\\n \\n //v_color.rgb = n * .5 + .5;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/roush-label/luuk-van-dijk-seduction", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n🍩\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.00)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n #define TRIS_AROUND_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 2.)\n float cTriId = mod(floor(vertexId / 3.), TRIS_AROUND_CIRCLE);\n float cTriV = cTriId / TRIS_AROUND_CIRCLE;\n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(0., 1., vy);\n \n float gv = (groupId + vy) / numGroups; \n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; \n float s = texture2D(sound, vec2(mix(0.1, mix(.1, .5, t5p5(sin(time * .1))), abs(cu * 2. - 1.)), abs(cu * 2. - 1.) * .1 + abs(cTriV * 2. - 1.) * .1)).a;\n\n float a = ux / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;\n vec3 pos = vec3(cos(a), sin(a), 0);\n vec3 nrm = pos;\n \n float r = 4.;\n float ct = time * .15 * .0;\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\n vec3 target = vec3(0, -3, 0);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n\n mat *= rotY(gv * PI * 2.);\n mat *= trans(vec3(5,0,0));\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n vec3 n = (mat * vec4(nrm, 0)).xyz;\n\n float hue = time * .1 + sin(gv) * 0.1 + cTriV * .1;\n float sat = pow(s, 1.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\n float l = dot(n, lightDir) * .5 + .5;\n \n v_color.rgb *= mix(1., l, sat);\n v_color.rgb *= v_color.a;\n \n //v_color.rgb = n * .5 + .5;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-7dc1ythjvqd4jie5e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BvPCLikPbdwxzJQS2/art.json b/art/BvPCLikPbdwxzJQS2/art.json index 63418a92..d8e00832 100644 --- a/art/BvPCLikPbdwxzJQS2/art.json +++ b/art/BvPCLikPbdwxzJQS2/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":59701,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n\\n gl_PointSize = 10.0; \\n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n gl_Position = vec4(sin(time/vertexId), sin(time)/vertexId+0.5,0.5,1.0);\\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\\n v_color = vec4(1,vertexId,0.5,1);\\n}\"}", + "settings": { + "num": 59701, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n\n gl_PointSize = 10.0; \n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n gl_Position = vec4(sin(time/vertexId), sin(time)/vertexId+0.5,0.5,1.0);\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\n v_color = vec4(1,vertexId,0.5,1);\n}" + }, "screenshotURL": "data/images/images-h1qmw7ey9trc1rcps-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BwFoiT5wD28u9HN5Z/art.json b/art/BwFoiT5wD28u9HN5Z/art.json index 959d8f11..f1441917 100644 --- a/art/BwFoiT5wD28u9HN5Z/art.json +++ b/art/BwFoiT5wD28u9HN5Z/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n vec3 pos = vec3((vertexId/vertexCount), 0.0, 0.0);\\n pos.y = (texture2D(volume, vec2(0.0, pos.x)).a-0.3)*1.6;\\n pos.x = (pos.x-0.5)*2.0;\\n vec3 clr = vec3(pos.x, pos.y, -pos.x)+0.5;\\n \\n gl_PointSize = 12.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(clr, 1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n vec3 pos = vec3((vertexId/vertexCount), 0.0, 0.0);\n pos.y = (texture2D(volume, vec2(0.0, pos.x)).a-0.3)*1.6;\n pos.x = (pos.x-0.5)*2.0;\n vec3 clr = vec3(pos.x, pos.y, -pos.x)+0.5;\n \n gl_PointSize = 12.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(clr, 1.0);\n}" + }, "screenshotURL": "data/images/images-sy8yn04hs80vf7ayu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BxMWaxP7Sqiz38FgK/art.json b/art/BxMWaxP7Sqiz38FgK/art.json index 5043ede8..3ffcf856 100644 --- a/art/BxMWaxP7Sqiz38FgK/art.json +++ b/art/BxMWaxP7Sqiz38FgK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n\\n#define PI radians(180.0)\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, s, 0, 0, \\n s, 0, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n 1 -dot(xAxis, eye), dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.3, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5); // soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * 1.2;\\n s *= 0.15;\\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 1.1;\\n\\tf = 0.00100*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n //vec3 cameraPos = vec3(4., mix(5., 1., p1m1(1.)), 2.);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\\n float val = mix(.05, 1., l);\\n\\n float ss = \\n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float pop = step(0.6, ss);\\n val = mix(max(val,pop), 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.)*ss;\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n\n#define PI radians(180.0)\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, s, 0, 0, \n s, 0, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n 1 -dot(xAxis, eye), dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.3, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5); // soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * 1.2;\n s *= 0.15;\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 1.1;\n\tf = 0.00100*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n //vec3 cameraPos = vec3(4., mix(5., 1., p1m1(1.)), 2.);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\n float val = mix(.05, 1., l);\n\n float ss = \n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float pop = step(0.6, ss);\n val = mix(max(val,pop), 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.)*ss;\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-8164z2ksyg481c9ol-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/BxXCFpZxu7eFdhiyP/art.json b/art/BxXCFpZxu7eFdhiyP/art.json index ad8ca3f9..44e2341d 100644 --- a/art/BxXCFpZxu7eFdhiyP/art.json +++ b/art/BxXCFpZxu7eFdhiyP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":449,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float id = vertexId;\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux * radians(180.0) / (vertexCount * 0.00333333);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy;\\n \\n float a = resolution.x / resolution.y;\\n \\n float x = c * radius / a;\\n float y = s * radius;\\n \\n vec2 xy = vec2(x,y);\\n gl_Position = vec4(xy* .5, 0, 1);\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 449, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float id = vertexId;\n \n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux * radians(180.0) / (vertexCount * 0.00333333);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy;\n \n float a = resolution.x / resolution.y;\n \n float x = c * radius / a;\n float y = s * radius;\n \n vec2 xy = vec2(x,y);\n gl_Position = vec4(xy* .5, 0, 1);\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ygc8kkhpgl24ivilu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/BzwXBknYWjs4nfk9h/art.json b/art/BzwXBknYWjs4nfk9h/art.json index 9c7ab228..7fbea9c7 100644 --- a/art/BzwXBknYWjs4nfk9h/art.json +++ b/art/BzwXBknYWjs4nfk9h/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=7c652ddc2d064bbbad85c4463ef16934&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00392156862745098,0.09803921568627451,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Audio Reactive\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointPerCircle);\\n float numCircles = floor(vertexCount / numPointPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 1. + snd * 0.2 + time * .1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=7c652ddc2d064bbbad85c4463ef16934&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00392156862745098, + 0.09803921568627451, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Audio Reactive\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointPerCircle);\n float numCircles = floor(vertexCount / numPointPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u * 1. + snd * 0.2 + time * .1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-0c5sam8p4y5ndabl9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C27MRCLnDuKJk9TrS/art.json b/art/C27MRCLnDuKJk9TrS/art.json index e5f728c0..c1d4997e 100644 --- a/art/C27MRCLnDuKJk9TrS/art.json +++ b/art/C27MRCLnDuKJk9TrS/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rotr3(float x, float n) {\\n return floor(x / pow(3.0, n)) + mod(x * pow(2.0, 3.0 - n), 10.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.5);\\n}\\n\\nvec3 cubePos(float x) {\\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n float near = -1.0;\\n float far = 1.0;\\n float aspectRatio = resolution.y / resolution.x;\\n float cubeIdx = floor(vertexId / 36.0);\\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\\n float faceDiv3 = floor(faceIdx / 3.0);\\n float faceMod3 = mod(faceIdx, 3.0);\\n float quadIdx = mod(vertexId, 6.0);\\n float baseIdx = faceIdx * 6.0;\\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\\n pos -= 0.10;\\n pos *= 0.10;\\n \\n float ct = time + mod(cubeIdx, 20.0);\\n float ct1 = time + floor(cubeIdx / 20.0);\\n float s = sin(ct*1.0), c = cos(ct*1.0);\\n float s1 = sin(ct1), c1 = cos(ct1);\\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n gl_Position = vec4(pos, 1.0) * rot * rot2;\\n\\n gl_Position.x += (mod(cubeIdx, 30.0) - 10.0) * 0.08;\\n gl_Position.y += (floor(cubeIdx / 10.0) - 10.0) * 0.0;\\n \\n gl_Position.y /= aspectRatio;\\n float zDist = gl_Position.z - near;\\n gl_Position.w = zDist;\\n\\n v_color = vec4(mod2(faceIdx + 10.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rotr3(float x, float n) {\n return floor(x / pow(3.0, n)) + mod(x * pow(2.0, 3.0 - n), 10.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.5);\n}\n\nvec3 cubePos(float x) {\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n float near = -1.0;\n float far = 1.0;\n float aspectRatio = resolution.y / resolution.x;\n float cubeIdx = floor(vertexId / 36.0);\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\n float faceDiv3 = floor(faceIdx / 3.0);\n float faceMod3 = mod(faceIdx, 3.0);\n float quadIdx = mod(vertexId, 6.0);\n float baseIdx = faceIdx * 6.0;\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\n pos -= 0.10;\n pos *= 0.10;\n \n float ct = time + mod(cubeIdx, 20.0);\n float ct1 = time + floor(cubeIdx / 20.0);\n float s = sin(ct*1.0), c = cos(ct*1.0);\n float s1 = sin(ct1), c1 = cos(ct1);\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n gl_Position = vec4(pos, 1.0) * rot * rot2;\n\n gl_Position.x += (mod(cubeIdx, 30.0) - 10.0) * 0.08;\n gl_Position.y += (floor(cubeIdx / 10.0) - 10.0) * 0.0;\n \n gl_Position.y /= aspectRatio;\n float zDist = gl_Position.z - near;\n gl_Position.w = zDist;\n\n v_color = vec4(mod2(faceIdx + 10.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.1);\n}" + }, "screenshotURL": "data/images/images-cxgcel0cddc7048p5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/C2Kzd3CnpNPtWHjRw/art.json b/art/C2Kzd3CnpNPtWHjRw/art.json index 61d116c9..095c29a2 100644 --- a/art/C2Kzd3CnpNPtWHjRw/art.json +++ b/art/C2Kzd3CnpNPtWHjRw/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":37500,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dimmakrecords/freefall-dance\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n float across = 25.0;\\n float down = 25.0;\\n \\n float per = 6.;\\n float cId = floor(vertexId / per);\\n float numC = floor(vertexCount / per);\\n \\n float perSet = across * down;\\n float numSets = floor(numC / perSet);\\n \\n float maxSize = max(resolution.x / across, resolution.y / down);\\n float minSize = 1.;min(resolution.x / across, resolution.y / down);\\n \\n float id = mod(cId, perSet);\\n float setId = floor(cId / perSet);\\n float sv = setId / (numSets - 1.);\\n \\n float x = mod(id, across);\\n float y = floor(id / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (down - 1.0);\\n \\n vec2 uv2 = vec2(u * 2. - 1., v * 2. - 1.);\\n\\n float vId = mod(vertexId, per);\\n float ux = floor(vId / 6.) + mod(vId, 2.) * 2. - 1.;\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.) * 2. - 1.; \\n vec3 pos = vec3(ux, vy, 0);\\n \\n \\n float s0 = texture2D(sound, vec2(\\n mix(0.01, 0.25, atan(abs(u * 2. - 1.), abs(v * 2. - 1.)) / PI), \\n (1. - sv) * 0.1)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(0, 0, 50);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * (1. - length(uv2)));\\n mat *= trans(vec3(uv2 * 30., 0.));\\n mat *= uniformScale(pow(s0, 5.) * mix(10., 0.25, (1. - sv)));\\n mat *= rotZ(6.*s0*sign(uv2.x - uv2.y));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.0;\\n v_color = mix(vec4(1,sv,0,1), vec4(1,0,0,1), step(0.9, s0));\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 37500, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dimmakrecords/freefall-dance", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n float across = 25.0;\n float down = 25.0;\n \n float per = 6.;\n float cId = floor(vertexId / per);\n float numC = floor(vertexCount / per);\n \n float perSet = across * down;\n float numSets = floor(numC / perSet);\n \n float maxSize = max(resolution.x / across, resolution.y / down);\n float minSize = 1.;min(resolution.x / across, resolution.y / down);\n \n float id = mod(cId, perSet);\n float setId = floor(cId / perSet);\n float sv = setId / (numSets - 1.);\n \n float x = mod(id, across);\n float y = floor(id / across);\n \n float u = x / (across - 1.0);\n float v = y / (down - 1.0);\n \n vec2 uv2 = vec2(u * 2. - 1., v * 2. - 1.);\n\n float vId = mod(vertexId, per);\n float ux = floor(vId / 6.) + mod(vId, 2.) * 2. - 1.;\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.) * 2. - 1.; \n vec3 pos = vec3(ux, vy, 0);\n \n \n float s0 = texture2D(sound, vec2(\n mix(0.01, 0.25, atan(abs(u * 2. - 1.), abs(v * 2. - 1.)) / PI), \n (1. - sv) * 0.1)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(0, 0, 50);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * (1. - length(uv2)));\n mat *= trans(vec3(uv2 * 30., 0.));\n mat *= uniformScale(pow(s0, 5.) * mix(10., 0.25, (1. - sv)));\n mat *= rotZ(6.*s0*sign(uv2.x - uv2.y));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.0;\n v_color = mix(vec4(1,sv,0,1), vec4(1,0,0,1), step(0.9, s0));\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-0ou7b6mqa3tnqrcsw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C2qmkuPNQvcyp6CGP/art.json b/art/C2qmkuPNQvcyp6CGP/art.json index 1c60c8c7..a74e9dc2 100644 --- a/art/C2qmkuPNQvcyp6CGP/art.json +++ b/art/C2qmkuPNQvcyp6CGP/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":10264,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ihsanozturk/kruder-dorfmeister-liquid-acid\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + .3, 3.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 10264, + "mode": "POINTS", + "sound": "https://soundcloud.com/ihsanozturk/kruder-dorfmeister-liquid-acid", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + .3, 3.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-68yjdp9dac1r7dzcy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C4gCacp8eQ337rdFD/art.json b/art/C4gCacp8eQ337rdFD/art.json index ef194ae8..5b31464f 100644 --- a/art/C4gCacp8eQ337rdFD/art.json +++ b/art/C4gCacp8eQ337rdFD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":90773,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.01568627450980392,0.023529411764705882,0.058823529411764705,1],\"shader\":\"// ==========================================\\n// ^\\n// |\\n// +-- click \\\"hide\\\" then MOVE YOUR MOUSE!!!!\\n// ==========================================\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>1.\\n#define kpx 0.160//KParameter 1.>>8.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n//KverticesNumber=233333\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float u = 0.0;\\n float v = fract(vertexId / 240.0);\\n float age = floor(vertexId / 240.0) / 240.0;\\n float invAge = 1.0 - age;\\n vec4 touch = texture2D(touch, vec2(u, v));\\n float snd = texture2D(sound, vec2(v, age) * vec2(0.25, 0.25)).a;\\n float t = time - touch.w;\\n \\n float a = mod(vertexId, 6.0) / 6.0 * PI * 2.0 + t * 100.0;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = vec2(touch.xy) + (cs * age * snd * 0.2 *asin(kpx/3. )- 0.21) * 0.1;\\n gl_Position = vec4(xy * (1.0 + (age + t) * 1.0) , age, 1);\\n\\n float hue = mix(age + 0.6*kpx + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\\n vec3 color = hsv2rgb(vec3(hue, invAge, snd + touch.z));\\n v_color = vec4(mix(color, background.rgb, age)-sin(color*.18) * invAge, invAge);\\n gl_PointSize = mix(20.0, 1.0, age);\\n\\n}\\n\\n\"}", + "settings": { + "num": 90773, + "mode": "LINES", + "sound": "https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy", + "lineSize": "CSS", + "backgroundColor": [ + 0.01568627450980392, + 0.023529411764705882, + 0.058823529411764705, + 1 + ], + "shader": "// ==========================================\n// ^\n// |\n// +-- click \"hide\" then MOVE YOUR MOUSE!!!!\n// ==========================================\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>1.\n#define kpx 0.160//KParameter 1.>>8.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n//KverticesNumber=233333\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float u = 0.0;\n float v = fract(vertexId / 240.0);\n float age = floor(vertexId / 240.0) / 240.0;\n float invAge = 1.0 - age;\n vec4 touch = texture2D(touch, vec2(u, v));\n float snd = texture2D(sound, vec2(v, age) * vec2(0.25, 0.25)).a;\n float t = time - touch.w;\n \n float a = mod(vertexId, 6.0) / 6.0 * PI * 2.0 + t * 100.0;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = vec2(touch.xy) + (cs * age * snd * 0.2 *asin(kpx/3. )- 0.21) * 0.1;\n gl_Position = vec4(xy * (1.0 + (age + t) * 1.0) , age, 1);\n\n float hue = mix(age + 0.6*kpx + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\n vec3 color = hsv2rgb(vec3(hue, invAge, snd + touch.z));\n v_color = vec4(mix(color, background.rgb, age)-sin(color*.18) * invAge, invAge);\n gl_PointSize = mix(20.0, 1.0, age);\n\n}\n\n" + }, "screenshotURL": "data/images/images-a7uuhpsoqh6tni2ho-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C549fio274zzAoidn/art.json b/art/C549fio274zzAoidn/art.json index 70d86a1c..1fb8a4e4 100644 --- a/art/C549fio274zzAoidn/art.json +++ b/art/C549fio274zzAoidn/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 10.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 10.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-kl7wzjiscsnbod2ac-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C5XnDd3TxCtHq52Jv/art.json b/art/C5XnDd3TxCtHq52Jv/art.json index de826528..02a644fa 100644 --- a/art/C5XnDd3TxCtHq52Jv/art.json +++ b/art/C5XnDd3TxCtHq52Jv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jaschahagen/simple-brain-dance\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.01;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).x;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.9 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/jaschahagen/simple-brain-dance", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.01;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).x;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.9 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-y19tap8hn96ao3kgt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C9maC3C6dCdyKmsuH/art.json b/art/C9maC3C6dCdyKmsuH/art.json index 5325ce01..991f1a17 100644 --- a/art/C9maC3C6dCdyKmsuH/art.json +++ b/art/C9maC3C6dCdyKmsuH/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "8bitrick", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/v-e-r-t-e/track1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Just a bunch of lines bouncing to music\\n//\\n\\n// I'm still learning and \\\"borrowing\\\" many techniques from other shaders\\n\\n// hsv2rgb borrowed from gman shaders\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n float ROWS = 5.;\\n float verts_per_row = vertexCount / ROWS;\\n float row = floor(vertexId / verts_per_row);\\n float row_per = row / (ROWS-1.);\\n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\\n float x = vertex_per*2.0 - 1.0 + row_per * 0.5;\\n float y = texture2D(sound,vec2(vertex_per,row_per)).a + (row_per) - 1.;\\n gl_PointSize = 10.0;\\n gl_Position = vec4(x,y,0,1);\\n v_color = mix(vec4(hsv2rgb(vec3(0.25, fract(time+row_per), 1.)), 1.-row_per), background, row_per - 0.2);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/v-e-r-t-e/track1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Just a bunch of lines bouncing to music\n//\n\n// I'm still learning and \"borrowing\" many techniques from other shaders\n\n// hsv2rgb borrowed from gman shaders\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n float ROWS = 5.;\n float verts_per_row = vertexCount / ROWS;\n float row = floor(vertexId / verts_per_row);\n float row_per = row / (ROWS-1.);\n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\n float x = vertex_per*2.0 - 1.0 + row_per * 0.5;\n float y = texture2D(sound,vec2(vertex_per,row_per)).a + (row_per) - 1.;\n gl_PointSize = 10.0;\n gl_Position = vec4(x,y,0,1);\n v_color = mix(vec4(hsv2rgb(vec3(0.25, fract(time+row_per), 1.)), 1.-row_per), background, row_per - 0.2);\n}\n" + }, "screenshotURL": "data/images/images-2k35nxtgggsdvfuf9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C9riFtXRKgMEZyY7p/art.json b/art/C9riFtXRKgMEZyY7p/art.json index dc57a6a2..e21b315b 100644 --- a/art/C9riFtXRKgMEZyY7p/art.json +++ b/art/C9riFtXRKgMEZyY7p/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "clydepashley", "avatarUrl": "https://avatars.githubusercontent.com/clydepashley?s=200", - "settings": "{\"num\":20,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/wondem/01-veggie-wondem-ras-g-sd-master01wav\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt (vertexCount));\\n float across = floor (vertexCount / down);\\n \\n //Create Grid\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n //Respace out\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n x = u;\\n y = v;\\n \\n //Move back around origin\\n x = x * 2. - 1.;\\n y = y * 2. - 1.;\\n \\n\\n float snd = texture2D(sound, vec2(u, 0.)).a;\\n float sin_thing = sin(vertexId + snd); \\n //Sin\\n \\n x = sin(x+(snd/6.)/y);\\n //y = cos(x+(snd/1000.)/y/(snd/1000.));\\n \\n //Comment and uncomment here, and change vertexCount to 10, 20, 50, 5000\\n //y = cos(x+(snd/10.))*3.5 - 2.9;\\n //y = cos(y+(snd/10.))*3.5 - 2.9;\\n \\n\\n \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = sin_thing * 10.;\\n //v_color = vec4(snd * 4., sin_thing * 20.,mod(snd,1.),1);\\n //v_color = vec4(snd+snd, mod(snd, 0.5) , mod(snd,1.3),1);\\n v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\\n //v_color = vec4(snd * snd, sin_thing * 20.,mod(snd,1.),1);\\n}\"}", + "settings": { + "num": 20, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/wondem/01-veggie-wondem-ras-g-sd-master01wav", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt (vertexCount));\n float across = floor (vertexCount / down);\n \n //Create Grid\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n //Respace out\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n x = u;\n y = v;\n \n //Move back around origin\n x = x * 2. - 1.;\n y = y * 2. - 1.;\n \n\n float snd = texture2D(sound, vec2(u, 0.)).a;\n float sin_thing = sin(vertexId + snd); \n //Sin\n \n x = sin(x+(snd/6.)/y);\n //y = cos(x+(snd/1000.)/y/(snd/1000.));\n \n //Comment and uncomment here, and change vertexCount to 10, 20, 50, 5000\n //y = cos(x+(snd/10.))*3.5 - 2.9;\n //y = cos(y+(snd/10.))*3.5 - 2.9;\n \n\n \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = sin_thing * 10.;\n //v_color = vec4(snd * 4., sin_thing * 20.,mod(snd,1.),1);\n //v_color = vec4(snd+snd, mod(snd, 0.5) , mod(snd,1.3),1);\n v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\n //v_color = vec4(snd * snd, sin_thing * 20.,mod(snd,1.),1);\n}" + }, "screenshotURL": "data/images/images-0rk8g3bz49roxuanf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/C9sbwtGje9tjnk7ed/art.json b/art/C9sbwtGje9tjnk7ed/art.json index de6e6ece..841404aa 100644 --- a/art/C9sbwtGje9tjnk7ed/art.json +++ b/art/C9sbwtGje9tjnk7ed/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minjae-yu", "avatarUrl": "https://avatars.githubusercontent.com/minjae-yu?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : MINJAE YU\\n//Assignment : Circles from Triangles\\n//Course : CS250\\n//Term : Spring 2023\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 2.0);\\n float oddSlice = mod(sliceId, 15.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 10. * sign(ux));\\n mat *= uniformScale(0.02 * sc);\\n\\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.5, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.5, pow(snd + 0.2, 5.), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : MINJAE YU\n//Assignment : Circles from Triangles\n//Course : CS250\n//Term : Spring 2023\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 2.0);\n float oddSlice = mod(sliceId, 15.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 10. * sign(ux));\n mat *= uniformScale(0.02 * sc);\n\n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.5, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.5, pow(snd + 0.2, 5.), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-lv9exrhaysog2y4at-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CBDvmeprw78fMTgQ4/art.json b/art/CBDvmeprw78fMTgQ4/art.json index 6d7f53d0..2bf8192c 100644 --- a/art/CBDvmeprw78fMTgQ4/art.json +++ b/art/CBDvmeprw78fMTgQ4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.5;\\n float rightBottom = 0.0125;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 1, 1, 1);\\n }\\n else {\\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.5;\n float rightBottom = 0.0125;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 1, 1, 1);\n }\n else {\n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-tzcb4aj7f66su6pfm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CERRMSf3KtHWagAFx/art.json b/art/CERRMSf3KtHWagAFx/art.json index 48ef137c..d0a80eb4 100644 --- a/art/CERRMSf3KtHWagAFx/art.json +++ b/art/CERRMSf3KtHWagAFx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "brandonlsw", "avatarUrl": "https://avatars.githubusercontent.com/BrandonLSW?s=200", - "settings": "{\"num\":1582,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n \\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.0);\\n float v = y / (across-1.0);\\n \\n\\n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.0; //sin(time+x*y*0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = 1.0; //u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float val = 1.0; //sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1582, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n \tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.0);\n float v = y / (across-1.0);\n \n\n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.0; //sin(time+x*y*0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = 1.0; //u * 0.1 + sin(time + v * 20.0) * 0.05;\n float sat = 1.0;\n float val = 1.0; //sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-d69v66a21s5plcwgz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CEmfhvYaGBEGw4vRT/art.json b/art/CEmfhvYaGBEGw4vRT/art.json index 72f07ce4..f27cc5bf 100644 --- a/art/CEmfhvYaGBEGw4vRT/art.json +++ b/art/CEmfhvYaGBEGw4vRT/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hzktqr", "avatarUrl": "https://secure.gravatar.com/avatar/c5ca7d7d4b527ab960b78f57cfbe61c2?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-xagnlkwm4n0vxpra8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CFqwmitinDNdXPsCF/art.json b/art/CFqwmitinDNdXPsCF/art.json index 839b148a..39c07ab0 100644 --- a/art/CFqwmitinDNdXPsCF/art.json +++ b/art/CFqwmitinDNdXPsCF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-jyume-18-phantasm-plus-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n🍩\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0, 0, s,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n s, 0, 0, c); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, c, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, c); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 1, 1, 0, 0,\\n 1, 0, 1, 0,\\n 0, 1, 1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(0., 1., vy);\\n \\n float gv = (groupId + vy) / numGroups; \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n float s = texture2D(sound, vec2(mix(0.1, 0.15, abs(gv * 2. - 1.)), 0)).a;\\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE /2., ux, inner, start, end, pos); \\n vec3 nrm = pos;\\n \\n float r = 4.;\\n float ct = time * .15;\\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\\n vec3 target = vec3(0, -3, 0);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotY(gv * PI * 2.);\\n mat *= trans(vec3(5,0,0));\\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n vec3 n = (mat * vec4(nrm, 0)).xyz;\\n\\n float hue = ct + sin(gv * PI) * 0.1;\\n float sat = 1. - pow(s + .45, 15.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\\n float l = dot(n, lightDir) * .5 + .5;\\n \\n v_color.rgb *= mix(1., l, sat);\\n v_color.rgb *= v_color.a;\\n \\n //v_color.rgb = n * .5 + .5;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-jyume-18-phantasm-plus-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n🍩\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0, 0, s,\n 0, c, s, 0,\n 0, -s, c, 0,\n s, 0, 0, c); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, c, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, c); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 1, 1, 0, 0,\n 1, 0, 1, 0,\n 0, 1, 1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(0., 1., vy);\n \n float gv = (groupId + vy) / numGroups; \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n float s = texture2D(sound, vec2(mix(0.1, 0.15, abs(gv * 2. - 1.)), 0)).a;\n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE /2., ux, inner, start, end, pos); \n vec3 nrm = pos;\n \n float r = 4.;\n float ct = time * .15;\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\n vec3 target = vec3(0, -3, 0);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n float sp = pow(snd, 5.0);\n\n mat *= rotY(gv * PI * 2.);\n mat *= trans(vec3(5,0,0));\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n vec3 n = (mat * vec4(nrm, 0)).xyz;\n\n float hue = ct + sin(gv * PI) * 0.1;\n float sat = 1. - pow(s + .45, 15.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\n float l = dot(n, lightDir) * .5 + .5;\n \n v_color.rgb *= mix(1., l, sat);\n v_color.rgb *= v_color.a;\n \n //v_color.rgb = n * .5 + .5;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-lu4cqfir5vfxpbycp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CGefenfT6rv2yQ4Bw/art.json b/art/CGefenfT6rv2yQ4Bw/art.json index 882c70a6..edb2d0e4 100644 --- a/art/CGefenfT6rv2yQ4Bw/art.json +++ b/art/CGefenfT6rv2yQ4Bw/art.json @@ -11,7 +11,19 @@ "origId": "nL6YpkW8YvGKNEKtj", "name": "point cloud vs spheres", "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*4.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*4.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-m6sn4mhftgzj4hoho-thumbnail.jpg", "views": { "$numberInt": "169" diff --git a/art/CHDRiwf7FFqgP2REr/art.json b/art/CHDRiwf7FFqgP2REr/art.json index 4b7c78db..f10f84a8 100644 --- a/art/CHDRiwf7FFqgP2REr/art.json +++ b/art/CHDRiwf7FFqgP2REr/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/newage62120/shades-of-chakra\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 1, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, -2,\\n s, 0, c, 0.4,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, -13, 0,\\n 0, 1.4/mouse.x, 1, 1,\\n c, 0,2, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, mouse.y*3., 0, 0.4,\\n 3, 1, 0, mouse.x,\\n 1, 0, 1, 2,\\n trans, 4);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -2, 0, 1, 0,\\n .1, -1., 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 0.3);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(crv(a0), crv(a1), 0);\\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\\n// return vec3(\\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n// 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 3000.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float qn = quadId / quadCount;\\n float ln = lineId / numLines;\\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.0, 0.1, pn))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.02, 0.12, pn))).a;\\n \\n snd0 = 0.6;\\n snd1 = 0.7;\\n// snd1 = snd0;\\n \\n float mult = .002;\\n getQuadPoint(\\n //pn + time * 0.5 + ln * .2, \\n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\\n mult,\\n pointId, \\n pow(snd0, 5.0) * 0.25, \\n vec2(\\n pow(snd0, 2.), \\n pow(snd1, 2.)), \\n pos, \\n uv); \\n \\n float across = floor(sqrt(numLines));\\n float down = floor(numLines / across);\\n float xx = mod(lineId, across);\\n float yy = floor(lineId / across);\\n float ux = xx / (across - 1.);\\n float vy = yy / (down - 1.);\\n \\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .15);\\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\\n gl_Position.xyz /= gl_Position.w;\\n gl_Position.z = -pn;\\n gl_Position.w = 1.;\\n\\n float hue = mix(0.95, 1.5, ln * 0.3 + qn * 00.) + time * 0.01;\\n float sat = 1. + sin(time) * .5;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pn);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n // v_color.a = 1.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/newage62120/shades-of-chakra", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 1, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, -2,\n s, 0, c, 0.4,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, -13, 0,\n 0, 1.4/mouse.x, 1, 1,\n c, 0,2, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, mouse.y*3., 0, 0.4,\n 3, 1, 0, mouse.x,\n 1, 0, 1, 2,\n trans, 4);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -2, 0, 1, 0,\n .1, -1., 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 0.3);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(crv(a0), crv(a1), 0);\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\n// return vec3(\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n// 0);\n}\n\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 3000.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float qn = quadId / quadCount;\n float ln = lineId / numLines;\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.0, 0.1, pn))).a;\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.02, 0.12, pn))).a;\n \n snd0 = 0.6;\n snd1 = 0.7;\n// snd1 = snd0;\n \n float mult = .002;\n getQuadPoint(\n //pn + time * 0.5 + ln * .2, \n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\n mult,\n pointId, \n pow(snd0, 5.0) * 0.25, \n vec2(\n pow(snd0, 2.), \n pow(snd1, 2.)), \n pos, \n uv); \n \n float across = floor(sqrt(numLines));\n float down = floor(numLines / across);\n float xx = mod(lineId, across);\n float yy = floor(lineId / across);\n float ux = xx / (across - 1.);\n float vy = yy / (down - 1.);\n \n float aspect = resolution.x / resolution.y;\n \n mat4 mat = scale(vec3(1, aspect, 1) * .15);\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\n gl_Position.xyz /= gl_Position.w;\n gl_Position.z = -pn;\n gl_Position.w = 1.;\n\n float hue = mix(0.95, 1.5, ln * 0.3 + qn * 00.) + time * 0.01;\n float sat = 1. + sin(time) * .5;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pn);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n // v_color.a = 1.;\n}" + }, "screenshotURL": "data/images/images-4eqkayamfh3we25ap-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CJqnsPPKxz3KGqWSZ/art.json b/art/CJqnsPPKxz3KGqWSZ/art.json index e7c6afc1..9d4dcfbc 100644 --- a/art/CJqnsPPKxz3KGqWSZ/art.json +++ b/art/CJqnsPPKxz3KGqWSZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":86913,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.4, 1) *3.;\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 8.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 4.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 6.), 2.)+1.;\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2.6 * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 3.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.6) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. + soundTexCoords0.x) + 0.071;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale(1. / 11.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1.3, 1.1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 86913, + "mode": "LINES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.4, 1) *3.;\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 8.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 4.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 6.), 2.)+1.;\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2.6 * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 3.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.6) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. + soundTexCoords0.x) + 0.071;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale(1. / 11.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1.3, 1.1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-gu6gyj2n68q7nwujc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CJyTYWu2F352dNTrn/art.json b/art/CJyTYWu2F352dNTrn/art.json index 935f44f9..e9480a26 100644 --- a/art/CJyTYWu2F352dNTrn/art.json +++ b/art/CJyTYWu2F352dNTrn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/lio-mass-it-apsara-mas-frequency-original-mix-open-your-mind-music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.;//0.5 + over * 0.7;\\n float sat = step(0.75,s2);\\n float val = pow(s2, 16.);\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/lio-mass-it-apsara-mas-frequency-original-mix-open-your-mind-music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.;//0.5 + over * 0.7;\n float sat = step(0.75,s2);\n float val = pow(s2, 16.);\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-43ydnt03cdasdoe4v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CQcbw4k7BmY3egppx/art.json b/art/CQcbw4k7BmY3egppx/art.json index cb7ab7a7..23d182b2 100644 --- a/art/CQcbw4k7BmY3egppx/art.json +++ b/art/CQcbw4k7BmY3egppx/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "visy", "avatarUrl": "https://avatars.githubusercontent.com/visy?s=200", - "settings": "{\"num\":17096,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/ep4/freeride\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n \\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n\\n float ss = texture2D(sound,vec2(point,point)).r;\\n\\n \\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0-ss);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2-time*0.01);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n (oC + c)*time*0.01*cos(time*0.1+point*10.5),\\n (oS + s)*time*0.01*sin(time*0.1+point*10.5));\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 10.0 - 9.*texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r);\\n\\n float b = 0.5 - pow(sin(count * 0.4) * 0.4 + 0.5, 1.0);\\n b /= time*0.00001*1.2*abs(cos(time*10.2)*0.5);mix(0.0, 0.7, b);\\n v_color = vec4(b+texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r, b+texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r, b+texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r, 1);\\n}\"}", + "settings": { + "num": 17096, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/ep4/freeride", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n \n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n\n float ss = texture2D(sound,vec2(point,point)).r;\n\n \n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0-ss);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2-time*0.01);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n (oC + c)*time*0.01*cos(time*0.1+point*10.5),\n (oS + s)*time*0.01*sin(time*0.1+point*10.5));\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 10.0 - 9.*texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r);\n\n float b = 0.5 - pow(sin(count * 0.4) * 0.4 + 0.5, 1.0);\n b /= time*0.00001*1.2*abs(cos(time*10.2)*0.5);mix(0.0, 0.7, b);\n v_color = vec4(b+texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r, b+texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r, b+texture2D(sound,vec2(cos(time)*xy.x*0.1,sin(time)*xy.y*0.1)).r, 1);\n}" + }, "screenshotURL": "data/images/images-vt2su5f6py5riuqk6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CQs9owSvkdHXMQDA8/art.json b/art/CQs9owSvkdHXMQDA8/art.json index fa629fa2..a71bbfae 100644 --- a/art/CQs9owSvkdHXMQDA8/art.json +++ b/art/CQs9owSvkdHXMQDA8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":35848,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n\\n gl_Position= vec4(0.0,0.0,0.0,1.0);\\n v_color = vec4 (1.0,0.0,0.0,1.0);\\n gl_PointSize=20.0;\\n \\n}\"}", + "settings": { + "num": 35848, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n\n gl_Position= vec4(0.0,0.0,0.0,1.0);\n v_color = vec4 (1.0,0.0,0.0,1.0);\n gl_PointSize=20.0;\n \n}" + }, "screenshotURL": "data/images/images-2tuh1q9uama6q4cbr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CS58jctRLd3zEqnaB/art.json b/art/CS58jctRLd3zEqnaB/art.json index dcdb0e6b..488ef176 100644 --- a/art/CS58jctRLd3zEqnaB/art.json +++ b/art/CS58jctRLd3zEqnaB/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":5051,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvoid main() {\\n\\n gl_PointSize = 10.0; \\n //gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.5,1.0);\\n v_color = vec4(1,1,0.5,1);\\n}\"}", + "settings": { + "num": 5051, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvoid main() {\n\n gl_PointSize = 10.0; \n //gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.5,1.0);\n v_color = vec4(1,1,0.5,1);\n}" + }, "screenshotURL": "data/images/images-c6dswm4of6tiskniw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CSXazpyPp2B7cScfa/art.json b/art/CSXazpyPp2B7cScfa/art.json index e045000e..40b363fa 100644 --- a/art/CSXazpyPp2B7cScfa/art.json +++ b/art/CSXazpyPp2B7cScfa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "julien", "avatarUrl": "https://avatars.githubusercontent.com/julien?s=200", - "settings": "{\"num\":17774,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/frank-biazzi/frank-biazzi-focus-driving\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n\\t\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n \\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n\\n float angle = ux / numCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n \\n return vec2(x, y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n \\n float numCircleSegments = 6.0;\\n vec2 circleXY = getCirclePoint(vertexId,\\n numCircleSegments);\\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.0;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time * 1.2 + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.1) * 0.25;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n \\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.025, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 4.0) * mix(1.0, 1.1, oddSlice) * .8;\\n \\n sc *= 20.0 / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1, aspect, 1));\\n \\n mat *= rotZ(time * 0.3);\\n \\n mat *= trans(vec3(ux, vy, 0) * 1.8);\\n \\n mat *= rotZ(snd * 40.0 * sign(ux));\\n \\n mat *= uniformScale(0.025 * sc);\\n \\n \\n\\n gl_Position = mat * pos;\\n \\n\\n float soff = sin(time + x * y * 0.02) * 8.0; \\n \\n float pump = step(0.08, snd);\\n \\n float hue = u + 0.1 + snd * 0.2 + time * 0.1; // u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float saturation = mix(0.0, 1.0, pump);\\n float value = mix(0.1, pow(snd + 0.02, 3.0), pump); //sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\n // hue = hue + pump + oddSlice * 0.5 + pump * 0.3;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 17774, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/frank-biazzi/frank-biazzi-focus-driving", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n\t\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n \n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n\n float angle = ux / numCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n \n return vec2(x, y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n \n float numCircleSegments = 6.0;\n vec2 circleXY = getCirclePoint(vertexId,\n numCircleSegments);\n \n \n float numPointsPerCircle = numCircleSegments * 6.0;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time * 1.2 + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.1) * 0.25;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n \n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.025, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 4.0) * mix(1.0, 1.1, oddSlice) * .8;\n \n sc *= 20.0 / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1, aspect, 1));\n \n mat *= rotZ(time * 0.3);\n \n mat *= trans(vec3(ux, vy, 0) * 1.8);\n \n mat *= rotZ(snd * 40.0 * sign(ux));\n \n mat *= uniformScale(0.025 * sc);\n \n \n\n gl_Position = mat * pos;\n \n\n float soff = sin(time + x * y * 0.02) * 8.0; \n \n float pump = step(0.08, snd);\n \n float hue = u + 0.1 + snd * 0.2 + time * 0.1; // u * 0.1 + sin(time + v * 20.0) * 0.05;\n float saturation = mix(0.0, 1.0, pump);\n float value = mix(0.1, pow(snd + 0.02, 3.0), pump); //sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n \n // hue = hue + pump + oddSlice * 0.5 + pump * 0.3;\n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-xerjpbk1fu2bsaw1e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CTgYQer69jnHTKudH/art.json b/art/CTgYQer69jnHTKudH/art.json index 60dcf918..3a094e97 100644 --- a/art/CTgYQer69jnHTKudH/art.json +++ b/art/CTgYQer69jnHTKudH/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":72000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\n//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=72000\\n\\n\\n#define tubeSpeedFactor 1. //KParameter 0.>>4.\\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 1. //KParameter 1.>>10.\\n#define radiusSizeFactor 0.2 //KParameter 0.05>>0.2\\n#define cubeScaleFactorX 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\\n#define cubeSizeFactor 0.5 \\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\n/*\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id *1.55),\\n cos(id *0.43),\\n sin(id*0.22));\\n}\\n*/\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\n//const float travelSpeed = -100.;\\nconst float expand = 120.;\\nconst float off = 0.09;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\\n \\n float sv = mod(vertexId-time*cudeSpeedFactor,vertexCount) / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n vec3 eye = r0 * expand + zaxis * 1.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nmat4 rotationMatrix(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n//\\n float sizeFactor = 1./10.;\\n \\n float shapeCount = floor(vertexCount / 36.);\\n float shapeId = floor(vertexId / 36.);\\n float shapeVertexId = mod(vertexId, 36.);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElementPerGroup = 10.;\\n float groupId = floor(shapeId/numberOfElementPerGroup);\\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\\n float relGroupId = shapeIdInGroup/numberOfElementPerGroup;\\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\\n \\n \\n float base = 14.5; // good place to adjust\\n base = time * tubeSpeedFactor;\\n\\n /*\\n vec3 b0 = getCurvePoint(base + off * 0.);\\n vec3 b1 = getCurvePoint(base + off * 1.);\\n vec3 b2 = getCurvePoint(base + off * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n \\n vec3 eye = b0 * expand + czaxis * 1.;\\n vec3 target = b1 * expand + czaxis;\\n vec3 up = cyaxis;\\n */\\n \\n /*\\n//Static eye\\n vec3 eye = vec3(0.5, 0.5, 2.5)*expand;\\n vec3 target = vec3(0.5, 0.5, 0.)*expand;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n */\\n \\n \\n //Following eye\\n float sv = 0.;//mod( (0. /2.)+time*0.,groupCount) / 1.;\\n float v = sv + base;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n //rotation around eye z axis\\n mat4 rotMat = rotationMatrix(zaxis, time*PI);\\n xaxis = (rotMat*vec4(xaxis,1.)).xyz;\\n yaxis = (rotMat*vec4(yaxis,1.)).xyz;\\n //\\n \\n vec3 eye = r1 * expand + zaxis * 1.;\\n vec3 target = r2 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n \\n \\n \\n mat4 vmat = inverse(cmat);\\n \\n \\n \\n \\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n //cubep*= sizeFactor;\\n\\n mat4 scaleMat = scale(vec3(cubeScaleFactorX*cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n mat4 zrot = rotZ(relGroupId*2.*PI);\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n //cbNi*=scaleMat;\\n \\n //create the circle group\\n \\n \\n \\n float radius = 100.*radiusSizeFactor;\\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n //base+= mod(time,2.);\\n mat4 wmat;\\n mat4 emat;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi;\\n //float rotx = atan( wmat.y, wmat.z );\\n //float roty = Math.atan2( x * Math.cos(rotx), z )\\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \\n \\n \\n //cbNi.xyz+= posi;\\n \\n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 72000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \n//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=72000\n\n\n#define tubeSpeedFactor 1. //KParameter 0.>>4.\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 1. //KParameter 1.>>10.\n#define radiusSizeFactor 0.2 //KParameter 0.05>>0.2\n#define cubeScaleFactorX 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\n#define cubeSizeFactor 0.5 \n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\n/*\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id *1.55),\n cos(id *0.43),\n sin(id*0.22));\n}\n*/\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\n//const float travelSpeed = -100.;\nconst float expand = 120.;\nconst float off = 0.09;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\n \n float sv = mod(vertexId-time*cudeSpeedFactor,vertexCount) / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n vec3 eye = r0 * expand + zaxis * 1.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nmat4 rotationMatrix(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n//\n float sizeFactor = 1./10.;\n \n float shapeCount = floor(vertexCount / 36.);\n float shapeId = floor(vertexId / 36.);\n float shapeVertexId = mod(vertexId, 36.);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElementPerGroup = 10.;\n float groupId = floor(shapeId/numberOfElementPerGroup);\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\n float relGroupId = shapeIdInGroup/numberOfElementPerGroup;\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\n \n \n float base = 14.5; // good place to adjust\n base = time * tubeSpeedFactor;\n\n /*\n vec3 b0 = getCurvePoint(base + off * 0.);\n vec3 b1 = getCurvePoint(base + off * 1.);\n vec3 b2 = getCurvePoint(base + off * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n \n vec3 eye = b0 * expand + czaxis * 1.;\n vec3 target = b1 * expand + czaxis;\n vec3 up = cyaxis;\n */\n \n /*\n//Static eye\n vec3 eye = vec3(0.5, 0.5, 2.5)*expand;\n vec3 target = vec3(0.5, 0.5, 0.)*expand;\n vec3 up = vec3(0.5, 0.5, 1.5);\n */\n \n \n //Following eye\n float sv = 0.;//mod( (0. /2.)+time*0.,groupCount) / 1.;\n float v = sv + base;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n //rotation around eye z axis\n mat4 rotMat = rotationMatrix(zaxis, time*PI);\n xaxis = (rotMat*vec4(xaxis,1.)).xyz;\n yaxis = (rotMat*vec4(yaxis,1.)).xyz;\n //\n \n vec3 eye = r1 * expand + zaxis * 1.;\n vec3 target = r2 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n \n \n \n mat4 vmat = inverse(cmat);\n \n \n \n \n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n //cubep*= sizeFactor;\n\n mat4 scaleMat = scale(vec3(cubeScaleFactorX*cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n mat4 zrot = rotZ(relGroupId*2.*PI);\n cubep = (zrot*vec4(cubep,1.)).xyz;\n //cbNi*=scaleMat;\n \n //create the circle group\n \n \n \n float radius = 100.*radiusSizeFactor;\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n vec4 color;\n \n \n //shapeId = mod(shapeId+time, shapeCount);\n //base+= mod(time,2.);\n mat4 wmat;\n mat4 emat;\n \n //shapeId = mod(shapeId+time, shapeCount);\n track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi;\n //float rotx = atan( wmat.y, wmat.z );\n //float roty = Math.atan2( x * Math.cos(rotx), z )\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \n \n \n //cbNi.xyz+= posi;\n \n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-zofjupzhw9i7n7asi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CTkvnfE6NaaXSPzzJ/art.json b/art/CTkvnfE6NaaXSPzzJ/art.json index 56b22ed5..4cd9e0b3 100644 --- a/art/CTkvnfE6NaaXSPzzJ/art.json +++ b/art/CTkvnfE6NaaXSPzzJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":41000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n// Tuned via XShade (http://www.funparadigm.com/xshad\\n#define kp0 2.0//KParameter -22.>>22.\\n#define kp1 1.0//KParameter -2.>>2.\\n//KVerticesNumber=41000.\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(90.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0.5,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 1.1415926\\n#define _05pi 2.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 8.;\\n\\n \\tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.20* kp1;\\n \\tvec2 height = vec2(22.*kp1,0.6);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 41000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n//KDrawmode=GL_TRIANGLE_STRIP\n// Tuned via XShade (http://www.funparadigm.com/xshad\n#define kp0 2.0//KParameter -22.>>22.\n#define kp1 1.0//KParameter -2.>>2.\n//KVerticesNumber=41000.\n\n////////////////////////////////////////////////////////////\n#define PI radians(90.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0.5,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 1.1415926\n#define _05pi 2.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 8.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.20* kp1;\n \tvec2 height = vec2(22.*kp1,0.6);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-odx2a9cagv1jtbkc0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CTzsP7M5MfkwZGXy2/art.json b/art/CTzsP7M5MfkwZGXy2/art.json index d9cfe9b0..d406bccc 100644 --- a/art/CTzsP7M5MfkwZGXy2/art.json +++ b/art/CTzsP7M5MfkwZGXy2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = (fract(pos+.5)-.5);\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId*.13;\\n\\n vec3 pos = posf(t,i);\\t\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += 1.7;\\n \\n pos.xy *= (3.-pos.z)*.7;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.1;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = (fract(pos+.5)-.5);\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId*.13;\n\n vec3 pos = posf(t,i);\t\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += 1.7;\n \n pos.xy *= (3.-pos.z)*.7;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.1;\n}" + }, "screenshotURL": "data/images/images-5aqkk347svcobzgje-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CXBRMQmfvMpA4bK9H/art.json b/art/CXBRMQmfvMpA4bK9H/art.json index 357ad727..53bb0424 100644 --- a/art/CXBRMQmfvMpA4bK9H/art.json +++ b/art/CXBRMQmfvMpA4bK9H/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "rojun", "avatarUrl": "https://secure.gravatar.com/avatar/d0fb9947940c68f7d8601a83d3f4a24a?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/wizkhalifa/wiz-khalifa-ty-dolla-ign-lil-yachty-sueco-the-child-speed-me-up-sonic-the-hedgehog?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float v = vertexId / vertexCount;\\n \\n vec2 sxy = vec2(0.1, 0.0);\\n vec4 ts = texture2D(sound, sxy);\\n vec4 tt = texture2D(sound, mix(vec2(0.0,0.0), vec2(0.0,0.4), v * ts.a));\\n float x = (sin(20.0 * PI * v * ts.a + time)) * log(ts.a / (1.0 - tt.a));\\n\\n float y = cos(30.0 * PI * v * (ts.a));\\n vec2 xy = vec2(x, y) * 0.5;\\n gl_Position = vec4(xy, 0, 1);\\n \\n\\n \\tgl_PointSize = (10.0 * v + 0.1);\\n\\n //float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(tt.a * 4.0, v, 1)), 1);\\n //v_color = vec4( ts.rgb, 1.0);\\n //v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/wizkhalifa/wiz-khalifa-ty-dolla-ign-lil-yachty-sueco-the-child-speed-me-up-sonic-the-hedgehog?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float v = vertexId / vertexCount;\n \n vec2 sxy = vec2(0.1, 0.0);\n vec4 ts = texture2D(sound, sxy);\n vec4 tt = texture2D(sound, mix(vec2(0.0,0.0), vec2(0.0,0.4), v * ts.a));\n float x = (sin(20.0 * PI * v * ts.a + time)) * log(ts.a / (1.0 - tt.a));\n\n float y = cos(30.0 * PI * v * (ts.a));\n vec2 xy = vec2(x, y) * 0.5;\n gl_Position = vec4(xy, 0, 1);\n \n\n \tgl_PointSize = (10.0 * v + 0.1);\n\n //float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(tt.a * 4.0, v, 1)), 1);\n //v_color = vec4( ts.rgb, 1.0);\n //v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-b42c2z4mxg99hh044-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CaPmeZQJn7C9sdRZw/art.json b/art/CaPmeZQJn7C9sdRZw/art.json index 8633895a..a44c7926 100644 --- a/art/CaPmeZQJn7C9sdRZw/art.json +++ b/art/CaPmeZQJn7C9sdRZw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lapixmusic/fugene2crossfade\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n\\n#define r 1.3 //KParameter 0.5>>4.\\n#define ocsFreq 1. //KParameter 1.>>4.\\n#define oscAmpFact 10. //KParameter 0.9>>2.\\n#define ocsFreq2 .05 //KParameter 1.>>4.\\n#define propagationFactor 0.5 //KParameter 1.>>4.\\n#define soundFactor 1. //KParameter 1.>>4.\\n#define shapeFactor0 1.25//KParameter 0.>>1.8\\n#define shapeFactor1 10.5 //KParameter 1.25>>2.\\n\\n//Shader functions\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\n}\\n\\nvec2 fSym(vec2 _p,float _s, float _h){\\n\\tvec2 k1 = v(_p,_s);\\n\\tvec2 k2 = v(_p+shapeFactor1*_h*k1,_s);\\n\\tvec2 k3 = v(_p+0.5*_h*k2,_s);\\n\\tvec2 k4 = v(_p+_h*k3,_s);\\n\\treturn _h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 colorize(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n //float finalDesiredPointSize = 1.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n float finalDesiredPointSize = resolution.x/across;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n u>0.5?u = 1.-u:u;\\n v>0.5?v = 1.- v:v;\\n \\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t\\n vec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\n \\tfor(int i = 0; i<20; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*propagationFactor + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=fSym(uv,s,hh);\\n\\t\\ts*=shapeFactor0;\\n\\t\\th/=1.25;\\n\\t }\\n\\t\\n v_color = vec4(colorize(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n\\n float tm = ocsFreq *time;\\n float tm2 = ocsFreq2*time;\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r/oscAmpFact, 0.3, r);\\n\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n float depth = soundFactor*(v_color.x+v_color.y+v_color.z)/3.;\\n \\n\\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = finalDesiredPointSize;\\n \\n}\\n\\n\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lapixmusic/fugene2crossfade", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n\n#define r 1.3 //KParameter 0.5>>4.\n#define ocsFreq 1. //KParameter 1.>>4.\n#define oscAmpFact 10. //KParameter 0.9>>2.\n#define ocsFreq2 .05 //KParameter 1.>>4.\n#define propagationFactor 0.5 //KParameter 1.>>4.\n#define soundFactor 1. //KParameter 1.>>4.\n#define shapeFactor0 1.25//KParameter 0.>>1.8\n#define shapeFactor1 10.5 //KParameter 1.25>>2.\n\n//Shader functions\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\n}\n\nvec2 fSym(vec2 _p,float _s, float _h){\n\tvec2 k1 = v(_p,_s);\n\tvec2 k2 = v(_p+shapeFactor1*_h*k1,_s);\n\tvec2 k3 = v(_p+0.5*_h*k2,_s);\n\tvec2 k4 = v(_p+_h*k3,_s);\n\treturn _h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 colorize(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n //float finalDesiredPointSize = 1.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n float finalDesiredPointSize = resolution.x/across;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n u>0.5?u = 1.-u:u;\n v>0.5?v = 1.- v:v;\n \n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t\n vec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \n \tfor(int i = 0; i<20; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*propagationFactor + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=fSym(uv,s,hh);\n\t\ts*=shapeFactor0;\n\t\th/=1.25;\n\t }\n\t\n v_color = vec4(colorize(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n\n float tm = ocsFreq *time;\n float tm2 = ocsFreq2*time;\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r/oscAmpFact, 0.3, r);\n\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n float depth = soundFactor*(v_color.x+v_color.y+v_color.z)/3.;\n \n\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = finalDesiredPointSize;\n \n}\n\n" + }, "screenshotURL": "data/images/images-0sggk7ecw217zo8sl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CbSdtkRA5gDx7hmXd/art.json b/art/CbSdtkRA5gDx7hmXd/art.json index b37c964e..898a3e50 100644 --- a/art/CbSdtkRA5gDx7hmXd/art.json +++ b/art/CbSdtkRA5gDx7hmXd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Vertexshaderart : Making a Grid\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Vertexshaderart : Making a Grid\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-iqtp3nz0l6va04iqf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CbmGerHritwgbEFvY/art.json b/art/CbmGerHritwgbEFvY/art.json index 74c3cdc5..40e96b23 100644 --- a/art/CbmGerHritwgbEFvY/art.json +++ b/art/CbmGerHritwgbEFvY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"\\n\\nvoid main() {\\n\\tgl_PointSize = 10.0;\\n \\tgl_Position = vec4(0.0,0.0,0.0,1.0);\\n \\tv_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "\n\nvoid main() {\n\tgl_PointSize = 10.0;\n \tgl_Position = vec4(0.0,0.0,0.0,1.0);\n \tv_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-z0joootz576g53u49-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Cc5rgXprLDzaGgDGt/art.json b/art/Cc5rgXprLDzaGgDGt/art.json index 89b107bc..1763314c 100644 --- a/art/Cc5rgXprLDzaGgDGt/art.json +++ b/art/Cc5rgXprLDzaGgDGt/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":2000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.8901960784313725,0.8431372549019608,1],\"shader\":\"/* \\n \\n \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n .___. \\n [__ | _ . , _ ._. \\n | |(_) \\\\/\\\\/ (/,[ \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n@31/12/2019 \\n*/ \\n#define PI radians(180.)\\n\\n\\nmat4 mAspect = mat4\\n(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n); \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\n/* -------------------------------- separater ------------------------------- */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/* -------------------------------- separater ------------------------------- */\\n\\nvoid main() \\n{\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1 , 20. ); \\n vec3 camera = vec3(0. , 0. , 1. ) ;\\n vec3 target = vec3(0.);\\n vec3 up = vec3(0., 1., 0.); \\n m*= cameraLookAt(camera , target , up);\\n m*= uniformScale(0.4);\\n \\n float radius = 0. ; \\n vec3 pos = vec3(0.) ; \\n \\n if(vertexId < 1000. )\\n {\\n\\tconst float fLength = 10. ; \\n float fy = floor(vertexId / vertexCount);\\n float xOffset = fract(vertexId / vertexCount) * 0.2; \\n float yOffset = sqrt(xOffset) ; \\n \\n pos = vec3(target.x + xOffset, target.y - yOffset , 0. );\\n } \\n else\\n {\\n radius = sin(vertexId * 5.) * .2 ;\\n float xPos = radius * sin(vertexId) ; \\n float yPos = radius * cos(vertexId) ; \\n pos = vec3( xPos, yPos, 0.);\\n }\\n gl_Position = m*vec4(pos + target, 1); \\n gl_PointSize = 2.; \\n v_color = vec4(vec3(0.), 1.); \\n \\n}\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\"}", + "settings": { + "num": 2000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.8901960784313725, + 0.8431372549019608, + 1 + ], + "shader": "/* \n \n \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n .___. \n [__ | _ . , _ ._. \n | |(_) \\/\\/ (/,[ \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n \n@31/12/2019 \n*/ \n#define PI radians(180.)\n\n\nmat4 mAspect = mat4\n(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n); \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\n/* -------------------------------- separater ------------------------------- */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* -------------------------------- separater ------------------------------- */\n\nvoid main() \n{\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1 , 20. ); \n vec3 camera = vec3(0. , 0. , 1. ) ;\n vec3 target = vec3(0.);\n vec3 up = vec3(0., 1., 0.); \n m*= cameraLookAt(camera , target , up);\n m*= uniformScale(0.4);\n \n float radius = 0. ; \n vec3 pos = vec3(0.) ; \n \n if(vertexId < 1000. )\n {\n\tconst float fLength = 10. ; \n float fy = floor(vertexId / vertexCount);\n float xOffset = fract(vertexId / vertexCount) * 0.2; \n float yOffset = sqrt(xOffset) ; \n \n pos = vec3(target.x + xOffset, target.y - yOffset , 0. );\n } \n else\n {\n radius = sin(vertexId * 5.) * .2 ;\n float xPos = radius * sin(vertexId) ; \n float yPos = radius * cos(vertexId) ; \n pos = vec3( xPos, yPos, 0.);\n }\n gl_Position = m*vec4(pos + target, 1); \n gl_PointSize = 2.; \n v_color = vec4(vec3(0.), 1.); \n \n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n" + }, "screenshotURL": "data/images/images-u1lthy52spu3zlqbj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ce87kL3i6r98HePhT/art.json b/art/Ce87kL3i6r98HePhT/art.json index 315a0970..662705a4 100644 --- a/art/Ce87kL3i6r98HePhT/art.json +++ b/art/Ce87kL3i6r98HePhT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const int num = 6;\\nvec3 points[num];\\nvec3 colors[num];\\n\\nvoid f_p()\\n{\\n points[0] = vec3(-0.5, -0.5, 0);\\n points[1] = vec3(-0.5, 0.5, 0);\\n points[2] = vec3( 0.5, -0.5, 0);\\n points[3] = vec3( 0.5, 0.5, 0);\\n points[4] = vec3( 0.5, -0.5, 1);\\n points[5] = vec3( 0.5, 0.5, 1);\\n \\n colors[0] = vec3( 1 , 0, 0);\\n colors[1] = vec3( 1 , 0, 0);\\n colors[2] = vec3( 1 , 0, 1);\\n colors[3] = vec3( 1 , 0, 1);\\n colors[4] = vec3( 0 , 0, 1);\\n colors[5] = vec3( 0 , 0, 1);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye , 2.5\\n );\\n}\\n\\n\\nvoid main() {\\n int VD = int(vertexId);\\n f_p();\\n vec2 mo = mouse;\\n float ct = time;\\n \\n vec3 p = vec3(sin(ct), 2, sin(ct)+1.);\\n vec3 t = vec3(p.x, 0, 4. + sin(ct));\\n vec3 u = normalize(vec3(sin(ct + 2.5)* 0.3, -1, 0));\\n \\n for(int i=0; i(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n \\n \\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y ; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+2.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/2.40);\\n gl_Position.xy-=vec2(.7,1.0);\\n float sample =texture2D(sound, (gl_Position.xy+1.0)/1.9 ).a;\\n gl_PointSize=sample*2.0;\\n gl_Position.z=(sample);\\n v_color =vec4(sample);\\n \\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n \n \n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y ; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+2.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/2.40);\n gl_Position.xy-=vec2(.7,1.0);\n float sample =texture2D(sound, (gl_Position.xy+1.0)/1.9 ).a;\n gl_PointSize=sample*2.0;\n gl_Position.z=(sample);\n v_color =vec4(sample);\n \n \n}" + }, "screenshotURL": "data/images/images-hx84zvn5n79vijhha-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CfPegKAcPj5D6axAW/art.json b/art/CfPegKAcPj5D6axAW/art.json index 9df87dee..bbc32f7f 100644 --- a/art/CfPegKAcPj5D6axAW/art.json +++ b/art/CfPegKAcPj5D6axAW/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "tim", "avatarUrl": "https://graph.facebook.com/10100145163528628/picture?type=large", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/je_suis_sierra/sierra-a-cold-night\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n# define PI radians (180.0)\\nvoid main (){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan (su,sv)) / PI;\\n float av = length(vec2(su,sv)); \\n float snd = texture2D(sound, vec2(au * .05 , av * .25)).a;\\n \\n gl_Position = vec4( xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.2) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\\n gl_PointSize *= 20./ across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + snd; // sin(time + v * 20.) * 0.05 ;\\n float sat = step(0.8, snd);\\n float val = pow(snd + 0.2, 5.);//sin(time + v * u * 20.0)*.5 +.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/je_suis_sierra/sierra-a-cold-night", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n# define PI radians (180.0)\nvoid main (){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan (su,sv)) / PI;\n float av = length(vec2(su,sv)); \n float snd = texture2D(sound, vec2(au * .05 , av * .25)).a;\n \n gl_Position = vec4( xy, 0, 1);\n \n float soff = sin(time + x * y * 0.2) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\n gl_PointSize *= 20./ across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + snd; // sin(time + v * 20.) * 0.05 ;\n float sat = step(0.8, snd);\n float val = pow(snd + 0.2, 5.);//sin(time + v * u * 20.0)*.5 +.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-8u2uy00zhzjym250s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CgmFpc7tyuEKBCKdm/art.json b/art/CgmFpc7tyuEKBCKdm/art.json index 66e8715f..8e454e69 100644 --- a/art/CgmFpc7tyuEKBCKdm/art.json +++ b/art/CgmFpc7tyuEKBCKdm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=7c652ddc2d064bbbad85c4463ef16934&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Audio Reactive\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 1. + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=7c652ddc2d064bbbad85c4463ef16934&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Audio Reactive\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * 1. + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-vjwitpzi4b2tfbxy8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ch3PxmZwN22dkrGCg/art.json b/art/Ch3PxmZwN22dkrGCg/art.json index 181f90dd..1c85db34 100644 --- a/art/Ch3PxmZwN22dkrGCg/art.json +++ b/art/Ch3PxmZwN22dkrGCg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bodhicollective/metacentric-eating-worms\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define SEGMENTS_PER_LINE 10.\\n#define VERTICES_PER_LINE (SEGMENTS_PER_LINE * 2.)\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvoid main() {\\n float vId = mod(vertexId, VERTICES_PER_LINE);\\n float vv = vId / (VERTICES_PER_LINE - 1.);\\n float lineId = floor(vertexId / VERTICES_PER_LINE);\\n float numLines = floor(vertexCount / VERTICES_PER_LINE);\\n float lineV = lineId / (numLines - 1.);\\n float p = float(vId / 2.) + mod(vId, 2.); \\n float pv = p / SEGMENTS_PER_LINE;\\n \\n float t = time * 8.;\\n float vxOff = lineV * 50.;\\n float vyOff = lineV * 50.;\\n float vs = pv * 2.;\\n vec2 xy = vec2(goop(t + vs + vxOff), goop(t + 10.5 + vs + vyOff)) * .0125;\\n \\n vec2 off = vec2(t2m1(hash(lineId * 0.123)), t2m1(hash(lineId * 0.717)));\\n \\n float su = hash(lineId * 0.511);\\n float sv = abs(atan(off.x, off.y));\\n float s = texture2D(sound, vec2(mix(0.2, 0.5, su), sv * .1)).a;\\n \\n \\n float aspect = resolution.x / resolution.y;\\n gl_Position = vec4(xy + off, -pv, 1) * vec4(1, aspect, 1, 1); \\n gl_PointSize = 5. * pv;\\n \\n float hue = .5 + lineV * .1 + pv * -.1;\\n float sat = .5;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pv * pow(mix(0., 2., s), 4.));\\n float pp = step(s, 0.5);\\n v_color.rgb = mix(v_color.rgb, vec3(0,0,0), pp);\\n gl_PointSize *= mix(0.5, 1., pp);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/bodhicollective/metacentric-eating-worms", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define SEGMENTS_PER_LINE 10.\n#define VERTICES_PER_LINE (SEGMENTS_PER_LINE * 2.)\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvoid main() {\n float vId = mod(vertexId, VERTICES_PER_LINE);\n float vv = vId / (VERTICES_PER_LINE - 1.);\n float lineId = floor(vertexId / VERTICES_PER_LINE);\n float numLines = floor(vertexCount / VERTICES_PER_LINE);\n float lineV = lineId / (numLines - 1.);\n float p = float(vId / 2.) + mod(vId, 2.); \n float pv = p / SEGMENTS_PER_LINE;\n \n float t = time * 8.;\n float vxOff = lineV * 50.;\n float vyOff = lineV * 50.;\n float vs = pv * 2.;\n vec2 xy = vec2(goop(t + vs + vxOff), goop(t + 10.5 + vs + vyOff)) * .0125;\n \n vec2 off = vec2(t2m1(hash(lineId * 0.123)), t2m1(hash(lineId * 0.717)));\n \n float su = hash(lineId * 0.511);\n float sv = abs(atan(off.x, off.y));\n float s = texture2D(sound, vec2(mix(0.2, 0.5, su), sv * .1)).a;\n \n \n float aspect = resolution.x / resolution.y;\n gl_Position = vec4(xy + off, -pv, 1) * vec4(1, aspect, 1, 1); \n gl_PointSize = 5. * pv;\n \n float hue = .5 + lineV * .1 + pv * -.1;\n float sat = .5;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pv * pow(mix(0., 2., s), 4.));\n float pp = step(s, 0.5);\n v_color.rgb = mix(v_color.rgb, vec3(0,0,0), pp);\n gl_PointSize *= mix(0.5, 1., pp);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-pt8qau7cw08y8b8t4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ChgRzRLbrFD5wzfZk/art.json b/art/ChgRzRLbrFD5wzfZk/art.json index a0beafa2..92ad2201 100644 --- a/art/ChgRzRLbrFD5wzfZk/art.json +++ b/art/ChgRzRLbrFD5wzfZk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ziad-husni/skyguide-music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nfloat easeInOutPow(float pos, float pw) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, pw);\\n }\\n return 0.5 * (pow((pos - 2.), pw) + 2.);\\n}\\n\\n\\nvoid main() {\\n vec3 pos = vec3(0, 0, 0);\\n //pos *= vec3(100, 100, 10);\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\\n float tm = time * -0.05;\\n float t2 = time * 0.05;\\n float t3 = time * 0.04;\\n float r = mix(10., 5., sin(t3) * .5 + .5);\\n vec3 eye = vec3(cos(tm) * r, sin(t2) * 2. + 3., sin(tm) * r);\\n vec3 target = vec3(0, sin(t2) * -2.5, 0);\\n vec3 up = vec3(0, 1, 0);\\n mat *= cameraLookAt(eye, target, up);\\n \\n vec3 n = normalize(\\n vec3(\\n hash(vertexId * 0.123), \\n hash(vertexId * 0.357), \\n hash(vertexId * 0.531)\\n ) * 2. - 1.\\n );\\n \\n if (vertexId < 5000.0) {\\n mat *= trans(n * 84.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.25;;\\n v_color = vec4(hash(vertexId * 0.211));\\n } else {\\n float d = hash(vertexId * 0.713);// * (sin(vertexId * 1.5) * .5 + .5);\\n \\n float s = texture2D(sound, vec2(d * .1, 0)).a;\\n \\n mat *= rotY(time * mix(0.01, 0.3, (1. - d)) + sin(atan(n.x,n.z) * 20.));\\n mat *= scale(vec3(10, easeInOutPow((1. - d), 4.) * 5., 10));\\n mat *= trans(n * pow(d, 3.));\\n gl_Position = mat * vec4(pos, 1);\\n\\n vec4 f = mat * vec4(1,1,pos.z,1);\\n f = f / f.w;\\n\\n gl_PointSize = mix(1.5, 2.5, (1. - d)); //f.y * 0.5;\\n float hue = mix(0.4, 0.8, s);\\n float sat = 0.45;\\n float val = mix(1., 1., s);\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), pow(1.-d, 0.2));\\n } \\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ziad-husni/skyguide-music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nfloat easeInOutPow(float pos, float pw) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, pw);\n }\n return 0.5 * (pow((pos - 2.), pw) + 2.);\n}\n\n\nvoid main() {\n vec3 pos = vec3(0, 0, 0);\n //pos *= vec3(100, 100, 10);\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\n float tm = time * -0.05;\n float t2 = time * 0.05;\n float t3 = time * 0.04;\n float r = mix(10., 5., sin(t3) * .5 + .5);\n vec3 eye = vec3(cos(tm) * r, sin(t2) * 2. + 3., sin(tm) * r);\n vec3 target = vec3(0, sin(t2) * -2.5, 0);\n vec3 up = vec3(0, 1, 0);\n mat *= cameraLookAt(eye, target, up);\n \n vec3 n = normalize(\n vec3(\n hash(vertexId * 0.123), \n hash(vertexId * 0.357), \n hash(vertexId * 0.531)\n ) * 2. - 1.\n );\n \n if (vertexId < 5000.0) {\n mat *= trans(n * 84.);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.25;;\n v_color = vec4(hash(vertexId * 0.211));\n } else {\n float d = hash(vertexId * 0.713);// * (sin(vertexId * 1.5) * .5 + .5);\n \n float s = texture2D(sound, vec2(d * .1, 0)).a;\n \n mat *= rotY(time * mix(0.01, 0.3, (1. - d)) + sin(atan(n.x,n.z) * 20.));\n mat *= scale(vec3(10, easeInOutPow((1. - d), 4.) * 5., 10));\n mat *= trans(n * pow(d, 3.));\n gl_Position = mat * vec4(pos, 1);\n\n vec4 f = mat * vec4(1,1,pos.z,1);\n f = f / f.w;\n\n gl_PointSize = mix(1.5, 2.5, (1. - d)); //f.y * 0.5;\n float hue = mix(0.4, 0.8, s);\n float sat = 0.45;\n float val = mix(1., 1., s);\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), pow(1.-d, 0.2));\n } \n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-qq1r2ih36yr4y9ik5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CiTmPsWuiBPzTRgDn/art.json b/art/CiTmPsWuiBPzTRgDn/art.json index 04a8eeaf..1f88f514 100644 --- a/art/CiTmPsWuiBPzTRgDn/art.json +++ b/art/CiTmPsWuiBPzTRgDn/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":54,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n vec3 pos = vec3(cos(time+vertexId)*0.7, sin(time+vertexId), 0.0);\\n float color = 1.0;\\n gl_PointSize = 40.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0)+0.5;\\n}\"}", + "settings": { + "num": 54, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n vec3 pos = vec3(cos(time+vertexId)*0.7, sin(time+vertexId), 0.0);\n float color = 1.0;\n gl_PointSize = 40.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0)+0.5;\n}" + }, "screenshotURL": "data/images/images-nx2k1jvqdmfkqwyam-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Cj2C3bSnE4yoFBfHp/art.json b/art/Cj2C3bSnE4yoFBfHp/art.json index b07861cd..a5ac0f6f 100644 --- a/art/Cj2C3bSnE4yoFBfHp/art.json +++ b/art/Cj2C3bSnE4yoFBfHp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":60,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n\\n#define AND(a,x) int(floor(x - (a * 16.0)))\\n#define MASK 1024.0\\n#define SCALE 112.0\\n#define MAX_TRIS 32\\n#define TOTAL_TRI 21\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec3 triangles[MAX_TRIS];\\nmat4 indices[4];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid populate(){ \\n\\ntriangles[0]=vec3(18451.0,7169.0,46.0);\\ntriangles[1]=vec3(46.0,18451.0,22588.0);\\ntriangles[2]=vec3(22588.0,46.0,75.0);\\ntriangles[3]=vec3(75.0,22588.0,18534.0);\\ntriangles[4]=vec3(18534.0,75.0,7288.0);\\ntriangles[5]=vec3(46.0,54525998.0,75.0);\\ntriangles[6]=vec3(54525998.0,54526027.0,75.0);\\ntriangles[7]=vec3(19930228.0,75.0,54526027.0) ;\\ntriangles[8]=vec3(7288.0,19930228.0,75.0);\\ntriangles[9]=vec3(19930116.0,46.0,54525998.0);\\ntriangles[10]=vec3(7169.0,19930116.0,46.0) ;\\ntriangles[11]=vec3(31473724.0,54526027.0,54525998.0) ;\\ntriangles[12]=vec3(31473724.0,22588.0,18534.0) ;\\ntriangles[13]=vec3(31473724.0,18451.0,22588.0) ;\\ntriangles[14]=vec3(31473724.0,18534.0,54526027.0) ;\\ntriangles[15]=vec3(31473724.0,54525998.0,18451.0) ;\\ntriangles[16]=vec3(54526027.0,18534.0,19930228.0) ;\\ntriangles[17]=vec3(54525998.0,18451.0,19930116.0) ;\\ntriangles[18]=vec3(7288.0,18534.0,19930228.0) ;\\ntriangles[19]=vec3(7169.0,18451.0,19930116.0) ;\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTICES_PER_TRI));\\n for(int i=0;i 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, DirLight,\\n sv) ; \\n vertexIndex -= floorVertexCount ; \\n #pragma endregion \\n \\n #pragma region Sphere\\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo,\\n DirLight, \\n camPos,\\n sv);\\n m *= uniformScale(1.5);\\n m *= trans(vec3(0. , 4. , 0. )) ; \\n }\\n vertexIndex -= fSphereVertexCount ; \\n #pragma endregion \\n#pragma endregion \\n \\n \\n#pragma region PostEffect\\n // PE_Vignette(sv) ;\\n#pragma endregion \\n \\n#pragma region ApplySetting\\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n#pragma endregion \\n}\"}", + "settings": { + "num": 18744, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.10196078431372549, + 0.10196078431372549, + 1 + ], + "shader": "// https://www.vertexshaderart.com/art/7qtbHrwZAwuFQLxhC\n\n\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 1.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t \n vec3 vOrigin;\n float fRadius ; \n \n float fSlices ; \n float fSegments ; \n }; \n \n struct Material \n {\n vec4 diffuseAlebdo;\n vec3 FresenlR0 ;\n float Roughness ;\n mat4 MatTransform ; \n }; \n struct Light\n {\n\n vec3 vStrength ; \n float FalloffStart ; \n vec3 vDirection ; \n float FalloffEnd ; \n vec3 vPosition ; \n float SpotPower ; \n };\n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, DirLight,\n sv) ; \n vertexIndex -= floorVertexCount ; \n #pragma endregion \n \n #pragma region Sphere\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo,\n DirLight, \n camPos,\n sv);\n m *= uniformScale(1.5);\n m *= trans(vec3(0. , 4. , 0. )) ; \n }\n vertexIndex -= fSphereVertexCount ; \n #pragma endregion \n#pragma endregion \n \n \n#pragma region PostEffect\n // PE_Vignette(sv) ;\n#pragma endregion \n \n#pragma region ApplySetting\n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n#pragma endregion \n}" + }, "screenshotURL": "data/images/images-34od41qc7j45hkxo8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Cn2Pn9cEKGgg9ZkC5/art.json b/art/Cn2Pn9cEKGgg9ZkC5/art.json index d9937b16..a0ce7a3d 100644 --- a/art/Cn2Pn9cEKGgg9ZkC5/art.json +++ b/art/Cn2Pn9cEKGgg9ZkC5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name \\n\\nvoid main()\\n{\\n \\n}\\n \"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name \n\nvoid main()\n{\n \n}\n " + }, "screenshotURL": "data/images/images-9v4c6yg6b0gsxxcce-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CnETJJi9SW7LPRebg/art.json b/art/CnETJJi9SW7LPRebg/art.json index 35677d50..f85536b6 100644 --- a/art/CnETJJi9SW7LPRebg/art.json +++ b/art/CnETJJi9SW7LPRebg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20001,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 20000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n // Good values for f:\\n // 0.0 in bass is always around 1\\n // 0.5 is in the mids, goes with music\\n // 1.0 is in the highs always 0\\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float phi = TWO_PI * t * 5.0;\\n float theta = TWO_PI * t * 7.0;\\n float sigma = t * TWO_PI;\\n float r = 0.7 + t * 0.3;\\n \\n phi += sin(theta * 5.0) * r * 0.2;\\n theta += cos(phi * 3.0) * r * 0.10;\\n sigma += sin(theta * 7.0) * r * 0.3;\\n r += sin(phi * 11.0) * 0.1 * r;\\n \\n phi += cos(sigma * 13.0 + r) * 0.2 * r * r;\\n theta += sin(phi * 11.0 + r) * 0.3 * r;\\n sigma += cos(theta * 3.0) * 0.2;\\n r += cos(theta) * 0.1 * r;\\n r *= 0.8 + 0.2 * sin(t * TWO_PI * 21.0);\\n r *= 0.5 + 0.5 * sqrt(t);\\n \\n float x0 = cos(phi) * r;\\n float y0 = sin(phi) * r;\\n float z0 = 0.0;\\n \\n float x1 = x0;\\n float y1 = sin(theta) * y0 + cos(theta) * z0;\\n float z1 = cos(theta) * y0 - sin(theta) * z0;\\n \\n float x = x1 * cos(sigma) + y1 * sin(sigma);\\n float y = x1 * sin(sigma) - y1 * cos(sigma);\\n float z = z1;\\n \\n return vec3(x, y, z\\n );\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\\n \\n float power = 0.0;\\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\\n power = sqrt(power);\\n \\n\\n float mix1 = getSound(r, 0.0) - r;\\n float mix2 = power - r + 0.3;\\n float mixt = mix1 * 3.0 + mix2 * 10.0;\\n \\n float rwave = sin(mixt * 0.8);\\n float tpulse = sin((time * 0.16 + t * 100.0) * TWO_PI + mixt * 0.05);\\n float trpulse = sin(r * 0.75 * TWO_PI - time);\\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\\n \\n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\\n \\n \\n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\\n float s = 1.0 - ((1.0 - rpulse) * pulse);\\n\\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\\n}\"}", + "settings": { + "num": 20001, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 20000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n // Good values for f:\n // 0.0 in bass is always around 1\n // 0.5 is in the mids, goes with music\n // 1.0 is in the highs always 0\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\n}\n\nvec3 curvePos(float t) {\n float phi = TWO_PI * t * 5.0;\n float theta = TWO_PI * t * 7.0;\n float sigma = t * TWO_PI;\n float r = 0.7 + t * 0.3;\n \n phi += sin(theta * 5.0) * r * 0.2;\n theta += cos(phi * 3.0) * r * 0.10;\n sigma += sin(theta * 7.0) * r * 0.3;\n r += sin(phi * 11.0) * 0.1 * r;\n \n phi += cos(sigma * 13.0 + r) * 0.2 * r * r;\n theta += sin(phi * 11.0 + r) * 0.3 * r;\n sigma += cos(theta * 3.0) * 0.2;\n r += cos(theta) * 0.1 * r;\n r *= 0.8 + 0.2 * sin(t * TWO_PI * 21.0);\n r *= 0.5 + 0.5 * sqrt(t);\n \n float x0 = cos(phi) * r;\n float y0 = sin(phi) * r;\n float z0 = 0.0;\n \n float x1 = x0;\n float y1 = sin(theta) * y0 + cos(theta) * z0;\n float z1 = cos(theta) * y0 - sin(theta) * z0;\n \n float x = x1 * cos(sigma) + y1 * sin(sigma);\n float y = x1 * sin(sigma) - y1 * cos(sigma);\n float z = z1;\n \n return vec3(x, y, z\n );\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\n \n float power = 0.0;\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\n power = sqrt(power);\n \n\n float mix1 = getSound(r, 0.0) - r;\n float mix2 = power - r + 0.3;\n float mixt = mix1 * 3.0 + mix2 * 10.0;\n \n float rwave = sin(mixt * 0.8);\n float tpulse = sin((time * 0.16 + t * 100.0) * TWO_PI + mixt * 0.05);\n float trpulse = sin(r * 0.75 * TWO_PI - time);\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\n \n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\n \n \n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\n float s = 1.0 - ((1.0 - rpulse) * pulse);\n\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\n}" + }, "screenshotURL": "data/images/images-0l0fnresu4z1qwvzd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CnGnHHGBHNdY2ZAbG/art.json b/art/CnGnHHGBHNdY2ZAbG/art.json index 64fda287..8d0e02d2 100644 --- a/art/CnGnHHGBHNdY2ZAbG/art.json +++ b/art/CnGnHHGBHNdY2ZAbG/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Audio Reactive\\n// CS250 \\n// Spring/2022\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Audio Reactive\n// CS250 \n// Spring/2022\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-s1t1adr52ns2bfoig-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Cou2fm28Bk2J2vbgy/art.json b/art/Cou2fm28Bk2J2vbgy/art.json index 103b538e..1b0ec67c 100644 --- a/art/Cou2fm28Bk2J2vbgy/art.json +++ b/art/Cou2fm28Bk2J2vbgy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mike-tobia", "avatarUrl": "https://avatars.githubusercontent.com/mike-tobia?s=200", - "settings": "{\"num\":1500,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * .2) * .2;\\n float yoff = sin(time + x * .2) * .2;\\n \\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float scale = .1;\\n \\n vec2 xy = vec2(ux, vy) * scale;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .002) * 15.;\\n \\n gl_PointSize = 10. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= mod(resolution.x / 600. * scale, 1.);\\n \\n\\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 1500, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * .2) * .2;\n float yoff = sin(time + x * .2) * .2;\n \n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float scale = .1;\n \n vec2 xy = vec2(ux, vy) * scale;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .002) * 15.;\n \n gl_PointSize = 10. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= mod(resolution.x / 600. * scale, 1.);\n \n\n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-6obwrsqwahnpt7n4q-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CqxWREeQWkFuAtK5d/art.json b/art/CqxWREeQWkFuAtK5d/art.json index e730750b..8b4f9a0a 100644 --- a/art/CqxWREeQWkFuAtK5d/art.json +++ b/art/CqxWREeQWkFuAtK5d/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":5638,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.21176470588235294,0.06666666666666667,0.43137254901960786,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Circles from Triangles\\n// Course : CS250\\n// Term & Year : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident()\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{ \\n float ux = floor(id / 6.) + mod(id, 2.); \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n\\n}\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, \\n numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; \\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\\n float sat = 1.; //mix(0.5, 1., pump); //mix(1., -10., av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5638, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.21176470588235294, + 0.06666666666666667, + 0.43137254901960786, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Circles from Triangles\n// Course : CS250\n// Term & Year : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident()\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s)\n{\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{ \n float ux = floor(id / 6.) + mod(id, 2.); \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n\n}\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, \n numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; \n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\n float sat = 1.; //mix(0.5, 1., pump); //mix(1., -10., av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ual4igpo37zdf5d8s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CsHf78qYSxbxGPwhv/art.json b/art/CsHf78qYSxbxGPwhv/art.json index 5f8b6906..d7852fb5 100644 --- a/art/CsHf78qYSxbxGPwhv/art.json +++ b/art/CsHf78qYSxbxGPwhv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":38370,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hugdealer/rtype-and-666gangstaz-john-wayne\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0,0.25098039215686274,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n#define K0 2.//KParameter0 1.>>18.\\n#define K1 \\t1.//KParameter1 11.>>10.\\n#define K2 2.//KParameter2 4.>>22.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n#define KP0 K0 * mouse.x\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.40), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( s -angle *2.);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 2,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1)*2.5;\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 1, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 2)*1.5;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 952.4337)-1.2;\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1. +v;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 100.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\\nvoid main() {\\n float vertexCount = (2800.0 * K1 * K2* mouse.y);\\n float quadCount = POINTS_PER_LINE / 3.; \\n float v = vertexId / vertexCount;\\n float invV = 2. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = tan(vertexId* 71.) / 12000. *mouse.y;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.0, 10.61, spread), mix(0.25, 10.1, v))).a;\\n \\n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 1.3 + vertexId / 2.1), goop(time * .11 + vertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\\n time-sin(snd0*KP0);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 6.4)).xyz, 1.82);\\n gl_Position.z = -m1p1(v*snd1);\\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 2.1;\\n gl_PointSize = 5.;\\n\\n float hue = mix(0.185, snd1 *.8, pow(snd1, 1.));\\n float sat = 0.2 * pow(snd0 * 8.2, 1.);\\n float val = -0.15 +snd0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.62);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 38370, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hugdealer/rtype-and-666gangstaz-john-wayne", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0, + 0.25098039215686274, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\n\n\n#define K0 2.//KParameter0 1.>>18.\n#define K1 \t1.//KParameter1 11.>>10.\n#define K2 2.//KParameter2 4.>>22.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n#define KP0 K0 * mouse.x\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.40), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( s -angle *2.);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 2,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1)*2.5;\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, 0, 0, 2);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 1, 0,\n 0, 0, s, 0,\n 0, 0, 0, 2)*1.5;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 952.4337)-1.2;\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1. +v;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 100.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\nvoid main() {\n float vertexCount = (2800.0 * K1 * K2* mouse.y);\n float quadCount = POINTS_PER_LINE / 3.; \n float v = vertexId / vertexCount;\n float invV = 2. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = tan(vertexId* 71.) / 12000. *mouse.y;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.0, 10.61, spread), mix(0.25, 10.1, v))).a;\n \n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 1.3 + vertexId / 2.1), goop(time * .11 + vertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\n time-sin(snd0*KP0);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 6.4)).xyz, 1.82);\n gl_Position.z = -m1p1(v*snd1);\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 2.1;\n gl_PointSize = 5.;\n\n float hue = mix(0.185, snd1 *.8, pow(snd1, 1.));\n float sat = 0.2 * pow(snd0 * 8.2, 1.);\n float val = -0.15 +snd0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.62);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-vslycrpiug8cdijz0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Csow3AwA4u2Zotovs/art.json b/art/Csow3AwA4u2Zotovs/art.json index a4d5b9d9..91ef744f 100644 --- a/art/Csow3AwA4u2Zotovs/art.json +++ b/art/Csow3AwA4u2Zotovs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":35000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.00222;\\n float phase = -time+mod(vertexId,2111.0);\\n float a = 0.5;\\n float b = 0.3063489;\\n float x = a * exp(b*t)*cos(t+phase)*0.015;\\n float y = a * exp(b*t)*sin(t+phase)*0.015;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n \\n float hue = floor(time*0.0071) / 0.23;\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 35000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.00222;\n float phase = -time+mod(vertexId,2111.0);\n float a = 0.5;\n float b = 0.3063489;\n float x = a * exp(b*t)*cos(t+phase)*0.015;\n float y = a * exp(b*t)*sin(t+phase)*0.015;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n \n float hue = floor(time*0.0071) / 0.23;\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-b26mmzekmhq018tq9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CtXSFrywWri4egF7m/art.json b/art/CtXSFrywWri4egF7m/art.json index cdffc256..0b32185e 100644 --- a/art/CtXSFrywWri4egF7m/art.json +++ b/art/CtXSFrywWri4egF7m/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Bubble Universe GLSL implementation\\n// Original is here: https://stardot.org.uk/forums/viewtopic.php?t=25833\\n\\nvoid main() {\\n\\n const int n=500;\\n const float r=6.283185307179586/235.;\\n\\tfloat x=0., y=0., u=0.,v=0., t=0., sz=200.;\\n int i = int(vertexId)/n;\\n float fj = 0.;\\n for (int j = 0; j < n; j++) {\\n u=sin(float(i)+v)+sin(r*float(i)+x);\\n v=cos(float(i)+v)+cos(r*float(i)+x);\\n x=u+time*.01;\\n fj = float(j);\\n if (j+i*n == int(vertexId)) {\\n break;\\n }\\n }\\n v_color = vec4(vertexId/vertexCount, fj/float(n),0.4,1.);\\n gl_PointSize = 1.3;\\n gl_Position = vec4(u*.5*min(1.,resolution.y/resolution.x),v*.5*min(1.,resolution.x/resolution.y),0,1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Bubble Universe GLSL implementation\n// Original is here: https://stardot.org.uk/forums/viewtopic.php?t=25833\n\nvoid main() {\n\n const int n=500;\n const float r=6.283185307179586/235.;\n\tfloat x=0., y=0., u=0.,v=0., t=0., sz=200.;\n int i = int(vertexId)/n;\n float fj = 0.;\n for (int j = 0; j < n; j++) {\n u=sin(float(i)+v)+sin(r*float(i)+x);\n v=cos(float(i)+v)+cos(r*float(i)+x);\n x=u+time*.01;\n fj = float(j);\n if (j+i*n == int(vertexId)) {\n break;\n }\n }\n v_color = vec4(vertexId/vertexCount, fj/float(n),0.4,1.);\n gl_PointSize = 1.3;\n gl_Position = vec4(u*.5*min(1.,resolution.y/resolution.x),v*.5*min(1.,resolution.x/resolution.y),0,1);\n}" + }, "screenshotURL": "data/images/images-ihujydzql8jnmlny2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CvsqyaFZq3hPtywor/art.json b/art/CvsqyaFZq3hPtywor/art.json index 50008551..e4fa7a86 100644 --- a/art/CvsqyaFZq3hPtywor/art.json +++ b/art/CvsqyaFZq3hPtywor/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":59825,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float NUM_SEGMENTS =3.0*mouse.r;\\n float NUM_POINTS = (NUM_SEGMENTS * 1.5);\\n float STEP = time*0.0001;\\n if (STEP > 0.003) STEP = 0.003;\\n float localTime = time*0.1 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * localTime*0.0001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(1.0-b, 1.0-c*10.0, 1.0-s*10.0, 1);\\n}\"}", + "settings": { + "num": 59825, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvoid main() {\n float NUM_SEGMENTS =3.0*mouse.r;\n float NUM_POINTS = (NUM_SEGMENTS * 1.5);\n float STEP = time*0.0001;\n if (STEP > 0.003) STEP = 0.003;\n float localTime = time*0.1 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * localTime*0.0001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(1.0-b, 1.0-c*10.0, 1.0-s*10.0, 1);\n}" + }, "screenshotURL": "data/images/images-b0f76ki6tvlp4lkug-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CxkapDDzkpTBvHykF/art.json b/art/CxkapDDzkpTBvHykF/art.json index c48150f1..74969b92 100644 --- a/art/CxkapDDzkpTBvHykF/art.json +++ b/art/CxkapDDzkpTBvHykF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "megaloler", "avatarUrl": "https://avatars.githubusercontent.com/MegaLoler?s=200", - "settings": "{\"num\":4240,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\nvoid main() {\\n \\n float aspect = resolution.x / resolution.y;\\n float width = aspect * 2.;\\n \\n float across = vertexCount;\\n float id = vertexId;\\n float rawX = id / across;\\n float x = rawX * width - aspect;\\n float amp0 = texture2D(sound, vec2(0., 0.)).a;\\n float amp = texture2D(sound, vec2(mix(0., 0.75, rawX), 0.)).a;\\n float freq = pow(x / 5., mix(amp0, 2., 3.0));\\n float y = sin((x + time) * PI * freq) * amp;\\n \\n gl_Position = vec4(x/aspect, y, 0, 1);\\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 4240, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\nvoid main() {\n \n float aspect = resolution.x / resolution.y;\n float width = aspect * 2.;\n \n float across = vertexCount;\n float id = vertexId;\n float rawX = id / across;\n float x = rawX * width - aspect;\n float amp0 = texture2D(sound, vec2(0., 0.)).a;\n float amp = texture2D(sound, vec2(mix(0., 0.75, rawX), 0.)).a;\n float freq = pow(x / 5., mix(amp0, 2., 3.0));\n float y = sin((x + time) * PI * freq) * amp;\n \n gl_Position = vec4(x/aspect, y, 0, 1);\n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-cl80fkkazvusepcc4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/CzKeby46tDXxFsGzL/art.json b/art/CzKeby46tDXxFsGzL/art.json index bada0c6b..e5f17e61 100644 --- a/art/CzKeby46tDXxFsGzL/art.json +++ b/art/CzKeby46tDXxFsGzL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9688,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\n\\n\\nvoid main() {\\n gl_Position = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 9688, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\n\n\nvoid main() {\n gl_Position = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-8h1plksd6zzq3bhub-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/CzzSa7bQ9iZ5f9hNx/art.json b/art/CzzSa7bQ9iZ5f9hNx/art.json index a0146265..60972855 100644 --- a/art/CzzSa7bQ9iZ5f9hNx/art.json +++ b/art/CzzSa7bQ9iZ5f9hNx/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":26276,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.06666666666666667,0.06666666666666667,1],\"shader\":\"\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>5.\\n#define parameter2 2.//KParameter2 -1.>>5.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time* 0.6 );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2/2.),\\n s, 0, 0-2, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, -2, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, -0.1, 0.5, 0.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, s, s-mouse.x, 1.31,\\n s-0.5, 0.3, s, 0,\\n 2, 0.5, 0, 0.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.5;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 13.0*parameter6);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * 1.83 + circleId) *0.5 /mouse.x);\\n float end = start + 5.;\\nstart + hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3*parameter4)*.4) * 0.5, uv.x * 120.4)).a;\\n float VertexCount =2000. * parameter1;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId * 0.17)), m1p1(circleId * numCircles*3.2\\n ));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\\n offset.y += goop(circleId * time + 10.13) *0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n \\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 26276, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.06666666666666667, + 0.06666666666666667, + 1 + ], + "shader": "\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>5.\n#define parameter2 2.//KParameter2 -1.>>5.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time* 0.6 );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2/2.),\n s, 0, 0-2, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, -2, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, -0.1, 0.5, 0.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, s, s-mouse.x, 1.31,\n s-0.5, 0.3, s, 0,\n 2, 0.5, 0, 0.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.5;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 13.0*parameter6);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\n float start = fract(hash(circleId * 0.33) + cos(time * 1.83 + circleId) *0.5 /mouse.x);\n float end = start + 5.;\nstart + hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3*parameter4)*.4) * 0.5, uv.x * 120.4)).a;\n float VertexCount =2000. * parameter1;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId * 0.17)), m1p1(circleId * numCircles*3.2\n ));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\n offset.y += goop(circleId * time + 10.13) *0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n \n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-f4p2ciggwunepauof-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/D2qJoBWBE7X8yWh5D/art.json b/art/D2qJoBWBE7X8yWh5D/art.json index f80a8db1..41204b0a 100644 --- a/art/D2qJoBWBE7X8yWh5D/art.json +++ b/art/D2qJoBWBE7X8yWh5D/art.json @@ -31,7 +31,19 @@ "private": true, "unlisted": false, "username": "gman", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//\\n\\n#define PI radians(180.)\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nvec3 shape00(float vertexId, float time) {\\n vec3 clocks = vec3(\\n time * hash(vertexId), \\n time * hash(vertexId * 0.37), \\n time * hash(vertexId * 0.73));\\n vec3 radius = vec3(\\n hash(vertexId * 0.23),\\n hash(vertexId * 1.17),\\n hash(vertexId * 2.99)\\n );\\n return vec3(\\n sin(clocks.x) * radius.x,\\n sin(clocks.y) * radius.y,\\n cos(clocks.z) * radius.z);\\n}\\n\\nvec3 shape01(float vertexId, float time) {\\n return vec3(\\n m1p1(hash(vertexId * 0.33)),\\n m1p1(hash(vertexId * 1.57)),\\n m1p1(hash(vertexId * 2.39)));\\n \\n}\\n\\nvec3 shape02(float vertexId, float time) {\\n return vec3( \\n sin(vertexId * 0.005),\\n cos(vertexId * 0.005),\\n cos(vertexId + time * 0.01));\\n \\n}\\n\\nvec3 shape03(float vertexId, float time) {\\n float r = cos(vertexId * mod(floor(time * 20.), 15.) * 0.25);\\n return vec3( \\n sin(vertexId * 0.005) * r,\\n cos(vertexId * 0.005) * r,\\n sin(vertexId + time * 0.01));\\n \\n}\\n\\nvoid main() {\\n vec3 pos00 = shape03(vertexId, time); \\n vec3 pos = pos00;\\n gl_Position = vec4(pos, 1);\\n gl_Position = vec4(gl_Position.xyz, .6 / gl_Position.z);\\n \\n float zish = p1m1(gl_Position.z / gl_Position.w);\\n gl_PointSize = zish;\\n v_color = vec4(1, 1, 1, zish);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//\n\n#define PI radians(180.)\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nvec3 shape00(float vertexId, float time) {\n vec3 clocks = vec3(\n time * hash(vertexId), \n time * hash(vertexId * 0.37), \n time * hash(vertexId * 0.73));\n vec3 radius = vec3(\n hash(vertexId * 0.23),\n hash(vertexId * 1.17),\n hash(vertexId * 2.99)\n );\n return vec3(\n sin(clocks.x) * radius.x,\n sin(clocks.y) * radius.y,\n cos(clocks.z) * radius.z);\n}\n\nvec3 shape01(float vertexId, float time) {\n return vec3(\n m1p1(hash(vertexId * 0.33)),\n m1p1(hash(vertexId * 1.57)),\n m1p1(hash(vertexId * 2.39)));\n \n}\n\nvec3 shape02(float vertexId, float time) {\n return vec3( \n sin(vertexId * 0.005),\n cos(vertexId * 0.005),\n cos(vertexId + time * 0.01));\n \n}\n\nvec3 shape03(float vertexId, float time) {\n float r = cos(vertexId * mod(floor(time * 20.), 15.) * 0.25);\n return vec3( \n sin(vertexId * 0.005) * r,\n cos(vertexId * 0.005) * r,\n sin(vertexId + time * 0.01));\n \n}\n\nvoid main() {\n vec3 pos00 = shape03(vertexId, time); \n vec3 pos = pos00;\n gl_Position = vec4(pos, 1);\n gl_Position = vec4(gl_Position.xyz, .6 / gl_Position.z);\n \n float zish = p1m1(gl_Position.z / gl_Position.w);\n gl_PointSize = zish;\n v_color = vec4(1, 1, 1, zish);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-08w7c6r49jcvlca6s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/D3DaiYq4ggr7qZEhu/art.json b/art/D3DaiYq4ggr7qZEhu/art.json index 601e29b1..40012452 100644 --- a/art/D3DaiYq4ggr7qZEhu/art.json +++ b/art/D3DaiYq4ggr7qZEhu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//#ifdef GL_ES\\n//precision highp float;\\n//#endif \\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\nconst float eps = 10e-6;\\nconst int max_steps = 128;\\n\\nmat4 rot = mat4(cos(0.8), sin(0.8), 0, 0,\\n\\t\\t-sin(0.8), cos(0.8), 0, 0,\\n\\t\\t0, \\t0, \\t1, \\t0,\\n\\t\\t0, \\t0, \\t0, \\t1);\\n\\nfloat sphere(vec3 rayPos, vec3 pos, float radius){\\n return length(rayPos - pos) - radius;\\n}\\n\\nfloat plane(vec3 rayPos, vec3 pos, vec3 normal){\\n return dot(rayPos - pos,normal.xyz);\\n}\\n\\nfloat box(vec3 rayPos, vec3 pos, vec3 bounds ){\\n return length(max(abs(rayPos - pos) - bounds, 0.0));\\n}\\n\\nvec3 repeat(vec3 rayPos, vec3 pos, vec3 modulo){\\n\\treturn mod(rayPos - pos,modulo) - 0.5 * modulo;\\n}\\n\\nvec3 transform(vec3 rayPos, vec3 pos, mat4 m){\\n return (/*inverse*/(m)*vec4((rayPos - pos), 1.0)).xyz;\\n}\\n\\nfloat scene(vec3 rayPos){\\n\\tfloat result = plane(rayPos, vec3(0, -1, 0), vec3(0,1,0));\\n\\tresult = min(result, sphere(repeat(rayPos, vec3(0,0,5), vec3(2,2,2)),vec3(0), 0.25));\\n\\tresult = min(result, box(transform(rayPos, vec3(1,0,3), rot),vec3(0), vec3(0.25,0.25,0.25)));\\n\\treturn result;\\n}\\n\\nvec3 getNormal(vec3 rayPos){\\n vec2 e = vec2(1.0,-1.0) * 0.5773 * 0.0005;\\n return normalize(e.xyy * scene(rayPos + e.xyy) + \\n\\t\\t e.yyx * scene(rayPos + e.yyx) + \\n\\t\\t e.yxy * scene(rayPos + e.yxy) + \\n\\t\\t e.xxx * scene(rayPos + e.xxx));\\n}\\n\\nvec3 sphereTrace(vec3 origin, vec3 direction){\\n\\tfloat t = 0.0;\\n\\t\\n\\tfor(int i = 0; i < max_steps; ++i) {\\n\\t\\tvec3 pos = origin + t * direction;\\n\\t\\t//float d = sphere(pos, vec3(0,0,2), 0.25);\\n\\t\\tfloat d = scene(pos);\\n\\n\\t\\tif (d <= eps * t) {\\n\\t\\t\\t//return vec3(float(i) / float(max_steps));\\n\\t\\t\\treturn (getNormal(pos) + 1.0) * 0.5;\\n\\t\\t}\\n\\t\\tt += d;\\n\\t}\\n\\treturn vec3(-1.0);\\n}\\n\\nvoid main( void ) {float finalDesiredPointSize = 2.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n\\tvec3 camPos = vec3(0.0);\\n\\tvec2 pixelPos = (-vertexResolution.xy + 2.0 * simFragCoord.xy) / vertexResolution.y;\\n\\tvec3 direction = normalize(vec3(pixelPos - camPos.xy, 2.0));\\n\\n\\tvec3 col = vec3(0.7, 0.9, 1.0) + direction.y * 0.618;\\n\\n\\tvec3 result = sphereTrace(camPos, direction);\\n\\tif( result.x >= 0.0)\\n\\t{\\n\\t\\tcol = result;\\n\\t}\\n\\t\\n\\tv_color = vec4(col, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//#ifdef GL_ES\n//precision highp float;\n//#endif \n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\nconst float eps = 10e-6;\nconst int max_steps = 128;\n\nmat4 rot = mat4(cos(0.8), sin(0.8), 0, 0,\n\t\t-sin(0.8), cos(0.8), 0, 0,\n\t\t0, \t0, \t1, \t0,\n\t\t0, \t0, \t0, \t1);\n\nfloat sphere(vec3 rayPos, vec3 pos, float radius){\n return length(rayPos - pos) - radius;\n}\n\nfloat plane(vec3 rayPos, vec3 pos, vec3 normal){\n return dot(rayPos - pos,normal.xyz);\n}\n\nfloat box(vec3 rayPos, vec3 pos, vec3 bounds ){\n return length(max(abs(rayPos - pos) - bounds, 0.0));\n}\n\nvec3 repeat(vec3 rayPos, vec3 pos, vec3 modulo){\n\treturn mod(rayPos - pos,modulo) - 0.5 * modulo;\n}\n\nvec3 transform(vec3 rayPos, vec3 pos, mat4 m){\n return (/*inverse*/(m)*vec4((rayPos - pos), 1.0)).xyz;\n}\n\nfloat scene(vec3 rayPos){\n\tfloat result = plane(rayPos, vec3(0, -1, 0), vec3(0,1,0));\n\tresult = min(result, sphere(repeat(rayPos, vec3(0,0,5), vec3(2,2,2)),vec3(0), 0.25));\n\tresult = min(result, box(transform(rayPos, vec3(1,0,3), rot),vec3(0), vec3(0.25,0.25,0.25)));\n\treturn result;\n}\n\nvec3 getNormal(vec3 rayPos){\n vec2 e = vec2(1.0,-1.0) * 0.5773 * 0.0005;\n return normalize(e.xyy * scene(rayPos + e.xyy) + \n\t\t e.yyx * scene(rayPos + e.yyx) + \n\t\t e.yxy * scene(rayPos + e.yxy) + \n\t\t e.xxx * scene(rayPos + e.xxx));\n}\n\nvec3 sphereTrace(vec3 origin, vec3 direction){\n\tfloat t = 0.0;\n\t\n\tfor(int i = 0; i < max_steps; ++i) {\n\t\tvec3 pos = origin + t * direction;\n\t\t//float d = sphere(pos, vec3(0,0,2), 0.25);\n\t\tfloat d = scene(pos);\n\n\t\tif (d <= eps * t) {\n\t\t\t//return vec3(float(i) / float(max_steps));\n\t\t\treturn (getNormal(pos) + 1.0) * 0.5;\n\t\t}\n\t\tt += d;\n\t}\n\treturn vec3(-1.0);\n}\n\nvoid main( void ) {float finalDesiredPointSize = 2.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n\tvec3 camPos = vec3(0.0);\n\tvec2 pixelPos = (-vertexResolution.xy + 2.0 * simFragCoord.xy) / vertexResolution.y;\n\tvec3 direction = normalize(vec3(pixelPos - camPos.xy, 2.0));\n\n\tvec3 col = vec3(0.7, 0.9, 1.0) + direction.y * 0.618;\n\n\tvec3 result = sphereTrace(camPos, direction);\n\tif( result.x >= 0.0)\n\t{\n\t\tcol = result;\n\t}\n\t\n\tv_color = vec4(col, 1.0);\n}" + }, "screenshotURL": "data/images/images-iv6my733oapidpd36-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/D3LC8ea768bS5NfQY/art.json b/art/D3LC8ea768bS5NfQY/art.json index eca5a4c4..57f87e28 100644 --- a/art/D3LC8ea768bS5NfQY/art.json +++ b/art/D3LC8ea768bS5NfQY/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/diskore/m4r\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 65.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v / 21. - v;}\\n\\nfloat p1m1(float v) {\\n return v * mod(0.1 *time, -3.0) ;\\n}\\n\\nfloat inv(float v) {\\n return 1. + v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 1.16 / PI * 5.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = 4.0;\\n pos = vec3(x, y+11., z-5.); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 1.7) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles+ 5.;\\n vec3 pos;\\n float inner = mix(0.03, 11.1, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 1.033) + sin(time * 1.83 + circleId) *2.1 *mouse.x);\\n float end = start + 3.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x - uv.y/1.8 - 0.3)*7.) * 0.05, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 5.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 1.4;\\n offset.y += goop(circleId + time - 0.13) * 1.31;\\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 12.;\\n\\n float hue = mix(0.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 - snd;\\n float val = 0.5- snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a /2.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/diskore/m4r", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 65.4337);\n}\n\nfloat m1p1(float v) {\n return v / 21. - v;}\n\nfloat p1m1(float v) {\n return v * mod(0.1 *time, -3.0) ;\n}\n\nfloat inv(float v) {\n return 1. + v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 1.16 / PI * 5.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = 4.0;\n pos = vec3(x, y+11., z-5.); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 1.7) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles+ 5.;\n vec3 pos;\n float inner = mix(0.03, 11.1, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 1.033) + sin(time * 1.83 + circleId) *2.1 *mouse.x);\n float end = start + 3.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x - uv.y/1.8 - 0.3)*7.) * 0.05, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 5.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 1.4;\n offset.y += goop(circleId + time - 0.13) * 1.31;\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 12.;\n\n float hue = mix(0.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 - snd;\n float val = 0.5- snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, snd*6.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a /2.0);\n}" + }, "screenshotURL": "data/images/images-nqz30ouqnw8hqz6v0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/D4KsKHDFES8P7NEBc/art.json b/art/D4KsKHDFES8P7NEBc/art.json index 579bd0f1..68a88c73 100644 --- a/art/D4KsKHDFES8P7NEBc/art.json +++ b/art/D4KsKHDFES8P7NEBc/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/discobelle/discobelle-mix-098-siete-catorce\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19607843137254902,0.2627450980392157,0.49411764705882355,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define parameter0 3.//KParameter0 -1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.03, 0.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, sin(22.0 -1.0) * 3.0, 0.2);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 116.0 / K.www / parameter0);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20 * parameter1, 0.8), c.x +c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, parameter3,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, parameter3,\\n 0, 1, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -0.2, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 1, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target +parameter5);\\n vec3 xAxis = normalize(cross(up, zAxis -parameter4));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137 * parameter5));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3. *parameter6), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123*parameter7);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5* parameter1;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float numStars = floor(vertexCount / 3.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n float s = texture2D(sound, vec2(\\n mix(0.02, 0.5, h),\\n mix(0.0, 0.05, starV))).a;\\n \\n \\n float pId = mod(vertexId, 3.);\\n float sz = pow(s + 0.25, 5.) * 10.;\\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n \\n float hue = time * .1 + h * .2;\\n float sat = 1.;\\n float val = pow(s + 0.4, 5.);\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n float pump = step(.8, s);\\n color = mix(color, vec4(1, 0, 0, 1), pump);\\n color.a = mix(1., 0.2, pow(s, 15.));\\n color.rgb *= color.a;\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.125;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0.26, cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/discobelle/discobelle-mix-098-siete-catorce", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19607843137254902, + 0.2627450980392157, + 0.49411764705882355, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define parameter0 3.//KParameter0 -1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.03, 0.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, sin(22.0 -1.0) * 3.0, 0.2);\n vec3 p = abs(fract(c.xxx + K.xyz) * 116.0 / K.www / parameter0);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20 * parameter1, 0.8), c.x +c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, parameter3,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, parameter3,\n 0, 1, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -0.2, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 1, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target +parameter5);\n vec3 xAxis = normalize(cross(up, zAxis -parameter4));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137 * parameter5));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3. *parameter6), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123*parameter7);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5* parameter1;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float numStars = floor(vertexCount / 3.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n float s = texture2D(sound, vec2(\n mix(0.02, 0.5, h),\n mix(0.0, 0.05, starV))).a;\n \n \n float pId = mod(vertexId, 3.);\n float sz = pow(s + 0.25, 5.) * 10.;\n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n \n float hue = time * .1 + h * .2;\n float sat = 1.;\n float val = pow(s + 0.4, 5.);\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n float pump = step(.8, s);\n color = mix(color, vec4(1, 0, 0, 1), pump);\n color.a = mix(1., 0.2, pow(s, 15.));\n color.rgb *= color.a;\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.125;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0.26, cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-wnp9tevekaaq1esow-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/D5f5NhSGgh7gLgnm3/art.json b/art/D5f5NhSGgh7gLgnm3/art.json index c0ebc840..8478a2ad 100644 --- a/art/D5f5NhSGgh7gLgnm3/art.json +++ b/art/D5f5NhSGgh7gLgnm3/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":60,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n\\n#define AND(a,x) int(floor(x - (a * 16.0)))\\n#define MASK 1024.0\\n#define SCALE 112.0\\n#define MAX_TRIS 15\\n#define TOTAL_TRI 21\\n#define VERTS_PER_VEC4 4\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nmat4 indices[4];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid populate(){ \\n\\n#define V1 18451.0\\n#define V2 7169.0\\n#define V3 46.0\\n#define V4 22588.0\\n#define V5 75.0\\n#define V6 18534.0\\n#define V7 7288.0\\n#define V8 54525998.0\\n#define V9 54526027.0\\n#define V10 19930228.0\\n#define V11 19930116.0\\n#define V12 31473724.0\\n\\ntriangles[0]=vec4(V1,V2,V3,V3);\\ntriangles[1]=vec4(V1,V4,V4,V3);\\ntriangles[2]=vec4(V5,V5,V4,V6);\\ntriangles[3]=vec4(V6,V5,V7,V3);\\ntriangles[4]=vec4(V8,V5,V8,V9);\\ntriangles[5]=vec4(V5,V10,V5,V9);\\ntriangles[6]=vec4(V7,V10,V5,V11);\\ntriangles[7]=vec4(V3,V8,V2,V11);\\ntriangles[8]=vec4(V3,V12,V9,V8);\\ntriangles[9]=vec4(V12,V4,V6,V12);\\ntriangles[10]=vec4(V1,V4,V12,V6);\\ntriangles[11]=vec4(V9,V12,V8,V1);\\ntriangles[12]=vec4(V9,V6,V10,V8);\\ntriangles[13]=vec4(V1,V11,V7,V6);\\ntriangles[14]=vec4(V10,V2,V1,V11);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n for(int i=0;i> comment all uniforms and varying\\n/*\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n\\nvec2 pattern(vec2 p) {\\n\\t\\n\\tfloat a = atan(p.x,p.y);\\n\\tfloat r = 9.0 * pow(1.0/length(p), 0.4);\\n\\tfloat t = time + length(p) * 0.0012;\\n\\treturn vec2(sin(a*3.0+cos(t*0.25)*10.0), sin(r*2.+sin(time*0.1)*10.0));\\n}\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simfragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n\\n //replace gl_FragCoord by vfragCoord \\n //replace gl_FragColor by v_color\\n \\n\\n\\tvec2 p = surfacePosition * 99.0;\\n\\tvec3 col = vec3(0.0);\\n\\t\\n\\tfor (int i=0; i<3; i++)\\n\\t\\tp.xy = pattern(p);\\n\\t\\n\\tcol.xy = sin(p.xy);\\n\\tcol.z = max(step(abs(p.x*p.x),0.5), -1.0 / abs(p.y));\\n\\t\\n\\tv_color = vec4( col, 1.0 );\\n\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\n//Step 1 >> comment all uniforms and varying\n/*\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n\nvec2 pattern(vec2 p) {\n\t\n\tfloat a = atan(p.x,p.y);\n\tfloat r = 9.0 * pow(1.0/length(p), 0.4);\n\tfloat t = time + length(p) * 0.0012;\n\treturn vec2(sin(a*3.0+cos(t*0.25)*10.0), sin(r*2.+sin(time*0.1)*10.0));\n}\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simfragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n\n //replace gl_FragCoord by vfragCoord \n //replace gl_FragColor by v_color\n \n\n\tvec2 p = surfacePosition * 99.0;\n\tvec3 col = vec3(0.0);\n\t\n\tfor (int i=0; i<3; i++)\n\t\tp.xy = pattern(p);\n\t\n\tcol.xy = sin(p.xy);\n\tcol.z = max(step(abs(p.x*p.x),0.5), -1.0 / abs(p.y));\n\t\n\tv_color = vec4( col, 1.0 );\n\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-y1rgwspmz2prgv99x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DNj4nZ8MZnj5JZFt2/art.json b/art/DNj4nZ8MZnj5JZFt2/art.json index be213e13..6bf67b03 100644 --- a/art/DNj4nZ8MZnj5JZFt2/art.json +++ b/art/DNj4nZ8MZnj5JZFt2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .331), h(s * .119)) * 1. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .331), h(s * .119)) * 1. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-id39thpy8e629p119-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DP7wFzXhDCPCpGfuF/art.json b/art/DP7wFzXhDCPCpGfuF/art.json index 83d7b58f..fd7f38a7 100644 --- a/art/DP7wFzXhDCPCpGfuF/art.json +++ b/art/DP7wFzXhDCPCpGfuF/art.json @@ -29,7 +29,19 @@ }, "private": false, "username": "sap", - "settings": "{\"num\":64,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU radians( 360. )\\n#define PI radians( 180. )\\n#define DEG2RAD 0.0174532925199433\\n\\n/*\\n http://steve.hollasch.net/thesis/\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec4 cross(vec4 u, vec4 v, vec4 w)\\n{\\n float a, b, c, d, e, f;\\n\\n a = (v[0] * w[1]) - (v[1] * w[0]);\\n b = (v[0] * w[2]) - (v[2] * w[0]);\\n c = (v[0] * w[3]) - (v[3] * w[0]);\\n d = (v[1] * w[2]) - (v[2] * w[1]);\\n e = (v[1] * w[3]) - (v[3] * w[1]);\\n f = (v[2] * w[3]) - (v[3] * w[2]);\\n\\n return vec4(\\n (u[1] * f) - (u[2] * e) + (u[3] * d),\\n - (u[0] * f) + (u[2] * c) - (u[3] * b),\\n (u[0] * e) - (u[1] * c) + (u[3] * a),\\n - (u[0] * d) + (u[1] * b) - (u[2] * a)\\n );\\n}\\n\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\n\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\n\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n\\nmat4 lookAt4(vec4 from, vec4 to, vec4 up, vec4 over)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n return mat4(a, b, c, d);\\n}\\n\\n// from 4d to 3d space.\\nvec4 project4(vec4 vertex, vec4 from, float fov, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n\\n T = 1.0 / tan (fov * 0.5 * DEG2RAD);\\n V = vertex - from;\\n S = T / dot (V, transform[3]);\\n\\n return vec4(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2]),\\n 0\\n );\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(0.5 * fov * DEG2RAD);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nvec4 hypercube(float id)\\n{\\n id = mod(id, 16.0);\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\n\\nvec4 hypercube_lines(float id)\\n{\\n id = mod(id, 64.0);\\n\\n // outer cuber\\n if (id == 00.) return hypercube(0.);\\n if (id == 01.) return hypercube(3.);\\n if (id == 02.) return hypercube(3.);\\n if (id == 03.) return hypercube(8.);\\n if (id == 04.) return hypercube(8.);\\n if (id == 05.) return hypercube(2.);\\n if (id == 06.) return hypercube(2.);\\n if (id == 07.) return hypercube(0.);\\n if (id == 08.) return hypercube(0.);\\n if (id == 09.) return hypercube(4.);\\n if (id == 10.) return hypercube(4.);\\n if (id == 11.) return hypercube(10.);\\n if (id == 12.) return hypercube(10.);\\n if (id == 13.) return hypercube(3.);\\n if (id == 14.) return hypercube(8.);\\n if (id == 15.) return hypercube(13.);\\n if (id == 16.) return hypercube(2.);\\n if (id == 17.) return hypercube(9.);\\n if (id == 18.) return hypercube(4.);\\n if (id == 19.) return hypercube(9.);\\n if (id == 20.) return hypercube(10.);\\n if (id == 21.) return hypercube(13.);\\n if (id == 22.) return hypercube(13.);\\n if (id == 23.) return hypercube(9.);\\n\\n // inner cube\\n if (id == 24.) return hypercube(1.);\\n if (id == 25.) return hypercube(6.);\\n if (id == 26.) return hypercube(6.);\\n if (id == 27.) return hypercube(11.);\\n if (id == 28.) return hypercube(11.);\\n if (id == 29.) return hypercube(5.);\\n if (id == 30.) return hypercube(5.);\\n if (id == 31.) return hypercube(1.);\\n if (id == 32.) return hypercube(7.);\\n if (id == 33.) return hypercube(14.);\\n if (id == 34.) return hypercube(14.);\\n if (id == 35.) return hypercube(15.);\\n if (id == 36.) return hypercube(15.);\\n if (id == 37.) return hypercube(12.);\\n if (id == 38.) return hypercube(12.);\\n if (id == 39.) return hypercube(7.);\\n if (id == 40.) return hypercube(1.);\\n if (id == 41.) return hypercube(7.);\\n if (id == 42.) return hypercube(6.);\\n if (id == 43.) return hypercube(14.);\\n if (id == 44.) return hypercube(11.);\\n if (id == 45.) return hypercube(15.);\\n if (id == 46.) return hypercube(5.);\\n if (id == 47.) return hypercube(12.);\\n\\n // w\\n if (id == 48.) return hypercube(2.);\\n if (id == 49.) return hypercube(5.);\\n if (id == 50.) return hypercube(8.);\\n if (id == 51.) return hypercube(11.);\\n if (id == 52.) return hypercube(13.);\\n if (id == 53.) return hypercube(15.);\\n if (id == 54.) return hypercube(9.);\\n if (id == 55.) return hypercube(12.);\\n if (id == 56.) return hypercube(0.);\\n if (id == 57.) return hypercube(1.);\\n if (id == 58.) return hypercube(3.);\\n if (id == 59.) return hypercube(6.);\\n if (id == 60.) return hypercube(10.);\\n if (id == 61.) return hypercube(14.);\\n if (id == 62.) return hypercube(4.);\\n if (id == 63.) return hypercube(7.);\\n return vec4(0);\\n}\\n\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 0, 0, 0);\\n vec4 up4 = vec4(0, 1, 0, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n\\n vec3 from3 = vec3(cos(PI * mouse.x), 0.3, sin(PI * mouse.x));\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n\\n mat4 m1 = ident();\\n m1 *= lookAt4(from4, to4, up4, over4);\\n m1 *= rot4xy(time * 0.1 * TAU);\\n\\n vec4 v4 = hypercube_lines(vertexId);\\n vec4 v3 = project4(v4, from4, 45.0, m1);\\n \\n mat4 m2 = ident();\\n m2 *= lookAt(from3, to3, up3);\\n m2 *= persp(45., resolution.x / resolution.y, 0.1, 60.);\\n vec4 v = v3 * m2 * 1.5;\\n\\n gl_Position = vec4(v.xy, 0, 1);\\n v_color = vec4(0);\\n v_color += vec4(vec3(1,0,0)*(1. - v4.x), 1);\\n v_color += vec4(vec3(0,0,1)*(v4.x), 1);\\n}\\n\"}", + "settings": { + "num": 64, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU radians( 360. )\n#define PI radians( 180. )\n#define DEG2RAD 0.0174532925199433\n\n/*\n http://steve.hollasch.net/thesis/\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec4 cross(vec4 u, vec4 v, vec4 w)\n{\n float a, b, c, d, e, f;\n\n a = (v[0] * w[1]) - (v[1] * w[0]);\n b = (v[0] * w[2]) - (v[2] * w[0]);\n c = (v[0] * w[3]) - (v[3] * w[0]);\n d = (v[1] * w[2]) - (v[2] * w[1]);\n e = (v[1] * w[3]) - (v[3] * w[1]);\n f = (v[2] * w[3]) - (v[3] * w[2]);\n\n return vec4(\n (u[1] * f) - (u[2] * e) + (u[3] * d),\n - (u[0] * f) + (u[2] * c) - (u[3] * b),\n (u[0] * e) - (u[1] * c) + (u[3] * a),\n - (u[0] * d) + (u[1] * b) - (u[2] * a)\n );\n}\n\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\n\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\n\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n\nmat4 lookAt4(vec4 from, vec4 to, vec4 up, vec4 over)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n return mat4(a, b, c, d);\n}\n\n// from 4d to 3d space.\nvec4 project4(vec4 vertex, vec4 from, float fov, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n\n T = 1.0 / tan (fov * 0.5 * DEG2RAD);\n V = vertex - from;\n S = T / dot (V, transform[3]);\n\n return vec4(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2]),\n 0\n );\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(0.5 * fov * DEG2RAD);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nvec4 hypercube(float id)\n{\n id = mod(id, 16.0);\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\n\nvec4 hypercube_lines(float id)\n{\n id = mod(id, 64.0);\n\n // outer cuber\n if (id == 00.) return hypercube(0.);\n if (id == 01.) return hypercube(3.);\n if (id == 02.) return hypercube(3.);\n if (id == 03.) return hypercube(8.);\n if (id == 04.) return hypercube(8.);\n if (id == 05.) return hypercube(2.);\n if (id == 06.) return hypercube(2.);\n if (id == 07.) return hypercube(0.);\n if (id == 08.) return hypercube(0.);\n if (id == 09.) return hypercube(4.);\n if (id == 10.) return hypercube(4.);\n if (id == 11.) return hypercube(10.);\n if (id == 12.) return hypercube(10.);\n if (id == 13.) return hypercube(3.);\n if (id == 14.) return hypercube(8.);\n if (id == 15.) return hypercube(13.);\n if (id == 16.) return hypercube(2.);\n if (id == 17.) return hypercube(9.);\n if (id == 18.) return hypercube(4.);\n if (id == 19.) return hypercube(9.);\n if (id == 20.) return hypercube(10.);\n if (id == 21.) return hypercube(13.);\n if (id == 22.) return hypercube(13.);\n if (id == 23.) return hypercube(9.);\n\n // inner cube\n if (id == 24.) return hypercube(1.);\n if (id == 25.) return hypercube(6.);\n if (id == 26.) return hypercube(6.);\n if (id == 27.) return hypercube(11.);\n if (id == 28.) return hypercube(11.);\n if (id == 29.) return hypercube(5.);\n if (id == 30.) return hypercube(5.);\n if (id == 31.) return hypercube(1.);\n if (id == 32.) return hypercube(7.);\n if (id == 33.) return hypercube(14.);\n if (id == 34.) return hypercube(14.);\n if (id == 35.) return hypercube(15.);\n if (id == 36.) return hypercube(15.);\n if (id == 37.) return hypercube(12.);\n if (id == 38.) return hypercube(12.);\n if (id == 39.) return hypercube(7.);\n if (id == 40.) return hypercube(1.);\n if (id == 41.) return hypercube(7.);\n if (id == 42.) return hypercube(6.);\n if (id == 43.) return hypercube(14.);\n if (id == 44.) return hypercube(11.);\n if (id == 45.) return hypercube(15.);\n if (id == 46.) return hypercube(5.);\n if (id == 47.) return hypercube(12.);\n\n // w\n if (id == 48.) return hypercube(2.);\n if (id == 49.) return hypercube(5.);\n if (id == 50.) return hypercube(8.);\n if (id == 51.) return hypercube(11.);\n if (id == 52.) return hypercube(13.);\n if (id == 53.) return hypercube(15.);\n if (id == 54.) return hypercube(9.);\n if (id == 55.) return hypercube(12.);\n if (id == 56.) return hypercube(0.);\n if (id == 57.) return hypercube(1.);\n if (id == 58.) return hypercube(3.);\n if (id == 59.) return hypercube(6.);\n if (id == 60.) return hypercube(10.);\n if (id == 61.) return hypercube(14.);\n if (id == 62.) return hypercube(4.);\n if (id == 63.) return hypercube(7.);\n return vec4(0);\n}\n\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 0, 0, 0);\n vec4 up4 = vec4(0, 1, 0, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n\n vec3 from3 = vec3(cos(PI * mouse.x), 0.3, sin(PI * mouse.x));\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n\n mat4 m1 = ident();\n m1 *= lookAt4(from4, to4, up4, over4);\n m1 *= rot4xy(time * 0.1 * TAU);\n\n vec4 v4 = hypercube_lines(vertexId);\n vec4 v3 = project4(v4, from4, 45.0, m1);\n \n mat4 m2 = ident();\n m2 *= lookAt(from3, to3, up3);\n m2 *= persp(45., resolution.x / resolution.y, 0.1, 60.);\n vec4 v = v3 * m2 * 1.5;\n\n gl_Position = vec4(v.xy, 0, 1);\n v_color = vec4(0);\n v_color += vec4(vec3(1,0,0)*(1. - v4.x), 1);\n v_color += vec4(vec3(0,0,1)*(v4.x), 1);\n}\n" + }, "screenshotURL": "data/images/images-umfpcyroohixkydph-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DPnrgr43T2RcprHMh/art.json b/art/DPnrgr43T2RcprHMh/art.json index 7abaaf13..90e9b9b2 100644 --- a/art/DPnrgr43T2RcprHMh/art.json +++ b/art/DPnrgr43T2RcprHMh/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\tvec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\t\\n\\tfor(float i = 0.001; i < 10.0; i++){\\n\\t\\t\\n\\t\\tfloat s = cos(sin(10. * time / i )) ;\\n\\t\\tfloat c = tan(cos(0.1* time + i ));\\n\\t\\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n v_color = vec4(vec3(destColor * f), 1.0);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n float snd = texture2D(sound, vec2(0., u)).a;\n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\tvec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\t\n\tfor(float i = 0.001; i < 10.0; i++){\n\t\t\n\t\tfloat s = cos(sin(10. * time / i )) ;\n\t\tfloat c = tan(cos(0.1* time + i ));\n\t\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\n\t}\n\n v_color = vec4(vec3(destColor * f), 1.0);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n\n \n\n}" + }, "screenshotURL": "data/images/images-8xjljrblh4mup39jp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DPyrvZcaDSQBadMfb/art.json b/art/DPyrvZcaDSQBadMfb/art.json index 4e049162..a8be30b2 100644 --- a/art/DPyrvZcaDSQBadMfb/art.json +++ b/art/DPyrvZcaDSQBadMfb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\" void main() \\n {\\n \\n \\n gl_PointSize = 10.0;\\n gl_Position = vec4(-0.5, -0.5, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n }\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": " void main() \n {\n \n \n gl_PointSize = 10.0;\n gl_Position = vec4(-0.5, -0.5, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n }" + }, "screenshotURL": "data/images/images-m8x9kmlhyobwcbapc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DQtN9os6r9QqLMWeq/art.json b/art/DQtN9os6r9QqLMWeq/art.json index 05f6026b..0d92f146 100644 --- a/art/DQtN9os6r9QqLMWeq/art.json +++ b/art/DQtN9os6r9QqLMWeq/art.json @@ -28,7 +28,19 @@ "name": "never saw a rainbow", "private": false, "username": "visy", - "settings": "{\"num\":26330,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/the-silicon-scientist/oceans-of-green-album-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n \\n float localTime = 0.01 + time*0.1;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(localTime * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 4.0-time*0.05);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * time*0.01, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n float cr = mix(0.0, 1.0, b+count*oC);\\n float cg = mix(0.0, 1.0, b+count*time*0.0000001);\\n float cb = mix(0.0, 1.0, b+count*oS);\\n \\n v_color = vec4(cr, cg, cb, 1);\\n}\"}", + "settings": { + "num": 26330, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/the-silicon-scientist/oceans-of-green-album-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n \n float localTime = 0.01 + time*0.1;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(localTime * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 4.0-time*0.05);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * time*0.01, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n float cr = mix(0.0, 1.0, b+count*oC);\n float cg = mix(0.0, 1.0, b+count*time*0.0000001);\n float cb = mix(0.0, 1.0, b+count*oS);\n \n v_color = vec4(cr, cg, cb, 1);\n}" + }, "screenshotURL": "data/images/images-tefw6f0rlgew9ebpl-thumbnail.jpg", "views": { "$numberInt": "435" diff --git a/art/DRYszuLsxNkzcz9SW/art.json b/art/DRYszuLsxNkzcz9SW/art.json index 65f60db9..d135485e 100644 --- a/art/DRYszuLsxNkzcz9SW/art.json +++ b/art/DRYszuLsxNkzcz9SW/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":16743,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0784313725490196,0.058823529411764705,0.027450980392156862,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 getCirclePoint(float id, float numSegments) { \\n // Each square is made of 2 triangles, 6 points\\n float ux = mod(id, 2.0) + floor(id / 6.0); \\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n\\n // Calculate angle and radial values\\n float angle = ux / numSegments * 2.0 * PI;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n // Translate back to x y\\n float radius = vy;\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numSegments = 20.0;\\n float numPointsPerCircle = numSegments * 6.0;\\n \\n float numCircles = floor(vertexCount / numPointsPerCircle) - 1.0;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n \\n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1;\\n \\n float cX = 2.0 * (circleId / numCircles) - 1.0;\\n \\n float nearness = abs(cos((time + circleId) / 2.0));\\n \\n gl_Position = vec4(xy.x + cX, xy.y + sin(time + circleId)*0.5, 0.0, 1);\\n gl_PointSize = 2.0 * nearness + 1.0;\\n \\n // Circle color\\n float hue = sin(circleId * 0.1 + time * .1) * 0.8;\\n float sat = 0.4;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n \\n}\"}", + "settings": { + "num": 16743, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.058823529411764705, + 0.027450980392156862, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 getCirclePoint(float id, float numSegments) { \n // Each square is made of 2 triangles, 6 points\n float ux = mod(id, 2.0) + floor(id / 6.0); \n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n\n // Calculate angle and radial values\n float angle = ux / numSegments * 2.0 * PI;\n float c = cos(angle);\n float s = sin(angle);\n \n // Translate back to x y\n float radius = vy;\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numSegments = 20.0;\n float numPointsPerCircle = numSegments * 6.0;\n \n float numCircles = floor(vertexCount / numPointsPerCircle) - 1.0;\n float circleId = floor(vertexId / numPointsPerCircle);\n \n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1;\n \n float cX = 2.0 * (circleId / numCircles) - 1.0;\n \n float nearness = abs(cos((time + circleId) / 2.0));\n \n gl_Position = vec4(xy.x + cX, xy.y + sin(time + circleId)*0.5, 0.0, 1);\n gl_PointSize = 2.0 * nearness + 1.0;\n \n // Circle color\n float hue = sin(circleId * 0.1 + time * .1) * 0.8;\n float sat = 0.4;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n \n}" + }, "screenshotURL": "data/images/images-c2u169kc65p3ubza8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DRbySCBiHXiG6DyNE/art.json b/art/DRbySCBiHXiG6DyNE/art.json index 4f9f91e9..67f08ab4 100644 --- a/art/DRbySCBiHXiG6DyNE/art.json +++ b/art/DRbySCBiHXiG6DyNE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Hyunjin Kim\\n// Circles from Triangles. \\n// spring 2022\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Hyunjin Kim\n// Circles from Triangles. \n// spring 2022\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-0n0rmsswnxj3fb0lw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DRvinsX4dNgHKSnSm/art.json b/art/DRvinsX4dNgHKSnSm/art.json index f7b27c74..c397e702 100644 --- a/art/DRvinsX4dNgHKSnSm/art.json +++ b/art/DRvinsX4dNgHKSnSm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20001,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 20000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n // Good values for f:\\n // 0.0 in bass is always around 1\\n // 0.5 is in the mids, goes with music\\n // 1.0 is in the highs always 0\\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float phi = TWO_PI * t * 5.0;\\n float theta = TWO_PI * t * 7.0;\\n float sigma = t * TWO_PI;\\n float r = 0.7 + t * 0.3;\\n \\n phi += sin(theta * 5.0) * r * 0.2;\\n theta += cos(phi * 3.0) * r * 0.10;\\n sigma += sin(theta * 7.0) * r * 0.3;\\n r += sin(phi * 11.0) * 0.1 * r;\\n \\n phi += cos(sigma * 13.0 + r) * 0.2 * r * r;\\n theta += sin(phi * 11.0 + r) * 0.3 * r;\\n sigma += cos(theta * 3.0) * 0.2;\\n r += cos(theta) * 0.1 * r;\\n r *= 0.8 + 0.2 * sin(t * TWO_PI * 21.0);\\n r *= 0.5 + 0.5 * sqrt(t);\\n \\n float x0 = cos(phi) * r;\\n float y0 = sin(phi) * r;\\n float z0 = 0.0;\\n \\n float x1 = x0;\\n float y1 = sin(theta) * y0 + cos(theta) * z0;\\n float z1 = cos(theta) * y0 - sin(theta) * z0;\\n \\n float x = x1 * cos(sigma) + y1 * sin(sigma);\\n float y = x1 * sin(sigma) - y1 * cos(sigma);\\n float z = z1;\\n \\n return vec3(x, y, z);\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\\n \\n float power = 0.0;\\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\\n power = sqrt(power);\\n \\n\\n float mix1 = getSound(r, 0.0) - r;\\n float mix2 = power - r + 0.3;\\n float mixt = mix1 * 3.0 + mix2 * 10.0;\\n \\n float rwave = sin(mixt * 0.8);\\n float tpulse = sin((time * 0.05 + t * 100.0) * TWO_PI + mixt * 0.05);\\n float trpulse = sin(r * 0.75 * TWO_PI - time);\\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\\n \\n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\\n \\n \\n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\\n float s = 1.0 - ((1.0 - rpulse) * pulse);\\n\\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\\n}\"}", + "settings": { + "num": 20001, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 20000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n // Good values for f:\n // 0.0 in bass is always around 1\n // 0.5 is in the mids, goes with music\n // 1.0 is in the highs always 0\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\n}\n\nvec3 curvePos(float t) {\n float phi = TWO_PI * t * 5.0;\n float theta = TWO_PI * t * 7.0;\n float sigma = t * TWO_PI;\n float r = 0.7 + t * 0.3;\n \n phi += sin(theta * 5.0) * r * 0.2;\n theta += cos(phi * 3.0) * r * 0.10;\n sigma += sin(theta * 7.0) * r * 0.3;\n r += sin(phi * 11.0) * 0.1 * r;\n \n phi += cos(sigma * 13.0 + r) * 0.2 * r * r;\n theta += sin(phi * 11.0 + r) * 0.3 * r;\n sigma += cos(theta * 3.0) * 0.2;\n r += cos(theta) * 0.1 * r;\n r *= 0.8 + 0.2 * sin(t * TWO_PI * 21.0);\n r *= 0.5 + 0.5 * sqrt(t);\n \n float x0 = cos(phi) * r;\n float y0 = sin(phi) * r;\n float z0 = 0.0;\n \n float x1 = x0;\n float y1 = sin(theta) * y0 + cos(theta) * z0;\n float z1 = cos(theta) * y0 - sin(theta) * z0;\n \n float x = x1 * cos(sigma) + y1 * sin(sigma);\n float y = x1 * sin(sigma) - y1 * cos(sigma);\n float z = z1;\n \n return vec3(x, y, z);\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\n \n float power = 0.0;\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\n power = sqrt(power);\n \n\n float mix1 = getSound(r, 0.0) - r;\n float mix2 = power - r + 0.3;\n float mixt = mix1 * 3.0 + mix2 * 10.0;\n \n float rwave = sin(mixt * 0.8);\n float tpulse = sin((time * 0.05 + t * 100.0) * TWO_PI + mixt * 0.05);\n float trpulse = sin(r * 0.75 * TWO_PI - time);\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\n \n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\n \n \n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\n float s = 1.0 - ((1.0 - rpulse) * pulse);\n\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\n}" + }, "screenshotURL": "data/images/images-tc07k34oe871vmj7o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DS8Yfx4noREuQ6YKi/art.json b/art/DS8Yfx4noREuQ6YKi/art.json index a0c78b10..8b8e4e91 100644 --- a/art/DS8Yfx4noREuQ6YKi/art.json +++ b/art/DS8Yfx4noREuQ6YKi/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":6879,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 6879, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-4fyf6w4vo3vkw062y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DSH7PskktA2rGgZ6F/art.json b/art/DSH7PskktA2rGgZ6F/art.json index b86e27e0..3d39836b 100644 --- a/art/DSH7PskktA2rGgZ6F/art.json +++ b/art/DSH7PskktA2rGgZ6F/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":83549,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat2 rotate(float a) {\\n float s=sin(a),c=cos(a);\\n return mat2(c,s,-s,c);\\n}\\n\\nmat4 perspective(in float fovy, in float aspect, in float near, in float far) {\\n float top = near * tan(radians(fovy * 0.5));\\n float right = top * aspect;\\n float u = right * 2.0;\\n float v = top * 2.0;\\n float w = far - near;\\n return mat4(\\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \\n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \\n -(far + near) / w, -1.0, 0.0, 0.0,\\n -(far * near * 2.0) / w, 0.0\\n ); \\n}\\n\\nvec2 meshUV(in float id, in vec2 dim){\\n float quadID = floor(id / 6.0);\\n vec2 pos = vec2(mod(quadID,dim.x), mod(floor(quadID / dim.x),dim.y));\\n float pointID = abs(3.0 - mod(id, 6.0)); \\n vec2 uv;\\n if (fract((pos.x+pos.y)*0.5)<0.1){\\n uv = vec2(1.0-floor(pointID / 2.0),mod(pointID, 2.0));\\n } else {\\n uv = vec2(mod(pointID, 2.0), floor(pointID / 2.0));\\n }\\n uv += pos;\\n uv /= dim;\\n return uv;\\n}\\n\\n\\nvec3 meshSqhere(in float id, in float split) {\\n if (true) {\\n // 8面体ベースのMesh\\n float d = split * 2.0;\\n float n = floor(id / 6.0);\\n vec2 q = vec2(mod(n,d), mod(floor(n/d),d));\\n vec2 a = q+0.5-split;\\n float s = sign(a.x*a.y);\\n float c = abs(3.0 - mod(id, 6.0)); \\n vec2 uv = vec2(mod(c, 2.0), abs(step(0.0, s)-floor(c / 2.0)));\\n uv = (uv+q)/split -1.0; \\n if ( uv.x > abs(uv.y)) uv.y -= (uv.x - abs(uv.y))*s;\\n if (-uv.x > abs(uv.y)) uv.y -= (uv.x + abs(uv.y))*s;\\n if ( uv.y > abs(uv.x)) uv.x -= (uv.y - abs(uv.x))*s;\\n if (-uv.y > abs(uv.x)) uv.x -= (uv.y + abs(uv.x))*s;\\n return normalize(vec3(uv , 0.8*(1.0-pow(max(abs(uv.x),abs(uv.y)),2.0)) *s));\\n }\\n else\\n { \\n // 平面Meshの2枚使い\\n\\tvec2 dim = vec2(split);\\n\\tvec2 uv = meshUV(mod(id, 6.0*dim.x*dim.y), dim);\\n vec3 p = vec3(uv * 2.0 - 1.0 , 0.0);\\n p.z = 0.85*(1.0- pow(max(abs(p.x),abs(p.y)),2.0));\\n p.xz *= sign(floor(id/(6.0*dim.x*dim.y))-0.5);\\n return normalize(p);\\n }\\n}\\n\\nvec3 boss(in vec3 p){\\n vec3 ret = vec3(0.0);\\n ret.y += -0.3 * smoothstep(0.2,0.0, length(abs(p.zx)-vec2(0.4,0.4)))*step(0.0,-p.y);\\n ret.y += 0.2 * smoothstep(0.15,0.0, length(abs(p.zx-vec2(0.4,0.0))-vec2(0.0, 0.4)))*step(0.0, p.y); \\n ret.z += 0.15 * smoothstep(0.4, 0.3, length(p.yx)) * step(0.0, p.z);\\n ret.z += -0.15 * smoothstep(0.1, 0.0, length(abs(p.yx) - vec2(0.0, 0.15)))*step(0.0, p.z);\\n ret.z += -0.1 * smoothstep(0.1, 0.0, length(abs(p.yx-vec2(0.4,0.0))-vec2(0.0,0.3)))*step(0.0, p.z);\\n ret.z += -0.15 * smoothstep( 0.1, 0.0, length(p.yx - vec2(0.35,0.0))) * step(0.0, -p.z); \\n return ret;\\n}\\n\\nfloat map(in vec3 p) // distance function\\n{ \\n p -= boss(p);\\n return (length(p) - 1.0);\\n}\\n\\nvec3 calcNormal(in vec3 p)\\n{\\n vec2 e = vec2(1.0,-1.0)*0.002;\\n return normalize(\\n e.xyy*map(p+e.xyy)+e.yyx*map(p+e.yyx)+ \\n e.yxy*map(p+e.yxy)+e.xxx*map(p+e.xxx));\\n}\\n\\nvoid main() {\\n \\n mat4 pMatrix = perspective(45.0, resolution.x/resolution.y, 0.1, 100.0);\\n mat4 vMatrix = mat4(1.0);\\n vMatrix[3].z = -3.5; \\n float split = floor(sqrt(floor(vertexCount/6.0)));\\n split = floor(split/2.0);\\n vec3 p = meshSqhere(vertexId, split);\\n p += boss(p);\\n vec3 nor = calcNormal(p); \\n vec3 col = vec3(0.8,0.5,0.3);\\n vec3 li = normalize(vec3(0.5,1.0,1.0));\\n float dif = clamp(dot(nor,li),0.0,1.0);\\n float amb = max(0.5+0.5*nor.y,0.0); \\n col *= clamp(max(dif,0.3)*amb,0.0,1.0); \\n p.zx *= rotate(time*0.5);\\n gl_Position = pMatrix *vMatrix * vec4(p, 1.0);\\n v_color = vec4(col, 1.0);\\n}\"}", + "settings": { + "num": 83549, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat2 rotate(float a) {\n float s=sin(a),c=cos(a);\n return mat2(c,s,-s,c);\n}\n\nmat4 perspective(in float fovy, in float aspect, in float near, in float far) {\n float top = near * tan(radians(fovy * 0.5));\n float right = top * aspect;\n float u = right * 2.0;\n float v = top * 2.0;\n float w = far - near;\n return mat4(\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \n -(far + near) / w, -1.0, 0.0, 0.0,\n -(far * near * 2.0) / w, 0.0\n ); \n}\n\nvec2 meshUV(in float id, in vec2 dim){\n float quadID = floor(id / 6.0);\n vec2 pos = vec2(mod(quadID,dim.x), mod(floor(quadID / dim.x),dim.y));\n float pointID = abs(3.0 - mod(id, 6.0)); \n vec2 uv;\n if (fract((pos.x+pos.y)*0.5)<0.1){\n uv = vec2(1.0-floor(pointID / 2.0),mod(pointID, 2.0));\n } else {\n uv = vec2(mod(pointID, 2.0), floor(pointID / 2.0));\n }\n uv += pos;\n uv /= dim;\n return uv;\n}\n\n\nvec3 meshSqhere(in float id, in float split) {\n if (true) {\n // 8面体ベースのMesh\n float d = split * 2.0;\n float n = floor(id / 6.0);\n vec2 q = vec2(mod(n,d), mod(floor(n/d),d));\n vec2 a = q+0.5-split;\n float s = sign(a.x*a.y);\n float c = abs(3.0 - mod(id, 6.0)); \n vec2 uv = vec2(mod(c, 2.0), abs(step(0.0, s)-floor(c / 2.0)));\n uv = (uv+q)/split -1.0; \n if ( uv.x > abs(uv.y)) uv.y -= (uv.x - abs(uv.y))*s;\n if (-uv.x > abs(uv.y)) uv.y -= (uv.x + abs(uv.y))*s;\n if ( uv.y > abs(uv.x)) uv.x -= (uv.y - abs(uv.x))*s;\n if (-uv.y > abs(uv.x)) uv.x -= (uv.y + abs(uv.x))*s;\n return normalize(vec3(uv , 0.8*(1.0-pow(max(abs(uv.x),abs(uv.y)),2.0)) *s));\n }\n else\n { \n // 平面Meshの2枚使い\n\tvec2 dim = vec2(split);\n\tvec2 uv = meshUV(mod(id, 6.0*dim.x*dim.y), dim);\n vec3 p = vec3(uv * 2.0 - 1.0 , 0.0);\n p.z = 0.85*(1.0- pow(max(abs(p.x),abs(p.y)),2.0));\n p.xz *= sign(floor(id/(6.0*dim.x*dim.y))-0.5);\n return normalize(p);\n }\n}\n\nvec3 boss(in vec3 p){\n vec3 ret = vec3(0.0);\n ret.y += -0.3 * smoothstep(0.2,0.0, length(abs(p.zx)-vec2(0.4,0.4)))*step(0.0,-p.y);\n ret.y += 0.2 * smoothstep(0.15,0.0, length(abs(p.zx-vec2(0.4,0.0))-vec2(0.0, 0.4)))*step(0.0, p.y); \n ret.z += 0.15 * smoothstep(0.4, 0.3, length(p.yx)) * step(0.0, p.z);\n ret.z += -0.15 * smoothstep(0.1, 0.0, length(abs(p.yx) - vec2(0.0, 0.15)))*step(0.0, p.z);\n ret.z += -0.1 * smoothstep(0.1, 0.0, length(abs(p.yx-vec2(0.4,0.0))-vec2(0.0,0.3)))*step(0.0, p.z);\n ret.z += -0.15 * smoothstep( 0.1, 0.0, length(p.yx - vec2(0.35,0.0))) * step(0.0, -p.z); \n return ret;\n}\n\nfloat map(in vec3 p) // distance function\n{ \n p -= boss(p);\n return (length(p) - 1.0);\n}\n\nvec3 calcNormal(in vec3 p)\n{\n vec2 e = vec2(1.0,-1.0)*0.002;\n return normalize(\n e.xyy*map(p+e.xyy)+e.yyx*map(p+e.yyx)+ \n e.yxy*map(p+e.yxy)+e.xxx*map(p+e.xxx));\n}\n\nvoid main() {\n \n mat4 pMatrix = perspective(45.0, resolution.x/resolution.y, 0.1, 100.0);\n mat4 vMatrix = mat4(1.0);\n vMatrix[3].z = -3.5; \n float split = floor(sqrt(floor(vertexCount/6.0)));\n split = floor(split/2.0);\n vec3 p = meshSqhere(vertexId, split);\n p += boss(p);\n vec3 nor = calcNormal(p); \n vec3 col = vec3(0.8,0.5,0.3);\n vec3 li = normalize(vec3(0.5,1.0,1.0));\n float dif = clamp(dot(nor,li),0.0,1.0);\n float amb = max(0.5+0.5*nor.y,0.0); \n col *= clamp(max(dif,0.3)*amb,0.0,1.0); \n p.zx *= rotate(time*0.5);\n gl_Position = pMatrix *vMatrix * vec4(p, 1.0);\n v_color = vec4(col, 1.0);\n}" + }, "screenshotURL": "data/images/images-5aqjcrcuwrl0squ63-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DSjZ92TYBwkdfi8db/art.json b/art/DSjZ92TYBwkdfi8db/art.json index 6935367a..a757784a 100644 --- a/art/DSjZ92TYBwkdfi8db/art.json +++ b/art/DSjZ92TYBwkdfi8db/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":46640,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//Circles from Triangles exercise\\n//CS250\\n//2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI*2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 18.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 1.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down); \\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n \\n float aspect = resolution.x/resolution.y;\\n float sc = pow(snd + 0.2, 5.)*mix(1., 1.1 ,oddSlice);\\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.5);\\n mat *= rotZ(snd * 20. * sin(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;\\n \\n float pump = step(0.8, snd*2.);\\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = 1.;\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33 ;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\\n\"}", + "settings": { + "num": 46640, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//Circles from Triangles exercise\n//CS250\n//2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\nvec2 getCirclePoint(float id, float numCircleSegments){\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI*2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n \n float numCircleSegments = 18.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 1.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down); \n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n \n float aspect = resolution.x/resolution.y;\n float sc = pow(snd + 0.2, 5.)*mix(1., 1.1 ,oddSlice);\n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.5);\n mat *= rotZ(snd * 20. * sin(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;\n \n float pump = step(0.8, snd*2.);\n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = 1.;\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33 ;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n\n" + }, "screenshotURL": "data/images/images-zuxplhexlvxyolecc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DTZTZdm35YfaxuP7k/art.json b/art/DTZTZdm35YfaxuP7k/art.json index 7b2201e1..87bd8e96 100644 --- a/art/DTZTZdm35YfaxuP7k/art.json +++ b/art/DTZTZdm35YfaxuP7k/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":6535,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265359\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 rotZ(vec3 v, float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n mat3 R = mat3(c, s, 0.,\\n -s, c, 0.,\\n 0., 0., 1.);\\n return R * v;\\n}\\n\\nvec3 rotY(vec3 v, float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n mat3 R = mat3(c, 0, s,\\n 0, 1, 0,\\n -s, 0, c);\\n return R * v;\\n}\\n\\nvec3 rotX(vec3 v, float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n mat3 R = mat3(1, 0, 0,\\n 0, c, s,\\n 0, -s, c);\\n return R * v;\\n}\\n\\n#define PNTS_PER_SPHERE 24.\\nvoid drawSphere(const float id, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id /2.) + floor(id / 3.), 2.);\\n float u = ux / PNTS_PER_SPHERE;\\n float v = vy;\\n float a = u * PI *2.;\\n pos = vec3(cos(a) * v, sin(a) * v, 0.);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id,\\n const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nvoid main() {\\n float pointId = vertexId;\\n float u = vertexId/vertexCount;\\n float v = fract(vertexId / vertexCount);\\n gl_PointSize = 10.;\\n \\n vec3 pos_disk;\\n drawSphere(pointId, pos_disk);\\n \\n vec3 pos = vec3(u, v, 0.);\\n pos = rotZ(pos, -time/0.5 + v * u);\\n pos = rotY(pos, -time/0.4 + v * u);\\n //gl_Position = vec4(pos.xyz,1);\\n gl_Position = vec4(pos_disk,1);\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 6535, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265359\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 rotZ(vec3 v, float angle) {\n float s = sin(angle);\n float c = cos(angle);\n mat3 R = mat3(c, s, 0.,\n -s, c, 0.,\n 0., 0., 1.);\n return R * v;\n}\n\nvec3 rotY(vec3 v, float angle) {\n float s = sin(angle);\n float c = cos(angle);\n mat3 R = mat3(c, 0, s,\n 0, 1, 0,\n -s, 0, c);\n return R * v;\n}\n\nvec3 rotX(vec3 v, float angle) {\n float s = sin(angle);\n float c = cos(angle);\n mat3 R = mat3(1, 0, 0,\n 0, c, s,\n 0, -s, c);\n return R * v;\n}\n\n#define PNTS_PER_SPHERE 24.\nvoid drawSphere(const float id, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id /2.) + floor(id / 3.), 2.);\n float u = ux / PNTS_PER_SPHERE;\n float v = vy;\n float a = u * PI *2.;\n pos = vec3(cos(a) * v, sin(a) * v, 0.);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id,\n const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nvoid main() {\n float pointId = vertexId;\n float u = vertexId/vertexCount;\n float v = fract(vertexId / vertexCount);\n gl_PointSize = 10.;\n \n vec3 pos_disk;\n drawSphere(pointId, pos_disk);\n \n vec3 pos = vec3(u, v, 0.);\n pos = rotZ(pos, -time/0.5 + v * u);\n pos = rotY(pos, -time/0.4 + v * u);\n //gl_Position = vec4(pos.xyz,1);\n gl_Position = vec4(pos_disk,1);\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-ucx9alc5wguf425qc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DWwhcFd3xWKC5yjiW/art.json b/art/DWwhcFd3xWKC5yjiW/art.json index 41afa41e..89f3d961 100644 --- a/art/DWwhcFd3xWKC5yjiW/art.json +++ b/art/DWwhcFd3xWKC5yjiW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\nvoid v(out vec3 p,out vec3 n,out float m,float x,float y,float z,float a,float b,float c,int d) {p=vec3(x,y,z);n=vec3(a,b,c);m=float(d);}\\n#define V(x,y,z,a,b,c,d) v(pos,norm,modelId,x,y,z,a,b,c,d);\\n#define Q(i) if(id 1000. )\\n {\\n\\tfloat ux = w2NDC(hashOld12(vec2(vertexId * u))) ;\\n if(ux < 0. )\\n { \\n gl_Position = vec4(ux, w2NDC(hashOld12(vec2(vertexId * v))) * v, 0. , 1. );\\n\\n gl_PointSize = 5.; \\n v_color = vec4(1.) ;\\n }\\n \\n ux = w2NDC(hashOld33(vec3(vertexId * u)).x ); \\n if(ux > 0. )\\n {\\n gl_Position = vec4( w2NDC(hashOld33(vec3(vertexId * u)).x ), w2NDC(hashOld12(vec2(vertexId * v))) * v, 0. , 1. ) * 1.;\\n gl_PointSize = 5.; \\n v_color = vec4(1.) ;\\n }\\n }\\n}\"}", + "settings": { + "num": 11804, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.11372549019607843, + 0.3411764705882353, + 1 + ], + "shader": "/* \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n , , , . . . ._ \n -+- _ __-+- -+-. , _ |__| _. __|_ |,. .._ _. \n | (/,_) | | \\/\\/ (_) | |(_]_) [ ) | (_|[ )(_. \n \n \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@07/12/2019\n@https://www.shadertoy.com/view/4djSRW \n*/ \n\n\n\n\n\n//test for the hash function used @gman\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n \n//https://www.shadertoy.com/view/4djSRW\nfloat hashOld12(vec2 p)\n{\n // Two typical hashes...\n\treturn fract(sin(dot(p, vec2(12.9898, 78.233))) * 43758.5453);\n \n // This one is better, but it still stretches out quite quickly...\n // But it's really quite bad on my Mac(!)\n //return fract(sin(dot(p, vec2(1.0,113.0)))*43758.5453123);\n\n}\n\nvec3 hashOld33( vec3 p )\n{\n\tp = vec3( dot(p,vec3(127.1,311.7, 74.7)),\n\t\t\t dot(p,vec3(269.5,183.3,246.1)),\n\t\t\t dot(p,vec3(113.5,271.9,124.6)));\n\n\treturn fract(sin(p)*43758.5453123);\n}\n\n\n\n\nfloat w2NDC(float v) {\n return v * 2. - 1.;\n}\n\nvoid main()\n{ \n float d = floor(sqrt(vertexCount)) ;\n float a = floor(vertexCount / d) ; \n float x = mod(vertexId , a ) ;\n float y = floor(vertexId / a ) ; \n\n float u = w2NDC(x / (a -1.)) ; //in NDC \n float v = w2NDC(y / (a -1.)) ; //in NDC \n float aspect = resolution.x/ resolution.y ;\n \n if(vertexId < 1000.)\n {\n gl_Position = vec4( 0. , w2NDC(vertexId / aspect * 0.01 ) , 0. , 1. ) ; \n gl_PointSize = 20. ; \n v_color = vec4(1. , 0.02 , 0.3 , 1.) ; \n }\n else if(vertexId < 3000. && vertexId > 1000. )\n {\n\tfloat ux = w2NDC(hashOld12(vec2(vertexId * u))) ;\n if(ux < 0. )\n { \n gl_Position = vec4(ux, w2NDC(hashOld12(vec2(vertexId * v))) * v, 0. , 1. );\n\n gl_PointSize = 5.; \n v_color = vec4(1.) ;\n }\n \n ux = w2NDC(hashOld33(vec3(vertexId * u)).x ); \n if(ux > 0. )\n {\n gl_Position = vec4( w2NDC(hashOld33(vec3(vertexId * u)).x ), w2NDC(hashOld12(vec2(vertexId * v))) * v, 0. , 1. ) * 1.;\n gl_PointSize = 5.; \n v_color = vec4(1.) ;\n }\n }\n}" + }, "screenshotURL": "data/images/images-kikaqqv5evbr3tf82-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DaM7frg7uQNDe7mK2/art.json b/art/DaM7frg7uQNDe7mK2/art.json index a7c45011..9c78a3d2 100644 --- a/art/DaM7frg7uQNDe7mK2/art.json +++ b/art/DaM7frg7uQNDe7mK2/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":39751,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/psyches-shroud/currents-demo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.047058823529411764,0.08235294117647059,0.09019607843137255,1],\"shader\":\"#define PI radians(180.0)\\n\\n/** Returns a random value between [0, 1) */\\nfloat rand(float val) {\\n\\treturn fract(sin(val)*10000.0);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 getSquarePoint(float id) { \\n float x = mod(id, 2.0) + floor(id / 6.0);\\n float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n return vec2(x, y);\\n}\\n\\nvec2 getCirclePoint(float id, float numSegments) { \\n // Each square is made of 2 triangles, 6 points\\n vec2 uv = getSquarePoint(id);\\n\\n // Calculate angle and radial values\\n float angle = uv.x / numSegments * 2.0 * PI;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n // Translate back to x y\\n float radius = uv.y;\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n // Segments to form a circle\\n float numSegments = 8.0;\\n \\n // How many points in a circle\\n float numPointsPerCircle = numSegments * 6.0;\\n \\n // How many circles\\n float numCircles = floor(vertexCount / numPointsPerCircle) - 1.0;\\n \\n // Which circle\\n float circleId = floor(vertexId / numPointsPerCircle);\\n \\n float sizeScaler = rand(rand(circleId));\\n \\n // Sound intensity \\n float snd = texture2D(sound, vec2(mix(0.0, 0.5, sizeScaler), 0.0)).a;\\n \\n // Size of circle\\n float size = mix(0.001, 0.01, snd); // mix(0.001, 0.005, sizeScaler);\\n \\n float aspect = resolution.x / resolution.y;\\n \\n // Now get our vertex point in its circle\\n vec2 xy = getCirclePoint(vertexId, numSegments) * size;\\n xy = vec2(xy.x / aspect, xy.y);\\n \\n // We'll use slowed down time\\n float scaledTime = time * 0.1;\\n \\n float xMotion = sin(scaledTime + PI*rand(rand(circleId*32.0)*rand(circleId)))*0.1;\\n float yMotion = cos(scaledTime + PI*rand(rand(circleId*52.02)*rand(circleId - 53.0)))*0.1;\\n float xOff = rand(circleId) * 2.0 - 1.0 + xMotion;\\n float yOff = rand(circleId + 4.0) * 2.0 - 1.0 + yMotion;\\n \\n gl_Position = vec4(xy.x + xOff, xy.y + yOff, 0.0, 1);\\n \\n // Circle color\\n float hue = 0.6;\\n float sat = 0.2;\\n float val = mix(0.5, 1.0, snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.0);\\n \\n}\"}", + "settings": { + "num": 39751, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/psyches-shroud/currents-demo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.047058823529411764, + 0.08235294117647059, + 0.09019607843137255, + 1 + ], + "shader": "#define PI radians(180.0)\n\n/** Returns a random value between [0, 1) */\nfloat rand(float val) {\n\treturn fract(sin(val)*10000.0);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 getSquarePoint(float id) { \n float x = mod(id, 2.0) + floor(id / 6.0);\n float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n return vec2(x, y);\n}\n\nvec2 getCirclePoint(float id, float numSegments) { \n // Each square is made of 2 triangles, 6 points\n vec2 uv = getSquarePoint(id);\n\n // Calculate angle and radial values\n float angle = uv.x / numSegments * 2.0 * PI;\n float c = cos(angle);\n float s = sin(angle);\n \n // Translate back to x y\n float radius = uv.y;\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n // Segments to form a circle\n float numSegments = 8.0;\n \n // How many points in a circle\n float numPointsPerCircle = numSegments * 6.0;\n \n // How many circles\n float numCircles = floor(vertexCount / numPointsPerCircle) - 1.0;\n \n // Which circle\n float circleId = floor(vertexId / numPointsPerCircle);\n \n float sizeScaler = rand(rand(circleId));\n \n // Sound intensity \n float snd = texture2D(sound, vec2(mix(0.0, 0.5, sizeScaler), 0.0)).a;\n \n // Size of circle\n float size = mix(0.001, 0.01, snd); // mix(0.001, 0.005, sizeScaler);\n \n float aspect = resolution.x / resolution.y;\n \n // Now get our vertex point in its circle\n vec2 xy = getCirclePoint(vertexId, numSegments) * size;\n xy = vec2(xy.x / aspect, xy.y);\n \n // We'll use slowed down time\n float scaledTime = time * 0.1;\n \n float xMotion = sin(scaledTime + PI*rand(rand(circleId*32.0)*rand(circleId)))*0.1;\n float yMotion = cos(scaledTime + PI*rand(rand(circleId*52.02)*rand(circleId - 53.0)))*0.1;\n float xOff = rand(circleId) * 2.0 - 1.0 + xMotion;\n float yOff = rand(circleId + 4.0) * 2.0 - 1.0 + yMotion;\n \n gl_Position = vec4(xy.x + xOff, xy.y + yOff, 0.0, 1);\n \n // Circle color\n float hue = 0.6;\n float sat = 0.2;\n float val = mix(0.5, 1.0, snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.0);\n \n}" + }, "screenshotURL": "data/images/images-mk2wlucfv1tpygtzm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DaN8tYyqjWyHdm6jd/art.json b/art/DaN8tYyqjWyHdm6jd/art.json index 309c7e6e..6283dee5 100644 --- a/art/DaN8tYyqjWyHdm6jd/art.json +++ b/art/DaN8tYyqjWyHdm6jd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/guigoo-official/acido\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const int maxIter = 10;\\nfloat df(vec3 p, float power) {\\n vec3 z = p;\\n float r = 0.0;\\n float dr = 1.0;\\n for(int i = 0; i < maxIter; i++) {\\n r = length(z);\\n if(r > 100.0) break;\\n \\n float theta = acos(z.z/r);\\n float phi = atan(z.y, z.x);\\n \\n dr = power*pow(r, power-1.0)*dr + 1.0;\\n \\n r = pow(r, power);\\n theta *= power;\\n phi *= power;\\n \\n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\\n z += p;\\n }\\n return 0.5*log(r)*r/dr;\\n}\\n\\n\\nstruct Ray {\\n bool hit;\\n vec3 hitPos;\\n float t;\\n int steps;\\n};\\nconst int maxSteps = 50;\\nRay trace(vec3 camPos, vec3 rayDir) {\\n vec3 p = vec3(0);\\n float t = 0.0; \\n int steps = 0;\\n bool hit = false;\\n for(int i = 0; i < maxSteps; i++) {\\n p = camPos + t*rayDir;\\n float d = df(p, 8.0*abs(sin(0.5*time)) + 1.0);\\n if(d < 0.001) {\\n hit = true;\\n steps = i;\\n break;\\n }\\n t += d*0.9;\\n }\\n return Ray(hit, p, t, steps);\\n}\\n\\n\\nvec3 shading(Ray tr) {\\n if(tr.hit) {\\n \\treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\\n }\\n else {\\n return vec3(0);\\n }\\n}\\n\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n //we want to keep the resolution.xresolution.y ratio\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //deduce from finalMaxVertexCount the number of possible lines with the given across\\n float down = floor(finalMaxVertexCount / across);\\n \\n //Now we have the across and down number of elements, we can now calculate the final number of vertices\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n\\n \\n //vec2 fragCoord = vec2(ux,vy);\\n \\n //apply fragment logic\\n\\n\\tvec2 fragCoord = vec2(x,y);\\n \\n\\tvec2 iResolution = vec2(across, down);\\n float iTime = time;\\n \\n\\tvec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\\n \\n //vec2 uv = vec2(u,v);\\n \\n //vec3 camPos = vec3(-2, 0, 0);\\n vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\\n vec3 camFront = normalize(-camPos);\\n vec3 camUp = vec3(0, 1, 0);\\n vec3 camRight = cross(camFront, camUp);\\n float focus = 1.0;\\n \\n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\\n Ray tr = trace(camPos, rayDir);\\n \\n\\t//fragColor = vec4(shading(tr), 1.0);\\n\\t\\n v_color = vec4(shading(tr), 1.0);\\n gl_Position = vec4(ux*v_color.x*5., vy*v_color.y *5., 0, 1);\\n //gl_Position = vec4(ux , vy , 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n \\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/guigoo-official/acido", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const int maxIter = 10;\nfloat df(vec3 p, float power) {\n vec3 z = p;\n float r = 0.0;\n float dr = 1.0;\n for(int i = 0; i < maxIter; i++) {\n r = length(z);\n if(r > 100.0) break;\n \n float theta = acos(z.z/r);\n float phi = atan(z.y, z.x);\n \n dr = power*pow(r, power-1.0)*dr + 1.0;\n \n r = pow(r, power);\n theta *= power;\n phi *= power;\n \n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\n z += p;\n }\n return 0.5*log(r)*r/dr;\n}\n\n\nstruct Ray {\n bool hit;\n vec3 hitPos;\n float t;\n int steps;\n};\nconst int maxSteps = 50;\nRay trace(vec3 camPos, vec3 rayDir) {\n vec3 p = vec3(0);\n float t = 0.0; \n int steps = 0;\n bool hit = false;\n for(int i = 0; i < maxSteps; i++) {\n p = camPos + t*rayDir;\n float d = df(p, 8.0*abs(sin(0.5*time)) + 1.0);\n if(d < 0.001) {\n hit = true;\n steps = i;\n break;\n }\n t += d*0.9;\n }\n return Ray(hit, p, t, steps);\n}\n\n\nvec3 shading(Ray tr) {\n if(tr.hit) {\n \treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\n }\n else {\n return vec3(0);\n }\n}\n\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n //we want to keep the resolution.xresolution.y ratio\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //deduce from finalMaxVertexCount the number of possible lines with the given across\n float down = floor(finalMaxVertexCount / across);\n \n //Now we have the across and down number of elements, we can now calculate the final number of vertices\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n\n \n //vec2 fragCoord = vec2(ux,vy);\n \n //apply fragment logic\n\n\tvec2 fragCoord = vec2(x,y);\n \n\tvec2 iResolution = vec2(across, down);\n float iTime = time;\n \n\tvec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\n \n //vec2 uv = vec2(u,v);\n \n //vec3 camPos = vec3(-2, 0, 0);\n vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\n vec3 camFront = normalize(-camPos);\n vec3 camUp = vec3(0, 1, 0);\n vec3 camRight = cross(camFront, camUp);\n float focus = 1.0;\n \n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\n Ray tr = trace(camPos, rayDir);\n \n\t//fragColor = vec4(shading(tr), 1.0);\n\t\n v_color = vec4(shading(tr), 1.0);\n gl_Position = vec4(ux*v_color.x*5., vy*v_color.y *5., 0, 1);\n //gl_Position = vec4(ux , vy , 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n \n \n //v_color = vec4(1.,1.,1.,1.);\n}" + }, "screenshotURL": "data/images/images-xqgh2ur206l1r2xr3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DagQjjsyoq4ygNS4K/art.json b/art/DagQjjsyoq4ygNS4K/art.json index 09bac075..8fd00fc0 100644 --- a/art/DagQjjsyoq4ygNS4K/art.json +++ b/art/DagQjjsyoq4ygNS4K/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n \\n float width = 10.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n x = x / (width - 1.0);\\n y = y / (width - 1.0);\\n \\n x = x * 2.0 - 1.0;\\n y = y * 2.0 - 1.0;\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n x = x + xOffset;\\n y = y + yOffset;\\n \\n vec2 xy = vec2(x, y) * 0.5;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 100, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n \n float width = 10.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n x = x / (width - 1.0);\n y = y / (width - 1.0);\n \n x = x * 2.0 - 1.0;\n y = y * 2.0 - 1.0;\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n x = x + xOffset;\n y = y + yOffset;\n \n vec2 xy = vec2(x, y) * 0.5;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-mlp35pmvw7ntyujx7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Dbuz4RR9kb9tav5ty/art.json b/art/Dbuz4RR9kb9tav5ty/art.json index 9bb781f3..dfef0272 100644 --- a/art/Dbuz4RR9kb9tav5ty/art.json +++ b/art/Dbuz4RR9kb9tav5ty/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Motion\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. -1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Motion\n//Course : CS250\n//Term : 2023 Fall\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. -1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-ub5t3ogsow6yiilx6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DhAP5qwkiBv5JbSuR/art.json b/art/DhAP5qwkiBv5JbSuR/art.json index b53bb6a6..e21bb8cc 100644 --- a/art/DhAP5qwkiBv5JbSuR/art.json +++ b/art/DhAP5qwkiBv5JbSuR/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":73798,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.2) + mod(vertexId, 2.3);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.4 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.50\\n ;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 5.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.6 - 1.7;\\n float y = v * 2.8 - 1.9;\\n vec2 xy = vec2(\\n x * mix(10.5, 1.2, invV),\\n y + pow(snd, 9.3) * 1.4) / (v + 5.5);\\n gl_Position = vec4(xy * 6.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 73798, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.2) + mod(vertexId, 2.3);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.4 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.50\n ;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 5.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.6 - 1.7;\n float y = v * 2.8 - 1.9;\n vec2 xy = vec2(\n x * mix(10.5, 1.2, invV),\n y + pow(snd, 9.3) * 1.4) / (v + 5.5);\n gl_Position = vec4(xy * 6.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-5sbgzczfql86iquoi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DiGpLPYqRW3DAtnFc/art.json b/art/DiGpLPYqRW3DAtnFc/art.json index 17bd1088..e3ae27fc 100644 --- a/art/DiGpLPYqRW3DAtnFc/art.json +++ b/art/DiGpLPYqRW3DAtnFc/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "galousis", "avatarUrl": "https://avatars.githubusercontent.com/galousis?s=200", - "settings": "{\"num\":80000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/pridon/here-be-dragons\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n___________________1111111111111__________________\\n______________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_____________\\n___________1¶¶¶¶¶¶111111111111111¶¶¶¶¶¶1__________\\n_________1¶¶¶11111111111111111111111¶1¶¶¶1________\\n_______1¶¶¶¶1111111111111111111111111111¶¶¶1______\\n______1¶¶1¶1111111111¶¶¶¶¶¶¶¶1111111111111¶¶1_____\\n_____¶¶¶11111111¶¶¶¶¶¶¶¶1_¶¶¶¶¶¶¶¶111111111¶¶¶____\\n____¶¶¶1111111¶¶¶¶¶¶¶¶1_____¶¶¶¶¶¶¶¶11111111¶¶¶___\\n___1¶¶111111¶¶¶¶¶¶¶¶1_________¶¶¶¶¶¶¶¶1111111¶¶1__\\n___¶¶11111¶¶¶¶¶¶¶¶1____________1¶¶¶¶¶¶¶¶111111¶¶1_\\n__¶¶11111¶¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶¶1¶¶¶¶¶¶¶¶111111¶¶_\\n__¶¶1111¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶_____1¶¶¶¶¶¶¶¶11111¶¶_\\n__¶¶1111¶¶¶¶¶¶¶1________¶¶________¶¶¶¶¶¶1¶¶1111¶¶_\\n__¶1111¶¶¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\\n__¶¶111¶1¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\\n__¶1111¶¶1¶¶¶¶¶¶________¶¶¶_______1¶¶¶¶¶11¶11111¶_\\n__¶¶111¶¶1¶¶¶¶¶¶1_____¶¶¶_¶¶______¶¶¶¶¶¶1¶¶1111¶¶_\\n__1¶¶111¶11¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶¶¶¶¶11¶1111¶¶1_\\n___¶¶¶11¶¶11¶¶¶¶¶¶¶1___________¶¶¶¶¶¶¶11¶¶111¶¶¶__\\n___1¶¶111¶¶111¶¶¶¶¶¶¶________1¶¶¶¶¶¶111¶¶1111¶¶1__\\n____1¶¶1111¶¶111¶¶¶¶¶¶¶1___¶¶¶¶¶¶¶111¶¶¶1111¶¶1___\\n_____1¶¶¶111¶¶¶11111¶¶¶¶¶¶¶¶¶¶11111¶¶¶11111¶¶1____\\n______1¶¶¶1111¶¶¶¶¶1111¶¶¶11111¶¶¶¶¶11111¶¶¶1_____\\n________1¶¶111111¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1111111¶¶1_______\\n__________¶¶1111111111¶¶¶¶1111111111111¶1_________\\n__________¶¶¶11111111¶¶11¶¶11111111111¶¶¶_________\\n________1¶¶11¶1¶¶111111111¶111111¶¶¶¶¶11¶¶________\\n_______1¶¶111111¶¶¶¶¶1¶1¶¶¶¶¶¶¶¶¶¶1111111¶¶_______\\n_______¶¶¶11111111111111¶¶11¶1111111111111¶¶______\\n______1¶1111¶11111111111¶¶11111111111111111¶1_____\\n______¶¶111¶111111111111¶¶1111111111111¶111¶¶_____\\n_____1¶111¶¶111111111111¶¶1111111111111¶1111¶1____\\n_____¶¶¶¶¶¶¶111111111111¶¶1111111111111¶¶¶¶¶¶¶____\\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\\n____1¶¶¶¶¶¶1111111111111¶¶11111111111111¶¶¶¶¶¶1___\\n______1111¶1111111111111¶¶11111111111111¶1111_____\\n__________¶¶¶11111111111¶¶111111111111¶¶¶_________\\n__________¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶_________\\n________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_______\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n// based & influenced by this https://github.com/KessonDalef/Shaders/blob/master/Vertex/spherepointcloud.vert\\n\\n/*{\\n \\\"pixelRatio\\\": 1,\\n \\\"vertexCount\\\": 80000,\\n \\\"vertexMode\\\": \\\"POINTS\\\",\\n}*/\\n\\n#define DOTS_PER 80000.\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nprecision mediump float;\\n/*\\nattribute float vertexId;\\nuniform float vertexCount;\\nuniform float time;\\nuniform vec2 resolution;\\nvarying vec4 v_color;\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// 2D Random\\nfloat random (in vec2 st) {\\n return fract(sin(dot(st.xy,\\n vec2(12.9898,78.233)))\\n * 43758.5453123);\\n}\\n\\n// Based on Morgan McGuire @morgan3d\\n// https://www.shadertoy.com/view/4dS3Wd\\nfloat noise (in vec2 st) {\\n vec2 i = floor(st);\\n vec2 f = fract(st);\\n\\n // Four corners in 2D of a tile\\n float a = random(i);\\n float b = random(i + vec2(1.0, 0.0));\\n float c = random(i + vec2(0.0, 1.0));\\n float d = random(i + vec2(1.0, 1.0));\\n\\n // Cubic Hermine Curve. Same as SmoothStep()\\n vec2 u = f*f*(3.-2.0*f);\\n u = smoothstep(0.,1.,f);\\n\\n // Mix 4 coorners percentages\\n return mix(a, b, u.x) +\\n (c - a)* u.y * (1.0 - u.x) +\\n (d - b) * u.x * u.y;\\n}\\n\\nmat4 rotateX(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateY(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateZ(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nfloat easeInOutSine(float x) \\n{\\n return -(cos(PI * x) - 1.) * 0.5;\\n}\\n\\nvec4 Slerp(vec4 p0, vec4 p1, float t)\\n{\\n float dotp = dot(normalize(p0), normalize(p1));\\n if ((dotp > 0.9999) || (dotp<-0.9999))\\n {\\n if (t<=0.5)\\n return p0;\\n return p1;\\n }\\n float theta = acos(dotp * PI/180.0);\\n vec4 P = (\\n (\\n p0*sin((1.-t)*theta) + p1*sin(t*theta)\\n ) / sin(theta)\\n );\\n P.w = 1.;\\n return P;\\n}\\n\\nvec3 posf2(float t, float i, float snd) \\n{\\n\\treturn vec3(\\n cos(t*.4+i*1.53) +\\n sin(t*4.84+i*.6)\\n //noise(vec2(t*.5*snd, i))\\n ,\\n cos(t*1.4+i*1.353-2.1) +\\n sin(t*4.84+i*.476-2.1) \\n //noise(vec2(t, i))\\n ,\\n sin(t*1.84+i*.36+2.1)// +\\n\\t)*.1;\\n}\\n\\nvec3 posf0(float t, float fsndweight, float snd) {\\n //return posf2(t,-1.)*0.9;\\n return posf2(t,-1.,snd)*fsndweight;\\n}\\n\\nvec3 posf(float t, float i, float fsndweight, float snd) \\n{\\n //float fsndweightf = mix(4.4, 4.49, pow(fsndweight, 2.0));\\n return posf2(t*.045,i,snd) + posf0(t,fsndweight,snd);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd, float lenghtweight, float snd) {\\n //vec3 pos = posf(t,i,.49)+ofs;\\n vec3 pos = posf(t,i, mix(.45, 4.5, pow(snd, 1.0)), snd) + ofs;\\n\\n vec3 posf = fract(pos+.5)-.5;\\n\\n float l = length(posf)*lenghtweight; //1.5\\n //return (- posf + posf/l)*(1.-smoothstep(lerpEnd,3.,l));\\n //return (posf/l)*(1.-smoothstep(lerpEnd,2.9,l));\\n return (posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// YUV to RGB matrix\\nmat3 yuv2rgb = mat3(1.0, 0.0, 1.13983,\\n 1.0, -0.39465, -0.58060,\\n 1.0, 2.03211, 0.0);\\n\\n// RGB to YUV matrix\\nmat3 rgb2yuv = mat3(0.2126, 0.7152, 0.0722,\\n -0.09991, -0.33609, 0.43600,\\n 0.615, -0.5586, -0.05639);\\n\\n#define OCTAVES 12\\nfloat fbm (in vec2 st) {\\n // Initial values\\n float value = 0.0;\\n float amplitude = .5;\\n float frequency = 0.;\\n //\\n // Loop of octaves\\n for (int i = 0; i < OCTAVES; i++) {\\n value += amplitude * noise(st);\\n st *= 2.;\\n amplitude *= .5;\\n }\\n return value;\\n}\\n\\nfloat fbm2 ( in vec2 _st) {\\n float v = 0.0;\\n float a = 0.5;\\n vec2 shift = vec2(100.0);\\n // Rotate to reduce axial bias\\n mat2 rot = mat2(cos(0.5), sin(0.5),\\n -sin(0.5), cos(0.50));\\n for (int i = 0; i < OCTAVES; ++i) {\\n v += a * noise(_st);\\n _st = rot * _st * 2.0 + shift;\\n a *= 0.5;\\n }\\n return v;\\n}\\n\\nvoid main(void)\\n{\\n\\n float t = time*.6;\\n float i = vertexId+sin(vertexId)*100.;\\n \\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n \\n float snd = texture2D(sound, vec2(thingV * 0.5 + 0.01, mod(thingV * 4., 4.) * 6. / 24.)).a*mix(.5, .9, .8);\\n \\n vec3 pos = posf(t,i, mix(1.45, 4.5, pow(snd, 1.)), snd);\\n \\n vec3 ofs = vec3(0);\\n \\n for (float f = -10.; f < 0.; f++) {\\n\\t //ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\\n ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(2.45, 1.5, pow(snd, 1.)),snd);\\n }\\n ofs += push(t,i,ofs,.999,mix(2.45, 1.5, pow(snd, 2.)),snd);\\n\\n //pos -= posf0(t);\\n pos -= posf0(t,.49, snd);\\n\\n pos += ofs;\\n\\n \\n //vec4 sphericalInt = Slerp(vec4(pos, 1.), vec4(vec3(ofs), 1.), time*pow(snd, 2.));\\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n //sphericalInt.yz *= mat2(.8,.6,-.6,.8);\\n //sphericalInt.xz *= mat2(.8,.6,-.6,.8);\\n\\n pos.x *= resolution.y/resolution.x;\\n pos.z *= resolution.y/resolution.x;\\n\\n mat4 rotation = rotateY(time*0.15);\\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\\n\\n pos.z += .9;\\n\\n //rot *= .95;\\n rot *= .5;\\n\\n gl_Position = vec4(rot.xyz, 0.55);\\n gl_PointSize = .3;\\n\\n float hue = 1.6 + v;// + v * time * 0.;\\n hue = mix(hue, 50., mod(floor(t * 4.0), 1.4));\\n hue = mix(hue, 0.5, step(0.95, snd*0.95));\\n \\n float clipZ = m1p1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n float val = invClipZ * 150.;\\n \\n \\n \\n \\n //v_color = vec4(hsv2rgb(vec3(hue*2., hue*22., val)),mix(1., 2.5, pow(snd, 4.)));\\n v_color = vec4(yuv2rgb * vec3(0.5, pos.x, pos.y),mix(1., 2.5, pow(snd, 4.)));\\n v_color = vec4(\\n v_color.rbg * v_color.g, \\n v_color.a\\n );\\n v_color += fbm(pos.xy*50.0);\\n \\n //v_color += vec4(.7, 0.6, 1.0, 0.6);\\n}\\n\"}", + "settings": { + "num": 80000, + "mode": "POINTS", + "sound": "https://soundcloud.com/pridon/here-be-dragons", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n___________________1111111111111__________________\n______________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_____________\n___________1¶¶¶¶¶¶111111111111111¶¶¶¶¶¶1__________\n_________1¶¶¶11111111111111111111111¶1¶¶¶1________\n_______1¶¶¶¶1111111111111111111111111111¶¶¶1______\n______1¶¶1¶1111111111¶¶¶¶¶¶¶¶1111111111111¶¶1_____\n_____¶¶¶11111111¶¶¶¶¶¶¶¶1_¶¶¶¶¶¶¶¶111111111¶¶¶____\n____¶¶¶1111111¶¶¶¶¶¶¶¶1_____¶¶¶¶¶¶¶¶11111111¶¶¶___\n___1¶¶111111¶¶¶¶¶¶¶¶1_________¶¶¶¶¶¶¶¶1111111¶¶1__\n___¶¶11111¶¶¶¶¶¶¶¶1____________1¶¶¶¶¶¶¶¶111111¶¶1_\n__¶¶11111¶¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶¶1¶¶¶¶¶¶¶¶111111¶¶_\n__¶¶1111¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶_____1¶¶¶¶¶¶¶¶11111¶¶_\n__¶¶1111¶¶¶¶¶¶¶1________¶¶________¶¶¶¶¶¶1¶¶1111¶¶_\n__¶1111¶¶¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\n__¶¶111¶1¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\n__¶1111¶¶1¶¶¶¶¶¶________¶¶¶_______1¶¶¶¶¶11¶11111¶_\n__¶¶111¶¶1¶¶¶¶¶¶1_____¶¶¶_¶¶______¶¶¶¶¶¶1¶¶1111¶¶_\n__1¶¶111¶11¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶¶¶¶¶11¶1111¶¶1_\n___¶¶¶11¶¶11¶¶¶¶¶¶¶1___________¶¶¶¶¶¶¶11¶¶111¶¶¶__\n___1¶¶111¶¶111¶¶¶¶¶¶¶________1¶¶¶¶¶¶111¶¶1111¶¶1__\n____1¶¶1111¶¶111¶¶¶¶¶¶¶1___¶¶¶¶¶¶¶111¶¶¶1111¶¶1___\n_____1¶¶¶111¶¶¶11111¶¶¶¶¶¶¶¶¶¶11111¶¶¶11111¶¶1____\n______1¶¶¶1111¶¶¶¶¶1111¶¶¶11111¶¶¶¶¶11111¶¶¶1_____\n________1¶¶111111¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1111111¶¶1_______\n__________¶¶1111111111¶¶¶¶1111111111111¶1_________\n__________¶¶¶11111111¶¶11¶¶11111111111¶¶¶_________\n________1¶¶11¶1¶¶111111111¶111111¶¶¶¶¶11¶¶________\n_______1¶¶111111¶¶¶¶¶1¶1¶¶¶¶¶¶¶¶¶¶1111111¶¶_______\n_______¶¶¶11111111111111¶¶11¶1111111111111¶¶______\n______1¶1111¶11111111111¶¶11111111111111111¶1_____\n______¶¶111¶111111111111¶¶1111111111111¶111¶¶_____\n_____1¶111¶¶111111111111¶¶1111111111111¶1111¶1____\n_____¶¶¶¶¶¶¶111111111111¶¶1111111111111¶¶¶¶¶¶¶____\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\n____1¶¶¶¶¶¶1111111111111¶¶11111111111111¶¶¶¶¶¶1___\n______1111¶1111111111111¶¶11111111111111¶1111_____\n__________¶¶¶11111111111¶¶111111111111¶¶¶_________\n__________¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶_________\n________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_______\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// based & influenced by this https://github.com/KessonDalef/Shaders/blob/master/Vertex/spherepointcloud.vert\n\n/*{\n \"pixelRatio\": 1,\n \"vertexCount\": 80000,\n \"vertexMode\": \"POINTS\",\n}*/\n\n#define DOTS_PER 80000.\n#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nprecision mediump float;\n/*\nattribute float vertexId;\nuniform float vertexCount;\nuniform float time;\nuniform vec2 resolution;\nvarying vec4 v_color;\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// 2D Random\nfloat random (in vec2 st) {\n return fract(sin(dot(st.xy,\n vec2(12.9898,78.233)))\n * 43758.5453123);\n}\n\n// Based on Morgan McGuire @morgan3d\n// https://www.shadertoy.com/view/4dS3Wd\nfloat noise (in vec2 st) {\n vec2 i = floor(st);\n vec2 f = fract(st);\n\n // Four corners in 2D of a tile\n float a = random(i);\n float b = random(i + vec2(1.0, 0.0));\n float c = random(i + vec2(0.0, 1.0));\n float d = random(i + vec2(1.0, 1.0));\n\n // Cubic Hermine Curve. Same as SmoothStep()\n vec2 u = f*f*(3.-2.0*f);\n u = smoothstep(0.,1.,f);\n\n // Mix 4 coorners percentages\n return mix(a, b, u.x) +\n (c - a)* u.y * (1.0 - u.x) +\n (d - b) * u.x * u.y;\n}\n\nmat4 rotateX(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateY(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateZ(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nfloat easeInOutSine(float x) \n{\n return -(cos(PI * x) - 1.) * 0.5;\n}\n\nvec4 Slerp(vec4 p0, vec4 p1, float t)\n{\n float dotp = dot(normalize(p0), normalize(p1));\n if ((dotp > 0.9999) || (dotp<-0.9999))\n {\n if (t<=0.5)\n return p0;\n return p1;\n }\n float theta = acos(dotp * PI/180.0);\n vec4 P = (\n (\n p0*sin((1.-t)*theta) + p1*sin(t*theta)\n ) / sin(theta)\n );\n P.w = 1.;\n return P;\n}\n\nvec3 posf2(float t, float i, float snd) \n{\n\treturn vec3(\n cos(t*.4+i*1.53) +\n sin(t*4.84+i*.6)\n //noise(vec2(t*.5*snd, i))\n ,\n cos(t*1.4+i*1.353-2.1) +\n sin(t*4.84+i*.476-2.1) \n //noise(vec2(t, i))\n ,\n sin(t*1.84+i*.36+2.1)// +\n\t)*.1;\n}\n\nvec3 posf0(float t, float fsndweight, float snd) {\n //return posf2(t,-1.)*0.9;\n return posf2(t,-1.,snd)*fsndweight;\n}\n\nvec3 posf(float t, float i, float fsndweight, float snd) \n{\n //float fsndweightf = mix(4.4, 4.49, pow(fsndweight, 2.0));\n return posf2(t*.045,i,snd) + posf0(t,fsndweight,snd);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd, float lenghtweight, float snd) {\n //vec3 pos = posf(t,i,.49)+ofs;\n vec3 pos = posf(t,i, mix(.45, 4.5, pow(snd, 1.0)), snd) + ofs;\n\n vec3 posf = fract(pos+.5)-.5;\n\n float l = length(posf)*lenghtweight; //1.5\n //return (- posf + posf/l)*(1.-smoothstep(lerpEnd,3.,l));\n //return (posf/l)*(1.-smoothstep(lerpEnd,2.9,l));\n return (posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n// YUV to RGB matrix\nmat3 yuv2rgb = mat3(1.0, 0.0, 1.13983,\n 1.0, -0.39465, -0.58060,\n 1.0, 2.03211, 0.0);\n\n// RGB to YUV matrix\nmat3 rgb2yuv = mat3(0.2126, 0.7152, 0.0722,\n -0.09991, -0.33609, 0.43600,\n 0.615, -0.5586, -0.05639);\n\n#define OCTAVES 12\nfloat fbm (in vec2 st) {\n // Initial values\n float value = 0.0;\n float amplitude = .5;\n float frequency = 0.;\n //\n // Loop of octaves\n for (int i = 0; i < OCTAVES; i++) {\n value += amplitude * noise(st);\n st *= 2.;\n amplitude *= .5;\n }\n return value;\n}\n\nfloat fbm2 ( in vec2 _st) {\n float v = 0.0;\n float a = 0.5;\n vec2 shift = vec2(100.0);\n // Rotate to reduce axial bias\n mat2 rot = mat2(cos(0.5), sin(0.5),\n -sin(0.5), cos(0.50));\n for (int i = 0; i < OCTAVES; ++i) {\n v += a * noise(_st);\n _st = rot * _st * 2.0 + shift;\n a *= 0.5;\n }\n return v;\n}\n\nvoid main(void)\n{\n\n float t = time*.6;\n float i = vertexId+sin(vertexId)*100.;\n \n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n \n float snd = texture2D(sound, vec2(thingV * 0.5 + 0.01, mod(thingV * 4., 4.) * 6. / 24.)).a*mix(.5, .9, .8);\n \n vec3 pos = posf(t,i, mix(1.45, 4.5, pow(snd, 1.)), snd);\n \n vec3 ofs = vec3(0);\n \n for (float f = -10.; f < 0.; f++) {\n\t //ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\n ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(2.45, 1.5, pow(snd, 1.)),snd);\n }\n ofs += push(t,i,ofs,.999,mix(2.45, 1.5, pow(snd, 2.)),snd);\n\n //pos -= posf0(t);\n pos -= posf0(t,.49, snd);\n\n pos += ofs;\n\n \n //vec4 sphericalInt = Slerp(vec4(pos, 1.), vec4(vec3(ofs), 1.), time*pow(snd, 2.));\n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n //sphericalInt.yz *= mat2(.8,.6,-.6,.8);\n //sphericalInt.xz *= mat2(.8,.6,-.6,.8);\n\n pos.x *= resolution.y/resolution.x;\n pos.z *= resolution.y/resolution.x;\n\n mat4 rotation = rotateY(time*0.15);\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\n\n pos.z += .9;\n\n //rot *= .95;\n rot *= .5;\n\n gl_Position = vec4(rot.xyz, 0.55);\n gl_PointSize = .3;\n\n float hue = 1.6 + v;// + v * time * 0.;\n hue = mix(hue, 50., mod(floor(t * 4.0), 1.4));\n hue = mix(hue, 0.5, step(0.95, snd*0.95));\n \n float clipZ = m1p1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n float val = invClipZ * 150.;\n \n \n \n \n //v_color = vec4(hsv2rgb(vec3(hue*2., hue*22., val)),mix(1., 2.5, pow(snd, 4.)));\n v_color = vec4(yuv2rgb * vec3(0.5, pos.x, pos.y),mix(1., 2.5, pow(snd, 4.)));\n v_color = vec4(\n v_color.rbg * v_color.g, \n v_color.a\n );\n v_color += fbm(pos.xy*50.0);\n \n //v_color += vec4(.7, 0.6, 1.0, 0.6);\n}\n" + }, "screenshotURL": "data/images/images-05fgsemszbjctt71m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Dj9AtcEn2SdwdS3Y2/art.json b/art/Dj9AtcEn2SdwdS3Y2/art.json index d59aa711..b820dc80 100644 --- a/art/Dj9AtcEn2SdwdS3Y2/art.json +++ b/art/Dj9AtcEn2SdwdS3Y2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":189,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Seulbin Seo\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4 (1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 189, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Making A Grid\n// CS250 Spring 2022\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4 (1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-u4f6bryeahsjxmulb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DjWJQf8DFiu4EnvvZ/art.json b/art/DjWJQf8DFiu4EnvvZ/art.json index 2f2ccd3d..f4a34e9f 100644 --- a/art/DjWJQf8DFiu4EnvvZ/art.json +++ b/art/DjWJQf8DFiu4EnvvZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec2 createCircle(float id){\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n //float vy = mod(floor(id / 2.0) + floor (id /3.0), 2.0);\\n float vy = floor(id) + mod(id, 3.0); \\n \\n float angle = ux /2.0;\\n float radius = vy;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n return vec2(x,y);\\n}\\n\\nvoid main() \\n{ \\n \\n vec2 xy = createCircle(vertexId)*0.01;\\n \\n gl_Position= vec4(xy , 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec2 createCircle(float id){\n float ux = floor(id / 6.0) + mod(id, 2.0);\n //float vy = mod(floor(id / 2.0) + floor (id /3.0), 2.0);\n float vy = floor(id) + mod(id, 3.0); \n \n float angle = ux /2.0;\n float radius = vy;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n return vec2(x,y);\n}\n\nvoid main() \n{ \n \n vec2 xy = createCircle(vertexId)*0.01;\n \n gl_Position= vec4(xy , 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-swiaspyv4bv1iude0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DkQkxp558QrXdoDTs/art.json b/art/DkQkxp558QrXdoDTs/art.json index ca5322db..3006e4dc 100644 --- a/art/DkQkxp558QrXdoDTs/art.json +++ b/art/DkQkxp558QrXdoDTs/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "in(trouble)", "username": "calderonsteven", - "settings": "{\"num\":6895,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/modularpeople/youth-in-trouble?in=the-presets/sets/youth-in-trouble\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 3.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 4.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 1.1;\\n float innerRadius = count * 0.003;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 6895, + "mode": "LINES", + "sound": "https://soundcloud.com/modularpeople/youth-in-trouble?in=the-presets/sets/youth-in-trouble", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 3.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 4.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 1.1;\n float innerRadius = count * 0.003;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "afczA2gKZEZw6u6GL", "views": { "$numberInt": "3019" diff --git a/art/DoEj3wxxxKrDkxKrZ/art.json b/art/DoEj3wxxxKrDkxKrZ/art.json index 0a7d4d2c..323e3aca 100644 --- a/art/DoEj3wxxxKrDkxKrZ/art.json +++ b/art/DoEj3wxxxKrDkxKrZ/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n float vertNorm = vertexId / vertexCount;\\n\\n float theta = vertNorm * 6.28;\\n float amplitude = max(mouse.x, 0.25);\\n float posX = cos(theta) * amplitude;\\n float posY = sin(theta) * amplitude;\\n \\n gl_Position = vec4(posX, posY, 0.0, 1.0);\\n gl_PointSize = 5.0;\\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n float vertNorm = vertexId / vertexCount;\n\n float theta = vertNorm * 6.28;\n float amplitude = max(mouse.x, 0.25);\n float posX = cos(theta) * amplitude;\n float posY = sin(theta) * amplitude;\n \n gl_Position = vec4(posX, posY, 0.0, 1.0);\n gl_PointSize = 5.0;\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-hpkdxil7xdl4zbeah-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DpHdSTbEXuhA4ZhTJ/art.json b/art/DpHdSTbEXuhA4ZhTJ/art.json index ffd92a3a..1a850bf6 100644 --- a/art/DpHdSTbEXuhA4ZhTJ/art.json +++ b/art/DpHdSTbEXuhA4ZhTJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "shinyisshiny", "avatarUrl": "https://secure.gravatar.com/avatar/382822a2fd34cc1eedf9317c4c63083d?default=retro&size=200", - "settings": "{\"num\":2766,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mood-hut/mh023-pender-street-steppers-our-time?in=pender-street-steppers/sets/music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.050980392156862744,0.32941176470588235,1],\"shader\":\"#define positionX 3.//KParameter 0.>>10.\\n#define positionY 1.//KParameter 0.>>1.\\n#define colorR 1.//KParameter 0.>>1.\\n#define colorG 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>8.\\n#define rotationFactorY 1.//KParameter 0.>>8.\\n#define rotationFactorZ 1.//KParameter 0.>>8.\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.9;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float snd = texture2D(sound, vec2(u, v * 0.)).a;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.6) * 15.;\\n \\n \\n \\n gl_PointSize = snd * 100.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n \\n v_color = vec4(1, v, 1, 1);\\n \\n \\n \\n}\\n \\n \"}", + "settings": { + "num": 2766, + "mode": "POINTS", + "sound": "https://soundcloud.com/mood-hut/mh023-pender-street-steppers-our-time?in=pender-street-steppers/sets/music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.050980392156862744, + 0.32941176470588235, + 1 + ], + "shader": "#define positionX 3.//KParameter 0.>>10.\n#define positionY 1.//KParameter 0.>>1.\n#define colorR 1.//KParameter 0.>>1.\n#define colorG 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>8.\n#define rotationFactorY 1.//KParameter 0.>>8.\n#define rotationFactorZ 1.//KParameter 0.>>8.\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.9;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float snd = texture2D(sound, vec2(u, v * 0.)).a;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n float soff = sin(time + x * y * 0.6) * 15.;\n \n \n \n gl_PointSize = snd * 100.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n \n v_color = vec4(1, v, 1, 1);\n \n \n \n}\n \n " + }, "screenshotURL": "data/images/images-m4zpxq51j21kdup52-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DsvE4S4dECyiP9akX/art.json b/art/DsvE4S4dECyiP9akX/art.json index ccdbacec..e0ba58e6 100644 --- a/art/DsvE4S4dECyiP9akX/art.json +++ b/art/DsvE4S4dECyiP9akX/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":18432,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/geotheorymusic/work-it-girl\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9921568627450981,0.984313725490196,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 2.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 1,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = mix(inner, 1., level);\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.5;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += 10.;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n mat *= scale(vec3(0.25, 0.25, -20.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(.65, 1., step(0.75, snd));\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n v_color.a = 1.0 - uvf.y;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 18432, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/geotheorymusic/work-it-girl", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9921568627450981, + 0.984313725490196, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 2.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 1,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = mix(inner, 1., level);\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.5;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += 10.;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n mat *= scale(vec3(0.25, 0.25, -20.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = mix(.65, 1., step(0.75, snd));\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n v_color.a = 1.0 - uvf.y;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-eob5epmw8n5hpi7dm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DtkxEHAy7rFi4TCjx/art.json b/art/DtkxEHAy7rFi4TCjx/art.json index 1bba4e6e..6191d921 100644 --- a/art/DtkxEHAy7rFi4TCjx/art.json +++ b/art/DtkxEHAy7rFi4TCjx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user6017377/6n5vosmj8t2h?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\nmat4 rotZ(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n return mat4(\\n c,-s,0,0,\\n s,c,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\n\\nmat4 trans(vec3 trans){\\n return mat4(\\n \\t1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n trans,1);\\n}\\nmat4 ident(){\\n return mat4(\\n \\t1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n \\ts[0],0,0,0,\\n 0,s[1],0,0,\\n 0,0,s[2],0,\\n 0,0,0,1);\\n}\\nmat4 uniformScale(float s){\\n return mat4(\\n \\ts,0,0,0,\\n 0,s,0,0,\\n 0,0,s,0,\\n 0,0,0,1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n float ux = floor(id / 6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id / 3.),2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy +1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\n return vec2(x,y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId/ numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/ 6.0);\\n float oddSlice = mod(sliceId,2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au* .05, av * .25)).a;\\n\\n \\n float sc = pow(snd+0.2,5.) * mix(1., 1.1, oddSlice);\\n float aspect = resolution.x / resolution.y;\\n \\n sc *= 20. / across;\\n \\n \\n vec4 pos = vec4(circleXY , 0 ,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.05 * sc );\\n \\n \\n gl_Position = mat * pos;\\n \\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n\\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice *0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user6017377/6n5vosmj8t2h?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\nmat4 rotZ(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n return mat4(\n c,-s,0,0,\n s,c,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\n\nmat4 trans(vec3 trans){\n return mat4(\n \t1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n trans,1);\n}\nmat4 ident(){\n return mat4(\n \t1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\nmat4 scale(vec3 s)\n{\n return mat4(\n \ts[0],0,0,0,\n 0,s[1],0,0,\n 0,0,s[2],0,\n 0,0,0,1);\n}\nmat4 uniformScale(float s){\n return mat4(\n \ts,0,0,0,\n 0,s,0,0,\n 0,0,s,0,\n 0,0,0,1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n float ux = floor(id / 6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id / 3.),2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy +1.;\n \n float x = c * radius;\n float y = s * radius;\n\n return vec2(x,y);\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId/ numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId/ 6.0);\n float oddSlice = mod(sliceId,2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au* .05, av * .25)).a;\n\n \n float sc = pow(snd+0.2,5.) * mix(1., 1.1, oddSlice);\n float aspect = resolution.x / resolution.y;\n \n sc *= 20. / across;\n \n \n vec4 pos = vec4(circleXY , 0 ,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.05 * sc );\n \n \n gl_Position = mat * pos;\n \n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n\n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice *0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ntq3pca9pmoetxeer-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DvSoWkCTBkqg9aKyY/art.json b/art/DvSoWkCTBkqg9aKyY/art.json index 2824b980..3516bc70 100644 --- a/art/DvSoWkCTBkqg9aKyY/art.json +++ b/art/DvSoWkCTBkqg9aKyY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 1.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /72. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 1.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /72. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-6z6wd9iqln6frc18u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DwqqEvCDpZA7dj9qu/art.json b/art/DwqqEvCDpZA7dj9qu/art.json index ca81a961..5bc09016 100644 --- a/art/DwqqEvCDpZA7dj9qu/art.json +++ b/art/DwqqEvCDpZA7dj9qu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"\\n// I get error when I type g1_Positon !!!\\n// so use this instead\\n\\n\\nvoid main(){\\n \\n gl_Position = vec4(0, 0, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "\n// I get error when I type g1_Positon !!!\n// so use this instead\n\n\nvoid main(){\n \n gl_Position = vec4(0, 0, 0, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1, 0, 0, 1);\n \n \n}" + }, "screenshotURL": "data/images/images-pxrgz5helblb25sff-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/DySYKJCWwydRwAsMo/art.json b/art/DySYKJCWwydRwAsMo/art.json index b5cb35ff..280a4b02 100644 --- a/art/DySYKJCWwydRwAsMo/art.json +++ b/art/DySYKJCWwydRwAsMo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":79062,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1843137254901961,0.32941176470588235,0.1803921568627451,1],\"shader\":\"\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 2.//KParameter2 -1.>>5.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time* 0.6 );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2/2.),\\n s, 0, 0-2, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, -2, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, -0.1, 0.5, 0.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, s, s-mouse.x, 1.31,\\n s-0.5, 0.3, s, 0,\\n 2, 0.5, 0, 0.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 13.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\\n float end = start + 5.;\\nstart + hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 79062, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1843137254901961, + 0.32941176470588235, + 0.1803921568627451, + 1 + ], + "shader": "\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 2.//KParameter2 -1.>>5.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time* 0.6 );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2/2.),\n s, 0, 0-2, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, -2, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, -0.1, 0.5, 0.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, s, s-mouse.x, 1.31,\n s-0.5, 0.3, s, 0,\n 2, 0.5, 0, 0.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 13.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\n float end = start + 5.;\nstart + hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-sjgkeudy3f8g13p29-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DypzytbA2gKkPjKXM/art.json b/art/DypzytbA2gKkPjKXM/art.json index e3f8cbd8..f52d51e1 100644 --- a/art/DypzytbA2gKkPjKXM/art.json +++ b/art/DypzytbA2gKkPjKXM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":13288,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.26666666666666666,0.4117647058823529,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 100.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId / 64. + (time * 20.));\\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.125, sy)).a, 2.) * 2.) * (1. - sy);\\n \\n float x = sin(deg) * radius;\\n float y = cos(deg) * radius;\\n float z = vertexId * 0.03125;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0.1, 0.1,\\n 0, 0, 0, 1);\\n \\n gl_Position = camera * vec4(pos.xyz, 1);\\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 13288, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.26666666666666666, + 0.4117647058823529, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nvoid main()\n{\n \n float pointsPerLoop = 100.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId / 64. + (time * 20.));\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.125, sy)).a, 2.) * 2.) * (1. - sy);\n \n float x = sin(deg) * radius;\n float y = cos(deg) * radius;\n float z = vertexId * 0.03125;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0.1, 0.1,\n 0, 0, 0, 1);\n \n gl_Position = camera * vec4(pos.xyz, 1);\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-9vwqtzvle25wgvwov-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DyvcR8jSTEBXSm6J7/art.json b/art/DyvcR8jSTEBXSm6J7/art.json index 73827bd0..a60a31fe 100644 --- a/art/DyvcR8jSTEBXSm6J7/art.json +++ b/art/DyvcR8jSTEBXSm6J7/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":3276,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = sin(time)*0.9;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*2.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.23 * cgv + snd * .25);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n gl_Position = mat * vec4(pos, 0.5);\\n gl_PointSize = 3.;\\n \\n float pump = step(0.5, snd);\\n float hue = 1. + cgId * 1. + pump * .17;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 3276, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = sin(time)*0.9;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*2.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.23 * cgv + snd * .25);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n gl_Position = mat * vec4(pos, 0.5);\n gl_PointSize = 3.;\n \n float pump = step(0.5, snd);\n float hue = 1. + cgId * 1. + pump * .17;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-dlp6o7b9nvq90f4me-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/DznDc4cHyA4yEMyz8/art.json b/art/DznDc4cHyA4yEMyz8/art.json index 979f80e3..64395a12 100644 --- a/art/DznDc4cHyA4yEMyz8/art.json +++ b/art/DznDc4cHyA4yEMyz8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=65536\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float lineId = 0.;//mod(shapeId, 3.0);\\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 10.;\\n float line = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float relXid = xPos/2.;\\n xPos =xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * min(line/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n \\n line/=numberOfElement;\\n\\n \\n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n \\n cubep = vec3(cubep.x, cubep.y+snd, cubep.z);\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);\\n \\n\\n //cubep .x*=aspect;\\n cubep.x+=xPos;\\n cubep.z+=line;\\n \\n vec3 eye = vec3(eyeX, eyeY, -.1);\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 1.), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=65536\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float lineId = 0.;//mod(shapeId, 3.0);\n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 10.;\n float line = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float relXid = xPos/2.;\n xPos =xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * min(line/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n \n line/=numberOfElement;\n\n \n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n \n cubep = vec3(cubep.x, cubep.y+snd, cubep.z);\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);\n \n\n //cubep .x*=aspect;\n cubep.x+=xPos;\n cubep.z+=line;\n \n vec3 eye = vec3(eyeX, eyeY, -.1);\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 1.), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-gotmcbkiblgp509sc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Dzq7Xbo9hsf8fwr58/art.json b/art/Dzq7Xbo9hsf8fwr58/art.json index e5fd19a1..1bc702bd 100644 --- a/art/Dzq7Xbo9hsf8fwr58/art.json +++ b/art/Dzq7Xbo9hsf8fwr58/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":40100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\n float x = vertexId/130. + sin(time/41.) ;\\n float y = sin(time/17. + tan(vertexId));\\n \\n gl_Position = vec4(x-2.-sin(time/20.), -y*(cos(x+vertexId)+0.5), 0., 1.);\\n \\n\\n gl_PointSize = 10. + (sin(time/12.+vertexId*5.)/2.+.5)*9.;\\n \\n v_color = vec4(sin(x)/2., y/2.+.2, cos(time/7.)/2.+.8, 1.);\\n}\"}", + "settings": { + "num": 40100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\n float x = vertexId/130. + sin(time/41.) ;\n float y = sin(time/17. + tan(vertexId));\n \n gl_Position = vec4(x-2.-sin(time/20.), -y*(cos(x+vertexId)+0.5), 0., 1.);\n \n\n gl_PointSize = 10. + (sin(time/12.+vertexId*5.)/2.+.5)*9.;\n \n v_color = vec4(sin(x)/2., y/2.+.2, cos(time/7.)/2.+.8, 1.);\n}" + }, "screenshotURL": "data/images/images-7socx0oolkcr8aupv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/E35W32ThAopNcnH4G/art.json b/art/E35W32ThAopNcnH4G/art.json index 6edf6de9..72bbb358 100644 --- a/art/E35W32ThAopNcnH4G/art.json +++ b/art/E35W32ThAopNcnH4G/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "luis", "avatarUrl": "https://graph.facebook.com/10208687216256743/picture?type=large", - "settings": "{\"num\":69773,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\n\\n\\nvoid main() {\\n \\n \\n float angle = radians(mod(vertexId,180.0));\\n float fi = radians(floor(vertexId / 180.0));\\n \\n float radius = 1.0;\\n \\n float x = radius * sin(angle) * cos(fi);\\n float y = radius * sin(angle) * sin(fi);\\n float z = radius * cos(angle);\\n \\n mat4 rotX = mat4(1.0);\\n rotX[1][1] = cos(time);\\n rotX[2][1] = -sin(time);\\n rotX[1][2] = sin(time);\\n rotX[2][2] = cos(time);\\n \\n \\n vec3 xy = vec3(x, y,z);\\n \\n gl_Position = rotX * vec4(xy * 0.5, 1.0);\\n gl_PointSize = 1.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 69773, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\n\n\nvoid main() {\n \n \n float angle = radians(mod(vertexId,180.0));\n float fi = radians(floor(vertexId / 180.0));\n \n float radius = 1.0;\n \n float x = radius * sin(angle) * cos(fi);\n float y = radius * sin(angle) * sin(fi);\n float z = radius * cos(angle);\n \n mat4 rotX = mat4(1.0);\n rotX[1][1] = cos(time);\n rotX[2][1] = -sin(time);\n rotX[1][2] = sin(time);\n rotX[2][2] = cos(time);\n \n \n vec3 xy = vec3(x, y,z);\n \n gl_Position = rotX * vec4(xy * 0.5, 1.0);\n gl_PointSize = 1.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-qhu7ykrr4kopcmm9j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/E3bguY87geHgSFKBW/art.json b/art/E3bguY87geHgSFKBW/art.json index 8b3b60bf..8e950b31 100644 --- a/art/E3bguY87geHgSFKBW/art.json +++ b/art/E3bguY87geHgSFKBW/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5112,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(0, b, b, 1);\\n}\"}", + "settings": { + "num": 5112, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(0, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-bmgzkc98864899v9k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/E77bqBL3BGzWQsqBw/art.json b/art/E77bqBL3BGzWQsqBw/art.json index bd48f89d..e30f0122 100644 --- a/art/E77bqBL3BGzWQsqBw/art.json +++ b/art/E77bqBL3BGzWQsqBw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":454,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4 (1, 0, 0, 1);\\n \\n}\\n\"}", + "settings": { + "num": 454, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4 (1, 0, 0, 1);\n \n}\n" + }, "screenshotURL": "data/images/images-hqkd8x1d69ojbl5qp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/E7ACzG2zArFipenu9/art.json b/art/E7ACzG2zArFipenu9/art.json index 6955d33e..fa2f9621 100644 --- a/art/E7ACzG2zArFipenu9/art.json +++ b/art/E7ACzG2zArFipenu9/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":3600,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nmat4 scaleXYZ(float _x, float _y, float _z)\\n{\\n return mat4(_x, 0, 0, 0,\\n 0, _y, 0, 0,\\n 0, 0, _z, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n 1., 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, 1., 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n/*\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n sin(id * 0.5+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}\\n*/\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n 0.,\\n cos(2.*PI*id),\\n sin(2.*PI*id)\\n );\\n}\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./50.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n cubep*= sizeFactor;\\n \\n \\n \\n \\n float off = 0.14;\\n float expand = 1.;\\n float curveFactor = time/20.;\\n vec3 r0 = getCurvePoint(shapeRelId + off * 0., curveFactor);\\n vec3 r1 = getCurvePoint(shapeRelId + off * 1., curveFactor);\\n vec3 r2 = getCurvePoint(shapeRelId + off * 2., curveFactor);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n cubep = (vec4(cubep,1.)*scaleXYZ(1., 10., 1.)).xyz;\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n vec3 zax = vec3(0., 0., 1.);\\n \\n float dotz = dot(zax,zaxis);\\n float angle = acos(dot(zax,zaxis));\\n //cubep = rotX(cubep.xyz, acos(dot(vec3(1., 0., 0.),xaxis)));\\n //cubep = rotY(cubep.xyz, acos(dot(vec3(0., 1., 0.),yaxis)));\\n cubep = rotZ(cubep.xyz, time+acos(dot(zaxis, vec3(0., 0., 1.))));\\n \\n //cubep*= sizeFactor;//resize\\n //cubep.xyz*= (wmat*vec4(cubep,1.)).xyz;\\n \\n\\n //cubep+=r0;\\n cubep+= getCurvePoint(shapeRelId, curveFactor) ;\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n //vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(2., 1., 2.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n float aspect = resolution.y / resolution.x;\\n \\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n //gl_Position.x*=aspect;\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 3600, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nmat4 scaleXYZ(float _x, float _y, float _z)\n{\n return mat4(_x, 0, 0, 0,\n 0, _y, 0, 0,\n 0, 0, _z, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n 1., 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, 1., 0,\n 0, 0, 0, 1);\n}\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n/*\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n sin(id * 0.5+_time*10.),\n sin(id * 0.25+_time*10.));\n}\n*/\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n 0.,\n cos(2.*PI*id),\n sin(2.*PI*id)\n );\n}\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./50.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n cubep*= sizeFactor;\n \n \n \n \n float off = 0.14;\n float expand = 1.;\n float curveFactor = time/20.;\n vec3 r0 = getCurvePoint(shapeRelId + off * 0., curveFactor);\n vec3 r1 = getCurvePoint(shapeRelId + off * 1., curveFactor);\n vec3 r2 = getCurvePoint(shapeRelId + off * 2., curveFactor);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n cubep = (vec4(cubep,1.)*scaleXYZ(1., 10., 1.)).xyz;\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n vec3 zax = vec3(0., 0., 1.);\n \n float dotz = dot(zax,zaxis);\n float angle = acos(dot(zax,zaxis));\n //cubep = rotX(cubep.xyz, acos(dot(vec3(1., 0., 0.),xaxis)));\n //cubep = rotY(cubep.xyz, acos(dot(vec3(0., 1., 0.),yaxis)));\n cubep = rotZ(cubep.xyz, time+acos(dot(zaxis, vec3(0., 0., 1.))));\n \n //cubep*= sizeFactor;//resize\n //cubep.xyz*= (wmat*vec4(cubep,1.)).xyz;\n \n\n //cubep+=r0;\n cubep+= getCurvePoint(shapeRelId, curveFactor) ;\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n //vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(2., 1., 2.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n float aspect = resolution.y / resolution.x;\n \n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n //gl_Position.x*=aspect;\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-rjfvhepw19lddi50p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/E8jpSws9ybhazxoiu/art.json b/art/E8jpSws9ybhazxoiu/art.json index 67585f0b..eb74fdf5 100644 --- a/art/E8jpSws9ybhazxoiu/art.json +++ b/art/E8jpSws9ybhazxoiu/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":1032,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Audio Reactive\\n// CS250 Spring 2022\\n\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float PI = 3.14159265358979;\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = 0.0;\\n float yOffset = 0.0;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float sizeOffset = 0.0;\\n \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;\\n float saturation = mix(0.0, 1.0, pump);\\n float value = mix(0.1, pow(snd + 0.2, 5.0), pump);\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 1032, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Audio Reactive\n// CS250 Spring 2022\n\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float PI = 3.14159265358979;\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = 0.0;\n float yOffset = 0.0;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float sizeOffset = 0.0;\n \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * 0.1 + snd * 0.2 + time * 0.1;\n float saturation = mix(0.0, 1.0, pump);\n float value = mix(0.1, pow(snd + 0.2, 5.0), pump);\n \n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-7lf4gzqejwh67pdip-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/E9ATxH3KR6gczc39H/art.json b/art/E9ATxH3KR6gczc39H/art.json index c7bc669c..b9a8878d 100644 --- a/art/E9ATxH3KR6gczc39H/art.json +++ b/art/E9ATxH3KR6gczc39H/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09019607843137255,0.08235294117647059,0.09019607843137255,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle + 3. );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 2.); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], -0.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n\\n -0.1 -s, 0, 0, 0.1,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 2) /2.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. + 0.1;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.07;\\n pos = vec3(x, y +1., z +2. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(.1, mod(circleId*2., 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles -parameter4;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n\\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.0203) * 1.4;\\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 * 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\\n float sat = 0.9 - circleId;\\n float val = .75;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9 /parameter6, 0.2));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09019607843137255, + 0.08235294117647059, + 0.09019607843137255, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle + 3. );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 2.); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], -0.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n\n -0.1 -s, 0, 0, 0.1,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 2) /2.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. + 0.1;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.07;\n pos = vec3(x, y +1., z +2. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(.1, mod(circleId*2., 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles -parameter4;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.0203) * 1.4;\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 * 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\n float sat = 0.9 - circleId;\n float val = .75;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9 /parameter6, 0.2));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-dhmuq374ibp21q4vk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ECyeESjJEpGZwP69a/art.json b/art/ECyeESjJEpGZwP69a/art.json index e34add80..163171d7 100644 --- a/art/ECyeESjJEpGZwP69a/art.json +++ b/art/ECyeESjJEpGZwP69a/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":300,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/skrillex/skrillex-kyoto-feat-sirah\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float lr = mod(vertexId, 2.0);\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + lr;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = mix(\\n mix(0.01, 0.25, u),\\n mix(0.5, 0.21, u),\\n lr);\\n \\n // Match each line to a specific row in the sound texture\\n float historyV = 0.;(v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = lr * 2.0 - 1.0;\\n float y = snd * 2.0 - 1.0;\\n \\n \\n vec2 xy = vec2(x, y);\\n \\n mat4 mat = uniformScale(1.5); \\n mat *= rotZ(time * 100. + u * PI * 3.);\\n gl_Position = mat * vec4(xy, 0, 1);\\n\\n float hue = floor(vertexId / 3.) * .5;\\n float sat = invV;\\n float val = 1. - mod(floor(vertexId / 3.), 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 300, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/skrillex/skrillex-kyoto-feat-sirah", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float lr = mod(vertexId, 2.0);\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + lr;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = mix(\n mix(0.01, 0.25, u),\n mix(0.5, 0.21, u),\n lr);\n \n // Match each line to a specific row in the sound texture\n float historyV = 0.;(v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = lr * 2.0 - 1.0;\n float y = snd * 2.0 - 1.0;\n \n \n vec2 xy = vec2(x, y);\n \n mat4 mat = uniformScale(1.5); \n mat *= rotZ(time * 100. + u * PI * 3.);\n gl_Position = mat * vec4(xy, 0, 1);\n\n float hue = floor(vertexId / 3.) * .5;\n float sat = invV;\n float val = 1. - mod(floor(vertexId / 3.), 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-2arlfwexed7lt7a1k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EDJJ9esPSEo3LRLmb/art.json b/art/EDJJ9esPSEo3LRLmb/art.json index c6ca199b..7c85f134 100644 --- a/art/EDJJ9esPSEo3LRLmb/art.json +++ b/art/EDJJ9esPSEo3LRLmb/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":58181,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define point_id vertexId\\n#define point_count vertexCount\\n#define point_pct (point_id/point_count)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float PI = 3.14;\\n float x = 0.5*cos(time + point_pct * 2.0 * PI);\\n float y = 0.5*sin(time + point_pct * 2.0 * PI);\\n // x -> [-1, 1]\\n // y -> [-1, 1]\\n // z -> 0\\n // w -> [0, inf]\\n gl_Position = vec4(x, y, 0.0, 1.0 + 0.2*point_pct);\\n gl_PointSize = 20.0 * point_pct;\\n float hue = point_pct;\\n float sat = 1.0;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue + 1.0 * time, sat, val)), 1);\\n}\"}", + "settings": { + "num": 58181, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define point_id vertexId\n#define point_count vertexCount\n#define point_pct (point_id/point_count)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float PI = 3.14;\n float x = 0.5*cos(time + point_pct * 2.0 * PI);\n float y = 0.5*sin(time + point_pct * 2.0 * PI);\n // x -> [-1, 1]\n // y -> [-1, 1]\n // z -> 0\n // w -> [0, inf]\n gl_Position = vec4(x, y, 0.0, 1.0 + 0.2*point_pct);\n gl_PointSize = 20.0 * point_pct;\n float hue = point_pct;\n float sat = 1.0;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue + 1.0 * time, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-4xxetrzignsq6x1f1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EF4WxFMCR2GvFYvTB/art.json b/art/EF4WxFMCR2GvFYvTB/art.json index c6b157d2..31e67d8b 100644 --- a/art/EF4WxFMCR2GvFYvTB/art.json +++ b/art/EF4WxFMCR2GvFYvTB/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mike-tobia", "avatarUrl": "https://avatars.githubusercontent.com/mike-tobia?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/louisfuton/venice\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float snd = texture2D(sound, vec2(u, 0.)).a;\\n \\n float xoff = sin(time + y * .2) * .1;\\n float yoff = sin(time + x * .3) * .1;\\n float zoff = sin(time + 1. * .3) * .1;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float scalar = 1.3;\\n float scale = scalar;\\n \\n vec2 xy = vec2(ux, vy) * scale;\\n float z = 1. * mod(scale * zoff, 1.);\\n \\n gl_Position = vec4(xy, z, 1.);\\n \\n float soff = sin(time + xy.x * xy.y * .002);\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n float hue = 1.29;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/louisfuton/venice", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float snd = texture2D(sound, vec2(u, 0.)).a;\n \n float xoff = sin(time + y * .2) * .1;\n float yoff = sin(time + x * .3) * .1;\n float zoff = sin(time + 1. * .3) * .1;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float scalar = 1.3;\n float scale = scalar;\n \n vec2 xy = vec2(ux, vy) * scale;\n float z = 1. * mod(scale * zoff, 1.);\n \n gl_Position = vec4(xy, z, 1.);\n \n float soff = sin(time + xy.x * xy.y * .002);\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n float hue = 1.29;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-uqri6hktwsn3cm8wu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EFCx8Coh8CuLXJXue/art.json b/art/EFCx8Coh8CuLXJXue/art.json index 6e3e8201..0de8f5ae 100644 --- a/art/EFCx8Coh8CuLXJXue/art.json +++ b/art/EFCx8Coh8CuLXJXue/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = vertexId * 0.1;\\n gl_Position = vec4(x, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 2, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = vertexId * 0.1;\n gl_Position = vec4(x, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-bhmn3ezu7leen1q2z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EFDPXE3qAdfaPgMT3/art.json b/art/EFDPXE3qAdfaPgMT3/art.json index 4e415689..1fa836ca 100644 --- a/art/EFDPXE3qAdfaPgMT3/art.json +++ b/art/EFDPXE3qAdfaPgMT3/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float PI = 6.28;\\n float p = vertexId / vertexCount;\\n float life = mod(time, p * 10.0);\\n float speed = mod(time, 2.0);\\n float vx = cos(PI * p) * speed * life * 0.1;\\n float vy = sin(PI * p) * speed * life * 0.1;\\n \\n gl_Position = vec4(vx, vy, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float PI = 6.28;\n float p = vertexId / vertexCount;\n float life = mod(time, p * 10.0);\n float speed = mod(time, 2.0);\n float vx = cos(PI * p) * speed * life * 0.1;\n float vy = sin(PI * p) * speed * life * 0.1;\n \n gl_Position = vec4(vx, vy, 0.0, 1.0);\n gl_PointSize = 10.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-axeehe66y6m2gt250-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EFczFa8BRmNtBibqB/art.json b/art/EFczFa8BRmNtBibqB/art.json index 038d78a3..206b50cf 100644 --- a/art/EFczFa8BRmNtBibqB/art.json +++ b/art/EFczFa8BRmNtBibqB/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = tan(time + y * 0.2) * 0.1;\\n float yoff = tan(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.5;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = tan(time + y * 0.2) * 0.1;\n float yoff = tan(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.5;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\n}" + }, "screenshotURL": "data/images/images-3favsxsmdoys1qa9k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EG3pbFeZPLiS72ia5/art.json b/art/EG3pbFeZPLiS72ia5/art.json index 862d5d7c..cbed005c 100644 --- a/art/EG3pbFeZPLiS72ia5/art.json +++ b/art/EG3pbFeZPLiS72ia5/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "wnstjr", "avatarUrl": "https://lh6.googleusercontent.com/-woU5-VARLRA/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcYXRdpCnpCitbsXa2kxR4Dtr7jrA/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\n\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float xoff = 0.0; \\n float yoff = 0.0; \\n \\n vec2 xy = vec2(xoff, yoff)*2.5;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n gl_PointSize *= 20.0 / across;\\n gl_PointSize=abs(sin(time)*(mouse.x))* 500.0;\\n \\n float red=cos(time*2.0);\\n float blue=sin(time*2.0);\\n float green=tan(time*2.0);\\n \\n v_color=vec4(red,green,blue,1.0);\\t\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\n\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float xoff = 0.0; \n float yoff = 0.0; \n \n vec2 xy = vec2(xoff, yoff)*2.5;\n \n gl_Position = vec4(xy, 0, 1);\n \n gl_PointSize *= 20.0 / across;\n gl_PointSize=abs(sin(time)*(mouse.x))* 500.0;\n \n float red=cos(time*2.0);\n float blue=sin(time*2.0);\n float green=tan(time*2.0);\n \n v_color=vec4(red,green,blue,1.0);\t\n}" + }, "screenshotURL": "data/images/images-3xasbhrlte8svoqv1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EGh5YgqAykhgd7zoM/art.json b/art/EGh5YgqAykhgd7zoM/art.json index 8e94e771..fb954eb4 100644 --- a/art/EGh5YgqAykhgd7zoM/art.json +++ b/art/EGh5YgqAykhgd7zoM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":37468,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0,0.5019607843137255,1],\"shader\":\"\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 0.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.4, tan(3.0 / 5.)));\\n vec4 K = vec4(1.0* parameter2, 2.0 / 3.0 / parameter1, 0.0 / 4.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * (parameter5 - 6.0) - K.www);\\n return c.z * mix(K.xxx, clamp(sin(p * c * .2 ) - K.xxx, 0.1, parameter7), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, parameter2, -1, 0,\\n parameter3, -c, 1.-s, .1,\\n 0, -s, c, 0,\\n 0, parameter4, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians * .2);\\n \\t\\n return mat4( \\n -c, 0, 1.03 - s, s * c,\\n 0.2, .1, 0, 0,\\n s, 0, -c, 0,\\n 0, 0, 1, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 1, \\n s, -1, 0, 1,\\n 0, s*parameter4, 1, 0,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 2, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 4., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a03 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a02 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.2,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 55.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / (2. *parameter3 )) + floor(id / 2. + parameter6), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * (2. * parameter2) + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a - v);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.45;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 8.\\n#define FACES_PER_CUBE 8.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.15;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nmat4 mixm(mat4 m1, mat4 m2, float m) {\\n return mat4(\\n mix(m1[0], m2[0], m),\\n mix(m1[1], m2[1], m),\\n mix(m1[2], m2[2], m),\\n mix(m1[3], m2[3], m));\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes) * 1.5);\\n float across = floor(numCubes / down);\\n float cv = cubeId / numCubes;\\n\\n float uu = mod(cubeId, across);\\n float vv = floor(cubeId / across);\\n vec2 uv = vec2(uu, vv) / vec2(across, down);\\n \\n// const int hist = 10;\\n// float s = 0.;\\n// for (int i = 0; i < hist; ++i) {\\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n// 1.;//float(hist - i);\\n// }\\n//// s /= float(hist * (hist - 1)) / 2.;\\n// s /= float(hist);\\n float s = texture2D(sound, vec2(mix(0.5, .5, hash(cubeId * .723)), 0.)).a;\\n \\n float tm = time * (1. / parameter4);\\n float rd = 2.;\\n mat4 pmat = persp(radians(110.0 * parameter4), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.5) * rd * 0.5, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up); \\n \\n mat4 mat = rotY(time * .1);\\n mat *= lookAt(\\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 1.8327)))) * \\n mix(20., 24.1, s),\\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 20. * s,\\n vec3(0, 1, 0));\\n \\n mat4 mvmat = vmat * mat;\\n \\n vec3 npos = normalize(mvmat[3].xyz);\\n \\n float hue = mix(.0, time * 10., step(.8, s));\\n float sat = mix(-1.0, 2.2, s);\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n\\n \\n float areaS = 1. - (npos.z * .5 + .5);\\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.1));\\n smat *= uniformScale(0.5);\\n smat *= trans(vec3(0, 0, -1));\\n \\n \\n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1, 0.1, 1));\\n\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(0., 2., s);\\n}\\n\\n\"}", + "settings": { + "num": 37468, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0, + 0.5019607843137255, + 1 + ], + "shader": "\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 0.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.4, tan(3.0 / 5.)));\n vec4 K = vec4(1.0* parameter2, 2.0 / 3.0 / parameter1, 0.0 / 4.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * (parameter5 - 6.0) - K.www);\n return c.z * mix(K.xxx, clamp(sin(p * c * .2 ) - K.xxx, 0.1, parameter7), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, parameter2, -1, 0,\n parameter3, -c, 1.-s, .1,\n 0, -s, c, 0,\n 0, parameter4, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians * .2);\n \t\n return mat4( \n -c, 0, 1.03 - s, s * c,\n 0.2, .1, 0, 0,\n s, 0, -c, 0,\n 0, 0, 1, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 1, \n s, -1, 0, 1,\n 0, s*parameter4, 1, 0,\n 0, 0, 0, 0); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 2, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 4., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a03 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a02 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.2,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 55.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / (2. *parameter3 )) + floor(id / 2. + parameter6), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * (2. * parameter2) + PI * 0.0;\n float s = sin(a);\n float c = cos(a - v);\n float x = c * v;\n float y = s * v;\n float z = 0.45;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 8.\n#define FACES_PER_CUBE 8.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.15;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nmat4 mixm(mat4 m1, mat4 m2, float m) {\n return mat4(\n mix(m1[0], m2[0], m),\n mix(m1[1], m2[1], m),\n mix(m1[2], m2[2], m),\n mix(m1[3], m2[3], m));\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes) * 1.5);\n float across = floor(numCubes / down);\n float cv = cubeId / numCubes;\n\n float uu = mod(cubeId, across);\n float vv = floor(cubeId / across);\n vec2 uv = vec2(uu, vv) / vec2(across, down);\n \n// const int hist = 10;\n// float s = 0.;\n// for (int i = 0; i < hist; ++i) {\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n// 1.;//float(hist - i);\n// }\n//// s /= float(hist * (hist - 1)) / 2.;\n// s /= float(hist);\n float s = texture2D(sound, vec2(mix(0.5, .5, hash(cubeId * .723)), 0.)).a;\n \n float tm = time * (1. / parameter4);\n float rd = 2.;\n mat4 pmat = persp(radians(110.0 * parameter4), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.5) * rd * 0.5, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up); \n \n mat4 mat = rotY(time * .1);\n mat *= lookAt(\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 1.8327)))) * \n mix(20., 24.1, s),\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 20. * s,\n vec3(0, 1, 0));\n \n mat4 mvmat = vmat * mat;\n \n vec3 npos = normalize(mvmat[3].xyz);\n \n float hue = mix(.0, time * 10., step(.8, s));\n float sat = mix(-1.0, 2.2, s);\n float val = 1.;//mix(1., 1., step(0.8, s));\n\n \n float areaS = 1. - (npos.z * .5 + .5);\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.1));\n smat *= uniformScale(0.5);\n smat *= trans(vec3(0, 0, -1));\n \n \n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1, 0.1, 1));\n\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(0., 2., s);\n}\n\n" + }, "screenshotURL": "data/images/images-evmsd8oskva0g4r0b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EJEPgF3KWdF9Bysia/art.json b/art/EJEPgF3KWdF9Bysia/art.json index 986f0838..1660082d 100644 --- a/art/EJEPgF3KWdF9Bysia/art.json +++ b/art/EJEPgF3KWdF9Bysia/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "bluesky", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14Ghql9JmmmeDe6q40nZwbsU6b-3RZSzJcvM_CVL4ww=s96-c", - "settings": "{\"num\":4617,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.12941176470588237,0.1411764705882353,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co, vec2(12.9898, 78.233))) * 43758.5453);\\n}\\n\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.0625 + (time * 20.));\\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.125, sy)).a, 2.) * 2.) * (1. - sy);\\n \\n radius *= rand(vec2(sx, sy)) * cos(time* sy);\\n \\n float x = cos(deg) * radius;\\n float y = sin(deg) * radius;\\n float z = vertexId * 0.01;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0., 0.1,\\n 0, 0, 0, 1);\\n \\n gl_Position = camera * vec4(pos.xyz, 1);\\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 4617, + "mode": "POINTS", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.12941176470588237, + 0.1411764705882353, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nfloat rand(vec2 co){\n return fract(sin(dot(co, vec2(12.9898, 78.233))) * 43758.5453);\n}\n\n\nvoid main()\n{\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.0625 + (time * 20.));\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.125, sy)).a, 2.) * 2.) * (1. - sy);\n \n radius *= rand(vec2(sx, sy)) * cos(time* sy);\n \n float x = cos(deg) * radius;\n float y = sin(deg) * radius;\n float z = vertexId * 0.01;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0., 0.1,\n 0, 0, 0, 1);\n \n gl_Position = camera * vec4(pos.xyz, 1);\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-zhy2vbwpc1xw72h0h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ENh2Lxp6QPPaotJzF/art.json b/art/ENh2Lxp6QPPaotJzF/art.json index 56dba728..c5e4cb87 100644 --- a/art/ENh2Lxp6QPPaotJzF/art.json +++ b/art/ENh2Lxp6QPPaotJzF/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":7258,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvoid main() {\\n\\n gl_PointSize = 15.0; \\n //gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n gl_Position = vec4(cos(time), 0.5,0.5,1.0);\\n v_color = vec4(1,1,0.5,1);\\n}\"}", + "settings": { + "num": 7258, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvoid main() {\n\n gl_PointSize = 15.0; \n //gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n gl_Position = vec4(cos(time), 0.5,0.5,1.0);\n v_color = vec4(1,1,0.5,1);\n}" + }, "screenshotURL": "data/images/images-gw5e3w5q9qx17tmim-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EPyk9Ehrx6dGCJsDY/art.json b/art/EPyk9Ehrx6dGCJsDY/art.json index f2758909..1e7b9a72 100644 --- a/art/EPyk9Ehrx6dGCJsDY/art.json +++ b/art/EPyk9Ehrx6dGCJsDY/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/apollyonpsy/loose-connection-vs-apollyon\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st){\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n} \\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b, float fact) {\\n\\tfloat scale = 10.0*fact;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n///float pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n vec2 vertexResolution = vec2(0.);\\n \\n //first the number of elements in a line\\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n\\n //then the number of possible lines with the given vertexCount\\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0.1, udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 st = uv;\\n\\tst.x *= resolution.x / resolution.y;\\n\\n\\tvec2 pos = st.yx* vec2(10.0, 3.0);\\n\\t\\n\\tfloat pattern = pos.x;\\n\\t\\n float timeFact = 5.;\\n\\tpos += rotate2d((noise(pos + timeFact*time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - timeFact*time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(timeFact*time) * 0.2) * 2.0 - 1.0);\\n\\t\\n\\tpattern = lines(pos, 0.5, snd/3.);\\n\\t\\n\\t//gl_FragColor = vec4(vec3(pattern), 1.0);\\n \\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n //camera\\n float r = 2.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(vec3(pattern), 1.0);\\n \\n vec4 finalPos = vec4(ux, vy+snd/2.-0.2, 0., 1.);\\n \\n gl_Position = finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/apollyonpsy/loose-connection-vs-apollyon", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\n//functions for the shader\nfloat random(in vec2 st){\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n} \n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b, float fact) {\n\tfloat scale = 10.0*fact;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n///float pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n vec2 vertexResolution = vec2(0.);\n \n //first the number of elements in a line\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n\n //then the number of possible lines with the given vertexCount\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0.1, udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 st = uv;\n\tst.x *= resolution.x / resolution.y;\n\n\tvec2 pos = st.yx* vec2(10.0, 3.0);\n\t\n\tfloat pattern = pos.x;\n\t\n float timeFact = 5.;\n\tpos += rotate2d((noise(pos + timeFact*time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - timeFact*time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(timeFact*time) * 0.2) * 2.0 - 1.0);\n\t\n\tpattern = lines(pos, 0.5, snd/3.);\n\t\n\t//gl_FragColor = vec4(vec3(pattern), 1.0);\n \n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n //camera\n float r = 2.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(vec3(pattern), 1.0);\n \n vec4 finalPos = vec4(ux, vy+snd/2.-0.2, 0., 1.);\n \n gl_Position = finalPos;\n}" + }, "screenshotURL": "data/images/images-4r35x7ym0xeiljha0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EWTJuKrqGXLji3GwW/art.json b/art/EWTJuKrqGXLji3GwW/art.json index 8afacda1..b54d5191 100644 --- a/art/EWTJuKrqGXLji3GwW/art.json +++ b/art/EWTJuKrqGXLji3GwW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":91736,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.60), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 1.9-s, 0.2, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 1, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle *2.);\\n \\t\\n return mat4( \\n c,-s, 0, s, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, s*2.0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0.1, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 2, 0.1, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, mouse.x, 0, 0,\\n 0, s-2., 0, .1,\\n -0.5, 0, s, -mouse.y,\\n 0, 0, 0, -1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 85.3983, p * 45.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 34.3137));\\n\\treturn fract(p2.x * p2.y * 51.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 3.2 - 2.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.81 - (0.1*v);\\n}\\n\\nfloat inv(float v) {\\n return 2. * v - mouse.x;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.5 + edgeId), 1.5 ); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI - tan(sin((1.6, 0.2) * PI * 1.10));\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v -s/2.;\\n float y = s * v-c;\\n float z = 0.15 * c;\\n pos = vec3(x, y, z <-s*u); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.17) + tan((t * 1.13) + mouse.y -t) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x/ 0.8 - 1.3)-7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3(4, resolution.y / resolution.x , mouse.y* 1.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 0.3 + snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(2.1 *v_color.rgb * v_color.a, v_color.a /9.0);\\n}\"}", + "settings": { + "num": 91736, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.60), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 1.9-s, 0.2, 0, 0,\n s, 0, c, 0,\n 0, 0, 1, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle *2.);\n \t\n return mat4( \n c,-s, 0, s, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, s*2.0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0.1, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 2, 0.1, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, mouse.x, 0, 0,\n 0, s-2., 0, .1,\n -0.5, 0, s, -mouse.y,\n 0, 0, 0, -1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 85.3983, p * 45.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 34.3137));\n\treturn fract(p2.x * p2.y * 51.4337);\n}\n\nfloat m1p1(float v) {\n return v * 3.2 - 2.;\n}\n\nfloat p1m1(float v) {\n return v * 1.81 - (0.1*v);\n}\n\nfloat inv(float v) {\n return 2. * v - mouse.x;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.5 + edgeId), 1.5 ); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI - tan(sin((1.6, 0.2) * PI * 1.10));\n float s = sin(a);\n float c = cos(a);\n float x = c * v -s/2.;\n float y = s * v-c;\n float z = 0.15 * c;\n pos = vec3(x, y, z <-s*u); \n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.17) + tan((t * 1.13) + mouse.y -t) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x/ 0.8 - 1.3)-7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3(4, resolution.y / resolution.x , mouse.y* 1.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 0.3 + snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(2.1 *v_color.rgb * v_color.a, v_color.a /9.0);\n}" + }, "screenshotURL": "data/images/images-1avo4905rdyt32xxz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EXKWEFXxnr6e7Bjch/art.json b/art/EXKWEFXxnr6e7Bjch/art.json index 17bf328d..377f988e 100644 --- a/art/EXKWEFXxnr6e7Bjch/art.json +++ b/art/EXKWEFXxnr6e7Bjch/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n float sx = cx - circlesPerRow * 0.5;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.125;\\n soundTexCoords.y = 0.; //((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * (1. + soundTexCoords.x) + 0.1;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale(1. / 11.);\\n \\n \\n \\n float temp;\\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n vec2 soundTexCoords = vec2(0, 0);\n float sx = cx - circlesPerRow * 0.5;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.125;\n soundTexCoords.y = 0.; //((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * (1. + soundTexCoords.x) + 0.1;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale(1. / 11.);\n \n \n \n float temp;\n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-tga01e8nztffaqfhj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EZG3qh8pDqtEo39W2/art.json b/art/EZG3qh8pDqtEo39W2/art.json index 4eb5ab12..af89cb2c 100644 --- a/art/EZG3qh8pDqtEo39W2/art.json +++ b/art/EZG3qh8pDqtEo39W2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":715,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - Motion\\n// spring 2022\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 715, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - Motion\n// spring 2022\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-0ikvszbnzx95ztz6g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EZmjdzfcpwjp7MSFM/art.json b/art/EZmjdzfcpwjp7MSFM/art.json index 50489963..41604a3a 100644 --- a/art/EZmjdzfcpwjp7MSFM/art.json +++ b/art/EZmjdzfcpwjp7MSFM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4617,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.17647058823529413,0.25098039215686274,0.3215686274509804,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 1.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.3\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\\n\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, .9);\\n float innerRadius = pow(count * 0.0005, .2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius*mouse.y;\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius*mouse.x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * 0.90161, .1+sin(time), 1);\\n\\n float b = 1.2 - pow(sin(count * 0.4+T) * 1.3 + 0.7, 1.8);\\n b = 0.0;mix(0.3, 0.7, b);\\n v_color = vec4(c, b, sin(T*.1)+c*b, 0.6);\\n}\\n\"}", + "settings": { + "num": 4617, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.17647058823529413, + 0.25098039215686274, + 0.3215686274509804, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 1.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.3\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\n\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, .9);\n float innerRadius = pow(count * 0.0005, .2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius*mouse.y;\n float oS = sin(orbitAngle + count * 0.01) * innerRadius*mouse.x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * 0.90161, .1+sin(time), 1);\n\n float b = 1.2 - pow(sin(count * 0.4+T) * 1.3 + 0.7, 1.8);\n b = 0.0;mix(0.3, 0.7, b);\n v_color = vec4(c, b, sin(T*.1)+c*b, 0.6);\n}\n" + }, "screenshotURL": "data/images/images-njkwyn6cyahgjgqk5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EZzESxRYabyXKSxqw/art.json b/art/EZzESxRYabyXKSxqw/art.json index b5c25695..58f8c6c6 100644 --- a/art/EZzESxRYabyXKSxqw/art.json +++ b/art/EZzESxRYabyXKSxqw/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 2.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 2.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-pxclrotmn0a4kapm2-thumbnail.jpg", "views": { "$numberInt": "87" diff --git a/art/Eb8KT9CKPyKMXSF7L/art.json b/art/Eb8KT9CKPyKMXSF7L/art.json index 47698890..1b53839a 100644 --- a/art/Eb8KT9CKPyKMXSF7L/art.json +++ b/art/Eb8KT9CKPyKMXSF7L/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\\n float beatwave =\\n ( pow( 1. - abs( sin( time * 0.5 ) ), 4.) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a * (1. - soundTexCoords0.y/(historyDepth * 2.));\\n float incomingR = texture2D(sound, soundTexCoords1).a * (1. - soundTexCoords1.y/(historyDepth * 2.));\\n float r = outgoingR + incomingR;\\n r = r * (1. + soundTexCoords0.x) + 0.1;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale(1. / 11.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\n float beatwave =\n ( pow( 1. - abs( sin( time * 0.5 ) ), 4.) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a * (1. - soundTexCoords0.y/(historyDepth * 2.));\n float incomingR = texture2D(sound, soundTexCoords1).a * (1. - soundTexCoords1.y/(historyDepth * 2.));\n float r = outgoingR + incomingR;\n r = r * (1. + soundTexCoords0.x) + 0.1;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale(1. / 11.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-prajvq9psjyjosm8p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EbKX65r26sjm5sY7t/art.json b/art/EbKX65r26sjm5sY7t/art.json index e283cf0b..6b5544ab 100644 --- a/art/EbKX65r26sjm5sY7t/art.json +++ b/art/EbKX65r26sjm5sY7t/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// hash functions\\n\\n\\n\\nvoid main() {\\n float width = 10.0;\\n \\n float x = mod(vertexId, width) * 0.05;\\n float y = vertexId * 0.05;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// hash functions\n\n\n\nvoid main() {\n float width = 10.0;\n \n float x = mod(vertexId, width) * 0.05;\n float y = vertexId * 0.05;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}\n" + }, "screenshotURL": "data/images/images-xani5rh2cgjij2zqt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ec8Lpab7csKeguMAy/art.json b/art/Ec8Lpab7csKeguMAy/art.json index 00c79e4c..e2192d9e 100644 --- a/art/Ec8Lpab7csKeguMAy/art.json +++ b/art/Ec8Lpab7csKeguMAy/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-w4ttzfq8uz0cstr8h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EdvEpRyeJaKAyAk7K/art.json b/art/EdvEpRyeJaKAyAk7K/art.json index 291c28e6..9fbae70e 100644 --- a/art/EdvEpRyeJaKAyAk7K/art.json +++ b/art/EdvEpRyeJaKAyAk7K/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 10.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n \\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n \\n float base = time * .5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //NEW\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n vec4 cbNi;\\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\\n \\n //float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\\n \\n cubep*= 0.08;\\n \\n //END NEW\\n track(shapeId*128.+time, vertexCount, base, pos, color);\\n //TRACK\\n /*\\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(czaxis, 0),\\n vec4(cxaxis, 0),\\n vec4(czaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n color = vec4(1.,1.,1.,1.);\\n*/\\n //END TRACK\\n cubep+= pos;\\n color.xyz = shade(eye, cubep, cbNi.xyz, color.xyz, 0.6, vec2(64.0, .8));\\n \\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 10.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n \n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\nvoid main() {\n \n float base = time * .5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n \n //NEW\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n vec4 cbNi;\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\n \n //float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\n \n cubep*= 0.08;\n \n //END NEW\n track(shapeId*128.+time, vertexCount, base, pos, color);\n //TRACK\n /*\n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(czaxis, 0),\n vec4(cxaxis, 0),\n vec4(czaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n color = vec4(1.,1.,1.,1.);\n*/\n //END TRACK\n cubep+= pos;\n color.xyz = shade(eye, cubep, cbNi.xyz, color.xyz, 0.6, vec2(64.0, .8));\n \n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-o3b065jtd40b7ylhq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EfjfmMvDH5P2mY3xa/art.json b/art/EfjfmMvDH5P2mY3xa/art.json index acd95bae..ec542c12 100644 --- a/art/EfjfmMvDH5P2mY3xa/art.json +++ b/art/EfjfmMvDH5P2mY3xa/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":42,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n float radius = 2.0 - y;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n vec2 xy = vec2(u, v) * 0.1;\\n \\n\\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 42, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float angle = x / 20.0 * radians(360.0);\n float radius = 2.0 - y;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n vec2 xy = vec2(u, v) * 0.1;\n \n\n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-9wzm9b5fkw41o1vt8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EgLk7JDok4GhxPeMH/art.json b/art/EgLk7JDok4GhxPeMH/art.json index d090ee54..cce9e710 100644 --- a/art/EgLk7JDok4GhxPeMH/art.json +++ b/art/EgLk7JDok4GhxPeMH/art.json @@ -27,7 +27,19 @@ "name": "stringart", "private": false, "username": "gman", - "settings": "{\"num\":500,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n#define PI 3.141592653589793\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n vec4 offsets = vec4(\\n sin(time), \\n sin(time * .13) * PI * 2.,\\n sin(time * .43) * .5 + 1.,\\n cos(time * .17) * .5 + .5);\\n\\n vec4 centers = vec4(\\n sin(time * .163) * .5,\\n cos(time * .267) * .5,\\n sin(time * .367) * .5,\\n cos(time * .497) * .5);\\n\\n vec4 mult = vec4(\\n 1.,\\n (sin(time * .1) * .5 + .5) * 3.,\\n 0.,\\n 0.);\\n\\n vec2 position = vec2(vertexId / vertexCount, mod(vertexId, 2.));\\n vec2 offset = mix(offsets.xz, offsets.yw, position.y);\\n float a = mult.x * position.x * PI * 2.0 + offset.x;//mix(u_offsets.x, u_offsets.y, a_position.y);\\n float c = cos(a * mult.y);\\n vec2 xy = vec2(\\n cos(a),\\n sin(a)) * c * offset.y +\\n mix(centers.xy, centers.zw, position.y);\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n \\n float hue = position.x;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 500, + "mode": "LINES", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n#define PI 3.141592653589793\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n vec4 offsets = vec4(\n sin(time), \n sin(time * .13) * PI * 2.,\n sin(time * .43) * .5 + 1.,\n cos(time * .17) * .5 + .5);\n\n vec4 centers = vec4(\n sin(time * .163) * .5,\n cos(time * .267) * .5,\n sin(time * .367) * .5,\n cos(time * .497) * .5);\n\n vec4 mult = vec4(\n 1.,\n (sin(time * .1) * .5 + .5) * 3.,\n 0.,\n 0.);\n\n vec2 position = vec2(vertexId / vertexCount, mod(vertexId, 2.));\n vec2 offset = mix(offsets.xz, offsets.yw, position.y);\n float a = mult.x * position.x * PI * 2.0 + offset.x;//mix(u_offsets.x, u_offsets.y, a_position.y);\n float c = cos(a * mult.y);\n vec2 xy = vec2(\n cos(a),\n sin(a)) * c * offset.y +\n mix(centers.xy, centers.zw, position.y);\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n gl_Position = vec4(xy * aspect, 0, 1);\n \n float hue = position.x;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-3miwbc8y1trizj8o4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EgwgPafyaLHWPDw2T/art.json b/art/EgwgPafyaLHWPDw2T/art.json index 0abbcfec..463e8208 100644 --- a/art/EgwgPafyaLHWPDw2T/art.json +++ b/art/EgwgPafyaLHWPDw2T/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lapixmusic/fugene2crossfade\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n \\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n \\n vec2 p = vec2(ux , vy);\\n //float z = fract(0.86);\\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lapixmusic/fugene2crossfade", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n \n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n \n vec2 p = vec2(ux , vy);\n //float z = fract(0.86);\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\n int a = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-3j89bh5l0xrb801yd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EhoHuSv6ou8bp9o66/art.json b/art/EhoHuSv6ou8bp9o66/art.json index 27943296..5d5e1019 100644 --- a/art/EhoHuSv6ou8bp9o66/art.json +++ b/art/EhoHuSv6ou8bp9o66/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/quakemusic/major7-d-addiction-drugs-chapeleiro-quake-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_POINTS_PER_GROUP 16.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float groupId = floor(vertexId / NUM_POINTS_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float ps = pointId / NUM_POINTS_PER_GROUP;\\n float numGroups = floor(vertexCount / NUM_POINTS_PER_GROUP);\\n float down = floor(sqrt(numGroups));\\n float across = floor(numGroups / down);\\n\\n float px = mod(groupId, across);\\n float py = floor(groupId / across);\\n float pu = px / across;\\n float pv = py / down;\\n \\n float sv = abs(atan(pv * 2. - 1., pu * 2. - 1.) / PI);\\n float sy = abs((pu * 2. - 1.) * (pv * 2. - 1.));\\n float snd = texture2D(sound, vec2(mix(0.002, 0.008, sv), sy * 0.5)).a;\\n float sn2 = texture2D(sound, vec2(mix(0.01, 0.3, sy), sv * 0.5)).a;\\n \\n float t = time + 1000.;\\n float tm = t * 0.5 - ps * 0.4 * (sin(t + pu * 3. * pv * 4.) * 0.5 + 0.5);\\n vec2 xy = vec2(\\n pu * 2. - 1. + sin(tm + px * 0.1) * 0.1 + cos(tm * px * py * 0.000009) * 0.1,\\n pv * 2. - 1. + sin(tm * 0.77 + py * 0.1) * cos(tm + px * 0.011) * 0.1\\n );\\n gl_Position = vec4(xy * 1.2, ps, 1);\\n gl_PointSize = 12.0 + sin(time * px * py * 0.000001) * 10.;\\n gl_PointSize *= resolution.x / 1600. * .5;\\n\\n float hue = 0.5 + pow(sn2, 3.0)* 0.3; //(time * 0.01 + pu * 0.2);\\n v_color = vec4(hsv2rgb(vec3(hue, 1., pow(sn2 + 0.4, 6.))), mix(0.9, 0., ps));\\n float pump = step(0.9, snd);\\n float pumps = (snd - 0.9) * 10.;\\n v_color.rgb = mix(v_color.rgb, vec3(mix(0.5, 1., pumps),0,0), pump);\\n gl_PointSize *= mix(1., 2., pump);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/quakemusic/major7-d-addiction-drugs-chapeleiro-quake-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_POINTS_PER_GROUP 16.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float groupId = floor(vertexId / NUM_POINTS_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_GROUP);\n float ps = pointId / NUM_POINTS_PER_GROUP;\n float numGroups = floor(vertexCount / NUM_POINTS_PER_GROUP);\n float down = floor(sqrt(numGroups));\n float across = floor(numGroups / down);\n\n float px = mod(groupId, across);\n float py = floor(groupId / across);\n float pu = px / across;\n float pv = py / down;\n \n float sv = abs(atan(pv * 2. - 1., pu * 2. - 1.) / PI);\n float sy = abs((pu * 2. - 1.) * (pv * 2. - 1.));\n float snd = texture2D(sound, vec2(mix(0.002, 0.008, sv), sy * 0.5)).a;\n float sn2 = texture2D(sound, vec2(mix(0.01, 0.3, sy), sv * 0.5)).a;\n \n float t = time + 1000.;\n float tm = t * 0.5 - ps * 0.4 * (sin(t + pu * 3. * pv * 4.) * 0.5 + 0.5);\n vec2 xy = vec2(\n pu * 2. - 1. + sin(tm + px * 0.1) * 0.1 + cos(tm * px * py * 0.000009) * 0.1,\n pv * 2. - 1. + sin(tm * 0.77 + py * 0.1) * cos(tm + px * 0.011) * 0.1\n );\n gl_Position = vec4(xy * 1.2, ps, 1);\n gl_PointSize = 12.0 + sin(time * px * py * 0.000001) * 10.;\n gl_PointSize *= resolution.x / 1600. * .5;\n\n float hue = 0.5 + pow(sn2, 3.0)* 0.3; //(time * 0.01 + pu * 0.2);\n v_color = vec4(hsv2rgb(vec3(hue, 1., pow(sn2 + 0.4, 6.))), mix(0.9, 0., ps));\n float pump = step(0.9, snd);\n float pumps = (snd - 0.9) * 10.;\n v_color.rgb = mix(v_color.rgb, vec3(mix(0.5, 1., pumps),0,0), pump);\n gl_PointSize *= mix(1., 2., pump);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-qmjglkdlpkhcujrw6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EjE5NRrJcWgx7nqze/art.json b/art/EjE5NRrJcWgx7nqze/art.json index d4f9f47e..ba73ba57 100644 --- a/art/EjE5NRrJcWgx7nqze/art.json +++ b/art/EjE5NRrJcWgx7nqze/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "pöstpöp", "avatarUrl": "https://lh3.googleusercontent.com/-JUIeC9mYGbM/AAAAAAAAAAI/AAAAAAAAACE/f6C0Rr97fYs/photo.jpg", - "settings": "{\"num\":25000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n _ \\n _ _ ___ ___| |_ ___ _ _ \\n| | | -_| _| _| -_|_'_|\\n \\\\_/|___|_| |_| |___|_,_|\\n _ _ \\n ___| |_ ___ _| |___ ___ \\n|_ -| | .'| . | -_| _|\\n|___|_|_|__,|___|___|_| \\n _ \\n ___ ___| |_ \\n| .'| _| _| \\n|__,|_| |_| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomBoxPoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n p[2] = mix(-1., 1., step(0., p[2]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n p[0] = mix(-1., 1., step(0., p[0]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomSpherePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319))));\\n}\\n\\nvec3 getRandomSphereVolumePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\\n}\\n\\nvec3 getRandomCubeVolumePoint(float seed) {\\n return vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n}\\n\\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getPoint(float set, float seed) {\\n set = mod(set, 7.);\\n if (set < 1.) \\n {\\n return getRandomCubePoint(seed);\\n }\\n if (set < 2.) \\n {\\n return getRandomSphereVolumePoint(seed);\\n }\\n if (set < 3.) \\n {\\n return getRandomFunkPoint(seed, 3., 3.);\\n }\\n if (set < 4.) \\n {\\n return getRandomSpherePoint(seed);\\n }\\n if (set < 5.) \\n {\\n return getRandomBoxPoint(seed);\\n }\\n if (set < 6.)\\n {\\n return getRandomCubeVolumePoint(seed);\\n }\\n return getRandomFunkOutPoint(seed, 4., 3.);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, 3.);\\n }\\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\\n}\\n\\nvec3 getLerpedPoint(float time, float seed) {\\n float set = mod(time, 7.);\\n vec3 p0 = getPoint(set, seed);\\n vec3 p1 = getPoint(set + 1., seed);\\n return mix(p0, p1, easeInOutCubic(fract(time)));\\n}\\n\\n#define DOTS_PER 4000.\\n\\nvoid main() {\\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n\\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\\n \\n float cameraRadius = 13.;\\n float camAngle = time * 0.3;\\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n\\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(\\n m1p1(hash(thingId * 0.179)) * 6., \\n m1p1(hash(thingId * 0.317)) * 6., \\n m1p1(hash(thingId * 0.251)) * 6.));\\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\\n gl_Position = m * vec4(p, 1);\\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n\\n float hue = 0.6+ v * 0.1;\\n hue = mix(hue, 0.4, mod(floor(time * 60.0), 2.));\\n hue = mix(hue, .1, step(0.9, snd));\\n float sat = 1.;\\n float val = invClipZ * 150.;\\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n gl_PointSize = 18. / gl_Position.z;\\n}\"}", + "settings": { + "num": 25000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n _ \n _ _ ___ ___| |_ ___ _ _ \n| | | -_| _| _| -_|_'_|\n \\_/|___|_| |_| |___|_,_|\n _ _ \n ___| |_ ___ _| |___ ___ \n|_ -| | .'| . | -_| _|\n|___|_|_|__,|___|___|_| \n _ \n ___ ___| |_ \n| .'| _| _| \n|__,|_| |_| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvec3 getRandomBoxPoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n p[1] = mix(-1., 1., step(0., p[1]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n p[2] = mix(-1., 1., step(0., p[2]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n p[0] = mix(-1., 1., step(0., p[0]));\n }\n return p;\n}\n\nvec3 getRandomSpherePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319))));\n}\n\nvec3 getRandomSphereVolumePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\n}\n\nvec3 getRandomCubeVolumePoint(float seed) {\n return vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n}\n\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getPoint(float set, float seed) {\n set = mod(set, 7.);\n if (set < 1.) \n {\n return getRandomCubePoint(seed);\n }\n if (set < 2.) \n {\n return getRandomSphereVolumePoint(seed);\n }\n if (set < 3.) \n {\n return getRandomFunkPoint(seed, 3., 3.);\n }\n if (set < 4.) \n {\n return getRandomSpherePoint(seed);\n }\n if (set < 5.) \n {\n return getRandomBoxPoint(seed);\n }\n if (set < 6.)\n {\n return getRandomCubeVolumePoint(seed);\n }\n return getRandomFunkOutPoint(seed, 4., 3.);\n}\n\nfloat easeInOutCubic(float pos) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, 3.);\n }\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\n}\n\nvec3 getLerpedPoint(float time, float seed) {\n float set = mod(time, 7.);\n vec3 p0 = getPoint(set, seed);\n vec3 p1 = getPoint(set + 1., seed);\n return mix(p0, p1, easeInOutCubic(fract(time)));\n}\n\n#define DOTS_PER 4000.\n\nvoid main() {\n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\n \n float cameraRadius = 13.;\n float camAngle = time * 0.3;\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(\n m1p1(hash(thingId * 0.179)) * 6., \n m1p1(hash(thingId * 0.317)) * 6., \n m1p1(hash(thingId * 0.251)) * 6.));\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\n gl_Position = m * vec4(p, 1);\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n\n float hue = 0.6+ v * 0.1;\n hue = mix(hue, 0.4, mod(floor(time * 60.0), 2.));\n hue = mix(hue, .1, step(0.9, snd));\n float sat = 1.;\n float val = invClipZ * 150.;\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n gl_PointSize = 18. / gl_Position.z;\n}" + }, "screenshotURL": "data/images/images-dz7orokl91gsvozag-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EjqDk64Ezh9aZ2oXN/art.json b/art/EjqDk64Ezh9aZ2oXN/art.json index a54b8e73..49b48fa7 100644 --- a/art/EjqDk64Ezh9aZ2oXN/art.json +++ b/art/EjqDk64Ezh9aZ2oXN/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Vertexshaderart : Making a Grid\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Vertexshaderart : Making a Grid\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-yaowpioagtmnv70en-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ekj2CXtjX5YZc76Lk/art.json b/art/Ekj2CXtjX5YZc76Lk/art.json index 078dd4cd..de74fa24 100644 --- a/art/Ekj2CXtjX5YZc76Lk/art.json +++ b/art/Ekj2CXtjX5YZc76Lk/art.json @@ -28,7 +28,19 @@ "name": "orb", "private": false, "username": "mark", - "settings": "{\"num\":28704,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mortengranau/morten-granau-not-over-yet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n\\nvec3 project(vec3 p) { return vec3(p.xy/p.z, -p.z); }\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main () {\\n float i = rand(vec2(vertexId, 184.98));\\n float j = rand(vec2(vertexId, 274.14));\\n float f = rand(vec2(vertexId, 387.36));\\n \\n float snd = pow(texture2D(sound, vec2(.02+.5 * f, 0.)).a, 2.);\\n float asp = resolution.x / resolution.y;\\n \\n \\n float rad = .2 + .05 * snd;\\n float a1 = 2. * PI * i;\\n float a2 = 2. * PI * j + time * .05;\\n a2 -= mouse.x;\\n \\n float y = rad * sin(a1) + .05;\\n float xz_rad = rad * cos(a1);\\n float x = xz_rad * cos(a2) / asp;\\n float z = -.4 + xz_rad * sin(a2);\\n z += mouse.y * .1;\\n\\n \\n float dist = abs(z) *.5;\\n \\n vec3 p = project(vec3(x, y, z));\\n gl_Position = vec4(p, 1.);\\n gl_PointSize = 8. * snd + 1. / dist;\\n v_color = vec4(\\n .2 * acos(f) / PI + .8 * snd,\\n .4 * snd * + .3 * asin(f) / PI,\\n .6 * snd + .2 * rand(vec2(i, j)),\\n \\tsnd);\\n}\"}", + "settings": { + "num": 28704, + "mode": "POINTS", + "sound": "https://soundcloud.com/mortengranau/morten-granau-not-over-yet", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n\nvec3 project(vec3 p) { return vec3(p.xy/p.z, -p.z); }\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main () {\n float i = rand(vec2(vertexId, 184.98));\n float j = rand(vec2(vertexId, 274.14));\n float f = rand(vec2(vertexId, 387.36));\n \n float snd = pow(texture2D(sound, vec2(.02+.5 * f, 0.)).a, 2.);\n float asp = resolution.x / resolution.y;\n \n \n float rad = .2 + .05 * snd;\n float a1 = 2. * PI * i;\n float a2 = 2. * PI * j + time * .05;\n a2 -= mouse.x;\n \n float y = rad * sin(a1) + .05;\n float xz_rad = rad * cos(a1);\n float x = xz_rad * cos(a2) / asp;\n float z = -.4 + xz_rad * sin(a2);\n z += mouse.y * .1;\n\n \n float dist = abs(z) *.5;\n \n vec3 p = project(vec3(x, y, z));\n gl_Position = vec4(p, 1.);\n gl_PointSize = 8. * snd + 1. / dist;\n v_color = vec4(\n .2 * acos(f) / PI + .8 * snd,\n .4 * snd * + .3 * asin(f) / PI,\n .6 * snd + .2 * rand(vec2(i, j)),\n \tsnd);\n}" + }, "screenshotURL": "data/images/images-2snl6a0p1dnl5uu96-thumbnail.jpg", "views": { "$numberInt": "570" diff --git a/art/Ekz3YzPYcEQyhT2z7/art.json b/art/Ekz3YzPYcEQyhT2z7/art.json index 57f43de6..bbce8398 100644 --- a/art/Ekz3YzPYcEQyhT2z7/art.json +++ b/art/Ekz3YzPYcEQyhT2z7/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float id = vertexId + .1;\\n float aspect = resolution.x / resolution.y;\\n float across = floor(sqrt(vertexCount) * aspect);\\n float down = floor(vertexCount / across);\\n float x = mod(id, across);\\n float y = floor(id / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (down - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float pointScale = min(\\n 20. / across * resolution.x / 600.0,\\n 20. / down * resolution.y / 600.0);\\n \\n gl_Position = vec4(vec2(ux, vy) * .75, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= pointScale;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float id = vertexId + .1;\n float aspect = resolution.x / resolution.y;\n float across = floor(sqrt(vertexCount) * aspect);\n float down = floor(vertexCount / across);\n float x = mod(id, across);\n float y = floor(id / across);\n \n float u = x / (across - 1.);\n float v = y / (down - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float pointScale = min(\n 20. / across * resolution.x / 600.0,\n 20. / down * resolution.y / 600.0);\n \n gl_Position = vec4(vec2(ux, vy) * .75, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= pointScale;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-kyy1cybih9ww1g0wc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Emf9HTtBkjpcSmC3a/art.json b/art/Emf9HTtBkjpcSmC3a/art.json index 6ae3ae23..8fc9a05e 100644 --- a/art/Emf9HTtBkjpcSmC3a/art.json +++ b/art/Emf9HTtBkjpcSmC3a/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvoid main() {\\n \\n float n = vertexId/1.0;\\n \\n float angle = 1.45*sin(n*0.23);\\n float radius = cos(n*0.1) * tan(angle*0.9);\\n \\n float scale = 0.2;\\n \\n float x = radius*sin(angle) * cos(2.0*time) * cos(2.0*time) * scale * 0.12;\\n float y = radius*cos(angle) * scale;\\n\\n float red = abs(x*9.0);\\n float green = abs(y*9.0);\\n float blue = 1.0;\\n \\n x += 0.6*sin(time*0.5);\\n y += 0.25*cos(time*1.8);\\n \\n \\n //bool beg = mod(vertexId, 2) ? true : false;\\n \\n //float x = 0.05*n;\\n //float y = 0.05*n;\\n \\n \\n \\n \\n gl_Position = vec4(x, y, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(red, green, blue, 1); \\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvoid main() {\n \n float n = vertexId/1.0;\n \n float angle = 1.45*sin(n*0.23);\n float radius = cos(n*0.1) * tan(angle*0.9);\n \n float scale = 0.2;\n \n float x = radius*sin(angle) * cos(2.0*time) * cos(2.0*time) * scale * 0.12;\n float y = radius*cos(angle) * scale;\n\n float red = abs(x*9.0);\n float green = abs(y*9.0);\n float blue = 1.0;\n \n x += 0.6*sin(time*0.5);\n y += 0.25*cos(time*1.8);\n \n \n //bool beg = mod(vertexId, 2) ? true : false;\n \n //float x = 0.05*n;\n //float y = 0.05*n;\n \n \n \n \n gl_Position = vec4(x, y, 0, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(red, green, blue, 1); \n}" + }, "screenshotURL": "data/images/images-9m5eh2co8szmq18aj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Epmt3yx3xHdhspZxB/art.json b/art/Epmt3yx3xHdhspZxB/art.json index 05d2734a..548982e0 100644 --- a/art/Epmt3yx3xHdhspZxB/art.json +++ b/art/Epmt3yx3xHdhspZxB/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/douglasfirstmusic/honestly-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6745098039215687,0,0.7019607843137254,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.01;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n// float snd = texture2D(sound, vec2(au * 0.01, av * 0.99 - 0.2 * sin(time * 0.2))).z;\\n float snd = texture2D(sound, vec2(au * 0.1 + 0.014, av * 0.02)).x;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/douglasfirstmusic/honestly-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6745098039215687, + 0, + 0.7019607843137254, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.01;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n// float snd = texture2D(sound, vec2(au * 0.01, av * 0.99 - 0.2 * sin(time * 0.2))).z;\n float snd = texture2D(sound, vec2(au * 0.1 + 0.014, av * 0.02)).x;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-mnc6d5r3hxkc3w5a8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Er8p4bB3vqTs4694p/art.json b/art/Er8p4bB3vqTs4694p/art.json index 7eb8daff..7682ca77 100644 --- a/art/Er8p4bB3vqTs4694p/art.json +++ b/art/Er8p4bB3vqTs4694p/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "ian", "avatarUrl": "https://lh5.googleusercontent.com/-kwFohQ1qZfc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reGM-mK9emfJ0BML17FZaOd7UGoXg/mo/photo.jpg", - "settings": "{\"num\":2437,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define INNER_RADIUS 0.3\\n#define OUTER_RADIUS 0.3\\n#define SEGMENT_COUNT 20.0\\n\\nvec2 getPosition(float id){\\n float width = 10.0;\\n \\n float x = mod(id , width);\\n float y = floor(id / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n return xy;\\n}\\n\\nvoid main(){\\n \\n// vec2 origin = vec2(vertexId/ (SEGMENT_COUNT * 3.0), mod(vertexId, SEGMENT_COUNT * 3.0));\\n \\n vec2 origin = getPosition(floor(vertexId/ 42.0));\\n \\n float x = floor(mod(vertexId, 42.0) / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float angle = x / SEGMENT_COUNT * radians(360.0);\\n float radius = INNER_RADIUS + y * OUTER_RADIUS;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(-angle);\\n \\n vec2 xy = vec2(u, v) * 0.1;\\n xy += origin;\\n\\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n \\n // gl_Position = vec4(origin, 0.0, 1.0);\\n // gl_PointSize = 20.0;\\n // v_color = vec4(1.);\\n}\\n\\n\\n\\n/* void main()\\n{\\n float width = 10.0f;\\n \\n float x = mod(gl_VertexID, width);\\n float y = floor(gl_VertexID / width);\\n \\n float u = x / (width - 1.0f);\\n float v = y / (width - 1.0f);\\n \\n float xOffset = cos(time + y * 0.2f) * 0.1f;\\n float yOffset = cos(time + x * 0.3f) * 0.2f;\\n \\n float ux = u * 2.0f - 1.0f + xOffset;\\n float vy = v * 2.0f - 1.0f + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.2f;\\n \\n gl_Position = vec4(xy, 0.0f, 1.0f);\\n gl_PointSize = 20.0f;\\n //v_color = vec4(0.0f, 0.0f, 0.0f, 1.0f);\\n}\\n*/\"}", + "settings": { + "num": 2437, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define INNER_RADIUS 0.3\n#define OUTER_RADIUS 0.3\n#define SEGMENT_COUNT 20.0\n\nvec2 getPosition(float id){\n float width = 10.0;\n \n float x = mod(id , width);\n float y = floor(id / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n return xy;\n}\n\nvoid main(){\n \n// vec2 origin = vec2(vertexId/ (SEGMENT_COUNT * 3.0), mod(vertexId, SEGMENT_COUNT * 3.0));\n \n vec2 origin = getPosition(floor(vertexId/ 42.0));\n \n float x = floor(mod(vertexId, 42.0) / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float angle = x / SEGMENT_COUNT * radians(360.0);\n float radius = INNER_RADIUS + y * OUTER_RADIUS;\n \n float u = radius * cos(angle);\n float v = radius * sin(-angle);\n \n vec2 xy = vec2(u, v) * 0.1;\n xy += origin;\n\n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n \n // gl_Position = vec4(origin, 0.0, 1.0);\n // gl_PointSize = 20.0;\n // v_color = vec4(1.);\n}\n\n\n\n/* void main()\n{\n float width = 10.0f;\n \n float x = mod(gl_VertexID, width);\n float y = floor(gl_VertexID / width);\n \n float u = x / (width - 1.0f);\n float v = y / (width - 1.0f);\n \n float xOffset = cos(time + y * 0.2f) * 0.1f;\n float yOffset = cos(time + x * 0.3f) * 0.2f;\n \n float ux = u * 2.0f - 1.0f + xOffset;\n float vy = v * 2.0f - 1.0f + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.2f;\n \n gl_Position = vec4(xy, 0.0f, 1.0f);\n gl_PointSize = 20.0f;\n //v_color = vec4(0.0f, 0.0f, 0.0f, 1.0f);\n}\n*/" + }, "screenshotURL": "data/images/images-c3j0x56tqgdsftbqc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/EtY77PNcjnaQtphnu/art.json b/art/EtY77PNcjnaQtphnu/art.json index c7c2800d..8dedd119 100644 --- a/art/EtY77PNcjnaQtphnu/art.json +++ b/art/EtY77PNcjnaQtphnu/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n\\n\\n\\nvec3 getCenterPoint(const float id, vec2 seed, float time) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n cos(0.01* id * time) * (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n sin(0.01*id * time) * (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + 0.0, seed, time);\\n vec3 p1 = getCenterPoint(quadId + 0.1, seed, time);\\n vec3 p2 = getCenterPoint(quadId + 0.2, seed, time);\\n vec3 p3 = getCenterPoint(quadId + 0.3, seed, time);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(0,0);//vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 1800.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float snd0 = 0.4; //0.5*sin(time); //texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n float snd1 = 0.0;//*cos(lineId*0.1); //texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId * 0.02 + time * (lineId + 1.), \\n pointId, \\n 0.01, \\n vec2(0, 0), \\n pos, \\n uv); \\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(quadId / quadCount);\\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.5, lineId * 0.1);\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n\n\n\nvec3 getCenterPoint(const float id, vec2 seed, float time) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n cos(0.01* id * time) * (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n sin(0.01*id * time) * (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + 0.0, seed, time);\n vec3 p1 = getCenterPoint(quadId + 0.1, seed, time);\n vec3 p2 = getCenterPoint(quadId + 0.2, seed, time);\n vec3 p3 = getCenterPoint(quadId + 0.3, seed, time);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(0,0);//vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 1800.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float snd0 = 0.4; //0.5*sin(time); //texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n float snd1 = 0.0;//*cos(lineId*0.1); //texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId * 0.02 + time * (lineId + 1.), \n pointId, \n 0.01, \n vec2(0, 0), \n pos, \n uv); \n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(quadId / quadCount);\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.5, lineId * 0.1);\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-1kvtic3uctrdoppvb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/EtZAgACkH5HwhRTKb/art.json b/art/EtZAgACkH5HwhRTKb/art.json index 63ad63d5..75761984 100644 --- a/art/EtZAgACkH5HwhRTKb/art.json +++ b/art/EtZAgACkH5HwhRTKb/art.json @@ -28,7 +28,19 @@ "name": "unnamed", "private": true, "username": "visy", - "settings": "{\"num\":56715,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/the-silicon-scientist/oceans-of-green-album-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = 0.01 + time*0.1;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(localTime * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 4.0-time*0.05);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * time*0.01, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n float cr = mix(0.0, 1.0, b+count*oC);\\n float cg = mix(0.0, 1.0, b+count*time*0.0000001);\\n float cb = mix(0.0, 1.0, b+count*oS);\\n \\n v_color = vec4(cr, cg, cb, 1);\\n}\"}", + "settings": { + "num": 56715, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/the-silicon-scientist/oceans-of-green-album-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = 0.01 + time*0.1;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(localTime * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 4.0-time*0.05);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * time*0.01, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n float cr = mix(0.0, 1.0, b+count*oC);\n float cg = mix(0.0, 1.0, b+count*time*0.0000001);\n float cb = mix(0.0, 1.0, b+count*oS);\n \n v_color = vec4(cr, cg, cb, 1);\n}" + }, "screenshotURL": "data/images/images-r7eqt5ulrsre5r0ws-thumbnail.jpg", "views": { "$numberInt": "62" diff --git a/art/EwiWN8pkXdNqqJ7tq/art.json b/art/EwiWN8pkXdNqqJ7tq/art.json index a8adabc1..38bea6f7 100644 --- a/art/EwiWN8pkXdNqqJ7tq/art.json +++ b/art/EwiWN8pkXdNqqJ7tq/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":5963,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0,0, 10, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) { \\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 0 0 0 0 1 1 1 1 1 1 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n // x = 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n // y = 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n float angle = ux /numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n \\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 274.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 3.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 30. * sign(ux));\\n mat *= uniformScale(0.05 * sc);\\n \\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.3; // sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.;//mix(0., 1., pump); // mix(1., -10.,av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5963, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0,0, 10, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) { \n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 0 0 0 0 1 1 1 1 1 1 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n // x = 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n // y = 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n float angle = ux /numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n \n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numCircleSegments = 274.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 3.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 30. * sign(ux));\n mat *= uniformScale(0.05 * sc);\n \n \n gl_Position = mat * pos;\n \n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.3; // sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.;//mix(0., 1., pump); // mix(1., -10.,av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-c9257fgnzmtzvi58z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ewq6xoiNuJyRhdSo5/art.json b/art/Ewq6xoiNuJyRhdSo5/art.json index d0b349b7..d74c9103 100644 --- a/art/Ewq6xoiNuJyRhdSo5/art.json +++ b/art/Ewq6xoiNuJyRhdSo5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09803921568627451,0.09803921568627451,0.10196078431372549,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09803921568627451, + 0.09803921568627451, + 0.10196078431372549, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-zcawqhsycf8ac0gv7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ex4L4mExH2paBQBj5/art.json b/art/Ex4L4mExH2paBQBj5/art.json index eee87905..bfef88f7 100644 --- a/art/Ex4L4mExH2paBQBj5/art.json +++ b/art/Ex4L4mExH2paBQBj5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":69582,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Circles from Triangles\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n float ux = floor(id/6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux/numCircleSegments * PI*2.;\\n float c =cos(angle);\\n float s =sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\treturn vec2(x,y);\\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 36.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n float numPointsPerCircle = numCircleSegments *6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount/numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/6.);\\n float oddSlice = mod(sliceId,2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down); \\n \\n float x = mod(circleId,across);\\n float y = floor(circleId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n float aspect = resolution.x/resolution.y;\\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\\n sc*=20./across;\\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n mat*= scale(vec3(1,aspect,1));\\n mat*= rotZ(time*0.1);\\n mat *= trans(vec3(ux,vy,0) *1.4);\\n mat*= rotZ(snd*20.*sign(ux));\\n mat*= uniformScale(0.03*sc);\\n \\n gl_Position = mat*pos;\\n \\n float soff = 0.;\\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = 1.;//mix(0., 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue +pump* oddSlice*0.5 + pump*0.33;\\n val += oddSlice*pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 69582, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Circles from Triangles\ncourse name : CS250\nterm : 2022 Spring\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\nvec2 getCirclePoint(float id, float numCircleSegments){\n float ux = floor(id/6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux/numCircleSegments * PI*2.;\n float c =cos(angle);\n float s =sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n\treturn vec2(x,y);\n}\n\n\nvoid main() {\n \n float numCircleSegments = 36.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n float numPointsPerCircle = numCircleSegments *6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount/numPointsPerCircle);\n \n float sliceId = floor(vertexId/6.);\n float oddSlice = mod(sliceId,2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down); \n \n float x = mod(circleId,across);\n float y = floor(circleId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n float aspect = resolution.x/resolution.y;\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\n sc*=20./across;\n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n mat*= scale(vec3(1,aspect,1));\n mat*= rotZ(time*0.1);\n mat *= trans(vec3(ux,vy,0) *1.4);\n mat*= rotZ(snd*20.*sign(ux));\n mat*= uniformScale(0.03*sc);\n \n gl_Position = mat*pos;\n \n float soff = 0.;\n\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = 1.;//mix(0., 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue +pump* oddSlice*0.5 + pump*0.33;\n val += oddSlice*pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-f1kzx9keg7c1ejt3y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/F3kKjy86maMCacENb/art.json b/art/F3kKjy86maMCacENb/art.json index f7af3342..051547b1 100644 --- a/art/F3kKjy86maMCacENb/art.json +++ b/art/F3kKjy86maMCacENb/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "政舜", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GgcW1R-EFhQweKFdAKeT4z-f8GCIYK2iIb8IgTVvw=s96-c", - "settings": "{\"num\":900,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/latium-entertainment/magic-rude-zedd-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0196078431372549,0.09803921568627451,0.2,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0);\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / ( across - 1.0);\\n float v = y / ( across - 1.0);\\n float sv = abs(v - 0.5) * 2.0;\\n float su = abs(u - 0.5) * 2.0;\\n float au = abs(atan(sv,su)) / PI;\\n float av = length(vec2(sv,su));\\n float snd = texture2D(sound,vec2( au * 0.05 , av * 0.25 )).x;\\n \\n float xoff = 0.; \\n float yoff = 0.; \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float soff = 0.;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n gl_PointSize = pow(snd + 0.2 , 5.0) * 30.0 + soff;\\n gl_PointSize *= 24.0 /across;\\n gl_PointSize *= resolution.x / 600.0;\\n gl_PointSize *= resolution.y / 789.0;\\n \\n float hue = av * cos(time) + snd * 0.22 + tan(time) * 0.2;\\n float sat = 2.5 * sin(au) * snd;\\n float val = pow(snd + 0.2 , 5.0);\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1.0);\\n\\n}\"}", + "settings": { + "num": 900, + "mode": "POINTS", + "sound": "https://soundcloud.com/latium-entertainment/magic-rude-zedd-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0196078431372549, + 0.09803921568627451, + 0.2, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0);\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / ( across - 1.0);\n float v = y / ( across - 1.0);\n float sv = abs(v - 0.5) * 2.0;\n float su = abs(u - 0.5) * 2.0;\n float au = abs(atan(sv,su)) / PI;\n float av = length(vec2(sv,su));\n float snd = texture2D(sound,vec2( au * 0.05 , av * 0.25 )).x;\n \n float xoff = 0.; \n float yoff = 0.; \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float soff = 0.;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n gl_PointSize = pow(snd + 0.2 , 5.0) * 30.0 + soff;\n gl_PointSize *= 24.0 /across;\n gl_PointSize *= resolution.x / 600.0;\n gl_PointSize *= resolution.y / 789.0;\n \n float hue = av * cos(time) + snd * 0.22 + tan(time) * 0.2;\n float sat = 2.5 * sin(au) * snd;\n float val = pow(snd + 0.2 , 5.0);\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1.0);\n\n}" + }, "screenshotURL": "data/images/images-nwgm82ror9we7ne4y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/F4CnAXam3PniXCQjt/art.json b/art/F4CnAXam3PniXCQjt/art.json index 24197abd..1a523bcf 100644 --- a/art/F4CnAXam3PniXCQjt/art.json +++ b/art/F4CnAXam3PniXCQjt/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5096,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 10.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\\n\"}", + "settings": { + "num": 5096, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 10.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}\n" + }, "screenshotURL": "data/images/images-k2w3ygjs4oskrg5de-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/F5nWdazPW5bXmip32/art.json b/art/F5nWdazPW5bXmip32/art.json index a6407f34..6f4e7a6b 100644 --- a/art/F5nWdazPW5bXmip32/art.json +++ b/art/F5nWdazPW5bXmip32/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "8bitrick", "avatarUrl": "https://avatars.githubusercontent.com/8BitRick?s=200", - "settings": "{\"num\":967,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/v-e-r-t-e/track1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float bins = 5.;\\n float percent_count = vertexId / vertexCount;\\n float freq = floor(percent_count * bins) / bins + bins * 0.5;\\n \\n \\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n \\n float intensity = texture2D(sound,vec2(freq,0.)).a;\\n gl_PointSize = mix(1.0, 5.0, intensity);\\n //gl_Position = vec4(x,y,0,1);\\n //v_color = mix(vec4(hsv2rgb(vec3(0.25, fract(time+row_per), 1.)), 1.-row_per), background, row_per - 0.2);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 967, + "mode": "POINTS", + "sound": "https://soundcloud.com/v-e-r-t-e/track1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float bins = 5.;\n float percent_count = vertexId / vertexCount;\n float freq = floor(percent_count * bins) / bins + bins * 0.5;\n \n \n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n \n float intensity = texture2D(sound,vec2(freq,0.)).a;\n gl_PointSize = mix(1.0, 5.0, intensity);\n //gl_Position = vec4(x,y,0,1);\n //v_color = mix(vec4(hsv2rgb(vec3(0.25, fract(time+row_per), 1.)), 1.-row_per), background, row_per - 0.2);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-uw9g33024qoq2ydg2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/F6MddBx2WQCrGct9a/art.json b/art/F6MddBx2WQCrGct9a/art.json index 77ef5aa3..f5f332aa 100644 --- a/art/F6MddBx2WQCrGct9a/art.json +++ b/art/F6MddBx2WQCrGct9a/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gonnavis", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GhSJKnNoTgcJa1k6UpXDyxIVcCzuktPMheOKdkK=s96-c", - "settings": "{\"num\":9,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hash3( float n ){\\n // http://glslsandbox.com/e#61476.1\\n return fract(sin(vec3(n,n+1.0,n+2.0))*vec3(43758.5453123,22578.1459123,19642.3490423));\\n}\\n\\nvoid main() {\\n gl_Position=vec4(hash3(vertexId+time*.0001)-.5,1);\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 9, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hash3( float n ){\n // http://glslsandbox.com/e#61476.1\n return fract(sin(vec3(n,n+1.0,n+2.0))*vec3(43758.5453123,22578.1459123,19642.3490423));\n}\n\nvoid main() {\n gl_Position=vec4(hash3(vertexId+time*.0001)-.5,1);\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-37bcsjcyf38exhod0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/F88Ekndwj4ihuRGmt/art.json b/art/F88Ekndwj4ihuRGmt/art.json index 20d3872c..0fa8df7d 100644 --- a/art/F88Ekndwj4ihuRGmt/art.json +++ b/art/F88Ekndwj4ihuRGmt/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "isaín", "avatarUrl": "https://lh6.googleusercontent.com/-PShsQ2rITQc/AAAAAAAAAAI/AAAAAAAAARc/ffHK8TazFeI/photo.jpg", - "settings": "{\"num\":22,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n \\n}\"}", + "settings": { + "num": 22, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n \n}" + }, "screenshotURL": "data/images/images-45o9q12z5ppgsxi6b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FAi4yHCJC2jr4B4Mj/art.json b/art/FAi4yHCJC2jr4B4Mj/art.json index ef53e558..fe9d61cf 100644 --- a/art/FAi4yHCJC2jr4B4Mj/art.json +++ b/art/FAi4yHCJC2jr4B4Mj/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Making A Grid exercise\\n//2022 spring\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Making A Grid exercise\n//2022 spring\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}\n" + }, "screenshotURL": "data/images/images-375p8v7658brs40uw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FAsmmhzQ9syJzXwzR/art.json b/art/FAsmmhzQ9syJzXwzR/art.json index 94cdb6a4..e2805eb6 100644 --- a/art/FAsmmhzQ9syJzXwzR/art.json +++ b/art/FAsmmhzQ9syJzXwzR/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 15.0\\n#define NUM_POINTS (NUM_SEGMENTS * 8.0)\\n#define STEP 0.25\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.02, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 4.0) + mod(vertexId, 4.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.2, 0, 1);\\n\\n float hue = (time * 0.0001 + count * 1.1);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 15.0\n#define NUM_POINTS (NUM_SEGMENTS * 8.0)\n#define STEP 0.25\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.02, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 4.0) + mod(vertexId, 4.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.2, 0, 1);\n\n float hue = (time * 0.0001 + count * 1.1);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-x7c5f45fsmlikex0j-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FBZkegcALhNaPJL6W/art.json b/art/FBZkegcALhNaPJL6W/art.json index 221e2811..c73c6470 100644 --- a/art/FBZkegcALhNaPJL6W/art.json +++ b/art/FBZkegcALhNaPJL6W/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "amagitakayosi", "avatarUrl": "https://secure.gravatar.com/avatar/14084b6462b19a8512ce5208a76f8925?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2Fad1ca2d3c1d7383c5f34676d7fced9ad", - "settings": "{\"num\":3311,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n \\n b = 1. - b;\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 3311, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n \n b = 1. - b;\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-6i3bn1ne0f8fvop5v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FD5KhRKjCLtaEQWHM/art.json b/art/FD5KhRKjCLtaEQWHM/art.json index 5e13e76c..37895b9a 100644 --- a/art/FD5KhRKjCLtaEQWHM/art.json +++ b/art/FD5KhRKjCLtaEQWHM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":28708,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 3. );\\n float c = tan( angle /7. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x / p2.y * 165.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\\n}\"}", + "settings": { + "num": 28708, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 3. );\n float c = tan( angle /7. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\n\treturn fract(p2.x / p2.y * 165.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\n}" + }, "screenshotURL": "data/images/images-0crnle6ycxd5mkhv9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FDYmXj7L2c7PJjTwe/art.json b/art/FDYmXj7L2c7PJjTwe/art.json index eb09ca39..3e4017b1 100644 --- a/art/FDYmXj7L2c7PJjTwe/art.json +++ b/art/FDYmXj7L2c7PJjTwe/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.111+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-4.2) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.111+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-4.2) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-lg7amx490lfy9l7vw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FDoMDz4QxPmpEY7FJ/art.json b/art/FDoMDz4QxPmpEY7FJ/art.json index fcf99328..520aa134 100644 --- a/art/FDoMDz4QxPmpEY7FJ/art.json +++ b/art/FDoMDz4QxPmpEY7FJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n#define parameter0 5.//KParameter0 -15.>>20.\\n#define parameter1 5.//KParameter1 -15.>>20.\\n#define parameter2 2.//KParameter2 -1.>>5.\\n#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. + soundTexCoords0.x) + 0.1;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 4. * r * parameter2;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n#define parameter0 5.//KParameter0 -15.>>20.\n#define parameter1 5.//KParameter1 -15.>>20.\n#define parameter2 2.//KParameter2 -1.>>5.\n#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. + soundTexCoords0.x) + 0.1;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 4. * r * parameter2;\n}" + }, "screenshotURL": "data/images/images-f5tq1vrxnt6xhyeie-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FDqpoXetoxdNjtLYb/art.json b/art/FDqpoXetoxdNjtLYb/art.json index 45e4c713..06a6e2ce 100644 --- a/art/FDqpoXetoxdNjtLYb/art.json +++ b/art/FDqpoXetoxdNjtLYb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(0.5, 0.5);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-0.5, 0.5);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(0.5, -0.5);\\n }\\n else {\\n fp = vec2(-0.5, -0.5);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 0.5);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -0.5);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 0.5, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -0.5, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-0.5, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(0.5, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 1.;\\n //float lineId = mod(shapeId, numberOfElement);\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float relXid = xPos/2.;\\n xPos =xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) *0.5;\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n //lineId+=mod(time*10.,2.);\\n //lineId/=numberOfElement;\\n\\n \\n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+= xPos;\\n \\n //float zDelta + mod(time,);\\n float speed = -13.;\\n float simpZ = cubep.z + lineId;\\n cubep.z = simpZ+ mod(time*speed,2.);//mod(time/1000.+simpZ,1.2*shapeCount);\\n //cubep.z+= mod(time/10.,10.);\\n \\n //float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 10., 13.5);//29./2.*abs(cos(time/5.))\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n float redCOmp = mod(lineId,2.);\\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 12.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n color.x = redCOmp;\\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(0.5, 0.5);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-0.5, 0.5);\n }\n else if(vtxId == 3.0) {\n fp = vec2(0.5, -0.5);\n }\n else {\n fp = vec2(-0.5, -0.5);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 0.5);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -0.5);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 0.5, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -0.5, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-0.5, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(0.5, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 1.;\n //float lineId = mod(shapeId, numberOfElement);\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float relXid = xPos/2.;\n xPos =xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi) *0.5;\n \n vec3 color = vec3(1., 1., 1.);\n \n //lineId+=mod(time*10.,2.);\n //lineId/=numberOfElement;\n\n \n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+= xPos;\n \n //float zDelta + mod(time,);\n float speed = -13.;\n float simpZ = cubep.z + lineId;\n cubep.z = simpZ+ mod(time*speed,2.);//mod(time/1000.+simpZ,1.2*shapeCount);\n //cubep.z+= mod(time/10.,10.);\n \n //float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 10., 13.5);//29./2.*abs(cos(time/5.))\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n float redCOmp = mod(lineId,2.);\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 12.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n color.x = redCOmp;\n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-y7jf6skz5nvdeq6wy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FEETng4czKpcp3kDg/art.json b/art/FEETng4czKpcp3kDg/art.json index 46a3ad18..2223af4e 100644 --- a/art/FEETng4czKpcp3kDg/art.json +++ b/art/FEETng4czKpcp3kDg/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "diego", "avatarUrl": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/photo.jpg", - "settings": "{\"num\":1858,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n vec2 getCircleXY(float id) \\n{\\n \\n float uxc= floor(id / 6.0) + mod(id, 2.0);\\n float vyc = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = uxc / 20.0 * radians(180.0) * 2.0; //20 segmentos\\n float radius = vyc + 1.0;\\n \\n \\n float xc = radius * cos(angle);\\n float yc = radius * sin(angle);\\n \\n return vec2(xc, yc);\\n}\\n\\n\\n void main()\\n{\\n \\n vec2 circleXY = getCircleXY(vertexId);\\n \\n float circleId = floor(vertexId / 120.0);\\n float circleCount = floor(vertexCount / 120.0);\\n \\n float sqrTotal = floor(sqrt(circleCount));\\n float width = sqrTotal;\\n \\n float x = mod(circleId, width); \\n float y = floor(circleId / width); \\n\\n\\n float u = x / (width - 1.0) ;\\n float v = y/ (width - 1.0) ;\\n\\n float ux = u * 2.0 - 1.0 ;\\n float vy = v * 2.0 - 1.0 ;\\n \\n vec2 xy = circleXY * 0.1 + vec2( ux, vy);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n\\n}\\n\"}", + "settings": { + "num": 1858, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n vec2 getCircleXY(float id) \n{\n \n float uxc= floor(id / 6.0) + mod(id, 2.0);\n float vyc = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = uxc / 20.0 * radians(180.0) * 2.0; //20 segmentos\n float radius = vyc + 1.0;\n \n \n float xc = radius * cos(angle);\n float yc = radius * sin(angle);\n \n return vec2(xc, yc);\n}\n\n\n void main()\n{\n \n vec2 circleXY = getCircleXY(vertexId);\n \n float circleId = floor(vertexId / 120.0);\n float circleCount = floor(vertexCount / 120.0);\n \n float sqrTotal = floor(sqrt(circleCount));\n float width = sqrTotal;\n \n float x = mod(circleId, width); \n float y = floor(circleId / width); \n\n\n float u = x / (width - 1.0) ;\n float v = y/ (width - 1.0) ;\n\n float ux = u * 2.0 - 1.0 ;\n float vy = v * 2.0 - 1.0 ;\n \n vec2 xy = circleXY * 0.1 + vec2( ux, vy);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n\n}\n" + }, "screenshotURL": "data/images/images-kysxigp7syb62zd5t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FEuQEawn8qHXvXTbY/art.json b/art/FEuQEawn8qHXvXTbY/art.json index 7db090ff..b78cf496 100644 --- a/art/FEuQEawn8qHXvXTbY/art.json +++ b/art/FEuQEawn8qHXvXTbY/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "mohammad", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GgRLVJR1d3hBTBUtVP87xxHCfbTV8QZ--NyKDA1tw", - "settings": "{\"num\":38147,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define PI radians(180.)\\n\\nconst float FARCLIPPED = 100000. ;\\nconst float NEARCLIPPED = 100.0\\t ; \\nfloat g_cameraFar = 1000.0;\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n return inverse(lookAt(eye, target, up));\\n}\\n\\nvec3 spiral(float vidx, float f, float b) {\\n float idx = mod(f + vidx * 0.4 + mod(time * 5.0, 20.0) / 20.0 * 100.0, 100.0);\\n float t = idx / 100.0;\\n float y = 50.0 - 100.0 * t;\\n float theta = t * 50.0;\\n float r = (50.0 - abs(y))/50.0 * 60.0;\\n return vec3(cos(theta) * r, y, sin(theta)*r);\\n}\\n\\n\\n\\nvoid main() {\\n mat4 m = persp(radians(60.),\\n resolution.x/ resolution.y, \\n NEARCLIPPED , \\n FARCLIPPED);\\n vec3 target = vec3(-500.0, 0.0, -500.0 ) ;\\n vec3 up = vec3(0. ,1. , 0. ) ;\\n vec3 camTarget = target ; \\n vec3 camPos = vec3(250. ,500. ,800.); \\n vec3 camForward = normalize(camTarget - camPos);\\n m *= cameraLookAt(camPos , camTarget, normalize(up));\\n \\n float spiralIdx = floor(vertexId / 100.0);\\n float vIdx = mod(vertexId, 100.0);\\n \\n float b = sin(time);\\n b = 100.0 / (1.0 + b * b * 20.0);\\n \\n vec3 spiralVertex = spiral(vIdx, 2.0, b);\\n spiralVertex += vec3(-mod(spiralIdx, 10.0) * 150.0, 0.0, -floor(spiralIdx / 10.0) * 150.0);\\n\\n\\n gl_Position = m * vec4(spiralVertex, 1);\\n\\n //v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n v_color = vec4(1, 1, 1, 1);\\n gl_PointSize = 2.0;\\n}\"}", + "settings": { + "num": 38147, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define PI radians(180.)\n\nconst float FARCLIPPED = 100000. ;\nconst float NEARCLIPPED = 100.0\t ; \nfloat g_cameraFar = 1000.0;\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n return inverse(lookAt(eye, target, up));\n}\n\nvec3 spiral(float vidx, float f, float b) {\n float idx = mod(f + vidx * 0.4 + mod(time * 5.0, 20.0) / 20.0 * 100.0, 100.0);\n float t = idx / 100.0;\n float y = 50.0 - 100.0 * t;\n float theta = t * 50.0;\n float r = (50.0 - abs(y))/50.0 * 60.0;\n return vec3(cos(theta) * r, y, sin(theta)*r);\n}\n\n\n\nvoid main() {\n mat4 m = persp(radians(60.),\n resolution.x/ resolution.y, \n NEARCLIPPED , \n FARCLIPPED);\n vec3 target = vec3(-500.0, 0.0, -500.0 ) ;\n vec3 up = vec3(0. ,1. , 0. ) ;\n vec3 camTarget = target ; \n vec3 camPos = vec3(250. ,500. ,800.); \n vec3 camForward = normalize(camTarget - camPos);\n m *= cameraLookAt(camPos , camTarget, normalize(up));\n \n float spiralIdx = floor(vertexId / 100.0);\n float vIdx = mod(vertexId, 100.0);\n \n float b = sin(time);\n b = 100.0 / (1.0 + b * b * 20.0);\n \n vec3 spiralVertex = spiral(vIdx, 2.0, b);\n spiralVertex += vec3(-mod(spiralIdx, 10.0) * 150.0, 0.0, -floor(spiralIdx / 10.0) * 150.0);\n\n\n gl_Position = m * vec4(spiralVertex, 1);\n\n //v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n v_color = vec4(1, 1, 1, 1);\n gl_PointSize = 2.0;\n}" + }, "screenshotURL": "data/images/images-dd1zkwbqiikmlvari-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FF4Q7tpyaSLjicasS/art.json b/art/FF4Q7tpyaSLjicasS/art.json index b5701ed1..df013f69 100644 --- a/art/FF4Q7tpyaSLjicasS/art.json +++ b/art/FF4Q7tpyaSLjicasS/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Rudy Castan\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n float x = mod(vertexId ,across);\\n float y = floor(vertexId/across);\\n \\n float u= x /(across-1.);\\n float v= y/(across-1.);\\n \\n float ux = u* 2. -1.;\\n float vy = v* 2.-1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Rudy Castan\n// Exercise Making A Grid\n// CS250 Spring 2022\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount /down);\n float x = mod(vertexId ,across);\n float y = floor(vertexId/across);\n \n float u= x /(across-1.);\n float v= y/(across-1.);\n \n float ux = u* 2. -1.;\n float vy = v* 2.-1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n \n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-lrv6r0ho0cdoay6i1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FGbfRShZBrEzgsq9v/art.json b/art/FGbfRShZBrEzgsq9v/art.json index 3ac1e250..a7ad3f0a 100644 --- a/art/FGbfRShZBrEzgsq9v/art.json +++ b/art/FGbfRShZBrEzgsq9v/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (1. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (1. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-4th7ngzptgb16wilw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FJRdnZn9mERmk9Yaz/art.json b/art/FJRdnZn9mERmk9Yaz/art.json index 7ac3d1a3..0affd8e8 100644 --- a/art/FJRdnZn9mERmk9Yaz/art.json +++ b/art/FJRdnZn9mERmk9Yaz/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "ארד", "avatarUrl": "https://lh4.googleusercontent.com/-8413R_UAuFI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdV_Fow1wVvKUVUEHJI563QumRktQ/photo.jpg", - "settings": "{\"num\":4784,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n \\n float across = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float default_point_size = (300. / across) * (resolution.x / 600.);\\n \\n float size = default_point_size * (sin(ux * 20.) * cos(vy * 20.));\\n \\n \\n gl_PointSize = abs(size);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n v_color = vec4(size, 0, 1. - size, 1.);\\n}\"}", + "settings": { + "num": 4784, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n \n float across = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float default_point_size = (300. / across) * (resolution.x / 600.);\n \n float size = default_point_size * (sin(ux * 20.) * cos(vy * 20.));\n \n \n gl_PointSize = abs(size);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n v_color = vec4(size, 0, 1. - size, 1.);\n}" + }, "screenshotURL": "data/images/images-5d9tqrhkygzmgg6f3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FKW2yC28uaYuXntoz/art.json b/art/FKW2yC28uaYuXntoz/art.json index 4591d7be..34e94b83 100644 --- a/art/FKW2yC28uaYuXntoz/art.json +++ b/art/FKW2yC28uaYuXntoz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*100.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*100.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-m2kamsv8foab92yd8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FMpo6tgK5xszx7CuS/art.json b/art/FMpo6tgK5xszx7CuS/art.json index 0102cd45..bd56f566 100644 --- a/art/FMpo6tgK5xszx7CuS/art.json +++ b/art/FMpo6tgK5xszx7CuS/art.json @@ -35,7 +35,19 @@ "unlisted": false, "username": "inoculate", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLPX__XSzFEjiaLL7ngTjVY--ujLu-wtKbsHzVss-EoO7Q=s96-c", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2549019607843137,0.043137254901960784,0.23921568627450981,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(1, 2, 3, 3);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2549019607843137, + 0.043137254901960784, + 0.23921568627450981, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(1, 2, 3, 3);\n}" + }, "screenshotURL": "data/images/images-rxtzxsr3gyf2krcwv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FMq3vpaDGsoEMC7e9/art.json b/art/FMq3vpaDGsoEMC7e9/art.json index 44d3259b..bc62dca4 100644 --- a/art/FMq3vpaDGsoEMC7e9/art.json +++ b/art/FMq3vpaDGsoEMC7e9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-q7md7mrgg5ouy81ri-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FMuoFaTjjywnD7fJm/art.json b/art/FMuoFaTjjywnD7fJm/art.json index 6efd6404..d3ba2a71 100644 --- a/art/FMuoFaTjjywnD7fJm/art.json +++ b/art/FMuoFaTjjywnD7fJm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Making a Grid \\n// Course : CS250\\n// Spring 2023\\n\\nvoid main()\\n{ \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n \\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(cos(time / 2.), cos(time / 5.), cos(time / 10.), 1);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Making a Grid \n// Course : CS250\n// Spring 2023\n\nvoid main()\n{ \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n \n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(cos(time / 2.), cos(time / 5.), cos(time / 10.), 1);\n}\n" + }, "screenshotURL": "data/images/images-xgqb9sloo2a81wcd3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FNFsfgYT3ysjSme2P/art.json b/art/FNFsfgYT3ysjSme2P/art.json index 6d0f3a7c..7879b66f 100644 --- a/art/FNFsfgYT3ysjSme2P/art.json +++ b/art/FNFsfgYT3ysjSme2P/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":40417,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/radioindielounge/jazz-lamour-summer-dreams-see-the-light-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 1.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.024, cu), gv * 1.)).a;\\n snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n vec3 pos;\\n float inner = mix(0.0, 0.98, cgv);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n vec3 offset = vec3(0, 0, gv);\\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= rotZ(time * 1.3 + time * -0.01 * (1. + (1. - gv) * 200.5));\\n mat *= trans(offset);\\n mat *= uniformScale(pow(gv * 2.8 + sliceId * gv * 0.5, 2.));\\n// mat *= uniformScale( pow(snd + 0.1, 5.0) * 0.1 + sliceId * 0.1);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * -0.01 + mix(0., .2, gv);\\n float sat = 0.6 - pow(snd, 5.) * 0.6;\\n float val = 1.;//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 40417, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/radioindielounge/jazz-lamour-summer-dreams-see-the-light-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 1.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd = texture2D(sound, vec2(mix(0.001, 0.024, cu), gv * 1.)).a;\n snd = pow(snd, mix(2., 0.5, su));\n \n \n vec3 pos;\n float inner = mix(0.0, 0.98, cgv);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n vec3 offset = vec3(0, 0, gv);\n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= rotZ(time * 1.3 + time * -0.01 * (1. + (1. - gv) * 200.5));\n mat *= trans(offset);\n mat *= uniformScale(pow(gv * 2.8 + sliceId * gv * 0.5, 2.));\n// mat *= uniformScale( pow(snd + 0.1, 5.0) * 0.1 + sliceId * 0.1);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = time * -0.01 + mix(0., .2, gv);\n float sat = 0.6 - pow(snd, 5.) * 0.6;\n float val = 1.;//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-l0k8vdupw883y6q85-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FNwMYwJ2SdwbbSNAN/art.json b/art/FNwMYwJ2SdwbbSNAN/art.json index 9112fc66..a15ba057 100644 --- a/art/FNwMYwJ2SdwbbSNAN/art.json +++ b/art/FNwMYwJ2SdwbbSNAN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":30720,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmag-1/premiere-luigi-madonna-chaudfontaine-pan-pot-remix\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,0.14901960784313725,0,1],\"shader\":\"/*\\n\\n\\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \\n /_/\\\\ /\\\\_\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\_______)\\\\ /\\\\_____\\\\/\\\\ /\\\\ /\\\\/ ____/\\\\ /\\\\_\\\\ /_/\\\\ /\\\\___/\\\\ /\\\\ __/\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\___/\\\\ /_/\\\\__/\\\\ /\\\\_______)\\\\ \\n ) ) ) ( (( (_____/) ) ) ) )\\\\(___ __\\\\/( (_____/\\\\ \\\\ \\\\/ / /) ) __\\\\/( ( (_) ) ) / / _ \\\\ \\\\ ) ) \\\\ \\\\( (_____/) ) ) ) ) / / _ \\\\ \\\\ ) ) ) ) )\\\\(___ __\\\\/ \\n/_/ / \\\\ \\\\_\\\\\\\\ \\\\__\\\\ /_/ /_/_/ / / / \\\\ \\\\__\\\\ \\\\ \\\\ / / \\\\ \\\\ \\\\ \\\\ \\\\___/ / \\\\ \\\\(_)/ // / /\\\\ \\\\ \\\\\\\\ \\\\__\\\\ /_/ /_/_/ \\\\ \\\\(_)/ //_/ /_/_/ / / / \\n\\\\ \\\\ \\\\_/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( / /__/_ / / \\\\ \\\\ _\\\\ \\\\ \\\\ / / _ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( \\n \\\\ \\\\ / /( (_____\\\\)_) ) \\\\ \\\\ \\\\ \\\\ \\\\ ( (_____\\\\/ / /\\\\ \\\\ \\\\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\\\)_) ) \\\\ \\\\( (_( )_) ))_) ) \\\\ \\\\ \\\\ \\\\ \\\\ \\n \\\\_\\\\_/_/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ /_/_/ \\\\/_____/\\\\/__\\\\/__\\\\/\\\\____\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/___\\\\/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\_\\\\/ \\\\_\\\\/ /_/_/ \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 256.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 2.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float edgeId = mod(vertexId, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float u2 = floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE;\\n float snd = texture2D(sound, vec2(mix(0.0, 0.25, hash(u2)), 0.0)).a;\\n float inner = mix(0.5, 1.0, pow(snd + .3, 5.0));//0.9; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\\n float start = fract(hash(circleId * 0.33));\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n \\n vec3 offset = vec3(m1p1(hash(circleId * floor(time * 1.2) * 0.123)), m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset = vec3(0);\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.2, 0.3, pow(snd, 1.)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n vec3 cc = mix(vec3(1), vec3(0), mod(circleId, 2.0));\\n vec3 fl = mix(vec3(0,1,1), vec3(.5,1,1), mod(time * 60.0, 2.0)); \\n vec3 c2 = mix(cc, fl, step(0.8, snd));\\n float hue = fract(circleId);//, 1., step(0.75, snd));\\n float sat = step(0.5, snd);\\n float val = mod(circleId, 2.);step(0.50, snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb = c2;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 30720, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmag-1/premiere-luigi-madonna-chaudfontaine-pan-pot-remix", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 0.14901960784313725, + 0, + 1 + ], + "shader": "/*\n\n\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \n /_/\\ /\\_\\ /\\_____\\/_/\\__/\\ /\\_______)\\ /\\_____\\/\\ /\\ /\\/ ____/\\ /\\_\\ /_/\\ /\\___/\\ /\\ __/\\ /\\_____\\/_/\\__/\\ /\\___/\\ /_/\\__/\\ /\\_______)\\ \n ) ) ) ( (( (_____/) ) ) ) )\\(___ __\\/( (_____/\\ \\ \\/ / /) ) __\\/( ( (_) ) ) / / _ \\ \\ ) ) \\ \\( (_____/) ) ) ) ) / / _ \\ \\ ) ) ) ) )\\(___ __\\/ \n/_/ / \\ \\_\\\\ \\__\\ /_/ /_/_/ / / / \\ \\__\\ \\ \\ / / \\ \\ \\ \\ \\___/ / \\ \\(_)/ // / /\\ \\ \\\\ \\__\\ /_/ /_/_/ \\ \\(_)/ //_/ /_/_/ / / / \n\\ \\ \\_/ / // /__/_\\ \\ \\ \\ \\ ( ( ( / /__/_ / / \\ \\ _\\ \\ \\ / / _ \\ \\ / / _ \\ \\\\ \\ \\/ / // /__/_\\ \\ \\ \\ \\ / / _ \\ \\\\ \\ \\ \\ \\ ( ( ( \n \\ \\ / /( (_____\\)_) ) \\ \\ \\ \\ \\ ( (_____\\/ / /\\ \\ \\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\)_) ) \\ \\( (_( )_) ))_) ) \\ \\ \\ \\ \\ \n \\_\\_/_/ \\/_____/\\_\\/ \\_\\/ /_/_/ \\/_____/\\/__\\/__\\/\\____\\/ \\/_/ \\_\\/ \\/_/ \\_\\/ \\/___\\/ \\/_____/\\_\\/ \\_\\/ \\/_/ \\_\\/ \\_\\/ \\_\\/ /_/_/ \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 256.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 2.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float edgeId = mod(vertexId, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float u2 = floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE;\n float snd = texture2D(sound, vec2(mix(0.0, 0.25, hash(u2)), 0.0)).a;\n float inner = mix(0.5, 1.0, pow(snd + .3, 5.0));//0.9; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\n float start = fract(hash(circleId * 0.33));\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n \n vec3 offset = vec3(m1p1(hash(circleId * floor(time * 1.2) * 0.123)), m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset = vec3(0);\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.2, 0.3, pow(snd, 1.)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n vec3 cc = mix(vec3(1), vec3(0), mod(circleId, 2.0));\n vec3 fl = mix(vec3(0,1,1), vec3(.5,1,1), mod(time * 60.0, 2.0)); \n vec3 c2 = mix(cc, fl, step(0.8, snd));\n float hue = fract(circleId);//, 1., step(0.75, snd));\n float sat = step(0.5, snd);\n float val = mod(circleId, 2.);step(0.50, snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb = c2;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-n1ff18rw1rhaacsyk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FPFBuCexgLQpriEoS/art.json b/art/FPFBuCexgLQpriEoS/art.json index ac9a4ace..cd55abea 100644 --- a/art/FPFBuCexgLQpriEoS/art.json +++ b/art/FPFBuCexgLQpriEoS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chill/ed-sheeran-i-see-fire-kalev-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = 1.;texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(u) * across * 1.0 + bxId * 0. ;\\n float vSpace = numRows * 2.0 + numBlocks * 0.;\\n float z = v * down * 2.0 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1) * snd);\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = hsv2rgb(vec3(\\n 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1, \\n 0.95, \\n 1));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 600, -400.6, 1000.0 );\\n \\tvec3 vCameraPos = vec3(-45.1, 6., -0.);\\n float ca = 0.;\\n \\n // get sick!\\n // ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chill/ed-sheeran-i-see-fire-kalev-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = 1.;texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(u) * across * 1.0 + bxId * 0. ;\n float vSpace = numRows * 2.0 + numBlocks * 0.;\n float z = v * down * 2.0 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1) * snd);\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = hsv2rgb(vec3(\n 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1, \n 0.95, \n 1));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 600, -400.6, 1000.0 );\n \tvec3 vCameraPos = vec3(-45.1, 6., -0.);\n float ca = 0.;\n \n // get sick!\n // ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-9bcl3otpidc8yk7s8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FWWNQRxd2LXsvsxj5/art.json b/art/FWWNQRxd2LXsvsxj5/art.json index fbb6d692..8e825751 100644 --- a/art/FWWNQRxd2LXsvsxj5/art.json +++ b/art/FWWNQRxd2LXsvsxj5/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":29895,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/combatrecordings/dead-fader-dancefloor-nemesis-preview\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.050980392156862744,0.050980392156862744,1],\"shader\":\"/*\\n\\n____ ____ __ \\n\\\\ \\\\ / /____________/ |_ ____ ___ ___ \\n \\\\ Y // __ \\\\_ __ \\\\ __\\\\/ __ \\\\\\\\ \\\\/ / \\n \\\\ /\\\\ ___/| | \\\\/| | \\\\ ___/ > < \\n \\\\___/ \\\\___ >__| |__| \\\\___ >__/\\\\_ \\\\ \\n \\\\/ \\\\/ \\\\/ \\n _________.__ .___ \\n / _____/| |__ _____ __| _/___________ \\n \\\\_____ \\\\ | | \\\\\\\\__ \\\\ / __ |/ __ \\\\_ __ \\\\\\n / \\\\| Y \\\\/ __ \\\\_/ /_/ \\\\ ___/| | \\\\/\\n/_______ /|___| (____ /\\\\____ |\\\\___ >__| \\n \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\n _____ __ \\n / _ \\\\________/ |_ \\n / /_\\\\ \\\\_ __ \\\\ __\\\\ \\n/ | \\\\ | \\\\/| | \\n\\\\____|__ /__| |__| \\n \\\\/ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 1,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(31.5351, 4.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define QUADS_PER_LINE 256.\\n#define SUBDIVISIONS_PER_QUAD 16.\\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\\nconst float tension = 0.3;\\n\\nvec2 funky(const float id) {\\n float v = id / QUADS_PER_LINE * 6.;\\n float t = time;\\n return vec2(\\n (sin(v + t) + tan(v * .118 / t) + sin(v * 2.951 + t)) / 3.,\\n (cos(v * 9.12 + t) + cos(v * .37 - t) + cos(v * 14.951 + t)) / 3.\\n );\\n}\\n\\nvec3 getCenterPoint(const float id) {\\n vec4 t = vec4(0);\\n const int samples = 4;\\n for (int ii = 0; ii < samples; ++ii) {\\n t += texture2D(touch, \\n vec2(0.,\\n (id + 0.1) / (soundRes.y * 3.)\\n + float(ii) / float(samples) * 0.1));\\n }\\n t /= 4.;\\n t.xy = funky(id);\\n return vec3(t.x, t.y, 0);\\n}\\n\\nvec3 getCurvePoint(const float superId) {\\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n vec3 q0 = getCenterPoint(quadId - 1.);\\n vec3 q1 = getCenterPoint(quadId + 0.);\\n vec3 q2 = getCenterPoint(quadId + 1.);\\n vec3 q3 = getCenterPoint(quadId - 2.);\\n vec3 q4 = getCenterPoint(quadId + 3.);\\n vec3 q5 = getCenterPoint(quadId + 4.);\\n \\n float s2 = pow(subV, 2.);\\n float s3 = pow(subV, 3.);\\n \\n float c1 = 1.5 * s3 - 3. - s2 + 1.;\\n float c2 = -(3. * s3) + 3. * s2; \\n float c3 = s3 - 2. * s2 + subV; \\n float c4 = s3 - s2; \\n\\n vec3 t1 = (q2 - q0) * tension;\\n vec3 t2 = (q3 - q1) * tension;\\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \\n}\\n\\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n \\n vec3 q0 = getCurvePoint(cpId + 1.);\\n vec3 q1 = getCurvePoint(cpId + 0.);\\n vec3 q2 = getCurvePoint(cpId + 2.);\\n vec3 q3 = getCurvePoint(cpId + 4.);\\n vec3 q4 = getCurvePoint(cpId + 4.);\\n vec3 q5 = getCurvePoint(cpId + 5.);\\n\\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n \\n #if 0\\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #else\\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 0.5, 0) * thickness;\\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #endif\\n \\n uv = vec2(ux, vy);\\n}\\n\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 14.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n float quadV = quadId / quadCount;\\n float invQuadV = inv(quadV);\\n vec3 pos;\\n vec2 uv;\\n\\n float snd0 = texture2D(sound, vec2(0.63, quadV * 0.2)).a;\\n float snd1 = 0.6;\\n float snd2 = texture2D(sound, vec2(0.01 * 0.25, 0.)).a;\\n \\n getQuadPoint(quadId, pointId, mix(0.1, 0.020, pow(snd0 + 0.12, 15.)) + pow(snd2, 20.0) * 0.05, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n pos.z = quadV;\\n \\n// vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(vec3(\\n mix(1., -1., mod(lineId, 2.)),\\n mix(1., -1., mod(floor(lineId / 2.), 2.)),\\n 1));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n// gl_Position.z = -m1p1(quadId / quadCount);\\n// gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.15, 10.95, snd0);\\n float sat = 1.;\\n float val = 0.4 / snd0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invQuadV);\\n //v_color = mix(v_color, vec4(1,0,0,1), pow(snd2, 15.));\\n //v_color.a = mix(1.0, 0.0, step(10., mod(quadId, 100.)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n\\n}\\n\\n\"}", + "settings": { + "num": 29895, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/combatrecordings/dead-fader-dancefloor-nemesis-preview", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.050980392156862744, + 0.050980392156862744, + 1 + ], + "shader": "/*\n\n____ ____ __ \n\\ \\ / /____________/ |_ ____ ___ ___ \n \\ Y // __ \\_ __ \\ __\\/ __ \\\\ \\/ / \n \\ /\\ ___/| | \\/| | \\ ___/ > < \n \\___/ \\___ >__| |__| \\___ >__/\\_ \\ \n \\/ \\/ \\/ \n _________.__ .___ \n / _____/| |__ _____ __| _/___________ \n \\_____ \\ | | \\\\__ \\ / __ |/ __ \\_ __ \\\n / \\| Y \\/ __ \\_/ /_/ \\ ___/| | \\/\n/_______ /|___| (____ /\\____ |\\___ >__| \n \\/ \\/ \\/ \\/ \\/ \n _____ __ \n / _ \\________/ |_ \n / /_\\ \\_ __ \\ __\\ \n/ | \\ | \\/| | \n\\____|__ /__| |__| \n \\/ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 1,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(31.5351, 4.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define QUADS_PER_LINE 256.\n#define SUBDIVISIONS_PER_QUAD 16.\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\nconst float tension = 0.3;\n\nvec2 funky(const float id) {\n float v = id / QUADS_PER_LINE * 6.;\n float t = time;\n return vec2(\n (sin(v + t) + tan(v * .118 / t) + sin(v * 2.951 + t)) / 3.,\n (cos(v * 9.12 + t) + cos(v * .37 - t) + cos(v * 14.951 + t)) / 3.\n );\n}\n\nvec3 getCenterPoint(const float id) {\n vec4 t = vec4(0);\n const int samples = 4;\n for (int ii = 0; ii < samples; ++ii) {\n t += texture2D(touch, \n vec2(0.,\n (id + 0.1) / (soundRes.y * 3.)\n + float(ii) / float(samples) * 0.1));\n }\n t /= 4.;\n t.xy = funky(id);\n return vec3(t.x, t.y, 0);\n}\n\nvec3 getCurvePoint(const float superId) {\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n vec3 q0 = getCenterPoint(quadId - 1.);\n vec3 q1 = getCenterPoint(quadId + 0.);\n vec3 q2 = getCenterPoint(quadId + 1.);\n vec3 q3 = getCenterPoint(quadId - 2.);\n vec3 q4 = getCenterPoint(quadId + 3.);\n vec3 q5 = getCenterPoint(quadId + 4.);\n \n float s2 = pow(subV, 2.);\n float s3 = pow(subV, 3.);\n \n float c1 = 1.5 * s3 - 3. - s2 + 1.;\n float c2 = -(3. * s3) + 3. * s2; \n float c3 = s3 - 2. * s2 + subV; \n float c4 = s3 - s2; \n\n vec3 t1 = (q2 - q0) * tension;\n vec3 t2 = (q3 - q1) * tension;\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \n}\n\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n \n vec3 q0 = getCurvePoint(cpId + 1.);\n vec3 q1 = getCurvePoint(cpId + 0.);\n vec3 q2 = getCurvePoint(cpId + 2.);\n vec3 q3 = getCurvePoint(cpId + 4.);\n vec3 q4 = getCurvePoint(cpId + 4.);\n vec3 q5 = getCurvePoint(cpId + 5.);\n\n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n \n #if 0\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #else\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 0.5, 0) * thickness;\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #endif\n \n uv = vec2(ux, vy);\n}\n\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 14.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n float quadV = quadId / quadCount;\n float invQuadV = inv(quadV);\n vec3 pos;\n vec2 uv;\n\n float snd0 = texture2D(sound, vec2(0.63, quadV * 0.2)).a;\n float snd1 = 0.6;\n float snd2 = texture2D(sound, vec2(0.01 * 0.25, 0.)).a;\n \n getQuadPoint(quadId, pointId, mix(0.1, 0.020, pow(snd0 + 0.12, 15.)) + pow(snd2, 20.0) * 0.05, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n pos.z = quadV;\n \n// vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(vec3(\n mix(1., -1., mod(lineId, 2.)),\n mix(1., -1., mod(floor(lineId / 2.), 2.)),\n 1));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n// gl_Position.z = -m1p1(quadId / quadCount);\n// gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.15, 10.95, snd0);\n float sat = 1.;\n float val = 0.4 / snd0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invQuadV);\n //v_color = mix(v_color, vec4(1,0,0,1), pow(snd2, 15.));\n //v_color.a = mix(1.0, 0.0, step(10., mod(quadId, 100.)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n\n}\n\n" + }, "screenshotURL": "data/images/images-ozmhslskkkqgm6vb4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Fc6iHGcLDEtSTqbNG/art.json b/art/Fc6iHGcLDEtSTqbNG/art.json index 9535e484..7b47a60d 100644 --- a/art/Fc6iHGcLDEtSTqbNG/art.json +++ b/art/Fc6iHGcLDEtSTqbNG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":44009,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/graham-panter/synthahol\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* \\n\\n⬆ click [UI] and pick [⚪] then move the [🖱] mouse\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 4.);\\n float quadId = floor(vertexId / 4.);\\n float down = floor(sqrt(numQuads));\\n float across = floor(numQuads / down);\\n \\n float gx = mod(quadId, across);\\n float gy = floor(quadId / across);\\n \\n float vId = mod(vertexId, 4.);\\n \\n float x = gx + mod(vId, 2.) - step(3., vId);\\n float y = gy + step(3., vId);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\\n \\n vec2 sp = xy * 1.1;\\n \\n const int count = 60;\\n for (int i = 0; i < count; ++i) {\\n float iv = 1. - float(i) / float(count - 1);\\n float hist = (float(i) + 0.5) / soundRes.y;\\n vec2 m = texture2D(touch, vec2(0, hist)).xy;\\n vec2 dm = m - sp;\\n float dist = length(dm);\\n float effect = mix(1., 0., clamp(dist * 5., 0., 1.));\\n sp = sp - dm * pow(abs(effect), 2.5) * 1. * pow(iv, 2.);\\n }\\n \\n float ang = fract(time * 0.1 + abs(atan(sp.x, sp.y) / PI));\\n float rad = length(sp);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.030, ang), rad * 0.2)).a;\\n \\n sp += pow(snd, 5.) * 0.025;\\n \\n \\n gl_Position = vec4(sp, 0, 1);\\n \\n float pump = step(mix(1., 0.8, ang), snd);\\n\\n v_color = vec4(vec3(mix(0.1, 1., pow(snd, 5.))), 1);\\n \\n v_color = mix(v_color, vec4(1,0,0,1), pump);\\n}\"}", + "settings": { + "num": 44009, + "mode": "LINES", + "sound": "https://soundcloud.com/graham-panter/synthahol", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* \n\n⬆ click [UI] and pick [⚪] then move the [🖱] mouse\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians(180.0)\n\nvoid main() {\n float numQuads = floor(vertexCount / 4.);\n float quadId = floor(vertexId / 4.);\n float down = floor(sqrt(numQuads));\n float across = floor(numQuads / down);\n \n float gx = mod(quadId, across);\n float gy = floor(quadId / across);\n \n float vId = mod(vertexId, 4.);\n \n float x = gx + mod(vId, 2.) - step(3., vId);\n float y = gy + step(3., vId);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\n \n vec2 sp = xy * 1.1;\n \n const int count = 60;\n for (int i = 0; i < count; ++i) {\n float iv = 1. - float(i) / float(count - 1);\n float hist = (float(i) + 0.5) / soundRes.y;\n vec2 m = texture2D(touch, vec2(0, hist)).xy;\n vec2 dm = m - sp;\n float dist = length(dm);\n float effect = mix(1., 0., clamp(dist * 5., 0., 1.));\n sp = sp - dm * pow(abs(effect), 2.5) * 1. * pow(iv, 2.);\n }\n \n float ang = fract(time * 0.1 + abs(atan(sp.x, sp.y) / PI));\n float rad = length(sp);\n float snd = texture2D(sound, vec2(mix(0.001, 0.030, ang), rad * 0.2)).a;\n \n sp += pow(snd, 5.) * 0.025;\n \n \n gl_Position = vec4(sp, 0, 1);\n \n float pump = step(mix(1., 0.8, ang), snd);\n\n v_color = vec4(vec3(mix(0.1, 1., pow(snd, 5.))), 1);\n \n v_color = mix(v_color, vec4(1,0,0,1), pump);\n}" + }, "screenshotURL": "data/images/images-5z38orofsfbe7vap7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Fc9c7BdBMHwtZfBd4/art.json b/art/Fc9c7BdBMHwtZfBd4/art.json index cb1433f1..eebfd7d1 100644 --- a/art/Fc9c7BdBMHwtZfBd4/art.json +++ b/art/Fc9c7BdBMHwtZfBd4/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Circles from Triangles\\n//course name : CS250\\n//term : Spring 2023\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1); \\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 s){\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1); \\n}\\nmat4 uniformScale(float s){\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n float ux = floor(id /6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\n \\n\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1; \\n float yoff = 0.; //sin(time * 1.1 + x * 0.2) * 0.2;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs( u - 0.5 ) * 2.;\\n float sv = abs( v - 0.5 ) * 2.;\\n float au = abs(atan(su,sv) ) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix( 1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u* 0.1 * snd * 0.2 + time * 0.1 + sliceId * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.; mix(0., 1., pump);\\n float val = mix(.3, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Circles from Triangles\n//course name : CS250\n//term : Spring 2023\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1); \n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 s){\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1); \n}\nmat4 uniformScale(float s){\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1); \n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n float ux = floor(id /6.) + mod(id, 2.);\n \n float vy = mod(floor(id/2.) + floor(id / 3.), 2.);\n \n\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1; \n float yoff = 0.; //sin(time * 1.1 + x * 0.2) * 0.2;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs( u - 0.5 ) * 2.;\n float sv = abs( v - 0.5 ) * 2.;\n float au = abs(atan(su,sv) ) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix( 1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u* 0.1 * snd * 0.2 + time * 0.1 + sliceId * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.; mix(0., 1., pump);\n float val = mix(.3, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-vkrg6vpe4jmi03e6h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FdyK8FcKsuCHmdq9D/art.json b/art/FdyK8FcKsuCHmdq9D/art.json index 370692c5..ad1d58e7 100644 --- a/art/FdyK8FcKsuCHmdq9D/art.json +++ b/art/FdyK8FcKsuCHmdq9D/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "polacienta", "avatarUrl": "https://avatars.githubusercontent.com/polacienta?s=200", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width=20.0;\\n \\n float x= mod(vertexId,width);\\n float y= floor(vertexId/width);\\n \\n float u= x/(width-1.0);\\n float v= y/(width-1.0);\\n \\n float xOffset= cos(time+y*0.2)*0.1;\\n float yOffset= sin(time+x*0.1);\\n \\n float ux=u*2.0-1.0+xOffset;\\n float uy= v*2.0-1.0+yOffset;\\n \\n vec2 xy= vec2(ux,uy);\\n \\n gl_Position= vec4(xy,0.0,1.0);\\n v_color=vec4 (0.0,1.0,0.0,1.0);\\n gl_PointSize=10.0;\\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width=20.0;\n \n float x= mod(vertexId,width);\n float y= floor(vertexId/width);\n \n float u= x/(width-1.0);\n float v= y/(width-1.0);\n \n float xOffset= cos(time+y*0.2)*0.1;\n float yOffset= sin(time+x*0.1);\n \n float ux=u*2.0-1.0+xOffset;\n float uy= v*2.0-1.0+yOffset;\n \n vec2 xy= vec2(ux,uy);\n \n gl_Position= vec4(xy,0.0,1.0);\n v_color=vec4 (0.0,1.0,0.0,1.0);\n gl_PointSize=10.0;\n}" + }, "screenshotURL": "data/images/images-m5v5o64uj8ka8ot6q-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FebsjBDDpXSkBLMfb/art.json b/art/FebsjBDDpXSkBLMfb/art.json index 741e3b06..4588f150 100644 --- a/art/FebsjBDDpXSkBLMfb/art.json +++ b/art/FebsjBDDpXSkBLMfb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/necmusic/holst-the-planets-mars-the\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n vec3 pos = vec3(0, 0, 0);\\n //pos *= vec3(100, 100, 10);\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\\n \\n mat4 cmat = rotX(sin(time * .2) * .3);\\n cmat *= trans(vec3(0, 0, 13));\\n mat *= inverse(cmat);\\n\\n \\n vec3 n = normalize(\\n vec3(\\n hash(vertexId * 0.123), \\n hash(vertexId * 0.357), \\n hash(vertexId * 0.531)\\n ) * 2. - 1.\\n );\\n \\n if (vertexId < 5000.0) {\\n mat *= trans(n * 84.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.5;;\\n v_color = vec4(hash(vertexId * 0.2111));\\n } else {\\n float d = hash(vertexId * 0.123);\\n\\n mat4 wmat = rotY(time * .1);\\n wmat *= trans(n * 5.);\\n gl_Position = mat * wmat * vec4(pos, 1);\\n\\n vec4 f = mat * vec4(1,1,pos.z,1);\\n f = f / f.w;\\n \\n float s = texture2D(sound, vec2(\\n abs(atan(n.x,n.z) / PI) * .1,\\n sin(n.y + n.x + n.z) * .5 + .5)).a;\\n\\n gl_PointSize = resolution.y / 885.0 * 22.; //f.y * 0.5;\\n v_color = vec4(hsv2rgb(vec3(\\n mix(0.0, 0.15, sin(pow(s + .3, 3.) *.9 + n.y * 3. + sin(n.x * 3.)) * .5 + .5), \\n mix(-0.3, 0.5, -pow(s+.3,5.) *.1 + 1.- smoothstep(0.7, 0.86, abs(n.y + 0.01 * sin(12. * atan(n.x, n.z))))), \\n 1.)), 1.);\\n float l = dot((wmat * vec4(n, 0)).xyz, normalize(vec3(1,2,3))) ;//* .5 + .5;\\n v_color.rgb *= l;\\n } \\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/necmusic/holst-the-planets-mars-the", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n vec3 pos = vec3(0, 0, 0);\n //pos *= vec3(100, 100, 10);\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\n \n mat4 cmat = rotX(sin(time * .2) * .3);\n cmat *= trans(vec3(0, 0, 13));\n mat *= inverse(cmat);\n\n \n vec3 n = normalize(\n vec3(\n hash(vertexId * 0.123), \n hash(vertexId * 0.357), \n hash(vertexId * 0.531)\n ) * 2. - 1.\n );\n \n if (vertexId < 5000.0) {\n mat *= trans(n * 84.);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.5;;\n v_color = vec4(hash(vertexId * 0.2111));\n } else {\n float d = hash(vertexId * 0.123);\n\n mat4 wmat = rotY(time * .1);\n wmat *= trans(n * 5.);\n gl_Position = mat * wmat * vec4(pos, 1);\n\n vec4 f = mat * vec4(1,1,pos.z,1);\n f = f / f.w;\n \n float s = texture2D(sound, vec2(\n abs(atan(n.x,n.z) / PI) * .1,\n sin(n.y + n.x + n.z) * .5 + .5)).a;\n\n gl_PointSize = resolution.y / 885.0 * 22.; //f.y * 0.5;\n v_color = vec4(hsv2rgb(vec3(\n mix(0.0, 0.15, sin(pow(s + .3, 3.) *.9 + n.y * 3. + sin(n.x * 3.)) * .5 + .5), \n mix(-0.3, 0.5, -pow(s+.3,5.) *.1 + 1.- smoothstep(0.7, 0.86, abs(n.y + 0.01 * sin(12. * atan(n.x, n.z))))), \n 1.)), 1.);\n float l = dot((wmat * vec4(n, 0)).xyz, normalize(vec3(1,2,3))) ;//* .5 + .5;\n v_color.rgb *= l;\n } \n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-rmijf94h13te9mqmv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FfHLpZyMW5rXY9aD5/art.json b/art/FfHLpZyMW5rXY9aD5/art.json index a73fb4e1..e038c09c 100644 --- a/art/FfHLpZyMW5rXY9aD5/art.json +++ b/art/FfHLpZyMW5rXY9aD5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float move = vertexId*3.0;\\n \\n float x= mouse.x ;\\n float y=mouse.y;\\n \\n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\\n \\n gl_PointSize = 30.0;\\n \\n float red=sin(time);\\n float blue=cos(time);\\n float green=tan(time);\\n \\n v_color=vec4(red,green,blue,1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float move = vertexId*3.0;\n \n float x= mouse.x ;\n float y=mouse.y;\n \n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\n \n gl_PointSize = 30.0;\n \n float red=sin(time);\n float blue=cos(time);\n float green=tan(time);\n \n v_color=vec4(red,green,blue,1.0);\n}" + }, "screenshotURL": "data/images/images-svb6wws9kqpmimcvc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FfZFDLCNW6cb8pxEg/art.json b/art/FfZFDLCNW6cb8pxEg/art.json index 50ef17ee..086a2fe3 100644 --- a/art/FfZFDLCNW6cb8pxEg/art.json +++ b/art/FfZFDLCNW6cb8pxEg/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width = 10.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width = 10.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-js9tkvd4szm7w5tzq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ffs2irmibSP7oFuTu/art.json b/art/Ffs2irmibSP7oFuTu/art.json index b8d2b6f0..3f7f8e4f 100644 --- a/art/Ffs2irmibSP7oFuTu/art.json +++ b/art/Ffs2irmibSP7oFuTu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "shu", "avatarUrl": "https://secure.gravatar.com/avatar/6dc8be209aeec21dc99956c1188c1b05?default=retro&size=200", - "settings": "{\"num\":3840,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){gl_Position=vec4(vertexId/vertexCount*2.-1.,-tan(mod(vertexId,99.)*vertexId+time)/9.,0,1);v_color=vec4(1,1,1,1)}\"}", + "settings": { + "num": 3840, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){gl_Position=vec4(vertexId/vertexCount*2.-1.,-tan(mod(vertexId,99.)*vertexId+time)/9.,0,1);v_color=vec4(1,1,1,1)}" + }, "screenshotURL": "data/images/images-y4grifiszavh7h2tz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FipmX7SNkZ3TqAY5p/art.json b/art/FipmX7SNkZ3TqAY5p/art.json index 6d546ee1..5d7b86e6 100644 --- a/art/FipmX7SNkZ3TqAY5p/art.json +++ b/art/FipmX7SNkZ3TqAY5p/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner,\\n const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n if (gl_Position.x < 0.) {\\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner,\n const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n if (gl_Position.x < 0.) {\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n}\n" + }, "screenshotURL": "data/images/images-uc2ibh2q06mz1x786-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FjA6DbEL9qbenj778/art.json b/art/FjA6DbEL9qbenj778/art.json index f899f09f..ba928e94 100644 --- a/art/FjA6DbEL9qbenj778/art.json +++ b/art/FjA6DbEL9qbenj778/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.xyz - c.xxx);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val )), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.xyz - c.xxx);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val )), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-cvc4cnxb7uua9k7ua-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FkZcSiHXEHreJBCH9/art.json b/art/FkZcSiHXEHreJBCH9/art.json index df61f51f..13c53848 100644 --- a/art/FkZcSiHXEHreJBCH9/art.json +++ b/art/FkZcSiHXEHreJBCH9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10241,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.2823529411764706,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 /3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x /(across -1.);\\n float v = y / (across -1.);\\n \\n float xoff = sin(time + y * 0.2)*0.1;\\n float yoff = sin(time + x *0.3)*0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v* 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.0;\\n \\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time+x*y*0.02)*5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x /600.;\\n \\n float hue = u * .1 + sin(time + v * 20.)* 0.05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n \\n}\"}", + "settings": { + "num": 10241, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.2823529411764706, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 /3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x /(across -1.);\n float v = y / (across -1.);\n \n float xoff = sin(time + y * 0.2)*0.1;\n float yoff = sin(time + x *0.3)*0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v* 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.0;\n \n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time+x*y*0.02)*5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x /600.;\n \n float hue = u * .1 + sin(time + v * 20.)* 0.05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n \n}" + }, "screenshotURL": "data/images/images-k9jtdeqibi5myicse-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Fkoesg8YQ6JMJPRDj/art.json b/art/Fkoesg8YQ6JMJPRDj/art.json index 2cc0a1d6..320e7eb0 100644 --- a/art/Fkoesg8YQ6JMJPRDj/art.json +++ b/art/Fkoesg8YQ6JMJPRDj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=7c652ddc2d064bbbad85c4463ef16934&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Circles from Triangles\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointPerCircle);\\n float numCircles = floor(vertexCount / numPointPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n \\n // Fun modifications\\n float hue = u * 2.0 + snd * 0.4 + time * 0.2; // Increased hue range and speed\\n float sat = mix(0.5, 1.0, pump); // Adjusted saturation range\\n float val = mix(0.4, pow(snd + 0.2, 5.), pump) + oddSlice * pump; // Adjusted value range\\n \\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=7c652ddc2d064bbbad85c4463ef16934&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Circles from Triangles\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointPerCircle);\n float numCircles = floor(vertexCount / numPointPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n \n // Fun modifications\n float hue = u * 2.0 + snd * 0.4 + time * 0.2; // Increased hue range and speed\n float sat = mix(0.5, 1.0, pump); // Adjusted saturation range\n float val = mix(0.4, pow(snd + 0.2, 5.), pump) + oddSlice * pump; // Adjusted value range\n \n hue += pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-8kwcahlggncvxoaui-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FomjPf4hmRGox2dnF/art.json b/art/FomjPf4hmRGox2dnF/art.json index 45755d9e..ced4a87c 100644 --- a/art/FomjPf4hmRGox2dnF/art.json +++ b/art/FomjPf4hmRGox2dnF/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "mohamed", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GgVXofh8qx5K33B1H69EyhooiCxOl7jU9KVOv5X=s96-c", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-wht771s9xo3e0r8hp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FozLSgACn56r8QXk5/art.json b/art/FozLSgACn56r8QXk5/art.json index cd257a70..1f1b9f7f 100644 --- a/art/FozLSgACn56r8QXk5/art.json +++ b/art/FozLSgACn56r8QXk5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":31038,\"mode\":\"TRI_STRIP\",\"sound\":\"feedback\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 -5.//KParameter -5.>>10.\\n#define P3 0.1//KParameter 0.1>>3.\\n#define P6 5.//KParameter 0.1>>10.\\n#define P5 -1.//KParameter -1.>>1.\\n#define P4 0.//KParameter 0.0>>1.\\n\\n//KVerticesNumber=40000\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 6. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos,sin(1.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *1.001;\\n float sat = P4;\\n float val = vertexCount/(vertexId * 2. * P6)*0.6;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 31038, + "mode": "TRI_STRIP", + "sound": "feedback", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 -5.//KParameter -5.>>10.\n#define P3 0.1//KParameter 0.1>>3.\n#define P6 5.//KParameter 0.1>>10.\n#define P5 -1.//KParameter -1.>>1.\n#define P4 0.//KParameter 0.0>>1.\n\n//KVerticesNumber=40000\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 6. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos,sin(1.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *1.001;\n float sat = P4;\n float val = vertexCount/(vertexId * 2. * P6)*0.6;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-jl5qiela8p3x8xeq9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Fpbwg9tJSGnDtFPom/art.json b/art/Fpbwg9tJSGnDtFPom/art.json index 8c3b6773..0b12059b 100644 --- a/art/Fpbwg9tJSGnDtFPom/art.json +++ b/art/Fpbwg9tJSGnDtFPom/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n float snd = texture2D(sound, vec2(0.2, u)).a;\\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\tvec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\t\\n\\tfor(float i = 0.001; i < 10.0; i++){\\n\\t\\t\\n\\t\\tfloat s = cos(sin(10. * time / i )) ;\\n\\t\\tfloat c = tan(cos(0.1* time + i ));\\n\\t\\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n\\n \\n \\n \\n gl_PointSize = 1.+snd*2.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(destColor * f), 1.0);\\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\\n v_color = vec4(vec3(1.), 1.0);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n float snd = texture2D(sound, vec2(0.2, u)).a;\n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\tvec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\t\n\tfor(float i = 0.001; i < 10.0; i++){\n\t\t\n\t\tfloat s = cos(sin(10. * time / i )) ;\n\t\tfloat c = tan(cos(0.1* time + i ));\n\t\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\n\t}\n\n\n \n \n \n gl_PointSize = 1.+snd*2.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(destColor * f), 1.0);\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\n v_color = vec4(vec3(1.), 1.0);\n\n}" + }, "screenshotURL": "data/images/images-568kbmihie93v38qj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FpeWqKvfuhWuYhfuT/art.json b/art/FpeWqKvfuhWuYhfuT/art.json index 83421188..4821f63a 100644 --- a/art/FpeWqKvfuhWuYhfuT/art.json +++ b/art/FpeWqKvfuhWuYhfuT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":55069,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 77.//KParameter0 0.>>1000.\\n#define KP1 5.//KParameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>10.\\n#define KP3 0.20//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>5.\\n#define KP5 1000.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=38000\\n#define PI radians(180. -KP1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 9.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 55069, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 77.//KParameter0 0.>>1000.\n#define KP1 5.//KParameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>10.\n#define KP3 0.20//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>5.\n#define KP5 1000.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=38000\n#define PI radians(180. -KP1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 9.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-mft4bm6rluwxv8bzt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FqNcEyWQSSAnHAtMY/art.json b/art/FqNcEyWQSSAnHAtMY/art.json index 7cde1ad2..6b717fb9 100644 --- a/art/FqNcEyWQSSAnHAtMY/art.json +++ b/art/FqNcEyWQSSAnHAtMY/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n float x = mod(vertexId,across);\\n float y = floor(vertexId/across);\\n float u = x/(across-1.);\\n float v = y/(across- 1.);\\n float xoff = sin(time + x * .2) *.1;\\n float yoff = sin(time + y * .3) *.2;\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 posoff = vec2(ux,vy) ;\\n \\n gl_Position = vec4(posoff,0,1);\\n \\n float soff = sin(time + 20. * ux * vy);\\n gl_PointSize = 10. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/ 600.;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v* u* 20.);\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n float x = mod(vertexId,across);\n float y = floor(vertexId/across);\n float u = x/(across-1.);\n float v = y/(across- 1.);\n float xoff = sin(time + x * .2) *.1;\n float yoff = sin(time + y * .3) *.2;\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 posoff = vec2(ux,vy) ;\n \n gl_Position = vec4(posoff,0,1);\n \n float soff = sin(time + 20. * ux * vy);\n gl_PointSize = 10. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/ 600.;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v* u* 20.);\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-ukzsutkv5foeup7vf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FqSZrJ7rAfB3savC5/art.json b/art/FqSZrJ7rAfB3savC5/art.json index 4cca1b6c..58d553b5 100644 --- a/art/FqSZrJ7rAfB3savC5/art.json +++ b/art/FqSZrJ7rAfB3savC5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n\\nmat3 rotationMatrix(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, \\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, \\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float vert_i = mod(vertexId, 3.0);\\n float tri_i = floor(vertexId / 3.0);\\n\\n vec4 snd = texture2D(sound, vec2(mod((vert_i + tri_i) / vertexCount, .5), 1));\\n \\n \\n float phi = acos(0.0) / 10.0;\\n float l = pow((snd.x + .6), 3.0);\\n float r = l * cos(phi);\\n float offset = -0.2;\\n float z = l * sin(phi) + offset;\\n float theta = (vert_i + tri_i) / 10.0;\\n float x = r * cos(theta);\\n float y = r * sin(theta);\\n \\n \\n if(vert_i == 0.0) {\\n x = 0.0;\\n y = 0.0;\\n z = offset;\\n }\\n \\n \\n \\n vec2 circle = vec2(x, y) * 100.0 + 100.0;// * 100.0;\\n circle /= resolution;\\n //circlepos.x += 200.0;\\n vec3 cone = vec3(circle, z) * rotationMatrix(normalize(vec3(1,1,0)), time);\\n \\n gl_Position = vec4(cone, 1);\\n \\n\\n\\n float hue = vertexId / vertexCount;\\n float sat = 1.0;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n\nmat3 rotationMatrix(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, \n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, \n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float vert_i = mod(vertexId, 3.0);\n float tri_i = floor(vertexId / 3.0);\n\n vec4 snd = texture2D(sound, vec2(mod((vert_i + tri_i) / vertexCount, .5), 1));\n \n \n float phi = acos(0.0) / 10.0;\n float l = pow((snd.x + .6), 3.0);\n float r = l * cos(phi);\n float offset = -0.2;\n float z = l * sin(phi) + offset;\n float theta = (vert_i + tri_i) / 10.0;\n float x = r * cos(theta);\n float y = r * sin(theta);\n \n \n if(vert_i == 0.0) {\n x = 0.0;\n y = 0.0;\n z = offset;\n }\n \n \n \n vec2 circle = vec2(x, y) * 100.0 + 100.0;// * 100.0;\n circle /= resolution;\n //circlepos.x += 200.0;\n vec3 cone = vec3(circle, z) * rotationMatrix(normalize(vec3(1,1,0)), time);\n \n gl_Position = vec4(cone, 1);\n \n\n\n float hue = vertexId / vertexCount;\n float sat = 1.0;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-2f79tm4lfguhhcmqx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FsHtLXJDGt87mpMLt/art.json b/art/FsHtLXJDGt87mpMLt/art.json index e78f309d..08797c7e 100644 --- a/art/FsHtLXJDGt87mpMLt/art.json +++ b/art/FsHtLXJDGt87mpMLt/art.json @@ -31,7 +31,19 @@ }, "private": false, "username": "visy", - "settings": "{\"num\":24693,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8,1,0.9764705882352941,1],\"shader\":\"void main()\\n{\\n int vx=int(vertexId/4.),vy=int(mod(vertexId,time*0.0001));\\n\\n vec3 rp=vec3(0.+time*1.00,1.+time*1.00,0.+time*.00),rd=rp.xzy;\\n \\n for(int j=0;j<10000;j++)\\n {\\n if(j>vx)\\n continue;\\n vec3 n=normalize(rp);\\n rp=n;\\n rd=normalize(rd-dot(n+vec3(cos(rd.z+time*0.00001))*0.01,rd)*n);\\n rd=normalize(rd+cross(n+rd,rd)*(sin(float(j)*.007)*10.+cos(float(j)*.009+float(vy)*0.1)+sin(float(j)*.001+float(vy)))*.05);\\n rp+=rd*0.02;\\n }\\n\\n float xx=mod((time-float(vx*(int(time*0.0000001)*int(time*0.00001)))/40000.0+floor(time/0007.)*07.)*time,0.009*time+0.01*cos(time*0.0001));\\n float ss=mod(vertexId/5.,2.);\\n\\n vec3 n=normalize(rp);\\n vec3 pos=rp-n*ss*.002+vec3(0.,-pow(xx,2.+cos(float(vx))*.8),0.)*ss;\\n float a=time/10.;\\n pos.xz*=mat2(cos(a),sin(a),-sin(a),cos(a));\\n pos.z+=3.;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n aspect.x*=1.5;\\n aspect.y*=1.3;\\n \\n v_color.a=1.;\\n v_color.rgb=mix(vec3(.2,.5,.6),vec3(.5,.6,1.+rd.y*10.0+time)*.1,(.5+.5*dot(n,normalize(vec3(0.2,0.2,0.2)))))/xx;\\n\\n gl_PointSize=4./(1.+xx*4.);\\n gl_Position=vec4(pos.xy/pos.z*aspect,0,1);\\n}\\n\"}", + "settings": { + "num": 24693, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8, + 1, + 0.9764705882352941, + 1 + ], + "shader": "void main()\n{\n int vx=int(vertexId/4.),vy=int(mod(vertexId,time*0.0001));\n\n vec3 rp=vec3(0.+time*1.00,1.+time*1.00,0.+time*.00),rd=rp.xzy;\n \n for(int j=0;j<10000;j++)\n {\n if(j>vx)\n continue;\n vec3 n=normalize(rp);\n rp=n;\n rd=normalize(rd-dot(n+vec3(cos(rd.z+time*0.00001))*0.01,rd)*n);\n rd=normalize(rd+cross(n+rd,rd)*(sin(float(j)*.007)*10.+cos(float(j)*.009+float(vy)*0.1)+sin(float(j)*.001+float(vy)))*.05);\n rp+=rd*0.02;\n }\n\n float xx=mod((time-float(vx*(int(time*0.0000001)*int(time*0.00001)))/40000.0+floor(time/0007.)*07.)*time,0.009*time+0.01*cos(time*0.0001));\n float ss=mod(vertexId/5.,2.);\n\n vec3 n=normalize(rp);\n vec3 pos=rp-n*ss*.002+vec3(0.,-pow(xx,2.+cos(float(vx))*.8),0.)*ss;\n float a=time/10.;\n pos.xz*=mat2(cos(a),sin(a),-sin(a),cos(a));\n pos.z+=3.;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n aspect.x*=1.5;\n aspect.y*=1.3;\n \n v_color.a=1.;\n v_color.rgb=mix(vec3(.2,.5,.6),vec3(.5,.6,1.+rd.y*10.0+time)*.1,(.5+.5*dot(n,normalize(vec3(0.2,0.2,0.2)))))/xx;\n\n gl_PointSize=4./(1.+xx*4.);\n gl_Position=vec4(pos.xy/pos.z*aspect,0,1);\n}\n" + }, "screenshotURL": "data/images/images-84llo9xy97zkz6757-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FsdFwLEhLHY2TyemA/art.json b/art/FsdFwLEhLHY2TyemA/art.json index ea3717ea..acbdfbcc 100644 --- a/art/FsdFwLEhLHY2TyemA/art.json +++ b/art/FsdFwLEhLHY2TyemA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n gl_Position = vec4(0, 0, 0, 1);\\n v_color = vec4(1, 1, 1, 1);\\n \\n gl_Position = vec4(1, 0, 0, 1);\\n v_color = vec4(1, 1, 1, 1);\\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n gl_Position = vec4(0, 0, 0, 1);\n v_color = vec4(1, 1, 1, 1);\n \n gl_Position = vec4(1, 0, 0, 1);\n v_color = vec4(1, 1, 1, 1);\n\n}" + }, "screenshotURL": "data/images/images-e2jilst5tshkd5426-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FtWQZjoHxqMK8dS5s/art.json b/art/FtWQZjoHxqMK8dS5s/art.json index 8531cf65..204f5a6e 100644 --- a/art/FtWQZjoHxqMK8dS5s/art.json +++ b/art/FtWQZjoHxqMK8dS5s/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "leithba", "avatarUrl": "https://avatars.githubusercontent.com/LeithBA?s=200", - "settings": "{\"num\":17442,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define phi PI * (3. - sqrt(5.))\\n\\n//\\tSimplex 4D Noise \\n//\\tby Ian McEwan, Ashima Arts\\n//\\nvec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\\nfloat permute(float x){return floor(mod(((x*34.0)+1.0)*x, 289.0));}\\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\\nfloat taylorInvSqrt(float r){return 1.79284291400159 - 0.85373472095314 * r;}\\n\\nvec4 grad4(float j, vec4 ip){\\n const vec4 ones = vec4(1.0, 1.0, 1.0, -1.0);\\n vec4 p,s;\\n\\n p.xyz = floor( fract (vec3(j) * ip.xyz) * 7.0) * ip.z - 1.0;\\n p.w = 1.5 - dot(abs(p.xyz), ones.xyz);\\n s = vec4(lessThan(p, vec4(0.0)));\\n p.xyz = p.xyz + (s.xyz*2.0 - 1.0) * s.www; \\n\\n return p;\\n}\\n\\nfloat snoise(vec4 v){\\n const vec2 C = vec2( 0.138196601125010504, // (5 - sqrt(5))/20 G4\\n 0.309016994374947451); // (sqrt(5) - 1)/4 F4\\n// First corner\\n vec4 i = floor(v + dot(v, C.yyyy) );\\n vec4 x0 = v - i + dot(i, C.xxxx);\\n\\n// Other corners\\n\\n// Rank sorting originally contributed by Bill Licea-Kane, AMD (formerly ATI)\\n vec4 i0;\\n\\n vec3 isX = step( x0.yzw, x0.xxx );\\n vec3 isYZ = step( x0.zww, x0.yyz );\\n// i0.x = dot( isX, vec3( 1.0 ) );\\n i0.x = isX.x + isX.y + isX.z;\\n i0.yzw = 1.0 - isX;\\n\\n// i0.y += dot( isYZ.xy, vec2( 1.0 ) );\\n i0.y += isYZ.x + isYZ.y;\\n i0.zw += 1.0 - isYZ.xy;\\n\\n i0.z += isYZ.z;\\n i0.w += 1.0 - isYZ.z;\\n\\n // i0 now contains the unique values 0,1,2,3 in each channel\\n vec4 i3 = clamp( i0, 0.0, 1.0 );\\n vec4 i2 = clamp( i0-1.0, 0.0, 1.0 );\\n vec4 i1 = clamp( i0-2.0, 0.0, 1.0 );\\n\\n // x0 = x0 - 0.0 + 0.0 * C \\n vec4 x1 = x0 - i1 + 1.0 * C.xxxx;\\n vec4 x2 = x0 - i2 + 2.0 * C.xxxx;\\n vec4 x3 = x0 - i3 + 3.0 * C.xxxx;\\n vec4 x4 = x0 - 1.0 + 4.0 * C.xxxx;\\n\\n// Permutations\\n i = mod(i, 289.0); \\n float j0 = permute( permute( permute( permute(i.w) + i.z) + i.y) + i.x);\\n vec4 j1 = permute( permute( permute( permute (\\n i.w + vec4(i1.w, i2.w, i3.w, 1.0 ))\\n + i.z + vec4(i1.z, i2.z, i3.z, 1.0 ))\\n + i.y + vec4(i1.y, i2.y, i3.y, 1.0 ))\\n + i.x + vec4(i1.x, i2.x, i3.x, 1.0 ));\\n// Gradients\\n// ( 7*7*6 points uniformly over a cube, mapped onto a 4-octahedron.)\\n// 7*7*6 = 294, which is close to the ring size 17*17 = 289.\\n\\n vec4 ip = vec4(1.0/294.0, 1.0/49.0, 1.0/7.0, 0.0) ;\\n\\n vec4 p0 = grad4(j0, ip);\\n vec4 p1 = grad4(j1.x, ip);\\n vec4 p2 = grad4(j1.y, ip);\\n vec4 p3 = grad4(j1.z, ip);\\n vec4 p4 = grad4(j1.w, ip);\\n\\n// Normalise gradients\\n vec4 norm = taylorInvSqrt(vec4(dot(p0,p0), dot(p1,p1), dot(p2, p2), dot(p3,p3)));\\n p0 *= norm.x;\\n p1 *= norm.y;\\n p2 *= norm.z;\\n p3 *= norm.w;\\n p4 *= taylorInvSqrt(dot(p4,p4));\\n\\n// Mix contributions from the five corners\\n vec3 m0 = max(0.6 - vec3(dot(x0,x0), dot(x1,x1), dot(x2,x2)), 0.0);\\n vec2 m1 = max(0.6 - vec2(dot(x3,x3), dot(x4,x4) ), 0.0);\\n m0 = m0 * m0;\\n m1 = m1 * m1;\\n return 49.0 * ( dot(m0*m0, vec3( dot( p0, x0 ), dot( p1, x1 ), dot( p2, x2 )))\\n + dot(m1*m1, vec2( dot( p3, x3 ), dot( p4, x4 ) ) ) ) ;\\n\\n}\\n\\nvec3 snoiseVec3( vec4 x ){\\n float s = snoise(vec4( x ));\\n float s1 = snoise(vec4( x.y - 19.1 , x.z + 33.4 , x.x + 47.2, x.w ));\\n float s2 = snoise(vec4( x.z + 74.2 , x.x - 124.5 , x.y + 99.4, x.w ));\\n vec3 c = vec3( s , s1 , s2 );\\n return c;\\n\\n}\\n\\n\\nvec3 curlNoise( vec4 p ){\\n \\n const float e = .1;\\n vec3 dx = vec3( e , 0.0 , 0.0 );\\n vec3 dy = vec3( 0.0 , e , 0.0 );\\n vec3 dz = vec3( 0.0 , 0.0 , e );\\n\\n vec3 p_x0 = snoiseVec3( vec4(p.xyz - dx, p.w) );\\n vec3 p_x1 = snoiseVec3( vec4(p.xyz + dx, p.w) );\\n vec3 p_y0 = snoiseVec3( vec4(p.xyz - dy, p.w) );\\n vec3 p_y1 = snoiseVec3( vec4(p.xyz + dy, p.w) );\\n vec3 p_z0 = snoiseVec3( vec4(p.xyz - dz, p.w) );\\n vec3 p_z1 = snoiseVec3( vec4(p.xyz + dz, p.w) );\\n\\n float x = p_y1.z - p_y0.z - p_z1.y + p_z0.y;\\n float y = p_z1.x - p_z0.x - p_x1.z + p_x0.z;\\n float z = p_x1.y - p_x0.y - p_y1.x + p_y0.x;\\n\\n const float divisor = 1.0 / ( 2.0 * e );\\n return normalize( vec3( x , y , z ) * divisor );\\n\\n}\\n\\nfloat radius = 0.5;\\n\\nvoid main() {\\n float y = 1. - (vertexId / float(vertexCount - 1.)) * 2.;\\n float r = sqrt(1. - y * y) * resolution.y/resolution.x * radius;\\n y *= radius;\\n\\n float theta = phi * vertexId;\\n\\n float x = cos(theta) * r;\\n float z = sin(theta) * r;\\n \\n vec3 pos = vec3(x,y,z);\\n vec3 n = curlNoise(vec4(pos, time* 0.5));\\n float n1 = snoise(vec4(n, time*0.5));\\n pos += pow(n, vec3(10.))*0.1;\\n pos *= 1.+n1*.2;\\n gl_Position = vec4(pos, 1.);\\n v_color = vec4(vec3(sqrt(-pos.z)*(1.+n1)), 0.1);\\n}\"}", + "settings": { + "num": 17442, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define phi PI * (3. - sqrt(5.))\n\n//\tSimplex 4D Noise \n//\tby Ian McEwan, Ashima Arts\n//\nvec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\nfloat permute(float x){return floor(mod(((x*34.0)+1.0)*x, 289.0));}\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\nfloat taylorInvSqrt(float r){return 1.79284291400159 - 0.85373472095314 * r;}\n\nvec4 grad4(float j, vec4 ip){\n const vec4 ones = vec4(1.0, 1.0, 1.0, -1.0);\n vec4 p,s;\n\n p.xyz = floor( fract (vec3(j) * ip.xyz) * 7.0) * ip.z - 1.0;\n p.w = 1.5 - dot(abs(p.xyz), ones.xyz);\n s = vec4(lessThan(p, vec4(0.0)));\n p.xyz = p.xyz + (s.xyz*2.0 - 1.0) * s.www; \n\n return p;\n}\n\nfloat snoise(vec4 v){\n const vec2 C = vec2( 0.138196601125010504, // (5 - sqrt(5))/20 G4\n 0.309016994374947451); // (sqrt(5) - 1)/4 F4\n// First corner\n vec4 i = floor(v + dot(v, C.yyyy) );\n vec4 x0 = v - i + dot(i, C.xxxx);\n\n// Other corners\n\n// Rank sorting originally contributed by Bill Licea-Kane, AMD (formerly ATI)\n vec4 i0;\n\n vec3 isX = step( x0.yzw, x0.xxx );\n vec3 isYZ = step( x0.zww, x0.yyz );\n// i0.x = dot( isX, vec3( 1.0 ) );\n i0.x = isX.x + isX.y + isX.z;\n i0.yzw = 1.0 - isX;\n\n// i0.y += dot( isYZ.xy, vec2( 1.0 ) );\n i0.y += isYZ.x + isYZ.y;\n i0.zw += 1.0 - isYZ.xy;\n\n i0.z += isYZ.z;\n i0.w += 1.0 - isYZ.z;\n\n // i0 now contains the unique values 0,1,2,3 in each channel\n vec4 i3 = clamp( i0, 0.0, 1.0 );\n vec4 i2 = clamp( i0-1.0, 0.0, 1.0 );\n vec4 i1 = clamp( i0-2.0, 0.0, 1.0 );\n\n // x0 = x0 - 0.0 + 0.0 * C \n vec4 x1 = x0 - i1 + 1.0 * C.xxxx;\n vec4 x2 = x0 - i2 + 2.0 * C.xxxx;\n vec4 x3 = x0 - i3 + 3.0 * C.xxxx;\n vec4 x4 = x0 - 1.0 + 4.0 * C.xxxx;\n\n// Permutations\n i = mod(i, 289.0); \n float j0 = permute( permute( permute( permute(i.w) + i.z) + i.y) + i.x);\n vec4 j1 = permute( permute( permute( permute (\n i.w + vec4(i1.w, i2.w, i3.w, 1.0 ))\n + i.z + vec4(i1.z, i2.z, i3.z, 1.0 ))\n + i.y + vec4(i1.y, i2.y, i3.y, 1.0 ))\n + i.x + vec4(i1.x, i2.x, i3.x, 1.0 ));\n// Gradients\n// ( 7*7*6 points uniformly over a cube, mapped onto a 4-octahedron.)\n// 7*7*6 = 294, which is close to the ring size 17*17 = 289.\n\n vec4 ip = vec4(1.0/294.0, 1.0/49.0, 1.0/7.0, 0.0) ;\n\n vec4 p0 = grad4(j0, ip);\n vec4 p1 = grad4(j1.x, ip);\n vec4 p2 = grad4(j1.y, ip);\n vec4 p3 = grad4(j1.z, ip);\n vec4 p4 = grad4(j1.w, ip);\n\n// Normalise gradients\n vec4 norm = taylorInvSqrt(vec4(dot(p0,p0), dot(p1,p1), dot(p2, p2), dot(p3,p3)));\n p0 *= norm.x;\n p1 *= norm.y;\n p2 *= norm.z;\n p3 *= norm.w;\n p4 *= taylorInvSqrt(dot(p4,p4));\n\n// Mix contributions from the five corners\n vec3 m0 = max(0.6 - vec3(dot(x0,x0), dot(x1,x1), dot(x2,x2)), 0.0);\n vec2 m1 = max(0.6 - vec2(dot(x3,x3), dot(x4,x4) ), 0.0);\n m0 = m0 * m0;\n m1 = m1 * m1;\n return 49.0 * ( dot(m0*m0, vec3( dot( p0, x0 ), dot( p1, x1 ), dot( p2, x2 )))\n + dot(m1*m1, vec2( dot( p3, x3 ), dot( p4, x4 ) ) ) ) ;\n\n}\n\nvec3 snoiseVec3( vec4 x ){\n float s = snoise(vec4( x ));\n float s1 = snoise(vec4( x.y - 19.1 , x.z + 33.4 , x.x + 47.2, x.w ));\n float s2 = snoise(vec4( x.z + 74.2 , x.x - 124.5 , x.y + 99.4, x.w ));\n vec3 c = vec3( s , s1 , s2 );\n return c;\n\n}\n\n\nvec3 curlNoise( vec4 p ){\n \n const float e = .1;\n vec3 dx = vec3( e , 0.0 , 0.0 );\n vec3 dy = vec3( 0.0 , e , 0.0 );\n vec3 dz = vec3( 0.0 , 0.0 , e );\n\n vec3 p_x0 = snoiseVec3( vec4(p.xyz - dx, p.w) );\n vec3 p_x1 = snoiseVec3( vec4(p.xyz + dx, p.w) );\n vec3 p_y0 = snoiseVec3( vec4(p.xyz - dy, p.w) );\n vec3 p_y1 = snoiseVec3( vec4(p.xyz + dy, p.w) );\n vec3 p_z0 = snoiseVec3( vec4(p.xyz - dz, p.w) );\n vec3 p_z1 = snoiseVec3( vec4(p.xyz + dz, p.w) );\n\n float x = p_y1.z - p_y0.z - p_z1.y + p_z0.y;\n float y = p_z1.x - p_z0.x - p_x1.z + p_x0.z;\n float z = p_x1.y - p_x0.y - p_y1.x + p_y0.x;\n\n const float divisor = 1.0 / ( 2.0 * e );\n return normalize( vec3( x , y , z ) * divisor );\n\n}\n\nfloat radius = 0.5;\n\nvoid main() {\n float y = 1. - (vertexId / float(vertexCount - 1.)) * 2.;\n float r = sqrt(1. - y * y) * resolution.y/resolution.x * radius;\n y *= radius;\n\n float theta = phi * vertexId;\n\n float x = cos(theta) * r;\n float z = sin(theta) * r;\n \n vec3 pos = vec3(x,y,z);\n vec3 n = curlNoise(vec4(pos, time* 0.5));\n float n1 = snoise(vec4(n, time*0.5));\n pos += pow(n, vec3(10.))*0.1;\n pos *= 1.+n1*.2;\n gl_Position = vec4(pos, 1.);\n v_color = vec4(vec3(sqrt(-pos.z)*(1.+n1)), 0.1);\n}" + }, "screenshotURL": "data/images/images-yd5t6llew6sj0q4ad-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FuHqi38wkbaQc4shv/art.json b/art/FuHqi38wkbaQc4shv/art.json index 3f8a2fde..b00c439e 100644 --- a/art/FuHqi38wkbaQc4shv/art.json +++ b/art/FuHqi38wkbaQc4shv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n \\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n \n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-7zwzs9elgw63xoqtn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FuT3HckGWwv5PxkNP/art.json b/art/FuT3HckGWwv5PxkNP/art.json index 9c83047f..5222382e 100644 --- a/art/FuT3HckGWwv5PxkNP/art.json +++ b/art/FuT3HckGWwv5PxkNP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/gscottcorey/sets/amphibian?si=41cf35a9260c4e2db7672d59451e9277\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.93) +\\n sin(t*0.311+i) +\\n sin(t*0.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*0.4+i*1.393-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.653-2.1) +\\n sin(t*0.311+i*1.1-2.1) +\\n sin(t*0.4+i*1.23+9.1) +\\n sin(t*0.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*1900.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -210.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,3.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .07;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-89))*.3+.7,1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/gscottcorey/sets/amphibian?si=41cf35a9260c4e2db7672d59451e9277", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.93) +\n sin(t*0.311+i) +\n sin(t*0.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*0.4+i*1.393-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.653-2.1) +\n sin(t*0.311+i*1.1-2.1) +\n sin(t*0.4+i*1.23+9.1) +\n sin(t*0.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*1900.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -210.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,3.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .07;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-89))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-o0m773xt4pt38ksqf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FucZXqgfuHN6wAZop/art.json b/art/FucZXqgfuHN6wAZop/art.json index 305e0ce0..4741b7dd 100644 --- a/art/FucZXqgfuHN6wAZop/art.json +++ b/art/FucZXqgfuHN6wAZop/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "piotr", "avatarUrl": "https://lh6.googleusercontent.com/-Rw7eaPICZuo/AAAAAAAAAAI/AAAAAAAAAAA/MqR-6QOwK5Q/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/snakebeats-1/bonus-bgc-warszawski-luj\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "https://soundcloud.com/snakebeats-1/bonus-bgc-warszawski-luj", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-kwl9b8a3dnxwi0boc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/FufiW6ZAC4tzCrSqe/art.json b/art/FufiW6ZAC4tzCrSqe/art.json index 2f0a9a59..36c46801 100644 --- a/art/FufiW6ZAC4tzCrSqe/art.json +++ b/art/FufiW6ZAC4tzCrSqe/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Making A Grid exercise\\n//2022 spring\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float xPos = ux/2. + sin(time);\\n \\n gl_Position = vec4( xPos,vy/2. ,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n if(xPos < 0.){\\n \\t v_color = vec4(1,0,mouse.x,1);\\n }else {\\n v_color = vec4(0,1,mouse.x,1);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Making A Grid exercise\n//2022 spring\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float xPos = ux/2. + sin(time);\n \n gl_Position = vec4( xPos,vy/2. ,0,1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n if(xPos < 0.){\n \t v_color = vec4(1,0,mouse.x,1);\n }else {\n v_color = vec4(0,1,mouse.x,1);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-8wjdikks5oxu2m9nr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FvWzPMiZrdqtgEJHY/art.json b/art/FvWzPMiZrdqtgEJHY/art.json index 6d292484..98dff144 100644 --- a/art/FvWzPMiZrdqtgEJHY/art.json +++ b/art/FvWzPMiZrdqtgEJHY/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":500,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 perspective(in float fovy, in float aspect, in float near, in float far) {\\n float top = near * tan(radians(fovy * 0.5));\\n float right = top * aspect;\\n float u = right * 2.0;\\n float v = top * 2.0;\\n float w = far - near;\\n return mat4(\\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \\n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \\n -(far + near) / w, -1.0, 0.0, 0.0,\\n -(far * near * 2.0) / w, 0.0\\n ); \\n}\\n\\nfloat hash(in float n) {\\n return fract(sin(n)*753.5453123);\\n}\\n \\nvec3 hash31(in float n) {\\n return vec3(hash(n * 0.123), hash(n * 0.456), hash(n * 0.789)); \\n} \\n\\nvoid main() {\\n\\tmat4 pMatrix = perspective(45.0, resolution.x/resolution.y, 0.1, 100.0);\\n \\tmat4 vMatrix = mat4(1.0);\\n \\tvMatrix[3].z = -3.5; \\n vec3 p = hash31(vertexId * 12.12 + 34.34) * 2.0 - 1.0;\\n vec3 v = hash31(vertexId * 56.56 + 78.78) * 2.0 - 1.0;\\n \\tp = abs(fract(p + v * time * 0.3) * 2.0 - 1.0) * 2.0 - 1.0;\\n \\tgl_Position = pMatrix *vMatrix * vec4(p, 1.0);\\n \\tgl_PointSize = 50.0 / pow(gl_Position.w, 2.0); \\n \\tvec3 col = hsv2rgb(vec3(hash(vertexId * 567.123), 0.5, 0.8));\\n \\tv_color = vec4(col, 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 500, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 perspective(in float fovy, in float aspect, in float near, in float far) {\n float top = near * tan(radians(fovy * 0.5));\n float right = top * aspect;\n float u = right * 2.0;\n float v = top * 2.0;\n float w = far - near;\n return mat4(\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \n -(far + near) / w, -1.0, 0.0, 0.0,\n -(far * near * 2.0) / w, 0.0\n ); \n}\n\nfloat hash(in float n) {\n return fract(sin(n)*753.5453123);\n}\n \nvec3 hash31(in float n) {\n return vec3(hash(n * 0.123), hash(n * 0.456), hash(n * 0.789)); \n} \n\nvoid main() {\n\tmat4 pMatrix = perspective(45.0, resolution.x/resolution.y, 0.1, 100.0);\n \tmat4 vMatrix = mat4(1.0);\n \tvMatrix[3].z = -3.5; \n vec3 p = hash31(vertexId * 12.12 + 34.34) * 2.0 - 1.0;\n vec3 v = hash31(vertexId * 56.56 + 78.78) * 2.0 - 1.0;\n \tp = abs(fract(p + v * time * 0.3) * 2.0 - 1.0) * 2.0 - 1.0;\n \tgl_Position = pMatrix *vMatrix * vec4(p, 1.0);\n \tgl_PointSize = 50.0 / pow(gl_Position.w, 2.0); \n \tvec3 col = hsv2rgb(vec3(hash(vertexId * 567.123), 0.5, 0.8));\n \tv_color = vec4(col, 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-iw5tw2hxsnowabvg7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Fx9jpEFb8X6WPRBT9/art.json b/art/Fx9jpEFb8X6WPRBT9/art.json index 196e68f6..bbe98455 100644 --- a/art/Fx9jpEFb8X6WPRBT9/art.json +++ b/art/Fx9jpEFb8X6WPRBT9/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chrisbartholomew", "avatarUrl": "https://secure.gravatar.com/avatar/42e5115d7d012ab147b9b06bc0759073?default=retro&size=200", - "settings": "{\"num\":245,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float horiz = floor(sqrt(vertexCount));\\n float vertic = floor(sqrt(vertexCount)) ; \\n float x = mod(vertexId, horiz);\\n float y = floor(vertexId / vertic);\\n \\n float u = x / (horiz - 1.) ;\\n float v = y / (vertic - 1.) ;\\n \\n float ux = u * 2. - 1. ; \\n float vy = v * 2. - 1. ; \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = floor(sqrt(vertexCount)); \\n v_color = vec4(1, 0, 0, 1);\\n} \\n\\n \\n \"}", + "settings": { + "num": 245, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float horiz = floor(sqrt(vertexCount));\n float vertic = floor(sqrt(vertexCount)) ; \n float x = mod(vertexId, horiz);\n float y = floor(vertexId / vertic);\n \n float u = x / (horiz - 1.) ;\n float v = y / (vertic - 1.) ;\n \n float ux = u * 2. - 1. ; \n float vy = v * 2. - 1. ; \n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = floor(sqrt(vertexCount)); \n v_color = vec4(1, 0, 0, 1);\n} \n\n \n " + }, "screenshotURL": "data/images/images-nltiey2ds1p50vdll-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/FxDGfLNG4kMa6DAGa/art.json b/art/FxDGfLNG4kMa6DAGa/art.json index e97f1758..adea22b9 100644 --- a/art/FxDGfLNG4kMa6DAGa/art.json +++ b/art/FxDGfLNG4kMa6DAGa/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-after-dark-043-may-2018-on-frisky-radio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.10588235294117647,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n\\n float qqu = floor(qu * 8.) / 8.;\\n float qqv = floor(qv * 8.) / 8.;\\n float dqu = qqu + (1./16.) - qu;\\n float dqv = qqv + (1./16.) - qv;\\n float dist = length(vec2(dqu, dqv) * 8. - vec2(0.));\\n \\n float qid = hash(qqu / .8 + qqv);\\n float ss = texture2D(sound, vec2(qid * .25, dist * .1)).a;\\n float pop = step(0.6, ss);\\n// val = mix(val, 1., pop);\\n// hue = mix(hue, hue + .5, pop);\\n \\n float hue = 0.6 + qid + p.y * 0.1;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = pow(ss + .3, 15.); mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-after-dark-043-may-2018-on-frisky-radio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.10588235294117647, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n\n float qqu = floor(qu * 8.) / 8.;\n float qqv = floor(qv * 8.) / 8.;\n float dqu = qqu + (1./16.) - qu;\n float dqv = qqv + (1./16.) - qv;\n float dist = length(vec2(dqu, dqv) * 8. - vec2(0.));\n \n float qid = hash(qqu / .8 + qqv);\n float ss = texture2D(sound, vec2(qid * .25, dist * .1)).a;\n float pop = step(0.6, ss);\n// val = mix(val, 1., pop);\n// hue = mix(hue, hue + .5, pop);\n \n float hue = 0.6 + qid + p.y * 0.1;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = pow(ss + .3, 15.); mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-q92xr3agj06m5bcat-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/G2qYBmuQs2cA7C4ze/art.json b/art/G2qYBmuQs2cA7C4ze/art.json index 16cb831d..ebb619af 100644 --- a/art/G2qYBmuQs2cA7C4ze/art.json +++ b/art/G2qYBmuQs2cA7C4ze/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .131), h(s * .119)) * 1. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .131), h(s * .119)) * 1. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-16qy3qcvp5qha4e5c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/G3infoeL8fLc5SiDQ/art.json b/art/G3infoeL8fLc5SiDQ/art.json index 73088d47..287be94d 100644 --- a/art/G3infoeL8fLc5SiDQ/art.json +++ b/art/G3infoeL8fLc5SiDQ/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rand(vec2 co){\\n return fract(sin(dot(co.xy, vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main() {\\n float n = vertexId / vertexCount;\\n float pointSize = n * 3.0;\\n float width = 5.0;\\n float height = 5.0;\\n float randomX = rand(vec2(vertexId, 5.0));\\n float randomY = rand(vec2(vertexId, 10.0));\\n \\n float xOff = cos(time * n) * 0.25;\\n float yOff = sin(time * n * n) * 0.3 * n;\\n \\n float x = randomX * width + xOff;\\n float y = height * randomY + yOff;\\n \\n gl_Position = vec4(x - 1.0, y - 1.0, 0.0, 1.0);\\n gl_PointSize = pointSize;\\n v_color = vec4(n, cos(time), n, 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rand(vec2 co){\n return fract(sin(dot(co.xy, vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main() {\n float n = vertexId / vertexCount;\n float pointSize = n * 3.0;\n float width = 5.0;\n float height = 5.0;\n float randomX = rand(vec2(vertexId, 5.0));\n float randomY = rand(vec2(vertexId, 10.0));\n \n float xOff = cos(time * n) * 0.25;\n float yOff = sin(time * n * n) * 0.3 * n;\n \n float x = randomX * width + xOff;\n float y = height * randomY + yOff;\n \n gl_Position = vec4(x - 1.0, y - 1.0, 0.0, 1.0);\n gl_PointSize = pointSize;\n v_color = vec4(n, cos(time), n, 1.0);\n}" + }, "screenshotURL": "data/images/images-rflk23r1ord67f6ss-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/G3kr88RT488uLRBzW/art.json b/art/G3kr88RT488uLRBzW/art.json index f4df7ac1..4a710890 100644 --- a/art/G3kr88RT488uLRBzW/art.json +++ b/art/G3kr88RT488uLRBzW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "makavelli3145", "avatarUrl": "https://avatars.githubusercontent.com/makavelli3145?s=200", - "settings": "{\"num\":2340,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/mouthofvigilance/womb-handsaloof?in=mouthofvigilance/sets/handsaloof\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n/*\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}*/\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 30.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 2340, + "mode": "LINES", + "sound": "https://soundcloud.com/mouthofvigilance/womb-handsaloof?in=mouthofvigilance/sets/handsaloof", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n/*\n#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}*/\n#define PI radians(180.)\n#define NUM_SEGMENTS 30.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-zlo50q2liksxu5lyb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/G44HeacsoBQDo4MFC/art.json b/art/G44HeacsoBQDo4MFC/art.json index 8033c6bd..b810fb94 100644 --- a/art/G44HeacsoBQDo4MFC/art.json +++ b/art/G44HeacsoBQDo4MFC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main(){\\n float across = 10.;\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / across;\\n float v = y / across;\\n \\n gl_Position = vec4(u,v,0,1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main(){\n float across = 10.;\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / across;\n float v = y / across;\n \n gl_Position = vec4(u,v,0,1);\n gl_PointSize = 10.0;\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-weyl6r771b2keqi5z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/G52W2EuQGvzn2m9mT/art.json b/art/G52W2EuQGvzn2m9mT/art.json index c7c5d17f..6bee633e 100644 --- a/art/G52W2EuQGvzn2m9mT/art.json +++ b/art/G52W2EuQGvzn2m9mT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":281,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float id = vertexId;\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux * radians(180.0) / (vertexCount * sin(time) * 0.005);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy;\\n \\n float a = resolution.x / resolution.y;\\n \\n float x = c * radius / a;\\n float y = s * radius;\\n \\n vec2 xy = vec2(x,y);\\n gl_Position = vec4(xy* .5, 0, 1);\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 281, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float id = vertexId;\n \n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux * radians(180.0) / (vertexCount * sin(time) * 0.005);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy;\n \n float a = resolution.x / resolution.y;\n \n float x = c * radius / a;\n float y = s * radius;\n \n vec2 xy = vec2(x,y);\n gl_Position = vec4(xy* .5, 0, 1);\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-mpgjex459hp0jz7id-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/G6MPufoeDCrfmHjqf/art.json b/art/G6MPufoeDCrfmHjqf/art.json index 114175b4..466d4cc2 100644 --- a/art/G6MPufoeDCrfmHjqf/art.json +++ b/art/G6MPufoeDCrfmHjqf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"http://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n#define kp1 1.//KParameter 0.>>10.\\n#define kp2 2.//KParameter 0.>>5.\\n#define kp3 -.5//KParameter -4.>>22.\\n#define P4 1.//KParameter -1.>>8.\\n//KVertices_Number=10000\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, -1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = .3 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, .71);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis)*P4;\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0.201/sin(kp1*snd),\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\\n\\treturn fract(p2.x * p2.y * 95.4337)*12.;\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v+s;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5)*v; \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.3);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n float vertexCount = 1666. *kp1;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * 2.);\\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -0.7));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1.1, 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat*snd, val*snd));\\n v_color = vec4(color * (dot(n, lightDir) * 0.165 + 0.5), pow(snd, 3.*P4));\\n v_color.rgb /= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "http://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n#define kp1 1.//KParameter 0.>>10.\n#define kp2 2.//KParameter 0.>>5.\n#define kp3 -.5//KParameter -4.>>22.\n#define P4 1.//KParameter -1.>>8.\n//KVertices_Number=10000\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, -1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = .3 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 3., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, .71);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis)*P4;\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0.201/sin(kp1*snd),\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\n\treturn fract(p2.x * p2.y * 95.4337)*12.;\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v+s;\n float z = 0.;\n pos = vec3(x, y, z-0.5)*v; \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.3);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n float vertexCount = 1666. *kp1;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * 2.);\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -0.7));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1.1, 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat*snd, val*snd));\n v_color = vec4(color * (dot(n, lightDir) * 0.165 + 0.5), pow(snd, 3.*P4));\n v_color.rgb /= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-2vnism27eqjmmqnzl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/G6uv6rnTuzAgmHniY/art.json b/art/G6uv6rnTuzAgmHniY/art.json index 81e201f0..af69cd62 100644 --- a/art/G6uv6rnTuzAgmHniY/art.json +++ b/art/G6uv6rnTuzAgmHniY/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":92244,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/huilo-1/amon-tobin-bedtime-stories\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.45098039215686275,1,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.0, 0.0, p1m1(sin(goop(circleId) + time * 0.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.03 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2. - 1.)) * 0.05, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.03) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.5, 0.6, fract(circleId * 0.79));\\n float sat = 0.5;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 15.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 92244, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/huilo-1/amon-tobin-bedtime-stories", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.45098039215686275, + 1, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.0, 0.0, p1m1(sin(goop(circleId) + time * 0.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.03 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2. - 1.)) * 0.05, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.03) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.5, 0.6, fract(circleId * 0.79));\n float sat = 0.5;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 15.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-xc9xupidzadldm94e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/G75PEGQA9JzRQKx4s/art.json b/art/G75PEGQA9JzRQKx4s/art.json index 322267b0..de9fbd88 100644 --- a/art/G75PEGQA9JzRQKx4s/art.json +++ b/art/G75PEGQA9JzRQKx4s/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":22102,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5725490196078431,0.5725490196078431,0.5725490196078431,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hash3(vec3 v) {\\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x;\\n rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 0.80) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\\n * vec4(p, 1.0);\\n return pp.xyz;\\n}\\n\\nvec3 lissajous(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\\n#define kCubeVertexCount 36.0\\nvec3 cubeVertex(float vid, out vec4 ni) {\\n float faceId = floor(vid / 6.0);\\n float vtxId = mod(vid, 6.0);\\n vec2 fp;\\n vec3 p;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n // front\\n p = vec3(fp.x, fp.y, 1.0);\\n ni = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n // back\\n p = vec3(-fp.x, fp.y, -1.0);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n // top\\n p = vec3(fp.x, 1.0, -fp.y);\\n ni = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n // bottom\\n p = vec3(fp.x, -1.0, fp.y);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n // right\\n p = vec3(-1.0, fp.y, -fp.x);\\n ni = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n // left\\n p = vec3(1.0, fp.y, fp.x);\\n ni = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return p;\\n}\\n\\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(n, lit)) * (1.0 - amb) + amb;\\n \\n vec3 h = normalize(normalize(eye - p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.0, pow(dot(n, h), spec.x));\\n }\\n \\n rgb = diffuse * dfscol + specular * spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kCubeVertexCount);\\n float shapeId = floor(vertexId / kCubeVertexCount);\\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\\n float lineId = mod(shapeId, 3.0);\\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 0.0) {\\n lineFactor = vec3(4.1, 6.7, 2.3);\\n color = vec3(1.0, 0.0, 0.0);\\n }\\n else if(lineId == 1.0) {\\n lineFactor = vec3(4.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(0.0, 0.0, 1.0);\\n }\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 cubeni;\\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.04;\\n \\n vec3 cubeHash = hash3(vec3(log(shapeId)));\\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\\n \\n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\\n \\n cubep = lissajous(lineFactor, (t + time * 0.1) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\\n \\n /*\\n if(cubeni.w == 0.0) {\\n color = vec3(1.0, 0.0, 0.0);\\n }\\n else if(cubeni.w == 1.0) {\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else if(cubeni.w == 2.0) {\\n color = vec3(0.0, 0.0, 1.0);\\n }\\n else if(cubeni.w == 3.0) {\\n color = vec3(1.0, 1.0, 0.0);\\n }\\n else if(cubeni.w == 4.0) {\\n color = vec3(1.0, 0.0, 1.0);\\n }\\n else {\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n */\\n \\n //vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.0), -mouse.x * 2.0), mouse.y);\\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.05), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 22102, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5725490196078431, + 0.5725490196078431, + 0.5725490196078431, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hash3(vec3 v) {\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x;\n rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 0.80) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\n * vec4(p, 1.0);\n return pp.xyz;\n}\n\nvec3 lissajous(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\n#define kCubeVertexCount 36.0\nvec3 cubeVertex(float vid, out vec4 ni) {\n float faceId = floor(vid / 6.0);\n float vtxId = mod(vid, 6.0);\n vec2 fp;\n vec3 p;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n // front\n p = vec3(fp.x, fp.y, 1.0);\n ni = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n // back\n p = vec3(-fp.x, fp.y, -1.0);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n // top\n p = vec3(fp.x, 1.0, -fp.y);\n ni = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n // bottom\n p = vec3(fp.x, -1.0, fp.y);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 4.0) {\n // right\n p = vec3(-1.0, fp.y, -fp.x);\n ni = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n // left\n p = vec3(1.0, fp.y, fp.x);\n ni = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return p;\n}\n\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(n, lit)) * (1.0 - amb) + amb;\n \n vec3 h = normalize(normalize(eye - p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.0, pow(dot(n, h), spec.x));\n }\n \n rgb = diffuse * dfscol + specular * spec.y;\n \n return rgb;\n}\n\nvoid main() {\n float shapeCount = floor(vertexCount / kCubeVertexCount);\n float shapeId = floor(vertexId / kCubeVertexCount);\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\n float lineId = mod(shapeId, 3.0);\n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 0.0) {\n lineFactor = vec3(4.1, 6.7, 2.3);\n color = vec3(1.0, 0.0, 0.0);\n }\n else if(lineId == 1.0) {\n lineFactor = vec3(4.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(0.0, 0.0, 1.0);\n }\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 cubeni;\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.04;\n \n vec3 cubeHash = hash3(vec3(log(shapeId)));\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\n \n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\n \n cubep = lissajous(lineFactor, (t + time * 0.1) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\n \n /*\n if(cubeni.w == 0.0) {\n color = vec3(1.0, 0.0, 0.0);\n }\n else if(cubeni.w == 1.0) {\n color = vec3(0.0, 1.0, 0.0);\n }\n else if(cubeni.w == 2.0) {\n color = vec3(0.0, 0.0, 1.0);\n }\n else if(cubeni.w == 3.0) {\n color = vec3(1.0, 1.0, 0.0);\n }\n else if(cubeni.w == 4.0) {\n color = vec3(1.0, 0.0, 1.0);\n }\n else {\n color = vec3(0.0, 1.0, 1.0);\n }\n */\n \n //vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.0), -mouse.x * 2.0), mouse.y);\n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.05), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-03l6o4bw8l0a1f7ms-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/G86ZR9sbc4BB8uW3m/art.json b/art/G86ZR9sbc4BB8uW3m/art.json index 64263870..50c86e44 100644 --- a/art/G86ZR9sbc4BB8uW3m/art.json +++ b/art/G86ZR9sbc4BB8uW3m/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10128,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 1.0;\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\n// sea\\nconst int ITER_GEOMETRY = 3;\\nconst int ITER_FRAGMENT = 5;\\nconst float SEA_HEIGHT = 0.6;\\nconst float SEA_CHOPPY = 4.0;\\nconst float SEA_SPEED = 0.8;\\nconst float SEA_FREQ = 0.16;\\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\\n#define SEA_TIME (1.0 + iTime * SEA_SPEED)\\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54031230, -0.84147 );\\n\\n\\nfloat hash( vec2 p ) {\\n\\tfloat h = dot(p,vec2(127.1,311.7));\\t\\n return fract(sin(h)*43758.5453123);\\n}\\nfloat noise( in vec2 p ) {\\n vec2 i = floor( p );\\n vec2 f = fract( p );\\t\\n\\tvec2 u = f*f*(3.0-2.0*f);\\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \\n hash( i + vec2(1.0,0.0) ), u.x),\\n mix( hash( i + vec2(0.0,1.0) ), \\n hash( i + vec2(1.0,1.0) ), u.x), u.y);\\n}\\nfloat fbm( vec2 uv, float choppy )\\n{\\n uv += noise(uv); \\n vec2 wv = 1.0-abs(sin(uv));\\n vec2 swv = abs(cos(uv)); \\n wv = mix(wv,swv,wv);\\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\\n}\\nfloat map(vec3 p) {\\n float freq = SEA_FREQ;\\n float amp = SEA_HEIGHT;\\n float choppy = SEA_CHOPPY;\\n vec2 uv = p.xz; uv.x *= 0.75;\\n \\n float d, h = 0.0; \\n for(int i = 0; i < ITER_GEOMETRY; i++) { \\n \\t//d = fbm((uv+SEA_TIME)*freq,SEA_CHOPPY);\\n \\t//d += fbm((uv-SEA_TIME)*freq,SEA_CHOPPY);\\n d = fbm(uv,SEA_CHOPPY);\\n \\td += fbm(uv,SEA_CHOPPY);\\n h += d * amp; \\n \\tuv *= octave_m; freq *= 1.9; amp *= 0.22;\\n choppy = mix(choppy,1.0,0.2);\\n }\\n return p.y - h;\\n}\\n\\n\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, map(vec3(x,2,y)), (-SIZE/2.0 + y) * SPACING );\\n //return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans, SEA_CHOPPY ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 10128, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 1.0;\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\n// sea\nconst int ITER_GEOMETRY = 3;\nconst int ITER_FRAGMENT = 5;\nconst float SEA_HEIGHT = 0.6;\nconst float SEA_CHOPPY = 4.0;\nconst float SEA_SPEED = 0.8;\nconst float SEA_FREQ = 0.16;\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\n#define SEA_TIME (1.0 + iTime * SEA_SPEED)\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54031230, -0.84147 );\n\n\nfloat hash( vec2 p ) {\n\tfloat h = dot(p,vec2(127.1,311.7));\t\n return fract(sin(h)*43758.5453123);\n}\nfloat noise( in vec2 p ) {\n vec2 i = floor( p );\n vec2 f = fract( p );\t\n\tvec2 u = f*f*(3.0-2.0*f);\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \n hash( i + vec2(1.0,0.0) ), u.x),\n mix( hash( i + vec2(0.0,1.0) ), \n hash( i + vec2(1.0,1.0) ), u.x), u.y);\n}\nfloat fbm( vec2 uv, float choppy )\n{\n uv += noise(uv); \n vec2 wv = 1.0-abs(sin(uv));\n vec2 swv = abs(cos(uv)); \n wv = mix(wv,swv,wv);\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\n}\nfloat map(vec3 p) {\n float freq = SEA_FREQ;\n float amp = SEA_HEIGHT;\n float choppy = SEA_CHOPPY;\n vec2 uv = p.xz; uv.x *= 0.75;\n \n float d, h = 0.0; \n for(int i = 0; i < ITER_GEOMETRY; i++) { \n \t//d = fbm((uv+SEA_TIME)*freq,SEA_CHOPPY);\n \t//d += fbm((uv-SEA_TIME)*freq,SEA_CHOPPY);\n d = fbm(uv,SEA_CHOPPY);\n \td += fbm(uv,SEA_CHOPPY);\n h += d * amp; \n \tuv *= octave_m; freq *= 1.9; amp *= 0.22;\n choppy = mix(choppy,1.0,0.2);\n }\n return p.y - h;\n}\n\n\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, map(vec3(x,2,y)), (-SIZE/2.0 + y) * SPACING );\n //return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans, SEA_CHOPPY ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-lzch6q7sevubdeu7l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GA5AfMNsPaGpaCd7b/art.json b/art/GA5AfMNsPaGpaCd7b/art.json index 7ceb6d30..67b2a5c1 100644 --- a/art/GA5AfMNsPaGpaCd7b/art.json +++ b/art/GA5AfMNsPaGpaCd7b/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":36170,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n}\"}", + "settings": { + "num": 36170, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n}" + }, "screenshotURL": "data/images/images-0vltv14uk2xqn25ie-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GBQRjtz2FMC4RcMvC/art.json b/art/GBQRjtz2FMC4RcMvC/art.json index 9a8b182e..f160424b 100644 --- a/art/GBQRjtz2FMC4RcMvC/art.json +++ b/art/GBQRjtz2FMC4RcMvC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":68590,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/ambassador21/ambassador21-sniff-your-leader-out-april-10th-2015-on-industrial-strength\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n _ _ _ _ \\n ( ) ( ) ( ) ( ) \\n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \\n( V )( o_)( _)( _)( o_)\\\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\\n \\\\_/ \\\\( /_\\\\ /_\\\\ \\\\( /_^_\\\\/__)/_\\\\||/_^_\\\\\\\\___\\\\ \\\\( /_\\\\ /_^_\\\\/_\\\\ /_\\\\ \\n \\n\\n\\n\\n*/\\n\\n\\n\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 8.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(40.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\\n \\n \\n \\n \\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = hash(u) * 0.25 + 0.1;\\n // Match each line to a specific row in the sound texture\\n float historyV = v * 0.004;\\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\\n vec2 off = vec2(\\n cos(snd1 * PI * 8.),\\n sin(snd2 * PI * 6.4));\\n\\n vec2 xy = vec2(\\n m1p1(hash(time + vertexId)),\\n m1p1(hash(time + vertexId + 1.)));\\n// snd1 * 2. - 1.,\\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\\n\\n float hue = u;\\n float sat = 0.;\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 68590, + "mode": "LINES", + "sound": "https://soundcloud.com/ambassador21/ambassador21-sniff-your-leader-out-april-10th-2015-on-industrial-strength", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n _ _ _ _ \n ( ) ( ) ( ) ( ) \n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \n( V )( o_)( _)( _)( o_)\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\n \\_/ \\( /_\\ /_\\ \\( /_^_\\/__)/_\\||/_^_\\\\___\\ \\( /_\\ /_^_\\/_\\ /_\\ \n \n\n\n\n*/\n\n\n\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 8.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(40.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\n \n \n \n \n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = hash(u) * 0.25 + 0.1;\n // Match each line to a specific row in the sound texture\n float historyV = v * 0.004;\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\n vec2 off = vec2(\n cos(snd1 * PI * 8.),\n sin(snd2 * PI * 6.4));\n\n vec2 xy = vec2(\n m1p1(hash(time + vertexId)),\n m1p1(hash(time + vertexId + 1.)));\n// snd1 * 2. - 1.,\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\n\n float hue = u;\n float sat = 0.;\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-8rhivs8wmb36t93gd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GCHbAzpPAFHCXStCn/art.json b/art/GCHbAzpPAFHCXStCn/art.json index 10d4d85c..8ef13f3c 100644 --- a/art/GCHbAzpPAFHCXStCn/art.json +++ b/art/GCHbAzpPAFHCXStCn/art.json @@ -11,7 +11,19 @@ "origId": "hhsdvkiJ32bCTcezv", "name": "blendy", "username": "-anon-", - "settings": "{\"num\":8542,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/modularpeople/the-presets-no-fun\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n gl_PointSize = 40.0;\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.04;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float r2 = sin(orbitAngle);\\n float oC = cos(orbitAngle + localTime * count * 0.01) * r2;\\n float oS = sin(orbitAngle + localTime * count * 0.01) * r2;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n\\n float dd = length(xy);\\n float snd = pow(texture2D(sound, vec2(fract(count * 0.01) * 0.25, dd * 0.1)).a, 5.0);\\n \\n xy = xy + xy * snd ;\\n gl_Position = vec4(xy * aspect + mouse * 0.1, -fract(count * 10.01), 1);\\n \\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(mix(hsv2rgb(vec3(hue + snd, 1, 1)), vec3(1,1,1), snd), 0.1 + snd * 0.5);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 8542, + "mode": "POINTS", + "sound": "https://soundcloud.com/modularpeople/the-presets-no-fun", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n gl_PointSize = 40.0;\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.04;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float r2 = sin(orbitAngle);\n float oC = cos(orbitAngle + localTime * count * 0.01) * r2;\n float oS = sin(orbitAngle + localTime * count * 0.01) * r2;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n\n float dd = length(xy);\n float snd = pow(texture2D(sound, vec2(fract(count * 0.01) * 0.25, dd * 0.1)).a, 5.0);\n \n xy = xy + xy * snd ;\n gl_Position = vec4(xy * aspect + mouse * 0.1, -fract(count * 10.01), 1);\n \n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(mix(hsv2rgb(vec3(hue + snd, 1, 1)), vec3(1,1,1), snd), 0.1 + snd * 0.5);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-yoofmit2ulo5s1yxa-thumbnail.jpg", "views": { "$numberInt": "154" diff --git a/art/GDZH8bzPmGJZX56xN/art.json b/art/GDZH8bzPmGJZX56xN/art.json index 32237507..9d2dfa9c 100644 --- a/art/GDZH8bzPmGJZX56xN/art.json +++ b/art/GDZH8bzPmGJZX56xN/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "w.chae", "avatarUrl": "https://secure.gravatar.com/avatar/e33886e1d2ddd9c8199ae2b5bbb15df9?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Wonhyeong Chae\\n// Exercise Motion\\n// CS250 Spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float angle = time * 2.0;\\n float cosAngle = cos(angle);\\n float sinAngle = sin(angle);\\n float rotatedX = ux * cosAngle - vy * sinAngle;\\n float rotatedY = ux * sinAngle + vy * cosAngle;\\n \\n gl_Position = vec4(tan(rotatedX), tan(rotatedY), 0., 1.);\\n\\n float soff = sin(time + x * y * 0.02) * 5.;\\n\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n float colorModRed = abs(sin(time * 0.5));\\n float colorModGreen = abs(tan(time * 0.5));\\n float colorModBlue = abs(cos(time * 0.5));\\n\\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Wonhyeong Chae\n// Exercise Motion\n// CS250 Spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float angle = time * 2.0;\n float cosAngle = cos(angle);\n float sinAngle = sin(angle);\n float rotatedX = ux * cosAngle - vy * sinAngle;\n float rotatedY = ux * sinAngle + vy * cosAngle;\n \n gl_Position = vec4(tan(rotatedX), tan(rotatedY), 0., 1.);\n\n float soff = sin(time + x * y * 0.02) * 5.;\n\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n float colorModRed = abs(sin(time * 0.5));\n float colorModGreen = abs(tan(time * 0.5));\n float colorModBlue = abs(cos(time * 0.5));\n\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\n}" + }, "screenshotURL": "data/images/images-0sp9becvggo36b4l8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GDrWuySq3yExsoNqR/art.json b/art/GDrWuySq3yExsoNqR/art.json index 51663b28..ea36334d 100644 --- a/art/GDrWuySq3yExsoNqR/art.json +++ b/art/GDrWuySq3yExsoNqR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daniel.shenkutie", "avatarUrl": "https://secure.gravatar.com/avatar/a88931f888921daebbcd2858d5dc3258?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.0784313725490196,0.0784313725490196,1],\"shader\":\"\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n \\n \\n \\n float accros =floor(vertexCount/ down);\\n float x = mod(vertexId,accros);\\n float y = floor(vertexId/accros);\\n float u = x/(accros -1.0);\\n float v = y/(accros -1.0);\\n \\n \\n float ux = 2.0*u -1.0;\\n float vy = 2.0*v - 1.0;\\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./ accros;\\n v_color=vec4(1,1,1,1);\\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.0784313725490196, + 0.0784313725490196, + 1 + ], + "shader": "\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n \n \n \n float accros =floor(vertexCount/ down);\n float x = mod(vertexId,accros);\n float y = floor(vertexId/accros);\n float u = x/(accros -1.0);\n float v = y/(accros -1.0);\n \n \n float ux = 2.0*u -1.0;\n float vy = 2.0*v - 1.0;\n \n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20./ accros;\n v_color=vec4(1,1,1,1);\n \n \n}" + }, "screenshotURL": "data/images/images-vhx60p9f4ff0ixtff-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GDwqy5yjHyevhi2rK/art.json b/art/GDwqy5yjHyevhi2rK/art.json index d1728cc0..715a35b0 100644 --- a/art/GDwqy5yjHyevhi2rK/art.json +++ b/art/GDwqy5yjHyevhi2rK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.20392156862745098,0.19215686274509805,0.24705882352941178,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.1));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.12;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.04;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.03 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.20392156862745098, + 0.19215686274509805, + 0.24705882352941178, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.1));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.12;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.04;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.03 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-qt7523111dkpyost4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GEtBB56A9P7F4wjdG/art.json b/art/GEtBB56A9P7F4wjdG/art.json index d6e396a8..c807fde6 100644 --- a/art/GEtBB56A9P7F4wjdG/art.json +++ b/art/GEtBB56A9P7F4wjdG/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "archer", "avatarUrl": "https://lh5.googleusercontent.com/-yNdyToHV35U/AAAAAAAAAAI/AAAAAAAABxw/qQAHdzq4gr8/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.\\n#define NUM_POINTS (NUM_SEGMENTS * 2.)\\n#define STEP 1.\\n\\nvec4 quatFromAxisAngle(vec3 axis, float angle) {\\n vec4 qr;\\n \\n float half_angle = angle/2.;\\n qr.x = axis.x * sin(half_angle);\\n qr.y = axis.y * sin(half_angle);\\n qr.z = axis.z * sin(half_angle);\\n qr.w = cos(half_angle);\\n \\n return qr;\\n}\\n\\nvec4 quatFromPos(vec3 pos) {\\n vec4 qp;\\n \\n qp.x = pos.x;\\n qp.y = pos.y;\\n qp.z = pos.z;\\n qp.w = 0.;\\n \\n return qp;\\n}\\n\\nvec4 quatInverse(vec4 q) {\\n return vec4(-q.x, -q.y, -q.z, q.w);\\n}\\n\\nvec4 quatMultiply(vec4 q1, vec4 q2) {\\n vec4 q;\\n \\n q.x = (q1.w * q2.x) + (q1.x * q2.w) + (q1.y * q2.z) - (q1.z * q2.y);\\n q.y = (q1.w * q2.y) - (q1.x * q2.z) + (q1.y * q2.w) + (q1.z * q2.x);\\n q.z = (q1.w * q2.z) + (q1.x * q2.y) - (q1.y * q2.x) + (q1.z * q2.w);\\n q.w = (q1.w * q2.w) - (q1.x * q2.x) - (q1.y * q2.y) - (q1.z * q2.z);\\n \\n return q;\\n}\\n\\nvec3 rotatePosAboutAxle(vec3 pos, vec3 axis, float angle) {\\n vec4 qr = quatFromAxisAngle(axis, angle);\\n vec4 qp = quatFromPos(pos);\\n vec4 qi = quatInverse(qr);\\n \\n vec4 qtemp = quatMultiply(qr, qp);\\n qtemp = quatMultiply(qtemp, qi);\\n \\n return qtemp.xyz;\\n}\\n\\nvec3 rotatePosXYZ(vec3 pos, vec3 angle) {\\n vec3 rotPos = vec3(pos);\\n \\n rotPos = rotatePosAboutAxle(rotPos, vec3(0, 0, 1), angle.z);\\n rotPos = rotatePosAboutAxle(rotPos, vec3(0, 1, 0), angle.y);\\n rotPos = rotatePosAboutAxle(rotPos, vec3(1, 0, 0), angle.x);\\n \\n return rotPos;\\n}\\n\\nvoid getVertInQuad(const float vert, out float quadId, out vec2 inQuadPos) {\\n \\n float inQuadId = mod(vert, 6.);\\n \\n if (inQuadId == 0.) {\\n inQuadPos = vec2(0, 0);\\n } else if (inQuadId == 1.) {\\n inQuadPos = vec2(1, 0);\\n } else if (inQuadId == 2.) {\\n inQuadPos = vec2(0, 1);\\n } else if (inQuadId == 3.) {\\n inQuadPos = vec2(1, 0);\\n } else if (inQuadId == 4.) {\\n inQuadPos = vec2(1, 1);\\n } else if (inQuadId == 5.) {\\n inQuadPos = vec2(0, 1);\\n }\\n \\n inQuadPos -= 0.5;\\n \\n quadId = floor(vert / 6.);\\n}\\n\\nvoid getQuadInBox(const float quadId, out float boxId, out vec3 quadPos, out vec3 quadAngle) {\\n boxId = floor(quadId / 6.0);\\n \\n quadAngle = vec3(0., 0., 0.);\\n \\n if (boxId == 0.) {\\n quadPos = vec3(0, 0, 1);\\n } else if (boxId == 1.) {\\n\\tquadPos = vec3(1, 0, 0);\\n quadAngle.y = PI / 2.;\\n } else if (boxId == 2.) {\\n\\tquadPos = vec3(0, 0, -1);\\n quadAngle.y = PI;\\n } else if (boxId == 3.) {\\n\\tquadPos = vec3(-1, 0, 0);\\n quadAngle.y = PI * 3. / 2.;\\n } else if (boxId == 4.) {\\n\\tquadPos = vec3(0, 1, 0);\\n quadAngle.x = PI * 3. / 2.;\\n } else if (boxId == 5.) {\\n\\tquadPos = vec3(0, -1, 0);\\n quadAngle.x = PI * 1. / 2.;\\n }\\n \\n quadPos /= 2.;\\n}\\n\\nvoid main() {\\n float quadId;\\n vec2 vertPos;\\n getVertInQuad(vertexId, quadId, vertPos);\\n \\n float boxId;\\n vec3 quadPos;\\n vec3 quadRot;\\n getQuadInBox(quadId, boxId, quadPos, quadRot);\\n \\n vec3 truePos = rotatePosXYZ(vec3(vertPos, 0.), quadRot);\\n truePos += quadPos;\\n truePos = rotatePosAboutAxle(truePos, vec3(0, 1, 1), mod(time / 5., 2. * PI));\\n truePos *= 0.1;\\n \\n truePos.z -= .5;\\n \\n gl_Position = vec4(truePos, 1.);\\n v_color = vec4(1., 1., 1., 1.);\\n}\"}", + "settings": { + "num": 100, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.\n#define NUM_POINTS (NUM_SEGMENTS * 2.)\n#define STEP 1.\n\nvec4 quatFromAxisAngle(vec3 axis, float angle) {\n vec4 qr;\n \n float half_angle = angle/2.;\n qr.x = axis.x * sin(half_angle);\n qr.y = axis.y * sin(half_angle);\n qr.z = axis.z * sin(half_angle);\n qr.w = cos(half_angle);\n \n return qr;\n}\n\nvec4 quatFromPos(vec3 pos) {\n vec4 qp;\n \n qp.x = pos.x;\n qp.y = pos.y;\n qp.z = pos.z;\n qp.w = 0.;\n \n return qp;\n}\n\nvec4 quatInverse(vec4 q) {\n return vec4(-q.x, -q.y, -q.z, q.w);\n}\n\nvec4 quatMultiply(vec4 q1, vec4 q2) {\n vec4 q;\n \n q.x = (q1.w * q2.x) + (q1.x * q2.w) + (q1.y * q2.z) - (q1.z * q2.y);\n q.y = (q1.w * q2.y) - (q1.x * q2.z) + (q1.y * q2.w) + (q1.z * q2.x);\n q.z = (q1.w * q2.z) + (q1.x * q2.y) - (q1.y * q2.x) + (q1.z * q2.w);\n q.w = (q1.w * q2.w) - (q1.x * q2.x) - (q1.y * q2.y) - (q1.z * q2.z);\n \n return q;\n}\n\nvec3 rotatePosAboutAxle(vec3 pos, vec3 axis, float angle) {\n vec4 qr = quatFromAxisAngle(axis, angle);\n vec4 qp = quatFromPos(pos);\n vec4 qi = quatInverse(qr);\n \n vec4 qtemp = quatMultiply(qr, qp);\n qtemp = quatMultiply(qtemp, qi);\n \n return qtemp.xyz;\n}\n\nvec3 rotatePosXYZ(vec3 pos, vec3 angle) {\n vec3 rotPos = vec3(pos);\n \n rotPos = rotatePosAboutAxle(rotPos, vec3(0, 0, 1), angle.z);\n rotPos = rotatePosAboutAxle(rotPos, vec3(0, 1, 0), angle.y);\n rotPos = rotatePosAboutAxle(rotPos, vec3(1, 0, 0), angle.x);\n \n return rotPos;\n}\n\nvoid getVertInQuad(const float vert, out float quadId, out vec2 inQuadPos) {\n \n float inQuadId = mod(vert, 6.);\n \n if (inQuadId == 0.) {\n inQuadPos = vec2(0, 0);\n } else if (inQuadId == 1.) {\n inQuadPos = vec2(1, 0);\n } else if (inQuadId == 2.) {\n inQuadPos = vec2(0, 1);\n } else if (inQuadId == 3.) {\n inQuadPos = vec2(1, 0);\n } else if (inQuadId == 4.) {\n inQuadPos = vec2(1, 1);\n } else if (inQuadId == 5.) {\n inQuadPos = vec2(0, 1);\n }\n \n inQuadPos -= 0.5;\n \n quadId = floor(vert / 6.);\n}\n\nvoid getQuadInBox(const float quadId, out float boxId, out vec3 quadPos, out vec3 quadAngle) {\n boxId = floor(quadId / 6.0);\n \n quadAngle = vec3(0., 0., 0.);\n \n if (boxId == 0.) {\n quadPos = vec3(0, 0, 1);\n } else if (boxId == 1.) {\n\tquadPos = vec3(1, 0, 0);\n quadAngle.y = PI / 2.;\n } else if (boxId == 2.) {\n\tquadPos = vec3(0, 0, -1);\n quadAngle.y = PI;\n } else if (boxId == 3.) {\n\tquadPos = vec3(-1, 0, 0);\n quadAngle.y = PI * 3. / 2.;\n } else if (boxId == 4.) {\n\tquadPos = vec3(0, 1, 0);\n quadAngle.x = PI * 3. / 2.;\n } else if (boxId == 5.) {\n\tquadPos = vec3(0, -1, 0);\n quadAngle.x = PI * 1. / 2.;\n }\n \n quadPos /= 2.;\n}\n\nvoid main() {\n float quadId;\n vec2 vertPos;\n getVertInQuad(vertexId, quadId, vertPos);\n \n float boxId;\n vec3 quadPos;\n vec3 quadRot;\n getQuadInBox(quadId, boxId, quadPos, quadRot);\n \n vec3 truePos = rotatePosXYZ(vec3(vertPos, 0.), quadRot);\n truePos += quadPos;\n truePos = rotatePosAboutAxle(truePos, vec3(0, 1, 1), mod(time / 5., 2. * PI));\n truePos *= 0.1;\n \n truePos.z -= .5;\n \n gl_Position = vec4(truePos, 1.);\n v_color = vec4(1., 1., 1., 1.);\n}" + }, "screenshotURL": "data/images/images-18v7oi81sokyupuma-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GG222nK5QwLhaPBqp/art.json b/art/GG222nK5QwLhaPBqp/art.json index b030c4a7..1bf98253 100644 --- a/art/GG222nK5QwLhaPBqp/art.json +++ b/art/GG222nK5QwLhaPBqp/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":80976,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/turborecordings/tiga-vs-audion-lets-go-6\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define K 1.0594630943592952645618\\n\\nvec4 hueRamp(vec4 col)\\n{\\n vec4 black = vec4(0.0,0.,0.0,1.0);\\n vec4 main = vec4(0.3,0.1,0.8,1.0);\\n vec4 result = mix(black,main,col.a*10.0-0.5);\\n return result;\\n}\\n\\nvoid main()\\n{\\n float W = 400.0;\\n float H = 250.0;\\n float u = 0.0;\\n float v = 0.0;\\n u = mod(vertexId/W,1.0);\\n v = floor(vertexId/W)/H;\\n float uScaled = pow(2.0,u*0.17)-1.0;\\n float vScaled = pow(abs(v-0.5)*1.0,1.3);\\n \\n v_color = vec4(pow(texture2D(sound,vec2(uScaled,vScaled)).a,5.0));\\n v_color = hueRamp(v_color);\\n \\n float x = v*-2.0 + 1.0;\\n float y;\\n y = u*2.0 - 0.8;\\n gl_PointSize = 12.0;\\n gl_Position = vec4(x,y,0,1);\\n}\\n\"}", + "settings": { + "num": 80976, + "mode": "POINTS", + "sound": "https://soundcloud.com/turborecordings/tiga-vs-audion-lets-go-6", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define K 1.0594630943592952645618\n\nvec4 hueRamp(vec4 col)\n{\n vec4 black = vec4(0.0,0.,0.0,1.0);\n vec4 main = vec4(0.3,0.1,0.8,1.0);\n vec4 result = mix(black,main,col.a*10.0-0.5);\n return result;\n}\n\nvoid main()\n{\n float W = 400.0;\n float H = 250.0;\n float u = 0.0;\n float v = 0.0;\n u = mod(vertexId/W,1.0);\n v = floor(vertexId/W)/H;\n float uScaled = pow(2.0,u*0.17)-1.0;\n float vScaled = pow(abs(v-0.5)*1.0,1.3);\n \n v_color = vec4(pow(texture2D(sound,vec2(uScaled,vScaled)).a,5.0));\n v_color = hueRamp(v_color);\n \n float x = v*-2.0 + 1.0;\n float y;\n y = u*2.0 - 0.8;\n gl_PointSize = 12.0;\n gl_Position = vec4(x,y,0,1);\n}\n" + }, "screenshotURL": "data/images/images-fbdbafqn9b885qva5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GKbc4tXKXpku2WT84/art.json b/art/GKbc4tXKXpku2WT84/art.json index b03f14a1..04c2df55 100644 --- a/art/GKbc4tXKXpku2WT84/art.json +++ b/art/GKbc4tXKXpku2WT84/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/newage62120/shades-of-chakra\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(crv(a0), crv(a1), 0);\\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\\n// return vec3(\\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n// 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 3000.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float qn = quadId / quadCount;\\n float ln = lineId / numLines;\\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.0, 0.1, pn))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.02, 0.12, pn))).a;\\n \\n snd0 = 0.6;\\n snd1 = 0.7;\\n// snd1 = snd0;\\n \\n float mult = .002;\\n getQuadPoint(\\n //pn + time * 0.5 + ln * .2, \\n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\\n mult,\\n pointId, \\n pow(snd0, 5.0) * 0.25, \\n vec2(\\n pow(snd0, 2.), \\n pow(snd1, 2.)), \\n pos, \\n uv); \\n \\n float across = floor(sqrt(numLines));\\n float down = floor(numLines / across);\\n float xx = mod(lineId, across);\\n float yy = floor(lineId / across);\\n float ux = xx / (across - 1.);\\n float vy = yy / (down - 1.);\\n \\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .15);\\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\\n gl_Position.xyz /= gl_Position.w;\\n gl_Position.z = -pn;\\n gl_Position.w = 1.;\\n\\n float hue = mix(0.95, 1.5, ln * 0.3 + qn * 00.) + time * 0.01;\\n float sat = 1. + sin(time) * .5;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pn);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n // v_color.a = 1.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/newage62120/shades-of-chakra", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(crv(a0), crv(a1), 0);\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\n// return vec3(\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n// 0);\n}\n\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 3000.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float qn = quadId / quadCount;\n float ln = lineId / numLines;\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.0, 0.1, pn))).a;\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.02, 0.12, pn))).a;\n \n snd0 = 0.6;\n snd1 = 0.7;\n// snd1 = snd0;\n \n float mult = .002;\n getQuadPoint(\n //pn + time * 0.5 + ln * .2, \n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\n mult,\n pointId, \n pow(snd0, 5.0) * 0.25, \n vec2(\n pow(snd0, 2.), \n pow(snd1, 2.)), \n pos, \n uv); \n \n float across = floor(sqrt(numLines));\n float down = floor(numLines / across);\n float xx = mod(lineId, across);\n float yy = floor(lineId / across);\n float ux = xx / (across - 1.);\n float vy = yy / (down - 1.);\n \n float aspect = resolution.x / resolution.y;\n \n mat4 mat = scale(vec3(1, aspect, 1) * .15);\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\n gl_Position.xyz /= gl_Position.w;\n gl_Position.z = -pn;\n gl_Position.w = 1.;\n\n float hue = mix(0.95, 1.5, ln * 0.3 + qn * 00.) + time * 0.01;\n float sat = 1. + sin(time) * .5;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pn);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n // v_color.a = 1.;\n}" + }, "screenshotURL": "data/images/images-a13x2pg5d1xdbvrt6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GKjSeb4FbAngScBTm/art.json b/art/GKjSeb4FbAngScBTm/art.json index ddddfddd..7807f05d 100644 --- a/art/GKjSeb4FbAngScBTm/art.json +++ b/art/GKjSeb4FbAngScBTm/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 1.13+mouse.x) + cos(-t* 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 11.33) + sin(time * 0.83 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n\\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + .1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 1.13+mouse.x) + cos(-t* 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 11.33) + sin(time * 0.83 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + .1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-ukba8piohggj47892-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GMo8BydtF9nZHuqcM/art.json b/art/GMo8BydtF9nZHuqcM/art.json index fc511048..2c238746 100644 --- a/art/GMo8BydtF9nZHuqcM/art.json +++ b/art/GMo8BydtF9nZHuqcM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nohell/the-juju-orchestra-take-four\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.41) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 24.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n //float s1 = texture2D(sound, vec2(mix(0.000, 0.015, hash(u * v * 0.137), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.04, hash(u * v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) * 0. + 1. + smoothstep(0.7, 1., s2) * 1.5;\\n vCubeOrigin.y += perBlock * -3.0 + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.; //quant(over, 3.) * 0.3;\\n float sat = pow(s2, 3.);step(0.75,s2);\\n float val = s2;step(0.7,s2);\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val)) * 3.;\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n float gy = goop(time);\\n float gx = goop(time * 0.371);\\n \\tvec3 vCameraTarget = vec3( gx * 10., gy * -6.8, 1.0 );\\n \\tvec3 vCameraPos = vec3(gx * 10.2, gy * -7., -0.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nohell/the-juju-orchestra-take-four", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.41) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 24.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n //float s1 = texture2D(sound, vec2(mix(0.000, 0.015, hash(u * v * 0.137), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.015, 0.04, hash(u * v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) * 0. + 1. + smoothstep(0.7, 1., s2) * 1.5;\n vCubeOrigin.y += perBlock * -3.0 + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.; //quant(over, 3.) * 0.3;\n float sat = pow(s2, 3.);step(0.75,s2);\n float val = s2;step(0.7,s2);\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val)) * 3.;\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n float gy = goop(time);\n float gx = goop(time * 0.371);\n \tvec3 vCameraTarget = vec3( gx * 10., gy * -6.8, 1.0 );\n \tvec3 vCameraPos = vec3(gx * 10.2, gy * -7., -0.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-8320phu836qa7oy9b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GNxuZLXb85Px27uwd/art.json b/art/GNxuZLXb85Px27uwd/art.json index dbf65cbd..4f4b42db 100644 --- a/art/GNxuZLXb85Px27uwd/art.json +++ b/art/GNxuZLXb85Px27uwd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️ mic version\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️ mic version\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-7fenhlws2lpn50fyf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GNybZ7r6mDiCQNAfW/art.json b/art/GNybZ7r6mDiCQNAfW/art.json index ecdc21d4..725e3158 100644 --- a/art/GNybZ7r6mDiCQNAfW/art.json +++ b/art/GNybZ7r6mDiCQNAfW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":45000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId + next) / (numSections - 1.);\\n float v = sv * 4. + base;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n #if 0\\n s = 1.;\\n s2 = 1.;\\n #endif\\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n //float width = mix(1., 2., pow(s2, .5));\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre * .4, 1)).xyz;\\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \\n \\n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n float pump = step(0.5, s2);\\n sat = mix(sat, 1., vert * pump);\\n val = mix(val, 1., vert * pump);\\n hue = mix(hue, hue + .15, vert * pump);\\n \\n //hue += sign(pre.x) * .25;\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\\n \\n //color.rgb = zaxis * .5 + .5; \\n color.a = 1. - pow(sv, 20.0);\\n color.rgb *= color.a;\\n}\\n\\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n pos = vec3(0);\\n color = vec4(0);\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * 2. * step(0.5, pId);\\n pos += cmat[1].xyz * 2. * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 10000.0;\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n if (id < numTrackPoints) {\\n track(id, numTrackPoints, base, pos, color);\\n } else {\\n id -= numTrackPoints;\\n if (id < numFunkPoints) {\\n funk(id, numFunkPoints, base, pos, color);\\n } else {\\n id -= numFunkPoints;\\n sky(id, base, cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 45000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId + next) / (numSections - 1.);\n float v = sv * 4. + base;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n #if 0\n s = 1.;\n s2 = 1.;\n #endif\n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n //float width = mix(1., 2., pow(s2, .5));\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre * .4, 1)).xyz;\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \n \n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n float pump = step(0.5, s2);\n sat = mix(sat, 1., vert * pump);\n val = mix(val, 1., vert * pump);\n hue = mix(hue, hue + .15, vert * pump);\n \n //hue += sign(pre.x) * .25;\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\n \n //color.rgb = zaxis * .5 + .5; \n color.a = 1. - pow(sv, 20.0);\n color.rgb *= color.a;\n}\n\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n pos = vec3(0);\n color = vec4(0);\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * 2. * step(0.5, pId);\n pos += cmat[1].xyz * 2. * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 10000.0;\n \n //float base = 15.; // good place to adjust\n float base = time * 0.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n if (id < numTrackPoints) {\n track(id, numTrackPoints, base, pos, color);\n } else {\n id -= numTrackPoints;\n if (id < numFunkPoints) {\n funk(id, numFunkPoints, base, pos, color);\n } else {\n id -= numFunkPoints;\n sky(id, base, cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-xzxc8pbv2yd937kre-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GPneC8Rz7k8CDKL6i/art.json b/art/GPneC8Rz7k8CDKL6i/art.json index 3d5f09b6..f0652f6e 100644 --- a/art/GPneC8Rz7k8CDKL6i/art.json +++ b/art/GPneC8Rz7k8CDKL6i/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "patrik", "avatarUrl": "https://lh6.googleusercontent.com/-KrDG70pboLE/AAAAAAAAAAI/AAAAAAAAAeo/TWpXHYT89SA/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n vec4 pos = vec4(-1.0, sin(4.0*time + vertexId * 0.005)-0.5 * 0.8, 0.0, 1.0);\\n gl_PointSize = 15.0;\\n gl_Position = pos + vertexId*0.0006;\\n v_color = vec4(mouse, pos.y, 1.0) + 0.5;\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n vec4 pos = vec4(-1.0, sin(4.0*time + vertexId * 0.005)-0.5 * 0.8, 0.0, 1.0);\n gl_PointSize = 15.0;\n gl_Position = pos + vertexId*0.0006;\n v_color = vec4(mouse, pos.y, 1.0) + 0.5;\n}" + }, "screenshotURL": "data/images/images-bd74ifwrtdjlvsddv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GRZbiaYQ5RXxaKsSA/art.json b/art/GRZbiaYQ5RXxaKsSA/art.json index 982b516d..1a13dd8c 100644 --- a/art/GRZbiaYQ5RXxaKsSA/art.json +++ b/art/GRZbiaYQ5RXxaKsSA/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":20572,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.403921568627451,0.403921568627451,0.403921568627451,1],\"shader\":\"void main()\\n{\\n \\n \\n gl_PointSize= 1. ; \\n gl_Position = vec4(1. ) ; \\n v_color = vec4(1. ) ; \\n}\"}", + "settings": { + "num": 20572, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "void main()\n{\n \n \n gl_PointSize= 1. ; \n gl_Position = vec4(1. ) ; \n v_color = vec4(1. ) ; \n}" + }, "screenshotURL": "data/images/images-dn4fav6m6ixqp77k4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GRmubu72jMXJivdL4/art.json b/art/GRmubu72jMXJivdL4/art.json index 1cc97b02..97244513 100644 --- a/art/GRmubu72jMXJivdL4/art.json +++ b/art/GRmubu72jMXJivdL4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "evilprofesseur", "avatarUrl": "https://avatars.githubusercontent.com/EvilProfesseur?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xOffset = sin(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xOffset; // switch from 0-1 to -1-1\\n float vy = v * 2. - 1. + yOffset;\\n \\n vec2 xy = vec2(ux, vy) *1.4;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float sizeOffset = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 7. + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1,v,u,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xOffset = sin(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xOffset; // switch from 0-1 to -1-1\n float vy = v * 2. - 1. + yOffset;\n \n vec2 xy = vec2(ux, vy) *1.4;\n \n gl_Position = vec4(xy, 0, 1);\n \n float sizeOffset = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 7. + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1,v,u,1);\n}" + }, "screenshotURL": "data/images/images-t1x5l5kfdoa3jf7bw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GRxBfbR6hkmf9Q3Am/art.json b/art/GRxBfbR6hkmf9Q3Am/art.json index dd70933a..2c119820 100644 --- a/art/GRxBfbR6hkmf9Q3Am/art.json +++ b/art/GRxBfbR6hkmf9Q3Am/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2158,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 11.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 2158, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 11.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-mxr4zzgx5x34krjln-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GSwqjg58RKKvcPvhZ/art.json b/art/GSwqjg58RKKvcPvhZ/art.json index 09d5640a..a2d41c3f 100644 --- a/art/GSwqjg58RKKvcPvhZ/art.json +++ b/art/GSwqjg58RKKvcPvhZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*void main(){\\n//Vector 4\\n float width = 20.0;\\n float row = 42.0 * 15.0;\\n float circleID = mod(vertexId, row);\\n \\n float y = mod(vertexId + 1.0, 2.0);\\n float x = floor(vertexId / 2.0);\\n float movx = floor(circleID/42.0) * 1.1;\\n float movy = floor(vertexId/ row) * 1.1;\\n float ang = (x/20.0)*radians(360.0);\\n float r = 2.0 - y;\\n float rx = r * cos(ang);\\n float ry = r *sin (ang);\\n \\n float u = rx / (width - 1.0);\\n float v = ry / (width - 1.0);\\n \\n float xOffset = cos(time + movy * 0.2) * 0.1;\\n float yOffset = sin(time + movx * 0.2) * 0.1;\\n \\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2 (ux + movx, uy + movy) * 0.1;\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n}*/\\n\\nvoid main() {\\n float y = mod(vertexId + 1.0, 2.0);\\n float x = floor(vertexId / 2.0);\\n float ang = (x/20.0)*radians(360.0);\\n float phi = (y/20.0)*radians(180.0);\\n float p = 0.1;\\n float rx = p * sin(phi) * cos(ang);\\n float ry = p * cos(phi) * sin (ang);\\n float rz = p * cos(phi);\\n \\n gl_Position = vec4(rx, ry, rz, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 5.0;\\n\\n}\\n\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*void main(){\n//Vector 4\n float width = 20.0;\n float row = 42.0 * 15.0;\n float circleID = mod(vertexId, row);\n \n float y = mod(vertexId + 1.0, 2.0);\n float x = floor(vertexId / 2.0);\n float movx = floor(circleID/42.0) * 1.1;\n float movy = floor(vertexId/ row) * 1.1;\n float ang = (x/20.0)*radians(360.0);\n float r = 2.0 - y;\n float rx = r * cos(ang);\n float ry = r *sin (ang);\n \n float u = rx / (width - 1.0);\n float v = ry / (width - 1.0);\n \n float xOffset = cos(time + movy * 0.2) * 0.1;\n float yOffset = sin(time + movx * 0.2) * 0.1;\n \n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2 (ux + movx, uy + movy) * 0.1;\n \n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n}*/\n\nvoid main() {\n float y = mod(vertexId + 1.0, 2.0);\n float x = floor(vertexId / 2.0);\n float ang = (x/20.0)*radians(360.0);\n float phi = (y/20.0)*radians(180.0);\n float p = 0.1;\n float rx = p * sin(phi) * cos(ang);\n float ry = p * cos(phi) * sin (ang);\n float rz = p * cos(phi);\n \n gl_Position = vec4(rx, ry, rz, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 5.0;\n\n}\n" + }, "screenshotURL": "data/images/images-5juipf59fxshw80kl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GSxj99d7zTTT52ZzF/art.json b/art/GSxj99d7zTTT52ZzF/art.json index 76f847b1..2d1070a9 100644 --- a/art/GSxj99d7zTTT52ZzF/art.json +++ b/art/GSxj99d7zTTT52ZzF/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 5.;\\n //float lineId = mod(shapeId, numberOfElement);\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float relXid = xPos/2.;\\n xPos =xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*10.,2.);\\n lineId/=numberOfElement;\\n\\n \\n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+= xPos;\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n //float eyeZ = sin(time/10.)*topZPos;\\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 5.;\n //float lineId = mod(shapeId, numberOfElement);\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float relXid = xPos/2.;\n xPos =xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*10.,2.);\n lineId/=numberOfElement;\n\n \n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+= xPos;\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n //float eyeZ = sin(time/10.)*topZPos;\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-pav37rbgm2qhoukce-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GY6bT7gTsHXRvMshg/art.json b/art/GY6bT7gTsHXRvMshg/art.json index 8e84d692..1d78cdec 100644 --- a/art/GY6bT7gTsHXRvMshg/art.json +++ b/art/GY6bT7gTsHXRvMshg/art.json @@ -20,7 +20,19 @@ "origId": null, "name": "wip", "username": "johan", - "settings": "{\"num\":56549,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define OCTAVES 8\\n\\nconst float DIM_X = 128.;\\nconst float DIM_Y = 64.;\\n\\nconst float BG_DIM_X = 8.;\\nconst float BG_DIM_Y = 6.;\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 hash(vec3 p){\\n return vec3(0.);\\n}\\n\\nfloat rand(in vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nfloat rand2(in vec2 co){\\n return fract(cos(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nfloat rand3(in vec3 co){\\n return fract(sin(dot(co.xyz ,vec3(12.9898,78.233,213.576))) * 43758.5453);\\n}\\n\\nfloat valueNoiseSimple3D(in vec3 vl) {\\n const vec2 helper = vec2(0., 1.);\\n vec3 grid = floor(vl);\\n vec3 interp = smoothstep(vec3(0.), vec3(1.), fract(vl));\\n \\n float interpY0 = mix(mix(rand3(grid),\\n \\t rand3(grid + helper.yxx),\\n \\t interp.x),\\n mix(rand3(grid + helper.xyx),\\n \\trand3(grid + helper.yyx),\\n \\tinterp.x),\\n interp.y);\\n \\n \\n float interpY1 = mix(mix(rand3(grid + helper.xxy),\\n \\t rand3(grid + helper.yxy),\\n \\tinterp.x),\\n mix(rand3(grid + helper.xyy),\\n \\trand3(grid + helper.yyy),\\n \\tinterp.x),\\n interp.y);\\n \\n return -1. + 2.*mix(interpY0, interpY1, interp.z);\\n}\\n\\nfloat fractalNoise(in vec3 vl) {\\n const float persistance = 2.;\\n const float persistanceA = 2.;\\n float amplitude = .5;\\n float rez = 0.0;\\n float rez2 = 0.0;\\n vec3 p = vl;\\n \\n for (int i = 0; i < OCTAVES / 2; i++) {\\n rez += amplitude * valueNoiseSimple3D(p);\\n amplitude /= persistanceA;\\n p *= persistance;\\n }\\n \\n float h = smoothstep(0., 1., vl.y*.5 + .5 );\\n if (h > 0.01) { // small optimization, since Hermit polynom has low front at the start\\n // God is in the details\\n for (int i = OCTAVES / 2; i < OCTAVES; i++) {\\n rez2 += amplitude * valueNoiseSimple3D(p);\\n amplitude /= persistanceA;\\n p *= persistance;\\n }\\n rez += mix(0., rez2, h);\\n }\\n \\n return rez;\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadTriIndex = floor(twoTriVertexIndex*0.334);\\n float quadVertexIndex = triVertexIndex + quadTriIndex;\\n\\n x = mod(quadVertexIndex, 2.);\\n y = floor(quadVertexIndex * 0.5);\\n \\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n//todo: DEFINE PROJECTION\\nmat4 GetProjection(){\\n float near = 0.01;\\n float far = 10.;\\n float aspectRatio = resolution.x / resolution.y;\\n float fov = 2.;\\n float h = cos(0.5*fov)/sin(0.5*fov);\\n float w = h * aspectRatio;\\n float a = - (near+far)/(near - far);\\n float b = - ((2.*far*near)/(far-near));\\n\\n mat4 m = mat4( \\n w, 0, 0, 0,\\n 0, h, 0, 0,\\n 0, 0, a, 1,\\n 0, 0, b, 0\\n );\\n return m;\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexIndex, quadX, quadY, quadId );\\n\\n //vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, BG_DIM_X);\\n quadTile.y = floor(quadId / BG_DIM_X);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV /= vec2(BG_DIM_X, BG_DIM_Y);\\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.99, 1.0 );\\n\\n v_color = vec4( vUV.xy, 0., 1.0 );\\n}\\n\\nvoid ProcessCylinder(float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexIndex, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2(DIM_X, DIM_Y);\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV /= vDim;\\n \\n float phase = vUV.x * PI * 2.;\\n vec3 pos;\\n float r = smoothstep(1.,0.,vUV.y);\\n r += 0.5;\\n r *= 0.25;\\n \\n pos.x = sin(phase);\\n pos.y = vUV.y - 0.5;\\n pos.z = cos(phase);\\n pos.xz *= r;\\n \\n pos.z += 1.;\\n \\n pos += fractalNoise(pos*10.)* 0.05;\\n \\n \\n gl_Position = GetProjection() * vec4(pos, 1.0 );\\n\\n //vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n //vPos.y *= resolution.x / resolution.y;\\n\\n v_color = vec4( vUV.xy, 0., 1.0 );\\n}\\n \\n\\nvoid main() {\\n float vid = vertexId;\\n float bgCount = BG_DIM_X * BG_DIM_Y * 6.;\\n \\n \\n \\tif( vid < bgCount )\\n {\\n\\t\\tProcessBackdrop(vid); \\n }\\n else \\n {\\n \\tvid -= bgCount;\\n \\tfloat cylCount = DIM_X * DIM_Y * 6.;\\n \\tif(vid < cylCount) ProcessCylinder(vid); \\n \\t//ProcessCylinder(vid); \\n \\t//ProcessCylinder(vertexId - bgCount);\\n }\\n /*\\n else if(vertexId - bgCount< DIM_X * DIM_Y * 6.)\\n {\\n ProcessCylinder(vertexId-bgCount); \\n }*/\\n\\n \\n}\"}", + "settings": { + "num": 56549, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define OCTAVES 8\n\nconst float DIM_X = 128.;\nconst float DIM_Y = 64.;\n\nconst float BG_DIM_X = 8.;\nconst float BG_DIM_Y = 6.;\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 hash(vec3 p){\n return vec3(0.);\n}\n\nfloat rand(in vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nfloat rand2(in vec2 co){\n return fract(cos(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nfloat rand3(in vec3 co){\n return fract(sin(dot(co.xyz ,vec3(12.9898,78.233,213.576))) * 43758.5453);\n}\n\nfloat valueNoiseSimple3D(in vec3 vl) {\n const vec2 helper = vec2(0., 1.);\n vec3 grid = floor(vl);\n vec3 interp = smoothstep(vec3(0.), vec3(1.), fract(vl));\n \n float interpY0 = mix(mix(rand3(grid),\n \t rand3(grid + helper.yxx),\n \t interp.x),\n mix(rand3(grid + helper.xyx),\n \trand3(grid + helper.yyx),\n \tinterp.x),\n interp.y);\n \n \n float interpY1 = mix(mix(rand3(grid + helper.xxy),\n \t rand3(grid + helper.yxy),\n \tinterp.x),\n mix(rand3(grid + helper.xyy),\n \trand3(grid + helper.yyy),\n \tinterp.x),\n interp.y);\n \n return -1. + 2.*mix(interpY0, interpY1, interp.z);\n}\n\nfloat fractalNoise(in vec3 vl) {\n const float persistance = 2.;\n const float persistanceA = 2.;\n float amplitude = .5;\n float rez = 0.0;\n float rez2 = 0.0;\n vec3 p = vl;\n \n for (int i = 0; i < OCTAVES / 2; i++) {\n rez += amplitude * valueNoiseSimple3D(p);\n amplitude /= persistanceA;\n p *= persistance;\n }\n \n float h = smoothstep(0., 1., vl.y*.5 + .5 );\n if (h > 0.01) { // small optimization, since Hermit polynom has low front at the start\n // God is in the details\n for (int i = OCTAVES / 2; i < OCTAVES; i++) {\n rez2 += amplitude * valueNoiseSimple3D(p);\n amplitude /= persistanceA;\n p *= persistance;\n }\n rez += mix(0., rez2, h);\n }\n \n return rez;\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadTriIndex = floor(twoTriVertexIndex*0.334);\n float quadVertexIndex = triVertexIndex + quadTriIndex;\n\n x = mod(quadVertexIndex, 2.);\n y = floor(quadVertexIndex * 0.5);\n \n quadId = floor( vertexIndex / 6.0 );\n}\n\n//todo: DEFINE PROJECTION\nmat4 GetProjection(){\n float near = 0.01;\n float far = 10.;\n float aspectRatio = resolution.x / resolution.y;\n float fov = 2.;\n float h = cos(0.5*fov)/sin(0.5*fov);\n float w = h * aspectRatio;\n float a = - (near+far)/(near - far);\n float b = - ((2.*far*near)/(far-near));\n\n mat4 m = mat4( \n w, 0, 0, 0,\n 0, h, 0, 0,\n 0, 0, a, 1,\n 0, 0, b, 0\n );\n return m;\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexIndex, quadX, quadY, quadId );\n\n //vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, BG_DIM_X);\n quadTile.y = floor(quadId / BG_DIM_X);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV /= vec2(BG_DIM_X, BG_DIM_Y);\n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.99, 1.0 );\n\n v_color = vec4( vUV.xy, 0., 1.0 );\n}\n\nvoid ProcessCylinder(float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexIndex, quadX, quadY, quadId );\n\n vec2 vDim = vec2(DIM_X, DIM_Y);\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV /= vDim;\n \n float phase = vUV.x * PI * 2.;\n vec3 pos;\n float r = smoothstep(1.,0.,vUV.y);\n r += 0.5;\n r *= 0.25;\n \n pos.x = sin(phase);\n pos.y = vUV.y - 0.5;\n pos.z = cos(phase);\n pos.xz *= r;\n \n pos.z += 1.;\n \n pos += fractalNoise(pos*10.)* 0.05;\n \n \n gl_Position = GetProjection() * vec4(pos, 1.0 );\n\n //vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n //vPos.y *= resolution.x / resolution.y;\n\n v_color = vec4( vUV.xy, 0., 1.0 );\n}\n \n\nvoid main() {\n float vid = vertexId;\n float bgCount = BG_DIM_X * BG_DIM_Y * 6.;\n \n \n \tif( vid < bgCount )\n {\n\t\tProcessBackdrop(vid); \n }\n else \n {\n \tvid -= bgCount;\n \tfloat cylCount = DIM_X * DIM_Y * 6.;\n \tif(vid < cylCount) ProcessCylinder(vid); \n \t//ProcessCylinder(vid); \n \t//ProcessCylinder(vertexId - bgCount);\n }\n /*\n else if(vertexId - bgCount< DIM_X * DIM_Y * 6.)\n {\n ProcessCylinder(vertexId-bgCount); \n }*/\n\n \n}" + }, "screenshotURL": "data/images/images-o9ijcc82vz6w3tsh0-thumbnail.jpg", "views": { "$numberInt": "86" diff --git a/art/Ga8SGpeNAfnweDCaB/art.json b/art/Ga8SGpeNAfnweDCaB/art.json index 57b70930..6b47fc2f 100644 --- a/art/Ga8SGpeNAfnweDCaB/art.json +++ b/art/Ga8SGpeNAfnweDCaB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#define PI radians( 180.0 )\\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( PI / 2., 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 1.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 1.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 1.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 3.0, 512.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.85;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 1.0, 1.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * PI;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 1.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#define PI radians( 180.0 )\n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( PI / 2., 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 1.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 1.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 1.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 3.0, 512.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.85;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 1.0, 1.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * PI;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 1.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-yymqe7n0wz8y7pvpg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GckHF7hRiWi7gJjys/art.json b/art/GckHF7hRiWi7gJjys/art.json index 13defc9d..8fb46dba 100644 --- a/art/GckHF7hRiWi7gJjys/art.json +++ b/art/GckHF7hRiWi7gJjys/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "dumpster", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJySGGmgPbDAoycXt3iXyhYrzMSM8CvuNCRqg0ay=s96-c", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/auvicmusic/tell-the-world-feat-samantha-montenero\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\" \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n#define PI radians(180.0)\\n\\n void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = 0.; // sin(time + y * 0.2) * .1;\\n float yoff = 0.; // sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u-0.5) * 2.; \\n float sv = abs(v-0.5) * 2.; \\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = .0; // sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd *.2 + time * 0.1;\\n float sat = mix(0., 1., pump); // mix(28., -8., av);\\n float val = mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\\n\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/auvicmusic/tell-the-world-feat-samantha-montenero", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": " \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n#define PI radians(180.0)\n\n void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = 0.; // sin(time + y * 0.2) * .1;\n float yoff = 0.; // sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u-0.5) * 2.; \n float sv = abs(v-0.5) * 2.; \n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = .0; // sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd *.2 + time * 0.1;\n float sat = mix(0., 1., pump); // mix(28., -8., av);\n float val = mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\n\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-r4w389ju48loensrg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GgTexb5kxP7TtFtyP/art.json b/art/GgTexb5kxP7TtFtyP/art.json index 8c200881..5db8e3e0 100644 --- a/art/GgTexb5kxP7TtFtyP/art.json +++ b/art/GgTexb5kxP7TtFtyP/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mipmap", "avatarUrl": "https://secure.gravatar.com/avatar/2840df8e29cba840a5b7f90f66bc66cd?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.1415\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n return inverse(lookAt(eye, target, up));\\n }\\n\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\n\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\n\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5); // soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * 1.2;\\n s *= 0.15;\\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 1.1;\\n\\tf = 0.00100*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\\n float val = mix(.05, 1., l);\\n\\n float ss = \\n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float pop = step(0.6, ss);\\n val = mix(max(val,pop), 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.)*ss;\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.1415\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n return inverse(lookAt(eye, target, up));\n }\n\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\n\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\n\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5); // soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * 1.2;\n s *= 0.15;\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 1.1;\n\tf = 0.00100*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\n float val = mix(.05, 1., l);\n\n float ss = \n texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float pop = step(0.6, ss);\n val = mix(max(val,pop), 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.)*ss;\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-sntqok46ffl0o9np7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ghsjg9yjpwFdatBgX/art.json b/art/Ghsjg9yjpwFdatBgX/art.json index fdba17ec..61dbe8ad 100644 --- a/art/Ghsjg9yjpwFdatBgX/art.json +++ b/art/Ghsjg9yjpwFdatBgX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "demoniak", "avatarUrl": "https://avatars.githubusercontent.com/johanberonius?s=200", - "settings": "{\"num\":54268,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/robundchris/eminem-vs-zombie-nation-without-kernkraft-400-rob-chris-bootleg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n \\n float aspect = resolution.x / resolution.y;\\n\\n float cPoints = 64.;\\n float circles = ceil(vertexCount / cPoints);\\n float cId = floor(vertexId / cPoints);\\n float cNorm = cId / circles;\\n float vId = mod(vertexId, cPoints);\\n \\n\\n float a = 2. * PI * vId / (cPoints - 1.);\\n\\n float snd = pow(texture2D(sound, vec2(0.05, cNorm * .125)).a, 4.);\\n \\n float rad = 0.05 + 0.1 * (1. - cNorm) + sin(a * 10.) * (0.05 + 0.3 * snd);\\n float x = sin(a) * rad;\\n float y = cos(a) * rad;\\n \\n \\n x += sin(time * 1.23 + cId / 133.3) * .3;\\n y += cos(time * 1.09 - cId / 159.2) * .3 / aspect;\\n \\n x += sin(time * 1.31 + cId / 171.3) * .4;\\n y += cos(time * 1.49 - cId / 147.2) * .4 / aspect;\\n \\n\\n gl_Position = vec4(x, y * aspect, 0, 1);\\n \\n float r = sin(time * 1.42 - cNorm * 8.) * .5 + .5;\\n float g = sin(time * 1.27 + a) * .5 + .5;\\n float b = sin(time * 1.12 + cNorm * 6.) * .5 + .5;\\n\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 54268, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/robundchris/eminem-vs-zombie-nation-without-kernkraft-400-rob-chris-bootleg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n \n float aspect = resolution.x / resolution.y;\n\n float cPoints = 64.;\n float circles = ceil(vertexCount / cPoints);\n float cId = floor(vertexId / cPoints);\n float cNorm = cId / circles;\n float vId = mod(vertexId, cPoints);\n \n\n float a = 2. * PI * vId / (cPoints - 1.);\n\n float snd = pow(texture2D(sound, vec2(0.05, cNorm * .125)).a, 4.);\n \n float rad = 0.05 + 0.1 * (1. - cNorm) + sin(a * 10.) * (0.05 + 0.3 * snd);\n float x = sin(a) * rad;\n float y = cos(a) * rad;\n \n \n x += sin(time * 1.23 + cId / 133.3) * .3;\n y += cos(time * 1.09 - cId / 159.2) * .3 / aspect;\n \n x += sin(time * 1.31 + cId / 171.3) * .4;\n y += cos(time * 1.49 - cId / 147.2) * .4 / aspect;\n \n\n gl_Position = vec4(x, y * aspect, 0, 1);\n \n float r = sin(time * 1.42 - cNorm * 8.) * .5 + .5;\n float g = sin(time * 1.27 + a) * .5 + .5;\n float b = sin(time * 1.12 + cNorm * 6.) * .5 + .5;\n\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-ow4oujnbbj9fs8imk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GhwS34Ee6m4sZemgY/art.json b/art/GhwS34Ee6m4sZemgY/art.json index 552704e3..30d001cf 100644 --- a/art/GhwS34Ee6m4sZemgY/art.json +++ b/art/GhwS34Ee6m4sZemgY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10824,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/groove-delight-the-voices-feature019\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>5.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * 0.05)).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 10824, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/groove-delight-the-voices-feature019", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>5.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * 0.05)).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-2yjxcp5g027esm5eh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Gi7T5DRKnAnrvCAPp/art.json b/art/Gi7T5DRKnAnrvCAPp/art.json index 7e132831..40a93300 100644 --- a/art/Gi7T5DRKnAnrvCAPp/art.json +++ b/art/Gi7T5DRKnAnrvCAPp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n gl_Position = vec4(0,0,0,1);\\n gl_PointSize = 10.0;\\n \\n\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n gl_Position = vec4(0,0,0,1);\n gl_PointSize = 10.0;\n \n\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-ox37r3fjrn3k07549-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GkEJbHknrmuoDysnp/art.json b/art/GkEJbHknrmuoDysnp/art.json index 770dcabc..420628d4 100644 --- a/art/GkEJbHknrmuoDysnp/art.json +++ b/art/GkEJbHknrmuoDysnp/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Color\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Color\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-fv7vkgby4ugwr0m7d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GobkkbXq2nNFAHBdB/art.json b/art/GobkkbXq2nNFAHBdB/art.json index 7c7ebf2f..d2748f47 100644 --- a/art/GobkkbXq2nNFAHBdB/art.json +++ b/art/GobkkbXq2nNFAHBdB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":47046,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nightclubband/show-it-2-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.23137254901960785,0.23137254901960785,0.23137254901960785,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() { \\n float units = 40.0;\\n float perSet = units * 6.0;\\n float numSets = floor(vertexCount / perSet);\\n float vertexCount = 44000./mouse.x;\\n float id = mod(vertexId, perSet);\\n float setId = floor(vertexId / perSet);\\n \\n float vId = mod(vertexId, perSet);\\n float ux = floor(vId / 6.) + mod(vId, 2.) * 2.;\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.) * 2. - 1.; \\n \\n float u = ux / (units + 1.);\\n \\n float sv = setId / (numSets - 1.);\\n \\n float s0 = texture2D(sound, vec2(mix(.05, .2, abs(sv * 0. - 1.)), u * .1)).a;\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(90.0/mouse.y), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(0, 0, 50);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n vec3 pos = vec3(ux, vy, u);\\n mat *= cameraLookAt(eye, target, up);\\n //mat *= trans(vec3(units * .5, 0, 0));\\n mat *= rotZ(PI * .5 +\\n sin(time * .3) * .5 +\\n time * sign(setId - numSets / 2.) + \\n sv * PI * 2. + \\n sin(time + u * 6. * sin(time * 0.2)) * u * 1.1 * sign(setId - numSets / 2.));\\n mat *= trans(vec3(0., 0, 0));\\n mat *= scale(vec3(1, (1. - pow(u, 15.)) * mix(0., 5., pow(clamp(s0 + .3, 0., 1.), 15.)), 1));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.0;\\n float hue = u * .1*mouse.y;\\n float sat = 1.;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = mix(vec4(0,0,1./mouse.y,1), vec4(color, 1), mod(setId, 2.));\\n //v_color.a = s0;\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 47046, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nightclubband/show-it-2-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.23137254901960785, + 0.23137254901960785, + 0.23137254901960785, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() { \n float units = 40.0;\n float perSet = units * 6.0;\n float numSets = floor(vertexCount / perSet);\n float vertexCount = 44000./mouse.x;\n float id = mod(vertexId, perSet);\n float setId = floor(vertexId / perSet);\n \n float vId = mod(vertexId, perSet);\n float ux = floor(vId / 6.) + mod(vId, 2.) * 2.;\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.) * 2. - 1.; \n \n float u = ux / (units + 1.);\n \n float sv = setId / (numSets - 1.);\n \n float s0 = texture2D(sound, vec2(mix(.05, .2, abs(sv * 0. - 1.)), u * .1)).a;\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(90.0/mouse.y), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(0, 0, 50);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n vec3 pos = vec3(ux, vy, u);\n mat *= cameraLookAt(eye, target, up);\n //mat *= trans(vec3(units * .5, 0, 0));\n mat *= rotZ(PI * .5 +\n sin(time * .3) * .5 +\n time * sign(setId - numSets / 2.) + \n sv * PI * 2. + \n sin(time + u * 6. * sin(time * 0.2)) * u * 1.1 * sign(setId - numSets / 2.));\n mat *= trans(vec3(0., 0, 0));\n mat *= scale(vec3(1, (1. - pow(u, 15.)) * mix(0., 5., pow(clamp(s0 + .3, 0., 1.), 15.)), 1));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.0;\n float hue = u * .1*mouse.y;\n float sat = 1.;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = mix(vec4(0,0,1./mouse.y,1), vec4(color, 1), mod(setId, 2.));\n //v_color.a = s0;\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-ns6mhyrw9bb4idybs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GoviGkHcqKYCZeJKp/art.json b/art/GoviGkHcqKYCZeJKp/art.json index 65f7bbc0..1630f995 100644 --- a/art/GoviGkHcqKYCZeJKp/art.json +++ b/art/GoviGkHcqKYCZeJKp/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":23287,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv(in float h, in float s, in float v) {\\n return mix(vec3(1.0), clamp((abs(fract(\\n h + vec3(3.0, 2.0, 1.0) / 3.0) * 6.0 - 3.0) - 1.0), 0.0, 1.0), s) * v;\\n}\\n\\n\\nmat2 rotate(float a) {\\n float s=sin(a),c=cos(a);\\n return mat2(c,s,-s,c);\\n}\\n\\nfloat hash(in float n) {\\n return fract(sin(n)*753.5453123);\\n}\\n\\n\\nvec3 test(in float id)\\n{\\n \\n \\n int stp = 0;\\n for(int i=0; i<10; i++){\\n float cnt = pow(2.0, float(i));\\n if (id < cnt) break;\\n id -= cnt;\\n stp++;\\n if(stp>6)break;\\n }\\n //stp=int(min(4.0,float(stp)));\\n float s = 1.0;\\n vec2 p = vec2(0);\\n float r = time*0.3;\\n \\n //return vec3(rotate(r) * vec2(1.0, 0.0),1.0);\\n //if (id >0.0){\\n //id =63.0;\\n //}else{id=0.0;}\\n \\n float t = time*0.3;\\n for(int i=0; i<10; i++){\\n if (stp==i) break;\\n float s0 = s;\\n if (mod(id,2.0) < 0.5){\\n s *= 0.87;\\n r += 1.0*t;\\n p += rotate(-r) * vec2(s0 - s, 0.0); \\n } else {\\n s *= 0.83;\\n r += 2.0*t;\\n p += rotate(-r) * vec2(s0 + s, 0.0); \\n } \\n id = floor(id/2.0);\\n }\\n \\n return vec3(p,s);\\n}\\n\\n\\nvoid main() {\\n \\n float aspect = resolution.x / resolution.y;\\n float instanceID = floor(vertexId / 6.0);\\n float pointID = abs(3.0 - mod(vertexId, 6.0));\\n vec2 uv = vec2(mod(pointID, 2.0), floor(pointID / 2.0));\\n vec2 p = uv*2.0-1.0;\\n \\n vec3 t = test(instanceID);\\n p *= t.z;\\n p += t.xy;\\n p *= 0.2;\\n \\n p.x /= aspect;\\n gl_Position = vec4(p, 0.0,1.0);\\n\\n vec3 col = hsv(fract(sin(instanceID * 0.123)), 0.5, 0.3);\\n \\n v_color = vec4(col, 1);\\n}\"}", + "settings": { + "num": 23287, + "mode": "LINES", + "sound": "https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv(in float h, in float s, in float v) {\n return mix(vec3(1.0), clamp((abs(fract(\n h + vec3(3.0, 2.0, 1.0) / 3.0) * 6.0 - 3.0) - 1.0), 0.0, 1.0), s) * v;\n}\n\n\nmat2 rotate(float a) {\n float s=sin(a),c=cos(a);\n return mat2(c,s,-s,c);\n}\n\nfloat hash(in float n) {\n return fract(sin(n)*753.5453123);\n}\n\n\nvec3 test(in float id)\n{\n \n \n int stp = 0;\n for(int i=0; i<10; i++){\n float cnt = pow(2.0, float(i));\n if (id < cnt) break;\n id -= cnt;\n stp++;\n if(stp>6)break;\n }\n //stp=int(min(4.0,float(stp)));\n float s = 1.0;\n vec2 p = vec2(0);\n float r = time*0.3;\n \n //return vec3(rotate(r) * vec2(1.0, 0.0),1.0);\n //if (id >0.0){\n //id =63.0;\n //}else{id=0.0;}\n \n float t = time*0.3;\n for(int i=0; i<10; i++){\n if (stp==i) break;\n float s0 = s;\n if (mod(id,2.0) < 0.5){\n s *= 0.87;\n r += 1.0*t;\n p += rotate(-r) * vec2(s0 - s, 0.0); \n } else {\n s *= 0.83;\n r += 2.0*t;\n p += rotate(-r) * vec2(s0 + s, 0.0); \n } \n id = floor(id/2.0);\n }\n \n return vec3(p,s);\n}\n\n\nvoid main() {\n \n float aspect = resolution.x / resolution.y;\n float instanceID = floor(vertexId / 6.0);\n float pointID = abs(3.0 - mod(vertexId, 6.0));\n vec2 uv = vec2(mod(pointID, 2.0), floor(pointID / 2.0));\n vec2 p = uv*2.0-1.0;\n \n vec3 t = test(instanceID);\n p *= t.z;\n p += t.xy;\n p *= 0.2;\n \n p.x /= aspect;\n gl_Position = vec4(p, 0.0,1.0);\n\n vec3 col = hsv(fract(sin(instanceID * 0.123)), 0.5, 0.3);\n \n v_color = vec4(col, 1);\n}" + }, "screenshotURL": "data/images/images-g0alrpn0gxqyq6q3x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Guf53TWBqY43SzNeS/art.json b/art/Guf53TWBqY43SzNeS/art.json index 5501afd2..80141bfa 100644 --- a/art/Guf53TWBqY43SzNeS/art.json +++ b/art/Guf53TWBqY43SzNeS/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0,0.2,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n#define KP0 4.//KParameter -0.5>>2.5\\n#define KP1 1.5//KParameter -2.>>2.\\n#define zoom 1.5//KParameter 1.0>>7.\\n#define KP2 1.3//KParameter 0.4>>2.\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0,KP0, 1.0);\\nfloat gExposure = 0.3;\\t\\n\\nfloat gCubeColorRandom = 20.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0*-mouse.y;\\nfloat g_cameraFar = 1000.0 * zoom;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( mouse.x*20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.2, target + 0.2);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n float beat = texture2D(sound, vec2(0.007, 0)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0.65; + floor(time * 0.50) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-1,0,-.3), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8 + KP2;\\n \\n//vec3 vCameraTarget = vec3( 330/int(KP0),111.6*zoom, 2222.0 );\\n//\\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n vec3 vCameraTarget = vec3( KP0, KP1, 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 5./zoom, sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1.-KP1,.4 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.3, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, .3) , background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0, + 0.2, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n#define KP0 4.//KParameter -0.5>>2.5\n#define KP1 1.5//KParameter -2.>>2.\n#define zoom 1.5//KParameter 1.0>>7.\n#define KP2 1.3//KParameter 0.4>>2.\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0,KP0, 1.0);\nfloat gExposure = 0.3;\t\n\nfloat gCubeColorRandom = 20.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0*-mouse.y;\nfloat g_cameraFar = 1000.0 * zoom;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( mouse.x*20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.2, target + 0.2);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n float beat = texture2D(sound, vec2(0.007, 0)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0.65; + floor(time * 0.50) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-1,0,-.3), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8 + KP2;\n \n//vec3 vCameraTarget = vec3( 330/int(KP0),111.6*zoom, 2222.0 );\n//\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n vec3 vCameraTarget = vec3( KP0, KP1, 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 5./zoom, sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1.-KP1,.4 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.3, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, .3) , background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-9wqgsjw8nlkunbbsa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GvMwNCPsyjoPaL9fj/art.json b/art/GvMwNCPsyjoPaL9fj/art.json index bf59afb4..6d6e726b 100644 --- a/art/GvMwNCPsyjoPaL9fj/art.json +++ b/art/GvMwNCPsyjoPaL9fj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":27929,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/thrillkillkult/07-bella-piranha\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.1568627450980392,0.7803921568627451,1],\"shader\":\"// _ _ _ _ \\n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \\n// \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__/ _` | '__| __|\\n// \\\\ V / __/ | | || __/> <\\\\__ \\\\ | | | (_| | (_| | __/ | | (_| | | | |_ \\n// \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\\\__,_|_| \\\\__|\\n//\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.02, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 7.8, 1.0 ) * 11.5;\\n\\nvec3 gCubeColor = vec3(1.7, 1.8, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 2.6;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 1.8;\\nfloat gFloorHeight = -2.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.7, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (2.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.7, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 1.60, 0.60 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 2.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\\n \\n float across = 32.;\\n float down = 20.;\\n float u = mod(fCubeId, across) / across;\\n float v = floor(fCubeId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.02;\\n \\n mat = ident();\\n \\tmat *= rotZ(lng);\\n \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= uniformScale(fScale);\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeCol = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol = mix(vCubeCol, vec3(1,0,0), step(0.95,s2));\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\t\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat snd = texture2D(sound, vec2(mix(0.1,0.3, mouse.y *5.), time *2.1)).a;\\n \\n float fov = 2. *snd;\\n \\n \\tfloat animTime = time * 2. *mouse.x;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n mat4 mCube;\\n vec3 vCubeCol;\\n\\n GetCubePosition( fCubeId, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 2.);//sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 27929, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/thrillkillkult/07-bella-piranha", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.1568627450980392, + 0.7803921568627451, + 1 + ], + "shader": "// _ _ _ _ \n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \n// \\ \\ / / _ \\ '__| __/ _ \\ \\/ / __| '_ \\ / _` |/ _` |/ _ \\ '__/ _` | '__| __|\n// \\ V / __/ | | || __/> <\\__ \\ | | | (_| | (_| | __/ | | (_| | | | |_ \n// \\_/ \\___|_| \\__\\___/_/\\_\\___/_| |_|\\__,_|\\__,_|\\___|_| \\__,_|_| \\__|\n//\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.02, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 7.8, 1.0 ) * 11.5;\n\nvec3 gCubeColor = vec3(1.7, 1.8, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 2.6;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 1.8;\nfloat gFloorHeight = -2.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.7, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (2.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.7, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 1.60, 0.60 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 2.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\n \n float across = 32.;\n float down = 20.;\n float u = mod(fCubeId, across) / across;\n float v = floor(fCubeId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.02;\n \n mat = ident();\n \tmat *= rotZ(lng);\n \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= uniformScale(fScale);\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeCol = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol = mix(vCubeCol, vec3(1,0,0), step(0.95,s2));\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \t\n \n \tvec2 vMouse = mouse;\n \n \tfloat snd = texture2D(sound, vec2(mix(0.1,0.3, mouse.y *5.), time *2.1)).a;\n \n float fov = 2. *snd;\n \n \tfloat animTime = time * 2. *mouse.x;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n mat4 mCube;\n vec3 vCubeCol;\n\n GetCubePosition( fCubeId, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 2.);//sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-aawreobqhin5nx66d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GwLMiSsyX3jZKW52s/art.json b/art/GwLMiSsyX3jZKW52s/art.json index ee0a49ba..97dfef84 100644 --- a/art/GwLMiSsyX3jZKW52s/art.json +++ b/art/GwLMiSsyX3jZKW52s/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Audio Reactive\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize =pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = sin(x*y) * u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = tan( mix(.1, pow(snd + 0.2, 5.0), pump));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Audio Reactive\ncourse name : CS250\nterm : 2022 Spring\n*/\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize =pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = sin(x*y) * u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = tan( mix(.1, pow(snd + 0.2, 5.0), pump));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-84vxsskpvnucb5ox4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GxL6CjaGt3wyQZxyL/art.json b/art/GxL6CjaGt3wyQZxyL/art.json index 16641c04..8f3dd353 100644 --- a/art/GxL6CjaGt3wyQZxyL/art.json +++ b/art/GxL6CjaGt3wyQZxyL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-b6wfbzpwwwsn5h13r-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/GxbSZ33B9swmxAmdT/art.json b/art/GxbSZ33B9swmxAmdT/art.json index a4f0d138..740c0ee7 100644 --- a/art/GxbSZ33B9swmxAmdT/art.json +++ b/art/GxbSZ33B9swmxAmdT/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.10588235294117647,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.6 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float ss = texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\\n float pop = step(0.6, ss);\\n val = mix(val, 1., pop);\\n hue = mix(hue, hue + .5, pop);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.10588235294117647, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.6 + qu * 0. + p.y * 0.1;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float ss = texture2D(sound, vec2(fract(hash(qu + qv) + qv + time * 0.5), 0.)).a;\n float pop = step(0.6, ss);\n val = mix(val, 1., pop);\n hue = mix(hue, hue + .5, pop);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-7mjkmkjjgdq7981th-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GzJvTrF4HxvXiNseC/art.json b/art/GzJvTrF4HxvXiNseC/art.json index dd1dc960..11c25702 100644 --- a/art/GzJvTrF4HxvXiNseC/art.json +++ b/art/GzJvTrF4HxvXiNseC/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Audio Reactive\\n// Course : CS250\\n// Term & Year : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump); //mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Audio Reactive\n// Course : CS250\n// Term & Year : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\n float sat = mix(0., 1., pump); //mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-yjw36svq2mpr2grye-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/GzxrG8cZEcozSK64v/art.json b/art/GzxrG8cZEcozSK64v/art.json index 0145e055..583a812f 100644 --- a/art/GzxrG8cZEcozSK64v/art.json +++ b/art/GzxrG8cZEcozSK64v/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/substruk-records/sub032-sixis-orbital-substruk\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Daehyeon Kim\\n//Audio Reactive\\n//CS250\\n//Spring, 2022\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/substruk-records/sub032-sixis-orbital-substruk", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Daehyeon Kim\n//Audio Reactive\n//CS250\n//Spring, 2022\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-dpa2ut9ciyfuaw07d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/H3mC5F9jwNY2cbBHH/art.json b/art/H3mC5F9jwNY2cbBHH/art.json index 3d5e6dde..d05bee54 100644 --- a/art/H3mC5F9jwNY2cbBHH/art.json +++ b/art/H3mC5F9jwNY2cbBHH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n parameter3, c, s, 0,\\n 0, -s, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0.2,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n parameter3, c, s, 0,\n 0, -s, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0.2,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-4g4g0hq81ch3lva00-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/H43CgK3XcPByECvuk/art.json b/art/H43CgK3XcPByECvuk/art.json index 1959dba7..6fd658f8 100644 --- a/art/H43CgK3XcPByECvuk/art.json +++ b/art/H43CgK3XcPByECvuk/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":69672,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 24.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float circlesPerRow = 33.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow) * 2.;\\n float cy = floor(circleId / circlesPerRow) * 2.;\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n float sx = cx - circlesPerRow;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx, cy, 0, 0);\\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\\n \\n // scale\\n gl_Position *= scale(1. / 16.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 0.5, 0, 1, 1) ;\\n}\"}", + "settings": { + "num": 69672, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 24.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float circlesPerRow = 33.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow) * 2.;\n float cy = floor(circleId / circlesPerRow) * 2.;\n \n vec2 soundTexCoords = vec2(0, 0);\n float sx = cx - circlesPerRow;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx, cy, 0, 0);\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\n \n // scale\n gl_Position *= scale(1. / 16.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 0.5, 0, 1, 1) ;\n}" + }, "screenshotURL": "data/images/images-hp84sufzjvogtcn18-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/H45bQs2Q9fsMAjnWt/art.json b/art/H45bQs2Q9fsMAjnWt/art.json index 2aeb27d5..48b6e798 100644 --- a/art/H45bQs2Q9fsMAjnWt/art.json +++ b/art/H45bQs2Q9fsMAjnWt/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.13333333333333333,0.4,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 3.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 2.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, mouse.xy);\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.06;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background-.13, vCubeCol.a* 1.36);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.13333333333333333, + 0.4, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES\n\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 3.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 2.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, mouse.xy);\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.06;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background-.13, vCubeCol.a* 1.36);\n \n}" + }, "screenshotURL": "data/images/images-l8y802g4y6yjy1axx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/H4mnhb75o8M2FZwGZ/art.json b/art/H4mnhb75o8M2FZwGZ/art.json index 2673a677..974d402e 100644 --- a/art/H4mnhb75o8M2FZwGZ/art.json +++ b/art/H4mnhb75o8M2FZwGZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "teraspora2", "avatarUrl": "https://avatars.githubusercontent.com/teraspora?s=200", - "settings": "{\"num\":256,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 8.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.2;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.4;\\n float c = cos(angle + time * 0.2) * radius;\\n float s = sin(angle + time * 0.1) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.001) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.001) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 256, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 8.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.2;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.4;\n float c = cos(angle + time * 0.2) * radius;\n float s = sin(angle + time * 0.1) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.001) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.001) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-cu626z1zgrhlr6pbv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/H56ztSpxnFf2kZGwv/art.json b/art/H56ztSpxnFf2kZGwv/art.json index 8bea2278..dfb1b7e2 100644 --- a/art/H56ztSpxnFf2kZGwv/art.json +++ b/art/H56ztSpxnFf2kZGwv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"TRIANGLES\",\"sound\":\"//KDrawmode=GL_TRIANGLES #define parameter0 1.//KParameter0 1.>>8. #define parameter1 -0.2//KParameter1 -1.>>1. #define parameter2 -1.//KParameter2 -1.>>1. #define parameter3 0.//KParameter3 0.>>12. #define parameter4 2.//KParameter4 0.>>2. #define parameter5 1.//KParameter5 0.1>>1.5 #define parameter6 0.3//KParameter6 0.>>1. #define parameter7 0.//KParameter7 0.>>10. #define HPI 1.570796326795 #define PI 3.1415926535898 #define SYMMETRY_H 1 #define SYMMETRY_V 1 #define COLOR_MODE 1 vec3 rotZ(vec3 _v, float _rad) { vec2 f = sin(vec2(_rad, _rad + HPI)); vec3 r = _v; r.x = _v.x * f.x + _v.y * f.y; r.y = _v.x * -f.y + _v.y * f.x; return r; } mat4 uniformScale(float _s) { return mat4( _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, 1); } vec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18]) { vec4 result = vec4(0., 0.,-1., 1.); float localVertexId = _vertexId - _startVertexId; if(localVertexId<1.) { result.xy = _letter[0].xy; } else if(localVertexId<2.) { result.xy = _letter[1].xy; } else if(localVertexId<3.) { result.xy = _letter[2].xy; } else //2nd triangle if(localVertexId<4.) { result.xy = _letter[3].xy; } else if(localVertexId<5.) { result.xy = _letter[4].xy; } else if(localVertexId<6.) { result.xy = _letter[5].xy; } else if(localVertexId<7.)//3 eme triangle { result.xy = _letter[6].xy; } else if(localVertexId<8.) { result.xy = _letter[7].xy; } else if(localVertexId<9.) { result.xy = _letter[8].xy; } else if(localVertexId<10.)//4eme triangle { result.xy = _letter[9].xy; } else if(localVertexId<11.) { result.xy = _letter[10].xy; } else if(localVertexId<12.) { result.xy = _letter[11].xy; } else if(localVertexId<13.) { result.xy = _letter[12].xy; } else if(localVertexId<14.) { result.xy = _letter[13].xy; } else if(localVertexId<15.) { result.xy = _letter[14].xy; } else if(localVertexId<16.) { result.xy = _letter[15].xy; } else if(localVertexId<17.) { result.xy = _letter[16].xy; } else if(localVertexId<18.) { result.xy = _letter[17].xy; } result.xy+=_pos; result.xy-=vec2(_barWidth*2.,0.5)+_pos; result.xyz =rotZ(result.xyz, _rotation); result.xy+=vec2(_barWidth*2.,0.5)+_pos; result *= uniformScale(_scale); return result.xyz; } vec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos) { vec2 finalPos = _pos; vec2 additionalPos = vec2(0.,0.); float transfoMode = floor(parameter3); //additionalPos.x = _relLetterTimeProgress*0.5; if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<2.) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6; finalPos+= additionalPos; } else if(transfoMode<3.) { additionalPos = -finalPos; additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI ); additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI ); finalPos+= additionalPos; } else if(transfoMode<4.) { additionalPos = -finalPos; vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) )); additionalPos.x+= m.x; additionalPos.y+= m.y; finalPos+= additionalPos; } else if(transfoMode<5.) { additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time)); finalPos+= additionalPos; } else if(transfoMode<6.) { additionalPos = -finalPos; additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5; additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));; finalPos+= additionalPos; } else if(transfoMode<7.) { if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); finalPos+= additionalPos; } } else if(transfoMode<8.) { additionalPos = -finalPos; if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<9.) { additionalPos = -finalPos; if(mod(_shapeId,2.)<1.) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<10.) { //if(_selectedShape == _shapeId) { vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. )); additionalPos.y = m.x*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<11.) { additionalPos = -finalPos; additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time ); additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time); finalPos+= additionalPos; } return finalPos; } float getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation) { float finalRot = _rotation; float additionalRotation = 0.; float transfoMode = floor(parameter3); if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress; } } else if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = 2.*2.*PI*_relLetterTimeProgress; } } finalRot+= additionalRotation; /* float additionalRotation = 0.; if(selectedLetterIndex == shapeId) { additionalRotation = 2.*PI*relLetterTimeProgress; } rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId; */ return finalRot; } vec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth) { vec2 finalCenter = _center; /* vec2 additionalCenter = vec2(0.,0.); if(_selectedShape == _shapeId) { additionalCenter.x = _relLetterTimeProgress*0.5; additionalCenter.y = _relLetterTimeProgress*0.5; } finalCenter+= additionalCenter; */ return finalCenter; } #define elementPerShapeLetterK 18. #define defaultRotationForShapeLetterK 0.13 #define defaultRotationForShapeLetterM - 0.09 #define defaultRotationForShapeLetterN 0.04 #define defaultRotationForShapeLetterA 0.1 #define defaultRotationForShapeLetterC - 0.05 #define defaultRotationForShapeLetterE - 0.03 #define defaultRotationForShapeLetterH 0.04 #define defaultRotationForShapeLetterI - 0.02 #define shapeNumber 8. #define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber void main() { vec3 color = vec3(1.); float sndFactor = texture2D(sound, vec2(0.01, 0.)).r; float _junctionY = 0.5 +parameter4*sndFactor/10.; float _barWidth = 0.2 ;// + parameter4*sndFactor/100.; float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.; float shapeId = 0.; vec2 letterK[18]; letterK[0] = vec2(0.,0.); letterK[1] = vec2(0.,1.); letterK[2] = vec2(_barWidth,1.); letterK[3] = vec2(0.,0.0); letterK[4] = vec2(_barWidth,1.); letterK[5] = vec2(_barWidth,0.); letterK[6] = vec2(_barWidth,_junctionY); letterK[7] = vec2((_secondVertY+_barWidth),1.); letterK[8] = vec2(_secondVertY,1.); letterK[9] = vec2(_barWidth,_junctionY); letterK[10] = vec2((_secondVertY+_barWidth),0.); letterK[11] = vec2(_secondVertY,0.); letterK[12] = vec2(_secondVertY,0.); letterK[13] = vec2(_secondVertY,0.); letterK[14] = vec2(_secondVertY,0.); letterK[15] = vec2(_secondVertY,0.); letterK[16] = vec2(_secondVertY,0.); letterK[17] = vec2(_secondVertY,0.); vec2 letterM[18]; letterM[0] = vec2(0.,0.); letterM[1] = vec2(0.,1.); letterM[2] = vec2(_barWidth,1.); letterM[3] = vec2(0.,0.0); letterM[4] = vec2(_barWidth,1.); letterM[5] = vec2(_barWidth,0.);//PROBLEM !! letterM[6] = vec2(_barWidth,_junctionY+_barWidth); letterM[7] = vec2(_barWidth,1.); letterM[8] = vec2(_barWidth*2.,_junctionY); letterM[9] = vec2(_barWidth*2.,_junctionY); letterM[10] = vec2((_barWidth*3.),1.); letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth); letterM[12] = vec2(_barWidth*3.,1.); letterM[13] = vec2(_barWidth*4.,1.); letterM[14] = vec2(_barWidth*3.,0.); letterM[15] = vec2(_barWidth*3.,0.); letterM[16] = vec2(_barWidth*4.,1.); letterM[17] = vec2(_barWidth*4.,0.); vec2 letterN[18]; letterN[0] = vec2(0.,0.); letterN[1] = vec2(0.,1.); letterN[2] = vec2(_barWidth,1.); letterN[3] = vec2(0.,0.0); letterN[4] = vec2(_barWidth,1.); letterN[5] = vec2(_barWidth,0.); letterN[6] = vec2(_barWidth,_junctionY+_barWidth); letterN[7] = vec2(_barWidth,1.); letterN[8] = vec2(_barWidth*2.,_junctionY); letterN[9] = vec2(_barWidth*2.,1.); letterN[10] = vec2(_barWidth*3.,1.); letterN[11] = vec2(_barWidth*2.,0.); letterN[12] = vec2(_barWidth*2.,0.); letterN[13] = vec2(_barWidth*3.,1.); letterN[14] = vec2(_barWidth*3.,0.); letterN[15] = vec2(_barWidth*3.,0.); letterN[16] = vec2(_barWidth*3.,0.); letterN[17] = vec2(_barWidth*3.,0.); vec2 letterA[18]; letterA[0] = vec2(0.,0.); letterA[1] = vec2(_barWidth,0.); letterA[2] = vec2(_barWidth*2.,1.); letterA[3] = vec2(_barWidth*4.,0.0); letterA[4] = vec2(_barWidth*2.,1.); letterA[5] = vec2(_barWidth*3.,0.); letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.); letterA[8] = vec2(_barWidth*3.,_junctionY); letterA[9] = vec2(_barWidth*3.,_junctionY); letterA[10] = vec2(_barWidth*3.,_junctionY); letterA[11] = vec2(_barWidth*3.,_junctionY); letterA[12] = vec2(_barWidth*3.,_junctionY); letterA[13] = vec2(_barWidth*3.,_junctionY); letterA[14] = vec2(_barWidth*3.,_junctionY); letterA[15] = vec2(_barWidth*3.,_junctionY); letterA[16] = vec2(_barWidth*3.,_junctionY); letterA[17] = vec2(_barWidth*3.,_junctionY); vec2 letterE[18]; letterE[0] = vec2(0.,0.); letterE[1] = vec2(0.,1.); letterE[2] = vec2(_barWidth,1.); letterE[3] = vec2(0.,0.0); letterE[4] = vec2(_barWidth,1.); letterE[5] = vec2(_barWidth,0.); letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5); letterE[7] = vec2(_barWidth,1.); letterE[8] = vec2(_barWidth*3.,1.); letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5); letterE[10] = vec2(_barWidth,0.); letterE[11] = vec2(_barWidth*3.,0.); letterE[12] = vec2(_barWidth,_junctionY); letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.); letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); vec2 letterC[18]; letterC[0] = vec2(0.,0.); letterC[1] = vec2(0.,1.); letterC[2] = vec2(_barWidth,1.); letterC[3] = vec2(0.,0.0); letterC[4] = vec2(_barWidth,1.); letterC[5] = vec2(_barWidth,0.); letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5); letterC[7] = vec2(_barWidth,1.); letterC[8] = vec2(_barWidth*3.,1.); letterC[9] = vec2(_barWidth,0.); letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5); letterC[11] = vec2(_barWidth*3.,0.); letterC[12] = vec2(_barWidth*3.,0.); letterC[13] = vec2(_barWidth*3.,0.); letterC[14] = vec2(_barWidth*3.,0.); letterC[15] = vec2(_barWidth*3.,0.); letterC[16] = vec2(_barWidth*3.,0.); letterC[17] = vec2(_barWidth*3.,0.); vec2 letterH[18]; letterH[0] = vec2(0.,0.); letterH[1] = vec2(0.,1.); letterH[2] = vec2(_barWidth,1.); letterH[3] = vec2(0.,0.0); letterH[4] = vec2(_barWidth,1.); letterH[5] = vec2(_barWidth,0.); letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.); letterH[8] = vec2(_barWidth*2.,_junctionY); letterH[9] = vec2(_barWidth*2.,_junctionY); letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.); letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.); letterH[12] = vec2(_barWidth*3.,1.); letterH[13] = vec2(_barWidth*4.,1.); letterH[14] = vec2(_barWidth*3.,0.); letterH[15] = vec2(_barWidth*3.,0.); letterH[16] = vec2(_barWidth*4.,1.); letterH[17] = vec2(_barWidth*4.,0.); vec2 letterI[18]; letterI[0] = vec2(0.,0.); letterI[1] = vec2(0.,_junctionY+_barWidth); letterI[2] = vec2(_barWidth,_junctionY+_barWidth); letterI[3] = vec2(0.,0.0); letterI[4] = vec2(_barWidth,_junctionY+_barWidth); letterI[5] = vec2(_barWidth,0.);//PROBLEM !! letterI[6] = vec2(0.,1.-_barWidth); letterI[7] = vec2(0.,1.); letterI[8] = vec2(_barWidth,1.-_barWidth); letterI[9] = vec2(_barWidth,1.-_barWidth); letterI[10] = vec2(0.,1.); letterI[11] = vec2(_barWidth,1.); letterI[12] = vec2(_barWidth,1.); letterI[13] = vec2(_barWidth,1.); letterI[14] = vec2(_barWidth,1.); letterI[15] = vec2(_barWidth,1.); letterI[16] = vec2(_barWidth,1.); letterI[17] = vec2(_barWidth,1.); float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord)); float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;// float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId); //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord); finalVertexId = min(maxNumberOfVertices,vertexId); finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord)); //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord); //float relMetaShapeId = metaShapeId/256.; float masterScale = parameter5;//parameter6; vec3 _v = vec3(0.,0.,0.); vec2 letterPos = vec2(0.,0.); float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.; float scaleK = 0.4*masterScale; float scale = 0.2*masterScale; float startPosK = parameter2; float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters); vec2 shapeCenter = vec2(0.,0.5); //for vsa float loopDurationMs = 4000.; float timeProgress = mod(time*1000.,loopDurationMs); float relLoopProgress = timeProgress/loopDurationMs; //end for vsa float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor)); float numberOfSubLoops = floor(parameter0); float subLoopLength = 1./numberOfSubLoops; finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength; float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber)); float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber); float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress); ///////////////////////// float rotation = PI/3.*time*shapeId; if(finalVertexId0 else if(vertexId0 else if(vertexId0 && SYMMETRY_H >0 else if(vertexId>8.\\n#define parameter1 -0.2//KParameter1 -1.>>1.\\n#define parameter2 -1.//KParameter2 -1.>>1.\\n#define parameter3 0.//KParameter3 0.>>12.\\n#define parameter4 2.//KParameter4 0.>>2.\\n#define parameter5 1.//KParameter5 0.1>>1.5\\n#define parameter6 0.3//KParameter6 0.>>1.\\n#define parameter7 0.//KParameter7 0.>>10.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define SYMMETRY_H 1\\n#define SYMMETRY_V 1\\n#define COLOR_MODE 1\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\\n{\\n \\n \\n \\n \\n vec4 result = vec4(0., 0.,-1., 1.);\\n \\n \\n float localVertexId = _vertexId - _startVertexId;\\n \\n if(localVertexId<1.)\\n {\\n result.xy = _letter[0].xy;\\n }\\n else\\n \\n if(localVertexId<2.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n \\n else\\n if(localVertexId<3.)\\n {\\n result.xy = _letter[2].xy;\\n }\\n else //2nd triangle\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[3].xy;\\n }\\n else\\n if(localVertexId<5.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<6.)\\n {\\n result.xy = _letter[5].xy;\\n }\\n else\\n if(localVertexId<7.)//3 eme triangle\\n {\\n result.xy = _letter[6].xy;\\n }\\n else\\n if(localVertexId<8.)\\n {\\n result.xy = _letter[7].xy;\\n }\\n else\\n if(localVertexId<9.)\\n {\\n result.xy = _letter[8].xy;\\n \\n }\\n \\n else\\n if(localVertexId<10.)//4eme triangle\\n {\\n result.xy = _letter[9].xy;\\n \\n }\\n else\\n if(localVertexId<11.)\\n {\\n result.xy = _letter[10].xy;\\n \\n }\\n \\n else\\n if(localVertexId<12.)\\n {\\n result.xy = _letter[11].xy;\\n \\n }\\n else\\n if(localVertexId<13.)\\n {\\n result.xy = _letter[12].xy;\\n \\n }\\n else\\n if(localVertexId<14.)\\n {\\n result.xy = _letter[13].xy;\\n \\n }\\n else\\n if(localVertexId<15.)\\n {\\n result.xy = _letter[14].xy;\\n \\n }\\n else\\n if(localVertexId<16.)\\n {\\n result.xy = _letter[15].xy;\\n \\n }\\n else\\n if(localVertexId<17.)\\n {\\n result.xy = _letter[16].xy;\\n \\n }\\n else\\n if(localVertexId<18.)\\n {\\n result.xy = _letter[17].xy;\\n \\n }\\n result.xy+=_pos;\\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\\n result.xyz =rotZ(result.xyz, _rotation);\\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\\n result *= uniformScale(_scale);\\n \\n \\n return result.xyz;\\n}\\n\\n\\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\\n{\\n vec2 finalPos = _pos;\\n \\n \\n vec2 additionalPos = vec2(0.,0.);\\n \\n float transfoMode = floor(parameter3);\\n \\n \\n //additionalPos.x = _relLetterTimeProgress*0.5;\\n if(transfoMode<1.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n else\\n if(transfoMode<2.)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<3.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<4.)\\n {\\n additionalPos = -finalPos;\\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\\n \\n additionalPos.x+= m.x;\\n additionalPos.y+= m.y;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<5.)\\n {\\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<6.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<7.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n finalPos+= additionalPos;\\n }\\n \\n }\\n else\\n if(transfoMode<8.)\\n {\\n additionalPos = -finalPos;\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<9.)\\n {\\n additionalPos = -finalPos;\\n \\n if(mod(_shapeId,2.)<1.)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n \\n if(transfoMode<10.)\\n {\\n //if(_selectedShape == _shapeId)\\n {\\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\\n additionalPos.y = m.x*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n \\n else\\n \\n if(transfoMode<11.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\\n finalPos+= additionalPos;\\n }\\n \\n return finalPos;\\n}\\n\\n\\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\\n{\\n float finalRot = _rotation;\\n \\n float additionalRotation = 0.;\\n \\n float transfoMode = floor(parameter3);\\n \\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n else\\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n \\n \\n finalRot+= additionalRotation;\\n \\n /*\\n float additionalRotation = 0.;\\n \\n if(selectedLetterIndex == shapeId)\\n {\\n additionalRotation = 2.*PI*relLetterTimeProgress;\\n }\\n \\n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\\n */\\n \\n return finalRot;\\n}\\n\\n\\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\\n{\\n vec2 finalCenter = _center;\\n \\n \\n /*\\n vec2 additionalCenter = vec2(0.,0.);\\n \\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalCenter.x = _relLetterTimeProgress*0.5;\\n additionalCenter.y = _relLetterTimeProgress*0.5;\\n }\\n \\n finalCenter+= additionalCenter;\\n */\\n \\n return finalCenter;\\n}\\n\\n#define elementPerShapeLetterK 18.\\n\\n#define defaultRotationForShapeLetterK 0.13\\n#define defaultRotationForShapeLetterM - 0.09\\n#define defaultRotationForShapeLetterN 0.04\\n#define defaultRotationForShapeLetterA 0.1\\n#define defaultRotationForShapeLetterC - 0.05\\n#define defaultRotationForShapeLetterE - 0.03\\n#define defaultRotationForShapeLetterH 0.04\\n#define defaultRotationForShapeLetterI - 0.02\\n\\n\\n#define shapeNumber 8.\\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\\n\\nvoid main() {\\n \\n \\n vec3 color = vec3(1.);\\n \\n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\\n float _junctionY = 0.5 +parameter4*sndFactor/10.;\\n \\n float _barWidth = 0.2 ;// + parameter4*sndFactor/100.;\\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\\n \\n float shapeId = 0.;\\n \\n vec2 letterK[18];\\n letterK[0] = vec2(0.,0.);\\n letterK[1] = vec2(0.,1.);\\n letterK[2] = vec2(_barWidth,1.);\\n letterK[3] = vec2(0.,0.0);\\n letterK[4] = vec2(_barWidth,1.);\\n letterK[5] = vec2(_barWidth,0.);\\n letterK[6] = vec2(_barWidth,_junctionY);\\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\\n letterK[8] = vec2(_secondVertY,1.);\\n letterK[9] = vec2(_barWidth,_junctionY);\\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\\n letterK[11] = vec2(_secondVertY,0.);\\n letterK[12] = vec2(_secondVertY,0.);\\n letterK[13] = vec2(_secondVertY,0.);\\n letterK[14] = vec2(_secondVertY,0.);\\n letterK[15] = vec2(_secondVertY,0.);\\n letterK[16] = vec2(_secondVertY,0.);\\n letterK[17] = vec2(_secondVertY,0.);\\n \\n vec2 letterM[18];\\n letterM[0] = vec2(0.,0.);\\n letterM[1] = vec2(0.,1.);\\n letterM[2] = vec2(_barWidth,1.);\\n letterM[3] = vec2(0.,0.0);\\n letterM[4] = vec2(_barWidth,1.);\\n letterM[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterM[7] = vec2(_barWidth,1.);\\n letterM[8] = vec2(_barWidth*2.,_junctionY);\\n letterM[9] = vec2(_barWidth*2.,_junctionY);\\n letterM[10] = vec2((_barWidth*3.),1.);\\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\\n letterM[12] = vec2(_barWidth*3.,1.);\\n letterM[13] = vec2(_barWidth*4.,1.);\\n letterM[14] = vec2(_barWidth*3.,0.);\\n letterM[15] = vec2(_barWidth*3.,0.);\\n letterM[16] = vec2(_barWidth*4.,1.);\\n letterM[17] = vec2(_barWidth*4.,0.);\\n \\n \\n vec2 letterN[18];\\n letterN[0] = vec2(0.,0.);\\n letterN[1] = vec2(0.,1.);\\n letterN[2] = vec2(_barWidth,1.);\\n letterN[3] = vec2(0.,0.0);\\n letterN[4] = vec2(_barWidth,1.);\\n letterN[5] = vec2(_barWidth,0.);\\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterN[7] = vec2(_barWidth,1.);\\n letterN[8] = vec2(_barWidth*2.,_junctionY);\\n letterN[9] = vec2(_barWidth*2.,1.);\\n letterN[10] = vec2(_barWidth*3.,1.);\\n letterN[11] = vec2(_barWidth*2.,0.);\\n \\n letterN[12] = vec2(_barWidth*2.,0.);\\n letterN[13] = vec2(_barWidth*3.,1.);\\n letterN[14] = vec2(_barWidth*3.,0.);\\n letterN[15] = vec2(_barWidth*3.,0.);\\n \\n letterN[16] = vec2(_barWidth*3.,0.);\\n letterN[17] = vec2(_barWidth*3.,0.);\\n \\n \\n vec2 letterA[18];\\n letterA[0] = vec2(0.,0.);\\n letterA[1] = vec2(_barWidth,0.);\\n letterA[2] = vec2(_barWidth*2.,1.);\\n letterA[3] = vec2(_barWidth*4.,0.0);\\n letterA[4] = vec2(_barWidth*2.,1.);\\n letterA[5] = vec2(_barWidth*3.,0.);\\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\\n letterA[8] = vec2(_barWidth*3.,_junctionY);\\n letterA[9] = vec2(_barWidth*3.,_junctionY);\\n letterA[10] = vec2(_barWidth*3.,_junctionY);\\n letterA[11] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[12] = vec2(_barWidth*3.,_junctionY);\\n letterA[13] = vec2(_barWidth*3.,_junctionY);\\n letterA[14] = vec2(_barWidth*3.,_junctionY);\\n letterA[15] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[16] = vec2(_barWidth*3.,_junctionY);\\n letterA[17] = vec2(_barWidth*3.,_junctionY);\\n \\n \\n vec2 letterE[18];\\n letterE[0] = vec2(0.,0.);\\n letterE[1] = vec2(0.,1.);\\n letterE[2] = vec2(_barWidth,1.);\\n letterE[3] = vec2(0.,0.0);\\n letterE[4] = vec2(_barWidth,1.);\\n letterE[5] = vec2(_barWidth,0.);\\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\\n letterE[7] = vec2(_barWidth,1.);\\n letterE[8] = vec2(_barWidth*3.,1.);\\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\\n letterE[10] = vec2(_barWidth,0.);\\n letterE[11] = vec2(_barWidth*3.,0.);\\n letterE[12] = vec2(_barWidth,_junctionY);\\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n \\n \\n vec2 letterC[18];\\n letterC[0] = vec2(0.,0.);\\n letterC[1] = vec2(0.,1.);\\n letterC[2] = vec2(_barWidth,1.);\\n letterC[3] = vec2(0.,0.0);\\n letterC[4] = vec2(_barWidth,1.);\\n letterC[5] = vec2(_barWidth,0.);\\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\\n letterC[7] = vec2(_barWidth,1.);\\n letterC[8] = vec2(_barWidth*3.,1.);\\n letterC[9] = vec2(_barWidth,0.);\\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\\n letterC[11] = vec2(_barWidth*3.,0.);\\n letterC[12] = vec2(_barWidth*3.,0.);\\n letterC[13] = vec2(_barWidth*3.,0.);\\n letterC[14] = vec2(_barWidth*3.,0.);\\n letterC[15] = vec2(_barWidth*3.,0.);\\n letterC[16] = vec2(_barWidth*3.,0.);\\n letterC[17] = vec2(_barWidth*3.,0.);\\n \\n vec2 letterH[18];\\n letterH[0] = vec2(0.,0.);\\n letterH[1] = vec2(0.,1.);\\n letterH[2] = vec2(_barWidth,1.);\\n letterH[3] = vec2(0.,0.0);\\n letterH[4] = vec2(_barWidth,1.);\\n letterH[5] = vec2(_barWidth,0.);\\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\\n letterH[8] = vec2(_barWidth*2.,_junctionY);\\n letterH[9] = vec2(_barWidth*2.,_junctionY);\\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\\n letterH[12] = vec2(_barWidth*3.,1.);\\n letterH[13] = vec2(_barWidth*4.,1.);\\n letterH[14] = vec2(_barWidth*3.,0.);\\n letterH[15] = vec2(_barWidth*3.,0.);\\n letterH[16] = vec2(_barWidth*4.,1.);\\n letterH[17] = vec2(_barWidth*4.,0.);\\n \\n vec2 letterI[18];\\n letterI[0] = vec2(0.,0.);\\n letterI[1] = vec2(0.,_junctionY+_barWidth);\\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[3] = vec2(0.,0.0);\\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterI[6] = vec2(0.,1.-_barWidth);\\n letterI[7] = vec2(0.,1.);\\n letterI[8] = vec2(_barWidth,1.-_barWidth);\\n letterI[9] = vec2(_barWidth,1.-_barWidth);\\n letterI[10] = vec2(0.,1.);\\n letterI[11] = vec2(_barWidth,1.);\\n letterI[12] = vec2(_barWidth,1.);\\n letterI[13] = vec2(_barWidth,1.);\\n letterI[14] = vec2(_barWidth,1.);\\n letterI[15] = vec2(_barWidth,1.);\\n letterI[16] = vec2(_barWidth,1.);\\n letterI[17] = vec2(_barWidth,1.);\\n \\n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\\n \\n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\\n \\n finalVertexId = min(maxNumberOfVertices,vertexId);\\n \\n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\\n \\n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\\n //float relMetaShapeId = metaShapeId/256.;\\n \\n float masterScale = parameter5;//parameter6;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n \\n vec2 letterPos = vec2(0.,0.);\\n \\n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\\n \\n float scaleK = 0.4*masterScale;\\n float scale = 0.2*masterScale;\\n float startPosK = parameter2;\\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\\n \\n vec2 shapeCenter = vec2(0.,0.5);\\n \\n //for vsa\\n \\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n \\n //end for vsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n \\n float numberOfSubLoops = floor(parameter0);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n \\n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\\n \\n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\\n \\n /////////////////////////\\n \\n float rotation = PI/3.*time*shapeId;\\n \\n if(finalVertexId0\\n else\\n if(vertexId0\\n else\\n if(vertexId0 && SYMMETRY_H >0\\n else\\n if(vertexId>8. #define parameter1 -0.2//KParameter1 -1.>>1. #define parameter2 -1.//KParameter2 -1.>>1. #define parameter3 0.//KParameter3 0.>>12. #define parameter4 2.//KParameter4 0.>>2. #define parameter5 1.//KParameter5 0.1>>1.5 #define parameter6 0.3//KParameter6 0.>>1. #define parameter7 0.//KParameter7 0.>>10. #define HPI 1.570796326795 #define PI 3.1415926535898 #define SYMMETRY_H 1 #define SYMMETRY_V 1 #define COLOR_MODE 1 vec3 rotZ(vec3 _v, float _rad) { vec2 f = sin(vec2(_rad, _rad + HPI)); vec3 r = _v; r.x = _v.x * f.x + _v.y * f.y; r.y = _v.x * -f.y + _v.y * f.x; return r; } mat4 uniformScale(float _s) { return mat4( _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, 1); } vec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18]) { vec4 result = vec4(0., 0.,-1., 1.); float localVertexId = _vertexId - _startVertexId; if(localVertexId<1.) { result.xy = _letter[0].xy; } else if(localVertexId<2.) { result.xy = _letter[1].xy; } else if(localVertexId<3.) { result.xy = _letter[2].xy; } else //2nd triangle if(localVertexId<4.) { result.xy = _letter[3].xy; } else if(localVertexId<5.) { result.xy = _letter[4].xy; } else if(localVertexId<6.) { result.xy = _letter[5].xy; } else if(localVertexId<7.)//3 eme triangle { result.xy = _letter[6].xy; } else if(localVertexId<8.) { result.xy = _letter[7].xy; } else if(localVertexId<9.) { result.xy = _letter[8].xy; } else if(localVertexId<10.)//4eme triangle { result.xy = _letter[9].xy; } else if(localVertexId<11.) { result.xy = _letter[10].xy; } else if(localVertexId<12.) { result.xy = _letter[11].xy; } else if(localVertexId<13.) { result.xy = _letter[12].xy; } else if(localVertexId<14.) { result.xy = _letter[13].xy; } else if(localVertexId<15.) { result.xy = _letter[14].xy; } else if(localVertexId<16.) { result.xy = _letter[15].xy; } else if(localVertexId<17.) { result.xy = _letter[16].xy; } else if(localVertexId<18.) { result.xy = _letter[17].xy; } result.xy+=_pos; result.xy-=vec2(_barWidth*2.,0.5)+_pos; result.xyz =rotZ(result.xyz, _rotation); result.xy+=vec2(_barWidth*2.,0.5)+_pos; result *= uniformScale(_scale); return result.xyz; } vec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos) { vec2 finalPos = _pos; vec2 additionalPos = vec2(0.,0.); float transfoMode = floor(parameter3); //additionalPos.x = _relLetterTimeProgress*0.5; if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<2.) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6; finalPos+= additionalPos; } else if(transfoMode<3.) { additionalPos = -finalPos; additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI ); additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI ); finalPos+= additionalPos; } else if(transfoMode<4.) { additionalPos = -finalPos; vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) )); additionalPos.x+= m.x; additionalPos.y+= m.y; finalPos+= additionalPos; } else if(transfoMode<5.) { additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time)); finalPos+= additionalPos; } else if(transfoMode<6.) { additionalPos = -finalPos; additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5; additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));; finalPos+= additionalPos; } else if(transfoMode<7.) { if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); finalPos+= additionalPos; } } else if(transfoMode<8.) { additionalPos = -finalPos; if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<9.) { additionalPos = -finalPos; if(mod(_shapeId,2.)<1.) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<10.) { //if(_selectedShape == _shapeId) { vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. )); additionalPos.y = m.x*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<11.) { additionalPos = -finalPos; additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time ); additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time); finalPos+= additionalPos; } return finalPos; } float getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation) { float finalRot = _rotation; float additionalRotation = 0.; float transfoMode = floor(parameter3); if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress; } } else if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = 2.*2.*PI*_relLetterTimeProgress; } } finalRot+= additionalRotation; /* float additionalRotation = 0.; if(selectedLetterIndex == shapeId) { additionalRotation = 2.*PI*relLetterTimeProgress; } rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId; */ return finalRot; } vec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth) { vec2 finalCenter = _center; /* vec2 additionalCenter = vec2(0.,0.); if(_selectedShape == _shapeId) { additionalCenter.x = _relLetterTimeProgress*0.5; additionalCenter.y = _relLetterTimeProgress*0.5; } finalCenter+= additionalCenter; */ return finalCenter; } #define elementPerShapeLetterK 18. #define defaultRotationForShapeLetterK 0.13 #define defaultRotationForShapeLetterM - 0.09 #define defaultRotationForShapeLetterN 0.04 #define defaultRotationForShapeLetterA 0.1 #define defaultRotationForShapeLetterC - 0.05 #define defaultRotationForShapeLetterE - 0.03 #define defaultRotationForShapeLetterH 0.04 #define defaultRotationForShapeLetterI - 0.02 #define shapeNumber 8. #define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber void main() { vec3 color = vec3(1.); float sndFactor = texture2D(sound, vec2(0.01, 0.)).r; float _junctionY = 0.5 +parameter4*sndFactor/10.; float _barWidth = 0.2 ;// + parameter4*sndFactor/100.; float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.; float shapeId = 0.; vec2 letterK[18]; letterK[0] = vec2(0.,0.); letterK[1] = vec2(0.,1.); letterK[2] = vec2(_barWidth,1.); letterK[3] = vec2(0.,0.0); letterK[4] = vec2(_barWidth,1.); letterK[5] = vec2(_barWidth,0.); letterK[6] = vec2(_barWidth,_junctionY); letterK[7] = vec2((_secondVertY+_barWidth),1.); letterK[8] = vec2(_secondVertY,1.); letterK[9] = vec2(_barWidth,_junctionY); letterK[10] = vec2((_secondVertY+_barWidth),0.); letterK[11] = vec2(_secondVertY,0.); letterK[12] = vec2(_secondVertY,0.); letterK[13] = vec2(_secondVertY,0.); letterK[14] = vec2(_secondVertY,0.); letterK[15] = vec2(_secondVertY,0.); letterK[16] = vec2(_secondVertY,0.); letterK[17] = vec2(_secondVertY,0.); vec2 letterM[18]; letterM[0] = vec2(0.,0.); letterM[1] = vec2(0.,1.); letterM[2] = vec2(_barWidth,1.); letterM[3] = vec2(0.,0.0); letterM[4] = vec2(_barWidth,1.); letterM[5] = vec2(_barWidth,0.);//PROBLEM !! letterM[6] = vec2(_barWidth,_junctionY+_barWidth); letterM[7] = vec2(_barWidth,1.); letterM[8] = vec2(_barWidth*2.,_junctionY); letterM[9] = vec2(_barWidth*2.,_junctionY); letterM[10] = vec2((_barWidth*3.),1.); letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth); letterM[12] = vec2(_barWidth*3.,1.); letterM[13] = vec2(_barWidth*4.,1.); letterM[14] = vec2(_barWidth*3.,0.); letterM[15] = vec2(_barWidth*3.,0.); letterM[16] = vec2(_barWidth*4.,1.); letterM[17] = vec2(_barWidth*4.,0.); vec2 letterN[18]; letterN[0] = vec2(0.,0.); letterN[1] = vec2(0.,1.); letterN[2] = vec2(_barWidth,1.); letterN[3] = vec2(0.,0.0); letterN[4] = vec2(_barWidth,1.); letterN[5] = vec2(_barWidth,0.); letterN[6] = vec2(_barWidth,_junctionY+_barWidth); letterN[7] = vec2(_barWidth,1.); letterN[8] = vec2(_barWidth*2.,_junctionY); letterN[9] = vec2(_barWidth*2.,1.); letterN[10] = vec2(_barWidth*3.,1.); letterN[11] = vec2(_barWidth*2.,0.); letterN[12] = vec2(_barWidth*2.,0.); letterN[13] = vec2(_barWidth*3.,1.); letterN[14] = vec2(_barWidth*3.,0.); letterN[15] = vec2(_barWidth*3.,0.); letterN[16] = vec2(_barWidth*3.,0.); letterN[17] = vec2(_barWidth*3.,0.); vec2 letterA[18]; letterA[0] = vec2(0.,0.); letterA[1] = vec2(_barWidth,0.); letterA[2] = vec2(_barWidth*2.,1.); letterA[3] = vec2(_barWidth*4.,0.0); letterA[4] = vec2(_barWidth*2.,1.); letterA[5] = vec2(_barWidth*3.,0.); letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.); letterA[8] = vec2(_barWidth*3.,_junctionY); letterA[9] = vec2(_barWidth*3.,_junctionY); letterA[10] = vec2(_barWidth*3.,_junctionY); letterA[11] = vec2(_barWidth*3.,_junctionY); letterA[12] = vec2(_barWidth*3.,_junctionY); letterA[13] = vec2(_barWidth*3.,_junctionY); letterA[14] = vec2(_barWidth*3.,_junctionY); letterA[15] = vec2(_barWidth*3.,_junctionY); letterA[16] = vec2(_barWidth*3.,_junctionY); letterA[17] = vec2(_barWidth*3.,_junctionY); vec2 letterE[18]; letterE[0] = vec2(0.,0.); letterE[1] = vec2(0.,1.); letterE[2] = vec2(_barWidth,1.); letterE[3] = vec2(0.,0.0); letterE[4] = vec2(_barWidth,1.); letterE[5] = vec2(_barWidth,0.); letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5); letterE[7] = vec2(_barWidth,1.); letterE[8] = vec2(_barWidth*3.,1.); letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5); letterE[10] = vec2(_barWidth,0.); letterE[11] = vec2(_barWidth*3.,0.); letterE[12] = vec2(_barWidth,_junctionY); letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.); letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); vec2 letterC[18]; letterC[0] = vec2(0.,0.); letterC[1] = vec2(0.,1.); letterC[2] = vec2(_barWidth,1.); letterC[3] = vec2(0.,0.0); letterC[4] = vec2(_barWidth,1.); letterC[5] = vec2(_barWidth,0.); letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5); letterC[7] = vec2(_barWidth,1.); letterC[8] = vec2(_barWidth*3.,1.); letterC[9] = vec2(_barWidth,0.); letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5); letterC[11] = vec2(_barWidth*3.,0.); letterC[12] = vec2(_barWidth*3.,0.); letterC[13] = vec2(_barWidth*3.,0.); letterC[14] = vec2(_barWidth*3.,0.); letterC[15] = vec2(_barWidth*3.,0.); letterC[16] = vec2(_barWidth*3.,0.); letterC[17] = vec2(_barWidth*3.,0.); vec2 letterH[18]; letterH[0] = vec2(0.,0.); letterH[1] = vec2(0.,1.); letterH[2] = vec2(_barWidth,1.); letterH[3] = vec2(0.,0.0); letterH[4] = vec2(_barWidth,1.); letterH[5] = vec2(_barWidth,0.); letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.); letterH[8] = vec2(_barWidth*2.,_junctionY); letterH[9] = vec2(_barWidth*2.,_junctionY); letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.); letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.); letterH[12] = vec2(_barWidth*3.,1.); letterH[13] = vec2(_barWidth*4.,1.); letterH[14] = vec2(_barWidth*3.,0.); letterH[15] = vec2(_barWidth*3.,0.); letterH[16] = vec2(_barWidth*4.,1.); letterH[17] = vec2(_barWidth*4.,0.); vec2 letterI[18]; letterI[0] = vec2(0.,0.); letterI[1] = vec2(0.,_junctionY+_barWidth); letterI[2] = vec2(_barWidth,_junctionY+_barWidth); letterI[3] = vec2(0.,0.0); letterI[4] = vec2(_barWidth,_junctionY+_barWidth); letterI[5] = vec2(_barWidth,0.);//PROBLEM !! letterI[6] = vec2(0.,1.-_barWidth); letterI[7] = vec2(0.,1.); letterI[8] = vec2(_barWidth,1.-_barWidth); letterI[9] = vec2(_barWidth,1.-_barWidth); letterI[10] = vec2(0.,1.); letterI[11] = vec2(_barWidth,1.); letterI[12] = vec2(_barWidth,1.); letterI[13] = vec2(_barWidth,1.); letterI[14] = vec2(_barWidth,1.); letterI[15] = vec2(_barWidth,1.); letterI[16] = vec2(_barWidth,1.); letterI[17] = vec2(_barWidth,1.); float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord)); float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;// float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId); //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord); finalVertexId = min(maxNumberOfVertices,vertexId); finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord)); //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord); //float relMetaShapeId = metaShapeId/256.; float masterScale = parameter5;//parameter6; vec3 _v = vec3(0.,0.,0.); vec2 letterPos = vec2(0.,0.); float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.; float scaleK = 0.4*masterScale; float scale = 0.2*masterScale; float startPosK = parameter2; float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters); vec2 shapeCenter = vec2(0.,0.5); //for vsa float loopDurationMs = 4000.; float timeProgress = mod(time*1000.,loopDurationMs); float relLoopProgress = timeProgress/loopDurationMs; //end for vsa float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor)); float numberOfSubLoops = floor(parameter0); float subLoopLength = 1./numberOfSubLoops; finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength; float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber)); float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber); float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress); ///////////////////////// float rotation = PI/3.*time*shapeId; if(finalVertexId0 else if(vertexId0 else if(vertexId0 && SYMMETRY_H >0 else if(vertexId>8.\n#define parameter1 -0.2//KParameter1 -1.>>1.\n#define parameter2 -1.//KParameter2 -1.>>1.\n#define parameter3 0.//KParameter3 0.>>12.\n#define parameter4 2.//KParameter4 0.>>2.\n#define parameter5 1.//KParameter5 0.1>>1.5\n#define parameter6 0.3//KParameter6 0.>>1.\n#define parameter7 0.//KParameter7 0.>>10.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n#define SYMMETRY_H 1\n#define SYMMETRY_V 1\n#define COLOR_MODE 1\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\n{\n \n \n \n \n vec4 result = vec4(0., 0.,-1., 1.);\n \n \n float localVertexId = _vertexId - _startVertexId;\n \n if(localVertexId<1.)\n {\n result.xy = _letter[0].xy;\n }\n else\n \n if(localVertexId<2.)\n {\n result.xy = _letter[1].xy;\n }\n \n else\n if(localVertexId<3.)\n {\n result.xy = _letter[2].xy;\n }\n else //2nd triangle\n if(localVertexId<4.)\n {\n result.xy = _letter[3].xy;\n }\n else\n if(localVertexId<5.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<6.)\n {\n result.xy = _letter[5].xy;\n }\n else\n if(localVertexId<7.)//3 eme triangle\n {\n result.xy = _letter[6].xy;\n }\n else\n if(localVertexId<8.)\n {\n result.xy = _letter[7].xy;\n }\n else\n if(localVertexId<9.)\n {\n result.xy = _letter[8].xy;\n \n }\n \n else\n if(localVertexId<10.)//4eme triangle\n {\n result.xy = _letter[9].xy;\n \n }\n else\n if(localVertexId<11.)\n {\n result.xy = _letter[10].xy;\n \n }\n \n else\n if(localVertexId<12.)\n {\n result.xy = _letter[11].xy;\n \n }\n else\n if(localVertexId<13.)\n {\n result.xy = _letter[12].xy;\n \n }\n else\n if(localVertexId<14.)\n {\n result.xy = _letter[13].xy;\n \n }\n else\n if(localVertexId<15.)\n {\n result.xy = _letter[14].xy;\n \n }\n else\n if(localVertexId<16.)\n {\n result.xy = _letter[15].xy;\n \n }\n else\n if(localVertexId<17.)\n {\n result.xy = _letter[16].xy;\n \n }\n else\n if(localVertexId<18.)\n {\n result.xy = _letter[17].xy;\n \n }\n result.xy+=_pos;\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\n result.xyz =rotZ(result.xyz, _rotation);\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\n result *= uniformScale(_scale);\n \n \n return result.xyz;\n}\n\n\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\n{\n vec2 finalPos = _pos;\n \n \n vec2 additionalPos = vec2(0.,0.);\n \n float transfoMode = floor(parameter3);\n \n \n //additionalPos.x = _relLetterTimeProgress*0.5;\n if(transfoMode<1.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n else\n if(transfoMode<2.)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<3.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<4.)\n {\n additionalPos = -finalPos;\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\n \n additionalPos.x+= m.x;\n additionalPos.y+= m.y;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<5.)\n {\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<6.)\n {\n additionalPos = -finalPos;\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<7.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n finalPos+= additionalPos;\n }\n \n }\n else\n if(transfoMode<8.)\n {\n additionalPos = -finalPos;\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<9.)\n {\n additionalPos = -finalPos;\n \n if(mod(_shapeId,2.)<1.)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n \n if(transfoMode<10.)\n {\n //if(_selectedShape == _shapeId)\n {\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\n additionalPos.y = m.x*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n \n else\n \n if(transfoMode<11.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\n finalPos+= additionalPos;\n }\n \n return finalPos;\n}\n\n\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\n{\n float finalRot = _rotation;\n \n float additionalRotation = 0.;\n \n float transfoMode = floor(parameter3);\n \n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\n \n }\n }\n else\n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\n \n }\n }\n \n \n finalRot+= additionalRotation;\n \n /*\n float additionalRotation = 0.;\n \n if(selectedLetterIndex == shapeId)\n {\n additionalRotation = 2.*PI*relLetterTimeProgress;\n }\n \n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\n */\n \n return finalRot;\n}\n\n\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\n{\n vec2 finalCenter = _center;\n \n \n /*\n vec2 additionalCenter = vec2(0.,0.);\n \n \n if(_selectedShape == _shapeId)\n {\n additionalCenter.x = _relLetterTimeProgress*0.5;\n additionalCenter.y = _relLetterTimeProgress*0.5;\n }\n \n finalCenter+= additionalCenter;\n */\n \n return finalCenter;\n}\n\n#define elementPerShapeLetterK 18.\n\n#define defaultRotationForShapeLetterK 0.13\n#define defaultRotationForShapeLetterM - 0.09\n#define defaultRotationForShapeLetterN 0.04\n#define defaultRotationForShapeLetterA 0.1\n#define defaultRotationForShapeLetterC - 0.05\n#define defaultRotationForShapeLetterE - 0.03\n#define defaultRotationForShapeLetterH 0.04\n#define defaultRotationForShapeLetterI - 0.02\n\n\n#define shapeNumber 8.\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\n\nvoid main() {\n \n \n vec3 color = vec3(1.);\n \n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\n float _junctionY = 0.5 +parameter4*sndFactor/10.;\n \n float _barWidth = 0.2 ;// + parameter4*sndFactor/100.;\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\n \n float shapeId = 0.;\n \n vec2 letterK[18];\n letterK[0] = vec2(0.,0.);\n letterK[1] = vec2(0.,1.);\n letterK[2] = vec2(_barWidth,1.);\n letterK[3] = vec2(0.,0.0);\n letterK[4] = vec2(_barWidth,1.);\n letterK[5] = vec2(_barWidth,0.);\n letterK[6] = vec2(_barWidth,_junctionY);\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\n letterK[8] = vec2(_secondVertY,1.);\n letterK[9] = vec2(_barWidth,_junctionY);\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\n letterK[11] = vec2(_secondVertY,0.);\n letterK[12] = vec2(_secondVertY,0.);\n letterK[13] = vec2(_secondVertY,0.);\n letterK[14] = vec2(_secondVertY,0.);\n letterK[15] = vec2(_secondVertY,0.);\n letterK[16] = vec2(_secondVertY,0.);\n letterK[17] = vec2(_secondVertY,0.);\n \n vec2 letterM[18];\n letterM[0] = vec2(0.,0.);\n letterM[1] = vec2(0.,1.);\n letterM[2] = vec2(_barWidth,1.);\n letterM[3] = vec2(0.,0.0);\n letterM[4] = vec2(_barWidth,1.);\n letterM[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterM[7] = vec2(_barWidth,1.);\n letterM[8] = vec2(_barWidth*2.,_junctionY);\n letterM[9] = vec2(_barWidth*2.,_junctionY);\n letterM[10] = vec2((_barWidth*3.),1.);\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\n letterM[12] = vec2(_barWidth*3.,1.);\n letterM[13] = vec2(_barWidth*4.,1.);\n letterM[14] = vec2(_barWidth*3.,0.);\n letterM[15] = vec2(_barWidth*3.,0.);\n letterM[16] = vec2(_barWidth*4.,1.);\n letterM[17] = vec2(_barWidth*4.,0.);\n \n \n vec2 letterN[18];\n letterN[0] = vec2(0.,0.);\n letterN[1] = vec2(0.,1.);\n letterN[2] = vec2(_barWidth,1.);\n letterN[3] = vec2(0.,0.0);\n letterN[4] = vec2(_barWidth,1.);\n letterN[5] = vec2(_barWidth,0.);\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterN[7] = vec2(_barWidth,1.);\n letterN[8] = vec2(_barWidth*2.,_junctionY);\n letterN[9] = vec2(_barWidth*2.,1.);\n letterN[10] = vec2(_barWidth*3.,1.);\n letterN[11] = vec2(_barWidth*2.,0.);\n \n letterN[12] = vec2(_barWidth*2.,0.);\n letterN[13] = vec2(_barWidth*3.,1.);\n letterN[14] = vec2(_barWidth*3.,0.);\n letterN[15] = vec2(_barWidth*3.,0.);\n \n letterN[16] = vec2(_barWidth*3.,0.);\n letterN[17] = vec2(_barWidth*3.,0.);\n \n \n vec2 letterA[18];\n letterA[0] = vec2(0.,0.);\n letterA[1] = vec2(_barWidth,0.);\n letterA[2] = vec2(_barWidth*2.,1.);\n letterA[3] = vec2(_barWidth*4.,0.0);\n letterA[4] = vec2(_barWidth*2.,1.);\n letterA[5] = vec2(_barWidth*3.,0.);\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\n letterA[8] = vec2(_barWidth*3.,_junctionY);\n letterA[9] = vec2(_barWidth*3.,_junctionY);\n letterA[10] = vec2(_barWidth*3.,_junctionY);\n letterA[11] = vec2(_barWidth*3.,_junctionY);\n \n letterA[12] = vec2(_barWidth*3.,_junctionY);\n letterA[13] = vec2(_barWidth*3.,_junctionY);\n letterA[14] = vec2(_barWidth*3.,_junctionY);\n letterA[15] = vec2(_barWidth*3.,_junctionY);\n \n letterA[16] = vec2(_barWidth*3.,_junctionY);\n letterA[17] = vec2(_barWidth*3.,_junctionY);\n \n \n vec2 letterE[18];\n letterE[0] = vec2(0.,0.);\n letterE[1] = vec2(0.,1.);\n letterE[2] = vec2(_barWidth,1.);\n letterE[3] = vec2(0.,0.0);\n letterE[4] = vec2(_barWidth,1.);\n letterE[5] = vec2(_barWidth,0.);\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\n letterE[7] = vec2(_barWidth,1.);\n letterE[8] = vec2(_barWidth*3.,1.);\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\n letterE[10] = vec2(_barWidth,0.);\n letterE[11] = vec2(_barWidth*3.,0.);\n letterE[12] = vec2(_barWidth,_junctionY);\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n \n \n vec2 letterC[18];\n letterC[0] = vec2(0.,0.);\n letterC[1] = vec2(0.,1.);\n letterC[2] = vec2(_barWidth,1.);\n letterC[3] = vec2(0.,0.0);\n letterC[4] = vec2(_barWidth,1.);\n letterC[5] = vec2(_barWidth,0.);\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\n letterC[7] = vec2(_barWidth,1.);\n letterC[8] = vec2(_barWidth*3.,1.);\n letterC[9] = vec2(_barWidth,0.);\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\n letterC[11] = vec2(_barWidth*3.,0.);\n letterC[12] = vec2(_barWidth*3.,0.);\n letterC[13] = vec2(_barWidth*3.,0.);\n letterC[14] = vec2(_barWidth*3.,0.);\n letterC[15] = vec2(_barWidth*3.,0.);\n letterC[16] = vec2(_barWidth*3.,0.);\n letterC[17] = vec2(_barWidth*3.,0.);\n \n vec2 letterH[18];\n letterH[0] = vec2(0.,0.);\n letterH[1] = vec2(0.,1.);\n letterH[2] = vec2(_barWidth,1.);\n letterH[3] = vec2(0.,0.0);\n letterH[4] = vec2(_barWidth,1.);\n letterH[5] = vec2(_barWidth,0.);\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\n letterH[8] = vec2(_barWidth*2.,_junctionY);\n letterH[9] = vec2(_barWidth*2.,_junctionY);\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\n letterH[12] = vec2(_barWidth*3.,1.);\n letterH[13] = vec2(_barWidth*4.,1.);\n letterH[14] = vec2(_barWidth*3.,0.);\n letterH[15] = vec2(_barWidth*3.,0.);\n letterH[16] = vec2(_barWidth*4.,1.);\n letterH[17] = vec2(_barWidth*4.,0.);\n \n vec2 letterI[18];\n letterI[0] = vec2(0.,0.);\n letterI[1] = vec2(0.,_junctionY+_barWidth);\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[3] = vec2(0.,0.0);\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterI[6] = vec2(0.,1.-_barWidth);\n letterI[7] = vec2(0.,1.);\n letterI[8] = vec2(_barWidth,1.-_barWidth);\n letterI[9] = vec2(_barWidth,1.-_barWidth);\n letterI[10] = vec2(0.,1.);\n letterI[11] = vec2(_barWidth,1.);\n letterI[12] = vec2(_barWidth,1.);\n letterI[13] = vec2(_barWidth,1.);\n letterI[14] = vec2(_barWidth,1.);\n letterI[15] = vec2(_barWidth,1.);\n letterI[16] = vec2(_barWidth,1.);\n letterI[17] = vec2(_barWidth,1.);\n \n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\n \n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\n \n finalVertexId = min(maxNumberOfVertices,vertexId);\n \n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\n \n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\n //float relMetaShapeId = metaShapeId/256.;\n \n float masterScale = parameter5;//parameter6;\n \n vec3 _v = vec3(0.,0.,0.);\n \n vec2 letterPos = vec2(0.,0.);\n \n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\n \n float scaleK = 0.4*masterScale;\n float scale = 0.2*masterScale;\n float startPosK = parameter2;\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\n \n vec2 shapeCenter = vec2(0.,0.5);\n \n //for vsa\n \n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n \n //end for vsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n \n float numberOfSubLoops = floor(parameter0);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n \n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\n \n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\n \n /////////////////////////\n \n float rotation = PI/3.*time*shapeId;\n \n if(finalVertexId0\n else\n if(vertexId0\n else\n if(vertexId0 && SYMMETRY_H >0\n else\n if(vertexId 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-4hcrrdd6bds0yxbxb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/H88o3mRfNBBZrnZh7/art.json b/art/H88o3mRfNBBZrnZh7/art.json index ce004e6b..5f0b85de 100644 --- a/art/H88o3mRfNBBZrnZh7/art.json +++ b/art/H88o3mRfNBBZrnZh7/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "lu", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14Gi3W5KBrIJ4G5NrATJuQSojtEJGMd72Qd59s5nt", - "settings": "{\"num\":2590,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8784313725490196,0.9333333333333333,0.8313725490196079,1],\"shader\":\"\\nconst float line = 3. ; \\nvec2 drawTriangle(in float vertexId ,out vec3 color )\\n{\\n vec2 res = vec2(1.);\\n // res.x = floor(mod(vertexId , line))/line;\\n // res.y = floor(vertexId/ line) ; \\n if(vertexId < (vertexCount / 3. ))\\n {\\n res.x = -0.5 ; \\n res.y = -0.5 ; \\n color.r = 1.;\\n color.g = 0. ; \\n color.b = 0. ; \\n res.x += (sin(-time * 3.0) * 0.1);\\n res.y += (cos(-time * 10.0) * 0.1);\\n } \\n else if (vertexId > (vertexCount * 2. /3. )) \\n {\\n res.x = 0.5 ; \\n res.y = -0.5 ; \\n color.r = 0.;\\n color.g = 1. ; \\n color.b = 0. ; \\n res.x += (sin(-time * 10.0) * 0.1);\\n res.y += (cos(time * 7.0) * 0.1);\\n }\\n else\\n {\\n res.x = 0. ; \\n res.y = 0.5 ;\\n color.r = 0.;\\n color.g = 0. ; \\n color.b = 1. ; \\n res.x += (sin(time * 5.0) * 0.1);\\n res.y += (cos(time * 11.0) * 0.1);\\n }\\n return res; \\n \\n}\\n\\nvoid main()\\n{\\n vec3 color = vec3(1.);\\n \\n \\n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\\n \\n gl_PointSize = 1. ; \\n \\n v_color = vec4(color , 1.0);\\n}\"}", + "settings": { + "num": 2590, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8784313725490196, + 0.9333333333333333, + 0.8313725490196079, + 1 + ], + "shader": "\nconst float line = 3. ; \nvec2 drawTriangle(in float vertexId ,out vec3 color )\n{\n vec2 res = vec2(1.);\n // res.x = floor(mod(vertexId , line))/line;\n // res.y = floor(vertexId/ line) ; \n if(vertexId < (vertexCount / 3. ))\n {\n res.x = -0.5 ; \n res.y = -0.5 ; \n color.r = 1.;\n color.g = 0. ; \n color.b = 0. ; \n res.x += (sin(-time * 3.0) * 0.1);\n res.y += (cos(-time * 10.0) * 0.1);\n } \n else if (vertexId > (vertexCount * 2. /3. )) \n {\n res.x = 0.5 ; \n res.y = -0.5 ; \n color.r = 0.;\n color.g = 1. ; \n color.b = 0. ; \n res.x += (sin(-time * 10.0) * 0.1);\n res.y += (cos(time * 7.0) * 0.1);\n }\n else\n {\n res.x = 0. ; \n res.y = 0.5 ;\n color.r = 0.;\n color.g = 0. ; \n color.b = 1. ; \n res.x += (sin(time * 5.0) * 0.1);\n res.y += (cos(time * 11.0) * 0.1);\n }\n return res; \n \n}\n\nvoid main()\n{\n vec3 color = vec3(1.);\n \n \n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\n \n gl_PointSize = 1. ; \n \n v_color = vec4(color , 1.0);\n}" + }, "screenshotURL": "data/images/images-vzzg29nql9htquoyf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HASGvL8w5vDqzrGQk/art.json b/art/HASGvL8w5vDqzrGQk/art.json index eb878f29..42f3d605 100644 --- a/art/HASGvL8w5vDqzrGQk/art.json +++ b/art/HASGvL8w5vDqzrGQk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/taeoxo/ty-x-seulgi-rose\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Audio Reactive\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/taeoxo/ty-x-seulgi-rose", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Audio Reactive\n// Course Name: CS250\n// Term: Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-rzvs4mpei5yx5xgze-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HCYetf4hAQidqDBdG/art.json b/art/HCYetf4hAQidqDBdG/art.json index 28f482fa..427eedb8 100644 --- a/art/HCYetf4hAQidqDBdG/art.json +++ b/art/HCYetf4hAQidqDBdG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// a good example to start adding Kparameters\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n //float soff = sin(time + x * y ) * 500.; \\n float soff = (sin(time + x / (y+2.)) + sin(time + y / (x+3.))) * 50.; \\n\\n gl_PointSize = soff/(xoff+ yoff +50.) +10. ;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(soff/100., xoff*10., sin(soff/10.) +1., 0);\\n // v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// a good example to start adding Kparameters\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n //float soff = sin(time + x * y ) * 500.; \n float soff = (sin(time + x / (y+2.)) + sin(time + y / (x+3.))) * 50.; \n\n gl_PointSize = soff/(xoff+ yoff +50.) +10. ;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(soff/100., xoff*10., sin(soff/10.) +1., 0);\n // v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-wprklghj0oba11vhu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HDvg7tiSomNBAxKwH/art.json b/art/HDvg7tiSomNBAxKwH/art.json index 9eccfdb2..cc3d9153 100644 --- a/art/HDvg7tiSomNBAxKwH/art.json +++ b/art/HDvg7tiSomNBAxKwH/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "cupcake", "avatarUrl": "https://secure.gravatar.com/avatar/cd544a78a28e83d0e0dc1f8154ee546f?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2Fa8e4aacf74a3636a5665c2f7fc641881", - "settings": "{\"num\":3474,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.011764705882352941,0.34509803921568627,0.29411764705882354,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x /(across-1.0);\\n float v = y /(across-1.0);\\n \\n float xoff = sin(time+y*0.2)*0.1;\\n float yoff = sin(time+x*0.3)*0.2;\\n \\n u = u*2.0-1.0 + xoff;\\n v = v*2.0-1.0 + yoff;\\n \\n vec2 xy = vec2(u, v) * 0.7;\\n \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x*y*0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1, 0.2, 0.2, 1);\\n \\n \\n \\n /*\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd;// = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n*/\\n}\"}", + "settings": { + "num": 3474, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.011764705882352941, + 0.34509803921568627, + 0.29411764705882354, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x /(across-1.0);\n float v = y /(across-1.0);\n \n float xoff = sin(time+y*0.2)*0.1;\n float yoff = sin(time+x*0.3)*0.2;\n \n u = u*2.0-1.0 + xoff;\n v = v*2.0-1.0 + yoff;\n \n vec2 xy = vec2(u, v) * 0.7;\n \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x*y*0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1, 0.2, 0.2, 1);\n \n \n \n /*\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd;// = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n*/\n}" + }, "screenshotURL": "data/images/images-acs87mtdesthl2emm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HFBbsCKy7Ypjr3eRc/art.json b/art/HFBbsCKy7Ypjr3eRc/art.json index 7e2d4a4a..3e941439 100644 --- a/art/HFBbsCKy7Ypjr3eRc/art.json +++ b/art/HFBbsCKy7Ypjr3eRc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":80000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/keshibeats/butimissyou\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(av * .25, au * .05)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.8, 5.) * 3.0 + soff;\\n gl_PointSize *= 50. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = mix(.1, pow(snd + 0.2, 5.), pump); // mix(1., -10.,av);\\n float val = mix(0., 1., pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 80000, + "mode": "POINTS", + "sound": "https://soundcloud.com/keshibeats/butimissyou", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(av * .25, au * .05)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.8, 5.) * 3.0 + soff;\n gl_PointSize *= 50. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = mix(.1, pow(snd + 0.2, 5.), pump); // mix(1., -10.,av);\n float val = mix(0., 1., pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-i63xslr5ocknrqmld-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HFT5yR2hvCfsLXPbM/art.json b/art/HFT5yR2hvCfsLXPbM/art.json index f4a819fc..0aba58af 100644 --- a/art/HFT5yR2hvCfsLXPbM/art.json +++ b/art/HFT5yR2hvCfsLXPbM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":5739,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 mouse.x *2.//KParameter0 0.>>1000.\\n#define KP1 56.//KParaeter1 0.0>>22.\\n#define KP2 mouse.y *9.0//KParameter2 -6.0>>10.\\n#define KP3 -0.01//KParameter3 -8.000>>0.5\\n#define KP4 11.2//KParameter4 0.000>>5.\\n#define KP5 1130.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=100000\\n#define PI radians(180. -KP1)\\n\\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 5739, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 mouse.x *2.//KParameter0 0.>>1000.\n#define KP1 56.//KParaeter1 0.0>>22.\n#define KP2 mouse.y *9.0//KParameter2 -6.0>>10.\n#define KP3 -0.01//KParameter3 -8.000>>0.5\n#define KP4 11.2//KParameter4 0.000>>5.\n#define KP5 1130.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=100000\n#define PI radians(180. -KP1)\n\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-eg3v13cpnvod9kyhi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HFcjWasxbbQroZZt3/art.json b/art/HFcjWasxbbQroZZt3/art.json index 88cea14c..2324064f 100644 --- a/art/HFcjWasxbbQroZZt3/art.json +++ b/art/HFcjWasxbbQroZZt3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\n/*\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id *1.55),\\n cos(id *0.43),\\n sin(id*0.22));\\n}\\n*/\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float travelSpeed = -150.;\\nconst float expand = 120.;\\nconst float off = 0.1;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\\n \\n float sv = mod(vertexId+time*travelSpeed,vertexCount) / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n vec3 eye = r0 * expand + zaxis * 1.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n//\\n float sizeFactor = 1./4.;\\n \\n float shapeCount = floor(vertexCount / 36.);\\n float shapeId = floor(vertexId / 36.);\\n float shapeVertexId = mod(vertexId, 36.);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElementPerGroup = 10.;\\n float groupId = floor(shapeId/numberOfElementPerGroup);\\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\\n float relGroupId = shapeIdInGroup/numberOfElementPerGroup;\\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\\n \\n \\n float base = 14.5; // good place to adjust\\n base = time * 1.0;\\n\\n /*\\n vec3 b0 = getCurvePoint(base + off * 0.);\\n vec3 b1 = getCurvePoint(base + off * 1.);\\n vec3 b2 = getCurvePoint(base + off * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n \\n vec3 eye = b0 * expand + czaxis * 1.;\\n vec3 target = b1 * expand + czaxis;\\n vec3 up = cyaxis;\\n */\\n \\n /*\\n//Static eye\\n vec3 eye = vec3(0.5, 0.5, 2.5)*expand;\\n vec3 target = vec3(0.5, 0.5, 0.)*expand;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n */\\n //Following eye\\n float sv = mod( (0. /2.)+time*0.,groupCount) / 1.;\\n float v = sv + base;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n vec3 eye = r1 * expand + zaxis * 1.;\\n vec3 target = r2 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n \\n \\n \\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n //cubep*= sizeFactor;\\n mat4 scaleMat = scale(vec3(sizeFactor,(3.+snd*snd)*sizeFactor,sizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n mat4 zrot = rotZ(relGroupId*2.*PI);\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n //cbNi*=scaleMat;\\n \\n //create the circle group\\n \\n \\n \\n float radius = 100.*sizeFactor;\\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n //base+= mod(time,2.);\\n mat4 wmat;\\n mat4 emat;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi;\\n //float rotx = atan( wmat.y, wmat.z );\\n //float roty = Math.atan2( x * Math.cos(rotx), z )\\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \\n \\n \\n //cbNi.xyz+= posi;\\n \\n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\n/*\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id *1.55),\n cos(id *0.43),\n sin(id*0.22));\n}\n*/\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float travelSpeed = -150.;\nconst float expand = 120.;\nconst float off = 0.1;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\n \n float sv = mod(vertexId+time*travelSpeed,vertexCount) / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n vec3 eye = r0 * expand + zaxis * 1.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n//\n float sizeFactor = 1./4.;\n \n float shapeCount = floor(vertexCount / 36.);\n float shapeId = floor(vertexId / 36.);\n float shapeVertexId = mod(vertexId, 36.);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElementPerGroup = 10.;\n float groupId = floor(shapeId/numberOfElementPerGroup);\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\n float relGroupId = shapeIdInGroup/numberOfElementPerGroup;\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\n \n \n float base = 14.5; // good place to adjust\n base = time * 1.0;\n\n /*\n vec3 b0 = getCurvePoint(base + off * 0.);\n vec3 b1 = getCurvePoint(base + off * 1.);\n vec3 b2 = getCurvePoint(base + off * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n \n vec3 eye = b0 * expand + czaxis * 1.;\n vec3 target = b1 * expand + czaxis;\n vec3 up = cyaxis;\n */\n \n /*\n//Static eye\n vec3 eye = vec3(0.5, 0.5, 2.5)*expand;\n vec3 target = vec3(0.5, 0.5, 0.)*expand;\n vec3 up = vec3(0.5, 0.5, 1.5);\n */\n //Following eye\n float sv = mod( (0. /2.)+time*0.,groupCount) / 1.;\n float v = sv + base;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n vec3 eye = r1 * expand + zaxis * 1.;\n vec3 target = r2 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n \n \n \n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n //cubep*= sizeFactor;\n mat4 scaleMat = scale(vec3(sizeFactor,(3.+snd*snd)*sizeFactor,sizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n mat4 zrot = rotZ(relGroupId*2.*PI);\n cubep = (zrot*vec4(cubep,1.)).xyz;\n //cbNi*=scaleMat;\n \n //create the circle group\n \n \n \n float radius = 100.*sizeFactor;\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n vec4 color;\n \n \n //shapeId = mod(shapeId+time, shapeCount);\n //base+= mod(time,2.);\n mat4 wmat;\n mat4 emat;\n \n //shapeId = mod(shapeId+time, shapeCount);\n track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi;\n //float rotx = atan( wmat.y, wmat.z );\n //float roty = Math.atan2( x * Math.cos(rotx), z )\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \n \n \n //cbNi.xyz+= posi;\n \n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-ak12h6rwllvxwrt26-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HKJSL9FWrAxtLhmyf/art.json b/art/HKJSL9FWrAxtLhmyf/art.json index a9d46d19..07f4d752 100644 --- a/art/HKJSL9FWrAxtLhmyf/art.json +++ b/art/HKJSL9FWrAxtLhmyf/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "ale", "avatarUrl": "https://lh6.googleusercontent.com/-A2JcKOXWDHc/AAAAAAAAAAI/AAAAAAAAAcE/deS0m5oEnec/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\" /* float theta = radians(0.0)< angle X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 5.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.25, fract(f * 2.))), \\n mix(-1., 1., step(0.55, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 13.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.2, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos * 3.0);\\n \\n \\tvec3 vH = normalize( vView - sin(vLight * time));\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.1, 1.0, pow( 3.0 - NdotL, 4.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 * 0.8;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.025 );\\n\\n outSceneVertex.fAlpha = 0.9; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 0.0, fAOAmount, clamp( h, 0.9, 0.5 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 11.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 1, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, -0.1,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -2,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.15, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.6, 0.03);\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "CSS", + "backgroundColor": [ + 0.5019607843137255, + 0.5019607843137255, + 0.5019607843137255, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.5;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 44.0, -50.3, -20.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.0031;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.15, vViewDir.y + 5.0) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 5.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 5.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.25, fract(f * 2.))), \n mix(-1., 1., step(0.55, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 13.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.2, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos * 3.0);\n \n \tvec3 vH = normalize( vView - sin(vLight * time));\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.1, 1.0, pow( 3.0 - NdotL, 4.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 * 0.8;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.025 );\n\n outSceneVertex.fAlpha = 0.9; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 0.0, fAOAmount, clamp( h, 0.9, 0.5 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 11.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 1, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, -0.1,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -2,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.15, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.6, 0.03);\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-i6m5il2zw7igl7gvj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HQrHbHySYQAdvmEGG/art.json b/art/HQrHbHySYQAdvmEGG/art.json index 7d71ce4f..ba0a30da 100644 --- a/art/HQrHbHySYQAdvmEGG/art.json +++ b/art/HQrHbHySYQAdvmEGG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thenoiseprocess/i-want-my-credit-card\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n float snd = texture2D(sound, vec2(0.2, u)).a;\\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 56.0;\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\tvec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\tfor(float i = 0.001; i < (13.0); i++){\\n\\t\\t\\n\\t\\tfloat s = 6.*snd*cos(sin(10. * time / i )) ;\\n\\t\\tfloat c = tan(cos(0.1* -time + i ));\\n\\t\\tf +=abs( (0.001+snd/0.07) / abs(length( s-(9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n\\n \\n \\n \\n gl_PointSize = 1.+snd*2.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(destColor * - f), 1.0);\\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\\n v_color = vec4(vec3(1.5), 0.8250);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thenoiseprocess/i-want-my-credit-card", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n float snd = texture2D(sound, vec2(0.2, u)).a;\n \n //apply fragment logic\n\n\tconst float colorCount = 56.0;\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\tvec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\tfor(float i = 0.001; i < (13.0); i++){\n\t\t\n\t\tfloat s = 6.*snd*cos(sin(10. * time / i )) ;\n\t\tfloat c = tan(cos(0.1* -time + i ));\n\t\tf +=abs( (0.001+snd/0.07) / abs(length( s-(9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\n\t}\n\n\n \n \n \n gl_PointSize = 1.+snd*2.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(destColor * - f), 1.0);\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\n v_color = vec4(vec3(1.5), 0.8250);\n\n}" + }, "screenshotURL": "data/images/images-28mun08spla2b902d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HS9sJXXJGFwxGjoYe/art.json b/art/HS9sJXXJGFwxGjoYe/art.json index 1d78e23f..7a1cf092 100644 --- a/art/HS9sJXXJGFwxGjoYe/art.json +++ b/art/HS9sJXXJGFwxGjoYe/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "marcoisaac", "avatarUrl": "https://lh6.googleusercontent.com/-jsbJZMoV7aw/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rczbGrsWSlymdrCUasJ8WzEUV3Ptg/mo/photo.jpg", - "settings": "{\"num\":28107,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec2 drawCircle(float id);\\n\\nvoid main()\\n{\\n \\n float circleId = floor(vertexId / 120.0);\\n float numCircles = floor(900.0 / 5.0);\\n \\n float col = floor(sqrt(numCircles));//down\\n float fil = floor(numCircles/col);//across\\n \\n float x = mod(circleId, fil); // [0, width - 1]\\n float y = floor(circleId / fil); // [0, inf]\\n\\n float u = x / (fil - 1.0);\\n float v = y / (fil - 1.0); \\n \\n float xOffset = cos(time + y * 0.2) * 0.3;\\n float yOffset = cos(time + x * 0.3) * 0.3 ;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n //vec2 xy = vec2(ux, vy)* 0.4;\\n vec2 xy = drawCircle(vertexId) * 0.16 + vec2(ux, vy) * 1.5;\\n\\n //gl_Position = vec4(xy + (drawCircleXY(vertexId) * 0.05) , 0.0, 1.0);\\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n gl_PointSize = 15.0 ;\\n gl_PointSize *= 32.0 / fil;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n}\\n\\n\\n\\nvec2 drawCircle(float id)\\n{\\n \\n float x = floor(id / 2.0) + mod(id, 2.0);\\n //float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n float y = mod(id + 1.0, 2.0);\\n \\n float angle = x / 20.0 * radians(180.0) * 2.0 ;\\n float radius = 2.0 - y;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n vec2 xy = vec2(u, v) * 0.33;\\n \\n return xy;\\n}\"}", + "settings": { + "num": 28107, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec2 drawCircle(float id);\n\nvoid main()\n{\n \n float circleId = floor(vertexId / 120.0);\n float numCircles = floor(900.0 / 5.0);\n \n float col = floor(sqrt(numCircles));//down\n float fil = floor(numCircles/col);//across\n \n float x = mod(circleId, fil); // [0, width - 1]\n float y = floor(circleId / fil); // [0, inf]\n\n float u = x / (fil - 1.0);\n float v = y / (fil - 1.0); \n \n float xOffset = cos(time + y * 0.2) * 0.3;\n float yOffset = cos(time + x * 0.3) * 0.3 ;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n //vec2 xy = vec2(ux, vy)* 0.4;\n vec2 xy = drawCircle(vertexId) * 0.16 + vec2(ux, vy) * 1.5;\n\n //gl_Position = vec4(xy + (drawCircleXY(vertexId) * 0.05) , 0.0, 1.0);\n gl_Position = vec4(xy, 0.0, 1.0);\n \n gl_PointSize = 15.0 ;\n gl_PointSize *= 32.0 / fil;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n}\n\n\n\nvec2 drawCircle(float id)\n{\n \n float x = floor(id / 2.0) + mod(id, 2.0);\n //float y = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n float y = mod(id + 1.0, 2.0);\n \n float angle = x / 20.0 * radians(180.0) * 2.0 ;\n float radius = 2.0 - y;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n vec2 xy = vec2(u, v) * 0.33;\n \n return xy;\n}" + }, "screenshotURL": "data/images/images-9om2eqdjc5suyd6eb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HSGSvjGwQyB6cFQMP/art.json b/art/HSGSvjGwQyB6cFQMP/art.json index 45e9d8e6..beafec32 100644 --- a/art/HSGSvjGwQyB6cFQMP/art.json +++ b/art/HSGSvjGwQyB6cFQMP/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "dots", "username": "gman", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/claudevonstroke/vocal-chords\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define NUM_SEGMENTS 64.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 32.0\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float sndPM = snd * 2.0 - 1.0;\\n \\n gl_PointSize = min(32.0, snd * 32.0) * invV;\\n\\n float x = u * 2.0 - 1.0 + sndPM * 0.05;\\n float y = v * 2.0 - 1.0;;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = u * 0.1 + time * 0.01;\\n float sat = invV;\\n float val = mix(snd * invV, 1.0, v);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/claudevonstroke/vocal-chords", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 64.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 32.0\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float sndPM = snd * 2.0 - 1.0;\n \n gl_PointSize = min(32.0, snd * 32.0) * invV;\n\n float x = u * 2.0 - 1.0 + sndPM * 0.05;\n float y = v * 2.0 - 1.0;;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = u * 0.1 + time * 0.01;\n float sat = invV;\n float val = mix(snd * invV, 1.0, v);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "ssTFyFzXXEKdnCe9X", "views": { "$numberInt": "400" diff --git a/art/HW98dGDbChYw2FjpS/art.json b/art/HW98dGDbChYw2FjpS/art.json index ab171cb2..669a024c 100644 --- a/art/HW98dGDbChYw2FjpS/art.json +++ b/art/HW98dGDbChYw2FjpS/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":50400,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5725490196078431,0.5725490196078431,0.5725490196078431,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hash3(vec3 v) {\\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x;\\n rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\\n * vec4(p, 1.0);\\n return pp.xyz;\\n}\\n\\nvec3 lissajous(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\\n#define kCubeVertexCount 36.0\\nvec3 cubeVertex(float vid, out vec4 ni) {\\n float faceId = floor(vid / 6.0);\\n float vtxId = mod(vid, 6.0);\\n vec2 fp;\\n vec3 p;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n // front\\n p = vec3(fp.x, fp.y, 1.0);\\n ni = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n // back\\n p = vec3(-fp.x, fp.y, -1.0);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n // top\\n p = vec3(fp.x, 1.0, -fp.y);\\n ni = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n // bottom\\n p = vec3(fp.x, -1.0, fp.y);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n // right\\n p = vec3(-1.0, fp.y, -fp.x);\\n ni = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n // left\\n p = vec3(1.0, fp.y, fp.x);\\n ni = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return p;\\n}\\n\\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(n, lit)) * (1.0 - amb) + amb;\\n \\n vec3 h = normalize(normalize(eye - p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.0, pow(dot(n, h), spec.x));\\n }\\n \\n rgb = diffuse * dfscol + specular * spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kCubeVertexCount);\\n float shapeId = floor(vertexId / kCubeVertexCount);\\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\\n float lineId = mod(shapeId, 3.0);\\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 0.0) {\\n lineFactor = vec3(4.1, 6.7, 2.3);\\n color = vec3(1.0, 0.0, 0.0);\\n }\\n else if(lineId == 1.0) {\\n lineFactor = vec3(4.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(0.0, 0.0, 1.0);\\n }\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 cubeni;\\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.04;\\n \\n vec3 cubeHash = hash3(vec3(log(shapeId)));\\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\\n \\n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\\n \\n cubep = lissajous(lineFactor, (t + time * 0.1) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\\n \\n /*\\n if(cubeni.w == 0.0) {\\n color = vec3(1.0, 0.0, 0.0);\\n }\\n else if(cubeni.w == 1.0) {\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else if(cubeni.w == 2.0) {\\n color = vec3(0.0, 0.0, 1.0);\\n }\\n else if(cubeni.w == 3.0) {\\n color = vec3(1.0, 1.0, 0.0);\\n }\\n else if(cubeni.w == 4.0) {\\n color = vec3(1.0, 0.0, 1.0);\\n }\\n else {\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n */\\n \\n //vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.0), -mouse.x * 2.0), mouse.y);\\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.05), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 50400, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5725490196078431, + 0.5725490196078431, + 0.5725490196078431, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hash3(vec3 v) {\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x;\n rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\n * vec4(p, 1.0);\n return pp.xyz;\n}\n\nvec3 lissajous(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\n#define kCubeVertexCount 36.0\nvec3 cubeVertex(float vid, out vec4 ni) {\n float faceId = floor(vid / 6.0);\n float vtxId = mod(vid, 6.0);\n vec2 fp;\n vec3 p;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n // front\n p = vec3(fp.x, fp.y, 1.0);\n ni = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n // back\n p = vec3(-fp.x, fp.y, -1.0);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n // top\n p = vec3(fp.x, 1.0, -fp.y);\n ni = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n // bottom\n p = vec3(fp.x, -1.0, fp.y);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 4.0) {\n // right\n p = vec3(-1.0, fp.y, -fp.x);\n ni = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n // left\n p = vec3(1.0, fp.y, fp.x);\n ni = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return p;\n}\n\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(n, lit)) * (1.0 - amb) + amb;\n \n vec3 h = normalize(normalize(eye - p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.0, pow(dot(n, h), spec.x));\n }\n \n rgb = diffuse * dfscol + specular * spec.y;\n \n return rgb;\n}\n\nvoid main() {\n float shapeCount = floor(vertexCount / kCubeVertexCount);\n float shapeId = floor(vertexId / kCubeVertexCount);\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\n float lineId = mod(shapeId, 3.0);\n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 0.0) {\n lineFactor = vec3(4.1, 6.7, 2.3);\n color = vec3(1.0, 0.0, 0.0);\n }\n else if(lineId == 1.0) {\n lineFactor = vec3(4.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(0.0, 0.0, 1.0);\n }\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 cubeni;\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.04;\n \n vec3 cubeHash = hash3(vec3(log(shapeId)));\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\n \n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\n \n cubep = lissajous(lineFactor, (t + time * 0.1) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\n \n /*\n if(cubeni.w == 0.0) {\n color = vec3(1.0, 0.0, 0.0);\n }\n else if(cubeni.w == 1.0) {\n color = vec3(0.0, 1.0, 0.0);\n }\n else if(cubeni.w == 2.0) {\n color = vec3(0.0, 0.0, 1.0);\n }\n else if(cubeni.w == 3.0) {\n color = vec3(1.0, 1.0, 0.0);\n }\n else if(cubeni.w == 4.0) {\n color = vec3(1.0, 0.0, 1.0);\n }\n else {\n color = vec3(0.0, 1.0, 1.0);\n }\n */\n \n //vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.0), -mouse.x * 2.0), mouse.y);\n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.05), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-6y9bmfj7t8dbgprml-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HWnhBgCbgrivBDfEY/art.json b/art/HWnhBgCbgrivBDfEY/art.json index 8e38952b..67879124 100644 --- a/art/HWnhBgCbgrivBDfEY/art.json +++ b/art/HWnhBgCbgrivBDfEY/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juseungyang", "avatarUrl": "https://secure.gravatar.com/avatar/81eafc39caedbb2647494280a881bf6a?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://on.soundcloud.com/CUWWY\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotz(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(c,-s,0,0,s,c,0,0,0,0,1,0,0,0,0,1);\\n \\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n\\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, trans,1);\\n \\n}\\n\\nmat4 ident()\\n{\\n\\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1);\\n \\n}\\n\\nmat4 scale(vec3 s)\\n{\\n\\n return mat4(s[0],0,0,0, 0,s[1],0,0, 0,0,s[2],0, 0,0,0,1);\\n \\n}\\n\\nmat4 uniformScale(float s)\\n{\\n\\n return mat4(s,0,0,0, 0,s,0,0, 0,0,s,0, 0,0,0,1);\\n \\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\t\\n}\\nvoid main() \\n{\\n float numCircleSegments = 10.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 3.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0. * sin(time + y * 0.2) * 0.1;\\n float yoff = 0. * sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\\n \\n sc*= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotz(snd * 40. * cos(ux));\\n mat *= uniformScale(0.01 * sc);\\n \\n \\n vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\\n \\n gl_Position = mat * pos;\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n float pump = step(1.0, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1 * sin(time + v * 20.) * .05;\\n float sat = mix(0.5, 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + oddSlice * 0.5 + pump * 0.2;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n//name : Juseung Yang\\n//assignment name/number : Exercise - Vertexshaderart : Circles from Triangles\\n//course name : CS250\\n//term : 2023/05/31\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://on.soundcloud.com/CUWWY", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotz(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(c,-s,0,0,s,c,0,0,0,0,1,0,0,0,0,1);\n \n}\n\nmat4 trans(vec3 trans)\n{\n\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, trans,1);\n \n}\n\nmat4 ident()\n{\n\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1);\n \n}\n\nmat4 scale(vec3 s)\n{\n\n return mat4(s[0],0,0,0, 0,s[1],0,0, 0,0,s[2],0, 0,0,0,1);\n \n}\n\nmat4 uniformScale(float s)\n{\n\n return mat4(s,0,0,0, 0,s,0,0, 0,0,s,0, 0,0,0,1);\n \n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\t\n}\nvoid main() \n{\n float numCircleSegments = 10.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 3.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0. * sin(time + y * 0.2) * 0.1;\n float yoff = 0. * sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\n \n sc*= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotz(snd * 40. * cos(ux));\n mat *= uniformScale(0.01 * sc);\n \n \n vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\n \n gl_Position = mat * pos;\n \n float soff = sin(time + x * y * .02) * 5.; \n \n float pump = step(1.0, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1 * sin(time + v * 20.) * .05;\n float sat = mix(0.5, 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + oddSlice * 0.5 + pump * 0.2;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n\n//name : Juseung Yang\n//assignment name/number : Exercise - Vertexshaderart : Circles from Triangles\n//course name : CS250\n//term : 2023/05/31\n\n" + }, "screenshotURL": "data/images/images-0wo88dy6zn4b5igi3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HXMkwYLhCJ3DTXojR/art.json b/art/HXMkwYLhCJ3DTXojR/art.json index 60ab06fa..50779dda 100644 --- a/art/HXMkwYLhCJ3DTXojR/art.json +++ b/art/HXMkwYLhCJ3DTXojR/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jpaquim", "avatarUrl": "https://secure.gravatar.com/avatar/374b09dacab582ca17818a391b59a214?default=retro&size=200", - "settings": "{\"num\":300,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.027450980392156862,0.3843137254901961,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n // float across = 10.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 300, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.027450980392156862, + 0.3843137254901961, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n // float across = 10.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ssdwagqkb9dsdei2x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HXy6XHHyptoZ9ENeS/art.json b/art/HXy6XHHyptoZ9ENeS/art.json index 21067596..561cc4f4 100644 --- a/art/HXy6XHHyptoZ9ENeS/art.json +++ b/art/HXy6XHHyptoZ9ENeS/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "ian", "avatarUrl": "https://lh5.googleusercontent.com/-kwFohQ1qZfc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reGM-mK9emfJ0BML17FZaOd7UGoXg/mo/photo.jpg", - "settings": "{\"num\":3600,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1803921568627451,0.1803921568627451,0.1803921568627451,1],\"shader\":\"#define POINTS_PER_HALF_CIRCLE 60.0\\n#define DELTA_ALPHA 20.0\\n#define DELTA_GAMMA 20.0\\n\\n#define ALPHA_ZERO 45.0\\n#define BETA_ZERO 0.0\\n#define GAMMA_ZERO -10.0\\n\\nvoid main() {\\n float theta = radians(floor(vertexId/ POINTS_PER_HALF_CIRCLE)*(360.0/POINTS_PER_HALF_CIRCLE) ) ;\\n float phi = radians(mod(vertexId, POINTS_PER_HALF_CIRCLE)*(180.0/POINTS_PER_HALF_CIRCLE));\\n \\n vec3 xyz = vec3(\\n sin(phi)*sin(theta),\\n cos(phi),\\n sin(phi)*cos(theta)\\n )*0.25;\\n \\n float alpha = radians(sin(time)*DELTA_ALPHA) + ALPHA_ZERO;\\n float beta = BETA_ZERO;\\n float gamma = radians(cos(time)*DELTA_ALPHA) + GAMMA_ZERO;\\n \\n mat3 rotationX = mat3(\\n \\tvec3(1.0, 0.0, 0.0),\\n vec3(0.0, cos(alpha), sin(alpha)),\\n vec3(0.0, -sin(alpha), cos(alpha))\\n );\\n mat3 rotationY = mat3(\\n \\tvec3(cos(beta), 0.0, -sin(beta)),\\n vec3(0.0, 1.0, 0.0),\\n vec3(sin(beta), 0.0, cos(beta))\\n );\\n mat3 rotationZ = mat3(\\n \\tvec3(cos(gamma), sin(gamma), 0.0),\\n vec3(-sin(gamma), cos(gamma), 0.0),\\n vec3(0.0, 0.0, 1.0)\\n );\\n \\n gl_Position = vec4(rotationX*rotationY*rotationZ*xyz, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3600, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1803921568627451, + 0.1803921568627451, + 0.1803921568627451, + 1 + ], + "shader": "#define POINTS_PER_HALF_CIRCLE 60.0\n#define DELTA_ALPHA 20.0\n#define DELTA_GAMMA 20.0\n\n#define ALPHA_ZERO 45.0\n#define BETA_ZERO 0.0\n#define GAMMA_ZERO -10.0\n\nvoid main() {\n float theta = radians(floor(vertexId/ POINTS_PER_HALF_CIRCLE)*(360.0/POINTS_PER_HALF_CIRCLE) ) ;\n float phi = radians(mod(vertexId, POINTS_PER_HALF_CIRCLE)*(180.0/POINTS_PER_HALF_CIRCLE));\n \n vec3 xyz = vec3(\n sin(phi)*sin(theta),\n cos(phi),\n sin(phi)*cos(theta)\n )*0.25;\n \n float alpha = radians(sin(time)*DELTA_ALPHA) + ALPHA_ZERO;\n float beta = BETA_ZERO;\n float gamma = radians(cos(time)*DELTA_ALPHA) + GAMMA_ZERO;\n \n mat3 rotationX = mat3(\n \tvec3(1.0, 0.0, 0.0),\n vec3(0.0, cos(alpha), sin(alpha)),\n vec3(0.0, -sin(alpha), cos(alpha))\n );\n mat3 rotationY = mat3(\n \tvec3(cos(beta), 0.0, -sin(beta)),\n vec3(0.0, 1.0, 0.0),\n vec3(sin(beta), 0.0, cos(beta))\n );\n mat3 rotationZ = mat3(\n \tvec3(cos(gamma), sin(gamma), 0.0),\n vec3(-sin(gamma), cos(gamma), 0.0),\n vec3(0.0, 0.0, 1.0)\n );\n \n gl_Position = vec4(rotationX*rotationY*rotationZ*xyz, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-fhhmbbgklqrqq27kg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HXzN44Rci8MBYDQYL/art.json b/art/HXzN44Rci8MBYDQYL/art.json index 20469e67..fad8f605 100644 --- a/art/HXzN44Rci8MBYDQYL/art.json +++ b/art/HXzN44Rci8MBYDQYL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float u = vertexId / vertexCount;\\n float v = u; \\n \\n v = pow(v, .1);\\n v = pow(v, 10.);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(u, v);\\n gl_Position = vec4(xy * 2. - 1., 0, 1);\\n\\n float hue = (u);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float u = vertexId / vertexCount;\n float v = u; \n \n v = pow(v, .1);\n v = pow(v, 10.);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(u, v);\n gl_Position = vec4(xy * 2. - 1., 0, 1);\n\n float hue = (u);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-i0fdttshgateaqpaq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HYQNJSjDiWBW4zafP/art.json b/art/HYQNJSjDiWBW4zafP/art.json index b12c53fc..69f49e96 100644 --- a/art/HYQNJSjDiWBW4zafP/art.json +++ b/art/HYQNJSjDiWBW4zafP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4368,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n \\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n\\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // Set up vertices\\n vec3 vert;\\n if (vertexId == 0.0) {\\n \\tvert = vec3(0.0, 0.0, 0.5);\\n } else if (vertexId == 1.0) {\\n \\tvert = vec3(0.0, 0.5, 0.5);\\n } else if (vertexId == 2.0) {\\n \\tvert = vec3(0.5, 0.5, 1.0);\\n }\\n // Project\\n vec3 normal = vec3(0.0, 0.0, 1.0);\\n vec3 outPos = (dot(vert, normal) * normal) / (length(normal) * length(normal));\\n gl_Position = vec4(outPos, 1.0);\\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 4368, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n \tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // Set up vertices\n vec3 vert;\n if (vertexId == 0.0) {\n \tvert = vec3(0.0, 0.0, 0.5);\n } else if (vertexId == 1.0) {\n \tvert = vec3(0.0, 0.5, 0.5);\n } else if (vertexId == 2.0) {\n \tvert = vec3(0.5, 0.5, 1.0);\n }\n // Project\n vec3 normal = vec3(0.0, 0.0, 1.0);\n vec3 outPos = (dot(vert, normal) * normal) / (length(normal) * length(normal));\n gl_Position = vec4(outPos, 1.0);\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-wu4v9xhedy400sgnx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HYa4rqvcqkB5bd4T4/art.json b/art/HYa4rqvcqkB5bd4T4/art.json index fd0c677c..689f71fa 100644 --- a/art/HYa4rqvcqkB5bd4T4/art.json +++ b/art/HYa4rqvcqkB5bd4T4/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "xi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GhDJubRRp-SM2AciN7fDuusjZXt4-We-Q9ZOwXU", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.0196078431372549,0.2784313725490196,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz,0.0,1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = 0.;//sin(time + y*0.2) * 0.1;\\n float yoff = 0.;//sin(time + x*0.2) * 0.1;\\n \\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av*0.25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;// sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x/600.;\\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1;//u * .1; //+ sin(time + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);// mix(1., -10., av);\\n float val = mix(.1, pow(snd+0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.0196078431372549, + 0.2784313725490196, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz,0.0,1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = 0.;//sin(time + y*0.2) * 0.1;\n float yoff = 0.;//sin(time + x*0.2) * 0.1;\n \n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av*0.25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;// sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x/600.;\n\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1;//u * .1; //+ sin(time + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);// mix(1., -10., av);\n float val = mix(.1, pow(snd+0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-gmnh1tvh5iehhxren-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Hap5jDJiPwQZ9oJx6/art.json b/art/Hap5jDJiPwQZ9oJx6/art.json index d4d27c7b..5f0aef2e 100644 --- a/art/Hap5jDJiPwQZ9oJx6/art.json +++ b/art/Hap5jDJiPwQZ9oJx6/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "eren", "avatarUrl": "https://lh3.googleusercontent.com/a/AAcHTteGyNZj5qjNhZ1PS7gklhngFJPOEGJ1ziUo1luJtIbl8o7k=s96-c", - "settings": "{\"num\":6532,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n \\n float down = floor(sqrt(vertexCount));\\n\\n float zort = floor(vertexCount / down);\\n \\n float x = mod(vertexId, zort);\\n \\n float y = floor(vertexId / zort);\\n \\n float u = x / (zort - 1.); \\n float v = y / (zort - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.2;\\n float yoff = sin(time + x * 0.1) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.5;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.001) * 5.;\\n \\n gl_PointSize = 4.0 + soff;\\n \\n gl_PointSize *= 20. / zort;\\n \\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n\\n\\n} \\n\\t\"}", + "settings": { + "num": 6532, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n \n float down = floor(sqrt(vertexCount));\n\n float zort = floor(vertexCount / down);\n \n float x = mod(vertexId, zort);\n \n float y = floor(vertexId / zort);\n \n float u = x / (zort - 1.); \n float v = y / (zort - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.2;\n float yoff = sin(time + x * 0.1) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.5;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.001) * 5.;\n \n gl_PointSize = 4.0 + soff;\n \n gl_PointSize *= 20. / zort;\n \n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n\n\n} \n\t" + }, "screenshotURL": "data/images/images-gf2p7e048xlcan3ah-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Hb6JwdFzxmc36PTuP/art.json b/art/Hb6JwdFzxmc36PTuP/art.json index 133e335c..9de55cd8 100644 --- a/art/Hb6JwdFzxmc36PTuP/art.json +++ b/art/Hb6JwdFzxmc36PTuP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":73435,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 5.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 73435, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 5.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-fme6a319e5kp9hozo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HckFNtc7tQ7Qg22YA/art.json b/art/HckFNtc7tQ7Qg22YA/art.json index b63f4bca..135d64e0 100644 --- a/art/HckFNtc7tQ7Qg22YA/art.json +++ b/art/HckFNtc7tQ7Qg22YA/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":10127,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float w = sqrt(vertexCount*fract(time));\\n float h = 100.;//;floor(fract(time)*10.);\\n float x = mod(vertexId, w);\\n float y = floor(vertexId/h);\\n float u = x/(w-1.);\\n float v = y/(h-1.);\\n float ux = u*2.-1.;\\n float vy = v*2.-1.;\\n gl_Position = vec4(ux,vy,0.,1.);\\n gl_PointSize = mod(time,10.);\\n v_color = vec4(1.);\\n}\\n\\n/*\\nvoid main(){\\n float w = sqrt(vertexCount);\\n float h = 10.;\\n float x = mod(vertexId, w);\\n float y = floor(vertexId/h);\\n float u = x/(w-1.);\\n float v = y/(h-1.);\\n float ux = u*2.-1.;\\n float vy = v*2.-1.;\\n gl_Position = vec4(ux,vy,0.,1.);\\n gl_PointSize = 10.;\\n v_color = vec4(1.);\\n}\\n*/\"}", + "settings": { + "num": 10127, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float w = sqrt(vertexCount*fract(time));\n float h = 100.;//;floor(fract(time)*10.);\n float x = mod(vertexId, w);\n float y = floor(vertexId/h);\n float u = x/(w-1.);\n float v = y/(h-1.);\n float ux = u*2.-1.;\n float vy = v*2.-1.;\n gl_Position = vec4(ux,vy,0.,1.);\n gl_PointSize = mod(time,10.);\n v_color = vec4(1.);\n}\n\n/*\nvoid main(){\n float w = sqrt(vertexCount);\n float h = 10.;\n float x = mod(vertexId, w);\n float y = floor(vertexId/h);\n float u = x/(w-1.);\n float v = y/(h-1.);\n float ux = u*2.-1.;\n float vy = v*2.-1.;\n gl_Position = vec4(ux,vy,0.,1.);\n gl_PointSize = 10.;\n v_color = vec4(1.);\n}\n*/" + }, "screenshotURL": "data/images/images-6p7zzd3h28ssq2jxr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HdvpCSWX4Kv64BoSD/art.json b/art/HdvpCSWX4Kv64BoSD/art.json index dd8a9e78..394a808f 100644 --- a/art/HdvpCSWX4Kv64BoSD/art.json +++ b/art/HdvpCSWX4Kv64BoSD/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "shinyisshiny", "avatarUrl": "https://secure.gravatar.com/avatar/382822a2fd34cc1eedf9317c4c63083d?default=retro&size=200", - "settings": "{\"num\":18433,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mood-hut/mh023-pender-street-steppers-our-time?in=pender-street-steppers/sets/music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.050980392156862744,0.32941176470588235,1],\"shader\":\"#define positionX 3.//KParameter 0.>>10.\\n#define positionY 1.//KParameter 0.>>1.\\n#define colorR 1.//KParameter 0.>>1.\\n#define colorG 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>8.\\n#define rotationFactorY 1.//KParameter 0.>>8.\\n#define rotationFactorZ 1.//KParameter 0.>>8.\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float snd = texture2D(sound, vec2(u, v * 0.)).a;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.6) * 15.;\\n \\n gl_PointSize = snd * 100.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n \\n v_color = vec4(1, v, 1, 1);\\n \\n \\n \\n}\\n \\n \"}", + "settings": { + "num": 18433, + "mode": "POINTS", + "sound": "https://soundcloud.com/mood-hut/mh023-pender-street-steppers-our-time?in=pender-street-steppers/sets/music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.050980392156862744, + 0.32941176470588235, + 1 + ], + "shader": "#define positionX 3.//KParameter 0.>>10.\n#define positionY 1.//KParameter 0.>>1.\n#define colorR 1.//KParameter 0.>>1.\n#define colorG 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>8.\n#define rotationFactorY 1.//KParameter 0.>>8.\n#define rotationFactorZ 1.//KParameter 0.>>8.\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float snd = texture2D(sound, vec2(u, v * 0.)).a;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n float soff = sin(time + x * y * 0.6) * 15.;\n \n gl_PointSize = snd * 100.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n \n v_color = vec4(1, v, 1, 1);\n \n \n \n}\n \n " + }, "screenshotURL": "data/images/images-1e8r6h12t3j3rta7f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HeuBWpdtNd6E9KmQk/art.json b/art/HeuBWpdtNd6E9KmQk/art.json index 405f21c0..2e9dd091 100644 --- a/art/HeuBWpdtNd6E9KmQk/art.json +++ b/art/HeuBWpdtNd6E9KmQk/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Motion\\n//course name : CS250\\n//term : Spring 2023\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1; \\n float yoff = sin(time + x * 0.2) * 0.2;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Motion\n//course name : CS250\n//term : Spring 2023\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1; \n float yoff = sin(time + x * 0.2) * 0.2;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-7rwj3u0gutpahln5k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HfPyQZbSJKZKsqjZ6/art.json b/art/HfPyQZbSJKZKsqjZ6/art.json index 8405c9f7..dd73963c 100644 --- a/art/HfPyQZbSJKZKsqjZ6/art.json +++ b/art/HfPyQZbSJKZKsqjZ6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.3254901960784314,0.34901960784313724,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 12.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 3.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle + 3. );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 2.); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, -0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, -1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.01, 0.3);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n\\n 1.1 -s, 0, 0, 0.1,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 2) /2.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(111.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. + 0.1;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 55.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 11.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 0.1, level);\\n float a = mix(start, end, u) * PI * 2. - PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 2./ s *.04;\\n float z = 0.1;\\n pos = vec3(x, y -1., z ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(.1, mod(circleId*22., 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles -parameter4;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - 1.3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n\\n float snd = texture2D(sound, vec2((cu + abs(uv.x / 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.000203) * 11.4;\\n offset.y += goop(circleId + time * 0.000013) *1.31*mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 *snd);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6*snd, fract(circleId + 10.79));\\n float sat = 0.9 - circleId;\\n float val = .75;sin(\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (0.2 - uv.y) * pow(snd*2.*uv.x*parameter6, snd+2.2-time)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a+.6);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.3254901960784314, + 0.34901960784313724, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 12.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 3.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle + 3. );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 2.); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, -0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, -1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.01, 0.3);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n\n 1.1 -s, 0, 0, 0.1,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 2) /2.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(111.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. + 0.1;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 55.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 11.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 0.1, level);\n float a = mix(start, end, u) * PI * 2. - PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 2./ s *.04;\n float z = 0.1;\n pos = vec3(x, y -1., z ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(.1, mod(circleId*22., 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles -parameter4;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - 1.3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n\n float snd = texture2D(sound, vec2((cu + abs(uv.x / 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.000203) * 11.4;\n offset.y += goop(circleId + time * 0.000013) *1.31*mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 *snd);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6*snd, fract(circleId + 10.79));\n float sat = 0.9 - circleId;\n float val = .75;sin(\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (0.2 - uv.y) * pow(snd*2.*uv.x*parameter6, snd+2.2-time)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a+.6);\n}" + }, "screenshotURL": "data/images/images-c171v7l4zhxqgn2ip-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HfQbodpsdXtRDyJar/art.json b/art/HfQbodpsdXtRDyJar/art.json index 64e8cbad..452a5f36 100644 --- a/art/HfQbodpsdXtRDyJar/art.json +++ b/art/HfQbodpsdXtRDyJar/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n \\n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n \n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-ioqdlc3kua7f4p2k1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Hg6xE7LkftDQPNqAW/art.json b/art/Hg6xE7LkftDQPNqAW/art.json index cf9474f8..4c866139 100644 --- a/art/Hg6xE7LkftDQPNqAW/art.json +++ b/art/Hg6xE7LkftDQPNqAW/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "w.e._aa", - "settings": "{\"num\":256,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/w-e-aa/qxycjrr4z3dv\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6470588235294118,0.6470588235294118,0.6470588235294118,1],\"shader\":\"/*\\n\\n _ _ _ _ \\n ( ) ( ) ( ) ( ) \\n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \\n( V )( o_)( _)( _)( o_)\\\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\\n \\\\_/ \\\\( /_\\\\ /_\\\\ \\\\( /_^_\\\\/__)/_\\\\||/_^_\\\\\\\\___\\\\ \\\\( /_\\\\ /_^_\\\\/_\\\\ /_\\\\ \\n \\n\\n\\n\\n*/\\n\\n\\n\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\\n \\n \\n \\n \\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = hash(u) * 0.25 + 0.1;\\n // Match each line to a specific row in the sound texture\\n float historyV = v * 0.004;\\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\\n vec2 off = vec2(\\n cos(snd1 * PI * 8.),\\n sin(snd2 * PI * 6.4));\\n\\n vec2 xy = vec2(\\n m1p1(hash(time + vertexId)),\\n m1p1(hash(time + vertexId + 1.)));\\n// snd1 * 2. - 1.,\\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\\n\\n float hue = u;\\n float sat = 0.;\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 256, + "mode": "LINES", + "sound": "https://soundcloud.com/w-e-aa/qxycjrr4z3dv", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6470588235294118, + 0.6470588235294118, + 0.6470588235294118, + 1 + ], + "shader": "/*\n\n _ _ _ _ \n ( ) ( ) ( ) ( ) \n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \n( V )( o_)( _)( _)( o_)\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\n \\_/ \\( /_\\ /_\\ \\( /_^_\\/__)/_\\||/_^_\\\\___\\ \\( /_\\ /_^_\\/_\\ /_\\ \n \n\n\n\n*/\n\n\n\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\n \n \n \n \n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = hash(u) * 0.25 + 0.1;\n // Match each line to a specific row in the sound texture\n float historyV = v * 0.004;\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\n vec2 off = vec2(\n cos(snd1 * PI * 8.),\n sin(snd2 * PI * 6.4));\n\n vec2 xy = vec2(\n m1p1(hash(time + vertexId)),\n m1p1(hash(time + vertexId + 1.)));\n// snd1 * 2. - 1.,\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\n\n float hue = u;\n float sat = 0.;\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-9b8ralrl7tplp7k5g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HigFydDgNaipM7SBk/art.json b/art/HigFydDgNaipM7SBk/art.json index 6ae82d6f..8fb5a496 100644 --- a/art/HigFydDgNaipM7SBk/art.json +++ b/art/HigFydDgNaipM7SBk/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":1050,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 0.2;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 200. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(0.7 , 0, 1, 1) + vec4(ux*ux, 1.0-vy, u*u*2.0, 1);\\n}\"}", + "settings": { + "num": 1050, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 0.2;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 200. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(0.7 , 0, 1, 1) + vec4(ux*ux, 1.0-vy, u*u*2.0, 1);\n}" + }, "screenshotURL": "data/images/images-ibj69bi86q94n5ivv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HoCy3fHXwDNeCoERy/art.json b/art/HoCy3fHXwDNeCoERy/art.json index e0771e45..c1698c27 100644 --- a/art/HoCy3fHXwDNeCoERy/art.json +++ b/art/HoCy3fHXwDNeCoERy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":38827,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define KP0 1.0//KParameter 0.>>1.\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 2.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd *(1.06+KP0)\\n ), 0., 1.), 1.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1+KP0)) * 0.41;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n \\n \\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.2,0), step(0.9299, snd));\\n vCubeCol.a = 0.0;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * tan(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\\n // \\tvec3 vCameraUp = vec3( 0, 0, 1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 38827, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define KP0 1.0//KParameter 0.>>1.\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 2.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd *(1.06+KP0)\n ), 0., 1.), 1.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1+KP0)) * 0.41;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n \n \n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.2,0), step(0.9299, snd));\n vCubeCol.a = 0.0;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * tan(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\n // \tvec3 vCameraUp = vec3( 0, 0, 1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-6xu37wl4a1h7kvb9r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HoKSKN5bu2omsjRi7/art.json b/art/HoKSKN5bu2omsjRi7/art.json index 8e6e659e..dd0cbd5e 100644 --- a/art/HoKSKN5bu2omsjRi7/art.json +++ b/art/HoKSKN5bu2omsjRi7/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chris-camplin/in-my-mind\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n \\nvoid main() {\\n float snd = pow(texture2D(sound, vec2(0.005, 0.0025)).a, 4.);\\n\\n float v=vertexId/30.0;\\n int num=int(mouse.x*10.0+10.0*snd);\\n int den=int(exp(mouse.y*3.0+3.0)*snd);\\n float frac=1.0-float(num)/float(den);\\n vec2 xy=vec2(sin(v),cos(v)*sin(v*frac))/2.0;\\n\\n for(int i = 0; i < 1; i++) {\\n xy*=abs(xy)/dot(xy, xy)-vec2(snd);\\n xy*=abs(xy)/dot(xy, xy)-vec2(frac);\\n }\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(xy * aspect, -xy.x, 1);\\n v_color = vec4(0,0,0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chris-camplin/in-my-mind", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n \nvoid main() {\n float snd = pow(texture2D(sound, vec2(0.005, 0.0025)).a, 4.);\n\n float v=vertexId/30.0;\n int num=int(mouse.x*10.0+10.0*snd);\n int den=int(exp(mouse.y*3.0+3.0)*snd);\n float frac=1.0-float(num)/float(den);\n vec2 xy=vec2(sin(v),cos(v)*sin(v*frac))/2.0;\n\n for(int i = 0; i < 1; i++) {\n xy*=abs(xy)/dot(xy, xy)-vec2(snd);\n xy*=abs(xy)/dot(xy, xy)-vec2(frac);\n }\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(xy * aspect, -xy.x, 1);\n v_color = vec4(0,0,0, 1);\n}" + }, "screenshotURL": "data/images/images-pfifpp4me2dxziq2w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HoXN7xPc28sQKFiCZ/art.json b/art/HoXN7xPc28sQKFiCZ/art.json index 90619505..ae53fea5 100644 --- a/art/HoXN7xPc28sQKFiCZ/art.json +++ b/art/HoXN7xPc28sQKFiCZ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":18956,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/spinninrecords/alok-alan-walker-headlights-feat-kiddo-listen-link\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,1,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n \\n float vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\n \\n \\n \\n \\n \\n \\n \\n \\n float angle = ux / numCircleSegments* PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\n\\n\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n \\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n \\n\\n \\n \\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au*.05, av*.25)).a;\\n \\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n \\n \\n //vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\\n //gl_Position = vec4(xy, 0, 1) * vec4(1, aspect, 1,1);\\n gl_Position = mat * pos;\\n float soff = 0.;//sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd*0.2+time * .1 + sliceId * 0.01;//sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;//mix(0.5, 1., pump);//mix(1., -10., av);\\n float val = mix(.5, pow(snd+0.2,5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 18956, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/spinninrecords/alok-alan-walker-headlights-feat-kiddo-listen-link", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 1, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n \n float ux = floor(id / 6.) + mod(id, 2.);\n \n \n float vy = mod(floor(id/2.) + floor(id / 3.), 2.);\n \n \n \n \n \n \n \n \n float angle = ux / numCircleSegments* PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\n\n\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n \n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n \n\n \n \n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au*.05, av*.25)).a;\n \n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n \n \n //vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\n //gl_Position = vec4(xy, 0, 1) * vec4(1, aspect, 1,1);\n gl_Position = mat * pos;\n float soff = 0.;//sin(time + 1.2 + x * y * 0.02) * 5.;\n \n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd*0.2+time * .1 + sliceId * 0.01;//sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;//mix(0.5, 1., pump);//mix(1., -10., av);\n float val = mix(.5, pow(snd+0.2,5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-h1c4w4nb2qc6ktppz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HpXGaca48eDSZRtbx/art.json b/art/HpXGaca48eDSZRtbx/art.json index 29e81452..e19e2d53 100644 --- a/art/HpXGaca48eDSZRtbx/art.json +++ b/art/HpXGaca48eDSZRtbx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 50\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n vec2 p = vec2(ux , vy);\\n //float z = fract(0.86);\\n float z = fract(1.2*snd);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z+snd2) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 4.;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 50\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n vec2 p = vec2(ux , vy);\n //float z = fract(0.86);\n float z = fract(1.2*snd);\n int a = 0;\n float trig = (cos(2. * M_PI * z+snd2) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 4.;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-s1xrhm0bju7yfs0rf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HpoPwexZeHvSos9jB/art.json b/art/HpoPwexZeHvSos9jB/art.json index 70d3f489..4a3863c6 100644 --- a/art/HpoPwexZeHvSos9jB/art.json +++ b/art/HpoPwexZeHvSos9jB/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "신일", "avatarUrl": "https://lh4.googleusercontent.com/-UYJtSdrMQjs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rf5HE_ag4Fy6JhSGK74D5Uz9FMccw/mo/photo.jpg", - "settings": "{\"num\":19117,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.48627450980392156,0.48627450980392156,0.48627450980392156,1],\"shader\":\"/*\\n * 1. sinil.gang\\n * 2. Shader Programming / 3\\n * 3. CS230\\n * 4. Spring 2019\\n */\\n\\nvoid main()\\n{\\n // X makes wide, Y too but not wide as much as X \\n float tmpX = vertexId * 100.;\\n float tmpY = vertexId * 1500.;\\n \\n // Variable for mouse and make Limit and adjustment\\n float scopeX = mouse.x * 10.;\\n float scopeY = mouse.y / 5.;\\n \\n // Conditional for preventing to make too narrow \\n if(abs(scopeX) < 1.0)\\n {\\n scopeX += 1.0 - scopeX;\\n }\\n \\n // Position setting\\n gl_Position = vec4(sin(tmpX) * scopeX, sin(tmpY) * mouse.y, 0, 1);\\n \\n // Size setting\\n gl_PointSize = abs(sin(time)) * 10.;\\n \\n // rgc with trigonometric function of time.\\n float red = sin(time);\\n float blue = cos(time);\\n float green = tan(time);\\n v_color = vec4(red, green, blue, 1);\\n}\"}", + "settings": { + "num": 19117, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.48627450980392156, + 0.48627450980392156, + 0.48627450980392156, + 1 + ], + "shader": "/*\n * 1. sinil.gang\n * 2. Shader Programming / 3\n * 3. CS230\n * 4. Spring 2019\n */\n\nvoid main()\n{\n // X makes wide, Y too but not wide as much as X \n float tmpX = vertexId * 100.;\n float tmpY = vertexId * 1500.;\n \n // Variable for mouse and make Limit and adjustment\n float scopeX = mouse.x * 10.;\n float scopeY = mouse.y / 5.;\n \n // Conditional for preventing to make too narrow \n if(abs(scopeX) < 1.0)\n {\n scopeX += 1.0 - scopeX;\n }\n \n // Position setting\n gl_Position = vec4(sin(tmpX) * scopeX, sin(tmpY) * mouse.y, 0, 1);\n \n // Size setting\n gl_PointSize = abs(sin(time)) * 10.;\n \n // rgc with trigonometric function of time.\n float red = sin(time);\n float blue = cos(time);\n float green = tan(time);\n v_color = vec4(red, green, blue, 1);\n}" + }, "screenshotURL": "data/images/images-bn70uxdpni9r5w9wh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HrZdqpnvqmB6gZw6J/art.json b/art/HrZdqpnvqmB6gZw6J/art.json index 3c12ee07..7755a209 100644 --- a/art/HrZdqpnvqmB6gZw6J/art.json +++ b/art/HrZdqpnvqmB6gZw6J/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/psychofilthrecords/pfsa003\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#45963.0\\nvec2 vertexResolution = resolution;\\n//#ifdef GL_ES\\n//precision highp float;\\n//#endif \\n\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n \\n#define time (time + 100.0)\\n#define PI 3.14159265358979323846\\n\\nfloat box(vec2 _st, vec2 _size, float _smoothEdges){\\n _size = vec2(1.75)-_size*0.75;\\n vec2 aa = vec2(_smoothEdges*0.5);\\n vec2 uv = smoothstep(_size,_size+aa,_st);\\n uv *= smoothstep(_size,_size+aa,vec2(1.0)-_st);\\n return uv.x*uv.y;\\n}\\n\\nvec2 tile(vec2 _st, float _zoom){\\n _st *= _zoom;\\n return fract(_st);\\n}\\n\\nvec2 rotate2D(vec2 _st, float _angle, vec2 shift){\\n _st -= 0.5 + shift.x;\\n _st = mat2(cos(_angle),-sin(_angle),\\n sin(_angle),cos(_angle)) * _st;\\n _st += 0.5 + shift.y;\\n return _st;\\n}\\n\\nvoid main(void){float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n\\tvec2 v = (simFragCoord.xy - vertexResolution/2.0) / min(vertexResolution.y,vertexResolution.x) * 5.0;\\n\\tvec2 vv = v; vec2 vvv = v;\\n\\tfloat tm = time*0.15;\\n\\tvec2 mspt = (vec2(\\n\\t\\t\\tsin(tm)+cos(tm*0.2)+sin(tm*0.5)+cos(tm*-0.4)+sin(tm*1.3),\\n\\t\\t\\tcos(tm)+sin(tm*0.1)+cos(tm*0.8)+sin(tm*-1.1)+cos(tm*1.5)\\n\\t\\t\\t)+15.0)*0.03;\\n\\t\\n\\t\\n\\tvec2 simple = (vec2(sin(tm), cos(tm)) + 1.5) * 0.15;\\n\\tfloat R = 0.0;\\n\\tfloat RR = 0.0;\\n\\tfloat RRR = 0.0;\\n\\tfloat a = (.6-simple.x)*6.2;\\n\\tfloat C = cos(a);\\n\\tfloat S = sin(a);\\n\\tvec2 xa=vec2(C, -S);\\n\\tvec2 ya=vec2(S, C);\\n\\tvec2 shift = vec2( 1.2, 1.62);\\n\\tfloat Z = 1.0 + simple.y*6.0;\\n\\tfloat ZZ = 1.0 + (simple.y)*6.2;\\n\\tfloat ZZZ = 1.0 + (simple.y)*6.9;\\n\\t\\n\\tvec2 b = simFragCoord.xy/(vertexResolution);\\n\\tb = rotate2D(b, PI*Z, 0.05*xa);\\n\\t//b = vec2(box(b,vec2(1.1),0.95));\\n\\t\\n\\tfor ( int i = 0; i < 25; i++ ){\\n\\t\\tfloat br = dot(b,b);\\n\\t\\tfloat r = dot(v,v);\\n\\t\\tif ( r > sin(tm) + 3.0 )\\n\\t\\t{\\n\\t\\t\\tr = (sin(tm) + 3.0)/r ;\\n\\t\\t\\tv.x = v.x * r + 0.;\\n\\t\\t\\tv.y = v.y * r + 0.;\\n\\t\\t}\\n\\t\\tif ( br > 0.75 )\\n\\t\\t{\\n\\t\\t\\tbr = (0.56)/br ;\\n\\t\\t\\t//v.x = v.x * r + 0.;\\n\\t\\t\\t//v.y = v.y * r + 0.;\\n\\t\\t}\\n\\t\\t\\n\\t\\tR *= 1.05;\\n\\t\\tR += br;//b.x;\\n\\t\\tif(i < 24){\\n\\t\\t\\tRR *= 1.05;\\n\\t\\t\\tRR += br;//b.x;\\n\\t\\t\\tif(i <23){\\n\\t\\t\\t\\tRRR *= 1.05;\\n\\t\\t\\t\\tRRR += br;//b.x;\\n\\t\\t\\t}\\n\\t\\t}\\n\\t\\t\\n\\t\\tv = vec2( dot(v, xa), dot(v, ya)) * Z + shift;\\n\\t\\t//b = vec2( dot(b.xy, xa), dot(b.xy, ya)) * Z + shift;\\n\\t\\t//b = rotate2D(vec2( dot(v, xa), dot(v, ya)), PI*Z, ya);\\n\\t\\t//b = vec2( dot(b, xa), dot(b, ya));\\n\\t\\tb = vec2(box(v,vec2(5.),0.9)) + shift * 0.42;\\n\\t}\\n\\tfloat c = ((mod(R,2.0)>1.0)?1.0-fract(R):fract(R));\\n\\tfloat cc = ((mod(RR,2.0)>1.0)?1.0-fract(RR):fract(RR));\\n\\tfloat ccc = ((mod(RRR,2.0)>1.0)?1.0-fract(RRR):fract(RRR));\\n\\tv_color = vec4(ccc,cc,c, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/psychofilthrecords/pfsa003", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#45963.0\nvec2 vertexResolution = resolution;\n//#ifdef GL_ES\n//precision highp float;\n//#endif \n\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n \n#define time (time + 100.0)\n#define PI 3.14159265358979323846\n\nfloat box(vec2 _st, vec2 _size, float _smoothEdges){\n _size = vec2(1.75)-_size*0.75;\n vec2 aa = vec2(_smoothEdges*0.5);\n vec2 uv = smoothstep(_size,_size+aa,_st);\n uv *= smoothstep(_size,_size+aa,vec2(1.0)-_st);\n return uv.x*uv.y;\n}\n\nvec2 tile(vec2 _st, float _zoom){\n _st *= _zoom;\n return fract(_st);\n}\n\nvec2 rotate2D(vec2 _st, float _angle, vec2 shift){\n _st -= 0.5 + shift.x;\n _st = mat2(cos(_angle),-sin(_angle),\n sin(_angle),cos(_angle)) * _st;\n _st += 0.5 + shift.y;\n return _st;\n}\n\nvoid main(void){float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n\tvec2 v = (simFragCoord.xy - vertexResolution/2.0) / min(vertexResolution.y,vertexResolution.x) * 5.0;\n\tvec2 vv = v; vec2 vvv = v;\n\tfloat tm = time*0.15;\n\tvec2 mspt = (vec2(\n\t\t\tsin(tm)+cos(tm*0.2)+sin(tm*0.5)+cos(tm*-0.4)+sin(tm*1.3),\n\t\t\tcos(tm)+sin(tm*0.1)+cos(tm*0.8)+sin(tm*-1.1)+cos(tm*1.5)\n\t\t\t)+15.0)*0.03;\n\t\n\t\n\tvec2 simple = (vec2(sin(tm), cos(tm)) + 1.5) * 0.15;\n\tfloat R = 0.0;\n\tfloat RR = 0.0;\n\tfloat RRR = 0.0;\n\tfloat a = (.6-simple.x)*6.2;\n\tfloat C = cos(a);\n\tfloat S = sin(a);\n\tvec2 xa=vec2(C, -S);\n\tvec2 ya=vec2(S, C);\n\tvec2 shift = vec2( 1.2, 1.62);\n\tfloat Z = 1.0 + simple.y*6.0;\n\tfloat ZZ = 1.0 + (simple.y)*6.2;\n\tfloat ZZZ = 1.0 + (simple.y)*6.9;\n\t\n\tvec2 b = simFragCoord.xy/(vertexResolution);\n\tb = rotate2D(b, PI*Z, 0.05*xa);\n\t//b = vec2(box(b,vec2(1.1),0.95));\n\t\n\tfor ( int i = 0; i < 25; i++ ){\n\t\tfloat br = dot(b,b);\n\t\tfloat r = dot(v,v);\n\t\tif ( r > sin(tm) + 3.0 )\n\t\t{\n\t\t\tr = (sin(tm) + 3.0)/r ;\n\t\t\tv.x = v.x * r + 0.;\n\t\t\tv.y = v.y * r + 0.;\n\t\t}\n\t\tif ( br > 0.75 )\n\t\t{\n\t\t\tbr = (0.56)/br ;\n\t\t\t//v.x = v.x * r + 0.;\n\t\t\t//v.y = v.y * r + 0.;\n\t\t}\n\t\t\n\t\tR *= 1.05;\n\t\tR += br;//b.x;\n\t\tif(i < 24){\n\t\t\tRR *= 1.05;\n\t\t\tRR += br;//b.x;\n\t\t\tif(i <23){\n\t\t\t\tRRR *= 1.05;\n\t\t\t\tRRR += br;//b.x;\n\t\t\t}\n\t\t}\n\t\t\n\t\tv = vec2( dot(v, xa), dot(v, ya)) * Z + shift;\n\t\t//b = vec2( dot(b.xy, xa), dot(b.xy, ya)) * Z + shift;\n\t\t//b = rotate2D(vec2( dot(v, xa), dot(v, ya)), PI*Z, ya);\n\t\t//b = vec2( dot(b, xa), dot(b, ya));\n\t\tb = vec2(box(v,vec2(5.),0.9)) + shift * 0.42;\n\t}\n\tfloat c = ((mod(R,2.0)>1.0)?1.0-fract(R):fract(R));\n\tfloat cc = ((mod(RR,2.0)>1.0)?1.0-fract(RR):fract(RR));\n\tfloat ccc = ((mod(RRR,2.0)>1.0)?1.0-fract(RRR):fract(RRR));\n\tv_color = vec4(ccc,cc,c, 1.0);\n}" + }, "screenshotURL": "data/images/images-ir0ra26uw0yoxy8ix-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HsWepANHmBqbdwzSo/art.json b/art/HsWepANHmBqbdwzSo/art.json index a4307867..62b7081f 100644 --- a/art/HsWepANHmBqbdwzSo/art.json +++ b/art/HsWepANHmBqbdwzSo/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.13725490196078433,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor (vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.13725490196078433, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor (vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-8wuimoyturt4c31bf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Hsmfxt55QrbZxDm4d/art.json b/art/Hsmfxt55QrbZxDm4d/art.json index c463931c..908a80ed 100644 --- a/art/Hsmfxt55QrbZxDm4d/art.json +++ b/art/Hsmfxt55QrbZxDm4d/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":22123,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/whippedcreammusic/popn11yuihuihyuihh\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.1, 0.2, 1.4) * 11.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 2.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 0.1 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(2.1, 1.2, 0.0)*3.;\\nfloat gExposure = 15.3;\\n\\nfloat gCubeColorRandom =3.8;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 2.8;\\nfloat gFloorHeight = -0.5;\\nfloat g_cameraFar = 1000.0;\\n#define PI radians( 185.0 -(mouse.y * 3. -4.) )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 110.3, 10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 14.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-3., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 2.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 0.2)).xyz;\\n \\tv3 = (mat * vec4(v3, 0.5)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 100 );\\n\\n outSceneVertex.fAlpha = 0.2; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 12.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, mouse.y * 3.0, 2.0*mouse.x);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, -0.2,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, -0.6, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n c, 0, 1, 0,\\n 0, s, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 0, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 172, 2 -mouse.x);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 2);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][2], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 - a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 + a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, -up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, -1,\\n zAxis, 0.11,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 3. - 0.5;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.5);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * (2. /mouse.y));\\n}\\n\\nconst float perBlock = 6.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 3.5));\\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z-snd*5.; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 2, cos(time * 1.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(0.37) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.4), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 22123, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/whippedcreammusic/popn11yuihuihyuihh", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.1, 0.2, 1.4) * 11.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 2.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 0.1 ) * 1.5;\n\nvec3 gCubeColor = vec3(2.1, 1.2, 0.0)*3.;\nfloat gExposure = 15.3;\n\nfloat gCubeColorRandom =3.8;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 2.8;\nfloat gFloorHeight = -0.5;\nfloat g_cameraFar = 1000.0;\n#define PI radians( 185.0 -(mouse.y * 3. -4.) )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 110.3, 10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 14.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-3., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 2.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 0.2)).xyz;\n \tv3 = (mat * vec4(v3, 0.5)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 100 );\n\n outSceneVertex.fAlpha = 0.2; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 12.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, mouse.y * 3.0, 2.0*mouse.x);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, -0.2,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, -0.6, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n c, 0, 1, 0,\n 0, s, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 0, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 172, 2 -mouse.x);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 2);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][2], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 - a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 + a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, -up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, -1,\n zAxis, 0.11,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 3. - 0.5;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.5);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * (2. /mouse.y));\n}\n\nconst float perBlock = 6.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 3.5));\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z-snd*5.; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 2, cos(time * 1.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(0.37) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.4), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-fmlneswktbpa45jgy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HtBoKeP3qMfWwH4gB/art.json b/art/HtBoKeP3qMfWwH4gB/art.json index a7765979..6a8976f2 100644 --- a/art/HtBoKeP3qMfWwH4gB/art.json +++ b/art/HtBoKeP3qMfWwH4gB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":1997,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Motion\\n// CS250 Spring 2022\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n bool isHorizontal = vertexId < vertexCount / 2.0;\\n \\n float x = isHorizontal ? mod(vertexId, across) : floor(vertexId / across);\\n float y = isHorizontal ? floor(vertexId / across) : mod(vertexId, across);\\n\\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n\\n float xOffset = sin(time + 0.3 * length(vec2(x, y)) + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.2;\\n \\n float ux = (isHorizontal ? u * 2.0 - 1.0 : u * 4.0 - 3.0) + xOffset;\\n float vy = (isHorizontal ? v * 4.0 - 1.0 : v * 2.0 - 1.0) + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n\\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1997, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Motion\n// CS250 Spring 2022\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n bool isHorizontal = vertexId < vertexCount / 2.0;\n \n float x = isHorizontal ? mod(vertexId, across) : floor(vertexId / across);\n float y = isHorizontal ? floor(vertexId / across) : mod(vertexId, across);\n\n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n\n float xOffset = sin(time + 0.3 * length(vec2(x, y)) + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.2;\n \n float ux = (isHorizontal ? u * 2.0 - 1.0 : u * 4.0 - 3.0) + xOffset;\n float vy = (isHorizontal ? v * 4.0 - 1.0 : v * 2.0 - 1.0) + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n\n gl_Position = vec4(xy, 0.0, 1.0);\n \n float sizeOffset = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-8hjtin7130b7snpd5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HtZXu6SRZeugBajhN/art.json b/art/HtZXu6SRZeugBajhN/art.json index 1615a934..99affd56 100644 --- a/art/HtZXu6SRZeugBajhN/art.json +++ b/art/HtZXu6SRZeugBajhN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "rubinhuang9239", "avatarUrl": "https://avatars.githubusercontent.com/Rubinhuang9239?s=200", - "settings": "{\"num\":2048,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor (vertexCount/down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x/ (across - 1.0);\\n \\tfloat v = y/ (across - 1.0);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u*2.0-1.0 + xoff;\\n float vy = v*2.0-1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux,vy) * 0.70;\\n\\n \\tgl_Position = vec4( xy, 0.0, 1.0); \\n \\n \\tfloat sizeoff = sin(time + x * y *0.02) * 10.0;\\n\\t\\n \\tgl_PointSize = 15.0 + sizeoff;\\n \\tgl_PointSize *= 20.0/across;\\t\\n \\tgl_PointSize *= resolution.x/600.0;\\t\\n \\n \\tv_color = vec4(ux + cos(sin(ux + time)), vy + cos(sin(vy + time)), 0.75,1.0);\\n}\\n\"}", + "settings": { + "num": 2048, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor (vertexCount/down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x/ (across - 1.0);\n \tfloat v = y/ (across - 1.0);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.1;\n \n float ux = u*2.0-1.0 + xoff;\n float vy = v*2.0-1.0 + yoff;\n \n \tvec2 xy = vec2(ux,vy) * 0.70;\n\n \tgl_Position = vec4( xy, 0.0, 1.0); \n \n \tfloat sizeoff = sin(time + x * y *0.02) * 10.0;\n\t\n \tgl_PointSize = 15.0 + sizeoff;\n \tgl_PointSize *= 20.0/across;\t\n \tgl_PointSize *= resolution.x/600.0;\t\n \n \tv_color = vec4(ux + cos(sin(ux + time)), vy + cos(sin(vy + time)), 0.75,1.0);\n}\n" + }, "screenshotURL": "data/images/images-8m16df7guopg2x34v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Hv927AXio5i8HPs2J/art.json b/art/Hv927AXio5i8HPs2J/art.json index b0366e8c..bfe3c62b 100644 --- a/art/Hv927AXio5i8HPs2J/art.json +++ b/art/Hv927AXio5i8HPs2J/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alexisrubio96", "avatarUrl": "https://avatars.githubusercontent.com/AlexisRubio96?s=200", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n \\tfloat width = 20.0;\\n \\n \\tfloat x = mod(vertexId, width);\\n\\tfloat y = floor(vertexId / width);\\n \\t\\n \\tfloat u = x / (width - 1.0);\\n \\tfloat v = y / (width - 1.0);\\n \\n \\tfloat xOffset = cos(time + y *0.2) * 0.1;\\n \\tfloat yOffset = sin(time + x * 0.3) * 0.1;\\n \\n \\tfloat ux = u *2.0 -1.0 + xOffset;\\n \\tfloat vy = v *2.0 -1.0 + yOffset;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.2;\\n \\n\\tgl_Position = vec4(xy,0.0,1.0);\\t\\t//Posición final de un vertice\\n \\tv_color = vec4(1.0,0.0,0.0,1.0);\\n \\tgl_PointSize = 10.0;\\n\\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n \tfloat width = 20.0;\n \n \tfloat x = mod(vertexId, width);\n\tfloat y = floor(vertexId / width);\n \t\n \tfloat u = x / (width - 1.0);\n \tfloat v = y / (width - 1.0);\n \n \tfloat xOffset = cos(time + y *0.2) * 0.1;\n \tfloat yOffset = sin(time + x * 0.3) * 0.1;\n \n \tfloat ux = u *2.0 -1.0 + xOffset;\n \tfloat vy = v *2.0 -1.0 + yOffset;\n \n \tvec2 xy = vec2(ux, vy) * 1.2;\n \n\tgl_Position = vec4(xy,0.0,1.0);\t\t//Posición final de un vertice\n \tv_color = vec4(1.0,0.0,0.0,1.0);\n \tgl_PointSize = 10.0;\n\n}" + }, "screenshotURL": "data/images/images-708qvrtsykncwa5ku-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HxBJDEFhjvg9CxYdQ/art.json b/art/HxBJDEFhjvg9CxYdQ/art.json index 7de8783d..eb04042f 100644 --- a/art/HxBJDEFhjvg9CxYdQ/art.json +++ b/art/HxBJDEFhjvg9CxYdQ/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "dzozef", - "settings": "{\"num\":5978,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// retro flag\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 10.0;// * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.05 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, (-SIZE/2.0 + y) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE * smoothstep( SIZE, 0., x ) );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*0.2-0.2 );\\n float origz = p.z;\\n p += vec3( 0.0, 0.0, 10.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 5978, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// retro flag\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 10.0;// * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.05 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, (-SIZE/2.0 + y) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE * smoothstep( SIZE, 0., x ) );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*0.2-0.2 );\n float origz = p.z;\n p += vec3( 0.0, 0.0, 10.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-5iwbjxnsflt4tsg3k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HyBREewYeJJq8kxKa/art.json b/art/HyBREewYeJJq8kxKa/art.json index 3bef481a..08fa5fb9 100644 --- a/art/HyBREewYeJJq8kxKa/art.json +++ b/art/HyBREewYeJJq8kxKa/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "molotovbliss", "avatarUrl": "https://avatars.githubusercontent.com/molotovbliss?s=200", - "settings": "{\"num\":84541,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.11372549019607843,0.1450980392156863,0.1803921568627451,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.01, av * .25)).a;\\n\\n float xoff = .1;//sin(time * y) / snd * PI;\\n float yoff = .1;//sin(snd * y * PI); \\n \\n x = snd / y;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .01);\\n gl_PointSize = pow(snd * time, snd) * snd * soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.01, time);\\n \\n float hue = u * .1 + snd * .4 + time / sin(time + v) * .00009 / time;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd, 20.), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 84541, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.11372549019607843, + 0.1450980392156863, + 0.1803921568627451, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.01, av * .25)).a;\n\n float xoff = .1;//sin(time * y) / snd * PI;\n float yoff = .1;//sin(snd * y * PI); \n \n x = snd / y;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .01);\n gl_PointSize = pow(snd * time, snd) * snd * soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.01, time);\n \n float hue = u * .1 + snd * .4 + time / sin(time + v) * .00009 / time;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd, 20.), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-4fhsfm0dxsyw1npml-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HyfsdJ6JLfMhwDRtz/art.json b/art/HyfsdJ6JLfMhwDRtz/art.json index 7683e6bc..e48a2162 100644 --- a/art/HyfsdJ6JLfMhwDRtz/art.json +++ b/art/HyfsdJ6JLfMhwDRtz/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "luis", "avatarUrl": "https://graph.facebook.com/10208687216256743/picture?type=large", - "settings": "{\"num\":75610,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvoid main()\\n{\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = ux /20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n vec2 xy = vec2(x, y);\\n \\n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n}\"}", + "settings": { + "num": 75610, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvoid main()\n{\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = ux /20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n vec2 xy = vec2(x, y);\n \n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n}" + }, "screenshotURL": "data/images/images-edj0oeyz9tyf9tzhd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/HzJkDk2XHyXcxbpik/art.json b/art/HzJkDk2XHyXcxbpik/art.json index b9db1b02..b1d01cb3 100644 --- a/art/HzJkDk2XHyXcxbpik/art.json +++ b/art/HzJkDk2XHyXcxbpik/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5096,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 10.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\\n\"}", + "settings": { + "num": 5096, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 10.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}\n" + }, "screenshotURL": "data/images/images-4nbri3v8wv2mi17mb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/HzfYepRNGKNTsrgjP/art.json b/art/HzfYepRNGKNTsrgjP/art.json index 34074f15..60ec8595 100644 --- a/art/HzfYepRNGKNTsrgjP/art.json +++ b/art/HzfYepRNGKNTsrgjP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":120,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.027450980392156862,0.08627450980392157,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 triangle(int vtx) {\\n if (vtx == 0) {\\n return vec3(-1.0, -1.0, 0.0);\\n } else if (vtx == 1) {\\n return vec3(0.0, 1.0, 0.0);\\n } else if (vtx == 2) {\\n return vec3(1.0, -1.0, 0.0);\\n } else {\\n return vec3(0.0, sin(time)*sin(time), 0.0);\\n }\\n}\\n\\nvoid main() {\\n float triangleId = floor(vertexId / 3.0);\\n float triangleCount = floor(vertexCount / 3.0);\\n float triVtx = mod(vertexId, 3.0);\\n \\n // uniformly spaced in (0, 1)\\n float t = mix(triangleId/triangleCount,\\n (triangleId+1.)/triangleCount,\\n 0.5);\\n \\n float angle = 2. * PI * t;\\n angle += time;\\n vec3 pos = triangle(int(triVtx));\\n mat3 rot = mat3(\\n vec3(cos(angle), -sin(angle), 0.0),\\n vec3(sin(angle), cos(angle), 0.0),\\n vec3(0.0, 0.0, 1.0)\\n );\\n mat3 scal = mat3(1./sqrt(2.));\\n pos = scal * rot * pos;\\n \\n pos.y *= resolution.x/resolution.y;\\n\\n gl_Position = vec4(pos, 1.0);\\n vec3 col = hsv2rgb(vec3(t, 0.7, 0.7));\\n v_color = vec4(col, 1.0 - t);\\n}\"}", + "settings": { + "num": 120, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.027450980392156862, + 0.08627450980392157, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 triangle(int vtx) {\n if (vtx == 0) {\n return vec3(-1.0, -1.0, 0.0);\n } else if (vtx == 1) {\n return vec3(0.0, 1.0, 0.0);\n } else if (vtx == 2) {\n return vec3(1.0, -1.0, 0.0);\n } else {\n return vec3(0.0, sin(time)*sin(time), 0.0);\n }\n}\n\nvoid main() {\n float triangleId = floor(vertexId / 3.0);\n float triangleCount = floor(vertexCount / 3.0);\n float triVtx = mod(vertexId, 3.0);\n \n // uniformly spaced in (0, 1)\n float t = mix(triangleId/triangleCount,\n (triangleId+1.)/triangleCount,\n 0.5);\n \n float angle = 2. * PI * t;\n angle += time;\n vec3 pos = triangle(int(triVtx));\n mat3 rot = mat3(\n vec3(cos(angle), -sin(angle), 0.0),\n vec3(sin(angle), cos(angle), 0.0),\n vec3(0.0, 0.0, 1.0)\n );\n mat3 scal = mat3(1./sqrt(2.));\n pos = scal * rot * pos;\n \n pos.y *= resolution.x/resolution.y;\n\n gl_Position = vec4(pos, 1.0);\n vec3 col = hsv2rgb(vec3(t, 0.7, 0.7));\n v_color = vec4(col, 1.0 - t);\n}" + }, "screenshotURL": "data/images/images-4h0eel76rr5lxvcod-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/J2FKQo6uXQ6EykLPi/art.json b/art/J2FKQo6uXQ6EykLPi/art.json index a9ec156a..e9758b39 100644 --- a/art/J2FKQo6uXQ6EykLPi/art.json +++ b/art/J2FKQo6uXQ6EykLPi/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":28986,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define K0 5.0//KParameter0 0.>>10.\\n#define K1 3.0//KParameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>5.\\n#define KP3 0.00//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>2.0\\n#define KP0 (K1 * mouse.y)\\n#define KP1 (K0 * mouse.x)\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2., quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 2.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 28986, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define K0 5.0//KParameter0 0.>>10.\n#define K1 3.0//KParameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>5.\n#define KP3 0.00//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>2.0\n#define KP0 (K1 * mouse.y)\n#define KP1 (K0 * mouse.x)\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2., quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 2.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-675ntls69829lgbdo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/J3PNfiNPbPxziEh3A/art.json b/art/J3PNfiNPbPxziEh3A/art.json index 0bf5eee0..806cd7cf 100644 --- a/art/J3PNfiNPbPxziEh3A/art.json +++ b/art/J3PNfiNPbPxziEh3A/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "daff", "avatarUrl": "https://lh6.googleusercontent.com/-q6F2s0HNLkg/AAAAAAAAAAI/AAAAAAAAABQ/1TC-kZyFYM0/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/re_gain/alert\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = u * 2. - 1.;\\n \\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/re_gain/alert", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount /down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = u * 2. - 1.;\n \n \n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-ck4qigihnzjuyjk3f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/J3bwBPducoTXfnDLs/art.json b/art/J3bwBPducoTXfnDLs/art.json index ace0d6a4..6be5981f 100644 --- a/art/J3bwBPducoTXfnDLs/art.json +++ b/art/J3bwBPducoTXfnDLs/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main()\\n{\\n float deg = vertexId + (time / 2.);\\n vec3 pos = vec3(sin(deg), cos(deg), floor(vertexId / (PI * 2.)));\\n \\n // Applied a sin wave to the tex2d sample as a smoothing operation\\n float fov = sin(radians(texture2D(sound, vec2(.4, 0)).a) * 2.) / 1.;\\n \\n mat4 camera = mat4(\\n resolution.y / resolution.x, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, fov, fov,\\n 0, 0, 0, 1);\\n \\n gl_Position = camera * vec4(pos.xyz, 1);\\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main()\n{\n float deg = vertexId + (time / 2.);\n vec3 pos = vec3(sin(deg), cos(deg), floor(vertexId / (PI * 2.)));\n \n // Applied a sin wave to the tex2d sample as a smoothing operation\n float fov = sin(radians(texture2D(sound, vec2(.4, 0)).a) * 2.) / 1.;\n \n mat4 camera = mat4(\n resolution.y / resolution.x, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, fov, fov,\n 0, 0, 0, 1);\n \n gl_Position = camera * vec4(pos.xyz, 1);\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-yq7jxy5rth3g50tax-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/J4JLEuTrJFshLPKeg/art.json b/art/J4JLEuTrJFshLPKeg/art.json index 4c6fd1b2..4f750503 100644 --- a/art/J4JLEuTrJFshLPKeg/art.json +++ b/art/J4JLEuTrJFshLPKeg/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "przemyslawzaworski", "avatarUrl": "https://secure.gravatar.com/avatar/3a3abcfa29dc9b0fa9fd2fb25ff10892?default=retro&size=200", - "settings": "{\"num\":65536,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// https://en.wikipedia.org/wiki/B%C3%A9zier_curve\\nvec2 BezierCurve (vec2 a, vec2 b, vec2 c, vec2 d, float t)\\n{\\n\\tfloat x = a.x * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.x * t * (1.0 - t) * (1.0 - t) + 3.0 * c.x * t * t * (1.0 - t) + d.x * t * t * t;\\n\\tfloat y = a.y * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.y * t * (1.0 - t) * (1.0 - t) + 3.0 * c.y * t * t * (1.0 - t) + d.y * t * t * t; \\n\\treturn vec2 (x, y);\\n}\\n\\n// https://www.shadertoy.com/view/4djSRW\\n// Returns value in range -1..1\\nvec4 Hash (float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * vec4(.1031, .1030, .0973, .1099));\\n\\tp4 += dot(p4, p4.wzxy + 33.33);\\n\\treturn fract((p4.xxyz + p4.yzzw) * p4.zywx) * 2.0 - 1.0;\\n}\\n\\n// https://www.khronos.org/registry/OpenGL-Refpages/gl4/html/mod.xhtml\\nfloat Mod (float x, float y)\\n{\\n\\treturn x - y * floor(x / y);\\n}\\n\\nvoid main() \\n{\\n\\tfloat strand = 64.0; // amount of vertices per strand\\n\\tfloat instance = floor(vertexId / strand); // instance ID\\n\\tfloat id = Mod(vertexId, strand); // vertex ID\\n\\tfloat t = max((id + Mod(id, 2.0) - 1.0), 0.0) / (strand - 1.0); // interpolator\\n\\tvec4 n = Hash(instance); // noise\\n\\tvec2 coords = BezierCurve(vec2(n.x + sin(time), n.y - cos(time)), n.xy, n.zw, vec2(-sin(time), cos(time)), t);\\n\\tgl_Position = vec4(coords, 0, 1);\\n\\tv_color = vec4(n.xyz, 1);\\n}\"}", + "settings": { + "num": 65536, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// https://en.wikipedia.org/wiki/B%C3%A9zier_curve\nvec2 BezierCurve (vec2 a, vec2 b, vec2 c, vec2 d, float t)\n{\n\tfloat x = a.x * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.x * t * (1.0 - t) * (1.0 - t) + 3.0 * c.x * t * t * (1.0 - t) + d.x * t * t * t;\n\tfloat y = a.y * (1.0 - t) * (1.0 - t) * (1.0 - t) + 3.0 * b.y * t * (1.0 - t) * (1.0 - t) + 3.0 * c.y * t * t * (1.0 - t) + d.y * t * t * t; \n\treturn vec2 (x, y);\n}\n\n// https://www.shadertoy.com/view/4djSRW\n// Returns value in range -1..1\nvec4 Hash (float p)\n{\n\tvec4 p4 = fract(vec4(p) * vec4(.1031, .1030, .0973, .1099));\n\tp4 += dot(p4, p4.wzxy + 33.33);\n\treturn fract((p4.xxyz + p4.yzzw) * p4.zywx) * 2.0 - 1.0;\n}\n\n// https://www.khronos.org/registry/OpenGL-Refpages/gl4/html/mod.xhtml\nfloat Mod (float x, float y)\n{\n\treturn x - y * floor(x / y);\n}\n\nvoid main() \n{\n\tfloat strand = 64.0; // amount of vertices per strand\n\tfloat instance = floor(vertexId / strand); // instance ID\n\tfloat id = Mod(vertexId, strand); // vertex ID\n\tfloat t = max((id + Mod(id, 2.0) - 1.0), 0.0) / (strand - 1.0); // interpolator\n\tvec4 n = Hash(instance); // noise\n\tvec2 coords = BezierCurve(vec2(n.x + sin(time), n.y - cos(time)), n.xy, n.zw, vec2(-sin(time), cos(time)), t);\n\tgl_Position = vec4(coords, 0, 1);\n\tv_color = vec4(n.xyz, 1);\n}" + }, "screenshotURL": "data/images/images-5fjdc82zhrln5r5vb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/J6Rbdqdhvx7Yjdh59/art.json b/art/J6Rbdqdhvx7Yjdh59/art.json index 45e94654..68ce3b89 100644 --- a/art/J6Rbdqdhvx7Yjdh59/art.json +++ b/art/J6Rbdqdhvx7Yjdh59/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.2) * .1;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.2) * .1;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-0wsynpp1jwvq4z5ij-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JANswiNfyJnruo62E/art.json b/art/JANswiNfyJnruo62E/art.json index f7cf8cc4..8d6c6d72 100644 --- a/art/JANswiNfyJnruo62E/art.json +++ b/art/JANswiNfyJnruo62E/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ambient_space/4-ali-khan-sol\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * .1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 2.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n float st = time; //-0.5 * PI * 10.;\\n float minRez = min(resolution.x, resolution.y);\\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 1000., sin(st * .2) * .5 + .5);\\n gl_PointSize = max(gl_PointSize, 1.0);\\n \\n float z = gl_Position.w / gl_Position.z * .5 + .5;\\n float hue = 1.1;// + mix(.4, .9, sin(st * .1) * .5 + .5);\\n float sat = 1.;\\n float val = 1. ;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ambient_space/4-ali-khan-sol", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * .1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 2.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n float st = time; //-0.5 * PI * 10.;\n float minRez = min(resolution.x, resolution.y);\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 1000., sin(st * .2) * .5 + .5);\n gl_PointSize = max(gl_PointSize, 1.0);\n \n float z = gl_Position.w / gl_Position.z * .5 + .5;\n float hue = 1.1;// + mix(.4, .9, sin(st * .1) * .5 + .5);\n float sat = 1.;\n float val = 1. ;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-bkgwqcyapt1aop426-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JDeTHnXLqGLsoocEr/art.json b/art/JDeTHnXLqGLsoocEr/art.json index c16ee197..eea92970 100644 --- a/art/JDeTHnXLqGLsoocEr/art.json +++ b/art/JDeTHnXLqGLsoocEr/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//vertex shader:\\nvoid main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.75;\\n float rightBottom = 0.0125;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 0, 0, 1);\\n }\\n else {\\n v_color = vec4(0, 0, 1, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//vertex shader:\nvoid main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.75;\n float rightBottom = 0.0125;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 0, 0, 1);\n }\n else {\n v_color = vec4(0, 0, 1, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-bdmm9c03bmu9g9xvr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JERxBfFS5YwaQptZ2/art.json b/art/JERxBfFS5YwaQptZ2/art.json index cbbdf4f7..8930bafc 100644 --- a/art/JERxBfFS5YwaQptZ2/art.json +++ b/art/JERxBfFS5YwaQptZ2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 0.3//KParameter 0.>>2.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv - 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI* 2. + PI * 1.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * -0.2;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(-t * 0.27) + sin(t * -0.013) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.)-1., 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI-2.);\\n float x = cos(qu * PI * 2.) + mouse.y * r*(21.*P3);\\n float y = sin(qu * PI *1.) * r*2.;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 1.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat/sin(time), val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 0.3//KParameter 0.>>2.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv - 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI* 2. + PI * 1.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * -0.2;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(-t * 0.27) + sin(t * -0.013) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.)-1., 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI-2.);\n float x = cos(qu * PI * 2.) + mouse.y * r*(21.*P3);\n float y = sin(qu * PI *1.) * r*2.;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 1.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat/sin(time), val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-mir9d4y5l21r1cqew-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JFFRA5wi7Gc3uCDuP/art.json b/art/JFFRA5wi7Gc3uCDuP/art.json index 7787504f..10ef6747 100644 --- a/art/JFFRA5wi7Gc3uCDuP/art.json +++ b/art/JFFRA5wi7Gc3uCDuP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 1000.//KParameter0 10.>>10000.\\n#define parameter1 1.//KParameter1 1.>>5.\\n#define parameter2 0.8//KParameter2 0.8>>10.\\n#define parameter3 10.//KParameter3 1.>>40.\\n#define symCount 3.//KParameter4 0.>>20.\\n#define colorR 1.//KParameter5 0.>>1.\\n#define colorG 2.//KParameter6 0.>>1.\\n#define colorB 3.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 1800.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n \\n float rotationCout = symCount;\\n \\n float quadCount = POINTS_PER_LINE / 6.;\\n \\n float fVertexId = mod(vertexId,vertexCount/rotationCout);\\n \\n float shapeId = floor(vertexId/rotationCout);\\n \\n float v = fVertexId / vertexCount;\\n float invV = 1. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = mod(fVertexId, 100.) / 100.;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\\n \\n pos = getCenterPoint(time * parameter3 + fVertexId * 1./parameter0, vec2(0,0));\\n pos += vec3(pow(snd1, parameter1) * parameter2 * v * vec2(goop(time * 10.3 + fVertexId * 0.01), goop(time * 5.11 + fVertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n \\n \\n mat4 rot = rotZ(shapeId*2.*PI/rotationCout);\\n vec4 fpos = vec4((vec4(pos, 1)).xyz, 1);\\n \\n fpos *= rot;\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n \\n fpos *= mat;\\n gl_Position = fpos;\\n gl_Position.z = -m1p1(v);\\n \\n \\n\\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.+pow(2.*snd1, 2.);\\n\\n\\n v_color = vec4(colorR,colorG,colorB, 0.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 1000.//KParameter0 10.>>10000.\n#define parameter1 1.//KParameter1 1.>>5.\n#define parameter2 0.8//KParameter2 0.8>>10.\n#define parameter3 10.//KParameter3 1.>>40.\n#define symCount 3.//KParameter4 0.>>20.\n#define colorR 1.//KParameter5 0.>>1.\n#define colorG 2.//KParameter6 0.>>1.\n#define colorB 3.//KParameter7 0.>>1.\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 1800.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n \n float rotationCout = symCount;\n \n float quadCount = POINTS_PER_LINE / 6.;\n \n float fVertexId = mod(vertexId,vertexCount/rotationCout);\n \n float shapeId = floor(vertexId/rotationCout);\n \n float v = fVertexId / vertexCount;\n float invV = 1. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = mod(fVertexId, 100.) / 100.;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\n \n pos = getCenterPoint(time * parameter3 + fVertexId * 1./parameter0, vec2(0,0));\n pos += vec3(pow(snd1, parameter1) * parameter2 * v * vec2(goop(time * 10.3 + fVertexId * 0.01), goop(time * 5.11 + fVertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n \n \n mat4 rot = rotZ(shapeId*2.*PI/rotationCout);\n vec4 fpos = vec4((vec4(pos, 1)).xyz, 1);\n \n fpos *= rot;\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n \n fpos *= mat;\n gl_Position = fpos;\n gl_Position.z = -m1p1(v);\n \n \n\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.+pow(2.*snd1, 2.);\n\n\n v_color = vec4(colorR,colorG,colorB, 0.);\n}" + }, "screenshotURL": "data/images/images-pk6191xy1uq27a65d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JFtfBxTELcg25TGwJ/art.json b/art/JFtfBxTELcg25TGwJ/art.json index a7f5b30d..3760a564 100644 --- a/art/JFtfBxTELcg25TGwJ/art.json +++ b/art/JFtfBxTELcg25TGwJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/huilo-1/amon-tobin-bedtime-stories\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 1.33) + sin(time * 0.83 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n\\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/huilo-1/amon-tobin-bedtime-stories", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 1.33) + sin(time * 0.83 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-wrhxi3rdumga69iix-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JG27yEiRBewAYsMxB/art.json b/art/JG27yEiRBewAYsMxB/art.json index 4f0a574a..75573dd5 100644 --- a/art/JG27yEiRBewAYsMxB/art.json +++ b/art/JG27yEiRBewAYsMxB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "duhochoi", "avatarUrl": "https://secure.gravatar.com/avatar/3a2a5d4b2ecd66c69241bc6b3e1e34e6?default=retro&size=200", - "settings": "{\"num\":7873,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Duho Choi\\n// Assignment : Exercise - Vertexshaderart : Making a Grid\\n// Course : CS250\\n// Term : Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(sin(ux * 3.), sin(vy * 2.), 0, 1);\\n \\n gl_PointSize = 20.0;\\n gl_PointSize *= 40. / across;\\n gl_PointSize *= resolution.x / 1000.;\\n \\n v_color = vec4 (0.2, 0.5, 0.5, 1);\\n \\n}\\n\"}", + "settings": { + "num": 7873, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Duho Choi\n// Assignment : Exercise - Vertexshaderart : Making a Grid\n// Course : CS250\n// Term : Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(sin(ux * 3.), sin(vy * 2.), 0, 1);\n \n gl_PointSize = 20.0;\n gl_PointSize *= 40. / across;\n gl_PointSize *= resolution.x / 1000.;\n \n v_color = vec4 (0.2, 0.5, 0.5, 1);\n \n}\n" + }, "screenshotURL": "data/images/images-yfw2w7ykh9gsw7eje-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JGGw63pb4BxyXBqyc/art.json b/art/JGGw63pb4BxyXBqyc/art.json index 6a558e90..7a8bce07 100644 --- a/art/JGGw63pb4BxyXBqyc/art.json +++ b/art/JGGw63pb4BxyXBqyc/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "nkkky", "avatarUrl": "https://avatars.githubusercontent.com/nkkky?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/nkkky/sir-rup\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 1280.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/nkkky/sir-rup", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 1280.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-so5lflx3v2310djhi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JGbg2hhv422MBQhyP/art.json b/art/JGbg2hhv422MBQhyP/art.json index 6351e6aa..0ac8ba14 100644 --- a/art/JGbg2hhv422MBQhyP/art.json +++ b/art/JGbg2hhv422MBQhyP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thenoiseprocess/i-want-my-credit-card\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n float snd = texture2D(sound, vec2(0.2, u)).a;\\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\tvec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\t\\n\\tfor(float i = 0.001; i < (10.0); i++){\\n\\t\\t\\n\\t\\tfloat s = 2.*snd*cos(sin(10. * time / i )) ;\\n\\t\\tfloat c = tan(cos(0.1* time + i ));\\n\\t\\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n\\n \\n \\n \\n gl_PointSize = 1.+snd*2.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(destColor * f), 1.0);\\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\\n v_color = vec4(vec3(1.), 1.0);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thenoiseprocess/i-want-my-credit-card", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n float snd = texture2D(sound, vec2(0.2, u)).a;\n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\tvec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\t\n\tfor(float i = 0.001; i < (10.0); i++){\n\t\t\n\t\tfloat s = 2.*snd*cos(sin(10. * time / i )) ;\n\t\tfloat c = tan(cos(0.1* time + i ));\n\t\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\n\t}\n\n\n \n \n \n gl_PointSize = 1.+snd*2.;// (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(destColor * f), 1.0);\n gl_Position = vec4(ux+v_color.x*sign(ux), vy, 0, 1);\n v_color = vec4(vec3(1.), 1.0);\n\n}" + }, "screenshotURL": "data/images/images-jgilrxlxy6vfio4p6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JJBEEPXrCubMND6ym/art.json b/art/JJBEEPXrCubMND6ym/art.json index 7381d264..8c011437 100644 --- a/art/JJBEEPXrCubMND6ym/art.json +++ b/art/JJBEEPXrCubMND6ym/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) -1.4;\\n offset.y += goop(circleId + time * 0.13) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -1.79));\\n float sat = 0.2 * circleId/snd;\\n float val = .9;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) / tan(uv * 83.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a-2.0);0\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) -1.4;\n offset.y += goop(circleId + time * 0.13) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -1.79));\n float sat = 0.2 * circleId/snd;\n float val = .9;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) / tan(uv * 83.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a-2.0);0\n}" + }, "screenshotURL": "data/images/images-h6d4rfa2gqrf5psdr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JJKZvJyWdK4ukftPz/art.json b/art/JJKZvJyWdK4ukftPz/art.json index cdb6b188..217040d3 100644 --- a/art/JJKZvJyWdK4ukftPz/art.json +++ b/art/JJKZvJyWdK4ukftPz/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":33829,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 -1.//KParameter 0.>>-10.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (1000. *(P2+1.5))+10.;\\n float numQuads = floor( vertexCount/6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) -(mouse.y * r);\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, mouse*((qv * PI )));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId / 0.66663;\\n float sat = quadId -3.3;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 01.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 33829, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 -1.//KParameter 0.>>-10.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (1000. *(P2+1.5))+10.;\n float numQuads = floor( vertexCount/6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) -(mouse.y * r);\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, mouse*((qv * PI )));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId / 0.66663;\n float sat = quadId -3.3;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 01.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-zlxr2jgma9p45tgxm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JL7KcqFFMw49BvCca/art.json b/art/JL7KcqFFMw49BvCca/art.json index f28c4b62..eb125112 100644 --- a/art/JL7KcqFFMw49BvCca/art.json +++ b/art/JL7KcqFFMw49BvCca/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evilmandarine", "avatarUrl": "https://secure.gravatar.com/avatar/89340ad27602758e65227662f476c233?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.13725490196078433,0.13725490196078433,0.13725490196078433,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n /*\\n float x = vertexId / 5. - 1.;\\n float y = (vertexId / 5. - 1.) * cos(time / 2.);\\n\\n // mod: 0 1 2 ... 9 0 1 2 ... (ex. mod(10))\\n // 0 1 2 ... 9 0 1 2 ...\\n\\n // floor: 0 0 0 ... 0 \\n // 1 1 1 ... 0\\n\\n gl_Position = vec4(x, y, 0, 1);\\n gl_PointSize = 5.;\\n\\n v_color = vec4(1., 1., 1., 1.);\\n */\\n \\n \\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n // 0 to 1 -> -1 to 1\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\\n\\n\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.13725490196078433, + 0.13725490196078433, + 0.13725490196078433, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n /*\n float x = vertexId / 5. - 1.;\n float y = (vertexId / 5. - 1.) * cos(time / 2.);\n\n // mod: 0 1 2 ... 9 0 1 2 ... (ex. mod(10))\n // 0 1 2 ... 9 0 1 2 ...\n\n // floor: 0 0 0 ... 0 \n // 1 1 1 ... 0\n\n gl_Position = vec4(x, y, 0, 1);\n gl_PointSize = 5.;\n\n v_color = vec4(1., 1., 1., 1.);\n */\n \n \n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n // 0 to 1 -> -1 to 1\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}\n\n\n" + }, "screenshotURL": "data/images/images-li2t6b8z49oxvjigi-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JNDG9tsxtQgJzkkCq/art.json b/art/JNDG9tsxtQgJzkkCq/art.json index c16af018..15e376a4 100644 --- a/art/JNDG9tsxtQgJzkkCq/art.json +++ b/art/JNDG9tsxtQgJzkkCq/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Hyunjin Kim\\n// Circles from Triangles.\\n// spring 2022\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Hyunjin Kim\n// Circles from Triangles.\n// spring 2022\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-jcubyvtw7fm0sstkf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JRyewraYLfP9taa98/art.json b/art/JRyewraYLfP9taa98/art.json index bf5e9588..82d58d07 100644 --- a/art/JRyewraYLfP9taa98/art.json +++ b/art/JRyewraYLfP9taa98/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 0.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\\n \\n \\n\\n float hue = sz * 1. + s * .0;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 0.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\n \n \n\n float hue = sz * 1. + s * .0;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-mcuhvernmqk2zekch-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JTAL2t63pEXrPKvru/art.json b/art/JTAL2t63pEXrPKvru/art.json index 561bb898..3dba14d9 100644 --- a/art/JTAL2t63pEXrPKvru/art.json +++ b/art/JTAL2t63pEXrPKvru/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":5009,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n#define kp0 -0.4//KParameter -1.>>1.\\n#define kp1 .9//KParameter -2.>>2.\\n#define kp2 5.2//KParameter -1.>>22.\\n//KVerticesNumber=4000.\\n\\n#define PI radians(33.*kp2)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.)*abs(kp1);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.;\\n float down = numQuads / around -1.1;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI *.1+r) * r;\\n float y = sin(qu * PI *-1.012) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * mix(0.01,abs(kp0),-.05) * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = sin(quadId *.01813333333);\\n float sat = 1.;\\n float val = .57;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.bg = v_color.rb;\\n}\\n\\n/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\\n*/\"}", + "settings": { + "num": 5009, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//KDrawmode=GL_TRIANGLES\n#define kp0 -0.4//KParameter -1.>>1.\n#define kp1 .9//KParameter -2.>>2.\n#define kp2 5.2//KParameter -1.>>22.\n//KVerticesNumber=4000.\n\n#define PI radians(33.*kp2)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.)*abs(kp1);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.;\n float down = numQuads / around -1.1;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI *.1+r) * r;\n float y = sin(qu * PI *-1.012) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * mix(0.01,abs(kp0),-.05) * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = sin(quadId *.01813333333);\n float sat = 1.;\n float val = .57;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.bg = v_color.rb;\n}\n\n/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\n*/" + }, "screenshotURL": "data/images/images-vzz59lxlx6uar3hrv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JWMAmcwDeMYh8uSZf/art.json b/art/JWMAmcwDeMYh8uSZf/art.json index bb2de2ed..a09f3eb8 100644 --- a/art/JWMAmcwDeMYh8uSZf/art.json +++ b/art/JWMAmcwDeMYh8uSZf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-sunday-morning-cave-mix-2019\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \\n out vec3 pos, out vec3 nrm, out vec2 uv) {\\n float numQuads = floor(vertexCount / 6.);\\n float down = numQuads / around;\\n float quadId = floor(float(vertexId) / 6.);\\n\\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n\\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n\\n float edgeId = mod(float(vertexId), 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\\n\\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n\\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n\\n pos = vec3(x, cos(qv * PI), z);\\n nrm = normalize(pos);\\n uv = vec2(qu, qv);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(0);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n vec2 uv;\\n float around = 90.0;\\n float down = 60.0;\\n float vertsPerSphere = around * down * 6.;\\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\\n float cubeId = floor(pointId / vertsPerSphere);\\n float maxCubes = floor(vertexCount / vertsPerSphere);\\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float vu = vertexId / vertexCount;\\n float cv = cubeId / numCubes;\\n float su = hash(vu);\\n //su = hash(cubeId / maxCubes);\\n float s1 = texture2D(sound, vec2(mix(.25, .00, fract(su + 1.0)), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(.26, .01, fract(su + 0.8)), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(.27, .02, fract(su + 0.6)), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(.28, .03, fract(su + 0.4)), 3. / soundRes.y)).a;\\n \\n float s = max(max(max(s1, s2), s3), s4);\\n float tm = time * .1;\\n float r = 11.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n float r2 = mix(8., 8., sin(cv * PI * 2. + time) * 0.5 + 0.5);\\n mat *= rotX(tm);\\n mat *= rotZ(cv * PI);\\n mat *= lookAt(loc * r2, vec3(0), up);\\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\\n// mat *= trans(vec3(0, 0, 1));\\n// mat *= rotZ(s * PI * 2.);\\n mat *= uniformScale(5.0 + pow(s, 5.) * 5.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = pow(s, 5.) + uv.y * .1;\\n float sat = 0. + step(0.9, s);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt * 1.2, 1);\\n// v_color.a = s;\\n v_color.rgb *= v_color.a; \\n// if (s < .2) {\\n// gl_Position.z = 10000.;\\n// }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-sunday-morning-cave-mix-2019", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \n out vec3 pos, out vec3 nrm, out vec2 uv) {\n float numQuads = floor(vertexCount / 6.);\n float down = numQuads / around;\n float quadId = floor(float(vertexId) / 6.);\n\n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n\n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n\n float edgeId = mod(float(vertexId), 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\n\n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n\n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n\n pos = vec3(x, cos(qv * PI), z);\n nrm = normalize(pos);\n uv = vec2(qu, qv);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(0);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n vec2 uv;\n float around = 90.0;\n float down = 60.0;\n float vertsPerSphere = around * down * 6.;\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\n float cubeId = floor(pointId / vertsPerSphere);\n float maxCubes = floor(vertexCount / vertsPerSphere);\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float vu = vertexId / vertexCount;\n float cv = cubeId / numCubes;\n float su = hash(vu);\n //su = hash(cubeId / maxCubes);\n float s1 = texture2D(sound, vec2(mix(.25, .00, fract(su + 1.0)), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(.26, .01, fract(su + 0.8)), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(.27, .02, fract(su + 0.6)), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(.28, .03, fract(su + 0.4)), 3. / soundRes.y)).a;\n \n float s = max(max(max(s1, s2), s3), s4);\n float tm = time * .1;\n float r = 11.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n float r2 = mix(8., 8., sin(cv * PI * 2. + time) * 0.5 + 0.5);\n mat *= rotX(tm);\n mat *= rotZ(cv * PI);\n mat *= lookAt(loc * r2, vec3(0), up);\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\n// mat *= trans(vec3(0, 0, 1));\n// mat *= rotZ(s * PI * 2.);\n mat *= uniformScale(5.0 + pow(s, 5.) * 5.);\n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = pow(s, 5.) + uv.y * .1;\n float sat = 0. + step(0.9, s);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt * 1.2, 1);\n// v_color.a = s;\n v_color.rgb *= v_color.a; \n// if (s < .2) {\n// gl_Position.z = 10000.;\n// }\n}\n\n" + }, "screenshotURL": "data/images/images-bflvw9rcplt4dkghu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JWZRdGqNAqvbskDLS/art.json b/art/JWZRdGqNAqvbskDLS/art.json index 54a38ca1..6f328814 100644 --- a/art/JWZRdGqNAqvbskDLS/art.json +++ b/art/JWZRdGqNAqvbskDLS/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "hyun", "avatarUrl": "https://lh6.googleusercontent.com/-85yu5m2ZywQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdO1OKKAqQzlgMFqnpApfbfi4i4Gw/mo/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t: Jina Hyun\\nAssignment Name/Number\\t: Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n\\n#define SIZE 0.1\\n#define SPEED 10.0\\n#define SCALE_OFFSET 0.1\\n\\nvoid main(void)\\n{ \\n // Heart Shape\\n float x = 16. * sin(vertexId) * sin(vertexId) * sin(vertexId);\\n float y = 13. * cos(vertexId) - 5. * cos(2. * vertexId) - 2. * cos(3. * vertexId) - cos(4. * vertexId);\\n \\n // Map -1 to 1\\n float size = 0.17 * SIZE;\\n x = x * size;\\n y = y * size;\\n \\n // Set Scale\\n float scale = (abs(sin(time * SPEED) * SCALE_OFFSET) + 0.5);\\n x = x * scale * 0.75;\\n y = y * scale;\\n \\n gl_Position = vec4(x + mouse.x, y + mouse.y, 0.0, 1.0); \\n v_color = vec4(abs(sin(time * mouse.x)), abs(cos(time * mouse.y)), abs((mouse.x + mouse.y)/2.), 1.);\\n}\"}", + "settings": { + "num": 1000, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t: Jina Hyun\nAssignment Name/Number\t: Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n\n#define SIZE 0.1\n#define SPEED 10.0\n#define SCALE_OFFSET 0.1\n\nvoid main(void)\n{ \n // Heart Shape\n float x = 16. * sin(vertexId) * sin(vertexId) * sin(vertexId);\n float y = 13. * cos(vertexId) - 5. * cos(2. * vertexId) - 2. * cos(3. * vertexId) - cos(4. * vertexId);\n \n // Map -1 to 1\n float size = 0.17 * SIZE;\n x = x * size;\n y = y * size;\n \n // Set Scale\n float scale = (abs(sin(time * SPEED) * SCALE_OFFSET) + 0.5);\n x = x * scale * 0.75;\n y = y * scale;\n \n gl_Position = vec4(x + mouse.x, y + mouse.y, 0.0, 1.0); \n v_color = vec4(abs(sin(time * mouse.x)), abs(cos(time * mouse.y)), abs((mouse.x + mouse.y)/2.), 1.);\n}" + }, "screenshotURL": "data/images/images-r73exb16ty0euxj5j-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JZBqJBXoyFqb5wyB6/art.json b/art/JZBqJBXoyFqb5wyB6/art.json index 5fb610d4..1c233246 100644 --- a/art/JZBqJBXoyFqb5wyB6/art.json +++ b/art/JZBqJBXoyFqb5wyB6/art.json @@ -27,7 +27,19 @@ "name": "graph", "private": true, "username": "gman", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.\\n#define NUM_POINTS (NUM_SEGMENTS * 2.)\\n#define STEP 1.\\n#define NUM_LINES_DOWN 64.\\n#define PI 3.141592653589793\\n#define ACROSS 8.\\n#define WIDTH (0.5 / ACROSS)\\n#define HEIGHT (0.4 / ACROSS)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat mixer(float count, float countId) {\\n return step(countId - .1, count) * step(count, countId + .1);\\n}\\n\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // area count\\n float count = floor(vertexId / NUM_POINTS);\\n // area origin\\n vec2 origin = vec2(\\n mod(count, ACROSS) / (ACROSS - 1.) * 2. - 1.,\\n floor(count / ACROSS) / (ACROSS - 1.) * 2. - 1.);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = mixer(count, 0.) * sin(u * PI * 2.) +\\n mixer(count, 1.) * cos(u * PI * 2.) +\\n mixer(count, 2.) * (u * 2.0 - 1.0) +\\n mixer(count, 3.) * pow(u, 5.0) +\\n mixer(count, 4.) * u +\\n mixer(count, 5.) * u +\\n mixer(count, 6.) * u +\\n mixer(count, 7.) * u +\\n mixer(count, 8.) * u +\\n mixer(count, 9.) * u +\\n mixer(count, 10.) * u +\\n mixer(count, 11.) * u +\\n mixer(count, 12.) * u +\\n mixer(count, 13.) * u +\\n mixer(count, 14.) * u +\\n mixer(count, 15.) * u +\\n mixer(count, 16.) * u +\\n mixer(count, 17.) * u +\\n mixer(count, 18.) * u +\\n mixer(count, 19.) * u +\\n mixer(count, 20.) * u +\\n mixer(count, 21.) * u +\\n mixer(count, 22.) * u +\\n mixer(count, 23.) * u +\\n mixer(count, 24.) * u +\\n mixer(count, 25.) * u +\\n mixer(count, 26.) * u +\\n mixer(count, 27.) * u +\\n mixer(count, 28.) * u +\\n mixer(count, 29.) * u +\\n mixer(count, 30.) * u +\\n mixer(count, 31.) * u +\\n mixer(count, 32.) * u +\\n mixer(count, 33.) * u +\\n mixer(count, 34.) * u +\\n mixer(count, 35.) * u +\\n mixer(count, 36.) * u +\\n mixer(count, 37.) * u +\\n mixer(count, 38.) * u +\\n mixer(count, 39.) * u +\\n mixer(count, 40.) * u +\\n mixer(count, 41.) * u +\\n mixer(count, 42.) * u +\\n mixer(count, 43.) * u +\\n mixer(count, 44.) * u +\\n mixer(count, 45.) * u +\\n mixer(count, 46.) * u +\\n mixer(count, 47.) * u +\\n mixer(count, 48.) * u +\\n mixer(count, 49.) * u +\\n mixer(count, 50.) * u +\\n mixer(count, 51.) * u +\\n mixer(count, 52.) * u +\\n mixer(count, 53.) * u +\\n mixer(count, 54.) * u +\\n mixer(count, 55.) * u +\\n mixer(count, 56.) * u +\\n mixer(count, 57.) * u +\\n mixer(count, 58.) * u +\\n mixer(count, 59.) * u +\\n mixer(count, 60.) * u +\\n mixer(count, 61.) * u +\\n mixer(count, 62.) * u +\\n mixer(count, 63.) * u +\\n 0.;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = origin * 0.8 + vec2(\\n x * WIDTH,\\n y * HEIGHT);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = count / 21.;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.\n#define NUM_POINTS (NUM_SEGMENTS * 2.)\n#define STEP 1.\n#define NUM_LINES_DOWN 64.\n#define PI 3.141592653589793\n#define ACROSS 8.\n#define WIDTH (0.5 / ACROSS)\n#define HEIGHT (0.4 / ACROSS)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat mixer(float count, float countId) {\n return step(countId - .1, count) * step(count, countId + .1);\n}\n\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // area count\n float count = floor(vertexId / NUM_POINTS);\n // area origin\n vec2 origin = vec2(\n mod(count, ACROSS) / (ACROSS - 1.) * 2. - 1.,\n floor(count / ACROSS) / (ACROSS - 1.) * 2. - 1.);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = mixer(count, 0.) * sin(u * PI * 2.) +\n mixer(count, 1.) * cos(u * PI * 2.) +\n mixer(count, 2.) * (u * 2.0 - 1.0) +\n mixer(count, 3.) * pow(u, 5.0) +\n mixer(count, 4.) * u +\n mixer(count, 5.) * u +\n mixer(count, 6.) * u +\n mixer(count, 7.) * u +\n mixer(count, 8.) * u +\n mixer(count, 9.) * u +\n mixer(count, 10.) * u +\n mixer(count, 11.) * u +\n mixer(count, 12.) * u +\n mixer(count, 13.) * u +\n mixer(count, 14.) * u +\n mixer(count, 15.) * u +\n mixer(count, 16.) * u +\n mixer(count, 17.) * u +\n mixer(count, 18.) * u +\n mixer(count, 19.) * u +\n mixer(count, 20.) * u +\n mixer(count, 21.) * u +\n mixer(count, 22.) * u +\n mixer(count, 23.) * u +\n mixer(count, 24.) * u +\n mixer(count, 25.) * u +\n mixer(count, 26.) * u +\n mixer(count, 27.) * u +\n mixer(count, 28.) * u +\n mixer(count, 29.) * u +\n mixer(count, 30.) * u +\n mixer(count, 31.) * u +\n mixer(count, 32.) * u +\n mixer(count, 33.) * u +\n mixer(count, 34.) * u +\n mixer(count, 35.) * u +\n mixer(count, 36.) * u +\n mixer(count, 37.) * u +\n mixer(count, 38.) * u +\n mixer(count, 39.) * u +\n mixer(count, 40.) * u +\n mixer(count, 41.) * u +\n mixer(count, 42.) * u +\n mixer(count, 43.) * u +\n mixer(count, 44.) * u +\n mixer(count, 45.) * u +\n mixer(count, 46.) * u +\n mixer(count, 47.) * u +\n mixer(count, 48.) * u +\n mixer(count, 49.) * u +\n mixer(count, 50.) * u +\n mixer(count, 51.) * u +\n mixer(count, 52.) * u +\n mixer(count, 53.) * u +\n mixer(count, 54.) * u +\n mixer(count, 55.) * u +\n mixer(count, 56.) * u +\n mixer(count, 57.) * u +\n mixer(count, 58.) * u +\n mixer(count, 59.) * u +\n mixer(count, 60.) * u +\n mixer(count, 61.) * u +\n mixer(count, 62.) * u +\n mixer(count, 63.) * u +\n 0.;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = origin * 0.8 + vec2(\n x * WIDTH,\n y * HEIGHT);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = count / 21.;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-2gtd9z97iet49dz8d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JZfSq6roYfXYSQTYs/art.json b/art/JZfSq6roYfXYSQTYs/art.json index f6e2d76f..7b0f18c8 100644 --- a/art/JZfSq6roYfXYSQTYs/art.json +++ b/art/JZfSq6roYfXYSQTYs/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sairu312", "avatarUrl": "https://avatars.githubusercontent.com/Sairu312?s=200", - "settings": "{\"num\":4875,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n//#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n//#define STEP 1.0\\n\\n\\nvoid main() {\\n vec3 p;\\n \\n //triangleIdは三角形の識別ようID\\n //triangleVertexIdはその三角形内での頂点の識別IDは\\n float triangleId = floor(vertexId / 3.0);\\n float triangleVertexId = mod(vertexId, 3.0);\\n \\n float angle = radians(60.0) * (triangleVertexId * 2.0 + triangleId * 0.6667);\\n p = vec3(sin(angle), cos(angle), -0.01 * triangleId);\\n \\n p.x *= resolution.y / resolution.x;\\n \\n gl_Position = vec4(p * 0.8, 1);\\n gl_PointSize = 10.0;\\n \\n v_color = vec4(0.5, 0.5, 0.5, 0.5);\\n}\"}", + "settings": { + "num": 4875, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n//#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n//#define STEP 1.0\n\n\nvoid main() {\n vec3 p;\n \n //triangleIdは三角形の識別ようID\n //triangleVertexIdはその三角形内での頂点の識別IDは\n float triangleId = floor(vertexId / 3.0);\n float triangleVertexId = mod(vertexId, 3.0);\n \n float angle = radians(60.0) * (triangleVertexId * 2.0 + triangleId * 0.6667);\n p = vec3(sin(angle), cos(angle), -0.01 * triangleId);\n \n p.x *= resolution.y / resolution.x;\n \n gl_Position = vec4(p * 0.8, 1);\n gl_PointSize = 10.0;\n \n v_color = vec4(0.5, 0.5, 0.5, 0.5);\n}" + }, "screenshotURL": "data/images/images-rd83nf4vwr2d6ctw0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JagMqSrHRchzQAMRB/art.json b/art/JagMqSrHRchzQAMRB/art.json index dcf23d0b..28edc0f0 100644 --- a/art/JagMqSrHRchzQAMRB/art.json +++ b/art/JagMqSrHRchzQAMRB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46321.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n/*\\n * Original shader from: https://www.shadertoy.com/view/XsKcDy\\n */\\n\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n\\n// glslsandbox //uniform s\\n//uniform //float time;\\n//uniform vec2 vertexResolution;\\n\\n// shadertoy globals\\nfloat iTime = time;//;\\nvec3 iResolution = vec3(vertexResolution, 0.0);\\n\\n// --------[ Original ShaderToy begins here ]---------- //\\n#define B(x,y) O += line( U, vec2(x,y+E),vec2(x,y-E) ) // vertical bar free\\n#define L(a,b) O += line( U, vec2(a,E), vec2(b,-E) ) // slanted bar on rail\\n#define S(D) smoothstep( 4./R.y, 0. , length(D)-e )\\n//#define S(D) sin ( 100.*(length(D)-e) ) *.05 / dot(D,D) // fun variant\\n#define T(a,b) if ( t>a && t2.)\\n T(1.,2.) L( f(1.,.3,l), f(1.,.6,l) ), // out the X\\n L( f(1.,.6,l+.2),f(1.,.3,l+.2));\\n \\n}\\n// --------[ Original ShaderToy ends here ]---------- //\\n\\nvoid main(void)\\n{float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n iTime = time;\\n iResolution = vec3(vertexResolution, 0.0);\\n\\n mainImage(v_color, simFragCoord.xy);\\n v_color.a = 1.0;\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46321.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n/*\n * Original shader from: https://www.shadertoy.com/view/XsKcDy\n */\n\n#ifdef GL_ES\n//precision mediump float;\n#endif\n\n// glslsandbox //uniform s\n//uniform //float time;\n//uniform vec2 vertexResolution;\n\n// shadertoy globals\nfloat iTime = time;//;\nvec3 iResolution = vec3(vertexResolution, 0.0);\n\n// --------[ Original ShaderToy begins here ]---------- //\n#define B(x,y) O += line( U, vec2(x,y+E),vec2(x,y-E) ) // vertical bar free\n#define L(a,b) O += line( U, vec2(a,E), vec2(b,-E) ) // slanted bar on rail\n#define S(D) smoothstep( 4./R.y, 0. , length(D)-e )\n//#define S(D) sin ( 100.*(length(D)-e) ) *.05 / dot(D,D) // fun variant\n#define T(a,b) if ( t>a && t2.)\n T(1.,2.) L( f(1.,.3,l), f(1.,.6,l) ), // out the X\n L( f(1.,.6,l+.2),f(1.,.3,l+.2));\n \n}\n// --------[ Original ShaderToy ends here ]---------- //\n\nvoid main(void)\n{float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n iTime = time;\n iResolution = vec3(vertexResolution, 0.0);\n\n mainImage(v_color, simFragCoord.xy);\n v_color.a = 1.0;\n}" + }, "screenshotURL": "data/images/images-gakyagezmo7p4g6wv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JfcfxquJzYFfZJ5cW/art.json b/art/JfcfxquJzYFfZJ5cW/art.json index 01eac4a9..5790bfa4 100644 --- a/art/JfcfxquJzYFfZJ5cW/art.json +++ b/art/JfcfxquJzYFfZJ5cW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":54990,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n#define P1 0.9//KParameter0 0.3>>1.0 \\n#define P2 0.2//KParameter1 -0.3>>0.5\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, c-0.7, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, P1, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2],a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.6,\\n yAxis, 0,\\n zAxis, .1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x - p2.y * 85.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.15 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 23.) * r;\\n float z = sin(qu * PI *2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) /(around * PI) * 68.)\\n );\\n \\n float tm = time * 1.1;\\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\\n mat4 mat = persp(PI * 1.1 + P1, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.5, 2.5, pow(s + 0.2 +P2, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 2.;\\n\\n float odd = mod(floor(quadId/6.), 2.);\\n float hue = time * .1 +s * .15;\\n float sat = mix(0., 3., pow(s, 2.));\\n float val = mix(0.1, 1., pow(s + .4, 15.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 54990, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n#define P1 0.9//KParameter0 0.3>>1.0 \n#define P2 0.2//KParameter1 -0.3>>0.5\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, c-0.7, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, P1, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2],a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.6,\n yAxis, 0,\n zAxis, .1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x - p2.y * 85.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.15 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 23.) * r;\n float z = sin(qu * PI *2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) /(around * PI) * 68.)\n );\n \n float tm = time * 1.1;\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\n mat4 mat = persp(PI * 1.1 + P1, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.5, 2.5, pow(s + 0.2 +P2, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 2.;\n\n float odd = mod(floor(quadId/6.), 2.);\n float hue = time * .1 +s * .15;\n float sat = mix(0., 3., pow(s, 2.));\n float val = mix(0.1, 1., pow(s + .4, 15.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-9go3rjrx6gq5nwx3y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JhD7Yeh3NstvQbkhJ/art.json b/art/JhD7Yeh3NstvQbkhJ/art.json index 5aea42c2..f43daee2 100644 --- a/art/JhD7Yeh3NstvQbkhJ/art.json +++ b/art/JhD7Yeh3NstvQbkhJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21568627450980393,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Motion\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21568627450980393, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Motion\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-saxcpw39a4cogiu9h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JhPkQF3eX4q9YcDML/art.json b/art/JhPkQF3eX4q9YcDML/art.json index bcbfd878..3259fc70 100644 --- a/art/JhPkQF3eX4q9YcDML/art.json +++ b/art/JhPkQF3eX4q9YcDML/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alejandrocamara", "avatarUrl": "https://avatars.githubusercontent.com/AlejandroCamara?s=200", - "settings": "{\"num\":742,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n \\t// Distancia entre los puntos\\n \\t// y numero de puntos por fila\\n \\tfloat width = 10.0;\\n \\n \\t\\n \\t// Ubicacion de los circulos\\n \\tfloat x = mod(vertexId, width);\\t// Columna\\n \\tfloat y = floor(vertexId / width);\\t// Fila\\n \\n \\t// Escala de los puntos para que quepan en la pantalla\\n \\tfloat u = x / (width - 1.0);\\n \\tfloat v = y / (width - 1.0);\\n \\n \\n \\t// Movimiento en onda\\n \\tfloat xOffset = sin(time + y * 0.2) * 0.1;\\n \\tfloat yOffset = cos(time + x * 0.3) * 0.2;\\n \\n \\t//float xOffset = 0.0;\\n \\t//float yOffset = 0.0;\\n \\n \\t// Coordenadas finales\\n \\tfloat ux = u * 2.0 - 1.0 + xOffset;\\n \\tfloat vy = v * 2.0 - 1.0 + yOffset;\\n \\t\\n \\tvec2 xy = vec2(ux, vy) * 1.2;\\n \\n\\tgl_Position = vec4(xy, 0.0, 1.0);\\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\tgl_PointSize = 20.0;\\n}\"}", + "settings": { + "num": 742, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n \t// Distancia entre los puntos\n \t// y numero de puntos por fila\n \tfloat width = 10.0;\n \n \t\n \t// Ubicacion de los circulos\n \tfloat x = mod(vertexId, width);\t// Columna\n \tfloat y = floor(vertexId / width);\t// Fila\n \n \t// Escala de los puntos para que quepan en la pantalla\n \tfloat u = x / (width - 1.0);\n \tfloat v = y / (width - 1.0);\n \n \n \t// Movimiento en onda\n \tfloat xOffset = sin(time + y * 0.2) * 0.1;\n \tfloat yOffset = cos(time + x * 0.3) * 0.2;\n \n \t//float xOffset = 0.0;\n \t//float yOffset = 0.0;\n \n \t// Coordenadas finales\n \tfloat ux = u * 2.0 - 1.0 + xOffset;\n \tfloat vy = v * 2.0 - 1.0 + yOffset;\n \t\n \tvec2 xy = vec2(ux, vy) * 1.2;\n \n\tgl_Position = vec4(xy, 0.0, 1.0);\n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n \tgl_PointSize = 20.0;\n}" + }, "screenshotURL": "data/images/images-e0jw4gqptq32tgd3w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JnRaHZcXYv7WBhq5b/art.json b/art/JnRaHZcXYv7WBhq5b/art.json index 3e4afdec..6ddbc202 100644 --- a/art/JnRaHZcXYv7WBhq5b/art.json +++ b/art/JnRaHZcXYv7WBhq5b/art.json @@ -27,7 +27,19 @@ "name": "pulse", "private": false, "username": "gman", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 51.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS - offset;\\n float rPlus = pow(sin(time * 3. + -count * 0.05), 4.0);\\n float radius = count * 0.02 + rPlus * 0.2 + 0.0;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.00;\\n float oRadius = count * 0.00;\\n float oC = cos(orbitAngle + time * count * 0.01) * oRadius;\\n float oS = sin(orbitAngle + time * count * 0.01) * oRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n gl_PointSize = 2.0 + length(xy) * 20. * resolution.x / 1600.0;\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = mix(vec4(hsv2rgb(vec3(hue, 1.- rPlus, 1.)), 1), background, length(xy) - rPlus);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 51.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS - offset;\n float rPlus = pow(sin(time * 3. + -count * 0.05), 4.0);\n float radius = count * 0.02 + rPlus * 0.2 + 0.0;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.00;\n float oRadius = count * 0.00;\n float oC = cos(orbitAngle + time * count * 0.01) * oRadius;\n float oS = sin(orbitAngle + time * count * 0.01) * oRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n gl_PointSize = 2.0 + length(xy) * 20. * resolution.x / 1600.0;\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = mix(vec4(hsv2rgb(vec3(hue, 1.- rPlus, 1.)), 1), background, length(xy) - rPlus);\n}" + }, "screenshotURL": "data/images/images-wa0a1s6901sy21cud-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Jo7swMZWe4vAuJ9Xk/art.json b/art/Jo7swMZWe4vAuJ9Xk/art.json index 721a018b..bc959925 100644 --- a/art/Jo7swMZWe4vAuJ9Xk/art.json +++ b/art/Jo7swMZWe4vAuJ9Xk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_Position = vec4(1, 1, 1, 1);\\n v_color = vec4(1, 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(1, 1, 1, 1);\n v_color = vec4(1, 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-ucd9nssoh8vlmpz01-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JoWAeXNsfz23C8d8b/art.json b/art/JoWAeXNsfz23C8d8b/art.json index 05c238bf..e3a67102 100644 --- a/art/JoWAeXNsfz23C8d8b/art.json +++ b/art/JoWAeXNsfz23C8d8b/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":5081,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.47843137254901963,0.47843137254901963,0.47843137254901963,1],\"shader\":\"#define NUM 15.0\\n\\nvoid main() {\\n gl_PointSize = 74.6;\\n float a = mod(vertexId, NUM * 1.0);\\n float b = mod(floor(vertexId / NUM), NUM * 1.0);\\n float xax = a / NUM * 2.0 - 1.0;\\n float yax = b / NUM * 2.0 - 1.0;\\n gl_Position = vec4(xax, yax, 0, 1);\\n v_color = vec4(pow(texture2D(sound,vec2(xax,yax)).a,8.0));\\n}\"}", + "settings": { + "num": 5081, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.47843137254901963, + 0.47843137254901963, + 0.47843137254901963, + 1 + ], + "shader": "#define NUM 15.0\n\nvoid main() {\n gl_PointSize = 74.6;\n float a = mod(vertexId, NUM * 1.0);\n float b = mod(floor(vertexId / NUM), NUM * 1.0);\n float xax = a / NUM * 2.0 - 1.0;\n float yax = b / NUM * 2.0 - 1.0;\n gl_Position = vec4(xax, yax, 0, 1);\n v_color = vec4(pow(texture2D(sound,vec2(xax,yax)).a,8.0));\n}" + }, "screenshotURL": "data/images/images-6qzsf4xfvsa9wh594-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JokykDr3Qve8hrLQR/art.json b/art/JokykDr3Qve8hrLQR/art.json index ae1ee99a..27f50244 100644 --- a/art/JokykDr3Qve8hrLQR/art.json +++ b/art/JokykDr3Qve8hrLQR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":19145,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/habut/children-of-the-doc-bionic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.2, 0.8, p1m1(sin(goop(circleId) + time * 0.0)));\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n \\n float snd = texture2D(sound, vec2(cu * 0.01, 0.)).a;\\n\\n vec3 offset = vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\\n offset.x += m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\\n offset.y += goop(circleId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= rotZ(snd * PI);\\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId)) + pow(snd, 5.0) * 0. + sliceId * 0.01);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 0.6;\\n float sat = 0.;//1. -pow(snd, 5.);\\n float val = mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * 1.05;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 19145, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/habut/children-of-the-doc-bionic", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.2, 0.8, p1m1(sin(goop(circleId) + time * 0.0)));\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n \n float snd = texture2D(sound, vec2(cu * 0.01, 0.)).a;\n\n vec3 offset = vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\n offset.x += m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\n offset.y += goop(circleId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= rotZ(snd * PI);\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId)) + pow(snd, 5.0) * 0. + sliceId * 0.01);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = 0.6;\n float sat = 0.;//1. -pow(snd, 5.);\n float val = mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * 1.05;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-6j7jzjty2zekebsu4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JovmnYPALtpYmhbx3/art.json b/art/JovmnYPALtpYmhbx3/art.json index f95c3cd7..31217cb8 100644 --- a/art/JovmnYPALtpYmhbx3/art.json +++ b/art/JovmnYPALtpYmhbx3/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16135,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 200.4\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 50.0 - v * 3.2 * v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.50 + v;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 7.5) / soundRes.y + 100.4;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = 5.5;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16135, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 200.4\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 50.0 - v * 3.2 * v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.50 + v;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 7.5) / soundRes.y + 100.4;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = 5.5;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-6box2rbjfvtabnp5h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JpNPSRbwfogR3zWkh/art.json b/art/JpNPSRbwfogR3zWkh/art.json index 0621efd6..4a14c717 100644 --- a/art/JpNPSRbwfogR3zWkh/art.json +++ b/art/JpNPSRbwfogR3zWkh/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":50134,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 -1.//KParameter 0.>>-10.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (333. *(P2*3.5))*10.;\\n float numQuads = floor( vertexCount/8.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\\n float vy = mod(floor(vertexId / 3.) + floor(vertexId / 3.), 1.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) -(mouse.y * r);\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, mouse*((qv * PI )));\\n \\n float tm = time * 1.2 -mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 3.) + (mouse.x *13.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0.6);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 0.6);\\n gl_PointSize = 1.;\\n\\n float hue = quadId / 0.66663;\\n float sat = quadId *3.3;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 3.54444);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 50134, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 -1.//KParameter 0.>>-10.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (333. *(P2*3.5))*10.;\n float numQuads = floor( vertexCount/8.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\n float vy = mod(floor(vertexId / 3.) + floor(vertexId / 3.), 1.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) -(mouse.y * r);\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, mouse*((qv * PI )));\n \n float tm = time * 1.2 -mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 3.) + (mouse.x *13.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0.6);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 0.6);\n gl_PointSize = 1.;\n\n float hue = quadId / 0.66663;\n float sat = quadId *3.3;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 3.54444);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-8h80f4nwfb1u4qrlh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Jpg8BhcLNg3DjTpT5/art.json b/art/Jpg8BhcLNg3DjTpT5/art.json index 16272580..4fcbd080 100644 --- a/art/Jpg8BhcLNg3DjTpT5/art.json +++ b/art/Jpg8BhcLNg3DjTpT5/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Circles from Triangles\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0, \\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale (float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\n\\nvoid main() {\\n float numCircleSegnemts = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegnemts);\\n \\n float numPointsPerCircle = numCircleSegnemts * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(av * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\\n float sat = 1.;//(0.5, 1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 4.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.66;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Circles from Triangles\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0, \n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale (float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\n\nvoid main() {\n float numCircleSegnemts = 6.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegnemts);\n \n float numPointsPerCircle = numCircleSegnemts * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(av * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\n float sat = 1.;//(0.5, 1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 4.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.66;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-5ej9nh0pf0f45jj9f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Jr5nXxcZNwvx5K4Bd/art.json b/art/Jr5nXxcZNwvx5K4Bd/art.json index d20aa6ed..b7b9adc2 100644 --- a/art/Jr5nXxcZNwvx5K4Bd/art.json +++ b/art/Jr5nXxcZNwvx5K4Bd/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":11263,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 11263, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-rq4luf4fnnlhz9zcu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Jrb5gxuyHzqMNukkg/art.json b/art/Jrb5gxuyHzqMNukkg/art.json index 0938eab0..ec97b1d3 100644 --- a/art/Jrb5gxuyHzqMNukkg/art.json +++ b/art/Jrb5gxuyHzqMNukkg/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 36.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 1192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 132.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 36.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 1192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 132.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-ufvkizpki0667ghu2-thumbnail.jpg", "views": { "$numberInt": "69" diff --git a/art/JsEv9AaC54NF6cY8Q/art.json b/art/JsEv9AaC54NF6cY8Q/art.json index 8a9d0bf8..2ab5d1ac 100644 --- a/art/JsEv9AaC54NF6cY8Q/art.json +++ b/art/JsEv9AaC54NF6cY8Q/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "round", "username": "gman", - "settings": "{\"num\":6224,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jamie-berry/jamie-berry-sweet-rascal-original-mix-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define NUM_SEGMENTS 64.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 32.0\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.1 + 0.1;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n \\n gl_PointSize = min(32.0, 3.0 + pow((snd + 0.2) * 1.5, 10.0) * mix(3.0, 3.0, v)) * resolution.x / 1600.;\\n\\n float x = u * PI * 2.0 + snd - 0.5 + sin(count + time * 0.00000) * 0.005;\\n float y = v - pow(snd, 1.5) * 0.4 + 0.5;\\n float c = cos(x);\\n float s = sin(x);\\n vec2 xy = vec2(c * y, s * y);\\n gl_Position = vec4(xy, length(xy) * 0.5, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(xy) * 0.1);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 6224, + "mode": "POINTS", + "sound": "https://soundcloud.com/jamie-berry/jamie-berry-sweet-rascal-original-mix-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 64.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 32.0\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.1 + 0.1;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n \n gl_PointSize = min(32.0, 3.0 + pow((snd + 0.2) * 1.5, 10.0) * mix(3.0, 3.0, v)) * resolution.x / 1600.;\n\n float x = u * PI * 2.0 + snd - 0.5 + sin(count + time * 0.00000) * 0.005;\n float y = v - pow(snd, 1.5) * 0.4 + 0.5;\n float c = cos(x);\n float s = sin(x);\n vec2 xy = vec2(c * y, s * y);\n gl_Position = vec4(xy, length(xy) * 0.5, 1);\n\n float hue = u;\n float sat = invV;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(xy) * 0.1);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotDataId": "3EH8QEmsqvefvJDLK", "views": { "$numberInt": "518" diff --git a/art/JscBDhcAFypHdaMCm/art.json b/art/JscBDhcAFypHdaMCm/art.json index 7b2ad243..177be960 100644 --- a/art/JscBDhcAFypHdaMCm/art.json +++ b/art/JscBDhcAFypHdaMCm/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":12000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n\\n\\n// mouse axis x => contorl section compelxity\\n// mouse axis y => controe torus complexity\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n\\nvoid main()\\n{\\n \\tgl_PointSize = 3.;\\n \\n\\tfloat pi = radians(180.);\\n\\tfloat pi2 = radians(360.);\\n\\t\\n \\tvec2 mo = 0.5 - mouse;\\n \\n\\t// vars\\n\\t// count point : 6 * quadsPerPolygon * countPolygon => here 3600\\n\\tfloat quadsPerPolygon = clamp(floor(10. * (mo.x*0.5+0.5)), 3., 10.);\\n\\tfloat countPolygon = clamp(floor(200. * (mo.y*0.5+0.5)), 3., 200.);\\n\\tfloat radius = 20.;\\n\\tfloat thickNess = 5.;\\n\\tfloat zoom = 2.;\\n\\t\\n \\tfloat countMax = 6. * quadsPerPolygon * countPolygon;\\n \\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\tfloat asp = pi * 2.0 / quadsPerPolygon; // angle step polygon\\n\\tfloat ap0 = asp * indexQuad; // angle polygon 0\\n\\tfloat ap1 = asp * (indexQuad + 1.); // angle polygon 0\\n\\t\\n\\tfloat indexPolygon = floor(indexQuad / quadsPerPolygon);\\n\\tfloat ast = pi * 2.0 / countPolygon; // angle step torus\\n\\tfloat at0 = ast * indexPolygon; // angle torus 0\\n\\tfloat at1 = ast * (indexPolygon + 1.); // angle torus 1\\n\\t\\n \\tvec2 st = vec2(0);\\n\\t\\n \\t// triangle 1\\n\\tif (index == 0.) st = vec2(ap0, at0);\\n\\tif (index == 1.) st = vec2(ap1, at0);\\n\\tif (index == 2.) st = vec2(ap1, at1);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) st = vec2(ap0, at0);\\n\\tif (index == 4.) st = vec2(ap1, at1);\\n\\tif (index == 5.) st = vec2(ap0, at1);\\n\\t\\n \\tvec3 p = vec3(cos(st.x),st.y,sin(st.x));\\n\\t\\n \\t// twist\\n\\tfloat ap = st.y - cos(st.y) + time;\\n\\t\\t\\t\\n \\t// polygon\\n\\tp.xz *= thickNess;\\n\\tp.xz *= mat2(cos(ap), sin(ap), -sin(ap), cos(ap));\\n\\t\\n\\t// torus\\n\\tp.x += radius;\\n\\tfloat at = p.y; p.y = 0.0;\\n\\tp.xy *= mat2(cos(at), sin(at), -sin(at), cos(at));\\n\\t\\n\\t// camera\\n\\tfloat ca = 0.5;//time * 0.1;\\n\\tfloat cd = 100.;\\n\\tvec3 eye = vec3(sin(ca), 0., cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n\\tmat4 camera = persp(45. * pi / 180., resolution.x / resolution.y, 0.1, 10000.) * \\n cameraLookAt(eye, target, up);\\n \\n \\t// vertex position\\n \\tif (vertexId < countMax)\\n {\\n \\t\\tgl_Position = camera * vec4(p,1);\\n }\\n \\telse\\n \\t{\\n \\tgl_Position = vec4(0,0,0,0);\\n \\t}\\n \\n\\t// face color\\n\\tindexQuad = mod(indexQuad, quadsPerPolygon);\\n\\tv_color = cos(vec4(10,20,30,1) + indexQuad);\\n\\tv_color = mix(v_color, vec4(normalize(p) * 0.5 + 0.5, 1), .5);\\n \\tv_color.a = 1.0;\\n}\\n\\n//////////////////////////////////////////////////////////////////////////\\n\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 12000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n\n\n// mouse axis x => contorl section compelxity\n// mouse axis y => controe torus complexity\n\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n\nvoid main()\n{\n \tgl_PointSize = 3.;\n \n\tfloat pi = radians(180.);\n\tfloat pi2 = radians(360.);\n\t\n \tvec2 mo = 0.5 - mouse;\n \n\t// vars\n\t// count point : 6 * quadsPerPolygon * countPolygon => here 3600\n\tfloat quadsPerPolygon = clamp(floor(10. * (mo.x*0.5+0.5)), 3., 10.);\n\tfloat countPolygon = clamp(floor(200. * (mo.y*0.5+0.5)), 3., 200.);\n\tfloat radius = 20.;\n\tfloat thickNess = 5.;\n\tfloat zoom = 2.;\n\t\n \tfloat countMax = 6. * quadsPerPolygon * countPolygon;\n \n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\tfloat asp = pi * 2.0 / quadsPerPolygon; // angle step polygon\n\tfloat ap0 = asp * indexQuad; // angle polygon 0\n\tfloat ap1 = asp * (indexQuad + 1.); // angle polygon 0\n\t\n\tfloat indexPolygon = floor(indexQuad / quadsPerPolygon);\n\tfloat ast = pi * 2.0 / countPolygon; // angle step torus\n\tfloat at0 = ast * indexPolygon; // angle torus 0\n\tfloat at1 = ast * (indexPolygon + 1.); // angle torus 1\n\t\n \tvec2 st = vec2(0);\n\t\n \t// triangle 1\n\tif (index == 0.) st = vec2(ap0, at0);\n\tif (index == 1.) st = vec2(ap1, at0);\n\tif (index == 2.) st = vec2(ap1, at1);\n\t\n\t// triangle 2\n\tif (index == 3.) st = vec2(ap0, at0);\n\tif (index == 4.) st = vec2(ap1, at1);\n\tif (index == 5.) st = vec2(ap0, at1);\n\t\n \tvec3 p = vec3(cos(st.x),st.y,sin(st.x));\n\t\n \t// twist\n\tfloat ap = st.y - cos(st.y) + time;\n\t\t\t\n \t// polygon\n\tp.xz *= thickNess;\n\tp.xz *= mat2(cos(ap), sin(ap), -sin(ap), cos(ap));\n\t\n\t// torus\n\tp.x += radius;\n\tfloat at = p.y; p.y = 0.0;\n\tp.xy *= mat2(cos(at), sin(at), -sin(at), cos(at));\n\t\n\t// camera\n\tfloat ca = 0.5;//time * 0.1;\n\tfloat cd = 100.;\n\tvec3 eye = vec3(sin(ca), 0., cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n\tmat4 camera = persp(45. * pi / 180., resolution.x / resolution.y, 0.1, 10000.) * \n cameraLookAt(eye, target, up);\n \n \t// vertex position\n \tif (vertexId < countMax)\n {\n \t\tgl_Position = camera * vec4(p,1);\n }\n \telse\n \t{\n \tgl_Position = vec4(0,0,0,0);\n \t}\n \n\t// face color\n\tindexQuad = mod(indexQuad, quadsPerPolygon);\n\tv_color = cos(vec4(10,20,30,1) + indexQuad);\n\tv_color = mix(v_color, vec4(normalize(p) * 0.5 + 0.5, 1), .5);\n \tv_color.a = 1.0;\n}\n\n//////////////////////////////////////////////////////////////////////////\n\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-yr524hzhakik4qllw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JtvN2gq9PiiSdwvHG/art.json b/art/JtvN2gq9PiiSdwvHG/art.json index 5ac7ecfd..2f3381e7 100644 --- a/art/JtvN2gq9PiiSdwvHG/art.json +++ b/art/JtvN2gq9PiiSdwvHG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "teraspora", "avatarUrl": "https://secure.gravatar.com/avatar/ee48754754126a1abee9056ee99b25c4?default=retro&size=200", - "settings": "{\"num\":1024,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// My first vertexshaderart code\\n// John Lynch, 11-09-2018\\n\\nconst float TWO_PI = 6.28318530716;\\nfloat scaleFactor = 0.5;\\n\\nvec2 rotate(vec2 v, float phi) {\\n return vec2(v.x * cos(phi) - v.y * sin(phi),\\n v.x * sin(phi) + v.y * cos(phi));\\n}\\n\\nbool isOdd(float n) {\\n return mod(n, 2.) > 0.5;\\n}\\n\\nvoid main() {\\n float span = floor(sqrt(vertexCount));\\n \\n float u = mod(vertexId, span) / (span - 1.);\\n float v = floor(vertexId / span) / (span - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float yDelta = (8. * sin(time / 4. * ux + vy ) + sin(time / 2.) + sin(time) + 3. * sin(time / 2.)) / 20.;\\n float xDelta = yDelta * 1.8;\\n if (isOdd(vertexId)) {\\n yDelta = -yDelta + 2. * mouse.y ;\\n }\\n vec2 xy = vec2(ux + xDelta, vy + yDelta * (ux / resolution.x) * vertexId) * scaleFactor;\\n xy = rotate(xy, sin(time / 20.) * TWO_PI * mouse.x / 4.);\\n gl_Position = vec4(xy, 0, 1);\\n gl_PointSize = 10.;\\n gl_PointSize += 1. / span;\\n gl_PointSize *= 0.1 * resolution.x * resolution.y / 262144.;\\n float k = vertexId / vertexCount;\\n v_color = vec4(k * 0.8, 0.2, 0.6 - k * mod(time, 10.) / 2., 1.);\\n}\\n\\n\"}", + "settings": { + "num": 1024, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// My first vertexshaderart code\n// John Lynch, 11-09-2018\n\nconst float TWO_PI = 6.28318530716;\nfloat scaleFactor = 0.5;\n\nvec2 rotate(vec2 v, float phi) {\n return vec2(v.x * cos(phi) - v.y * sin(phi),\n v.x * sin(phi) + v.y * cos(phi));\n}\n\nbool isOdd(float n) {\n return mod(n, 2.) > 0.5;\n}\n\nvoid main() {\n float span = floor(sqrt(vertexCount));\n \n float u = mod(vertexId, span) / (span - 1.);\n float v = floor(vertexId / span) / (span - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float yDelta = (8. * sin(time / 4. * ux + vy ) + sin(time / 2.) + sin(time) + 3. * sin(time / 2.)) / 20.;\n float xDelta = yDelta * 1.8;\n if (isOdd(vertexId)) {\n yDelta = -yDelta + 2. * mouse.y ;\n }\n vec2 xy = vec2(ux + xDelta, vy + yDelta * (ux / resolution.x) * vertexId) * scaleFactor;\n xy = rotate(xy, sin(time / 20.) * TWO_PI * mouse.x / 4.);\n gl_Position = vec4(xy, 0, 1);\n gl_PointSize = 10.;\n gl_PointSize += 1. / span;\n gl_PointSize *= 0.1 * resolution.x * resolution.y / 262144.;\n float k = vertexId / vertexCount;\n v_color = vec4(k * 0.8, 0.2, 0.6 - k * mod(time, 10.) / 2., 1.);\n}\n\n" + }, "screenshotURL": "data/images/images-on9qz63amyzwgmlgu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JvvtkuvxB6iKmfBQa/art.json b/art/JvvtkuvxB6iKmfBQa/art.json index 586002d3..f38637f9 100644 --- a/art/JvvtkuvxB6iKmfBQa/art.json +++ b/art/JvvtkuvxB6iKmfBQa/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "seb", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxbz60ciBcSyCj3Dt3II92yJebQyNYi3_hc9mMxwSg=s96-c", - "settings": "{\"num\":3907,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define COUNT_PER_LINE 100.\\n\\nvoid main() {\\n\\n gl_PointSize=2.;\\n vec2 baseP = vec2(mod(vertexId,COUNT_PER_LINE)*.2+.1*sin(vertexId*.2), \\n floor(vertexId/COUNT_PER_LINE))*.05;\\n vec2 hairId = vec2(mod(vertexId,COUNT_PER_LINE), \\n floor(vertexId/COUNT_PER_LINE));\\n vec2 offse = vec2(.02+0.05*sin(vertexId), 0.5*sin(vertexId*.2+time)*.05+.1);\\n vec2 position = baseP + mod(vertexId, 2.0)*offse;\\ngl_Position = vec4((position-.5)*2., 0., 1);\\n\\tvec3 rgb = mix(vec3(0.816,0.165,0.996), \\n vec3(0.180,0.494,1.000)*.3, \\n sin(vertexId)*.5+.5);\\n\\trgb = mix(vec3(0.), rgb, mod(vertexId, 2.0));\\n v_color = vec4(rgb,1.);\\n}\"}", + "settings": { + "num": 3907, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define COUNT_PER_LINE 100.\n\nvoid main() {\n\n gl_PointSize=2.;\n vec2 baseP = vec2(mod(vertexId,COUNT_PER_LINE)*.2+.1*sin(vertexId*.2), \n floor(vertexId/COUNT_PER_LINE))*.05;\n vec2 hairId = vec2(mod(vertexId,COUNT_PER_LINE), \n floor(vertexId/COUNT_PER_LINE));\n vec2 offse = vec2(.02+0.05*sin(vertexId), 0.5*sin(vertexId*.2+time)*.05+.1);\n vec2 position = baseP + mod(vertexId, 2.0)*offse;\ngl_Position = vec4((position-.5)*2., 0., 1);\n\tvec3 rgb = mix(vec3(0.816,0.165,0.996), \n vec3(0.180,0.494,1.000)*.3, \n sin(vertexId)*.5+.5);\n\trgb = mix(vec3(0.), rgb, mod(vertexId, 2.0));\n v_color = vec4(rgb,1.);\n}" + }, "screenshotURL": "data/images/images-994wwzya5osurulq2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/JwR5ZvmH2Nkcr3Rnx/art.json b/art/JwR5ZvmH2Nkcr3Rnx/art.json index 48507ecd..4cc1a16f 100644 --- a/art/JwR5ZvmH2Nkcr3Rnx/art.json +++ b/art/JwR5ZvmH2Nkcr3Rnx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nvec4 qmult(vec4 a, vec4 b) {\\n\\tvec4 r;\\n\\tr.x = a.x * b.x - dot(a.yzw, b.yzw);\\n\\tr.yzw = a.x * b.yzw + b.x * a.yzw + cross(a.yzw, b.yzw);\\n\\treturn r;\\n}\\n\\nvoid julia(inout vec4 z, inout vec4 dz, in vec4 c) {\\n\\tfor(int i = 0; i < 10; i++) {\\n\\t\\tdz = 2.0 * qmult(z, dz);\\n\\t\\tz = qmult(z, z) + c;\\n\\t\\t\\n\\t\\tif(dot(z, z) > 3.0) {\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t}\\n}\\n\\nvec3 transform(vec3 p) {\\n\\tfloat t = time * .03;\\n\\tp.xy *= mat2(cos(t), sin(t), -sin(t), cos(t));\\n\\tt = time * .07;\\n\\tp.zx *= mat2(cos(t), sin(t), -sin(t), cos(t));\\n\\treturn p;\\n}\\n\\nfloat dist(in vec3 p, float _factor) {\\n\\tp = transform(p);\\n\\tvec4 z = vec4(p, 0.0);\\n\\tvec4 dz = vec4(1.0, 0.0, 0.0, 0.0);\\n\\t\\n\\tvec2 m = vec2(cos(_factor),sin(_factor));//0.0;//mouse * 2.0 - 1.0;\\n\\tvec4 c = vec4(m.x, m.y, 0.0, 0.0);\\n\\t\\t\\n\\tjulia(z, dz, c);\\n\\t\\t\\n\\tfloat lz = length(z);\\n\\tfloat d = 0.5 * log(lz) * lz / length(dz) ; \\n\\t\\n\\treturn d;\\n}\\n\\n\\nvoid main ()\\n{\\n \\n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float ratioXforY = resolution.y/resolution.x;\\n float ratioXforX = resolution.x/resolution.y;\\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalResolution = vec2(sqrt(ratioXforX * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n //float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n //float ratio = resolution.y/numAcrossDown;\\n \\n //float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n float x = mod(finalVertexId, finalResolution.x);\\n float y = floor(finalVertexId / finalResolution.y);\\n \\n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\\n float v = (y / finalResolution.y);\\n \\n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\\n \\n float vy = ( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n vec2 fragCoord = vec2(x, y);\\n //apply fragment logic\\n\\n vec2 st = (fragCoord.xy * 2.0 - finalResolution) / finalResolution.y;\\n\\t\\n\\tvec3 ori = vec3(0.0, 0.0, 2.0);\\n\\tvec3 tar = vec3(0.0, 0.0, 0.0);\\n\\tvec3 cz = normalize(tar - ori);\\n\\tvec3 cx = cross(cz, vec3(0.0, 1.0, 0.0));\\n\\tvec3 cy = cross(cx, cz);\\n\\tvec3 dir = normalize(cx * st.x + cy * st.y + cz * 1.0);\\n\\t\\n\\tfloat t = 0.0;\\n\\tint steps = 0;\\n\\tfor (int i = 0; i < 48; i++) {\\n\\t\\tsteps = i;\\n\\t\\tfloat d = dist( ori + t * dir, snd*10.);\\n\\t\\tif (d < 0.001 || t > 27.0) break;\\n\\t\\tt += d;\\n\\t}\\n\\t\\n\\tvec3 c = vec3(1.0);\\n\\tif (t < 10.0) {\\n\\t\\tc = vec3(vec3(1.0 - float(steps) / 64.0));\\n\\t}\\n\\t\\n\\t//gl_FragColor = vec4(c, 1.0);\\n //end of fragment logic\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 1.;(resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(c, 1.0);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nvec4 qmult(vec4 a, vec4 b) {\n\tvec4 r;\n\tr.x = a.x * b.x - dot(a.yzw, b.yzw);\n\tr.yzw = a.x * b.yzw + b.x * a.yzw + cross(a.yzw, b.yzw);\n\treturn r;\n}\n\nvoid julia(inout vec4 z, inout vec4 dz, in vec4 c) {\n\tfor(int i = 0; i < 10; i++) {\n\t\tdz = 2.0 * qmult(z, dz);\n\t\tz = qmult(z, z) + c;\n\t\t\n\t\tif(dot(z, z) > 3.0) {\n\t\t\tbreak;\n\t\t}\n\t}\n}\n\nvec3 transform(vec3 p) {\n\tfloat t = time * .03;\n\tp.xy *= mat2(cos(t), sin(t), -sin(t), cos(t));\n\tt = time * .07;\n\tp.zx *= mat2(cos(t), sin(t), -sin(t), cos(t));\n\treturn p;\n}\n\nfloat dist(in vec3 p, float _factor) {\n\tp = transform(p);\n\tvec4 z = vec4(p, 0.0);\n\tvec4 dz = vec4(1.0, 0.0, 0.0, 0.0);\n\t\n\tvec2 m = vec2(cos(_factor),sin(_factor));//0.0;//mouse * 2.0 - 1.0;\n\tvec4 c = vec4(m.x, m.y, 0.0, 0.0);\n\t\t\n\tjulia(z, dz, c);\n\t\t\n\tfloat lz = length(z);\n\tfloat d = 0.5 * log(lz) * lz / length(dz) ; \n\t\n\treturn d;\n}\n\n\nvoid main ()\n{\n \n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float ratioXforY = resolution.y/resolution.x;\n float ratioXforX = resolution.x/resolution.y;\n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalResolution = vec2(sqrt(ratioXforX * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n //float numAcrossDown = floor(sqrt(finalVertexCount));\n \n //float ratio = resolution.y/numAcrossDown;\n \n //float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n float x = mod(finalVertexId, finalResolution.x);\n float y = floor(finalVertexId / finalResolution.y);\n \n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\n float v = (y / finalResolution.y);\n \n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\n \n float vy = ( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n vec2 fragCoord = vec2(x, y);\n //apply fragment logic\n\n vec2 st = (fragCoord.xy * 2.0 - finalResolution) / finalResolution.y;\n\t\n\tvec3 ori = vec3(0.0, 0.0, 2.0);\n\tvec3 tar = vec3(0.0, 0.0, 0.0);\n\tvec3 cz = normalize(tar - ori);\n\tvec3 cx = cross(cz, vec3(0.0, 1.0, 0.0));\n\tvec3 cy = cross(cx, cz);\n\tvec3 dir = normalize(cx * st.x + cy * st.y + cz * 1.0);\n\t\n\tfloat t = 0.0;\n\tint steps = 0;\n\tfor (int i = 0; i < 48; i++) {\n\t\tsteps = i;\n\t\tfloat d = dist( ori + t * dir, snd*10.);\n\t\tif (d < 0.001 || t > 27.0) break;\n\t\tt += d;\n\t}\n\t\n\tvec3 c = vec3(1.0);\n\tif (t < 10.0) {\n\t\tc = vec3(vec3(1.0 - float(steps) / 64.0));\n\t}\n\t\n\t//gl_FragColor = vec4(c, 1.0);\n //end of fragment logic\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 1.;(resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(c, 1.0);;\n \n\n}" + }, "screenshotURL": "data/images/images-cm1quyvl31lq29x3l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/JwXL4sBud9x3F6iKY/art.json b/art/JwXL4sBud9x3F6iKY/art.json index 9c416a0d..4c070af6 100644 --- a/art/JwXL4sBud9x3F6iKY/art.json +++ b/art/JwXL4sBud9x3F6iKY/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":13199,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thesoftmoon/stupid-child?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.11372549019607843,0.32941176470588235,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float xoff = sin(time + y * 0.1) * 0.1;\\n float yoff = sin(time + x * 0.1) * 0.1;\\n float soff = sin(time + x) * -0.2 * 10.;\\n\\n \\n float u = x / (across - 1.) + xoff;\\n float v = y / (across - 1.) + yoff;\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float scale = 0.9;\\n vec2 xy = vec2(ux, vy) * scale;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600. * soff;\\n \\n v_color = vec4(0., 1., 0., 1.);\\n}\"}", + "settings": { + "num": 13199, + "mode": "POINTS", + "sound": "https://soundcloud.com/thesoftmoon/stupid-child?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.11372549019607843, + 0.32941176470588235, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float xoff = sin(time + y * 0.1) * 0.1;\n float yoff = sin(time + x * 0.1) * 0.1;\n float soff = sin(time + x) * -0.2 * 10.;\n\n \n float u = x / (across - 1.) + xoff;\n float v = y / (across - 1.) + yoff;\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float scale = 0.9;\n vec2 xy = vec2(ux, vy) * scale;\n \n gl_Position = vec4(xy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600. * soff;\n \n v_color = vec4(0., 1., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-gcbk7fywrl1pfs034-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Jy4jz9wJ54XyG6hFF/art.json b/art/Jy4jz9wJ54XyG6hFF/art.json index 4152aba2..41cff23e 100644 --- a/art/Jy4jz9wJ54XyG6hFF/art.json +++ b/art/Jy4jz9wJ54XyG6hFF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":1003,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - Motion\\n// spring 2022\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = floor(x) / (across - 1.);\\n float v = floor(y) / (across - 1.);\\n\\n float xoff = sin(time + floor(y) * 0.01);\\n float yoff = cos(time + floor(x) * 0.01);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.5;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * u * v) * 10.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n //gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(v, v, v + 0.2, 1);\\n}\"}", + "settings": { + "num": 1003, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - Motion\n// spring 2022\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = floor(x) / (across - 1.);\n float v = floor(y) / (across - 1.);\n\n float xoff = sin(time + floor(y) * 0.01);\n float yoff = cos(time + floor(x) * 0.01);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.5;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * u * v) * 10.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n //gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(v, v, v + 0.2, 1);\n}" + }, "screenshotURL": "data/images/images-js4wgshp94ik4pt46-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/K2GTMMGc83q5GQ6Sa/art.json b/art/K2GTMMGc83q5GQ6Sa/art.json index cce0e4f0..0afb0233 100644 --- a/art/K2GTMMGc83q5GQ6Sa/art.json +++ b/art/K2GTMMGc83q5GQ6Sa/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#40190.0\\n//Another experiment of 'vertexification' of a fragment shader \\n\\n#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader NICE\\n//NICE\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\tif(v>0.5)\\n v = 1.- v;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 1.3;\\n float tm = 1.5 *time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\\n //vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 2.;///abs(gl_Position.z);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#40190.0\n//Another experiment of 'vertexification' of a fragment shader \n\n#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader NICE\n//NICE\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\tif(v>0.5)\n v = 1.- v;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 1.3;\n float tm = 1.5 *time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\n //vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 2.;///abs(gl_Position.z);\n \n //v_color = vec4(1.,1.,1.,1.);\n}\n\n" + }, "screenshotURL": "data/images/images-zpi16uz8syqpir3d8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/K2eiDz74g3k842g37/art.json b/art/K2eiDz74g3k842g37/art.json index 4d1aa43d..b99efc43 100644 --- a/art/K2eiDz74g3k842g37/art.json +++ b/art/K2eiDz74g3k842g37/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nvec3 triangle(float idx) // vec2:p / float triangleIndex\\n{\\n\\tfloat triangleIndex = floor(idx / 6.);\\n\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 p = vec2(0);\\n\\t\\n\\tif (index == 0.) p = vec2(0,0);\\n\\tif (index == 1.) p = vec2(1,0);\\n\\tif (index == 2.) p = vec2(1,1);\\n\\t\\n\\tif (index == 3.) p = vec2(0,0);\\n\\tif (index == 4.) p = vec2(1,1);\\n\\tif (index == 5.) p = vec2(0,1);\\n\\t\\n\\treturn vec3(p, triangleIndex);\\n}\\n\\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\\n{\\n\\tvec4 res;\\n\\tvec3 pi = triangle(idx);\\n\\t\\n\\tpi.y += floor(pi.z / countQuadsX);\\n pi.x += mod(pi.z, countQuadsX);\\n \\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadsX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\t\\n\\tif (centered == true)\\n\\t{\\n\\t\\tpi.x -= nx * 0.5;\\n\\t\\tpi.y -= ny * 0.5;\\n\\t}\\n\\t\\n\\treturn vec4(pi.xy, nx, ny);\\n}\\n\\n//https://www.shadertoy.com/view/ltK3WD\\nvec4 voronoi(vec2 g )\\n{\\n\\tvec4 f = vec4(9);\\n\\tvec2 p = g /= 200. ; f.x=9.;\\n \\n\\tg += time;\\n\\t\\n float t = time * 0.1;\\n \\n for(int x=-2;x<=2;x++)\\n for(int y=-2;y<=2;y++)\\n {\\t\\n p = vec2(x,y);\\n\\t\\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\\n\\t\\t//f.y = max(abs(p.x), abs(p.y));\\n\\t\\t//f.y = dot(p,p);\\n\\t\\tif (f.y < f.x)\\n {\\n f.x = f.y;\\n f.zw = p;\\n }\\n }\\n\\t\\n vec3 n = vec3(0);\\n \\n if ( f.x == -f.z*.866 - f.w*.5) \\tn = vec3(1,0,0);\\n\\tif ( f.x == f.z*.866 - f.w*.5) \\t\\tn = vec3(0,1,0);\\n\\tif ( f.x == f.w) \\t\\t\\t\\t\\tn = vec3(0,0,1);\\n\\t\\n return vec4(f.x, n);\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 2.;\\n\\t\\n \\tvec3 uSlider = vec3(50, 5, 1.2);\\n \\n\\tfloat thickNess = uSlider.x;\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat sizeEdge = floor(sqrt(countMax));\\n\\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\\n\\t\\n\\tvec4 voro = voronoi(p.xy * uSlider.y);\\n\\t\\n\\tfloat d = voro.x;\\n\\tvec3 n = voro.yzw;\\n\\t\\n\\tv_color = vec4(n*d,1);\\n\\t\\n\\tmat4 camera = ident();\\n\\t\\n\\tfloat ca = time * 0.1;\\n\\tfloat cd = 160.;\\n\\tfloat ce = PI * mouse.y;\\n\\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(1, 1, 0);\\n \\n\\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nvec3 triangle(float idx) // vec2:p / float triangleIndex\n{\n\tfloat triangleIndex = floor(idx / 6.);\n\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 p = vec2(0);\n\t\n\tif (index == 0.) p = vec2(0,0);\n\tif (index == 1.) p = vec2(1,0);\n\tif (index == 2.) p = vec2(1,1);\n\t\n\tif (index == 3.) p = vec2(0,0);\n\tif (index == 4.) p = vec2(1,1);\n\tif (index == 5.) p = vec2(0,1);\n\t\n\treturn vec3(p, triangleIndex);\n}\n\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\n{\n\tvec4 res;\n\tvec3 pi = triangle(idx);\n\t\n\tpi.y += floor(pi.z / countQuadsX);\n pi.x += mod(pi.z, countQuadsX);\n \n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadsX;\n\tfloat ny = floor(countQuads / nx);\n\t\t\n\tif (centered == true)\n\t{\n\t\tpi.x -= nx * 0.5;\n\t\tpi.y -= ny * 0.5;\n\t}\n\t\n\treturn vec4(pi.xy, nx, ny);\n}\n\n//https://www.shadertoy.com/view/ltK3WD\nvec4 voronoi(vec2 g )\n{\n\tvec4 f = vec4(9);\n\tvec2 p = g /= 200. ; f.x=9.;\n \n\tg += time;\n\t\n float t = time * 0.1;\n \n for(int x=-2;x<=2;x++)\n for(int y=-2;y<=2;y++)\n {\t\n p = vec2(x,y);\n\t\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\n\t\t//f.y = max(abs(p.x), abs(p.y));\n\t\t//f.y = dot(p,p);\n\t\tif (f.y < f.x)\n {\n f.x = f.y;\n f.zw = p;\n }\n }\n\t\n vec3 n = vec3(0);\n \n if ( f.x == -f.z*.866 - f.w*.5) \tn = vec3(1,0,0);\n\tif ( f.x == f.z*.866 - f.w*.5) \t\tn = vec3(0,1,0);\n\tif ( f.x == f.w) \t\t\t\t\tn = vec3(0,0,1);\n\t\n return vec4(f.x, n);\n}\n\nvoid main()\n{\n\tgl_PointSize = 2.;\n\t\n \tvec3 uSlider = vec3(50, 5, 1.2);\n \n\tfloat thickNess = uSlider.x;\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat sizeEdge = floor(sqrt(countMax));\n\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\n\t\n\tvec4 voro = voronoi(p.xy * uSlider.y);\n\t\n\tfloat d = voro.x;\n\tvec3 n = voro.yzw;\n\t\n\tv_color = vec4(n*d,1);\n\t\n\tmat4 camera = ident();\n\t\n\tfloat ca = time * 0.1;\n\tfloat cd = 160.;\n\tfloat ce = PI * mouse.y;\n\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(1, 1, 0);\n \n\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\n}" + }, "screenshotURL": "data/images/images-nm46pishh23i3ou86-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/K3dPqehYPJMnZyDBD/art.json b/art/K3dPqehYPJMnZyDBD/art.json index f9417c07..4cece6ad 100644 --- a/art/K3dPqehYPJMnZyDBD/art.json +++ b/art/K3dPqehYPJMnZyDBD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "danyalillo", "avatarUrl": "https://lh5.googleusercontent.com/-AubKP6RsE4s/AAAAAAAAAAI/AAAAAAAAABI/DdOK5vvzKn0/photo.jpg", - "settings": "{\"num\":889,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n float width = 20.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float squares = 36.0;\\n float angle = (x / squares) * radians(360.0);\\n float radius = y + 1.0;\\n \\n float ux = radius * cos(angle) + 35.0;\\n float vy = radius * sin(angle);\\n if(vertexId > 74.0)\\n {\\n float test = mod(vertexId, 75.0);\\n if(test != 0.0)\\n { \\n \\tux = ux - floor(vertexId / 74.0) * 4.0;\\n }\\n }\\n \\n vec2 xy = vec2(ux, vy) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 889, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n float width = 20.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float squares = 36.0;\n float angle = (x / squares) * radians(360.0);\n float radius = y + 1.0;\n \n float ux = radius * cos(angle) + 35.0;\n float vy = radius * sin(angle);\n if(vertexId > 74.0)\n {\n float test = mod(vertexId, 75.0);\n if(test != 0.0)\n { \n \tux = ux - floor(vertexId / 74.0) * 4.0;\n }\n }\n \n vec2 xy = vec2(ux, vy) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-mdhhk7s3w33khrxoj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/K4mA9KNyq7jBxdzxc/art.json b/art/K4mA9KNyq7jBxdzxc/art.json index 2aa7cd88..0c381dbe 100644 --- a/art/K4mA9KNyq7jBxdzxc/art.json +++ b/art/K4mA9KNyq7jBxdzxc/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10721,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.1607843137254902,0.1607843137254902,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 11.//KParameter0 -10.>>1000.\\n#define KP1 16.//KParameter1 0.0>>32.\\n#define K2 9.0//KParameter2 6.0>>10.\\n#define KP3 -0.01//KParameter3 -8.000>>0.5\\n#define KP4 6.2//KParameter4 0.000>>15.\\n#define KP5 32.0//KParameter5 30.000>>90000.0\\n#define K6 11.0//Ksat 0.000>>11.0\\n\\n\\n\\n\\n#define PI radians(180. -KP1)\\nfloat VertexCount = 10000. * K2;\\n \\n float KP2 = (K2 + mouse.y);\\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz,.1*K6,1.1));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(y-x -x,.5*y+y, z*3.); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 1.125;\\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.52) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n ,1.15)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect );\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 10721, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.1607843137254902, + 0.1607843137254902, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 11.//KParameter0 -10.>>1000.\n#define KP1 16.//KParameter1 0.0>>32.\n#define K2 9.0//KParameter2 6.0>>10.\n#define KP3 -0.01//KParameter3 -8.000>>0.5\n#define KP4 6.2//KParameter4 0.000>>15.\n#define KP5 32.0//KParameter5 30.000>>90000.0\n#define K6 11.0//Ksat 0.000>>11.0\n\n\n\n\n#define PI radians(180. -KP1)\nfloat VertexCount = 10000. * K2;\n \n float KP2 = (K2 + mouse.y);\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz,.1*K6,1.1));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(y-x -x,.5*y+y, z*3.); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 1.125;\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.52) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n ,1.15)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect );\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-t27m8crr4986kl8jk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/K5ZpsaMBvzDxkvbwo/art.json b/art/K5ZpsaMBvzDxkvbwo/art.json index d1143b34..3dd62b08 100644 --- a/art/K5ZpsaMBvzDxkvbwo/art.json +++ b/art/K5ZpsaMBvzDxkvbwo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonathan", "avatarUrl": "https://lh5.googleusercontent.com/-LRM8jVIFBuQ/AAAAAAAAAAI/AAAAAAAAANs/OaE9ey6FMjY/photo.jpg", - "settings": "{\"num\":1994,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.3764705882352941,1],\"shader\":\"void main(){\\n float vWidth = floor(sqrt(vertexCount));\\n float vHeight = 1. / vWidth;\\n \\n float x = 2.0 * mod(vertexId / vWidth, 1.) - 1.;\\n float y = 2.0 * floor(vertexId / vWidth) * vHeight - 1.;\\n \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 30. * vHeight;\\n gl_PointSize *= resolution.x / 1000.;\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1994, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.3764705882352941, + 1 + ], + "shader": "void main(){\n float vWidth = floor(sqrt(vertexCount));\n float vHeight = 1. / vWidth;\n \n float x = 2.0 * mod(vertexId / vWidth, 1.) - 1.;\n float y = 2.0 * floor(vertexId / vWidth) * vHeight - 1.;\n \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = 10.0;\n gl_PointSize *= 30. * vHeight;\n gl_PointSize *= resolution.x / 1000.;\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-khn57lae5r9c3tls8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/K5xqhTGgRRGkJzitm/art.json b/art/K5xqhTGgRRGkJzitm/art.json index 2250cdfa..8986d04e 100644 --- a/art/K5xqhTGgRRGkJzitm/art.json +++ b/art/K5xqhTGgRRGkJzitm/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "gman", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n//\\n\\n#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n float snd = texture2D(sound, vec2(abs(m1p1(a1 / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n float t = time * 0.1;\\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.3,.6))\\n \\t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.9 + t,.5,.8))\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.6 + t,.7,.4))\\n \\t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.7 + t,.4,.7));\\n\\n light *= mix(0.5, 2.0, snd);\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n v_color = vec4(vec3(light), 1);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n//\n\n#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n float snd = texture2D(sound, vec2(abs(m1p1(a1 / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n float t = time * 0.1;\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.3,.6))\n \t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.9 + t,.5,.8))\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.6 + t,.7,.4))\n \t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.7 + t,.4,.7));\n\n light *= mix(0.5, 2.0, snd);\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n v_color = vec4(vec3(light), 1);\n}" + }, "screenshotURL": "data/images/images-898ktk0eltqxxxh5m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/K84niXFJgvqPCrhF3/art.json b/art/K84niXFJgvqPCrhF3/art.json index 0729c5de..25b9d8ea 100644 --- a/art/K84niXFJgvqPCrhF3/art.json +++ b/art/K84niXFJgvqPCrhF3/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 8.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 8.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-psnggln1496tx7jwp-thumbnail.jpg", "views": { "$numberInt": "92" diff --git a/art/K8g3Q6ckgSTWZuRPv/art.json b/art/K8g3Q6ckgSTWZuRPv/art.json index 10b8e664..6045bd9c 100644 --- a/art/K8g3Q6ckgSTWZuRPv/art.json +++ b/art/K8g3Q6ckgSTWZuRPv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n float spd = 0.3;\\n float tm = time * spd;\\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\\n gl_PointSize = 14.0;\\n\\n \\n v_color = vec4(2.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n float spd = 0.3;\n float tm = time * spd;\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\n gl_PointSize = 14.0;\n\n \n v_color = vec4(2.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-9kop22k5fdvtjoso4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/K8sAwLQqxzqjXN3FT/art.json b/art/K8sAwLQqxzqjXN3FT/art.json index 13646f8c..d8e9e221 100644 --- a/art/K8sAwLQqxzqjXN3FT/art.json +++ b/art/K8sAwLQqxzqjXN3FT/art.json @@ -11,7 +11,19 @@ "origId": "gqJ33JsAWdcuKjJHH", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-r3ddlegcc4cl04il4-thumbnail.jpg", "views": { "$numberInt": "128" diff --git a/art/K9kkXT25juoLDcni4/art.json b/art/K9kkXT25juoLDcni4/art.json index 9230b22a..41563ec4 100644 --- a/art/K9kkXT25juoLDcni4/art.json +++ b/art/K9kkXT25juoLDcni4/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "wip3", "username": "gman", - "settings": "{\"num\":9680,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/dj-wonkar/easy-funk-edit\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define ACROSS 10.\\n#define DOWN 10.\\n#define PER_AREA ((ACROSS + 1.) * (DOWN + 1.) * 10.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec4 area(float vertexId, float areaId) {\\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 2.)) * 2., 5.);\\n float thingId = floor(vertexId / 10.);\\n float col = mod(thingId, ACROSS + 1.);\\n float row = floor(thingId / (ACROSS + 1.));\\n float u = col / ACROSS;\\n float v = row / DOWN;\\n float x = u * 2. - 1.;\\n float y = v * 2. - 1.;\\n \\n float d = length(vec2(x, y));\\n float su = mod(PI * 2. + atan(y ,x) + areaId / .8 * PI * 2. + time, PI * 2.) / (PI * 2.);\\n float sv = d * 0.1;\\n float snd = texture2D(sound, vec2(su * 0.25 / 8. * areaId, sv)).a;\\n \\n float r = 0.04 + pow(snd, 3.) * 0.15;\\n float a = pointId / 5. * PI * 2. + thingId * 0.05 + time * 2.;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = cs * r;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\n float hue = (time * 0.01) + areaId / 8.;\\n \\n return vec4(\\n vec2(x, y) * 1.0 + xy * aspect,\\n snd,\\n hue);\\n}\\n\\nvoid main() {\\n gl_PointSize = 4.0;\\n\\n float areaId = floor(vertexId / PER_AREA);\\n float aCol = mod(areaId, 4.);\\n float aRow = floor(areaId / 4.);\\n float ax = (aCol + 0.5) / 4. * 2. - 1.;\\n float ay = (aRow + 0.5) / 2. * 1.8 - 0.9;\\n float avId = mod(vertexId, PER_AREA); \\n \\n vec4 a = area(avId, areaId);\\n \\n gl_Position = vec4(a.xy * vec2(0.25, 0.4) + vec2(ax, ay), 0, 1);\\n float snd = a.z;\\n float hue = a.w;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 1, snd)), vec3(1,1,1), 0.0), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 9680, + "mode": "LINES", + "sound": "https://soundcloud.com/dj-wonkar/easy-funk-edit", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define ACROSS 10.\n#define DOWN 10.\n#define PER_AREA ((ACROSS + 1.) * (DOWN + 1.) * 10.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec4 area(float vertexId, float areaId) {\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 2.)) * 2., 5.);\n float thingId = floor(vertexId / 10.);\n float col = mod(thingId, ACROSS + 1.);\n float row = floor(thingId / (ACROSS + 1.));\n float u = col / ACROSS;\n float v = row / DOWN;\n float x = u * 2. - 1.;\n float y = v * 2. - 1.;\n \n float d = length(vec2(x, y));\n float su = mod(PI * 2. + atan(y ,x) + areaId / .8 * PI * 2. + time, PI * 2.) / (PI * 2.);\n float sv = d * 0.1;\n float snd = texture2D(sound, vec2(su * 0.25 / 8. * areaId, sv)).a;\n \n float r = 0.04 + pow(snd, 3.) * 0.15;\n float a = pointId / 5. * PI * 2. + thingId * 0.05 + time * 2.;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = cs * r;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \n float hue = (time * 0.01) + areaId / 8.;\n \n return vec4(\n vec2(x, y) * 1.0 + xy * aspect,\n snd,\n hue);\n}\n\nvoid main() {\n gl_PointSize = 4.0;\n\n float areaId = floor(vertexId / PER_AREA);\n float aCol = mod(areaId, 4.);\n float aRow = floor(areaId / 4.);\n float ax = (aCol + 0.5) / 4. * 2. - 1.;\n float ay = (aRow + 0.5) / 2. * 1.8 - 0.9;\n float avId = mod(vertexId, PER_AREA); \n \n vec4 a = area(avId, areaId);\n \n gl_Position = vec4(a.xy * vec2(0.25, 0.4) + vec2(ax, ay), 0, 1);\n float snd = a.z;\n float hue = a.w;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 1, snd)), vec3(1,1,1), 0.0), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-2kb3wfu2zxsv7diex-thumbnail.jpg", "views": { "$numberInt": "3908" diff --git a/art/KAsduiMs3RKWHDcHk/art.json b/art/KAsduiMs3RKWHDcHk/art.json index dea6699d..d31fac2e 100644 --- a/art/KAsduiMs3RKWHDcHk/art.json +++ b/art/KAsduiMs3RKWHDcHk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":247,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/settle-the-score\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n \\n \\n float x = sin(time+cos(vertexId));\\n float yy = sin(vertexId * time*0.0009);\\n float dim = sin(yy+x)+ 4.;\\n float red = sin(vertexId) * 255.;\\n float bleu = sin(vertexId) * 255.;\\n float green = sin(vertexId) * 255.;\\n gl_Position = vec4(x,yy,0,1);\\n gl_PointSize = (dim);\\n v_color = vec4(1,bleu,green,0);\\n \\n}\"}", + "settings": { + "num": 247, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/settle-the-score", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n \n \n float x = sin(time+cos(vertexId));\n float yy = sin(vertexId * time*0.0009);\n float dim = sin(yy+x)+ 4.;\n float red = sin(vertexId) * 255.;\n float bleu = sin(vertexId) * 255.;\n float green = sin(vertexId) * 255.;\n gl_Position = vec4(x,yy,0,1);\n gl_PointSize = (dim);\n v_color = vec4(1,bleu,green,0);\n \n}" + }, "screenshotURL": "data/images/images-ed4tiyto0y1w1ng9e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KCTdZhosdnszWh5Co/art.json b/art/KCTdZhosdnszWh5Co/art.json index c2409cbf..d0fb9ce9 100644 --- a/art/KCTdZhosdnszWh5Co/art.json +++ b/art/KCTdZhosdnszWh5Co/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "rudy2", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJxjrAjHwwN61-aEd5Ck_NAnP9iTFLqowFJNDG0m=s96-c", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Rudy Castan\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Rudy Castan\n// Exercise Making A Grid\n// CS250 Spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-19ku4t7jw6rjox3k3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KCb2cGRMiF3zp2P9E/art.json b/art/KCb2cGRMiF3zp2P9E/art.json index 134af5c1..88ad0527 100644 --- a/art/KCb2cGRMiF3zp2P9E/art.json +++ b/art/KCb2cGRMiF3zp2P9E/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "liaminjapan", "avatarUrl": "https://avatars.githubusercontent.com/LiamInJapan?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aguti/aphex-twin-tha\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.47843137254901963,0.03137254901960784,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, .0, 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .0, 1.), c.y);\\n \\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0,0,\\n s, c, 0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n 1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n trans, 1);\\n}\\n\\nmat4 ident()\\n{\\n return mat4(\\n 1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n s[0], 0,0,0,\\n 0,s[1],0,0,\\n 0,0,s[2],0,\\n 0,0,0,1);\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n return mat4(\\n s,0,0,0,\\n 0,s,0,0,\\n 0,0,s,0,\\n 0,0,0,1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux /numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\n\\nvoid main()\\n{\\n float numCircleSegments = 64.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * .2) * .1;\\n float yoff = 0.;//sin(time + x * .3) * .2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.025 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.;\\n \\n \\n float pump = step(0.8, snd);\\n //float hue = u * .1 + snd *.2 + time * .1;//sin(time + v * 20.) * .05;\\n //float sat = mix(0., 1., pump);\\n //float val = mix(.1, pow(snd + .2, 5.), pump);//pow(snd + .2, 5.);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n //v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n v_color = vec4(1,1,1,1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aguti/aphex-twin-tha", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.47843137254901963, + 0.03137254901960784, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, .0, 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .0, 1.), c.y);\n \n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0,0,\n s, c, 0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n 1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n trans, 1);\n}\n\nmat4 ident()\n{\n return mat4(\n 1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\n\nmat4 scale(vec3 s)\n{\n return mat4(\n s[0], 0,0,0,\n 0,s[1],0,0,\n 0,0,s[2],0,\n 0,0,0,1);\n}\n\nmat4 uniformScale(float s)\n{\n return mat4(\n s,0,0,0,\n 0,s,0,0,\n 0,0,s,0,\n 0,0,0,1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux /numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\n\nvoid main()\n{\n float numCircleSegments = 64.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * .2) * .1;\n float yoff = 0.;//sin(time + x * .3) * .2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.025 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * .02) * 5.;\n \n \n float pump = step(0.8, snd);\n //float hue = u * .1 + snd *.2 + time * .1;//sin(time + v * 20.) * .05;\n //float sat = mix(0., 1., pump);\n //float val = mix(.1, pow(snd + .2, 5.), pump);//pow(snd + .2, 5.);//sin(time + v * u * 20.0) * .5 + .5;\n \n //v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n v_color = vec4(1,1,1,1);\n}\n" + }, "screenshotURL": "data/images/images-ue7thora907bswc72-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KE36FRWxcF7s2qX3i/art.json b/art/KE36FRWxcF7s2qX3i/art.json index f6d00b36..6275f69d 100644 --- a/art/KE36FRWxcF7s2qX3i/art.json +++ b/art/KE36FRWxcF7s2qX3i/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1927,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0,0.2,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define KP0 4.//KParameter -0.5>>2.5\\n#define KP1 1.5//KParameter -2.>>2.\\n#define zoom 1.5//KParameter 1.0>>7.\\n#define KP2 1.3//KParameter 0.4>>2.\\n\\n//KVerticesNumber=2000\\n\\nvec3 gSunColor = vec3(1.0, 5.8, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0,KP0, 1.0);\\nfloat gExposure = 0.3;\\t\\n\\nfloat gCubeColorRandom = 20.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0*-mouse.y;\\nfloat g_cameraFar = 1000.0 * zoom;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( mouse.x*20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.2, target + 0.2);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n float beat = texture2D(sound, vec2(0.007, 0)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0.65; + floor(time * 0.50) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-1,0,-.3), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8 + KP2;\\n \\n//vec3 vCameraTarget = vec3( 330/int(KP0),111.6*zoom, 2222.0 );\\n//\\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n vec3 vCameraTarget = vec3( KP0, KP1, 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 5./zoom, sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1.-KP1,.4 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.3, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, .3) , background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 1927, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0, + 0.2, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define KP0 4.//KParameter -0.5>>2.5\n#define KP1 1.5//KParameter -2.>>2.\n#define zoom 1.5//KParameter 1.0>>7.\n#define KP2 1.3//KParameter 0.4>>2.\n\n//KVerticesNumber=2000\n\nvec3 gSunColor = vec3(1.0, 5.8, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0,KP0, 1.0);\nfloat gExposure = 0.3;\t\n\nfloat gCubeColorRandom = 20.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0*-mouse.y;\nfloat g_cameraFar = 1000.0 * zoom;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( mouse.x*20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.2, target + 0.2);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n float beat = texture2D(sound, vec2(0.007, 0)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0.65; + floor(time * 0.50) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-1,0,-.3), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8 + KP2;\n \n//vec3 vCameraTarget = vec3( 330/int(KP0),111.6*zoom, 2222.0 );\n//\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n vec3 vCameraTarget = vec3( KP0, KP1, 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 5./zoom, sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1.-KP1,.4 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.3, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, .3) , background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-9mk4cqawu64psaqge-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KFvg6n392t9qpC7HD/art.json b/art/KFvg6n392t9qpC7HD/art.json index 43bb4e76..11c3b2a7 100644 --- a/art/KFvg6n392t9qpC7HD/art.json +++ b/art/KFvg6n392t9qpC7HD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3333,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/pridon/here-be-dragons\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n___________________1111111111111__________________\\n______________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_____________\\n___________1¶¶¶¶¶¶111111111111111¶¶¶¶¶¶1__________\\n_________1¶¶¶11111111111111111111111¶1¶¶¶1________\\n_______1¶¶¶¶1111111111111111111111111111¶¶¶1______\\n______1¶¶1¶1111111111¶¶¶¶¶¶¶¶1111111111111¶¶1_____\\n_____¶¶¶11111111¶¶¶¶¶¶¶¶1_¶¶¶¶¶¶¶¶111111111¶¶¶____\\n____¶¶¶1111111¶¶¶¶¶¶¶¶1_____¶¶¶¶¶¶¶¶11111111¶¶¶___\\n___1¶¶111111¶¶¶¶¶¶¶¶1_________¶¶¶¶¶¶¶¶1111111¶¶1__\\n___¶¶11111¶¶¶¶¶¶¶¶1____________1¶¶¶¶¶¶¶¶111111¶¶1_\\n__¶¶11111¶¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶¶1¶¶¶¶¶¶¶¶111111¶¶_\\n__¶¶1111¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶_____1¶¶¶¶¶¶¶¶11111¶¶_\\n__¶¶1111¶¶¶¶¶¶¶1________¶¶________¶¶¶¶¶¶1¶¶1111¶¶_\\n__¶1111¶¶¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\\n__¶¶111¶1¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\\n__¶1111¶¶1¶¶¶¶¶¶________¶¶¶_______1¶¶¶¶¶11¶11111¶_\\n__¶¶111¶¶1¶¶¶¶¶¶1_____¶¶¶_¶¶______¶¶¶¶¶¶1¶¶1111¶¶_\\n__1¶¶111¶11¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶¶¶¶¶11¶1111¶¶1_\\n___¶¶¶11¶¶11¶¶¶¶¶¶¶1___________¶¶¶¶¶¶¶11¶¶111¶¶¶__\\n___1¶¶111¶¶111¶¶¶¶¶¶¶________1¶¶¶¶¶¶111¶¶1111¶¶1__\\n____1¶¶1111¶¶111¶¶¶¶¶¶¶1___¶¶¶¶¶¶¶111¶¶¶1111¶¶1___\\n_____1¶¶¶111¶¶¶11111¶¶¶¶¶¶¶¶¶¶11111¶¶¶11111¶¶1____\\n______1¶¶¶1111¶¶¶¶¶1111¶¶¶11111¶¶¶¶¶11111¶¶¶1_____\\n________1¶¶111111¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1111111¶¶1_______\\n__________¶¶1111111111¶¶¶¶1111111111111¶1_________\\n__________¶¶¶11111111¶¶11¶¶11111111111¶¶¶_________\\n________1¶¶11¶1¶¶111111111¶111111¶¶¶¶¶11¶¶________\\n_______1¶¶111111¶¶¶¶¶1¶1¶¶¶¶¶¶¶¶¶¶1111111¶¶_______\\n_______¶¶¶11111111111111¶¶11¶1111111111111¶¶______\\n______1¶1111¶11111111111¶¶11111111111111111¶1_____\\n______¶¶111¶111111111111¶¶1111111111111¶111¶¶_____\\n_____1¶111¶¶111111111111¶¶1111111111111¶1111¶1____\\n_____¶¶¶¶¶¶¶111111111111¶¶1111111111111¶¶¶¶¶¶¶____\\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\\n____1¶¶¶¶¶¶1111111111111¶¶11111111111111¶¶¶¶¶¶1___\\n______1111¶1111111111111¶¶11111111111111¶1111_____\\n__________¶¶¶11111111111¶¶111111111111¶¶¶_________\\n__________¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶_________\\n________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_______\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n// based & influenced by this https://github.com/KessonDalef/Shaders/blob/master/Vertex/spherepointcloud.vert\\n\\n/*{\\n \\\"pixelRatio\\\": 1,\\n \\\"vertexCount\\\": 80000,\\n \\\"vertexMode\\\": \\\"POINTS\\\",\\n}*/\\n\\n#define DOTS_PER 80000.\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.6\\n\\nprecision mediump float;\\n/*\\nattribute float vertexId;\\nuniform float vertexCount;\\nuniform float time;\\nuniform vec2 resolution;\\nvarying vec4 v_color;\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// 2D Random\\nfloat random (in vec2 st) {\\n return fract(sin(dot(st.xy,\\n vec2(12.9898,78.233)))\\n * 43758.5453123);\\n}\\n\\n// Based on Morgan McGuire @morgan3d\\n// https://www.shadertoy.com/view/4dS3Wd\\nfloat noise (in vec2 st) {\\n vec2 i = floor(st);\\n vec2 f = fract(st);\\n\\n // Four corners in 2D of a tile\\n float a = random(i);\\n float b = random(i + vec2(1.0, 0.0));\\n float c = random(i + vec2(0.0, 1.0));\\n float d = random(i + vec2(1.0, 1.0));\\n\\n // Cubic Hermine Curve. Same as SmoothStep()\\n vec2 u = f*f*(3.-2.0*f);\\n u = smoothstep(0.,1.,f);\\n\\n // Mix 4 coorners percentages\\n return mix(a, b, u.x) +\\n (c - a)* u.y * (1.0 - u.x) +\\n (d - b) * u.x * u.y;\\n}\\n\\nmat4 rotateX(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateY(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateZ(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nfloat easeInOutSine(float x) \\n{\\n return -(cos(PI * x) - 1.) * 0.5;\\n}\\n\\nvec4 Slerp(vec4 p0, vec4 p1, float t)\\n{\\n float dotp = dot(normalize(p0), normalize(p1));\\n if ((dotp > 0.9999) || (dotp<-0.9999))\\n {\\n if (t<=0.5)\\n return p0;\\n return p1;\\n }\\n float theta = acos(dotp * PI/180.0);\\n vec4 P = (\\n (\\n p0*sin((1.-t)*theta) + p1*sin(t*theta)\\n ) / sin(theta)\\n );\\n P.w = 1.;\\n return P;\\n}\\n\\nvec3 posf2(float t, float i, float snd) \\n{\\n \\n \\n\\treturn vec3(\\n cos(t*.4+i*1.53) +\\n sin(t*4.84+i*.6)\\n //noise(vec2(t*.5*snd, i))\\n ,\\n cos(t*1.4+i*1.353-2.1) +\\n sin(t*4.84+i*.476-2.1) \\n //noise(vec2(t, i))\\n ,\\n sin(t*1.84+i*.36+2.1)// +\\n\\t)*.1;\\n}\\n\\nvec3 posf0(float t, float fsndweight, float snd) {\\n //return posf2(t,-1.)*0.9;\\n return posf2(t,-1.,snd)*fsndweight;\\n}\\n\\nvec3 posf(float t, float i, float fsndweight, float snd) \\n{\\n //float fsndweightf = mix(4.4, 4.49, pow(fsndweight, 2.0));\\n return posf2(t*.045,i,snd) + posf0(t,fsndweight,snd);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd, float lenghtweight, float snd) {\\n //vec3 pos = posf(t,i,.49)+ofs;\\n vec3 pos = posf(t,i, mix(.45, 4.5, pow(snd, 1.0)), snd) + ofs;\\n\\n vec3 posf = fract(pos+.25)-.5;\\n\\n float l = length(posf)*lenghtweight; //1.5\\n //return (- posf + posf/l)*(1.-smoothstep(lerpEnd,3.,l));\\n //return (posf/l)*(1.-smoothstep(lerpEnd,2.9,l));\\n return (posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// YUV to RGB matrix\\nmat3 yuv2rgb = mat3(1.0, 0.0, 1.13983,\\n 1.0, -0.39465, -0.58060,\\n 1.0, 2.03211, 0.0);\\n\\n// RGB to YUV matrix\\nmat3 rgb2yuv = mat3(0.2126, 0.7152, 0.0722,\\n -0.09991, -0.33609, 0.43600,\\n 0.615, -0.5586, -0.05639);\\n\\n#define OCTAVES 12\\nfloat fbm (in vec2 st) {\\n // Initial values\\n float value = 0.0;\\n float amplitude = .5;\\n float frequency = 0.;\\n //\\n // Loop of octaves\\n for (int i = 0; i < OCTAVES; i++) {\\n value += amplitude * noise(st);\\n st *= 2.;\\n amplitude *= .5;\\n }\\n return value;\\n}\\n\\nfloat fbm2 ( in vec2 _st) {\\n float v = 0.0;\\n float a = 0.5;\\n vec2 shift = vec2(100.0);\\n // Rotate to reduce axial bias\\n mat2 rot = mat2(cos(0.5), sin(0.5),\\n -sin(0.5), cos(0.50));\\n for (int i = 0; i < OCTAVES; ++i) {\\n v += a * noise(_st);\\n _st = rot * _st * 2.0 + shift;\\n a *= 0.5;\\n }\\n return v;\\n}\\n\\nvoid main(void)\\n{\\n\\n float t = time*.6;\\n float i = vertexId+sin(vertexId)*100.;\\n \\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n \\n float snd = texture2D(sound, vec2(thingV * 0.5 + 0.01, mod(thingV * 4., 4.) * 6. / 24.)).a*mix(.5, .9, .8);\\n \\n vec3 pos = posf(t,i, mix(1.45, 4.5, pow(snd, 1.)), snd);\\n \\n vec3 ofs = vec3(0);\\n \\n for (float f = -10.; f < 0.; f++) {\\n\\t //ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\\n ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\\n }\\n ofs += push(t,i,ofs,.999,mix(1.45, 1.5, pow(snd, 2.)),snd);\\n\\n //pos -= posf0(t);\\n pos -= posf0(t,.49, snd);\\n \\n pos += ofs;\\n\\n vec3 oscillationV = posf0(t*.1,0.25, 10.001);\\n\\t\\n oscillationV = vec3(\\n oscillationV.x, \\n dot(normalize( cross(pos,vec3(1.0,0.0,0.0)) ),oscillationV), \\n dot(pos,oscillationV)\\n );\\n\\n float offset = .5 + .5*sin( 1.0 + 6.0*pow(.5-.5*oscillationV.x,1.) );\\n float dist = length( oscillationV*vec3(5.,.0,.0) ) - .80 - offset;\\n \\n dist += 8.*sin(1.*oscillationV.z);\\n dist += sin(10.0*oscillationV.x) * sin(500.*oscillationV.y) * sin(10.*oscillationV.z) * clamp(2.0*oscillationV.y+0.5,0.0,1.0);\\n //dist *= clamp(2.0*oscillationV.y+0.5,0.0,1.0);\\n \\n //vec4 sphericalInt = Slerp(vec4(pos, 1.), vec4(vec3(ofs), 1.), time*pow(snd, 2.));\\n \\n pos.yz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\\n pos.xz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\\n \\n //pos.yz *= mat2(.8,.6,-.6,.8);\\n //pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n //sphericalInt.yz *= mat2(.8,.6,-.6,.8);\\n //sphericalInt.xz *= mat2(.8,.6,-.6,.8);\\n\\n pos.x *= resolution.y/resolution.x;\\n pos.z *= resolution.y/resolution.x;\\n\\n mat4 rotation = rotateY(time*0.15);\\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\\n\\n pos.z += .9;\\n\\n //rot *= .95;\\n rot *= .5;\\n\\n gl_Position = vec4(rot.xyz, 0.55);\\n gl_PointSize = .3;\\n\\n float hue = 1.6 + v;// + v * time * 0.;\\n hue = mix(hue, 50., mod(floor(t * 4.0), 1.4));\\n hue = mix(hue, 0.5, step(0.95, snd*0.95));\\n \\n float clipZ = m1p1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n float val = invClipZ * 150.;\\n \\n \\n \\n \\n //v_color = vec4(hsv2rgb(vec3(hue*2., hue*22., val)),mix(1., 2.5, pow(snd, 4.)));\\n v_color = vec4(yuv2rgb * vec3(0.5, pos.x, pos.y),mix(1., 2.5, pow(snd, 4.)));\\n v_color = vec4(\\n v_color.rbg * v_color.g, \\n v_color.a\\n );\\n v_color += fbm(pos.xy*50.0);\\n \\n //v_color += vec4(.7, 0.6, 1.0, 0.6);\\n}\\n\"}", + "settings": { + "num": 3333, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/pridon/here-be-dragons", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n___________________1111111111111__________________\n______________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_____________\n___________1¶¶¶¶¶¶111111111111111¶¶¶¶¶¶1__________\n_________1¶¶¶11111111111111111111111¶1¶¶¶1________\n_______1¶¶¶¶1111111111111111111111111111¶¶¶1______\n______1¶¶1¶1111111111¶¶¶¶¶¶¶¶1111111111111¶¶1_____\n_____¶¶¶11111111¶¶¶¶¶¶¶¶1_¶¶¶¶¶¶¶¶111111111¶¶¶____\n____¶¶¶1111111¶¶¶¶¶¶¶¶1_____¶¶¶¶¶¶¶¶11111111¶¶¶___\n___1¶¶111111¶¶¶¶¶¶¶¶1_________¶¶¶¶¶¶¶¶1111111¶¶1__\n___¶¶11111¶¶¶¶¶¶¶¶1____________1¶¶¶¶¶¶¶¶111111¶¶1_\n__¶¶11111¶¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶¶1¶¶¶¶¶¶¶¶111111¶¶_\n__¶¶1111¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶_____1¶¶¶¶¶¶¶¶11111¶¶_\n__¶¶1111¶¶¶¶¶¶¶1________¶¶________¶¶¶¶¶¶1¶¶1111¶¶_\n__¶1111¶¶¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\n__¶¶111¶1¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\n__¶1111¶¶1¶¶¶¶¶¶________¶¶¶_______1¶¶¶¶¶11¶11111¶_\n__¶¶111¶¶1¶¶¶¶¶¶1_____¶¶¶_¶¶______¶¶¶¶¶¶1¶¶1111¶¶_\n__1¶¶111¶11¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶¶¶¶¶11¶1111¶¶1_\n___¶¶¶11¶¶11¶¶¶¶¶¶¶1___________¶¶¶¶¶¶¶11¶¶111¶¶¶__\n___1¶¶111¶¶111¶¶¶¶¶¶¶________1¶¶¶¶¶¶111¶¶1111¶¶1__\n____1¶¶1111¶¶111¶¶¶¶¶¶¶1___¶¶¶¶¶¶¶111¶¶¶1111¶¶1___\n_____1¶¶¶111¶¶¶11111¶¶¶¶¶¶¶¶¶¶11111¶¶¶11111¶¶1____\n______1¶¶¶1111¶¶¶¶¶1111¶¶¶11111¶¶¶¶¶11111¶¶¶1_____\n________1¶¶111111¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1111111¶¶1_______\n__________¶¶1111111111¶¶¶¶1111111111111¶1_________\n__________¶¶¶11111111¶¶11¶¶11111111111¶¶¶_________\n________1¶¶11¶1¶¶111111111¶111111¶¶¶¶¶11¶¶________\n_______1¶¶111111¶¶¶¶¶1¶1¶¶¶¶¶¶¶¶¶¶1111111¶¶_______\n_______¶¶¶11111111111111¶¶11¶1111111111111¶¶______\n______1¶1111¶11111111111¶¶11111111111111111¶1_____\n______¶¶111¶111111111111¶¶1111111111111¶111¶¶_____\n_____1¶111¶¶111111111111¶¶1111111111111¶1111¶1____\n_____¶¶¶¶¶¶¶111111111111¶¶1111111111111¶¶¶¶¶¶¶____\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\n____1¶¶¶¶¶¶1111111111111¶¶11111111111111¶¶¶¶¶¶1___\n______1111¶1111111111111¶¶11111111111111¶1111_____\n__________¶¶¶11111111111¶¶111111111111¶¶¶_________\n__________¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶_________\n________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_______\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// based & influenced by this https://github.com/KessonDalef/Shaders/blob/master/Vertex/spherepointcloud.vert\n\n/*{\n \"pixelRatio\": 1,\n \"vertexCount\": 80000,\n \"vertexMode\": \"POINTS\",\n}*/\n\n#define DOTS_PER 80000.\n#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.6\n\nprecision mediump float;\n/*\nattribute float vertexId;\nuniform float vertexCount;\nuniform float time;\nuniform vec2 resolution;\nvarying vec4 v_color;\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// 2D Random\nfloat random (in vec2 st) {\n return fract(sin(dot(st.xy,\n vec2(12.9898,78.233)))\n * 43758.5453123);\n}\n\n// Based on Morgan McGuire @morgan3d\n// https://www.shadertoy.com/view/4dS3Wd\nfloat noise (in vec2 st) {\n vec2 i = floor(st);\n vec2 f = fract(st);\n\n // Four corners in 2D of a tile\n float a = random(i);\n float b = random(i + vec2(1.0, 0.0));\n float c = random(i + vec2(0.0, 1.0));\n float d = random(i + vec2(1.0, 1.0));\n\n // Cubic Hermine Curve. Same as SmoothStep()\n vec2 u = f*f*(3.-2.0*f);\n u = smoothstep(0.,1.,f);\n\n // Mix 4 coorners percentages\n return mix(a, b, u.x) +\n (c - a)* u.y * (1.0 - u.x) +\n (d - b) * u.x * u.y;\n}\n\nmat4 rotateX(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateY(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateZ(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nfloat easeInOutSine(float x) \n{\n return -(cos(PI * x) - 1.) * 0.5;\n}\n\nvec4 Slerp(vec4 p0, vec4 p1, float t)\n{\n float dotp = dot(normalize(p0), normalize(p1));\n if ((dotp > 0.9999) || (dotp<-0.9999))\n {\n if (t<=0.5)\n return p0;\n return p1;\n }\n float theta = acos(dotp * PI/180.0);\n vec4 P = (\n (\n p0*sin((1.-t)*theta) + p1*sin(t*theta)\n ) / sin(theta)\n );\n P.w = 1.;\n return P;\n}\n\nvec3 posf2(float t, float i, float snd) \n{\n \n \n\treturn vec3(\n cos(t*.4+i*1.53) +\n sin(t*4.84+i*.6)\n //noise(vec2(t*.5*snd, i))\n ,\n cos(t*1.4+i*1.353-2.1) +\n sin(t*4.84+i*.476-2.1) \n //noise(vec2(t, i))\n ,\n sin(t*1.84+i*.36+2.1)// +\n\t)*.1;\n}\n\nvec3 posf0(float t, float fsndweight, float snd) {\n //return posf2(t,-1.)*0.9;\n return posf2(t,-1.,snd)*fsndweight;\n}\n\nvec3 posf(float t, float i, float fsndweight, float snd) \n{\n //float fsndweightf = mix(4.4, 4.49, pow(fsndweight, 2.0));\n return posf2(t*.045,i,snd) + posf0(t,fsndweight,snd);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd, float lenghtweight, float snd) {\n //vec3 pos = posf(t,i,.49)+ofs;\n vec3 pos = posf(t,i, mix(.45, 4.5, pow(snd, 1.0)), snd) + ofs;\n\n vec3 posf = fract(pos+.25)-.5;\n\n float l = length(posf)*lenghtweight; //1.5\n //return (- posf + posf/l)*(1.-smoothstep(lerpEnd,3.,l));\n //return (posf/l)*(1.-smoothstep(lerpEnd,2.9,l));\n return (posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n// YUV to RGB matrix\nmat3 yuv2rgb = mat3(1.0, 0.0, 1.13983,\n 1.0, -0.39465, -0.58060,\n 1.0, 2.03211, 0.0);\n\n// RGB to YUV matrix\nmat3 rgb2yuv = mat3(0.2126, 0.7152, 0.0722,\n -0.09991, -0.33609, 0.43600,\n 0.615, -0.5586, -0.05639);\n\n#define OCTAVES 12\nfloat fbm (in vec2 st) {\n // Initial values\n float value = 0.0;\n float amplitude = .5;\n float frequency = 0.;\n //\n // Loop of octaves\n for (int i = 0; i < OCTAVES; i++) {\n value += amplitude * noise(st);\n st *= 2.;\n amplitude *= .5;\n }\n return value;\n}\n\nfloat fbm2 ( in vec2 _st) {\n float v = 0.0;\n float a = 0.5;\n vec2 shift = vec2(100.0);\n // Rotate to reduce axial bias\n mat2 rot = mat2(cos(0.5), sin(0.5),\n -sin(0.5), cos(0.50));\n for (int i = 0; i < OCTAVES; ++i) {\n v += a * noise(_st);\n _st = rot * _st * 2.0 + shift;\n a *= 0.5;\n }\n return v;\n}\n\nvoid main(void)\n{\n\n float t = time*.6;\n float i = vertexId+sin(vertexId)*100.;\n \n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n \n float snd = texture2D(sound, vec2(thingV * 0.5 + 0.01, mod(thingV * 4., 4.) * 6. / 24.)).a*mix(.5, .9, .8);\n \n vec3 pos = posf(t,i, mix(1.45, 4.5, pow(snd, 1.)), snd);\n \n vec3 ofs = vec3(0);\n \n for (float f = -10.; f < 0.; f++) {\n\t //ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\n ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\n }\n ofs += push(t,i,ofs,.999,mix(1.45, 1.5, pow(snd, 2.)),snd);\n\n //pos -= posf0(t);\n pos -= posf0(t,.49, snd);\n \n pos += ofs;\n\n vec3 oscillationV = posf0(t*.1,0.25, 10.001);\n\t\n oscillationV = vec3(\n oscillationV.x, \n dot(normalize( cross(pos,vec3(1.0,0.0,0.0)) ),oscillationV), \n dot(pos,oscillationV)\n );\n\n float offset = .5 + .5*sin( 1.0 + 6.0*pow(.5-.5*oscillationV.x,1.) );\n float dist = length( oscillationV*vec3(5.,.0,.0) ) - .80 - offset;\n \n dist += 8.*sin(1.*oscillationV.z);\n dist += sin(10.0*oscillationV.x) * sin(500.*oscillationV.y) * sin(10.*oscillationV.z) * clamp(2.0*oscillationV.y+0.5,0.0,1.0);\n //dist *= clamp(2.0*oscillationV.y+0.5,0.0,1.0);\n \n //vec4 sphericalInt = Slerp(vec4(pos, 1.), vec4(vec3(ofs), 1.), time*pow(snd, 2.));\n \n pos.yz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\n pos.xz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\n \n //pos.yz *= mat2(.8,.6,-.6,.8);\n //pos.xz *= mat2(.8,.6,-.6,.8);\n \n //sphericalInt.yz *= mat2(.8,.6,-.6,.8);\n //sphericalInt.xz *= mat2(.8,.6,-.6,.8);\n\n pos.x *= resolution.y/resolution.x;\n pos.z *= resolution.y/resolution.x;\n\n mat4 rotation = rotateY(time*0.15);\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\n\n pos.z += .9;\n\n //rot *= .95;\n rot *= .5;\n\n gl_Position = vec4(rot.xyz, 0.55);\n gl_PointSize = .3;\n\n float hue = 1.6 + v;// + v * time * 0.;\n hue = mix(hue, 50., mod(floor(t * 4.0), 1.4));\n hue = mix(hue, 0.5, step(0.95, snd*0.95));\n \n float clipZ = m1p1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n float val = invClipZ * 150.;\n \n \n \n \n //v_color = vec4(hsv2rgb(vec3(hue*2., hue*22., val)),mix(1., 2.5, pow(snd, 4.)));\n v_color = vec4(yuv2rgb * vec3(0.5, pos.x, pos.y),mix(1., 2.5, pow(snd, 4.)));\n v_color = vec4(\n v_color.rbg * v_color.g, \n v_color.a\n );\n v_color += fbm(pos.xy*50.0);\n \n //v_color += vec4(.7, 0.6, 1.0, 0.6);\n}\n" + }, "screenshotURL": "data/images/images-pj8lji8n4d6b33xbo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KGbmKNcckp4MMvaNK/art.json b/art/KGbmKNcckp4MMvaNK/art.json index 864e1175..3cf64520 100644 --- a/art/KGbmKNcckp4MMvaNK/art.json +++ b/art/KGbmKNcckp4MMvaNK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6007,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/dan-hekate-1/i-am-the-captain-of-my-soul\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 1, 0,\\n 0, f, -1, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1.56,\\n 0, 0, zNear * zFar * rangeInv * -1., 1);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, -1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = -2.0 /texture2D(sound,vec2(mix(0.001, 1., exp(atan(offset.x, offset.y) / PI )), length(offset) * .01)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner =.9+snd;\\t\\n float start = -.1;\\n float end = 3.*mouse.x;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 2., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .25));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.55, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.*snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(0.6,mouse), pump);\\n v_color.rgb *= v_color.a*0.3;\\n}\\n\\n\"}", + "settings": { + "num": 6007, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/dan-hekate-1/i-am-the-captain-of-my-soul", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 1, 0,\n 0, f, -1, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1.56,\n 0, 0, zNear * zFar * rangeInv * -1., 1);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, -1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = -2.0 /texture2D(sound,vec2(mix(0.001, 1., exp(atan(offset.x, offset.y) / PI )), length(offset) * .01)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner =.9+snd;\t\n float start = -.1;\n float end = 3.*mouse.x;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 2., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .25));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.55, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.*snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(0.6,mouse), pump);\n v_color.rgb *= v_color.a*0.3;\n}\n\n" + }, "screenshotURL": "data/images/images-42dbezjh40lvcl8g8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KGe8YM5pCyu8n6Rhs/art.json b/art/KGe8YM5pCyu8n6Rhs/art.json index 716d5367..18afc616 100644 --- a/art/KGe8YM5pCyu8n6Rhs/art.json +++ b/art/KGe8YM5pCyu8n6Rhs/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/tim-e-aka-current-value/scenario\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\nvec2 project(vec2 position, vec2 a, vec2 b);\\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n \\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n float snd1 = texture2D(sound, vec2(0., 0.3)).a;\\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(snd*.008), cos( time*.006)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n\\tfor(int i = 0; i < 35; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\tb += box(p, vec2(.5));\\n\\t\\tt += triangle(p, vec2(.5));\\n\\t\\tp *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\n v_color = result;\\n\\t\\n //camera\\n float r = 0.9;\\n float tm = 1.5;\\n float tm2 = 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n if(depth>=0.5)\\n {\\n depthFactor = depth/10.;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, depth*0.1, 1.);\\n \\n gl_Position = mat*finalPos;\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.73205080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t*= .86602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(t);\\n\\treturn mat2(c, s, -s, c);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/tim-e-aka-current-value/scenario", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\nvec2 project(vec2 position, vec2 a, vec2 b);\nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n \n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., u)).a;\n float snd1 = texture2D(sound, vec2(0., 0.3)).a;\n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(snd*.008), cos( time*.006)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n\tfor(int i = 0; i < 35; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\tb += box(p, vec2(.5));\n\t\tt += triangle(p, vec2(.5));\n\t\tp *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\n v_color = result;\n\t\n //camera\n float r = 0.9;\n float tm = 1.5;\n float tm2 = 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n if(depth>=0.5)\n {\n depthFactor = depth/10.;\n }\n \n vec4 finalPos = vec4(ux, vy, depth*0.1, 1.);\n \n gl_Position = mat*finalPos;\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.73205080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t*= .86602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(t);\n\treturn mat2(c, s, -s, c);\n}" + }, "screenshotURL": "data/images/images-8z31ptgjoos0pl3uz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KGsjT9edDDoFLsK2a/art.json b/art/KGsjT9edDDoFLsK2a/art.json index 60b3760e..d2671e82 100644 --- a/art/KGsjT9edDDoFLsK2a/art.json +++ b/art/KGsjT9edDDoFLsK2a/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":74675,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/soulkai/sunset-killer\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* Lambmeow */ \\n\\n#define PI radians(180.)\\n\\nvec2 GetCirclePoint(float id, float NumCircleSegments) {\\n \\n \\n float ux= floor(id/6.) + mod(id,2.);\\n float vy = mod(floor(id/2.)+ floor(id/3.), 2.);\\n \\n float angle =ux/NumCircleSegments * PI * 2. ;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy +1.;\\n \\n \\n \\n float x = c * radius ; \\n float y = s * radius;\\n \\n return vec2(x,y);\\n \\n \\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main(){\\n float numCircleSeg = 20.;\\n vec2 cir = GetCirclePoint(vertexId,numCircleSeg);\\n float numPointsPerCircle = numCircleSeg * 6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount/numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles/down);\\n \\n float x = mod(circleId,across);\\n float y = floor(circleId/across);\\n \\n float u = x/(across-1.);\\n float v = y/(across- 1.);\\n \\n float xoff = sin(time + y *.2);\\n float yoff = sin(time +x *.2);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = cir * 0.1 + vec2(ux,vy) * texture2D(sound,vec2(u,v)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float snd = texture2D(sound, vec2(u,v/4.)).a;\\n \\n float soff = sin(time +x * y ) * .5 ;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/ 600.;\\n float h = (u +cos(time * -v))* sin(time * .3) + snd;\\n float s = 1.;\\n float val = v+.8;\\n v_color = vec4(hsv2rgb(vec3(h,s,val)),1);\\n}\"}", + "settings": { + "num": 74675, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/soulkai/sunset-killer", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* Lambmeow */ \n\n#define PI radians(180.)\n\nvec2 GetCirclePoint(float id, float NumCircleSegments) {\n \n \n float ux= floor(id/6.) + mod(id,2.);\n float vy = mod(floor(id/2.)+ floor(id/3.), 2.);\n \n float angle =ux/NumCircleSegments * PI * 2. ;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy +1.;\n \n \n \n float x = c * radius ; \n float y = s * radius;\n \n return vec2(x,y);\n \n \n}\n\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main(){\n float numCircleSeg = 20.;\n vec2 cir = GetCirclePoint(vertexId,numCircleSeg);\n float numPointsPerCircle = numCircleSeg * 6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount/numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles/down);\n \n float x = mod(circleId,across);\n float y = floor(circleId/across);\n \n float u = x/(across-1.);\n float v = y/(across- 1.);\n \n float xoff = sin(time + y *.2);\n float yoff = sin(time +x *.2);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = cir * 0.1 + vec2(ux,vy) * texture2D(sound,vec2(u,v)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float snd = texture2D(sound, vec2(u,v/4.)).a;\n \n float soff = sin(time +x * y ) * .5 ;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/ 600.;\n float h = (u +cos(time * -v))* sin(time * .3) + snd;\n float s = 1.;\n float val = v+.8;\n v_color = vec4(hsv2rgb(vec3(h,s,val)),1);\n}" + }, "screenshotURL": "data/images/images-aa7pzjncwwadg3s9r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KH4u8GjbkXFrDypQh/art.json b/art/KH4u8GjbkXFrDypQh/art.json index 530e4dbd..d10e948d 100644 --- a/art/KH4u8GjbkXFrDypQh/art.json +++ b/art/KH4u8GjbkXFrDypQh/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":7327,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle /2.- PI);\\n float c = cos( angle *.33);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1., 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, (1./PI), 0.2,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, -.30, 0,\\n 0, s[1], 0, .30,\\n 0, 0, s[2], 0,\\n 0, 0, 0,1)/1.2;\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 1.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.015 - 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 24.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 * circleId) * .1);\\n float end = start - 1.3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y / 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) /.4;\\n offset.y += goop(circleId + time *1.13) * sin(11.31/mouse.y);\\n vec3 aspect = vec3(1, resolution.x / resolution.y, .2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.4, .4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, .2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 0.6/snd, fract(circleId -1.79));\\n float sat = fract(1.2 * circleId/snd);\\n float val = .9;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), tan(11. +uv.y) *(pos / 93.1/ snd));\\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\\n}\"}", + "settings": { + "num": 7327, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle /2.- PI);\n float c = cos( angle *.33);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1., 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, (1./PI), 0.2,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, -.30, 0,\n 0, s[1], 0, .30,\n 0, 0, s[2], 0,\n 0, 0, 0,1)/1.2;\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 1.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.015 - 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 24.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 * circleId) * .1);\n float end = start - 1.3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y / 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) /.4;\n offset.y += goop(circleId + time *1.13) * sin(11.31/mouse.y);\n vec3 aspect = vec3(1, resolution.x / resolution.y, .2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.4, .4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, .2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 0.6/snd, fract(circleId -1.79));\n float sat = fract(1.2 * circleId/snd);\n float val = .9;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), tan(11. +uv.y) *(pos / 93.1/ snd));\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\n}" + }, "screenshotURL": "data/images/images-2dmkwigqo74jk5k0w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KLtJG7Mcf8FhRihJn/art.json b/art/KLtJG7Mcf8FhRihJn/art.json index 52a03b69..ecc58a89 100644 --- a/art/KLtJG7Mcf8FhRihJn/art.json +++ b/art/KLtJG7Mcf8FhRihJn/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":60000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ciccio-and-the-curran/clang\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define T radians(360.)\\n#define f float\\nf h(f p) {\\n vec2 p2 = fract(vec2(p*5.3983, p*5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x*p2.y*95.4337);\\n}\\nvec3 h3(f s) { return vec3(h(s),h(s*.731),h(s*1.319))*2.-1.; }\\nvec2 r(vec2 p,f a) { return vec2(p.x*cos(a)-p.y*sin(a), p.x*sin(a)+p.y*cos(a)); }\\nvec3 fk(f s, f x, f y, f ff) {\\n vec3 p = vec3(r(vec2(ff*.5,0.),T*h(s*.311)),1);\\n p.xz = r(p.xz,T*floor(h(s*.731)*y)/y);\\n p.yz = r(p.yz,T*floor(h(s)*x)/x);\\n return p;\\n}\\nvec3 c(f s, f b) {\\n f a = h(s * 0.911) * 3.;\\n vec3 p = h3(s), A = vec3(1.-step(.5,a));\\n A.y = 1.-step(1.5,a) * 1.-A.x;\\n A.z = 1.-step(2.5,a) * 1.-A.x * 1.-A.y;\\n p = mix(step(0., p)*2.-1.,p,mix(1.-A,A,b));\\n return p;\\n}\\nvec3 m(f t, f s) {\\n t = floor(mod(t, 7.));\\n if (t == 0.||t == 3.) return c(s,step(1.,t));\\n if (t == 1.||t == 4.) return normalize(h3(s))*mix(1.,h(s*2.117),step(2.,t));\\n if (t == 2.) return fk(s,3.,3.,h(s*2.117));\\n if (t == 5.) return h3(s);\\n return fk(s, 4., 3.,1.);\\n}\\nf e(f p) {\\n if ((p/=.5) < 1.) return .5*pow(p,3.);\\n return .5*(pow((p-2.),3.)+2.);\\n}\\nvec3 b(f t, f s) { return mix(m(t, s), m(t + 1., s), e(fract(time))); }\\nvoid main() {\\n f r = 13., m = 1./r, a = time*.2, A=2.*resolution.y/resolution.x,\\n v = vertexId/vertexCount, i = floor(vertexId/4e3);\\n vec3 p = b(time+i,v*4.+time*.01)*(1.+.5*h(i*.8))+h3(i*.3)*6., e=vec3(cos(a)*r,sin(time),sin(a)*r);\\n f d = length(e), l = 1./d, z=d-dot(p,e)*l;\\n gl_Position=vec4((p.x*e.z - p.z*e.x)*m*A,(p.y*r-dot(p.xz,e.xz)*e.y*m)*l*2.,z-2.,z);\\n v_color = mix(vec4(i/4.+p.y,mod(p.x+i,2.),v*p.z,1),vec4(0,1,0,1),sin(time-i*.5));\\n gl_PointSize = 18./z;\\n}\"}", + "settings": { + "num": 60000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ciccio-and-the-curran/clang", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define T radians(360.)\n#define f float\nf h(f p) {\n vec2 p2 = fract(vec2(p*5.3983, p*5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x*p2.y*95.4337);\n}\nvec3 h3(f s) { return vec3(h(s),h(s*.731),h(s*1.319))*2.-1.; }\nvec2 r(vec2 p,f a) { return vec2(p.x*cos(a)-p.y*sin(a), p.x*sin(a)+p.y*cos(a)); }\nvec3 fk(f s, f x, f y, f ff) {\n vec3 p = vec3(r(vec2(ff*.5,0.),T*h(s*.311)),1);\n p.xz = r(p.xz,T*floor(h(s*.731)*y)/y);\n p.yz = r(p.yz,T*floor(h(s)*x)/x);\n return p;\n}\nvec3 c(f s, f b) {\n f a = h(s * 0.911) * 3.;\n vec3 p = h3(s), A = vec3(1.-step(.5,a));\n A.y = 1.-step(1.5,a) * 1.-A.x;\n A.z = 1.-step(2.5,a) * 1.-A.x * 1.-A.y;\n p = mix(step(0., p)*2.-1.,p,mix(1.-A,A,b));\n return p;\n}\nvec3 m(f t, f s) {\n t = floor(mod(t, 7.));\n if (t == 0.||t == 3.) return c(s,step(1.,t));\n if (t == 1.||t == 4.) return normalize(h3(s))*mix(1.,h(s*2.117),step(2.,t));\n if (t == 2.) return fk(s,3.,3.,h(s*2.117));\n if (t == 5.) return h3(s);\n return fk(s, 4., 3.,1.);\n}\nf e(f p) {\n if ((p/=.5) < 1.) return .5*pow(p,3.);\n return .5*(pow((p-2.),3.)+2.);\n}\nvec3 b(f t, f s) { return mix(m(t, s), m(t + 1., s), e(fract(time))); }\nvoid main() {\n f r = 13., m = 1./r, a = time*.2, A=2.*resolution.y/resolution.x,\n v = vertexId/vertexCount, i = floor(vertexId/4e3);\n vec3 p = b(time+i,v*4.+time*.01)*(1.+.5*h(i*.8))+h3(i*.3)*6., e=vec3(cos(a)*r,sin(time),sin(a)*r);\n f d = length(e), l = 1./d, z=d-dot(p,e)*l;\n gl_Position=vec4((p.x*e.z - p.z*e.x)*m*A,(p.y*r-dot(p.xz,e.xz)*e.y*m)*l*2.,z-2.,z);\n v_color = mix(vec4(i/4.+p.y,mod(p.x+i,2.),v*p.z,1),vec4(0,1,0,1),sin(time-i*.5));\n gl_PointSize = 18./z;\n}" + }, "screenshotURL": "data/images/images-tpn6igvq9nkm2dsi2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KQLkpoBAPGrNrd3XK/art.json b/art/KQLkpoBAPGrNrd3XK/art.json index bdf74087..851e2a54 100644 --- a/art/KQLkpoBAPGrNrd3XK/art.json +++ b/art/KQLkpoBAPGrNrd3XK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][3], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][3], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-z929ey3qev30op9j2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KRmBguLvKHcjPJHpn/art.json b/art/KRmBguLvKHcjPJHpn/art.json index 3c71276a..3e3b8d4c 100644 --- a/art/KRmBguLvKHcjPJHpn/art.json +++ b/art/KRmBguLvKHcjPJHpn/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":25,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thesoftmoon/exister?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.06666666666666667,0.06666666666666667,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float scale = 0.9;\\n vec2 xy = vec2(ux, vy) * scale;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(0., .2, 0., 1.);\\n}\"}", + "settings": { + "num": 25, + "mode": "POINTS", + "sound": "https://soundcloud.com/thesoftmoon/exister?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.06666666666666667, + 0.06666666666666667, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float scale = 0.9;\n vec2 xy = vec2(ux, vy) * scale;\n \n gl_Position = vec4(xy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(0., .2, 0., 1.);\n}" + }, "screenshotURL": "data/images/images-vzwdy476bl07rcfwi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KRpCEmbJ2GTTRtxsR/art.json b/art/KRpCEmbJ2GTTRtxsR/art.json index 7e4c9e07..89348e59 100644 --- a/art/KRpCEmbJ2GTTRtxsR/art.json +++ b/art/KRpCEmbJ2GTTRtxsR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "der", "avatarUrl": "https://secure.gravatar.com/avatar/3edd222097c4b36118a8d5f5ab65ddb6?default=retro&size=200", - "settings": "{\"num\":10404,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float dist(vec2 p1, vec2 p2) {\\n return sqrt(pow(p1.x - p2.x, 2.0) + pow(p1.y - p2.y, 2.0));\\n}\\n\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount));\\n \\n float x = ((mod(vertexId, across) / (across - 1.0)) * 2.0 - 1.0);\\n float y =((floor(vertexId / across) / (across - 1.0)) * 2.0 - 1.0);\\n \\n float distFromCenter = dist(vec2(x, y), vec2(0.0, 0.0));\\n \\n if(1.0 - distFromCenter < 0.0) {\\n return;\\n }\\n \\n float ang = atan(0.0 - y, 0.0 - x);\\n \\n float normX = cos(ang + time * (1.0 - distFromCenter));\\n float normY = sin(ang + time * (1.0 - distFromCenter));\\n \\n float xPos = normX * distFromCenter;\\n float yPos = normY * distFromCenter;\\n \\n float aspect = resolution.y / resolution.x;\\n \\n gl_Position = vec4(xPos * aspect, yPos, 0.0, 1.0);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 10404, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float dist(vec2 p1, vec2 p2) {\n return sqrt(pow(p1.x - p2.x, 2.0) + pow(p1.y - p2.y, 2.0));\n}\n\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount));\n \n float x = ((mod(vertexId, across) / (across - 1.0)) * 2.0 - 1.0);\n float y =((floor(vertexId / across) / (across - 1.0)) * 2.0 - 1.0);\n \n float distFromCenter = dist(vec2(x, y), vec2(0.0, 0.0));\n \n if(1.0 - distFromCenter < 0.0) {\n return;\n }\n \n float ang = atan(0.0 - y, 0.0 - x);\n \n float normX = cos(ang + time * (1.0 - distFromCenter));\n float normY = sin(ang + time * (1.0 - distFromCenter));\n \n float xPos = normX * distFromCenter;\n float yPos = normY * distFromCenter;\n \n float aspect = resolution.y / resolution.x;\n \n gl_Position = vec4(xPos * aspect, yPos, 0.0, 1.0);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-fiknrwvr70oi98kth-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KRuXE4SBCi4kRBG6j/art.json b/art/KRuXE4SBCi4kRBG6j/art.json index d37b4124..e9adfb2d 100644 --- a/art/KRuXE4SBCi4kRBG6j/art.json +++ b/art/KRuXE4SBCi4kRBG6j/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/jutste/fresh-water-original\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.050980392156862744,0.18823529411764706,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(crv(a0), crv(a1), 0);\\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\\n// return vec3(\\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n// 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 3000.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float qn = quadId / quadCount;\\n float ln = lineId / numLines * 50.;\\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, pn), mix(0.0, 0.3, pn))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, pn), mix(0.5, 0.12, pn))).a;\\n \\n \\n float mult = .002;\\n getQuadPoint(\\n //pn + time * 0.5 + ln * .2, \\n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\\n mult,\\n pointId, \\n 0.002 + pow(snd0 + 0.15, 5.0) * 0.05, \\n vec2(\\n pow(0.6 + 0.2, 2.), \\n pow(0.7 + 0.2, 2.)), \\n pos, \\n uv); \\n \\n float across = floor(sqrt(numLines));\\n float down = floor(numLines / across);\\n float xx = mod(lineId, across);\\n float yy = floor(lineId / across);\\n float ux = xx / (across - 1.);\\n float vy = yy / (down - 1.);\\n \\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .15);\\n mat *= rotZ(time * 0.01);\\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\\n gl_Position.xyz /= gl_Position.w;\\n gl_Position.z = -pn;\\n gl_Position.w = 1.;\\n\\n float hue = mix(0.95, 1.5, ln * 0.005 + qn * 00.) + time * 0.01;\\n float sat = 1. + sin(time) * .5 - snd1 * 0.3;\\n float val = pow(snd0 + 0.8, 5.) + snd1;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (pow(snd0 + 0.4, 5.0) + snd1 * 0.5) * pn);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/jutste/fresh-water-original", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.050980392156862744, + 0.18823529411764706, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(crv(a0), crv(a1), 0);\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\n// return vec3(\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n// 0);\n}\n\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 3000.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float qn = quadId / quadCount;\n float ln = lineId / numLines * 50.;\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, pn), mix(0.0, 0.3, pn))).a;\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, pn), mix(0.5, 0.12, pn))).a;\n \n \n float mult = .002;\n getQuadPoint(\n //pn + time * 0.5 + ln * .2, \n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\n mult,\n pointId, \n 0.002 + pow(snd0 + 0.15, 5.0) * 0.05, \n vec2(\n pow(0.6 + 0.2, 2.), \n pow(0.7 + 0.2, 2.)), \n pos, \n uv); \n \n float across = floor(sqrt(numLines));\n float down = floor(numLines / across);\n float xx = mod(lineId, across);\n float yy = floor(lineId / across);\n float ux = xx / (across - 1.);\n float vy = yy / (down - 1.);\n \n float aspect = resolution.x / resolution.y;\n \n mat4 mat = scale(vec3(1, aspect, 1) * .15);\n mat *= rotZ(time * 0.01);\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\n gl_Position.xyz /= gl_Position.w;\n gl_Position.z = -pn;\n gl_Position.w = 1.;\n\n float hue = mix(0.95, 1.5, ln * 0.005 + qn * 00.) + time * 0.01;\n float sat = 1. + sin(time) * .5 - snd1 * 0.3;\n float val = pow(snd0 + 0.8, 5.) + snd1;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (pow(snd0 + 0.4, 5.0) + snd1 * 0.5) * pn);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-51wh6l8cue4tx7wk0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KRwzSvynXozMTXZ7w/art.json b/art/KRwzSvynXozMTXZ7w/art.json index d035e439..d28fb782 100644 --- a/art/KRwzSvynXozMTXZ7w/art.json +++ b/art/KRwzSvynXozMTXZ7w/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/plu-collective/dr-phil\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Dr. Phil\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n \\n return vec2(x, y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 80.;\\n vec2 circleXY = getCirclePoint(vertexId, \\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .02, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 3.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.2);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.85, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = 1.;mix(.3, pow(snd + 0.2, 4.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.2 + pump * 1. / 3.;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/plu-collective/dr-phil", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Dr. Phil\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n \n return vec2(x, y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 80.;\n vec2 circleXY = getCirclePoint(vertexId, \n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .02, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 3.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.2);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.85, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = 1.;mix(.3, pow(snd + 0.2, 4.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.2 + pump * 1. / 3.;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-cu8fxcy7zho46ir4m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KSMjJjpv6c7spHTef/art.json b/art/KSMjJjpv6c7spHTef/art.json index f72f0a5b..9dfa6872 100644 --- a/art/KSMjJjpv6c7spHTef/art.json +++ b/art/KSMjJjpv6c7spHTef/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":50134,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 -1.//KParameter 0.>>-10.\\n#define P4 -1.//KParameter -2.>>2.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (333. *(P2*3.5))*10.;\\n float numQuads = floor( vertexCount/8.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\\n float vy = mod(floor(vertexId / 3.) + floor(vertexId / 3.), 1.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) -( P4 * r);\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, mouse*((qv * PI )));\\n \\n float tm = time * 1.2 -mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 3.) + (mouse.x *13.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0.6);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 0.6);\\n gl_PointSize = 1.;\\n\\n float hue = quadId / 0.66663;\\n float sat = quadId *3.3;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 3.54444);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 50134, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 -1.//KParameter 0.>>-10.\n#define P4 -1.//KParameter -2.>>2.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (333. *(P2*3.5))*10.;\n float numQuads = floor( vertexCount/8.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\n float vy = mod(floor(vertexId / 3.) + floor(vertexId / 3.), 1.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) -( P4 * r);\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, mouse*((qv * PI )));\n \n float tm = time * 1.2 -mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 3.) + (mouse.x *13.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0.6);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 0.6);\n gl_PointSize = 1.;\n\n float hue = quadId / 0.66663;\n float sat = quadId *3.3;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 3.54444);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-e19cjh9y6yuisdoan-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KT6E6Ka96dcuzvJKG/art.json b/art/KT6E6Ka96dcuzvJKG/art.json index 6aa8ad18..117a975b 100644 --- a/art/KT6E6Ka96dcuzvJKG/art.json +++ b/art/KT6E6Ka96dcuzvJKG/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":421,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 4;\\t\\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(vertexId),1.0-acos(cos(time)),0.0,1.0);\\n }\\n\\n gl_PointSize = vertexId/5.0; \\n \\n \\n v_color = vec4(vertexId/500.0,vertexId/255.0,0.5,1);\\n}\"}", + "settings": { + "num": 421, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 4;\t\n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(vertexId),1.0-acos(cos(time)),0.0,1.0);\n }\n\n gl_PointSize = vertexId/5.0; \n \n \n v_color = vec4(vertexId/500.0,vertexId/255.0,0.5,1);\n}" + }, "screenshotURL": "data/images/images-ptsswdpmwfg4pox5c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KTyBEnoxgZWR569eH/art.json b/art/KTyBEnoxgZWR569eH/art.json index 756eb475..c6247eb5 100644 --- a/art/KTyBEnoxgZWR569eH/art.json +++ b/art/KTyBEnoxgZWR569eH/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float NUM_SEGMENTS = floor(mix(3., 10., 0.5 + 0.5 * sin(PI * 2. * fract(time * 0.1))));\\n float NUM_POINTS = NUM_SEGMENTS * 2.;\\n float STEP = 1.;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(0.05, count * 0.0)).a;\\n float offset = count * 0.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset + time * 0.2;\\n float radius = 2.5;\\n float c = cos(angle) * radius;\\n float s = sin(angle) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.0;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n\\n vec4 m = texture2D(touch, vec2(0.0, count * 0.00));\\n vec2 xy = vec2(c, s) + vec2(oC, oS) + m.xy * .5;// + vec2(2. * snd, 0.);\\n gl_Position = vec4(xy * aspect, count * 0.1, count * 0.2);\\n\\n float stripe = \\n mix(0.0, 1.5, step(\\n 0.5, fract(time * 4. + count * .025)));\\n float hue = time * 0.25;\\n float sat = 1. - snd;\\n float val = stripe;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float NUM_SEGMENTS = floor(mix(3., 10., 0.5 + 0.5 * sin(PI * 2. * fract(time * 0.1))));\n float NUM_POINTS = NUM_SEGMENTS * 2.;\n float STEP = 1.;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(0.05, count * 0.0)).a;\n float offset = count * 0.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset + time * 0.2;\n float radius = 2.5;\n float c = cos(angle) * radius;\n float s = sin(angle) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.0;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n\n vec4 m = texture2D(touch, vec2(0.0, count * 0.00));\n vec2 xy = vec2(c, s) + vec2(oC, oS) + m.xy * .5;// + vec2(2. * snd, 0.);\n gl_Position = vec4(xy * aspect, count * 0.1, count * 0.2);\n\n float stripe = \n mix(0.0, 1.5, step(\n 0.5, fract(time * 4. + count * .025)));\n float hue = time * 0.25;\n float sat = 1. - snd;\n float val = stripe;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.1);\n}" + }, "screenshotURL": "data/images/images-wgrinolii03me1opn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KYv8eW5R2AYwLSdtm/art.json b/art/KYv8eW5R2AYwLSdtm/art.json index 8502259c..47aaf064 100644 --- a/art/KYv8eW5R2AYwLSdtm/art.json +++ b/art/KYv8eW5R2AYwLSdtm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "visa-valtteri", "avatarUrl": "https://lh4.googleusercontent.com/-LZnRtqD3Cf4/AAAAAAAAAAI/AAAAAAAAEyw/CB7DLj_ThQA/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/daataa/mitch-murder-breeze\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 1.+time*0.001 - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 10.*time;\\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(time*0.2, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 1.;//0.5 + over * 0.7;\\n float sat = step(0.25,s2)*3.;\\n float val = pow(s2*0.01,0.3);\\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/daataa/mitch-murder-breeze", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 1.+time*0.001 - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\n \n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 10.*time;\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(time*0.2, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 1.;//0.5 + over * 0.7;\n float sat = step(0.25,s2)*3.;\n float val = pow(s2*0.01,0.3);\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\n \tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-hxgx17vj5p8opznao-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KZdmbdYsnSLLCa4bQ/art.json b/art/KZdmbdYsnSLLCa4bQ/art.json index e5575695..69669b14 100644 --- a/art/KZdmbdYsnSLLCa4bQ/art.json +++ b/art/KZdmbdYsnSLLCa4bQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":13961,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/truecast-on-proton-music-guestmix-apsara\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2901960784313726,0.2901960784313726,0.2901960784313726,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n float snd = texture2D(sound, vec2(oC, oS)).a;\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + snd * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 13961, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/djapsara/truecast-on-proton-music-guestmix-apsara", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2901960784313726, + 0.2901960784313726, + 0.2901960784313726, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n float snd = texture2D(sound, vec2(oC, oS)).a;\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + snd * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-wpkpox3zosg9lahy8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ka9eWpFE3Yj86HdYN/art.json b/art/Ka9eWpFE3Yj86HdYN/art.json index e3f850ec..82040614 100644 --- a/art/Ka9eWpFE3Yj86HdYN/art.json +++ b/art/Ka9eWpFE3Yj86HdYN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 5.//KParameter0 -15.>>20.\\n#define parameter1 5.//KParameter1 -15.>>20.\\n#define parameter2 5.//KParameter1 1.>>10.\\n#define parameter3 4.//KParameter1 1.>>10.\\n#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * .5;\\n float sy = cy - circlesPerColumn * 0.5; cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.;sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. - soundTexCoords0.x) + 0.1;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * .5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 10.25 - time * 1. *parameter2) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 5. * r * parameter3 ;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 5.//KParameter0 -15.>>20.\n#define parameter1 5.//KParameter1 -15.>>20.\n#define parameter2 5.//KParameter1 1.>>10.\n#define parameter3 4.//KParameter1 1.>>10.\n#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * .5;\n float sy = cy - circlesPerColumn * 0.5; cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.;sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. - soundTexCoords0.x) + 0.1;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * .5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 10.25 - time * 1. *parameter2) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 5. * r * parameter3 ;\n}" + }, "screenshotURL": "data/images/images-0612poreet0o6jhkl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KeA92CgMaurk37juY/art.json b/art/KeA92CgMaurk37juY/art.json index a82833d7..b8bdfee8 100644 --- a/art/KeA92CgMaurk37juY/art.json +++ b/art/KeA92CgMaurk37juY/art.json @@ -31,7 +31,19 @@ "private": true, "unlisted": false, "username": "gman", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/dr-doug/06-log-sweep-20-to-20k-0db-to\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// octaves\\n\\n#define PI radians(180.)\\n\\nfloat at(float v, float target) {\\n return step(target - 0.95, v) * step(v, target + 0.95);\\n}\\n\\nfloat sample(float u) {\\n return (floor(u * soundRes.x) + 0.5) / soundRes.x;\\n}\\n\\nvoid main() {\\n float numVerts = floor((vertexCount + 3.) / 4.);\\n float lineId = mod(vertexId, 4.);\\n float id = floor(vertexId / 4.);\\n float u = id / numVerts;\\n float u2 = (1. - pow(1. - u, 2.)) * 0.5; \\n \\n /*\\n\\n 1 -> 0.5 -> 0.5\\n 0.9 -> 0.25 -> 0.25\\n 0.8 -> 0.125 -> 0.25\\n\\n */\\n \\n const int numSamples = 32;\\n float s = 0.;\\n for (int ii = 0; ii < numSamples; ++ii) {\\n float u3 = u2 + u2 * (float(ii) / float(numSamples));\\n s += texture2D(sound, vec2(sample(u3), 0.)).a;\\n }\\n float v = s / float(numSamples);\\n float x = u * 2. - 1.;\\n \\n float vs = texture2D(sound, vec2(sample(u), 0.)).a;\\n float vl = log(texture2D(sound, vec2(sample(u), 0.)).a);\\n \\n v = v * (u * 4.);\\n v = mix(v, vs, step(0.5, lineId));\\n v = mix(v, vl, at(2., lineId));\\n \\n gl_Position = vec4(x, v, 0, 1);\\n v_color = vec4(1, u2, 0, 1);\\n v_color = mix(v_color, vec4(0,0,1,1), step(0.5, lineId));\\n v_color = mix(v_color, vec4(0,1,0,1), at(2., lineId));\\n gl_PointSize = 10. * resolution.x / 1680.;\\n \\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "https://soundcloud.com/dr-doug/06-log-sweep-20-to-20k-0db-to", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// octaves\n\n#define PI radians(180.)\n\nfloat at(float v, float target) {\n return step(target - 0.95, v) * step(v, target + 0.95);\n}\n\nfloat sample(float u) {\n return (floor(u * soundRes.x) + 0.5) / soundRes.x;\n}\n\nvoid main() {\n float numVerts = floor((vertexCount + 3.) / 4.);\n float lineId = mod(vertexId, 4.);\n float id = floor(vertexId / 4.);\n float u = id / numVerts;\n float u2 = (1. - pow(1. - u, 2.)) * 0.5; \n \n /*\n\n 1 -> 0.5 -> 0.5\n 0.9 -> 0.25 -> 0.25\n 0.8 -> 0.125 -> 0.25\n\n */\n \n const int numSamples = 32;\n float s = 0.;\n for (int ii = 0; ii < numSamples; ++ii) {\n float u3 = u2 + u2 * (float(ii) / float(numSamples));\n s += texture2D(sound, vec2(sample(u3), 0.)).a;\n }\n float v = s / float(numSamples);\n float x = u * 2. - 1.;\n \n float vs = texture2D(sound, vec2(sample(u), 0.)).a;\n float vl = log(texture2D(sound, vec2(sample(u), 0.)).a);\n \n v = v * (u * 4.);\n v = mix(v, vs, step(0.5, lineId));\n v = mix(v, vl, at(2., lineId));\n \n gl_Position = vec4(x, v, 0, 1);\n v_color = vec4(1, u2, 0, 1);\n v_color = mix(v_color, vec4(0,0,1,1), step(0.5, lineId));\n v_color = mix(v_color, vec4(0,1,0,1), at(2., lineId));\n gl_PointSize = 10. * resolution.x / 1680.;\n \n}" + }, "screenshotURL": "data/images/images-0bptmxah6g8q00jbs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KeyjGeoFSgZNieLtF/art.json b/art/KeyjGeoFSgZNieLtF/art.json index ac60b945..6afdd2fe 100644 --- a/art/KeyjGeoFSgZNieLtF/art.json +++ b/art/KeyjGeoFSgZNieLtF/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n float n = vertexId / vertexCount;\\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \\n float angle = n * 6.28;\\n \\n float avx = 0.5;\\n float axy = 0.2;\\n \\n float dx = cos(angle * time * avx) * n; // + mouse.x;\\n float dy = sin(angle * time * axy) * n; // + mouse.y;\\n \\n gl_Position = vec4(dx, dy, 0.0, abs(cos(snd.a)));\\n gl_PointSize = dy / resolution.y * n * 10.0;\\n v_color = vec4(abs(dy / dx), abs(dx / dy), dy / dx, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n float n = vertexId / vertexCount;\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \n float angle = n * 6.28;\n \n float avx = 0.5;\n float axy = 0.2;\n \n float dx = cos(angle * time * avx) * n; // + mouse.x;\n float dy = sin(angle * time * axy) * n; // + mouse.y;\n \n gl_Position = vec4(dx, dy, 0.0, abs(cos(snd.a)));\n gl_PointSize = dy / resolution.y * n * 10.0;\n v_color = vec4(abs(dy / dx), abs(dx / dy), dy / dx, 1.0);\n}" + }, "screenshotURL": "data/images/images-rv7j2nwch97g8aazg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KgWfhQ8N9LTWDds2b/art.json b/art/KgWfhQ8N9LTWDds2b/art.json index 1b6f5df9..1f23377f 100644 --- a/art/KgWfhQ8N9LTWDds2b/art.json +++ b/art/KgWfhQ8N9LTWDds2b/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"plasma grid\\\" by johanberonius\\n\\nvoid main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.9 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"plasma grid\" by johanberonius\n\nvoid main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.9 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-45sqfjb6u3momy9r8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KgwQJvsXGiER7oBtf/art.json b/art/KgwQJvsXGiER7oBtf/art.json index 69f23d8d..f53d678a 100644 --- a/art/KgwQJvsXGiER7oBtf/art.json +++ b/art/KgwQJvsXGiER7oBtf/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":49807,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DIST 2.0\\n\\nvoid main() {\\n float pointId = (vertexId/vertexCount);\\n float faceId = floor(vertexId / 100.0);\\n\\n /*\\n Face ID:\\n Right - 0\\n Left - 1\\n Top - 2\\n Bottom - 3\\n Front - 4\\n Back - 5\\n */\\n// VertexCount\\n /* vec3 pos = vec3(0.0, mod(pointId, 10.0), 0.5);\\n pos.x = (pointId - pos.y) / 10.0;\\n pos.xy = pos.xy / 10.0 - 0.5;\\n\\n if (mod(faceId, 2.0) == 1.0) pos.z *= -1.0;\\n if (faceId == 0.0 || faceId == 1.0) pos = pos.zyx;\\n if (faceId == 2.0 || faceId == 3.0) pos = pos.xzy;\\n\\n // Set color before transforms so the colors don't slip\\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\\n\\n float c = cos(time), s = sin(time);\\n pos.xz *= mat2(c, s, -s, c);\\n pos.yz *= mat2(c, s, -s, c);\\n pos *= 1.5;\\n\\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\\n gl_Position.x *= resolution.y / resolution.x;\\n gl_PointSize = 5.0 / (EYE_DIST - pos.z);*/\\n \\n float c = cos(time/6.), s = sin(time/6.);\\n vec3 pos = vec3( cos(vertexId), sin(vertexId), 0.5);\\n pos.xy *=pointId;\\n \\tpos.z*=cos(pointId)*sin(time*4.+pointId*2.)*2.;\\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\\n pos.xz *= mat2(c, s, -s, c);\\n pos.yz *= mat2(c, s, -s, c);\\npos *=1.5;\\n\\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\\n gl_PointSize =2.;\\n}\"}", + "settings": { + "num": 49807, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DIST 2.0\n\nvoid main() {\n float pointId = (vertexId/vertexCount);\n float faceId = floor(vertexId / 100.0);\n\n /*\n Face ID:\n Right - 0\n Left - 1\n Top - 2\n Bottom - 3\n Front - 4\n Back - 5\n */\n// VertexCount\n /* vec3 pos = vec3(0.0, mod(pointId, 10.0), 0.5);\n pos.x = (pointId - pos.y) / 10.0;\n pos.xy = pos.xy / 10.0 - 0.5;\n\n if (mod(faceId, 2.0) == 1.0) pos.z *= -1.0;\n if (faceId == 0.0 || faceId == 1.0) pos = pos.zyx;\n if (faceId == 2.0 || faceId == 3.0) pos = pos.xzy;\n\n // Set color before transforms so the colors don't slip\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\n\n float c = cos(time), s = sin(time);\n pos.xz *= mat2(c, s, -s, c);\n pos.yz *= mat2(c, s, -s, c);\n pos *= 1.5;\n\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\n gl_Position.x *= resolution.y / resolution.x;\n gl_PointSize = 5.0 / (EYE_DIST - pos.z);*/\n \n float c = cos(time/6.), s = sin(time/6.);\n vec3 pos = vec3( cos(vertexId), sin(vertexId), 0.5);\n pos.xy *=pointId;\n \tpos.z*=cos(pointId)*sin(time*4.+pointId*2.)*2.;\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\n pos.xz *= mat2(c, s, -s, c);\n pos.yz *= mat2(c, s, -s, c);\npos *=1.5;\n\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\n gl_PointSize =2.;\n}" + }, "screenshotURL": "data/images/images-0j0toyhlvandw4d4m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KivkeanM6qFjxFhon/art.json b/art/KivkeanM6qFjxFhon/art.json index f615f838..0d2dcec9 100644 --- a/art/KivkeanM6qFjxFhon/art.json +++ b/art/KivkeanM6qFjxFhon/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minjae-yu", "avatarUrl": "https://avatars.githubusercontent.com/minjae-yu?s=200", - "settings": "{\"num\":48610,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : MINJAE YU\\n//Assignment : Colors\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.05;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.2 + x * y * 0.02 * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = sin(time);\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 48610, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : MINJAE YU\n//Assignment : Colors\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.05;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.2 + x * y * 0.02 * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = sin(time);\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-86jd12ybyvue0pmss-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KjC8ebmWp9gkJC7dp/art.json b/art/KjC8ebmWp9gkJC7dp/art.json index 7d6e5620..10573777 100644 --- a/art/KjC8ebmWp9gkJC7dp/art.json +++ b/art/KjC8ebmWp9gkJC7dp/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hzktqr", "avatarUrl": "https://secure.gravatar.com/avatar/c5ca7d7d4b527ab960b78f57cfbe61c2?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-ad11jb5ai68en4duy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KjuuMXE22tpxPbTLE/art.json b/art/KjuuMXE22tpxPbTLE/art.json index 1ca55fc3..797731be 100644 --- a/art/KjuuMXE22tpxPbTLE/art.json +++ b/art/KjuuMXE22tpxPbTLE/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":70000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define kNumVertX 15.0\\n#define kNumVertY 15.0\\n//#define kNumVertZ\\n#define kScale 0.2\\n#define kTranslate vec3(-1.5)\\n\\nvec3 hash3(vec3 v) {\\n return fract(sin(v) * vec3(43758.5453123, 12345.6789012,76543.2109876));\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x;\\n rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nmat4 lookat(vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\\n}\\n\\nvec3 voxelPosToWorld(vec3 vxlp) {\\n return vxlp * kScale + kTranslate;\\n}\\n\\nfloat blobSphere(vec3 p, float r) {\\n return 1.0 / (1.0 + pow(length(p / r), 2.0));\\n}\\n\\nfloat dePig(in vec3 p)\\n{ \\n p.y += 0.3 * smoothstep( 0.2, 0.0, length(abs(p.zx) - vec2(0.4, 0.4))) * (1.0 - step(0.0, p.y));\\n p.y += -0.2 * smoothstep(0.15, 0.0, length(abs(p.zx - vec2(0.4,0.0)) - vec2(0.0, 0.4))) * step(0.0, p.y); \\n p.z += -0.15 * smoothstep( 0.4, 0.3, length(p.yx)) * step(0.0, p.z);\\n p.z += 0.15 * smoothstep( 0.1, 0.0, length(abs(p.yx) - vec2(0.0, 0.15))) * step(0.0, p.z);\\n p.z += 0.1 * smoothstep( 0.1, 0.0, length(abs(p.yx - vec2(0.4,0.0)) - vec2(0.0, 0.3))) * step(0.0, p.z);\\n p.z += 0.15 * smoothstep( 0.1, 0.0, length(p.yx - vec2(0.35,0.0))) * (1.0 - step(0.0, p.z));\\n return 0.6 * (length(p) - 1.0);\\n}\\n\\n\\nfloat scene(vec3 p) {\\n \\treturn dePig(p);\\n const float kThreshould = 0.5;\\n float d = 0.0;\\n d += blobSphere(p + sin(time * vec3(1.5, 2.1, 0.5)) * vec3(0.5, 0.6, 0.3), 0.4);\\n d += blobSphere(p + sin(time * vec3(2.3, 1.2, 1.7)) * vec3(0.6, 0.5, 0.8), 0.2);\\n d += blobSphere(p + sin(time * vec3(0.3, 1.2, 2.7)) * vec3(0.5, 0.4, 0.5), 0.3);\\n //d += 1.0 / (1.0 + pow(length(p * 2.0), 2.0));\\n return kThreshould - d;\\n}\\n\\nvec3 sceneNormal(vec3 p) {\\n vec3 EPS = vec3(0.01, 0.0, 0.0);\\n vec3 n;\\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\\n return normalize(n);\\n}\\n\\nvec3 smoothVertex(vec3 ip) {\\n vec3 p = ip;\\n vec3 n = sceneNormal(p);\\n for(int i = 0; i < 8; i++) {\\n float d = scene(p);\\n p -= n * d;\\n if(abs(d) < 0.01) { break; }\\n }\\n return p;\\n}\\n\\nvec4 shading(vec3 p, vec3 n) {\\n vec3 kDc = vec3(0.6, 0.05, 0.15);\\n vec3 kSp = vec3(1.0, 1.0, 1.0) * 0.2;\\n vec3 kFc = vec3(0.3,0.1,0.15);\\n vec3 L = normalize(vec3(1.0, 1.0, 1.0));\\n float d = dot(L, n);\\n float s = 0.0;\\n if(d > 0.0) {\\n vec3 h = (normalize(-p) + L) * 0.5;\\n s = pow(max(0.0, dot(h, n)), 4.0);\\n }\\n float kR0 = 0.02;\\n float F = kR0 + (1.0 - kR0) * pow(1.0 - max(0.0, dot(normalize(-p), n)), 5.0);\\n \\n return vec4((max(0.0, d) * 0.6 + 0.2) * kDc + s * kSp + F * kFc, 1.0);\\n}\\n\\nvoid main() {\\n // vertex index in quad face (2 triangles: 0-5)\\n float faceVertId = mod(vertexId, 6.0);\\n // face index\\n float faceId = floor(vertexId / 6.0);\\n // fece index in corner\\n float cornerFaceId = mod(faceId, 3.0);\\n // edge index in corner\\n float cornerEdgeId = mod(faceId, 3.0);\\n // corner index (1 corner = 3 faces = 3 * 6 verts)\\n float cornerId = floor(vertexId / 18.0);\\n // corner position\\n vec3 cornerPos;\\n cornerPos.x = mod(cornerId, kNumVertX);\\n cornerPos.y = mod(floor(cornerId / kNumVertX), kNumVertY);\\n cornerPos.z = mod(floor(cornerId / (kNumVertX * kNumVertY)), kNumVertY);\\n \\n vec3 faceNormal;\\n vec3 faceTangent;\\n vec3 faceCotangent;\\n vec3 faceColor;\\n if(cornerEdgeId == 0.0) {\\n faceNormal = vec3(1.0, 0.0, 0.0);\\n faceTangent = vec3(0.0, 0.0, -1.0);\\n faceCotangent = vec3(0.0, 1.0, 0.0);\\n } else if(cornerEdgeId == 1.0) {\\n faceNormal = vec3(0.0, 1.0, 0.0);\\n faceTangent = vec3(1.0, 0.0, 0.0);\\n faceCotangent = vec3(0.0, 0.0, -1.0);\\n } else {\\n faceNormal = vec3(0.0, 0.0, 1.0);\\n faceTangent = vec3(1.0, 0.0, 0.0);\\n faceCotangent = vec3(0.0, 1.0, 0.0);\\n }\\n vec3 anotherPos = cornerPos + faceNormal;\\n \\n // sampling points\\n vec3 p0 = voxelPosToWorld(cornerPos);\\n vec3 p1 = voxelPosToWorld(anotherPos);\\n \\n // field value\\n float d0 = scene(p0);\\n float d1 = scene(p1);\\n \\n vec3 p;\\n vec3 vertNorm;\\n \\n if(d0 * d1 > 0.0) {\\n // no face\\n p = p0;\\n vertNorm = vec3(1.0, 1.0, 1.0);\\n } else {\\n // have a face\\n if(d1 < d0) {\\n // 0->1 is standard normal.\\n // otherwise flip triangle\\n if(faceVertId == 0.0) {\\n faceVertId = 2.0;\\n } else if(faceVertId == 2.0) {\\n faceVertId = 0.0;\\n } else if(faceVertId == 3.0) {\\n faceVertId = 5.0;\\n } else if(faceVertId == 5.0) {\\n faceVertId = 3.0;\\n }\\n faceNormal *= -1.0;\\n }\\n \\n /*\\n face\\n 2 4-5\\n |\\\\ \\\\|\\n 0-1 3\\n */\\n float kFaceSize = mix(0.45, 0.5, clamp(cos(time * 1.5) * 4.0 + 0.5, 0.0, 1.0));\\n vec3 edgeMidPos = (cornerPos + anotherPos) * 0.5;\\n vec3 faceVertPos;\\n if(faceVertId == 0.0) {\\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * -kFaceSize;\\n } else if(faceVertId == 1.0) {\\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\\n } else if(faceVertId == 2.0) {\\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\\n } else if(faceVertId == 3.0) {\\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\\n } else if(faceVertId == 4.0) {\\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\\n } else if(faceVertId == 5.0) {\\n faceVertPos = edgeMidPos + faceTangent * 0.5 + faceCotangent * 0.5;\\n }\\n p = voxelPosToWorld(faceVertPos);\\n \\n // smoothing\\n vec3 sp = smoothVertex(p);\\n vertNorm = sceneNormal(p);\\n \\n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\\n p = mix(p, sp, vmix);\\n vertNorm = mix(faceNormal, vertNorm, vmix);\\n }\\n \\n vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.5), -mouse.x * 2.0), mouse.y);\\n //vec3 eye = vec3(0.0, 0.0, 3.0);\\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n vec3 viewPos = (viewMat * vec4(p, 1.0)).xyz;\\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\\n \\n gl_Position = perspective(viewPos, 60.0, 0.1, 10.0);\\n gl_PointSize = 2.0;\\n //v_color = vec4(abs(faceNormal), 1.0);\\n //v_color = vec4(vertNorm * 0.5 + 0.5, 1.0);\\n //v_color = vec4(viewNorm * 0.5 + 0.5, 1.0);\\n v_color = shading(viewPos, viewNorm);\\n}\\n\"}", + "settings": { + "num": 70000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n\n#define kNumVertX 15.0\n#define kNumVertY 15.0\n//#define kNumVertZ\n#define kScale 0.2\n#define kTranslate vec3(-1.5)\n\nvec3 hash3(vec3 v) {\n return fract(sin(v) * vec3(43758.5453123, 12345.6789012,76543.2109876));\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x;\n rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nmat4 lookat(vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\n}\n\nvec3 voxelPosToWorld(vec3 vxlp) {\n return vxlp * kScale + kTranslate;\n}\n\nfloat blobSphere(vec3 p, float r) {\n return 1.0 / (1.0 + pow(length(p / r), 2.0));\n}\n\nfloat dePig(in vec3 p)\n{ \n p.y += 0.3 * smoothstep( 0.2, 0.0, length(abs(p.zx) - vec2(0.4, 0.4))) * (1.0 - step(0.0, p.y));\n p.y += -0.2 * smoothstep(0.15, 0.0, length(abs(p.zx - vec2(0.4,0.0)) - vec2(0.0, 0.4))) * step(0.0, p.y); \n p.z += -0.15 * smoothstep( 0.4, 0.3, length(p.yx)) * step(0.0, p.z);\n p.z += 0.15 * smoothstep( 0.1, 0.0, length(abs(p.yx) - vec2(0.0, 0.15))) * step(0.0, p.z);\n p.z += 0.1 * smoothstep( 0.1, 0.0, length(abs(p.yx - vec2(0.4,0.0)) - vec2(0.0, 0.3))) * step(0.0, p.z);\n p.z += 0.15 * smoothstep( 0.1, 0.0, length(p.yx - vec2(0.35,0.0))) * (1.0 - step(0.0, p.z));\n return 0.6 * (length(p) - 1.0);\n}\n\n\nfloat scene(vec3 p) {\n \treturn dePig(p);\n const float kThreshould = 0.5;\n float d = 0.0;\n d += blobSphere(p + sin(time * vec3(1.5, 2.1, 0.5)) * vec3(0.5, 0.6, 0.3), 0.4);\n d += blobSphere(p + sin(time * vec3(2.3, 1.2, 1.7)) * vec3(0.6, 0.5, 0.8), 0.2);\n d += blobSphere(p + sin(time * vec3(0.3, 1.2, 2.7)) * vec3(0.5, 0.4, 0.5), 0.3);\n //d += 1.0 / (1.0 + pow(length(p * 2.0), 2.0));\n return kThreshould - d;\n}\n\nvec3 sceneNormal(vec3 p) {\n vec3 EPS = vec3(0.01, 0.0, 0.0);\n vec3 n;\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\n return normalize(n);\n}\n\nvec3 smoothVertex(vec3 ip) {\n vec3 p = ip;\n vec3 n = sceneNormal(p);\n for(int i = 0; i < 8; i++) {\n float d = scene(p);\n p -= n * d;\n if(abs(d) < 0.01) { break; }\n }\n return p;\n}\n\nvec4 shading(vec3 p, vec3 n) {\n vec3 kDc = vec3(0.6, 0.05, 0.15);\n vec3 kSp = vec3(1.0, 1.0, 1.0) * 0.2;\n vec3 kFc = vec3(0.3,0.1,0.15);\n vec3 L = normalize(vec3(1.0, 1.0, 1.0));\n float d = dot(L, n);\n float s = 0.0;\n if(d > 0.0) {\n vec3 h = (normalize(-p) + L) * 0.5;\n s = pow(max(0.0, dot(h, n)), 4.0);\n }\n float kR0 = 0.02;\n float F = kR0 + (1.0 - kR0) * pow(1.0 - max(0.0, dot(normalize(-p), n)), 5.0);\n \n return vec4((max(0.0, d) * 0.6 + 0.2) * kDc + s * kSp + F * kFc, 1.0);\n}\n\nvoid main() {\n // vertex index in quad face (2 triangles: 0-5)\n float faceVertId = mod(vertexId, 6.0);\n // face index\n float faceId = floor(vertexId / 6.0);\n // fece index in corner\n float cornerFaceId = mod(faceId, 3.0);\n // edge index in corner\n float cornerEdgeId = mod(faceId, 3.0);\n // corner index (1 corner = 3 faces = 3 * 6 verts)\n float cornerId = floor(vertexId / 18.0);\n // corner position\n vec3 cornerPos;\n cornerPos.x = mod(cornerId, kNumVertX);\n cornerPos.y = mod(floor(cornerId / kNumVertX), kNumVertY);\n cornerPos.z = mod(floor(cornerId / (kNumVertX * kNumVertY)), kNumVertY);\n \n vec3 faceNormal;\n vec3 faceTangent;\n vec3 faceCotangent;\n vec3 faceColor;\n if(cornerEdgeId == 0.0) {\n faceNormal = vec3(1.0, 0.0, 0.0);\n faceTangent = vec3(0.0, 0.0, -1.0);\n faceCotangent = vec3(0.0, 1.0, 0.0);\n } else if(cornerEdgeId == 1.0) {\n faceNormal = vec3(0.0, 1.0, 0.0);\n faceTangent = vec3(1.0, 0.0, 0.0);\n faceCotangent = vec3(0.0, 0.0, -1.0);\n } else {\n faceNormal = vec3(0.0, 0.0, 1.0);\n faceTangent = vec3(1.0, 0.0, 0.0);\n faceCotangent = vec3(0.0, 1.0, 0.0);\n }\n vec3 anotherPos = cornerPos + faceNormal;\n \n // sampling points\n vec3 p0 = voxelPosToWorld(cornerPos);\n vec3 p1 = voxelPosToWorld(anotherPos);\n \n // field value\n float d0 = scene(p0);\n float d1 = scene(p1);\n \n vec3 p;\n vec3 vertNorm;\n \n if(d0 * d1 > 0.0) {\n // no face\n p = p0;\n vertNorm = vec3(1.0, 1.0, 1.0);\n } else {\n // have a face\n if(d1 < d0) {\n // 0->1 is standard normal.\n // otherwise flip triangle\n if(faceVertId == 0.0) {\n faceVertId = 2.0;\n } else if(faceVertId == 2.0) {\n faceVertId = 0.0;\n } else if(faceVertId == 3.0) {\n faceVertId = 5.0;\n } else if(faceVertId == 5.0) {\n faceVertId = 3.0;\n }\n faceNormal *= -1.0;\n }\n \n /*\n face\n 2 4-5\n |\\ \\|\n 0-1 3\n */\n float kFaceSize = mix(0.45, 0.5, clamp(cos(time * 1.5) * 4.0 + 0.5, 0.0, 1.0));\n vec3 edgeMidPos = (cornerPos + anotherPos) * 0.5;\n vec3 faceVertPos;\n if(faceVertId == 0.0) {\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * -kFaceSize;\n } else if(faceVertId == 1.0) {\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\n } else if(faceVertId == 2.0) {\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\n } else if(faceVertId == 3.0) {\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\n } else if(faceVertId == 4.0) {\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\n } else if(faceVertId == 5.0) {\n faceVertPos = edgeMidPos + faceTangent * 0.5 + faceCotangent * 0.5;\n }\n p = voxelPosToWorld(faceVertPos);\n \n // smoothing\n vec3 sp = smoothVertex(p);\n vertNorm = sceneNormal(p);\n \n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\n p = mix(p, sp, vmix);\n vertNorm = mix(faceNormal, vertNorm, vmix);\n }\n \n vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.5), -mouse.x * 2.0), mouse.y);\n //vec3 eye = vec3(0.0, 0.0, 3.0);\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n vec3 viewPos = (viewMat * vec4(p, 1.0)).xyz;\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\n \n gl_Position = perspective(viewPos, 60.0, 0.1, 10.0);\n gl_PointSize = 2.0;\n //v_color = vec4(abs(faceNormal), 1.0);\n //v_color = vec4(vertNorm * 0.5 + 0.5, 1.0);\n //v_color = vec4(viewNorm * 0.5 + 0.5, 1.0);\n v_color = shading(viewPos, viewNorm);\n}\n" + }, "screenshotURL": "data/images/images-m64ou2fr7uki1riz1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KmNbwStFkxfRGJ2Bs/art.json b/art/KmNbwStFkxfRGJ2Bs/art.json index 13ebc67b..912bee29 100644 --- a/art/KmNbwStFkxfRGJ2Bs/art.json +++ b/art/KmNbwStFkxfRGJ2Bs/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 67.//KParameter0 0.>>1000.\\n#define KP1 6.//KParameter1 0.0>>22.\\n#define KP2 9.0//KParameter2 -6.0>>10.\\n#define KP3 -0.01//KParameter3 -8.000>>0.5\\n#define KP4 11.2//KParameter4 0.000>>5.\\n#define KP5 1130.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=338000\\n#define PI radians(180. -KP1)\\n\\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 67.//KParameter0 0.>>1000.\n#define KP1 6.//KParameter1 0.0>>22.\n#define KP2 9.0//KParameter2 -6.0>>10.\n#define KP3 -0.01//KParameter3 -8.000>>0.5\n#define KP4 11.2//KParameter4 0.000>>5.\n#define KP5 1130.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=338000\n#define PI radians(180. -KP1)\n\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-hvgqy0t44i8h3o9gr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KmPLGgqiLsMdk7QpB/art.json b/art/KmPLGgqiLsMdk7QpB/art.json index a0c07c0c..a34a6793 100644 --- a/art/KmPLGgqiLsMdk7QpB/art.json +++ b/art/KmPLGgqiLsMdk7QpB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9355,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .1//KParameter .1>>2.\\n#define PointSizeValue 1.13//KParameter 1.>>4.\\n#define deltaFactor0 0.//KParameter 0.>>1.\\n#define deltaFactor1 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n\\n//KDrawmode=GL_POINTS\\n\\n\\nvec3 osc3(float t, float i)\\n{\\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 osc3Comb(float t, float i) {\\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\\n}\\n\\nvec3 incr(float _t, float _i, vec3 _add, float _l)\\n{\\n vec3 pos = osc3Comb(_t,_i)+_add;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/2.) );\\n \\n\\n float t = time*timeFactor;\\n float i = localVertexId;\\n\\n vec3 pos = osc3Comb(t,i);\\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\\n \\n \\n for (float f = 0.; f < 10.; f++) \\n {\\n\\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\\n }\\n \\n posDelta += incr(t,i,posDelta,0.2);\\n \\n pos -= osc3(t,-1.)*posComp0;\\n \\n pos += posDelta;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .9;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n \\n if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\\n\\n}\\n\"}", + "settings": { + "num": 9355, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .1//KParameter .1>>2.\n#define PointSizeValue 1.13//KParameter 1.>>4.\n#define deltaFactor0 0.//KParameter 0.>>1.\n#define deltaFactor1 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n\n//KDrawmode=GL_POINTS\n\n\nvec3 osc3(float t, float i)\n{\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 osc3Comb(float t, float i) {\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\n}\n\nvec3 incr(float _t, float _i, vec3 _add, float _l)\n{\n vec3 pos = osc3Comb(_t,_i)+_add;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/2.) );\n \n\n float t = time*timeFactor;\n float i = localVertexId;\n\n vec3 pos = osc3Comb(t,i);\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\n \n \n for (float f = 0.; f < 10.; f++) \n {\n\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\n }\n \n posDelta += incr(t,i,posDelta,0.2);\n \n pos -= osc3(t,-1.)*posComp0;\n \n pos += posDelta;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .9;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n \n if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\n\n}\n" + }, "screenshotURL": "data/images/images-4iugfltq73592b12b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KmzEiJEqjGKKKKFCN/art.json b/art/KmzEiJEqjGKKKKFCN/art.json index f4c75736..08627a04 100644 --- a/art/KmzEiJEqjGKKKKFCN/art.json +++ b/art/KmzEiJEqjGKKKKFCN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":17711,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.054901960784313725,0.0392156862745098,0.06274509803921569,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n// Seulbin Seo\\n// Exercise Audio Reactive Art 2\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main ()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float count = floor(vertexId / NUM_POINTS);\\n \\n float ux = cos((count * 0.0) + time * 0.4 + count * 0.1) * (count * 0.001); //u * 2. - 1. + xoff;\\n float vy = sin((count * 0.0) + time + count * 0.1) * (count * 0.001); ///v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy)* 1.3;\\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(sv, su));\\n float snd = texture2D(sound, vec2(fract(count / 128.), fract(count / 20000.))).a; //au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue =count * 1.001 + time * 0.01; // + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);\\n float val =mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 17711, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.054901960784313725, + 0.0392156862745098, + 0.06274509803921569, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n// Seulbin Seo\n// Exercise Audio Reactive Art 2\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main ()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float count = floor(vertexId / NUM_POINTS);\n \n float ux = cos((count * 0.0) + time * 0.4 + count * 0.1) * (count * 0.001); //u * 2. - 1. + xoff;\n float vy = sin((count * 0.0) + time + count * 0.1) * (count * 0.001); ///v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy)* 1.3;\n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(sv, su));\n float snd = texture2D(sound, vec2(fract(count / 128.), fract(count / 20000.))).a; //au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue =count * 1.001 + time * 0.01; // + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);\n float val =mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4 (hav2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-0ewettubie35s3flt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KnBXy8WqLABdJzqxA/art.json b/art/KnBXy8WqLABdJzqxA/art.json index 2d444ae7..eb822b67 100644 --- a/art/KnBXy8WqLABdJzqxA/art.json +++ b/art/KnBXy8WqLABdJzqxA/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width = 10.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n gl_Position = vec4(u, v, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width = 10.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n gl_Position = vec4(u, v, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-o4v3q1tp2ar7uiik6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KoGGiKxguyZYonJzH/art.json b/art/KoGGiKxguyZYonJzH/art.json index e0a28c28..e5a90973 100644 --- a/art/KoGGiKxguyZYonJzH/art.json +++ b/art/KoGGiKxguyZYonJzH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "w.chae", "avatarUrl": "https://secure.gravatar.com/avatar/e33886e1d2ddd9c8199ae2b5bbb15df9?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Wonhyeong Chae\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\nvoid main() {\\nfloat down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float colorModRed = abs(sin(time * 0.5));\\n float colorModGreen = abs(tan(time * 0.5));\\n float colorModBlue = abs(cos(time * 0.5));\\n \\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\\n\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Wonhyeong Chae\n// Exercise Making A Grid\n// CS250 Spring 2022\n\nvoid main() {\nfloat down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float colorModRed = abs(sin(time * 0.5));\n float colorModGreen = abs(tan(time * 0.5));\n float colorModBlue = abs(cos(time * 0.5));\n \n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\n\n \n}" + }, "screenshotURL": "data/images/images-465o0gyaacj7yqh76-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KokxqxAL7cGNXEh47/art.json b/art/KokxqxAL7cGNXEh47/art.json index 75024cbd..51236de6 100644 --- a/art/KokxqxAL7cGNXEh47/art.json +++ b/art/KokxqxAL7cGNXEh47/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\\n{\\n vec2 finalRes = vec2(1.,1.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n _maxvertexCount = floor(vertexCount*ratioXforY);\\n \\n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\\n \\n return vec2(finalRes.x,finalRes.x/ratioXforY);\\n}\\n \\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n //float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n //float ratio = resolution.y/numAcrossDown;\\n \\n //float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n float x = mod(finalVertexId, finalResolution.x);\\n float y = floor(finalVertexId / finalResolution.y);\\n \\n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\\n float v = (y / finalResolution.y);\\n \\n float snd = texture2D(sound, vec2(0., v)).a;\\n \\n //float sndXOffset = 0.;\\n \\n float sndXOffset = snd;\\n if(u>0.5)\\n sndXOffset = -snd;\\n \\n \\n float ux = sndXOffset+( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\\n \\n float sndYOffset = 0.;\\n /*\\n float sndYOffset = snd;\\n if(v>0.5)\\n sndYOffset = -snd;\\n */\\n float vy = sndYOffset+( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\\n \\n \\n \\n \\n //apply fragment logic\\n\\n vec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n \\n \\n\\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\n{\n vec2 finalRes = vec2(1.,1.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n _maxvertexCount = floor(vertexCount*ratioXforY);\n \n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\n \n return vec2(finalRes.x,finalRes.x/ratioXforY);\n}\n \nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n //float numAcrossDown = floor(sqrt(finalVertexCount));\n \n //float ratio = resolution.y/numAcrossDown;\n \n //float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n float x = mod(finalVertexId, finalResolution.x);\n float y = floor(finalVertexId / finalResolution.y);\n \n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\n float v = (y / finalResolution.y);\n \n float snd = texture2D(sound, vec2(0., v)).a;\n \n //float sndXOffset = 0.;\n \n float sndXOffset = snd;\n if(u>0.5)\n sndXOffset = -snd;\n \n \n float ux = sndXOffset+( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\n \n float sndYOffset = 0.;\n /*\n float sndYOffset = snd;\n if(v>0.5)\n sndYOffset = -snd;\n */\n float vy = sndYOffset+( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\n \n \n \n \n //apply fragment logic\n\n vec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n \n \n\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-1wgcg8gvu7meqzu8f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KouaGmh83NF5FCHdM/art.json b/art/KouaGmh83NF5FCHdM/art.json index 724312ec..a3f17db7 100644 --- a/art/KouaGmh83NF5FCHdM/art.json +++ b/art/KouaGmh83NF5FCHdM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.7686274509803922,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.7686274509803922, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-c0cnzc68g5xb9rpmr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KpCz9hjoFif9i3TvM/art.json b/art/KpCz9hjoFif9i3TvM/art.json index aa92e121..33f550b2 100644 --- a/art/KpCz9hjoFif9i3TvM/art.json +++ b/art/KpCz9hjoFif9i3TvM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float n = 30.0;\\n float angle = (x/n)*2.0*radians(360.0);\\n float circleWidth = 0.5;\\n float radio = 1.0 + y*1.0;\\n \\n float xOffset = radio*cos(angle);\\n float yOffset = radio*sin(angle);\\n vec2 xy = vec2(xOffset, yOffset) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n \\n // E2\\n /*\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n */\\n \\n // E1\\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 16, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float n = 30.0;\n float angle = (x/n)*2.0*radians(360.0);\n float circleWidth = 0.5;\n float radio = 1.0 + y*1.0;\n \n float xOffset = radio*cos(angle);\n float yOffset = radio*sin(angle);\n vec2 xy = vec2(xOffset, yOffset) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n \n // E2\n /*\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n */\n \n // E1\n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-6kxyt3je0wd3g468z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KpZcShvoy64nZQwG7/art.json b/art/KpZcShvoy64nZQwG7/art.json index 414a2d68..9912946b 100644 --- a/art/KpZcShvoy64nZQwG7/art.json +++ b/art/KpZcShvoy64nZQwG7/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.13725490196078433,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\\n vertexId;\\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\\n float x = mod(vertexId, across);\\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1., 0., 0., 1.);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.13725490196078433, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\n vertexId;\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\n float x = mod(vertexId, across);\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n gl_Position = vec4(ux, vy, 0., 1.);\n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1., 0., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-jbwi4f8sjrm2kjrz9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Kq2X2rn957ZFHdph9/art.json b/art/Kq2X2rn957ZFHdph9/art.json index 1b94c723..c416713d 100644 --- a/art/Kq2X2rn957ZFHdph9/art.json +++ b/art/Kq2X2rn957ZFHdph9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "soumakdev", "avatarUrl": "https://avatars.githubusercontent.com/soumakdev?s=200", - "settings": "{\"num\":4137,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/anuv-jain/mishri\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = 0.5 - x / (across -1.);\\n float v = 0.5 - y / (across - 1.);\\n\\n \\n gl_Position = vec4(u,v,0,1);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x /600.;\\n \\n v_color = vec4(1, 0, 0,1);\\n}\"}", + "settings": { + "num": 4137, + "mode": "POINTS", + "sound": "https://soundcloud.com/anuv-jain/mishri", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = 0.5 - x / (across -1.);\n float v = 0.5 - y / (across - 1.);\n\n \n gl_Position = vec4(u,v,0,1);\n \n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x /600.;\n \n v_color = vec4(1, 0, 0,1);\n}" + }, "screenshotURL": "data/images/images-qquzu2r3ux4zol3ey-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KsdyG6xS6Dzvyi2wN/art.json b/art/KsdyG6xS6Dzvyi2wN/art.json index 13d26e14..8f374fde 100644 --- a/art/KsdyG6xS6Dzvyi2wN/art.json +++ b/art/KsdyG6xS6Dzvyi2wN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * 1.319)) * 2. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * 1.319)) * 2. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-tjlfjn51z6mq5edzk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/KvFyruyQSz6mfh8jg/art.json b/art/KvFyruyQSz6mfh8jg/art.json index 03b5e6e8..40169d1e 100644 --- a/art/KvFyruyQSz6mfh8jg/art.json +++ b/art/KvFyruyQSz6mfh8jg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":3677,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat2 Rotate2D(float x) {\\n float a=sin(x), b=cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main () {\\n vec3 pos = vec3(vertexId/vertexCount, 0.0, 0.0);\\n pos.xy*= Rotate2D(sin(time+vertexId*0.1));\\n pos.xy*= Rotate2D(3.14159/2.0);\\n pos.y -= 0.3;\\n vec3 clr = vec3(pos.x-0.2, pos.y-1.0, -pos.x)+0.5;\\n \\n gl_PointSize = 6.0; /* if points avaible */\\n gl_Position = vec4(pos.xy, pos.z, 1.0);\\n v_color = vec4(clr, 1.0);\\n}\"}", + "settings": { + "num": 3677, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat2 Rotate2D(float x) {\n float a=sin(x), b=cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main () {\n vec3 pos = vec3(vertexId/vertexCount, 0.0, 0.0);\n pos.xy*= Rotate2D(sin(time+vertexId*0.1));\n pos.xy*= Rotate2D(3.14159/2.0);\n pos.y -= 0.3;\n vec3 clr = vec3(pos.x-0.2, pos.y-1.0, -pos.x)+0.5;\n \n gl_PointSize = 6.0; /* if points avaible */\n gl_Position = vec4(pos.xy, pos.z, 1.0);\n v_color = vec4(clr, 1.0);\n}" + }, "screenshotURL": "data/images/images-xvsfguth18jdiw431-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Kwq7Qw7tBHGz5oiy3/art.json b/art/Kwq7Qw7tBHGz5oiy3/art.json index c10fafed..bf4e3f0a 100644 --- a/art/Kwq7Qw7tBHGz5oiy3/art.json +++ b/art/Kwq7Qw7tBHGz5oiy3/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "w.chae", "avatarUrl": "https://secure.gravatar.com/avatar/e33886e1d2ddd9c8199ae2b5bbb15df9?default=retro&size=200", - "settings": "{\"num\":26669,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Wonhyeong Chae\\n// Exercise Circles from triangles\\n// CS250 Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans, float spreading) {\\n // Update the translation transformation with spreading effect\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans * spreading, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) { \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n \\n // Add spreading effect to the translation\\n float spreading = 1.0 + (snd * 0.5); // Adjust the spreading factor as desired\\n mat *= trans(vec3(ux, vy, 0) * 1.4, spreading);\\n \\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 26669, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Wonhyeong Chae\n// Exercise Circles from triangles\n// CS250 Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans, float spreading) {\n // Update the translation transformation with spreading effect\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans * spreading, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) { \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n \n // Add spreading effect to the translation\n float spreading = 1.0 + (snd * 0.5); // Adjust the spreading factor as desired\n mat *= trans(vec3(ux, vy, 0) * 1.4, spreading);\n \n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-i62nkqkjmyc48ox32-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Kx8LRqN4KEH3xcg9Q/art.json b/art/Kx8LRqN4KEH3xcg9Q/art.json index fbe2f92a..1c9531d7 100644 --- a/art/Kx8LRqN4KEH3xcg9Q/art.json +++ b/art/Kx8LRqN4KEH3xcg9Q/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27058823529411763,0.23921568627450981,0.6823529411764706,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Making a Grid\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27058823529411763, + 0.23921568627450981, + 0.6823529411764706, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Making a Grid\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-9c76pih5xn28dsktg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Kxv3hXqcQJecCkWdp/art.json b/art/Kxv3hXqcQJecCkWdp/art.json index 894c8d37..081fc1ab 100644 --- a/art/Kxv3hXqcQJecCkWdp/art.json +++ b/art/Kxv3hXqcQJecCkWdp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "phi16", "avatarUrl": "https://lh6.googleusercontent.com/-EMFaalZS9Rg/AAAAAAAAAAI/AAAAAAAAAjg/SGZ_70U2Idc/photo.jpg", - "settings": "{\"num\":80000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rand(vec2 co) {\\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\\n}\\n\\nfloat noise(vec2 r) {\\n\\tvec2 p = floor(r);\\n vec2 f = fract(r);\\n f = smoothstep(0.,1.,f);\\n vec2 e = vec2(0,1);\\n float p00 = rand(p+e.xx);\\n float p01 = rand(p+e.xy);\\n float p10 = rand(p+e.yx);\\n float p11 = rand(p+e.yy);\\n\\treturn mix(\\n mix(p00,p01,f.y),\\n mix(p10,p11,f.y),\\n f.x) - 0.5;\\n}\\n\\nfloat ot(vec2 r) {\\n\\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\\n return v * 0.5 + 0.5;\\n}\\n\\nvoid shift(inout vec3 p) {\\n\\tp.y += pow(ot(p.xz),1.2)*0.5;\\n}\\n\\nvoid main() {\\n vec3 pos, color;\\n float alpha = 1.0;\\n vec2 div;\\n int i = int(mod(vertexId,6.));\\n if(i==0) {\\n div = vec2(-1,-1);\\n } else if(i==1) {\\n div = vec2(-1,1);\\n } else if(i==2) {\\n div = vec2(1,-1);\\n } else if(i==3) {\\n div = vec2(1,-1);\\n } else if(i==4) {\\n div = vec2(-1,1);\\n } else if(i==5) {\\n div = vec2(1,1);\\n }\\n if(vertexId < 6.) {\\n pos = vec3(0,0,100.);\\n pos.xy += div * 1000.;\\n color = vec3(0.03);\\n } else if(vertexId < 12.) {\\n pos = vec3(0,0.2,0);\\n pos.xz += div * 100.;\\n color = vec3(0,0,0.2);\\n } else if(vertexId < 4812.) {\\n float vid = vertexId-6.;\\n float unitIx = floor(vid/6.);\\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\\n p.x -= 20.5;\\n p *= 0.5;\\n vec2 origP = p;\\n \\n p += div * 0.25;\\n\\tpos = vec3(p.x,0,p.y);\\n shift(pos);\\n \\n color = vec3(0.1,0.1,0.3);\\n color *= noise(pos.xz) * 0.5 + 0.5;\\n \\n vec3 u = pos - vec3(1,1.5,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - abs(u.y*0.2);\\n \\n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\\n } else if(vertexId < 15000.) {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float per = time*3. + rand(vec2(unitIx,3));\\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\\n float th = rand(vec2(seed,0))*3.1415926535*2.;\\n th += rand(vec2(seed,1));\\n float rad = rand(vec2(seed,2))*10. + 0.2;\\n pos = vec3(cos(th),0,sin(th)) * rad;\\n float ww = rand(vec2(seed,4))*0.02;\\n float ww2 = rand(vec2(seed,6))*0.5;\\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\\n pos.y += 3.0;\\n pos.z -= 1.0;\\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\\n \\tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\\n } else {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float v = rand(vec2(unitIx,9.))*2.-1.;\\n float per = time * 0.02 * v;\\n float au = time*0.05 + rand(vec2(unitIx,10.));\\n pos = vec3(\\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\\n rand(vec2(unitIx,2.)) * 2.,\\n rand(vec2(unitIx,3.)) * 2. - 1.\\n );\\n pos.x += sin(au*3.1415926535*2.)*0.1;\\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\\n vec3 ddiv = vec3(div,0.);\\n float ra = time*(1. + rand(vec2(unitIx,8.)));\\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n ra *= 2.;\\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n float size = rand(vec2(unitIx,5.))+0.5;\\n pos += ddiv*0.01*size;\\n \\n vec3 u = pos - vec3(1,1.8,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - u.y*0.05;\\n \\n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\\n \\talpha = 0.;\\n }\\n vec3 cam = vec3(0.,1.,0.);\\n pos -= cam;\\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\\n\\n float near = 0.001;\\n float far = 1000.;\\n float fovy = 3.1415926535 * 0.4;\\n float aspect = resolution.x / resolution.y;\\n float f = 1. / tan(fovy / 2.);\\n mat4 P = mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0,0,-2./(far-near),1,\\n 0,0,-(far+near)/(far-near),1\\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\\n // 0, 0, -1, 0\\n );\\n gl_Position = P * vec4(pos,1.);\\n v_color = vec4(color,alpha);\\n}\"}", + "settings": { + "num": 80000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rand(vec2 co) {\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\n}\n\nfloat noise(vec2 r) {\n\tvec2 p = floor(r);\n vec2 f = fract(r);\n f = smoothstep(0.,1.,f);\n vec2 e = vec2(0,1);\n float p00 = rand(p+e.xx);\n float p01 = rand(p+e.xy);\n float p10 = rand(p+e.yx);\n float p11 = rand(p+e.yy);\n\treturn mix(\n mix(p00,p01,f.y),\n mix(p10,p11,f.y),\n f.x) - 0.5;\n}\n\nfloat ot(vec2 r) {\n\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\n return v * 0.5 + 0.5;\n}\n\nvoid shift(inout vec3 p) {\n\tp.y += pow(ot(p.xz),1.2)*0.5;\n}\n\nvoid main() {\n vec3 pos, color;\n float alpha = 1.0;\n vec2 div;\n int i = int(mod(vertexId,6.));\n if(i==0) {\n div = vec2(-1,-1);\n } else if(i==1) {\n div = vec2(-1,1);\n } else if(i==2) {\n div = vec2(1,-1);\n } else if(i==3) {\n div = vec2(1,-1);\n } else if(i==4) {\n div = vec2(-1,1);\n } else if(i==5) {\n div = vec2(1,1);\n }\n if(vertexId < 6.) {\n pos = vec3(0,0,100.);\n pos.xy += div * 1000.;\n color = vec3(0.03);\n } else if(vertexId < 12.) {\n pos = vec3(0,0.2,0);\n pos.xz += div * 100.;\n color = vec3(0,0,0.2);\n } else if(vertexId < 4812.) {\n float vid = vertexId-6.;\n float unitIx = floor(vid/6.);\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\n p.x -= 20.5;\n p *= 0.5;\n vec2 origP = p;\n \n p += div * 0.25;\n\tpos = vec3(p.x,0,p.y);\n shift(pos);\n \n color = vec3(0.1,0.1,0.3);\n color *= noise(pos.xz) * 0.5 + 0.5;\n \n vec3 u = pos - vec3(1,1.5,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - abs(u.y*0.2);\n \n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\n } else if(vertexId < 15000.) {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float per = time*3. + rand(vec2(unitIx,3));\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\n float th = rand(vec2(seed,0))*3.1415926535*2.;\n th += rand(vec2(seed,1));\n float rad = rand(vec2(seed,2))*10. + 0.2;\n pos = vec3(cos(th),0,sin(th)) * rad;\n float ww = rand(vec2(seed,4))*0.02;\n float ww2 = rand(vec2(seed,6))*0.5;\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\n pos.y += 3.0;\n pos.z -= 1.0;\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\n \tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\n } else {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float v = rand(vec2(unitIx,9.))*2.-1.;\n float per = time * 0.02 * v;\n float au = time*0.05 + rand(vec2(unitIx,10.));\n pos = vec3(\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\n rand(vec2(unitIx,2.)) * 2.,\n rand(vec2(unitIx,3.)) * 2. - 1.\n );\n pos.x += sin(au*3.1415926535*2.)*0.1;\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\n vec3 ddiv = vec3(div,0.);\n float ra = time*(1. + rand(vec2(unitIx,8.)));\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n ra *= 2.;\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n float size = rand(vec2(unitIx,5.))+0.5;\n pos += ddiv*0.01*size;\n \n vec3 u = pos - vec3(1,1.8,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - u.y*0.05;\n \n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\n \talpha = 0.;\n }\n vec3 cam = vec3(0.,1.,0.);\n pos -= cam;\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\n\n float near = 0.001;\n float far = 1000.;\n float fovy = 3.1415926535 * 0.4;\n float aspect = resolution.x / resolution.y;\n float f = 1. / tan(fovy / 2.);\n mat4 P = mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0,0,-2./(far-near),1,\n 0,0,-(far+near)/(far-near),1\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\n // 0, 0, -1, 0\n );\n gl_Position = P * vec4(pos,1.);\n v_color = vec4(color,alpha);\n}" + }, "screenshotURL": "data/images/images-a8z01fgvo45zvgz00-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Kyf3xbtcypvZ4KbPc/art.json b/art/Kyf3xbtcypvZ4KbPc/art.json index ebba4e48..da76719c 100644 --- a/art/Kyf3xbtcypvZ4KbPc/art.json +++ b/art/Kyf3xbtcypvZ4KbPc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"///GLSL\\nvoid main() {\\n gl_PointSize = 100.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\\n /*RGB */\\n v_color = vec4(1.0, .0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "///GLSL\nvoid main() {\n gl_PointSize = 100.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\n /*RGB */\n v_color = vec4(1.0, .0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-ozdivp9cuinwdfrb7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/KzGvbRByeAs6noPkG/art.json b/art/KzGvbRByeAs6noPkG/art.json index 8e2ad87c..a065b92c 100644 --- a/art/KzGvbRByeAs6noPkG/art.json +++ b/art/KzGvbRByeAs6noPkG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "nirth", "avatarUrl": "https://secure.gravatar.com/avatar/7680c06bcde43ab09d0427a712255363?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/qumumusic/pokemon-dppt-cynthia-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define NUM_SEGMENTS 30.0\\n#define NUM_POINTS (NUM_SEGMENTS * 55.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 10.0, 1.0));\\n vec4 K = vec4(0.50, 0.50 / 0.60, 7.0 / 0.80, 0.60);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 3.50) + mod(vertexId, 1.50);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.0425;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.05) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 1.90 - 2.5;\\n float y = v * 0.90 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.95, 0.50, invV),\\n y + pow(snd, 5.0) * 2.0) / (v + .795);\\n gl_Position = vec4(xy * 0.58, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/qumumusic/pokemon-dppt-cynthia-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define NUM_SEGMENTS 30.0\n#define NUM_POINTS (NUM_SEGMENTS * 55.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 10.0, 1.0));\n vec4 K = vec4(0.50, 0.50 / 0.60, 7.0 / 0.80, 0.60);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 3.50) + mod(vertexId, 1.50);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.0425;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.05) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 1.90 - 2.5;\n float y = v * 0.90 - 1.0;\n vec2 xy = vec2(\n x * mix(0.95, 0.50, invV),\n y + pow(snd, 5.0) * 2.0) / (v + .795);\n gl_Position = vec4(xy * 0.58, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n" + }, "screenshotURL": "data/images/images-4vvfdvqwyn8oi7xow-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/L2EkNfwTM8yncpYNw/art.json b/art/L2EkNfwTM8yncpYNw/art.json index 1f88bf77..15b89366 100644 --- a/art/L2EkNfwTM8yncpYNw/art.json +++ b/art/L2EkNfwTM8yncpYNw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":14490,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dj-wonkar/easy-funk-edit\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define ACROSS 8.\\n#define DOWN 10.\\n#define PER_AREA ((ACROSS + 0.61) * (DOWN + 2.) *8.1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 1.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -1.14, 0.7), c.y);\\n}\\n\\nvec4 area(float vertexId, float areaId) {\\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 1.)) * 2., 5.);\\n float thingId = floor(vertexId - 1.);\\n float col = mod(thingId, ACROSS + 0.5);\\n float row = floor(thingId / (ACROSS - 1.5));\\n float u = col / ACROSS;\\n float v = row / DOWN;\\n float x = u * 2. - 1.;\\n float y = v * 1. - 1.;\\n \\n float d = length(vec2(x, y) *2.);\\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / -11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\\n float sv = d * 0.1;\\n float snd = texture2D(sound, vec2(su * 1.25 / 8. * areaId, sv)).a;\\n \\n float r = 0.4 + pow(snd, 8.) * -3.15;\\n float a = pointId / 5. * PI * (2. + thingId * 0.005 + time) / 12.;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = cs * y - r;\\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\\n \\n float hue = (time * 0.1) + areaId / 1.;\\n \\n return vec4(\\n vec2(x * snd, y + snd) * 0.1 - xy / aspect,\\n snd,\\n hue) * 2.5 ;\\n}\\n\\nvoid main() {\\n gl_PointSize = 11.0;\\n\\n float areaId = floor(vertexId / PER_AREA);\\n float aCol = mod(areaId, 3.);\\n float aRow = floor(areaId / 4.)/3.2;\\n float ax = (aCol - 0.5) - (0.4 / 2.) - 2.;\\n float ay = (aRow + 0.5) / 2. * 1.8 - 0.9;\\n float avId = mod(vertexId, PER_AREA)-3.; \\n \\n vec4 a = area(avId, areaId);\\n \\n gl_Position = vec4(a.xy *- vec2(0.125, -0.4) + vec2(ax, ay), 0, 1);\\n float snd = a.z;\\n float hue = a.w;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 14490, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dj-wonkar/easy-funk-edit", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define ACROSS 8.\n#define DOWN 10.\n#define PER_AREA ((ACROSS + 0.61) * (DOWN + 2.) *8.1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 1.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -1.14, 0.7), c.y);\n}\n\nvec4 area(float vertexId, float areaId) {\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 1.)) * 2., 5.);\n float thingId = floor(vertexId - 1.);\n float col = mod(thingId, ACROSS + 0.5);\n float row = floor(thingId / (ACROSS - 1.5));\n float u = col / ACROSS;\n float v = row / DOWN;\n float x = u * 2. - 1.;\n float y = v * 1. - 1.;\n \n float d = length(vec2(x, y) *2.);\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / -11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\n float sv = d * 0.1;\n float snd = texture2D(sound, vec2(su * 1.25 / 8. * areaId, sv)).a;\n \n float r = 0.4 + pow(snd, 8.) * -3.15;\n float a = pointId / 5. * PI * (2. + thingId * 0.005 + time) / 12.;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = cs * y - r;\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\n \n float hue = (time * 0.1) + areaId / 1.;\n \n return vec4(\n vec2(x * snd, y + snd) * 0.1 - xy / aspect,\n snd,\n hue) * 2.5 ;\n}\n\nvoid main() {\n gl_PointSize = 11.0;\n\n float areaId = floor(vertexId / PER_AREA);\n float aCol = mod(areaId, 3.);\n float aRow = floor(areaId / 4.)/3.2;\n float ax = (aCol - 0.5) - (0.4 / 2.) - 2.;\n float ay = (aRow + 0.5) / 2. * 1.8 - 0.9;\n float avId = mod(vertexId, PER_AREA)-3.; \n \n vec4 a = area(avId, areaId);\n \n gl_Position = vec4(a.xy *- vec2(0.125, -0.4) + vec2(ax, ay), 0, 1);\n float snd = a.z;\n float hue = a.w;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-uf4mx9u5kg81obiq9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/L2TarY6jCmDDb2z8r/art.json b/art/L2TarY6jCmDDb2z8r/art.json index 584e806f..91ffee31 100644 --- a/art/L2TarY6jCmDDb2z8r/art.json +++ b/art/L2TarY6jCmDDb2z8r/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/foreverhomesick/sandwiches?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.47843137254901963,0.5568627450980392,0.4549019607843137,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 14.;\\n float across = 14.;\\n float back = 14.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float cz = floor(cubeId / across / back);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (back - 1.);\\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n float cc = cw * 2. - 1.;\\n \\n float sv1 = atan(ca, cb) / PI;\\n float sv = abs(atan(sv1, cc)) / PI;\\n \\n\\n float s1 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 3. / soundRes.y)).a;\\n float s = (s1 + s2 + s3 + s4) / 4.;\\n \\n s = mix(0., 1. + sv * .3, s);\\n s = clamp(s, 0., 1.);\\n \\n float tm = time * 0.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up);\\n mat4 wmat = rotY(time * 0.1); \\n wmat *= rotX(sin(time * 0.13));\\n wmat *= trans(vec3(ca, cc, cb) * down * 0.65);\\n wmat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\\n \\n vec4 wpos = wmat * vec4(pos, 1);\\n gl_Position = pmat * vmat * wpos;\\n vec3 n = normalize((wmat * vec4(normal, 0)).xyz);\\n \\n //vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(34, 3, -24);\\n vec3 lightDir = normalize(lightPos - wpos.xyz);\\n\\n float hue = 0.5;//abs(ca * cc) * 2.;\\n float sat = 0.1;//mix(0., 1., step(10.8, s));\\n float val = mix(0.5, -.5, step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = dot(n, lightDir) * 0.5 + 0.5;\\n v_color = vec4(color * pinch(lt, 3.) + vec3(pow(lt,11.)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/foreverhomesick/sandwiches?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.47843137254901963, + 0.5568627450980392, + 0.4549019607843137, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 14.;\n float across = 14.;\n float back = 14.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float cz = floor(cubeId / across / back);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (back - 1.);\n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n float cc = cw * 2. - 1.;\n \n float sv1 = atan(ca, cb) / PI;\n float sv = abs(atan(sv1, cc)) / PI;\n \n\n float s1 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 3. / soundRes.y)).a;\n float s = (s1 + s2 + s3 + s4) / 4.;\n \n s = mix(0., 1. + sv * .3, s);\n s = clamp(s, 0., 1.);\n \n float tm = time * 0.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up);\n mat4 wmat = rotY(time * 0.1); \n wmat *= rotX(sin(time * 0.13));\n wmat *= trans(vec3(ca, cc, cb) * down * 0.65);\n wmat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\n \n vec4 wpos = wmat * vec4(pos, 1);\n gl_Position = pmat * vmat * wpos;\n vec3 n = normalize((wmat * vec4(normal, 0)).xyz);\n \n //vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(34, 3, -24);\n vec3 lightDir = normalize(lightPos - wpos.xyz);\n\n float hue = 0.5;//abs(ca * cc) * 2.;\n float sat = 0.1;//mix(0., 1., step(10.8, s));\n float val = mix(0.5, -.5, step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = dot(n, lightDir) * 0.5 + 0.5;\n v_color = vec4(color * pinch(lt, 3.) + vec3(pow(lt,11.)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-x0bxvj75lj4miydh2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/L4yzBqmc6NRwKXSrs/art.json b/art/L4yzBqmc6NRwKXSrs/art.json index c0b1d6c0..811d6076 100644 --- a/art/L4yzBqmc6NRwKXSrs/art.json +++ b/art/L4yzBqmc6NRwKXSrs/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":42447,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.123 * cgv + snd * .125);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n gl_Position = mat * vec4(pos, .25);\\n gl_PointSize = 1.;\\n \\n float pump = step(.45, snd);\\n float hue = 1.- cgId * 1.05 + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 7.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 42447, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.123 * cgv + snd * .125);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n gl_Position = mat * vec4(pos, .25);\n gl_PointSize = 1.;\n \n float pump = step(.45, snd);\n float hue = 1.- cgId * 1.05 + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 7.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-olpd7focu18z17hef-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/L6xDZ78mbnpnMQGQj/art.json b/art/L6xDZ78mbnpnMQGQj/art.json index 790af31b..d3ad3c93 100644 --- a/art/L6xDZ78mbnpnMQGQj/art.json +++ b/art/L6xDZ78mbnpnMQGQj/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.403921568627451,0.403921568627451,0.403921568627451,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n01/01/2019\\n@BestRegard \\n*/ \\n\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region Scene_Vertex_Collection \\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n\\n struct SurfaceInfo \\n {\\n vec3 vPos;\\n vec3 vNormal;\\n float fGloss;\\n };\\n struct SphereInfo\\n {\\t\\n\\t \\n vec3 vOrigin;\\n float fRadius ; \\n \\n \\n \\n float fSlices ; \\n float fSegments ; \\n }; \\n#pragma endregion \\n \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, sv) ; \\n vertexIndex -= floorTileCount ; \\n */\\n /*draw the sphere*/ \\n \\tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo, camPos,\\n sv);\\n }\\n \\tvertexIndex -= fSphereVertexCount ; \\n \\n #pragma endregion \\n \\n \\n #pragma region add to glsl\\n \\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n #pragma endregion \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n01/01/2019\n@BestRegard \n*/ \n\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t\n\t \n vec3 vOrigin;\n float fRadius ; \n \n \n \n float fSlices ; \n float fSegments ; \n }; \n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, sv) ; \n vertexIndex -= floorTileCount ; \n */\n /*draw the sphere*/ \n \tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo, camPos,\n sv);\n }\n \tvertexIndex -= fSphereVertexCount ; \n \n #pragma endregion \n \n \n #pragma region add to glsl\n \n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n #pragma endregion \n}" + }, "screenshotURL": "data/images/images-4wnxoqfogmuozeav9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/L7qW9rkYQEWF4AzkK/art.json b/art/L7qW9rkYQEWF4AzkK/art.json index e1d45a02..a29372ed 100644 --- a/art/L7qW9rkYQEWF4AzkK/art.json +++ b/art/L7qW9rkYQEWF4AzkK/art.json @@ -11,7 +11,19 @@ "origId": "wTaKE9X796qNFqgEM", "name": "BigSwingingSnake", "username": "-anon-", - "settings": "{\"num\":64000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvec3 computeVert(float angle, float H) {\\n float STEP = time*0.7;\\n float R = (cos(H * 2.6 + STEP * 1.5 + sin(STEP * 4.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\\n R *= sin((H + 4.0) * 0.375);\\n \\n float Q = cos(STEP * 0.54 + H * 0.7);\\n float dX = cos(H * 1.4) * Q * 1.5;\\n float dY = sin(H * 0.75) * Q * 0.4;\\n float dZ = sin(H * 0.5) * Q * 0.5;\\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\\n}\\n\\nvec3 computeNorm(float angle, float H) {\\n float dA = 0.01;\\n float dH = 0.01;\\n vec3 A = computeVert(angle, H);\\n vec3 B = computeVert(angle + dA, H);\\n vec3 C = computeVert(angle, H + dH);\\n return normalize(-cross((B-A)/dA,(C-A)/dH));\\n}\\n\\nvoid main() {\\n int NUM_ROT = 64;\\n float dH = 0.05;\\n \\n float STEP = time*0.7;\\n \\n int base = int(vertexId) / 6;\\n int level = int(base) / NUM_ROT;\\n int idx = int(mod(vertexId,6.0));\\n vec3 xyz = vec3(0,0,0);\\n vec3 N = normalize(vec3(1,0,0));\\n \\n float dA = 2.0 * PI / float(NUM_ROT);\\n\\n float H = float(level) * dH - 4.0;\\n float angle = float(base) * dA;\\n \\n if (idx == 0) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n if (idx == 1) {\\n \\txyz = computeVert(angle + dA, H);\\n \\tN = computeNorm(angle + dA, H);\\n }\\n if (idx == 2) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n \\n if (idx == 3) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n if (idx == 4) {\\n \\txyz = computeVert(angle, H + dH);\\n \\tN = computeNorm(angle, H + dH);\\n }\\n if (idx == 5) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n \\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n \\n float Cs = cos(STEP);\\n float Si = sin(STEP);\\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\\n xyz *= 0.3;\\n //xyz *= rot;\\n //N *= rot;\\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\\n \\n vec3 light = normalize(vec3(1,1,-1));\\n vec3 V = vec3(0,0,1);\\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\\n vec3 A_col = vec3(1,1,1) * N * rot2;\\n vec3 D_col = vec3(1,1,1) * N;\\n vec3 S_col = vec3(1,1,1);\\n vec3 LUM = A * A_col + D * D_col +S * S_col;\\n v_color = vec4(LUM, 1);\\n}\"}", + "settings": { + "num": 64000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvec3 computeVert(float angle, float H) {\n float STEP = time*0.7;\n float R = (cos(H * 2.6 + STEP * 1.5 + sin(STEP * 4.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\n R *= sin((H + 4.0) * 0.375);\n \n float Q = cos(STEP * 0.54 + H * 0.7);\n float dX = cos(H * 1.4) * Q * 1.5;\n float dY = sin(H * 0.75) * Q * 0.4;\n float dZ = sin(H * 0.5) * Q * 0.5;\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\n}\n\nvec3 computeNorm(float angle, float H) {\n float dA = 0.01;\n float dH = 0.01;\n vec3 A = computeVert(angle, H);\n vec3 B = computeVert(angle + dA, H);\n vec3 C = computeVert(angle, H + dH);\n return normalize(-cross((B-A)/dA,(C-A)/dH));\n}\n\nvoid main() {\n int NUM_ROT = 64;\n float dH = 0.05;\n \n float STEP = time*0.7;\n \n int base = int(vertexId) / 6;\n int level = int(base) / NUM_ROT;\n int idx = int(mod(vertexId,6.0));\n vec3 xyz = vec3(0,0,0);\n vec3 N = normalize(vec3(1,0,0));\n \n float dA = 2.0 * PI / float(NUM_ROT);\n\n float H = float(level) * dH - 4.0;\n float angle = float(base) * dA;\n \n if (idx == 0) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n if (idx == 1) {\n \txyz = computeVert(angle + dA, H);\n \tN = computeNorm(angle + dA, H);\n }\n if (idx == 2) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n \n if (idx == 3) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n if (idx == 4) {\n \txyz = computeVert(angle, H + dH);\n \tN = computeNorm(angle, H + dH);\n }\n if (idx == 5) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n \n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n \n float Cs = cos(STEP);\n float Si = sin(STEP);\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\n xyz *= 0.3;\n //xyz *= rot;\n //N *= rot;\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\n \n vec3 light = normalize(vec3(1,1,-1));\n vec3 V = vec3(0,0,1);\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\n vec3 A_col = vec3(1,1,1) * N * rot2;\n vec3 D_col = vec3(1,1,1) * N;\n vec3 S_col = vec3(1,1,1);\n vec3 LUM = A * A_col + D * D_col +S * S_col;\n v_color = vec4(LUM, 1);\n}" + }, "screenshotURL": "data/images/images-vyqpj3pwtutad8w7a-thumbnail.jpg", "views": { "$numberInt": "221" diff --git a/art/L89txYMotSKb9FLad/art.json b/art/L89txYMotSKb9FLad/art.json index ae466352..3af8572a 100644 --- a/art/L89txYMotSKb9FLad/art.json +++ b/art/L89txYMotSKb9FLad/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/elastic-drums-preset-abc\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n float v = vertexId;\\n //float sndFactor = texture2D(sound, vec2(;\\n float off = .1;\\n float scale = 5.; //0.001 * vertexCount / vertexId;\\n float grid = floor(vertexCount / 1000.);\\n float sndF = texture2D(sound, vec2(mod(v, 1.), 0)).a;\\n\\n \\n float y = sin(v + time / (sndF * 20000.)) * (1. - sndF * 5.);\\n float x = cos(v + time / (sndF * 18000.) ) * (1. - sndF * 7.);\\n \\n float ux = x / scale - off;\\n float uy = y / scale - off;\\n \\n gl_Position =vec4(ux, uy, 0, 1);\\n gl_PointSize = 1. + sndF * 10. ;// grid;\\n v_color = vec4(sin(sndF), sin(v), sin(time), 1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/elastic-drums-preset-abc", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n float v = vertexId;\n //float sndFactor = texture2D(sound, vec2(;\n float off = .1;\n float scale = 5.; //0.001 * vertexCount / vertexId;\n float grid = floor(vertexCount / 1000.);\n float sndF = texture2D(sound, vec2(mod(v, 1.), 0)).a;\n\n \n float y = sin(v + time / (sndF * 20000.)) * (1. - sndF * 5.);\n float x = cos(v + time / (sndF * 18000.) ) * (1. - sndF * 7.);\n \n float ux = x / scale - off;\n float uy = y / scale - off;\n \n gl_Position =vec4(ux, uy, 0, 1);\n gl_PointSize = 1. + sndF * 10. ;// grid;\n v_color = vec4(sin(sndF), sin(v), sin(time), 1);\n \n}" + }, "screenshotURL": "data/images/images-i0lkrxb0w7nqnn3cl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LAiiJujhpHqHEG35u/art.json b/art/LAiiJujhpHqHEG35u/art.json index 50f88ba4..04d8f6c2 100644 --- a/art/LAiiJujhpHqHEG35u/art.json +++ b/art/LAiiJujhpHqHEG35u/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "vanoog", "avatarUrl": "https://secure.gravatar.com/avatar/896efd4abc5be73fd287b615b8a43698?default=retro&size=200", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/kellex_urps/yellow-bond\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n //float xOffset = cos(time + y * 0.2) * 0.1;\\n //float yOffset = sin(time + x * 0.1) * 0.2;\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n //v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n v_color = vec4(sin(time*x), cos(time*y), cos(x*y), 1.0);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "https://soundcloud.com/kellex_urps/yellow-bond", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n //float xOffset = cos(time + y * 0.2) * 0.1;\n //float yOffset = sin(time + x * 0.1) * 0.2;\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n //v_color = vec4(1.0, 0.0, 0.0, 1.0);\n v_color = vec4(sin(time*x), cos(time*y), cos(x*y), 1.0);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-rjrv5rq7t6mzwqnbk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LDxR3x6bY8ujTYt3M/art.json b/art/LDxR3x6bY8ujTYt3M/art.json index b016dbd3..37eb64e4 100644 --- a/art/LDxR3x6bY8ujTYt3M/art.json +++ b/art/LDxR3x6bY8ujTYt3M/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/manon-ariza/tortuga-deities\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 1.0)\\n#define STEP 2.0\\n\\nfloat radius = 0.15;\\nfloat amount = 100.;\\nfloat len = vertexCount / amount;\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (3.0 - 2.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, .0, 0.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + .02);\\n\\n vec4 o1 = fract(k3 * (1.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (2.0 - d.y);\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float seg = floor(vertexId/len);\\n float segId = mod(vertexId,len);\\n float v = texture2D(volume, vec2(1., (2.-seg)/amount*2.)).a;\\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\\n float n = noise(p);\\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\\n \\n x += cos(n * PI*4.) * segId * 0.000002 * s;\\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\\n \\n gl_Position = vec4(x/v-x/s, y/v, y-0.1, 1);\\n\\n float b = 2.3 / mod(vertexId/len,21.3);\\n v_color = vec4(vec3(b), 1.915);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/manon-ariza/tortuga-deities", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 1.0)\n#define STEP 2.0\n\nfloat radius = 0.15;\nfloat amount = 100.;\nfloat len = vertexCount / amount;\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (3.0 - 2.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, .0, 0.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + .02);\n\n vec4 o1 = fract(k3 * (1.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (2.0 - d.y);\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float seg = floor(vertexId/len);\n float segId = mod(vertexId,len);\n float v = texture2D(volume, vec2(1., (2.-seg)/amount*2.)).a;\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\n float n = noise(p);\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\n \n x += cos(n * PI*4.) * segId * 0.000002 * s;\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\n \n gl_Position = vec4(x/v-x/s, y/v, y-0.1, 1);\n\n float b = 2.3 / mod(vertexId/len,21.3);\n v_color = vec4(vec3(b), 1.915);\n}" + }, "screenshotURL": "data/images/images-vnr2z620np0c86ir9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LE2ob3EHvHzjFMK9W/art.json b/art/LE2ob3EHvHzjFMK9W/art.json index a4f58767..81787504 100644 --- a/art/LE2ob3EHvHzjFMK9W/art.json +++ b/art/LE2ob3EHvHzjFMK9W/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 4.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 20;\\n float snd = 0.;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf * 7.123);\\n float spy = hash(spf * 0.317);\\n float sps = hash(spf * 3.411);\\n \\n float sds = distance(vec2(u, v), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7, sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 20. / across);\\n //mat *= rotZ(snd * 10. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.7, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 4.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 20;\n float snd = 0.;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf * 7.123);\n float spy = hash(spf * 0.317);\n float sps = hash(spf * 3.411);\n \n float sds = distance(vec2(u, v), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7, sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 20. / across);\n //mat *= rotZ(snd * 10. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.7, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-x05oo8sx1u5v0tmuc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LEzaqrf9HzkcvwKea/art.json b/art/LEzaqrf9HzkcvwKea/art.json index 87ace3ac..09aa4855 100644 --- a/art/LEzaqrf9HzkcvwKea/art.json +++ b/art/LEzaqrf9HzkcvwKea/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "vanoog", "avatarUrl": "https://secure.gravatar.com/avatar/896efd4abc5be73fd287b615b8a43698?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n float pi = 3.14159;\\n \\n float y = mod(vertexId,2.0);\\n float x = floor(vertexId/2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n \\n float r = 2.0 - y;\\n \\n x = r*cos(angle);\\n y = r*sin(angle);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(sin(time*x), cos(time*y), cos(x*y), 1.0);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n float pi = 3.14159;\n \n float y = mod(vertexId,2.0);\n float x = floor(vertexId/2.0);\n \n float angle = x / 20.0 * radians(360.0);\n \n float r = 2.0 - y;\n \n x = r*cos(angle);\n y = r*sin(angle);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(sin(time*x), cos(time*y), cos(x*y), 1.0);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-f2spl3aqfcb7kevh0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LHZYGPs7pPvxmLMbm/art.json b/art/LHZYGPs7pPvxmLMbm/art.json index 146e43bc..ac9c7330 100644 --- a/art/LHZYGPs7pPvxmLMbm/art.json +++ b/art/LHZYGPs7pPvxmLMbm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":72000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 15.0\\n#define fakeVerticeNumber 72000.\\n\\nconst float dim = 120.;\\nconst float off = 0.1;\\nconst vec3 vAlb = vec3(0.5);\\n/////////////////////////////\\n//K Machine parameters\\n/////////////////////////////\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 100.1 //KParameter 1.>>10.\\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\\n\\n\\nmat4 rotZ(float _radAngle) {\\n float s = sin(_radAngle);\\n float c = cos(_radAngle);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 _s) {\\n return mat4(\\n _s[0], 0, 0, 0,\\n 0, _s[1], 0, 0,\\n 0, 0, _s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\\n float f = tan(PI * 0.5 - 0.5 * _fov);\\n float rInv = 1.0 / (_zNear - _zFar);\\n\\n return mat4(\\n f / _aspect, 0., 0., 0.,\\n 0., f, 0., 0.,\\n 0., 0., (_zNear + _zFar) * rInv, -1.,\\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\\n}\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\n\\nvec3 getTrajPoint(const float _id) {\\n return vec3(\\n sin(_id * 0.99),\\n sin(_id * 2.43),\\n sin(_id * 1.57));\\n}\\n \\nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\\n{\\n \\n float pg = _rel + _delta;\\n \\n vec3 r0 = getTrajPoint(pg + off * 0.);\\n vec3 r1 = getTrajPoint(pg + off * 1.);\\n vec3 r2 = getTrajPoint(pg + off * 2.);\\n \\n _pos = mat3(\\n getTrajPoint(pg + off * 0.),\\n getTrajPoint(pg + off * 1.),\\n getTrajPoint(pg + off * 2.));\\n \\n vec3 s0 = normalize(_pos[1] - _pos[0]);\\n vec3 s1 = normalize(_pos[2] - _pos[1]);\\n \\n vec4 zaxis = vec4(normalize(s1 - s0),1.);\\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\\n \\n _axis = mat3(\\n xaxis,\\n yaxis,\\n zaxis);\\n\\n\\n}\\n\\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\\n \\n \\n float prog = (_shapeId / _shapeCount)+_timeB;\\n \\n mat3 axis, mPos;\\n\\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\\n\\n //pos mtx\\n _wmat = mat4(\\n vec4(axis[0], 0),\\n vec4(axis[1], 0),\\n vec4(axis[2], 0),\\n vec4(mPos[0] * dim, 1)); \\n \\n //orient mtx\\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\\n vec3 target = mPos[1] * dim + axis[2];\\n vec3 up = axis[1];\\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\nmat4 rotMatx(vec3 _axis, float _angle)\\n{\\n _axis = normalize(_axis);\\n float s = sin(_angle);\\n float c = cos(_angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * _axis.x * _axis.x + c, oc * _axis.x * _axis.y - _axis.z * s, oc * _axis.z * _axis.x + _axis.y * s, 0.0,\\n oc * _axis.x * _axis.y + _axis.z * s, oc * _axis.y * _axis.y + c, oc * _axis.y * _axis.z - _axis.x * s, 0.0,\\n oc * _axis.z * _axis.x - _axis.y * s, oc * _axis.y * _axis.z + _axis.x * s, oc * _axis.z * _axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\nvoid addPtLight( vec3 vLightPos, vec3 vLightColor, in vec3 _pos, in vec3 _norm, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - _pos);\\n vec3 vViewDir = normalize(-_pos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, _norm ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid addDirLight( vec3 _vLDir, vec3 _vLColor, in vec3 _pos, in vec3 _norm, inout vec3 _vDiff, inout vec3 _vSpec )\\n{\\n vec3 vViewDir = normalize(-_pos);\\n \\n float NdotL = max( 0.0, dot( _vLDir, _norm ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + _vLDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\\n \\n _vDiff += NdotL * _vLColor;\\n\\n float fPower = 80.0;\\n _vSpec += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * _vLColor;\\n}\\n\\nvec3 lightget(const vec3 vAlbedo, const vec3 _pos, const vec3 _eyePos, const vec3 _norm )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n vec3 vAmbient = vec3(1., 1., 1.);\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n\\n addPtLight( vec3(3.0, 2.0, 30.0), vec3( 0.2, 0.2,0.2),_pos, _norm, vDiffuseLight, vSpecLight );\\n \\n addDirLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, _pos, _norm, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(-_eyePos);\\n \\n float fNdotD = clamp(dot(_norm, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\n\\nvec3 lightPost( vec3 _vColor )\\n{\\n float exposure = 1.0;\\n _vColor = vec3(1.0) - exp2( _vColor * -exposure );\\n\\n _vColor = pow( _vColor, vec3(1.0 / 2.2) );\\n\\n return _vColor;\\n}\\n\\n#define EYE_STATIC true\\n//#define STOP_TRAJ true\\n#define DYN_GROUPID true\\n#define SOUND_REACT true\\n\\nvoid main() {\\n \\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\\n //shape\\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\\n float shapeId = floor(finalVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n #ifdef SOUND_REACT\\n float snd = 2.*texture2D(sound, vec2(0., (1.-relGroupId))).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n \\n #ifdef STOP_TRAJ\\n float timeB = 14.;\\n #else\\n float timeB = time * tubeSpeedFactor;\\n #endif\\n \\n\\n \\n //Static eye\\n #ifdef EYE_STATIC\\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n #else\\n //Following eye\\n mat3 axis, sPos;// = getAxisMat(0., timeB);\\n getPosAndAxisMat(0., timeB, axis, sPos);\\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\\n vec3 target = sPos[2] * dim + axis[2];\\n vec3 up = axis[1];\\n #endif\\n \\n \\n //rotation around eye z axis\\n //mat4 rotMat = rotationMatrix(zaxis, time*PI);\\n //xaxis = (rotMat*vec4(xaxis,1.)).xyz;\\n //yaxis = (rotMat*vec4(yaxis,1.)).xyz;\\n \\n //\\n\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n\\n vec4 cNorm;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\\n \\n \\n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n \\n cNorm *= zrot;\\n //create the circle group\\n float radius =100.*radiusSizeFactor;\\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n\\n mat4 posmat, rotmat;\\n\\n #ifdef DYN_GROUPID\\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\\n #else\\n getTrajMat(groupId, groupCount, timeB, posmat, rotmat);\\n #endif\\n \\n //shape orientation\\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\\n cNorm *= rotmat;\\n \\n //shape position\\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\\n \\n //vec3 finalColor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n //vec3 LightSurface(const vec3 vAlbedo, const vec3 _eyePos, const vec3 _norm )\\n vec3 finalColor = lightget(vAlb, cubep, eye, cNorm.xyz);\\n lightPost(finalColor);\\n \\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n \\n v_color = vec4(finalColor,1.);\\n}\\n\"}", + "settings": { + "num": 72000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 15.0\n#define fakeVerticeNumber 72000.\n\nconst float dim = 120.;\nconst float off = 0.1;\nconst vec3 vAlb = vec3(0.5);\n/////////////////////////////\n//K Machine parameters\n/////////////////////////////\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 100.1 //KParameter 1.>>10.\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\n\n\nmat4 rotZ(float _radAngle) {\n float s = sin(_radAngle);\n float c = cos(_radAngle);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 _s) {\n return mat4(\n _s[0], 0, 0, 0,\n 0, _s[1], 0, 0,\n 0, 0, _s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\n float f = tan(PI * 0.5 - 0.5 * _fov);\n float rInv = 1.0 / (_zNear - _zFar);\n\n return mat4(\n f / _aspect, 0., 0., 0.,\n 0., f, 0., 0.,\n 0., 0., (_zNear + _zFar) * rInv, -1.,\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\n}\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\n\nvec3 getTrajPoint(const float _id) {\n return vec3(\n sin(_id * 0.99),\n sin(_id * 2.43),\n sin(_id * 1.57));\n}\n \nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\n{\n \n float pg = _rel + _delta;\n \n vec3 r0 = getTrajPoint(pg + off * 0.);\n vec3 r1 = getTrajPoint(pg + off * 1.);\n vec3 r2 = getTrajPoint(pg + off * 2.);\n \n _pos = mat3(\n getTrajPoint(pg + off * 0.),\n getTrajPoint(pg + off * 1.),\n getTrajPoint(pg + off * 2.));\n \n vec3 s0 = normalize(_pos[1] - _pos[0]);\n vec3 s1 = normalize(_pos[2] - _pos[1]);\n \n vec4 zaxis = vec4(normalize(s1 - s0),1.);\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\n \n _axis = mat3(\n xaxis,\n yaxis,\n zaxis);\n\n\n}\n\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\n \n \n float prog = (_shapeId / _shapeCount)+_timeB;\n \n mat3 axis, mPos;\n\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\n\n //pos mtx\n _wmat = mat4(\n vec4(axis[0], 0),\n vec4(axis[1], 0),\n vec4(axis[2], 0),\n vec4(mPos[0] * dim, 1)); \n \n //orient mtx\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\n vec3 target = mPos[1] * dim + axis[2];\n vec3 up = axis[1];\n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\nmat4 rotMatx(vec3 _axis, float _angle)\n{\n _axis = normalize(_axis);\n float s = sin(_angle);\n float c = cos(_angle);\n float oc = 1.0 - c;\n \n return mat4(oc * _axis.x * _axis.x + c, oc * _axis.x * _axis.y - _axis.z * s, oc * _axis.z * _axis.x + _axis.y * s, 0.0,\n oc * _axis.x * _axis.y + _axis.z * s, oc * _axis.y * _axis.y + c, oc * _axis.y * _axis.z - _axis.x * s, 0.0,\n oc * _axis.z * _axis.x - _axis.y * s, oc * _axis.y * _axis.z + _axis.x * s, oc * _axis.z * _axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\nvoid addPtLight( vec3 vLightPos, vec3 vLightColor, in vec3 _pos, in vec3 _norm, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - _pos);\n vec3 vViewDir = normalize(-_pos);\n \n float NdotL = max( 0.0, dot( vLightDir, _norm ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid addDirLight( vec3 _vLDir, vec3 _vLColor, in vec3 _pos, in vec3 _norm, inout vec3 _vDiff, inout vec3 _vSpec )\n{\n vec3 vViewDir = normalize(-_pos);\n \n float NdotL = max( 0.0, dot( _vLDir, _norm ) );\n \n vec3 vHalfAngle = normalize( vViewDir + _vLDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\n \n _vDiff += NdotL * _vLColor;\n\n float fPower = 80.0;\n _vSpec += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * _vLColor;\n}\n\nvec3 lightget(const vec3 vAlbedo, const vec3 _pos, const vec3 _eyePos, const vec3 _norm )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n vec3 vAmbient = vec3(1., 1., 1.);\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n\n addPtLight( vec3(3.0, 2.0, 30.0), vec3( 0.2, 0.2,0.2),_pos, _norm, vDiffuseLight, vSpecLight );\n \n addDirLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, _pos, _norm, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(-_eyePos);\n \n float fNdotD = clamp(dot(_norm, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\n\nvec3 lightPost( vec3 _vColor )\n{\n float exposure = 1.0;\n _vColor = vec3(1.0) - exp2( _vColor * -exposure );\n\n _vColor = pow( _vColor, vec3(1.0 / 2.2) );\n\n return _vColor;\n}\n\n#define EYE_STATIC true\n//#define STOP_TRAJ true\n#define DYN_GROUPID true\n#define SOUND_REACT true\n\nvoid main() {\n \n float finalVertexId = mod(vertexId,fakeVerticeNumber);\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\n //shape\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\n float shapeId = floor(finalVertexId / kShapeVertexCount);\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n #ifdef SOUND_REACT\n float snd = 2.*texture2D(sound, vec2(0., (1.-relGroupId))).a;\n #else\n float snd = 1.;\n #endif\n \n \n #ifdef STOP_TRAJ\n float timeB = 14.;\n #else\n float timeB = time * tubeSpeedFactor;\n #endif\n \n\n \n //Static eye\n #ifdef EYE_STATIC\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\n vec3 up = vec3(0.5, 0.5, 1.5);\n #else\n //Following eye\n mat3 axis, sPos;// = getAxisMat(0., timeB);\n getPosAndAxisMat(0., timeB, axis, sPos);\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\n vec3 target = sPos[2] * dim + axis[2];\n vec3 up = axis[1];\n #endif\n \n \n //rotation around eye z axis\n //mat4 rotMat = rotationMatrix(zaxis, time*PI);\n //xaxis = (rotMat*vec4(xaxis,1.)).xyz;\n //yaxis = (rotMat*vec4(yaxis,1.)).xyz;\n \n //\n\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n\n vec4 cNorm;\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\n \n \n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\n cubep = (zrot*vec4(cubep,1.)).xyz;\n \n cNorm *= zrot;\n //create the circle group\n float radius =100.*radiusSizeFactor;\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n \n //shapeId = mod(shapeId+time, shapeCount);\n\n mat4 posmat, rotmat;\n\n #ifdef DYN_GROUPID\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\n #else\n getTrajMat(groupId, groupCount, timeB, posmat, rotmat);\n #endif\n \n //shape orientation\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\n cNorm *= rotmat;\n \n //shape position\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\n \n //vec3 finalColor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n //vec3 LightSurface(const vec3 vAlbedo, const vec3 _eyePos, const vec3 _norm )\n vec3 finalColor = lightget(vAlb, cubep, eye, cNorm.xyz);\n lightPost(finalColor);\n \n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n \n v_color = vec4(finalColor,1.);\n}\n" + }, "screenshotURL": "data/images/images-a609athoqwojd0n3s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LHgS8fK9eqJpbzbLF/art.json b/art/LHgS8fK9eqJpbzbLF/art.json index 5c3c4020..c8427c6f 100644 --- a/art/LHgS8fK9eqJpbzbLF/art.json +++ b/art/LHgS8fK9eqJpbzbLF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-x33gar5fb1tzj4y9y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LHj56pPH8J6ufctmP/art.json b/art/LHj56pPH8J6ufctmP/art.json index 1a733841..b8abb6a5 100644 --- a/art/LHj56pPH8J6ufctmP/art.json +++ b/art/LHj56pPH8J6ufctmP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "randomstarz", "avatarUrl": "https://secure.gravatar.com/avatar/742ed793ae5d9783e12bdf3ff554e51a?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main ()\\n{\\n \\tgl_PointSize = 10.0;\\n \\n \\t\\n \\tfloat across = 10.;\\n \\n \\n \\t//float x = ( vertexId / vertexCount ) + 0.1;\\n \\n \\tfloat x = mod( vertexId, across );\\n \\tfloat y = floor( vertexId / across );\\n \\n \\tx = x - across / 2.;\\n \\ty = y - across / 2.;\\n \\n \\tx /= across;\\n \\ty /= across;\\n \\n\\n \\tgl_Position = vec4( x, y, 0, 1 );\\n \\n \\n\\tv_color = vec4( 0.1, 0.4, 0.8, 1.0 );\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main ()\n{\n \tgl_PointSize = 10.0;\n \n \t\n \tfloat across = 10.;\n \n \n \t//float x = ( vertexId / vertexCount ) + 0.1;\n \n \tfloat x = mod( vertexId, across );\n \tfloat y = floor( vertexId / across );\n \n \tx = x - across / 2.;\n \ty = y - across / 2.;\n \n \tx /= across;\n \ty /= across;\n \n\n \tgl_Position = vec4( x, y, 0, 1 );\n \n \n\tv_color = vec4( 0.1, 0.4, 0.8, 1.0 );\n}" + }, "screenshotURL": "data/images/images-ogyjpa39kqnr7sr72-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LJLGx9kqDknzmmmW5/art.json b/art/LJLGx9kqDknzmmmW5/art.json index 1c3f9a02..c96914c3 100644 --- a/art/LJLGx9kqDknzmmmW5/art.json +++ b/art/LJLGx9kqDknzmmmW5/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spinninrecords/alok-alan-walker-headlights-feat-kiddo-listen-link\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au*.05, av*.25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd+0.2,5.)* 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd*0.2+time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd+0.2,5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spinninrecords/alok-alan-walker-headlights-feat-kiddo-listen-link", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au*.05, av*.25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd+0.2,5.)* 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd*0.2+time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd+0.2,5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-2mpfi817tahychowc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LJeqquzeSbtKjtQGN/art.json b/art/LJeqquzeSbtKjtQGN/art.json index d45a61cd..14135581 100644 --- a/art/LJeqquzeSbtKjtQGN/art.json +++ b/art/LJeqquzeSbtKjtQGN/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":5180,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Exercise Colors\\n// CS250 Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 5180, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Exercise Colors\n// CS250 Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-v057ml7c4o1n59k55-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LLTEjXA7Q49X7GMMm/art.json b/art/LLTEjXA7Q49X7GMMm/art.json index 3f3c3bcd..99e49807 100644 --- a/art/LLTEjXA7Q49X7GMMm/art.json +++ b/art/LLTEjXA7Q49X7GMMm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":24579,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.403921568627451,0.403921568627451,0.403921568627451,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n01/01/2019\\n@BestRegard \\n*/ \\n\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region Scene_Vertex_Collection d\\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n\\n struct SurfaceInfo \\n {\\n vec3 vPos;\\n vec3 vNormal;\\n float fGloss;\\n };\\n struct SphereInfo\\n {\\t \\n vec3 vOrigin;\\n float fRadius ; \\n \\n float fSlices ; \\n float fSegments ; \\n }; \\n \\n struct Material \\n {\\n vec4 diffuseAlebdo;\\n vec3 FresenlR0 ;\\n float Roughness ;\\n mat4 MatTransform ; \\n }; \\n struct Light\\n {\\n\\n vec3 vStrength ; \\n float FalloffStart ; \\n vec3 vDirection ; \\n float FalloffEnd ; \\n vec3 vPosition ; \\n float SpotPower ; \\n };\\n#pragma endregion \\n \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 140.0;\\n \\treturn vec3( 0.0, 0.3, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, DirLight,\\n sv) ; \\n vertexIndex -= floorVertexCount ; \\n #pragma endregion \\n \\n #pragma region Sphere\\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo,\\n DirLight, \\n camPos,\\n sv);\\n m *= uniformScale(1.5);\\n m *= trans(vec3(0. , 4. , 0. )) ; \\n }\\n vertexIndex -= fSphereVertexCount ; \\n #pragma endregion \\n#pragma endregion \\n \\n \\n#pragma region PostEffect\\n // PE_Vignette(sv) ;\\n#pragma endregion \\n \\n#pragma region ApplySetting\\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n#pragma endregion \\n}\"}", + "settings": { + "num": 24579, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n01/01/2019\n@BestRegard \n*/ \n\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection d\n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t \n vec3 vOrigin;\n float fRadius ; \n \n float fSlices ; \n float fSegments ; \n }; \n \n struct Material \n {\n vec4 diffuseAlebdo;\n vec3 FresenlR0 ;\n float Roughness ;\n mat4 MatTransform ; \n }; \n struct Light\n {\n\n vec3 vStrength ; \n float FalloffStart ; \n vec3 vDirection ; \n float FalloffEnd ; \n vec3 vPosition ; \n float SpotPower ; \n };\n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 140.0;\n \treturn vec3( 0.0, 0.3, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, DirLight,\n sv) ; \n vertexIndex -= floorVertexCount ; \n #pragma endregion \n \n #pragma region Sphere\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo,\n DirLight, \n camPos,\n sv);\n m *= uniformScale(1.5);\n m *= trans(vec3(0. , 4. , 0. )) ; \n }\n vertexIndex -= fSphereVertexCount ; \n #pragma endregion \n#pragma endregion \n \n \n#pragma region PostEffect\n // PE_Vignette(sv) ;\n#pragma endregion \n \n#pragma region ApplySetting\n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n#pragma endregion \n}" + }, "screenshotURL": "data/images/images-nrc1qatost8r66lf6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LMN6w6vBdQz2DyQdB/art.json b/art/LMN6w6vBdQz2DyQdB/art.json index 0966ca95..d00645cf 100644 --- a/art/LMN6w6vBdQz2DyQdB/art.json +++ b/art/LMN6w6vBdQz2DyQdB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Exercise - Vertexshaderart : Making a Grid\\n// Course : CS250\\n// Term & Year : 2023 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down );\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\t\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0,1);\\n \\n gl_PointSize = abs(cos(time)) * 10.;\\n\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(mouse.x, cos(time * 2.), mouse.y,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Exercise - Vertexshaderart : Making a Grid\n// Course : CS250\n// Term & Year : 2023 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down );\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \t\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0,1);\n \n gl_PointSize = abs(cos(time)) * 10.;\n\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(mouse.x, cos(time * 2.), mouse.y,1);\n}" + }, "screenshotURL": "data/images/images-mj0wfyvefpol3jcq8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LPS8BeAeCDomFZXzX/art.json b/art/LPS8BeAeCDomFZXzX/art.json index 9b9270ca..1577e7d2 100644 --- a/art/LPS8BeAeCDomFZXzX/art.json +++ b/art/LPS8BeAeCDomFZXzX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":14909,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dirtybirdrecords/claudevonstroke-dood\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n🔴\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertsPerBlob = 6. * 45.;\\n float blobId = floor(vertexId / vertsPerBlob);\\n float numBlobs = floor(vertexCount / vertsPerBlob);\\n float bv = blobId / numBlobs;\\n float id = mod(vertexId, vertsPerBlob);\\n float numQuads = floor(vertsPerBlob / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(id / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(id, 6.);\\n float ux = floor(id / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n vec3 nrm = pos;\\n \\n float tm = time * 0.1 * 1.;\\n float rd = 3.;\\n mat4 pmat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float groupId = floor(blobId / 2.);\\n float numGroups = floor(numBlobs / 2.);\\n float gv = groupId / numGroups;\\n float odd = mod(blobId, 2.);\\n \\n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, gv), 0.)).a;\\n float s1 = texture2D(sound, vec2(mix(0.5, 0.5, gv), qv)).a;\\n \\n mat4 cmat = lookAt(eye, target, up); \\n mat4 vmat = inverse(cmat);\\n \\n float t0 = floor(time);\\n float t1 = floor(time + 1.);\\n vec3 p0 = vec3(\\n t2m1(hash(t0 * 0.123)), \\n t2m1(hash(t0 * 0.617)), \\n t2m1(hash(t0 * 0.371)));\\n vec3 p1 = vec3(\\n t2m1(hash(t1 * 0.123)), \\n t2m1(hash(t1 * 0.617)), \\n t2m1(hash(t1 * 0.371)));\\n \\n #if 1\\n mat4 wmat = ident();\\n wmat *= trans(t2m1(s0) * .0 + \\n mix(p0, p1, fract(time)) +\\n cmat[2].xyz * -odd * 0.1);\\n #endif\\n wmat *= rotX(time + qv);\\n wmat *= rotY(time * .77);\\n wmat *= rotZ(gv);\\n wmat *= uniformScale(mix(0., 1.7, pow(s0 + .2, 5.)) + odd * 0.0);\\n// wmat *= scale(vec3(1, 1, 1. - odd));\\n// mat *= uniformScale(0.4);\\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .0 + id * 0.0;\\n float sat = 1.;\\n float val = 1. - odd;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n vec3 n = (cmat * wmat * vec4(nrm, 0)).xyz;\\n float l = dot(normalize(vec3(.5,1,-3)), n) * .2 + .8;\\n v_color.rgb *= l;//mix(l, 1., pow(s0, .1));\\n \\n v_color.rgb *= v_color.a;\\n \\n #if 0\\n gl_Position.xy /= gl_Position.w;\\n gl_Position.z = bv;\\n gl_Position.w = 1.;\\n #endif\\n}\"}", + "settings": { + "num": 14909, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dirtybirdrecords/claudevonstroke-dood", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n🔴\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertsPerBlob = 6. * 45.;\n float blobId = floor(vertexId / vertsPerBlob);\n float numBlobs = floor(vertexCount / vertsPerBlob);\n float bv = blobId / numBlobs;\n float id = mod(vertexId, vertsPerBlob);\n float numQuads = floor(vertsPerBlob / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(id / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(id, 6.);\n float ux = floor(id / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n vec3 nrm = pos;\n \n float tm = time * 0.1 * 1.;\n float rd = 3.;\n mat4 pmat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float groupId = floor(blobId / 2.);\n float numGroups = floor(numBlobs / 2.);\n float gv = groupId / numGroups;\n float odd = mod(blobId, 2.);\n \n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, gv), 0.)).a;\n float s1 = texture2D(sound, vec2(mix(0.5, 0.5, gv), qv)).a;\n \n mat4 cmat = lookAt(eye, target, up); \n mat4 vmat = inverse(cmat);\n \n float t0 = floor(time);\n float t1 = floor(time + 1.);\n vec3 p0 = vec3(\n t2m1(hash(t0 * 0.123)), \n t2m1(hash(t0 * 0.617)), \n t2m1(hash(t0 * 0.371)));\n vec3 p1 = vec3(\n t2m1(hash(t1 * 0.123)), \n t2m1(hash(t1 * 0.617)), \n t2m1(hash(t1 * 0.371)));\n \n #if 1\n mat4 wmat = ident();\n wmat *= trans(t2m1(s0) * .0 + \n mix(p0, p1, fract(time)) +\n cmat[2].xyz * -odd * 0.1);\n #endif\n wmat *= rotX(time + qv);\n wmat *= rotY(time * .77);\n wmat *= rotZ(gv);\n wmat *= uniformScale(mix(0., 1.7, pow(s0 + .2, 5.)) + odd * 0.0);\n// wmat *= scale(vec3(1, 1, 1. - odd));\n// mat *= uniformScale(0.4);\n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .0 + id * 0.0;\n float sat = 1.;\n float val = 1. - odd;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n vec3 n = (cmat * wmat * vec4(nrm, 0)).xyz;\n float l = dot(normalize(vec3(.5,1,-3)), n) * .2 + .8;\n v_color.rgb *= l;//mix(l, 1., pow(s0, .1));\n \n v_color.rgb *= v_color.a;\n \n #if 0\n gl_Position.xy /= gl_Position.w;\n gl_Position.z = bv;\n gl_Position.w = 1.;\n #endif\n}" + }, "screenshotURL": "data/images/images-qi5beqf99iupnv4ko-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LR4nX9WApQc5MZDDq/art.json b/art/LR4nX9WApQc5MZDDq/art.json index cbc87add..91240553 100644 --- a/art/LR4nX9WApQc5MZDDq/art.json +++ b/art/LR4nX9WApQc5MZDDq/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/index-marcel-fengler/marcel-fengler-scion-imf04\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2784313725490196,0.3137254901960784,0.1803921568627451,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define kp0 mouse.x\\n#define kp1 floor(mouse.y+3.)\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p *-5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 3.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, -13., vy)*3.;\\n float a = mix(start, end, u) * PI * 2. + PI * 3.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.-kp1\\n#define FACES_PER_CUBE 6.-kp1\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 6.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, .1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * .5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, .1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 200.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36./kp0);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = gv + cu * 9. + time * .05;// + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 1.5, gv),\\n cu * 1.2)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n float r = 2.;\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .1 + 1., sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n mat *= p4;\\n mat *= rotZ(hash(gv * 0.132));\\n mat *= rotX(hash(gv));\\n mat *= trans(vec3(0,0.2,0));\\n mat *= uniformScale(mix(0.01, 0.5, pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .0 + time * .0;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = mix(0.2, 2.0, pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(-2.5, 5., s);\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/index-marcel-fengler/marcel-fengler-scion-imf04", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2784313725490196, + 0.3137254901960784, + 0.1803921568627451, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define kp0 mouse.x\n#define kp1 floor(mouse.y+3.)\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p *-5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 3.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, -13., vy)*3.;\n float a = mix(start, end, u) * PI * 2. + PI * 3.;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.-kp1\n#define FACES_PER_CUBE 6.-kp1\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 6.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, .1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * .5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, .1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 200.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36./kp0);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = gv + cu * 9. + time * .05;// + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 1.5, gv),\n cu * 1.2)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n float r = 2.;\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .1 + 1., sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n mat *= p4;\n mat *= rotZ(hash(gv * 0.132));\n mat *= rotX(hash(gv));\n mat *= trans(vec3(0,0.2,0));\n mat *= uniformScale(mix(0.01, 0.5, pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .0 + time * .0;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = mix(0.2, 2.0, pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(-2.5, 5., s);\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-c8kf3greh0r0lfe5y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LTuqGKGJGc3bHxGij/art.json b/art/LTuqGKGJGc3bHxGij/art.json index 60a9c4f0..98ff75b1 100644 --- a/art/LTuqGKGJGc3bHxGij/art.json +++ b/art/LTuqGKGJGc3bHxGij/art.json @@ -21,7 +21,19 @@ "origId": "wmrGHPZAroXn6EtZz", "name": "pinkstars", "username": "gman", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.18823529411764706,0.5882352941176471,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 6.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00024, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.9, 0.8);\\n float innerRadius = pow(count * 0.0025, 1.2);\\n float oC = cos(orbitAngle + count * 0.01) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.18823529411764706, + 0.5882352941176471, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 6.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00024, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.9, 0.8);\n float innerRadius = pow(count * 0.0025, 1.2);\n float oC = cos(orbitAngle + count * 0.01) * innerRadius;\n float oS = sin(orbitAngle + count * 0.01) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotDataId": "ZtPx2spAm6Si8sEws", "views": { "$numberInt": "521" diff --git a/art/LWQB7Eh4wa4moh9oa/art.json b/art/LWQB7Eh4wa4moh9oa/art.json index 84c170f9..19338247 100644 --- a/art/LWQB7Eh4wa4moh9oa/art.json +++ b/art/LWQB7Eh4wa4moh9oa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":25233,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/djmag/premiere-detroit-swindle-heads-down\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() {\\n float numCircles = 1.;\\n float numPointsPerCircle = floor(vertexCount / numCircles);\\n float id = mod(vertexId, numPointsPerCircle);\\n float u = id / numPointsPerCircle;\\n \\n float cId = floor(vertexId / numPointsPerCircle);\\n float cv = cId / numCircles;\\n float v = vertexId / vertexCount;\\n\\n float a = u * PI * 2. * 20.;\\n vec3 pos = vec3(cos(a), 0, sin(a));\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 mat = persp(PI * 0.25, aspect, .01, 150.);\\n \\n float cs = time * 0.5;\\n float r = 1.5;\\n vec3 eye = vec3(cos(cs) * r, 1, sin(cs) * r);\\n vec3 target = vec3(0,-.25, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.25, v),\\n v * .2)).a;\\n float s2 = texture2D(sound, vec2( mix(0.1, 0.25, v), 0)).a;\\n float pump = step(0.70, s);\\n \\n mat *= cameraLookAt(eye, target, up);\\n float vmix = mix(.2, 1., v);\\n mat *= rotX(vmix * sin(time * 1.73) * 1.);\\n mat *= rotZ(vmix * sin(time * 1. ) * 4.);\\n \\n mat *= uniformScale(v);\\n\\n gl_Position = mat * vec4(pos, 1);\\n float z = gl_Position.z / gl_Position.w * .5 + .5;\\n z = pow(z, 8.);\\n z = 1. - z;\\n \\n float hue = floor(s2 * 1.5) * .5 + time * .1; //sin( * PI * 2.) * .1 + time * .1;\\n float sat = pow(s2 * 2., 2.);\\n float val = pow(s2 * 2., 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), val);\\n v_color.rgb *= v_color.a;\\n \\n \\n gl_PointSize = 2. + pow(s * 2., 5.) * 8.;z * (5. * pow(s + .2, 5.) * 5.);\\n gl_PointSize *= min(resolution.x, resolution.y) / 1000.;\\n}\"}", + "settings": { + "num": 25233, + "mode": "POINTS", + "sound": "https://soundcloud.com/djmag/premiere-detroit-swindle-heads-down", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() {\n float numCircles = 1.;\n float numPointsPerCircle = floor(vertexCount / numCircles);\n float id = mod(vertexId, numPointsPerCircle);\n float u = id / numPointsPerCircle;\n \n float cId = floor(vertexId / numPointsPerCircle);\n float cv = cId / numCircles;\n float v = vertexId / vertexCount;\n\n float a = u * PI * 2. * 20.;\n vec3 pos = vec3(cos(a), 0, sin(a));\n \n float aspect = resolution.x / resolution.y;\n mat4 mat = persp(PI * 0.25, aspect, .01, 150.);\n \n float cs = time * 0.5;\n float r = 1.5;\n vec3 eye = vec3(cos(cs) * r, 1, sin(cs) * r);\n vec3 target = vec3(0,-.25, 0);\n vec3 up = vec3(0, 1, 0);\n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.25, v),\n v * .2)).a;\n float s2 = texture2D(sound, vec2( mix(0.1, 0.25, v), 0)).a;\n float pump = step(0.70, s);\n \n mat *= cameraLookAt(eye, target, up);\n float vmix = mix(.2, 1., v);\n mat *= rotX(vmix * sin(time * 1.73) * 1.);\n mat *= rotZ(vmix * sin(time * 1. ) * 4.);\n \n mat *= uniformScale(v);\n\n gl_Position = mat * vec4(pos, 1);\n float z = gl_Position.z / gl_Position.w * .5 + .5;\n z = pow(z, 8.);\n z = 1. - z;\n \n float hue = floor(s2 * 1.5) * .5 + time * .1; //sin( * PI * 2.) * .1 + time * .1;\n float sat = pow(s2 * 2., 2.);\n float val = pow(s2 * 2., 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), val);\n v_color.rgb *= v_color.a;\n \n \n gl_PointSize = 2. + pow(s * 2., 5.) * 8.;z * (5. * pow(s + .2, 5.) * 5.);\n gl_PointSize *= min(resolution.x, resolution.y) / 1000.;\n}" + }, "screenshotURL": "data/images/images-xlltf3zxucthecfhj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LX4SGokNFQgLciwnK/art.json b/art/LX4SGokNFQgLciwnK/art.json index 914b11bc..60e908fe 100644 --- a/art/LX4SGokNFQgLciwnK/art.json +++ b/art/LX4SGokNFQgLciwnK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2400,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 1.0;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\t\\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat countSection = floor(6.);\\n\\t\\n\\tfloat indexCircle = floor(indexQuad / countSection);\\n\\t\\n\\tfloat astep = 3.14159 * 2.0 / countSection;\\n\\t\\n\\tfloat angle0 = indexQuad * astep;\\n\\tfloat angle1 = (indexQuad + 1.) * astep;\\n\\t\\n\\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\\n\\tfloat angleTorus = indexCircle * astepTorus;\\n\\t\\n\\tfloat radius = 4. * cos(angleTorus * 1.5 + time) * 2.;\\n\\t\\n\\t// triangle 1\\n\\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\\n\\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\\n\\t\\n \\tfloat atten = p.x;\\n \\n\\tp *= RotX(-angleTorus);\\n\\t\\n\\tp.z += 11. * cos(angleTorus);\\n\\tp.y += 11. * sin(angleTorus);\\n\\t\\n\\t// cam\\n\\tfloat ca = 3.14159 * 0.6;\\n\\tfloat cd = 50.;\\n\\tvec3 eye = vec3(sin(ca), 0.5, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n \\t// pos\\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\t// color\\n \\tp /= atten;\\n \\n\\tv_color = vec4(normalize(p) * 0.5 + 0.5, 1);\\n}\"}", + "settings": { + "num": 2400, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvoid main()\n{\n\tgl_PointSize = 1.0;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tvec3 p = vec3(0);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\t\n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat countSection = floor(6.);\n\t\n\tfloat indexCircle = floor(indexQuad / countSection);\n\t\n\tfloat astep = 3.14159 * 2.0 / countSection;\n\t\n\tfloat angle0 = indexQuad * astep;\n\tfloat angle1 = (indexQuad + 1.) * astep;\n\t\n\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\n\tfloat angleTorus = indexCircle * astepTorus;\n\t\n\tfloat radius = 4. * cos(angleTorus * 1.5 + time) * 2.;\n\t\n\t// triangle 1\n\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\n\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\t\n\t// triangle 2\n\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\n\t\n \tfloat atten = p.x;\n \n\tp *= RotX(-angleTorus);\n\t\n\tp.z += 11. * cos(angleTorus);\n\tp.y += 11. * sin(angleTorus);\n\t\n\t// cam\n\tfloat ca = 3.14159 * 0.6;\n\tfloat cd = 50.;\n\tvec3 eye = vec3(sin(ca), 0.5, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n \t// pos\n\tgl_Position = camera * vec4(p, 1);\n\t\n \t// color\n \tp /= atten;\n \n\tv_color = vec4(normalize(p) * 0.5 + 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-9dmzaqnktr5cdqip7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LZvMDxAGHssNSpJ44/art.json b/art/LZvMDxAGHssNSpJ44/art.json index 5411edcc..bb2cebdc 100644 --- a/art/LZvMDxAGHssNSpJ44/art.json +++ b/art/LZvMDxAGHssNSpJ44/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":15,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n \\n // E2\\n /*\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n */\\n \\n // E1\\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 15, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n \n // E2\n /*\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n */\n \n // E1\n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-isxlffor6ddmr8rgl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LbkZcKYz5Z7nbCP4s/art.json b/art/LbkZcKYz5Z7nbCP4s/art.json index 8b0ba9a7..bfaad7e1 100644 --- a/art/LbkZcKYz5Z7nbCP4s/art.json +++ b/art/LbkZcKYz5Z7nbCP4s/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main(){\\n \\n float x = vertexId / 10.;\\n \\n gl_Position = vec4(0, 0, 0, 1);\\n \\n gl_PointSize = 10.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main(){\n \n float x = vertexId / 10.;\n \n gl_Position = vec4(0, 0, 0, 1);\n \n gl_PointSize = 10.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-vw4ecrvq04bazd9vj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LcQbjMTCCKXywR2Rb/art.json b/art/LcQbjMTCCKXywR2Rb/art.json index 751c5d72..e68a0ea3 100644 --- a/art/LcQbjMTCCKXywR2Rb/art.json +++ b/art/LcQbjMTCCKXywR2Rb/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sina5an", "avatarUrl": "https://secure.gravatar.com/avatar/8ea2eb4d1d5da005eca6f4aae81d9e15?default=retro&size=200", - "settings": "{\"num\":60,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.24313725490196078,0.22745098039215686,0.32941176470588235,1],\"shader\":\"void main() {\\n gl_Position = vec4(cos(vertexId / 3.14 * .5 * cos(time * .25)),\\n sin(vertexId / 3.14 * .5 * sin(time * .5)),\\n 0, 1);\\n v_color = vec4(mod(vertexId, 6.0 + (cos(time))) / 5.0, \\n mod(vertexId, 3.0 + (sin(time))) / 2.0\\n ,0,1);\\n}\"}", + "settings": { + "num": 60, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.24313725490196078, + 0.22745098039215686, + 0.32941176470588235, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(cos(vertexId / 3.14 * .5 * cos(time * .25)),\n sin(vertexId / 3.14 * .5 * sin(time * .5)),\n 0, 1);\n v_color = vec4(mod(vertexId, 6.0 + (cos(time))) / 5.0, \n mod(vertexId, 3.0 + (sin(time))) / 2.0\n ,0,1);\n}" + }, "screenshotURL": "data/images/images-h1uqv5yaqk10zsgli-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LcpL4rKHDw4JYGvvt/art.json b/art/LcpL4rKHDw4JYGvvt/art.json index aa8e4363..1c18f605 100644 --- a/art/LcpL4rKHDw4JYGvvt/art.json +++ b/art/LcpL4rKHDw4JYGvvt/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sendi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GiA4oVEHO7tNcUpxHud7p60dl8Gb-TqVLeqG_Q1=s96-c", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7176470588235294,0.7568627450980392,0.6431372549019608,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 3.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(2.0, 2.0 / 1.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7176470588235294, + 0.7568627450980392, + 0.6431372549019608, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 3.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(2.0, 2.0 / 1.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-1ig2xxn4r22qcgwgq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LdAPq7RiPQZHYmFbx/art.json b/art/LdAPq7RiPQZHYmFbx/art.json index 0ae43f32..68364e69 100644 --- a/art/LdAPq7RiPQZHYmFbx/art.json +++ b/art/LdAPq7RiPQZHYmFbx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\\n v_color = vec4(0.0, 0.0, 0.0, .0);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\n v_color = vec4(0.0, 0.0, 0.0, .0);\n}" + }, "screenshotURL": "data/images/images-wtvk0ys1pbuhgob7u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LdQAN7vDm59Kqcvgs/art.json b/art/LdQAN7vDm59Kqcvgs/art.json index 4582df1d..b3f66d9d 100644 --- a/art/LdQAN7vDm59Kqcvgs/art.json +++ b/art/LdQAN7vDm59Kqcvgs/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-sv9hdk715egkb9nui-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LfMFq222gHE4os9ai/art.json b/art/LfMFq222gHE4os9ai/art.json index 808d0560..bac84498 100644 --- a/art/LfMFq222gHE4os9ai/art.json +++ b/art/LfMFq222gHE4os9ai/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "nathan", "avatarUrl": "https://lh6.googleusercontent.com/-JT7xJ_JWLYc/AAAAAAAAAAI/AAAAAAAAAC4/7ddaOc6vFnQ/photo.jpg", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.12549019607843137,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n \\n float across = down;\\n\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across -1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,1,0,1);\\n \\n \\n \\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.12549019607843137, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n \n float across = down;\n\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across -1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,1,0,1);\n \n \n \n}" + }, "screenshotURL": "data/images/images-lnsj2fxmcyxmdff0p-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LfQCKq93ccXsMC3DD/art.json b/art/LfQCKq93ccXsMC3DD/art.json index 7a3100aa..d85ed02c 100644 --- a/art/LfQCKq93ccXsMC3DD/art.json +++ b/art/LfQCKq93ccXsMC3DD/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "rmccampbell7", "avatarUrl": "https://secure.gravatar.com/avatar/06a15f2260899be5cfa7484a476adf34?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const float EXPLODE = 0.15;\\nconst float SPEED = .5;\\nconst float NLON = 32.;\\nconst float NLAT = 16.;\\nconst float NQUADS = NLON*NLAT;\\nconst float TAU = radians(360.);\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 rotx(vec3 v, float theta) {\\n float c = cos(theta), s = sin(theta);\\n return vec3(v.x, c*v.y-s*v.z, s*v.y+c*v.z);\\n}\\n\\nvec3 roty(vec3 v, float theta) {\\n float c = cos(theta), s = sin(theta);\\n return vec3(c*v.x+s*v.z, v.y, -s*v.x+c*v.z);\\n}\\n\\nvec3 rotz(vec3 v, float theta) {\\n float c = cos(theta), s = sin(theta);\\n return vec3(c*v.x-s*v.y, s*v.x+c*v.y, v.z);\\n}\\n\\nstruct Vert {\\n vec3 pos;\\n vec2 uv;\\n};\\n\\nVert getQuadVert(vec2 quadCoord, float quadVertId) {\\n vec2 vertOff = (quadVertId == 0. ? vec2(0, 0) :\\n quadVertId == 1. ? vec2(1, 0) :\\n quadVertId == 2. ? vec2(1, 1) :\\n quadVertId == 3. ? vec2(1, 1) :\\n quadVertId == 4. ? vec2(0, 1) :\\n vec2(0, 0));\\n vec2 vertCoord = quadCoord + vertOff;\\n vec2 uv = vertCoord / vec2(NLON, NLAT);\\n float theta = TAU*uv.x;\\n float phi = .5*TAU*uv.y;\\n vec3 pos;\\n pos.x = sin(theta)*sin(phi);\\n pos.y = -cos(phi);\\n pos.z = cos(theta)*sin(phi);\\n return Vert(pos, uv);\\n}\\n\\nvec3 getTriNormal(vec2 quadCoord, float quadVertId) {\\n float triVertId0 = floor(quadVertId/3.)*3.;\\n vec3 v1 = getQuadVert(quadCoord, triVertId0+0.).pos;\\n vec3 v2 = getQuadVert(quadCoord, triVertId0+1.).pos;\\n vec3 v3 = getQuadVert(quadCoord, triVertId0+2.).pos;\\n return normalize(cross(v2-v1, v3-v1));\\n}\\n\\nvec3 getTriCentroid(vec2 quadCoord, float quadVertId) {\\n float triVertId0 = floor(quadVertId/3.)*3.;\\n vec3 v1 = getQuadVert(quadCoord, triVertId0+0.).pos;\\n vec3 v2 = getQuadVert(quadCoord, triVertId0+1.).pos;\\n vec3 v3 = getQuadVert(quadCoord, triVertId0+2.).pos;\\n return (v1 + v2 + v3) / 3.;\\n}\\n\\nvoid main() {\\n float quadId = mod(floor(vertexId / 6.), NQUADS);\\n float quadVertId = mod(vertexId, 6.);\\n vec2 quadCoord = vec2(mod(quadId, NLON), floor(quadId / NLON));\\n Vert v = getQuadVert(quadCoord, quadVertId);\\n //vec3 triNorm = getTriNormal(quadCoord, quadVertId);\\n vec3 triCentroid = getTriCentroid(quadCoord, quadVertId);\\n v.pos += triCentroid*EXPLODE;\\n\\n vec3 pos = roty(v.pos, SPEED*time);\\n pos = rotx(pos, .08*TAU);\\n pos = roty(pos, SPEED*time) * .7;\\n\\n float aspect = resolution.x / resolution.y;\\n vec2 scale = min(vec2(1./aspect, aspect), 1.);\\n gl_Position = vec4(pos.x*scale.x, pos.y*scale.y, -pos.z, 1);\\n //gl_PointSize = 4.;\\n\\n v_color = vec4(hsv2rgb(vec3(v.uv.x+v.uv.y*.5, 1, 1)), 1);\\n //v_color = vec4(triNorm*.5+.5, 1);\\n if (pos.z < 0.) v_color *= 0.;\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const float EXPLODE = 0.15;\nconst float SPEED = .5;\nconst float NLON = 32.;\nconst float NLAT = 16.;\nconst float NQUADS = NLON*NLAT;\nconst float TAU = radians(360.);\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 rotx(vec3 v, float theta) {\n float c = cos(theta), s = sin(theta);\n return vec3(v.x, c*v.y-s*v.z, s*v.y+c*v.z);\n}\n\nvec3 roty(vec3 v, float theta) {\n float c = cos(theta), s = sin(theta);\n return vec3(c*v.x+s*v.z, v.y, -s*v.x+c*v.z);\n}\n\nvec3 rotz(vec3 v, float theta) {\n float c = cos(theta), s = sin(theta);\n return vec3(c*v.x-s*v.y, s*v.x+c*v.y, v.z);\n}\n\nstruct Vert {\n vec3 pos;\n vec2 uv;\n};\n\nVert getQuadVert(vec2 quadCoord, float quadVertId) {\n vec2 vertOff = (quadVertId == 0. ? vec2(0, 0) :\n quadVertId == 1. ? vec2(1, 0) :\n quadVertId == 2. ? vec2(1, 1) :\n quadVertId == 3. ? vec2(1, 1) :\n quadVertId == 4. ? vec2(0, 1) :\n vec2(0, 0));\n vec2 vertCoord = quadCoord + vertOff;\n vec2 uv = vertCoord / vec2(NLON, NLAT);\n float theta = TAU*uv.x;\n float phi = .5*TAU*uv.y;\n vec3 pos;\n pos.x = sin(theta)*sin(phi);\n pos.y = -cos(phi);\n pos.z = cos(theta)*sin(phi);\n return Vert(pos, uv);\n}\n\nvec3 getTriNormal(vec2 quadCoord, float quadVertId) {\n float triVertId0 = floor(quadVertId/3.)*3.;\n vec3 v1 = getQuadVert(quadCoord, triVertId0+0.).pos;\n vec3 v2 = getQuadVert(quadCoord, triVertId0+1.).pos;\n vec3 v3 = getQuadVert(quadCoord, triVertId0+2.).pos;\n return normalize(cross(v2-v1, v3-v1));\n}\n\nvec3 getTriCentroid(vec2 quadCoord, float quadVertId) {\n float triVertId0 = floor(quadVertId/3.)*3.;\n vec3 v1 = getQuadVert(quadCoord, triVertId0+0.).pos;\n vec3 v2 = getQuadVert(quadCoord, triVertId0+1.).pos;\n vec3 v3 = getQuadVert(quadCoord, triVertId0+2.).pos;\n return (v1 + v2 + v3) / 3.;\n}\n\nvoid main() {\n float quadId = mod(floor(vertexId / 6.), NQUADS);\n float quadVertId = mod(vertexId, 6.);\n vec2 quadCoord = vec2(mod(quadId, NLON), floor(quadId / NLON));\n Vert v = getQuadVert(quadCoord, quadVertId);\n //vec3 triNorm = getTriNormal(quadCoord, quadVertId);\n vec3 triCentroid = getTriCentroid(quadCoord, quadVertId);\n v.pos += triCentroid*EXPLODE;\n\n vec3 pos = roty(v.pos, SPEED*time);\n pos = rotx(pos, .08*TAU);\n pos = roty(pos, SPEED*time) * .7;\n\n float aspect = resolution.x / resolution.y;\n vec2 scale = min(vec2(1./aspect, aspect), 1.);\n gl_Position = vec4(pos.x*scale.x, pos.y*scale.y, -pos.z, 1);\n //gl_PointSize = 4.;\n\n v_color = vec4(hsv2rgb(vec3(v.uv.x+v.uv.y*.5, 1, 1)), 1);\n //v_color = vec4(triNorm*.5+.5, 1);\n if (pos.z < 0.) v_color *= 0.;\n}\n" + }, "screenshotURL": "data/images/images-6ox8gccuy97vqqba1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LgRGGzXFTTEZFmP9x/art.json b/art/LgRGGzXFTTEZFmP9x/art.json index 61959753..019b93c9 100644 --- a/art/LgRGGzXFTTEZFmP9x/art.json +++ b/art/LgRGGzXFTTEZFmP9x/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21176470588235294,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n#define KP0 2.//KParameter -0.5>>2.5\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.5//KParameter 1.0>>7.\\n#define KP2 .3//KParameter 0.4>>2.\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0,KP0, 1.0);\\nfloat gExposure = 0.3;\\t\\n\\nfloat gCubeColorRandom = 10.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0 * zoom;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n float beat = texture2D(sound, vec2(0.007, 0)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0.65; + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(5,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8 + KP2;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, KP1, 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.3, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, .3) , background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21176470588235294, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n#define KP0 2.//KParameter -0.5>>2.5\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.5//KParameter 1.0>>7.\n#define KP2 .3//KParameter 0.4>>2.\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0,KP0, 1.0);\nfloat gExposure = 0.3;\t\n\nfloat gCubeColorRandom = 10.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0 * zoom;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n float beat = texture2D(sound, vec2(0.007, 0)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0.65; + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(5,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8 + KP2;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, KP1, 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.3, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, .3) , background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-7lh0vwembkphz9oj9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LgbwRMagZDAcxeyMF/art.json b/art/LgbwRMagZDAcxeyMF/art.json index d9388572..f0152555 100644 --- a/art/LgbwRMagZDAcxeyMF/art.json +++ b/art/LgbwRMagZDAcxeyMF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":16622,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define kp0 sin(time*0.60)//KParameter -5.>>5.\\n#define kp1 sin(time*0.10)//KParameter -6.>>5.\\n#define kp2 sin(1.-time*0.30)//KParameter -6.>>5.\\n#define kp3 sin(1.-time*0.930)//KParameter -6.>>5.\\n#define kp4 sin(-time*0.70)//KParameter -6.>>5.\\n#define kp5 sin(-time*.130)//KParameter -6.>>5.\\n//#define kp0 -5.//KParameter -5.>>5.\\n//#define kp1 1.//KParameter -6.>>5.\\n//KVerticesNumber=16622\\n\\n\\n\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.0030;\\n \\tfloat transitionStrength = 1.3*kp5;\\n \\tvec3 colKernel0 = vec3(1,0,1.-kp3);\\n \\tvec3 colKernel1 = vec3(0,kp2,0);\\n \\tvec3 colTransition = vec3(kp0,kp4,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = .5 - kp1* 0.5;\\n\\tfloat ce = -1.5+ kp0* 3.+1.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 1, 0);\\n\\tvec3 up = vec3(0, 0.6,1.);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(33.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = .2 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * 1.23, 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, sin(mouse.y/8.),\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,\\n \\n 2.)*0.3;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye*2.);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 1,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.45); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 16622, + "mode": "LINES", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define kp0 sin(time*0.60)//KParameter -5.>>5.\n#define kp1 sin(time*0.10)//KParameter -6.>>5.\n#define kp2 sin(1.-time*0.30)//KParameter -6.>>5.\n#define kp3 sin(1.-time*0.930)//KParameter -6.>>5.\n#define kp4 sin(-time*0.70)//KParameter -6.>>5.\n#define kp5 sin(-time*.130)//KParameter -6.>>5.\n//#define kp0 -5.//KParameter -5.>>5.\n//#define kp1 1.//KParameter -6.>>5.\n//KVerticesNumber=16622\n\n\n\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.0030;\n \tfloat transitionStrength = 1.3*kp5;\n \tvec3 colKernel0 = vec3(1,0,1.-kp3);\n \tvec3 colKernel1 = vec3(0,kp2,0);\n \tvec3 colTransition = vec3(kp0,kp4,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = .5 - kp1* 0.5;\n\tfloat ce = -1.5+ kp0* 3.+1.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 1, 0);\n\tvec3 up = vec3(0, 0.6,1.);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(33.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = .2 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * 1.23, 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, sin(mouse.y/8.),\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,\n \n 2.)*0.3;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye*2.);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 1,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.45); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-eawd1tboiaw8qf0jg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LgcuGRxZ6AGSaGnQE/art.json b/art/LgcuGRxZ6AGSaGnQE/art.json index 69d8e618..03811c89 100644 --- a/art/LgcuGRxZ6AGSaGnQE/art.json +++ b/art/LgcuGRxZ6AGSaGnQE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KPxx 62.//KParameter0 0.>>1000.\\n#define KPx 12.//KParameter1 0.0>>22.\\n#define KPxxx 9.0//KParameter2 -6.0>>10.\\n#define KP3 -0.0//KParameter3 -8.000>>0.5\\n#define KP4 1.2//KParameter4 0.000>>15.\\n#define KP5 130.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=100000\\n#define PI radians(180. /KP1)\\n#define KP1 (KPx * mouse.y)\\n#define KP0 (KPxx * mouse.x)\\n#define KP2 (KPxxx * mouse.x *mouse.y)\\n\\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 + a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det *(2.2 / KPx);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, xAxis));\\n vec3 yAxis = cross(zAxis, zAxis *KP2);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137*KP1));\\n\\treturn fract(p2.x * p2.y * 129.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv, mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.125, sin(time * (0.21+mouse.x)) * 0.5, .5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, );\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * 0.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KPxx 62.//KParameter0 0.>>1000.\n#define KPx 12.//KParameter1 0.0>>22.\n#define KPxxx 9.0//KParameter2 -6.0>>10.\n#define KP3 -0.0//KParameter3 -8.000>>0.5\n#define KP4 1.2//KParameter4 0.000>>15.\n#define KP5 130.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=100000\n#define PI radians(180. /KP1)\n#define KP1 (KPx * mouse.y)\n#define KP0 (KPxx * mouse.x)\n#define KP2 (KPxxx * mouse.x *mouse.y)\n\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 + a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det *(2.2 / KPx);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, xAxis));\n vec3 yAxis = cross(zAxis, zAxis *KP2);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137*KP1));\n\treturn fract(p2.x * p2.y * 129.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv, mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.125, sin(time * (0.21+mouse.x)) * 0.5, .5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, );\n \n mat4 mat = scale(vec3(1, aspect, 1) * 0.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-h2mjwzgplfp32v0un-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LhgDszKTstGZBHjt7/art.json b/art/LhgDszKTstGZBHjt7/art.json index 3924f742..c867211d 100644 --- a/art/LhgDszKTstGZBHjt7/art.json +++ b/art/LhgDszKTstGZBHjt7/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":40100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.7333333333333333,1,1],\"shader\":\"void main() {\\n\\n float x = vertexId/100. + sin(time/41.) ;\\n float y = sin(time/17. + tan(vertexId/600.));\\n \\n gl_Position = vec4(x-4.-sin(time/20.), -y*(cos(x+vertexId)+0.), sin(x), 1.);\\n \\n gl_PointSize = 10. + (sin(time/12.+vertexId*50.)/2.+.5)*90.;\\n \\n v_color = vec4(tan(x), y, cos(time/7.)/2.+.8, 1.);\\n}\"}", + "settings": { + "num": 40100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.7333333333333333, + 1, + 1 + ], + "shader": "void main() {\n\n float x = vertexId/100. + sin(time/41.) ;\n float y = sin(time/17. + tan(vertexId/600.));\n \n gl_Position = vec4(x-4.-sin(time/20.), -y*(cos(x+vertexId)+0.), sin(x), 1.);\n \n gl_PointSize = 10. + (sin(time/12.+vertexId*50.)/2.+.5)*90.;\n \n v_color = vec4(tan(x), y, cos(time/7.)/2.+.8, 1.);\n}" + }, "screenshotURL": "data/images/images-16lrc0vhq9mbte0wd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ljd8Z84mCFeiRwfuy/art.json b/art/Ljd8Z84mCFeiRwfuy/art.json index 3fca5783..96dad61e 100644 --- a/art/Ljd8Z84mCFeiRwfuy/art.json +++ b/art/Ljd8Z84mCFeiRwfuy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gerrygoo", "avatarUrl": "https://avatars.githubusercontent.com/gerrygoo?s=200", - "settings": "{\"num\":10,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// 1m x 1m\\n\\n#define G = 9.8\\n\\nfloat rand(float x) {\\n\\treturn fract(sin(x)*10000000.0);\\n}\\n\\nvoid main() {\\n\\n \\n\\n float\\n i = vertexId,\\n // r = rand(),\\n \\n origin_x = -1.0,\\n origin_y = 1.0,\\n \\n\\n x_i_offset = 2.0 * rand(i),\\n y_i_offset = 0.0,\\n \\n starting_x = origin_x,\\n starting_y = origin_y,\\n \\n \\tfall_distance = - (mod(time, 2.0) * 0.5) * mod(time, 2.0),\\n \\n \\twiggle_x_offset = 0.01 * sin(time*10.0),\\n \\n x = starting_x + wiggle_x_offset + x_i_offset,\\n y = starting_y + fall_distance //+ y_i_offset;\\n \\n ;\\n \\n gl_Position = vec4(x, y, 0, 1);\\n \\n gl_PointSize = 10.0;\\n v_color = vec4(0, 0.8, 1, 1);\\n \\n}\"}", + "settings": { + "num": 10, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// 1m x 1m\n\n#define G = 9.8\n\nfloat rand(float x) {\n\treturn fract(sin(x)*10000000.0);\n}\n\nvoid main() {\n\n \n\n float\n i = vertexId,\n // r = rand(),\n \n origin_x = -1.0,\n origin_y = 1.0,\n \n\n x_i_offset = 2.0 * rand(i),\n y_i_offset = 0.0,\n \n starting_x = origin_x,\n starting_y = origin_y,\n \n \tfall_distance = - (mod(time, 2.0) * 0.5) * mod(time, 2.0),\n \n \twiggle_x_offset = 0.01 * sin(time*10.0),\n \n x = starting_x + wiggle_x_offset + x_i_offset,\n y = starting_y + fall_distance //+ y_i_offset;\n \n ;\n \n gl_Position = vec4(x, y, 0, 1);\n \n gl_PointSize = 10.0;\n v_color = vec4(0, 0.8, 1, 1);\n \n}" + }, "screenshotURL": "data/images/images-e33hloz13jcbwvkwn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LorQPsDrEHNowrcw5/art.json b/art/LorQPsDrEHNowrcw5/art.json index 1cecac1d..6a3e0f34 100644 --- a/art/LorQPsDrEHNowrcw5/art.json +++ b/art/LorQPsDrEHNowrcw5/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":466,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2784313725490196,0.00784313725490196,0.9176470588235294,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n float x = mod(vertexId,across);\\n float y = floor(vertexId/across);\\n float u = x/(across-1.);\\n float v = y/(across- 1.);\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/ 600.;\\n v_color = vec4(u,v,0,1);\\n}\"}", + "settings": { + "num": 466, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2784313725490196, + 0.00784313725490196, + 0.9176470588235294, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n float x = mod(vertexId,across);\n float y = floor(vertexId/across);\n float u = x/(across-1.);\n float v = y/(across- 1.);\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/ 600.;\n v_color = vec4(u,v,0,1);\n}" + }, "screenshotURL": "data/images/images-mhyoyj1mxu59yqsgc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LpSrFozFQa5LHaw8v/art.json b/art/LpSrFozFQa5LHaw8v/art.json index 4cf7d293..68080157 100644 --- a/art/LpSrFozFQa5LHaw8v/art.json +++ b/art/LpSrFozFQa5LHaw8v/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 5.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*10.,2.);\\n lineId/=numberOfElement;\\n\\n cubep*= min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+= xPos;\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n //float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 2., -1.2);//29./2.*abs(cos(time/5.))\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 5.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*10.,2.);\n lineId/=numberOfElement;\n\n cubep*= min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+= xPos;\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n //float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 2., -1.2);//29./2.*abs(cos(time/5.))\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-8y07lv3hgk4c0pb1r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LpWRC9LAg6ck6rSzf/art.json b/art/LpWRC9LAg6ck6rSzf/art.json index b5e37797..695edd8d 100644 --- a/art/LpWRC9LAg6ck6rSzf/art.json +++ b/art/LpWRC9LAg6ck6rSzf/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time * 1.1 + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * .5;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time * 1.1 + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * .5;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-q71qaduuozgoge1le-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LqFT5m3gwdtNfjFnA/art.json b/art/LqFT5m3gwdtNfjFnA/art.json index 8fc6e201..015316c1 100644 --- a/art/LqFT5m3gwdtNfjFnA/art.json +++ b/art/LqFT5m3gwdtNfjFnA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=36000\\n\\n\\n#define slideSpeed 5. //KParameter 0.>>30.\\n\\n#define fakeVerticeNumber 72000.\\n\\n\\n#define PI radians( 180.0 )\\n\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\\n float f = tan(PI * 0.5 - 0.5 * _fov);\\n float rInv = 1.0 / (_zNear - _zFar);\\n\\n return mat4(\\n f / _aspect, 0., 0., 0.,\\n 0., f, 0., 0.,\\n 0., 0., (_zNear + _zFar) * rInv, -1.,\\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\\n}\\n\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo, const vec2 _sceneSize)\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.2);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n float center = _sceneSize.x/2.;\\n AddPointLight( vec3(0.0, center, 2.0), vec3( 1.0, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 1.0, 1., 1.), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 0.0, 2.9, 0.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI, in vec3 _sizes)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(0.5, 0.5);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-0.5, 0.5);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(0.5, -0.5);\\n }\\n else {\\n fp = vec2(-0.5, -0.5);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 0.5);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -0.5);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 0.5, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -0.5, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-0.5, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(0.50, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n\\n\\n//#define MOVING_SHAPES\\n#define SOUND_ON\\n#define EYE_STYLE 0\\nvoid main() \\n{\\n \\n vec2 gridDim = vec2(2.,2.);\\n //Given the number of vertices, find the best config\\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\\n \\n //shape\\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\\n float shapeId = floor(finalVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n float xCount, zCount;\\n xCount = floor(sqrt(shapeCount));\\n zCount = xCount;\\n \\n \\n float marginSize = 0.2;//in % of cube size\\n\\n float xIndex = mod(shapeId,xCount);\\n float zIndex = floor(shapeId/xCount);\\n float relx = xIndex/xCount;\\n float relz = zIndex/zCount;\\n \\n #ifdef SOUND_ON\\n float snd = 10.*texture2D(sound, vec2(1. - relx, 1. -relz)).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n vec4 cNorm;\\n \\n vec3 sizes = vec3(1.,1.,1.);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm, sizes);\\n \\n float lineWidth = gridDim.x/xCount; //the shape 'line' size including margins\\n float cubeWidth = lineWidth - (marginSize*lineWidth);//the shape size\\n mat4 scaleMat = scale(vec3(cubeWidth,(1.+snd)*cubeWidth,cubeWidth));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n\\n #ifdef MOVING_SHAPES\\n cubep += vec3(zIndex*lineWidth, 0., mod(xIndex - time*slideSpeed,xCount)*cubeSize); \\n #else\\n cubep += vec3(xIndex*lineWidth, 0., zIndex*lineWidth);\\n #endif\\n \\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = cubep;\\n surfaceInfo.vNormal = cNorm.xyz;\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n \\n float dim = 1.;\\n\\n float pos = xCount*lineWidth;\\n \\n \\n float eyePosY = 1.2;//10.*texture2D(sound, vec2(relcol, 0.)).a; \\n float eyeSpeedFactor = 0.2;\\n #if EYE_STYLE == 0\\n vec3 eye = vec3(gridDim.x/2.+gridDim.x/2.*cos(time*eyeSpeedFactor), eyePosY, gridDim.x/2.+gridDim.x/2.*sin(time*eyeSpeedFactor))*dim;\\n #else\\n vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\\n #endif\\n //vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\\n //vec3 eye = vec3(pos+sin(time*1.57), 0.6, pos+cos(time*0.2))*dim;\\n vec3 target = vec3(gridDim.x/2., 0., gridDim.x/2.)*dim;\\n vec3 up = vec3(0., 1., 0.);\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n \\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n \\n vec3 vAlbedo = vec3(1.0, 1.0, 1.0);\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo, gridDim ); \\n\\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=36000\n\n\n#define slideSpeed 5. //KParameter 0.>>30.\n\n#define fakeVerticeNumber 72000.\n\n\n#define PI radians( 180.0 )\n\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\n float f = tan(PI * 0.5 - 0.5 * _fov);\n float rInv = 1.0 / (_zNear - _zFar);\n\n return mat4(\n f / _aspect, 0., 0., 0.,\n 0., f, 0., 0.,\n 0., 0., (_zNear + _zFar) * rInv, -1.,\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\n}\n\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo, const vec2 _sceneSize)\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.2);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n float center = _sceneSize.x/2.;\n AddPointLight( vec3(0.0, center, 2.0), vec3( 1.0, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 1.0, 1., 1.), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 0.0, 2.9, 0.5), surfaceInfo, vDiffuseLight, vSpecLight );\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI, in vec3 _sizes)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(0.5, 0.5);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-0.5, 0.5);\n }\n else if(vtxId == 3.0) {\n fp = vec2(0.5, -0.5);\n }\n else {\n fp = vec2(-0.5, -0.5);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 0.5);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -0.5);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 0.5, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -0.5, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-0.5, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(0.50, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n\n\n//#define MOVING_SHAPES\n#define SOUND_ON\n#define EYE_STYLE 0\nvoid main() \n{\n \n vec2 gridDim = vec2(2.,2.);\n //Given the number of vertices, find the best config\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\n \n //shape\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\n float shapeId = floor(finalVertexId / kShapeVertexCount);\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n float xCount, zCount;\n xCount = floor(sqrt(shapeCount));\n zCount = xCount;\n \n \n float marginSize = 0.2;//in % of cube size\n\n float xIndex = mod(shapeId,xCount);\n float zIndex = floor(shapeId/xCount);\n float relx = xIndex/xCount;\n float relz = zIndex/zCount;\n \n #ifdef SOUND_ON\n float snd = 10.*texture2D(sound, vec2(1. - relx, 1. -relz)).a;\n #else\n float snd = 1.;\n #endif\n \n vec4 cNorm;\n \n vec3 sizes = vec3(1.,1.,1.);\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm, sizes);\n \n float lineWidth = gridDim.x/xCount; //the shape 'line' size including margins\n float cubeWidth = lineWidth - (marginSize*lineWidth);//the shape size\n mat4 scaleMat = scale(vec3(cubeWidth,(1.+snd)*cubeWidth,cubeWidth));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n\n #ifdef MOVING_SHAPES\n cubep += vec3(zIndex*lineWidth, 0., mod(xIndex - time*slideSpeed,xCount)*cubeSize); \n #else\n cubep += vec3(xIndex*lineWidth, 0., zIndex*lineWidth);\n #endif\n \n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = cubep;\n surfaceInfo.vNormal = cNorm.xyz;\n\n vec3 vViewPos = surfaceInfo.vPos;\n \n float dim = 1.;\n\n float pos = xCount*lineWidth;\n \n \n float eyePosY = 1.2;//10.*texture2D(sound, vec2(relcol, 0.)).a; \n float eyeSpeedFactor = 0.2;\n #if EYE_STYLE == 0\n vec3 eye = vec3(gridDim.x/2.+gridDim.x/2.*cos(time*eyeSpeedFactor), eyePosY, gridDim.x/2.+gridDim.x/2.*sin(time*eyeSpeedFactor))*dim;\n #else\n vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\n #endif\n //vec3 eye = vec3(gridDim.x/2., eyePosY, -1.3)*dim;\n //vec3 eye = vec3(pos+sin(time*1.57), 0.6, pos+cos(time*0.2))*dim;\n vec3 target = vec3(gridDim.x/2., 0., gridDim.x/2.)*dim;\n vec3 up = vec3(0., 1., 0.);\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n \n gl_Position = pmat * vmat * vec4(cubep, 1);\n \n vec3 vAlbedo = vec3(1.0, 1.0, 1.0);\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo, gridDim ); \n\n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\n\n" + }, "screenshotURL": "data/images/images-z7ep0sucz5bmu0n3q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LqqzrrF9Dgq3J5Z4P/art.json b/art/LqqzrrF9Dgq3J5Z4P/art.json index 9fa3c2b9..43596161 100644 --- a/art/LqqzrrF9Dgq3J5Z4P/art.json +++ b/art/LqqzrrF9Dgq3J5Z4P/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":40000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Color\\n//Course : CS250\\n//Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + k.xyz) * 9.0 - k.www);\\n \\treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main()\\n{ \\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across) + 1.0;\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across * 0.2 - 1.0);\\n \\tfloat v = y / (across / 2.0);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 5.0 + xoff * 10.0 + sin(time) + cos(u * time) / 20.0;\\n \\tfloat vy = v * 3.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.1;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time * 1.2 + x * y * 0.02) * 0.5;\\n \\n \\tgl_PointSize = 25.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 500.0;\\n \\n \\tfloat hue = u * 0.1 + sin(time * 1.3 + v * 20.0);\\n \\tfloat sat = v;\\n \\tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 40000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Color\n//Course : CS250\n//Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + k.xyz) * 9.0 - k.www);\n \treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main()\n{ \n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across) + 1.0;\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across * 0.2 - 1.0);\n \tfloat v = y / (across / 2.0);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n \tfloat ux = u * 5.0 + xoff * 10.0 + sin(time) + cos(u * time) / 20.0;\n \tfloat vy = v * 3.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.1;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time * 1.2 + x * y * 0.02) * 0.5;\n \n \tgl_PointSize = 25.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 500.0;\n \n \tfloat hue = u * 0.1 + sin(time * 1.3 + v * 20.0);\n \tfloat sat = v;\n \tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-0jk0s7oxypkp8o4pv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LrWhYy7j7kZTWy5FC/art.json b/art/LrWhYy7j7kZTWy5FC/art.json index 0aa8c655..fa1f7659 100644 --- a/art/LrWhYy7j7kZTWy5FC/art.json +++ b/art/LrWhYy7j7kZTWy5FC/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mhorga", "avatarUrl": "https://secure.gravatar.com/avatar/00bbccef092919170c720cae49be2403?default=retro&size=200", - "settings": "{\"num\":2000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.17647058823529413,1],\"shader\":\"// circles made of triangles - try > 2000 vertices for smooth edge\\nvoid main() {\\n float x = floor(vertexId / 6.) + mod(vertexId, 2.);\\n float y = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float s = sin(x);\\n float c = cos(x);\\n float radius = y + 1.;\\n x = s * radius;\\n y = c * radius;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * 0.1, 0, 1);\\n v_color = vec4(1, 0 , 0, 1);\\n}\\n\\n#if 0\\n\\n// a mesh made out of triangles (switch to Triangles primitive)\\nvoid main() {\\n float x = floor(vertexId / 6.) + mod(vertexId, 2.);\\n float y = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * 0.1, 0, 1);\\n v_color = vec4(1, 0 , 0, 1)\\n}\\n\\n// a grid made of points (switch to using Points primitive)\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across) / (across - 1.);\\n float y = floor(vertexId / across) / (across - 1.);\\n float u = x * 2. - 1.;\\n float v = y * 2. - 1.;\\n gl_Position = vec4(u, v, 0, 1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.; \\n v_color = vec4(1, 0 , 0, 1); \\n}\\n\\n#endif\\n\"}", + "settings": { + "num": 2000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.17647058823529413, + 1 + ], + "shader": "// circles made of triangles - try > 2000 vertices for smooth edge\nvoid main() {\n float x = floor(vertexId / 6.) + mod(vertexId, 2.);\n float y = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float s = sin(x);\n float c = cos(x);\n float radius = y + 1.;\n x = s * radius;\n y = c * radius;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * 0.1, 0, 1);\n v_color = vec4(1, 0 , 0, 1);\n}\n\n#if 0\n\n// a mesh made out of triangles (switch to Triangles primitive)\nvoid main() {\n float x = floor(vertexId / 6.) + mod(vertexId, 2.);\n float y = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * 0.1, 0, 1);\n v_color = vec4(1, 0 , 0, 1)\n}\n\n// a grid made of points (switch to using Points primitive)\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across) / (across - 1.);\n float y = floor(vertexId / across) / (across - 1.);\n float u = x * 2. - 1.;\n float v = y * 2. - 1.;\n gl_Position = vec4(u, v, 0, 1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.; \n v_color = vec4(1, 0 , 0, 1); \n}\n\n#endif\n" + }, "screenshotURL": "data/images/images-9pxc9hor06vyndqni-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LsoEApydzv2sCKs27/art.json b/art/LsoEApydzv2sCKs27/art.json index b74d7430..0b92f13a 100644 --- a/art/LsoEApydzv2sCKs27/art.json +++ b/art/LsoEApydzv2sCKs27/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nfloat segment(vec2 p, vec2 a, vec2 b) {\\n vec2 ab = b - a;\\n vec2 ap = p - a;\\n float k = clamp(dot(ap, ab)/dot(ab, ab), 0.0, 1.0);\\n return smoothstep(0.0, 5.0/resolution.y, length(ap - k*ab) - 0.001);\\n}\\n\\nfloat shape(float u,vec2 p, float angle) {\\n float d = 100.0;\\n vec2 a = vec2(1.0, 0.0), b;\\n vec2 rot = vec2(cos(angle), sin(angle)*u);\\n \\n for (int i = 0; i < 6; ++i) {\\n b = a;\\n for (int j = 0; j < 18; ++j) {\\n \\tb = vec2(b.x*rot.x - b.y*rot.y, b.x*rot.y + b.y*rot.x);\\n \\td = min(d, segment(p, a, b));\\n }\\n a = vec2(a.x*rot.x - a.y*rot.y, a.x*rot.y + a.y*rot.x);\\n }\\n return d;\\n}\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n float snd = texture2D(sound, vec2(0., 0.2)).a;\\n \\n \\n //apply fragment logic\\n\\n\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\t\\tvec2 uv = p.xy / res.xy;\\n vec2 cc = (-res.xy + 2.0*p.xy) / res.y;\\n \\n float numPhases=1114.5;\\n float u1;\\n float t;\\n float SpeedReal=0.2532;\\n u1=0.005+(snd*2.2);\\n t = snd * numPhases;\\n\\n float col = shape(u1,abs(cc), t+cos(0.01*(time*SpeedReal))*TAU);\\n col *= 0.5 + 1.5*pow(uv.x*uv.y*(1.0-uv.x)*(1.0-uv.y), 0.3);\\n \\n \\n\\t//gl_FragColor = vec4(vec3(pow(1.0-col, 2.15)),1.0);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(pow(1.0-col, 2.15)),1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nfloat segment(vec2 p, vec2 a, vec2 b) {\n vec2 ab = b - a;\n vec2 ap = p - a;\n float k = clamp(dot(ap, ab)/dot(ab, ab), 0.0, 1.0);\n return smoothstep(0.0, 5.0/resolution.y, length(ap - k*ab) - 0.001);\n}\n\nfloat shape(float u,vec2 p, float angle) {\n float d = 100.0;\n vec2 a = vec2(1.0, 0.0), b;\n vec2 rot = vec2(cos(angle), sin(angle)*u);\n \n for (int i = 0; i < 6; ++i) {\n b = a;\n for (int j = 0; j < 18; ++j) {\n \tb = vec2(b.x*rot.x - b.y*rot.y, b.x*rot.y + b.y*rot.x);\n \td = min(d, segment(p, a, b));\n }\n a = vec2(a.x*rot.x - a.y*rot.y, a.x*rot.y + a.y*rot.x);\n }\n return d;\n}\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n float snd = texture2D(sound, vec2(0., 0.2)).a;\n \n \n //apply fragment logic\n\n\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\t\tvec2 uv = p.xy / res.xy;\n vec2 cc = (-res.xy + 2.0*p.xy) / res.y;\n \n float numPhases=1114.5;\n float u1;\n float t;\n float SpeedReal=0.2532;\n u1=0.005+(snd*2.2);\n t = snd * numPhases;\n\n float col = shape(u1,abs(cc), t+cos(0.01*(time*SpeedReal))*TAU);\n col *= 0.5 + 1.5*pow(uv.x*uv.y*(1.0-uv.x)*(1.0-uv.y), 0.3);\n \n \n\t//gl_FragColor = vec4(vec3(pow(1.0-col, 2.15)),1.0);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(pow(1.0-col, 2.15)),1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-y5xsqor1zi5hddauc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LuZZ97aigeATvKnsh/art.json b/art/LuZZ97aigeATvKnsh/art.json index 487489d9..54db0dec 100644 --- a/art/LuZZ97aigeATvKnsh/art.json +++ b/art/LuZZ97aigeATvKnsh/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "langtoner", "avatarUrl": "https://secure.gravatar.com/avatar/dceb35cad80ced6f55f55cf8d2fd8971?default=retro&size=200", - "settings": "{\"num\":10,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\ngl_Position = vec4(0,0,0,1);\\ngl_PointSize = 10.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 10, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\ngl_Position = vec4(0,0,0,1);\ngl_PointSize = 10.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-pprvk0gvxrs303gcl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LubzbLTSn6qdhTHhs/art.json b/art/LubzbLTSn6qdhTHhs/art.json index d94126d9..f9ec6115 100644 --- a/art/LubzbLTSn6qdhTHhs/art.json +++ b/art/LubzbLTSn6qdhTHhs/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":51951,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 -1.//KParameter 0.>>-10.\\n#define P4 1.//KParameter 0.>>10.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 1.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0.5,\\n s, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 1.-c, 1, 0, -0.50,\\n -s, 1, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 0,-s, 0, 0, \\n s, c, 0, .50,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 2, 0, 0, 0,\\n 0, 1, 0, .50,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 0.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[3][0], m[1][0], m[2][0], \\n m[3][1], m[1][1], m[2][1], \\n m[0][2], m[1][0], m[3][1]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 * a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 * a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 - b02) + det*mouse.y;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.6,\\n yAxis,1 -1.4,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis/33., snd *eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (333. *(P2+3.5))+10.;\\n float numQuads = floor( vertexCount/6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) -(mouse.y * r);\\n float y = sin(qu * PI * 2.* P4) * r;\\n \\n vec3 pos = vec3(x, y, mouse*((qv * PI )));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId / 0.66663;\\n float sat = quadId -3.3;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 01.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 51951, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 -1.//KParameter 0.>>-10.\n#define P4 1.//KParameter 0.>>10.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 1.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0.5,\n s, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 1.-c, 1, 0, -0.50,\n -s, 1, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 0,-s, 0, 0, \n s, c, 0, .50,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 2, 0, 0, 0,\n 0, 1, 0, .50,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 0.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[3][0], m[1][0], m[2][0], \n m[3][1], m[1][1], m[2][1], \n m[0][2], m[1][0], m[3][1]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 * a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 * a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 - b02) + det*mouse.y;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.6,\n yAxis,1 -1.4,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis/33., snd *eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (333. *(P2+3.5))+10.;\n float numQuads = floor( vertexCount/6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) -(mouse.y * r);\n float y = sin(qu * PI * 2.* P4) * r;\n \n vec3 pos = vec3(x, y, mouse*((qv * PI )));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId / 0.66663;\n float sat = quadId -3.3;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 01.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-qcles2nwa1lrn2r5s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LucsLY5k9d68aLNgv/art.json b/art/LucsLY5k9d68aLNgv/art.json index 9e46c993..12f8d0f8 100644 --- a/art/LucsLY5k9d68aLNgv/art.json +++ b/art/LucsLY5k9d68aLNgv/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":94,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat rand(float p){\\n \\treturn fract(sin(p*10000./time));\\n}\\n\\nfloat noise(vec2 p)\\n{\\n return rand((p.x + p.y) * 1000.00);\\n}\\n\\nvoid main() {\\n vec2 uv = vec2(sin(time+ vertexId + time),tan(time + vertexId));\\n gl_Position = vec4(uv,0,1);\\n gl_PointSize = 100.;\\n v_color = vec4(1);\\n v_color.a*= noise(uv *time); \\n vec3 gle = vec3(rand(vertexId),rand(sin(time)),rand(vertexCount));\\n v_color.rgb *= gle;\\n}\"}", + "settings": { + "num": 94, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat rand(float p){\n \treturn fract(sin(p*10000./time));\n}\n\nfloat noise(vec2 p)\n{\n return rand((p.x + p.y) * 1000.00);\n}\n\nvoid main() {\n vec2 uv = vec2(sin(time+ vertexId + time),tan(time + vertexId));\n gl_Position = vec4(uv,0,1);\n gl_PointSize = 100.;\n v_color = vec4(1);\n v_color.a*= noise(uv *time); \n vec3 gle = vec3(rand(vertexId),rand(sin(time)),rand(vertexCount));\n v_color.rgb *= gle;\n}" + }, "screenshotURL": "data/images/images-c1c6we7osvcd4tyzc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/LvJLKq69EEcAHDcJh/art.json b/art/LvJLKq69EEcAHDcJh/art.json index 5cb4796a..359a5c25 100644 --- a/art/LvJLKq69EEcAHDcJh/art.json +++ b/art/LvJLKq69EEcAHDcJh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1831,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 circleCoord(float angle, float rad) {\\n return vec2(cos(radians(angle)) * rad, sin(radians(angle)) * rad);\\n}\\n\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n/* float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);*/\\n // gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n // gl_Position = vec4(-1, sin(time), 0, 1);\\n// gl_Position = vec4(circleCoord(vertexId * 4.0, 0.2 * time * 0.005), 0.9, 1);\\n vec2 actual_coord = vec2(-1.0 + (vertexId / 1000.0), 0);\\n gl_Position = vec4(circleCoord(time*50., -1. + (vertexId) / 1000.), 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n gl_PointSize = 5.0;\\n}\"}", + "settings": { + "num": 1831, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 circleCoord(float angle, float rad) {\n return vec2(cos(radians(angle)) * rad, sin(radians(angle)) * rad);\n}\n\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n/* float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);*/\n // gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n // gl_Position = vec4(-1, sin(time), 0, 1);\n// gl_Position = vec4(circleCoord(vertexId * 4.0, 0.2 * time * 0.005), 0.9, 1);\n vec2 actual_coord = vec2(-1.0 + (vertexId / 1000.0), 0);\n gl_Position = vec4(circleCoord(time*50., -1. + (vertexId) / 1000.), 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n gl_PointSize = 5.0;\n}" + }, "screenshotURL": "data/images/images-p0wqlcon0xw76q8g5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LvcnWcXcAvYeK7Hmf/art.json b/art/LvcnWcXcAvYeK7Hmf/art.json index d4054137..cbcb53b3 100644 --- a/art/LvcnWcXcAvYeK7Hmf/art.json +++ b/art/LvcnWcXcAvYeK7Hmf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":57755,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter 1.>>3.\\n#define parameter1 3.//KParameter 0.1>>3.\\n#define parameter2 1.//KParameter -1.>>1.\\n#define parameter3 -0.1//KParameter -0.5>2.\\n#define parameter4 1.3//KParameter 0.5>>2.\\n#define parameter5 1.//KParameter 0.>>3.\\n#define parameter6 1.//KParameter 0.>>1.\\n#define parameter7 1.//KParameter 0.>>1.\\n#define PI radians(190.)\\n//KVerticesNumber=65000\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *17.,s)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 57755, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter 1.>>3.\n#define parameter1 3.//KParameter 0.1>>3.\n#define parameter2 1.//KParameter -1.>>1.\n#define parameter3 -0.1//KParameter -0.5>2.\n#define parameter4 1.3//KParameter 0.5>>2.\n#define parameter5 1.//KParameter 0.>>3.\n#define parameter6 1.//KParameter 0.>>1.\n#define parameter7 1.//KParameter 0.>>1.\n#define PI radians(190.)\n//KVerticesNumber=65000\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *17.,s)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-m26c3rwhh57nmku13-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LwRP8tRgdnHBEYtuM/art.json b/art/LwRP8tRgdnHBEYtuM/art.json index b71eeacc..10883c31 100644 --- a/art/LwRP8tRgdnHBEYtuM/art.json +++ b/art/LwRP8tRgdnHBEYtuM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "makavelli3145", "avatarUrl": "https://avatars.githubusercontent.com/makavelli3145?s=200", - "settings": "{\"num\":2340,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mouthofvigilance/womb-handsaloof?in=mouthofvigilance/sets/handsaloof\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09411764705882353,0.14901960784313725,0.611764705882353,1],\"shader\":\"void main(){\\n\\n \\tfloat x1 = vertexId/ 10.;\\n \\tfloat y1 = vertexId/10.;\\n \\ty1 = y1*y1;\\n \\n \\tfloat x2 = mod(vertexId, 10.0);\\n \\tfloat y2 = floor(vertexId/10.0);\\n \\n \\tfloat x3 = x2/10.0;\\n \\tfloat y3 = y2/10.0;\\n \\t\\n \\n \\t//gl_Position = vec4(0, 0, 0, 1);\\n //gl_Position = vec4(x, 0, 0, 1);\\n \\t//gl_Position = vec4(x1, y1, 0, 1);\\n \\t//gl_Position = vec4(x2, y2, 0, 1);\\n \\tgl_Position = vec4(x3, y3, 0, 1);\\n \\n \\tgl_PointSize = 10.0;\\n \\n \\t\\n \\t//Note that v_color is unique to vertexshaderart\\n \\tv_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 2340, + "mode": "POINTS", + "sound": "https://soundcloud.com/mouthofvigilance/womb-handsaloof?in=mouthofvigilance/sets/handsaloof", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09411764705882353, + 0.14901960784313725, + 0.611764705882353, + 1 + ], + "shader": "void main(){\n\n \tfloat x1 = vertexId/ 10.;\n \tfloat y1 = vertexId/10.;\n \ty1 = y1*y1;\n \n \tfloat x2 = mod(vertexId, 10.0);\n \tfloat y2 = floor(vertexId/10.0);\n \n \tfloat x3 = x2/10.0;\n \tfloat y3 = y2/10.0;\n \t\n \n \t//gl_Position = vec4(0, 0, 0, 1);\n //gl_Position = vec4(x, 0, 0, 1);\n \t//gl_Position = vec4(x1, y1, 0, 1);\n \t//gl_Position = vec4(x2, y2, 0, 1);\n \tgl_Position = vec4(x3, y3, 0, 1);\n \n \tgl_PointSize = 10.0;\n \n \t\n \t//Note that v_color is unique to vertexshaderart\n \tv_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-xn45dxdmd1os73mjo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/LyBvXsiJxi4cJ9T3G/art.json b/art/LyBvXsiJxi4cJ9T3G/art.json index 9ceb6528..011ce06f 100644 --- a/art/LyBvXsiJxi4cJ9T3G/art.json +++ b/art/LyBvXsiJxi4cJ9T3G/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\nfloat gFogDensity = 0.01;\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\nfloat gCubeColorRandom = 0.4;\\n#endif\\n\\n#ifdef COLOR_VIVID\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\nfloat gFogDensity = 0.05;\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\nfloat gCubeColorRandom = 0.9;\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.25, 0.15) * 10.0; \\nvec3 gSkyTop = vec3( 1.0, 0.58, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\nfloat gFogDensity = 0.095;\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\nfloat gCubeColorRandom = 0.5;\\n#endif\\n\\n#define MOVE_OUTWARDS\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n#define PI radians( 180.0 )\\n\\nvec3 GetSunDir(){ \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );}\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId ){\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV ){\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV ){\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m ){\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m ){\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 ) { vY = vec3( 1.0, 0.0, 0.0 ); }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\nstruct SceneVertex{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\nfloat GetCosSunRadius(){ \\t\\treturn 0.01;}\\nfloat GetSunIntensity(){ \\t \\treturn 0.001;}\\nvec3 GetSkyColor( vec3 vViewDir ){\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nvec3 GetBackdropColor( vec3 vViewDir ){\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\tfloat fShade = 0.0;\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex ){\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices ); \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n \\tvWorldSpherePos += vCameraPos; \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\nfloat gFogDensity = 0.01;\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\nfloat gCubeColorRandom = 0.4;\n#endif\n\n#ifdef COLOR_VIVID\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\nfloat gFogDensity = 0.05;\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\nfloat gCubeColorRandom = 0.9;\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.25, 0.15) * 10.0; \nvec3 gSkyTop = vec3( 1.0, 0.58, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\nfloat gFogDensity = 0.095;\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\nfloat gCubeColorRandom = 0.5;\n#endif\n\n#define MOVE_OUTWARDS\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n#define PI radians( 180.0 )\n\nvec3 GetSunDir(){ \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );}\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId ){\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV ){\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV ){\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m ){\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m ){\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 ) { vY = vec3( 1.0, 0.0, 0.0 ); }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\nstruct SceneVertex{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\nfloat GetCosSunRadius(){ \t\treturn 0.01;}\nfloat GetSunIntensity(){ \t \treturn 0.001;}\nvec3 GetSkyColor( vec3 vViewDir ){\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nvec3 GetBackdropColor( vec3 vViewDir ){\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \tfloat fShade = 0.0;\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \tfloat fCosSunRadius = GetCosSunRadius();\n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex ){\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices ); \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n \tvWorldSpherePos += vCameraPos; \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-u7ag9npovta39fgxc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/M3TQnRJ4QA4c5vpBc/art.json b/art/M3TQnRJ4QA4c5vpBc/art.json index acbceeb4..622fbb9f 100644 --- a/art/M3TQnRJ4QA4c5vpBc/art.json +++ b/art/M3TQnRJ4QA4c5vpBc/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "monguri", "avatarUrl": "https://avatars.githubusercontent.com/monguri?s=200", - "settings": "{\"num\":4,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec2 getPosition(vec2 resolution, float index)\\n{\\n\\tfloat signX = ((index < 2.0) ? -1.0 : 1.0);\\n\\tfloat signY = ((index == 0.0 || index == 3.0) ? -1.0 : 1.0);\\n\\treturn vec2(\\n\\t\\tresolution.x * 0.25 * signX * 0.001,\\n\\t\\tresolution.x * 0.25 * signY * 0.001\\n\\t);\\n}\\n \\nvoid main() {\\n\\tgl_Position = vec4(getPosition(resolution, vertexId).xy, 0, 1);\\n\\tv_color = vec4(1, 1, 1, 1);\\n}\\n\"}", + "settings": { + "num": 4, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec2 getPosition(vec2 resolution, float index)\n{\n\tfloat signX = ((index < 2.0) ? -1.0 : 1.0);\n\tfloat signY = ((index == 0.0 || index == 3.0) ? -1.0 : 1.0);\n\treturn vec2(\n\t\tresolution.x * 0.25 * signX * 0.001,\n\t\tresolution.x * 0.25 * signY * 0.001\n\t);\n}\n \nvoid main() {\n\tgl_Position = vec4(getPosition(resolution, vertexId).xy, 0, 1);\n\tv_color = vec4(1, 1, 1, 1);\n}\n" + }, "screenshotURL": "data/images/images-j0ouh0mux015s1cot-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/M6uEwrn2PMs7yXoRA/art.json b/art/M6uEwrn2PMs7yXoRA/art.json index cc5c0fd8..2199f5b1 100644 --- a/art/M6uEwrn2PMs7yXoRA/art.json +++ b/art/M6uEwrn2PMs7yXoRA/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount)); // gets the count of rows\\n float across = floor(vertexCount / down); // gets the count of columns\\n \\n // vertexId is the \\n float x = mod(vertexId, across); // always use floats\\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = sin(time + y * 0.2) * 0.1; \\n float yOffset = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset; // gets value from -1 to 1\\n float uy = v * 2.0 - 1.0 + yOffset; // gets value from -1 to 1\\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n float sizeOffset = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 200.0 / across; // set point size\\n gl_PointSize *= resolution.x / 600.0 + sizeOffset;\\n \\n float hue = u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float sat = 1.;\\n float value = sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1); // this is unique to vertex shader art\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount)); // gets the count of rows\n float across = floor(vertexCount / down); // gets the count of columns\n \n // vertexId is the \n float x = mod(vertexId, across); // always use floats\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = sin(time + y * 0.2) * 0.1; \n float yOffset = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset; // gets value from -1 to 1\n float uy = v * 2.0 - 1.0 + yOffset; // gets value from -1 to 1\n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n float sizeOffset = sin(time + x * y * 0.02) * 5.0;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 200.0 / across; // set point size\n gl_PointSize *= resolution.x / 600.0 + sizeOffset;\n \n float hue = u * 0.1 + sin(time + v * 20.0) * 0.05;\n float sat = 1.;\n float value = sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1); // this is unique to vertex shader art\n}" + }, "screenshotURL": "data/images/images-xky0chefkr16isr4a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/M8SShtkWcQkZ4XLZ4/art.json b/art/M8SShtkWcQkZ4XLZ4/art.json index 3200a943..04c2ed80 100644 --- a/art/M8SShtkWcQkZ4XLZ4/art.json +++ b/art/M8SShtkWcQkZ4XLZ4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "vidarw", "avatarUrl": "https://avatars.githubusercontent.com/vidarw?s=200", - "settings": "{\"num\":99647,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/eboo11/trust-no-one-001\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec2 rotate(vec2 point, float degree, vec2 pivot)\\n{\\n float radAngle = -radians(degree);// \\\"-\\\" - clockwise\\n float x = point.x;\\n float y = point.y;\\n\\n float rX = pivot.x + (x - pivot.x) * cos(radAngle) - (y - pivot.y) * sin(radAngle);\\n float rY = pivot.y + (x - pivot.x) * sin(radAngle) + (y - pivot.y) * cos(radAngle);\\n\\n return vec2(rX, rY);\\n}\\n\\nvoid pond() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.; // center u and create symmetry;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .250, av * .25)).a; // Only using parts of the spectrum and 1 second of data.\\n \\n float x_offset = 0.; // sin(time + y * 0.01) * .4;\\n float y_offset = 0.; // sin(time + x * 0.01) * .1;\\n \\n float ux = u * 2. - 1. + x_offset;\\n float vy = v * 2. - 1. + y_offset;\\n \\n \\n vec2 xy = rotate(vec2(ux, vy) * 0.6, time * snd, vec2(0, 0));\\n \\n gl_Position = vec4(xy, 0, 1); \\n \\n\\n \\n float s_offset = 0.; // sin(time + x * y * 0.03) * 2.;\\n \\n \\n gl_PointSize = snd * 10.0 + s_offset;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float hue = abs(sin(snd)*1.);\\n float sat = 1.;\\n float val = pow(snd + 0.3, 5.0);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); \\n}\\n\\n\\nvoid main() {\\n pond();\\n}\"}", + "settings": { + "num": 99647, + "mode": "POINTS", + "sound": "https://soundcloud.com/eboo11/trust-no-one-001", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec2 rotate(vec2 point, float degree, vec2 pivot)\n{\n float radAngle = -radians(degree);// \"-\" - clockwise\n float x = point.x;\n float y = point.y;\n\n float rX = pivot.x + (x - pivot.x) * cos(radAngle) - (y - pivot.y) * sin(radAngle);\n float rY = pivot.y + (x - pivot.x) * sin(radAngle) + (y - pivot.y) * cos(radAngle);\n\n return vec2(rX, rY);\n}\n\nvoid pond() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.; // center u and create symmetry;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .250, av * .25)).a; // Only using parts of the spectrum and 1 second of data.\n \n float x_offset = 0.; // sin(time + y * 0.01) * .4;\n float y_offset = 0.; // sin(time + x * 0.01) * .1;\n \n float ux = u * 2. - 1. + x_offset;\n float vy = v * 2. - 1. + y_offset;\n \n \n vec2 xy = rotate(vec2(ux, vy) * 0.6, time * snd, vec2(0, 0));\n \n gl_Position = vec4(xy, 0, 1); \n \n\n \n float s_offset = 0.; // sin(time + x * y * 0.03) * 2.;\n \n \n gl_PointSize = snd * 10.0 + s_offset;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float hue = abs(sin(snd)*1.);\n float sat = 1.;\n float val = pow(snd + 0.3, 5.0);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); \n}\n\n\nvoid main() {\n pond();\n}" + }, "screenshotURL": "data/images/images-ryajn33qbh37h28ua-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/M922vaDbAxvAZALbx/art.json b/art/M922vaDbAxvAZALbx/art.json index 7dd3c39f..1b91fc33 100644 --- a/art/M922vaDbAxvAZALbx/art.json +++ b/art/M922vaDbAxvAZALbx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":22222,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 22222, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-ksqxhvymx2jhw00yc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/M9HqzgN5qio4LRDxq/art.json b/art/M9HqzgN5qio4LRDxq/art.json index 6a27ada8..14e23554 100644 --- a/art/M9HqzgN5qio4LRDxq/art.json +++ b/art/M9HqzgN5qio4LRDxq/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":6812,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 77.//KParameter0 0.>>1000.\\n#define KP1 5.//KParameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>10.\\n#define KP3 0.20//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>5.\\n#define KP5 1000.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=38000\\n#define PI radians(180. -KP1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP2 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 11./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 0.1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 6812, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 77.//KParameter0 0.>>1000.\n#define KP1 5.//KParameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>10.\n#define KP3 0.20//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>5.\n#define KP5 1000.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=38000\n#define PI radians(180. -KP1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP2 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 11./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 0.1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-9fjhmly4e2v6rosii-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MA9L7t9wKoSZh4sHG/art.json b/art/MA9L7t9wKoSZh4sHG/art.json index f12c3bf7..fff797b9 100644 --- a/art/MA9L7t9wKoSZh4sHG/art.json +++ b/art/MA9L7t9wKoSZh4sHG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":30452,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5019607843137255,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float width = 10.0;\\n \\n float x =mod( vertexId,width);\\n float y = floor (vertexId / width);\\n \\n float u= x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y *0.2)*0.1;\\n float yOffset = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 * xOffset;\\n float vy = v * 2.0 - 1.0;\\n \\n \\n gl_Position = vec4(0,0,0,1.0);\\n gl_PointSize = 40.0;\\n v_color = vec4(1.0,0.0,0.0,2.0);\\n \\n \\n}\"}", + "settings": { + "num": 30452, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5019607843137255, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float width = 10.0;\n \n float x =mod( vertexId,width);\n float y = floor (vertexId / width);\n \n float u= x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y *0.2)*0.1;\n float yOffset = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 * xOffset;\n float vy = v * 2.0 - 1.0;\n \n \n gl_Position = vec4(0,0,0,1.0);\n gl_PointSize = 40.0;\n v_color = vec4(1.0,0.0,0.0,2.0);\n \n \n}" + }, "screenshotURL": "data/images/images-w24a9rashrfihe8ni-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ME2wYxKbBPSRwmXxf/art.json b/art/ME2wYxKbBPSRwmXxf/art.json index f467d2c5..71da4bc4 100644 --- a/art/ME2wYxKbBPSRwmXxf/art.json +++ b/art/ME2wYxKbBPSRwmXxf/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":2575,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define PHI_A (3.-sqrt(5.))* PI\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float scale = .35; // repeats/extends\\n float size = 0.001; // stretch/squeeze\\n float rad_max = (vertexCount * size);\\n \\n float theta = PHI_A * vertexId;// * PHI_A;\\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\\n float snd = texture2D(sound, vec2(fract(theta / 35.0), fract(theta / 80000.0))).a;\\n float radius = sqrt(vertexId * size) + snd;\\n \\n radius = radius * scale;\\n \\n float xoff = sin(time*0.8) * 0.8;\\n float yoff = sin(time*1.3) * 0.1;\\n gl_Position = vec4(cos(theta) * radius,\\n sin(theta) * radius,\\n 0, 1);\\n float soff = pow(snd + 0.02, 5.);\\n gl_PointSize = (soff + 2.) * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\\n\\n float hue = snd*0.01 + time * 0.1;\\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\\n 1. // change step to 0. (all pass) for no blackening\\n )), pow(snd, 5.));\\n}\"}", + "settings": { + "num": 2575, + "mode": "POINTS", + "sound": "https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define PHI_A (3.-sqrt(5.))* PI\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float scale = .35; // repeats/extends\n float size = 0.001; // stretch/squeeze\n float rad_max = (vertexCount * size);\n \n float theta = PHI_A * vertexId;// * PHI_A;\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\n float snd = texture2D(sound, vec2(fract(theta / 35.0), fract(theta / 80000.0))).a;\n float radius = sqrt(vertexId * size) + snd;\n \n radius = radius * scale;\n \n float xoff = sin(time*0.8) * 0.8;\n float yoff = sin(time*1.3) * 0.1;\n gl_Position = vec4(cos(theta) * radius,\n sin(theta) * radius,\n 0, 1);\n float soff = pow(snd + 0.02, 5.);\n gl_PointSize = (soff + 2.) * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\n\n float hue = snd*0.01 + time * 0.1;\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\n 1. // change step to 0. (all pass) for no blackening\n )), pow(snd, 5.));\n}" + }, "screenshotURL": "data/images/images-lksx0y4wq3sgnmr3s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MEwKmhHiC3nJoPSyW/art.json b/art/MEwKmhHiC3nJoPSyW/art.json index 8130f042..033767ae 100644 --- a/art/MEwKmhHiC3nJoPSyW/art.json +++ b/art/MEwKmhHiC3nJoPSyW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":60352,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/beerlove2/qfafaagzufdb?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6941176470588235,0.41568627450980394,0.8235294117647058,1],\"shader\":\"// Seulbin Seo\\n// Exercise Circles from Triangles\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n \\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) \\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n\\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\n\\nvoid main ()\\n{\\n float numCircleSegments = 27.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n float numPointPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointPerCircle);\\n float numCircles = floor(vertexCount / numPointPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(sv, su));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n\\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) *mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n\\n gl_Position = mat * pos;\\n \\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; // + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 60352, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/beerlove2/qfafaagzufdb?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6941176470588235, + 0.41568627450980394, + 0.8235294117647058, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Circles from Triangles\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n \n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) \n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n\n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\n\nvoid main ()\n{\n float numCircleSegments = 27.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n float numPointPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointPerCircle);\n float numCircles = floor(vertexCount / numPointPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(sv, su));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n\n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) *mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n\n gl_Position = mat * pos;\n \n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; // + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-a48rkn2shwowoqqmp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MFG9beZgKvqHQdo9F/art.json b/art/MFG9beZgKvqHQdo9F/art.json index b2288e42..2292b1ba 100644 --- a/art/MFG9beZgKvqHQdo9F/art.json +++ b/art/MFG9beZgKvqHQdo9F/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":41493,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0784313725490196,0.06274509803921569,0.0784313725490196,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 4.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\\n vec4 K = vec4(1.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time* 0.6 );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2/2.),\\n 1.-s, 0, 2, 0.4,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle / 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0.1, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 0.33, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, -1, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, -2, 0, 0.4);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[1], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, -0.1, 0.5, 0.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, s, s-mouse.x, 1.31,\\n s-0.5, 0.3, s, 0,\\n 2, 0.5, 0, 0.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 13.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 41493, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.06274509803921569, + 0.0784313725490196, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 4.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\n vec4 K = vec4(1.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time* 0.6 );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2/2.),\n 1.-s, 0, 2, 0.4,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle / 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0.1, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 0.33, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, -1, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, -2, 0, 0.4);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[1], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, -0.1, 0.5, 0.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, s, s-mouse.x, 1.31,\n s-0.5, 0.3, s, 0,\n 2, 0.5, 0, 0.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 13.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-j8vrxqccftc2jledk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MGJ5AcYQq32diSNSW/art.json b/art/MGJ5AcYQq32diSNSW/art.json index ce609074..66f564d4 100644 --- a/art/MGJ5AcYQq32diSNSW/art.json +++ b/art/MGJ5AcYQq32diSNSW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "epoch", "avatarUrl": "https://secure.gravatar.com/avatar/3e53f54468906b25ff02d4860fa32a28?default=retro&size=200", - "settings": "{\"num\":70155,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/drumcomplex/drumcomplex-roel-salemink-load-my-battery-bush-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 14.;\\n float across = 14.;\\n float back = 14.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float cz = floor(cubeId / across / back);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (back - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n float cc = cw * 2. - 1.;\\n \\n float sv1 = atan(ca, cb) / PI;\\n float sv = abs(atan(sv1, cc)) / PI;\\n \\n\\n float s1 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 3. / soundRes.y)).a;\\n float s = (s1 + s2 + s3 + s4) / 4.;\\n \\n s = mix(0., 1. + sv * .3, s);\\n s = clamp(s, 0., 1.);\\n \\n float tm = time * 0.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up);\\n mat4 wmat = rotY(time * 0.1); \\n wmat *= rotX(sin(time * 0.13));\\n wmat *= trans(vec3(ca, cc, cb) * down * 0.65);\\n wmat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\\n \\n vec4 wpos = wmat * vec4(pos, 1);\\n gl_Position = pmat * vmat * wpos;\\n vec3 n = normalize((wmat * vec4(normal, 0)).xyz);\\n \\n //vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(34, 3, -24);\\n vec3 lightDir = normalize(lightPos - wpos.xyz);\\n\\n float hue = 0.5;//abs(ca * cc) * 2.;\\n float sat = 0.1;//mix(0., 1., step(10.8, s));\\n float val = mix(0.5, 0.5, step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = dot(n, lightDir) * 0.5 + 0.5;\\n v_color = vec4(color * pinch(lt, 2.) + vec3(pow(lt, 200.)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 70155, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/drumcomplex/drumcomplex-roel-salemink-load-my-battery-bush-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 14.;\n float across = 14.;\n float back = 14.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float cz = floor(cubeId / across / back);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (back - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n float cc = cw * 2. - 1.;\n \n float sv1 = atan(ca, cb) / PI;\n float sv = abs(atan(sv1, cc)) / PI;\n \n\n float s1 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 3. / soundRes.y)).a;\n float s = (s1 + s2 + s3 + s4) / 4.;\n \n s = mix(0., 1. + sv * .3, s);\n s = clamp(s, 0., 1.);\n \n float tm = time * 0.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up);\n mat4 wmat = rotY(time * 0.1); \n wmat *= rotX(sin(time * 0.13));\n wmat *= trans(vec3(ca, cc, cb) * down * 0.65);\n wmat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\n \n vec4 wpos = wmat * vec4(pos, 1);\n gl_Position = pmat * vmat * wpos;\n vec3 n = normalize((wmat * vec4(normal, 0)).xyz);\n \n //vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(34, 3, -24);\n vec3 lightDir = normalize(lightPos - wpos.xyz);\n\n float hue = 0.5;//abs(ca * cc) * 2.;\n float sat = 0.1;//mix(0., 1., step(10.8, s));\n float val = mix(0.5, 0.5, step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = dot(n, lightDir) * 0.5 + 0.5;\n v_color = vec4(color * pinch(lt, 2.) + vec3(pow(lt, 200.)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-416r5qkd2n097s4yj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MGn7wAioaMfoXcbmL/art.json b/art/MGn7wAioaMfoXcbmL/art.json index 92fe9712..621f2291 100644 --- a/art/MGn7wAioaMfoXcbmL/art.json +++ b/art/MGn7wAioaMfoXcbmL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "aphim44", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocIbUrfKa-_sasPTCzc5YyCidETMwcm-KjFqfbic41trqgs=s96-c", - "settings": "{\"num\":40,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7803921568627451,0.5568627450980392,0.5568627450980392,1],\"shader\":\"void main(){\\n float act = resolution[1]/resolution[0];\\n\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 5.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId +1., 2.0);\\n \\n float elements = x / 5.0;\\n float angle = elements * radians(360.0);\\n float radius = 4. - y;\\n \\n x = radius * cos(angle);\\n y = radius * sin(angle);\\n \\n vec2 xy = vec2(x, y) * abs(sin(time))*.05;\\n xy[0]*=act;\\n// xy[0]*=cos(10.);\\n //xy[1]*=sin(10.);\\n\\n\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 40, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7803921568627451, + 0.5568627450980392, + 0.5568627450980392, + 1 + ], + "shader": "void main(){\n float act = resolution[1]/resolution[0];\n\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n gl_PointSize = 5.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId +1., 2.0);\n \n float elements = x / 5.0;\n float angle = elements * radians(360.0);\n float radius = 4. - y;\n \n x = radius * cos(angle);\n y = radius * sin(angle);\n \n vec2 xy = vec2(x, y) * abs(sin(time))*.05;\n xy[0]*=act;\n// xy[0]*=cos(10.);\n //xy[1]*=sin(10.);\n\n\n \n gl_Position = vec4(xy, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-yqc24n0mtiybq1vaw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MJ9q4A2jzk3t8vEsP/art.json b/art/MJ9q4A2jzk3t8vEsP/art.json index 97a2b540..08cae56e 100644 --- a/art/MJ9q4A2jzk3t8vEsP/art.json +++ b/art/MJ9q4A2jzk3t8vEsP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TWOPI 6.28318530718\\n#define PI 3.14159265359\\n#define DEG2RAD 0.01745329251\\n#define RAD2DEG 57.2957795131\\n#define HASHSCALE1 .1031\\n\\nfloat hash11(float p) {\\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat3 rotX(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat3(1.0, 0.0, 0.0, 0.0, c, s, 0.0, -s, c);\\n}\\n\\nmat3 rotY(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat3(c, 0.0, s, 0.0, 1.0, 0.0, -s, 0.0, c);\\n}\\n\\nmat3 rotZ(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat3(c, s, 0.6, -s, c, 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nmat4 perspective(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\\n vec3 vr = normalize(pb - pa);\\n vec3 vu = normalize(pc - pa);\\n vec3 vn = cross(vr, vu);\\n vec3 va = pa - pe;\\n vec3 vb = pb - pe;\\n vec3 vc = pc - pe;\\n float d = -dot(va, vn);\\n float nod = n / d;\\n float l = dot(vr, va) * nod;\\n float r = dot(vr, vb) * nod;\\n float b = dot(vu, va) * nod;\\n float t = dot(vu, vc) * nod;\\n\\n // glFrustum\\n float x = 2. * n / (r - l);\\n float y = 2. * n / (t - b);\\n float A = (r + l) / (r - l);\\n float B = (t + b) / (t - b);\\n float C = -(f + n) / (f - n);\\n float D = -2. * f * n / (f - n);\\n mat4 P = mat4(\\n x, 0, 0, 0,\\n 0, y, 0, 0,\\n A, B, C, -1,\\n 0, 0, D, 0\\n );\\n return P;\\n}\\n\\nmat4 camera(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\\n vec3 vr = normalize(pb - pa);\\n vec3 vu = normalize(pc - pa);\\n vec3 vn = cross(vr, vu);\\n mat4 cam = mat4(\\n vec4(vr, 0),\\n vec4(vu, 0),\\n vec4(vn, 0),\\n vec4(-pe, 1));\\n return cam;\\n}\\n\\nvec2 quad(float id) {\\n float ux = floor(id / 6.) + mod (id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n float x = ux;\\n float y = vy;\\n // generate vertices [-1, 1] x [-,1 1]\\n return 2. * mod(vec2(x, y), vec2(2, 2)) - 1.;\\n}\\n\\n\\nvoid main() {\\n // screen + camera setup\\n float screen_width_mm = 350.90;\\n float screen_height_mm = 247.1;\\n float aspect = screen_width_mm / screen_height_mm;\\n float head_to_screen_mm = 1000.;\\n vec3 pa = 0.5 * vec3(-screen_width_mm, -screen_height_mm, 0);\\n vec3 pb = 0.5 * vec3(screen_width_mm, -screen_height_mm, 0);\\n vec3 pc = 0.5 * vec3(-screen_width_mm, screen_height_mm, 0);\\n vec3 pe = vec3(0, 0, head_to_screen_mm);\\n float n = 0.01;\\n float f = 2000.;\\n mat4 P = perspective(pa, pb, pc, pe, n, f);\\n mat4 C = camera(pa, pb, pc, pe, n, f);\\n \\n float quad_id = floor(vertexId / 6.0);\\n float quad_count = floor(vertexCount / 6.0);\\n float quad_hash = hash11(quad_id + 5.0);\\n float quad_pct = quad_id / quad_count;\\n\\n vec2 quad_size = vec2(1.0);\\n quad_size.x *= aspect;\\n\\n float wrap = (0.5 + 0.5 * sin(0.15*time)) * 50.0;\\n float r = (0.2 + 0.1*sin(50.0*quad_pct * TWOPI)) * screen_height_mm;\\n float x = r * cos(wrap * quad_pct * TWOPI);\\n float y = r * sin(wrap * quad_pct * TWOPI);\\n float z = (quad_pct - 0.5) * 0.7 * screen_height_mm;\\n vec3 worldPos = \\n rotX(DEG2RAD * 45.0) * \\n rotY(DEG2RAD * 33.0) * \\n (vec3(quad_size * quad(vertexId), 0.0) + vec3(x,y,z));\\n vec4 camPos = C * vec4(worldPos, 1.0);\\n gl_Position = P *camPos;\\n\\n // write the color\\n vec3 hsv = vec3(0.5 + 0.2 * quad_pct, 0.9, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TWOPI 6.28318530718\n#define PI 3.14159265359\n#define DEG2RAD 0.01745329251\n#define RAD2DEG 57.2957795131\n#define HASHSCALE1 .1031\n\nfloat hash11(float p) {\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat3 rotX(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat3(1.0, 0.0, 0.0, 0.0, c, s, 0.0, -s, c);\n}\n\nmat3 rotY(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat3(c, 0.0, s, 0.0, 1.0, 0.0, -s, 0.0, c);\n}\n\nmat3 rotZ(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat3(c, s, 0.6, -s, c, 0.0, 0.0, 0.0, 1.0);\n}\n\nmat4 perspective(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\n vec3 vr = normalize(pb - pa);\n vec3 vu = normalize(pc - pa);\n vec3 vn = cross(vr, vu);\n vec3 va = pa - pe;\n vec3 vb = pb - pe;\n vec3 vc = pc - pe;\n float d = -dot(va, vn);\n float nod = n / d;\n float l = dot(vr, va) * nod;\n float r = dot(vr, vb) * nod;\n float b = dot(vu, va) * nod;\n float t = dot(vu, vc) * nod;\n\n // glFrustum\n float x = 2. * n / (r - l);\n float y = 2. * n / (t - b);\n float A = (r + l) / (r - l);\n float B = (t + b) / (t - b);\n float C = -(f + n) / (f - n);\n float D = -2. * f * n / (f - n);\n mat4 P = mat4(\n x, 0, 0, 0,\n 0, y, 0, 0,\n A, B, C, -1,\n 0, 0, D, 0\n );\n return P;\n}\n\nmat4 camera(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\n vec3 vr = normalize(pb - pa);\n vec3 vu = normalize(pc - pa);\n vec3 vn = cross(vr, vu);\n mat4 cam = mat4(\n vec4(vr, 0),\n vec4(vu, 0),\n vec4(vn, 0),\n vec4(-pe, 1));\n return cam;\n}\n\nvec2 quad(float id) {\n float ux = floor(id / 6.) + mod (id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n float x = ux;\n float y = vy;\n // generate vertices [-1, 1] x [-,1 1]\n return 2. * mod(vec2(x, y), vec2(2, 2)) - 1.;\n}\n\n\nvoid main() {\n // screen + camera setup\n float screen_width_mm = 350.90;\n float screen_height_mm = 247.1;\n float aspect = screen_width_mm / screen_height_mm;\n float head_to_screen_mm = 1000.;\n vec3 pa = 0.5 * vec3(-screen_width_mm, -screen_height_mm, 0);\n vec3 pb = 0.5 * vec3(screen_width_mm, -screen_height_mm, 0);\n vec3 pc = 0.5 * vec3(-screen_width_mm, screen_height_mm, 0);\n vec3 pe = vec3(0, 0, head_to_screen_mm);\n float n = 0.01;\n float f = 2000.;\n mat4 P = perspective(pa, pb, pc, pe, n, f);\n mat4 C = camera(pa, pb, pc, pe, n, f);\n \n float quad_id = floor(vertexId / 6.0);\n float quad_count = floor(vertexCount / 6.0);\n float quad_hash = hash11(quad_id + 5.0);\n float quad_pct = quad_id / quad_count;\n\n vec2 quad_size = vec2(1.0);\n quad_size.x *= aspect;\n\n float wrap = (0.5 + 0.5 * sin(0.15*time)) * 50.0;\n float r = (0.2 + 0.1*sin(50.0*quad_pct * TWOPI)) * screen_height_mm;\n float x = r * cos(wrap * quad_pct * TWOPI);\n float y = r * sin(wrap * quad_pct * TWOPI);\n float z = (quad_pct - 0.5) * 0.7 * screen_height_mm;\n vec3 worldPos = \n rotX(DEG2RAD * 45.0) * \n rotY(DEG2RAD * 33.0) * \n (vec3(quad_size * quad(vertexId), 0.0) + vec3(x,y,z));\n vec4 camPos = C * vec4(worldPos, 1.0);\n gl_Position = P *camPos;\n\n // write the color\n vec3 hsv = vec3(0.5 + 0.2 * quad_pct, 0.9, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n}" + }, "screenshotURL": "data/images/images-ijdoujod8d0kwu8wl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MK7bag3KKs9CFJdf8/art.json b/art/MK7bag3KKs9CFJdf8/art.json index a816980f..e16f2e68 100644 --- a/art/MK7bag3KKs9CFJdf8/art.json +++ b/art/MK7bag3KKs9CFJdf8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(20.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(20.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-s1dh3yr8f1hnace8o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MLaWwDHo66XjxhwCc/art.json b/art/MLaWwDHo66XjxhwCc/art.json index 1531c538..e4bae38d 100644 --- a/art/MLaWwDHo66XjxhwCc/art.json +++ b/art/MLaWwDHo66XjxhwCc/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.01568627450980392,0.10588235294117647,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.350;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.01568627450980392, + 0.10588235294117647, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.350;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-l0k4ovgqb7eyfeo3c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MLdXbo7E4ENYKNQqj/art.json b/art/MLdXbo7E4ENYKNQqj/art.json index 0f2b2f24..75d7b1bb 100644 --- a/art/MLdXbo7E4ENYKNQqj/art.json +++ b/art/MLdXbo7E4ENYKNQqj/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "salvatore", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocKio7TORJMn8A7RkX3-sf6UDKi8ACBRf3ulZjs1E6B-yDqExhFe=s96-c", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n// Must be called with idx > 0 and idx < 8\\nvec4 GetCubeVertex(int idx)\\n{\\n // Half the cube side\\n float h_size = 0.5; \\n\\n // idx 1,3,5,7 have negative x\\n float x = h_size + mod(float(idx), 2.) * -2. * h_size;\\n // idx 3,4,6,7 have negative y\\n float y = h_size + mod(float(idx / 2), 2.) * -2. * h_size; \\n // idx 4,5,6,7 have negative z\\n float z = h_size + mod(float(idx / 4), 2.) * -2. * h_size;\\n \\n return vec4(x, y, z, 1.);\\n}\\n\\n\\nvoid main() \\n{\\n vec4 v = GetCubeVertex(int(vertexId));\\n gl_Position = v;\\n gl_PointSize = 10.;\\n v_color = vec4(0,0,0, 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n// Must be called with idx > 0 and idx < 8\nvec4 GetCubeVertex(int idx)\n{\n // Half the cube side\n float h_size = 0.5; \n\n // idx 1,3,5,7 have negative x\n float x = h_size + mod(float(idx), 2.) * -2. * h_size;\n // idx 3,4,6,7 have negative y\n float y = h_size + mod(float(idx / 2), 2.) * -2. * h_size; \n // idx 4,5,6,7 have negative z\n float z = h_size + mod(float(idx / 4), 2.) * -2. * h_size;\n \n return vec4(x, y, z, 1.);\n}\n\n\nvoid main() \n{\n vec4 v = GetCubeVertex(int(vertexId));\n gl_Position = v;\n gl_PointSize = 10.;\n v_color = vec4(0,0,0, 1);\n}" + }, "screenshotURL": "data/images/images-r6gwi3wy9x5apif9l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MLtascKR4NfzQFhJj/art.json b/art/MLtascKR4NfzQFhJj/art.json index 24621fbd..5c4881a4 100644 --- a/art/MLtascKR4NfzQFhJj/art.json +++ b/art/MLtascKR4NfzQFhJj/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "aisis", "avatarUrl": "https://avatars.githubusercontent.com/aisis?s=200", - "settings": "{\"num\":14935,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/resident-advisor/ra546-esther-duijn\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n cos(t*1.311+i) +\\n cos(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n \\tcos(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n \\tcos(t+i*.5553-2.1) +\\n cos(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float hsvEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(hsvEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.10;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 14935, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/resident-advisor/ra546-esther-duijn", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n cos(t*1.311+i) +\n cos(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n \tcos(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n \tcos(t+i*.5553-2.1) +\n cos(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float hsvEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(hsvEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.10;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-p1zedbffjetmflhkd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MNGReAdLScFwNiZDg/art.json b/art/MNGReAdLScFwNiZDg/art.json index 366343bc..9c87aa01 100644 --- a/art/MNGReAdLScFwNiZDg/art.json +++ b/art/MNGReAdLScFwNiZDg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2048,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float phi = vertexId / vertexCount * 3.14159265*2.0;\\n \\n float x = cos(phi);\\n float y = sin(phi);\\n float z = 0.0;\\n \\n float theta = sin(cos(phi)*3.1415192 + time);//(x+time * 0.3) * 3.141592*2.0;\\n \\n theta *= 10.0;\\n \\n y *= cos(theta);\\n z = sin(theta) * sin(phi);\\n \\n vec4 pos = vec4(x, y, z, 1.0);\\n \\n vec3 eye = vec3(sin(time*0.3), 0, cos(time*0.3));\\n vec3 right = vec3(-eye.z, 0, eye.x);\\n vec3 look = -eye;\\n\\n mat4 L = mat4(vec4(right, 0),\\n vec4(0, 1, 0, 0),\\n vec4(look, 0),\\n vec4(0, 0, 0, 1));\\n \\n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\\n v_color = vec4(sin(theta) * 0.5 + 0.5,\\n cos(phi) * 0.5 + 0.5,\\n sin(time) * 0.5 + 0.5,\\n 1.0);\\n}\"}", + "settings": { + "num": 2048, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float phi = vertexId / vertexCount * 3.14159265*2.0;\n \n float x = cos(phi);\n float y = sin(phi);\n float z = 0.0;\n \n float theta = sin(cos(phi)*3.1415192 + time);//(x+time * 0.3) * 3.141592*2.0;\n \n theta *= 10.0;\n \n y *= cos(theta);\n z = sin(theta) * sin(phi);\n \n vec4 pos = vec4(x, y, z, 1.0);\n \n vec3 eye = vec3(sin(time*0.3), 0, cos(time*0.3));\n vec3 right = vec3(-eye.z, 0, eye.x);\n vec3 look = -eye;\n\n mat4 L = mat4(vec4(right, 0),\n vec4(0, 1, 0, 0),\n vec4(look, 0),\n vec4(0, 0, 0, 1));\n \n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\n v_color = vec4(sin(theta) * 0.5 + 0.5,\n cos(phi) * 0.5 + 0.5,\n sin(time) * 0.5 + 0.5,\n 1.0);\n}" + }, "screenshotURL": "data/images/images-v7ub2gxdazwmvntoo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MPp2oxLmZsPapDWCv/art.json b/art/MPp2oxLmZsPapDWCv/art.json index df82f2e2..6600a9fa 100644 --- a/art/MPp2oxLmZsPapDWCv/art.json +++ b/art/MPp2oxLmZsPapDWCv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.2)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+snd*25.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 0.9;\\n float tm = 1.5;//*time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/10., 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 3./abs(gl_Position.z);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.2)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+snd*25.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 0.9;\n float tm = 1.5;//*time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/10., 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 3./abs(gl_Position.z);\n}\n\n" + }, "screenshotURL": "data/images/images-2o6j5sqvweok46ige-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MPxc2mXYAQd5F3JFC/art.json b/art/MPxc2mXYAQd5F3JFC/art.json index 5d10c743..d8dae719 100644 --- a/art/MPxc2mXYAQd5F3JFC/art.json +++ b/art/MPxc2mXYAQd5F3JFC/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres", "private": false, "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-manubfey3gyxpkuez-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MR2L3baykwugQk8qM/art.json b/art/MR2L3baykwugQk8qM/art.json index eddc43f8..0b06423c 100644 --- a/art/MR2L3baykwugQk8qM/art.json +++ b/art/MR2L3baykwugQk8qM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":90217,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/butterflycrash/butterfly-crash-4-dem-filthy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 12.;\\n\\n \\tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\\n\\tfloat hexSpace = 1.0;\\n \\tvec2 height = vec2(1.,0.4);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 33.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 12.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\\n float rangeInv = 0.2 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.143,\\n yAxis, 0.001,\\n zAxis, .210,\\n eye, sin(1.51*time));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 * a10 * b09 - a12 * b06,\\n a00 * b09 - a01 / b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) * det;\\n}\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye+(3.*mouse.y), target*2., (up-1.,-up)))\\n\\n;\\n #else\\n vec3 zAxis = normalize(target * eye)/mouse.x;\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1.,\\n yAxis, -1.2+snd\\n zAxis, 1.2\\n -dot(xAxis, 1.-eye)*mouse, *dot(yAxis, mouse*eye),-dot(zAxis, eye), .6); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 90217, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/butterflycrash/butterfly-crash-4-dem-filthy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 12.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\n\tfloat hexSpace = 1.0;\n \tvec2 height = vec2(1.,0.4);\n \t\n\tfloat indexQuad = floor(vertexId / 33.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 12.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\n float rangeInv = 0.2 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.143,\n yAxis, 0.001,\n zAxis, .210,\n eye, sin(1.51*time));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 * a10 * b09 - a12 * b06,\n a00 * b09 - a01 / b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) * det;\n}\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye+(3.*mouse.y), target*2., (up-1.,-up)))\n\n;\n #else\n vec3 zAxis = normalize(target * eye)/mouse.x;\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1.,\n yAxis, -1.2+snd\n zAxis, 1.2\n -dot(xAxis, 1.-eye)*mouse, *dot(yAxis, mouse*eye),-dot(zAxis, eye), .6); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-yz8hrq2sctf7mipqx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MRTD3jA6zwi4pa9j6/art.json b/art/MRTD3jA6zwi4pa9j6/art.json index b919944a..f8227149 100644 --- a/art/MRTD3jA6zwi4pa9j6/art.json +++ b/art/MRTD3jA6zwi4pa9j6/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n#define WALK\\n\\n#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n//#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n#define WALK\n\n#define COLOR_PASTEL\n//#define COLOR_VIVID\n//#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-eon2h4fsmo579nimn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MTJf2S5uhN4Z4Fswj/art.json b/art/MTJf2S5uhN4Z4Fswj/art.json index 69b2c488..b309b2d0 100644 --- a/art/MTJf2S5uhN4Z4Fswj/art.json +++ b/art/MTJf2S5uhN4Z4Fswj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":3860,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/abc-trance-king-arturia-ms2k\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Kstreamer\\n\\n//KDrawmode=GL_POINTS\\n\\n//KVerticesNumber=3860\\n\\n// **** K Parameters **********\\n// **** parameter 0 is General Scale/Zoom\\n#define parameter0 1.0//KParameter0 1.0>>100.0\\n// **** parameter 1 is Sound Sensitivity\\n#define parameter1 5.0//KParameter1 1.0>>2.0\\n// **** parameter 2 is x offset mod\\n#define parameter2 0.3//KParameter2 1.0>>2.0\\n// **** parameter 3 is y offset mod\\n#define parameter3 0.3//KParameter3 1.0>>2.0\\n// **** parameter 4 is x mod factor\\n#define parameter4 100.0//KParameter4 10.0>>100.0\\n// **** parameter 5 is y mod factor\\n#define parameter5 100.0//KParameter5 10.0>>100.0\\n// **** parameter 6 is thumb tune\\n#define parameter6 2.0//KParameter6 1.0>>4.0\\n// **** parameter 6 is sound tune\\n#define parameter7 2.0//KParameter7 1.0>>4.0\\n\\nvoid main () {\\n float v = vertexId;\\n \\n float grid = floor(vertexCount / (1000.0 * (1.0 + sin(time/30.0))));\\n float scale = parameter0 * 1.0 / (grid * grid); \\n \\n float xsound = 0.2 * parameter7; //range of values in sound \\n float ysound = floor((v*240.0) / vertexCount) / 240.0; \\n \\n float sndFactor = texture2D(sound, vec2(xsound , ysound)).a;\\n float sndFactorBass = texture2D(sound, vec2(0.1 * parameter6, 0.0)).a;\\n \\n float x = sin(sin(time/11.0)* v/100.0); //comod(v, grid); \\n float y = cos(sin(time/10.0)* v/100.0); //mod(floor(v / grid), grid);\\n \\n float xoff = parameter2 / 2.0;\\n float yoff = parameter3 / 2.0 + 0.1 * parameter1 * sndFactor;\\n \\n float xmod = (1.0 - (parameter4 * v / (vertexCount * 100.0)));\\n xmod *= 10.0 * parameter1 * sndFactorBass;\\n xmod *= sin(time/100.0);\\n float ymod = (1.0 - (parameter5 * v / (vertexCount * 100.0)));\\n ymod *= 10.0 * parameter1 * sndFactorBass;\\n ymod *= sin(time/130.0);\\n \\n float ux = (x * xmod * scale - xoff);\\n float uy = (y * ymod * scale - yoff);\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = parameter1 * sndFactorBass * 40.0 * (vertexCount/(10.0*v+vertexCount));\\n\\n v_color = vec4(sin(sndFactor/2.0), v/vertexCount, v/vertexCount, 1);\\n}\"}", + "settings": { + "num": 3860, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/abc-trance-king-arturia-ms2k", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Kstreamer\n\n//KDrawmode=GL_POINTS\n\n//KVerticesNumber=3860\n\n// **** K Parameters **********\n// **** parameter 0 is General Scale/Zoom\n#define parameter0 1.0//KParameter0 1.0>>100.0\n// **** parameter 1 is Sound Sensitivity\n#define parameter1 5.0//KParameter1 1.0>>2.0\n// **** parameter 2 is x offset mod\n#define parameter2 0.3//KParameter2 1.0>>2.0\n// **** parameter 3 is y offset mod\n#define parameter3 0.3//KParameter3 1.0>>2.0\n// **** parameter 4 is x mod factor\n#define parameter4 100.0//KParameter4 10.0>>100.0\n// **** parameter 5 is y mod factor\n#define parameter5 100.0//KParameter5 10.0>>100.0\n// **** parameter 6 is thumb tune\n#define parameter6 2.0//KParameter6 1.0>>4.0\n// **** parameter 6 is sound tune\n#define parameter7 2.0//KParameter7 1.0>>4.0\n\nvoid main () {\n float v = vertexId;\n \n float grid = floor(vertexCount / (1000.0 * (1.0 + sin(time/30.0))));\n float scale = parameter0 * 1.0 / (grid * grid); \n \n float xsound = 0.2 * parameter7; //range of values in sound \n float ysound = floor((v*240.0) / vertexCount) / 240.0; \n \n float sndFactor = texture2D(sound, vec2(xsound , ysound)).a;\n float sndFactorBass = texture2D(sound, vec2(0.1 * parameter6, 0.0)).a;\n \n float x = sin(sin(time/11.0)* v/100.0); //comod(v, grid); \n float y = cos(sin(time/10.0)* v/100.0); //mod(floor(v / grid), grid);\n \n float xoff = parameter2 / 2.0;\n float yoff = parameter3 / 2.0 + 0.1 * parameter1 * sndFactor;\n \n float xmod = (1.0 - (parameter4 * v / (vertexCount * 100.0)));\n xmod *= 10.0 * parameter1 * sndFactorBass;\n xmod *= sin(time/100.0);\n float ymod = (1.0 - (parameter5 * v / (vertexCount * 100.0)));\n ymod *= 10.0 * parameter1 * sndFactorBass;\n ymod *= sin(time/130.0);\n \n float ux = (x * xmod * scale - xoff);\n float uy = (y * ymod * scale - yoff);\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = parameter1 * sndFactorBass * 40.0 * (vertexCount/(10.0*v+vertexCount));\n\n v_color = vec4(sin(sndFactor/2.0), v/vertexCount, v/vertexCount, 1);\n}" + }, "screenshotURL": "data/images/images-l6hpflu5dw7c2saqb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MTW5NGatj8ZLp9cAD/art.json b/art/MTW5NGatj8ZLp9cAD/art.json index fe4ef770..33260183 100644 --- a/art/MTW5NGatj8ZLp9cAD/art.json +++ b/art/MTW5NGatj8ZLp9cAD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/hobac/just-once-james-ingram?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5294117647058824,0.5294117647058824,0.5294117647058824,1],\"shader\":\"#define PI radians(180.44)\\n#define NUM_SEGMENTS 4.2\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.23, 1.0));\\n vec4 K = vec4(1.0, 2.5 / 6.0, 1.6 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y) + 0.01;\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0 * 4.1) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS) + 20.10;\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.01;\\n float angle = point * PI + 3.1 * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 1.1 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c + 0.1,\\n oS + s);\\n gl_Position = vec4(xy * 3.4 * aspect + mouse * 2.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/hobac/just-once-james-ingram?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5294117647058824, + 0.5294117647058824, + 0.5294117647058824, + 1 + ], + "shader": "#define PI radians(180.44)\n#define NUM_SEGMENTS 4.2\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.23, 1.0));\n vec4 K = vec4(1.0, 2.5 / 6.0, 1.6 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y) + 0.01;\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0 * 4.1) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS) + 20.10;\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.01;\n float angle = point * PI + 3.1 * 2.0 / NUM_SEGMENTS + offset;\n float radius = 1.1 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c + 0.1,\n oS + s);\n gl_Position = vec4(xy * 3.4 * aspect + mouse * 2.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-vbsh00yiwbryqhu7f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MTyhyqrCPDN5Fd7Xr/art.json b/art/MTyhyqrCPDN5Fd7Xr/art.json index 8c1a3f5b..32a34678 100644 --- a/art/MTyhyqrCPDN5Fd7Xr/art.json +++ b/art/MTyhyqrCPDN5Fd7Xr/art.json @@ -11,7 +11,19 @@ "origId": "nL6YpkW8YvGKNEKtj", "name": "point cloud vs spheres", "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -8.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -8.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-svabsqowjrenqn7go-thumbnail.jpg", "views": { "$numberInt": "163" diff --git a/art/MWD3RYNPkSTxNBnw5/art.json b/art/MWD3RYNPkSTxNBnw5/art.json index d7ceee80..578380d9 100644 --- a/art/MWD3RYNPkSTxNBnw5/art.json +++ b/art/MWD3RYNPkSTxNBnw5/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "bigmike", "avatarUrl": "https://secure.gravatar.com/avatar/f6c53f1e06b699fc6a147bcaeef73923?default=retro&size=200", - "settings": "{\"num\":26667,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 3.835)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 4.0)\\n ;\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 26667, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 3.835)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 4.0)\n ;\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-ag2a6arvji65ixhau-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MX75C8xPApWmjNBQE/art.json b/art/MX75C8xPApWmjNBQE/art.json index 0fb92aca..5b5bc80b 100644 --- a/art/MX75C8xPApWmjNBQE/art.json +++ b/art/MX75C8xPApWmjNBQE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sean", "avatarUrl": "https://lh4.googleusercontent.com/-2XVr7oP52uM/AAAAAAAAAAI/AAAAAAAAF8w/OxC5EHp2Xvk/photo.jpg", - "settings": "{\"num\":1677,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n vec2 foci[4];\\n foci[0] = vec2(0,0);\\n foci[1] = vec2(.2, sin(time));\\n foci[2] = vec2(sin(time*.3), -.8);\\n foci[3] = mouse;\\n \\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.); \\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n vec2 pos = vec2(ux, vy);\\n \\n \\n \\n for (int i = 0; i < 4; i++)\\n {\\n vec2 dir = foci[i] - pos;\\n float dist = length(dir);\\n \\tvec2 u_dir = dir / dist;\\n \\tvec2 offset = -0.1 * u_dir;\\n pos += offset;\\n }\\n \\n\\n gl_Position = vec4(pos, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(.5,.5,0,1);\\n \\n}\\n \\n\"}", + "settings": { + "num": 1677, + "mode": "POINTS", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n vec2 foci[4];\n foci[0] = vec2(0,0);\n foci[1] = vec2(.2, sin(time));\n foci[2] = vec2(sin(time*.3), -.8);\n foci[3] = mouse;\n \n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.); \n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n vec2 pos = vec2(ux, vy);\n \n \n \n for (int i = 0; i < 4; i++)\n {\n vec2 dir = foci[i] - pos;\n float dist = length(dir);\n \tvec2 u_dir = dir / dist;\n \tvec2 offset = -0.1 * u_dir;\n pos += offset;\n }\n \n\n gl_Position = vec4(pos, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(.5,.5,0,1);\n \n}\n \n" + }, "screenshotURL": "data/images/images-ljj6h1rkqziaer3vs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MY3AP4cLfmex5ki2b/art.json b/art/MY3AP4cLfmex5ki2b/art.json index a13fedd8..4c42192b 100644 --- a/art/MY3AP4cLfmex5ki2b/art.json +++ b/art/MY3AP4cLfmex5ki2b/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/rukunetsu/alpha-beat-office-shenmue-rmix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1803921568627451,0.1803921568627451,0.1803921568627451,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \\n out vec3 pos, out vec3 nrm, out vec2 uv) {\\n float numQuads = floor(vertexCount / 6.);\\n float down = numQuads / around;\\n float quadId = floor(float(vertexId) / 6.);\\n\\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n\\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n\\n float edgeId = mod(float(vertexId), 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\\n\\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n\\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n\\n pos = vec3(x, cos(qv * PI), z);\\n nrm = normalize(pos);\\n uv = vec2(qu, qv);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(0);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n vec2 uv;\\n float around = 24.0;\\n float down = 12.0;\\n float vertsPerSphere = around * down * 6.;\\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\\n float cubeId = floor(pointId / vertsPerSphere);\\n float maxCubes = floor(vertexCount / vertsPerSphere);\\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\\n\\n //vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = (cv);\\n \\n float cvv = cubeId / (numCubes - 1.);\\n \\n //su = hash(cubeId / maxCubes);\\n /*\\n float s1 = texture2D(sound, vec2(mix(.05, .00, fract(su + 1.0)), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(.06, .01, fract(su + 0.8)), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(.07, .02, fract(su + 0.6)), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(.08, .03, fract(su + 0.4)), 3. / soundRes.y)).a;\\n \\n float s = max(max(max(s1, s2), s3), s4);mix(0.0, 0.25, s1 + s2 + s3 + s4);\\n */\\n \\n float numVertsAround = around * 6.0;\\n float lonId = floor(vertexId / numVertsAround);\\n float lonV = fract(lonId / around);\\n\\n float latId = mod(floor(vertexId / 6.0), around);\\n float latV = fract(latId / around);\\n \\n vec2 u1 =vec2(mix(0.02, 0.1, latV), lonV * 0.2);\\n vec2 u2 =vec2(mix(0.02, 0.1, lonV), latV * 0.2);\\n float s = texture2D(sound, mix(u1, u2, cvv)).a;\\n float sBeat = texture2D(sound, vec2(cvv, 0)).a;\\n float sLon = texture2D(sound, vec2(cvv * 0.1 + lonV, 0) * 0.2).a;\\n float sLat = texture2D(sound, vec2(cvv * 0.11 + abs(latV * 2. - 1.) * 0.2, 0)).a;\\n \\n float tm = time * .1;\\n float r = 2.5;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 20.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n float r2 = mix(25., 50., sin(cv * PI * 2. + time) * 0.5 + 0.5);\\n// mat *= rotX(tm);\\n//mat *= lookAt(loc * r2, vec3(0), up);\\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\\n mat *= trans((2. * vec3(hash(cvv), hash(cvv * 0.531), hash(cvv * 0.712)) - 1.) * 2.);\\n// mat *= rotZ(s * PI * 2.);\\n float ss = fract(time * .1 + cvv * 0.5) * 4.;\\n mat *= uniformScale(0.1);\\n mat *= uniformScale(ss);\\n mat *= uniformScale(1. + mix(sLat * sin(pos.y * PI), sLon, cvv));\\n mat *= uniformScale(mix(1.0, 1.5, sBeat));\\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = mix(cv + time * 0.1, sin(latV * PI) * 0.1 + cvv, 1. - cvv);\\n float sat = .5;\\n float val = mix(1., pow(sLon + 0.3, 2.), cvv);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n vec3 color2 = hsv2rgb(vec3(hue + 0.5, 1., 1.));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = mix(vec4(color * lt, 1), vec4(color2, 1), step(0.7, s));\\n// v_color.a = s;\\n v_color.a = min(1. , 4.0 - ss);\\n v_color.rgb *= v_color.a; \\n// if (s < .2) {\\n// gl_Position.z = 10000.;\\n// }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/rukunetsu/alpha-beat-office-shenmue-rmix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1803921568627451, + 0.1803921568627451, + 0.1803921568627451, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \n out vec3 pos, out vec3 nrm, out vec2 uv) {\n float numQuads = floor(vertexCount / 6.);\n float down = numQuads / around;\n float quadId = floor(float(vertexId) / 6.);\n\n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n\n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n\n float edgeId = mod(float(vertexId), 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\n\n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n\n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n\n pos = vec3(x, cos(qv * PI), z);\n nrm = normalize(pos);\n uv = vec2(qu, qv);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(0);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n vec2 uv;\n float around = 24.0;\n float down = 12.0;\n float vertsPerSphere = around * down * 6.;\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\n float cubeId = floor(pointId / vertsPerSphere);\n float maxCubes = floor(vertexCount / vertsPerSphere);\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\n\n //vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = (cv);\n \n float cvv = cubeId / (numCubes - 1.);\n \n //su = hash(cubeId / maxCubes);\n /*\n float s1 = texture2D(sound, vec2(mix(.05, .00, fract(su + 1.0)), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(.06, .01, fract(su + 0.8)), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(.07, .02, fract(su + 0.6)), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(.08, .03, fract(su + 0.4)), 3. / soundRes.y)).a;\n \n float s = max(max(max(s1, s2), s3), s4);mix(0.0, 0.25, s1 + s2 + s3 + s4);\n */\n \n float numVertsAround = around * 6.0;\n float lonId = floor(vertexId / numVertsAround);\n float lonV = fract(lonId / around);\n\n float latId = mod(floor(vertexId / 6.0), around);\n float latV = fract(latId / around);\n \n vec2 u1 =vec2(mix(0.02, 0.1, latV), lonV * 0.2);\n vec2 u2 =vec2(mix(0.02, 0.1, lonV), latV * 0.2);\n float s = texture2D(sound, mix(u1, u2, cvv)).a;\n float sBeat = texture2D(sound, vec2(cvv, 0)).a;\n float sLon = texture2D(sound, vec2(cvv * 0.1 + lonV, 0) * 0.2).a;\n float sLat = texture2D(sound, vec2(cvv * 0.11 + abs(latV * 2. - 1.) * 0.2, 0)).a;\n \n float tm = time * .1;\n float r = 2.5;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 20.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n float r2 = mix(25., 50., sin(cv * PI * 2. + time) * 0.5 + 0.5);\n// mat *= rotX(tm);\n//mat *= lookAt(loc * r2, vec3(0), up);\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\n mat *= trans((2. * vec3(hash(cvv), hash(cvv * 0.531), hash(cvv * 0.712)) - 1.) * 2.);\n// mat *= rotZ(s * PI * 2.);\n float ss = fract(time * .1 + cvv * 0.5) * 4.;\n mat *= uniformScale(0.1);\n mat *= uniformScale(ss);\n mat *= uniformScale(1. + mix(sLat * sin(pos.y * PI), sLon, cvv));\n mat *= uniformScale(mix(1.0, 1.5, sBeat));\n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = mix(cv + time * 0.1, sin(latV * PI) * 0.1 + cvv, 1. - cvv);\n float sat = .5;\n float val = mix(1., pow(sLon + 0.3, 2.), cvv);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n vec3 color2 = hsv2rgb(vec3(hue + 0.5, 1., 1.));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = mix(vec4(color * lt, 1), vec4(color2, 1), step(0.7, s));\n// v_color.a = s;\n v_color.a = min(1. , 4.0 - ss);\n v_color.rgb *= v_color.a; \n// if (s < .2) {\n// gl_Position.z = 10000.;\n// }\n}\n\n" + }, "screenshotURL": "data/images/images-egfuq7qaauvg1h4tr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MZedxmNrAz7p828Eu/art.json b/art/MZedxmNrAz7p828Eu/art.json index 316e1da1..1e5c443c 100644 --- a/art/MZedxmNrAz7p828Eu/art.json +++ b/art/MZedxmNrAz7p828Eu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":93901,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=83000\\n#define KP0 10.0 * mouse.x\\n#define KP1 3.0 * mouse.y\\n#define K0 * 10 1.//KParameter0 0.>>1000.\\n#define K1 * 3 1.//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>10.\\n#define KP3 0.0//KParameter3 0.000>>0.5\\n#define KP4 5.0//KParameter4 0.000>>5.\\n#define KP5 1000.0//KParameter5 3.000>>10000.0\\n\\n\\n#define PI radians(180. -KP1)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.08, 3.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (1.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) *(6.0 ,KP4)- K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0.4, 0, 0,\\n 0, (2.*c), s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, s, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 1,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans,3);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[2][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][2], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP5 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 10.01;\\n float end = 2.*sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv*4.,mouse.xy;\\n \\n vec3 eye = vec3(-s, s/KP1, 1)*KP1;//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 1.-s2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(s-0.5),1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(2, aspect, s) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.-s2)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) *-h + pow(s2+22.2, 5.) * KP3 - 110. * sign(h));\\n mat *= scale(vec3(1.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 1.3 + cgId * s /0.4;\\n float sat = 11. * step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 1.*s2;\\n v_color = vec4(hsv2rgb(vec3(hue*s *mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 93901, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=83000\n#define KP0 10.0 * mouse.x\n#define KP1 3.0 * mouse.y\n#define K0 * 10 1.//KParameter0 0.>>1000.\n#define K1 * 3 1.//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>10.\n#define KP3 0.0//KParameter3 0.000>>0.5\n#define KP4 5.0//KParameter4 0.000>>5.\n#define KP5 1000.0//KParameter5 3.000>>10000.0\n\n\n#define PI radians(180. -KP1)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.08, 3.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (1.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) *(6.0 ,KP4)- K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0.4, 0, 0,\n 0, (2.*c), s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, s, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 1,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans,3);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 2);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[2][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][2], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP5 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 10.01;\n float end = 2.*sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv*4.,mouse.xy;\n \n vec3 eye = vec3(-s, s/KP1, 1)*KP1;//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 1.-s2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(s-0.5),1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(2, aspect, s) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.-s2)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) *-h + pow(s2+22.2, 5.) * KP3 - 110. * sign(h));\n mat *= scale(vec3(1.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 1.3 + cgId * s /0.4;\n float sat = 11. * step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 1.*s2;\n v_color = vec4(hsv2rgb(vec3(hue*s *mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-94p6l12c48ynbu428-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MaN6KTGWG43vyhd68/art.json b/art/MaN6KTGWG43vyhd68/art.json index 6be4494e..d555f397 100644 --- a/art/MaN6KTGWG43vyhd68/art.json +++ b/art/MaN6KTGWG43vyhd68/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "aisis", "avatarUrl": "https://avatars.githubusercontent.com/aisis?s=200", - "settings": "{\"num\":86521,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/iamlpmusic/lost-on-you\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 86521, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/iamlpmusic/lost-on-you", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-o3iil0z48u58kjdko-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MaT4wjZqPmXjfRqe3/art.json b/art/MaT4wjZqPmXjfRqe3/art.json index 66ca1987..fffbb065 100644 --- a/art/MaT4wjZqPmXjfRqe3/art.json +++ b/art/MaT4wjZqPmXjfRqe3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":80943,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI *.1+r) * r;\\n float y = sin(qu * PI *-1.012) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * mix(0.01,mouse.x,-.05) * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * 1.813333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.b = v_color.r;\\n}\"}", + "settings": { + "num": 80943, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI *.1+r) * r;\n float y = sin(qu * PI *-1.012) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * mix(0.01,mouse.x,-.05) * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * 1.813333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.b = v_color.r;\n}" + }, "screenshotURL": "data/images/images-p7tvo3r9d4n67n4vy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MbBmy2fnJsn82TKWm/art.json b/art/MbBmy2fnJsn82TKWm/art.json index c8898700..62ffd947 100644 --- a/art/MbBmy2fnJsn82TKWm/art.json +++ b/art/MbBmy2fnJsn82TKWm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Garden Fireworks - @P_Malin\\n// Playing with motion blurred hexagonal bokeh\\n\\n#define SHAKY_CAM\\n\\nfloat Cross( const in vec2 A, const in vec2 B )\\n{\\n return A.x * B.y - A.y * B.x;\\n}\\n\\nvoid GetTriInfo( const float vertexIndex, out vec2 triVertId, out float triId )\\n{\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( triVertexIndex < 1.5 ) \\ttriVertId = vec2( 1.2, 3.4 );\\n else if\\t( triVertexIndex > 1.5 )\\ttriVertId = vec2( 1.2, 1.3 );\\n else \\t\\t\\t\\t\\t\\t\\t\\ttriVertId = vec2( 4.5, 1.5 );\\n\\n triId = floor( vertexIndex / 3.0 );\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nmat3 RotMatrixX( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( 1.0, 0.0, 0.0, \\n 0.0, c, s,\\n 0.0, -s, c ); \\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat Hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nvec3 Hash3(float p)\\n{\\n vec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\\n}\\n\\nvec3 Hash32(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\\n p3 += dot(p3, p3.yxz+19.19);\\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\\n}\\n\\n\\nvec3 Noise23( vec2 p )\\n{\\n\\tvec2 fl = floor(p);\\n\\n\\tvec3 h00 = Hash32( fl + vec2( 0.0, 0.0 ) );\\n\\tvec3 h10 = Hash32( fl + vec2( 1.0, 0.0 ) );\\n\\tvec3 h01 = Hash32( fl + vec2( 0.0, 1.0 ) );\\n\\tvec3 h11 = Hash32( fl + vec2( 1.0, 1.0 ) );\\n\\n\\tvec2 fr = p - fl;\\n\\t\\n\\tvec2 fr2 = fr * fr;\\n\\tvec2 fr3 = fr2 * fr;\\n\\t\\n\\tvec2 t1 = 3.0 * fr2 - 2.0 * fr3;\\t\\n\\tvec2 t0 = 1.0 - t1;\\n\\t\\n\\treturn h00 * t0.x * t0.y\\n\\t\\t + h10 * t1.x * t0.y\\n\\t\\t + h01 * t0.x * t1.y\\n\\t\\t + h11 * t1.x * t1.y;\\n}\\n\\nstruct CameraSettings\\n{\\n float fAperture;\\n float fFocalLength;\\n float fPlaneInFocus; \\n float fExposure;\\n};\\n\\nstruct CameraPosition\\n{\\n \\tvec3 vPosition;\\n \\tvec3 vTarget;\\n \\tvec3 vUp;\\n \\n \\tmat3 mRotation;\\n};\\n \\nstruct OutVertex\\n{\\n \\tvec2 vPos;\\n \\tvec3 vColor;\\n}; \\n \\n#define HEXAGON_OUTLINE_VERTEX_COUNT \\t6.0 * (6.0 + 2.0)\\n\\nvoid GetHexagonOutlineVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r0, const float r1, const vec3 col0, const vec3 col1, inout OutVertex vertex )\\n{\\n \\tfloat fAngleOffset = settings.fAperture * 0.5;\\n \\n \\tif ( fVertexIndex < 6.0 * 6.0 ) \\n {\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndex, vQuadVertId, fQuadId );\\n\\n float fIndex = fQuadId + vQuadVertId.x;\\n\\n float fAngle = fIndex * radians(360.0) / 6.0;\\n\\n float fRadius = mix( r0, r1, vQuadVertId.y);\\n\\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\\n\\n float fCurrIndex = fQuadId;\\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\\n\\n float fNextIndex = fQuadId + 1.0;\\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\\n\\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\\n {\\n vPos += vDir;\\n }\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n else\\n {\\n\\t float fVertexIndexB = fVertexIndex - 6.0 * 6.0;\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\\n \\n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\\n \\n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\\n \\n if ( fQuadId > 0.0 )\\n {\\n\\t\\tfEdgeAngle += radians( 180.0 );\\n }\\n \\n float fRadius = mix( r0, r1, vQuadVertId.y);\\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\\n vPos += vDir * vQuadVertId.x;\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n}\\n \\n#define HEXAGON_VERTEX_COUNT (6.0 * 3.0 + 6.0 * 2.0)\\nvoid GetHexagonVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r, const vec3 col0, const vec3 col1, inout OutVertex vertex )\\n{\\n \\tfloat fAngleOffset = settings.fAperture * 0.5;\\n \\n \\tif ( fVertexIndex < 6.0 * 3.0 ) \\n {\\n float fTriId;\\n\\n vec2 vTriVertId;\\n GetTriInfo( fVertexIndex, vTriVertId, fTriId );\\n\\n float fIndex = fTriId + vTriVertId.x;\\n\\n float fAngle = fIndex * radians(360.0) / 6.0;\\n\\n float fRadius = vTriVertId.y * r;\\n\\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\\n\\n float fCurrIndex = fTriId;\\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\\n\\n float fNextIndex = fTriId + 1.0;\\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\\n\\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\\n {\\n vPos += vDir;\\n }\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vTriVertId.y );\\n }\\n else\\n {\\n\\t float fVertexIndexB = fVertexIndex - 6.0 * 3.0;\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\\n \\n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\\n \\n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\\n \\n if ( fQuadId > 0.0 )\\n {\\n\\t\\tfEdgeAngle += radians( 180.0 );\\n }\\n \\n float fRadius = vQuadVertId.y * r;\\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\\n vPos += vDir * vQuadVertId.x;\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n}\\n\\n\\n#define BOKEH_VERTEX_COUNT ( HEXAGON_VERTEX_COUNT + HEXAGON_OUTLINE_VERTEX_COUNT ) \\nvoid GetBokehVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float fSize, const float fCoC, const vec3 vCol, out OutVertex vertex )\\n{\\n \\tfloat fInnerSize = fSize + fCoC;\\n \\tfloat fGlowSize = 0.02;\\n \\tfloat fOuterSize = fInnerSize + fGlowSize;\\n \\n \\tif ( fVertexIndex < HEXAGON_VERTEX_COUNT )\\n {\\n \\t\\tGetHexagonVertex( settings, fVertexIndex, vOrigin, vDir, fInnerSize, vCol, vCol, vertex );\\n }\\n \\telse\\n {\\n\\t \\tvec3 vGlowCol = pow(vCol, vec3(0.5)) * 0.0001; \\n \\tif ( length( vGlowCol ) > 0.0000001 )\\n {\\n \\t\\t\\tGetHexagonOutlineVertex( settings, fVertexIndex - HEXAGON_VERTEX_COUNT, vOrigin, vDir, fInnerSize, fOuterSize, vGlowCol, vCol * 0.0, vertex );\\n }\\n else\\n {\\n \\tvertex.vPos.xy = vec2(0.0);\\n \\tvertex.vColor.rgb = vec3(0.0);\\n }\\n }\\n}\\n\\nfloat GetCoC( CameraSettings settings, float objectdistance )\\n{\\n // http://http.developer.nvidia.com/GPUGems/gpugems_ch23.html\\n\\n\\treturn abs(settings.fAperture * (settings.fFocalLength * (objectdistance - settings.fPlaneInFocus)) /\\n (objectdistance * (settings.fPlaneInFocus - settings.fFocalLength))); \\n}\\n\\n\\nvec3 GetViewPos( CameraSettings settings, CameraPosition cameraPos, vec3 vWorldPos )\\n{\\n \\treturn (vWorldPos - cameraPos.vPosition) * cameraPos.mRotation;\\n}\\n\\nvec2 GetScreenPos( CameraSettings settings, vec3 vViewPos )\\n{ \\n \\treturn vViewPos.xy * settings.fFocalLength * 5.0 / vViewPos.z;\\n}\\n\\nCameraSettings GetCameraSettings( CameraPosition cameraPosition )\\n{\\n \\tCameraSettings settings;\\n \\n \\tfloat aVal = sin(time * 0.25) * 0.5 + 0.5;\\n \\taVal = aVal * aVal;\\n \\tsettings.fAperture = aVal * 2.9 + 0.1;\\n \\tfloat fVal = sin(time * 0.123) * 0.5 + 0.5;\\n \\tsettings.fFocalLength = 0.2 + 0.2 * fVal;\\n \\tsettings.fPlaneInFocus = length(cameraPosition.vTarget - cameraPosition.vPosition);\\n \\n \\tfloat oldAVal = sin((time - 0.5) * 0.25) * 0.5 + 0.5;\\n \\toldAVal = oldAVal * oldAVal;\\n \\n\\tsettings.fExposure = 3.0 + oldAVal *3.0;\\n\\n \\treturn settings;\\n}\\n\\nstruct LightInfo\\n{\\n\\tvec3 vWorldPos;\\n \\tfloat fRadius;\\n \\tvec3 vColor;\\n};\\n \\n \\nvec2 SolveQuadratic( float a, float b, float c )\\n{\\n float d = sqrt( b * b - 4.0 * a * c );\\n vec2 dV = vec2( d, -d );\\n return (-b + dV) / (2.0 * a);\\n}\\n\\n\\nvec3 BounceParticle( vec3 vOrigin, vec3 vInitialVel, float fGravity, float fFloorHeight, float fTime )\\n{\\n \\tvec3 u = vInitialVel;\\n \\tvec3 a = vec3(0.0, fGravity, 0.0);\\n \\tvec3 vPos = vOrigin;\\n\\n \\tfloat t = fTime;\\n \\t \\t\\n \\tfor( int iBounce=0; iBounce < 3; iBounce++)\\n {\\n // When will we hit the ground?\\n vec2 q = SolveQuadratic( 0.5 * a.y, u.y, -fFloorHeight + vPos.y);\\n float tInt = max( q.x, q.y );\\n tInt -= 0.0001;\\n \\n\\n if ( t < tInt )\\n {\\n\\t vPos += u * t + 0.5 * a * t * t;\\n break;\\n }\\n else\\n { \\n // Calculate velocity at intersect time\\n vec3 v = u + a * tInt;\\n\\n // step to intersect time\\n vPos += u * tInt + 0.5 * a * tInt * tInt;\\n \\t u = v;\\n \\n // bounce\\n u.y = -u.y * 0.3;\\n u.xz *= 0.6;\\n\\n t -= tInt;\\n }\\n }\\n\\n \\treturn vPos;\\n}\\n\\nfloat fFloorHeight = 0.0;\\n\\nLightInfo Fountain( const in float fLightIndex, const in vec3 vPos, float fTime, vec3 vCol, float fSpread )\\n{\\n float fParticleLifetime = 1.5;\\n \\tLightInfo lightInfo;\\n \\n \\tfloat h = Hash( fLightIndex + 12.0 );\\n \\tvec3 h3 = Hash3( fLightIndex + 13.0 );\\n \\n \\tfloat fAngle = fLightIndex;\\n \\n \\tvec3 vInitialVel = (normalize(h3 * 2.0 - 1.0) * fSpread + vec3( 0.0, 10.0 - fSpread * 1.3, 0.0 )) * (0.4 + h * 0.4);\\n \\tvec3 vOrigin = vPos + vec3( 0.0, fFloorHeight + 0.1, 0.0 ) + vInitialVel * 0.1;\\n \\tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fTime );\\n\\n \\n \\tlightInfo.fRadius = 0.01; \\n// \\tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\\n \\tlightInfo.vColor = vCol;\\n \\tlightInfo.vColor *= clamp( 1.0 - fTime + fParticleLifetime - 1.0, 0.0, 1.0);\\n\\treturn lightInfo; \\n}\\n\\nLightInfo CatherineWheel( const in float fLightIndex, const in vec3 vPos, float fSequenceStart, float fSpawnTime, float fParticleT, vec3 vCol )\\n{\\n \\tfloat h = Hash( fLightIndex + 4.0 );\\n\\n\\t float fParticleLifetime = 0.3 + h *0.5;\\n \\tLightInfo lightInfo;\\n\\n \\tvec3 h3 = Hash3( fLightIndex + 12.0 );\\n \\tfloat t = fSpawnTime - fSequenceStart;\\n \\tif( t < 5.0 ) t = t * t;\\n \\telse t = t * 5.0 + 5.0 * 5.0;\\n \\t\\n \\tfloat fSpawnAngle = t * 5.0;\\n \\n \\tif ( h > 0.5 )\\n {\\n fSpawnAngle += radians( 180.0 );\\n }\\n \\n \\tmat3 m = RotMatrixZ(fSpawnAngle);\\n \\n \\tvec3 vInitialVel = vec3(-3.0, 0.0, 0.0 ) + h3 * 0.5;\\n \\tvInitialVel = vInitialVel * m;\\n \\tvec3 vOffset = vec3( 0.0, 0.03, 0.0 * m);\\n \\tvec3 vOrigin = vPos + vOffset + vInitialVel * 0.1;\\n \\tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fParticleT );\\n\\n \\n \\tlightInfo.fRadius = 0.01; \\n// \\tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\\n \\tlightInfo.vColor = vCol;\\n \\tlightInfo.vColor *= clamp( 1.0 - fParticleT + fParticleLifetime - 1.0, 0.0, 1.0);\\n\\treturn lightInfo; \\n}\\n\\n\\nstruct SequenceInfo\\n{\\n \\tfloat fSequenceSet;\\n \\tfloat fSequenceSetLength;\\n \\n \\tfloat fSequenceIndex;\\n \\tfloat fSequenceStartTime;\\n \\n \\tfloat fSequenceSeed;\\n \\tvec3 vSequenceHash;\\n \\n \\tvec3 vCol;\\n \\n \\tfloat fType;\\n \\tvec3 vPos;\\n \\tvec3 vTarget;\\n};\\n \\nSequenceInfo GetSequenceInfo( float fSetIndex, float fTime )\\n{\\n \\tSequenceInfo sequenceInfo;\\n\\n \\t\\tfloat fSequenceSetCount = 2.0;\\n \\tsequenceInfo.fSequenceSet = mod(fSetIndex, fSequenceSetCount);\\n\\n \\t\\tfloat sh = Hash( sequenceInfo.fSequenceSet );\\n \\t\\tfloat fSequenceSetLength = 10.0 + sh * 5.0;\\n \\n\\n \\t\\tsequenceInfo.fSequenceIndex = floor( fTime / fSequenceSetLength );\\n \\t\\tsequenceInfo.fSequenceStartTime = (sequenceInfo.fSequenceIndex * fSequenceSetLength);\\n \\n \\t\\tsequenceInfo.fSequenceSeed = sequenceInfo.fSequenceIndex + sequenceInfo.fSequenceSet * 12.3;\\n \\t\\tsequenceInfo.vSequenceHash = Hash3(sequenceInfo.fSequenceSeed);\\n\\n \\t\\tfloat ch = Hash( sequenceInfo.fSequenceSeed * 2.34 );\\n \\t\\tsequenceInfo.vCol = vec3(1.0, 0.4, 0.1);\\n \\n \\t\\tif( ch < 0.25 )\\n {\\n sequenceInfo.vCol = vec3(1.0, 0.08, 0.08);\\n }\\n \\t\\telse if( ch < 0.5 )\\n {\\n sequenceInfo.vCol = vec3(0.08, 0.08, 1.0);\\n }\\n \\t\\telse if( ch < 0.75 )\\n {\\n sequenceInfo.vCol = vec3(0.08, 1.0, 0.08 );\\n }\\n \\n \\n \\tif ( sequenceInfo.vSequenceHash.x < 0.7)\\n {\\n \\t\\t\\tsequenceInfo.vPos = vec3(0.0);\\n\\t \\t\\tsequenceInfo.vPos.xz = sequenceInfo.vSequenceHash.yz * 6.0 - 3.0;\\n\\t \\t\\tsequenceInfo.fType = 0.0;\\n \\tsequenceInfo.vTarget = sequenceInfo.vPos;\\n \\tsequenceInfo.vTarget.y = 1.5;\\n }\\n \\t\\telse\\n {\\n \\tsequenceInfo.vPos = vec3(0.0, 2.5, 7.0);\\n\\t \\t\\tsequenceInfo.vPos += (sequenceInfo.vSequenceHash.xyz * 2.0 - 1.0) * vec3(5.0, 1.5, 3.0);\\n\\t \\t\\tsequenceInfo.fType = 1.0;\\n \\tsequenceInfo.vTarget = sequenceInfo.vPos;\\n } \\n \\n \\treturn sequenceInfo;\\n}\\n\\nLightInfo GetFireworkSparkInfo( in float fLightIndex, float fTime, float fDeltaTime, vec3 h3 )\\n{ \\n\\t float fParticleLifetime = 1.5;\\n \\tfloat fParticleSpawnTime = (floor( (fTime / fParticleLifetime) + h3.x) - h3.x) * fParticleLifetime;\\n \\tfloat fParticleEndTime = fParticleSpawnTime + fParticleLifetime;\\n \\tfloat fParticleGlobalT = fTime - fParticleSpawnTime;\\n \\tfloat fParticleT = mod( fParticleGlobalT, fParticleLifetime ) + fDeltaTime;\\n \\n \\t\\tSequenceInfo sequenceInfo = GetSequenceInfo( fLightIndex, fParticleSpawnTime );\\n \\n \\tLightInfo lightInfo;\\n \\n \\t\\tif ( sequenceInfo.fType < 0.5)\\n {\\n \\tfloat fSpread = fract( sequenceInfo.vSequenceHash.z + sequenceInfo.vSequenceHash.y ) + 1.0;\\n\\t \\t\\tlightInfo = Fountain( fLightIndex, sequenceInfo.vPos, fParticleT, sequenceInfo.vCol, fSpread );\\n }\\n \\t\\telse\\n {\\n \\tlightInfo = CatherineWheel( fLightIndex, sequenceInfo.vPos, sequenceInfo.fSequenceStartTime, fParticleSpawnTime, fParticleT, sequenceInfo.vCol );\\n } \\n \\n return lightInfo; \\n}\\n\\nLightInfo GetLightInfo( const in float fLightIndex, float fTime, float fDeltaTime, CameraPosition cameraPos )\\n{\\n \\tLightInfo lightInfo;\\n\\n \\t//float h = Hash( fLightIndex );\\n \\tvec3 h3 = Hash3(fLightIndex);\\n\\n \\tfloat kHangingLightCount = 32.0;\\n \\tfloat kHangingLightMax = 0.0 + kHangingLightCount;\\n \\n \\tfloat kStarCount = 0.0;\\n \\tfloat kStarMax = kHangingLightMax + kStarCount;\\n \\t\\n \\tfloat kDirtCount = 16.0;\\n \\tfloat kDirtMax = kStarMax + kDirtCount;\\n\\n \\tfloat kStreetLightCount = 64.0;\\n \\tfloat kStreetLightMax = kDirtMax + kStreetLightCount;\\n \\n \\tfloat kGardenLightCount = 16.0;\\n \\tfloat kGardenLightMax = kStreetLightMax + kGardenLightCount;\\n\\n \\tif( fLightIndex < kHangingLightMax )\\n \\t{\\n \\t// hanging lights\\n \\tlightInfo.vWorldPos.x = ((fLightIndex / 10.0) * 2.0 - 1.0) * 3.0;\\n \\tlightInfo.vWorldPos.y = 2.0 + -abs( cos( fLightIndex * 0.4 ) * 0.8 ); \\n \\tlightInfo.vWorldPos.z = 20.0;\\n \\t\\tlightInfo.vColor = vec3(0.01) * 0.5;\\n \\tfloat fColIndex = mod(fLightIndex, 3.0);\\n \\tif ( fColIndex == 0.0 ) lightInfo.vColor.x = 1.0;\\n \\tif ( fColIndex == 1.0 ) lightInfo.vColor.y = 1.0;\\n \\tif ( fColIndex == 2.0 ) lightInfo.vColor.z = 1.0;\\n\\t lightInfo.vColor *= 0.05;\\n \\t\\t//lightInfo.vColor = normalize(vec3(sin(fLightIndex) * .5 + 0.5, sin(fLightIndex * 3.45) * .5 + 0.5, sin(fLightIndex * 4.56) * .5 + 0.5)) * 0.5;\\n \\n \\t\\tlightInfo.fRadius = 0.05;\\n\\t}\\n \\telse\\n \\tif( fLightIndex < kStarMax )\\n \\t{\\n // stars\\n \\tlightInfo.vWorldPos = normalize( h3 * 2.0 - 1.0 ) * 5000.0;\\n \\tlightInfo.vWorldPos.y = abs(lightInfo.vWorldPos.y);\\n \\t\\tlightInfo.vColor = vec3(0.01);\\n \\t\\tlightInfo.fRadius = 0.001;\\n }\\n \\telse\\n \\tif( fLightIndex < kDirtMax )\\n \\t{\\n // lens dirt\\n \\tlightInfo.vWorldPos.xy = (Hash3(fLightIndex).xy * 2.0 - 1.0);\\n \\tlightInfo.vWorldPos.xy = normalize(lightInfo.vWorldPos.xy) * pow( length(lightInfo.vWorldPos.xy), 0.3 ) * 0.35;\\n\\t lightInfo.vWorldPos.y *= resolution.y / resolution.x;\\n \\tlightInfo.vWorldPos.z = 0.3;\\n \\tvec3 vOffset = cameraPos.mRotation * lightInfo.vWorldPos;\\n \\tlightInfo.vWorldPos = vOffset + cameraPos.vPosition;\\n \\t\\tlightInfo.vColor = vec3(0.2, 0.18, 0.1) * abs( dot(normalize(vOffset), vec3(0.0, 0.0, 1.0)) ) * 10.0;\\n \\t\\tlightInfo.fRadius = 0.0001;\\n }\\n \\telse\\n // street lights\\n \\tif( fLightIndex < kStreetLightMax )\\n \\t{\\n \\tlightInfo.vWorldPos.xz = (h3.xy * 2.0 - 1.0) * 500.0;\\n \\tlightInfo.vWorldPos.y = 10.0; \\n \\t\\tlightInfo.vColor = vec3(1.0, 0.3, 0.01) * 0.5;\\n \\n \\t\\tlightInfo.fRadius = 0.2;\\n\\t}\\n \\telse if( fLightIndex < kGardenLightMax )\\n \\t{\\n \\tlightInfo.vWorldPos.y = 0.05 + h3.y * 0.5; \\n \\tvec2 vOffset = (h3.xz * 2.0 - 1.0);\\n \\tlightInfo.vWorldPos.xz = vOffset * 50.0 + normalize( vOffset ) * 10.0;\\n \\t\\tlightInfo.vColor = sin(h3 * 10.0 + vec3(0.1, 0.2, 0.3)) * 0.5 + 0.5;\\n \\tlightInfo.vColor = normalize(lightInfo.vColor);\\n\\t lightInfo.vColor *= 0.005;\\n \\n \\t\\tlightInfo.fRadius = 0.05;\\n\\t}\\n \\telse\\n {\\n \\tlightInfo = GetFireworkSparkInfo( fLightIndex, fTime, fDeltaTime, h3 );\\n }\\n \\n\\n \\treturn lightInfo;\\n}\\n\\n\\nvec3 GetCameraTarget( float fTime )\\n{\\n \\t//return vec3(0.0, 1.8, 0.0);\\n\\n \\tfloat fInterval = 8.0;\\n \\n \\tfloat t0 = floor(fTime / fInterval) * fInterval; \\n \\tfloat t1 = (floor(fTime / fInterval+ 1.0) ) * fInterval; \\n \\n \\tSequenceInfo inf0 = GetSequenceInfo( 0.0, t0 );\\n \\tSequenceInfo inf1 = GetSequenceInfo( 0.0, t1 );\\n \\n \\tfloat fBlend = (fTime - t0) / fInterval;\\n \\n \\tfBlend = smoothstep( 0.0, 1.0, fBlend);\\n \\n \\treturn mix( inf0.vTarget, inf1.vTarget, fBlend );\\n}\\n\\nCameraPosition GetCameraPosition( float fTime, vec2 vTouch )\\n{\\n \\tCameraPosition cameraPos;\\n \\n \\tif( (vTouch.y > 0.9) && (vTouch.x > -0.83) && (vTouch.x < -0.80) )\\n {\\t\\n \\tvTouch.xy = vec2(0.0);\\n }\\n \\n \\tcameraPos.vTarget = GetCameraTarget( fTime );\\n \\n \\tcameraPos.vPosition += cameraPos.vTarget;\\n \\t\\n \\tcameraPos.vPosition = vec3( sin(fTime * 0.2) * 5.0, 2.0, -6.0 + sin(fTime * 0.0567) * 3.0);\\n \\tcameraPos.vUp = vec3( 0.0, 1.0, 0.0 );\\n \\n \\tGetMatrixFromZY( normalize(cameraPos.vTarget - cameraPos.vPosition), cameraPos.vUp, cameraPos.mRotation );\\n \\n \\tvec3 vRot = vec3( vTouch.y * 0.5, vTouch.x * 0.5, 0.0 );\\n \\n#ifdef SHAKY_CAM\\n\\tvRot += Noise23( cameraPos.vPosition.xz * 4.0 ) * vec3( 0.05, 0.03, 0.01 ); //shaky cam\\n#endif\\n \\n \\tcameraPos.mRotation = cameraPos.mRotation * RotMatrixZ(vRot.z) * RotMatrixY(vRot.y) * RotMatrixX( vRot.x ) ; \\n \\n \\treturn cameraPos;\\n}\\n\\nvoid main() \\n{\\n float fVertexIndex = vertexId;\\n\\n vec4 touch1 = texture2D(touch, vec2(0.0, 0.0));\\n vec4 touch2 = texture2D(touch, vec2(0.0, 0.01)); \\n\\n\\tfloat fShutterSpeed = 1.0 / 60.0;\\n \\n CameraPosition cameraPos = GetCameraPosition( time, touch1.xy );\\n CameraPosition lastCameraPos = GetCameraPosition( time - fShutterSpeed, touch2.xy );\\n\\n CameraSettings cameraSettings = GetCameraSettings( cameraPos );\\n\\n OutVertex vertex;\\n\\n float fBokehIndex = floor( fVertexIndex / BOKEH_VERTEX_COUNT );\\n \\n LightInfo lightInfo = GetLightInfo( fBokehIndex, time, 0.0, cameraPos );\\n LightInfo prevLightInfo = GetLightInfo( fBokehIndex, time, -fShutterSpeed, lastCameraPos );\\n \\n vec3 vViewPos = GetViewPos( cameraSettings, cameraPos, lightInfo.vWorldPos );\\n vec3 vLastViewPos = GetViewPos( cameraSettings, lastCameraPos, prevLightInfo.vWorldPos );\\n\\n vec2 vScreenPos = GetScreenPos( cameraSettings, vViewPos );\\n vec2 vLastScreenPos = GetScreenPos( cameraSettings, vLastViewPos ); \\n\\n float fScreenSize = GetScreenPos( cameraSettings, vec3( lightInfo.fRadius, lightInfo.fRadius, vViewPos.z ) ).x;\\n \\n vec2 vOrigin = vScreenPos.xy;\\n vec2 vDir = vLastScreenPos.xy - vScreenPos.xy;\\n \\n float fCoC = GetCoC( cameraSettings, vViewPos.z );\\n\\n vec3 vCol = lightInfo.vColor;\\n\\n float fSize = fCoC + fScreenSize;\\n vCol *= fScreenSize * fScreenSize * 3.14 / (length( vDir ) * fSize + fSize * fSize * 3.14);\\n \\n float fBokehVertexIndex = mod( fVertexIndex, BOKEH_VERTEX_COUNT );\\n GetBokehVertex( cameraSettings, fBokehVertexIndex, vOrigin, vDir, fScreenSize, fCoC, vCol, vertex );\\n \\n vertex.vPos.y *= resolution.x / resolution.y;\\n \\n gl_Position = vec4(vertex.vPos.x, vertex.vPos.y, 1.0 / vertexId, 1);\\n float fFinalExposure = cameraSettings.fExposure / (cameraSettings.fAperture * cameraSettings.fAperture);\\n v_color.rgb = 1.0 - exp2( vertex.vColor * -fFinalExposure );\\n v_color.rgb = pow( v_color.rgb, vec3(1.0 / 2.2) );\\n v_color.a = 0.0;\\n \\n float fNearClip = 0.25;\\n if ( vViewPos.z <= fNearClip || vLastViewPos.z <= fNearClip)\\n {\\n gl_Position = vec4(0.0);\\n v_color = vec4(0.0);\\n }\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Garden Fireworks - @P_Malin\n// Playing with motion blurred hexagonal bokeh\n\n#define SHAKY_CAM\n\nfloat Cross( const in vec2 A, const in vec2 B )\n{\n return A.x * B.y - A.y * B.x;\n}\n\nvoid GetTriInfo( const float vertexIndex, out vec2 triVertId, out float triId )\n{\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( triVertexIndex < 1.5 ) \ttriVertId = vec2( 1.2, 3.4 );\n else if\t( triVertexIndex > 1.5 )\ttriVertId = vec2( 1.2, 1.3 );\n else \t\t\t\t\t\t\t\ttriVertId = vec2( 4.5, 1.5 );\n\n triId = floor( vertexIndex / 3.0 );\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nmat3 RotMatrixX( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( 1.0, 0.0, 0.0, \n 0.0, c, s,\n 0.0, -s, c ); \n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat Hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nvec3 Hash3(float p)\n{\n vec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\n}\n\nvec3 Hash32(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\n p3 += dot(p3, p3.yxz+19.19);\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\n}\n\n\nvec3 Noise23( vec2 p )\n{\n\tvec2 fl = floor(p);\n\n\tvec3 h00 = Hash32( fl + vec2( 0.0, 0.0 ) );\n\tvec3 h10 = Hash32( fl + vec2( 1.0, 0.0 ) );\n\tvec3 h01 = Hash32( fl + vec2( 0.0, 1.0 ) );\n\tvec3 h11 = Hash32( fl + vec2( 1.0, 1.0 ) );\n\n\tvec2 fr = p - fl;\n\t\n\tvec2 fr2 = fr * fr;\n\tvec2 fr3 = fr2 * fr;\n\t\n\tvec2 t1 = 3.0 * fr2 - 2.0 * fr3;\t\n\tvec2 t0 = 1.0 - t1;\n\t\n\treturn h00 * t0.x * t0.y\n\t\t + h10 * t1.x * t0.y\n\t\t + h01 * t0.x * t1.y\n\t\t + h11 * t1.x * t1.y;\n}\n\nstruct CameraSettings\n{\n float fAperture;\n float fFocalLength;\n float fPlaneInFocus; \n float fExposure;\n};\n\nstruct CameraPosition\n{\n \tvec3 vPosition;\n \tvec3 vTarget;\n \tvec3 vUp;\n \n \tmat3 mRotation;\n};\n \nstruct OutVertex\n{\n \tvec2 vPos;\n \tvec3 vColor;\n}; \n \n#define HEXAGON_OUTLINE_VERTEX_COUNT \t6.0 * (6.0 + 2.0)\n\nvoid GetHexagonOutlineVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r0, const float r1, const vec3 col0, const vec3 col1, inout OutVertex vertex )\n{\n \tfloat fAngleOffset = settings.fAperture * 0.5;\n \n \tif ( fVertexIndex < 6.0 * 6.0 ) \n {\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndex, vQuadVertId, fQuadId );\n\n float fIndex = fQuadId + vQuadVertId.x;\n\n float fAngle = fIndex * radians(360.0) / 6.0;\n\n float fRadius = mix( r0, r1, vQuadVertId.y);\n\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\n\n float fCurrIndex = fQuadId;\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\n\n float fNextIndex = fQuadId + 1.0;\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\n\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\n {\n vPos += vDir;\n }\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n else\n {\n\t float fVertexIndexB = fVertexIndex - 6.0 * 6.0;\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\n \n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\n \n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\n \n if ( fQuadId > 0.0 )\n {\n\t\tfEdgeAngle += radians( 180.0 );\n }\n \n float fRadius = mix( r0, r1, vQuadVertId.y);\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\n vPos += vDir * vQuadVertId.x;\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n}\n \n#define HEXAGON_VERTEX_COUNT (6.0 * 3.0 + 6.0 * 2.0)\nvoid GetHexagonVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r, const vec3 col0, const vec3 col1, inout OutVertex vertex )\n{\n \tfloat fAngleOffset = settings.fAperture * 0.5;\n \n \tif ( fVertexIndex < 6.0 * 3.0 ) \n {\n float fTriId;\n\n vec2 vTriVertId;\n GetTriInfo( fVertexIndex, vTriVertId, fTriId );\n\n float fIndex = fTriId + vTriVertId.x;\n\n float fAngle = fIndex * radians(360.0) / 6.0;\n\n float fRadius = vTriVertId.y * r;\n\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\n\n float fCurrIndex = fTriId;\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\n\n float fNextIndex = fTriId + 1.0;\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\n\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\n {\n vPos += vDir;\n }\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vTriVertId.y );\n }\n else\n {\n\t float fVertexIndexB = fVertexIndex - 6.0 * 3.0;\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\n \n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\n \n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\n \n if ( fQuadId > 0.0 )\n {\n\t\tfEdgeAngle += radians( 180.0 );\n }\n \n float fRadius = vQuadVertId.y * r;\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\n vPos += vDir * vQuadVertId.x;\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n}\n\n\n#define BOKEH_VERTEX_COUNT ( HEXAGON_VERTEX_COUNT + HEXAGON_OUTLINE_VERTEX_COUNT ) \nvoid GetBokehVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float fSize, const float fCoC, const vec3 vCol, out OutVertex vertex )\n{\n \tfloat fInnerSize = fSize + fCoC;\n \tfloat fGlowSize = 0.02;\n \tfloat fOuterSize = fInnerSize + fGlowSize;\n \n \tif ( fVertexIndex < HEXAGON_VERTEX_COUNT )\n {\n \t\tGetHexagonVertex( settings, fVertexIndex, vOrigin, vDir, fInnerSize, vCol, vCol, vertex );\n }\n \telse\n {\n\t \tvec3 vGlowCol = pow(vCol, vec3(0.5)) * 0.0001; \n \tif ( length( vGlowCol ) > 0.0000001 )\n {\n \t\t\tGetHexagonOutlineVertex( settings, fVertexIndex - HEXAGON_VERTEX_COUNT, vOrigin, vDir, fInnerSize, fOuterSize, vGlowCol, vCol * 0.0, vertex );\n }\n else\n {\n \tvertex.vPos.xy = vec2(0.0);\n \tvertex.vColor.rgb = vec3(0.0);\n }\n }\n}\n\nfloat GetCoC( CameraSettings settings, float objectdistance )\n{\n // http://http.developer.nvidia.com/GPUGems/gpugems_ch23.html\n\n\treturn abs(settings.fAperture * (settings.fFocalLength * (objectdistance - settings.fPlaneInFocus)) /\n (objectdistance * (settings.fPlaneInFocus - settings.fFocalLength))); \n}\n\n\nvec3 GetViewPos( CameraSettings settings, CameraPosition cameraPos, vec3 vWorldPos )\n{\n \treturn (vWorldPos - cameraPos.vPosition) * cameraPos.mRotation;\n}\n\nvec2 GetScreenPos( CameraSettings settings, vec3 vViewPos )\n{ \n \treturn vViewPos.xy * settings.fFocalLength * 5.0 / vViewPos.z;\n}\n\nCameraSettings GetCameraSettings( CameraPosition cameraPosition )\n{\n \tCameraSettings settings;\n \n \tfloat aVal = sin(time * 0.25) * 0.5 + 0.5;\n \taVal = aVal * aVal;\n \tsettings.fAperture = aVal * 2.9 + 0.1;\n \tfloat fVal = sin(time * 0.123) * 0.5 + 0.5;\n \tsettings.fFocalLength = 0.2 + 0.2 * fVal;\n \tsettings.fPlaneInFocus = length(cameraPosition.vTarget - cameraPosition.vPosition);\n \n \tfloat oldAVal = sin((time - 0.5) * 0.25) * 0.5 + 0.5;\n \toldAVal = oldAVal * oldAVal;\n \n\tsettings.fExposure = 3.0 + oldAVal *3.0;\n\n \treturn settings;\n}\n\nstruct LightInfo\n{\n\tvec3 vWorldPos;\n \tfloat fRadius;\n \tvec3 vColor;\n};\n \n \nvec2 SolveQuadratic( float a, float b, float c )\n{\n float d = sqrt( b * b - 4.0 * a * c );\n vec2 dV = vec2( d, -d );\n return (-b + dV) / (2.0 * a);\n}\n\n\nvec3 BounceParticle( vec3 vOrigin, vec3 vInitialVel, float fGravity, float fFloorHeight, float fTime )\n{\n \tvec3 u = vInitialVel;\n \tvec3 a = vec3(0.0, fGravity, 0.0);\n \tvec3 vPos = vOrigin;\n\n \tfloat t = fTime;\n \t \t\n \tfor( int iBounce=0; iBounce < 3; iBounce++)\n {\n // When will we hit the ground?\n vec2 q = SolveQuadratic( 0.5 * a.y, u.y, -fFloorHeight + vPos.y);\n float tInt = max( q.x, q.y );\n tInt -= 0.0001;\n \n\n if ( t < tInt )\n {\n\t vPos += u * t + 0.5 * a * t * t;\n break;\n }\n else\n { \n // Calculate velocity at intersect time\n vec3 v = u + a * tInt;\n\n // step to intersect time\n vPos += u * tInt + 0.5 * a * tInt * tInt;\n \t u = v;\n \n // bounce\n u.y = -u.y * 0.3;\n u.xz *= 0.6;\n\n t -= tInt;\n }\n }\n\n \treturn vPos;\n}\n\nfloat fFloorHeight = 0.0;\n\nLightInfo Fountain( const in float fLightIndex, const in vec3 vPos, float fTime, vec3 vCol, float fSpread )\n{\n float fParticleLifetime = 1.5;\n \tLightInfo lightInfo;\n \n \tfloat h = Hash( fLightIndex + 12.0 );\n \tvec3 h3 = Hash3( fLightIndex + 13.0 );\n \n \tfloat fAngle = fLightIndex;\n \n \tvec3 vInitialVel = (normalize(h3 * 2.0 - 1.0) * fSpread + vec3( 0.0, 10.0 - fSpread * 1.3, 0.0 )) * (0.4 + h * 0.4);\n \tvec3 vOrigin = vPos + vec3( 0.0, fFloorHeight + 0.1, 0.0 ) + vInitialVel * 0.1;\n \tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fTime );\n\n \n \tlightInfo.fRadius = 0.01; \n// \tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\n \tlightInfo.vColor = vCol;\n \tlightInfo.vColor *= clamp( 1.0 - fTime + fParticleLifetime - 1.0, 0.0, 1.0);\n\treturn lightInfo; \n}\n\nLightInfo CatherineWheel( const in float fLightIndex, const in vec3 vPos, float fSequenceStart, float fSpawnTime, float fParticleT, vec3 vCol )\n{\n \tfloat h = Hash( fLightIndex + 4.0 );\n\n\t float fParticleLifetime = 0.3 + h *0.5;\n \tLightInfo lightInfo;\n\n \tvec3 h3 = Hash3( fLightIndex + 12.0 );\n \tfloat t = fSpawnTime - fSequenceStart;\n \tif( t < 5.0 ) t = t * t;\n \telse t = t * 5.0 + 5.0 * 5.0;\n \t\n \tfloat fSpawnAngle = t * 5.0;\n \n \tif ( h > 0.5 )\n {\n fSpawnAngle += radians( 180.0 );\n }\n \n \tmat3 m = RotMatrixZ(fSpawnAngle);\n \n \tvec3 vInitialVel = vec3(-3.0, 0.0, 0.0 ) + h3 * 0.5;\n \tvInitialVel = vInitialVel * m;\n \tvec3 vOffset = vec3( 0.0, 0.03, 0.0 * m);\n \tvec3 vOrigin = vPos + vOffset + vInitialVel * 0.1;\n \tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fParticleT );\n\n \n \tlightInfo.fRadius = 0.01; \n// \tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\n \tlightInfo.vColor = vCol;\n \tlightInfo.vColor *= clamp( 1.0 - fParticleT + fParticleLifetime - 1.0, 0.0, 1.0);\n\treturn lightInfo; \n}\n\n\nstruct SequenceInfo\n{\n \tfloat fSequenceSet;\n \tfloat fSequenceSetLength;\n \n \tfloat fSequenceIndex;\n \tfloat fSequenceStartTime;\n \n \tfloat fSequenceSeed;\n \tvec3 vSequenceHash;\n \n \tvec3 vCol;\n \n \tfloat fType;\n \tvec3 vPos;\n \tvec3 vTarget;\n};\n \nSequenceInfo GetSequenceInfo( float fSetIndex, float fTime )\n{\n \tSequenceInfo sequenceInfo;\n\n \t\tfloat fSequenceSetCount = 2.0;\n \tsequenceInfo.fSequenceSet = mod(fSetIndex, fSequenceSetCount);\n\n \t\tfloat sh = Hash( sequenceInfo.fSequenceSet );\n \t\tfloat fSequenceSetLength = 10.0 + sh * 5.0;\n \n\n \t\tsequenceInfo.fSequenceIndex = floor( fTime / fSequenceSetLength );\n \t\tsequenceInfo.fSequenceStartTime = (sequenceInfo.fSequenceIndex * fSequenceSetLength);\n \n \t\tsequenceInfo.fSequenceSeed = sequenceInfo.fSequenceIndex + sequenceInfo.fSequenceSet * 12.3;\n \t\tsequenceInfo.vSequenceHash = Hash3(sequenceInfo.fSequenceSeed);\n\n \t\tfloat ch = Hash( sequenceInfo.fSequenceSeed * 2.34 );\n \t\tsequenceInfo.vCol = vec3(1.0, 0.4, 0.1);\n \n \t\tif( ch < 0.25 )\n {\n sequenceInfo.vCol = vec3(1.0, 0.08, 0.08);\n }\n \t\telse if( ch < 0.5 )\n {\n sequenceInfo.vCol = vec3(0.08, 0.08, 1.0);\n }\n \t\telse if( ch < 0.75 )\n {\n sequenceInfo.vCol = vec3(0.08, 1.0, 0.08 );\n }\n \n \n \tif ( sequenceInfo.vSequenceHash.x < 0.7)\n {\n \t\t\tsequenceInfo.vPos = vec3(0.0);\n\t \t\tsequenceInfo.vPos.xz = sequenceInfo.vSequenceHash.yz * 6.0 - 3.0;\n\t \t\tsequenceInfo.fType = 0.0;\n \tsequenceInfo.vTarget = sequenceInfo.vPos;\n \tsequenceInfo.vTarget.y = 1.5;\n }\n \t\telse\n {\n \tsequenceInfo.vPos = vec3(0.0, 2.5, 7.0);\n\t \t\tsequenceInfo.vPos += (sequenceInfo.vSequenceHash.xyz * 2.0 - 1.0) * vec3(5.0, 1.5, 3.0);\n\t \t\tsequenceInfo.fType = 1.0;\n \tsequenceInfo.vTarget = sequenceInfo.vPos;\n } \n \n \treturn sequenceInfo;\n}\n\nLightInfo GetFireworkSparkInfo( in float fLightIndex, float fTime, float fDeltaTime, vec3 h3 )\n{ \n\t float fParticleLifetime = 1.5;\n \tfloat fParticleSpawnTime = (floor( (fTime / fParticleLifetime) + h3.x) - h3.x) * fParticleLifetime;\n \tfloat fParticleEndTime = fParticleSpawnTime + fParticleLifetime;\n \tfloat fParticleGlobalT = fTime - fParticleSpawnTime;\n \tfloat fParticleT = mod( fParticleGlobalT, fParticleLifetime ) + fDeltaTime;\n \n \t\tSequenceInfo sequenceInfo = GetSequenceInfo( fLightIndex, fParticleSpawnTime );\n \n \tLightInfo lightInfo;\n \n \t\tif ( sequenceInfo.fType < 0.5)\n {\n \tfloat fSpread = fract( sequenceInfo.vSequenceHash.z + sequenceInfo.vSequenceHash.y ) + 1.0;\n\t \t\tlightInfo = Fountain( fLightIndex, sequenceInfo.vPos, fParticleT, sequenceInfo.vCol, fSpread );\n }\n \t\telse\n {\n \tlightInfo = CatherineWheel( fLightIndex, sequenceInfo.vPos, sequenceInfo.fSequenceStartTime, fParticleSpawnTime, fParticleT, sequenceInfo.vCol );\n } \n \n return lightInfo; \n}\n\nLightInfo GetLightInfo( const in float fLightIndex, float fTime, float fDeltaTime, CameraPosition cameraPos )\n{\n \tLightInfo lightInfo;\n\n \t//float h = Hash( fLightIndex );\n \tvec3 h3 = Hash3(fLightIndex);\n\n \tfloat kHangingLightCount = 32.0;\n \tfloat kHangingLightMax = 0.0 + kHangingLightCount;\n \n \tfloat kStarCount = 0.0;\n \tfloat kStarMax = kHangingLightMax + kStarCount;\n \t\n \tfloat kDirtCount = 16.0;\n \tfloat kDirtMax = kStarMax + kDirtCount;\n\n \tfloat kStreetLightCount = 64.0;\n \tfloat kStreetLightMax = kDirtMax + kStreetLightCount;\n \n \tfloat kGardenLightCount = 16.0;\n \tfloat kGardenLightMax = kStreetLightMax + kGardenLightCount;\n\n \tif( fLightIndex < kHangingLightMax )\n \t{\n \t// hanging lights\n \tlightInfo.vWorldPos.x = ((fLightIndex / 10.0) * 2.0 - 1.0) * 3.0;\n \tlightInfo.vWorldPos.y = 2.0 + -abs( cos( fLightIndex * 0.4 ) * 0.8 ); \n \tlightInfo.vWorldPos.z = 20.0;\n \t\tlightInfo.vColor = vec3(0.01) * 0.5;\n \tfloat fColIndex = mod(fLightIndex, 3.0);\n \tif ( fColIndex == 0.0 ) lightInfo.vColor.x = 1.0;\n \tif ( fColIndex == 1.0 ) lightInfo.vColor.y = 1.0;\n \tif ( fColIndex == 2.0 ) lightInfo.vColor.z = 1.0;\n\t lightInfo.vColor *= 0.05;\n \t\t//lightInfo.vColor = normalize(vec3(sin(fLightIndex) * .5 + 0.5, sin(fLightIndex * 3.45) * .5 + 0.5, sin(fLightIndex * 4.56) * .5 + 0.5)) * 0.5;\n \n \t\tlightInfo.fRadius = 0.05;\n\t}\n \telse\n \tif( fLightIndex < kStarMax )\n \t{\n // stars\n \tlightInfo.vWorldPos = normalize( h3 * 2.0 - 1.0 ) * 5000.0;\n \tlightInfo.vWorldPos.y = abs(lightInfo.vWorldPos.y);\n \t\tlightInfo.vColor = vec3(0.01);\n \t\tlightInfo.fRadius = 0.001;\n }\n \telse\n \tif( fLightIndex < kDirtMax )\n \t{\n // lens dirt\n \tlightInfo.vWorldPos.xy = (Hash3(fLightIndex).xy * 2.0 - 1.0);\n \tlightInfo.vWorldPos.xy = normalize(lightInfo.vWorldPos.xy) * pow( length(lightInfo.vWorldPos.xy), 0.3 ) * 0.35;\n\t lightInfo.vWorldPos.y *= resolution.y / resolution.x;\n \tlightInfo.vWorldPos.z = 0.3;\n \tvec3 vOffset = cameraPos.mRotation * lightInfo.vWorldPos;\n \tlightInfo.vWorldPos = vOffset + cameraPos.vPosition;\n \t\tlightInfo.vColor = vec3(0.2, 0.18, 0.1) * abs( dot(normalize(vOffset), vec3(0.0, 0.0, 1.0)) ) * 10.0;\n \t\tlightInfo.fRadius = 0.0001;\n }\n \telse\n // street lights\n \tif( fLightIndex < kStreetLightMax )\n \t{\n \tlightInfo.vWorldPos.xz = (h3.xy * 2.0 - 1.0) * 500.0;\n \tlightInfo.vWorldPos.y = 10.0; \n \t\tlightInfo.vColor = vec3(1.0, 0.3, 0.01) * 0.5;\n \n \t\tlightInfo.fRadius = 0.2;\n\t}\n \telse if( fLightIndex < kGardenLightMax )\n \t{\n \tlightInfo.vWorldPos.y = 0.05 + h3.y * 0.5; \n \tvec2 vOffset = (h3.xz * 2.0 - 1.0);\n \tlightInfo.vWorldPos.xz = vOffset * 50.0 + normalize( vOffset ) * 10.0;\n \t\tlightInfo.vColor = sin(h3 * 10.0 + vec3(0.1, 0.2, 0.3)) * 0.5 + 0.5;\n \tlightInfo.vColor = normalize(lightInfo.vColor);\n\t lightInfo.vColor *= 0.005;\n \n \t\tlightInfo.fRadius = 0.05;\n\t}\n \telse\n {\n \tlightInfo = GetFireworkSparkInfo( fLightIndex, fTime, fDeltaTime, h3 );\n }\n \n\n \treturn lightInfo;\n}\n\n\nvec3 GetCameraTarget( float fTime )\n{\n \t//return vec3(0.0, 1.8, 0.0);\n\n \tfloat fInterval = 8.0;\n \n \tfloat t0 = floor(fTime / fInterval) * fInterval; \n \tfloat t1 = (floor(fTime / fInterval+ 1.0) ) * fInterval; \n \n \tSequenceInfo inf0 = GetSequenceInfo( 0.0, t0 );\n \tSequenceInfo inf1 = GetSequenceInfo( 0.0, t1 );\n \n \tfloat fBlend = (fTime - t0) / fInterval;\n \n \tfBlend = smoothstep( 0.0, 1.0, fBlend);\n \n \treturn mix( inf0.vTarget, inf1.vTarget, fBlend );\n}\n\nCameraPosition GetCameraPosition( float fTime, vec2 vTouch )\n{\n \tCameraPosition cameraPos;\n \n \tif( (vTouch.y > 0.9) && (vTouch.x > -0.83) && (vTouch.x < -0.80) )\n {\t\n \tvTouch.xy = vec2(0.0);\n }\n \n \tcameraPos.vTarget = GetCameraTarget( fTime );\n \n \tcameraPos.vPosition += cameraPos.vTarget;\n \t\n \tcameraPos.vPosition = vec3( sin(fTime * 0.2) * 5.0, 2.0, -6.0 + sin(fTime * 0.0567) * 3.0);\n \tcameraPos.vUp = vec3( 0.0, 1.0, 0.0 );\n \n \tGetMatrixFromZY( normalize(cameraPos.vTarget - cameraPos.vPosition), cameraPos.vUp, cameraPos.mRotation );\n \n \tvec3 vRot = vec3( vTouch.y * 0.5, vTouch.x * 0.5, 0.0 );\n \n#ifdef SHAKY_CAM\n\tvRot += Noise23( cameraPos.vPosition.xz * 4.0 ) * vec3( 0.05, 0.03, 0.01 ); //shaky cam\n#endif\n \n \tcameraPos.mRotation = cameraPos.mRotation * RotMatrixZ(vRot.z) * RotMatrixY(vRot.y) * RotMatrixX( vRot.x ) ; \n \n \treturn cameraPos;\n}\n\nvoid main() \n{\n float fVertexIndex = vertexId;\n\n vec4 touch1 = texture2D(touch, vec2(0.0, 0.0));\n vec4 touch2 = texture2D(touch, vec2(0.0, 0.01)); \n\n\tfloat fShutterSpeed = 1.0 / 60.0;\n \n CameraPosition cameraPos = GetCameraPosition( time, touch1.xy );\n CameraPosition lastCameraPos = GetCameraPosition( time - fShutterSpeed, touch2.xy );\n\n CameraSettings cameraSettings = GetCameraSettings( cameraPos );\n\n OutVertex vertex;\n\n float fBokehIndex = floor( fVertexIndex / BOKEH_VERTEX_COUNT );\n \n LightInfo lightInfo = GetLightInfo( fBokehIndex, time, 0.0, cameraPos );\n LightInfo prevLightInfo = GetLightInfo( fBokehIndex, time, -fShutterSpeed, lastCameraPos );\n \n vec3 vViewPos = GetViewPos( cameraSettings, cameraPos, lightInfo.vWorldPos );\n vec3 vLastViewPos = GetViewPos( cameraSettings, lastCameraPos, prevLightInfo.vWorldPos );\n\n vec2 vScreenPos = GetScreenPos( cameraSettings, vViewPos );\n vec2 vLastScreenPos = GetScreenPos( cameraSettings, vLastViewPos ); \n\n float fScreenSize = GetScreenPos( cameraSettings, vec3( lightInfo.fRadius, lightInfo.fRadius, vViewPos.z ) ).x;\n \n vec2 vOrigin = vScreenPos.xy;\n vec2 vDir = vLastScreenPos.xy - vScreenPos.xy;\n \n float fCoC = GetCoC( cameraSettings, vViewPos.z );\n\n vec3 vCol = lightInfo.vColor;\n\n float fSize = fCoC + fScreenSize;\n vCol *= fScreenSize * fScreenSize * 3.14 / (length( vDir ) * fSize + fSize * fSize * 3.14);\n \n float fBokehVertexIndex = mod( fVertexIndex, BOKEH_VERTEX_COUNT );\n GetBokehVertex( cameraSettings, fBokehVertexIndex, vOrigin, vDir, fScreenSize, fCoC, vCol, vertex );\n \n vertex.vPos.y *= resolution.x / resolution.y;\n \n gl_Position = vec4(vertex.vPos.x, vertex.vPos.y, 1.0 / vertexId, 1);\n float fFinalExposure = cameraSettings.fExposure / (cameraSettings.fAperture * cameraSettings.fAperture);\n v_color.rgb = 1.0 - exp2( vertex.vColor * -fFinalExposure );\n v_color.rgb = pow( v_color.rgb, vec3(1.0 / 2.2) );\n v_color.a = 0.0;\n \n float fNearClip = 0.25;\n if ( vViewPos.z <= fNearClip || vLastViewPos.z <= fNearClip)\n {\n gl_Position = vec4(0.0);\n v_color = vec4(0.0);\n }\n \n}" + }, "screenshotURL": "data/images/images-3fy82ued29u3itmci-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/McGjF3J5vvtWpxnDw/art.json b/art/McGjF3J5vvtWpxnDw/art.json index acfa72a4..7a0ea805 100644 --- a/art/McGjF3J5vvtWpxnDw/art.json +++ b/art/McGjF3J5vvtWpxnDw/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "tdhooper", "avatarUrl": "https://avatars.githubusercontent.com/tdhooper?s=200", - "settings": "{\"num\":12093,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chahinesounds/kirby-chahine\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// --------------------------------------------------------\\n// Spectrum colour palette\\n// IQ https://www.shadertoy.com/view/ll2GD3\\n// --------------------------------------------------------\\n\\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\\n return a + b*cos( 6.28318*(c*t+d) );\\n}\\n\\nvec3 spectrum(float n) {\\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\\n}\\n\\n\\n// --------------------------------------------------------\\n// Camera and display\\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\\n// --------------------------------------------------------\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nstruct Tri {\\n vec3 a;\\n vec3 b;\\n vec3 c;\\n};\\n \\nvec3 bToC(Tri tri, float a, float b, float c) {\\n return a * tri.a + b * tri.b + c * tri.c;\\n}\\n\\nvec3 bToC(Tri tri, vec3 bary) {\\n return bary.x * tri.a + bary.y * tri.b + bary.z * tri.c;\\n}\\n\\n\\nfloat calcTriRow(float n) {\\n return floor( (1. + sqrt(1. + 8. * n)) / 2. ) - 1.;\\n}\\n\\n\\nvec3 triVertex(Tri tri, float row, float column, float rows, float index, float doSecondPass) {\\n float doFirstPass = 1. - doSecondPass;\\n \\n // First pass offsets\\n row += min(index, 1.) * doFirstPass;\\n column += max(index - 1., 0.) * doFirstPass;\\n\\n // Second pass offsets\\n row += max(index, 1.) * doSecondPass;\\n column += min(index, 1.) * doSecondPass;\\n\\n // Cartesian coordinates for column/row\\n float mixA = row / rows;\\n float mixB = column / max(row, 1.);\\n vec3 vertex = mix(tri.a, mix(tri.b, tri.c, mixB), mixA);\\n return vertex;\\n}\\n\\nvec3 pick(vec3 a, vec3 b, vec3 c, float index) {\\n\\treturn mix(mix(a, b, index), c, max(index - 1., 0.));\\n}\\n\\n\\nstruct GeoPoints {\\n\\tvec3 vertex;\\n \\tvec3 center;\\n};\\n \\n\\n// Find vertex and center in triangle with n subdivision rows at index\\nGeoPoints geoPoints(Tri tri, float rows, float i) {\\n float firstPass = (rows - 1.) * (rows + 2.) / 2. + 1.;\\n \\n // Sub-tringle vertex index\\n float id = mod(i, 3.);\\n \\n //firstPass = 56.;\\n \\n // Repeat whole triangle\\n ///i = mod(i, rows * rows* 3.);\\n \\n // Sub-triangle index\\n i = floor(i / 3.);\\n \\n \\n // First pass is upwards pointing triangles,\\n // second pass fills in the gaps\\n float doSecondPass = max(0., sign(i - firstPass + 1.));\\n \\n i -= firstPass * doSecondPass;\\n \\n float row = calcTriRow(i);\\n float startOfRow = row * (row + 1.) / 2.;\\n float column = mod(i - startOfRow, row + 1.);\\n\\n \\n vec3 vertexA = triVertex(tri, row, column, rows, 0., doSecondPass); \\n vec3 vertexB = triVertex(tri, row, column, rows, 1., doSecondPass); \\n vec3 vertexC = triVertex(tri, row, column, rows, 2., doSecondPass); \\n \\n vec3 vertex = pick(vertexA, vertexB, vertexC, id);\\n vec3 center = (vertexA + vertexB + vertexC) / 3.;\\n \\n return GeoPoints(vertex, center);\\n}\\n\\n#define PHI (1.618033988749895)\\n // PHI (sqrt(5)*0.5 + 0.5)\\n\\n\\n#define IcoVert0 normalize(vec3(0, PHI, 1))\\n#define IcoVert1 normalize(vec3(0, PHI, -1))\\n#define IcoVert2 normalize(vec3(0, -PHI, 1))\\n#define IcoVert3 normalize(vec3(0, -PHI, -1))\\n#define IcoVert4 normalize(vec3(1, 0, PHI))\\n#define IcoVert5 normalize(vec3(1, 0, -PHI))\\n#define IcoVert6 normalize(vec3(-1, 0, PHI))\\n#define IcoVert7 normalize(vec3(-1, 0, -PHI))\\n#define IcoVert8 normalize(vec3(PHI, 1, 0))\\n#define IcoVert9 normalize(vec3(PHI, -1, 0))\\n#define IcoVert10 normalize(vec3(-PHI, 1, 0))\\n#define IcoVert11 normalize(vec3(-PHI, -1, 0))\\n\\nfloat beat(float i, float loop) {\\n\\treturn 1. - min(mod(i, loop), 1.);\\n} \\n\\nfloat signbeat(float i, float loop) {\\n\\treturn beat(i, loop) * 2. - 1.;\\n}\\n\\n\\nvec3 shift(vec3 v, float offset) {\\n\\toffset = mod(offset, 3.);\\n \\tif (offset == 0.) {\\n return v.xyz;\\n \\t}\\n \\tif (offset == 1.) {\\n return v.zxy;\\n \\t}\\n \\tif (offset == 2.) {\\n return v.yzx;\\n \\t}\\n}\\n\\nfloat round(float a) {\\n\\treturn floor(a + .5);\\n}\\n\\n// Step through each vertex of each icosahedron face\\nvec3 icosahedronFaceVertex(float i) {\\n \\n float stage, stageIndexOffset, stageLength;\\n float a, a0, a1, a2, b, b0, b1, b2, offset, offset0, offset1,offset2;\\n \\n stage = round( log2( floor(i / 6.) + 2.) - 1.);\\n stageIndexOffset = 6. * (stage * stage);\\n i -= stageIndexOffset;\\n stageLength = 3. * (stage + 1.) * (stage + 2.);\\n \\n float floatFudge = .01; // Fixes rounding issue on OS X\\n float invert = floor(i / stageLength * (2. + floatFudge)) * 2. - 1.;\\n \\n // Stage 0\\n a0 = invert;\\n b0 = invert;\\n offset0 = mod(i, 3.);\\n \\n // Stage 1\\n a1 = invert;\\n b1 = signbeat(i, 3.) * -1. * invert;\\n offset1 = mod(floor(i / 3.) - beat(i - 2., 3.), 3.);\\n\\n // Stage 2\\n a2 = b1;\\n b2 = signbeat(i - 2., 3.) * -1. * invert;\\n offset2 = mod(floor(i / 6.) + (1. - beat(i, 3.)) + beat(i - 5., 6.), 3.);\\n \\n // Pick stage to show\\n float blend1 = stage;\\n float blend2 = max(0., stage - 1.);\\n a = mix(mix(a0, a1, blend1), a2, blend2);\\n b = mix(mix(b0, b1, blend1), b2, blend2);\\n offset = mix(mix(offset0, offset1, blend1), offset2, blend2);\\n\\n vec3 icoVert = normalize(vec3(PHI, 1, 0));\\n icoVert *= vec3(a, b, 1.);\\n icoVert = shift(icoVert, offset); \\n //icoVert = normalize(icoVert);\\n return icoVert;\\n}\\n\\n\\nfloat mb(GeoPoints geo, vec3 origin, float index) {\\n \\tvec3 o2 = vec3(1,0,0);\\n \\t//origin = vec3(0,1,0);\\n \\tvec3 pos = mix(geo.center, geo.vertex, sin(time) * .5 + .5);\\n\\t\\n \\tfloat blendVertex = abs(dot(geo.vertex, origin));\\t\\n\\tfloat blendCenter = abs(dot(geo.center, origin));\\t\\n\\t\\n \\tfloat b1 = sin(blendVertex * 20. + time) * .5 + .5;\\n \\tfloat b2 = sin(blendCenter * 10. + time*-2.) * .5 + .5;\\n \\n \\treturn b1 + b2 * (sin(time * .5) * .5 + .5) * 1.2;\\n \\n \\tfloat x = abs(dot(pos, vec3(0,1,0)));\\n \\tfloat y = abs(dot(pos, vec3(1,0,0)));\\n \\tvec4 a = texture2D(sound, vec2(x, 240. * y));\\n\\treturn a.a;\\n\\t//return blend;\\t\\n\\t//return sin(blend * 20. + time * -5.) * .5 + .5;\\n}\\n\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 100.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n float maxPoints = vertexCount;\\n \\n \\n float subdivisionRows = floor(sqrt(vertexCount / 20. / 3.));\\n //subdivisionRows = 2.;\\n float trianglesPerFace = subdivisionRows * subdivisionRows;\\n maxPoints = trianglesPerFace * 3. * 20.;\\n float i = min(vertexId, maxPoints);\\n float faceIndex = floor(i / (trianglesPerFace * 3.));\\n \\n //faceIndex = 0.;\\n \\n Tri tri = Tri(\\n \\ticosahedronFaceVertex(faceIndex * 3. + 0.),\\n icosahedronFaceVertex(faceIndex * 3. + 1.),\\n icosahedronFaceVertex(faceIndex * 3. + 2.)\\n );\\n \\n i = mod(i, trianglesPerFace * 3.);\\n GeoPoints geo = geoPoints(tri, subdivisionRows, i);\\n pos = geo.vertex;\\n pos = normalize(pos);\\n\\n //pos = icosahedronFaceVertex(vertexId);\\n \\n \\n float blend2 = 0.;\\n blend2 += mb(geo, IcoVert0, 0.);\\n blend2 += mb(geo, IcoVert1, 1.);\\n blend2 += mb(geo, IcoVert4, 2.);\\n blend2 += mb(geo, IcoVert5, 3.);\\n blend2 += mb(geo, IcoVert8, 4.);\\n blend2 += mb(geo, IcoVert9, 5.);\\n \\n blend2 /= 5.;\\n \\n float blend = blend2;\\n //blend = pow(blend, (sin(time * 5.) * .5 + .5) * 10.);\\n //blend = blend2 * 5. - 10.;\\n \\n pos *= mix(.5, .8, blend);\\n \\n float tm = time * .5;\\n tm = 8.;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(\\n cos(tm) * rd,\\n cos(tm) * rd,\\n sin(tm) * rd\\n );\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n vec4 pos4 = mat * vec4(pos, 1);\\n //pos4 = vec4(pos, 1.);\\n \\n \\n gl_Position = pos4;\\n gl_PointSize = 4.;\\n\\n vec3 col = vec3(spectrum(vertexId / maxPoints));\\n //col = vec3(.5);\\n col *= smoothstep(rd*3., rd, pos4.z);\\n col += pow((dot(normalize(pos4.xyz), vec3(.5,-.5,0))) * 2., 2.);\\n \\n col = spectrum(blend);\\n \\n v_color = vec4(col, 1.);\\n \\n \\n}\"}", + "settings": { + "num": 12093, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chahinesounds/kirby-chahine", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// --------------------------------------------------------\n// Spectrum colour palette\n// IQ https://www.shadertoy.com/view/ll2GD3\n// --------------------------------------------------------\n\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\n return a + b*cos( 6.28318*(c*t+d) );\n}\n\nvec3 spectrum(float n) {\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\n}\n\n\n// --------------------------------------------------------\n// Camera and display\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\n// --------------------------------------------------------\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nstruct Tri {\n vec3 a;\n vec3 b;\n vec3 c;\n};\n \nvec3 bToC(Tri tri, float a, float b, float c) {\n return a * tri.a + b * tri.b + c * tri.c;\n}\n\nvec3 bToC(Tri tri, vec3 bary) {\n return bary.x * tri.a + bary.y * tri.b + bary.z * tri.c;\n}\n\n\nfloat calcTriRow(float n) {\n return floor( (1. + sqrt(1. + 8. * n)) / 2. ) - 1.;\n}\n\n\nvec3 triVertex(Tri tri, float row, float column, float rows, float index, float doSecondPass) {\n float doFirstPass = 1. - doSecondPass;\n \n // First pass offsets\n row += min(index, 1.) * doFirstPass;\n column += max(index - 1., 0.) * doFirstPass;\n\n // Second pass offsets\n row += max(index, 1.) * doSecondPass;\n column += min(index, 1.) * doSecondPass;\n\n // Cartesian coordinates for column/row\n float mixA = row / rows;\n float mixB = column / max(row, 1.);\n vec3 vertex = mix(tri.a, mix(tri.b, tri.c, mixB), mixA);\n return vertex;\n}\n\nvec3 pick(vec3 a, vec3 b, vec3 c, float index) {\n\treturn mix(mix(a, b, index), c, max(index - 1., 0.));\n}\n\n\nstruct GeoPoints {\n\tvec3 vertex;\n \tvec3 center;\n};\n \n\n// Find vertex and center in triangle with n subdivision rows at index\nGeoPoints geoPoints(Tri tri, float rows, float i) {\n float firstPass = (rows - 1.) * (rows + 2.) / 2. + 1.;\n \n // Sub-tringle vertex index\n float id = mod(i, 3.);\n \n //firstPass = 56.;\n \n // Repeat whole triangle\n ///i = mod(i, rows * rows* 3.);\n \n // Sub-triangle index\n i = floor(i / 3.);\n \n \n // First pass is upwards pointing triangles,\n // second pass fills in the gaps\n float doSecondPass = max(0., sign(i - firstPass + 1.));\n \n i -= firstPass * doSecondPass;\n \n float row = calcTriRow(i);\n float startOfRow = row * (row + 1.) / 2.;\n float column = mod(i - startOfRow, row + 1.);\n\n \n vec3 vertexA = triVertex(tri, row, column, rows, 0., doSecondPass); \n vec3 vertexB = triVertex(tri, row, column, rows, 1., doSecondPass); \n vec3 vertexC = triVertex(tri, row, column, rows, 2., doSecondPass); \n \n vec3 vertex = pick(vertexA, vertexB, vertexC, id);\n vec3 center = (vertexA + vertexB + vertexC) / 3.;\n \n return GeoPoints(vertex, center);\n}\n\n#define PHI (1.618033988749895)\n // PHI (sqrt(5)*0.5 + 0.5)\n\n\n#define IcoVert0 normalize(vec3(0, PHI, 1))\n#define IcoVert1 normalize(vec3(0, PHI, -1))\n#define IcoVert2 normalize(vec3(0, -PHI, 1))\n#define IcoVert3 normalize(vec3(0, -PHI, -1))\n#define IcoVert4 normalize(vec3(1, 0, PHI))\n#define IcoVert5 normalize(vec3(1, 0, -PHI))\n#define IcoVert6 normalize(vec3(-1, 0, PHI))\n#define IcoVert7 normalize(vec3(-1, 0, -PHI))\n#define IcoVert8 normalize(vec3(PHI, 1, 0))\n#define IcoVert9 normalize(vec3(PHI, -1, 0))\n#define IcoVert10 normalize(vec3(-PHI, 1, 0))\n#define IcoVert11 normalize(vec3(-PHI, -1, 0))\n\nfloat beat(float i, float loop) {\n\treturn 1. - min(mod(i, loop), 1.);\n} \n\nfloat signbeat(float i, float loop) {\n\treturn beat(i, loop) * 2. - 1.;\n}\n\n\nvec3 shift(vec3 v, float offset) {\n\toffset = mod(offset, 3.);\n \tif (offset == 0.) {\n return v.xyz;\n \t}\n \tif (offset == 1.) {\n return v.zxy;\n \t}\n \tif (offset == 2.) {\n return v.yzx;\n \t}\n}\n\nfloat round(float a) {\n\treturn floor(a + .5);\n}\n\n// Step through each vertex of each icosahedron face\nvec3 icosahedronFaceVertex(float i) {\n \n float stage, stageIndexOffset, stageLength;\n float a, a0, a1, a2, b, b0, b1, b2, offset, offset0, offset1,offset2;\n \n stage = round( log2( floor(i / 6.) + 2.) - 1.);\n stageIndexOffset = 6. * (stage * stage);\n i -= stageIndexOffset;\n stageLength = 3. * (stage + 1.) * (stage + 2.);\n \n float floatFudge = .01; // Fixes rounding issue on OS X\n float invert = floor(i / stageLength * (2. + floatFudge)) * 2. - 1.;\n \n // Stage 0\n a0 = invert;\n b0 = invert;\n offset0 = mod(i, 3.);\n \n // Stage 1\n a1 = invert;\n b1 = signbeat(i, 3.) * -1. * invert;\n offset1 = mod(floor(i / 3.) - beat(i - 2., 3.), 3.);\n\n // Stage 2\n a2 = b1;\n b2 = signbeat(i - 2., 3.) * -1. * invert;\n offset2 = mod(floor(i / 6.) + (1. - beat(i, 3.)) + beat(i - 5., 6.), 3.);\n \n // Pick stage to show\n float blend1 = stage;\n float blend2 = max(0., stage - 1.);\n a = mix(mix(a0, a1, blend1), a2, blend2);\n b = mix(mix(b0, b1, blend1), b2, blend2);\n offset = mix(mix(offset0, offset1, blend1), offset2, blend2);\n\n vec3 icoVert = normalize(vec3(PHI, 1, 0));\n icoVert *= vec3(a, b, 1.);\n icoVert = shift(icoVert, offset); \n //icoVert = normalize(icoVert);\n return icoVert;\n}\n\n\nfloat mb(GeoPoints geo, vec3 origin, float index) {\n \tvec3 o2 = vec3(1,0,0);\n \t//origin = vec3(0,1,0);\n \tvec3 pos = mix(geo.center, geo.vertex, sin(time) * .5 + .5);\n\t\n \tfloat blendVertex = abs(dot(geo.vertex, origin));\t\n\tfloat blendCenter = abs(dot(geo.center, origin));\t\n\t\n \tfloat b1 = sin(blendVertex * 20. + time) * .5 + .5;\n \tfloat b2 = sin(blendCenter * 10. + time*-2.) * .5 + .5;\n \n \treturn b1 + b2 * (sin(time * .5) * .5 + .5) * 1.2;\n \n \tfloat x = abs(dot(pos, vec3(0,1,0)));\n \tfloat y = abs(dot(pos, vec3(1,0,0)));\n \tvec4 a = texture2D(sound, vec2(x, 240. * y));\n\treturn a.a;\n\t//return blend;\t\n\t//return sin(blend * 20. + time * -5.) * .5 + .5;\n}\n\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 100.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n float maxPoints = vertexCount;\n \n \n float subdivisionRows = floor(sqrt(vertexCount / 20. / 3.));\n //subdivisionRows = 2.;\n float trianglesPerFace = subdivisionRows * subdivisionRows;\n maxPoints = trianglesPerFace * 3. * 20.;\n float i = min(vertexId, maxPoints);\n float faceIndex = floor(i / (trianglesPerFace * 3.));\n \n //faceIndex = 0.;\n \n Tri tri = Tri(\n \ticosahedronFaceVertex(faceIndex * 3. + 0.),\n icosahedronFaceVertex(faceIndex * 3. + 1.),\n icosahedronFaceVertex(faceIndex * 3. + 2.)\n );\n \n i = mod(i, trianglesPerFace * 3.);\n GeoPoints geo = geoPoints(tri, subdivisionRows, i);\n pos = geo.vertex;\n pos = normalize(pos);\n\n //pos = icosahedronFaceVertex(vertexId);\n \n \n float blend2 = 0.;\n blend2 += mb(geo, IcoVert0, 0.);\n blend2 += mb(geo, IcoVert1, 1.);\n blend2 += mb(geo, IcoVert4, 2.);\n blend2 += mb(geo, IcoVert5, 3.);\n blend2 += mb(geo, IcoVert8, 4.);\n blend2 += mb(geo, IcoVert9, 5.);\n \n blend2 /= 5.;\n \n float blend = blend2;\n //blend = pow(blend, (sin(time * 5.) * .5 + .5) * 10.);\n //blend = blend2 * 5. - 10.;\n \n pos *= mix(.5, .8, blend);\n \n float tm = time * .5;\n tm = 8.;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(\n cos(tm) * rd,\n cos(tm) * rd,\n sin(tm) * rd\n );\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n vec4 pos4 = mat * vec4(pos, 1);\n //pos4 = vec4(pos, 1.);\n \n \n gl_Position = pos4;\n gl_PointSize = 4.;\n\n vec3 col = vec3(spectrum(vertexId / maxPoints));\n //col = vec3(.5);\n col *= smoothstep(rd*3., rd, pos4.z);\n col += pow((dot(normalize(pos4.xyz), vec3(.5,-.5,0))) * 2., 2.);\n \n col = spectrum(blend);\n \n v_color = vec4(col, 1.);\n \n \n}" + }, "screenshotURL": "data/images/images-9dxn7oklyspslz893-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MdL5GN8abavG8YvBs/art.json b/art/MdL5GN8abavG8YvBs/art.json index f81a83bb..387a9fef 100644 --- a/art/MdL5GN8abavG8YvBs/art.json +++ b/art/MdL5GN8abavG8YvBs/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "juhye", "avatarUrl": "https://lh5.googleusercontent.com/-WIjF1SYiutc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfjC8iee2cn7usm3MsiloBz79O9-Q/mo/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t: Joohye Son\\nAssignment Name/Number\\t: Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n\\n \\ngl_Position=vec4(sin(time)*mouse.x, cos(time)*mouse.y*cos(vertexId), 0, 1);\\n gl_PointSize=20.;\\n v_color=vec4(sin(time), cos(time), tan(time), 1);\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t: Joohye Son\nAssignment Name/Number\t: Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n\n \ngl_Position=vec4(sin(time)*mouse.x, cos(time)*mouse.y*cos(vertexId), 0, 1);\n gl_PointSize=20.;\n v_color=vec4(sin(time), cos(time), tan(time), 1);\n \n}" + }, "screenshotURL": "data/images/images-jns6at1yydbn1nzik-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Mdfu3bDECkPeKcnKH/art.json b/art/Mdfu3bDECkPeKcnKH/art.json index fa8d9f6b..77fe562c 100644 --- a/art/Mdfu3bDECkPeKcnKH/art.json +++ b/art/Mdfu3bDECkPeKcnKH/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "ivan", "avatarUrl": "https://lh6.googleusercontent.com/-DfySwQJhPmU/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-gqZceMeW-XdcpSRy_BvwsdgkoQIQ/mo/photo.jpg", - "settings": "{\"num\":3,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.35294117647058826,0.6,1],\"shader\":\"void main() {\\n gl_PointSize = 3.0;\\n \\n vec2 xy = vec2(-0.5, 0);\\n \\n if (vertexId == 1.0)\\n xy = vec2(0, 0.5);\\n else if (vertexId == 2.0)\\n xy = vec2(0.5, 0);\\n \\n xy += vec2(0, sin(time));\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n v_color = vec4(0.65, 0.8, 0.4, 1);\\n}\"}", + "settings": { + "num": 3, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.35294117647058826, + 0.6, + 1 + ], + "shader": "void main() {\n gl_PointSize = 3.0;\n \n vec2 xy = vec2(-0.5, 0);\n \n if (vertexId == 1.0)\n xy = vec2(0, 0.5);\n else if (vertexId == 2.0)\n xy = vec2(0.5, 0);\n \n xy += vec2(0, sin(time));\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n v_color = vec4(0.65, 0.8, 0.4, 1);\n}" + }, "screenshotURL": "data/images/images-e3d8ag654na2gh90l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MdhYtpNnJFJv3jXmY/art.json b/art/MdhYtpNnJFJv3jXmY/art.json index 6f8d92e2..4c84aa6f 100644 --- a/art/MdhYtpNnJFJv3jXmY/art.json +++ b/art/MdhYtpNnJFJv3jXmY/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "danyalillo", "avatarUrl": "https://lh5.googleusercontent.com/-AubKP6RsE4s/AAAAAAAAAAI/AAAAAAAAABI/DdOK5vvzKn0/photo.jpg", - "settings": "{\"num\":10,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n //float width = 10.0;\\n \\n float x = floor(vertexId / 3.0);\\n float y = floor(vertexId / 3.0);\\n \\n if(mod(vertexId, 2.0) == 0.0){\\n x = (floor(vertexId / 2.0)) / 3.0;\\n y = floor( 1.0 / 3.0);\\n }\\n else\\n {\\n x = (floor((vertexId - 1.0) / 2.0)) / 3.0;\\n y = floor( 1.0 / 3.0);\\n }\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n \\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 10, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n //float width = 10.0;\n \n float x = floor(vertexId / 3.0);\n float y = floor(vertexId / 3.0);\n \n if(mod(vertexId, 2.0) == 0.0){\n x = (floor(vertexId / 2.0)) / 3.0;\n y = floor( 1.0 / 3.0);\n }\n else\n {\n x = (floor((vertexId - 1.0) / 2.0)) / 3.0;\n y = floor( 1.0 / 3.0);\n }\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n \n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-u5xh5jviptvumhdy3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MefAhfbtS5ZbYifPi/art.json b/art/MefAhfbtS5ZbYifPi/art.json index ee93fdb7..2fd4265b 100644 --- a/art/MefAhfbtS5ZbYifPi/art.json +++ b/art/MefAhfbtS5ZbYifPi/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cristianvarela/ken-ishii-play-biting-cristian\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21176470588235294,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 30.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.5, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n //vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n //vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = getRandomCubePoint(fCubeId * 0.177);\\n vec3 ax = (rotZ(PI * 0.25) * rotY(PI * 0.25) * vec4(vCubeOrigin, 1)).xyz;\\n vCubeOrigin += (vec3(hash(fCubeId * 0.317), hash(fCubeId * 0.591), hash(fCubeId * 0.781)) * 2. - 1.) * 0.01;\\n //vCubeOrigin += sign(vCubeOrigin);\\n vCubeOrigin *= 20.0;\\n \\n float ps = p1m1(atan(ax.y, ax.z) / PI);\\n float snd = texture2D(sound, vec2(mix(0.006, 0.019, ps), p1m1(ax.x / 1.4142) * 0.5)).a;\\n float beat = 0.;texture2D(sound, vec2(0.007, 0)).a;\\n \\n vCubeOrigin += normalize(vec3(PI * 0.25, PI * .25, 0)) * snd * -8.;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin + sign(normalize(vCubeOrigin)) * pow(snd, 5.) * -0.);\\n mat *= rotZ(p1m1(snd) * 20.);\\n mat *= rotY(p1m1(snd) * 20.);\\n mat *= uniformScale(mix(1.5, 1.5, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n 0.3, //st,//pow(snd, 0.), \\n pow(snd, 5.)));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(mix(0.9, 0.55, ps), snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( sin(time * 0.13) * -20., -20., sin(time * 0.13) * -20.0 );\\n \\tvec3 vCameraPos = vec3(5) + vec3(sin(time * 0.1) * 7., sin(time * 0.17) * 7., cos(time * 0.1) * 7.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(90.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cristianvarela/ken-ishii-play-biting-cristian", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 30.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.5, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n //vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n //vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = getRandomCubePoint(fCubeId * 0.177);\n vec3 ax = (rotZ(PI * 0.25) * rotY(PI * 0.25) * vec4(vCubeOrigin, 1)).xyz;\n vCubeOrigin += (vec3(hash(fCubeId * 0.317), hash(fCubeId * 0.591), hash(fCubeId * 0.781)) * 2. - 1.) * 0.01;\n //vCubeOrigin += sign(vCubeOrigin);\n vCubeOrigin *= 20.0;\n \n float ps = p1m1(atan(ax.y, ax.z) / PI);\n float snd = texture2D(sound, vec2(mix(0.006, 0.019, ps), p1m1(ax.x / 1.4142) * 0.5)).a;\n float beat = 0.;texture2D(sound, vec2(0.007, 0)).a;\n \n vCubeOrigin += normalize(vec3(PI * 0.25, PI * .25, 0)) * snd * -8.;\n \n mat = ident();\n mat *= trans(vCubeOrigin + sign(normalize(vCubeOrigin)) * pow(snd, 5.) * -0.);\n mat *= rotZ(p1m1(snd) * 20.);\n mat *= rotY(p1m1(snd) * 20.);\n mat *= uniformScale(mix(1.5, 1.5, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n 0.3, //st,//pow(snd, 0.), \n pow(snd, 5.)));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(mix(0.9, 0.55, ps), snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( sin(time * 0.13) * -20., -20., sin(time * 0.13) * -20.0 );\n \tvec3 vCameraPos = vec3(5) + vec3(sin(time * 0.1) * 7., sin(time * 0.17) * 7., cos(time * 0.1) * 7.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(90.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-pkr1n4bwl2aprmizg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MegMNJwR7hpTYFf2G/art.json b/art/MegMNJwR7hpTYFf2G/art.json index 81ec9808..b44c2760 100644 --- a/art/MegMNJwR7hpTYFf2G/art.json +++ b/art/MegMNJwR7hpTYFf2G/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 77.//KParameter0 0.>>1000.\\n#define KP1 11.//KParameter1 0.0>>22.\\n#define KP2 1.0//KParameter2 0.0>>10.\\n#define KP3 0.20//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>5.\\n#define KP5 1000.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=338000\\n#define PI radians(180. -KP0)\\n\\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 9.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 77.//KParameter0 0.>>1000.\n#define KP1 11.//KParameter1 0.0>>22.\n#define KP2 1.0//KParameter2 0.0>>10.\n#define KP3 0.20//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>5.\n#define KP5 1000.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=338000\n#define PI radians(180. -KP0)\n\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 9.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-4cql116znfu09o6gm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MfHtgKgYcLYo4gHrB/art.json b/art/MfHtgKgYcLYo4gHrB/art.json index 7f24e96b..e10f6bfe 100644 --- a/art/MfHtgKgYcLYo4gHrB/art.json +++ b/art/MfHtgKgYcLYo4gHrB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jimhanks", "avatarUrl": "https://secure.gravatar.com/avatar/2bf167068c2de88c2a8119b5403a900b?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/florandfaun/alone\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return (sin(t) * 8. + sin(t * 0.27) * 4. + sin(t * 0.13) * 2. + sin(t * 0.73)) / 15.0;\\n}\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (3.0 - 2.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + 1.0);\\n\\n vec4 o1 = fract(k3 * (1.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (1.0 - d.y);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\n#define POINTS_PER_LINE 6.\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float pointId = mod(vertexId, POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n vec2 uv = vec2(\\n pointId / POINTS_PER_LINE, \\n lineId / numLines);\\n\\n float ang = uv.x * PI * 2. + uv.y * mix(10., 100., sin(time * 0.1));\\n vec3 pos = vec3(\\n cos(ang),\\n sin(ang),\\n uv.y * 10.\\n );\\n \\n vec3 eye = vec3(0, 0, 0.0);\\n vec3 target = vec3(0, 0.5, 1);\\n vec3 up = vec3(0, 1, 0.);\\n \\n float sa = abs(atan(uv.x, uv.y) / PI);\\n float snd = texture2D(sound, vec2(0.02, mix(1.0, 0.0, uv.y))).a;\\n \\n pos.xy *= mix(1., 3.2, pow(snd, 5.));\\n float tm = time*0.2- uv.y * 15.;\\n pos.xy += vec2(sin(tm), cos(tm * 1.11)) * -0.2;\\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = persp(radians(140.), 1., 0.1, 200.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= scale(vec3(0.5, 0.09, 1));\\n //mat *= trans(vec3(0.,.0,-0.4));\\n gl_Position = mat * vec4(pos, 1);\\n float clipZ = gl_Position.z / gl_Position.w;\\n gl_PointSize = mix(0.7, 50., pow(1. - uv.y, 50.));\\n gl_PointSize *= resolution.x / 1400.;\\n\\n float hue = pos.z* 0.02 + time * 0.01;\\n float sat = 0.4;\\n float val = 1.;\\n float alp = noise(pos * 3. + time *0.1 * vec3(.7,0.3,5.));//clamp(goop(uv.x * 20. + time) + goop(uv.y * 20.123 + time), 0., 1.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alp);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/florandfaun/alone", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return (sin(t) * 8. + sin(t * 0.27) * 4. + sin(t * 0.13) * 2. + sin(t * 0.73)) / 15.0;\n}\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (3.0 - 2.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + 1.0);\n\n vec4 o1 = fract(k3 * (1.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (1.0 - d.y);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\n#define POINTS_PER_LINE 6.\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float pointId = mod(vertexId, POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n vec2 uv = vec2(\n pointId / POINTS_PER_LINE, \n lineId / numLines);\n\n float ang = uv.x * PI * 2. + uv.y * mix(10., 100., sin(time * 0.1));\n vec3 pos = vec3(\n cos(ang),\n sin(ang),\n uv.y * 10.\n );\n \n vec3 eye = vec3(0, 0, 0.0);\n vec3 target = vec3(0, 0.5, 1);\n vec3 up = vec3(0, 1, 0.);\n \n float sa = abs(atan(uv.x, uv.y) / PI);\n float snd = texture2D(sound, vec2(0.02, mix(1.0, 0.0, uv.y))).a;\n \n pos.xy *= mix(1., 3.2, pow(snd, 5.));\n float tm = time*0.2- uv.y * 15.;\n pos.xy += vec2(sin(tm), cos(tm * 1.11)) * -0.2;\n float aspect = resolution.x / resolution.y;\n \n mat4 mat = persp(radians(140.), 1., 0.1, 200.); \n mat *= cameraLookAt(eye, target, up);\n mat *= scale(vec3(0.5, 0.09, 1));\n //mat *= trans(vec3(0.,.0,-0.4));\n gl_Position = mat * vec4(pos, 1);\n float clipZ = gl_Position.z / gl_Position.w;\n gl_PointSize = mix(0.7, 50., pow(1. - uv.y, 50.));\n gl_PointSize *= resolution.x / 1400.;\n\n float hue = pos.z* 0.02 + time * 0.01;\n float sat = 0.4;\n float val = 1.;\n float alp = noise(pos * 3. + time *0.1 * vec3(.7,0.3,5.));//clamp(goop(uv.x * 20. + time) + goop(uv.y * 20.123 + time), 0., 1.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alp);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-le9jph5y2mi3w3yvt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MfQT7AKEmWF7Q35TS/art.json b/art/MfQT7AKEmWF7Q35TS/art.json index e5799e5a..3eaa6b59 100644 --- a/art/MfQT7AKEmWF7Q35TS/art.json +++ b/art/MfQT7AKEmWF7Q35TS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-70gp5rwnnp6jd7bx7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Mfirr9f2pxxX9ieik/art.json b/art/Mfirr9f2pxxX9ieik/art.json index 85505b4a..b454e3c0 100644 --- a/art/Mfirr9f2pxxX9ieik/art.json +++ b/art/Mfirr9f2pxxX9ieik/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "航", "avatarUrl": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-6tla8yclljzevqjxu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MgC43FZpWMJiPkiAD/art.json b/art/MgC43FZpWMJiPkiAD/art.json index 7793e03a..8d0f08ab 100644 --- a/art/MgC43FZpWMJiPkiAD/art.json +++ b/art/MgC43FZpWMJiPkiAD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0, 0, 0, 1);\\n v_color = vec4(1, 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0, 0, 0, 1);\n v_color = vec4(1, 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-cqhncfbu57hin3bb5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MgCFmyZHQF4Xy4EsJ/art.json b/art/MgCFmyZHQF4Xy4EsJ/art.json index 0b2e812f..2b838d0a 100644 --- a/art/MgCFmyZHQF4Xy4EsJ/art.json +++ b/art/MgCFmyZHQF4Xy4EsJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 100.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 100.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-u66iretvmzye5qjmd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MgTTiHeeh58AxqR7D/art.json b/art/MgTTiHeeh58AxqR7D/art.json index d1a96e35..da4f6c25 100644 --- a/art/MgTTiHeeh58AxqR7D/art.json +++ b/art/MgTTiHeeh58AxqR7D/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "feathj", "avatarUrl": "https://secure.gravatar.com/avatar/7cb271d20d843ec2bb42e83f693a2a6a?default=retro&size=200", - "settings": "{\"num\":2533,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.2) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.5;\\n \\n float soff = sin(time + x * y) * 5.0;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 2533, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.2) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.5;\n \n float soff = sin(time + x * y) * 5.0;\n \n gl_Position = vec4(xy, 0, 1);\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-etywjt6pkuwmomsju-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MgkDcnH4JMLmrHeHs/art.json b/art/MgkDcnH4JMLmrHeHs/art.json index 9fec4d16..97741fc6 100644 --- a/art/MgkDcnH4JMLmrHeHs/art.json +++ b/art/MgkDcnH4JMLmrHeHs/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kaleidocollective/9duskus-bear\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float s = 0.;//texture2D(sound, vec2(fract(p.x * 0.01), fract(p.y * .1))).a;\\n return pow(s, 5.) * 0.3;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = (vec3(ux, 0, vy) + off) * scale; \\n pos.y += fbm(pos.xz) * 2.;\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float down = floor(sqrt(numQuads));\\n float across = floor(numQuads / down);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraTarget = vec3(0, 0, 3);\\n vec3 cameraUp = vec3(0, 1, 0);\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float snd = texture2D(sound, vec2(p1m1(gl_Position.x) * 0.1 * 0.25, gl_Position.z * 0.1)).a;\\n float hue = snd;//time * 0.01 + qu * 0.2;//1.;m1p1(n.z);\\n float sat = .3;abs(n.z);\\n float val = mix(0.5, 1., l);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n //v_color = vec4(n * 0.5 + 0.5, 1);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kaleidocollective/9duskus-bear", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float s = 0.;//texture2D(sound, vec2(fract(p.x * 0.01), fract(p.y * .1))).a;\n return pow(s, 5.) * 0.3;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = (vec3(ux, 0, vy) + off) * scale; \n pos.y += fbm(pos.xz) * 2.;\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float down = floor(sqrt(numQuads));\n float across = floor(numQuads / down);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraTarget = vec3(0, 0, 3);\n vec3 cameraUp = vec3(0, 1, 0);\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float snd = texture2D(sound, vec2(p1m1(gl_Position.x) * 0.1 * 0.25, gl_Position.z * 0.1)).a;\n float hue = snd;//time * 0.01 + qu * 0.2;//1.;m1p1(n.z);\n float sat = .3;abs(n.z);\n float val = mix(0.5, 1., l);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n //v_color = vec4(n * 0.5 + 0.5, 1);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-3r19kv32cyt9qgm7u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MjsCC6T8BoLYtnpKv/art.json b/art/MjsCC6T8BoLYtnpKv/art.json index ad587853..ffd74efb 100644 --- a/art/MjsCC6T8BoLYtnpKv/art.json +++ b/art/MjsCC6T8BoLYtnpKv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":2242,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){gl_Position=vec4(vertexId/vertexCount*7.461-6.,cos(mod(vertexId/time,3.)-vertexId+time),0,1);v_color=vec4(0,1,0,1)}\"}", + "settings": { + "num": 2242, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){gl_Position=vec4(vertexId/vertexCount*7.461-6.,cos(mod(vertexId/time,3.)-vertexId+time),0,1);v_color=vec4(0,1,0,1)}" + }, "screenshotURL": "data/images/images-uijlp4766agb6m5pa-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MkAt4QQ3RgdpxBAtb/art.json b/art/MkAt4QQ3RgdpxBAtb/art.json index 3f95a0a3..c99c9090 100644 --- a/art/MkAt4QQ3RgdpxBAtb/art.json +++ b/art/MkAt4QQ3RgdpxBAtb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "megaloler", "avatarUrl": "https://avatars.githubusercontent.com/MegaLoler?s=200", - "settings": "{\"num\":85351,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/kayfaraday/naiadess-botb-ohb-no-3768\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nfloat rand(float n) {\\n return fract(sin(n) * 1473.5453123 + cos(n*0.9635) * 647.473261);\\n}\\n\\nvec2 rect(float i) {\\n float a = i * 4.;\\n float s = floor(a);\\n float si = mod(a, 1.) * 2. - 1.;\\n vec2 side;\\n if(s == 0.) side = vec2(si, -1.);\\n else if(s == 1.) side = vec2(1., si);\\n else if(s == 2.) side = vec2(-si, 1.);\\n else if(s == 3.) side = vec2(-1., -si);\\n return side;\\n}\\n\\nvec2 diamond(float i) {\\n float a = i * 4.;\\n float s = floor(a);\\n float si = mod(a, 1.);\\n float comsi = 1.0 - si;\\n vec2 side;\\n if(s == 0.) side = vec2(si, comsi);\\n else if(s == 1.) side = vec2(-comsi, si);\\n else if(s == 2.) side = vec2(-si, -comsi);\\n else if(s == 3.) side = vec2(comsi, -si);\\n return side;\\n}\\n\\nvec2 circle(float i) {\\n return vec2(cos(i * TAU), sin(i * TAU));\\n}\\n\\nvoid main() {\\n float shapeCount = 3.;\\n float i = vertexId / vertexCount * shapeCount;\\n int shapeId = int(floor(i));\\n float shape_i = fract(i);\\n vec2 pos;\\n \\n float seed = vertexId + time;\\n float u_noise = rand(seed);\\n float v_noise = rand(seed+1.);\\n float snd = texture2D(sound, vec2(shape_i / 1.33, shape_i)).a;\\n float noiseAmp = (cos(time) / 2. + 0.5) * 0.8;\\n float curve = pow(log(v_noise), sin(time)+1.);\\n float noiseLevel = curve * snd;\\n vec2 fudge = circle(u_noise) * noiseLevel * noiseAmp;\\n \\n float col = mix(1., 0.8, noiseLevel);\\n float col2 = mix(0.9, 0.5, log(noiseLevel));\\n \\n if(shapeId == 0) {\\n pos = circle(shape_i) * 0.5;\\n v_color = vec4(col, col2, col2 / 2., 0);\\n } else if (shapeId == 1) {\\n pos = rect(shape_i) * 0.5;\\n v_color = vec4(col2 / 2., col, col2, 0);\\n } else if (shapeId == 2) {\\n pos = diamond(shape_i) * 0.25;\\n v_color = vec4(col2, col, col2 / 2., 0);\\n }\\n gl_PointSize = 1.;\\n float aspect = resolution.y / resolution.x;\\n mat4 perspective = mat4(aspect, 0., 0., 0.,\\n 0., 1., 0., 0.,\\n 0., 0., 1., 0.,\\n 0., 0., 0., 1.);\\n gl_Position = perspective * vec4(fudge + pos, noiseLevel, 1.);\\n}\"}", + "settings": { + "num": 85351, + "mode": "POINTS", + "sound": "https://soundcloud.com/kayfaraday/naiadess-botb-ohb-no-3768", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nfloat rand(float n) {\n return fract(sin(n) * 1473.5453123 + cos(n*0.9635) * 647.473261);\n}\n\nvec2 rect(float i) {\n float a = i * 4.;\n float s = floor(a);\n float si = mod(a, 1.) * 2. - 1.;\n vec2 side;\n if(s == 0.) side = vec2(si, -1.);\n else if(s == 1.) side = vec2(1., si);\n else if(s == 2.) side = vec2(-si, 1.);\n else if(s == 3.) side = vec2(-1., -si);\n return side;\n}\n\nvec2 diamond(float i) {\n float a = i * 4.;\n float s = floor(a);\n float si = mod(a, 1.);\n float comsi = 1.0 - si;\n vec2 side;\n if(s == 0.) side = vec2(si, comsi);\n else if(s == 1.) side = vec2(-comsi, si);\n else if(s == 2.) side = vec2(-si, -comsi);\n else if(s == 3.) side = vec2(comsi, -si);\n return side;\n}\n\nvec2 circle(float i) {\n return vec2(cos(i * TAU), sin(i * TAU));\n}\n\nvoid main() {\n float shapeCount = 3.;\n float i = vertexId / vertexCount * shapeCount;\n int shapeId = int(floor(i));\n float shape_i = fract(i);\n vec2 pos;\n \n float seed = vertexId + time;\n float u_noise = rand(seed);\n float v_noise = rand(seed+1.);\n float snd = texture2D(sound, vec2(shape_i / 1.33, shape_i)).a;\n float noiseAmp = (cos(time) / 2. + 0.5) * 0.8;\n float curve = pow(log(v_noise), sin(time)+1.);\n float noiseLevel = curve * snd;\n vec2 fudge = circle(u_noise) * noiseLevel * noiseAmp;\n \n float col = mix(1., 0.8, noiseLevel);\n float col2 = mix(0.9, 0.5, log(noiseLevel));\n \n if(shapeId == 0) {\n pos = circle(shape_i) * 0.5;\n v_color = vec4(col, col2, col2 / 2., 0);\n } else if (shapeId == 1) {\n pos = rect(shape_i) * 0.5;\n v_color = vec4(col2 / 2., col, col2, 0);\n } else if (shapeId == 2) {\n pos = diamond(shape_i) * 0.25;\n v_color = vec4(col2, col, col2 / 2., 0);\n }\n gl_PointSize = 1.;\n float aspect = resolution.y / resolution.x;\n mat4 perspective = mat4(aspect, 0., 0., 0.,\n 0., 1., 0., 0.,\n 0., 0., 1., 0.,\n 0., 0., 0., 1.);\n gl_Position = perspective * vec4(fudge + pos, noiseLevel, 1.);\n}" + }, "screenshotURL": "data/images/images-p4jgj50t04pzggs4z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Mm6CKQSnDcsLCorEL/art.json b/art/Mm6CKQSnDcsLCorEL/art.json index e70ec0e8..0eb19327 100644 --- a/art/Mm6CKQSnDcsLCorEL/art.json +++ b/art/Mm6CKQSnDcsLCorEL/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "ultr7a", "avatarUrl": "https://avatars.githubusercontent.com/ultr7A?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/itsdrdonk/be-my-lover-dr-donk-edit\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n s * cos(s + time / 3.0) / 16.0, s * -sin(s+time / 2.0) / 16.0, 1, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.015 + 0.0125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. + soundTexCoords0.x) + 0.1;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle * beatwave / sy) * radius / sy * 0.95;\\n float y = sin(angle * beatwave / sx) * radius / sx * 0.95;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale(1. / 11.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 5.) * 0.5 + 0.5);\\n v_color = vec4(1, g + 0.2, 1.0-r, 1);\\n \\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/itsdrdonk/be-my-lover-dr-donk-edit", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n s * cos(s + time / 3.0) / 16.0, s * -sin(s+time / 2.0) / 16.0, 1, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.015 + 0.0125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. + soundTexCoords0.x) + 0.1;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle * beatwave / sy) * radius / sy * 0.95;\n float y = sin(angle * beatwave / sx) * radius / sx * 0.95;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale(1. / 11.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 5.) * 0.5 + 0.5);\n v_color = vec4(1, g + 0.2, 1.0-r, 1);\n \n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-npviscy5bouiby1w6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Mn5Lhm33cELxeTJsN/art.json b/art/Mn5Lhm33cELxeTJsN/art.json index fd18d8a8..bff790c9 100644 --- a/art/Mn5Lhm33cELxeTJsN/art.json +++ b/art/Mn5Lhm33cELxeTJsN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "orange4glace", "avatarUrl": "https://avatars.githubusercontent.com/orange4glace?s=200", - "settings": "{\"num\":800,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0784313725490196,0.0784313725490196,0.0784313725490196,1],\"shader\":\"#define EXP 2.718\\n#define PI 3.1415926535897932\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n \\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nfloat spiral(float x) {\\n return pow(EXP, -0.1 * x);\\n}\\n\\nvoid main() {\\n float t = (PI * 8.) * (vertexId / vertexCount);\\n float x = 0.5 * pow(EXP, 0.15 * t) * cos(2. * t);\\n float y = 0.5 * pow(EXP, 0.15 * t) * sin(2. * t);\\n float z = 0.5 * pow(EXP, 0.15 * t);\\n vec3 pos = vec3(x, y, z) / (PI * 8.);\\n \\n float tm = time * .5;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(\\n cos(tm) * rd,\\n cos(tm) * rd,\\n sin(tm) * rd\\n );\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1.0);\\n gl_PointSize = 2.;\\n \\n float c = vertexId / vertexCount;\\n v_color = vec4(c, c, c, 1);\\n}\"}", + "settings": { + "num": 800, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.0784313725490196, + 0.0784313725490196, + 1 + ], + "shader": "#define EXP 2.718\n#define PI 3.1415926535897932\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n \n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nfloat spiral(float x) {\n return pow(EXP, -0.1 * x);\n}\n\nvoid main() {\n float t = (PI * 8.) * (vertexId / vertexCount);\n float x = 0.5 * pow(EXP, 0.15 * t) * cos(2. * t);\n float y = 0.5 * pow(EXP, 0.15 * t) * sin(2. * t);\n float z = 0.5 * pow(EXP, 0.15 * t);\n vec3 pos = vec3(x, y, z) / (PI * 8.);\n \n float tm = time * .5;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(\n cos(tm) * rd,\n cos(tm) * rd,\n sin(tm) * rd\n );\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1.0);\n gl_PointSize = 2.;\n \n float c = vertexId / vertexCount;\n v_color = vec4(c, c, c, 1);\n}" + }, "screenshotURL": "data/images/images-v1a96252rukhs1g23-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MncGu5v3jXSZbE4xh/art.json b/art/MncGu5v3jXSZbE4xh/art.json index e2c55787..436ef6b9 100644 --- a/art/MncGu5v3jXSZbE4xh/art.json +++ b/art/MncGu5v3jXSZbE4xh/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\n\\n\\nvoid main ()\\n{\\n //float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n float snd = texture2D(sound, vec2(0., 0.)).a;\\n //apply fragment logic\\n\\n\\t//vec2 position = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);\\n\\tvec2 position = vec2(x, y);\\n\\t\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n vec2 res = vec2(numAcrossDown, numAcrossDown);\\n vec2 fragCoord = vec2(u,v);\\n \\n vec3 d = normalize( vec3( (position.xy - res.xy * .5) / numAcrossDown, .15));\\n \\n\\tvec3 p, c, f, g=d, o, y1=vec3(1.0,3.0,0.0);\\n \\n \\n \\to.y = 4. + 4.8*cos((o.x=0.1)*(o.z=time * 10.0));\\n\\to.x -= sin(time) + 3.0;\\n\\n for( float i=.0; i<8.; i+=.05 ) {\\n f = fract(c = o += d*i*.1); \\n\\tp = floor( c )*.4;\\n if( cos(p.z) + sin(p.x) > ++p.y ) {\\n\\t \\tg = (f.y-.04*cos((c.x+c.z)*10.)>.7?y1:f.x*y1.yxz) / i;\\n break;\\n }\\n }\\n //gl_FragColor = vec4(g,1.0);\\n\\t\\n \\n \\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g,1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\n\n\nvoid main ()\n{\n //float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n float snd = texture2D(sound, vec2(0., 0.)).a;\n //apply fragment logic\n\n\t//vec2 position = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);\n\tvec2 position = vec2(x, y);\n\t\n gl_Position = vec4(ux, vy, 0, 1);\n \n vec2 res = vec2(numAcrossDown, numAcrossDown);\n vec2 fragCoord = vec2(u,v);\n \n vec3 d = normalize( vec3( (position.xy - res.xy * .5) / numAcrossDown, .15));\n \n\tvec3 p, c, f, g=d, o, y1=vec3(1.0,3.0,0.0);\n \n \n \to.y = 4. + 4.8*cos((o.x=0.1)*(o.z=time * 10.0));\n\to.x -= sin(time) + 3.0;\n\n for( float i=.0; i<8.; i+=.05 ) {\n f = fract(c = o += d*i*.1); \n\tp = floor( c )*.4;\n if( cos(p.z) + sin(p.x) > ++p.y ) {\n\t \tg = (f.y-.04*cos((c.x+c.z)*10.)>.7?y1:f.x*y1.yxz) / i;\n break;\n }\n }\n //gl_FragColor = vec4(g,1.0);\n\t\n \n \n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g,1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-29vjz4j00hgxtoyp3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MpkYwsT75rAGCYNQb/art.json b/art/MpkYwsT75rAGCYNQb/art.json index 2f31f75f..efe9b8c4 100644 --- a/art/MpkYwsT75rAGCYNQb/art.json +++ b/art/MpkYwsT75rAGCYNQb/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "richel", "avatarUrl": "https://graph.facebook.com/1269313776429568/picture?type=large", - "settings": "{\"num\":3894,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/industrialpope/pferdloss\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0196078431372549,0,0.058823529411764705,1],\"shader\":\"float map(float s, float a1, float a2, float b1, float b2)\\n{\\n return b1 + (s-a1)*(b2-b1)/(a2-a1);\\n}\\n\\nfloat rand(vec2 co)\\n{\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main() \\n{\\n vec2 coords;\\n \\tcoords.x = mod(vertexId, 30.0);\\n \\tcoords.y = floor(vertexId / 30.0);\\n \\n \\t\\n \\n //flag\\n if(vertexId < 600.0)\\n {\\n float u = 1.0 / 30.0 * coords.x;\\n \\tfloat v = 1.0 / 20.0 * coords.y;\\n \\n \\tfloat historyX = abs(map(u, 0.0, 1.0, -.5, 1.0) * .7);\\n \\tfloat historyV = (v *coords.y + 0.5) / soundRes.y;\\n \\n \\tfloat snd = pow(texture2D(sound, vec2(historyX, historyV)).a, 1.6);\\n\\n \\tfloat sinDingX = sin(time + coords.x * 0.2) * 0.01;\\n \\tfloat posX = -0.35 + ((0.7 / 30.0) * coords.x);\\n \\tposX += sinDingX;\\n \\n \\tfloat sinDingY = sin(time + coords.x * 0.2) * 0.1;\\n \\tfloat posY = -0.35 + (.7 / 20.0) * coords.y * (1.0 + sinDingY * 1.4);\\n \\tposY += sinDingY;\\n \\n \\tfloat posZ = 0.8;\\n \\n \\tgl_Position = vec4(posX, posY, posZ, 1);\\n\\n \\tif(coords.x > 8. && coords.x < 12. ||\\n coords.y > 8. && coords.y < 12. )\\n \\t{\\n \\tv_color = vec4(1.0, 1.0, 1.0, 1);\\n \\t}\\n \\telse\\n \\t{\\n \\tv_color = vec4(1.0, 0.0, 0.0, 1);\\n \\t}\\n \\n \\tv_color.rgb *= map(sinDingX, -0.01, 0.01, 0.3, 1.0);\\n \\n \\tgl_PointSize = snd * 20.0;\\n }\\n // starfield\\n else if(vertexId < 800.0)\\n {\\n float speed = 0.5;\\n \\n vec2 startPos = vec2(rand(vec2(vertexId + 12345., vertexId + 4312.)), rand(vec2(vertexId, vertexId)));\\n \\n float posX = -1.0 + startPos.x * 2.;\\n posX *= 0.1;\\n if(posX > 0.)\\n {\\n posX += startPos.x * time * speed;\\n posX = mod(posX, 1.0);\\n }\\n else\\n {\\n posX -= startPos.x * time;\\n posX = mod(posX, -1.0);\\n }\\n \\n float posY = -1.0 + startPos.y * 2.;\\n posY *= 0.1;\\n if(posY > 0.)\\n {\\n posY += startPos.y * time * speed;\\n posY = mod(posY, 1.0);\\n }\\n else\\n {\\n posY -= startPos.y * time;\\n posY = mod(posY, -1.0);\\n }\\n \\n float posZ = .8;\\n \\n gl_Position = vec4(posX, posY, posZ, 1.0);\\n \\n float d = sqrt( gl_Position.x * gl_Position.x + gl_Position.y * gl_Position.y);\\n \\n d = map(d, 0.0, 1.0, 0.0, 2.0);\\n if(d < 1.0)\\n {\\n posZ = 1.0;\\n }\\n else\\n {\\n posZ = 0.8;\\n }\\n \\n \\n\\n \\n gl_Position = vec4(posX, posY, posZ, 1.0);\\n gl_PointSize = pow(d, 2.0);\\n \\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n }\\n}\"}", + "settings": { + "num": 3894, + "mode": "POINTS", + "sound": "https://soundcloud.com/industrialpope/pferdloss", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0196078431372549, + 0, + 0.058823529411764705, + 1 + ], + "shader": "float map(float s, float a1, float a2, float b1, float b2)\n{\n return b1 + (s-a1)*(b2-b1)/(a2-a1);\n}\n\nfloat rand(vec2 co)\n{\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main() \n{\n vec2 coords;\n \tcoords.x = mod(vertexId, 30.0);\n \tcoords.y = floor(vertexId / 30.0);\n \n \t\n \n //flag\n if(vertexId < 600.0)\n {\n float u = 1.0 / 30.0 * coords.x;\n \tfloat v = 1.0 / 20.0 * coords.y;\n \n \tfloat historyX = abs(map(u, 0.0, 1.0, -.5, 1.0) * .7);\n \tfloat historyV = (v *coords.y + 0.5) / soundRes.y;\n \n \tfloat snd = pow(texture2D(sound, vec2(historyX, historyV)).a, 1.6);\n\n \tfloat sinDingX = sin(time + coords.x * 0.2) * 0.01;\n \tfloat posX = -0.35 + ((0.7 / 30.0) * coords.x);\n \tposX += sinDingX;\n \n \tfloat sinDingY = sin(time + coords.x * 0.2) * 0.1;\n \tfloat posY = -0.35 + (.7 / 20.0) * coords.y * (1.0 + sinDingY * 1.4);\n \tposY += sinDingY;\n \n \tfloat posZ = 0.8;\n \n \tgl_Position = vec4(posX, posY, posZ, 1);\n\n \tif(coords.x > 8. && coords.x < 12. ||\n coords.y > 8. && coords.y < 12. )\n \t{\n \tv_color = vec4(1.0, 1.0, 1.0, 1);\n \t}\n \telse\n \t{\n \tv_color = vec4(1.0, 0.0, 0.0, 1);\n \t}\n \n \tv_color.rgb *= map(sinDingX, -0.01, 0.01, 0.3, 1.0);\n \n \tgl_PointSize = snd * 20.0;\n }\n // starfield\n else if(vertexId < 800.0)\n {\n float speed = 0.5;\n \n vec2 startPos = vec2(rand(vec2(vertexId + 12345., vertexId + 4312.)), rand(vec2(vertexId, vertexId)));\n \n float posX = -1.0 + startPos.x * 2.;\n posX *= 0.1;\n if(posX > 0.)\n {\n posX += startPos.x * time * speed;\n posX = mod(posX, 1.0);\n }\n else\n {\n posX -= startPos.x * time;\n posX = mod(posX, -1.0);\n }\n \n float posY = -1.0 + startPos.y * 2.;\n posY *= 0.1;\n if(posY > 0.)\n {\n posY += startPos.y * time * speed;\n posY = mod(posY, 1.0);\n }\n else\n {\n posY -= startPos.y * time;\n posY = mod(posY, -1.0);\n }\n \n float posZ = .8;\n \n gl_Position = vec4(posX, posY, posZ, 1.0);\n \n float d = sqrt( gl_Position.x * gl_Position.x + gl_Position.y * gl_Position.y);\n \n d = map(d, 0.0, 1.0, 0.0, 2.0);\n if(d < 1.0)\n {\n posZ = 1.0;\n }\n else\n {\n posZ = 0.8;\n }\n \n \n\n \n gl_Position = vec4(posX, posY, posZ, 1.0);\n gl_PointSize = pow(d, 2.0);\n \n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n }\n}" + }, "screenshotURL": "data/images/images-fkdm8q88oy6jux60w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Mpv9f3xLsHhv58XD9/art.json b/art/Mpv9f3xLsHhv58XD9/art.json index f4d6321d..afd000f7 100644 --- a/art/Mpv9f3xLsHhv58XD9/art.json +++ b/art/Mpv9f3xLsHhv58XD9/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jamination", "avatarUrl": "https://secure.gravatar.com/avatar/bd499cc8eca0978852d6d5748be7baed?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nfloat x = 0.0;\\n\\nvoid main() {\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 3.0;\\n v_color = vec4(100.0, 0.0, 10.0, 255.0);\\n x += .01;\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nfloat x = 0.0;\n\nvoid main() {\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n gl_PointSize = 3.0;\n v_color = vec4(100.0, 0.0, 10.0, 255.0);\n x += .01;\n}" + }, "screenshotURL": "data/images/images-ib0xy16o7p5iqobnj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MqRQ3wYqFZLGPAQWd/art.json b/art/MqRQ3wYqFZLGPAQWd/art.json index d9372051..8aadeeb5 100644 --- a/art/MqRQ3wYqFZLGPAQWd/art.json +++ b/art/MqRQ3wYqFZLGPAQWd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Vertexshaderart : Making a Grid\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n\\n\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across; \\n gl_PointSize *= resolution.x / 600.;\\n\\n v_color = vec4(1,0,0,1); \\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Vertexshaderart : Making a Grid\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n\n\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across; \n gl_PointSize *= resolution.x / 600.;\n\n v_color = vec4(1,0,0,1); \n \n \n}" + }, "screenshotURL": "data/images/images-vwv4rqo6xc0w7k168-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/MrwTGnkcE7aQ4y6XX/art.json b/art/MrwTGnkcE7aQ4y6XX/art.json index 2a8c9a17..3a714157 100644 --- a/art/MrwTGnkcE7aQ4y6XX/art.json +++ b/art/MrwTGnkcE7aQ4y6XX/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":43914,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define Kp0 22.//KParameter 0.>>22.\\n#define Kp1 1.//KParameter 0.>>1.\\n#define Kp2 0.6//KParameter 0.>>1.5\\n#define Kp3 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>1.\\n#define rotationFactorY 1.//KParameter 0.>>1.\\n#define rotationFactorZ 1.//KParameter 0.>>1.\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW2\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 4.3983, p * 5.4427*Kp0));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .15)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(cpos*-0.18*snd);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-.1, Kp2, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0.)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4+Kp1, 0.5*Kp2));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.3, snd));\\n abs(ca * cd) * Kp2;\\n float sat =pow(snd * 11.,.16); step(0., snd)*5.;\\n float val =- 0.4+snd;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 43914, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define Kp0 22.//KParameter 0.>>22.\n#define Kp1 1.//KParameter 0.>>1.\n#define Kp2 0.6//KParameter 0.>>1.5\n#define Kp3 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>1.\n#define rotationFactorY 1.//KParameter 0.>>1.\n#define rotationFactorZ 1.//KParameter 0.>>1.\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW2\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 4.3983, p * 5.4427*Kp0));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .15)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(cpos*-0.18*snd);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-.1, Kp2, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0.)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 1.4+Kp1, 0.5*Kp2));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.3, snd));\n abs(ca * cd) * Kp2;\n float sat =pow(snd * 11.,.16); step(0., snd)*5.;\n float val =- 0.4+snd;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-21qkfqta2myaxjy4q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MspbSjFRCRuPmozZy/art.json b/art/MspbSjFRCRuPmozZy/art.json index c7dd6c5a..1158195b 100644 --- a/art/MspbSjFRCRuPmozZy/art.json +++ b/art/MspbSjFRCRuPmozZy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-sunday-morning-cave-mix-2019\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \\n out vec3 pos, out vec3 nrm, out vec2 uv) {\\n float numQuads = floor(vertexCount / 6.);\\n float down = numQuads / around;\\n float quadId = floor(float(vertexId) / 6.);\\n\\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n\\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n\\n float edgeId = mod(float(vertexId), 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\\n\\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n\\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n\\n pos = vec3(x, cos(qv * PI), z);\\n nrm = normalize(pos);\\n uv = vec2(qu, qv);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(0);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n vec2 uv;\\n float around = floor(mix(10.0, 90.0, sin(time * 0.13) * 0.5 + 0.5));\\n float down = 60.0;\\n float vertsPerSphere = around * down * 6.;\\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\\n float cubeId = floor(pointId / vertsPerSphere);\\n float maxCubes = floor(vertexCount / vertsPerSphere);\\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float vu = vertexId / vertexCount;\\n float cv = cubeId / numCubes;\\n float su = hash(vu);\\n float vertsAround = around * 6.0;\\n float sr = mod(vertexId, vertsAround);\\n float sd = fract(vertexId / vertsPerSphere);\\n float srv = abs(atan(pos.x, pos.z) / PI);sr / vertsAround;\\n sd = abs(atan(length(vec2(pos.xy)), pos.y) / PI);\\n su = srv;\\n //su = hash(cubeId / maxCubes);\\n float sd2 = floor(sd * soundRes.y) / soundRes.y;\\n float s1 = texture2D(sound, vec2(mix(.25, .02, fract(su + 1.0)), sd2)).a;\\n float s2 = texture2D(sound, vec2(mix(.26, .03, fract(su + 0.8)), sd2)).a;\\n float s3 = texture2D(sound, vec2(mix(.27, .04, fract(su + 0.6)), sd2)).a;\\n float s4 = texture2D(sound, vec2(mix(.28, .05, fract(su + 0.4)), sd2)).a;\\n \\n float s = max(max(max(s1, s2), s3), s4);\\n float tm = time * .1;\\n float r = 11.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n float r2 = mix(8., 8., sin(cv * PI * 2. + time) * 0.5 + 0.5);\\n mat *= rotX(tm);\\n mat *= rotZ(cv * PI);\\n mat *= lookAt(loc * r2, vec3(0), up);\\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\\n// mat *= trans(vec3(0, 0, 1));\\n// mat *= rotZ(s * PI * 2.);\\n mat *= uniformScale(mix(0.2, 1., 3. / maxCubes));\\n mat *= uniformScale(5.0 + pow(s, 5.) * 13.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = pow(s, 5.) * 0.1 + time * 0.1 + sd2 * 0.1 + uv.y * .1;\\n float sat = 0.5 + step(0.6, s);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt * 1.2, 1);\\n// v_color.a = s;\\n v_color.rgb *= v_color.a; \\n// if (s < .2) {\\n// gl_Position.z = 10000.;\\n// }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-sunday-morning-cave-mix-2019", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\nvoid getSphereVertex(float vertexId, float vertexCount, float around, \n out vec3 pos, out vec3 nrm, out vec2 uv) {\n float numQuads = floor(vertexCount / 6.);\n float down = numQuads / around;\n float quadId = floor(float(vertexId) / 6.);\n\n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n\n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n\n float edgeId = mod(float(vertexId), 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.);\n\n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n\n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n\n pos = vec3(x, cos(qv * PI), z);\n nrm = normalize(pos);\n uv = vec2(qu, qv);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(0);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n vec2 uv;\n float around = floor(mix(10.0, 90.0, sin(time * 0.13) * 0.5 + 0.5));\n float down = 60.0;\n float vertsPerSphere = around * down * 6.;\n getSphereVertex(mod(pointId, vertsPerSphere), vertsPerSphere, around, pos, normal, uv);\n float cubeId = floor(pointId / vertsPerSphere);\n float maxCubes = floor(vertexCount / vertsPerSphere);\n float numCubes = maxCubes;// * mix(0.1, 1., t5p5(sin(time * .05)));\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float vu = vertexId / vertexCount;\n float cv = cubeId / numCubes;\n float su = hash(vu);\n float vertsAround = around * 6.0;\n float sr = mod(vertexId, vertsAround);\n float sd = fract(vertexId / vertsPerSphere);\n float srv = abs(atan(pos.x, pos.z) / PI);sr / vertsAround;\n sd = abs(atan(length(vec2(pos.xy)), pos.y) / PI);\n su = srv;\n //su = hash(cubeId / maxCubes);\n float sd2 = floor(sd * soundRes.y) / soundRes.y;\n float s1 = texture2D(sound, vec2(mix(.25, .02, fract(su + 1.0)), sd2)).a;\n float s2 = texture2D(sound, vec2(mix(.26, .03, fract(su + 0.8)), sd2)).a;\n float s3 = texture2D(sound, vec2(mix(.27, .04, fract(su + 0.6)), sd2)).a;\n float s4 = texture2D(sound, vec2(mix(.28, .05, fract(su + 0.4)), sd2)).a;\n \n float s = max(max(max(s1, s2), s3), s4);\n float tm = time * .1;\n float r = 11.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n float r2 = mix(8., 8., sin(cv * PI * 2. + time) * 0.5 + 0.5);\n mat *= rotX(tm);\n mat *= rotZ(cv * PI);\n mat *= lookAt(loc * r2, vec3(0), up);\n// mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\n// mat *= trans(vec3(0, 0, 1));\n// mat *= rotZ(s * PI * 2.);\n mat *= uniformScale(mix(0.2, 1., 3. / maxCubes));\n mat *= uniformScale(5.0 + pow(s, 5.) * 13.);\n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = pow(s, 5.) * 0.1 + time * 0.1 + sd2 * 0.1 + uv.y * .1;\n float sat = 0.5 + step(0.6, s);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt * 1.2, 1);\n// v_color.a = s;\n v_color.rgb *= v_color.a; \n// if (s < .2) {\n// gl_Position.z = 10000.;\n// }\n}\n\n" + }, "screenshotURL": "data/images/images-nrkvyyzh4wj7dw8c0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MuxJWoHfp7M47hF8N/art.json b/art/MuxJWoHfp7M47hF8N/art.json index c7b19554..b05b725c 100644 --- a/art/MuxJWoHfp7M47hF8N/art.json +++ b/art/MuxJWoHfp7M47hF8N/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1072,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sonicunleashed/sonic-unleashed-endless-possibility\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\nvoid main() {\\n \\n gl_PointSize = 10.0;\\n\\tgl_Position = vec4(0.0,0.0,0.0,1.0);\\n v_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 1072, + "mode": "LINES", + "sound": "https://soundcloud.com/sonicunleashed/sonic-unleashed-endless-possibility", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\nvoid main() {\n \n gl_PointSize = 10.0;\n\tgl_Position = vec4(0.0,0.0,0.0,1.0);\n v_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-xawswahw5l0n5l9g8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MvGQHAgKDYs3xAtq6/art.json b/art/MvGQHAgKDYs3xAtq6/art.json index 64afd940..42fd35e4 100644 --- a/art/MvGQHAgKDYs3xAtq6/art.json +++ b/art/MvGQHAgKDYs3xAtq6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":39178,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/christopher-camplin/qlabmilano\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 1\\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n\\n float ux = floor(id / 6.0) + mod(id, 2.);\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.0;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n \\t// \\n \\tfloat numSegments = 16.0;\\n \\tvec2 circleXY = getCirclePoint(vertexId, numSegments);\\n \\tfloat numPointsPerCircle = numSegments * 6.0;\\n \\tfloat circleId = floor(vertexId / numPointsPerCircle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\\n \\tfloat cols = floor(sqrt(numCircles));\\n \\tfloat rows = floor(numCircles / cols);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(circleId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = 0.;//sin(PI * time * 1.5 + y * 0.25) * 0.1;\\n \\tfloat yOff = 0.; //sin(time + x * 0.25) * 0.2;\\n \\tfloat soff = 0.; //sin(time * x * y * 0.0005) * 0.5;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\\\\\n \\t// sound\\n\\n float ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n\\n \\t// concentrate on center\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\n // circular - atan returns values between PI & -PI\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat scl = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\\n \\tscl *= 20. / rows;\\t\\n \\tvec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\\n \\tvec4 pos = vec4(circleXY, 0, 1);\\n \\tmat4 mat = ident();\\n \\tmat *= scale(vec3(1, aspect, 1));\\n \\tmat *= rotZ(time * 0.1);\\n \\tmat *= trans(vec3(ux, vy, 0) * 1.3);\\n \\tmat *= uniformScale(0.025 * scl);\\n \\tmat *= rotX(snd * 10.0);\\n \\t//mat *= rotY(PI * snd * 0.1);\\n \\tmat *= rotZ(snd * 10.0 * sign(ux));\\n \\n\\tgl_Position = mat * pos;\\n\\n \\n \\tfloat pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + 0.2 + time * 0.1;\\n hue = hue + oddSlice * 0.5;//smoothstep(x, y, pump);\\n float sat = 1.0;\\n \\t// add more impact using pow\\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\\n \\tval += oddSlice;\\n vec4 color = vec4(hsv2rgb(vec3(fract(hue), sat, val)), 1);\\n color *= snd;\\n //background += 0.1;\\n //vec4 finalColor = mix(color, background, s);\\n\\n v_color = color;\\n }\\n\\n\"}", + "settings": { + "num": 39178, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/christopher-camplin/qlabmilano", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 1\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n\n float ux = floor(id / 6.0) + mod(id, 2.);\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 1 1 2 2 3 3 4 4 5 5 6\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.0;\n\n float x = c * radius;\n float y = s * radius;\n\n \n return vec2(x, y);\n}\n\nvoid main() {\n \t// \n \tfloat numSegments = 16.0;\n \tvec2 circleXY = getCirclePoint(vertexId, numSegments);\n \tfloat numPointsPerCircle = numSegments * 6.0;\n \tfloat circleId = floor(vertexId / numPointsPerCircle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCircle);\n \n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\n \tfloat cols = floor(sqrt(numCircles));\n \tfloat rows = floor(numCircles / cols);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(circleId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = 0.;//sin(PI * time * 1.5 + y * 0.25) * 0.1;\n \tfloat yOff = 0.; //sin(time + x * 0.25) * 0.2;\n \tfloat soff = 0.; //sin(time * x * y * 0.0005) * 0.5;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\\\n \t// sound\n\n float ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n\n \t// concentrate on center\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat su = abs(u - 0.5) * 2.0;\n \n // circular - atan returns values between PI & -PI\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat scl = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\n \tscl *= 20. / rows;\t\n \tvec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\n \tvec4 pos = vec4(circleXY, 0, 1);\n \tmat4 mat = ident();\n \tmat *= scale(vec3(1, aspect, 1));\n \tmat *= rotZ(time * 0.1);\n \tmat *= trans(vec3(ux, vy, 0) * 1.3);\n \tmat *= uniformScale(0.025 * scl);\n \tmat *= rotX(snd * 10.0);\n \t//mat *= rotY(PI * snd * 0.1);\n \tmat *= rotZ(snd * 10.0 * sign(ux));\n \n\tgl_Position = mat * pos;\n\n \n \tfloat pump = step(0.8, snd);\n float hue = u * 0.1 + snd + 0.2 + time * 0.1;\n hue = hue + oddSlice * 0.5;//smoothstep(x, y, pump);\n float sat = 1.0;\n \t// add more impact using pow\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\n \tval += oddSlice;\n vec4 color = vec4(hsv2rgb(vec3(fract(hue), sat, val)), 1);\n color *= snd;\n //background += 0.1;\n //vec4 finalColor = mix(color, background, s);\n\n v_color = color;\n }\n\n" + }, "screenshotURL": "data/images/images-d4j5q1hggbxa6gbzy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/MvaSyANZqpM9Mewxp/art.json b/art/MvaSyANZqpM9Mewxp/art.json index 61285444..88b1dc58 100644 --- a/art/MvaSyANZqpM9Mewxp/art.json +++ b/art/MvaSyANZqpM9Mewxp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wearethebraveofficial/alan-fitzpatrick-friday-night-dancing-skream-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float numStars = floor(vertexCount / 3.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 3.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n vec3 cpos;\\n vec3 cnormal;\\n \\n float pointId = vertexId;\\n getCubePoint(pointId, cpos, cnormal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.5, hash(cubeId * 0.379)),\\n length(t) * .05)).a;\\n\\n float pump = step(0.7, s);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0);\\n mat *= uniformScale(2.);\\n #else\\n mat *= trans(t * dim * .5);\\n mat *= rotX(time * 1. + cubeId);\\n mat *= rotZ(time * 1.1 + cubeId);\\n mat *= uniformScale(mix(4., 20. + pump * 20., pow(s, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n \\n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\\n float sat = 1.;mix(1., 0., abs(ca));\\n float val = 1.;mix(1., 0.5, abs(cd));\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(0);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = dot(n, surfaceToLight);\\n float specular = pow(clamp(dot(n, halfVector), 0., 1.), 20.);\\n \\n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n}\\n\\nvoid main() {\\n const float numCubePoints = 900000.0;\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.125;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n // eye = vec3(1, 1, 1);\\n// target = vec3(0);\\n// up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (vertexId < numCubePoints) {\\n cube(vertexId, vertexCount, base, cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, base, cmat, pos, color);\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wearethebraveofficial/alan-fitzpatrick-friday-night-dancing-skream-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float numStars = floor(vertexCount / 3.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 3.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n \n color = vec4(h, h, h, 1);\n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n vec3 cpos;\n vec3 cnormal;\n \n float pointId = vertexId;\n getCubePoint(pointId, cpos, cnormal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n \n \n float s = texture2D(sound, vec2(\n mix(0.01, 0.5, hash(cubeId * 0.379)),\n length(t) * .05)).a;\n\n float pump = step(0.7, s);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0);\n mat *= uniformScale(2.);\n #else\n mat *= trans(t * dim * .5);\n mat *= rotX(time * 1. + cubeId);\n mat *= rotZ(time * 1.1 + cubeId);\n mat *= uniformScale(mix(4., 20. + pump * 20., pow(s, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n \n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\n float sat = 1.;mix(1., 0., abs(ca));\n float val = 1.;mix(1., 0.5, abs(cd));\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(0);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = dot(n, surfaceToLight);\n float specular = pow(clamp(dot(n, halfVector), 0., 1.), 20.);\n \n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n}\n\nvoid main() {\n const float numCubePoints = 900000.0;\n \n //float base = 15.; // good place to adjust\n float base = time * 0.125;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n // eye = vec3(1, 1, 1);\n// target = vec3(0);\n// up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (vertexId < numCubePoints) {\n cube(vertexId, vertexCount, base, cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, base, cmat, pos, color);\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-di8ioxncx41ha0f02-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/N22sSoSPGrRpJDyjK/art.json b/art/N22sSoSPGrRpJDyjK/art.json index 04e62f38..8674b821 100644 --- a/art/N22sSoSPGrRpJDyjK/art.json +++ b/art/N22sSoSPGrRpJDyjK/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Vertexshaderart : Motion\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Vertexshaderart : Motion\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-t6tzvyhyxz1r22flq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/N29W9bLojSA4Kv2fq/art.json b/art/N29W9bLojSA4Kv2fq/art.json index 10220a2a..21188f8a 100644 --- a/art/N29W9bLojSA4Kv2fq/art.json +++ b/art/N29W9bLojSA4Kv2fq/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Circles from Triangles\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0, \\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale (float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\n\\nvoid main() {\\n float numCircleSegnemts = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegnemts);\\n \\n float numPointsPerCircle = numCircleSegnemts * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\\n float sat = 1.;//(0.5, 1., pump);//mix(1., -10., av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Circles from Triangles\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0, \n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale (float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\n\nvoid main() {\n float numCircleSegnemts = 6.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegnemts);\n \n float numPointsPerCircle = numCircleSegnemts * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\n float sat = 1.;//(0.5, 1., pump);//mix(1., -10., av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-2w73tzfx3v9668bnl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/N2YXPmoxfuJSPWjhk/art.json b/art/N2YXPmoxfuJSPWjhk/art.json index 85e6b669..e4f169eb 100644 --- a/art/N2YXPmoxfuJSPWjhk/art.json +++ b/art/N2YXPmoxfuJSPWjhk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":2,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\nvoid main() {\\n float x = vertexId - 0.5;\\n \\n float duration = 30.0;\\n float t = mod(time, duration);\\n float v = t / duration;\\n\\n \\n \\n float b = fract(t * mix(1., 8., pow(v, 8.0)));\\n v_color = vec4(b, b, b, 1);\\n\\n\\n gl_Position = vec4(x, (v * 2.0 - 1.0) * vertexId, 0, 1);\\n gl_PointSize = 256.0;\\n}\"}", + "settings": { + "num": 2, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\nvoid main() {\n float x = vertexId - 0.5;\n \n float duration = 30.0;\n float t = mod(time, duration);\n float v = t / duration;\n\n \n \n float b = fract(t * mix(1., 8., pow(v, 8.0)));\n v_color = vec4(b, b, b, 1);\n\n\n gl_Position = vec4(x, (v * 2.0 - 1.0) * vertexId, 0, 1);\n gl_PointSize = 256.0;\n}" + }, "screenshotURL": "data/images/images-z4pcv900x5tyxme8g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/N3hXFQfEHwQ9N3TkC/art.json b/art/N3hXFQfEHwQ9N3TkC/art.json index 978bffdd..78d81118 100644 --- a/art/N3hXFQfEHwQ9N3TkC/art.json +++ b/art/N3hXFQfEHwQ9N3TkC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-the-cell-percomaniacs\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.5, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.1;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z) * 5.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.) * 1. + abs(cd) * 7.);\\n float sc = mix(0.02, 0.25, pow(snd + 0.2, 5.));\\n mat *= scale(vec3(0.2 * sc, sc, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.3 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);//pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-the-cell-percomaniacs", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.5, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.1;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z) * 5.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.) * 1. + abs(cd) * 7.);\n float sc = mix(0.02, 0.25, pow(snd + 0.2, 5.));\n mat *= scale(vec3(0.2 * sc, sc, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.3 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);//pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-nejd8r5o2tptxich8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/N5RMgW9QWmZvX9X2D/art.json b/art/N5RMgW9QWmZvX9X2D/art.json index 3ec4db05..80a786ba 100644 --- a/art/N5RMgW9QWmZvX9X2D/art.json +++ b/art/N5RMgW9QWmZvX9X2D/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Vertexshaderart : Motion\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Vertexshaderart : Motion\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-kqfnf2qqupzceu430-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/N9XCgfYxZ2Ffxr7hk/art.json b/art/N9XCgfYxZ2Ffxr7hk/art.json index edc25a53..9116143e 100644 --- a/art/N9XCgfYxZ2Ffxr7hk/art.json +++ b/art/N9XCgfYxZ2Ffxr7hk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 1.0, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x / vSunDir.y;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z / vSunDir.y;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 1.0, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x / vSunDir.y;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z / vSunDir.y;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-sqwmccwyqoewm6x8r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/N9ij5y2vHTpi6aDYM/art.json b/art/N9ij5y2vHTpi6aDYM/art.json index 44c2429f..abdb83e1 100644 --- a/art/N9ij5y2vHTpi6aDYM/art.json +++ b/art/N9ij5y2vHTpi6aDYM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 11\\\\\\\\ 13\\\\\\\\ 15,(16,17) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n \\n \\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\nfloat sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\\n gl_PointSize=sample*3.0;\\n v_color =vec4(sample);\\n \\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n \n \n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\nfloat sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\n gl_PointSize=sample*3.0;\n v_color =vec4(sample);\n \n \n}" + }, "screenshotURL": "data/images/images-ie2t9ag4g8ktc4h9x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NAnnyGCyAH9xTsjGs/art.json b/art/NAnnyGCyAH9xTsjGs/art.json index aa3f5f1e..95c575e3 100644 --- a/art/NAnnyGCyAH9xTsjGs/art.json +++ b/art/NAnnyGCyAH9xTsjGs/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/marawan-alsyed/suzume-no-tojimari-ost-kanata?si=42a11f4e833c444788b6183feac7bee8&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor( sqrt(vertexCount) );\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump); //mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/marawan-alsyed/suzume-no-tojimari-ost-kanata?si=42a11f4e833c444788b6183feac7bee8&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor( sqrt(vertexCount) );\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time + x * y * .02) * 5.; \n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump); //mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\n}" + }, "screenshotURL": "data/images/images-8rxiz7cnzyfoumsqn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NCmuezkb94xMJ4gtR/art.json b/art/NCmuezkb94xMJ4gtR/art.json index a79b61b8..eb27dd56 100644 --- a/art/NCmuezkb94xMJ4gtR/art.json +++ b/art/NCmuezkb94xMJ4gtR/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":32356,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.00784313725490196,0.00784313725490196,1],\"shader\":\"//KDrawmode=GL_LINES\\n//KVerticesNumber=22000\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = f * 2.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, -.2, 0, -0.01,\\n 0, f, 0, 0,\\n -f-2., 11.0-mouse.y, -tan(zNear - zFar) *cos(9.0/rangeInv*f), -2.+f,\\n 0, 0, zNear - zFar * rangeInv * 1.25, f/2.);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target*1.6)*2.;\\n vec3 xAxis = normalize(cross(up, zAxis)*5.0);\\n vec3 yAxis = cross(zAxis, min(xAxis, mouse.x))/1.;\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, tan( fract(mouse.x* 0.2)));\\n}\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * sin(a11 - a01 * a10),\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a11 / sin(min(mouse.x,3.) + 5.0 + a02) / a11,\\n b04 = a00 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 +\\n a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 3.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\t\\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat countSection = floor(6.);\\n\\t\\n\\tfloat indexCircle = floor(indexQuad / countSection);\\n\\t\\n\\tfloat astep = 3.14159 * 2.0 / countSection;\\n\\t\\n\\tfloat angle0 = indexQuad * astep;\\n\\tfloat angle1 = (indexQuad + 1.) * astep;\\n\\t\\n\\tfloat astepTorus = 3.14159 * 1.0 / floor(666.);\\n\\tfloat angleTorus = indexCircle * astepTorus;\\n\\t\\n\\tfloat radius = 4. *- cos(angleTorus * 1.5 + time) * 2.;\\n\\t\\n\\t// triangle 1\\n\\tif (index == 0.) p = vec3(cos(angle0) * radius, 1.3, tan(angle0) * radius);\\n\\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) -23.8+ radius);\\n\\tif (index == 2.) p = vec3(cos(angle1) * radius, 1.3, cos(angle1) * radius);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) p = vec3(cos(angle0) * radius, 0.6, sin(angle0) * radius);\\n\\tif (index == 4.) p = vec3(cos(angle1) * radius/mouse.y, 1., sin(angle1) * radius);\\n\\tif (index == 5.) p = vec3(cos(angle0) - radius, 1., sin(angle0) * radius);\\n\\t\\n \\tfloat atten = p.z;\\n \\n\\tp *= RotX(-angleTorus);\\n\\t\\n\\tp.z += 11. * cos(angleTorus);\\n\\tp.y += 11. * sin(angleTorus);\\n\\t\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 3.14159 * 0.6;\\n\\tfloat cd = 50.;\\n\\tvec3 eye = vec3(sin(ca), 0.15, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(65. * PI / 180., resolution.x / resolution.y, 0.01, 1000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 2.1);\\n\\t\\n \\tp /= atten;\\n \\n\\tv_color = vec4(normalize(p) * 0.5 + 0.2, 0.4);\\n}\"}", + "settings": { + "num": 32356, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.00784313725490196, + 0.00784313725490196, + 1 + ], + "shader": "//KDrawmode=GL_LINES\n//KVerticesNumber=22000\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = f * 2.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, -.2, 0, -0.01,\n 0, f, 0, 0,\n -f-2., 11.0-mouse.y, -tan(zNear - zFar) *cos(9.0/rangeInv*f), -2.+f,\n 0, 0, zNear - zFar * rangeInv * 1.25, f/2.);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target*1.6)*2.;\n vec3 xAxis = normalize(cross(up, zAxis)*5.0);\n vec3 yAxis = cross(zAxis, min(xAxis, mouse.x))/1.;\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, tan( fract(mouse.x* 0.2)));\n}\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * sin(a11 - a01 * a10),\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a11 / sin(min(mouse.x,3.) + 5.0 + a02) / a11,\n b04 = a00 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 +\n a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvoid main()\n{\n\tgl_PointSize = 3.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tvec3 p = vec3(0);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\t\n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat countSection = floor(6.);\n\t\n\tfloat indexCircle = floor(indexQuad / countSection);\n\t\n\tfloat astep = 3.14159 * 2.0 / countSection;\n\t\n\tfloat angle0 = indexQuad * astep;\n\tfloat angle1 = (indexQuad + 1.) * astep;\n\t\n\tfloat astepTorus = 3.14159 * 1.0 / floor(666.);\n\tfloat angleTorus = indexCircle * astepTorus;\n\t\n\tfloat radius = 4. *- cos(angleTorus * 1.5 + time) * 2.;\n\t\n\t// triangle 1\n\tif (index == 0.) p = vec3(cos(angle0) * radius, 1.3, tan(angle0) * radius);\n\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) -23.8+ radius);\n\tif (index == 2.) p = vec3(cos(angle1) * radius, 1.3, cos(angle1) * radius);\n\t\n\t// triangle 2\n\tif (index == 3.) p = vec3(cos(angle0) * radius, 0.6, sin(angle0) * radius);\n\tif (index == 4.) p = vec3(cos(angle1) * radius/mouse.y, 1., sin(angle1) * radius);\n\tif (index == 5.) p = vec3(cos(angle0) - radius, 1., sin(angle0) * radius);\n\t\n \tfloat atten = p.z;\n \n\tp *= RotX(-angleTorus);\n\t\n\tp.z += 11. * cos(angleTorus);\n\tp.y += 11. * sin(angleTorus);\n\t\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 3.14159 * 0.6;\n\tfloat cd = 50.;\n\tvec3 eye = vec3(sin(ca), 0.15, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(65. * PI / 180., resolution.x / resolution.y, 0.01, 1000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 2.1);\n\t\n \tp /= atten;\n \n\tv_color = vec4(normalize(p) * 0.5 + 0.2, 0.4);\n}" + }, "screenshotURL": "data/images/images-ozyd2jul0jmoq5wub-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NDEYmpHPER7Tg3oiu/art.json b/art/NDEYmpHPER7Tg3oiu/art.json index 5581f31a..871d91db 100644 --- a/art/NDEYmpHPER7Tg3oiu/art.json +++ b/art/NDEYmpHPER7Tg3oiu/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9896,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/argofox/doctor-vox-death\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = abs(atan(loc.x, loc.z) / PI);\\n float sv = abs(loc.y);\\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(cos(tm),-sin(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, pow(s, 2.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(0.9, 1.1, s) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n #if 0\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n#endif\\n}\\n\\n\"}", + "settings": { + "num": 9896, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/argofox/doctor-vox-death", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = abs(atan(loc.x, loc.z) / PI);\n float sv = abs(loc.y);\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(cos(tm),-sin(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, pow(s, 2.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(0.9, 1.1, s) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n #if 0\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n#endif\n}\n\n" + }, "screenshotURL": "data/images/images-16y8vf1sp40le5ntp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NE74eMsB75DrWvCf2/art.json b/art/NE74eMsB75DrWvCf2/art.json index ca15ad9c..cf1783ea 100644 --- a/art/NE74eMsB75DrWvCf2/art.json +++ b/art/NE74eMsB75DrWvCf2/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n\\n gl_PointSize = 10.0; \\n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n gl_Position = vec4(-1.0+cos(time)*vertexId/10000.0, vertexId/10000.0*cos(vertexId),0,1.0);\\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\\n v_color = vec4(1,cos(time),0.5,1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n\n gl_PointSize = 10.0; \n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n gl_Position = vec4(-1.0+cos(time)*vertexId/10000.0, vertexId/10000.0*cos(vertexId),0,1.0);\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\n v_color = vec4(1,cos(time),0.5,1);\n}" + }, "screenshotURL": "data/images/images-yeg7ylfm2aiyzfmot-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NFPQeRuNoFDunGBxd/art.json b/art/NFPQeRuNoFDunGBxd/art.json index 1eeba1ff..a1ecd7e4 100644 --- a/art/NFPQeRuNoFDunGBxd/art.json +++ b/art/NFPQeRuNoFDunGBxd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-jl3hq6z8juias815a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NFjum54CBQsEgz5sK/art.json b/art/NFjum54CBQsEgz5sK/art.json index 555ffb39..af3ed835 100644 --- a/art/NFjum54CBQsEgz5sK/art.json +++ b/art/NFjum54CBQsEgz5sK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\tgl_Position = vec4(0, 0, 0 ,1);\\n\\tgl_PointSize = 10.0;\\n\\tv_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\tgl_Position = vec4(0, 0, 0 ,1);\n\tgl_PointSize = 10.0;\n\tv_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ocuoiiv74iapja0ft-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NHc5v2ZJ5kCQAefNG/art.json b/art/NHc5v2ZJ5kCQAefNG/art.json index dfebc1c3..beec36e6 100644 --- a/art/NHc5v2ZJ5kCQAefNG/art.json +++ b/art/NHc5v2ZJ5kCQAefNG/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "iso-wip", "username": "gman", - "settings": "{\"num\":12,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n/*\\n {-X, 0., Z}, \\n { X, 0., Z}, \\n {-X, 0., -Z}, \\n { X, 0., -Z}, \\n {0., Z, X}, \\n {0., Z, -X}, \\n {0., -Z, X}, \\n {0., -Z, -X}, \\n { Z, X, 0.}, \\n {-Z, X, 0.}, \\n { Z, -X, 0.}, \\n {-Z, -X, 0.} \\n*/\\n#define ICOSO_X 0.525731112119133606\\n#define ICOSO_Z 0.850650808352039932\\nfloat icosoHelp(float pId) {\\n float id = mod(pId, 12.);\\n float useX = step(pId, 3.5);\\n float xOr0 = mix(ICOSO_X, 0., useX);\\n float sgn = mix(-1., 1., useX);\\n return mix(xOr0, ICOSO_Z, step(7.5, pId)) * sgn; \\n}\\n\\nvec3 icosoNorm(float normId) {\\n if (normId < 1.) return vec3(-ICOSO_X, 0., ICOSO_Z); \\n if (normId < 2.) return vec3( ICOSO_X, 0., ICOSO_Z); \\n if (normId < 3.) return vec3(-ICOSO_X, 0., -ICOSO_Z); \\n if (normId < 4.) return vec3( ICOSO_X, 0., -ICOSO_Z); \\n if (normId < 5.) return vec3(0., ICOSO_Z, ICOSO_X); \\n if (normId < 6.) return vec3(0., ICOSO_Z, -ICOSO_X); \\n if (normId < 7.) return vec3(0., -ICOSO_Z, ICOSO_X); \\n if (normId < 8.) return vec3(0., -ICOSO_Z, -ICOSO_X); \\n if (normId < 9.) return vec3( ICOSO_Z, ICOSO_X, 0.); \\n if (normId < 10.) return vec3(-ICOSO_Z, ICOSO_X, 0.); \\n if (normId < 11.) return vec3( ICOSO_Z, -ICOSO_X, 0.); \\n /*if (normId < 12.)*/ return vec3(-ICOSO_Z, -ICOSO_X, 0.); \\n}\\n \\n\\nvoid main() {\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n\\n vec3 p = icosoNorm(vertexId);\\n gl_Position = vec4(p * 0.5 * vec3(aspect, 1), 1);\\n\\n gl_PointSize = 10.0;\\n float hue = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 12, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n/*\n {-X, 0., Z}, \n { X, 0., Z}, \n {-X, 0., -Z}, \n { X, 0., -Z}, \n {0., Z, X}, \n {0., Z, -X}, \n {0., -Z, X}, \n {0., -Z, -X}, \n { Z, X, 0.}, \n {-Z, X, 0.}, \n { Z, -X, 0.}, \n {-Z, -X, 0.} \n*/\n#define ICOSO_X 0.525731112119133606\n#define ICOSO_Z 0.850650808352039932\nfloat icosoHelp(float pId) {\n float id = mod(pId, 12.);\n float useX = step(pId, 3.5);\n float xOr0 = mix(ICOSO_X, 0., useX);\n float sgn = mix(-1., 1., useX);\n return mix(xOr0, ICOSO_Z, step(7.5, pId)) * sgn; \n}\n\nvec3 icosoNorm(float normId) {\n if (normId < 1.) return vec3(-ICOSO_X, 0., ICOSO_Z); \n if (normId < 2.) return vec3( ICOSO_X, 0., ICOSO_Z); \n if (normId < 3.) return vec3(-ICOSO_X, 0., -ICOSO_Z); \n if (normId < 4.) return vec3( ICOSO_X, 0., -ICOSO_Z); \n if (normId < 5.) return vec3(0., ICOSO_Z, ICOSO_X); \n if (normId < 6.) return vec3(0., ICOSO_Z, -ICOSO_X); \n if (normId < 7.) return vec3(0., -ICOSO_Z, ICOSO_X); \n if (normId < 8.) return vec3(0., -ICOSO_Z, -ICOSO_X); \n if (normId < 9.) return vec3( ICOSO_Z, ICOSO_X, 0.); \n if (normId < 10.) return vec3(-ICOSO_Z, ICOSO_X, 0.); \n if (normId < 11.) return vec3( ICOSO_Z, -ICOSO_X, 0.); \n /*if (normId < 12.)*/ return vec3(-ICOSO_Z, -ICOSO_X, 0.); \n}\n \n\nvoid main() {\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n\n vec3 p = icosoNorm(vertexId);\n gl_Position = vec4(p * 0.5 * vec3(aspect, 1), 1);\n\n gl_PointSize = 10.0;\n float hue = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-geh4tfrkzxltrx2yu-thumbnail.jpg", "views": { "$numberInt": "9" diff --git a/art/NJM9uDGaaTJfRnrQC/art.json b/art/NJM9uDGaaTJfRnrQC/art.json index 23f9307a..fd4029f3 100644 --- a/art/NJM9uDGaaTJfRnrQC/art.json +++ b/art/NJM9uDGaaTJfRnrQC/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":13959,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.137;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.123 * cgv + snd * .125);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n\\n \\n float pump = step(.45, snd);\\n float hue = 1.- cgId * 1.05 + pump * .7;\\n float sat = mod(cgId, 1.) + pump;\\n float val = 1. - mod(cgId + 1., 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.925);\\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\\n v_color.rgb *= v_color.a;\\n \\n gl_Position = mat * vec4(pos, .25);\\n gl_PointSize = 2. + hue * 2.;\\n}\\n\\n\"}", + "settings": { + "num": 13959, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.137;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.123 * cgv + snd * .125);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n\n \n float pump = step(.45, snd);\n float hue = 1.- cgId * 1.05 + pump * .7;\n float sat = mod(cgId, 1.) + pump;\n float val = 1. - mod(cgId + 1., 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.925);\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\n v_color.rgb *= v_color.a;\n \n gl_Position = mat * vec4(pos, .25);\n gl_PointSize = 2. + hue * 2.;\n}\n\n" + }, "screenshotURL": "data/images/images-wqsuzlzop0bl6xgbu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NKCTpuxGSTTQAXHYw/art.json b/art/NKCTpuxGSTTQAXHYw/art.json index 1d47350e..a7b43b89 100644 --- a/art/NKCTpuxGSTTQAXHYw/art.json +++ b/art/NKCTpuxGSTTQAXHYw/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "plasticrainbow", "avatarUrl": "https://secure.gravatar.com/avatar/6a162c0fed03619171f63772ec1198d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-vrz38w7n86p5bxw47-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NLAbSqYY5BSBZfShB/art.json b/art/NLAbSqYY5BSBZfShB/art.json index 6bfe3d3a..776a7569 100644 --- a/art/NLAbSqYY5BSBZfShB/art.json +++ b/art/NLAbSqYY5BSBZfShB/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":2065,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Seulbin Seo\\n// Exercise Motion \\n// CS250 Spring 2023\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4 (1 ,0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 2065, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Motion \n// CS250 Spring 2023\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4 (1 ,0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-tllzdulqaaa9f81ic-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NMXGFyxQwcGWH96PG/art.json b/art/NMXGFyxQwcGWH96PG/art.json index e218af55..0eb7b8d3 100644 --- a/art/NMXGFyxQwcGWH96PG/art.json +++ b/art/NMXGFyxQwcGWH96PG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2158,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 11.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 1.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 2158, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 11.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 1.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-svh7esczabf87qnnc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NP3rRKeHPZeXBhymB/art.json b/art/NP3rRKeHPZeXBhymB/art.json index 939918a0..04bf2b92 100644 --- a/art/NP3rRKeHPZeXBhymB/art.json +++ b/art/NP3rRKeHPZeXBhymB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/graham-panter/lotus\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvoid main() {\\n float pointsAroundCircle = 240.;\\n float pointsPerCircle = pointsAroundCircle * 2.;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float vId = mod(vertexId, pointsPerCircle);\\n float pointId = floor(vId / 2.) + mod(vId, 2.);\\n float pointV = pointId / (pointsAroundCircle - 1.);\\n \\n float circleV = circleId / (numCircles - 1.);\\n float odd = mod(circleId, 2.);\\n float quad = mod(floor(circleId / 2.), 2.);\\n \\n float tm = time * 4. - circleV;\\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .5;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float off = mix(.0, 0.953, circleV);\\n\\n float su = hash(pointV * 13.7);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.5)).a;\\n \\n float q = (odd + quad * 2.) / 3.;\\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\\n \\n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 17.)/sq);\\n float scale = mix(\\n mix(\\n mix(.04, .25, circleV),\\n mix(-.4, snd/0.7, circleV),\\n odd),\\n mix(\\n mix(.1, -.15+snd, circleV),\\n mix(-.1, -.05, circleV),\\n odd),\\n quad) + pow(sq, 2.) * .3;\\n \\n gl_Position = vec4(xy * aspect * scale, circleV, 1);\\n\\n float hue = 0.5 + odd * .25 + quad * .125;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/graham-panter/lotus", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvoid main() {\n float pointsAroundCircle = 240.;\n float pointsPerCircle = pointsAroundCircle * 2.;\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float vId = mod(vertexId, pointsPerCircle);\n float pointId = floor(vId / 2.) + mod(vId, 2.);\n float pointV = pointId / (pointsAroundCircle - 1.);\n \n float circleV = circleId / (numCircles - 1.);\n float odd = mod(circleId, 2.);\n float quad = mod(floor(circleId / 2.), 2.);\n \n float tm = time * 4. - circleV;\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .5;\n float c = cos(angle);\n float s = sin(angle);\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float off = mix(.0, 0.953, circleV);\n\n float su = hash(pointV * 13.7);\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.5)).a;\n \n float q = (odd + quad * 2.) / 3.;\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\n \n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 17.)/sq);\n float scale = mix(\n mix(\n mix(.04, .25, circleV),\n mix(-.4, snd/0.7, circleV),\n odd),\n mix(\n mix(.1, -.15+snd, circleV),\n mix(-.1, -.05, circleV),\n odd),\n quad) + pow(sq, 2.) * .3;\n \n gl_Position = vec4(xy * aspect * scale, circleV, 1);\n\n float hue = 0.5 + odd * .25 + quad * .125;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-p55vl0rhufzj9ov0a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NPJKuYxHxpNRWHnid/art.json b/art/NPJKuYxHxpNRWHnid/art.json index 7e7e9fe6..20c27f53 100644 --- a/art/NPJKuYxHxpNRWHnid/art.json +++ b/art/NPJKuYxHxpNRWHnid/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":23,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n \\n float radio = 5.0;\\n float angle = (x/20.0)*2.0*3.14;\\n \\n float xOffset = cos(x);\\n float yOffset = sin(y);\\n vec2 xy = vec2(x*yOffset, y*xOffset) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n \\n // E2\\n /*\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n */\\n \\n // E1\\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 23, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n \n float radio = 5.0;\n float angle = (x/20.0)*2.0*3.14;\n \n float xOffset = cos(x);\n float yOffset = sin(y);\n vec2 xy = vec2(x*yOffset, y*xOffset) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n \n // E2\n /*\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n */\n \n // E1\n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-931r5q280impeifqc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NPRtMLeXooWxf64wn/art.json b/art/NPRtMLeXooWxf64wn/art.json index b700581f..d8be1a0c 100644 --- a/art/NPRtMLeXooWxf64wn/art.json +++ b/art/NPRtMLeXooWxf64wn/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/plini/electric-sunrise\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = vertexId / vertexCount;\\n float cols = mod(vertexId, 100.0) * 0.01;\\n float rows = floor(vertexId / 100.0) * 0.025;\\n \\n float track = texture2D(sound, vec2(point, pow(point, 1000.0))).a;\\n \\n float z = sin(point * point * time) * 0.5;\\n float x = cols - 0.5 + z;\\n float y = rows * track * point;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n gl_PointSize = track * pow(point, 3.0) * 50.0;\\n v_color = vec4(track * y * x, x, 1.0 - y, 1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/plini/electric-sunrise", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = vertexId / vertexCount;\n float cols = mod(vertexId, 100.0) * 0.01;\n float rows = floor(vertexId / 100.0) * 0.025;\n \n float track = texture2D(sound, vec2(point, pow(point, 1000.0))).a;\n \n float z = sin(point * point * time) * 0.5;\n float x = cols - 0.5 + z;\n float y = rows * track * point;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n gl_PointSize = track * pow(point, 3.0) * 50.0;\n v_color = vec4(track * y * x, x, 1.0 - y, 1.0);\n}" + }, "screenshotURL": "data/images/images-qg36hob2e5776h5qd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NPjebpJsCc3dqek4y/art.json b/art/NPjebpJsCc3dqek4y/art.json index 06507a82..4b7b55a1 100644 --- a/art/NPjebpJsCc3dqek4y/art.json +++ b/art/NPjebpJsCc3dqek4y/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":78962,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nvec3 triangle(float idx) // vec2:p / float triangleIndex\\n{\\n\\tfloat triangleIndex = floor(idx / 6.);\\n\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 p = vec2(0);\\n\\t\\n\\tif (index == 0.) p = vec2(0,0);\\n\\tif (index == 1.) p = vec2(1,0);\\n\\tif (index == 2.) p = vec2(1,1);\\n\\t\\n\\tif (index == 3.) p = vec2(0,0);\\n\\tif (index == 4.) p = vec2(1,1);\\n\\tif (index == 5.) p = vec2(0,1);\\n\\t\\n\\treturn vec3(p, triangleIndex);\\n}\\n\\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\\n{\\n\\tvec4 res;\\n\\tvec3 pi = triangle(idx);\\n\\t\\n\\tpi.y += floor(pi.z / countQuadsX);\\n pi.x += mod(pi.z, countQuadsX);\\n \\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadsX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\t\\n\\tif (centered == true)\\n\\t{\\n\\t\\tpi.x -= nx * 0.5;\\n\\t\\tpi.y -= ny * 0.5;\\n\\t}\\n\\t\\n\\treturn vec4(pi.xy, nx, ny);\\n}\\n\\n//https://www.shadertoy.com/view/ltK3WD\\nvec4 voronoi(vec2 g )\\n{\\n\\tvec4 f = vec4(9);\\n\\tvec2 p = g /= 200. ; f.x=9.;\\n \\n\\tg += time;\\n\\t\\n float t = time * 0.1;\\n \\n for(int x=-2;x<=2;x++)\\n for(int y=-2;y<=2;y++)\\n {\\t\\n p = vec2(x,y);\\n\\t\\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\\n\\t\\t//f.y = max(abs(p.x), abs(p.y));\\n\\t\\t//f.y = dot(p,p);\\n\\t\\tif (f.y < f.x)\\n {\\n f.x = f.y;\\n f.zw = p;\\n }\\n }\\n\\t\\n vec3 n = vec3(0);\\n \\n if ( f.x == -f.z*.866 - f.w*.5) \\tn = vec3(1,0,0);\\n\\tif ( f.x == f.z*.866 - f.w*.5) \\t\\tn = vec3(0,1,0);\\n\\tif ( f.x == f.w) \\t\\t\\t\\t\\tn = vec3(0,0,1);\\n\\t\\n return vec4(f.x, n);\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 20.;\\n\\t\\n \\tvec3 uSlider = vec3(50, 5, 1.2);\\n \\n\\tfloat thickNess = uSlider.x;\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat sizeEdge = floor(sqrt(countMax));\\n\\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\\n\\t\\n\\tvec4 voro = voronoi(p.xy * uSlider.y);\\n\\t\\n\\tfloat d = voro.x;\\n\\tvec3 n = voro.yzw;\\n\\t\\n\\tv_color = vec4(n*d,1);\\n\\t\\n\\tmat4 camera = ident();\\n\\t\\n\\tfloat ca = time * 0.1;\\n\\tfloat cd = 160.;\\n\\tfloat ce = PI * mouse.y;\\n\\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(1, 1, 0);\\n \\n\\tcamera = 2.0*persp(45. * PI / 10., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p.x-mouse.x*10.0, 1.0-voro.x * thickNess - thickNess * 0.5, p.y, 0.51);\\n}\"}", + "settings": { + "num": 78962, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nvec3 triangle(float idx) // vec2:p / float triangleIndex\n{\n\tfloat triangleIndex = floor(idx / 6.);\n\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 p = vec2(0);\n\t\n\tif (index == 0.) p = vec2(0,0);\n\tif (index == 1.) p = vec2(1,0);\n\tif (index == 2.) p = vec2(1,1);\n\t\n\tif (index == 3.) p = vec2(0,0);\n\tif (index == 4.) p = vec2(1,1);\n\tif (index == 5.) p = vec2(0,1);\n\t\n\treturn vec3(p, triangleIndex);\n}\n\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\n{\n\tvec4 res;\n\tvec3 pi = triangle(idx);\n\t\n\tpi.y += floor(pi.z / countQuadsX);\n pi.x += mod(pi.z, countQuadsX);\n \n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadsX;\n\tfloat ny = floor(countQuads / nx);\n\t\t\n\tif (centered == true)\n\t{\n\t\tpi.x -= nx * 0.5;\n\t\tpi.y -= ny * 0.5;\n\t}\n\t\n\treturn vec4(pi.xy, nx, ny);\n}\n\n//https://www.shadertoy.com/view/ltK3WD\nvec4 voronoi(vec2 g )\n{\n\tvec4 f = vec4(9);\n\tvec2 p = g /= 200. ; f.x=9.;\n \n\tg += time;\n\t\n float t = time * 0.1;\n \n for(int x=-2;x<=2;x++)\n for(int y=-2;y<=2;y++)\n {\t\n p = vec2(x,y);\n\t\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\n\t\t//f.y = max(abs(p.x), abs(p.y));\n\t\t//f.y = dot(p,p);\n\t\tif (f.y < f.x)\n {\n f.x = f.y;\n f.zw = p;\n }\n }\n\t\n vec3 n = vec3(0);\n \n if ( f.x == -f.z*.866 - f.w*.5) \tn = vec3(1,0,0);\n\tif ( f.x == f.z*.866 - f.w*.5) \t\tn = vec3(0,1,0);\n\tif ( f.x == f.w) \t\t\t\t\tn = vec3(0,0,1);\n\t\n return vec4(f.x, n);\n}\n\nvoid main()\n{\n\tgl_PointSize = 20.;\n\t\n \tvec3 uSlider = vec3(50, 5, 1.2);\n \n\tfloat thickNess = uSlider.x;\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat sizeEdge = floor(sqrt(countMax));\n\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\n\t\n\tvec4 voro = voronoi(p.xy * uSlider.y);\n\t\n\tfloat d = voro.x;\n\tvec3 n = voro.yzw;\n\t\n\tv_color = vec4(n*d,1);\n\t\n\tmat4 camera = ident();\n\t\n\tfloat ca = time * 0.1;\n\tfloat cd = 160.;\n\tfloat ce = PI * mouse.y;\n\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(1, 1, 0);\n \n\tcamera = 2.0*persp(45. * PI / 10., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p.x-mouse.x*10.0, 1.0-voro.x * thickNess - thickNess * 0.5, p.y, 0.51);\n}" + }, "screenshotURL": "data/images/images-t0koj4c55bekap93z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NPohkmBgKdTBhML8P/art.json b/art/NPohkmBgKdTBhML8P/art.json index 45a92d83..1ec9f4e9 100644 --- a/art/NPohkmBgKdTBhML8P/art.json +++ b/art/NPohkmBgKdTBhML8P/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":151,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nUniform Grid Based on VertexCount and window dimensions\\n\\nChange the count and/or size the window\\n\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n \\n float x = u * 2. - 1.;\\n float y = v * 2. - 1.;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = u * v;\\n float sat = 1.0;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5;\\n}\\n\"}", + "settings": { + "num": 151, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nUniform Grid Based on VertexCount and window dimensions\n\nChange the count and/or size the window\n\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n \n float x = u * 2. - 1.;\n float y = v * 2. - 1.;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = u * v;\n float sat = 1.0;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5;\n}\n" + }, "screenshotURL": "data/images/images-r6t9cel985nash18l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NR42qFZjAfmdmw6oR/art.json b/art/NR42qFZjAfmdmw6oR/art.json index 65498cb3..2fd3074c 100644 --- a/art/NR42qFZjAfmdmw6oR/art.json +++ b/art/NR42qFZjAfmdmw6oR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":72586,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/thrillkillkult/the-chains-of-fame\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 16.;\\n float maxEdge = 16.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.04, abs(cu * 2. - 1.)), 0.)).a; \\n float s2 = texture2D(sound, vec2(0.125, abs(cu * 2. - 1.) * .1)).a; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n // vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,10);//rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(0,0,0);//vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, .5);\\n\\n mat4 wmat = ident();\\n\\n wmat *= rotZ(cu * PI * 2. + sv);\\n wmat *= scale(vec3(.1, mix(0., 8., pow(s, 5.)), 1));\\n wmat *= trans(vec3(0, 1.5, cu));\\n \\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n float sl = step(0.8, s);\\n float hue = time * 0.1 + mix(s2 * .2 + .4, 1., sl);\\n float sat = mix(1., 1., sl);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.a = mix(.1, .2, s);\\n v_color.rgb *= v_color.a; \\n}\\n\"}", + "settings": { + "num": 72586, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/thrillkillkult/the-chains-of-fame", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 16.;\n float maxEdge = 16.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.04, abs(cu * 2. - 1.)), 0.)).a; \n float s2 = texture2D(sound, vec2(0.125, abs(cu * 2. - 1.) * .1)).a; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n // vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,0,10);//rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(0,0,0);//vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, .5);\n\n mat4 wmat = ident();\n\n wmat *= rotZ(cu * PI * 2. + sv);\n wmat *= scale(vec3(.1, mix(0., 8., pow(s, 5.)), 1));\n wmat *= trans(vec3(0, 1.5, cu));\n \n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n float sl = step(0.8, s);\n float hue = time * 0.1 + mix(s2 * .2 + .4, 1., sl);\n float sat = mix(1., 1., sl);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.a = mix(.1, .2, s);\n v_color.rgb *= v_color.a; \n}\n" + }, "screenshotURL": "data/images/images-kqun6djr5u11njmpm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NTihgba8cFq4fMyQF/art.json b/art/NTihgba8cFq4fMyQF/art.json index 2ee02345..8e7d82aa 100644 --- a/art/NTihgba8cFq4fMyQF/art.json +++ b/art/NTihgba8cFq4fMyQF/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount)); // gets the count of rows\\n float across = floor(vertexCount / down); // gets the count of columns\\n \\n // vertexId is the \\n float x = mod(vertexId, across); // always use floats\\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = sin(time * 1.7 + y * 0.2) * 0.1; \\n float yOffset = sin(time * 0.5 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset; // gets value from -1 to 1\\n float uy = v * 2.0 - 1.0 + yOffset; // gets value from -1 to 1\\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n float sizeOffset = sin(time * 3.5 + x * y * 0.02) * 5.0;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 200.0 / across; // set point size\\n gl_PointSize *= resolution.x / 600.0 + sizeOffset;\\n \\n float hue = u * 0.1 + sin(time * 1.25 + v * 20.0) * 0.05;\\n float sat = 1.;\\n float value = sin(time * 2.0 + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1); // this is unique to vertex shader art\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount)); // gets the count of rows\n float across = floor(vertexCount / down); // gets the count of columns\n \n // vertexId is the \n float x = mod(vertexId, across); // always use floats\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = sin(time * 1.7 + y * 0.2) * 0.1; \n float yOffset = sin(time * 0.5 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset; // gets value from -1 to 1\n float uy = v * 2.0 - 1.0 + yOffset; // gets value from -1 to 1\n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n float sizeOffset = sin(time * 3.5 + x * y * 0.02) * 5.0;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 200.0 / across; // set point size\n gl_PointSize *= resolution.x / 600.0 + sizeOffset;\n \n float hue = u * 0.1 + sin(time * 1.25 + v * 20.0) * 0.05;\n float sat = 1.;\n float value = sin(time * 2.0 + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1); // this is unique to vertex shader art\n}" + }, "screenshotURL": "data/images/images-mu0lxdtj34c33s0fn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NTmBiN65MW5gE5nBQ/art.json b/art/NTmBiN65MW5gE5nBQ/art.json index 08ae0e8c..fb7d6a8d 100644 --- a/art/NTmBiN65MW5gE5nBQ/art.json +++ b/art/NTmBiN65MW5gE5nBQ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "yonatan", "avatarUrl": "https://secure.gravatar.com/avatar/c7fabc219ab011fe8a1bd0590bcbcbd5?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 2D version at https://www.dwitter.net/d/9544:\\n// for(i=w=c.width=500;(i*=.9998)>w/2;x.fillRect(w/2+S(i+t)*q,j*300-C(i+t)*q,9,9))j=1-i/w,q=(2+S(i*5)**3)*j**4*w,x.fillStyle=R(a=j*600,a*2,a/2)\\n\\n#define PI radians(180.)\\n\\nvec2 rot(vec2 p, float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return vec2(p.x * s + p.y * c, p.y * s - p.x * c);\\n}\\n\\nvoid main() {\\n float v = sqrt(vertexId / vertexCount);\\n float t = v + 1.5;\\n float i = mod(t, 1.0) * 1000.0;\\n float s = sin(i * 6.0);\\n float q = (2.0 + s * s * s) * pow(t, 5.5) / 2000.0;\\n\\n vec2 aspect = vec2(1.0, resolution.x / resolution.y);\\n vec3 p = vec3(\\n sin(i) * q,\\n cos(i) * q,\\n (1.0-sqrt(v))\\n );\\n\\n p = vec3(rot(p.xy, time), p.z);\\n p = vec3(p.x, rot(p.zy, 3.5+cos(time)/3.));\\n p.xy *= aspect;\\n p.y += .3;\\n gl_Position = vec4(p, 1);\\n\\n float a = min(255.0, pow(t, 2.6) * 25.0) / 255.0;\\n v_color = vec4(a, a * 1.5, t * t * 15.0 / 255.0, 1.0);\\n gl_PointSize = 3.0;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 2D version at https://www.dwitter.net/d/9544:\n// for(i=w=c.width=500;(i*=.9998)>w/2;x.fillRect(w/2+S(i+t)*q,j*300-C(i+t)*q,9,9))j=1-i/w,q=(2+S(i*5)**3)*j**4*w,x.fillStyle=R(a=j*600,a*2,a/2)\n\n#define PI radians(180.)\n\nvec2 rot(vec2 p, float a) {\n float s = sin(a);\n float c = cos(a);\n return vec2(p.x * s + p.y * c, p.y * s - p.x * c);\n}\n\nvoid main() {\n float v = sqrt(vertexId / vertexCount);\n float t = v + 1.5;\n float i = mod(t, 1.0) * 1000.0;\n float s = sin(i * 6.0);\n float q = (2.0 + s * s * s) * pow(t, 5.5) / 2000.0;\n\n vec2 aspect = vec2(1.0, resolution.x / resolution.y);\n vec3 p = vec3(\n sin(i) * q,\n cos(i) * q,\n (1.0-sqrt(v))\n );\n\n p = vec3(rot(p.xy, time), p.z);\n p = vec3(p.x, rot(p.zy, 3.5+cos(time)/3.));\n p.xy *= aspect;\n p.y += .3;\n gl_Position = vec4(p, 1);\n\n float a = min(255.0, pow(t, 2.6) * 25.0) / 255.0;\n v_color = vec4(a, a * 1.5, t * t * 15.0 / 255.0, 1.0);\n gl_PointSize = 3.0;\n}\n" + }, "screenshotURL": "data/images/images-07om8jwk9kc6qd3b5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NYiqfuasX6PFoLoQr/art.json b/art/NYiqfuasX6PFoLoQr/art.json index fed61c20..3fed8b59 100644 --- a/art/NYiqfuasX6PFoLoQr/art.json +++ b/art/NYiqfuasX6PFoLoQr/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "morimea", "avatarUrl": "https://secure.gravatar.com/avatar/8ff4b4cacdf52d8d31a020cd244c5269?default=retro&size=200", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// number of triangles == pow(2,X)*6\\n// pow(2,2)*6=24\\n// pow(2,14)*6=98304\\n// pow(2,9)*6=3072 ...etc\\n// pow(2,6)*6=384 ...etc\\n\\n// comment for union\\n#define difference\\n\\n\\nfloat sdfDifference( const float a, const float b)\\n{\\n return max(a, -b);\\n}\\n\\nfloat sphereSDF(vec3 p, float r) {\\n return length(p) - r;\\n}\\n\\n\\nconst float pi = 3.1415926;\\nconst float degree_to_rad = pi / 180.0;\\n\\nvec3 phongContribForLight(vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye,\\n vec3 lightPos, vec3 lightIntensity, vec3 N) {\\n vec3 L = normalize(lightPos - p);\\n vec3 V = normalize(eye - p);\\n vec3 R = normalize(reflect(-L, N));\\n \\n float dotLN = dot(L, N);\\n float dotRV = dot(R, V);\\n \\n if (dotLN < 0.0) {\\n return vec3(0.0, 0.0, 0.0);\\n } \\n \\n if (dotRV < 0.0) {\\n return lightIntensity * (k_d * dotLN);\\n }\\n return lightIntensity * (k_d * dotLN + k_s * pow(dotRV, alpha));\\n}\\n\\nvec3 phongIllumination(vec3 k_a, vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 norm) {\\n const vec3 ambientLight = 0.5 * vec3(1.0, 1.0, 1.0);\\n vec3 color = ambientLight * k_a;\\n \\n vec3 light1Pos = normalize(vec3(mouse.x,mouse.y,.20))*5.;\\n vec3 light1Intensity = 5.*vec3(0.4, 0.4, 0.4);\\n \\n color += phongContribForLight(k_d, k_s, alpha, p, eye,\\n light1Pos,\\n light1Intensity, norm);\\n \\n return color;\\n}\\n\\nvec3 color_phong(vec3 p, vec3 ro, vec3 nor, vec3 col){\\n vec3 K_a = col;\\n vec3 K_d = K_a;\\n vec3 K_s = vec3(1.0, 1.0, 1.0);\\n float shininess = 12.0;\\n \\n col = phongIllumination(K_a, K_d, K_s, shininess, p, ro, nor);\\n return col;\\n}\\n\\n\\nvec3 basic_light(vec3 nor){\\n \\tvec3 li = normalize(vec3(0.5, 1.0, 1.0));\\n float dif = clamp(dot(nor, li), 0.0, 1.0);\\n float amb = max(0.5 + 0.5 * nor.y, 0.0);\\n \\tvec3 col = vec3(0.88);\\n \\treturn col*clamp(max(dif, 0.3) * amb, 0.0, 1.0);\\n}\\n\\nmat3 rotx(float a){float s = sin(a);float c = cos(a);return mat3(vec3(1.0, 0.0, 0.0), vec3(0.0, c, s), vec3(0.0, -s, c)); }\\nmat3 roty(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, 0.0, s), vec3(0.0, 1.0, 0.0), vec3(-s, 0.0, c));}\\nmat3 rotz(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0 ));}\\n\\n\\nmat4 rotXMatrix(float theta)\\n{\\n float cs = cos(theta);\\n float ss = sin(theta);\\n \\n mat4 result = \\n mat4(vec4(1.0, 0.0, 0.0, 0.0), \\n vec4(0.0, cs, -ss, 0.0),\\n vec4(0.0, ss, cs, 0.0),\\n vec4(0.0, 0.0, 0.0, 1.0) );\\n \\n return result;\\n}\\n\\nmat4 rotYMatrix(float theta)\\n{\\n float cs = cos(theta);\\n float ss = sin(theta);\\n \\n mat4 result = \\n mat4(vec4(cs, 0.0, -ss, 0.0), \\n vec4(0.0, 1.0, 0.0, 0.0),\\n vec4(ss, 0.0, cs, 0.0),\\n vec4(0.0, 0.0, 0.0, 1.0) );\\n \\n return result;\\n}\\n\\nmat4 perspectiveMatrix(float fovYInRad, float aspectRatio)\\n{\\n float yScale = 1.0 / tan(fovYInRad / 2.0);\\n float xScale = yScale / aspectRatio;\\n float zf = 100.0;\\n float zn = 0.3;\\n\\n float z1 = zf / (zf - zn);\\n float z2 = -zn * zf / (zf - zn);\\n\\n mat4 result = mat4(xScale, 0.0, 0.0, 0.0, 0.0, yScale, 0.0, 0.0, 0.0, 0.0, -z1, -1., 0.0, 0.0, z2, 0.0);\\n\\n return result;\\n}\\n\\nvec3 meshSqhere(in float id, in float split)\\n{\\n float d = split * 2.0;\\n float n = floor(id / 6.0);\\n vec2 q = vec2(mod(n, d), mod(floor(n / d), d));\\n vec2 a = q + 0.5 - split;\\n float s = sign(a.x * a.y);\\n float c = abs(3.0 - mod(id, 6.0));\\n vec2 uv = vec2(mod(c, 2.0), abs(step(0.0, s) - floor(c / 2.0)));\\n uv = floor(uv + q) / split - 1.0;\\n if (uv.x > abs(uv.y))\\n uv.y -= (uv.x - abs(uv.y)) * s;\\n if (-uv.x > abs(uv.y))\\n uv.y -= (uv.x + abs(uv.y)) * s;\\n if (uv.y > abs(uv.x))\\n uv.x -= (uv.y - abs(uv.x)) * s;\\n if (-uv.y > abs(uv.x))\\n uv.x -= (uv.y + abs(uv.x)) * s;\\n return normalize(vec3(uv, 0.8 * (1.0 - pow(max(abs(uv.x), abs(uv.y)), 2.0)) * s));\\n}\\n\\n\\n\\nfloat map(in vec3 p)\\n{\\n return sphereSDF(p,1.);\\n}\\n\\nvec3 calcNormal(in vec3 p)\\n{\\n vec2 e = vec2(1.0, -1.0) * 0.002;\\n return normalize(e.xyy * map(p + e.xyy) + e.yyx * map(p + e.yyx) + e.yxy * map(p + e.yxy) + e.xxx * map(p + e.xxx));\\n}\\n\\nvoid main()\\n{\\n \\tvec4 sphere1 = vec4(0.,0.,0.,1.);\\n\\tvec4 sphere2 = vec4(0.,.5,0.,1.);\\n \\n \\n mat4 pMatrix = perspectiveMatrix(45.0 * degree_to_rad, resolution.x / resolution.y);\\n mat4 vMatrix = mat4(1.0);\\n vMatrix[3].z += -3.5;\\n \\tvMatrix[3].xyz+=sphere1.xyz;\\n \\t\\n \\n float split = floor(sqrt(floor(vertexCount / 6.0)));\\n split = floor(split / 2.0);\\n vec3 p_smooth = meshSqhere(vertexId, split);\\n \\tvec3 p_flat = meshSqhere(floor(vertexId/3.)*3., split);\\n\\n vec3 nor_smooth = calcNormal(p_smooth);\\n \\tvec3 nor_flat = calcNormal(p_flat);\\n //vec3 col = basic_light(nor_smooth);\\n\\n \\tfloat d1=sphereSDF(p_smooth-sphere1.xyz,sphere1.w);\\n float d2=sphereSDF(p_smooth-sphere2.xyz,sphere2.w);\\n \\tfloat d=sdfDifference(d1,d2);\\n \\n \\n //sphere2\\n mat4 pMatrix2 = perspectiveMatrix(45.0 * degree_to_rad, resolution.x / resolution.y);\\n mat4 vMatrix2 = mat4(1.0);\\n vMatrix2[3].z += -3.5;\\n \\tvMatrix2[3].xyz+=sphere2.xyz;\\n #ifdef difference\\n vMatrix2*=rotYMatrix(1.*pi);\\n #endif\\n \\t\\n float split2 = floor(sqrt(floor(vertexCount / 6.0)));\\n split2 = floor(split2 / 2.0);\\n vec3 p_smooth2 = meshSqhere(vertexId, split2)*rotx(0.5);\\n \\tvec3 p_flat2 = meshSqhere(floor(vertexId/3.)*3., split2)*rotx(0.5);\\n #ifdef difference\\n p_smooth2*=-1.;\\n p_flat2*=-1.;\\n #endif\\n\\n vec3 nor_smooth2 = calcNormal(p_smooth2);\\n \\n /*\\n if(d>0.001){\\n gl_Position = pMatrix2 * vMatrix2 * vec4(p_smooth2, 1.0);\\n p_smooth=p_smooth2;\\n p_flat=p_flat2;\\n nor_smooth=nor_smooth2;\\n }\\n else {\\n gl_Position = pMatrix * vMatrix * vec4(p_smooth, 1.0);\\n }\\n */\\n \\n \\tgl_Position = pMatrix2 * vMatrix2 * vec4(p_smooth2, 1.0);\\n gl_Position = min(gl_Position,pMatrix * vMatrix * vec4(p_smooth, 1.0));\\n \\n \\tvec3 col=vec3(0.);\\n if(gl_Position.x<-.15){\\n vec3 nor = calcNormal(p_flat);\\n col=color_phong(p_flat,vec3(0.,0.,10.), nor, (nor_flat+1.)/2.);\\n col *= 0.65 + .35 * floor(mod(floor(vertexId / 3.), 2.));\\n }else{\\n vec3 nor = calcNormal(p_smooth);\\n col=color_phong(p_smooth,vec3(0.,0.,10.), nor, (nor_smooth+1.)/2.);\\n }\\n \\n \\n v_color = vec4(col, 1.0);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// number of triangles == pow(2,X)*6\n// pow(2,2)*6=24\n// pow(2,14)*6=98304\n// pow(2,9)*6=3072 ...etc\n// pow(2,6)*6=384 ...etc\n\n// comment for union\n#define difference\n\n\nfloat sdfDifference( const float a, const float b)\n{\n return max(a, -b);\n}\n\nfloat sphereSDF(vec3 p, float r) {\n return length(p) - r;\n}\n\n\nconst float pi = 3.1415926;\nconst float degree_to_rad = pi / 180.0;\n\nvec3 phongContribForLight(vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye,\n vec3 lightPos, vec3 lightIntensity, vec3 N) {\n vec3 L = normalize(lightPos - p);\n vec3 V = normalize(eye - p);\n vec3 R = normalize(reflect(-L, N));\n \n float dotLN = dot(L, N);\n float dotRV = dot(R, V);\n \n if (dotLN < 0.0) {\n return vec3(0.0, 0.0, 0.0);\n } \n \n if (dotRV < 0.0) {\n return lightIntensity * (k_d * dotLN);\n }\n return lightIntensity * (k_d * dotLN + k_s * pow(dotRV, alpha));\n}\n\nvec3 phongIllumination(vec3 k_a, vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 norm) {\n const vec3 ambientLight = 0.5 * vec3(1.0, 1.0, 1.0);\n vec3 color = ambientLight * k_a;\n \n vec3 light1Pos = normalize(vec3(mouse.x,mouse.y,.20))*5.;\n vec3 light1Intensity = 5.*vec3(0.4, 0.4, 0.4);\n \n color += phongContribForLight(k_d, k_s, alpha, p, eye,\n light1Pos,\n light1Intensity, norm);\n \n return color;\n}\n\nvec3 color_phong(vec3 p, vec3 ro, vec3 nor, vec3 col){\n vec3 K_a = col;\n vec3 K_d = K_a;\n vec3 K_s = vec3(1.0, 1.0, 1.0);\n float shininess = 12.0;\n \n col = phongIllumination(K_a, K_d, K_s, shininess, p, ro, nor);\n return col;\n}\n\n\nvec3 basic_light(vec3 nor){\n \tvec3 li = normalize(vec3(0.5, 1.0, 1.0));\n float dif = clamp(dot(nor, li), 0.0, 1.0);\n float amb = max(0.5 + 0.5 * nor.y, 0.0);\n \tvec3 col = vec3(0.88);\n \treturn col*clamp(max(dif, 0.3) * amb, 0.0, 1.0);\n}\n\nmat3 rotx(float a){float s = sin(a);float c = cos(a);return mat3(vec3(1.0, 0.0, 0.0), vec3(0.0, c, s), vec3(0.0, -s, c)); }\nmat3 roty(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, 0.0, s), vec3(0.0, 1.0, 0.0), vec3(-s, 0.0, c));}\nmat3 rotz(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0 ));}\n\n\nmat4 rotXMatrix(float theta)\n{\n float cs = cos(theta);\n float ss = sin(theta);\n \n mat4 result = \n mat4(vec4(1.0, 0.0, 0.0, 0.0), \n vec4(0.0, cs, -ss, 0.0),\n vec4(0.0, ss, cs, 0.0),\n vec4(0.0, 0.0, 0.0, 1.0) );\n \n return result;\n}\n\nmat4 rotYMatrix(float theta)\n{\n float cs = cos(theta);\n float ss = sin(theta);\n \n mat4 result = \n mat4(vec4(cs, 0.0, -ss, 0.0), \n vec4(0.0, 1.0, 0.0, 0.0),\n vec4(ss, 0.0, cs, 0.0),\n vec4(0.0, 0.0, 0.0, 1.0) );\n \n return result;\n}\n\nmat4 perspectiveMatrix(float fovYInRad, float aspectRatio)\n{\n float yScale = 1.0 / tan(fovYInRad / 2.0);\n float xScale = yScale / aspectRatio;\n float zf = 100.0;\n float zn = 0.3;\n\n float z1 = zf / (zf - zn);\n float z2 = -zn * zf / (zf - zn);\n\n mat4 result = mat4(xScale, 0.0, 0.0, 0.0, 0.0, yScale, 0.0, 0.0, 0.0, 0.0, -z1, -1., 0.0, 0.0, z2, 0.0);\n\n return result;\n}\n\nvec3 meshSqhere(in float id, in float split)\n{\n float d = split * 2.0;\n float n = floor(id / 6.0);\n vec2 q = vec2(mod(n, d), mod(floor(n / d), d));\n vec2 a = q + 0.5 - split;\n float s = sign(a.x * a.y);\n float c = abs(3.0 - mod(id, 6.0));\n vec2 uv = vec2(mod(c, 2.0), abs(step(0.0, s) - floor(c / 2.0)));\n uv = floor(uv + q) / split - 1.0;\n if (uv.x > abs(uv.y))\n uv.y -= (uv.x - abs(uv.y)) * s;\n if (-uv.x > abs(uv.y))\n uv.y -= (uv.x + abs(uv.y)) * s;\n if (uv.y > abs(uv.x))\n uv.x -= (uv.y - abs(uv.x)) * s;\n if (-uv.y > abs(uv.x))\n uv.x -= (uv.y + abs(uv.x)) * s;\n return normalize(vec3(uv, 0.8 * (1.0 - pow(max(abs(uv.x), abs(uv.y)), 2.0)) * s));\n}\n\n\n\nfloat map(in vec3 p)\n{\n return sphereSDF(p,1.);\n}\n\nvec3 calcNormal(in vec3 p)\n{\n vec2 e = vec2(1.0, -1.0) * 0.002;\n return normalize(e.xyy * map(p + e.xyy) + e.yyx * map(p + e.yyx) + e.yxy * map(p + e.yxy) + e.xxx * map(p + e.xxx));\n}\n\nvoid main()\n{\n \tvec4 sphere1 = vec4(0.,0.,0.,1.);\n\tvec4 sphere2 = vec4(0.,.5,0.,1.);\n \n \n mat4 pMatrix = perspectiveMatrix(45.0 * degree_to_rad, resolution.x / resolution.y);\n mat4 vMatrix = mat4(1.0);\n vMatrix[3].z += -3.5;\n \tvMatrix[3].xyz+=sphere1.xyz;\n \t\n \n float split = floor(sqrt(floor(vertexCount / 6.0)));\n split = floor(split / 2.0);\n vec3 p_smooth = meshSqhere(vertexId, split);\n \tvec3 p_flat = meshSqhere(floor(vertexId/3.)*3., split);\n\n vec3 nor_smooth = calcNormal(p_smooth);\n \tvec3 nor_flat = calcNormal(p_flat);\n //vec3 col = basic_light(nor_smooth);\n\n \tfloat d1=sphereSDF(p_smooth-sphere1.xyz,sphere1.w);\n float d2=sphereSDF(p_smooth-sphere2.xyz,sphere2.w);\n \tfloat d=sdfDifference(d1,d2);\n \n \n //sphere2\n mat4 pMatrix2 = perspectiveMatrix(45.0 * degree_to_rad, resolution.x / resolution.y);\n mat4 vMatrix2 = mat4(1.0);\n vMatrix2[3].z += -3.5;\n \tvMatrix2[3].xyz+=sphere2.xyz;\n #ifdef difference\n vMatrix2*=rotYMatrix(1.*pi);\n #endif\n \t\n float split2 = floor(sqrt(floor(vertexCount / 6.0)));\n split2 = floor(split2 / 2.0);\n vec3 p_smooth2 = meshSqhere(vertexId, split2)*rotx(0.5);\n \tvec3 p_flat2 = meshSqhere(floor(vertexId/3.)*3., split2)*rotx(0.5);\n #ifdef difference\n p_smooth2*=-1.;\n p_flat2*=-1.;\n #endif\n\n vec3 nor_smooth2 = calcNormal(p_smooth2);\n \n /*\n if(d>0.001){\n gl_Position = pMatrix2 * vMatrix2 * vec4(p_smooth2, 1.0);\n p_smooth=p_smooth2;\n p_flat=p_flat2;\n nor_smooth=nor_smooth2;\n }\n else {\n gl_Position = pMatrix * vMatrix * vec4(p_smooth, 1.0);\n }\n */\n \n \tgl_Position = pMatrix2 * vMatrix2 * vec4(p_smooth2, 1.0);\n gl_Position = min(gl_Position,pMatrix * vMatrix * vec4(p_smooth, 1.0));\n \n \tvec3 col=vec3(0.);\n if(gl_Position.x<-.15){\n vec3 nor = calcNormal(p_flat);\n col=color_phong(p_flat,vec3(0.,0.,10.), nor, (nor_flat+1.)/2.);\n col *= 0.65 + .35 * floor(mod(floor(vertexId / 3.), 2.));\n }else{\n vec3 nor = calcNormal(p_smooth);\n col=color_phong(p_smooth,vec3(0.,0.,10.), nor, (nor_smooth+1.)/2.);\n }\n \n \n v_color = vec4(col, 1.0);\n}" + }, "screenshotURL": "data/images/images-ip6tbvgojtbqp91jt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NZXTQnoGoqztxfJDm/art.json b/art/NZXTQnoGoqztxfJDm/art.json index b0216dc4..1a638328 100644 --- a/art/NZXTQnoGoqztxfJDm/art.json +++ b/art/NZXTQnoGoqztxfJDm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 01.00) + 90.00;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 01.00) + 90.00;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-vrybjvc9nvdfejo54-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NZyPJxqb9KngCnPmj/art.json b/art/NZyPJxqb9KngCnPmj/art.json index 430d8635..68ac7832 100644 --- a/art/NZyPJxqb9KngCnPmj/art.json +++ b/art/NZyPJxqb9KngCnPmj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "keyu", "avatarUrl": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/photo.jpg", - "settings": "{\"num\":3111,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float x = vertexId;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect +0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 3111, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float x = vertexId;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect +0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-0apd08t6z0r337qou-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Nd7RLTNMwo9xcqBgZ/art.json b/art/Nd7RLTNMwo9xcqBgZ/art.json index 7393b1c6..58355301 100644 --- a/art/Nd7RLTNMwo9xcqBgZ/art.json +++ b/art/Nd7RLTNMwo9xcqBgZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46283.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n\\n//precision mediump float;\\n\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\nvec2 R = vertexResolution;\\nvec2 Offset;\\nvec2 Scale=vec2(0.001,0.002);\\nfloat Saturation = 0.8; // 0 - 1;\\n\\n\\nvec3 lungth(vec2 x,vec3 c){\\n return vec3(length(x+c.r),length(x+c.g),length(c.b));\\n}\\n\\nvoid main( void ) {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n\\t\\n\\tvec2 position = (simFragCoord.xy - vertexResolution * .5) / vertexResolution.yy;\\n\\tfloat th = atan(position.y, position.x) / (1.0 * 3.1415926);\\n\\tfloat dd = length(position) + 0.005;\\n\\tfloat d = 0.5 / dd + time;\\n\\t\\n \\tvec2 x2 = simFragCoord.xy;\\n \\tx2=x2*Scale*R/R.x;\\n \\tx2+sin(x2.yx*sqrt(vec2(1,9)))/1.;\\n\\tx2+=sin(x2.yx*sqrt(vec2(73,5)))/5.;\\n \\tx2+=sin(x2.yx*sqrt(vec2(93,7)))/3.;\\n\\t\\n\\tvec3 uv = vec3(th + d, th - d, th + sin(d) * 0.45);\\n\\tfloat a = 0.5 + cos(uv.x * 3.1415926 * 2.0) * 0.5;\\n\\tfloat b = 0.5 + cos(uv.y * 3.1415926 * 2.0) * 0.5;\\n\\tfloat c = 0.5 + cos(uv.z * 3.1415926 * 6.0) * 0.5;\\n\\tvec3 color = \\tmix(vec3(0.1, 0.5, 0.5), \\tvec3(0.1, 0.1, 0.2), pow(a, 0.2)) * 3.;\\n\\tcolor += \\tmix(vec3(0.8, 0.2, 1.0), \\tvec3(0.1, 0.1, 0.2), pow(b, 0.1)) * 0.75;\\n\\t//color += \\tmix(c2, \\t\\t\\tvec3(0.1, 0.2, 0.2), pow(c, 0.1)) * 0.75;\\n\\n\\tv_color = vec4( (color * dd), 1.0);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46283.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n\n//precision mediump float;\n\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\nvec2 R = vertexResolution;\nvec2 Offset;\nvec2 Scale=vec2(0.001,0.002);\nfloat Saturation = 0.8; // 0 - 1;\n\n\nvec3 lungth(vec2 x,vec3 c){\n return vec3(length(x+c.r),length(x+c.g),length(c.b));\n}\n\nvoid main( void ) {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n\t\n\tvec2 position = (simFragCoord.xy - vertexResolution * .5) / vertexResolution.yy;\n\tfloat th = atan(position.y, position.x) / (1.0 * 3.1415926);\n\tfloat dd = length(position) + 0.005;\n\tfloat d = 0.5 / dd + time;\n\t\n \tvec2 x2 = simFragCoord.xy;\n \tx2=x2*Scale*R/R.x;\n \tx2+sin(x2.yx*sqrt(vec2(1,9)))/1.;\n\tx2+=sin(x2.yx*sqrt(vec2(73,5)))/5.;\n \tx2+=sin(x2.yx*sqrt(vec2(93,7)))/3.;\n\t\n\tvec3 uv = vec3(th + d, th - d, th + sin(d) * 0.45);\n\tfloat a = 0.5 + cos(uv.x * 3.1415926 * 2.0) * 0.5;\n\tfloat b = 0.5 + cos(uv.y * 3.1415926 * 2.0) * 0.5;\n\tfloat c = 0.5 + cos(uv.z * 3.1415926 * 6.0) * 0.5;\n\tvec3 color = \tmix(vec3(0.1, 0.5, 0.5), \tvec3(0.1, 0.1, 0.2), pow(a, 0.2)) * 3.;\n\tcolor += \tmix(vec3(0.8, 0.2, 1.0), \tvec3(0.1, 0.1, 0.2), pow(b, 0.1)) * 0.75;\n\t//color += \tmix(c2, \t\t\tvec3(0.1, 0.2, 0.2), pow(c, 0.1)) * 0.75;\n\n\tv_color = vec4( (color * dd), 1.0);\n}" + }, "screenshotURL": "data/images/images-yq7e5jsrccm6qx4oh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NdqnSLhc6EZ67TXkP/art.json b/art/NdqnSLhc6EZ67TXkP/art.json index c525ff23..9bccd9b6 100644 --- a/art/NdqnSLhc6EZ67TXkP/art.json +++ b/art/NdqnSLhc6EZ67TXkP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "floppafilms google emails", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocIuaBwUR9c6Zno3BImNS0s8sMlZcGj0gBrDxanr22L0IECUEO0=s96-c", - "settings": "{\"num\":1024,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/user-458550313/whats-up\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat2 rot(float a) {\\n float s=sin(a), c=cos(a);\\n return mat2(c,s,-s,c);\\n}\\n\\nvoid main() {\\n float a = 4. * 6.283185307179586 * vertexId / vertexCount;\\n \\n float r = 3.25;\\n float s = texture2D(sound, vec2(mix(0.01, 0.02, 0.03), 0.)).a;\\n vec2 off = vec2(0.5 * sin(r*a) + 1., cos(r*a));\\n vec3 p = vec3(sin(a), 1, cos(a)) * off.xyx;\\n \\n p.xz *= rot(time);\\n p.yz *= rot(0.8);\\n \\n gl_Position = vec4(p/(p.z+3.), 1);\\n v_color = vec4(1./(p.z+2.),s,0,1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/user-458550313/whats-up", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat2 rot(float a) {\n float s=sin(a), c=cos(a);\n return mat2(c,s,-s,c);\n}\n\nvoid main() {\n float a = 4. * 6.283185307179586 * vertexId / vertexCount;\n \n float r = 3.25;\n float s = texture2D(sound, vec2(mix(0.01, 0.02, 0.03), 0.)).a;\n vec2 off = vec2(0.5 * sin(r*a) + 1., cos(r*a));\n vec3 p = vec3(sin(a), 1, cos(a)) * off.xyx;\n \n p.xz *= rot(time);\n p.yz *= rot(0.8);\n \n gl_Position = vec4(p/(p.z+3.), 1);\n v_color = vec4(1./(p.z+2.),s,0,1);\n}" + }, "screenshotURL": "data/images/images-xi7z5ypu2r43cz2zz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ndrs3aeC35272f5ku/art.json b/art/Ndrs3aeC35272f5ku/art.json index 6be8440a..d4a5ce6c 100644 --- a/art/Ndrs3aeC35272f5ku/art.json +++ b/art/Ndrs3aeC35272f5ku/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\nvec2 project(vec2 position, vec2 a, vec2 b);\\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n\\tfor(int i = 0; i < 48; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\tb += box(p, vec2(.5));\\n\\t\\tt += triangle(p, vec2(.5));\\n\\t\\tp *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\t\\n\\t//gl_FragColor = result;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = result;\\n \\n\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.73205080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t*= .86602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(t);\\n\\treturn mat2(c, s, -s, c);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\nvec2 project(vec2 position, vec2 a, vec2 b);\nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n\tfor(int i = 0; i < 48; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\tb += box(p, vec2(.5));\n\t\tt += triangle(p, vec2(.5));\n\t\tp *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\t\n\t//gl_FragColor = result;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = result;\n \n\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.73205080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t*= .86602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(t);\n\treturn mat2(c, s, -s, c);\n}\n" + }, "screenshotURL": "data/images/images-q9384dy8uz7uqda4d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NeGB5oyRfmeMmWodT/art.json b/art/NeGB5oyRfmeMmWodT/art.json index a64e2d37..479c2141 100644 --- a/art/NeGB5oyRfmeMmWodT/art.json +++ b/art/NeGB5oyRfmeMmWodT/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":12200,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ihsanozturk/kruder-dorfmeister-liquid-acid\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + .3, 3.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 1000.0;\\n \\n float pump = step(0.1, snd);\\n float hue = u * 0.2 + snd + sin(0.9); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.3, .8, pump);\\n float val = mix(0.6, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 12200, + "mode": "POINTS", + "sound": "https://soundcloud.com/ihsanozturk/kruder-dorfmeister-liquid-acid", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + .3, 3.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 1000.0;\n \n float pump = step(0.1, snd);\n float hue = u * 0.2 + snd + sin(0.9); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.3, .8, pump);\n float val = mix(0.6, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-9zzexce5pbt62hq8z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NfQPZoWHTBFY7AKy5/art.json b/art/NfQPZoWHTBFY7AKy5/art.json index 6c653e23..c149102e 100644 --- a/art/NfQPZoWHTBFY7AKy5/art.json +++ b/art/NfQPZoWHTBFY7AKy5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES\\n#define parameter0 1.//KParameter0 0.>>5.\\n#define parameter1 0.4//KParameter1 0.>>5.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>1.\\n#define parameter4 1.//KParameter4 0.>>2.\\n#define parameter5 1.//KParameter5 0.>>2.\\n#define parameter6 0.3//KParameter6 0.1>>0.4\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n#define kCubeVertexCount 36.0\\n\\nvec3 shapeVertex(float _vid, out vec4 _ni, float _factor) {\\n float faceId = floor(_vid / 6.0);\\n float vtxId = mod(_vid, 6.0);\\n vec2 fp;\\n vec3 p;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n // front\\n p = vec3(fp.x, fp.y, _factor);\\n _ni = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n // back\\n p = vec3(-fp.x, fp.y, -1.0);\\n _ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n // top\\n p = vec3(fp.x, 1.0, -fp.y);\\n _ni = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n // bottom\\n p = vec3(fp.x, -1.0, fp.y);\\n _ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n // right\\n p = vec3(-1.0, fp.y, -fp.x);\\n _ni = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n // left\\n p = vec3(1.0, fp.y, fp.x);\\n _ni = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return p;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\n\\n#define elementPerShape 12.\\n\\n\\nvec3 getShapeKVector(float _vertexId, float _junctionY, float _secondVertY, float _barWidth)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n if(_vertexId<1.)\\n {\\n result.xy = vec2(0.,0.);\\n }\\n else\\n \\n if(_vertexId<2.)\\n {\\n result.xy = vec2(0.,1.);\\n }\\n \\n else\\n if(_vertexId<3.)\\n {\\n result.xy = vec2(_barWidth,1.);\\n }\\n else //2nd triangle\\n if(vertexId<4.)\\n {\\n result.xy = vec2(0.,0.0);\\n }\\n else\\n if(_vertexId<5.)\\n {\\n result.xy = vec2(_barWidth,1.);\\n }\\n else\\n if(_vertexId<6.)\\n {\\n result.xy = vec2(_barWidth,0.);//PROBLEM !!\\n }\\n else\\n if(_vertexId<7.)//3 eme triangle\\n {\\n result.xy = vec2(_barWidth,_junctionY);\\n }\\n else\\n if(_vertexId<8.)\\n {\\n result.xy = vec2((_secondVertY+_barWidth),1.);\\n }\\n else\\n if(_vertexId<9.)\\n {\\n result.xy = vec2(_secondVertY,1.);\\n \\n }\\n \\n else\\n if(_vertexId<10.)//4eme triangle\\n {\\n result.xy = vec2(_barWidth,_junctionY);\\n \\n }\\n else\\n if(_vertexId<11.)\\n {\\n result.xy = vec2((_secondVertY+_barWidth),0.);\\n \\n }\\n \\n else\\n if(_vertexId<12.)\\n {\\n result.xy = vec2(_secondVertY,0.);\\n \\n }\\n \\n return result;\\n}\\n\\n#define elementPerTriangleShape 3.\\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n \\n float localVertexId = mod(_vertexId, elementPerTriangleShape);\\n \\n \\n float localAngle = localVertexId*2.*PI/elementPerTriangleShape;\\n //result.xy = _center+_radius*vec2(cos(localAngle),sin(localAngle));\\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\\n result = rotZ(result,_angle);\\n result.xy+=_center.xy;\\n return result;\\n}\\n\\nvec3 getTriangleCircle(float _vertexId, vec2 _center, float _radius, float _numberOfElements, float _triangleSize, float _rotationAngleRad, float _cosFactor, float _sinFactor)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n //triangle index\\n float shapeId = floor(_vertexId/elementPerTriangleShape);\\n \\n \\n //index of the vertex in the triangle\\n float localVertexId = mod(_vertexId, elementPerTriangleShape);\\n \\n float relShapeId = shapeId/_numberOfElements;\\n \\n float trianglePosAngle = relShapeId*(2.*PI)+_rotationAngleRad;\\n \\n vec2 trianglePos = vec2(_center.x+_radius*_cosFactor*cos(trianglePosAngle), _center.y+_radius*_sinFactor*sin(trianglePosAngle));\\n \\n result = getTriangle(localVertexId, trianglePos, _triangleSize, trianglePosAngle);\\n \\n return result;\\n}\\n\\n\\nvec3 getTriangleLimitedCircle(float _vertexId, vec2 _center, float _radius, float _numberOfElements, float _triangleSize, float _rotationAngleRad, float _startAngle, float _endAngle, float _cosFactor, float _sinFactor)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n //triangle index\\n float shapeId = floor(_vertexId/elementPerTriangleShape);\\n \\n \\n //index of the vertex in the triangle\\n float localVertexId = mod(_vertexId, elementPerTriangleShape);\\n \\n float relShapeId = shapeId/_numberOfElements;\\n \\n //float trianglePosAngle = relShapeId*(2.*PI)+_rotationAngleRad;\\n \\n //angle must be between _startAngle and _endAngle\\n float trianglePosAngle = _startAngle+relShapeId*(_endAngle-_startAngle)+_rotationAngleRad;\\n \\n vec2 trianglePos = vec2(_center.x+_radius*_cosFactor*cos(trianglePosAngle), _center.y+_radius*_sinFactor*1.*sin(trianglePosAngle));\\n \\n //vec2 trianglePos = vec2(relShapeId*10.,0.);\\n //result.xy = trianglePos;//getTriangle(localVertexId, trianglePos, 0.02, trianglePosAngle);\\n result = getTriangle(localVertexId, trianglePos, _triangleSize, trianglePosAngle+PI/2.);\\n \\n return result;\\n}\\n\\n#define shapeNumForEye 20.\\n#define shapeNumForMouth 20.\\n#define shapeNumForHead 40.\\n#define shapeNumForPupil 1.\\n#define shapeNumForEar 30.\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n float vertu = (vertexId/vertexCount);\\n \\n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\\n \\n float eyesY = 0.3;\\n float eye1X = 0.35;\\n \\n float earsY = 0.4;\\n float ear1X = 0.85;\\n \\n float mouthY = -0.3;\\n vec2 center = vec2(-0.5,eyesY);\\n \\n vec3 _v = vec3(0.,0.,0.);\\n \\n \\n float vertexCount = 0.;\\n \\n float stopVerticesForEye1 = shapeNumForEye*elementPerTriangleShape;\\n float stopVerticesForEye2 = stopVerticesForEye1+shapeNumForEye*elementPerTriangleShape;\\n float stopVerticesForMouth = stopVerticesForEye2+shapeNumForMouth*elementPerTriangleShape;\\n float stopVerticesForHead = stopVerticesForMouth+shapeNumForHead*elementPerTriangleShape;\\n float stopVerticesForPupil1 = stopVerticesForHead+shapeNumForPupil*elementPerTriangleShape;\\n float stopVerticesForPupil2 = stopVerticesForPupil1+shapeNumForPupil*elementPerTriangleShape;\\n \\n float stopVerticesForEar1 = stopVerticesForPupil2+shapeNumForEar*elementPerTriangleShape;\\n float stopVerticesForEar2 = stopVerticesForEar1+shapeNumForEar*elementPerTriangleShape;\\n \\n float numberOfTriangles = 20.;\\n if(vertexId< stopVerticesForEye1)//1 eye\\n {\\n center = vec2(-eye1X,eyesY);\\n _v = getTriangleCircle(vertexId, center, 0.15, shapeNumForEye, 0.05+sndFactor/50., time, parameter4*cos(time), parameter4*cos(time));\\n \\n }\\n else//2nd eye\\n if(vertexId< stopVerticesForEye2)\\n {\\n center = vec2(eye1X,eyesY);\\n _v = getTriangleCircle(vertexId, center, 0.15, shapeNumForEye, 0.05+sndFactor/50., -time, parameter5*sin(time), parameter5*sin(time));\\n \\n }\\n else//mouth\\n if(vertexId< stopVerticesForMouth)\\n {\\n //mouth\\n center = vec2(0.,mouthY);\\n //numberOfTriangles = 20.;\\n //_v = getTriangleLimitedCircle(vertexId-stopVerticesForEye2, center, 0.4, shapeNumForMouth, 0.02+sndFactor/10., 0., PI, 2.*PI, parameter2, parameter3);\\n _v = getTriangleCircle(vertexId, center, 0.25, shapeNumForMouth, 0.05+sndFactor/50., 7.*time, parameter0, parameter1*cos(time));\\n }\\n \\n else\\n if(vertexId< stopVerticesForHead)\\n {\\n \\n center = vec2(0.,0.);\\n //numberOfTriangles = 100.;\\n _v = getTriangleLimitedCircle(vertexId, center, 0.8, shapeNumForEye, 0.01+sndFactor/10., time, PI, 2.*PI, 1.,1.);\\n }\\n else\\n if(vertexId< stopVerticesForPupil1)\\n {\\n \\n center = vec2(eye1X,eyesY);\\n //numberOfTriangles = 100.;\\n //_v = getTriangleLimitedCircle(vertexId, center, 0., shapeNumForPupil, 0.02, time, PI, 2.*PI, parameter6, parameter7);\\n _v = getTriangleCircle(vertexId, center, 0.0, shapeNumForEye, 0.03+sndFactor/50., 7.*time, 1., parameter5);\\n }\\n else\\n if(vertexId< stopVerticesForPupil2)\\n {\\n \\n center = vec2(-eye1X,eyesY);\\n //numberOfTriangles = 100.;\\n //_v = getTriangleLimitedCircle(vertexId, center, 0., shapeNumForPupil, 0.02, time, PI, 2.*PI, parameter6, parameter7);\\n _v = getTriangleCircle(vertexId, center, 0.0, shapeNumForEye, 0.03+sndFactor/50., -5.*time, 1., parameter5);\\n }\\n else\\n if(vertexId< stopVerticesForEar1)\\n {\\n \\n center = vec2(ear1X+parameter6/2.,earsY);\\n _v = getTriangleCircle(vertexId, center, parameter6, shapeNumForEar, 0.05+sndFactor/50., 5.*time, 1., parameter7);\\n }\\n else\\n if(vertexId< stopVerticesForEar2)\\n {\\n \\n center = vec2(-ear1X-parameter6/2.,earsY);\\n _v = getTriangleCircle(vertexId, center, parameter6, shapeNumForEar, 0.05+sndFactor/50., -5.*time, 1., parameter7);\\n }\\n _v.x*=resolution.y/resolution.x;\\n gl_Position = vec4(_v, 1.);\\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES\n#define parameter0 1.//KParameter0 0.>>5.\n#define parameter1 0.4//KParameter1 0.>>5.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>1.\n#define parameter4 1.//KParameter4 0.>>2.\n#define parameter5 1.//KParameter5 0.>>2.\n#define parameter6 0.3//KParameter6 0.1>>0.4\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n#define kCubeVertexCount 36.0\n\nvec3 shapeVertex(float _vid, out vec4 _ni, float _factor) {\n float faceId = floor(_vid / 6.0);\n float vtxId = mod(_vid, 6.0);\n vec2 fp;\n vec3 p;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n // front\n p = vec3(fp.x, fp.y, _factor);\n _ni = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n // back\n p = vec3(-fp.x, fp.y, -1.0);\n _ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n // top\n p = vec3(fp.x, 1.0, -fp.y);\n _ni = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n // bottom\n p = vec3(fp.x, -1.0, fp.y);\n _ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 4.0) {\n // right\n p = vec3(-1.0, fp.y, -fp.x);\n _ni = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n // left\n p = vec3(1.0, fp.y, fp.x);\n _ni = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return p;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\n\n#define elementPerShape 12.\n\n\nvec3 getShapeKVector(float _vertexId, float _junctionY, float _secondVertY, float _barWidth)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n if(_vertexId<1.)\n {\n result.xy = vec2(0.,0.);\n }\n else\n \n if(_vertexId<2.)\n {\n result.xy = vec2(0.,1.);\n }\n \n else\n if(_vertexId<3.)\n {\n result.xy = vec2(_barWidth,1.);\n }\n else //2nd triangle\n if(vertexId<4.)\n {\n result.xy = vec2(0.,0.0);\n }\n else\n if(_vertexId<5.)\n {\n result.xy = vec2(_barWidth,1.);\n }\n else\n if(_vertexId<6.)\n {\n result.xy = vec2(_barWidth,0.);//PROBLEM !!\n }\n else\n if(_vertexId<7.)//3 eme triangle\n {\n result.xy = vec2(_barWidth,_junctionY);\n }\n else\n if(_vertexId<8.)\n {\n result.xy = vec2((_secondVertY+_barWidth),1.);\n }\n else\n if(_vertexId<9.)\n {\n result.xy = vec2(_secondVertY,1.);\n \n }\n \n else\n if(_vertexId<10.)//4eme triangle\n {\n result.xy = vec2(_barWidth,_junctionY);\n \n }\n else\n if(_vertexId<11.)\n {\n result.xy = vec2((_secondVertY+_barWidth),0.);\n \n }\n \n else\n if(_vertexId<12.)\n {\n result.xy = vec2(_secondVertY,0.);\n \n }\n \n return result;\n}\n\n#define elementPerTriangleShape 3.\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n \n float localVertexId = mod(_vertexId, elementPerTriangleShape);\n \n \n float localAngle = localVertexId*2.*PI/elementPerTriangleShape;\n //result.xy = _center+_radius*vec2(cos(localAngle),sin(localAngle));\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\n result = rotZ(result,_angle);\n result.xy+=_center.xy;\n return result;\n}\n\nvec3 getTriangleCircle(float _vertexId, vec2 _center, float _radius, float _numberOfElements, float _triangleSize, float _rotationAngleRad, float _cosFactor, float _sinFactor)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n //triangle index\n float shapeId = floor(_vertexId/elementPerTriangleShape);\n \n \n //index of the vertex in the triangle\n float localVertexId = mod(_vertexId, elementPerTriangleShape);\n \n float relShapeId = shapeId/_numberOfElements;\n \n float trianglePosAngle = relShapeId*(2.*PI)+_rotationAngleRad;\n \n vec2 trianglePos = vec2(_center.x+_radius*_cosFactor*cos(trianglePosAngle), _center.y+_radius*_sinFactor*sin(trianglePosAngle));\n \n result = getTriangle(localVertexId, trianglePos, _triangleSize, trianglePosAngle);\n \n return result;\n}\n\n\nvec3 getTriangleLimitedCircle(float _vertexId, vec2 _center, float _radius, float _numberOfElements, float _triangleSize, float _rotationAngleRad, float _startAngle, float _endAngle, float _cosFactor, float _sinFactor)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n //triangle index\n float shapeId = floor(_vertexId/elementPerTriangleShape);\n \n \n //index of the vertex in the triangle\n float localVertexId = mod(_vertexId, elementPerTriangleShape);\n \n float relShapeId = shapeId/_numberOfElements;\n \n //float trianglePosAngle = relShapeId*(2.*PI)+_rotationAngleRad;\n \n //angle must be between _startAngle and _endAngle\n float trianglePosAngle = _startAngle+relShapeId*(_endAngle-_startAngle)+_rotationAngleRad;\n \n vec2 trianglePos = vec2(_center.x+_radius*_cosFactor*cos(trianglePosAngle), _center.y+_radius*_sinFactor*1.*sin(trianglePosAngle));\n \n //vec2 trianglePos = vec2(relShapeId*10.,0.);\n //result.xy = trianglePos;//getTriangle(localVertexId, trianglePos, 0.02, trianglePosAngle);\n result = getTriangle(localVertexId, trianglePos, _triangleSize, trianglePosAngle+PI/2.);\n \n return result;\n}\n\n#define shapeNumForEye 20.\n#define shapeNumForMouth 20.\n#define shapeNumForHead 40.\n#define shapeNumForPupil 1.\n#define shapeNumForEar 30.\n\nvoid main() {\n \n vec3 color = vec3(1.);\n float vertu = (vertexId/vertexCount);\n \n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\n \n float eyesY = 0.3;\n float eye1X = 0.35;\n \n float earsY = 0.4;\n float ear1X = 0.85;\n \n float mouthY = -0.3;\n vec2 center = vec2(-0.5,eyesY);\n \n vec3 _v = vec3(0.,0.,0.);\n \n \n float vertexCount = 0.;\n \n float stopVerticesForEye1 = shapeNumForEye*elementPerTriangleShape;\n float stopVerticesForEye2 = stopVerticesForEye1+shapeNumForEye*elementPerTriangleShape;\n float stopVerticesForMouth = stopVerticesForEye2+shapeNumForMouth*elementPerTriangleShape;\n float stopVerticesForHead = stopVerticesForMouth+shapeNumForHead*elementPerTriangleShape;\n float stopVerticesForPupil1 = stopVerticesForHead+shapeNumForPupil*elementPerTriangleShape;\n float stopVerticesForPupil2 = stopVerticesForPupil1+shapeNumForPupil*elementPerTriangleShape;\n \n float stopVerticesForEar1 = stopVerticesForPupil2+shapeNumForEar*elementPerTriangleShape;\n float stopVerticesForEar2 = stopVerticesForEar1+shapeNumForEar*elementPerTriangleShape;\n \n float numberOfTriangles = 20.;\n if(vertexId< stopVerticesForEye1)//1 eye\n {\n center = vec2(-eye1X,eyesY);\n _v = getTriangleCircle(vertexId, center, 0.15, shapeNumForEye, 0.05+sndFactor/50., time, parameter4*cos(time), parameter4*cos(time));\n \n }\n else//2nd eye\n if(vertexId< stopVerticesForEye2)\n {\n center = vec2(eye1X,eyesY);\n _v = getTriangleCircle(vertexId, center, 0.15, shapeNumForEye, 0.05+sndFactor/50., -time, parameter5*sin(time), parameter5*sin(time));\n \n }\n else//mouth\n if(vertexId< stopVerticesForMouth)\n {\n //mouth\n center = vec2(0.,mouthY);\n //numberOfTriangles = 20.;\n //_v = getTriangleLimitedCircle(vertexId-stopVerticesForEye2, center, 0.4, shapeNumForMouth, 0.02+sndFactor/10., 0., PI, 2.*PI, parameter2, parameter3);\n _v = getTriangleCircle(vertexId, center, 0.25, shapeNumForMouth, 0.05+sndFactor/50., 7.*time, parameter0, parameter1*cos(time));\n }\n \n else\n if(vertexId< stopVerticesForHead)\n {\n \n center = vec2(0.,0.);\n //numberOfTriangles = 100.;\n _v = getTriangleLimitedCircle(vertexId, center, 0.8, shapeNumForEye, 0.01+sndFactor/10., time, PI, 2.*PI, 1.,1.);\n }\n else\n if(vertexId< stopVerticesForPupil1)\n {\n \n center = vec2(eye1X,eyesY);\n //numberOfTriangles = 100.;\n //_v = getTriangleLimitedCircle(vertexId, center, 0., shapeNumForPupil, 0.02, time, PI, 2.*PI, parameter6, parameter7);\n _v = getTriangleCircle(vertexId, center, 0.0, shapeNumForEye, 0.03+sndFactor/50., 7.*time, 1., parameter5);\n }\n else\n if(vertexId< stopVerticesForPupil2)\n {\n \n center = vec2(-eye1X,eyesY);\n //numberOfTriangles = 100.;\n //_v = getTriangleLimitedCircle(vertexId, center, 0., shapeNumForPupil, 0.02, time, PI, 2.*PI, parameter6, parameter7);\n _v = getTriangleCircle(vertexId, center, 0.0, shapeNumForEye, 0.03+sndFactor/50., -5.*time, 1., parameter5);\n }\n else\n if(vertexId< stopVerticesForEar1)\n {\n \n center = vec2(ear1X+parameter6/2.,earsY);\n _v = getTriangleCircle(vertexId, center, parameter6, shapeNumForEar, 0.05+sndFactor/50., 5.*time, 1., parameter7);\n }\n else\n if(vertexId< stopVerticesForEar2)\n {\n \n center = vec2(-ear1X-parameter6/2.,earsY);\n _v = getTriangleCircle(vertexId, center, parameter6, shapeNumForEar, 0.05+sndFactor/50., -5.*time, 1., parameter7);\n }\n _v.x*=resolution.y/resolution.x;\n gl_Position = vec4(_v, 1.);\n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-6097xa50kdr0vu9b4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NfsvpqNHppMHhscah/art.json b/art/NfsvpqNHppMHhscah/art.json index 34091ce3..1ef046ef 100644 --- a/art/NfsvpqNHppMHhscah/art.json +++ b/art/NfsvpqNHppMHhscah/art.json @@ -20,7 +20,19 @@ }, "private": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 5.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 5.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-dhe5saqbwjgjn2n7n-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NhWzyi4RTkjqEik5t/art.json b/art/NhWzyi4RTkjqEik5t/art.json index 7438d314..ab31dd17 100644 --- a/art/NhWzyi4RTkjqEik5t/art.json +++ b/art/NhWzyi4RTkjqEik5t/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/drumcomplex-junglism-master-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nWait for the music to pump \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 14.;\\n float across = 14.;\\n float back = 14.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float cz = floor(cubeId / across / back);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (back - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n float cc = cw * 2. - 1.;\\n \\n float s1 = texture2D(sound, vec2(abs(0.1), length(vec3(ca, cb, cc)) * .1)).a;\\n float s2 = texture2D(sound, vec2(abs(0.2), length(vec3(ca, cb, cc)) * .1)).a;\\n float s = max(s1, s2) * 1.3;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= uniformScale(mix(0., 1.9, pow(s1, 1.)));\\n mat *= trans(vec3(ca, cc, cb) * down * 0.65);\\n mat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 0.;//abs(ca * cc) * 2.;\\n float sat = mix(0.9, 1., step(0.8, s));\\n float val = mix(1., 1., step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/drumcomplex-junglism-master-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nWait for the music to pump \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 14.;\n float across = 14.;\n float back = 14.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float cz = floor(cubeId / across / back);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (back - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n float cc = cw * 2. - 1.;\n \n float s1 = texture2D(sound, vec2(abs(0.1), length(vec3(ca, cb, cc)) * .1)).a;\n float s2 = texture2D(sound, vec2(abs(0.2), length(vec3(ca, cb, cc)) * .1)).a;\n float s = max(s1, s2) * 1.3;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= uniformScale(mix(0., 1.9, pow(s1, 1.)));\n mat *= trans(vec3(ca, cc, cb) * down * 0.65);\n mat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 0.;//abs(ca * cc) * 2.;\n float sat = mix(0.9, 1., step(0.8, s));\n float val = mix(1., 1., step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-31p3h95wynxi1stpb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NitinB9Gc5jPZZ4vh/art.json b/art/NitinB9Gc5jPZZ4vh/art.json index 642e0eb6..713082df 100644 --- a/art/NitinB9Gc5jPZZ4vh/art.json +++ b/art/NitinB9Gc5jPZZ4vh/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "watermeloon", "avatarUrl": "https://secure.gravatar.com/avatar/e0a1c061d10e360fcf5646229dd6e29a?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\n//returns the evenly distributed points\\n//https://stackoverflow.com/questions/9600801/evenly\\n//-distributing-n-points-on-a-sphere\\nvec3 FIBO(float rad, float id, float sum){\\n\\n \\t//golden angle in radians\\n float phi = PI * (3. - sqrt(5.));\\n\\n \\t// y goes from 1 to -1\\n float y = 1. - (id / (sum - 1.)) * 2.; \\n float radius = sqrt(1. - y * y);\\n\\n float theta = phi * id;\\n\\n float x = cos(theta) * radius;\\n float z = sin(theta) * radius;\\n \\t\\n vec3 point = vec3(x * rad, y * rad, z * rad);\\n \\n return point;\\n}\\n\\n//X axis rotation\\nmat4 rotateX(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n \\n//Y axis rotation\\nmat4 rotateY(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n//Z axis rotation\\nmat4 rotateZ(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n//OpenGL perspective function //gman\\n//\\n//fov: how much you can see\\n//aspect: ratio of how wide the screen is\\n//zNear: the distance from the near clipping plane\\n//zFar: the distance from the far clipping plane\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n//looking at the object //gman\\nmat4 look_at(vec3 eye, vec3 target, vec3 up) {\\n vec3 zx = normalize(eye - target);\\n vec3 xx = normalize(cross(up, zx));\\n vec3 yx = cross(zx, xx);\\n\\n return mat4(\\n xx, 0,\\n yx, 0,\\n zx, 0,\\n eye, 1);\\n}\\n\\n//inverse of a 4x4 matrix //gman\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nvoid main() {\\n vec4 point;\\n float radius = 0.7;\\n point = vec4(FIBO(radius, vertexId, floor(vertexCount / 10.)), 1.);\\n \\n point *= rotateX(time * .2);\\n point *= rotateY(time * .2);\\n point *= rotateZ(time * .2);\\n \\n gl_Position = vec4(point.x * resolution.y/resolution.x, point.y, point.z, 1.);\\n \\n float color_norm = (gl_Position.z + 2.) / 2.;\\n color_norm -= .2;\\n //color_norm -= .6; back is visible too\\n vec4 color = vec4(color_norm, color_norm, color_norm, 1);\\n v_color = color;\\n \\n gl_PointSize = 1.;\\n gl_PointSize -= gl_Position.z * .15;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\n//returns the evenly distributed points\n//https://stackoverflow.com/questions/9600801/evenly\n//-distributing-n-points-on-a-sphere\nvec3 FIBO(float rad, float id, float sum){\n\n \t//golden angle in radians\n float phi = PI * (3. - sqrt(5.));\n\n \t// y goes from 1 to -1\n float y = 1. - (id / (sum - 1.)) * 2.; \n float radius = sqrt(1. - y * y);\n\n float theta = phi * id;\n\n float x = cos(theta) * radius;\n float z = sin(theta) * radius;\n \t\n vec3 point = vec3(x * rad, y * rad, z * rad);\n \n return point;\n}\n\n//X axis rotation\nmat4 rotateX(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n \n//Y axis rotation\nmat4 rotateY(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n//Z axis rotation\nmat4 rotateZ(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n//OpenGL perspective function //gman\n//\n//fov: how much you can see\n//aspect: ratio of how wide the screen is\n//zNear: the distance from the near clipping plane\n//zFar: the distance from the far clipping plane\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n//looking at the object //gman\nmat4 look_at(vec3 eye, vec3 target, vec3 up) {\n vec3 zx = normalize(eye - target);\n vec3 xx = normalize(cross(up, zx));\n vec3 yx = cross(zx, xx);\n\n return mat4(\n xx, 0,\n yx, 0,\n zx, 0,\n eye, 1);\n}\n\n//inverse of a 4x4 matrix //gman\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nvoid main() {\n vec4 point;\n float radius = 0.7;\n point = vec4(FIBO(radius, vertexId, floor(vertexCount / 10.)), 1.);\n \n point *= rotateX(time * .2);\n point *= rotateY(time * .2);\n point *= rotateZ(time * .2);\n \n gl_Position = vec4(point.x * resolution.y/resolution.x, point.y, point.z, 1.);\n \n float color_norm = (gl_Position.z + 2.) / 2.;\n color_norm -= .2;\n //color_norm -= .6; back is visible too\n vec4 color = vec4(color_norm, color_norm, color_norm, 1);\n v_color = color;\n \n gl_PointSize = 1.;\n gl_PointSize -= gl_Position.z * .15;\n \n\n}" + }, "screenshotURL": "data/images/images-gej2k6vs6xchkpqer-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Njfu8NkcFaWN4RDAx/art.json b/art/Njfu8NkcFaWN4RDAx/art.json index 0ab71276..0fa5b24d 100644 --- a/art/Njfu8NkcFaWN4RDAx/art.json +++ b/art/Njfu8NkcFaWN4RDAx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/autonoise_records/plom_b4-forma\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n//Shader funcitons\\n\\n \\n\\nfloat Hash( vec2 p)\\n{\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p)\\n{\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p)\\n{\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v -= noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v * -1.25;\\n}\\n\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n // if(u>0.5)\\n // u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n//vec2 uv = ( fragcoord.xy / resolution.xy ) * 2.0 - 1.0;\\n\\tuv.x *= resolution.x/resolution.y;\\n\\tuv.xy = uv.yx;\\n\\tfloat j = 2.5;\\n\\tvec3 finalColor = vec3( 0.0 );\\n\\tfor( int i=2; i < 13; ++i )\\n\\t{\\n\\t\\tfloat hh = 0.5 - float(i);\\n\\t\\t\\n\\t\\tfloat t = abs(1.0 / ((uv.x + fbm( uv + (time + 40.)/float(i)))*200.));\\n\\t\\tfinalColor += t * vec3( sin(hh-j), fract(t/j), cos(j-t) );\\n\\t\\tj = float(i)-hh;\\n\\t}\\n\\t\\n\\t//gl_FragColor = vec4( sqrt(finalColor), 1.0 );\\n\\n v_color = vec4( sqrt(finalColor), 1.0 );\\n\\t\\n //camera\\n float r = 0.9;\\n float tm = 1.5*time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n if(depth>=0.5)\\n {\\n depthFactor = depth/10.;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/40., 1.);\\n \\n gl_Position = mat*finalPos;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/autonoise_records/plom_b4-forma", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n//Shader funcitons\n\n \n\nfloat Hash( vec2 p)\n{\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p)\n{\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p)\n{\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v -= noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v * -1.25;\n}\n\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n // if(u>0.5)\n // u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n//vec2 uv = ( fragcoord.xy / resolution.xy ) * 2.0 - 1.0;\n\tuv.x *= resolution.x/resolution.y;\n\tuv.xy = uv.yx;\n\tfloat j = 2.5;\n\tvec3 finalColor = vec3( 0.0 );\n\tfor( int i=2; i < 13; ++i )\n\t{\n\t\tfloat hh = 0.5 - float(i);\n\t\t\n\t\tfloat t = abs(1.0 / ((uv.x + fbm( uv + (time + 40.)/float(i)))*200.));\n\t\tfinalColor += t * vec3( sin(hh-j), fract(t/j), cos(j-t) );\n\t\tj = float(i)-hh;\n\t}\n\t\n\t//gl_FragColor = vec4( sqrt(finalColor), 1.0 );\n\n v_color = vec4( sqrt(finalColor), 1.0 );\n\t\n //camera\n float r = 0.9;\n float tm = 1.5*time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n if(depth>=0.5)\n {\n depthFactor = depth/10.;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/40., 1.);\n \n gl_Position = mat*finalPos;\n}\n\n" + }, "screenshotURL": "data/images/images-rxa9g9rim28cjowje-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NkGu9MkBw25Y4yT2Y/art.json b/art/NkGu9MkBw25Y4yT2Y/art.json index 8bc5a6c7..82e175b2 100644 --- a/art/NkGu9MkBw25Y4yT2Y/art.json +++ b/art/NkGu9MkBw25Y4yT2Y/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "teraspora", "avatarUrl": "https://secure.gravatar.com/avatar/ee48754754126a1abee9056ee99b25c4?default=retro&size=200", - "settings": "{\"num\":26501,\"mode\":\"TRIANGLES\",\"sound\":\"file:///media/john/sys2/web18/playground/audio/bach-01.wma\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// My second vertexshaderart code attempt\\n// John Lynch, 11-09-2018\\n#define PI 3.141592653589793234\\n#define TWO_PI 6.28318530716\\n\\n// ==================================================================\\n// Some functions adapted from Github - \\n// https://github.com/tobspr/GLSL-Color-Spaces/blob/master/ColorSpaces.inc.glsl\\n// - not tested rigorously by me, seem to work!\\n\\nvec3 hue2rgb(float hue)\\n{\\n float R = abs(hue * 6. - 3.) - 1.;\\n float G = 2. - abs(hue * 6. - 2.);\\n float B = 2. - abs(hue * 6. - 4.);\\n return clamp(vec3(R,G,B), 0., 1.);\\n}\\n\\n// Converts from HSL to linear RGB\\nvec3 hsl2rgb(vec3 hsl) {\\n vec3 rgb = hue2rgb(hsl.x);\\n float C = (1. - abs(2. * hsl.z - 1.)) * hsl.y;\\n return (rgb - 0.5) * C + hsl.z;\\n}\\n\\n// ======================== USEFUL FUNCTIONS ========================\\n\\nfloat scaleFactor = 1.0;\\n\\nvec2 rotate(vec2 v, float phi) {\\n return vec2(v.x * cos(phi) - v.y * sin(phi),\\n v.x * sin(phi) + v.y * cos(phi));\\n}\\n\\nbool isOdd(float n) {\\n return mod(n, 2.) > 0.5;\\n}\\n\\n// ==== == ==== == ==== == ==== == ==== == ==== == ==== == ==== == ==\\n\\n\\n\\n\\n\\nvec2 circle(float vid, float numSegments) {\\n \\n float ux = floor(vid / 6.) + mod(vid, 2.);\\n float vy = mod(floor(vid / 2.) + floor(vid / 3.), 2.);\\n \\n float phi = ux / numSegments * TWO_PI;\\n float r = (vy + 2.) * 0.1;\\n float c = cos(phi);\\n float s = sin(phi);\\n \\n float x = c * r;\\n float y = s * r; \\n \\n return vec2(x, y);\\n}\\n \\nvoid main() {\\n float segs = mod(time, 20.);\\n vec2 circleXY = circle(vertexId, segs);\\n float numPointsPerCircle = segs * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float circleCount = floor(vertexCount / numPointsPerCircle);\\n \\n float ySpan = floor(sqrt(circleCount));\\n float xSpan = floor(circleCount / ySpan);\\n \\n float x = mod(circleId, xSpan);\\n float y = floor(circleId / xSpan);\\n \\n float u = x / (xSpan - 1.);\\n float v = y / (xSpan - 1.);\\n \\n float ux = u * 2. - 1. + mouse.x;\\n float vy = v * 2. - 1. + mouse.y;\\n \\n vec2 xy = circleXY * 0.1 + vec2(ux, vy) * scaleFactor * (sin(time / 2.) + 0.5);\\n xy *= length(xy);\\n xy = rotate(xy, -time * PI / 10.) + 0.1 * sin(time);\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n // float au = abs(atan(su, sv)) / PI;\\n // float av = length(vec2(su, sv));\\n \\n gl_Position = vec4(xy, 0.99, 1) ;\\n gl_PointSize = 1.;\\n \\n vec3 col = hue2rgb(cos(time / 6.));\\n v_color = vec4(col, 1.);\\n \\n // vec3 col = vec3(cos(circleId * sin(time / 6.)) , 0., 1. - cos(time));\\n // v_color = vec4(col, 1.);\\n \\n \\n \\n \\n \\n}\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/*\\nvoid main() {\\n float span = floor(sqrt(vertexCount));\\n \\n float u = mod(vertexId, span) / (span - 1.);\\n float v = floor(vertexId / span) / (span - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float yDelta = (8. * sin(time / 4. * ux + vy ) + sin(time / 2.) + sin(time) + 3. * sin(time / 2.)) / 20.;\\n float xDelta = yDelta * 1.8;\\n if (isOdd(vertexId)) {\\n yDelta = -yDelta + 2. * mouse.y ;\\n }\\n vec2 xy = vec2(ux + xDelta, vy + yDelta * (ux / resolution.x) * vertexId) * scaleFactor;\\n xy = rotate(xy, sin(time / 20.) * TWO_PI * mouse.x / 4.);\\n gl_Position = vec4(xy, 0, 1);\\n gl_PointSize = 10.;\\n gl_PointSize += 1. / span;\\n gl_PointSize *= 0.1 * resolution.x * resolution.y / 262144.;\\n float k = vertexId / vertexCount;\\n v_color = vec4(k * 0.8, 0.2, 0.6 - k * mod(time, 10.) / 2., 1.);\\n}\\n*/\"}", + "settings": { + "num": 26501, + "mode": "TRIANGLES", + "sound": "file:///media/john/sys2/web18/playground/audio/bach-01.wma", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// My second vertexshaderart code attempt\n// John Lynch, 11-09-2018\n#define PI 3.141592653589793234\n#define TWO_PI 6.28318530716\n\n// ==================================================================\n// Some functions adapted from Github - \n// https://github.com/tobspr/GLSL-Color-Spaces/blob/master/ColorSpaces.inc.glsl\n// - not tested rigorously by me, seem to work!\n\nvec3 hue2rgb(float hue)\n{\n float R = abs(hue * 6. - 3.) - 1.;\n float G = 2. - abs(hue * 6. - 2.);\n float B = 2. - abs(hue * 6. - 4.);\n return clamp(vec3(R,G,B), 0., 1.);\n}\n\n// Converts from HSL to linear RGB\nvec3 hsl2rgb(vec3 hsl) {\n vec3 rgb = hue2rgb(hsl.x);\n float C = (1. - abs(2. * hsl.z - 1.)) * hsl.y;\n return (rgb - 0.5) * C + hsl.z;\n}\n\n// ======================== USEFUL FUNCTIONS ========================\n\nfloat scaleFactor = 1.0;\n\nvec2 rotate(vec2 v, float phi) {\n return vec2(v.x * cos(phi) - v.y * sin(phi),\n v.x * sin(phi) + v.y * cos(phi));\n}\n\nbool isOdd(float n) {\n return mod(n, 2.) > 0.5;\n}\n\n// ==== == ==== == ==== == ==== == ==== == ==== == ==== == ==== == ==\n\n\n\n\n\nvec2 circle(float vid, float numSegments) {\n \n float ux = floor(vid / 6.) + mod(vid, 2.);\n float vy = mod(floor(vid / 2.) + floor(vid / 3.), 2.);\n \n float phi = ux / numSegments * TWO_PI;\n float r = (vy + 2.) * 0.1;\n float c = cos(phi);\n float s = sin(phi);\n \n float x = c * r;\n float y = s * r; \n \n return vec2(x, y);\n}\n \nvoid main() {\n float segs = mod(time, 20.);\n vec2 circleXY = circle(vertexId, segs);\n float numPointsPerCircle = segs * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float circleCount = floor(vertexCount / numPointsPerCircle);\n \n float ySpan = floor(sqrt(circleCount));\n float xSpan = floor(circleCount / ySpan);\n \n float x = mod(circleId, xSpan);\n float y = floor(circleId / xSpan);\n \n float u = x / (xSpan - 1.);\n float v = y / (xSpan - 1.);\n \n float ux = u * 2. - 1. + mouse.x;\n float vy = v * 2. - 1. + mouse.y;\n \n vec2 xy = circleXY * 0.1 + vec2(ux, vy) * scaleFactor * (sin(time / 2.) + 0.5);\n xy *= length(xy);\n xy = rotate(xy, -time * PI / 10.) + 0.1 * sin(time);\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n // float au = abs(atan(su, sv)) / PI;\n // float av = length(vec2(su, sv));\n \n gl_Position = vec4(xy, 0.99, 1) ;\n gl_PointSize = 1.;\n \n vec3 col = hue2rgb(cos(time / 6.));\n v_color = vec4(col, 1.);\n \n // vec3 col = vec3(cos(circleId * sin(time / 6.)) , 0., 1. - cos(time));\n // v_color = vec4(col, 1.);\n \n \n \n \n \n}\n \n\n\n\n\n\n\n\n\n\n/*\nvoid main() {\n float span = floor(sqrt(vertexCount));\n \n float u = mod(vertexId, span) / (span - 1.);\n float v = floor(vertexId / span) / (span - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float yDelta = (8. * sin(time / 4. * ux + vy ) + sin(time / 2.) + sin(time) + 3. * sin(time / 2.)) / 20.;\n float xDelta = yDelta * 1.8;\n if (isOdd(vertexId)) {\n yDelta = -yDelta + 2. * mouse.y ;\n }\n vec2 xy = vec2(ux + xDelta, vy + yDelta * (ux / resolution.x) * vertexId) * scaleFactor;\n xy = rotate(xy, sin(time / 20.) * TWO_PI * mouse.x / 4.);\n gl_Position = vec4(xy, 0, 1);\n gl_PointSize = 10.;\n gl_PointSize += 1. / span;\n gl_PointSize *= 0.1 * resolution.x * resolution.y / 262144.;\n float k = vertexId / vertexCount;\n v_color = vec4(k * 0.8, 0.2, 0.6 - k * mod(time, 10.) / 2., 1.);\n}\n*/" + }, "screenshotURL": "data/images/images-gn1x1hpja4a8a0hwz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Nn9NwLg9EkcRu5ySW/art.json b/art/Nn9NwLg9EkcRu5ySW/art.json index bb489731..64a43ab1 100644 --- a/art/Nn9NwLg9EkcRu5ySW/art.json +++ b/art/Nn9NwLg9EkcRu5ySW/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.25882352941176473,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Colors\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v*20.0) * 0.05;\\n float sat = 1.0;\\n float val = sin(time * 1.4 + v*u*20.0)*0.5+0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.25882352941176473, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Colors\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 1.3 + v*20.0) * 0.05;\n float sat = 1.0;\n float val = sin(time * 1.4 + v*u*20.0)*0.5+0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-puxdsjfgkxgbk44sd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NnwTMwz27MKZEbr46/art.json b/art/NnwTMwz27MKZEbr46/art.json index 81eb650c..55be102d 100644 --- a/art/NnwTMwz27MKZEbr46/art.json +++ b/art/NnwTMwz27MKZEbr46/art.json @@ -11,7 +11,19 @@ "origId": "ZzCgG7HuSE6BLGSKR", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-2wiuo4cpros2lrpsy-thumbnail.jpg", "views": { "$numberInt": "162" diff --git a/art/Nphqdj5rtbnvnS26q/art.json b/art/Nphqdj5rtbnvnS26q/art.json index 775030e7..5324150a 100644 --- a/art/Nphqdj5rtbnvnS26q/art.json +++ b/art/Nphqdj5rtbnvnS26q/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Colors\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Colors\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-wmqq3w3ase72885a4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NpnhMDf6aivDMB3x9/art.json b/art/NpnhMDf6aivDMB3x9/art.json index 50125aea..20d18a45 100644 --- a/art/NpnhMDf6aivDMB3x9/art.json +++ b/art/NpnhMDf6aivDMB3x9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/manon-ariza/tortuga-deities\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n\\nfloat radius = 0.15;\\nfloat amount = 100.;\\nfloat len = vertexCount / amount;\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (3.0 - 2.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + 1.0);\\n\\n vec4 o1 = fract(k3 * (1.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (1.0 - d.y);\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float seg = floor(vertexId/len);\\n float segId = mod(vertexId,len);\\n float v = texture2D(volume, vec2(1., (1.+seg)/amount*240.)).a;\\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\\n float n = noise(p);\\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\\n \\n x += cos(n * PI*4.) * segId * 0.000002 * s;\\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\\n \\n gl_Position = vec4(x/v-x/s, y/v, 0, 1);\\n\\n float b = 0.3 / mod(vertexId/len,1.);\\n v_color = vec4(vec3(b), 0.5);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/manon-ariza/tortuga-deities", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n\nfloat radius = 0.15;\nfloat amount = 100.;\nfloat len = vertexCount / amount;\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (3.0 - 2.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + 1.0);\n\n vec4 o1 = fract(k3 * (1.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (1.0 - d.y);\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float seg = floor(vertexId/len);\n float segId = mod(vertexId,len);\n float v = texture2D(volume, vec2(1., (1.+seg)/amount*240.)).a;\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\n float n = noise(p);\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\n \n x += cos(n * PI*4.) * segId * 0.000002 * s;\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\n \n gl_Position = vec4(x/v-x/s, y/v, 0, 1);\n\n float b = 0.3 / mod(vertexId/len,1.);\n v_color = vec4(vec3(b), 0.5);\n}" + }, "screenshotURL": "data/images/images-u5bvcnvkl5f1w1gof-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NrcGDcivscB3MHpcB/art.json b/art/NrcGDcivscB3MHpcB/art.json index 4e96cca0..b1382ad4 100644 --- a/art/NrcGDcivscB3MHpcB/art.json +++ b/art/NrcGDcivscB3MHpcB/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hug-life/hood-nigga-si-begg-rhythm-hugdealer-bootleg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define KP0 1.0\\n\\n#define PI radians(180.)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0.3, 0,\\n 0, 0, 1, 10,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye) *snd1 *22.;\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, snd1,\\n yAxis, snd0,\\n zAxis, snd2 * 2.,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\nfloat K0 = KP0+3.0 *mouse.y;\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 151.3983, p * 51.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(KP0* 111.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 1192.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 12. - 12.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id /(K0)),3.)* time;\\n return vec3(ux, vy, 1);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 1.);\\n float vy = mod(floor(id / 2.) + floor(id / 3. *time), 4.0 )*time; // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v,snd1;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0 *K0);\\n float a = pointId * PI * 12. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, -0.9)).xyz;\\n}\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 1.4)))*37.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0+6.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(1.6,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\nfloat expand =(10.0* mouse.x);\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 3.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.7)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * .4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * 9.1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 2.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 1.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 0.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * .05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 2.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 5.6, cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 1.4, cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 1., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, -tan(time *0.3));\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hug-life/hood-nigga-si-begg-rhythm-hugdealer-bootleg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define KP0 1.0\n\n#define PI radians(180.)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0.3, 0,\n 0, 0, 1, 10,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye) *snd1 *22.;\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, snd1,\n yAxis, snd0,\n zAxis, snd2 * 2.,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\nfloat K0 = KP0+3.0 *mouse.y;\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 151.3983, p * 51.4427));\n p2 += dot(p2.yx, p2.xy + vec2(KP0* 111.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 1192.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 12. - 12.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id /(K0)),3.)* time;\n return vec3(ux, vy, 1);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 1.);\n float vy = mod(floor(id / 2.) + floor(id / 3. *time), 4.0 )*time; // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v,snd1;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0 *K0);\n float a = pointId * PI * 12. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, -0.9)).xyz;\n}\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 1.4)))*37.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0+6.0*f);\n\n return mix(mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(1.6,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\nfloat expand =(10.0* mouse.x);\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 3.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.7)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * .4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * 9.1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 2.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 1.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 0.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * .05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 2.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 5.6, cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 1.4, cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 1., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, -tan(time *0.3));\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-dhawbjp9yntrbs4cg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NrwDd6WWDm4WJAvtM/art.json b/art/NrwDd6WWDm4WJAvtM/art.json index b12494a6..6392536b 100644 --- a/art/NrwDd6WWDm4WJAvtM/art.json +++ b/art/NrwDd6WWDm4WJAvtM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nfloat segment(vec2 p, vec2 a, vec2 b) {\\n vec2 ab = b - a;\\n vec2 ap = p - a;\\n float k = clamp(dot(ap, ab)/dot(ab, ab), 0.0, 1.0);\\n return smoothstep(0.0, 5.0/resolution.y, length(ap - k*ab) - 0.001);\\n}\\n\\nfloat shape(float u,vec2 p, float angle) {\\n float d = 100.0;\\n vec2 a = vec2(1.0, 0.0), b;\\n vec2 rot = vec2(cos(angle), sin(angle)*u);\\n \\n for (int i = 0; i < 6; ++i) {\\n b = a;\\n for (int j = 0; j < 18; ++j) {\\n \\tb = vec2(b.x*rot.x - b.y*rot.y, b.x*rot.y + b.y*rot.x);\\n \\td = min(d, segment(p, a, b));\\n }\\n a = vec2(a.x*rot.x - a.y*rot.y, a.x*rot.y + a.y*rot.x);\\n }\\n return d;\\n}\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n float snd = texture2D(sound, vec2(0., 0.)).a;\\n \\n \\n //apply fragment logic\\n\\n\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\t\\tvec2 uv = p.xy / res.xy;\\n vec2 cc = (-res.xy + 2.0*p.xy) / res.y;\\n \\n float numPhases=1114.5;\\n float u1;\\n float t;\\n float SpeedReal=0.2532;\\n u1=0.005+(mouse.y*2.2);\\n t = mouse.x/res.x * numPhases;\\n\\n float col = shape(u1,abs(cc), t+cos(0.01*(time*SpeedReal))*TAU);\\n col *= 0.5 + 1.5*pow(uv.x*uv.y*(1.0-uv.x)*(1.0-uv.y), 0.3);\\n \\n \\n\\t//gl_FragColor = vec4(vec3(pow(1.0-col, 2.15)),1.0);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(pow(1.0-col, 2.15)),1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nfloat segment(vec2 p, vec2 a, vec2 b) {\n vec2 ab = b - a;\n vec2 ap = p - a;\n float k = clamp(dot(ap, ab)/dot(ab, ab), 0.0, 1.0);\n return smoothstep(0.0, 5.0/resolution.y, length(ap - k*ab) - 0.001);\n}\n\nfloat shape(float u,vec2 p, float angle) {\n float d = 100.0;\n vec2 a = vec2(1.0, 0.0), b;\n vec2 rot = vec2(cos(angle), sin(angle)*u);\n \n for (int i = 0; i < 6; ++i) {\n b = a;\n for (int j = 0; j < 18; ++j) {\n \tb = vec2(b.x*rot.x - b.y*rot.y, b.x*rot.y + b.y*rot.x);\n \td = min(d, segment(p, a, b));\n }\n a = vec2(a.x*rot.x - a.y*rot.y, a.x*rot.y + a.y*rot.x);\n }\n return d;\n}\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n float snd = texture2D(sound, vec2(0., 0.)).a;\n \n \n //apply fragment logic\n\n\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\t\tvec2 uv = p.xy / res.xy;\n vec2 cc = (-res.xy + 2.0*p.xy) / res.y;\n \n float numPhases=1114.5;\n float u1;\n float t;\n float SpeedReal=0.2532;\n u1=0.005+(mouse.y*2.2);\n t = mouse.x/res.x * numPhases;\n\n float col = shape(u1,abs(cc), t+cos(0.01*(time*SpeedReal))*TAU);\n col *= 0.5 + 1.5*pow(uv.x*uv.y*(1.0-uv.x)*(1.0-uv.y), 0.3);\n \n \n\t//gl_FragColor = vec4(vec3(pow(1.0-col, 2.15)),1.0);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(pow(1.0-col, 2.15)),1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-0v02qefrd26y26g0s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Nv4BapXAuEeZYTdNe/art.json b/art/Nv4BapXAuEeZYTdNe/art.json index 96a9d629..4d42bf1c 100644 --- a/art/Nv4BapXAuEeZYTdNe/art.json +++ b/art/Nv4BapXAuEeZYTdNe/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "taejukwon-digipen", "avatarUrl": "https://avatars.githubusercontent.com/taejuKwon-digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bbnomula/bbno-y2k-lalala\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Taeju Kwon\\n//CS250\\n//2022_Spring\\n//04_AudioReactiveArt\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3 (c.x, clamp(c.yz, 0.0,1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p-K.xxx , 0.0, 1.0) , c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float sv = abs(v-0.9) * 3.;\\n float su = abs(u-0.9) * 3.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au* .05,av * .25)).a;\\n \\n gl_Position = vec4(xy, 0,1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.1, 5.)* 30.0 + soff;\\n gl_PointSize += 20. / across;\\n gl_PointSize += resolution.x / 600.;\\n \\n \\n float hue = u * .3 + snd * .1 + time * .2; //u * 1. + sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1.,1.);\\n float val = mix(-1.,pow(snd + 0.2, 5.), 1.5); //sin(time + v * u * 20.0 ) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/bbnomula/bbno-y2k-lalala", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Taeju Kwon\n//CS250\n//2022_Spring\n//04_AudioReactiveArt\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3 (c.x, clamp(c.yz, 0.0,1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p-K.xxx , 0.0, 1.0) , c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float sv = abs(v-0.9) * 3.;\n float su = abs(u-0.9) * 3.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au* .05,av * .25)).a;\n \n gl_Position = vec4(xy, 0,1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.1, 5.)* 30.0 + soff;\n gl_PointSize += 20. / across;\n gl_PointSize += resolution.x / 600.;\n \n \n float hue = u * .3 + snd * .1 + time * .2; //u * 1. + sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1.,1.);\n float val = mix(-1.,pow(snd + 0.2, 5.), 1.5); //sin(time + v * u * 20.0 ) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n}\n" + }, "screenshotURL": "data/images/images-lyfg8qo1cza6em05t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/NwAsyqz4w4XbYrCZv/art.json b/art/NwAsyqz4w4XbYrCZv/art.json index 011503f0..02ab186e 100644 --- a/art/NwAsyqz4w4XbYrCZv/art.json +++ b/art/NwAsyqz4w4XbYrCZv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mattsonic", "avatarUrl": "https://secure.gravatar.com/avatar/4b4ea9969843f3808dccbabf78ea4289?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1568627450980392,0.15294117647058825,0.2627450980392157,1],\"shader\":\"// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 15.; \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1568627450980392, + 0.15294117647058825, + 0.2627450980392157, + 1 + ], + "shader": "// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 15.; \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-dqj86dp9tqtt5h1xz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/NyEsirDmwdF3Q65i6/art.json b/art/NyEsirDmwdF3Q65i6/art.json index a9c5fb65..28f8f561 100644 --- a/art/NyEsirDmwdF3Q65i6/art.json +++ b/art/NyEsirDmwdF3Q65i6/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":72279,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/bufirolas/bananarama-venus-bufi-edit\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 50.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 3.0, 4.0 / 3.0, 4.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown - 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 72279, + "mode": "LINES", + "sound": "https://soundcloud.com/bufirolas/bananarama-venus-bufi-edit", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 50.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 3.0, 4.0 / 3.0, 4.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown - 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-xcrd4z9wzg4c4fvu5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/P4e5h3iG9MkcanmBM/art.json b/art/P4e5h3iG9MkcanmBM/art.json index 46475ab7..ce78a84f 100644 --- a/art/P4e5h3iG9MkcanmBM/art.json +++ b/art/P4e5h3iG9MkcanmBM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":30000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/whitneysix/didnt-we-almost-have-it-all?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / sin(128.0)), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(5, resolution.x * resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + oC * oS + 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 30000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/whitneysix/didnt-we-almost-have-it-all?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / sin(128.0)), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(5, resolution.x * resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + oC * oS + 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ttns5u3x3yhhrwg52-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/P5PC55YtuMYdAYrM8/art.json b/art/P5PC55YtuMYdAYrM8/art.json index e56415c4..71b138b9 100644 --- a/art/P5PC55YtuMYdAYrM8/art.json +++ b/art/P5PC55YtuMYdAYrM8/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "wnstjr", "avatarUrl": "https://lh6.googleusercontent.com/-woU5-VARLRA/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcYXRdpCnpCitbsXa2kxR4Dtr7jrA/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float move = vertexId*10.0;\\n \\n float x= mouse.x ;\\n float y=mouse.y;\\n \\n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\\n \\n gl_PointSize = 30.0;\\n \\n float red=sin(time);\\n float blue=cos(time);\\n float green=tan(time);\\n \\n v_color=vec4(red,green,blue,1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float move = vertexId*10.0;\n \n float x= mouse.x ;\n float y=mouse.y;\n \n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\n \n gl_PointSize = 30.0;\n \n float red=sin(time);\n float blue=cos(time);\n float green=tan(time);\n \n v_color=vec4(red,green,blue,1.0);\n}" + }, "screenshotURL": "data/images/images-30e4etsehjli4yf9c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/P5RqTvyQgTLzoCwXM/art.json b/art/P5RqTvyQgTLzoCwXM/art.json index aee19f27..489ed725 100644 --- a/art/P5RqTvyQgTLzoCwXM/art.json +++ b/art/P5RqTvyQgTLzoCwXM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/babalos/babalos-power-up\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 7.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n float sizeFactor = 0.1;\\n \\n float numberOfElement = 5.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = sizeFactor*(xPos*2.-1.);\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*10.,2.);\\n lineId/=numberOfElement;\\n\\n \\n //smaller size on front\\n cubep*= min(sizeFactor*lineId/2., 0.9*sizeFactor)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+= xPos;\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n //rotation of the group around z\\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.+PI/2.);\\n \\n cubep.z+=lineId*2.*sizeFactor;\\n //cubep.z+= mod(time/10.,10.);\\n \\n //float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0.,20.*sizeFactor, 1.);//29./2.*abs(cos(time/5.))\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, -1.9, 0.), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/babalos/babalos-power-up", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 7.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n float sizeFactor = 0.1;\n \n float numberOfElement = 5.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = sizeFactor*(xPos*2.-1.);\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*10.,2.);\n lineId/=numberOfElement;\n\n \n //smaller size on front\n cubep*= min(sizeFactor*lineId/2., 0.9*sizeFactor)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+= xPos;\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n //rotation of the group around z\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.+PI/2.);\n \n cubep.z+=lineId*2.*sizeFactor;\n //cubep.z+= mod(time/10.,10.);\n \n //float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0.,20.*sizeFactor, 1.);//29./2.*abs(cos(time/5.))\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, -1.9, 0.), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-utgnytx10869sjp72-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/P5mpP2Tb9XkwhuTK7/art.json b/art/P5mpP2Tb9XkwhuTK7/art.json index efb83125..58ad380c 100644 --- a/art/P5mpP2Tb9XkwhuTK7/art.json +++ b/art/P5mpP2Tb9XkwhuTK7/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "salvatore", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocKio7TORJMn8A7RkX3-sf6UDKi8ACBRf3ulZjs1E6B-yDqExhFe=s96-c", - "settings": "{\"num\":961,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/maslyastar/capsule-world-of-fantasy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\nvoid main()\\n{\\n \\n \\t// Use the floor to get an integer. Due vertexId is integer, the vertices x coord will be aligned.\\n\\tfloat RowLen = floor(sqrt(vertexCount)); \\n \\n // [x, y] position\\n \\tfloat x = mod(vertexId, RowLen);\\n \\tfloat y = floor(vertexId / RowLen);\\n \\n // Eg. if RowLen is 10., x goes to 0 to 9, due the mod operation\\n // and y too due to the division and floor, this cause the last x and y points to be drawn before the screen border\\n // and the grid seems not uniform.\\n // So scale the coordinate dividing them by 9, (RowLen-1), instead of dividing by 10,\\n // to optain the starting and the end points on the screen border.\\n \\t\\n // [u,v] = [0,1]x[0,1]\\n float u = x / (RowLen - 1.);\\n float v = y / (RowLen - 1.);\\n \\n // Add animation\\n \\tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.;//sin(time + x * 0.2) * 0.2;\\n \\n // [U,V] = [-1,1]x[-1,1]\\n \\tfloat U = 2. * u - 1. + xoff;\\n \\tfloat V = 2. * v - 1. + yoff;\\n \\n // Scale coordinates\\n vec2 UV = vec2(U,V) * 0.6;\\n \\t\\n\\tgl_Position = vec4(UV, 0, 1);\\n \\t\\n \\t\\n \\tfloat PointSizeScale = sin(time + x * y * 0.02) * 5.;\\n \\t\\n \\t// More point on screen -> smaller point size\\n \\tgl_PointSize = 15. + PointSizeScale;\\n \\tgl_PointSize *= 5. / RowLen;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\t\\n\\n // Change color\\n \\tv_color = vec4(1,0,0, 1);\\n \\n}\"}", + "settings": { + "num": 961, + "mode": "POINTS", + "sound": "https://soundcloud.com/maslyastar/capsule-world-of-fantasy", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\nvoid main()\n{\n \n \t// Use the floor to get an integer. Due vertexId is integer, the vertices x coord will be aligned.\n\tfloat RowLen = floor(sqrt(vertexCount)); \n \n // [x, y] position\n \tfloat x = mod(vertexId, RowLen);\n \tfloat y = floor(vertexId / RowLen);\n \n // Eg. if RowLen is 10., x goes to 0 to 9, due the mod operation\n // and y too due to the division and floor, this cause the last x and y points to be drawn before the screen border\n // and the grid seems not uniform.\n // So scale the coordinate dividing them by 9, (RowLen-1), instead of dividing by 10,\n // to optain the starting and the end points on the screen border.\n \t\n // [u,v] = [0,1]x[0,1]\n float u = x / (RowLen - 1.);\n float v = y / (RowLen - 1.);\n \n // Add animation\n \tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.;//sin(time + x * 0.2) * 0.2;\n \n // [U,V] = [-1,1]x[-1,1]\n \tfloat U = 2. * u - 1. + xoff;\n \tfloat V = 2. * v - 1. + yoff;\n \n // Scale coordinates\n vec2 UV = vec2(U,V) * 0.6;\n \t\n\tgl_Position = vec4(UV, 0, 1);\n \t\n \t\n \tfloat PointSizeScale = sin(time + x * y * 0.02) * 5.;\n \t\n \t// More point on screen -> smaller point size\n \tgl_PointSize = 15. + PointSizeScale;\n \tgl_PointSize *= 5. / RowLen;\n \tgl_PointSize *= resolution.x / 600.;\n \n \t\n\n // Change color\n \tv_color = vec4(1,0,0, 1);\n \n}" + }, "screenshotURL": "data/images/images-zbek0adj6e0yuaz9k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/P6Gk2AsdD2B7g9Kus/art.json b/art/P6Gk2AsdD2B7g9Kus/art.json index 7e91c100..519a90f5 100644 --- a/art/P6Gk2AsdD2B7g9Kus/art.json +++ b/art/P6Gk2AsdD2B7g9Kus/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "krankerapfel", "avatarUrl": "https://secure.gravatar.com/avatar/5f1830cb37d80a96e1946cc8afe0caa0?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n\\t\\n\\n float x = (vertexId/resolution.x) - 0.99;\\n gl_Position = vec4(x, sin(x+time), sin(x+time), 1);\\n gl_PointSize = 50.0;\\n\\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n\t\n\n float x = (vertexId/resolution.x) - 0.99;\n gl_Position = vec4(x, sin(x+time), sin(x+time), 1);\n gl_PointSize = 50.0;\n\n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-r71artuclmtt2i279-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/P6MCpqz4ahLWemiGr/art.json b/art/P6MCpqz4ahLWemiGr/art.json index 3cb1fb2e..4e9f73e0 100644 --- a/art/P6MCpqz4ahLWemiGr/art.json +++ b/art/P6MCpqz4ahLWemiGr/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\n\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x* y* 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v*u*20.0)*.5+.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\n\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x* y* 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v*u*20.0)*.5+.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}" + }, "screenshotURL": "data/images/images-jtlfppq5h1si9o3tx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/P6oFn7ms5b8ZLioGX/art.json b/art/P6oFn7ms5b8ZLioGX/art.json index 56ce1f58..2ff1673e 100644 --- a/art/P6oFn7ms5b8ZLioGX/art.json +++ b/art/P6oFn7ms5b8ZLioGX/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 0.3//KParameter 0.>>2.\\n//KDrawmode=GL_TRIANGLES\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv - 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI* 2. + PI * 1.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * -0.2;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(-t * 0.27) + sin(t * -0.013) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.)-1., 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI-2.);\\n float x = cos(qu * PI * 2.) + mouse.y * r*(21.*P3);\\n float y = sin(qu * PI *1.) * r*2.;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 1.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1.);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat/sin(time), val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 0.3//KParameter 0.>>2.\n//KDrawmode=GL_TRIANGLES\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv - 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI* 2. + PI * 1.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * -0.2;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(-t * 0.27) + sin(t * -0.013) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.)-1., 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI-2.);\n float x = cos(qu * PI * 2.) + mouse.y * r*(21.*P3);\n float y = sin(qu * PI *1.) * r*2.;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 1.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1.);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat/sin(time), val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-cveh4hg162nzti7lf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/P788bkYrZh4KcFHgQ/art.json b/art/P788bkYrZh4KcFHgQ/art.json index 91b7e274..eef1d8d0 100644 --- a/art/P788bkYrZh4KcFHgQ/art.json +++ b/art/P788bkYrZh4KcFHgQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3923,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float width = floor(sqrt(vertexCount-5.));\\n \\n float x = mod(vertexId*0.5, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.6);\\n \\n float xOffset = cos(time + y * 10.2) * 0.1;\\n float yOffset = cos(time + x * 1.3) * 0.3;\\n \\n float ux = u * 2.0 - 1.35 -sin(time)+ xOffset;\\n float vy = v * 5.0 / (time *0.3) + yOffset;\\n \\n //vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\\n \\n vec2 xy = vec2(ux, vy) * (2.2-sin(time/x-3.));\\n \\n gl_Position = vec4 (xy, 0.5, 1.0);\\n \\n float sizeOffset = sin(time + x * y * 0.712) * 17.0;\\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 32.0 / width/6.;\\n \\n v_color= vec4(0.5, .22, (x *sin(y-time*0.6)-y), 0.2);\\n}\"}", + "settings": { + "num": 3923, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float width = floor(sqrt(vertexCount-5.));\n \n float x = mod(vertexId*0.5, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.6);\n \n float xOffset = cos(time + y * 10.2) * 0.1;\n float yOffset = cos(time + x * 1.3) * 0.3;\n \n float ux = u * 2.0 - 1.35 -sin(time)+ xOffset;\n float vy = v * 5.0 / (time *0.3) + yOffset;\n \n //vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\n \n vec2 xy = vec2(ux, vy) * (2.2-sin(time/x-3.));\n \n gl_Position = vec4 (xy, 0.5, 1.0);\n \n float sizeOffset = sin(time + x * y * 0.712) * 17.0;\n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 32.0 / width/6.;\n \n v_color= vec4(0.5, .22, (x *sin(y-time*0.6)-y), 0.2);\n}" + }, "screenshotURL": "data/images/images-261vspphqu4pkrk6s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/P7xh5mAYe3HWaA4x7/art.json b/art/P7xh5mAYe3HWaA4x7/art.json index 5780bed2..8541af1d 100644 --- a/art/P7xh5mAYe3HWaA4x7/art.json +++ b/art/P7xh5mAYe3HWaA4x7/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "상민", "avatarUrl": "https://lh5.googleusercontent.com/-FBZLbE_y4_Q/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reklXxy3FykkwCC2DQh9jjtzFC4fg/mo/photo.jpg", - "settings": "{\"num\":950,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.48627450980392156,0.48627450980392156,0.48627450980392156,1],\"shader\":\"void main()\\n{\\n // gl_Position = vec4(ux, vy, 0, 1);\\n gl_Position = vec4(sin(mouse.x), sin(mouse.y), 0, 1);\\n \\n \\n \\n gl_PointSize = abs(sin(time)) * 150.;\\n \\n\\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 950, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.48627450980392156, + 0.48627450980392156, + 0.48627450980392156, + 1 + ], + "shader": "void main()\n{\n // gl_Position = vec4(ux, vy, 0, 1);\n gl_Position = vec4(sin(mouse.x), sin(mouse.y), 0, 1);\n \n \n \n gl_PointSize = abs(sin(time)) * 150.;\n \n\n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-5jtjobjtuipzlwm67-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/P8gqvjnX5d6r53X7y/art.json b/art/P8gqvjnX5d6r53X7y/art.json index c0a1fcc1..27884286 100644 --- a/art/P8gqvjnX5d6r53X7y/art.json +++ b/art/P8gqvjnX5d6r53X7y/art.json @@ -26,7 +26,19 @@ "name": "cube", "private": true, "username": "baldand", - "settings": "{\"num\":32,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n vec3 z = vec3(0.);\\n vec3 o = vec3(1.);\\n vec3 a = z;\\n vec3 b = z;\\n vec3 p = z;\\n \\n float cube = floor(vertexId/36.);\\n float cubeVert = mod(vertexId,36.0);\\n float face = floor(cubeVert/6.);\\n float faceVert = mod(cubeVert,6.);\\n if (face==0.) { a.x = 1.; b.z = 1.; }\\n if (face==1.) { a.x = 1.; b.y = 1.; }\\n if (face==2.) { a.x = 1.; b.y = 1.; p.z = 1.; }\\n if (face==3.) { a.y = 1.; b.z = 1.; }\\n if (face==4.) { a.y = 1.; b.z = 1.; p.x = 1.; }\\n if (face==5.) { a.x = 1.; b.z = 1.; p.y = 1.; }\\n if (faceVert>0. && faceVert<4.) p += a;\\n if (faceVert>1. && faceVert<5.) p += b;\\n p.z += 3.;\\n p.y -= 2.;\\n p.x -= .5;\\n gl_Position = vec4(p.xy,1.0/-p.z,p.z);\\n v_color = vec4(1.);\\n}\"}", + "settings": { + "num": 32, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n vec3 z = vec3(0.);\n vec3 o = vec3(1.);\n vec3 a = z;\n vec3 b = z;\n vec3 p = z;\n \n float cube = floor(vertexId/36.);\n float cubeVert = mod(vertexId,36.0);\n float face = floor(cubeVert/6.);\n float faceVert = mod(cubeVert,6.);\n if (face==0.) { a.x = 1.; b.z = 1.; }\n if (face==1.) { a.x = 1.; b.y = 1.; }\n if (face==2.) { a.x = 1.; b.y = 1.; p.z = 1.; }\n if (face==3.) { a.y = 1.; b.z = 1.; }\n if (face==4.) { a.y = 1.; b.z = 1.; p.x = 1.; }\n if (face==5.) { a.x = 1.; b.z = 1.; p.y = 1.; }\n if (faceVert>0. && faceVert<4.) p += a;\n if (faceVert>1. && faceVert<5.) p += b;\n p.z += 3.;\n p.y -= 2.;\n p.x -= .5;\n gl_Position = vec4(p.xy,1.0/-p.z,p.z);\n v_color = vec4(1.);\n}" + }, "screenshotURL": "data/images/images-p51x58b5y1wlpqpdq-thumbnail.jpg", "views": { "$numberInt": "1" diff --git a/art/P9XfoFdHfyNDCwh2N/art.json b/art/P9XfoFdHfyNDCwh2N/art.json index fab1b864..b6f168b1 100644 --- a/art/P9XfoFdHfyNDCwh2N/art.json +++ b/art/P9XfoFdHfyNDCwh2N/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richarddevine/strum-modular-patch\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/*\\n point cloud vs spheres by Kabuto remix by Macro Machines\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 10.0\\n#define SND 1.\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.1492;\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5;\\n float l = length(posf)*1.45;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float t = time*.10;\\n float i = vertexId+sin(vertexId)*0.10;\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n \\tfloat snd = texture2D(sound,vec2(-f*0.1,f*i)).a*SND;\\n\\t \\tofs += push(t+f*.105*snd,i,ofs,2.-exp(-f*.1*snd));\\n \\tofs -= snd*0.2;\\n \\tofs += SND*0.05;\\n }\\n ofs += push(t,i,ofs,.999);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *= 1.;\\n pos.z += 0.7;\\n pos.xy *= 0.6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1.0/pos.z* 0.1;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richarddevine/strum-modular-patch", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/*\n point cloud vs spheres by Kabuto remix by Macro Machines\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 10.0\n#define SND 1.\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.1492;\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5;\n float l = length(posf)*1.45;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float t = time*.10;\n float i = vertexId+sin(vertexId)*0.10;\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n \tfloat snd = texture2D(sound,vec2(-f*0.1,f*i)).a*SND;\n\t \tofs += push(t+f*.105*snd,i,ofs,2.-exp(-f*.1*snd));\n \tofs -= snd*0.2;\n \tofs += SND*0.05;\n }\n ofs += push(t,i,ofs,.999);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *= 1.;\n pos.z += 0.7;\n pos.xy *= 0.6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1.0/pos.z* 0.1;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\n}" + }, "screenshotURL": "data/images/images-8a45576ikjiwxgo8d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PBjvGFAxsjcQZhMod/art.json b/art/PBjvGFAxsjcQZhMod/art.json index 4cc2fb76..144305dd 100644 --- a/art/PBjvGFAxsjcQZhMod/art.json +++ b/art/PBjvGFAxsjcQZhMod/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/taeoxo/ty-x-baekhyun-monroe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9137254901960784,0.788235294117647,0.9019607843137255,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Circles from Triangles\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n \\n}\\n\\nvoid main() {\\n float numCircleSegments = 10.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat += rotZ(time * 0.5);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 50. * sign(ux));\\n mat *= uniformScale(0.015 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "https://soundcloud.com/taeoxo/ty-x-baekhyun-monroe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9137254901960784, + 0.788235294117647, + 0.9019607843137255, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Circles from Triangles\n// Course Name: CS250\n// Term: Spring 2022\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n \n}\n\nvoid main() {\n float numCircleSegments = 10.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat += rotZ(time * 0.5);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 50. * sign(ux));\n mat *= uniformScale(0.015 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-y6o2pdp6cnt1cegbm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PCd9WgpvsQcj7HXTc/art.json b/art/PCd9WgpvsQcj7HXTc/art.json index fca3a3f7..3fb12b07 100644 --- a/art/PCd9WgpvsQcj7HXTc/art.json +++ b/art/PCd9WgpvsQcj7HXTc/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":7371,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/psyches-shroud/lethe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; // sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float sv = abs(v - 0.5) * 2.0;\\n float su = abs(u - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.125, av * .25)).a * 1.0;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.0; // sin(time * 1.2 + x*y*0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = snd; //tep(0.8, snd);\\n float hue = u * 0.1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump); // sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 7371, + "mode": "POINTS", + "sound": "https://soundcloud.com/psyches-shroud/lethe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; // sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float sv = abs(v - 0.5) * 2.0;\n float su = abs(u - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.125, av * .25)).a * 1.0;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.0; // sin(time * 1.2 + x*y*0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = snd; //tep(0.8, snd);\n float hue = u * 0.1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump); // sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-oakz96yd0gyt8dim0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PERFs2wtC9jvSqbDY/art.json b/art/PERFs2wtC9jvSqbDY/art.json index 640db43e..82f5ac54 100644 --- a/art/PERFs2wtC9jvSqbDY/art.json +++ b/art/PERFs2wtC9jvSqbDY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 5.0\\n\\n#define PI 3.1415\\n\\n#define RESOLUTION vec3(45.0)\\n#define SIZE vec3(2.5)\\n\\n// New hash based on hash13() from \\\"Hash without Sine\\\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\\n// 4 in, 1 out\\nfloat Hash41(in vec4 p) {\\n\\tp = fract(p * 0.1031);\\n p += dot(p, p.zwyx + 31.32);\\n return fract((p.x + p.y) * p.z - p.x * p.w);\\n}\\n\\n\\nfloat SmoothNoise4D(in vec4 p) {\\n vec4 cell = floor(p);\\n vec4 local = fract(p);\\n local *= local * (3.0 - 2.0 * local);\\n\\n float ldbq = Hash41(cell);\\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\\n float rufw = Hash41(cell + 1.0);\\n\\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\\n mix(lubq, rubq, local.x),\\n local.y),\\n\\n mix(mix(ldfq, rdfq, local.x),\\n mix(lufq, rufq, local.x),\\n local.y),\\n\\n local.z),\\n\\n mix(mix(mix(ldbw, rdbw, local.x),\\n mix(lubw, rubw, local.x),\\n local.y),\\n\\n mix(mix(ldfw, rdfw, local.x),\\n mix(lufw, rufw, local.x),\\n local.y),\\n\\n local.z),\\n\\n local.w);\\n}\\n\\nfloat FractalNoise4D(in vec4 p) {\\n p *= 2.0;\\n\\n float nscale = 1.0;\\n float tscale = 0.0;\\n float value = 0.0;\\n\\n for (int octave=0; octave < 5; octave++) {\\n value += SmoothNoise4D(p) * nscale;\\n tscale += nscale;\\n nscale *= 0.5;\\n p *= 1.0;\\n }\\n\\n return value / tscale;\\n}\\n\\nfloat mapShape(vec3 p) {\\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\\n}\\n\\nvec3 mapColor(in vec3 p) {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, .40));\\n vec2 e = vec2(0.001, 0.0);\\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\\n\\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\\n}\\n\\nvoid main() {\\n float t = time * 0.25;\\n\\n float cellId = vertexId;\\n float gridX = mod(cellId, RESOLUTION.x);\\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\\n\\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\\n vec3 color = mapColor(vertex);\\n\\n vec2 mouseRot = mouse * PI;\\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.50);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 5.0\n\n#define PI 3.1415\n\n#define RESOLUTION vec3(45.0)\n#define SIZE vec3(2.5)\n\n// New hash based on hash13() from \"Hash without Sine\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\n// 4 in, 1 out\nfloat Hash41(in vec4 p) {\n\tp = fract(p * 0.1031);\n p += dot(p, p.zwyx + 31.32);\n return fract((p.x + p.y) * p.z - p.x * p.w);\n}\n\n\nfloat SmoothNoise4D(in vec4 p) {\n vec4 cell = floor(p);\n vec4 local = fract(p);\n local *= local * (3.0 - 2.0 * local);\n\n float ldbq = Hash41(cell);\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\n float rufw = Hash41(cell + 1.0);\n\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\n mix(lubq, rubq, local.x),\n local.y),\n\n mix(mix(ldfq, rdfq, local.x),\n mix(lufq, rufq, local.x),\n local.y),\n\n local.z),\n\n mix(mix(mix(ldbw, rdbw, local.x),\n mix(lubw, rubw, local.x),\n local.y),\n\n mix(mix(ldfw, rdfw, local.x),\n mix(lufw, rufw, local.x),\n local.y),\n\n local.z),\n\n local.w);\n}\n\nfloat FractalNoise4D(in vec4 p) {\n p *= 2.0;\n\n float nscale = 1.0;\n float tscale = 0.0;\n float value = 0.0;\n\n for (int octave=0; octave < 5; octave++) {\n value += SmoothNoise4D(p) * nscale;\n tscale += nscale;\n nscale *= 0.5;\n p *= 1.0;\n }\n\n return value / tscale;\n}\n\nfloat mapShape(vec3 p) {\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\n}\n\nvec3 mapColor(in vec3 p) {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, .40));\n vec2 e = vec2(0.001, 0.0);\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\n\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\n}\n\nvoid main() {\n float t = time * 0.25;\n\n float cellId = vertexId;\n float gridX = mod(cellId, RESOLUTION.x);\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\n\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\n vec3 color = mapColor(vertex);\n\n vec2 mouseRot = mouse * PI;\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.50);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-o4log2npwlpwswubi-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PERaHxC8pvwoBGHMo/art.json b/art/PERaHxC8pvwoBGHMo/art.json index 4b221799..0b4d9185 100644 --- a/art/PERaHxC8pvwoBGHMo/art.json +++ b/art/PERaHxC8pvwoBGHMo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n} \\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\n\\nvec2 getFragCoord(in float _finalDesiredPointSize, out float _finalVertexCount, out float _finalVertexId, out vec2 _finalResolution )\\n{\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n _finalVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n _finalResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n _finalResolution.y = floor(_finalVertexCount / _finalResolution.x);\\n _finalVertexId = mod(vertexId,_finalVertexCount);\\n return vec2(0.,0.);\\n}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n vec2 vertexResolution = vec2(0.);\\n \\n //first the number of elements in a line\\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n\\n //then the number of possible lines with the given vertexCount\\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n //cordinates in 0..1 referential\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n vec2 vfragCoord = vec2(u,v);\\n \\n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\\n \\n //cordinates in -1...1 referential\\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\\n float vy = v0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\\n \\n //optional for symetry\\n //if(u>0.5)\\n //u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 st = uv;\\n\\tst.x *= resolution.x / resolution.y;\\n\\n\\tvec2 pos = st.yx* vec2(10.0, 3.0);\\n\\t\\n\\tfloat pattern = pos.x;\\n\\t\\n\\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\\n\\t\\n\\tpattern = lines(pos, 0.5);\\n\\t\\n\\t\\n\\n //camera\\n float r = 2.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(vec3(pattern), 1.0);\\n \\n vec4 finalPos = vec4(ux, vy, 0., 1.);\\n \\n gl_Position = finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n} \n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\n\nvec2 getFragCoord(in float _finalDesiredPointSize, out float _finalVertexCount, out float _finalVertexId, out vec2 _finalResolution )\n{\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n _finalVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n _finalResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n _finalResolution.y = floor(_finalVertexCount / _finalResolution.x);\n _finalVertexId = mod(vertexId,_finalVertexCount);\n return vec2(0.,0.);\n}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n vec2 vertexResolution = vec2(0.);\n \n //first the number of elements in a line\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n\n //then the number of possible lines with the given vertexCount\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n //cordinates in 0..1 referential\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n vec2 vfragCoord = vec2(u,v);\n \n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\n \n //cordinates in -1...1 referential\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\n float vy = v0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\n \n //optional for symetry\n //if(u>0.5)\n //u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 st = uv;\n\tst.x *= resolution.x / resolution.y;\n\n\tvec2 pos = st.yx* vec2(10.0, 3.0);\n\t\n\tfloat pattern = pos.x;\n\t\n\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\n\t\n\tpattern = lines(pos, 0.5);\n\t\n\t\n\n //camera\n float r = 2.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(vec3(pattern), 1.0);\n \n vec4 finalPos = vec4(ux, vy, 0., 1.);\n \n gl_Position = finalPos;\n}" + }, "screenshotURL": "data/images/images-7a7rcse41clqzoye9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PF6C8TWcrEB3Mz3NP/art.json b/art/PF6C8TWcrEB3Mz3NP/art.json index 4579ab1b..a8a0518e 100644 --- a/art/PF6C8TWcrEB3Mz3NP/art.json +++ b/art/PF6C8TWcrEB3Mz3NP/art.json @@ -21,7 +21,19 @@ "origId": "nL6YpkW8YvGKNEKtj", "name": "point cloud vs spheres", "username": "bcarlyle", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-wg847jyoyyf3fisrs-thumbnail.jpg", "views": { "$numberInt": "221" diff --git a/art/PFHJfQrt3knT8K8sQ/art.json b/art/PFHJfQrt3knT8K8sQ/art.json index 9731cb5e..dd817d46 100644 --- a/art/PFHJfQrt3knT8K8sQ/art.json +++ b/art/PFHJfQrt3knT8K8sQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":23736,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hema_singer/o-sajna-live-movie-parakh\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.9882352941176471,0.4745098039215686,1],\"shader\":\"/*\\n\\n _ \\n | | \\n __ _____ _ __| |_ _____ __ \\n \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / \\n \\\\ V / __/ | | || __/> < \\n \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\ \\n | | | | \\n ___| |__ __ _ __| | ___ _ __ \\n / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__|\\n \\\\__ \\\\ | | | (_| | (_| | __/ | \\n |___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\n | | \\n __ _ _ __| |_ \\n / _` | '__| __| \\n | (_| | | | |_ \\n \\\\__,_|_| \\\\__| \\n \\n \\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_PARTS_PER_PETAL 20.\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 4.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float circleId, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = 0.;//texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n float z = mix(inner, 1., level);\\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. + sin(time * 1. + (circleId + z) * 0.1) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return (sin(t) + sin(t * 0.27) + sin(t * 1.53) + sin(t * 1.73)) / 4.;\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float petalId = floor(circleId / NUM_PARTS_PER_PETAL);\\n circleId = mod(circleId, NUM_PARTS_PER_PETAL);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE / 12.);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.0;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, circleId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += circleId * 2.6;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n float edgeId = circleId + pos.z * 0.76;\\n \\n float ss = texture2D(sound, vec2(0.053, edgeId / numCircles * 1.)).a;\\n \\n vec3 camera = vec3(0, 50., -0.01);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65. * resolution.y / resolution.x), resolution.x / resolution.y, 0.1, 100.);\\n mat *= rotZ(sin(time * 0.1));\\n mat *= cameraLookAt(camera, target, up);\\n mat *= rotY(petalId / 12. * PI * 2. + sin(time * 0.4 + 3. + edgeId * mix(0.1, 0.5, p1m1(sin(time * 0.1)))) * 0.3);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n float sc = mix(0.5, 5., mix(1., 2., pow(edgeId / numCircles, 10.))\\n * (pow(ss + 0.2, 5.0) + pow(goop((time * 0.1 + 38. + edgeId) * 0.1), 3.)));\\n mat *= scale(vec3(sc, sc, 2.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float hue = mix(0.0, 0.5, mod(uvf.z, 2.)) + time * 0.1;\\n float sat = 1.; mod(uvf.z, 2.);\\n float val = mix(0.5, 1., fract((edgeId)* 0.25 - time));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), );\\n}\"}", + "settings": { + "num": 23736, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hema_singer/o-sajna-live-movie-parakh", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.9882352941176471, + 0.4745098039215686, + 1 + ], + "shader": "/*\n\n _ \n | | \n __ _____ _ __| |_ _____ __ \n \\ \\ / / _ \\ '__| __/ _ \\ \\/ / \n \\ V / __/ | | || __/> < \n \\_/ \\___|_| \\__\\___/_/\\_\\ \n | | | | \n ___| |__ __ _ __| | ___ _ __ \n / __| '_ \\ / _` |/ _` |/ _ \\ '__|\n \\__ \\ | | | (_| | (_| | __/ | \n |___/_| |_|\\__,_|\\__,_|\\___|_| \n | | \n __ _ _ __| |_ \n / _` | '__| __| \n | (_| | | | |_ \n \\__,_|_| \\__| \n \n \n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_PARTS_PER_PETAL 20.\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 4.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float circleId, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = 0.;//texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n float z = mix(inner, 1., level);\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. + sin(time * 1. + (circleId + z) * 0.1) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return (sin(t) + sin(t * 0.27) + sin(t * 1.53) + sin(t * 1.73)) / 4.;\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float petalId = floor(circleId / NUM_PARTS_PER_PETAL);\n circleId = mod(circleId, NUM_PARTS_PER_PETAL);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE / 12.);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.0;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, circleId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += circleId * 2.6;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n float edgeId = circleId + pos.z * 0.76;\n \n float ss = texture2D(sound, vec2(0.053, edgeId / numCircles * 1.)).a;\n \n vec3 camera = vec3(0, 50., -0.01);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = ident(); \n mat *= persp(radians(65. * resolution.y / resolution.x), resolution.x / resolution.y, 0.1, 100.);\n mat *= rotZ(sin(time * 0.1));\n mat *= cameraLookAt(camera, target, up);\n mat *= rotY(petalId / 12. * PI * 2. + sin(time * 0.4 + 3. + edgeId * mix(0.1, 0.5, p1m1(sin(time * 0.1)))) * 0.3);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n float sc = mix(0.5, 5., mix(1., 2., pow(edgeId / numCircles, 10.))\n * (pow(ss + 0.2, 5.0) + pow(goop((time * 0.1 + 38. + edgeId) * 0.1), 3.)));\n mat *= scale(vec3(sc, sc, 2.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float hue = mix(0.0, 0.5, mod(uvf.z, 2.)) + time * 0.1;\n float sat = 1.; mod(uvf.z, 2.);\n float val = mix(0.5, 1., fract((edgeId)* 0.25 - time));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), );\n}" + }, "screenshotURL": "data/images/images-h4zyv5ocyga3huw79-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PFcfvGhtiFiKLLvYC/art.json b/art/PFcfvGhtiFiKLLvYC/art.json index 96dc9b5d..35959d79 100644 --- a/art/PFcfvGhtiFiKLLvYC/art.json +++ b/art/PFcfvGhtiFiKLLvYC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float ratio = resolution.y/numAcrossDown;\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = (x / numAcrossDown) * (resolution.y/resolution.x);\\n float v = (y / numAcrossDown);\\n \\n float ux = ( u * 2.0 - 1.0) *1./(resolution.y/numAcrossDown);\\n \\n float vy = ( v );\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n \\n //apply fragment logic\\n\\nvec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(numAcrossDown,numAcrossDown);\\n \\n\\tvec2 uv1=(p.xy*2.-res.xy)/min(res.x,res.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float ratio = resolution.y/numAcrossDown;\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = (x / numAcrossDown) * (resolution.y/resolution.x);\n float v = (y / numAcrossDown);\n \n float ux = ( u * 2.0 - 1.0) *1./(resolution.y/numAcrossDown);\n \n float vy = ( v );\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n \n //apply fragment logic\n\nvec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(numAcrossDown,numAcrossDown);\n \n\tvec2 uv1=(p.xy*2.-res.xy)/min(res.x,res.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-erpqm81dim2xg6xo8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PG4Ca7xxyoYxNdTGe/art.json b/art/PG4Ca7xxyoYxNdTGe/art.json index 7b5f288f..21659c9a 100644 --- a/art/PG4Ca7xxyoYxNdTGe/art.json +++ b/art/PG4Ca7xxyoYxNdTGe/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.30196078431372547,0.30196078431372547,0.30196078431372547,1],\"shader\":\"void main() {\\n \\n \\n float accross = 30.;\\n \\n \\n float x = mod(vertexId,accross);\\n \\n float y = floor(vertexId/accross);\\n \\n float u = x/(accross-1.0);\\n float v = y/(accross-1.0);\\n \\n float ux = u *2.0 -1.0;\\n float vy = v *2.0 -1.0;\\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1,0,0,1)\\n\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.30196078431372547, + 0.30196078431372547, + 0.30196078431372547, + 1 + ], + "shader": "void main() {\n \n \n float accross = 30.;\n \n \n float x = mod(vertexId,accross);\n \n float y = floor(vertexId/accross);\n \n float u = x/(accross-1.0);\n float v = y/(accross-1.0);\n \n float ux = u *2.0 -1.0;\n float vy = v *2.0 -1.0;\n \n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n v_color = vec4(1,0,0,1)\n\n}" + }, "screenshotURL": "data/images/images-sy6kbjjotxu4jbo95-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PGXc8D9XenBb5xokv/art.json b/art/PGXc8D9XenBb5xokv/art.json index 5fb76302..de80b7ea 100644 --- a/art/PGXc8D9XenBb5xokv/art.json +++ b/art/PGXc8D9XenBb5xokv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":9235,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 1, 0,\\n 0, 0, 1, 0,\\n 0, 0, 2, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1.2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.01;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 5.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 12.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 4.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 40;\\n float snd = 0.01;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf *- 0.123);\\n float spy = hash(spf / 0.317);\\n float sps = hash(spf - 3.411);\\n \\n float sds = distance(vec2(u*step(1.9,snd*2.), -v+snd), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7*2., sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 0.5));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 33. / across);\\n mat *= rotZ(snd * 2. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.17, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .63;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 9235, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 1, 0,\n 0, 0, 1, 0,\n 0, 0, 2, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1.2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.01;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 5.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 12.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 4.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 40;\n float snd = 0.01;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf *- 0.123);\n float spy = hash(spf / 0.317);\n float sps = hash(spf - 3.411);\n \n float sds = distance(vec2(u*step(1.9,snd*2.), -v+snd), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7*2., sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 0.5));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 33. / across);\n mat *= rotZ(snd * 2. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = sin(time + x * y * .02) * 5.; \n \n float pump = step(0.17, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .63;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-7qkivga9onla3i8xm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PHANwhhRXk62fsaeC/art.json b/art/PHANwhhRXk62fsaeC/art.json index c4b88862..5a745b0e 100644 --- a/art/PHANwhhRXk62fsaeC/art.json +++ b/art/PHANwhhRXk62fsaeC/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 aspect = mat4(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 1,\\n 0, 0, 0, 1);\\n\\nmat4 scale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY() {\\n float s = sin(time / 4.);\\n float c = cos(time / 4.);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotX() {\\n float deg = radians((-0.5 * (mouse.y + 1.)) * 360.);\\n float s = sin(deg);\\n float c = cos(deg);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, -s, 0,\\n 0, s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main()\\n{\\n float pointsPerCircle = 5000.;\\n if(vertexId < pointsPerCircle) {\\n float yPos = cos(vertexId / pointsPerCircle * PI);\\n float xyLen = sin(vertexId / pointsPerCircle * PI);\\n float xPos = sin(vertexId) * xyLen;\\n float zPos = cos(vertexId) * xyLen;\\n vec4 pos = vec4(xPos, yPos, zPos, 1);\\n pos = aspect * scale(0.5) * rotX() * rotY() * pos;\\n \\tgl_Position = pos;\\n gl_PointSize = (-pos.z + 0.5) * 8.;\\n \\tv_color = mix(vec4(1, 0, 0, 1), vec4(0, 0, 1, 1), vertexId / pointsPerCircle);\\n }\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 aspect = mat4(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 1,\n 0, 0, 0, 1);\n\nmat4 scale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY() {\n float s = sin(time / 4.);\n float c = cos(time / 4.);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotX() {\n float deg = radians((-0.5 * (mouse.y + 1.)) * 360.);\n float s = sin(deg);\n float c = cos(deg);\n return mat4(\n 1, 0, 0, 0,\n 0, c, -s, 0,\n 0, s, c, 0,\n 0, 0, 0, 1);\n}\n\nvoid main()\n{\n float pointsPerCircle = 5000.;\n if(vertexId < pointsPerCircle) {\n float yPos = cos(vertexId / pointsPerCircle * PI);\n float xyLen = sin(vertexId / pointsPerCircle * PI);\n float xPos = sin(vertexId) * xyLen;\n float zPos = cos(vertexId) * xyLen;\n vec4 pos = vec4(xPos, yPos, zPos, 1);\n pos = aspect * scale(0.5) * rotX() * rotY() * pos;\n \tgl_Position = pos;\n gl_PointSize = (-pos.z + 0.5) * 8.;\n \tv_color = mix(vec4(1, 0, 0, 1), vec4(0, 0, 1, 1), vertexId / pointsPerCircle);\n }\n}" + }, "screenshotURL": "data/images/images-gihztdx0i7zvgyqd9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PHWvovEcpp6R6yT8K/art.json b/art/PHWvovEcpp6R6yT8K/art.json index 4fe7f176..b1e4622f 100644 --- a/art/PHWvovEcpp6R6yT8K/art.json +++ b/art/PHWvovEcpp6R6yT8K/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/awen-recordings/lily-pitaapsara-filtering-history-original-mix-release-data-18052020\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 4.0);\\n float across = floor(sqrt(numQuads));\\n float down = floor(numQuads / across);\\n \\n float qId = floor(vertexId / 4.0);\\n float qx = mod(qId, across);\\n float qy = floor(qId / across);\\n\\n float vId = mod(vertexId, 4.0);\\n\\n vec2 p = vec2(\\n qx + step(vId, 0.5),\\n qy + step(2.5, vId)) / vec2(across, down);\\n vec2 pn = p * 2. - 1.;\\n \\n float distFromCenter = length(pn);\\n\\n float s = texture2D(sound, vec2(\\n hash(p.x) * 0.004 + \\n mix(0.02, 0.15, (abs(atan(pn.x, pn.y)) / PI)),\\n length(pn) * 0.5)).r;\\n \\n \\n vec3 pos = vec3(pn * 1., (pow(1. - distFromCenter, 0.3)) * .4 * s );\\n \\n \\n \\n vec3 eye = vec3(0, 0, -.01);\\n vec3 target = vec3(0, sin(time * 0.923) * 0.0005, 0);\\n vec3 up = vec3(sin(time * 0.37), 1, 0);\\n \\n mat4 mat = persp(160. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \\n mat *= cameraLookAt(eye, target, up);\\n gl_Position = mat * vec4(pos, 1);\\n\\n\\n float boost = step(0.7, s);\\n \\n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\\n float val = mix(0.25, 2.0, pow(s, 2.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/awen-recordings/lily-pitaapsara-filtering-history-original-mix-release-data-18052020", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid main() {\n float numQuads = floor(vertexCount / 4.0);\n float across = floor(sqrt(numQuads));\n float down = floor(numQuads / across);\n \n float qId = floor(vertexId / 4.0);\n float qx = mod(qId, across);\n float qy = floor(qId / across);\n\n float vId = mod(vertexId, 4.0);\n\n vec2 p = vec2(\n qx + step(vId, 0.5),\n qy + step(2.5, vId)) / vec2(across, down);\n vec2 pn = p * 2. - 1.;\n \n float distFromCenter = length(pn);\n\n float s = texture2D(sound, vec2(\n hash(p.x) * 0.004 + \n mix(0.02, 0.15, (abs(atan(pn.x, pn.y)) / PI)),\n length(pn) * 0.5)).r;\n \n \n vec3 pos = vec3(pn * 1., (pow(1. - distFromCenter, 0.3)) * .4 * s );\n \n \n \n vec3 eye = vec3(0, 0, -.01);\n vec3 target = vec3(0, sin(time * 0.923) * 0.0005, 0);\n vec3 up = vec3(sin(time * 0.37), 1, 0);\n \n mat4 mat = persp(160. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \n mat *= cameraLookAt(eye, target, up);\n gl_Position = mat * vec4(pos, 1);\n\n\n float boost = step(0.7, s);\n \n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\n float val = mix(0.25, 2.0, pow(s, 2.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-9qm2rtzrqgbaw4qsy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PHjEAtNPJWshykNWj/art.json b/art/PHjEAtNPJWshykNWj/art.json index 73a0b140..78cf7b12 100644 --- a/art/PHjEAtNPJWshykNWj/art.json +++ b/art/PHjEAtNPJWshykNWj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_POINTS_PER_GROUP 30.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float groupId = floor(vertexId / NUM_POINTS_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float ps = pointId / NUM_POINTS_PER_GROUP;\\n float numGroups = floor(vertexCount / NUM_POINTS_PER_GROUP);\\n float down = floor(sqrt(numGroups));\\n float across = floor(numGroups / down);\\n\\n float px = mod(groupId, across);\\n float py = floor(groupId / across);\\n float pu = px / across;\\n float pv = py / down;\\n \\n float tm = time * 0.5 - ps * 0.8 * (sin(time + pu * 3. * pv * 4.) * 0.5 + 0.5);\\n vec2 xy = vec2(\\n pu * 2. - 1. + sin(tm + px * 0.1) * 0.1 + cos(tm * px * py * 0.000009) * 0.1,\\n pv * 2. - 1. + sin(tm * 0.17 + py * 0.03) * cos(tm * 0.1 + px * 0.019) * 0.3\\n );\\n gl_Position = vec4(xy * 1.2, ps, 1);\\n gl_PointSize = 2.0;\\n\\n float hue = (time * 0.01 + pu * .12);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 0.7)), mix(0.9, 0., ps));\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_POINTS_PER_GROUP 30.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float groupId = floor(vertexId / NUM_POINTS_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_GROUP);\n float ps = pointId / NUM_POINTS_PER_GROUP;\n float numGroups = floor(vertexCount / NUM_POINTS_PER_GROUP);\n float down = floor(sqrt(numGroups));\n float across = floor(numGroups / down);\n\n float px = mod(groupId, across);\n float py = floor(groupId / across);\n float pu = px / across;\n float pv = py / down;\n \n float tm = time * 0.5 - ps * 0.8 * (sin(time + pu * 3. * pv * 4.) * 0.5 + 0.5);\n vec2 xy = vec2(\n pu * 2. - 1. + sin(tm + px * 0.1) * 0.1 + cos(tm * px * py * 0.000009) * 0.1,\n pv * 2. - 1. + sin(tm * 0.17 + py * 0.03) * cos(tm * 0.1 + px * 0.019) * 0.3\n );\n gl_Position = vec4(xy * 1.2, ps, 1);\n gl_PointSize = 2.0;\n\n float hue = (time * 0.01 + pu * .12);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 0.7)), mix(0.9, 0., ps));\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-7vozbqh0nrtxd40d4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PHxPuJWQiqm9gamRN/art.json b/art/PHxPuJWQiqm9gamRN/art.json index 7a924f4f..3eda0631 100644 --- a/art/PHxPuJWQiqm9gamRN/art.json +++ b/art/PHxPuJWQiqm9gamRN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46234.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\nvoid main()\\n{float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n vec2 r = vertexResolution,\\n o = simFragCoord.xy - r/2.;\\n o = vec2(length(o) / r.y - .3, atan(o.y,o.x)); \\n vec4 s = .1*cos(1.6*vec4(0,1,2,3) + time + o.y + sin(o.x) * sin(mouse.x * time / 1. + 5.4)*2.),\\n e = s.yzwx, \\n f = min(o.x-s,e-o.x);\\n v_color = dot(clamp(f*r.y,0.,1.), 40.*(s-e)) * (s-.1) - f;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46234.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n#ifdef GL_ES\n//precision mediump float;\n#endif\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\nvoid main()\n{float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n vec2 r = vertexResolution,\n o = simFragCoord.xy - r/2.;\n o = vec2(length(o) / r.y - .3, atan(o.y,o.x)); \n vec4 s = .1*cos(1.6*vec4(0,1,2,3) + time + o.y + sin(o.x) * sin(mouse.x * time / 1. + 5.4)*2.),\n e = s.yzwx, \n f = min(o.x-s,e-o.x);\n v_color = dot(clamp(f*r.y,0.,1.), 40.*(s-e)) * (s-.1) - f;\n}" + }, "screenshotURL": "data/images/images-xnr29rnwb5wv8a2zg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PJNdD52L3irdZzLDv/art.json b/art/PJNdD52L3irdZzLDv/art.json index d13b643b..f7ee069f 100644 --- a/art/PJNdD52L3irdZzLDv/art.json +++ b/art/PJNdD52L3irdZzLDv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ltms", "avatarUrl": "https://secure.gravatar.com/avatar/a8817f3d21a3b5c68e6c8d52f54fafa2?default=retro&size=200", - "settings": "{\"num\":346,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00392156862745098,0,0.23921568627450981,1],\"shader\":\"void main() {\\n // \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n // igy csak a x,y > 0 tartomanyban lesznek pontok (jobb felso)\\n // -1 azert kell, mert 0-9-ig megy x es y, 10zel osztva sose lesz 1 (emiatt nem volt jobb oldalt pontok)\\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n // megvaltoztatom az ertektartomanyt -1, +1 -re\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n // valtoztatjuk a pontok meretet attol fuggoen hany vertexunk van\\n gl_PointSize *= 20. / across;\\n // valtoztatjuk a pontok meretet a felbontastol fuggoen, hogy mindig arányos maradjon\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color= vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 346, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00392156862745098, + 0, + 0.23921568627450981, + 1 + ], + "shader": "void main() {\n // \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n // igy csak a x,y > 0 tartomanyban lesznek pontok (jobb felso)\n // -1 azert kell, mert 0-9-ig megy x es y, 10zel osztva sose lesz 1 (emiatt nem volt jobb oldalt pontok)\n float u = x / (across-1.);\n float v = y / (across-1.);\n \n // megvaltoztatom az ertektartomanyt -1, +1 -re\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n // valtoztatjuk a pontok meretet attol fuggoen hany vertexunk van\n gl_PointSize *= 20. / across;\n // valtoztatjuk a pontok meretet a felbontastol fuggoen, hogy mindig arányos maradjon\n gl_PointSize *= resolution.x / 600.;\n \n v_color= vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-348v7b4dqrzqwvkey-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PJotDZ2XkNc3ut8ok/art.json b/art/PJotDZ2XkNc3ut8ok/art.json index ff86b903..bed94fc8 100644 --- a/art/PJotDZ2XkNc3ut8ok/art.json +++ b/art/PJotDZ2XkNc3ut8ok/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.023529411764705882,0.16470588235294117,0.33725490196078434,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Making a Grid \\n// Course : CS250\\n// Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n \\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.023529411764705882, + 0.16470588235294117, + 0.33725490196078434, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Making a Grid \n// Course : CS250\n// Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n \n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-cc9dsnufoliof9fnc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PKKSn3hisqqifLpXX/art.json b/art/PKKSn3hisqqifLpXX/art.json index 468ee106..391ec607 100644 --- a/art/PKKSn3hisqqifLpXX/art.json +++ b/art/PKKSn3hisqqifLpXX/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "richel", "avatarUrl": "https://graph.facebook.com/1269313776429568/picture?type=large", - "settings": "{\"num\":600,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/industrialpope/pferdloss\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() \\n{\\n vec2 coords;\\n coords.x = mod(vertexId, 30.0);\\n coords.y = floor(vertexId / 30.0);\\n \\n float u = 1.0 / 30.0 * coords.x;\\n float v = 1.0 / 20.0 * coords.y;\\n \\n\\n // float historyX = u * 1.0;\\n //float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n \\n float historyX = sin((u * 0.5)/ soundRes.y * soundRes.y) * 0.8;\\n float historyV = cos((v * 0.5) / soundRes.x * soundRes.x) * .8;\\n \\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float posX = -0.7 + ((1.4 / 30.0) * coords.x);\\n posX += sin(time) * 0.1;\\n \\n float posY = -0.7 + (1.4 / 20.0) * coords.y;\\n posY += sin(time + coords.x * 0.1) * 0.1;\\n \\n float posZ = -1.0;//sin(coords.x + time);\\n \\n gl_Position = vec4(posX, posY, posZ, 1);\\n\\n if(coords.x > 8. && coords.x < 12. ||\\n coords.y > 8. && coords.y < 12. )\\n {\\n v_color = vec4(1.0, 1.0, 1.0, 1);\\n }\\n else\\n {\\n v_color = vec4(1.0, 0.0, 0.0, 1);\\n }\\n \\n gl_PointSize = snd * 35.0;\\n \\n \\n //gl_PointSize = 5.0 + (0.5 + sin(posX * posY * 10.0 + time * 2.0) * 0.5) * 20.0;\\n}\"}", + "settings": { + "num": 600, + "mode": "POINTS", + "sound": "https://soundcloud.com/industrialpope/pferdloss", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() \n{\n vec2 coords;\n coords.x = mod(vertexId, 30.0);\n coords.y = floor(vertexId / 30.0);\n \n float u = 1.0 / 30.0 * coords.x;\n float v = 1.0 / 20.0 * coords.y;\n \n\n // float historyX = u * 1.0;\n //float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n \n float historyX = sin((u * 0.5)/ soundRes.y * soundRes.y) * 0.8;\n float historyV = cos((v * 0.5) / soundRes.x * soundRes.x) * .8;\n \n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float posX = -0.7 + ((1.4 / 30.0) * coords.x);\n posX += sin(time) * 0.1;\n \n float posY = -0.7 + (1.4 / 20.0) * coords.y;\n posY += sin(time + coords.x * 0.1) * 0.1;\n \n float posZ = -1.0;//sin(coords.x + time);\n \n gl_Position = vec4(posX, posY, posZ, 1);\n\n if(coords.x > 8. && coords.x < 12. ||\n coords.y > 8. && coords.y < 12. )\n {\n v_color = vec4(1.0, 1.0, 1.0, 1);\n }\n else\n {\n v_color = vec4(1.0, 0.0, 0.0, 1);\n }\n \n gl_PointSize = snd * 35.0;\n \n \n //gl_PointSize = 5.0 + (0.5 + sin(posX * posY * 10.0 + time * 2.0) * 0.5) * 20.0;\n}" + }, "screenshotURL": "data/images/images-zg0rly956jm5h8ehw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PLaQo2H7Zkft5CLu2/art.json b/art/PLaQo2H7Zkft5CLu2/art.json index fdb56567..266f2d14 100644 --- a/art/PLaQo2H7Zkft5CLu2/art.json +++ b/art/PLaQo2H7Zkft5CLu2/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/allaboutthebeat/distant-friends-gen-neo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n \\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n \\n float x = (u*200.0)-10.0;\\n float y = 0.0;\\n gl_PointSize = 100.0;\\n gl_Position = vec4(x,y,0,1);\\n \\n float lum = floor(v *8.0 + 1.9)/10.0;\\n //float lum = 1.0;\\n v_color = vec4(v*lum*0.2,lum*0.75,lum*1.0,1);\\n\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/allaboutthebeat/distant-friends-gen-neo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n \n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n \n float x = (u*200.0)-10.0;\n float y = 0.0;\n gl_PointSize = 100.0;\n gl_Position = vec4(x,y,0,1);\n \n float lum = floor(v *8.0 + 1.9)/10.0;\n //float lum = 1.0;\n v_color = vec4(v*lum*0.2,lum*0.75,lum*1.0,1);\n\n}" + }, "screenshotURL": "data/images/images-t58m9twr6k3espldo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PLaynf8Y9S5jEPnGP/art.json b/art/PLaynf8Y9S5jEPnGP/art.json index c66557b6..13c9be5c 100644 --- a/art/PLaynf8Y9S5jEPnGP/art.json +++ b/art/PLaynf8Y9S5jEPnGP/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n parameter3, c, s, 0,\\n 0, -s, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 1,\\n s, 0, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians/parameter5);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0.2,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, parameter7 *4.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337 * parameter6);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.03 )).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 2.5 - parameter5);\\n mat *= rotZ(time * (0.1 + parameter2) * mix(-1., 1. , mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (parameter2 - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd / 3. * parameter3);\\n mat *= rotZ(PI * .25 + (parameter1 + snd));\\n \\n gl_Position = mat * vec4(pos, 3.- parameter3);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.66, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + (1. * parameter6), 2. );\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(2), pump);\\n v_color.rgb *= v_color.a ;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n parameter3, c, s, 0,\n 0, -s, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 1,\n s, 0, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians/parameter5);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0.2,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, parameter7 *4.3137));\n\treturn fract(p2.x * p2.y * 95.4337 * parameter6);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.03 )).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 2.5 - parameter5);\n mat *= rotZ(time * (0.1 + parameter2) * mix(-1., 1. , mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (parameter2 - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd / 3. * parameter3);\n mat *= rotZ(PI * .25 + (parameter1 + snd));\n \n gl_Position = mat * vec4(pos, 3.- parameter3);\n gl_PointSize = 4.;\n \n float pump = step(0.66, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + (1. * parameter6), 2. );\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(2), pump);\n v_color.rgb *= v_color.a ;\n}\n\n" + }, "screenshotURL": "data/images/images-2wbrxd7jhbg25dqkz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PMP5Sqmw8vLLrpJgw/art.json b/art/PMP5Sqmw8vLLrpJgw/art.json index eaf9315e..97356182 100644 --- a/art/PMP5Sqmw8vLLrpJgw/art.json +++ b/art/PMP5Sqmw8vLLrpJgw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3159,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define Kp0 22.//KParameter 0.>>22.\\n#define Kp1 1.//KParameter 0.>>1.\\n#define Kp2 0.6//KParameter 0.>>1.5\\n#define Kp3 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>1.\\n#define rotationFactorY 1.//KParameter 0.>>1.\\n#define rotationFactorZ 1.//KParameter 0.>>1.\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW2\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 4.3983, p * 5.4427*Kp0));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 4.) + mod(id, 4./Kp3);\\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 4. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 2.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * .3;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.7113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 2.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, .25, hash(cubeId)), length(cpos) * .015)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * .1, sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),-tm);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(cpos*-0.8*snd);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-.1, Kp2, pow(snd, 2.6)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0.)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4+Kp1, 0.5*Kp2));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.3, snd));\\n abs(ca * cd) * Kp2;\\n float sat =pow(snd * 11.,.16); step(0., snd)*2.;\\n float val =- 0.4+snd;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * .65 + 0.5);\\n v_color = vec4(color * mix(-4., 9., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 3159, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define Kp0 22.//KParameter 0.>>22.\n#define Kp1 1.//KParameter 0.>>1.\n#define Kp2 0.6//KParameter 0.>>1.5\n#define Kp3 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>1.\n#define rotationFactorY 1.//KParameter 0.>>1.\n#define rotationFactorZ 1.//KParameter 0.>>1.\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW2\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 4.3983, p * 5.4427*Kp0));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 4.) + mod(id, 4./Kp3);\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 4. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 2.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * .3;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.7113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 2.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, .25, hash(cubeId)), length(cpos) * .015)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * .1, sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),-tm);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(cpos*-0.8*snd);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-.1, Kp2, pow(snd, 2.6)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0.)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 1.4+Kp1, 0.5*Kp2));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.3, snd));\n abs(ca * cd) * Kp2;\n float sat =pow(snd * 11.,.16); step(0., snd)*2.;\n float val =- 0.4+snd;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * .65 + 0.5);\n v_color = vec4(color * mix(-4., 9., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-4idqy6pnfswlwukfw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PMhjdsdCjrLMctssg/art.json b/art/PMhjdsdCjrLMctssg/art.json index b72b43df..77eef1ef 100644 --- a/art/PMhjdsdCjrLMctssg/art.json +++ b/art/PMhjdsdCjrLMctssg/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27450980392156865,0.2784313725490196,0.42745098039215684,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Term : Spring 2023\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n \\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27450980392156865, + 0.2784313725490196, + 0.42745098039215684, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Term : Spring 2023\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n \n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1,0,0,1);\n \n}\n" + }, "screenshotURL": "data/images/images-r1y6prtdjizib41zv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PNKS5Rcz4wR4JLhcq/art.json b/art/PNKS5Rcz4wR4JLhcq/art.json index c4f8a035..e7c56f63 100644 --- a/art/PNKS5Rcz4wR4JLhcq/art.json +++ b/art/PNKS5Rcz4wR4JLhcq/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Motion\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Motion\n// Course Name: CS250\n// Term: Spring 2022\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-bblaw67y01otximv0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PNhE8dDWq3i4kPX64/art.json b/art/PNhE8dDWq3i4kPX64/art.json index 5884953e..54609839 100644 --- a/art/PNhE8dDWq3i4kPX64/art.json +++ b/art/PNhE8dDWq3i4kPX64/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":60000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define pi acos(-1.)\\n\\nmat4 porj(float l, float r, float b, float t, float n, float f){\\n return mat4(\\n 2./(r-l),0,0 ,0./*-(r+l)/(r-l)*/,\\n 0,2./(t-b),0 ,0./*-(t+b)/(t-b)*/,\\n 0,0,-2./(f-n),-(f+n)/(f-n),\\n 0,0,0,1\\n );\\n}\\n\\nmat4 mov(vec3 p){\\n return mat4(\\n 1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n p ,1\\n );\\n}\\n\\nmat4 rotz(float t){\\n float s=sin(t), c=cos(t);\\n return mat4(\\n c,-s,0,0,\\n s,c,0,0,\\n 0,0,1,0,\\n 0,0,0,1\\n );\\n}\\n\\nmat4 roty(float t){\\n float s=sin(t), c=cos(t);\\n return mat4(\\n c,0,s,0,\\n 0,1,0,0,\\n -s,0,c,0,\\n 0,0,0,1\\n );\\n}\\n\\nmat4 rotx(float t){\\n float s=sin(t), c=cos(t);\\n return mat4(\\n 1,0,0,0,\\n 0,c,-s,0,\\n 0,s,c,0,\\n 0,0,0,1\\n );\\n}\\n\\nvoid getMesh(out float x, out float y, out float s){\\n float step6 = mod(vertexId, 6.);\\n float step3 = mod(vertexId, 3.);\\n float temp = step3;\\n if(step6 >= 3.){\\n temp ++;\\n }\\n if(temp < 0.5){\\n x = 0.;\\n y = 0.;\\n }\\n else if(temp < 1.5){\\n x = 1.;\\n y = 0.;\\n }\\n else if(temp < 2.5){\\n x = 0.;\\n y = 1.;\\n }\\n else if(temp < 3.5){\\n x = 1.;\\n y = 1.;\\n }\\n s = floor(vertexId/6.);\\n}\\n\\nfloat f(vec2 uv ){\\n //return (-pow(uv.x,2.)-pow(uv.y,2.))+1.;\\n return 0.07+0.07*sin(time-length(5.*pi*uv));\\n}\\n\\n\\nvoid main() {\\n float posx, posy, posStep;\\n \\n getMesh(posx, posy, posStep);\\n \\n vec2 v8 = vec2(100., 100.);\\n vec2 uv;\\n vec3 vuv;\\n \\n uv.x = mod(posStep, v8.x);\\n uv.y = floor(posStep/ v8.y);\\n \\n vuv.x = posx + uv.x;\\n vuv.y = posy + uv.y;\\n \\n vuv.xy = vuv.xy * (1. / v8);\\n vuv.xy = vuv.xy * 2. - 1.;\\n \\n vuv.z = f(vuv.xy);\\n \\n mat4 M = mov(vec3(0.,0.,0.)) * rotx(2.*mouse.y) * roty(0.) * rotz(-2.*mouse.x);\\n mat4 V = mov(vec3(0.,-0.5,-2)) * rotx(pi/2.) * roty(0.) * rotz(0.);\\n mat4 P = porj(0., 1., 0., 1., 1., 100000.0);\\n \\n gl_Position = P*V*M* vec4(vuv,1);\\n gl_PointSize = 8.;\\n \\n vec3 normal = cross(vec3(1,0,vuv.xy*vuv.z),vec3(0,1,vuv.yx*vuv.z));\\n vec3 pos_light1 = normalize(vuv-vec3(5.*cos(1.7),5.*-sin(1.7),-1.));\\n float light1 = max(0.0,dot(pos_light1, normal))*2.;\\n vec3 color = vec3(.3,.5,.8)*light1;\\n \\n \\n v_color = vec4(color,1.);\\n}\"}", + "settings": { + "num": 60000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define pi acos(-1.)\n\nmat4 porj(float l, float r, float b, float t, float n, float f){\n return mat4(\n 2./(r-l),0,0 ,0./*-(r+l)/(r-l)*/,\n 0,2./(t-b),0 ,0./*-(t+b)/(t-b)*/,\n 0,0,-2./(f-n),-(f+n)/(f-n),\n 0,0,0,1\n );\n}\n\nmat4 mov(vec3 p){\n return mat4(\n 1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n p ,1\n );\n}\n\nmat4 rotz(float t){\n float s=sin(t), c=cos(t);\n return mat4(\n c,-s,0,0,\n s,c,0,0,\n 0,0,1,0,\n 0,0,0,1\n );\n}\n\nmat4 roty(float t){\n float s=sin(t), c=cos(t);\n return mat4(\n c,0,s,0,\n 0,1,0,0,\n -s,0,c,0,\n 0,0,0,1\n );\n}\n\nmat4 rotx(float t){\n float s=sin(t), c=cos(t);\n return mat4(\n 1,0,0,0,\n 0,c,-s,0,\n 0,s,c,0,\n 0,0,0,1\n );\n}\n\nvoid getMesh(out float x, out float y, out float s){\n float step6 = mod(vertexId, 6.);\n float step3 = mod(vertexId, 3.);\n float temp = step3;\n if(step6 >= 3.){\n temp ++;\n }\n if(temp < 0.5){\n x = 0.;\n y = 0.;\n }\n else if(temp < 1.5){\n x = 1.;\n y = 0.;\n }\n else if(temp < 2.5){\n x = 0.;\n y = 1.;\n }\n else if(temp < 3.5){\n x = 1.;\n y = 1.;\n }\n s = floor(vertexId/6.);\n}\n\nfloat f(vec2 uv ){\n //return (-pow(uv.x,2.)-pow(uv.y,2.))+1.;\n return 0.07+0.07*sin(time-length(5.*pi*uv));\n}\n\n\nvoid main() {\n float posx, posy, posStep;\n \n getMesh(posx, posy, posStep);\n \n vec2 v8 = vec2(100., 100.);\n vec2 uv;\n vec3 vuv;\n \n uv.x = mod(posStep, v8.x);\n uv.y = floor(posStep/ v8.y);\n \n vuv.x = posx + uv.x;\n vuv.y = posy + uv.y;\n \n vuv.xy = vuv.xy * (1. / v8);\n vuv.xy = vuv.xy * 2. - 1.;\n \n vuv.z = f(vuv.xy);\n \n mat4 M = mov(vec3(0.,0.,0.)) * rotx(2.*mouse.y) * roty(0.) * rotz(-2.*mouse.x);\n mat4 V = mov(vec3(0.,-0.5,-2)) * rotx(pi/2.) * roty(0.) * rotz(0.);\n mat4 P = porj(0., 1., 0., 1., 1., 100000.0);\n \n gl_Position = P*V*M* vec4(vuv,1);\n gl_PointSize = 8.;\n \n vec3 normal = cross(vec3(1,0,vuv.xy*vuv.z),vec3(0,1,vuv.yx*vuv.z));\n vec3 pos_light1 = normalize(vuv-vec3(5.*cos(1.7),5.*-sin(1.7),-1.));\n float light1 = max(0.0,dot(pos_light1, normal))*2.;\n vec3 color = vec3(.3,.5,.8)*light1;\n \n \n v_color = vec4(color,1.);\n}" + }, "screenshotURL": "data/images/images-5bnlbabuqnjsbdg3b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PRrsa99yGZN6XannP/art.json b/art/PRrsa99yGZN6XannP/art.json index 0cc8cf4a..02a0ef43 100644 --- a/art/PRrsa99yGZN6XannP/art.json +++ b/art/PRrsa99yGZN6XannP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":37039,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0392156862745098,0.054901960784313725,0.027450980392156862,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner =mouse.y;\\n float start = mouse.x;\\n float end =step(0.13,0.5+s);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.4123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(-t * .63 +s) * 10., sin(t * .4+s)*20.*s, 0.);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0.5);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .017);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 23.5 +s *s* .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\\n float sat =1.0;step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb /= v_color.a*s;\\n \\n float super = step(0.9, 1.-s);\\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\\n \\n}\\n\"}", + "settings": { + "num": 37039, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0392156862745098, + 0.054901960784313725, + 0.027450980392156862, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner =mouse.y;\n float start = mouse.x;\n float end =step(0.13,0.5+s);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.4123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(-t * .63 +s) * 10., sin(t * .4+s)*20.*s, 0.);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0.5);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .017);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 23.5 +s *s* .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\n float sat =1.0;step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb /= v_color.a*s;\n \n float super = step(0.9, 1.-s);\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\n \n}\n" + }, "screenshotURL": "data/images/images-qrykwnw7a1quvp65e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PSjv6ihn8226ALFCx/art.json b/art/PSjv6ihn8226ALFCx/art.json index 99fe6f83..e678a981 100644 --- a/art/PSjv6ihn8226ALFCx/art.json +++ b/art/PSjv6ihn8226ALFCx/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 4.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 20;\\n float snd = 0.;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf * 7.123);\\n float spy = hash(spf * 0.317);\\n float sps = hash(spf * 3.411);\\n \\n float sds = distance(vec2(u, v), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.01, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7, sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.1 * sc * 30. / across);\\n //mat *= rotZ(snd * 10. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.7, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.6, hsv.x) + time * 0.6 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 4.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 20;\n float snd = 0.;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf * 7.123);\n float spy = hash(spf * 0.317);\n float sps = hash(spf * 3.411);\n \n float sds = distance(vec2(u, v), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.01, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7, sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.1 * sc * 30. / across);\n //mat *= rotZ(snd * 10. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.7, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.6, hsv.x) + time * 0.6 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-aqowvzjy4b44t7zez-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PTcamNGqbYP3egN7J/art.json b/art/PTcamNGqbYP3egN7J/art.json index 765f6176..d1fcc61c 100644 --- a/art/PTcamNGqbYP3egN7J/art.json +++ b/art/PTcamNGqbYP3egN7J/art.json @@ -28,7 +28,19 @@ "name": "unnamed 2", "private": true, "username": "andrea", - "settings": "{\"num\":5550,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\\n#define STEP 8.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 1.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 60.0;\\n float point = mod(floor(vertexId / 8.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 3.14 / NUM_SEGMENTS + offset;\\n float radius = 0.1;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.004;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5550, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\n#define STEP 8.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 1.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 60.0;\n float point = mod(floor(vertexId / 8.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 3.14 / NUM_SEGMENTS + offset;\n float radius = 0.1;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.004;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ptr8xhnk2iozgzema-thumbnail.jpg", "views": { "$numberInt": "100" diff --git a/art/PXhZibqyymFpz4qCz/art.json b/art/PXhZibqyymFpz4qCz/art.json index bf9984dc..86cf7a81 100644 --- a/art/PXhZibqyymFpz4qCz/art.json +++ b/art/PXhZibqyymFpz4qCz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":8000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Motion, own variation\\n//course name : CS250\\n//term : Spring 2023\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.4; \\n float yoff = sin(time + x * 0.2) * 0.4;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3 ;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n v_color += vec4(ux * cos(time),vy * cos(time * 2.), u * cos(time * 3.),1);\\n}\"}", + "settings": { + "num": 8000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Motion, own variation\n//course name : CS250\n//term : Spring 2023\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.4; \n float yoff = sin(time + x * 0.2) * 0.4;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3 ;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n v_color += vec4(ux * cos(time),vy * cos(time * 2.), u * cos(time * 3.),1);\n}" + }, "screenshotURL": "data/images/images-1gmlkf8vmlr5nxs5h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PXqNQnv5Xc23ek5f2/art.json b/art/PXqNQnv5Xc23ek5f2/art.json index 458bc909..27e0b6ba 100644 --- a/art/PXqNQnv5Xc23ek5f2/art.json +++ b/art/PXqNQnv5Xc23ek5f2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Audio Reactive\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Audio Reactive\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-u2xbmxoq5wihkpara-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PZbvDng9i2QhrcC3y/art.json b/art/PZbvDng9i2QhrcC3y/art.json index 37ca32c4..f6d85868 100644 --- a/art/PZbvDng9i2QhrcC3y/art.json +++ b/art/PZbvDng9i2QhrcC3y/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lizell", "avatarUrl": "https://secure.gravatar.com/avatar/8cbc7cccd5a415ae64aab0284832279b?default=retro&size=200", - "settings": "{\"num\":2277,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time * 1.2 + x * y * 0.02) *5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 2277, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time * 1.2 + x * y * 0.02) *5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-q5cuwjn0h3mrrwju6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PaksuLs2j2rAHuzxw/art.json b/art/PaksuLs2j2rAHuzxw/art.json index 1a27b177..891ded0c 100644 --- a/art/PaksuLs2j2rAHuzxw/art.json +++ b/art/PaksuLs2j2rAHuzxw/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thesoftmoon/stupid-child?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.11372549019607843,0.32941176470588235,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float scale = 0.8;\\n vec2 xy = vec2(ux, vy) * scale;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n float soff = 0.; // sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float hue = u;\\n float sat = v;\\n float val = 1.;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/thesoftmoon/stupid-child?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.11372549019607843, + 0.32941176470588235, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float scale = 0.8;\n vec2 xy = vec2(ux, vy) * scale;\n \n gl_Position = vec4(xy, 0., 1.);\n \n float soff = 0.; // sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float hue = u;\n float sat = v;\n float val = 1.;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n}" + }, "screenshotURL": "data/images/images-lrt39s1la0lpozjm7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PbQ763xTmvvCYLywu/art.json b/art/PbQ763xTmvvCYLywu/art.json index 88e134a5..3be51d73 100644 --- a/art/PbQ763xTmvvCYLywu/art.json +++ b/art/PbQ763xTmvvCYLywu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "isaac", "avatarUrl": "https://lh4.googleusercontent.com/-G3dTIkCG6vw/AAAAAAAAAAI/AAAAAAAAAdM/34mVqVIkl-4/photo.jpg", - "settings": "{\"num\":30078,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/jericho2k/modular-diary-ambient6-live-jam-shapeshifter-spectral-multiband-resonator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0., 0., 0),\\n vec3(0, 0.0, 0.0),\\n gl_Position.x);\\n gl_PointSize = s*s*10.0;\\n v_color = vec4(color, gl_Position.z*0.1 );\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 30078, + "mode": "LINES", + "sound": "https://soundcloud.com/jericho2k/modular-diary-ambient6-live-jam-shapeshifter-spectral-multiband-resonator", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0., 0., 0),\n vec3(0, 0.0, 0.0),\n gl_Position.x);\n gl_PointSize = s*s*10.0;\n v_color = vec4(color, gl_Position.z*0.1 );\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-ls6d76snz52ucnov6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PcGaeSXys75hdn3ky/art.json b/art/PcGaeSXys75hdn3ky/art.json index f4830530..04c82d8b 100644 --- a/art/PcGaeSXys75hdn3ky/art.json +++ b/art/PcGaeSXys75hdn3ky/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c - v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t * 0.3+mouse.x) + cos(-t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId - 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 1.33) + sin(time * .3 + circleId) * 3.1);\\n float end = start - 6.3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + .1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c - v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t * 0.3+mouse.x) + cos(-t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId - 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 1.33) + sin(time * .3 + circleId) * 3.1);\n float end = start - 6.3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + .1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-s8c60owuwvzrevlcv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PcKwWKK2nMJ7TjaaT/art.json b/art/PcKwWKK2nMJ7TjaaT/art.json index 291bd872..47f0ab67 100644 --- a/art/PcKwWKK2nMJ7TjaaT/art.json +++ b/art/PcKwWKK2nMJ7TjaaT/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/autonoise_records/plom_b8-forma\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\\n{\\n vec2 finalRes = vec2(1.,1.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n _maxvertexCount = floor(vertexCount*ratioXforY);\\n \\n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\\n \\n return vec2(finalRes.x,finalRes.x/ratioXforY);\\n}\\n \\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n //float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n //float ratio = resolution.y/numAcrossDown;\\n \\n //float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n float x = mod(finalVertexId, finalResolution.x);\\n float y = floor(finalVertexId / finalResolution.y);\\n \\n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\\n float v = (y / finalResolution.y);\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\\n \\n float sndOffset = snd;\\n if(v>0.5)\\n sndOffset = -snd;\\n float vy = sndOffset+( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\\n \\n \\n \\n \\n \\n //apply fragment logic\\n\\n vec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n \\n \\n\\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/autonoise_records/plom_b8-forma", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\n{\n vec2 finalRes = vec2(1.,1.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n _maxvertexCount = floor(vertexCount*ratioXforY);\n \n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\n \n return vec2(finalRes.x,finalRes.x/ratioXforY);\n}\n \nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n //float numAcrossDown = floor(sqrt(finalVertexCount));\n \n //float ratio = resolution.y/numAcrossDown;\n \n //float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n float x = mod(finalVertexId, finalResolution.x);\n float y = floor(finalVertexId / finalResolution.y);\n \n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\n float v = (y / finalResolution.y);\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\n \n float sndOffset = snd;\n if(v>0.5)\n sndOffset = -snd;\n float vy = sndOffset+( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\n \n \n \n \n \n //apply fragment logic\n\n vec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n \n \n\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-425pey3xui2udoa4l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Pcb2n3yJfxALCGt2x/art.json b/art/Pcb2n3yJfxALCGt2x/art.json index b8cfcef7..15c0163f 100644 --- a/art/Pcb2n3yJfxALCGt2x/art.json +++ b/art/Pcb2n3yJfxALCGt2x/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "pgan", "avatarUrl": "https://secure.gravatar.com/avatar/b786c3cea88eff238ced38e7ee896997?default=retro&size=200", - "settings": "{\"num\":3845,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n // gl_PointSize = 10.0;\\n gl_PointSize = 5.0;\\n\\n float magic = vertexCount;\\n vec2 adjust = vec2(-magic / 2.0, -magic / 2.0);\\n\\n // float x = mod(vertexId, magic);\\n float x = 2.0 * (vertexId / vertexCount) - 1.0;\\n // float y = floor(vertexId / magic);\\n float y = vertexId / vertexCount;\\n \\n float s = sin(mod(vertexId / 100.0, 100.0) - 0.5);\\n \\n // gl_Position = vec4(x, y, 0.0, 1.0);\\n gl_Position = vec4(x, s, 0.0, 1.0);\\n \\n // v_color = vec4(0.0, 1.0, 0.0, 1.0);\\n v_color = vec4(s, mod(time * 0.25, 1.0), 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 3845, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n // gl_PointSize = 10.0;\n gl_PointSize = 5.0;\n\n float magic = vertexCount;\n vec2 adjust = vec2(-magic / 2.0, -magic / 2.0);\n\n // float x = mod(vertexId, magic);\n float x = 2.0 * (vertexId / vertexCount) - 1.0;\n // float y = floor(vertexId / magic);\n float y = vertexId / vertexCount;\n \n float s = sin(mod(vertexId / 100.0, 100.0) - 0.5);\n \n // gl_Position = vec4(x, y, 0.0, 1.0);\n gl_Position = vec4(x, s, 0.0, 1.0);\n \n // v_color = vec4(0.0, 1.0, 0.0, 1.0);\n v_color = vec4(s, mod(time * 0.25, 1.0), 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-u4f3fg7g8mha0wkhe-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PdyGqhyQKndEoHwaa/art.json b/art/PdyGqhyQKndEoHwaa/art.json index 410d84a5..68ab31ca 100644 --- a/art/PdyGqhyQKndEoHwaa/art.json +++ b/art/PdyGqhyQKndEoHwaa/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":32707,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 1.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n#define PI radians(180.)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *17.,s)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE * 8.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (3.0 /v);\\n float s = sin(a);\\n float c = cos(s-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.5;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) - mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y *1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 1.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId*snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 32707, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 1.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n#define PI radians(180.)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *17.,s)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE * 8.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (3.0 /v);\n float s = sin(a);\n float c = cos(s-a);\n float x = c -v;\n float y = s * v;\n float z = -0.5;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) - mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y *1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 1.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId*snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-0hxbw9nfgttj88b5d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PitEvTS6w7WK8RHn8/art.json b/art/PitEvTS6w7WK8RHn8/art.json index 41ec20ef..74775765 100644 --- a/art/PitEvTS6w7WK8RHn8/art.json +++ b/art/PitEvTS6w7WK8RHn8/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 27.0;\\n float radius1 = 20;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 27.0;\n float radius1 = 20;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-yleufhj08d1y2t4ob-thumbnail.jpg", "views": { "$numberInt": "96" diff --git a/art/Piyv2py4bQL283mTB/art.json b/art/Piyv2py4bQL283mTB/art.json index 9f0e3367..3ca319c6 100644 --- a/art/Piyv2py4bQL283mTB/art.json +++ b/art/Piyv2py4bQL283mTB/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "mrshoor", "avatarUrl": "https://lh5.googleusercontent.com/-LXMYHmf3REM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3re1I0lelewVaOzZYQnhGBlwPNSlaA/photo.jpg", - "settings": "{\"num\":8000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat anim(float t) {\\n float st = sin(t);\\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvec3 SampleCubePos(float idx, float num) {\\n float side = floor(pow(num, 1.0/3.0)+0.5);\\n vec3 res;\\n res.x = mod(idx, side);\\n res.y = floor( mod(idx, side*side)/side );\\n res.z = floor( mod(idx, side*side*side)/side/side );\\n res -= vec3(side * 0.5);\\n res *= 1.5/side;\\n return res;\\n}\\n\\nvoid main() {\\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 8000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat anim(float t) {\n float st = sin(t);\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvec3 SampleCubePos(float idx, float num) {\n float side = floor(pow(num, 1.0/3.0)+0.5);\n vec3 res;\n res.x = mod(idx, side);\n res.y = floor( mod(idx, side*side)/side );\n res.z = floor( mod(idx, side*side*side)/side/side );\n res -= vec3(side * 0.5);\n res *= 1.5/side;\n return res;\n}\n\nvoid main() {\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\n \n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-o0l69ynhe0rxfgd8s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PjY2sWZMomTjpuym6/art.json b/art/PjY2sWZMomTjpuym6/art.json index dfc60d65..ab53854d 100644 --- a/art/PjY2sWZMomTjpuym6/art.json +++ b/art/PjY2sWZMomTjpuym6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thenoiseprocess/i-want-my-credit-card\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n \\n\\n if(v>0.5)\\n position.y = (1. -position.y);\\n \\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\t//j *= 1.;\\n\\tj = mod(j + time, 1.0);\\n\\t\\n\\tfloat i = mod( position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\\n\\t\\n i = mod( sin(position.y * (7.+snd*40.))*sin(position.x * 7.) * j, i / j);\\n \\n\\ti *= 5.;\\n\\t\\n\\t//i = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thenoiseprocess/i-want-my-credit-card", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n \n\n if(v>0.5)\n position.y = (1. -position.y);\n \n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\t//j *= 1.;\n\tj = mod(j + time, 1.0);\n\t\n\tfloat i = mod( position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\n\t\n i = mod( sin(position.y * (7.+snd*40.))*sin(position.x * 7.) * j, i / j);\n \n\ti *= 5.;\n\t\n\t//i = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-24fahu7rqy2vsnvwc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PkSbv7TufuWHiNRbd/art.json b/art/PkSbv7TufuWHiNRbd/art.json index d9046eef..5ea7c2ef 100644 --- a/art/PkSbv7TufuWHiNRbd/art.json +++ b/art/PkSbv7TufuWHiNRbd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":15360,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/beatsfar/grand-mas-mandoline\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 🌈 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 64.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float tm = time - cgv * 0.2;\\n \\n float su = mix(0.01, 0.2, abs(t2m1(cu)));\\n float sv = 0.;\\n float s = texture2D(sound, vec2(su, sv)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cu * 0.001;\\n pos.x *= cos(pos.y) * mix(.25, .75, abs(sin(time * 0.131)));\\n \\n vec3 eye = vec3(sin(time * 0.), sin(time * 0.) * 0.25, 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 10.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.1 + t2m1(cu) * PI);// * sin(time* 0.1));\\n mat *= trans(vec3(t5p5(sin(time * 0.273)), mix(0.2, 1.5, t5p5(sin(time * 0.171))), 0));\\n mat *= rotZ(t5p5(sin(time * 0.147)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n\\n float hue = 1. + cu;\\n float sat = mix(.3, 1., abs(sin(time * 0.213)));\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0.01, 0.2, s));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 15360, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/beatsfar/grand-mas-mandoline", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 🌈 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 64.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float tm = time - cgv * 0.2;\n \n float su = mix(0.01, 0.2, abs(t2m1(cu)));\n float sv = 0.;\n float s = texture2D(sound, vec2(su, sv)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cu * 0.001;\n pos.x *= cos(pos.y) * mix(.25, .75, abs(sin(time * 0.131)));\n \n vec3 eye = vec3(sin(time * 0.), sin(time * 0.) * 0.25, 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 10.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.1 + t2m1(cu) * PI);// * sin(time* 0.1));\n mat *= trans(vec3(t5p5(sin(time * 0.273)), mix(0.2, 1.5, t5p5(sin(time * 0.171))), 0));\n mat *= rotZ(t5p5(sin(time * 0.147)));\n \n gl_Position = mat * vec4(pos, 1);\n\n float hue = 1. + cu;\n float sat = mix(.3, 1., abs(sin(time * 0.213)));\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0.01, 0.2, s));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-s05kmrz2baxi53qgk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PkkKJZY7bP4Q5oHQQ/art.json b/art/PkkKJZY7bP4Q5oHQQ/art.json index fafccb56..4de9f156 100644 --- a/art/PkkKJZY7bP4Q5oHQQ/art.json +++ b/art/PkkKJZY7bP4Q5oHQQ/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/quitstalin/lookatu-deadmau5-holland9000\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 512.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/quitstalin/lookatu-deadmau5-holland9000", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 512.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-83y58pv62sbtu4kz6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PmRwSpR6jxkbJgsE4/art.json b/art/PmRwSpR6jxkbJgsE4/art.json index 5bc3ea8b..025e3571 100644 --- a/art/PmRwSpR6jxkbJgsE4/art.json +++ b/art/PmRwSpR6jxkbJgsE4/art.json @@ -27,7 +27,19 @@ "name": "modern_fireplace", "private": false, "username": "spotline", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/resting-at-the-mainframes-inn-ft-hirundo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define K 1.0594630943592952645618\\n\\nvec4 hueRamp(vec4 col)\\n{\\n vec4 blu = vec4(0.1,0.05,0.1,1.0);\\n vec4 red = vec4(0.5,0.1,0.1,1.0);\\n vec4 result = mix(blu,red,col.a*60.0-0.1);\\n return result;\\n}\\n\\nvoid main() \\n{\\n float W = 400.0;\\n float H = 250.0;\\n float u = 0.0;\\n float v = 0.0;\\n u = mod(vertexId/W,1.0);\\n v = floor(vertexId/W)/H;\\n float uScaled = pow(2.0,u*0.17)-1.0;\\n float vScaled = pow(abs(v-0.5)*1.0,1.3);\\n \\n v_color = vec4(pow(texture2D(sound,vec2(uScaled,vScaled)).a,8.0));\\n v_color = hueRamp(v_color);\\n \\n float x = v*-2.0 + 1.0;\\n float y;\\n y = u*2.0 - 0.8 + 0.5*pow(x,2.0);\\n gl_PointSize = 12.0;\\n gl_Position = vec4(x,y,0,1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/resting-at-the-mainframes-inn-ft-hirundo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define K 1.0594630943592952645618\n\nvec4 hueRamp(vec4 col)\n{\n vec4 blu = vec4(0.1,0.05,0.1,1.0);\n vec4 red = vec4(0.5,0.1,0.1,1.0);\n vec4 result = mix(blu,red,col.a*60.0-0.1);\n return result;\n}\n\nvoid main() \n{\n float W = 400.0;\n float H = 250.0;\n float u = 0.0;\n float v = 0.0;\n u = mod(vertexId/W,1.0);\n v = floor(vertexId/W)/H;\n float uScaled = pow(2.0,u*0.17)-1.0;\n float vScaled = pow(abs(v-0.5)*1.0,1.3);\n \n v_color = vec4(pow(texture2D(sound,vec2(uScaled,vScaled)).a,8.0));\n v_color = hueRamp(v_color);\n \n float x = v*-2.0 + 1.0;\n float y;\n y = u*2.0 - 0.8 + 0.5*pow(x,2.0);\n gl_PointSize = 12.0;\n gl_Position = vec4(x,y,0,1);\n}\n" + }, "screenshotURL": "data/images/images-nbty2jodhfck9lmdx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PmW7c9NeLghdwa8S4/art.json b/art/PmW7c9NeLghdwa8S4/art.json index 71da5fef..92e0e0ff 100644 --- a/art/PmW7c9NeLghdwa8S4/art.json +++ b/art/PmW7c9NeLghdwa8S4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/queen-e/the-bird-and-the-bee-florence\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n \\n . \\n .-. ...;....;. _ \\n_.; : .-. .;.::..'.-. `.,' ' \\n ; ;.;.-' .; .;.;.-' ,'`. \\n `._.' `:::'.;' .; `:::' -' `._. \\n .; .' \\n . ;;-. .-. .-..' .-. .;.::. \\n .'; ;; ;; : : ; .;.-' .; \\n .' .'.;` ``:::'-'`:::'`.`:::'.;' \\n' . \\n ...;... \\n .-. .;.::..' \\n ; : .; .; \\n `:::'-'.;' .; \\n \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float r = pow(cos((u - 0.5) * 2.), 2.);\\n float s = sin(a) * abs(cos(a * 0.5));\\n float c = cos(a);\\n float x = c * v * r;\\n float y = s * v * r;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nconst float numTrails = 1.;\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n// float trailId = mod(circleId, numTrails);\\n// float trailV = trailId / numTrails;\\n// circleId = floor(circleId / trailId);\\nfloat trailV = 1.;\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float pointV = pointId / NUM_POINTS_PER_CIRCLE;\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;//mix(0.0, 1.0, p1m1(sin(goop(circleId) + time * 0.0)));\\n float start = 0.0;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n \\n float across = floor(sqrt(numCircles));\\n float down = floor(numCircles / across);\\n float uId = mod(circleId, across);\\n float u = uId / (across - 1.);\\n float vId = floor(circleId / across);\\n float v = vId / (down - 1.);\\n \\n float ur = m1p1(u);// * cos(time);\\n float vr = m1p1(v);// * sin(time);\\n float rr = length(vec2(ur, vr));\\n float aa = (atan(ur, vr) + PI) / (2. * PI);\\n float snd = texture2D(sound, vec2(abs(m1p1(aa)) * 0.0125, rr * .2)).a;\\n \\n \\n vec3 offset = vec3(0);vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\\n offset.x += 0.;m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\\n offset.y += 0.;goop(circleId + time * 0.) * 0.1;\\n float timeOff = m1p1(mod(time * 0.01 + (cu * 3.), 1.));\\n offset.x += m1p1(u) + mod(vId, 2.) / across; //sin(timeOff * PI * 2.) * cu * 2.;\\n offset.y += m1p1(v); //cos(timeOff * PI * 2.) * cu * 2.;\\n offset.z = -m1p1(cu);//m1p1(hash(circleId * 0.641)) - trailV * 0.01;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1.);\\n \\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n // mat *= rotZ(hash(circleId * 0.543) * PI * 2.);\\n mat *= trans(offset);\\n // mat *= rotZ(hash(circleId * 0.234) * PI * 2. + time);\\n // mat *= rotZ(PI * -1.5 + snd * 6.);\\n mat *= rotZ(m1p1(aa) * PI - PI * 0.5 );\\n mat *= uniformScale(mix(0.0, 0.2, /*hash(circleId) * */ pow(snd, 3.0)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.9, 1.05, fract(circleId * 0.17 + snd));\\n float sat = trailV; //mix(1., 0., step(0.99, pow(snd, 5.0)));\\n float val = mix(0.8, 1.0, fract(circleId * 0.79));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.a = p1m1(offset.z);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/queen-e/the-bird-and-the-bee-florence", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n \n . \n .-. ...;....;. _ \n_.; : .-. .;.::..'.-. `.,' ' \n ; ;.;.-' .; .;.;.-' ,'`. \n `._.' `:::'.;' .; `:::' -' `._. \n .; .' \n . ;;-. .-. .-..' .-. .;.::. \n .'; ;; ;; : : ; .;.-' .; \n .' .'.;` ``:::'-'`:::'`.`:::'.;' \n' . \n ...;... \n .-. .;.::..' \n ; : .; .; \n `:::'-'.;' .; \n \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float r = pow(cos((u - 0.5) * 2.), 2.);\n float s = sin(a) * abs(cos(a * 0.5));\n float c = cos(a);\n float x = c * v * r;\n float y = s * v * r;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nconst float numTrails = 1.;\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n// float trailId = mod(circleId, numTrails);\n// float trailV = trailId / numTrails;\n// circleId = floor(circleId / trailId);\nfloat trailV = 1.;\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float pointV = pointId / NUM_POINTS_PER_CIRCLE;\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;//mix(0.0, 1.0, p1m1(sin(goop(circleId) + time * 0.0)));\n float start = 0.0;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n \n float across = floor(sqrt(numCircles));\n float down = floor(numCircles / across);\n float uId = mod(circleId, across);\n float u = uId / (across - 1.);\n float vId = floor(circleId / across);\n float v = vId / (down - 1.);\n \n float ur = m1p1(u);// * cos(time);\n float vr = m1p1(v);// * sin(time);\n float rr = length(vec2(ur, vr));\n float aa = (atan(ur, vr) + PI) / (2. * PI);\n float snd = texture2D(sound, vec2(abs(m1p1(aa)) * 0.0125, rr * .2)).a;\n \n \n vec3 offset = vec3(0);vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\n offset.x += 0.;m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\n offset.y += 0.;goop(circleId + time * 0.) * 0.1;\n float timeOff = m1p1(mod(time * 0.01 + (cu * 3.), 1.));\n offset.x += m1p1(u) + mod(vId, 2.) / across; //sin(timeOff * PI * 2.) * cu * 2.;\n offset.y += m1p1(v); //cos(timeOff * PI * 2.) * cu * 2.;\n offset.z = -m1p1(cu);//m1p1(hash(circleId * 0.641)) - trailV * 0.01;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1.);\n \n \n mat4 mat = ident(); \n mat *= scale(aspect);\n // mat *= rotZ(hash(circleId * 0.543) * PI * 2.);\n mat *= trans(offset);\n // mat *= rotZ(hash(circleId * 0.234) * PI * 2. + time);\n // mat *= rotZ(PI * -1.5 + snd * 6.);\n mat *= rotZ(m1p1(aa) * PI - PI * 0.5 );\n mat *= uniformScale(mix(0.0, 0.2, /*hash(circleId) * */ pow(snd, 3.0)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.9, 1.05, fract(circleId * 0.17 + snd));\n float sat = trailV; //mix(1., 0., step(0.99, pow(snd, 5.0)));\n float val = mix(0.8, 1.0, fract(circleId * 0.79));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.a = p1m1(offset.z);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-sffycqhx97o09mff9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PnP9nGDCsdg3X8R6u/art.json b/art/PnP9nGDCsdg3X8R6u/art.json index 8d6129af..c1aa7add 100644 --- a/art/PnP9nGDCsdg3X8R6u/art.json +++ b/art/PnP9nGDCsdg3X8R6u/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":25002,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Audio Reactive Art Own Variation\\n//course name : CS250\\n//term : Spring 2023\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1; \\n float yoff = 0.;//sin(time * 1.1 + x * 0.2) * 0.2;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs( u - 0.5 ) * 2.;\\n float sv = abs( v ) * 2.;\\n float au = abs(atan(su,sv) ) + floor( ux * ux) / PI ;\\n float av = length(vec2(su,sv)) * floor(ux * ux * vy);\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n\\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u* 0.1 * snd * 0.2 + time * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 25002, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Audio Reactive Art Own Variation\n//course name : CS250\n//term : Spring 2023\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1; \n float yoff = 0.;//sin(time * 1.1 + x * 0.2) * 0.2;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs( u - 0.5 ) * 2.;\n float sv = abs( v ) * 2.;\n float au = abs(atan(su,sv) ) + floor( ux * ux) / PI ;\n float av = length(vec2(su,sv)) * floor(ux * ux * vy);\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u* 0.1 * snd * 0.2 + time * 0.1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.),pump); //sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-oe1l6urzyusrb8jzk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PnfhNHTd9N2nBjoiw/art.json b/art/PnfhNHTd9N2nBjoiw/art.json index 1712b781..f4daf8d8 100644 --- a/art/PnfhNHTd9N2nBjoiw/art.json +++ b/art/PnfhNHTd9N2nBjoiw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":10971,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define TAU radians(360.)#define PI radians(180.)\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 1.625 + (time * 30.));\\n float sx = mod(vertexId, pointsPerLoop /2.) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (.85 + pow(texture2D(sound, vec2(sx * 0.0365, sy)).a, 4.) * 2.) * (1. - sy);\\n \\n float x = sin(deg) * radius * 1.9;\\n float y = cos(deg) * radius * 1.9;\\n float z = vertexId * sx * 0.0125;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0.1*mouse.y, 1.-radius-mouse.y, 0,\\n -0.3*radius, -1.1*mouse.x*radius, .1, 0,\\n -0.06, 0.01, 0.31-mouse.y*0.1, 0.1,\\n 0, 0, -0.5, 1)/radius*2.;\\n \\n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\\n v_color = vec4(.1, (vertexId / vertexCount *2.) / 2.5 * 2.1, 0.4, 0.1);\\n}\"}", + "settings": { + "num": 10971, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define TAU radians(360.)#define PI radians(180.)\n\nvoid main()\n{\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 1.625 + (time * 30.));\n float sx = mod(vertexId, pointsPerLoop /2.) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (.85 + pow(texture2D(sound, vec2(sx * 0.0365, sy)).a, 4.) * 2.) * (1. - sy);\n \n float x = sin(deg) * radius * 1.9;\n float y = cos(deg) * radius * 1.9;\n float z = vertexId * sx * 0.0125;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0.1*mouse.y, 1.-radius-mouse.y, 0,\n -0.3*radius, -1.1*mouse.x*radius, .1, 0,\n -0.06, 0.01, 0.31-mouse.y*0.1, 0.1,\n 0, 0, -0.5, 1)/radius*2.;\n \n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\n v_color = vec4(.1, (vertexId / vertexCount *2.) / 2.5 * 2.1, 0.4, 0.1);\n}" + }, "screenshotURL": "data/images/images-jx611wbmwmgktrupb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PorioQ3ztpHifDuAx/art.json b/art/PorioQ3ztpHifDuAx/art.json index 1d86a202..82c17b36 100644 --- a/art/PorioQ3ztpHifDuAx/art.json +++ b/art/PorioQ3ztpHifDuAx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jairhumberto", "avatarUrl": "https://secure.gravatar.com/avatar/b39c05ec440599cda2aa819673a481cf?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/neural_drift\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 k = vec4(1.0, 2.0/3.0, 1.0/0.3, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = sin(v * snd) * 2.5 - 1.;\\n \\n vec2 xy = vec2(ux, vy);\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(snd * 1.2 + x * y);\\n \\n gl_PointSize = pow(snd + 0.1, 0.5) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 1900.0;\\n \\n float hue = sin(u * 0.1) + snd * 0.2 + time * 0.1;\\n float sat = mix(0.0, 1.0, snd);\\n float val = mix(0.0, pow(snd + 2., 6.0), snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/neural_drift", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 k = vec4(1.0, 2.0/3.0, 1.0/0.3, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float ux = u * 2.0 - 1.0;\n float vy = sin(v * snd) * 2.5 - 1.;\n \n vec2 xy = vec2(ux, vy);\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(snd * 1.2 + x * y);\n \n gl_PointSize = pow(snd + 0.1, 0.5) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 1900.0;\n \n float hue = sin(u * 0.1) + snd * 0.2 + time * 0.1;\n float sat = mix(0.0, 1.0, snd);\n float val = mix(0.0, pow(snd + 2., 6.0), snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-ldew9z1wnihz70e8m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PoyGoZL5Lmmn9N5SF/art.json b/art/PoyGoZL5Lmmn9N5SF/art.json index 157dc186..3d109d55 100644 --- a/art/PoyGoZL5Lmmn9N5SF/art.json +++ b/art/PoyGoZL5Lmmn9N5SF/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "Jack-o'-lantern", "username": "P_Malin", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\n// Jack-o'-lantern\\n// @P_Malin\\n\\n//\\n\\n#define kRaymarchMaxIter 64\\n\\n#define kBounceCount 1\\n\\n// Enable this to use POINTS primitive type\\n//#define POINTS_VERSION\\n\\nfloat g_AlphaBlend = 1.0;\\n\\n//#define SCENE_DOMAIN_REPEAT\\n\\nfloat kFarClip=100.0;\\n\\nvec2 GetWindowCoord( const in vec2 vUV );\\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget );\\nvec3 GetSceneColour( in vec3 vRayOrigin, in vec3 vRayDir );\\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput );\\n\\nfloat GetCarving2dDistance(const in vec2 vPos );\\n\\nvec3 vLightPos = vec3(0.0, -0.5, 0.0);\\t\\t\\t\\nvec3 vLightColour = vec3(1.0, 0.8, 0.4);\\n\\nfloat fCarving = 1.0;\\n\\n// from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// CAMERA\\n\\nvec2 GetWindowCoord( const in vec2 vUV )\\n{\\n\\tvec2 vWindow = vUV * 2.0 - 1.0;\\n\\tvWindow.x *= resolution.x / resolution.y;\\n\\n\\treturn vWindow;\\t\\n}\\n\\n\\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget )\\n{\\n\\tvec3 vForward = normalize(vCameraTarget - vCameraPos);\\n\\tvec3 vRight = normalize(cross(vec3(0.0, 1.0, 0.0), vForward));\\n\\tvec3 vUp = normalize(cross(vForward, vRight));\\n\\t\\t\\t\\t\\t\\t\\t \\n\\tvec3 vDir = normalize(vWindow.x * vRight + vWindow.y * vUp + vForward * 1.5);\\n\\n\\treturn vDir;\\n}\\n\\n// POSTFX\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvec3 ApplyTonemap( const in vec3 vLinear )\\n{\\n\\tfloat kExposure = 1.0;\\n \\n\\treturn 1.0 - exp2(vLinear * -kExposure);\\t\\n}\\n\\nvec3 ApplyGamma( const in vec3 vLinear )\\n{\\n\\tconst float kGamma = 2.2;\\n\\n\\treturn pow(vLinear, vec3(1.0/kGamma));\\t\\n}\\n\\nvec3 ApplyBlackLevel( const in vec3 vColour )\\n{\\n float fBlackLevel = 0.1;\\n return vColour / (1.0 - fBlackLevel) - fBlackLevel;\\n}\\n\\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec3 vTemp = ApplyVignetting( vUV, vInput );\\t\\n\\t\\n\\tvTemp = ApplyTonemap(vTemp);\\n\\t\\n\\tvTemp = ApplyGamma(vTemp);\\t\\t\\n \\n vTemp = ApplyBlackLevel(vTemp);\\n \\n return vTemp;\\n}\\n\\t\\n// RAYTRACE\\n\\nstruct C_Intersection\\n{\\n\\tvec3 vPos;\\n\\tfloat fDist;\\t\\n\\tvec3 vNormal;\\n\\tvec3 vUVW;\\n\\tfloat fObjectId;\\n};\\n\\nfloat GetCarving2dDistance(const in vec2 vPos )\\n{\\n if(fCarving < 0.0)\\n return 10.0;\\n \\n\\tfloat fMouthDist = length(vPos.xy + vec2(0.0, -0.5)) - 1.5;\\n\\tfloat fMouthDist2 = length(vPos.xy + vec2(0.0, -1.1 - 0.5)) - 2.0;\\n\\t\\n\\tif(-fMouthDist2 > fMouthDist )\\n\\t{\\n\\t\\tfMouthDist = -fMouthDist2;\\n\\t}\\n\\n float fFaceDist = fMouthDist;\\n\\n vec2 vNosePos = vPos.xy + vec2(0.0, -0.5);\\n vNosePos.x = abs(vNosePos.x);\\n float fNoseDist = dot(vNosePos.xy, normalize(vec2(1.0, 0.5)));\\n fNoseDist = max(fNoseDist, -(vNosePos.y + 0.5));\\n if(fNoseDist < fFaceDist)\\n {\\n fFaceDist = fNoseDist;\\n }\\n\\n\\n vec2 vEyePos = vPos.xy;\\n vEyePos.x = abs(vEyePos.x);\\n vEyePos.x -= 1.0;\\n vEyePos.y -= 1.0;\\n float fEyeDist = dot(vEyePos.xy, normalize(vec2(-1.0, 1.5)));\\n fEyeDist = max(fEyeDist, dot(vEyePos.xy, normalize(vec2(1.0, 0.5))));\\n fEyeDist = max(fEyeDist, -0.5+dot(vEyePos.xy, normalize(vec2(0.0, -1.0))));\\n if(fEyeDist < fFaceDist)\\n {\\n fFaceDist = fEyeDist;\\n }\\n \\n return fFaceDist;\\n}\\n\\nfloat GetCarvingDistance(const in vec3 vPos )\\n{\\n\\tfloat fDist = (length(vPos * vec3(1.0, 1.4, 1.0)) - 2.7) / 1.5;\\n\\n float fFaceDist = GetCarving2dDistance(vPos.xy);\\n \\n\\tfloat fRearDist = vPos.z;\\n\\t\\n\\tif(fRearDist > fFaceDist)\\n\\t{\\n\\t\\tfFaceDist = fRearDist;\\n\\t}\\t\\n\\t\\n\\tif(fFaceDist < fDist )\\n\\t{\\n\\t\\tfDist = fFaceDist;\\n\\t}\\n\\n float fR = length(vPos.xz);\\n \\n float fLidDist = dot( vec2(fR, vPos.y), normalize(vec2(1.0, -1.5)));\\n \\n fLidDist = abs(fLidDist) - 0.03;\\n\\tif(fLidDist < fDist )\\n\\t{\\n\\t\\tfDist = fLidDist;\\n\\t}\\n \\n\\treturn fDist;\\n}\\n\\nfloat GetPumpkinDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\\n{\\n vec3 vSphereOrigin = vec3(0.0, 0.0, 0.0);\\n float fSphereRadius = 3.0;\\n\\n\\tvec3 vOffset = vPos - vSphereOrigin;\\n\\tfloat fFirstDist = length(vOffset);\\n\\t\\n\\tfloat fOutDist;\\n\\tif(fFirstDist > 3.5)\\n\\t{\\n\\t\\tfOutDist = fFirstDist - fSphereRadius;\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tfloat fAngle1 = atan(vOffset.x, vOffset.z);\\n\\t\\tfloat fSin = sin(fAngle1 * 10.0);\\n\\t\\tfSin = 1.0 - sqrt(abs(fSin));\\n\\t\\tvOffset *= 1.0 + fSin * vec3(0.05, 0.025, 0.05);\\n\\t\\tvOffset.y *= 1.0 + 0.5 * (fSphereRadius - length(vOffset.xz)) / fSphereRadius;\\n\\t\\tfOutDist = length(vOffset) - fSphereRadius;\\n\\t}\\n\\t\\n\\n\\tvec4 vSphere1UVW_Id = vec4(normalize(vPos - vSphereOrigin), 3.0);\\n\\tvOutUVW_Id = vSphere1UVW_Id;\\n\\t\\n\\tvec3 vStalkOffset = vPos;\\n\\tvStalkOffset.x += -(vStalkOffset.y - fSphereRadius) * 0.1;\\n\\tfloat fDist2d = length(vStalkOffset.xz);\\n\\tfloat fStalkDist = fDist2d - 0.2;\\n\\tfStalkDist = max(fStalkDist, vPos.y - 2.5 + vPos.x * 0.25);\\n\\tfStalkDist = max(fStalkDist, -vPos.y);\\n\\tif( fStalkDist < fOutDist )\\n\\t{\\n\\t\\tfOutDist = fStalkDist;\\n\\t\\tvOutUVW_Id = vSphere1UVW_Id;\\n\\t\\tvOutUVW_Id.w = 2.0;\\n\\t}\\n\\n\\treturn fOutDist;\\n}\\n\\nfloat GetSceneDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\\n{\\n\\tfloat fFloorDist = vPos.y + 2.0;\\n\\tvec4 vFloorUVW_Id = vec4(vPos.xz, 0.0, 1.0);\\n\\n\\t\\n\\tvec3 vPumpkinDomain = vPos;\\n\\n#ifdef SCENE_DOMAIN_REPEAT\\n\\tfloat fRepeat = 12.0;\\n\\tfloat fOffset = (fRepeat * 0.5);\\n\\tvPumpkinDomain.xz = fract((vPos.xz + fOffset) / fRepeat) * fRepeat - fOffset;\\n#endif \\n \\n\\tfloat fOutDist = fFloorDist;\\n\\tvOutUVW_Id = vFloorUVW_Id;\\n\\n\\tvec4 vPumpkinUVW_Id;\\n\\tfloat fPumpkinDist = GetPumpkinDistance( vPumpkinUVW_Id, vPumpkinDomain );\\n\\n\\tfloat fCarvingDist = GetCarvingDistance( vPumpkinDomain );\\n\\t\\n\\tif(-fCarvingDist > fPumpkinDist)\\n\\t{\\n\\t\\tfPumpkinDist = -fCarvingDist;\\n\\t\\tvPumpkinUVW_Id = vec4(4.0);\\n\\t}\\n\\n\\t\\n\\tif(fPumpkinDist < fOutDist)\\n\\t{\\n\\t\\tfOutDist = fPumpkinDist;\\n\\t\\tvOutUVW_Id = vPumpkinUVW_Id;\\n\\t}\\n\\t\\n\\treturn fOutDist;\\n}\\n\\nvec3 GetSceneNormal(const in vec3 vPos)\\n{\\n const float fDelta = 0.001;\\n\\n vec3 vDir1 = vec3( 1.0, -1.0, -1.0);\\n vec3 vDir2 = vec3(-1.0, -1.0, 1.0);\\n vec3 vDir3 = vec3(-1.0, 1.0, -1.0);\\n vec3 vDir4 = vec3( 1.0, 1.0, 1.0);\\n\\t\\n vec3 vOffset1 = vDir1 * fDelta;\\n vec3 vOffset2 = vDir2 * fDelta;\\n vec3 vOffset3 = vDir3 * fDelta;\\n vec3 vOffset4 = vDir4 * fDelta;\\n\\n\\tvec4 vUnused;\\n float f1 = GetSceneDistance( vUnused, vPos + vOffset1 );\\n float f2 = GetSceneDistance( vUnused, vPos + vOffset2 );\\n float f3 = GetSceneDistance( vUnused, vPos + vOffset3 );\\n float f4 = GetSceneDistance( vUnused, vPos + vOffset4 );\\n\\t\\n vec3 vNormal = vDir1 * f1 + vDir2 * f2 + vDir3 * f3 + vDir4 * f4;\\t\\n\\t\\t\\n return normalize( vNormal );\\n}\\n\\nvoid TraceScene( out C_Intersection outIntersection, const in vec3 vOrigin, const in vec3 vDir )\\n{\\t\\n\\tvec4 vUVW_Id = vec4(0.0);\\t\\t\\n\\tvec3 vPos = vec3(0.0);\\n\\t\\n\\tfloat t = 0.01;\\n\\tfor(int i=0; i 100.0)\\n\\t\\t{\\n\\t\\t\\tt = kFarClip;\\n\\t\\t\\tvPos = vOrigin + vDir * t;\\n\\t\\t\\tvUVW_Id = vec4(0.0);\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t}\\n\\t\\n\\toutIntersection.fDist = t;\\n\\toutIntersection.vPos = vPos;\\n\\toutIntersection.vNormal = GetSceneNormal(vPos);\\n\\toutIntersection.vUVW = vUVW_Id.xyz;\\n\\toutIntersection.fObjectId = vUVW_Id.w;\\n}\\n\\n\\nfloat TraceShadow( const in vec3 vOrigin, const in vec3 vDir, const in float fDist )\\n{\\n C_Intersection shadowIntersection;\\n\\tTraceScene(shadowIntersection, vOrigin, vDir);\\n\\tif(shadowIntersection.fDist < fDist) \\n\\t{\\n\\t\\treturn 0.0;\\t\\t\\n\\t}\\n\\t\\n\\treturn 1.0;\\n}\\n\\nfloat GetSSS( const in vec3 vPos, const in vec3 vLightPos )\\n{\\n vec3 vLightToPos = vPos - vLightPos;\\n vec3 vDir = normalize(vLightToPos);\\n \\n\\tC_Intersection intersection;\\n\\tTraceScene(intersection, vLightPos, vDir);\\n\\tfloat fOpticalDepth = length(vLightToPos) - intersection.fDist;\\n\\n fOpticalDepth = max(0.00001, fOpticalDepth);\\n \\n\\treturn exp2( fOpticalDepth * -8.0 );\\n}\\n\\n// LIGHTING\\n\\nfloat GIV( float dotNV, float k)\\n{\\n\\treturn 1.0 / ((dotNV + 0.0001) * (1.0 - k)+k);\\n}\\n\\nvoid AddLighting(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightColour)\\n{\\n\\tvec3 vH = normalize( -vViewDir + vLightDir );\\n\\tfloat fNDotL = clamp(dot(vLightDir, vNormal), 0.0, 1.0);\\n\\tfloat fNDotV = clamp(dot(-vViewDir, vNormal), 0.0, 1.0);\\n\\tfloat fNDotH = clamp(dot(vNormal, vH), 0.0, 1.0);\\n\\t\\n\\tfloat alpha = 1.0 - fSmoothness;\\n\\talpha = alpha * alpha;\\n\\t// D\\n\\n\\tfloat alphaSqr = alpha * alpha;\\n\\tfloat pi = 3.14159;\\n\\tfloat denom = fNDotH * fNDotH * (alphaSqr - 1.0) + 1.0;\\n\\tfloat d = alphaSqr / (pi * denom * denom);\\n\\n\\tfloat k = alpha / 2.0;\\n\\tfloat vis = GIV(fNDotL, k) * GIV(fNDotV, k);\\n\\n\\tfloat fSpecularIntensity = d * vis * fNDotL;\\n\\tvSpecularLight += vLightColour * fSpecularIntensity;\\n\\n\\tvDiffuseLight += vLightColour * fNDotL;\\n}\\n\\nvoid AddPointLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightPos, const in vec3 vLightColour)\\n{\\n\\tvec3 vToLight = vLightPos - vPos;\\t\\n\\tfloat fDistance2 = dot(vToLight, vToLight);\\n\\tfloat fAttenuation = 100.0 / (fDistance2);\\n\\tvec3 vLightDir = normalize(vToLight);\\n\\t\\n\\tvec3 vShadowRayDir = vLightDir;\\n\\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\\n\\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, length(vToLight));\\n\\t\\n\\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\\n}\\n\\nfloat AddDirectionalLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightDir, const in vec3 vLightColour)\\n{\\t\\n\\tfloat fAttenuation = 1.0;\\n\\n\\tvec3 vShadowRayDir = -vLightDir;\\n\\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\\n\\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, 10.0);\\n\\t\\n\\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, -vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\\t\\n \\n return fShadowFactor;\\n}\\n\\nvoid AddDirectionalLightFlareToFog(inout vec3 vFogColour, const in vec3 vRayDir, const in vec3 vLightDir, const in vec3 vLightColour)\\n{\\n\\tfloat fDirDot = clamp(dot(-vLightDir, vRayDir), 0.0, 1.0);\\n\\tfloat kSpreadPower = 4.0;\\n\\tvFogColour += vLightColour * pow(fDirDot, kSpreadPower);\\n}\\n\\n// SCENE MATERIALS\\n\\n#define MOD2 vec2(4.438975,3.972973)\\n\\nfloat Hash( float p ) \\n{\\n // https://www.shadertoy.com/view/4djSRW - Dave Hoskins\\n\\tvec2 p2 = fract(vec2(p) * MOD2);\\n p2 += dot(p2.yx, p2.xy+19.19);\\n\\treturn fract(p2.x * p2.y); \\n\\t//return fract(sin(n)*43758.5453);\\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = Hash(n+ 0.0);\\n\\tfloat b = Hash(n+ 1.0);\\n\\tfloat c = Hash(n+ 57.0);\\n\\tfloat d = Hash(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0;\\n for( int i=0; i= 3.0)\\n {\\n vDiffuseLight += GetSSS(intersection.vPos, vPointLightPos) * vLightColour;\\n }\\n else\\n {\\n vec3 vToLight = vPointLightPos - intersection.vPos;\\n float fNdotL = dot(normalize(vToLight), vBumpNormal) * 0.5 + 0.5;\\n\\t\\t\\t\\tvDiffuseLight += max(0.0, 1.0 - length(vToLight)/5.0) * vLightColour * fNdotL; \\n }\\n\\n\\t\\t\\tfloat fSmoothFactor = fSmoothness * 0.9 + 0.1;\\n float fFresnelClamp = 0.25; // too much fresnel produces sparkly artefacts\\n float fNdotD = clamp(dot(vBumpNormal, -vRayDir), fFresnelClamp, 1.0);\\n\\t\\t\\tvec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0) * fSmoothFactor;\\n\\n \\n\\t\\t\\tvResult = mix(vAlbedo * vDiffuseLight, vSpecularLight, vFresnel);\\t\\t\\n\\t\\t\\tvBlendFactor = vFresnel;\\n\\t\\t\\t\\n\\t\\t\\tApplyAtmosphere(vResult, intersection.fDist, vRayOrigin, vRayDir);\\t\\t\\n\\t\\t\\t\\n\\t\\t\\tvRemaining *= vBlendFactor;\\t\\t\\t\\t\\n\\t\\t\\tvRayDir = normalize(reflect(vRayDir, vBumpNormal));\\n\\t\\t\\tvRayOrigin = intersection.vPos;\\n\\t\\t}\\t\\t\\t\\n\\n\\t\\tvColour += vResult * vCurrRemaining * fShouldApply;\\t\\n\\t}\\n\\n\\tvec3 vSkyColor = GetSkyColour(vRayDir);\\n\\t\\n\\tApplyAtmosphere(vSkyColor, kFarClip, vRayOrigin, vRayDir);\\t\\t\\n\\t\\n // Hack for this scene when using 1 bounce.\\n // remove final sky reflection when in shadow\\n vSkyColor *= fLastShadow; \\n \\n\\tvColour += vSkyColor * vRemaining;\\n\\t\\n // Face glow\\n float t = -(_vRayOrigin.z + 2.8) / _vRayDir.z;\\n \\n if( t > 0.0 )\\n {\\n vec3 vPos = _vRayOrigin + _vRayDir * t;\\n\\n float fDist = abs(GetCarving2dDistance(vPos.xy * vec2(1.0, 1.0)));\\n float fDot = max(0.0, _vRayDir.z);\\n fDot = fDot * fDot;\\n vColour += exp2(-fDist * 10.0) * fDot * vLightColour * 0.25;\\n }\\n \\n \\n\\treturn vColour;\\n}\\n\\n\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\n\\nvec2 hash21(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n\\tp3 += dot(p3, p3.yzx + 19.19);\\n\\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nvoid main() \\n{\\n#ifdef POINTS_VERSION\\n float fTriangleIndex = vertexId + time;\\n float fTriangleVertexIndex = 0.0;\\n#else\\n float fTriangleIndex = floor( vertexId / 3.0 ) + time;\\n float fTriangleVertexIndex = mod( vertexId, 3.0 );\\n#endif \\n \\n vec2 vUV = hash21( fTriangleIndex );\\n \\n \\tfloat fSize = 1.0;\\n\\n float fDist = 7.0;\\n\\n float fAngle = radians(190.0) + sin(time * 0.25) * 0.2;\\n float fHeight = 2.0 + sin(time * 0.1567) * 1.5;\\n \\n\\tvec3 vCameraPos = vec3(sin(fAngle) * fDist, fHeight, cos(fAngle) * fDist);\\n\\tvec3 vCameraTarget = vec3(0.0, -0.5, 0.0);\\n \\n\\tvec3 vRayOrigin = vCameraPos;\\n\\tvec3 vRayDir = GetCameraRayDir( GetWindowCoord(vUV), vCameraPos, vCameraTarget );\\n\\t\\n \\tfloat fHitDist = 0.0;\\n \\tvec3 vHitNormal = vec3(0.0);\\n\\tvec3 vResult = GetSceneColour(vRayOrigin, vRayDir, fHitDist, vHitNormal);\\n\\t \\n\\tvec3 vFinal = ApplyPostFX( vUV, vResult );\\n\\n\\n //fSize = 0.05 / fHitDist;\\n fSize *= 0.01;\\n fSize *= 0.5 + vFinal.x * vFinal.y * 0.5;\\n vec2 vOffset = vec2(0.0);\\n \\n if( fTriangleVertexIndex < 0.5 )\\n {\\n vOffset.y += fSize;\\n }\\n else if( fTriangleVertexIndex < 1.5 )\\n {\\n vOffset.x -= fSize;\\n }\\n else if( fTriangleVertexIndex < 2.5 )\\n {\\n vOffset.x += fSize;\\n }\\n \\n vOffset = Rotate( vOffset, fTriangleIndex );\\n vUV += vOffset;\\n\\n vUV.xy = vUV.xy * 2.0 - 1.0;\\n \\n#ifdef POINTS_VERSION\\n gl_PointSize = fSize * 800.0;\\n#endif \\n \\n gl_Position = vec4(vUV.xy * fHitDist, 0, fHitDist);\\n v_color = vec4(vFinal, 1.0);\\n \\n v_color *= g_AlphaBlend; \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\n// Jack-o'-lantern\n// @P_Malin\n\n//\n\n#define kRaymarchMaxIter 64\n\n#define kBounceCount 1\n\n// Enable this to use POINTS primitive type\n//#define POINTS_VERSION\n\nfloat g_AlphaBlend = 1.0;\n\n//#define SCENE_DOMAIN_REPEAT\n\nfloat kFarClip=100.0;\n\nvec2 GetWindowCoord( const in vec2 vUV );\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget );\nvec3 GetSceneColour( in vec3 vRayOrigin, in vec3 vRayDir );\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput );\n\nfloat GetCarving2dDistance(const in vec2 vPos );\n\nvec3 vLightPos = vec3(0.0, -0.5, 0.0);\t\t\t\nvec3 vLightColour = vec3(1.0, 0.8, 0.4);\n\nfloat fCarving = 1.0;\n\n// from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// CAMERA\n\nvec2 GetWindowCoord( const in vec2 vUV )\n{\n\tvec2 vWindow = vUV * 2.0 - 1.0;\n\tvWindow.x *= resolution.x / resolution.y;\n\n\treturn vWindow;\t\n}\n\n\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget )\n{\n\tvec3 vForward = normalize(vCameraTarget - vCameraPos);\n\tvec3 vRight = normalize(cross(vec3(0.0, 1.0, 0.0), vForward));\n\tvec3 vUp = normalize(cross(vForward, vRight));\n\t\t\t\t\t\t\t \n\tvec3 vDir = normalize(vWindow.x * vRight + vWindow.y * vUp + vForward * 1.5);\n\n\treturn vDir;\n}\n\n// POSTFX\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvec3 ApplyTonemap( const in vec3 vLinear )\n{\n\tfloat kExposure = 1.0;\n \n\treturn 1.0 - exp2(vLinear * -kExposure);\t\n}\n\nvec3 ApplyGamma( const in vec3 vLinear )\n{\n\tconst float kGamma = 2.2;\n\n\treturn pow(vLinear, vec3(1.0/kGamma));\t\n}\n\nvec3 ApplyBlackLevel( const in vec3 vColour )\n{\n float fBlackLevel = 0.1;\n return vColour / (1.0 - fBlackLevel) - fBlackLevel;\n}\n\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec3 vTemp = ApplyVignetting( vUV, vInput );\t\n\t\n\tvTemp = ApplyTonemap(vTemp);\n\t\n\tvTemp = ApplyGamma(vTemp);\t\t\n \n vTemp = ApplyBlackLevel(vTemp);\n \n return vTemp;\n}\n\t\n// RAYTRACE\n\nstruct C_Intersection\n{\n\tvec3 vPos;\n\tfloat fDist;\t\n\tvec3 vNormal;\n\tvec3 vUVW;\n\tfloat fObjectId;\n};\n\nfloat GetCarving2dDistance(const in vec2 vPos )\n{\n if(fCarving < 0.0)\n return 10.0;\n \n\tfloat fMouthDist = length(vPos.xy + vec2(0.0, -0.5)) - 1.5;\n\tfloat fMouthDist2 = length(vPos.xy + vec2(0.0, -1.1 - 0.5)) - 2.0;\n\t\n\tif(-fMouthDist2 > fMouthDist )\n\t{\n\t\tfMouthDist = -fMouthDist2;\n\t}\n\n float fFaceDist = fMouthDist;\n\n vec2 vNosePos = vPos.xy + vec2(0.0, -0.5);\n vNosePos.x = abs(vNosePos.x);\n float fNoseDist = dot(vNosePos.xy, normalize(vec2(1.0, 0.5)));\n fNoseDist = max(fNoseDist, -(vNosePos.y + 0.5));\n if(fNoseDist < fFaceDist)\n {\n fFaceDist = fNoseDist;\n }\n\n\n vec2 vEyePos = vPos.xy;\n vEyePos.x = abs(vEyePos.x);\n vEyePos.x -= 1.0;\n vEyePos.y -= 1.0;\n float fEyeDist = dot(vEyePos.xy, normalize(vec2(-1.0, 1.5)));\n fEyeDist = max(fEyeDist, dot(vEyePos.xy, normalize(vec2(1.0, 0.5))));\n fEyeDist = max(fEyeDist, -0.5+dot(vEyePos.xy, normalize(vec2(0.0, -1.0))));\n if(fEyeDist < fFaceDist)\n {\n fFaceDist = fEyeDist;\n }\n \n return fFaceDist;\n}\n\nfloat GetCarvingDistance(const in vec3 vPos )\n{\n\tfloat fDist = (length(vPos * vec3(1.0, 1.4, 1.0)) - 2.7) / 1.5;\n\n float fFaceDist = GetCarving2dDistance(vPos.xy);\n \n\tfloat fRearDist = vPos.z;\n\t\n\tif(fRearDist > fFaceDist)\n\t{\n\t\tfFaceDist = fRearDist;\n\t}\t\n\t\n\tif(fFaceDist < fDist )\n\t{\n\t\tfDist = fFaceDist;\n\t}\n\n float fR = length(vPos.xz);\n \n float fLidDist = dot( vec2(fR, vPos.y), normalize(vec2(1.0, -1.5)));\n \n fLidDist = abs(fLidDist) - 0.03;\n\tif(fLidDist < fDist )\n\t{\n\t\tfDist = fLidDist;\n\t}\n \n\treturn fDist;\n}\n\nfloat GetPumpkinDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\n{\n vec3 vSphereOrigin = vec3(0.0, 0.0, 0.0);\n float fSphereRadius = 3.0;\n\n\tvec3 vOffset = vPos - vSphereOrigin;\n\tfloat fFirstDist = length(vOffset);\n\t\n\tfloat fOutDist;\n\tif(fFirstDist > 3.5)\n\t{\n\t\tfOutDist = fFirstDist - fSphereRadius;\n\t}\n\telse\n\t{\n\t\tfloat fAngle1 = atan(vOffset.x, vOffset.z);\n\t\tfloat fSin = sin(fAngle1 * 10.0);\n\t\tfSin = 1.0 - sqrt(abs(fSin));\n\t\tvOffset *= 1.0 + fSin * vec3(0.05, 0.025, 0.05);\n\t\tvOffset.y *= 1.0 + 0.5 * (fSphereRadius - length(vOffset.xz)) / fSphereRadius;\n\t\tfOutDist = length(vOffset) - fSphereRadius;\n\t}\n\t\n\n\tvec4 vSphere1UVW_Id = vec4(normalize(vPos - vSphereOrigin), 3.0);\n\tvOutUVW_Id = vSphere1UVW_Id;\n\t\n\tvec3 vStalkOffset = vPos;\n\tvStalkOffset.x += -(vStalkOffset.y - fSphereRadius) * 0.1;\n\tfloat fDist2d = length(vStalkOffset.xz);\n\tfloat fStalkDist = fDist2d - 0.2;\n\tfStalkDist = max(fStalkDist, vPos.y - 2.5 + vPos.x * 0.25);\n\tfStalkDist = max(fStalkDist, -vPos.y);\n\tif( fStalkDist < fOutDist )\n\t{\n\t\tfOutDist = fStalkDist;\n\t\tvOutUVW_Id = vSphere1UVW_Id;\n\t\tvOutUVW_Id.w = 2.0;\n\t}\n\n\treturn fOutDist;\n}\n\nfloat GetSceneDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\n{\n\tfloat fFloorDist = vPos.y + 2.0;\n\tvec4 vFloorUVW_Id = vec4(vPos.xz, 0.0, 1.0);\n\n\t\n\tvec3 vPumpkinDomain = vPos;\n\n#ifdef SCENE_DOMAIN_REPEAT\n\tfloat fRepeat = 12.0;\n\tfloat fOffset = (fRepeat * 0.5);\n\tvPumpkinDomain.xz = fract((vPos.xz + fOffset) / fRepeat) * fRepeat - fOffset;\n#endif \n \n\tfloat fOutDist = fFloorDist;\n\tvOutUVW_Id = vFloorUVW_Id;\n\n\tvec4 vPumpkinUVW_Id;\n\tfloat fPumpkinDist = GetPumpkinDistance( vPumpkinUVW_Id, vPumpkinDomain );\n\n\tfloat fCarvingDist = GetCarvingDistance( vPumpkinDomain );\n\t\n\tif(-fCarvingDist > fPumpkinDist)\n\t{\n\t\tfPumpkinDist = -fCarvingDist;\n\t\tvPumpkinUVW_Id = vec4(4.0);\n\t}\n\n\t\n\tif(fPumpkinDist < fOutDist)\n\t{\n\t\tfOutDist = fPumpkinDist;\n\t\tvOutUVW_Id = vPumpkinUVW_Id;\n\t}\n\t\n\treturn fOutDist;\n}\n\nvec3 GetSceneNormal(const in vec3 vPos)\n{\n const float fDelta = 0.001;\n\n vec3 vDir1 = vec3( 1.0, -1.0, -1.0);\n vec3 vDir2 = vec3(-1.0, -1.0, 1.0);\n vec3 vDir3 = vec3(-1.0, 1.0, -1.0);\n vec3 vDir4 = vec3( 1.0, 1.0, 1.0);\n\t\n vec3 vOffset1 = vDir1 * fDelta;\n vec3 vOffset2 = vDir2 * fDelta;\n vec3 vOffset3 = vDir3 * fDelta;\n vec3 vOffset4 = vDir4 * fDelta;\n\n\tvec4 vUnused;\n float f1 = GetSceneDistance( vUnused, vPos + vOffset1 );\n float f2 = GetSceneDistance( vUnused, vPos + vOffset2 );\n float f3 = GetSceneDistance( vUnused, vPos + vOffset3 );\n float f4 = GetSceneDistance( vUnused, vPos + vOffset4 );\n\t\n vec3 vNormal = vDir1 * f1 + vDir2 * f2 + vDir3 * f3 + vDir4 * f4;\t\n\t\t\n return normalize( vNormal );\n}\n\nvoid TraceScene( out C_Intersection outIntersection, const in vec3 vOrigin, const in vec3 vDir )\n{\t\n\tvec4 vUVW_Id = vec4(0.0);\t\t\n\tvec3 vPos = vec3(0.0);\n\t\n\tfloat t = 0.01;\n\tfor(int i=0; i 100.0)\n\t\t{\n\t\t\tt = kFarClip;\n\t\t\tvPos = vOrigin + vDir * t;\n\t\t\tvUVW_Id = vec4(0.0);\n\t\t\tbreak;\n\t\t}\n\t}\n\t\n\toutIntersection.fDist = t;\n\toutIntersection.vPos = vPos;\n\toutIntersection.vNormal = GetSceneNormal(vPos);\n\toutIntersection.vUVW = vUVW_Id.xyz;\n\toutIntersection.fObjectId = vUVW_Id.w;\n}\n\n\nfloat TraceShadow( const in vec3 vOrigin, const in vec3 vDir, const in float fDist )\n{\n C_Intersection shadowIntersection;\n\tTraceScene(shadowIntersection, vOrigin, vDir);\n\tif(shadowIntersection.fDist < fDist) \n\t{\n\t\treturn 0.0;\t\t\n\t}\n\t\n\treturn 1.0;\n}\n\nfloat GetSSS( const in vec3 vPos, const in vec3 vLightPos )\n{\n vec3 vLightToPos = vPos - vLightPos;\n vec3 vDir = normalize(vLightToPos);\n \n\tC_Intersection intersection;\n\tTraceScene(intersection, vLightPos, vDir);\n\tfloat fOpticalDepth = length(vLightToPos) - intersection.fDist;\n\n fOpticalDepth = max(0.00001, fOpticalDepth);\n \n\treturn exp2( fOpticalDepth * -8.0 );\n}\n\n// LIGHTING\n\nfloat GIV( float dotNV, float k)\n{\n\treturn 1.0 / ((dotNV + 0.0001) * (1.0 - k)+k);\n}\n\nvoid AddLighting(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightColour)\n{\n\tvec3 vH = normalize( -vViewDir + vLightDir );\n\tfloat fNDotL = clamp(dot(vLightDir, vNormal), 0.0, 1.0);\n\tfloat fNDotV = clamp(dot(-vViewDir, vNormal), 0.0, 1.0);\n\tfloat fNDotH = clamp(dot(vNormal, vH), 0.0, 1.0);\n\t\n\tfloat alpha = 1.0 - fSmoothness;\n\talpha = alpha * alpha;\n\t// D\n\n\tfloat alphaSqr = alpha * alpha;\n\tfloat pi = 3.14159;\n\tfloat denom = fNDotH * fNDotH * (alphaSqr - 1.0) + 1.0;\n\tfloat d = alphaSqr / (pi * denom * denom);\n\n\tfloat k = alpha / 2.0;\n\tfloat vis = GIV(fNDotL, k) * GIV(fNDotV, k);\n\n\tfloat fSpecularIntensity = d * vis * fNDotL;\n\tvSpecularLight += vLightColour * fSpecularIntensity;\n\n\tvDiffuseLight += vLightColour * fNDotL;\n}\n\nvoid AddPointLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightPos, const in vec3 vLightColour)\n{\n\tvec3 vToLight = vLightPos - vPos;\t\n\tfloat fDistance2 = dot(vToLight, vToLight);\n\tfloat fAttenuation = 100.0 / (fDistance2);\n\tvec3 vLightDir = normalize(vToLight);\n\t\n\tvec3 vShadowRayDir = vLightDir;\n\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\n\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, length(vToLight));\n\t\n\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\n}\n\nfloat AddDirectionalLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightDir, const in vec3 vLightColour)\n{\t\n\tfloat fAttenuation = 1.0;\n\n\tvec3 vShadowRayDir = -vLightDir;\n\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\n\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, 10.0);\n\t\n\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, -vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\t\n \n return fShadowFactor;\n}\n\nvoid AddDirectionalLightFlareToFog(inout vec3 vFogColour, const in vec3 vRayDir, const in vec3 vLightDir, const in vec3 vLightColour)\n{\n\tfloat fDirDot = clamp(dot(-vLightDir, vRayDir), 0.0, 1.0);\n\tfloat kSpreadPower = 4.0;\n\tvFogColour += vLightColour * pow(fDirDot, kSpreadPower);\n}\n\n// SCENE MATERIALS\n\n#define MOD2 vec2(4.438975,3.972973)\n\nfloat Hash( float p ) \n{\n // https://www.shadertoy.com/view/4djSRW - Dave Hoskins\n\tvec2 p2 = fract(vec2(p) * MOD2);\n p2 += dot(p2.yx, p2.xy+19.19);\n\treturn fract(p2.x * p2.y); \n\t//return fract(sin(n)*43758.5453);\n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = Hash(n+ 0.0);\n\tfloat b = Hash(n+ 1.0);\n\tfloat c = Hash(n+ 57.0);\n\tfloat d = Hash(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n#define k_fmbSteps 10\nfloat FBM( vec2 p, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0;\n for( int i=0; i= 3.0)\n {\n vDiffuseLight += GetSSS(intersection.vPos, vPointLightPos) * vLightColour;\n }\n else\n {\n vec3 vToLight = vPointLightPos - intersection.vPos;\n float fNdotL = dot(normalize(vToLight), vBumpNormal) * 0.5 + 0.5;\n\t\t\t\tvDiffuseLight += max(0.0, 1.0 - length(vToLight)/5.0) * vLightColour * fNdotL; \n }\n\n\t\t\tfloat fSmoothFactor = fSmoothness * 0.9 + 0.1;\n float fFresnelClamp = 0.25; // too much fresnel produces sparkly artefacts\n float fNdotD = clamp(dot(vBumpNormal, -vRayDir), fFresnelClamp, 1.0);\n\t\t\tvec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0) * fSmoothFactor;\n\n \n\t\t\tvResult = mix(vAlbedo * vDiffuseLight, vSpecularLight, vFresnel);\t\t\n\t\t\tvBlendFactor = vFresnel;\n\t\t\t\n\t\t\tApplyAtmosphere(vResult, intersection.fDist, vRayOrigin, vRayDir);\t\t\n\t\t\t\n\t\t\tvRemaining *= vBlendFactor;\t\t\t\t\n\t\t\tvRayDir = normalize(reflect(vRayDir, vBumpNormal));\n\t\t\tvRayOrigin = intersection.vPos;\n\t\t}\t\t\t\n\n\t\tvColour += vResult * vCurrRemaining * fShouldApply;\t\n\t}\n\n\tvec3 vSkyColor = GetSkyColour(vRayDir);\n\t\n\tApplyAtmosphere(vSkyColor, kFarClip, vRayOrigin, vRayDir);\t\t\n\t\n // Hack for this scene when using 1 bounce.\n // remove final sky reflection when in shadow\n vSkyColor *= fLastShadow; \n \n\tvColour += vSkyColor * vRemaining;\n\t\n // Face glow\n float t = -(_vRayOrigin.z + 2.8) / _vRayDir.z;\n \n if( t > 0.0 )\n {\n vec3 vPos = _vRayOrigin + _vRayDir * t;\n\n float fDist = abs(GetCarving2dDistance(vPos.xy * vec2(1.0, 1.0)));\n float fDot = max(0.0, _vRayDir.z);\n fDot = fDot * fDot;\n vColour += exp2(-fDist * 10.0) * fDot * vLightColour * 0.25;\n }\n \n \n\treturn vColour;\n}\n\n\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\n\nvec2 hash21(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n\tp3 += dot(p3, p3.yzx + 19.19);\n\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nvoid main() \n{\n#ifdef POINTS_VERSION\n float fTriangleIndex = vertexId + time;\n float fTriangleVertexIndex = 0.0;\n#else\n float fTriangleIndex = floor( vertexId / 3.0 ) + time;\n float fTriangleVertexIndex = mod( vertexId, 3.0 );\n#endif \n \n vec2 vUV = hash21( fTriangleIndex );\n \n \tfloat fSize = 1.0;\n\n float fDist = 7.0;\n\n float fAngle = radians(190.0) + sin(time * 0.25) * 0.2;\n float fHeight = 2.0 + sin(time * 0.1567) * 1.5;\n \n\tvec3 vCameraPos = vec3(sin(fAngle) * fDist, fHeight, cos(fAngle) * fDist);\n\tvec3 vCameraTarget = vec3(0.0, -0.5, 0.0);\n \n\tvec3 vRayOrigin = vCameraPos;\n\tvec3 vRayDir = GetCameraRayDir( GetWindowCoord(vUV), vCameraPos, vCameraTarget );\n\t\n \tfloat fHitDist = 0.0;\n \tvec3 vHitNormal = vec3(0.0);\n\tvec3 vResult = GetSceneColour(vRayOrigin, vRayDir, fHitDist, vHitNormal);\n\t \n\tvec3 vFinal = ApplyPostFX( vUV, vResult );\n\n\n //fSize = 0.05 / fHitDist;\n fSize *= 0.01;\n fSize *= 0.5 + vFinal.x * vFinal.y * 0.5;\n vec2 vOffset = vec2(0.0);\n \n if( fTriangleVertexIndex < 0.5 )\n {\n vOffset.y += fSize;\n }\n else if( fTriangleVertexIndex < 1.5 )\n {\n vOffset.x -= fSize;\n }\n else if( fTriangleVertexIndex < 2.5 )\n {\n vOffset.x += fSize;\n }\n \n vOffset = Rotate( vOffset, fTriangleIndex );\n vUV += vOffset;\n\n vUV.xy = vUV.xy * 2.0 - 1.0;\n \n#ifdef POINTS_VERSION\n gl_PointSize = fSize * 800.0;\n#endif \n \n gl_Position = vec4(vUV.xy * fHitDist, 0, fHitDist);\n v_color = vec4(vFinal, 1.0);\n \n v_color *= g_AlphaBlend; \n}" + }, "screenshotDataId": "sWQLPikTGF2y79XC9", "views": { "$numberInt": "8721" diff --git a/art/PpBTtfY3xx82oxNdo/art.json b/art/PpBTtfY3xx82oxNdo/art.json index f6cfc9b4..b5f3fbc1 100644 --- a/art/PpBTtfY3xx82oxNdo/art.json +++ b/art/PpBTtfY3xx82oxNdo/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "gurp", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocJehezG8JeoeUZ10YQPxwZNY5g1Yrq1NhESU0uVHnjqhPhokQ=s96-c", - "settings": "{\"num\":16384,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/ihavenomanas/no-mana-lost-call\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * 4.), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * 4.), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * 1.4;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n// normal.xz *= rotateX;\\n// normal.yz *= rotateY;\\n \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -1.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/ihavenomanas/no-mana-lost-call", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * 4.), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * 4.), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * 1.4;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n// normal.xz *= rotateX;\n// normal.yz *= rotateY;\n \n\n \n float screenZ = -0.;\n float eyeZ = -1.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}\n" + }, "screenshotURL": "data/images/images-g5wlliu9e8nd81m0t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PponkZdtktgJHhipC/art.json b/art/PponkZdtktgJHhipC/art.json index 05b569ac..142212b5 100644 --- a/art/PponkZdtktgJHhipC/art.json +++ b/art/PponkZdtktgJHhipC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ciccio-and-the-curran/clang\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n _ \\n _ _ ___ ___| |_ ___ _ _ \\n| | | -_| _| _| -_|_'_|\\n \\\\_/|___|_| |_| |___|_,_|\\n _ _ \\n ___| |_ ___ _| |___ ___ \\n|_ -| | .'| . | -_| _|\\n|___|_|_|__,|___|___|_| \\n _ \\n ___ ___| |_ \\n| .'| _| _| \\n|__,|_| |_| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomBoxPoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n p[2] = mix(-1., 1., step(0., p[2]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n p[0] = mix(-1., 1., step(0., p[0]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomSpherePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319))));\\n}\\n\\nvec3 getRandomSphereVolumePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\\n}\\n\\nvec3 getRandomCubeVolumePoint(float seed) {\\n return vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n}\\n\\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getPoint(float set, float seed) {\\n set = mod(set, 7.);\\n if (set < 1.) \\n {\\n return getRandomCubePoint(seed);\\n }\\n if (set < 2.) \\n {\\n return getRandomSphereVolumePoint(seed);\\n }\\n if (set < 3.) \\n {\\n return getRandomFunkPoint(seed, 3., 3.);\\n }\\n if (set < 4.) \\n {\\n return getRandomSpherePoint(seed);\\n }\\n if (set < 5.) \\n {\\n return getRandomBoxPoint(seed);\\n }\\n if (set < 6.)\\n {\\n return getRandomCubeVolumePoint(seed);\\n }\\n return getRandomFunkOutPoint(seed, 4., 3.);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, 3.);\\n }\\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\\n}\\n\\nvec3 getLerpedPoint(float time, float seed) {\\n float set = mod(time, 7.);\\n vec3 p0 = getPoint(set, seed);\\n vec3 p1 = getPoint(set + 1., seed);\\n return mix(p0, p1, easeInOutCubic(fract(time)));\\n}\\n\\n#define DOTS_PER 4000.\\n\\nvoid main() {\\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n\\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\\n \\n float cameraRadius = 13.;\\n float camAngle = time * 0.3;\\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n\\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(\\n m1p1(hash(thingId * 0.179)) * 6., \\n m1p1(hash(thingId * 0.317)) * 6., \\n m1p1(hash(thingId * 0.251)) * 6.));\\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\\n gl_Position = m * vec4(p, 1);\\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n\\n float hue = 0.6 + v * 0.1;\\n hue = mix(hue, 0.5, mod(floor(time * 60.0), 2.));\\n hue = mix(hue, 0., step(0.9, snd));\\n float sat = 1.;\\n float val = invClipZ * 150.;\\n// v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n gl_PointSize = 18. / gl_Position.z;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ciccio-and-the-curran/clang", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n _ \n _ _ ___ ___| |_ ___ _ _ \n| | | -_| _| _| -_|_'_|\n \\_/|___|_| |_| |___|_,_|\n _ _ \n ___| |_ ___ _| |___ ___ \n|_ -| | .'| . | -_| _|\n|___|_|_|__,|___|___|_| \n _ \n ___ ___| |_ \n| .'| _| _| \n|__,|_| |_| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvec3 getRandomBoxPoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n p[1] = mix(-1., 1., step(0., p[1]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n p[2] = mix(-1., 1., step(0., p[2]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n p[0] = mix(-1., 1., step(0., p[0]));\n }\n return p;\n}\n\nvec3 getRandomSpherePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319))));\n}\n\nvec3 getRandomSphereVolumePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\n}\n\nvec3 getRandomCubeVolumePoint(float seed) {\n return vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n}\n\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getPoint(float set, float seed) {\n set = mod(set, 7.);\n if (set < 1.) \n {\n return getRandomCubePoint(seed);\n }\n if (set < 2.) \n {\n return getRandomSphereVolumePoint(seed);\n }\n if (set < 3.) \n {\n return getRandomFunkPoint(seed, 3., 3.);\n }\n if (set < 4.) \n {\n return getRandomSpherePoint(seed);\n }\n if (set < 5.) \n {\n return getRandomBoxPoint(seed);\n }\n if (set < 6.)\n {\n return getRandomCubeVolumePoint(seed);\n }\n return getRandomFunkOutPoint(seed, 4., 3.);\n}\n\nfloat easeInOutCubic(float pos) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, 3.);\n }\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\n}\n\nvec3 getLerpedPoint(float time, float seed) {\n float set = mod(time, 7.);\n vec3 p0 = getPoint(set, seed);\n vec3 p1 = getPoint(set + 1., seed);\n return mix(p0, p1, easeInOutCubic(fract(time)));\n}\n\n#define DOTS_PER 4000.\n\nvoid main() {\n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\n \n float cameraRadius = 13.;\n float camAngle = time * 0.3;\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(\n m1p1(hash(thingId * 0.179)) * 6., \n m1p1(hash(thingId * 0.317)) * 6., \n m1p1(hash(thingId * 0.251)) * 6.));\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\n gl_Position = m * vec4(p, 1);\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n\n float hue = 0.6 + v * 0.1;\n hue = mix(hue, 0.5, mod(floor(time * 60.0), 2.));\n hue = mix(hue, 0., step(0.9, snd));\n float sat = 1.;\n float val = invClipZ * 150.;\n// v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n gl_PointSize = 18. / gl_Position.z;\n}" + }, "screenshotURL": "data/images/images-gk0971btcdp9xclvb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PpwJ5uNXyzHCnWSZJ/art.json b/art/PpwJ5uNXyzHCnWSZJ/art.json index 3b9df346..a5e872d7 100644 --- a/art/PpwJ5uNXyzHCnWSZJ/art.json +++ b/art/PpwJ5uNXyzHCnWSZJ/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "rbowsnd", "username": "gman", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n //\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n //\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "L7Z2J9KQ9pxLS9xQy", "views": { "$numberInt": "1123" diff --git a/art/Pq8cc68g6sG9jYR6Y/art.json b/art/Pq8cc68g6sG9jYR6Y/art.json index c390b227..06a7d280 100644 --- a/art/Pq8cc68g6sG9jYR6Y/art.json +++ b/art/Pq8cc68g6sG9jYR6Y/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n#define timeFactor .05//KParameter 0.>>1.\\n#define PointSizeValue 2.//KParameter 1.>>4.\\n#define colorFactorR 0.//KParameter 0.>>1.\\n#define colorFactorG 0.//KParameter 0.>>1.\\n#define colorFactorB 0.//KParameter 0.>>1.\\n#define symmetry 0.//KParameter 0.>>1.\\n\\nvec3 posf2(float t, float i) {\\n //return vec3(sin(t+i*.9553),cos(t+i*.9553),sin(t+i*.79553));\\n return vec3(sin(t+i*.5),cos(t+i*.5),sin(t+i*.79553));\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\\n \\n // more or less random movement\\n float t = time*timeFactor;\\n float i = localVertexId+sin(localVertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(colorFactorR,colorFactorG,colorFactorB);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\\n //v_color = vec4(0.,0.,0.,1.);//abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n#define timeFactor .05//KParameter 0.>>1.\n#define PointSizeValue 2.//KParameter 1.>>4.\n#define colorFactorR 0.//KParameter 0.>>1.\n#define colorFactorG 0.//KParameter 0.>>1.\n#define colorFactorB 0.//KParameter 0.>>1.\n#define symmetry 0.//KParameter 0.>>1.\n\nvec3 posf2(float t, float i) {\n //return vec3(sin(t+i*.9553),cos(t+i*.9553),sin(t+i*.79553));\n return vec3(sin(t+i*.5),cos(t+i*.5),sin(t+i*.79553));\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\n \n // more or less random movement\n float t = time*timeFactor;\n float i = localVertexId+sin(localVertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(colorFactorR,colorFactorG,colorFactorB);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\n //v_color = vec4(0.,0.,0.,1.);//abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\n}" + }, "screenshotURL": "data/images/images-5cszusi4z3anu663u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PsHuyZzqaS6pheL2D/art.json b/art/PsHuyZzqaS6pheL2D/art.json index da73c56c..1b7b7fb4 100644 --- a/art/PsHuyZzqaS6pheL2D/art.json +++ b/art/PsHuyZzqaS6pheL2D/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-961665354/yt5scom-bondhu-kala-chanponkoj-roy-jk-shanto-bangla-new-dance-video-2021-320-kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.07450980392156863,0.1450980392156863,1],\"shader\":\"// chrillo\\n\\n#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n\\nvoid main () {\\n float i = hash(vertexId);\\n float f = hash(i);\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 2.);\\n \\n float ang = vertexId / 1000.;\\n float perspective = .65 / sin(0.785398);\\n float t = time * (f - .5);\\n float x = i * sin(ang + t) * 1.1;\\n float y = i * cos(ang + t) * 0.7;\\n y += .1 * snd * (1. - y);\\n y *= perspective;\\n \\n float vis = snd / (y + 1.1);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 5. * vis;\\n \\n v_color = vec4(\\n snd * .7 * (5. - f),\\n snd * .8 * cos(f * PI),\\n snd * 2. * sin(f * PI/2.),\\n vis);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-961665354/yt5scom-bondhu-kala-chanponkoj-roy-jk-shanto-bangla-new-dance-video-2021-320-kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.07450980392156863, + 0.1450980392156863, + 1 + ], + "shader": "// chrillo\n\n#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n\nvoid main () {\n float i = hash(vertexId);\n float f = hash(i);\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 2.);\n \n float ang = vertexId / 1000.;\n float perspective = .65 / sin(0.785398);\n float t = time * (f - .5);\n float x = i * sin(ang + t) * 1.1;\n float y = i * cos(ang + t) * 0.7;\n y += .1 * snd * (1. - y);\n y *= perspective;\n \n float vis = snd / (y + 1.1);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 5. * vis;\n \n v_color = vec4(\n snd * .7 * (5. - f),\n snd * .8 * cos(f * PI),\n snd * 2. * sin(f * PI/2.),\n vis);\n}" + }, "screenshotURL": "data/images/images-85im1du6dl5fe3pyo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PtvnQNWKfKdFBWHtm/art.json b/art/PtvnQNWKfKdFBWHtm/art.json index 76c6ade1..59f4cd79 100644 --- a/art/PtvnQNWKfKdFBWHtm/art.json +++ b/art/PtvnQNWKfKdFBWHtm/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main() {\\n float maxPoints = 10.0;\\n float currentCircle = mod(vertexId, maxPoints) * 0.1;\\n float norm = vertexId / vertexCount;\\n float theta = norm * 6.28;\\n float speed = norm * 10.0;\\n \\n float vx = cos(theta * time * time) * currentCircle;\\n float vy = sin(theta * time) * currentCircle;\\n \\n float x = 0.0;\\n float y = 0.0;\\n \\n x += vx;\\n y += vy;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n gl_PointSize = norm * 2.0;\\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main() {\n float maxPoints = 10.0;\n float currentCircle = mod(vertexId, maxPoints) * 0.1;\n float norm = vertexId / vertexCount;\n float theta = norm * 6.28;\n float speed = norm * 10.0;\n \n float vx = cos(theta * time * time) * currentCircle;\n float vy = sin(theta * time) * currentCircle;\n \n float x = 0.0;\n float y = 0.0;\n \n x += vx;\n y += vy;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n gl_PointSize = norm * 2.0;\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-v4kwzxcfw97asec9e-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PtxL78jLv4jyfZCi9/art.json b/art/PtxL78jLv4jyfZCi9/art.json index 56484636..1cc4222e 100644 --- a/art/PtxL78jLv4jyfZCi9/art.json +++ b/art/PtxL78jLv4jyfZCi9/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "watermeloon", "avatarUrl": "https://secure.gravatar.com/avatar/e0a1c061d10e360fcf5646229dd6e29a?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/waveshaper-2/you-are-the-end-furi-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\n//returns the evenly distributed points\\n//https://stackoverflow.com/questions/9600801/evenly\\n//-distributing-n-points-on-a-sphere\\nvec3 FIBO(float rad, float id, float sum){\\n\\n \\t//golden angle in radians\\n float phi = PI * (3. - sqrt(5.));\\n\\n \\t// y goes from 1 to -1\\n float y = 1. - (id / (sum - 1.)) * 2.; \\n float radius = sqrt(1. - y * y);\\n\\n float theta = phi * id;\\n\\n float x = cos(theta) * radius;\\n float z = sin(theta) * radius;\\n \\t\\n vec3 point = vec3(x * rad, y * rad, z * rad);\\n \\n return point;\\n}\\n\\n//X axis rotation\\nmat4 rotateX(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n \\n//Y axis rotation\\nmat4 rotateY(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n//Z axis rotation\\nmat4 rotateZ(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvoid main(){\\n \\n vec4 point;\\n float radius = 0.7;\\n \\n float node_count = floor(vertexCount / 10.);\\n float node_id = floor(vertexId / 10.);\\n float cv = node_id / node_count;\\n \\n float m = 4.;\\n \\n if(mod(vertexId, m) == 0.){\\n\\tpoint = vec4(FIBO(radius, vertexId / m, node_count), 1.);\\n }\\n \\n if(mod(vertexId, m) == 1.){\\n\\tpoint = vec4(FIBO(radius * 0.9, vertexId / m, node_count), 1.);\\n }\\n \\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), atan(hash(cv) / 2. * 3.2))).a;\\n s = mix(0.0, 2.0, s);\\n \\n point *= 1. + pow(s, 15.) / 999.;\\n \\n point *= rotateX(time * .2);\\n point *= rotateY(time * .2);\\n point *= rotateZ(time * .2);\\n \\n gl_Position = vec4(point.x * resolution.y/resolution.x, point.y, point.z, 1.);\\n \\n float color_norm = (gl_Position.z + 2.) / 2.;\\n color_norm -= .6;\\n //color_norm -= .6; back is visible too\\n vec4 color = vec4(color_norm, color_norm, color_norm, 1);\\n v_color = color;\\n \\n gl_PointSize = 1.;\\n gl_PointSize -= gl_Position.z * .15;\\n gl_PointSize = 2. * s;\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/waveshaper-2/you-are-the-end-furi-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\n//returns the evenly distributed points\n//https://stackoverflow.com/questions/9600801/evenly\n//-distributing-n-points-on-a-sphere\nvec3 FIBO(float rad, float id, float sum){\n\n \t//golden angle in radians\n float phi = PI * (3. - sqrt(5.));\n\n \t// y goes from 1 to -1\n float y = 1. - (id / (sum - 1.)) * 2.; \n float radius = sqrt(1. - y * y);\n\n float theta = phi * id;\n\n float x = cos(theta) * radius;\n float z = sin(theta) * radius;\n \t\n vec3 point = vec3(x * rad, y * rad, z * rad);\n \n return point;\n}\n\n//X axis rotation\nmat4 rotateX(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n \n//Y axis rotation\nmat4 rotateY(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n//Z axis rotation\nmat4 rotateZ(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvoid main(){\n \n vec4 point;\n float radius = 0.7;\n \n float node_count = floor(vertexCount / 10.);\n float node_id = floor(vertexId / 10.);\n float cv = node_id / node_count;\n \n float m = 4.;\n \n if(mod(vertexId, m) == 0.){\n\tpoint = vec4(FIBO(radius, vertexId / m, node_count), 1.);\n }\n \n if(mod(vertexId, m) == 1.){\n\tpoint = vec4(FIBO(radius * 0.9, vertexId / m, node_count), 1.);\n }\n \n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), atan(hash(cv) / 2. * 3.2))).a;\n s = mix(0.0, 2.0, s);\n \n point *= 1. + pow(s, 15.) / 999.;\n \n point *= rotateX(time * .2);\n point *= rotateY(time * .2);\n point *= rotateZ(time * .2);\n \n gl_Position = vec4(point.x * resolution.y/resolution.x, point.y, point.z, 1.);\n \n float color_norm = (gl_Position.z + 2.) / 2.;\n color_norm -= .6;\n //color_norm -= .6; back is visible too\n vec4 color = vec4(color_norm, color_norm, color_norm, 1);\n v_color = color;\n \n gl_PointSize = 1.;\n gl_PointSize -= gl_Position.z * .15;\n gl_PointSize = 2. * s;\n\n}" + }, "screenshotURL": "data/images/images-vvcfuuljm37ejfkdg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PuJz9tt4xX8z7tBP8/art.json b/art/PuJz9tt4xX8z7tBP8/art.json index 2779cabc..09dd7df7 100644 --- a/art/PuJz9tt4xX8z7tBP8/art.json +++ b/art/PuJz9tt4xX8z7tBP8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":88086,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 2.9\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n fract(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n tan(t+i*1.5553-.81) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*fract(0.9492)*fract(0.999);\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*1.3*mouse.y,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5*mouse.x));\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float t = time*.010;\\n float i = fract(240000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -2.; f < 0.; f++) {\\n\\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,1.799/cos(time*0.4));\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *=1.*atan(mouse.x-.6);\\n pos.z += 0.7;\\n pos.xy *= 0.6/pos.z-cos(mouse.y);\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 28.0/pos.z* 0.09+fract(sin(time*.2)+1.);\\n\\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\\n}\"}", + "settings": { + "num": 88086, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 2.9\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n fract(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n tan(t+i*1.5553-.81) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*fract(0.9492)*fract(0.999);\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*1.3*mouse.y,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5*mouse.x));\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float t = time*.010;\n float i = fract(240000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -2.; f < 0.; f++) {\n\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,1.799/cos(time*0.4));\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *=1.*atan(mouse.x-.6);\n pos.z += 0.7;\n pos.xy *= 0.6/pos.z-cos(mouse.y);\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 28.0/pos.z* 0.09+fract(sin(time*.2)+1.);\n\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\n}" + }, "screenshotURL": "data/images/images-efj2gg37jcx1bnxq7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Px6gh46SuTaM4EEnF/art.json b/art/Px6gh46SuTaM4EEnF/art.json index dd9e1e33..4a56b94b 100644 --- a/art/Px6gh46SuTaM4EEnF/art.json +++ b/art/Px6gh46SuTaM4EEnF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 ctr = vec2(0.5);\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 4.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 80. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown * snd; \\n gl_PointSize *= resolution.x / 40. * xOff; \\n xy -= ctr;\\n xy *= rotate2D(snd * PI * 2.0 +s);\\n xy += ctr;\\n xy *= pow(xy, ctr + xy);\\n xy *= -3.;\\n //xy = fract(xy / 0.1);\\n vec4 pos = vec4(xy / yOff, -.25*s*xOff/sin(s*sin(time)) , 1.15-xOff);\\n pos *= rotY(PI * s);\\n gl_Position = pos;\\n xy -= vec2(0.5);\\n xy *= rotate2D(-snd * -PI * 2.0);\\n xy += vec2(0.5);\\n xy *= mouse;\\n float hue = snd *-s;\\n hue = smoothstep(xy.x, xy.y, s);\\n float sat = 1.0;\\n float val = invV;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val))+0.95*s, 1);\\n color *= rotY(PI * snd * s/2.);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n \\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n vec2 ctr = vec2(0.5);\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 4.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 80. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown * snd; \n gl_PointSize *= resolution.x / 40. * xOff; \n xy -= ctr;\n xy *= rotate2D(snd * PI * 2.0 +s);\n xy += ctr;\n xy *= pow(xy, ctr + xy);\n xy *= -3.;\n //xy = fract(xy / 0.1);\n vec4 pos = vec4(xy / yOff, -.25*s*xOff/sin(s*sin(time)) , 1.15-xOff);\n pos *= rotY(PI * s);\n gl_Position = pos;\n xy -= vec2(0.5);\n xy *= rotate2D(-snd * -PI * 2.0);\n xy += vec2(0.5);\n xy *= mouse;\n float hue = snd *-s;\n hue = smoothstep(xy.x, xy.y, s);\n float sat = 1.0;\n float val = invV;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val))+0.95*s, 1);\n color *= rotY(PI * snd * s/2.);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n \n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-uh63fy28jajvpio8p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/PyWaWYkpMMnc2GQBc/art.json b/art/PyWaWYkpMMnc2GQBc/art.json index 60082c91..f30f052c 100644 --- a/art/PyWaWYkpMMnc2GQBc/art.json +++ b/art/PyWaWYkpMMnc2GQBc/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Hash without Sine\\n// MIT License...\\n/* Copyright (c)2014 David Hoskins.\\n\\nPermission is hereby granted, free of charge, to any person obtaining a copy\\nof this software and associated documentation files (the \\\"Software\\\"), to deal\\nin the Software without restriction, including without limitation the rights\\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\\ncopies of the Software, and to permit persons to whom the Software is\\nfurnished to do so, subject to the following conditions:\\n\\nThe above copyright notice and this permission notice shall be included in all\\ncopies or substantial portions of the Software.\\n\\nTHE SOFTWARE IS PROVIDED \\\"AS IS\\\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\\nSOFTWARE.*/\\n\\n//----------------------------------------------------------------------------------------\\n// 1 out, 1 in...\\nfloat hash11(float p) {\\n p = fract(p * .1031);\\n p *= p + 33.33;\\n p *= p + p;\\n return fract(p);\\n}\\n\\n\\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\\n// Licensed under CC BY-SA 3.0\\n\\n#ifndef TAU\\n#define TAU 6.28318530718\\n#endif\\n#ifndef PI\\n#define PI 3.14159265359\\n#endif\\n\\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\\n\\nvec2 parametric_ngon(float n, float theta) {\\n theta = mod(TAU * theta, TAU);\\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\\n float x = r * cos(theta);\\n float y = r * sin(theta);\\n return vec2(x, y);\\n}\\n\\nvec4 grid2(float id, float w, float h) {\\n float ux = w == 1.0 ? 0.0 : mod(id, w);\\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\\n return vec4(x, y, ux, uy);\\n}\\n\\nmat2 rot2(float t) {\\n float ct = cos(t);\\n float st = sin(t);\\n return mat2(ct, -st, st, ct);\\n}\\n\\n\\nvoid main() {\\n float gridw = 10.;\\n float gridh = 10.;\\n float particles_per_tile = 1000.0;\\n float i = vertexId;\\n float pct = i / (vertexCount - 1.0);\\n\\n float tile_i = floor(i / particles_per_tile);\\n float tile_count = gridw * gridh;\\n\\n float tile_pi = mod(i, particles_per_tile);\\n float tile_ppct = tile_pi / particles_per_tile;\\n\\n float row = floor(tile_i/gridw);\\n float col = mod(tile_i, gridw);\\n\\n float size = 2.0/(gridw - 1.0);\\n vec2 grid_scale = 1.3*vec2(1.0*sqrt(3.0)*size, 1.5*size);\\n vec2 tile_scale = vec2(size);\\n vec2 center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\\n float loop_len = 4.0;\\n float time_off = 0.0;\\n float loop_pct = mod(time + time_off, loop_len) / (loop_len - 1.0);\\n\\n float ngon = 6.0;\\n vec2 shape_a = parametric_ngon(ngon, tile_ppct);\\n vec2 shape_b = parametric_ngon(ngon, tile_ppct + 0.5);\\n float anim_delay = mix(0.0, 0.6, length(center + 0.0001)/(0.93*sqrt(2.0))) + mix(0.0, 0.2, tile_ppct);\\n float anim_len = 0.2;\\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\\n vec2 shape = mix(shape_a, shape_b, m);\\n float eo = mod(row, 2.0);\\n float rotoff = 0.0*(max(abs(center.x), abs(center.y)));\\n shape = rot2(0.25*TAU)*shape;\\n shape *= tile_scale;\\n shape.x += 1.0 * eo * tile_scale.x;\\n shape.y += 1.0*size;\\n gl_Position.xy = center + shape;\\n gl_Position.zw = vec2(0.0, 1.0);\\n\\n float scale = 0.006;\\n gl_PointSize = 1000.0*scale;\\n\\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Hash without Sine\n// MIT License...\n/* Copyright (c)2014 David Hoskins.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.*/\n\n//----------------------------------------------------------------------------------------\n// 1 out, 1 in...\nfloat hash11(float p) {\n p = fract(p * .1031);\n p *= p + 33.33;\n p *= p + p;\n return fract(p);\n}\n\n\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\n// Licensed under CC BY-SA 3.0\n\n#ifndef TAU\n#define TAU 6.28318530718\n#endif\n#ifndef PI\n#define PI 3.14159265359\n#endif\n\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\n\nvec2 parametric_ngon(float n, float theta) {\n theta = mod(TAU * theta, TAU);\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\n float x = r * cos(theta);\n float y = r * sin(theta);\n return vec2(x, y);\n}\n\nvec4 grid2(float id, float w, float h) {\n float ux = w == 1.0 ? 0.0 : mod(id, w);\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\n return vec4(x, y, ux, uy);\n}\n\nmat2 rot2(float t) {\n float ct = cos(t);\n float st = sin(t);\n return mat2(ct, -st, st, ct);\n}\n\n\nvoid main() {\n float gridw = 10.;\n float gridh = 10.;\n float particles_per_tile = 1000.0;\n float i = vertexId;\n float pct = i / (vertexCount - 1.0);\n\n float tile_i = floor(i / particles_per_tile);\n float tile_count = gridw * gridh;\n\n float tile_pi = mod(i, particles_per_tile);\n float tile_ppct = tile_pi / particles_per_tile;\n\n float row = floor(tile_i/gridw);\n float col = mod(tile_i, gridw);\n\n float size = 2.0/(gridw - 1.0);\n vec2 grid_scale = 1.3*vec2(1.0*sqrt(3.0)*size, 1.5*size);\n vec2 tile_scale = vec2(size);\n vec2 center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\n float loop_len = 4.0;\n float time_off = 0.0;\n float loop_pct = mod(time + time_off, loop_len) / (loop_len - 1.0);\n\n float ngon = 6.0;\n vec2 shape_a = parametric_ngon(ngon, tile_ppct);\n vec2 shape_b = parametric_ngon(ngon, tile_ppct + 0.5);\n float anim_delay = mix(0.0, 0.6, length(center + 0.0001)/(0.93*sqrt(2.0))) + mix(0.0, 0.2, tile_ppct);\n float anim_len = 0.2;\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\n vec2 shape = mix(shape_a, shape_b, m);\n float eo = mod(row, 2.0);\n float rotoff = 0.0*(max(abs(center.x), abs(center.y)));\n shape = rot2(0.25*TAU)*shape;\n shape *= tile_scale;\n shape.x += 1.0 * eo * tile_scale.x;\n shape.y += 1.0*size;\n gl_Position.xy = center + shape;\n gl_Position.zw = vec2(0.0, 1.0);\n\n float scale = 0.006;\n gl_PointSize = 1000.0*scale;\n\n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-yhmdeti00zvf5ywj4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/PyqCH2QLtx4JYsvAY/art.json b/art/PyqCH2QLtx4JYsvAY/art.json index ec754351..dca5d3e3 100644 --- a/art/PyqCH2QLtx4JYsvAY/art.json +++ b/art/PyqCH2QLtx4JYsvAY/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"void main() {\\n \\n float density = 50.;\\n \\n float xoff = -0.5 * sin(vertexId);\\n \\n float yoff = -0.5 * sin(time*vertexId);\\n \\n float ux = 0.01;\\n \\n float uy = 0.01;\\n \\n float x = mod(vertexId , density);\\n \\n float y = mod(floor(vertexId / density), density);\\n \\n \\n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n\\n \\n gl_PointSize = 10.*(sin(time*vertexId/1000.)+ 1.); //mod(vertexId, density * density) / 5.;\\n\\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "void main() {\n \n float density = 50.;\n \n float xoff = -0.5 * sin(vertexId);\n \n float yoff = -0.5 * sin(time*vertexId);\n \n float ux = 0.01;\n \n float uy = 0.01;\n \n float x = mod(vertexId , density);\n \n float y = mod(floor(vertexId / density), density);\n \n \n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n\n \n gl_PointSize = 10.*(sin(time*vertexId/1000.)+ 1.); //mod(vertexId, density * density) / 5.;\n\n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-xe70xdftg2thbr6cj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Pzbk6qLsSg2d38JRq/art.json b/art/Pzbk6qLsSg2d38JRq/art.json index 8db3ac34..a018d56d 100644 --- a/art/Pzbk6qLsSg2d38JRq/art.json +++ b/art/Pzbk6qLsSg2d38JRq/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "przemyslawzaworski", "avatarUrl": "https://secure.gravatar.com/avatar/3a3abcfa29dc9b0fa9fd2fb25ff10892?default=retro&size=200", - "settings": "{\"num\":24576,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const mat4 ModelViewProjection = mat4(\\n\\t0.974278, 0.000000, 0.000000, 0.000000,\\n\\t0.000000, 1.705737, -0.173752, -0.173648,\\n\\t0.000000, 0.300767, 0.985398, 0.984807,\\n\\t0.000000, 1.301937, 9.427560, 10.021725\\n);\\n\\nvec3 Hash(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973));\\n\\tp3 += dot(p3, p3.yzx+33.33);\\n\\treturn fract((p3.xxy+p3.yzz)*p3.zyx); \\n}\\n\\nvoid main() \\n{\\n\\tint tessellationFactor = 64; // vertex count = _TessellationFactor * _TessellationFactor * 6\\n\\tint instance = int(floor(vertexId / 6.0));\\n\\tfloat x = sign(mod(20.0, mod(float(vertexId), 6.0) + 2.0));\\n\\tfloat y = sign(mod(18.0, mod(float(vertexId), 6.0) + 2.0));\\n\\tfloat u = (float(instance / tessellationFactor) + x) / float(tessellationFactor);\\n\\tfloat v = (mod(float(instance), float(tessellationFactor)) + y) / float(tessellationFactor);\\n\\tfloat pi = 3.14159265359;\\n\\tfloat radius = 4.0;\\n\\tfloat a = sin(pi * u) * cos(2.0 * pi * v);\\n\\tfloat b = cos(pi * u);\\n\\tfloat c = sin(pi * u) * sin(2.0 * pi * v);\\n\\tvec3 position = vec3(a, b, c) * radius;\\n\\tgl_Position = ModelViewProjection * vec4(position, 1.0);\\n\\tvec3 normalDir = normalize(position);\\n\\tvec3 lightDir = normalize(vec3(0, 0, -10));\\n\\tfloat diffusion = max(dot(lightDir, normalDir), 0.0);\\n\\tv_color = vec4(Hash(float(instance + 123)), 1.0) * vec4(vec3(diffusion), 1.0);\\n}\"}", + "settings": { + "num": 24576, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const mat4 ModelViewProjection = mat4(\n\t0.974278, 0.000000, 0.000000, 0.000000,\n\t0.000000, 1.705737, -0.173752, -0.173648,\n\t0.000000, 0.300767, 0.985398, 0.984807,\n\t0.000000, 1.301937, 9.427560, 10.021725\n);\n\nvec3 Hash(float p)\n{\n\tvec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973));\n\tp3 += dot(p3, p3.yzx+33.33);\n\treturn fract((p3.xxy+p3.yzz)*p3.zyx); \n}\n\nvoid main() \n{\n\tint tessellationFactor = 64; // vertex count = _TessellationFactor * _TessellationFactor * 6\n\tint instance = int(floor(vertexId / 6.0));\n\tfloat x = sign(mod(20.0, mod(float(vertexId), 6.0) + 2.0));\n\tfloat y = sign(mod(18.0, mod(float(vertexId), 6.0) + 2.0));\n\tfloat u = (float(instance / tessellationFactor) + x) / float(tessellationFactor);\n\tfloat v = (mod(float(instance), float(tessellationFactor)) + y) / float(tessellationFactor);\n\tfloat pi = 3.14159265359;\n\tfloat radius = 4.0;\n\tfloat a = sin(pi * u) * cos(2.0 * pi * v);\n\tfloat b = cos(pi * u);\n\tfloat c = sin(pi * u) * sin(2.0 * pi * v);\n\tvec3 position = vec3(a, b, c) * radius;\n\tgl_Position = ModelViewProjection * vec4(position, 1.0);\n\tvec3 normalDir = normalize(position);\n\tvec3 lightDir = normalize(vec3(0, 0, -10));\n\tfloat diffusion = max(dot(lightDir, normalDir), 0.0);\n\tv_color = vec4(Hash(float(instance + 123)), 1.0) * vec4(vec3(diffusion), 1.0);\n}" + }, "screenshotURL": "data/images/images-gzyo53tr1ng52yz76-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Q2oHwSyr3NpT7jokA/art.json b/art/Q2oHwSyr3NpT7jokA/art.json index 805264e8..44ece71d 100644 --- a/art/Q2oHwSyr3NpT7jokA/art.json +++ b/art/Q2oHwSyr3NpT7jokA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Daehyeon Kim\\n//Make a grid\\n//CS250\\n//Spring, 2022\\n\\nvoid main() {\\n float factor = sin(time) * 5. + 6.;\\n \\n float down = floor(sqrt(vertexCount)) * factor;\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n x += sin(time) * 5.;\\n y += cos(time) * 8.;\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(sin(time) * 0.5 + 0.5,cos(time) * 0.5 + 0.5,0,1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Daehyeon Kim\n//Make a grid\n//CS250\n//Spring, 2022\n\nvoid main() {\n float factor = sin(time) * 5. + 6.;\n \n float down = floor(sqrt(vertexCount)) * factor;\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n x += sin(time) * 5.;\n y += cos(time) * 8.;\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(sin(time) * 0.5 + 0.5,cos(time) * 0.5 + 0.5,0,1);\n}" + }, "screenshotURL": "data/images/images-3qk4qpigbz0rd8y04-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Q3Mv3prh5dPis7GsK/art.json b/art/Q3Mv3prh5dPis7GsK/art.json index 3668b0c1..4a0ae451 100644 --- a/art/Q3Mv3prh5dPis7GsK/art.json +++ b/art/Q3Mv3prh5dPis7GsK/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":40076,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 0.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /72. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x / p2.y * 165.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\\n}\"}", + "settings": { + "num": 40076, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 0.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /72. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\n\treturn fract(p2.x / p2.y * 165.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\n}" + }, "screenshotURL": "data/images/images-nx9nubm4636437bwe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Q3ckKgYEBkj3MgeLP/art.json b/art/Q3ckKgYEBkj3MgeLP/art.json index 112933a5..136361f1 100644 --- a/art/Q3ckKgYEBkj3MgeLP/art.json +++ b/art/Q3ckKgYEBkj3MgeLP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define Kp0 22.//KParameter 0.>>22.\\n#define Kp1 1.//KParameter 0.>>1.\\n#define Kp2 0.6//KParameter 0.>>1.5\\n#define Kp3 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>1.\\n#define rotationFactorY 1.//KParameter 0.>>1.\\n#define rotationFactorZ 1.//KParameter 0.>>1.\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427*Kp0));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .15)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(cpos*-0.8*snd);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-.1, Kp2, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0.)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4+Kp1, 0.5*Kp2));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.3, snd));\\n abs(ca * cd) * Kp2;\\n float sat =pow(snd + 1.3,3.); step(0.4, snd);\\n float val =- 0.4+snd;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define Kp0 22.//KParameter 0.>>22.\n#define Kp1 1.//KParameter 0.>>1.\n#define Kp2 0.6//KParameter 0.>>1.5\n#define Kp3 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>1.\n#define rotationFactorY 1.//KParameter 0.>>1.\n#define rotationFactorZ 1.//KParameter 0.>>1.\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427*Kp0));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .15)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(cpos*-0.8*snd);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-.1, Kp2, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0.)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 1.4+Kp1, 0.5*Kp2));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.3, snd));\n abs(ca * cd) * Kp2;\n float sat =pow(snd + 1.3,3.); step(0.4, snd);\n float val =- 0.4+snd;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-0x4xmpjl994ydidtk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Q3wB5rKJ8hQm7Qu7Q/art.json b/art/Q3wB5rKJ8hQm7Qu7Q/art.json index 0961a4a4..028aaa73 100644 --- a/art/Q3wB5rKJ8hQm7Qu7Q/art.json +++ b/art/Q3wB5rKJ8hQm7Qu7Q/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":421,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 5;\\t\\n \\n \\n \\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\\n }\\n \\n else if(num == 5) {\\n gl_Position = vec4(cos(vertexId),sin(vertexId),0.0,1.0);\\n }\\n\\n gl_PointSize = cos(time)*vertexId/50.0; \\n \\n \\n v_color = vec4(sin(vertexId/122.0),\\n sin(vertexId/122.0),\\n sin(vertexId/122.0),1);\\n}\"}", + "settings": { + "num": 421, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 5;\t\n \n \n \n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\n }\n \n else if(num == 5) {\n gl_Position = vec4(cos(vertexId),sin(vertexId),0.0,1.0);\n }\n\n gl_PointSize = cos(time)*vertexId/50.0; \n \n \n v_color = vec4(sin(vertexId/122.0),\n sin(vertexId/122.0),\n sin(vertexId/122.0),1);\n}" + }, "screenshotURL": "data/images/images-1cpbh842ifaq8wogr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Q4dpCbhvWMYfDz5Nb/art.json b/art/Q4dpCbhvWMYfDz5Nb/art.json index 387d173d..12ef6097 100644 --- a/art/Q4dpCbhvWMYfDz5Nb/art.json +++ b/art/Q4dpCbhvWMYfDz5Nb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/drumcomplex-roel-salemink-load-my-battery-bush-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 14.;\\n float across = 14.;\\n float back = 14.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float cz = floor(cubeId / across / back);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (back - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n float cc = cw * 2. - 1.;\\n \\n float sv1 = atan(ca, cb) / PI;\\n float sv = abs(atan(sv1, cc)) / PI;\\n \\n\\n float s1 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 3. / soundRes.y)).a;\\n float s = (s1 + s2 + s3 + s4) / 4.;\\n \\n s = mix(0., 1. + sv * .3, s);\\n s = clamp(s, 0., 1.);\\n \\n float tm = time * 0.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up);\\n mat4 wmat = rotY(time * 0.1); \\n wmat *= rotX(sin(time * 0.13));\\n wmat *= trans(vec3(ca, cc, cb) * down * 0.65);\\n wmat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\\n \\n vec4 wpos = wmat * vec4(pos, 1);\\n gl_Position = pmat * vmat * wpos;\\n vec3 n = normalize((wmat * vec4(normal, 0)).xyz);\\n \\n //vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(34, 3, -24);\\n vec3 lightDir = normalize(lightPos - wpos.xyz);\\n\\n float hue = 0.5;//abs(ca * cc) * 2.;\\n float sat = 0.1;//mix(0., 1., step(10.8, s));\\n float val = mix(0.5, 0.5, step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = dot(n, lightDir) * 0.5 + 0.5;\\n v_color = vec4(color * pinch(lt, 2.) + vec3(pow(lt, 200.)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/drumcomplex-roel-salemink-load-my-battery-bush-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 14.;\n float across = 14.;\n float back = 14.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float cz = floor(cubeId / across / back);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (back - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n float cc = cw * 2. - 1.;\n \n float sv1 = atan(ca, cb) / PI;\n float sv = abs(atan(sv1, cc)) / PI;\n \n\n float s1 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(0.01, 0.5, (sv)), 3. / soundRes.y)).a;\n float s = (s1 + s2 + s3 + s4) / 4.;\n \n s = mix(0., 1. + sv * .3, s);\n s = clamp(s, 0., 1.);\n \n float tm = time * 0.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up);\n mat4 wmat = rotY(time * 0.1); \n wmat *= rotX(sin(time * 0.13));\n wmat *= trans(vec3(ca, cc, cb) * down * 0.65);\n wmat *= uniformScale(clamp(mix(-.2, 9., pow(s, 6.)), 0., 1.));\n \n vec4 wpos = wmat * vec4(pos, 1);\n gl_Position = pmat * vmat * wpos;\n vec3 n = normalize((wmat * vec4(normal, 0)).xyz);\n \n //vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(34, 3, -24);\n vec3 lightDir = normalize(lightPos - wpos.xyz);\n\n float hue = 0.5;//abs(ca * cc) * 2.;\n float sat = 0.1;//mix(0., 1., step(10.8, s));\n float val = mix(0.5, 0.5, step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = dot(n, lightDir) * 0.5 + 0.5;\n v_color = vec4(color * pinch(lt, 2.) + vec3(pow(lt, 200.)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-rhdtg29vo6feev03t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Q6WYaT35yY2FLBkgi/art.json b/art/Q6WYaT35yY2FLBkgi/art.json index 71722c8a..217878b3 100644 --- a/art/Q6WYaT35yY2FLBkgi/art.json +++ b/art/Q6WYaT35yY2FLBkgi/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "spirography", "username": "gman", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//\\n#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//\n#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "XDjiC5DcXbYw7fpvF", "views": { "$numberInt": "362" diff --git a/art/Q85DLHuNZgXEXPBYw/art.json b/art/Q85DLHuNZgXEXPBYw/art.json index 95f08239..6bcf3131 100644 --- a/art/Q85DLHuNZgXEXPBYw/art.json +++ b/art/Q85DLHuNZgXEXPBYw/art.json @@ -26,7 +26,19 @@ "name": "Sea", "private": true, "username": "baldand", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5019607843137255,1,1,1],\"shader\":\"#define GRID_WIDTH 40.0\\n#define GRID_DEPTH 50.0\\n#define TRIS (GRID_WIDTH * GRID_DEPTH * 4.0)\\n#define VERTS (TRIS * 3.0)\\n\\nfloat heightMap(vec2 pos) {\\n return sin(pos.x+time)+sin(pos.y+pos.x*1.4+time);\\n}\\n\\nvec4 heightMapCol(vec2 pos) {\\n return vec4(0.2,0.4+0.1*sin(100.*pos.x+10.0*pos.y+time*2.),0.8+0.2*sin(200.*pos.y*pos.x+time),1.);\\n}\\n\\nvec2 getPos(float v) {\\n vec2 pos;\\n float square = floor(v/12.0);\\n float sx = mod(v,12.0);\\n float ox = 1.;\\n if (sx==0. || sx==3. || sx==4. || sx==6.) ox = 0.;\\n else if (mod(sx,3.)==2.) ox = .5;\\n float oy = 1.;\\n if (sx==0. || sx==1. || sx==3. || sx==9.) oy = 0.;\\n else if (mod(sx,3.)==2.) oy = .5;\\n float gx = floor(square/GRID_DEPTH);\\n float gy = mod(square,GRID_DEPTH);\\n return vec2(gx+ox,gy+oy);\\n}\\n\\nvoid main() {\\n v_color = vec4(0.);\\n vec3 p;\\n if (vertexId < VERTS) {\\n vec2 pos = getPos(vertexId);\\n float h = heightMap(pos);\\n\\t v_color = heightMapCol(pos);\\n p = vec3(pos.x-GRID_WIDTH*.5,h*.5-2.,pos.y*.5+1.);\\n }\\n gl_Position = vec4(p.xy,1.0/-p.z,p.z);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5019607843137255, + 1, + 1, + 1 + ], + "shader": "#define GRID_WIDTH 40.0\n#define GRID_DEPTH 50.0\n#define TRIS (GRID_WIDTH * GRID_DEPTH * 4.0)\n#define VERTS (TRIS * 3.0)\n\nfloat heightMap(vec2 pos) {\n return sin(pos.x+time)+sin(pos.y+pos.x*1.4+time);\n}\n\nvec4 heightMapCol(vec2 pos) {\n return vec4(0.2,0.4+0.1*sin(100.*pos.x+10.0*pos.y+time*2.),0.8+0.2*sin(200.*pos.y*pos.x+time),1.);\n}\n\nvec2 getPos(float v) {\n vec2 pos;\n float square = floor(v/12.0);\n float sx = mod(v,12.0);\n float ox = 1.;\n if (sx==0. || sx==3. || sx==4. || sx==6.) ox = 0.;\n else if (mod(sx,3.)==2.) ox = .5;\n float oy = 1.;\n if (sx==0. || sx==1. || sx==3. || sx==9.) oy = 0.;\n else if (mod(sx,3.)==2.) oy = .5;\n float gx = floor(square/GRID_DEPTH);\n float gy = mod(square,GRID_DEPTH);\n return vec2(gx+ox,gy+oy);\n}\n\nvoid main() {\n v_color = vec4(0.);\n vec3 p;\n if (vertexId < VERTS) {\n vec2 pos = getPos(vertexId);\n float h = heightMap(pos);\n\t v_color = heightMapCol(pos);\n p = vec3(pos.x-GRID_WIDTH*.5,h*.5-2.,pos.y*.5+1.);\n }\n gl_Position = vec4(p.xy,1.0/-p.z,p.z);\n}" + }, "screenshotURL": "data/images/images-zn2y5pj0nou4l9agh-thumbnail.jpg", "views": { "$numberInt": "1" diff --git a/art/Q8RpzMoMpG8LgruMo/art.json b/art/Q8RpzMoMpG8LgruMo/art.json index 43a25ece..495674d5 100644 --- a/art/Q8RpzMoMpG8LgruMo/art.json +++ b/art/Q8RpzMoMpG8LgruMo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\\n}\\n\\nmat3 rotx(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 roty(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 rotz(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvec3 to3D( float idx, vec3 side ) \\n{\\n float z = floor(idx / (side.x * side.y));\\n idx -= (z * side.x * side.y);\\n float y = (idx / side.x);\\n float x = mod(idx, side.x);\\n return vec3(x,y,z);\\n}\\n\\nfloat grow = 1.;\\n\\nfloat df(vec3 p)\\n{\\n\\tp.xyz += 1.000*sin( 2.0*p.yzx )*grow;\\n \\tp.xyz += 0.500*sin( 4.0*p.yzx )*grow;\\n return length(p)-1.;\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 2.;\\n\\tfloat sideCount = pow(vertexCount, 1./3.);\\n\\tvec3 p = to3D(vertexId, vec3(sideCount)) - sideCount * .5;\\n\\tfloat d = df(p);\\n\\tvec3 ro = p;\\n\\tvec3 rd = normalize(vec3(0) - ro);//\\n\\tgrow = sin(time * 0.5)*.6;\\n\\tfloat s = 1.;\\n\\tfor (int i = 0;i <200; i++)\\n\\t{\\n\\t\\ts = df(ro+rd*d);\\n\\t\\td += abs(s) * .1;\\n\\t}\\n\\t\\t\\n\\tvec3 pos = ro + rd * d;\\n\\tpos *= 0.23;\\n\\tpos *= rotx(-time*0.1) * roty(time*0.3);\\n \\tpos.y *= resolution.x / resolution.y;\\n\\tgl_Position = vec4(pos,1);\\n\\n \\tfloat hue = (time * 0.01 + floor(vertexId) * 1.001);\\n \\tv_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\n}\n\nmat3 rotx(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 roty(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 rotz(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvec3 to3D( float idx, vec3 side ) \n{\n float z = floor(idx / (side.x * side.y));\n idx -= (z * side.x * side.y);\n float y = (idx / side.x);\n float x = mod(idx, side.x);\n return vec3(x,y,z);\n}\n\nfloat grow = 1.;\n\nfloat df(vec3 p)\n{\n\tp.xyz += 1.000*sin( 2.0*p.yzx )*grow;\n \tp.xyz += 0.500*sin( 4.0*p.yzx )*grow;\n return length(p)-1.;\n}\n\nvoid main()\n{\n\tgl_PointSize = 2.;\n\tfloat sideCount = pow(vertexCount, 1./3.);\n\tvec3 p = to3D(vertexId, vec3(sideCount)) - sideCount * .5;\n\tfloat d = df(p);\n\tvec3 ro = p;\n\tvec3 rd = normalize(vec3(0) - ro);//\n\tgrow = sin(time * 0.5)*.6;\n\tfloat s = 1.;\n\tfor (int i = 0;i <200; i++)\n\t{\n\t\ts = df(ro+rd*d);\n\t\td += abs(s) * .1;\n\t}\n\t\t\n\tvec3 pos = ro + rd * d;\n\tpos *= 0.23;\n\tpos *= rotx(-time*0.1) * roty(time*0.3);\n \tpos.y *= resolution.x / resolution.y;\n\tgl_Position = vec4(pos,1);\n\n \tfloat hue = (time * 0.01 + floor(vertexId) * 1.001);\n \tv_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}\n" + }, "screenshotURL": "data/images/images-zhy93hztoppc95eki-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Q9DLLK5ZfccWG9Shv/art.json b/art/Q9DLLK5ZfccWG9Shv/art.json index 314bfcdb..47aee071 100644 --- a/art/Q9DLLK5ZfccWG9Shv/art.json +++ b/art/Q9DLLK5ZfccWG9Shv/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":35646,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define P 180.\\n#define I 5.\\n#define L (P*I*I)\\nfloat expo(float t) { return t*(t*(4.*t - 6.) + 3.); }\\n\\nvec2 circle(float eid, float start, float arclen, float N) {\\n float angle = start + (mod(floor(eid/2.)+floor(mod(eid,2.)), N*2.)/N*2.*arclen);\\n \\treturn vec2(cos(angle*PI*2.),sin(angle*PI*2.));\\n}\\n\\nvoid main() {\\n\\tfloat \\tlv = mod(vertexId,L), l = floor(vertexId/L),\\n\\t\\t\\ti = floor(lv / P), iv = mod(lv,P), e = mod(i,2.);\\n\\tvec2 pos = vec2( mod(i,I)-2.2, floor(i/I)-2. )*vec2(.4,.39), xy;\\n\\tif (l == 1.) {\\n\\t\\txy = pos+circle(iv,0.,1.,P) * (0.2 + e*0.04);\\n \\tv_color = vec4(vec3(.5)*floor(mod(iv,4.)/2.),1); \\n\\t} else if (l == 0.) {\\n \\tfloat a = mod((time + i*6.)*.2*(1.+e)+.3*e+.8,1.), s = mod(a,.25);\\n \\ta = expo(s/.25)*.25 + a - s;\\n \\txy = pos+circle(iv,a,.25,P) * (.2 + e*.04);\\n \\tv_color = vec4(0.,0.2+clamp(e*cos(7.*a-.5),0.,1.) + clamp((1.-e)*sin(7.*a+0.25),0.,1.),0,.5); \\n \\t} else if (l <=3.) {\\n float scale = (l-2.)*0.03;\\n xy = pos+circle(mod(iv,P-1.),.75,0.5,P)*vec2(.03+scale,.03+scale*.6)+vec2(scale*-.4-.05,-0.09);\\n v_color = vec4(1,1,1,1); \\n \\t} else if (l <= 5.) {\\n // float lx = 0.;//(l-4.);\\n // float part =floor(iv/P*2.);\\n // xy = vec2(lx*0.03*-.4+.05,lx*-0.01-0.09) + pos+circle(P-iv+1.,mix(0.2,0.27,part),mix(0.53,0.46,part),P/2.)*vec2(1.,1.-part*2.)*0.05+vec2(0,part*-.1);\\n // xy = pos+circle(mod(iv,P-1.),.75,0.5)*vec2(.03+scale,.03+scale*.6)+vec2(scale*-.4+.05,-0.09);\\n v_color = vec4(1,1,1,1); \\n \\t}\\n\\tgl_Position = vec4(xy * vec2(1, resolution.x / resolution.y)*0.9, 0, 1);\\n}\\n\\n\"}", + "settings": { + "num": 35646, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define P 180.\n#define I 5.\n#define L (P*I*I)\nfloat expo(float t) { return t*(t*(4.*t - 6.) + 3.); }\n\nvec2 circle(float eid, float start, float arclen, float N) {\n float angle = start + (mod(floor(eid/2.)+floor(mod(eid,2.)), N*2.)/N*2.*arclen);\n \treturn vec2(cos(angle*PI*2.),sin(angle*PI*2.));\n}\n\nvoid main() {\n\tfloat \tlv = mod(vertexId,L), l = floor(vertexId/L),\n\t\t\ti = floor(lv / P), iv = mod(lv,P), e = mod(i,2.);\n\tvec2 pos = vec2( mod(i,I)-2.2, floor(i/I)-2. )*vec2(.4,.39), xy;\n\tif (l == 1.) {\n\t\txy = pos+circle(iv,0.,1.,P) * (0.2 + e*0.04);\n \tv_color = vec4(vec3(.5)*floor(mod(iv,4.)/2.),1); \n\t} else if (l == 0.) {\n \tfloat a = mod((time + i*6.)*.2*(1.+e)+.3*e+.8,1.), s = mod(a,.25);\n \ta = expo(s/.25)*.25 + a - s;\n \txy = pos+circle(iv,a,.25,P) * (.2 + e*.04);\n \tv_color = vec4(0.,0.2+clamp(e*cos(7.*a-.5),0.,1.) + clamp((1.-e)*sin(7.*a+0.25),0.,1.),0,.5); \n \t} else if (l <=3.) {\n float scale = (l-2.)*0.03;\n xy = pos+circle(mod(iv,P-1.),.75,0.5,P)*vec2(.03+scale,.03+scale*.6)+vec2(scale*-.4-.05,-0.09);\n v_color = vec4(1,1,1,1); \n \t} else if (l <= 5.) {\n // float lx = 0.;//(l-4.);\n // float part =floor(iv/P*2.);\n // xy = vec2(lx*0.03*-.4+.05,lx*-0.01-0.09) + pos+circle(P-iv+1.,mix(0.2,0.27,part),mix(0.53,0.46,part),P/2.)*vec2(1.,1.-part*2.)*0.05+vec2(0,part*-.1);\n // xy = pos+circle(mod(iv,P-1.),.75,0.5)*vec2(.03+scale,.03+scale*.6)+vec2(scale*-.4+.05,-0.09);\n v_color = vec4(1,1,1,1); \n \t}\n\tgl_Position = vec4(xy * vec2(1, resolution.x / resolution.y)*0.9, 0, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-kbxq6b5frcee7gefy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QCpubvSnQsitsMWjB/art.json b/art/QCpubvSnQsitsMWjB/art.json index f3c9c1b5..eb3fec34 100644 --- a/art/QCpubvSnQsitsMWjB/art.json +++ b/art/QCpubvSnQsitsMWjB/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "8bitrick", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/turanoza/desert-symphony-the-piano-guys\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI 3.14159\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) { return v * 2. - 1.; }\\n\\nvoid main()\\n{\\n float NUM_FLOWERS = 13.;\\n float verts_per_flower = vertexCount / NUM_FLOWERS;\\n float flower = floor(vertexId / verts_per_flower);\\n float flower_per = flower / (NUM_FLOWERS-1.);\\n float hash_flower = hash(flower_per-0.17777);\\n vec2 center = vec2(m1p1(hash_flower), m1p1(hash(hash_flower))) * 0.6;\\n \\n float vertex_per = mod(vertexId, verts_per_flower) / verts_per_flower;\\n float freq = vertex_per * 0.8 + 0.1;\\n float amp = texture2D(sound,vec2(freq,0.)).a;// + (flower_per) - 1. + hash(flower_per);\\n \\n float layers = 37.;\\n float angle = fract(hash(vertexId/(vertexCount-1.)) * layers) * 0.333 * PI + (0.333 * PI);\\n vec2 xy = center + vec2(cos(angle), sin(angle)) * amp;\\n \\n float dist = clamp(0.,1.,(center.y+1.)*(center.y+1.)-1.);\\n \\n gl_PointSize = mix(10.0, 5., dist);\\n gl_Position = vec4(xy,0,1);\\n v_color = mix(vec4(hsv2rgb(vec3(amp*0.21, 1.-amp, 1.)), 1.-flower_per), background, dist - 0.5);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/turanoza/desert-symphony-the-piano-guys", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI 3.14159\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) { return v * 2. - 1.; }\n\nvoid main()\n{\n float NUM_FLOWERS = 13.;\n float verts_per_flower = vertexCount / NUM_FLOWERS;\n float flower = floor(vertexId / verts_per_flower);\n float flower_per = flower / (NUM_FLOWERS-1.);\n float hash_flower = hash(flower_per-0.17777);\n vec2 center = vec2(m1p1(hash_flower), m1p1(hash(hash_flower))) * 0.6;\n \n float vertex_per = mod(vertexId, verts_per_flower) / verts_per_flower;\n float freq = vertex_per * 0.8 + 0.1;\n float amp = texture2D(sound,vec2(freq,0.)).a;// + (flower_per) - 1. + hash(flower_per);\n \n float layers = 37.;\n float angle = fract(hash(vertexId/(vertexCount-1.)) * layers) * 0.333 * PI + (0.333 * PI);\n vec2 xy = center + vec2(cos(angle), sin(angle)) * amp;\n \n float dist = clamp(0.,1.,(center.y+1.)*(center.y+1.)-1.);\n \n gl_PointSize = mix(10.0, 5., dist);\n gl_Position = vec4(xy,0,1);\n v_color = mix(vec4(hsv2rgb(vec3(amp*0.21, 1.-amp, 1.)), 1.-flower_per), background, dist - 0.5);\n}\n" + }, "screenshotURL": "data/images/images-yaymimp38ohxugkcp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QCxSnbduPERK5rQni/art.json b/art/QCxSnbduPERK5rQni/art.json index eb1f4859..163b15c4 100644 --- a/art/QCxSnbduPERK5rQni/art.json +++ b/art/QCxSnbduPERK5rQni/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":3096,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ken-ishii-70drums/ken-ishii-feat-jazztronik-after-the-rainstorm-hideo-kobayashi-remix-remastered-70-drums\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nJust a challenge to put both lines and dots in the same piece\\n\\nNote: I should really not be using my cirlce funciton which\\nis generating a square from 24 vertices instead of 6 but \\nI'm lazy and maybe using the circle funciton will generate\\nsome different results later.\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1.41421356237, vy);\\n float a = mix(start, end, u) * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float line = mod(circleId, 2.); // 1 if line, 0 if point\\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = line * .1;\\n \\n \\n float g0 = (groupId ) / numGroups;\\n float g1 = (groupId + 1.) / numGroups;\\n \\n float s0 = texture2D(sound, vec2(mix(.1, .5, g0), 0)).a;\\n float s1 = texture2D(sound, vec2(mix(.1, .5, g1), 0)).a;\\n \\n #if 0\\n float t = time * 0.1;\\n s0 = sin(t + g0 * 20.) * .5;\\n s1 = sin(t + g1 * 20.) * .5;\\n #endif\\n \\n vec2 p0 = vec2(t2m1(g0) * .9, s0 - .5);\\n vec2 p1 = vec2(t2m1(g0) * .9, s1 - .5);\\n vec2 dif = p1 - p0;\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 mat = scale(vec3(1, aspect, 1));\\n \\n const float dotSize = .005;\\n const float lineWidth = .001;\\n \\n mat *= trans(vec3(p0, 0));\\n mat *= rotZ(atan(dif.x, dif.y) * line);\\n mat *= scale(mix(vec3(dotSize, dotSize, 1), vec3(lineWidth, length(dif) * .5, 1), line));\\n mat *= trans(vec3(0, line * 1.0, 0));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * .1 + gv * .2;\\n float sat = 1. - line;\\n float val = 1. - line * .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 3096, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ken-ishii-70drums/ken-ishii-feat-jazztronik-after-the-rainstorm-hideo-kobayashi-remix-remastered-70-drums", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nJust a challenge to put both lines and dots in the same piece\n\nNote: I should really not be using my cirlce funciton which\nis generating a square from 24 vertices instead of 6 but \nI'm lazy and maybe using the circle funciton will generate\nsome different results later.\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1.41421356237, vy);\n float a = mix(start, end, u) * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float line = mod(circleId, 2.); // 1 if line, 0 if point\n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = line * .1;\n \n \n float g0 = (groupId ) / numGroups;\n float g1 = (groupId + 1.) / numGroups;\n \n float s0 = texture2D(sound, vec2(mix(.1, .5, g0), 0)).a;\n float s1 = texture2D(sound, vec2(mix(.1, .5, g1), 0)).a;\n \n #if 0\n float t = time * 0.1;\n s0 = sin(t + g0 * 20.) * .5;\n s1 = sin(t + g1 * 20.) * .5;\n #endif\n \n vec2 p0 = vec2(t2m1(g0) * .9, s0 - .5);\n vec2 p1 = vec2(t2m1(g0) * .9, s1 - .5);\n vec2 dif = p1 - p0;\n \n float aspect = resolution.x / resolution.y;\n mat4 mat = scale(vec3(1, aspect, 1));\n \n const float dotSize = .005;\n const float lineWidth = .001;\n \n mat *= trans(vec3(p0, 0));\n mat *= rotZ(atan(dif.x, dif.y) * line);\n mat *= scale(mix(vec3(dotSize, dotSize, 1), vec3(lineWidth, length(dif) * .5, 1), line));\n mat *= trans(vec3(0, line * 1.0, 0));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * .1 + gv * .2;\n float sat = 1. - line;\n float val = 1. - line * .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-hvt1d0nn03h757b41-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QDDLhEyNvhc9PFDQo/art.json b/art/QDDLhEyNvhc9PFDQo/art.json index 9510bc7d..8a3df417 100644 --- a/art/QDDLhEyNvhc9PFDQo/art.json +++ b/art/QDDLhEyNvhc9PFDQo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvec3 getColor(int index)\\n{\\n\\tif (index == 0)\\n\\t\\treturn vec3(0.2, 0.2, 0.2);\\n\\tif (index == 1)\\n\\t\\treturn vec3(0.2, 0.4, 0.6);\\n\\tif (index == 2)\\n\\t\\treturn vec3(0.2, 0.6, 0.4);\\n\\tif (index == 3)\\n\\t\\treturn vec3(0.4, 0.2, 0.6);\\n\\tif (index == 4)\\n\\t\\treturn vec3(0.4, 0.6, 0.2);\\n\\tif (index == 5)\\n\\t\\treturn vec3(0.6, 0.2, 0.4);\\n\\tif (index == 6)\\n\\t\\treturn vec3(0.6, 0.4, 0.2);\\n\\tif (index == 7)\\n\\t\\treturn vec3(0.6, 0.6, 0.6);\\n\\t\\n}\\n\\n\\nvoid main ()\\n{\\n \\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n float snd = texture2D(sound, vec2(0.1, v)).a;\\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n\\t\\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\tj *= 1.;\\n\\tj = mod(j - time/2., 1.0);\\n\\t\\n\\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\\n\\ti = mod(position.y * colorCount * j, i / j);\\n\\ti *= 8.;\\n\\t\\n\\ti = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( getColor(int(i)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvec3 getColor(int index)\n{\n\tif (index == 0)\n\t\treturn vec3(0.2, 0.2, 0.2);\n\tif (index == 1)\n\t\treturn vec3(0.2, 0.4, 0.6);\n\tif (index == 2)\n\t\treturn vec3(0.2, 0.6, 0.4);\n\tif (index == 3)\n\t\treturn vec3(0.4, 0.2, 0.6);\n\tif (index == 4)\n\t\treturn vec3(0.4, 0.6, 0.2);\n\tif (index == 5)\n\t\treturn vec3(0.6, 0.2, 0.4);\n\tif (index == 6)\n\t\treturn vec3(0.6, 0.4, 0.2);\n\tif (index == 7)\n\t\treturn vec3(0.6, 0.6, 0.6);\n\t\n}\n\n\nvoid main ()\n{\n \n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n float snd = texture2D(sound, vec2(0.1, v)).a;\n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n\t\n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\tj *= 1.;\n\tj = mod(j - time/2., 1.0);\n\t\n\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\n\ti = mod(position.y * colorCount * j, i / j);\n\ti *= 8.;\n\t\n\ti = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( getColor(int(i)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-6hj7b7361kvt8vb7z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QGXB5e8RAqNJsredQ/art.json b/art/QGXB5e8RAqNJsredQ/art.json index cd9821c9..451ef265 100644 --- a/art/QGXB5e8RAqNJsredQ/art.json +++ b/art/QGXB5e8RAqNJsredQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":45140,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.06666666666666667,0.06666666666666667,1],\"shader\":\"\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 2.//KParameter2 -1.>>5.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time* 0.6 );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2/2.),\\n s, 0, 0-2, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, -2, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, -0.1, 0.5, 0.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, s, s-mouse.x, 1.31,\\n s-0.5, 0.3, s, 0,\\n 2, 0.5, 0, 0.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 13.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\\n float end = start + 5.;\\nstart + hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\\n offset.y += goop(circleId * time + 10.13) *0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 45140, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.06666666666666667, + 0.06666666666666667, + 1 + ], + "shader": "\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 2.//KParameter2 -1.>>5.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time* 0.6 );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2/2.),\n s, 0, 0-2, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, -2, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, -0.1, 0.5, 0.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, s, s-mouse.x, 1.31,\n s-0.5, 0.3, s, 0,\n 2, 0.5, 0, 0.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 13.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\n float end = start + 5.;\nstart + hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\n offset.y += goop(circleId * time + 10.13) *0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-7gpwriqsfz2qnlm2a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QH3gSYw84QKSqtGr2/art.json b/art/QH3gSYw84QKSqtGr2/art.json index a186e29a..6603f0bc 100644 --- a/art/QH3gSYw84QKSqtGr2/art.json +++ b/art/QH3gSYw84QKSqtGr2/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "lint", "username": "gman", - "settings": "{\"num\":3343,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6274509803921569,0.984313725490196,0.44313725490196076,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = time * 0.01 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(localTime * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.0025, 0.8);\\n float innerRadius = pow(count * 0.00005, 1.2);\\n float oC = cos(orbitAngle + count * 0.00001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.00001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 3343, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6274509803921569, + 0.984313725490196, + 0.44313725490196076, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = time * 0.01 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(localTime * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.0025, 0.8);\n float innerRadius = pow(count * 0.00005, 1.2);\n float oC = cos(orbitAngle + count * 0.00001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.00001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotDataId": "2e36dARvwMEZykDCX", "views": { "$numberInt": "472" diff --git a/art/QHfQoa4YycdGxqd8r/art.json b/art/QHfQoa4YycdGxqd8r/art.json index bfb2846c..82f5fe07 100644 --- a/art/QHfQoa4YycdGxqd8r/art.json +++ b/art/QHfQoa4YycdGxqd8r/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":28423,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/spiritedlabel/in-my-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"// POST-ITs\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time * 0.1;// - cgv * 0.2;\\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.121, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cu * 0.001;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n// mat *= cameraLookAt(eye, target, up);\\n// mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= trans(vec3(cgv * -0.3 * snd, cgv * 0.2 * snd, -2. + gv + cgId * 0.01));\\n // mat *= rotZ(time * hash(gv * 0.124));// * 0.01 * gy * 0.1 + PI * 0.5);\\n // mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n // mat *= rotZ(gx / gAcross * PI * 2.);\\n // mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(\\n fract(t2m1(hash(gv) + tm * hash(gv * 0.12))) * 20. - 10. , \\n t2m1(hash(gv * .123)) * 3., 0.));\\n mat *= rotZ(PI * .25 + time * hash(groupId * 0.712));\\n mat *= uniformScale(snd);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * 0.01 + sp * 0.2;//groupId * 0.1;\\n float sat = 1.;\\n float val = mix(0., 1., cgId);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(.5, 1., cgId));\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 28423, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/spiritedlabel/in-my-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "// POST-ITs\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time * 0.1;// - cgv * 0.2;\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.121, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cu * 0.001;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n// mat *= cameraLookAt(eye, target, up);\n// mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= trans(vec3(cgv * -0.3 * snd, cgv * 0.2 * snd, -2. + gv + cgId * 0.01));\n // mat *= rotZ(time * hash(gv * 0.124));// * 0.01 * gy * 0.1 + PI * 0.5);\n // mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n // mat *= rotZ(gx / gAcross * PI * 2.);\n // mat *= rotY(PI * 0.5);\n mat *= trans(vec3(\n fract(t2m1(hash(gv) + tm * hash(gv * 0.12))) * 20. - 10. , \n t2m1(hash(gv * .123)) * 3., 0.));\n mat *= rotZ(PI * .25 + time * hash(groupId * 0.712));\n mat *= uniformScale(snd);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * 0.01 + sp * 0.2;//groupId * 0.1;\n float sat = 1.;\n float val = mix(0., 1., cgId);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(.5, 1., cgId));\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-i01msf2w0t87dqmat-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QJskLnkaikLSdkYEs/art.json b/art/QJskLnkaikLSdkYEs/art.json index c95fe52b..fdef7da1 100644 --- a/art/QJskLnkaikLSdkYEs/art.json +++ b/art/QJskLnkaikLSdkYEs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 3.4;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 3.4;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-d14t0js9z65qdfo9a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QKr9Zs5phrohEPjCp/art.json b/art/QKr9Zs5phrohEPjCp/art.json index 4f7a1228..6882af39 100644 --- a/art/QKr9Zs5phrohEPjCp/art.json +++ b/art/QKr9Zs5phrohEPjCp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wearethebraveofficial/we-do-what-we-want\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = start + 1.;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n float s = texture2D(sound, vec2(\\n mix(3./64., 5./64., uvfl.y), //pointId / NUM_POINTS_PER_CIRCLE), \\n 0)).a; \\n float s2 = texture2D(sound, vec2(\\n mix(3.2/64., 3.2/64., pointId / NUM_POINTS_PER_CIRCLE), \\n 0)).a; \\n \\n float tm = 0.;\\n float r = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .0 + 0., sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n float rot = PI * 0.5;\\n mat *= rotY(rot);\\n mat *= uniformScale(mix(1.2, 3., pow(s2 * 1.2, 5.)));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * 0.1 + mix(1.2, 1.9, pow(s, 2.));//time * 0.1 + modStep(uvfl.w, 2.) * abs(sin(time * 0.13));\\n float sat = pow(s, 4.); + sin(time * 0.07) * 0.3;\\n float val = 1.;t5p5(abs(sin(rot)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wearethebraveofficial/we-do-what-we-want", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = start + 1.;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n float s = texture2D(sound, vec2(\n mix(3./64., 5./64., uvfl.y), //pointId / NUM_POINTS_PER_CIRCLE), \n 0)).a; \n float s2 = texture2D(sound, vec2(\n mix(3.2/64., 3.2/64., pointId / NUM_POINTS_PER_CIRCLE), \n 0)).a; \n \n float tm = 0.;\n float r = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .0 + 0., sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n float rot = PI * 0.5;\n mat *= rotY(rot);\n mat *= uniformScale(mix(1.2, 3., pow(s2 * 1.2, 5.)));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * 0.1 + mix(1.2, 1.9, pow(s, 2.));//time * 0.1 + modStep(uvfl.w, 2.) * abs(sin(time * 0.13));\n float sat = pow(s, 4.); + sin(time * 0.07) * 0.3;\n float val = 1.;t5p5(abs(sin(rot)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-3xr0k4qe5qnaurcjb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QLuMqpKa5JSrpLW5B/art.json b/art/QLuMqpKa5JSrpLW5B/art.json index 9b841fa1..68e87ae7 100644 --- a/art/QLuMqpKa5JSrpLW5B/art.json +++ b/art/QLuMqpKa5JSrpLW5B/art.json @@ -11,7 +11,19 @@ "origId": "K8sAwLQqxzqjXN3FT", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-hlnr64xi78xvuofes-thumbnail.jpg", "views": { "$numberInt": "65" diff --git a/art/QNRa7fHrHnYWcZoCm/art.json b/art/QNRa7fHrHnYWcZoCm/art.json index 3003d457..fc43ed6a 100644 --- a/art/QNRa7fHrHnYWcZoCm/art.json +++ b/art/QNRa7fHrHnYWcZoCm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * .319)) * 1. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * .319)) * 1. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-oa5a4swy0aziifkdn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QNecaJ5aHf8ckGNJa/art.json b/art/QNecaJ5aHf8ckGNJa/art.json index 6f999940..165b60a5 100644 --- a/art/QNecaJ5aHf8ckGNJa/art.json +++ b/art/QNecaJ5aHf8ckGNJa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "serdar2", "avatarUrl": "https://lh3.googleusercontent.com/a/AAcHTtcr8OLY4PHhjXfZ85YOTN46nqHnfmZkTLoNu6Hn6vAL=s96-c", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/lio-mass-it-apsara-mas-frequency-original-mix-open-your-mind-music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7058823529411765,0.12941176470588237,0.023529411764705882,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 1.0, dot( vNormal, -vLight ) );\\n \\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 05.0, 5.0, -11.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.;//0.5 + over * 0.7;\\n float sat = step(0.75,s2);\\n float val = pow(s2, 16.);\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/lio-mass-it-apsara-mas-frequency-original-mix-open-your-mind-music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7058823529411765, + 0.12941176470588237, + 0.023529411764705882, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 1.0, dot( vNormal, -vLight ) );\n \n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 05.0, 5.0, -11.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.;//0.5 + over * 0.7;\n float sat = step(0.75,s2);\n float val = pow(s2, 16.);\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-yz391kh8hnmnlzhz8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QPCMC7RgjqG63yQvN/art.json b/art/QPCMC7RgjqG63yQvN/art.json index 00e8c729..69345cfe 100644 --- a/art/QPCMC7RgjqG63yQvN/art.json +++ b/art/QPCMC7RgjqG63yQvN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) \\n{\\n\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId ) / (numSections);\\n float v = sv + base;\\n \\n float off = 0.9;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = .5;//texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = 0.5;//texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n \\n track(id, numTrackPoints, base, pos, color);\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) \n{\n\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId ) / (numSections);\n float v = sv + base;\n \n float off = 0.9;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = .5;//texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = 0.5;//texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\n\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n \n track(id, numTrackPoints, base, pos, color);\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-65fke5fw03vpdz5f2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QQPfLKd8XLAt6wWQi/art.json b/art/QQPfLKd8XLAt6wWQi/art.json index c6fac39d..4732e2f3 100644 --- a/art/QQPfLKd8XLAt6wWQi/art.json +++ b/art/QQPfLKd8XLAt6wWQi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Making a Grid is due\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Making a Grid is due\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-k7av4d2f7a4hnhrvx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QQn8ttKsNBFEpfwuE/art.json b/art/QQn8ttKsNBFEpfwuE/art.json index 4124de36..17dc21f4 100644 --- a/art/QQn8ttKsNBFEpfwuE/art.json +++ b/art/QQn8ttKsNBFEpfwuE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "pawel", "avatarUrl": "https://lh5.googleusercontent.com/-9JIRL9QqVbE/AAAAAAAAAAI/AAAAAAAAAQU/EIVR4mSPtL4/photo.jpg", - "settings": "{\"num\":73798,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.50\\n ;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 9.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 73798, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.50\n ;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 9.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-0vrh7da3ec7ydx4gy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QRwggT8zdiZbYuaXv/art.json b/art/QRwggT8zdiZbYuaXv/art.json index 137420d6..b21c7de9 100644 --- a/art/QRwggT8zdiZbYuaXv/art.json +++ b/art/QRwggT8zdiZbYuaXv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"// Taking control - the moving grid\\n\\nvoid main() {\\n float scale = 2.;\\n float modi = 0.5 * (sin(time)+1.);\\n float lfo1 = (sin(time * 1.1) + 1.) / 2.;\\n float lfo2 = (cos(time * 1.5) + 1.) / 2.;\\n float grid = floor(modi * 10.) + 10.;\\n float xoff = -0.5 * scale;\\n float yoff = -0.5 * scale;\\n float x = mod(vertexId , grid);\\n float y = mod(floor(vertexId / grid), grid);\\n float ux = x * lfo1 * scale / grid + xoff * lfo2;\\n float uy = y * scale * lfo2 / grid + yoff * lfo1;\\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = 100./grid;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "// Taking control - the moving grid\n\nvoid main() {\n float scale = 2.;\n float modi = 0.5 * (sin(time)+1.);\n float lfo1 = (sin(time * 1.1) + 1.) / 2.;\n float lfo2 = (cos(time * 1.5) + 1.) / 2.;\n float grid = floor(modi * 10.) + 10.;\n float xoff = -0.5 * scale;\n float yoff = -0.5 * scale;\n float x = mod(vertexId , grid);\n float y = mod(floor(vertexId / grid), grid);\n float ux = x * lfo1 * scale / grid + xoff * lfo2;\n float uy = y * scale * lfo2 / grid + yoff * lfo1;\n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = 100./grid;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-4ckys6bh5171a27t0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QTWSXRpNKJ4KJEHur/art.json b/art/QTWSXRpNKJ4KJEHur/art.json index fdc8e5ac..27d470a5 100644 --- a/art/QTWSXRpNKJ4KJEHur/art.json +++ b/art/QTWSXRpNKJ4KJEHur/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\nvec2 project(vec2 position, vec2 a, vec2 b); \\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 4.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n \\n\\tfor(int i = 0; i < 8; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\t//b += box(p, vec2(.5));\\n\\t\\t//t += triangle(p, vec2(.5));\\n\\t\\t//p *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\t\\n\\t//gl_FragColor = result;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = result;\\n \\n\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.73205080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t*= .86602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(t);\\n\\treturn mat2(c, s, -s, c);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\nvec2 project(vec2 position, vec2 a, vec2 b); \nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 4.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n \n\tfor(int i = 0; i < 8; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\t//b += box(p, vec2(.5));\n\t\t//t += triangle(p, vec2(.5));\n\t\t//p *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\t\n\t//gl_FragColor = result;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = result;\n \n\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.73205080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t*= .86602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(t);\n\treturn mat2(c, s, -s, c);\n}\n" + }, "screenshotURL": "data/images/images-rj08thkuivijng79h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QWNj2ZspFrBLdtsJm/art.json b/art/QWNj2ZspFrBLdtsJm/art.json index f9437d5f..b3db48b9 100644 --- a/art/QWNj2ZspFrBLdtsJm/art.json +++ b/art/QWNj2ZspFrBLdtsJm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27058823529411763,0.6509803921568628,0.7294117647058823,1],\"shader\":\"void main()\\n{\\n \\n\\tvec4 color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\t/*if (sin(time) >= 0.0)\\n color = vec4(sin(time), 1.0/sin(time), 0.0, 0.0);\\n \\telse\\n color = vec4(1.0/(sin(time)*-1.0), sin(time)*-1.0, 0.0, 0.0);*/\\n \\n \\tvec4 pos = vec4(vertexId/10.0, vertexId/10.0, 0.0, 1.0);\\n \\tgl_Position = pos;\\n \\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27058823529411763, + 0.6509803921568628, + 0.7294117647058823, + 1 + ], + "shader": "void main()\n{\n \n\tvec4 color = vec4(1.0, 0.0, 0.0, 1.0);\n \t/*if (sin(time) >= 0.0)\n color = vec4(sin(time), 1.0/sin(time), 0.0, 0.0);\n \telse\n color = vec4(1.0/(sin(time)*-1.0), sin(time)*-1.0, 0.0, 0.0);*/\n \n \tvec4 pos = vec4(vertexId/10.0, vertexId/10.0, 0.0, 1.0);\n \tgl_Position = pos;\n \n}" + }, "screenshotURL": "data/images/images-9ewfpwmxi2ukbtscv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QXw5ie5QNXrscXSgX/art.json b/art/QXw5ie5QNXrscXSgX/art.json index e0cfbffb..9d7a6374 100644 --- a/art/QXw5ie5QNXrscXSgX/art.json +++ b/art/QXw5ie5QNXrscXSgX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":32027,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/jahtari_records/hail-the-robots?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + sin(t * 1.13) - sin(t * 0.273);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.;\\n float down = numQuads / around +2.1;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI *.131+r) * r;\\n float y = sin(qv * PI *.651012) * r-x;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * mix(0.01,mouse.x,-.05) * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 8.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -1.19) * 11.0 + 0.1, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(1.-mouse.y,sin(time*-2.2-cos(time*3.1666))*sin(time),11.22);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = sin(quadId *.001813333333);\\n float sat = .83;\\n float val = 1.57;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.bg = v_color.ab;\\n}\"}", + "settings": { + "num": 32027, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/jahtari_records/hail-the-robots?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + sin(t * 1.13) - sin(t * 0.273);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.;\n float down = numQuads / around +2.1;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI *.131+r) * r;\n float y = sin(qv * PI *.651012) * r-x;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * mix(0.01,mouse.x,-.05) * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 8.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -1.19) * 11.0 + 0.1, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(1.-mouse.y,sin(time*-2.2-cos(time*3.1666))*sin(time),11.22);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = sin(quadId *.001813333333);\n float sat = .83;\n float val = 1.57;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.bg = v_color.ab;\n}" + }, "screenshotURL": "data/images/images-53f2bo3xblywjqd6v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Qa2CxakRKHmYmZgdH/art.json b/art/Qa2CxakRKHmYmZgdH/art.json index 83bf3ab4..612667f4 100644 --- a/art/Qa2CxakRKHmYmZgdH/art.json +++ b/art/Qa2CxakRKHmYmZgdH/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n \\n float pointsPerSection = 1.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sv = (sectionId ) / (numSections);\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 1.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n \\n track(id, numTrackPoints, base, pos, color);\\n \\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n \n float pointsPerSection = 1.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float numSections = (vertexCount / pointsPerSection);\n \n float sv = (sectionId ) / (numSections);\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 1.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n \n track(id, numTrackPoints, base, pos, color);\n \n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-1ki9t1anw3k1htp9h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Qa3ssdh39M6HGfPqM/art.json b/art/Qa3ssdh39M6HGfPqM/art.json index 0fa82113..354c69b1 100644 --- a/art/Qa3ssdh39M6HGfPqM/art.json +++ b/art/Qa3ssdh39M6HGfPqM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 10.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n/*\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n sin(id * 0.5+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}\\n*/\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 1.),\\n sin(id * 0.5),\\n sin(id * 0.25));\\n}\\n\\n\\nconst float expand = 120.;\\nconst float off = 0.1;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \\n{\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 eye = r0 * expand + zaxis * 1.;\\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n /*_emat = mat4(\\n 1.,0.,0.,0.,\\n 0.,1.,0.,0.,\\n 0.,0.,1.,0.,\\n 0.,0.,0.,1.); \\n */\\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n \\n float sizeFactor = 1./100.;\\n\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElementPerGroup = lineNumber;\\n \\n \\n float groupId = floor(shapeId/numberOfElementPerGroup);\\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n mat4 scaleMat = scale(vec3(1.*sizeFactor,1.*sizeFactor,1.*sizeFactor));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n //create the circle group\\n float radius = 10.*sizeFactor;\\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n \\n \\n mat4 wmat;\\n mat4 emat;\\n \\n float base = 14.5; \\n base = time * 30.0;\\n vec4 color2 = vec4(1.,1.,1.,1.);\\n vec3 pos;\\n //void track(shapeId, shapeCount, base, pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \\n track(groupId, groupCount/10., base, pos, color2, wmat, emat);\\n \\n // track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi/expand;\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 50000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 10.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n/*\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n sin(id * 0.5+_time*10.),\n sin(id * 0.25+_time*10.));\n}\n*/\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 1.),\n sin(id * 0.5),\n sin(id * 0.25));\n}\n\n\nconst float expand = 120.;\nconst float off = 0.1;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \n{\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 eye = r0 * expand + zaxis * 1.;\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n /*_emat = mat4(\n 1.,0.,0.,0.,\n 0.,1.,0.,0.,\n 0.,0.,1.,0.,\n 0.,0.,0.,1.); \n */\n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n \n float sizeFactor = 1./100.;\n\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElementPerGroup = lineNumber;\n \n \n float groupId = floor(shapeId/numberOfElementPerGroup);\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n mat4 scaleMat = scale(vec3(1.*sizeFactor,1.*sizeFactor,1.*sizeFactor));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n //create the circle group\n float radius = 10.*sizeFactor;\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n \n \n mat4 wmat;\n mat4 emat;\n \n float base = 14.5; \n base = time * 30.0;\n vec4 color2 = vec4(1.,1.,1.,1.);\n vec3 pos;\n //void track(shapeId, shapeCount, base, pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \n track(groupId, groupCount/10., base, pos, color2, wmat, emat);\n \n // track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi/expand;\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-xseot4t5svrshwpw9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QcXB9sbhnSW4SxjpP/art.json b/art/QcXB9sbhnSW4SxjpP/art.json index 9f7bd886..c2f6c464 100644 --- a/art/QcXB9sbhnSW4SxjpP/art.json +++ b/art/QcXB9sbhnSW4SxjpP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/haddaway-what-is-love\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 k = vec4(1.0, 2.0/3.0, 1.0/0.3, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.1);\\n \\n float su = abs(u - 2.5) * 2.3;\\n float sv = abs(v - 4.5) * 2.5;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(av * 0.05, av * 6.5)).a;\\n \\n float ux = u * 2.7 - 1.8;\\n float vy = sin(v * snd) * 2.5 - 1.9;\\n \\n vec2 xy = vec2(ux, vy);\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(snd * 1.2 + x * y);\\n \\n gl_PointSize = pow(snd + 10.1, 1.5) * 32.3 + soff;\\n gl_PointSize *= 24.5 / across;\\n gl_PointSize *= resolution.x / 1967.8;\\n \\n float hue = sin(u * 9.1) + snd * 10.2 + time * 0.1;\\n float sat = mix(1.2, 1.3, snd);\\n float val = mix(4.5, pow(snd + 2.6, 6.7), snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/haddaway-what-is-love", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 k = vec4(1.0, 2.0/3.0, 1.0/0.3, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.1);\n \n float su = abs(u - 2.5) * 2.3;\n float sv = abs(v - 4.5) * 2.5;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(av * 0.05, av * 6.5)).a;\n \n float ux = u * 2.7 - 1.8;\n float vy = sin(v * snd) * 2.5 - 1.9;\n \n vec2 xy = vec2(ux, vy);\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(snd * 1.2 + x * y);\n \n gl_PointSize = pow(snd + 10.1, 1.5) * 32.3 + soff;\n gl_PointSize *= 24.5 / across;\n gl_PointSize *= resolution.x / 1967.8;\n \n float hue = sin(u * 9.1) + snd * 10.2 + time * 0.1;\n float sat = mix(1.2, 1.3, snd);\n float val = mix(4.5, pow(snd + 2.6, 6.7), snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-f8p70kvbtpadqb78a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QdJXEkZPWPvB4XKiy/art.json b/art/QdJXEkZPWPvB4XKiy/art.json index 6c5138aa..4bc7a239 100644 --- a/art/QdJXEkZPWPvB4XKiy/art.json +++ b/art/QdJXEkZPWPvB4XKiy/art.json @@ -27,7 +27,19 @@ "name": "pointsprite plasma", "private": false, "username": "myownclone", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n \\n c = sin(time + (cos(pos.x/2.0)*2.0+sin(pos.y/2.0)*2.0)); \\n c += sin(time + (cos(pos.x/2.0)*2.0+sin(pos.y/2.0)*2.0)) + 2.0*sin(time + (cos(pos.y/2.0)*2.0+sin(pos.x/2.0)*2.0)) ;\\n c += 3.0*sin(time + (cos(pos.x/2.0)*2.0+sin(pos.x/2.0)*2.0));\\n c += 4.0*sin(time + (cos(pos.y/2.0)*2.0+sin(pos.y/2.0)*2.0));\\n \\n c *= 2.0;\\n \\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 10.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n \n c = sin(time + (cos(pos.x/2.0)*2.0+sin(pos.y/2.0)*2.0)); \n c += sin(time + (cos(pos.x/2.0)*2.0+sin(pos.y/2.0)*2.0)) + 2.0*sin(time + (cos(pos.y/2.0)*2.0+sin(pos.x/2.0)*2.0)) ;\n c += 3.0*sin(time + (cos(pos.x/2.0)*2.0+sin(pos.x/2.0)*2.0));\n c += 4.0*sin(time + (cos(pos.y/2.0)*2.0+sin(pos.y/2.0)*2.0));\n \n c *= 2.0;\n \n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 10.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-vsljci00g2v5q6ewp-thumbnail.jpg", "views": { "$numberInt": "113" diff --git a/art/Qdhn9CoweLkKbkKLT/art.json b/art/Qdhn9CoweLkKbkKLT/art.json index 49e4a697..5232d70e 100644 --- a/art/Qdhn9CoweLkKbkKLT/art.json +++ b/art/Qdhn9CoweLkKbkKLT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":15,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// vertexId is provided by this site.\\n// it goes from 0 to vertexCount - 1\\n//\\n// vertexCount is provided vby this site and is set above with the silder\\n// it is also the value passed to `gl.drawArrays(primitive, offset, vertexCount);\\n// \\n// v_color is provided by this site. It is the output color the fragment shader will\\n// use to set the color\\n\\nvoid main() {\\n float u = vertexId / (vertexCount - 1.0); // get a value that goes from 0 ot 1\\n float x = u * 2.0 - 1.0; // convert to a value that goes from -1 to 1\\n gl_Position = vec4(x, 0, 0, 1);\\n gl_PointSize = vertexId * 5.;\\n v_color = vec4(1);\\n}\"}", + "settings": { + "num": 15, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// vertexId is provided by this site.\n// it goes from 0 to vertexCount - 1\n//\n// vertexCount is provided vby this site and is set above with the silder\n// it is also the value passed to `gl.drawArrays(primitive, offset, vertexCount);\n// \n// v_color is provided by this site. It is the output color the fragment shader will\n// use to set the color\n\nvoid main() {\n float u = vertexId / (vertexCount - 1.0); // get a value that goes from 0 ot 1\n float x = u * 2.0 - 1.0; // convert to a value that goes from -1 to 1\n gl_Position = vec4(x, 0, 0, 1);\n gl_PointSize = vertexId * 5.;\n v_color = vec4(1);\n}" + }, "screenshotURL": "data/images/images-p6zvbuv1ese4oyupo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QfDybr9wdsTip3KZ5/art.json b/art/QfDybr9wdsTip3KZ5/art.json index 582a3295..706ffb22 100644 --- a/art/QfDybr9wdsTip3KZ5/art.json +++ b/art/QfDybr9wdsTip3KZ5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 500.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(0, vertexId * aspect.x / 500. - 1., 0, 1);\\n \\n vec4 color = vec4(0.5, 0.25, 0.5, 1);\\n vec4 highlight = vec4(1, 1, 1, 0.5);\\n float length_of_sword = 1000.; // in vertices\\n float time_speed = 2000.; // arbitrary\\n highlight *= mod(vertexId - time * time_speed, length_of_sword) / length_of_sword;\\n v_color = color + highlight;\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 500.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(0, vertexId * aspect.x / 500. - 1., 0, 1);\n \n vec4 color = vec4(0.5, 0.25, 0.5, 1);\n vec4 highlight = vec4(1, 1, 1, 0.5);\n float length_of_sword = 1000.; // in vertices\n float time_speed = 2000.; // arbitrary\n highlight *= mod(vertexId - time * time_speed, length_of_sword) / length_of_sword;\n v_color = color + highlight;\n}" + }, "screenshotURL": "data/images/images-grefl15glfvp2hiux-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QfRkDTHRvsH4cztQA/art.json b/art/QfRkDTHRvsH4cztQA/art.json index db36f733..6b4cdadd 100644 --- a/art/QfRkDTHRvsH4cztQA/art.json +++ b/art/QfRkDTHRvsH4cztQA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "タケシ", "avatarUrl": "https://lh3.googleusercontent.com/-DscYffOX92k/AAAAAAAAAAI/AAAAAAAAABA/PNB3e9i2cJM/photo.jpg", - "settings": "{\"num\":13070,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/anime-song-s-3/re-zero-kara-hajimeru-isekai-seikatsu-ending-full\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 rotate(vec3 p, float angle, vec3 axis){\\n vec3 a = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float r = 1.0 - c;\\n mat3 m = mat3(\\n a.x * a.x * r + c,\\n a.y * a.x * r + a.z * s,\\n a.z * a.x * r - a.y * s,\\n a.x * a.y * r - a.z * s,\\n a.y * a.y * r + c,\\n a.z * a.y * r + a.x * s,\\n a.x * a.z * r + a.y * s,\\n a.y * a.z * r - a.x * s,\\n a.z * a.z * r + c\\n );\\n return m * p;\\n}\\n\\nvec3 Hue( float hue )\\n{\\n\\tvec3 rgb = fract(hue + vec3(0.0,2.0/3.0,1.0/3.0));\\n\\n\\trgb = abs(rgb*2.0-1.0);\\n\\t\\t\\n\\treturn clamp(rgb*3.0-1.0,0.0,1.0);\\n}\\n\\nvec3 HSVtoRGB( vec3 hsv )\\n{\\n\\treturn ((Hue(hsv.x)-1.0)*hsv.y+1.0) * hsv.z;\\n}\\nvoid main() {\\n float sq=floor(sqrt(vertexCount));\\n // float sq=floor(pow(vertexCount,0.5));\\n float bunnkatu=floor(vertexCount/sq);\\n \\n \\n \\n \\n float x=mod(vertexId,bunnkatu);\\n float y=floor(vertexId/bunnkatu);\\n float z=floor(y/bunnkatu);\\n float u=x/(bunnkatu-1.);\\n float v=y/(bunnkatu-1.);\\n float s=z/(bunnkatu-1.);\\n \\n float stx=abs(u-0.5)*2.;\\n float sty=abs(v-0.5)*2.;\\n float ax=(atan(stx,sty))/5.14;\\n float ay=length(vec2(stx,sty));\\n float sound=texture2D(sound,vec2(ax*0.035,ay*0.25)).a; \\n float soundz=2.*sound;\\n \\n u=4.*u-2.;\\n v=4.*v-2.;\\n \\n //u+=0.05*sin((time*1.+v)*3.);\\n // v+=0.1*sin((time*1.+u)*3.);\\n vec3 rpos=rotate(vec3(u,v,2.*soundz-3.5-0.5*sin(ay)), 1.5*time, vec3(1,1,1));\\n\\n // vec3 rpos=rotate(vec3(u,v,-0.5*soundz-0.5*cos(ay*3.14)), 0.5*time, vec3(1,1,1));\\n gl_Position=vec4(rpos.x,rpos.y,rpos.z,1.);\\n // gl_Position=vec4(u+0.1*sin(sound*6.28),v+0.1*cos(sound*6.28),0,1.);\\n float ani=(sin((u+time*2.)*8.)+1.)*5.;\\n gl_PointSize=1.*pow(sound+0.2,12.)+0.2-rpos.z*2.;//-ani;\\n // gl_PointSize=15.;//-ani;\\n // gl_PointSize=gl_PointSize/resolution.x*600.;\\n \\n // v_color = vec4(ani/5.,1.0,1.0,1.0);\\n //v_color = vec4(sound,ax,ay,1.0);\\n v_color = vec4(HSVtoRGB(vec3(pow(sound,4.9)*1.1,pow(1.-rpos.z,1.),pow(1.-rpos.z,1.))),1.0);\\n /*\\n float a=vertexId/10.;\\n float b=mod(vertexId,10.)/3.;\\n gl_Position=vec4(sin(a+time),cos(a+2.5*time)+b*cos(time),0.,1);\\n gl_PointSize=40.0*(1.5+sin(a+time*5.));\\n \\n v_color = vec4(1.0,sin(a+time),sin(a+time*0.5),1.0);\\n*/\\n}\"}", + "settings": { + "num": 13070, + "mode": "POINTS", + "sound": "https://soundcloud.com/anime-song-s-3/re-zero-kara-hajimeru-isekai-seikatsu-ending-full", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 rotate(vec3 p, float angle, vec3 axis){\n vec3 a = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float r = 1.0 - c;\n mat3 m = mat3(\n a.x * a.x * r + c,\n a.y * a.x * r + a.z * s,\n a.z * a.x * r - a.y * s,\n a.x * a.y * r - a.z * s,\n a.y * a.y * r + c,\n a.z * a.y * r + a.x * s,\n a.x * a.z * r + a.y * s,\n a.y * a.z * r - a.x * s,\n a.z * a.z * r + c\n );\n return m * p;\n}\n\nvec3 Hue( float hue )\n{\n\tvec3 rgb = fract(hue + vec3(0.0,2.0/3.0,1.0/3.0));\n\n\trgb = abs(rgb*2.0-1.0);\n\t\t\n\treturn clamp(rgb*3.0-1.0,0.0,1.0);\n}\n\nvec3 HSVtoRGB( vec3 hsv )\n{\n\treturn ((Hue(hsv.x)-1.0)*hsv.y+1.0) * hsv.z;\n}\nvoid main() {\n float sq=floor(sqrt(vertexCount));\n // float sq=floor(pow(vertexCount,0.5));\n float bunnkatu=floor(vertexCount/sq);\n \n \n \n \n float x=mod(vertexId,bunnkatu);\n float y=floor(vertexId/bunnkatu);\n float z=floor(y/bunnkatu);\n float u=x/(bunnkatu-1.);\n float v=y/(bunnkatu-1.);\n float s=z/(bunnkatu-1.);\n \n float stx=abs(u-0.5)*2.;\n float sty=abs(v-0.5)*2.;\n float ax=(atan(stx,sty))/5.14;\n float ay=length(vec2(stx,sty));\n float sound=texture2D(sound,vec2(ax*0.035,ay*0.25)).a; \n float soundz=2.*sound;\n \n u=4.*u-2.;\n v=4.*v-2.;\n \n //u+=0.05*sin((time*1.+v)*3.);\n // v+=0.1*sin((time*1.+u)*3.);\n vec3 rpos=rotate(vec3(u,v,2.*soundz-3.5-0.5*sin(ay)), 1.5*time, vec3(1,1,1));\n\n // vec3 rpos=rotate(vec3(u,v,-0.5*soundz-0.5*cos(ay*3.14)), 0.5*time, vec3(1,1,1));\n gl_Position=vec4(rpos.x,rpos.y,rpos.z,1.);\n // gl_Position=vec4(u+0.1*sin(sound*6.28),v+0.1*cos(sound*6.28),0,1.);\n float ani=(sin((u+time*2.)*8.)+1.)*5.;\n gl_PointSize=1.*pow(sound+0.2,12.)+0.2-rpos.z*2.;//-ani;\n // gl_PointSize=15.;//-ani;\n // gl_PointSize=gl_PointSize/resolution.x*600.;\n \n // v_color = vec4(ani/5.,1.0,1.0,1.0);\n //v_color = vec4(sound,ax,ay,1.0);\n v_color = vec4(HSVtoRGB(vec3(pow(sound,4.9)*1.1,pow(1.-rpos.z,1.),pow(1.-rpos.z,1.))),1.0);\n /*\n float a=vertexId/10.;\n float b=mod(vertexId,10.)/3.;\n gl_Position=vec4(sin(a+time),cos(a+2.5*time)+b*cos(time),0.,1);\n gl_PointSize=40.0*(1.5+sin(a+time*5.));\n \n v_color = vec4(1.0,sin(a+time),sin(a+time*0.5),1.0);\n*/\n}" + }, "screenshotURL": "data/images/images-rrhvieu7hc7gngx00-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Qg6cjjRRKxsXEEGYB/art.json b/art/Qg6cjjRRKxsXEEGYB/art.json index 4d5862f9..466eae38 100644 --- a/art/Qg6cjjRRKxsXEEGYB/art.json +++ b/art/Qg6cjjRRKxsXEEGYB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27058823529411763,0.23921568627450981,0.6823529411764706,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Motion\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y);\\n float yoff = sin(time + x);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * abs(sin(time))*0.7;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float amount = 5.0;\\n float soff = sin(time + x * y * 0.02) * amount;\\t//-5~5\\n \\n gl_PointSize = 7.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n // map to 0~1\\n soff += amount;\\n soff /= amount*2.0;\\n \\n // small = ash , big = flame\\n v_color = vec4(soff,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27058823529411763, + 0.23921568627450981, + 0.6823529411764706, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Motion\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y);\n float yoff = sin(time + x);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * abs(sin(time))*0.7;\n \n gl_Position = vec4(xy,0,1);\n \n float amount = 5.0;\n float soff = sin(time + x * y * 0.02) * amount;\t//-5~5\n \n gl_PointSize = 7.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n // map to 0~1\n soff += amount;\n soff /= amount*2.0;\n \n // small = ash , big = flame\n v_color = vec4(soff,0,0,1);\n}" + }, "screenshotURL": "data/images/images-nbtnh2r36pizeae24-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QgXakG4wfDMZ4Au6n/art.json b/art/QgXakG4wfDMZ4Au6n/art.json index d8443a51..dc68c54c 100644 --- a/art/QgXakG4wfDMZ4Au6n/art.json +++ b/art/QgXakG4wfDMZ4Au6n/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "r21nomi", "avatarUrl": "https://avatars.githubusercontent.com/r21nomi?s=200", - "settings": "{\"num\":16314,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/meiden/meiden-im-hereeeeeee\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"float CUBE_SIZE = 0.08;\\n\\nfloat map(float value, float beforeMin, float beforeMax, float afterMin, float afterMax) {\\n\\treturn afterMin + (afterMax - afterMin) * ((value - beforeMin) / (beforeMax - beforeMin));\\n}\\n\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 saturate(vec3 x) {\\n\\treturn clamp(x, 0.0, 1.0);\\n}\\n\\nvec3 hue2rgb(float h) {\\n h = fract(h) * 6.0 - 2.0;\\n return saturate(vec3(abs(h - 1.0) - 1.0, 2.0 - abs(h), 2.0 - abs(h - 2.0)));\\n}\\n\\nmat3 rotateX(float rad) {\\n float c = cos(rad);\\n float s = sin(rad);\\n return mat3(\\n 1.0, 0.0, 0.0,\\n 0.0, c, s,\\n 0.0, -s, c\\n );\\n}\\n\\nmat3 rotateY(float rad) {\\n float c = cos(rad);\\n float s = sin(rad);\\n return mat3(\\n c, 0.0, -s,\\n 0.0, 1.0, 0.0,\\n s, 0.0, c\\n );\\n}\\n\\nfloat rotr3(float x, float n) {\\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.0);\\n}\\n\\nfloat VERTEX_COUNT_FOR_SURFACE = 6.0;\\nfloat SURFACE_COUNT_FOR_CUBE = 6.0;\\nfloat VERTEX_COUNT_FOR_CUBE = VERTEX_COUNT_FOR_SURFACE * SURFACE_COUNT_FOR_CUBE;\\n\\nvec3 cube(in float id) {\\n float faceId = mod(floor(id / VERTEX_COUNT_FOR_SURFACE), SURFACE_COUNT_FOR_CUBE);\\n float faceDiv3 = floor(faceId / 3.0);\\n float faceMod3 = mod(faceId, 3.0);\\n float quadId = mod(id, VERTEX_COUNT_FOR_SURFACE);\\n float baseId = faceId * SURFACE_COUNT_FOR_CUBE;\\n float newVertId = abs(faceDiv3 == 0.0 ? quadId - 2.0 : 3.0 - quadId);\\n \\n \\tfloat x = rotr3(newVertId + faceDiv3 * 4.0, faceMod3);\\n \\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n vec3 cubePosition = cube(vertexId);\\n float cubeId = floor(vertexId / VERTEX_COUNT_FOR_CUBE);\\n float faceId = mod(floor(vertexId / VERTEX_COUNT_FOR_SURFACE), SURFACE_COUNT_FOR_CUBE);\\n \\n \\tfloat scaleOffset = mod(cubeId, 5.0);\\n \\tfloat snd = texture2D(sound, vec2(mix(0.1, 0.5, hash(scaleOffset)), hash(scaleOffset) / 5.0)).x;\\n \\tfloat scaleBySound = 0.2 * mix(0.0, 4.0, pow(snd, 5.0));\\n \\n cubePosition -= 0.5; // Fix center for cube.\\n cubePosition *= scaleBySound * map(sin(time * 10.0 * fract(cubeId * 0.9)), -1.0, 1.0, 0.5, 1.0);\\n \\n \\tcubePosition.x += sin(cubeId) * 0.5;\\n \\tcubePosition.z += cos(cubeId) * 0.5;\\n \\n // Rotate first not to make rotation for whole boxes.\\n mat3 rotX = rotateX(time);\\n mat3 rotY = rotateY(time);\\n cubePosition *= rotX * rotY;\\n \\n // Layout\\n \\tfloat cubeCount = 20.0;\\n float gridX = (fract(cubeId / cubeCount) - 0.5) * 1.5;\\n float gridY = floor(cubeId / cubeCount) * 0.1 - 1.0;\\n \\n cubePosition.x += gridX;\\n cubePosition.y += gridY;\\n gl_Position = vec4(cubePosition, 1.0);\\n \\n \\tvec3 color = vec3(faceId / SURFACE_COUNT_FOR_CUBE);\\n \\tcolor += fract(cubeId / 6.0);\\n \\n\\tfloat pump = step(0.3, snd);\\n \\tcolor *= hue2rgb(cubeId * 0.5) * pump;\\n \\tv_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 16314, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/meiden/meiden-im-hereeeeeee", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "float CUBE_SIZE = 0.08;\n\nfloat map(float value, float beforeMin, float beforeMax, float afterMin, float afterMax) {\n\treturn afterMin + (afterMax - afterMin) * ((value - beforeMin) / (beforeMax - beforeMin));\n}\n\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 saturate(vec3 x) {\n\treturn clamp(x, 0.0, 1.0);\n}\n\nvec3 hue2rgb(float h) {\n h = fract(h) * 6.0 - 2.0;\n return saturate(vec3(abs(h - 1.0) - 1.0, 2.0 - abs(h), 2.0 - abs(h - 2.0)));\n}\n\nmat3 rotateX(float rad) {\n float c = cos(rad);\n float s = sin(rad);\n return mat3(\n 1.0, 0.0, 0.0,\n 0.0, c, s,\n 0.0, -s, c\n );\n}\n\nmat3 rotateY(float rad) {\n float c = cos(rad);\n float s = sin(rad);\n return mat3(\n c, 0.0, -s,\n 0.0, 1.0, 0.0,\n s, 0.0, c\n );\n}\n\nfloat rotr3(float x, float n) {\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.0);\n}\n\nfloat VERTEX_COUNT_FOR_SURFACE = 6.0;\nfloat SURFACE_COUNT_FOR_CUBE = 6.0;\nfloat VERTEX_COUNT_FOR_CUBE = VERTEX_COUNT_FOR_SURFACE * SURFACE_COUNT_FOR_CUBE;\n\nvec3 cube(in float id) {\n float faceId = mod(floor(id / VERTEX_COUNT_FOR_SURFACE), SURFACE_COUNT_FOR_CUBE);\n float faceDiv3 = floor(faceId / 3.0);\n float faceMod3 = mod(faceId, 3.0);\n float quadId = mod(id, VERTEX_COUNT_FOR_SURFACE);\n float baseId = faceId * SURFACE_COUNT_FOR_CUBE;\n float newVertId = abs(faceDiv3 == 0.0 ? quadId - 2.0 : 3.0 - quadId);\n \n \tfloat x = rotr3(newVertId + faceDiv3 * 4.0, faceMod3);\n \n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n vec3 cubePosition = cube(vertexId);\n float cubeId = floor(vertexId / VERTEX_COUNT_FOR_CUBE);\n float faceId = mod(floor(vertexId / VERTEX_COUNT_FOR_SURFACE), SURFACE_COUNT_FOR_CUBE);\n \n \tfloat scaleOffset = mod(cubeId, 5.0);\n \tfloat snd = texture2D(sound, vec2(mix(0.1, 0.5, hash(scaleOffset)), hash(scaleOffset) / 5.0)).x;\n \tfloat scaleBySound = 0.2 * mix(0.0, 4.0, pow(snd, 5.0));\n \n cubePosition -= 0.5; // Fix center for cube.\n cubePosition *= scaleBySound * map(sin(time * 10.0 * fract(cubeId * 0.9)), -1.0, 1.0, 0.5, 1.0);\n \n \tcubePosition.x += sin(cubeId) * 0.5;\n \tcubePosition.z += cos(cubeId) * 0.5;\n \n // Rotate first not to make rotation for whole boxes.\n mat3 rotX = rotateX(time);\n mat3 rotY = rotateY(time);\n cubePosition *= rotX * rotY;\n \n // Layout\n \tfloat cubeCount = 20.0;\n float gridX = (fract(cubeId / cubeCount) - 0.5) * 1.5;\n float gridY = floor(cubeId / cubeCount) * 0.1 - 1.0;\n \n cubePosition.x += gridX;\n cubePosition.y += gridY;\n gl_Position = vec4(cubePosition, 1.0);\n \n \tvec3 color = vec3(faceId / SURFACE_COUNT_FOR_CUBE);\n \tcolor += fract(cubeId / 6.0);\n \n\tfloat pump = step(0.3, snd);\n \tcolor *= hue2rgb(cubeId * 0.5) * pump;\n \tv_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-tqvf2059n0axfkngr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Qh7WiD2iwnCrdfCXy/art.json b/art/Qh7WiD2iwnCrdfCXy/art.json index adc356aa..d821d06d 100644 --- a/art/Qh7WiD2iwnCrdfCXy/art.json +++ b/art/Qh7WiD2iwnCrdfCXy/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define circular 1\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 CircleVPos(float vId, float segmentsPerCircle) {\\n float bx = mod(vId, 2.) + floor(vId / 6.);\\n float by = mod(floor(vId / 2.) + floor(vId / 3.), 2.); // 0 0 1, 0 1 1, 1 1 0, 1 0 0, ...\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n return vec2(cos(angle), sin(angle)) * by;\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 24.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n vec2 nCircleVertexPos = CircleVPos(vertexId, segmentsPerCircle);\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 30.;\\n vec2 gridSize = vec2(circlesPerRow, floor(circleCount / circlesPerRow));\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n vec2 modelPos = vec2(mod(circleId, circlesPerRow), floor(circleId / circlesPerRow));\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n#if circular\\n vec2 sndUv = modelPos;\\n sndUv.x -= gridSize.x * 0.5;\\n float theta = atan(abs(sndUv.x)/sndUv.y) / (PI*0.5); // theta goes from 0 to 1, radialy, from the middle vertical to the bottom horizontal\\n theta *= 0.66; // 1/3rd of the sound texture is unused.\\n theta *= 0.75; // arbitrarily trimming to find a good section of the sound tex.\\n theta += 1./480.;\\n soundTexCoords.x = theta;\\n float maxLen = length(vec2(gridSize.x*0.5, gridSize.y));\\n soundTexCoords.y = length(sndUv)*0.05 / maxLen;\\n#else\\n float sx = modelPos.x - circlesPerRow * 0.5 - mod(circlesPerRow, 2.0) * 0.5;\\n soundTexCoords.x = abs(sx) / (abs(sx) + modelPos.y) * 0.215;\\n soundTexCoords.y = ((abs(sx) + modelPos.y) - 1.) / (circlesPerRow + gridSize.y) * 0.1;\\n#endif\\n \\n float s = texture2D(sound, soundTexCoords).a;\\n soundTexCoords.y -= 1./240.;\\n float s1 = texture2D(sound, soundTexCoords).a+0.5;\\n //s1 = clamp(s1, 0., 1.);\\n //s *= s1;\\n s *= 0.75+soundTexCoords.x*1.25; // enhance strength of high-end values\\n s = smoothstep(0.2, 0.8, s);\\n s = pow(s, 4.); // enhance enhance enhance\\n vec2 circleVertexPos = nCircleVertexPos * s;\\n \\n float viewDist = -10.; // pretty much just used to approximate \\\"viewing at a distance\\\" in lieu of an actual perspective matrix.\\n vec2 viewPos = vec2(-gridSize*0.5);\\n \\n gl_Position = vec4((modelPos + circleVertexPos + viewPos)/-viewDist, -s / 2., 1);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n //v_color = vec4(theta, 0.0, 0.0, 1.0);\\n v_color = vec4(s * 2. - 0.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define circular 1\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 CircleVPos(float vId, float segmentsPerCircle) {\n float bx = mod(vId, 2.) + floor(vId / 6.);\n float by = mod(floor(vId / 2.) + floor(vId / 3.), 2.); // 0 0 1, 0 1 1, 1 1 0, 1 0 0, ...\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n return vec2(cos(angle), sin(angle)) * by;\n}\n\nvoid main() {\n float segmentsPerCircle = 24.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n vec2 nCircleVertexPos = CircleVPos(vertexId, segmentsPerCircle);\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 30.;\n vec2 gridSize = vec2(circlesPerRow, floor(circleCount / circlesPerRow));\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n vec2 modelPos = vec2(mod(circleId, circlesPerRow), floor(circleId / circlesPerRow));\n \n vec2 soundTexCoords = vec2(0, 0);\n#if circular\n vec2 sndUv = modelPos;\n sndUv.x -= gridSize.x * 0.5;\n float theta = atan(abs(sndUv.x)/sndUv.y) / (PI*0.5); // theta goes from 0 to 1, radialy, from the middle vertical to the bottom horizontal\n theta *= 0.66; // 1/3rd of the sound texture is unused.\n theta *= 0.75; // arbitrarily trimming to find a good section of the sound tex.\n theta += 1./480.;\n soundTexCoords.x = theta;\n float maxLen = length(vec2(gridSize.x*0.5, gridSize.y));\n soundTexCoords.y = length(sndUv)*0.05 / maxLen;\n#else\n float sx = modelPos.x - circlesPerRow * 0.5 - mod(circlesPerRow, 2.0) * 0.5;\n soundTexCoords.x = abs(sx) / (abs(sx) + modelPos.y) * 0.215;\n soundTexCoords.y = ((abs(sx) + modelPos.y) - 1.) / (circlesPerRow + gridSize.y) * 0.1;\n#endif\n \n float s = texture2D(sound, soundTexCoords).a;\n soundTexCoords.y -= 1./240.;\n float s1 = texture2D(sound, soundTexCoords).a+0.5;\n //s1 = clamp(s1, 0., 1.);\n //s *= s1;\n s *= 0.75+soundTexCoords.x*1.25; // enhance strength of high-end values\n s = smoothstep(0.2, 0.8, s);\n s = pow(s, 4.); // enhance enhance enhance\n vec2 circleVertexPos = nCircleVertexPos * s;\n \n float viewDist = -10.; // pretty much just used to approximate \"viewing at a distance\" in lieu of an actual perspective matrix.\n vec2 viewPos = vec2(-gridSize*0.5);\n \n gl_Position = vec4((modelPos + circleVertexPos + viewPos)/-viewDist, -s / 2., 1);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n //v_color = vec4(theta, 0.0, 0.0, 1.0);\n v_color = vec4(s * 2. - 0.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-egaao5daktn03ms2q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Qi72eGRatu7XNwXS3/art.json b/art/Qi72eGRatu7XNwXS3/art.json index 15e5d39b..8d297716 100644 --- a/art/Qi72eGRatu7XNwXS3/art.json +++ b/art/Qi72eGRatu7XNwXS3/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":108,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Making a Grid\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 25.0;//*abs(sin(time));\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 1900.0;\\n \\n float gradiant_sin= sin(time*0.5)+1.0*0.5;\\n float gradiant_cos= cos(time*0.5)+1.0*0.5;\\n \\n v_color = vec4(mix(vec3(gradiant_cos,0.,gradiant_sin),vec3(gradiant_sin,0.,gradiant_cos),vec3(smoothstep( -1.0, 1.0, ux))),1.0);\\n}\"}", + "settings": { + "num": 108, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Making a Grid\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 25.0;//*abs(sin(time));\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 1900.0;\n \n float gradiant_sin= sin(time*0.5)+1.0*0.5;\n float gradiant_cos= cos(time*0.5)+1.0*0.5;\n \n v_color = vec4(mix(vec3(gradiant_cos,0.,gradiant_sin),vec3(gradiant_sin,0.,gradiant_cos),vec3(smoothstep( -1.0, 1.0, ux))),1.0);\n}" + }, "screenshotURL": "data/images/images-qoansppiynpahobjl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Qkrc49g3Qm8mZHg9J/art.json b/art/Qkrc49g3Qm8mZHg9J/art.json index d38c47dc..d4bd4cff 100644 --- a/art/Qkrc49g3Qm8mZHg9J/art.json +++ b/art/Qkrc49g3Qm8mZHg9J/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : Making a Grid\\n//course name : CS250\\n//term : Spring 2023\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : Making a Grid\n//course name : CS250\n//term : Spring 2023\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-aht5cu3sqrn68oy0p-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/QmSnBFirC9qwWGrrA/art.json b/art/QmSnBFirC9qwWGrrA/art.json index eef5087b..0c175a0e 100644 --- a/art/QmSnBFirC9qwWGrrA/art.json +++ b/art/QmSnBFirC9qwWGrrA/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "w.e._aa", - "settings": "{\"num\":256,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/w-e-aa/jnzohozssxuk\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9529411764705882,0.9529411764705882,0.9529411764705882,1],\"shader\":\"/*\\n\\n _ _ _ _ \\n ( ) ( ) ( ) ( ) \\n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \\n( V )( o_)( _)( _)( o_)\\\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\\n \\\\_/ \\\\( /_\\\\ /_\\\\ \\\\( /_^_\\\\/__)/_\\\\||/_^_\\\\\\\\___\\\\ \\\\( /_\\\\ /_^_\\\\/_\\\\ /_\\\\ \\n \\n\\n\\n\\n*/\\n\\n\\n\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\\n \\n \\n \\n \\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = hash(u) * 0.25 + 0.1;\\n // Match each line to a specific row in the sound texture\\n float historyV = v * 0.004;\\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\\n vec2 off = vec2(\\n cos(snd1 * PI * 8.),\\n sin(snd2 * PI * 6.4));\\n\\n vec2 xy = vec2(\\n m1p1(hash(time + vertexId)),\\n m1p1(hash(time + vertexId + 1.)));\\n// snd1 * 2. - 1.,\\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\\n\\n float hue = u;\\n float sat = 0.;\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 256, + "mode": "LINES", + "sound": "https://soundcloud.com/w-e-aa/jnzohozssxuk", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9529411764705882, + 0.9529411764705882, + 0.9529411764705882, + 1 + ], + "shader": "/*\n\n _ _ _ _ \n ( ) ( ) ( ) ( ) \n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \n( V )( o_)( _)( _)( o_)\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\n \\_/ \\( /_\\ /_\\ \\( /_^_\\/__)/_\\||/_^_\\\\___\\ \\( /_\\ /_^_\\/_\\ /_\\ \n \n\n\n\n*/\n\n\n\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\n \n \n \n \n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = hash(u) * 0.25 + 0.1;\n // Match each line to a specific row in the sound texture\n float historyV = v * 0.004;\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\n vec2 off = vec2(\n cos(snd1 * PI * 8.),\n sin(snd2 * PI * 6.4));\n\n vec2 xy = vec2(\n m1p1(hash(time + vertexId)),\n m1p1(hash(time + vertexId + 1.)));\n// snd1 * 2. - 1.,\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\n\n float hue = u;\n float sat = 0.;\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-572wwms5umrderpqp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QmjXyegEDvGDmMNkK/art.json b/art/QmjXyegEDvGDmMNkK/art.json index a6ff3659..87bb288e 100644 --- a/art/QmjXyegEDvGDmMNkK/art.json +++ b/art/QmjXyegEDvGDmMNkK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":88425,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n#define kp1 8.//KParameter 0.>>10.\\n#define kp2 1.//KParameter 0.>>5.\\n#define kp3 3.5//KParameter -4.>>22.\\n//KVertices_Number=#define kp2 3.//KParameter 0.>>5.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0.2/sin(kp1*snd),\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\\n\\treturn fract(p2.x * p2.y * 95.4337)*12.;\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5)*v; \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.3);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n float vertexCount = 1666. *kp1;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * 2.);\\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1.1, 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.65 + 0.5), pow(snd, 3.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 88425, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n#define kp1 8.//KParameter 0.>>10.\n#define kp2 1.//KParameter 0.>>5.\n#define kp3 3.5//KParameter -4.>>22.\n//KVertices_Number=#define kp2 3.//KParameter 0.>>5.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 3., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0.2/sin(kp1*snd),\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\n\treturn fract(p2.x * p2.y * 95.4337)*12.;\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5)*v; \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.3);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n float vertexCount = 1666. *kp1;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * 2.);\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1.1, 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.65 + 0.5), pow(snd, 3.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-5xupasfx1bc1rd9xh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QsjAsodRs56HTtASm/art.json b/art/QsjAsodRs56HTtASm/art.json index 0492f394..96c4aec3 100644 --- a/art/QsjAsodRs56HTtASm/art.json +++ b/art/QsjAsodRs56HTtASm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "paul-jan", "avatarUrl": "https://secure.gravatar.com/avatar/40d0673cb04e3c59ed5f9086f215bb8d?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Based on https://www.shadertoy.com/view/llsXRX\\n\\n\\n// number of samples (for blurring)\\n#define NS 2\\n\\n\\n\\n//------------ primitives ------------\\n\\n\\nfloat sdCapsule( vec3 p, vec3 a, vec3 b, float r )\\n{\\n\\tvec3 pa = p-a, ba = b-a;\\n\\tfloat h = clamp( dot(pa,ba)/dot(ba,ba), 0.0, 1.0 );\\n\\treturn length( pa - ba*h ) - r;\\n}\\n\\nfloat sdSphere( in vec3 p, in vec4 s )\\n{\\n return length(p-s.xyz) - s.w;\\n}\\n\\nfloat sdEllipsoid( in vec3 p, in vec3 c, in vec3 r )\\n{\\n return (length( (p-c)/r ) - 1.0) * min(min(r.x,r.y),r.z);\\n}\\n\\nfloat udRoundBox( vec3 p, vec3 b, float r )\\n{\\n return length(max(abs(p)-b,0.0))-r;\\n}\\n\\n//------------ operators ------------\\n\\nfloat smin( float a, float b, float k )\\n{\\n\\tfloat h = clamp( 0.5 + 0.5*(b-a)/k, 0.0, 1.0 );\\n\\treturn mix( b, a, h ) - k*h*(1.0-h);\\n}\\n\\nfloat smax( float a, float b, float k )\\n{\\n\\tfloat h = clamp( 0.5 + 0.5*(b-a)/k, 0.0, 1.0 );\\n\\treturn mix( a, b, h ) + k*h*(1.0-h);\\n}\\n\\nvec2 minx( in vec2 a, in vec2 b )\\n{\\n return (a.xmaxdist ) break;\\n \\n t += h.x;//*0.5;\\n }\\n\\treturn res;\\n}\\n\\n//----------------------------------------------------------------------------------\\nvec2 mapTerrain( vec3 p )\\n{\\n float h = -2.5;\\n h -= 1.5*sin( 5.0 + 0.2*p.z);\\n h += 1.5*sin( 0.0 - 0.05*p.x - 0.05*p.z);\\n float g = h;\\n if( (p.y-h)<0.2 )\\n // h += 0.1*(texture2D( iChannel0, 0.1*p.xz ).x);\\n\\n float d1 = 0.2*(p.y-h);\\n \\n // TODO, PJ: WTF ?\\n // vec2 res = vec2( d1, 1.0 );\\n vec2 res = vec2( 1.0, 1.0);\\n \\n#if 1 \\n if( -p.z>11.0 )\\n {\\n float ss = 4.0;\\n vec3 q = p;\\n vec2 id = floor( (q.xz+0.5*ss)/ss );\\n q.xz = mod( q.xz+0.5*ss, ss ) - 0.5*ss;\\n \\n\\n float r1 = hash(121.11*id.x+id.y*117.4);\\n float r2 = hash( 71.72*id.x+id.y* 61.9);\\n float r3 = hash( 31.74*id.x+id.y*317.1);\\n mat4 rm = matRotate( vec3(1.0*r1,313.13*r2,0.2) );\\n \\n vec3 r = (rm*vec4(q,0.0)).xyz;\\n r.y -= g + 0.25;\\n \\n float d2 = 0.8*udRoundBox( r, vec3(2.,0.01+0.2*r3,0.1+0.5*r3), 0.002 );\\n // TODO, PJ: WTF?\\n // res.x = min( d1, d2 );\\n res.x = 2.0;\\n }\\n#endif\\n \\n return res;\\n}\\n\\nvec2 mapTerrainH( vec3 p )\\n{\\n float h = -2.5;\\n h -= 1.5*sin( 5.0 + 0.2*p.z);\\n h += 1.5*sin( 0.0 - 0.05*p.x - 0.05*p.z);\\n float g = h;\\n // TODO, PJ: Find a smart alternative\\n // h += 0.1*(texture2D( iChannel0, 0.1*p.xz ).x);\\n\\n float d1 = 0.2*(p.y-h);\\n \\n vec2 res = vec2( d1, 1.0 );\\n \\n#if 1 \\n if( -p.z>11.0 )\\n {\\n float ss = 4.0;\\n vec3 q = p;\\n vec2 id = floor( (q.xz+0.5*ss)/ss );\\n q.xz = mod( q.xz+0.5*ss, ss ) - 0.5*ss;\\n \\n\\n float r1 = hash(121.11*id.x+id.y*117.4);\\n float r2 = hash( 71.72*id.x+id.y* 61.9);\\n float r3 = hash( 31.74*id.x+id.y*317.1);\\n mat4 rm = matRotate( vec3(1.0*r1,313.13*r2,0.2) );\\n \\n vec3 r = (rm*vec4(q,0.0)).xyz;\\n r.y -= g + 0.25;\\n \\n float d2 = 0.8*udRoundBox( r, vec3(2.,0.01+0.2*r3,0.1+0.5*r3), 0.002 );\\n res.x = min( d1, d2 );\\n }\\n#endif\\n \\n return res;\\n}\\n\\n\\nvec3 calcNormalTerrain( in vec3 pos, in float eps )\\n{\\n vec2 e = vec2(1.0,-1.0)*0.5773*eps;\\n return normalize( e.xyy*mapTerrainH( pos + e.xyy ).x + \\n\\t\\t\\t\\t\\t e.yyx*mapTerrainH( pos + e.yyx ).x + \\n\\t\\t\\t\\t\\t e.yxy*mapTerrainH( pos + e.yxy ).x + \\n\\t\\t\\t\\t\\t e.xxx*mapTerrainH( pos + e.xxx ).x );\\n}\\n\\nfloat calcSoftshadowTerrain( in vec3 ro, in vec3 rd, float k )\\n{\\n float res = 1.0;\\n float t = 0.01;\\n for( int i=0; i<16; i++ )\\n {\\n float h = mapTerrain(ro + rd*t ).x;\\n res = min( res, smoothstep(0.0,1.0,k*h/t) );\\n t += clamp( h, 0.04, 0.1 );\\n\\t\\tif( res<0.01 ) break;\\n }\\n return clamp(res,0.0,1.0);\\n}\\n\\nvec3 shadeTerrain( in vec3 ro, in vec3 rd, in float t, float m )\\n{\\n vec3 pos = ro + rd * t;\\n vec3 nor = calcNormalTerrain( pos, 0.01 );\\n vec3 hal = normalize( sundir - rd );\\n \\n // vec3 col = texture2D( iChannel0, 0.01*pos.xz ).xyz*0.14 * vec3(1.1,1.0,0.9);\\n vec3 col = vec3(0.5, 0.5, 0.5);\\n\\n float dif = clamp( dot(sundir,nor), 0.0, 1.0 );\\n float spe = clamp( dot(nor,hal), 0.0, 1.0 );\\n float amb = clamp( 0.3 + 0.7*nor.y, 0.0, 1.0 );\\n //dif *= calcSoftshadowTerrain( pos+nor*0.1, sundir, 32.0 );\\n vec3 lig = dif*vec3(3.0,2.0,1.5)*2.0 + pow(spe,8.0)*3.0*dif*4.0 + vec3(0.5,0.6,1.0)*amb;\\n \\n col *= lig;\\n\\n return col;\\n}\\n \\nvec2 intersectTerrain( in vec3 ro, in vec3 rd, float maxdist )\\n{\\n vec2 res = vec2(-1.0);\\n float t = 1.0;\\n \\n for( int i=0; i<256; i++ )\\n {\\n vec3 p = ro + t*rd;\\n vec2 h = mapTerrain( p );\\n res = vec2( t, h.y );\\n if( h.x<(0.001*t) || t>maxdist ) break;\\n t += h.x;\\n }\\n \\n \\n\\treturn res;\\n}\\n\\n\\nvec3 render( in vec3 ro, in vec3 rd )\\n{\\n vec3 col = mix( vec3(1.0,1.0,1.0),\\n vec3(0.8,0.6,0.4),\\n sqrt(max(rd.y,0.0)) );\\n\\n float sun = clamp( dot(rd,sundir), 0.0, 1.0 );\\n col += 0.9*pow( sun, 64.0 );\\n \\n // terrain\\n float maxdistTerrain = 200.0;\\n float bp = (4.0-ro.y)/rd.y; if( bp>0.0 && bpmaxdist ) break;\n \n t += h.x;//*0.5;\n }\n\treturn res;\n}\n\n//----------------------------------------------------------------------------------\nvec2 mapTerrain( vec3 p )\n{\n float h = -2.5;\n h -= 1.5*sin( 5.0 + 0.2*p.z);\n h += 1.5*sin( 0.0 - 0.05*p.x - 0.05*p.z);\n float g = h;\n if( (p.y-h)<0.2 )\n // h += 0.1*(texture2D( iChannel0, 0.1*p.xz ).x);\n\n float d1 = 0.2*(p.y-h);\n \n // TODO, PJ: WTF ?\n // vec2 res = vec2( d1, 1.0 );\n vec2 res = vec2( 1.0, 1.0);\n \n#if 1 \n if( -p.z>11.0 )\n {\n float ss = 4.0;\n vec3 q = p;\n vec2 id = floor( (q.xz+0.5*ss)/ss );\n q.xz = mod( q.xz+0.5*ss, ss ) - 0.5*ss;\n \n\n float r1 = hash(121.11*id.x+id.y*117.4);\n float r2 = hash( 71.72*id.x+id.y* 61.9);\n float r3 = hash( 31.74*id.x+id.y*317.1);\n mat4 rm = matRotate( vec3(1.0*r1,313.13*r2,0.2) );\n \n vec3 r = (rm*vec4(q,0.0)).xyz;\n r.y -= g + 0.25;\n \n float d2 = 0.8*udRoundBox( r, vec3(2.,0.01+0.2*r3,0.1+0.5*r3), 0.002 );\n // TODO, PJ: WTF?\n // res.x = min( d1, d2 );\n res.x = 2.0;\n }\n#endif\n \n return res;\n}\n\nvec2 mapTerrainH( vec3 p )\n{\n float h = -2.5;\n h -= 1.5*sin( 5.0 + 0.2*p.z);\n h += 1.5*sin( 0.0 - 0.05*p.x - 0.05*p.z);\n float g = h;\n // TODO, PJ: Find a smart alternative\n // h += 0.1*(texture2D( iChannel0, 0.1*p.xz ).x);\n\n float d1 = 0.2*(p.y-h);\n \n vec2 res = vec2( d1, 1.0 );\n \n#if 1 \n if( -p.z>11.0 )\n {\n float ss = 4.0;\n vec3 q = p;\n vec2 id = floor( (q.xz+0.5*ss)/ss );\n q.xz = mod( q.xz+0.5*ss, ss ) - 0.5*ss;\n \n\n float r1 = hash(121.11*id.x+id.y*117.4);\n float r2 = hash( 71.72*id.x+id.y* 61.9);\n float r3 = hash( 31.74*id.x+id.y*317.1);\n mat4 rm = matRotate( vec3(1.0*r1,313.13*r2,0.2) );\n \n vec3 r = (rm*vec4(q,0.0)).xyz;\n r.y -= g + 0.25;\n \n float d2 = 0.8*udRoundBox( r, vec3(2.,0.01+0.2*r3,0.1+0.5*r3), 0.002 );\n res.x = min( d1, d2 );\n }\n#endif\n \n return res;\n}\n\n\nvec3 calcNormalTerrain( in vec3 pos, in float eps )\n{\n vec2 e = vec2(1.0,-1.0)*0.5773*eps;\n return normalize( e.xyy*mapTerrainH( pos + e.xyy ).x + \n\t\t\t\t\t e.yyx*mapTerrainH( pos + e.yyx ).x + \n\t\t\t\t\t e.yxy*mapTerrainH( pos + e.yxy ).x + \n\t\t\t\t\t e.xxx*mapTerrainH( pos + e.xxx ).x );\n}\n\nfloat calcSoftshadowTerrain( in vec3 ro, in vec3 rd, float k )\n{\n float res = 1.0;\n float t = 0.01;\n for( int i=0; i<16; i++ )\n {\n float h = mapTerrain(ro + rd*t ).x;\n res = min( res, smoothstep(0.0,1.0,k*h/t) );\n t += clamp( h, 0.04, 0.1 );\n\t\tif( res<0.01 ) break;\n }\n return clamp(res,0.0,1.0);\n}\n\nvec3 shadeTerrain( in vec3 ro, in vec3 rd, in float t, float m )\n{\n vec3 pos = ro + rd * t;\n vec3 nor = calcNormalTerrain( pos, 0.01 );\n vec3 hal = normalize( sundir - rd );\n \n // vec3 col = texture2D( iChannel0, 0.01*pos.xz ).xyz*0.14 * vec3(1.1,1.0,0.9);\n vec3 col = vec3(0.5, 0.5, 0.5);\n\n float dif = clamp( dot(sundir,nor), 0.0, 1.0 );\n float spe = clamp( dot(nor,hal), 0.0, 1.0 );\n float amb = clamp( 0.3 + 0.7*nor.y, 0.0, 1.0 );\n //dif *= calcSoftshadowTerrain( pos+nor*0.1, sundir, 32.0 );\n vec3 lig = dif*vec3(3.0,2.0,1.5)*2.0 + pow(spe,8.0)*3.0*dif*4.0 + vec3(0.5,0.6,1.0)*amb;\n \n col *= lig;\n\n return col;\n}\n \nvec2 intersectTerrain( in vec3 ro, in vec3 rd, float maxdist )\n{\n vec2 res = vec2(-1.0);\n float t = 1.0;\n \n for( int i=0; i<256; i++ )\n {\n vec3 p = ro + t*rd;\n vec2 h = mapTerrain( p );\n res = vec2( t, h.y );\n if( h.x<(0.001*t) || t>maxdist ) break;\n t += h.x;\n }\n \n \n\treturn res;\n}\n\n\nvec3 render( in vec3 ro, in vec3 rd )\n{\n vec3 col = mix( vec3(1.0,1.0,1.0),\n vec3(0.8,0.6,0.4),\n sqrt(max(rd.y,0.0)) );\n\n float sun = clamp( dot(rd,sundir), 0.0, 1.0 );\n col += 0.9*pow( sun, 64.0 );\n \n // terrain\n float maxdistTerrain = 200.0;\n float bp = (4.0-ro.y)/rd.y; if( bp>0.0 && bp>5.\\n#define parameter1 0.4//KParameter 0.0>>10.\\n#define parameter2 100.//KParameter 10.0>>100.\\n#define parameter3 3.2//KParameter 0.0>>1.\\n#define rotationX 0.//KParameter 0.0>>2.\\n#define rotationY 0.//KParameter 0.0>>1.\\n#define soundFact 0.//KParameter 0.0>>1.\\n#define soundAmp 0.//KParameter 0.0>>5.\\n\\n#define PI 3.14159265359\\n#define HPI PI/2.\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n\\nfloat random(float n) {\\n\\treturn fract(abs(sin(n * 55.753) * 367.34));\\n}\\n\\nmat2 rotate2d(float angle){\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nvoid main( void ) {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\n\\nfloat sndComp = u_i;\\nif(u_i>0.5)\\n {\\n sndComp = 1.-sndComp;\\n }\\n \\nfloat snd = soundFact * texture2D(sound, vec2(0., sndComp)).a;\\n \\n\\n \\n //camera stuffs\\n\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.4, 0.0);\\n vec3 eye = vec3(0., 0., 1.5);\\n\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., 1., 0.);\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n \\n\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n\\tvec2 uv = (simFragCoord.xy * 2.0 - vertexResolution.xy) / vertexResolution.x;\\n\\n float rot = parameter3;\\n if(u_i>0.5)\\n {\\n rot = -rot;\\n };\\n \\n\\tuv *= rotate2d(time * rot); //time * 0.2\\n\\n\\tfloat direction = 1.0;\\n\\tfloat speed = time * direction * parameter0;\\n\\tfloat distanceFromCenter = length(uv);\\n\\n float angleCompX = uv.x; \\n if(u_i>0.5)\\n {\\n angleCompX = -angleCompX;\\n }\\n\\tfloat meteorAngle = atan(uv.y, angleCompX) * (180.0 / PI);\\n\\n\\tfloat flooredAngle = floor(meteorAngle);\\n\\tfloat randomAngle = pow(random(flooredAngle), 0.5);\\n\\tfloat t = speed;\\n\\n\\tfloat lightsCountOffset = parameter1;\\n\\tfloat adist = randomAngle / distanceFromCenter * lightsCountOffset + snd;\\n\\tfloat dist = t + adist;\\n\\tfloat meteorDirection = (direction < 0.0) ? -1.0 : 0.0;\\n\\tdist = abs(fract(dist) + meteorDirection);\\n\\n\\tfloat lightLength = parameter2;\\n\\tfloat meteor = (5.0 / dist) * cos(sin(speed)) / lightLength;\\n\\tmeteor *= distanceFromCenter * 5.0;\\n\\n\\n\\tvec3 color = vec3(0.);\\n \\n\\n float depth = snd*(color.x+color.y+color.z)/3.;\\n \\n\\tcolor += meteor;\\n\\n\\tv_color = vec4(color, 1.0);\\n \\n \\n vec4 finalPos = vec4(ux, vy, snd, 1.);\\n \\n finalPos = vec4(rotX(rotY(finalPos.xyz, rotationY*2.*PI),rotationX*2.*PI),1.);\\n \\n gl_Position = mat*finalPos;\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define parameter0 0.6//KParameter -5.0>>5.\n#define parameter1 0.4//KParameter 0.0>>10.\n#define parameter2 100.//KParameter 10.0>>100.\n#define parameter3 3.2//KParameter 0.0>>1.\n#define rotationX 0.//KParameter 0.0>>2.\n#define rotationY 0.//KParameter 0.0>>1.\n#define soundFact 0.//KParameter 0.0>>1.\n#define soundAmp 0.//KParameter 0.0>>5.\n\n#define PI 3.14159265359\n#define HPI PI/2.\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n\nfloat random(float n) {\n\treturn fract(abs(sin(n * 55.753) * 367.34));\n}\n\nmat2 rotate2d(float angle){\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nvoid main( void ) {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\n\nfloat sndComp = u_i;\nif(u_i>0.5)\n {\n sndComp = 1.-sndComp;\n }\n \nfloat snd = soundFact * texture2D(sound, vec2(0., sndComp)).a;\n \n\n \n //camera stuffs\n\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.4, 0.0);\n vec3 eye = vec3(0., 0., 1.5);\n\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., 1., 0.);\n \n \n mat *= cameraLookAt(eye, target, up);\n \n \n\nvec2 surfacePosition = vec2(ux,vy);\n\n\tvec2 uv = (simFragCoord.xy * 2.0 - vertexResolution.xy) / vertexResolution.x;\n\n float rot = parameter3;\n if(u_i>0.5)\n {\n rot = -rot;\n };\n \n\tuv *= rotate2d(time * rot); //time * 0.2\n\n\tfloat direction = 1.0;\n\tfloat speed = time * direction * parameter0;\n\tfloat distanceFromCenter = length(uv);\n\n float angleCompX = uv.x; \n if(u_i>0.5)\n {\n angleCompX = -angleCompX;\n }\n\tfloat meteorAngle = atan(uv.y, angleCompX) * (180.0 / PI);\n\n\tfloat flooredAngle = floor(meteorAngle);\n\tfloat randomAngle = pow(random(flooredAngle), 0.5);\n\tfloat t = speed;\n\n\tfloat lightsCountOffset = parameter1;\n\tfloat adist = randomAngle / distanceFromCenter * lightsCountOffset + snd;\n\tfloat dist = t + adist;\n\tfloat meteorDirection = (direction < 0.0) ? -1.0 : 0.0;\n\tdist = abs(fract(dist) + meteorDirection);\n\n\tfloat lightLength = parameter2;\n\tfloat meteor = (5.0 / dist) * cos(sin(speed)) / lightLength;\n\tmeteor *= distanceFromCenter * 5.0;\n\n\n\tvec3 color = vec3(0.);\n \n\n float depth = snd*(color.x+color.y+color.z)/3.;\n \n\tcolor += meteor;\n\n\tv_color = vec4(color, 1.0);\n \n \n vec4 finalPos = vec4(ux, vy, snd, 1.);\n \n finalPos = vec4(rotX(rotY(finalPos.xyz, rotationY*2.*PI),rotationX*2.*PI),1.);\n \n gl_Position = mat*finalPos;\n \n}" + }, "screenshotURL": "data/images/images-ivqh5c6876dsw1ys3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Qx9JCRsXfk5Ajh3t7/art.json b/art/Qx9JCRsXfk5Ajh3t7/art.json index bd123683..815ef3e4 100644 --- a/art/Qx9JCRsXfk5Ajh3t7/art.json +++ b/art/Qx9JCRsXfk5Ajh3t7/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hug-life/pychodelik-pussy-assan-rubber-ducks-jam\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define KP0 sin((time*0.0000006))\\n\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * (3.*mouse.y);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 0.1, vy\\n *1.-mouse.y);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x*2., y+x);\\n}\\n\\n\\nvoid main() {\\n float vertexCount = 100000. *abs(mouse.x);\\n float numCircleSegments = 4.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 2;\\n float snd = 0.;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11)*KP0;\\n float spx = hash(spf * 7.123-KP0);\\n float spy = hash(spf * 0.317)+sin(KP0);\\n float sps = hash(spf * 3.411)-sin(mouse.y+0.5);\\n \\n float sds = distance(vec2(u, v), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7, sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds,2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 0.9 + oddSlice * 0.1;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 0.5);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 0.5));\\n mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 20. / across);\\n mat *= rotZ(snd * 22. * sign(ux)+2.);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.7, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hug-life/pychodelik-pussy-assan-rubber-ducks-jam", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define KP0 sin((time*0.0000006))\n\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * (3.*mouse.y);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 0.1, vy\n *1.-mouse.y);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x*2., y+x);\n}\n\n\nvoid main() {\n float vertexCount = 100000. *abs(mouse.x);\n float numCircleSegments = 4.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 2;\n float snd = 0.;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11)*KP0;\n float spx = hash(spf * 7.123-KP0);\n float spy = hash(spf * 0.317)+sin(KP0);\n float sps = hash(spf * 3.411)-sin(mouse.y+0.5);\n \n float sds = distance(vec2(u, v), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7, sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds,2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 0.9 + oddSlice * 0.1;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 0.5);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 0.5));\n mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 20. / across);\n mat *= rotZ(snd * 22. * sign(ux)+2.);\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.7, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-860e8l68bz126jbr2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/QyDcaPpdEjfdFhiJZ/art.json b/art/QyDcaPpdEjfdFhiJZ/art.json index 46dd9a81..7993c8d7 100644 --- a/art/QyDcaPpdEjfdFhiJZ/art.json +++ b/art/QyDcaPpdEjfdFhiJZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":3031,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius*5.3;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 3031, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius*5.3;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-tegy2c7uxlyql310h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R24A9rmCwYpy84QtX/art.json b/art/R24A9rmCwYpy84QtX/art.json index 367052c7..3da9806a 100644 --- a/art/R24A9rmCwYpy84QtX/art.json +++ b/art/R24A9rmCwYpy84QtX/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"attribute vec4 position; \\nvoid main() \\n{ \\n gl_Position = vec4(position.xyz, 1.0); \\n} \\n\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "attribute vec4 position; \nvoid main() \n{ \n gl_Position = vec4(position.xyz, 1.0); \n} \n" + }, "screenshotURL": "data/images/images-5tl91249fuqjk513m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/R2FYLbHWTcCWh5PiE/art.json b/art/R2FYLbHWTcCWh5PiE/art.json index 8708649d..5cc08701 100644 --- a/art/R2FYLbHWTcCWh5PiE/art.json +++ b/art/R2FYLbHWTcCWh5PiE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/argofox/doctor-vox-death\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = abs(atan(loc.x, loc.z) / PI);\\n float sv = abs(loc.y);\\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(cos(tm),-sin(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, pow(s, 2.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(0.9, 1.1, s) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n #if 0\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n#endif\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/argofox/doctor-vox-death", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = abs(atan(loc.x, loc.z) / PI);\n float sv = abs(loc.y);\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(cos(tm),-sin(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, pow(s, 2.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(0.9, 1.1, s) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n #if 0\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n#endif\n}\n\n" + }, "screenshotURL": "data/images/images-1rfxx5odugofg21pg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R4LHf9BCLCCDYjbez/art.json b/art/R4LHf9BCLCCDYjbez/art.json index 3347d6c7..3cb315e3 100644 --- a/art/R4LHf9BCLCCDYjbez/art.json +++ b/art/R4LHf9BCLCCDYjbez/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n vec4 pos = vec4(cos(time + vertexId * 0.01) * 0.5, sin(time + vertexId * 0.01) * 0.8, 0.0, 1.0);\\n gl_PointSize = 15.0;\\n gl_Position = pos + vertexId*0.0006;\\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0) + 0.5;\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n vec4 pos = vec4(cos(time + vertexId * 0.01) * 0.5, sin(time + vertexId * 0.01) * 0.8, 0.0, 1.0);\n gl_PointSize = 15.0;\n gl_Position = pos + vertexId*0.0006;\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0) + 0.5;\n}" + }, "screenshotURL": "data/images/images-t2t4mtdh3fevgvkib-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R4ridvuayrATd6Tgy/art.json b/art/R4ridvuayrATd6Tgy/art.json index ae0c5e53..cb2b3777 100644 --- a/art/R4ridvuayrATd6Tgy/art.json +++ b/art/R4ridvuayrATd6Tgy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.17647058823529413,0.17647058823529413,0.17647058823529413,1],\"shader\":\"mat2 Rotate2D (float x) {\\n float a = sin(x), b = cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main () {\\n vec2 pos = vec2(vertexId/vertexCount, abs(sin(time)))*0.8 * Rotate2D(vertexId+time*10.0);\\n gl_PointSize = 15.0;\\n gl_Position = vec4(pos, 0.0, 1.0);\\n v_color = vec4(pos.x, pos.y, -pos.x, 1.0) + 0.5;\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.17647058823529413, + 0.17647058823529413, + 0.17647058823529413, + 1 + ], + "shader": "mat2 Rotate2D (float x) {\n float a = sin(x), b = cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main () {\n vec2 pos = vec2(vertexId/vertexCount, abs(sin(time)))*0.8 * Rotate2D(vertexId+time*10.0);\n gl_PointSize = 15.0;\n gl_Position = vec4(pos, 0.0, 1.0);\n v_color = vec4(pos.x, pos.y, -pos.x, 1.0) + 0.5;\n}" + }, "screenshotURL": "data/images/images-vq5ysgwkfi9qlp64i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R5YxJnoTPRwwaJqFz/art.json b/art/R5YxJnoTPRwwaJqFz/art.json index 268cc892..5f0fe5a4 100644 --- a/art/R5YxJnoTPRwwaJqFz/art.json +++ b/art/R5YxJnoTPRwwaJqFz/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2980392156862745,0.2235294117647059,0.7254901960784313,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define KP0 3.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(2.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, tan(1.-c), 0,\\n 0, c, 1, 0,\\n 0, 0, c, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1.1, 0, 0, 0,\\n 0, 1, 0, -0.2,\\n 0, 0.3, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, -0.3,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov)-(0.93);\\n float rangeInv = f / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0.02, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1.1,\\n 1, 0.1, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][1], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[0][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[2], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 2, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[1][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 - b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 * a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 / b01 + a22 - b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 2,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), dot(zAxis, eye), .1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 15.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 1.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 2. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 4.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI *1.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 1.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 12.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * 0.4 * v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * 1.2;\\n float sat = mix(.5, 1., mod(floor(time * 6. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 0. + length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (0.1 - length(p)) * sz * 0.1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / .5);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1164.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4, -1));\\n vec3 lightPos = vec3(500, 1000, -200);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 0.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 22.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 1.5 + 0.5), 11); \\n color = vec4(tcolor * light + vec3(specular), 2.3); \\n \\n // color.a = mix(1., 15., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = 2.5 + (pow(s1, 1.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 111.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 1.91, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * 1.05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 1., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 2., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, sin(1.1*-time)+1.);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2980392156862745, + 0.2235294117647059, + 0.7254901960784313, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define KP0 3.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(2.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, tan(1.-c), 0,\n 0, c, 1, 0,\n 0, 0, c, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1.1, 0, 0, 0,\n 0, 1, 0, -0.2,\n 0, 0.3, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, -0.3,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov)-(0.93);\n float rangeInv = f / (zNear - zFar);\n\n return mat4(\n f / aspect, 0.02, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1.1,\n 1, 0.1, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][1], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[0][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[2], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 2, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[1][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 - b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 * a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 / b01 + a22 - b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 2,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), dot(zAxis, eye), .1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 15.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 1.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 2. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 4.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI *1.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 1.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 12.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * 0.4 * v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * 1.2;\n float sat = mix(.5, 1., mod(floor(time * 6. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 0. + length(p));\n// color.rgb *= color.a;\n gl_PointSize = (0.1 - length(p)) * sz * 0.1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / .5);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1164.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 1.4, -1));\n vec3 lightPos = vec3(500, 1000, -200);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 0.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 22.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 1.5 + 0.5), 11); \n color = vec4(tcolor * light + vec3(specular), 2.3); \n \n // color.a = mix(1., 15., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = 2.5 + (pow(s1, 1.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 111.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 1.91, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * 1.05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 1., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 2., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, sin(1.1*-time)+1.);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-0lh1tgb10ko064rut-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R7mtRmP2cCPdJk6Bv/art.json b/art/R7mtRmP2cCPdJk6Bv/art.json index 5ac19c72..2a950033 100644 --- a/art/R7mtRmP2cCPdJk6Bv/art.json +++ b/art/R7mtRmP2cCPdJk6Bv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hug-life/freek-it-remaster\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 14.0 / 2.4, 2.0 / 6.0, 2);\\n vec3 p = abs(fract(c.xxx + K.xyz) * (mouse.y + 18.6) - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 10.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle +sin(9.0 -time));\\n float c = cos( angle * mouse.x );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 1.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) -1.4;\\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 6.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .02)).xyz, 1.2);\\n gl_PointSize = tan(5. *snd);\\n float hue = mix(1.3*snd, 12.6/snd, fract(circleId -21.79)*3.);\\n float sat = 45.2 * circleId/snd;\\n float val = .29;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-2.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/hug-life/freek-it-remaster", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 14.0 / 2.4, 2.0 / 6.0, 2);\n vec3 p = abs(fract(c.xxx + K.xyz) * (mouse.y + 18.6) - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 10.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle +sin(9.0 -time));\n float c = cos( angle * mouse.x );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 1.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) -1.4;\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 6.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .02)).xyz, 1.2);\n gl_PointSize = tan(5. *snd);\n float hue = mix(1.3*snd, 12.6/snd, fract(circleId -21.79)*3.);\n float sat = 45.2 * circleId/snd;\n float val = .29;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-2.0);\n}" + }, "screenshotURL": "data/images/images-c022mpwshr8a65zpf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R7yXZW3KoMpDcS5NW/art.json b/art/R7yXZW3KoMpDcS5NW/art.json index 9cb664a1..cc84997a 100644 --- a/art/R7yXZW3KoMpDcS5NW/art.json +++ b/art/R7yXZW3KoMpDcS5NW/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define KP0 0.5//KParam\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.01;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 5.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 20;\\n float snd = 0.;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf * 7.123);\\n float spy = hash(spf * 0.317);\\n float sps = hash(spf * 3.411);\\n \\n float sds = distance(vec2(u, v), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7, sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 20. / across);\\n //mat *= rotZ(snd * 10. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.7, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define KP0 0.5//KParam\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.01;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 5.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 20;\n float snd = 0.;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf * 7.123);\n float spy = hash(spf * 0.317);\n float sps = hash(spf * 3.411);\n \n float sds = distance(vec2(u, v), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7, sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 20. / across);\n //mat *= rotZ(snd * 10. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.7, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-u82cwweaesj0hg16v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/R9YtdbpwyPFwwKsix/art.json b/art/R9YtdbpwyPFwwKsix/art.json index 7a3b61d5..5f6dccb8 100644 --- a/art/R9YtdbpwyPFwwKsix/art.json +++ b/art/R9YtdbpwyPFwwKsix/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/kostaellis/look-up-superbreak-presents\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 400.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define PI radians(180.0)\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 spirograph(float u, float n1, float n2, float n3, float a, float b, float y, float z) {\\n u *= PI * 2.0;\\n float a1 = pow(abs(cos(y * u / 4.) / a), n2);\\n float b1 = pow(abs(sin(z * u / 4.) / b), n3);\\n float ab = a1 + b1;\\n float r = pow(abs(ab), -1. / n1);\\n \\n float c1 = cos(u) * r;\\n float s1 = sin(u) * r;\\n \\n return vec2(c1, s1);\\n}\\n\\nfloat bloop(float v) {\\n return sin(v * PI * 2.) * .5 + .5;\\n}\\n\\nvoid main() {\\n float numCircles = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n float circleId = floor(vertexId / NUM_POINTS);\\n \\n float u = point / NUM_SEGMENTS; \\n float v = circleId / numCircles; \\n float invV = 1.0 - v;\\n \\n float tm = time * 0.05 - v;\\n vec2 ra = spirograph(\\n u, \\n mix(-20., 20., bloop(tm * 0.6)), // n1\\n mix(-20., 20., bloop(tm * 0.7)), // n2\\n mix(-20., 20., bloop(tm * 0.8)), // n3\\n mix( 1., 50., bloop(tm * 0.9)), // a\\n mix( 1., 50., bloop(tm * 0.10)), // b\\n mix( 1., 100., bloop(tm * 0.11)), // y\\n mix( 1., 100., bloop(tm * 0.12))); // z\\n\\n vec2 xy = ra;\\n float aspect = resolution.y / resolution.x;\\n gl_Position = vec4(xy * 0.25, 0, v) * vec4(aspect, 1, 1, 1);\\n \\n float su = bloop(u * 3. + time * 0.25);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.1, su), v * 0.2)).a;\\n snd *= mix(1.0, 1.3, su);\\n\\n float cs = pow(snd, 5.);\\n float hue = time * 0.1 + v * 0.2 + cs * 0.2;\\n float sat = mix(0.75, 1., cs);\\n float val = mix(0.75, 1., cs);\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, 0.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/kostaellis/look-up-superbreak-presents", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 400.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define PI radians(180.0)\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 spirograph(float u, float n1, float n2, float n3, float a, float b, float y, float z) {\n u *= PI * 2.0;\n float a1 = pow(abs(cos(y * u / 4.) / a), n2);\n float b1 = pow(abs(sin(z * u / 4.) / b), n3);\n float ab = a1 + b1;\n float r = pow(abs(ab), -1. / n1);\n \n float c1 = cos(u) * r;\n float s1 = sin(u) * r;\n \n return vec2(c1, s1);\n}\n\nfloat bloop(float v) {\n return sin(v * PI * 2.) * .5 + .5;\n}\n\nvoid main() {\n float numCircles = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n float circleId = floor(vertexId / NUM_POINTS);\n \n float u = point / NUM_SEGMENTS; \n float v = circleId / numCircles; \n float invV = 1.0 - v;\n \n float tm = time * 0.05 - v;\n vec2 ra = spirograph(\n u, \n mix(-20., 20., bloop(tm * 0.6)), // n1\n mix(-20., 20., bloop(tm * 0.7)), // n2\n mix(-20., 20., bloop(tm * 0.8)), // n3\n mix( 1., 50., bloop(tm * 0.9)), // a\n mix( 1., 50., bloop(tm * 0.10)), // b\n mix( 1., 100., bloop(tm * 0.11)), // y\n mix( 1., 100., bloop(tm * 0.12))); // z\n\n vec2 xy = ra;\n float aspect = resolution.y / resolution.x;\n gl_Position = vec4(xy * 0.25, 0, v) * vec4(aspect, 1, 1, 1);\n \n float su = bloop(u * 3. + time * 0.25);\n float snd = texture2D(sound, vec2(mix(0.001, 0.1, su), v * 0.2)).a;\n snd *= mix(1.0, 1.3, su);\n\n float cs = pow(snd, 5.);\n float hue = time * 0.1 + v * 0.2 + cs * 0.2;\n float sat = mix(0.75, 1., cs);\n float val = mix(0.75, 1., cs);\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, 0.);\n}" + }, "screenshotURL": "data/images/images-3cd8m3krl5ko84n58-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RAEKCeDDfGBmYSyQY/art.json b/art/RAEKCeDDfGBmYSyQY/art.json index 5ed4fc3a..a72897a6 100644 --- a/art/RAEKCeDDfGBmYSyQY/art.json +++ b/art/RAEKCeDDfGBmYSyQY/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 10.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 4.0;\\n float braids = 20.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 10.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 4.0;\n float braids = 20.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-60lr0sm1wesyiy0do-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RAKtMyYWNoC4Qni29/art.json b/art/RAKtMyYWNoC4Qni29/art.json index db8274cf..1989b14b 100644 --- a/art/RAKtMyYWNoC4Qni29/art.json +++ b/art/RAKtMyYWNoC4Qni29/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(2.4, 1.2, 0.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\\n\\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * -3.;\\nfloat gExposure = 0.2;\\nfloat gCubeColorRandom = .85;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 3.6;\\nfloat gFloorHeight = -43.0*mouse.x;\\nfloat g_cameraFar = 99.0 /mouse.y;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 30.0, -10.3, -50.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 1.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 5.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = (v2- mouse.y);\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3, mouse.x;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\\n}\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 1.25 + 1.6;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 1, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 1, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 2.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.25);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\\n float z = vP * down * 11.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 10.);\\n mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \\n pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 0.78;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\\n float ca = 0.01;\\n \\n // get sick!\\n ca = time * 0.7;\\n \\tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(2.4, 1.2, 0.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\n\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * -3.;\nfloat gExposure = 0.2;\nfloat gCubeColorRandom = .85;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 3.6;\nfloat gFloorHeight = -43.0*mouse.x;\nfloat g_cameraFar = 99.0 /mouse.y;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 30.0, -10.3, -50.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 1.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 5.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = (v2- mouse.y);\n }\n \telse\n {\n\t \tvWorldPos = v3, mouse.x;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\n}\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 1.25 + 1.6;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 1, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 1, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 2.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.25);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\n float z = vP * down * 11.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 10.);\n mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \n pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 0.78;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\n \tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\n float ca = 0.01;\n \n // get sick!\n ca = time * 0.7;\n \tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-bgxg95m5hs7d81ggg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RAbYpopPvqhdXyhM5/art.json b/art/RAbYpopPvqhdXyhM5/art.json index 51585269..10f404aa 100644 --- a/art/RAbYpopPvqhdXyhM5/art.json +++ b/art/RAbYpopPvqhdXyhM5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.403921568627451,0.403921568627451,0.403921568627451,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n01/01/2019\\n@BestRegard \\n*/ \\n\\n#define COLOR_VIVID\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region Scene_Vertex_Collection \\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n\\n struct SurfaceInfo \\n {\\n vec3 vPos;\\n vec3 vNormal;\\n float fGloss;\\n };\\n struct SphereInfo\\n {\\t\\n\\t \\n vec3 vOrigin;\\n float fRadius ; \\n \\n \\n \\n float fSlices ; \\n float fSegments ; \\n }; \\n#pragma endregion \\n \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, sv) ; \\n vertexIndex -= floorTileCount ; \\n */\\n /*draw the sphere*/ \\n \\tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo, camPos,\\n sv);\\n }\\n \\tvertexIndex -= fSphereVertexCount ; \\n \\n #pragma endregion \\n \\n \\n #pragma region add to glsl\\n \\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n #pragma endregion \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n01/01/2019\n@BestRegard \n*/ \n\n#define COLOR_VIVID\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t\n\t \n vec3 vOrigin;\n float fRadius ; \n \n \n \n float fSlices ; \n float fSegments ; \n }; \n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, sv) ; \n vertexIndex -= floorTileCount ; \n */\n /*draw the sphere*/ \n \tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo, camPos,\n sv);\n }\n \tvertexIndex -= fSphereVertexCount ; \n \n #pragma endregion \n \n \n #pragma region add to glsl\n \n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n #pragma endregion \n}" + }, "screenshotURL": "data/images/images-5wd2wj4qz4xdseqd6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/REkY7MvYAx7KwFMrw/art.json b/art/REkY7MvYAx7KwFMrw/art.json index b76f3c59..7124d4da 100644 --- a/art/REkY7MvYAx7KwFMrw/art.json +++ b/art/REkY7MvYAx7KwFMrw/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DIST 5.0\\n#define BOX_SIZE 4.0\\n\\nvec3 Hash23(vec2 p) {\\n\\tvec3 p3 = fract(p.xyx * vec3(0.1031, 0.103, 0.0973));\\n p3 += dot(p3, p3.yxz + 33.33);\\n return fract((p3.xxy + p3.yzz) * p3.zyx);\\n}\\n\\nvec3 getPos(in float t) {\\n return mix(Hash23(vec2(vertexId, floor(t))),\\n Hash23(vec2(vertexId, ceil(t))),\\n smoothstep(0.0, 1.0, fract(t))) * BOX_SIZE - 0.5 * BOX_SIZE;\\n}\\n\\nvoid main() {\\n vec3 pos = getPos(time);\\n v_color = vec4(getPos(0.0), 1.0);\\n\\n vec2 mouseRot = mouse * 3.14;\\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n\\n pos.yz *= mat2(cp, sp, -sp, cp);\\n pos.xz *= mat2(cy, sy, -sy, cy);\\n\\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\\n gl_Position.x *= resolution.y / resolution.x;\\n gl_PointSize = 10.0 / (EYE_DIST - pos.z);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DIST 5.0\n#define BOX_SIZE 4.0\n\nvec3 Hash23(vec2 p) {\n\tvec3 p3 = fract(p.xyx * vec3(0.1031, 0.103, 0.0973));\n p3 += dot(p3, p3.yxz + 33.33);\n return fract((p3.xxy + p3.yzz) * p3.zyx);\n}\n\nvec3 getPos(in float t) {\n return mix(Hash23(vec2(vertexId, floor(t))),\n Hash23(vec2(vertexId, ceil(t))),\n smoothstep(0.0, 1.0, fract(t))) * BOX_SIZE - 0.5 * BOX_SIZE;\n}\n\nvoid main() {\n vec3 pos = getPos(time);\n v_color = vec4(getPos(0.0), 1.0);\n\n vec2 mouseRot = mouse * 3.14;\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n\n pos.yz *= mat2(cp, sp, -sp, cp);\n pos.xz *= mat2(cy, sy, -sy, cy);\n\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\n gl_Position.x *= resolution.y / resolution.x;\n gl_PointSize = 10.0 / (EYE_DIST - pos.z);\n}" + }, "screenshotURL": "data/images/images-enh2bk3caekgrqnq4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RHYaZ3WADZyQo4ypC/art.json b/art/RHYaZ3WADZyQo4ypC/art.json index 91714743..a01d7402 100644 --- a/art/RHYaZ3WADZyQo4ypC/art.json +++ b/art/RHYaZ3WADZyQo4ypC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lapixmusic/fugene2crossfade\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n //simfragCoord <=> gl_FragCoord in the vertex shader\\n \\n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (simfragCoord.x /vertexResolution.x);\\n float v = (simfragCoord.y /vertexResolution.y);\\n \\n //calculate coordinates in -1.>>1.0 space\\n float sizeFactor = 1.;\\n float fact = 2.*sizeFactor;\\n float ux = fact*(u - 0.5);\\n float vy = fact*(v - 0.5);\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n \\n vec2 p = vec2(ux , vy);\\n \\n //https://www.shadertoy.com/view/XllGDH\\n\\n\\n\\tfloat t = 0.;//iTime/11.;\\n vec2 uv = (.2 + .05 * sin(t*1.1)) * simfragCoord.xy / vertexResolution.y + .2 * vec2(2.2+1.*sin(t), .4+.4*cos(t*.9));\\n \\n for (int i=0; i<11; ++i)\\n uv = abs(uv) / dot(uv,uv) - vec2( (0.2*sin(time)+.81)-.1*uv.y);\\n \\n\\tv_color = vec4(uv*uv, uv.y-uv.x, 1.);\\n \\n /*\\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / vertexResolution.y) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n*/\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = (resolution.y/vertexResolution.y) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\\n\\n //v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lapixmusic/fugene2crossfade", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n //simfragCoord <=> gl_FragCoord in the vertex shader\n \n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (simfragCoord.x /vertexResolution.x);\n float v = (simfragCoord.y /vertexResolution.y);\n \n //calculate coordinates in -1.>>1.0 space\n float sizeFactor = 1.;\n float fact = 2.*sizeFactor;\n float ux = fact*(u - 0.5);\n float vy = fact*(v - 0.5);\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n \n vec2 p = vec2(ux , vy);\n \n //https://www.shadertoy.com/view/XllGDH\n\n\n\tfloat t = 0.;//iTime/11.;\n vec2 uv = (.2 + .05 * sin(t*1.1)) * simfragCoord.xy / vertexResolution.y + .2 * vec2(2.2+1.*sin(t), .4+.4*cos(t*.9));\n \n for (int i=0; i<11; ++i)\n uv = abs(uv) / dot(uv,uv) - vec2( (0.2*sin(time)+.81)-.1*uv.y);\n \n\tv_color = vec4(uv*uv, uv.y-uv.x, 1.);\n \n /*\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\n int a = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / vertexResolution.y) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n*/\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = (resolution.y/vertexResolution.y) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\n\n //v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-4cksiljfqzsyfarvx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RJ4Tjj3PSsq4kvDcc/art.json b/art/RJ4Tjj3PSsq4kvDcc/art.json index 19c5052a..ee720c3c 100644 --- a/art/RJ4Tjj3PSsq4kvDcc/art.json +++ b/art/RJ4Tjj3PSsq4kvDcc/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":87554,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/noisia/noisia-machine-gun-amon-tobin-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n __ __ __ __ \\n _ _____ _____/ /____ _ _______/ /_ ____ _____/ /__ _________ ______/ /_\\n| | / / _ \\\\/ ___/ __/ _ \\\\| |/_/ ___/ __ \\\\/ __ `/ __ / _ \\\\/ ___/ __ `/ ___/ __/\\n| |/ / __/ / / /_/ __/> <(__ ) / / / /_/ / /_/ / __/ / / /_/ / / / /_ \\n|___/\\\\___/_/ \\\\__/\\\\___/_/|_/____/_/ /_/\\\\__,_/\\\\__,_/\\\\___/_/ \\\\__,_/_/ \\\\__/ \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 10.83;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec4 vColor;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float fCubeId, const float vertexIndex, const mat4 mat, const vec4 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n float glow = mod(fCubeId, 2.);\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec4(0,0,0,1);\\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor.xyz += GetSkyLighting( vNormal );\\n outSceneVertex.vColor.xyz *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor.xyz += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor.xyz *= vCubeCol.rgb; \\n\\n outSceneVertex.vColor.xyz += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition( float fVertexId, float fCubeId, out mat4 mat, out vec4 vCubeCol, out float snd)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 4.);\\n float side = m1p1(mod(floor(fCubeId / 2.), 2.));\\n float across = 32.;\\n float down = 20.;\\n float u = mod(posId, across) / across;\\n float v = floor(posId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n snd = texture2D(sound, vec2(mix(0.05, 0.25, ur), vr * 0.05)).a;\\n float glow = mod(fCubeId, 2.);\\n float glowScale = pow(snd, 5.) * glow * 6.;\\n //vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = 0.1 + glowScale * 0.2;//mix(0.1, 0.6, sin(lat)) * snd * 1.02;\\n vCubeOrigin.x = side * 6. * (1. - pow(snd, 5.) * 2.);\\n vCubeOrigin.y = m1p1(v) * 10.;\\n vCubeOrigin.z = m1p1(u) * 10.; \\n \\n float axisId = floor(fVertexId / 12.);\\n \\n \\n mat = ident();\\n // \\tmat *= rotZ(lng);\\n // \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., 0.33, glow * at(axisId, 1.)), \\n fScale * mix(1., 0.33, glow * at(axisId, 2.)),\\n fScale * mix(1., 0.33, glow * at(axisId, 0.))));\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeCol.xyz = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol.xyz = mix(vCubeCol.xyz, vec3(1,0,0), step(0.95,s2));\\n vCubeCol.xyz = vec3(0,0,1);\\n\\n #if 0\\n vCubeCol.xyz = hsv2rgb(vec3(axisId / 3., 1, 1));\\n vCubeCol.xyz = \\n at(axisId, 0.) * vec3(1,1,0) * 1. +\\n at(axisId, 1.) * vec3(1,0,1) * 1. + \\n at(axisId, 2.) * vec3(0,1,1) * 1. ;\\n #endif\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n float snd;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol, snd );\\n\\n GenerateCubeVertex( fCubeId, fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n float glow = mod(fCubeId, 2.);\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec4 vFinalColor = vec4(sqrt( vec3(1.0) - exp2( sceneVertex.vColor.xyz * -fExposure ) ), sceneVertex.vColor.a);\\n vFinalColor = mix(vFinalColor, vec4(1,1,1,0.9), glow);\\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n}\"}", + "settings": { + "num": 87554, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/noisia/noisia-machine-gun-amon-tobin-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n __ __ __ __ \n _ _____ _____/ /____ _ _______/ /_ ____ _____/ /__ _________ ______/ /_\n| | / / _ \\/ ___/ __/ _ \\| |/_/ ___/ __ \\/ __ `/ __ / _ \\/ ___/ __ `/ ___/ __/\n| |/ / __/ / / /_/ __/> <(__ ) / / / /_/ / /_/ / __/ / / /_/ / / / /_ \n|___/\\___/_/ \\__/\\___/_/|_/____/_/ /_/\\__,_/\\__,_/\\___/_/ \\__,_/_/ \\__/ \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 10.83;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec4 vColor;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float fCubeId, const float vertexIndex, const mat4 mat, const vec4 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n float glow = mod(fCubeId, 2.);\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec4(0,0,0,1);\n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor.xyz += GetSkyLighting( vNormal );\n outSceneVertex.vColor.xyz *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor.xyz += GetSunLighting( vNormal );\n\n outSceneVertex.vColor.xyz *= vCubeCol.rgb; \n\n outSceneVertex.vColor.xyz += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition( float fVertexId, float fCubeId, out mat4 mat, out vec4 vCubeCol, out float snd)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 4.);\n float side = m1p1(mod(floor(fCubeId / 2.), 2.));\n float across = 32.;\n float down = 20.;\n float u = mod(posId, across) / across;\n float v = floor(posId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n snd = texture2D(sound, vec2(mix(0.05, 0.25, ur), vr * 0.05)).a;\n float glow = mod(fCubeId, 2.);\n float glowScale = pow(snd, 5.) * glow * 6.;\n //vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = 0.1 + glowScale * 0.2;//mix(0.1, 0.6, sin(lat)) * snd * 1.02;\n vCubeOrigin.x = side * 6. * (1. - pow(snd, 5.) * 2.);\n vCubeOrigin.y = m1p1(v) * 10.;\n vCubeOrigin.z = m1p1(u) * 10.; \n \n float axisId = floor(fVertexId / 12.);\n \n \n mat = ident();\n // \tmat *= rotZ(lng);\n // \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., 0.33, glow * at(axisId, 1.)), \n fScale * mix(1., 0.33, glow * at(axisId, 2.)),\n fScale * mix(1., 0.33, glow * at(axisId, 0.))));\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeCol.xyz = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol.xyz = mix(vCubeCol.xyz, vec3(1,0,0), step(0.95,s2));\n vCubeCol.xyz = vec3(0,0,1);\n\n #if 0\n vCubeCol.xyz = hsv2rgb(vec3(axisId / 3., 1, 1));\n vCubeCol.xyz = \n at(axisId, 0.) * vec3(1,1,0) * 1. +\n at(axisId, 1.) * vec3(1,0,1) * 1. + \n at(axisId, 2.) * vec3(0,1,1) * 1. ;\n #endif\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n float snd;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol, snd );\n\n GenerateCubeVertex( fCubeId, fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n float glow = mod(fCubeId, 2.);\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec4 vFinalColor = vec4(sqrt( vec3(1.0) - exp2( sceneVertex.vColor.xyz * -fExposure ) ), sceneVertex.vColor.a);\n vFinalColor = mix(vFinalColor, vec4(1,1,1,0.9), glow);\n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n}" + }, "screenshotURL": "data/images/images-y4cjt7x163oumppk0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RKtpsEbtLZPFtvxRA/art.json b/art/RKtpsEbtLZPFtvxRA/art.json index 06df9eb7..f1c604c0 100644 --- a/art/RKtpsEbtLZPFtvxRA/art.json +++ b/art/RKtpsEbtLZPFtvxRA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":72000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n#define fakeVerticeNumber 72000\\n\\n/////////////////////////////\\n//K Machine parameters\\n/////////////////////////////\\n\\n//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=72000\\n\\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 1. //KParameter 1.>>10.\\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 2. //KParameter 0.5>>40.\\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\n//const float travelSpeed = -100.;\\nconst float dim = 120.;\\nconst float off = 0.3;\\n\\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\\n \\n \\n float prog = (_shapeId / _shapeCount)+_timeB;\\n \\n vec3 p0 = getCurvePoint(prog + off * 0.);\\n vec3 p1 = getCurvePoint(prog + off * 1.);\\n vec3 p2 = getCurvePoint(prog + off * 2.);\\n \\n vec3 np0 = normalize(p1 - p0);\\n vec3 np1 = normalize(p2 - p1);\\n \\n vec3 zaxis = normalize(np1 - np0);\\n vec3 xaxis = normalize(cross(np0, np1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n //position matrix\\n _wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(p0 * dim, 1)); \\n \\n //orientation matrix\\n vec3 eye = p0 * dim + zaxis * 1.;\\n vec3 target = p1 * dim + zaxis;\\n vec3 up = yaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nmat4 rotationMatrix(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n \\n //shape\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\\n \\n \\n float timeB = 4.5;\\n timeB = time * tubeSpeedFactor;\\n\\n /*\\n vec3 b0 = getCurvePoint(base + off * 0.);\\n vec3 b1 = getCurvePoint(base + off * 1.);\\n vec3 b2 = getCurvePoint(base + off * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n \\n vec3 eye = b0 * expand + czaxis * 1.;\\n vec3 target = b1 * expand + czaxis;\\n vec3 up = cyaxis;\\n */\\n \\n /* \\n//Static eye\\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n */\\n \\n \\n //Following eye\\n float sv = 0.;//mod( (0. /2.)+time*0.,groupCount) / 1.;\\n float v = sv + timeB;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n /*\\n //rotation around eye z axis\\n mat4 rotMat = rotationMatrix(zaxis, time*PI);\\n xaxis = (rotMat*vec4(xaxis,1.)).xyz;\\n yaxis = (rotMat*vec4(yaxis,1.)).xyz;\\n*/\\n //\\n \\n vec3 eye = r1 * dim + zaxis * 1.;\\n vec3 target = r2 * dim + zaxis;\\n vec3 up = yaxis;\\n \\n \\n //mat4 cmat = inverse(lookAt(eye, target, up));\\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n \\n \\n \\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n //cubep*= sizeFactor;\\n\\n mat4 scaleMat = scale(vec3(1.*cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n mat4 zrot = rotZ(relGroupId*2.*PI);\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n //cbNi*=scaleMat;\\n \\n //create the circle group\\n \\n \\n \\n float radius = 100.*radiusSizeFactor;\\n cubep.x+= radius*sin(2.*PI*relGroupId);\\n cubep.y+= radius*cos(2.*PI*relGroupId);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n //base+= mod(time,2.);\\n mat4 posmat;\\n mat4 rotmat;\\n \\n \\n getTrajMat(mod(shapeId-time*cudeSpeedFactor,shapeCount), shapeCount, timeB, posmat, rotmat);\\n \\n //shape orientation\\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\\n cbNi = cbNi*rotmat;\\n \\n //shape position\\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\\n //cbNi.xyz+= posi;\\n \\n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 72000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n#define fakeVerticeNumber 72000\n\n/////////////////////////////\n//K Machine parameters\n/////////////////////////////\n\n//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=72000\n\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 1. //KParameter 1.>>10.\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 2. //KParameter 0.5>>40.\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\n//const float travelSpeed = -100.;\nconst float dim = 120.;\nconst float off = 0.3;\n\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\n \n \n float prog = (_shapeId / _shapeCount)+_timeB;\n \n vec3 p0 = getCurvePoint(prog + off * 0.);\n vec3 p1 = getCurvePoint(prog + off * 1.);\n vec3 p2 = getCurvePoint(prog + off * 2.);\n \n vec3 np0 = normalize(p1 - p0);\n vec3 np1 = normalize(p2 - p1);\n \n vec3 zaxis = normalize(np1 - np0);\n vec3 xaxis = normalize(cross(np0, np1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n //position matrix\n _wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(p0 * dim, 1)); \n \n //orientation matrix\n vec3 eye = p0 * dim + zaxis * 1.;\n vec3 target = p1 * dim + zaxis;\n vec3 up = yaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nmat4 rotationMatrix(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n \n //shape\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\n \n \n float timeB = 4.5;\n timeB = time * tubeSpeedFactor;\n\n /*\n vec3 b0 = getCurvePoint(base + off * 0.);\n vec3 b1 = getCurvePoint(base + off * 1.);\n vec3 b2 = getCurvePoint(base + off * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n \n vec3 eye = b0 * expand + czaxis * 1.;\n vec3 target = b1 * expand + czaxis;\n vec3 up = cyaxis;\n */\n \n /* \n//Static eye\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\n vec3 up = vec3(0.5, 0.5, 1.5);\n */\n \n \n //Following eye\n float sv = 0.;//mod( (0. /2.)+time*0.,groupCount) / 1.;\n float v = sv + timeB;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n /*\n //rotation around eye z axis\n mat4 rotMat = rotationMatrix(zaxis, time*PI);\n xaxis = (rotMat*vec4(xaxis,1.)).xyz;\n yaxis = (rotMat*vec4(yaxis,1.)).xyz;\n*/\n //\n \n vec3 eye = r1 * dim + zaxis * 1.;\n vec3 target = r2 * dim + zaxis;\n vec3 up = yaxis;\n \n \n //mat4 cmat = inverse(lookAt(eye, target, up));\n mat4 vmat = inverse(lookAt(eye, target, up));\n \n \n \n \n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n //cubep*= sizeFactor;\n\n mat4 scaleMat = scale(vec3(1.*cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n mat4 zrot = rotZ(relGroupId*2.*PI);\n cubep = (zrot*vec4(cubep,1.)).xyz;\n //cbNi*=scaleMat;\n \n //create the circle group\n \n \n \n float radius = 100.*radiusSizeFactor;\n cubep.x+= radius*sin(2.*PI*relGroupId);\n cubep.y+= radius*cos(2.*PI*relGroupId);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n vec4 color;\n \n \n //shapeId = mod(shapeId+time, shapeCount);\n //base+= mod(time,2.);\n mat4 posmat;\n mat4 rotmat;\n \n \n getTrajMat(mod(shapeId-time*cudeSpeedFactor,shapeCount), shapeCount, timeB, posmat, rotmat);\n \n //shape orientation\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\n cbNi = cbNi*rotmat;\n \n //shape position\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\n //cbNi.xyz+= posi;\n \n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-agt2hl9oupveicbdk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RLCfXFKZw5SjhED9h/art.json b/art/RLCfXFKZw5SjhED9h/art.json index 0291442a..9eae504c 100644 --- a/art/RLCfXFKZw5SjhED9h/art.json +++ b/art/RLCfXFKZw5SjhED9h/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "amagitakayosi", "avatarUrl": "https://secure.gravatar.com/avatar/14084b6462b19a8512ce5208a76f8925?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2Fad1ca2d3c1d7383c5f34676d7fced9ad", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float across = floor(sqrt(vertexCount));\\n float x = mod(vertexId, across) / across;\\n float y = floor(vertexId / across) / across;\\n x = x* 3. - 1.5;\\n y = y* 3. - 1.5; \\n \\n float u = x + sin(time * y) * .02;\\n float v = y + cos(time * x) * 4.; \\n \\n gl_Position = vec4(u, v, 0, 1);\\n gl_PointSize = 300. / across;\\n\\n v_color = vec4(0, 1, 1, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float across = floor(sqrt(vertexCount));\n float x = mod(vertexId, across) / across;\n float y = floor(vertexId / across) / across;\n x = x* 3. - 1.5;\n y = y* 3. - 1.5; \n \n float u = x + sin(time * y) * .02;\n float v = y + cos(time * x) * 4.; \n \n gl_Position = vec4(u, v, 0, 1);\n gl_PointSize = 300. / across;\n\n v_color = vec4(0, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-uchu34856j7pg0bop-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RM7eRS2ZAytCwuqj5/art.json b/art/RM7eRS2ZAytCwuqj5/art.json index b64c7bbd..89e6b2d9 100644 --- a/art/RM7eRS2ZAytCwuqj5/art.json +++ b/art/RM7eRS2ZAytCwuqj5/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "8bitrick", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/queroxmusic/querox-phaxe-tripical-moon\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI 3.14159\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) { return v * 2. - 1.; }\\n\\nvoid main()\\n{\\n float ROWS = 15.;\\n float verts_per_row = vertexCount / ROWS;\\n float row = floor(vertexId / verts_per_row);\\n float row_per = row / (ROWS-1.);\\n float freq = (vertexId / (vertexCount - 1.)) * 0.6 + 0.1;\\n vec2 center = vec2(m1p1(hash(row_per)), m1p1(hash(hash(row_per))));\\n \\n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\\n float x = vertex_per;\\n //float y = texture2D(sound,vec2(vertex_per*0.90+0.1,0.)).a;// + (row_per) - 1. + hash(row_per);\\n float y = texture2D(sound,vec2(freq, 0.)).a;// + (row_per) - 1. + hash(row_per);\\n \\n float angle = x * 2. * PI;\\n vec2 xy = (center + vec2(cos(angle), sin(angle)) * y) * 0.7;\\n \\n gl_PointSize = 10.0;\\n gl_Position = vec4(xy,0,1);\\n v_color = mix(vec4(hsv2rgb(vec3(y*0.21, 1.-y, 1.)), 1.-row_per), background, row_per - 0.2);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/queroxmusic/querox-phaxe-tripical-moon", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI 3.14159\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) { return v * 2. - 1.; }\n\nvoid main()\n{\n float ROWS = 15.;\n float verts_per_row = vertexCount / ROWS;\n float row = floor(vertexId / verts_per_row);\n float row_per = row / (ROWS-1.);\n float freq = (vertexId / (vertexCount - 1.)) * 0.6 + 0.1;\n vec2 center = vec2(m1p1(hash(row_per)), m1p1(hash(hash(row_per))));\n \n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\n float x = vertex_per;\n //float y = texture2D(sound,vec2(vertex_per*0.90+0.1,0.)).a;// + (row_per) - 1. + hash(row_per);\n float y = texture2D(sound,vec2(freq, 0.)).a;// + (row_per) - 1. + hash(row_per);\n \n float angle = x * 2. * PI;\n vec2 xy = (center + vec2(cos(angle), sin(angle)) * y) * 0.7;\n \n gl_PointSize = 10.0;\n gl_Position = vec4(xy,0,1);\n v_color = mix(vec4(hsv2rgb(vec3(y*0.21, 1.-y, 1.)), 1.-row_per), background, row_per - 0.2);\n}\n" + }, "screenshotURL": "data/images/images-ch46y5wl0su5531d9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RNPaQH4DP4FJeTJZi/art.json b/art/RNPaQH4DP4FJeTJZi/art.json index 4efb5865..9cce03a2 100644 --- a/art/RNPaQH4DP4FJeTJZi/art.json +++ b/art/RNPaQH4DP4FJeTJZi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0.0, 0.0, 0.0, 0.0);\\n gl_PointSize = 10.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0.0, 0.0, 0.0, 0.0);\n gl_PointSize = 10.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-51ay7b78ym2hx9un9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RNvmyLxwWoWWorb59/art.json b/art/RNvmyLxwWoWWorb59/art.json index 489320a6..0beea40d 100644 --- a/art/RNvmyLxwWoWWorb59/art.json +++ b/art/RNvmyLxwWoWWorb59/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "ninja", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14Gj-w1Ghj5YMiIFpayQEZMuePeU64oQTM2GR_7wc-Q", - "settings": "{\"num\":74709,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3333333333333333,0.3333333333333333,0.3333333333333333,1],\"shader\":\"void main()\\n{\\n \\n float x = mod(vertexId,10.0);\\n float y = ceil(vertexId/10.0) * vertexCount/123123.0;\\n \\n float u = x/10.0;\\n float v = y/10.0;\\n \\n gl_Position = vec4(u - 0.5 ,v - 0.5 ,0,1);\\n gl_PointSize = 10.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 74709, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3333333333333333, + 0.3333333333333333, + 0.3333333333333333, + 1 + ], + "shader": "void main()\n{\n \n float x = mod(vertexId,10.0);\n float y = ceil(vertexId/10.0) * vertexCount/123123.0;\n \n float u = x/10.0;\n float v = y/10.0;\n \n gl_Position = vec4(u - 0.5 ,v - 0.5 ,0,1);\n gl_PointSize = 10.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-tnvlrihybkx0zf10f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RRi3txAyxdQDsZW35/art.json b/art/RRi3txAyxdQDsZW35/art.json index 76216f7b..b6ac3fba 100644 --- a/art/RRi3txAyxdQDsZW35/art.json +++ b/art/RRi3txAyxdQDsZW35/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":41536,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ACROSS 1000\\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define HASHSCALE1 .1031\\n#define HASHSCALE3 vec3(.1031, .1030, .0973)\\n#define HASHSCALE4 vec4(.1031, .1030, .0973, .1099)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 1 out, 2 in...\\nfloat hash12(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 1 out, 3 in...\\nfloat hash13(vec3 p3)\\n{\\n\\tp3 = fract(p3 * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 2 out, 1 in...\\nvec2 hash21(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * HASHSCALE3);\\n\\tp3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.xx+p3.yz)*p3.zy);\\n\\n}\\n\\n//----------------------------------------------------------------------------------------\\n/// 2 out, 2 in...\\nvec2 hash22(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE3);\\n p3 += dot(p3, p3.yzx+19.19);\\n return fract((p3.xx+p3.yz)*p3.zy);\\n\\n}\\n\\n//----------------------------------------------------------------------------------------\\n/// 2 out, 3 in...\\nvec2 hash23(vec3 p3)\\n{\\n\\tp3 = fract(p3 * HASHSCALE3);\\n p3 += dot(p3, p3.yzx+19.19);\\n return fract((p3.xx+p3.yz)*p3.zy);\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 3 out, 1 in...\\nvec3 hash31(float p)\\n{\\n vec3 p3 = fract(vec3(p) * HASHSCALE3);\\n p3 += dot(p3, p3.yzx+19.19);\\n return fract((p3.xxy+p3.yzz)*p3.zyx); \\n}\\n\\n\\n//----------------------------------------------------------------------------------------\\n/// 3 out, 2 in...\\nvec3 hash32(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE3);\\n p3 += dot(p3, p3.yxz+19.19);\\n return fract((p3.xxy+p3.yzz)*p3.zyx);\\n}\\n\\n//----------------------------------------------------------------------------------------\\n/// 3 out, 3 in...\\nvec3 hash33(vec3 p3)\\n{\\n\\tp3 = fract(p3 * HASHSCALE3);\\n p3 += dot(p3, p3.yxz+19.19);\\n return fract((p3.xxy + p3.yxx)*p3.zyx);\\n\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 4 out, 1 in...\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * HASHSCALE4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\\n \\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 4 out, 2 in...\\nvec4 hash42(vec2 p)\\n{\\n\\tvec4 p4 = fract(vec4(p.xyxy) * HASHSCALE4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\\n\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 4 out, 3 in...\\nvec4 hash43(vec3 p)\\n{\\n\\tvec4 p4 = fract(vec4(p.xyzx) * HASHSCALE4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\\n}\\n\\n//----------------------------------------------------------------------------------------\\n// 4 out, 4 in...\\nvec4 hash44(vec4 p4)\\n{\\n\\tp4 = fract(p4 * HASHSCALE4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\\n}\\n\\nfloat thash12(vec2 p) {\\n\\treturn fract(sin(dot(p, vec2(12.9898, 78.233))) * 43758.5453);\\n}\\n\\nvec3 thash33(vec3 p) {\\n\\tp = vec3( dot(p,vec3(127.1,311.7, 74.7)),\\n\\t\\t\\t dot(p,vec3(269.5,183.3,246.1)),\\n\\t\\t\\t dot(p,vec3(113.5,271.9,124.6)));\\n\\treturn fract(sin(p)*43758.5453123);\\n}\\n\\nmat3 rotX( float fAngle ) {\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n return mat3( 1.0, 0.0, 0.0, \\n 0.0, c, s,\\n 0.0, -s, c ); \\n}\\n\\n\\nmat3 rotY( float fAngle ) {\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 rotZ( float fAngle ) {\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\n\\nmat4 projection(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\\n vec3 vr = normalize(pb - pa);\\n vec3 vu = normalize(pc - pa);\\n vec3 vn = cross(vr, vu);\\n vec3 va = pa - pe;\\n vec3 vb = pb - pe;\\n vec3 vc = pc - pe;\\n float d = -dot(va, vn);\\n float nod = n / d;\\n float l = dot(vr, va) * nod;\\n float r = dot(vr, vb) * nod;\\n float b = dot(vu, va) * nod;\\n float t = dot(vu, vc) * nod;\\n\\n // glFrustum\\n float x = 2. * n / (r - l);\\n float y = 2. * n / (t - b);\\n float A = (r + l) / (r - l);\\n float B = (t + b) / (t - b);\\n float C = -(f + n) / (f - n);\\n float D = -2. * f * n / (f - n);\\n mat4 P = mat4(\\n x, 0, 0, 0,\\n 0, y, 0, 0,\\n A, B, C, -1.,\\n 0, 0, D, 0.\\n );\\n return P;\\n}\\n\\nmat4 camera(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\\n vec3 vr = normalize(pb - pa);\\n vec3 vu = normalize(pc - pa);\\n vec3 vn = cross(vr, vu);\\n mat4 cam = mat4(\\n vec4(vr, 0), \\n vec4(vu, 0), \\n vec4(vn, 0), \\n vec4(-pe, 1));\\n return cam;\\n}\\n\\nvec2 quad(float id) {\\n float ux = floor(id / 6.) + mod (id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n float x = ux;\\n float y = vy;\\n // generate vertices [-1, 1] x [-,1 1]\\n return 2. * mod(vec2(x, y), vec2(2, 2)) - 1.;\\n}\\n\\nvec3 position(float id) {\\n // For across = 2, we want:\\n // x -> [0; 6], [1; 6]\\n // y -> [0; 6], [1; 6]\\n // quad 0, id = 0 - 6\\n // x -> 0\\n // y -> 0\\n // quad 1, id = 6 - 12\\n // x -> 1\\n // y -> 0\\n // quad 2, id = 12 - 18\\n // x -> 0\\n // y -> 1\\n float across = 100.;\\n float x = mod(floor(id / 6.), across);\\n float y = floor(id / (6. * across));\\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n float ux = 2. * u - 1.;\\n float vy = 2. * v - 1.;\\n return vec3(ux, vy, 0);\\n}\\n\\nvec3 position_offset(float id) {\\n vec3 pos = position(id);\\n vec3 offset = thash33(pos.xyz);\\n offset = 2. * offset - 1.;\\n return offset;\\n}\\n\\nfloat circleSDF(float radius, vec2 pos) {\\n return length(pos) - radius;\\n}\\n\\nvoid main() {\\n // screen + camera setup\\n float screen_width_mm = 350.90; // 14 inch\\n float screen_height_mm = 247.1; // \\n float head_to_screen_mm = 300.; // 1 ft\\n vec3 pa = 0.5 * vec3(-screen_width_mm, -screen_height_mm, 0);\\n vec3 pb = 0.5 * vec3(screen_width_mm, -screen_height_mm, 0);\\n vec3 pc = 0.5 * vec3(-screen_width_mm, screen_height_mm, 0);\\n vec3 pe = 1.*vec3(0, 0, head_to_screen_mm);\\n float n = 0.1;\\n float f = 10000.;\\n mat4 P = projection(pa, pb, pc, pe, n, f);\\n mat4 C = camera(pa, pb, pc, pe, n, f);\\n\\n // write the position\\n float id = vertexId;\\n float param = 0.5 + 0.5 * sin(time);\\n vec3 world_scale = vec3(20, 20, 100);\\n vec3 pos_offset = position_offset(id);\\n vec3 xyz = position(id) + world_scale*pos_offset;\\n\\n float sphere_radius = 20.;\\n vec3 sphere_xyz = vec3(0);\\n sphere_xyz.z = -(3. * world_scale.z - mod(time, 10.) * 0.6 * world_scale.z);\\n float sphere_dist = length(xyz - sphere_xyz) - sphere_radius;\\n float m = 5. * sphere_radius;\\n float s = 1.4 * sphere_radius + 60.0*hash11(xyz.z);\\n //float s = 80.*hash11(id);\\n vec3 scatter_dir = normalize(2. * hash33(pos_offset) - 1.);\\n xyz.xy += scatter_dir.xy * s * smoothstep(1.*m, -1.0*m, sphere_dist);\\n\\n xyz = xyz + vec3(quad(id), 0);\\n mat3 model = rotX(3.14 * -.3) * rotZ(3.14 * time * 0.5 * pos_offset.z);\\n gl_Position = P * C * vec4(model * (xyz + 0.5*vec3(quad(id), 0)), 1.0);\\n\\n // write the color\\n vec4 base = vec4(0.1 * hash13(position(id)));\\n base.a = 0.15;\\n vec4 shocked = vec4(0.4 * hsv2rgb(vec3(1. - 0.1*pos_offset.z, 1., 1.)), 0.2);\\n v_color = mix(base, shocked, smoothstep(1.*m, -1.*m, sphere_dist));\\n}\"}", + "settings": { + "num": 41536, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ACROSS 1000\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define HASHSCALE1 .1031\n#define HASHSCALE3 vec3(.1031, .1030, .0973)\n#define HASHSCALE4 vec4(.1031, .1030, .0973, .1099)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n//----------------------------------------------------------------------------------------\n// 1 out, 2 in...\nfloat hash12(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n//----------------------------------------------------------------------------------------\n// 1 out, 3 in...\nfloat hash13(vec3 p3)\n{\n\tp3 = fract(p3 * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n//----------------------------------------------------------------------------------------\n// 2 out, 1 in...\nvec2 hash21(float p)\n{\n\tvec3 p3 = fract(vec3(p) * HASHSCALE3);\n\tp3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.xx+p3.yz)*p3.zy);\n\n}\n\n//----------------------------------------------------------------------------------------\n/// 2 out, 2 in...\nvec2 hash22(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE3);\n p3 += dot(p3, p3.yzx+19.19);\n return fract((p3.xx+p3.yz)*p3.zy);\n\n}\n\n//----------------------------------------------------------------------------------------\n/// 2 out, 3 in...\nvec2 hash23(vec3 p3)\n{\n\tp3 = fract(p3 * HASHSCALE3);\n p3 += dot(p3, p3.yzx+19.19);\n return fract((p3.xx+p3.yz)*p3.zy);\n}\n\n//----------------------------------------------------------------------------------------\n// 3 out, 1 in...\nvec3 hash31(float p)\n{\n vec3 p3 = fract(vec3(p) * HASHSCALE3);\n p3 += dot(p3, p3.yzx+19.19);\n return fract((p3.xxy+p3.yzz)*p3.zyx); \n}\n\n\n//----------------------------------------------------------------------------------------\n/// 3 out, 2 in...\nvec3 hash32(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE3);\n p3 += dot(p3, p3.yxz+19.19);\n return fract((p3.xxy+p3.yzz)*p3.zyx);\n}\n\n//----------------------------------------------------------------------------------------\n/// 3 out, 3 in...\nvec3 hash33(vec3 p3)\n{\n\tp3 = fract(p3 * HASHSCALE3);\n p3 += dot(p3, p3.yxz+19.19);\n return fract((p3.xxy + p3.yxx)*p3.zyx);\n\n}\n\n//----------------------------------------------------------------------------------------\n// 4 out, 1 in...\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * HASHSCALE4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\n \n}\n\n//----------------------------------------------------------------------------------------\n// 4 out, 2 in...\nvec4 hash42(vec2 p)\n{\n\tvec4 p4 = fract(vec4(p.xyxy) * HASHSCALE4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\n\n}\n\n//----------------------------------------------------------------------------------------\n// 4 out, 3 in...\nvec4 hash43(vec3 p)\n{\n\tvec4 p4 = fract(vec4(p.xyzx) * HASHSCALE4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\n}\n\n//----------------------------------------------------------------------------------------\n// 4 out, 4 in...\nvec4 hash44(vec4 p4)\n{\n\tp4 = fract(p4 * HASHSCALE4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract((p4.xxyz+p4.yzzw)*p4.zywx);\n}\n\nfloat thash12(vec2 p) {\n\treturn fract(sin(dot(p, vec2(12.9898, 78.233))) * 43758.5453);\n}\n\nvec3 thash33(vec3 p) {\n\tp = vec3( dot(p,vec3(127.1,311.7, 74.7)),\n\t\t\t dot(p,vec3(269.5,183.3,246.1)),\n\t\t\t dot(p,vec3(113.5,271.9,124.6)));\n\treturn fract(sin(p)*43758.5453123);\n}\n\nmat3 rotX( float fAngle ) {\n float s = sin( fAngle );\n float c = cos( fAngle );\n return mat3( 1.0, 0.0, 0.0, \n 0.0, c, s,\n 0.0, -s, c ); \n}\n\n\nmat3 rotY( float fAngle ) {\n float s = sin( fAngle );\n float c = cos( fAngle );\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 rotZ( float fAngle ) {\n float s = sin( fAngle );\n float c = cos( fAngle );\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\n\nmat4 projection(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\n vec3 vr = normalize(pb - pa);\n vec3 vu = normalize(pc - pa);\n vec3 vn = cross(vr, vu);\n vec3 va = pa - pe;\n vec3 vb = pb - pe;\n vec3 vc = pc - pe;\n float d = -dot(va, vn);\n float nod = n / d;\n float l = dot(vr, va) * nod;\n float r = dot(vr, vb) * nod;\n float b = dot(vu, va) * nod;\n float t = dot(vu, vc) * nod;\n\n // glFrustum\n float x = 2. * n / (r - l);\n float y = 2. * n / (t - b);\n float A = (r + l) / (r - l);\n float B = (t + b) / (t - b);\n float C = -(f + n) / (f - n);\n float D = -2. * f * n / (f - n);\n mat4 P = mat4(\n x, 0, 0, 0,\n 0, y, 0, 0,\n A, B, C, -1.,\n 0, 0, D, 0.\n );\n return P;\n}\n\nmat4 camera(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\n vec3 vr = normalize(pb - pa);\n vec3 vu = normalize(pc - pa);\n vec3 vn = cross(vr, vu);\n mat4 cam = mat4(\n vec4(vr, 0), \n vec4(vu, 0), \n vec4(vn, 0), \n vec4(-pe, 1));\n return cam;\n}\n\nvec2 quad(float id) {\n float ux = floor(id / 6.) + mod (id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n float x = ux;\n float y = vy;\n // generate vertices [-1, 1] x [-,1 1]\n return 2. * mod(vec2(x, y), vec2(2, 2)) - 1.;\n}\n\nvec3 position(float id) {\n // For across = 2, we want:\n // x -> [0; 6], [1; 6]\n // y -> [0; 6], [1; 6]\n // quad 0, id = 0 - 6\n // x -> 0\n // y -> 0\n // quad 1, id = 6 - 12\n // x -> 1\n // y -> 0\n // quad 2, id = 12 - 18\n // x -> 0\n // y -> 1\n float across = 100.;\n float x = mod(floor(id / 6.), across);\n float y = floor(id / (6. * across));\n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n float ux = 2. * u - 1.;\n float vy = 2. * v - 1.;\n return vec3(ux, vy, 0);\n}\n\nvec3 position_offset(float id) {\n vec3 pos = position(id);\n vec3 offset = thash33(pos.xyz);\n offset = 2. * offset - 1.;\n return offset;\n}\n\nfloat circleSDF(float radius, vec2 pos) {\n return length(pos) - radius;\n}\n\nvoid main() {\n // screen + camera setup\n float screen_width_mm = 350.90; // 14 inch\n float screen_height_mm = 247.1; // \n float head_to_screen_mm = 300.; // 1 ft\n vec3 pa = 0.5 * vec3(-screen_width_mm, -screen_height_mm, 0);\n vec3 pb = 0.5 * vec3(screen_width_mm, -screen_height_mm, 0);\n vec3 pc = 0.5 * vec3(-screen_width_mm, screen_height_mm, 0);\n vec3 pe = 1.*vec3(0, 0, head_to_screen_mm);\n float n = 0.1;\n float f = 10000.;\n mat4 P = projection(pa, pb, pc, pe, n, f);\n mat4 C = camera(pa, pb, pc, pe, n, f);\n\n // write the position\n float id = vertexId;\n float param = 0.5 + 0.5 * sin(time);\n vec3 world_scale = vec3(20, 20, 100);\n vec3 pos_offset = position_offset(id);\n vec3 xyz = position(id) + world_scale*pos_offset;\n\n float sphere_radius = 20.;\n vec3 sphere_xyz = vec3(0);\n sphere_xyz.z = -(3. * world_scale.z - mod(time, 10.) * 0.6 * world_scale.z);\n float sphere_dist = length(xyz - sphere_xyz) - sphere_radius;\n float m = 5. * sphere_radius;\n float s = 1.4 * sphere_radius + 60.0*hash11(xyz.z);\n //float s = 80.*hash11(id);\n vec3 scatter_dir = normalize(2. * hash33(pos_offset) - 1.);\n xyz.xy += scatter_dir.xy * s * smoothstep(1.*m, -1.0*m, sphere_dist);\n\n xyz = xyz + vec3(quad(id), 0);\n mat3 model = rotX(3.14 * -.3) * rotZ(3.14 * time * 0.5 * pos_offset.z);\n gl_Position = P * C * vec4(model * (xyz + 0.5*vec3(quad(id), 0)), 1.0);\n\n // write the color\n vec4 base = vec4(0.1 * hash13(position(id)));\n base.a = 0.15;\n vec4 shocked = vec4(0.4 * hsv2rgb(vec3(1. - 0.1*pos_offset.z, 1., 1.)), 0.2);\n v_color = mix(base, shocked, smoothstep(1.*m, -1.*m, sphere_dist));\n}" + }, "screenshotURL": "data/images/images-29udcfgi4z50blicm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RSCshw9mQCvMmvyzw/art.json b/art/RSCshw9mQCvMmvyzw/art.json index 154a1dcc..674d9518 100644 --- a/art/RSCshw9mQCvMmvyzw/art.json +++ b/art/RSCshw9mQCvMmvyzw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/nocopyrightsounds/alan-walker-dreamer-ncs-release\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 3.0, 0.5 / 10.0, 6.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n#define PI radians(180.0)\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.9;\\n float yoff = sin(time + x * 0.1) * 0.7;\\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\n \\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .05)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + 1.1 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.1, 5.) * 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float pump = step(0.7, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0. , 1. , pump);//1.;\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/nocopyrightsounds/alan-walker-dreamer-ncs-release", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 3.0, 0.5 / 10.0, 6.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n#define PI radians(180.0)\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.9;\n float yoff = sin(time + x * 0.1) * 0.7;\n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n \n \n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .05)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + 1.1 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.1, 5.) * 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float pump = step(0.7, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0. , 1. , pump);//1.;\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-clzk9aqyun5iclc0v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RWjPnvTPcF45HvKFo/art.json b/art/RWjPnvTPcF45HvKFo/art.json index ec814037..3ed02cac 100644 --- a/art/RWjPnvTPcF45HvKFo/art.json +++ b/art/RWjPnvTPcF45HvKFo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, cv)*0.18, cv / 10. * .8)).a;\\n \\n s = mix(0.0, 1.3, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, cv)*0.18, cv / 10. * .8)).a;\n \n s = mix(0.0, 1.3, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-zpjy0emz9q3hml032-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RYrCnYygNSqgtTDKi/art.json b/art/RYrCnYygNSqgtTDKi/art.json index 786be533..aafe22dd 100644 --- a/art/RYrCnYygNSqgtTDKi/art.json +++ b/art/RYrCnYygNSqgtTDKi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":82331,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 11\\\\\\\\ 13\\\\\\\\ 15,(16,17) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n \\n \\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\nfloat sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\\n gl_PointSize=sample*3.0;\\ngl_Position.z=(sample);\\n v_color =vec4(sample);\\n \\n \\n}\"}", + "settings": { + "num": 82331, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n \n \n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\nfloat sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\n gl_PointSize=sample*3.0;\ngl_Position.z=(sample);\n v_color =vec4(sample);\n \n \n}" + }, "screenshotURL": "data/images/images-g3itdjhq4zurornkq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RYzSiASv8yuq6xWHJ/art.json b/art/RYzSiASv8yuq6xWHJ/art.json index c86bd3a1..e7ad3a3f 100644 --- a/art/RYzSiASv8yuq6xWHJ/art.json +++ b/art/RYzSiASv8yuq6xWHJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-rzignx03v5jbcjfj4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RZ3HmsB9XBnW5yn7k/art.json b/art/RZ3HmsB9XBnW5yn7k/art.json index 8447bf7d..751e34fc 100644 --- a/art/RZ3HmsB9XBnW5yn7k/art.json +++ b/art/RZ3HmsB9XBnW5yn7k/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/graham-panter/lotus\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvoid main() {\\n float pointsAroundCircle = 240.;\\n float pointsPerCircle = pointsAroundCircle * 2.;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float vId = mod(vertexId, pointsPerCircle);\\n float pointId = floor(vId / 2.) + mod(vId, 2.);\\n float pointV = pointId / (pointsAroundCircle - 1.);\\n \\n float circleV = circleId / (numCircles - 1.);\\n float odd = mod(circleId, 2.);\\n float quad = mod(floor(circleId / 2.), 2.);\\n \\n float tm = time * 4. - circleV;\\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .5;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float off = mix(.0, 0.953, circleV);\\n\\n float su = hash(pointV * 13.7);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.5)).a;\\n \\n float q = (odd + quad * 2.) / 3.;\\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\\n \\n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 17.)/sq);\\n float scale = mix(\\n mix(\\n mix(.4, .5, circleV),\\n mix(-.4, snd/1.3, circleV),\\n odd),\\n mix(\\n mix(.1, .15, circleV),\\n mix(-.1, -.05, circleV),\\n odd),\\n quad) + pow(sq, 10.) * .1;\\n \\n gl_Position = vec4(xy * aspect * scale, circleV, 1);\\n\\n float hue = 0.5 + odd * .5 + quad * .125;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/graham-panter/lotus", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvoid main() {\n float pointsAroundCircle = 240.;\n float pointsPerCircle = pointsAroundCircle * 2.;\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float vId = mod(vertexId, pointsPerCircle);\n float pointId = floor(vId / 2.) + mod(vId, 2.);\n float pointV = pointId / (pointsAroundCircle - 1.);\n \n float circleV = circleId / (numCircles - 1.);\n float odd = mod(circleId, 2.);\n float quad = mod(floor(circleId / 2.), 2.);\n \n float tm = time * 4. - circleV;\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .5;\n float c = cos(angle);\n float s = sin(angle);\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float off = mix(.0, 0.953, circleV);\n\n float su = hash(pointV * 13.7);\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.5)).a;\n \n float q = (odd + quad * 2.) / 3.;\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\n \n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 17.)/sq);\n float scale = mix(\n mix(\n mix(.4, .5, circleV),\n mix(-.4, snd/1.3, circleV),\n odd),\n mix(\n mix(.1, .15, circleV),\n mix(-.1, -.05, circleV),\n odd),\n quad) + pow(sq, 10.) * .1;\n \n gl_Position = vec4(xy * aspect * scale, circleV, 1);\n\n float hue = 0.5 + odd * .5 + quad * .125;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-s32bl6rwot1h2gvmf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RZLFdeaBCJsCmp6Qg/art.json b/art/RZLFdeaBCJsCmp6Qg/art.json index 7cb2d04d..569eb326 100644 --- a/art/RZLFdeaBCJsCmp6Qg/art.json +++ b/art/RZLFdeaBCJsCmp6Qg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":120,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main ()\\n{\\n \\n float ux = floor(vertexId/ 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 1.0), 2.0);\\n\\n float angle = ux/ 20.0 * radians(180.0) * 2.0; //el 20 es como la resolucion convertir, pi radianes por 2( gados de un circulo) , entre 20(ocupar 20 segmentos), lo que necesitas para formar un circulo \\n float radius = vy + 1.0; // el radio del circulo es uno, va a ir girando, centro vacio 1\\n // ux mas a la derecha , 0, 1 ,2 ,3 ...\\n float x =radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n // x = radius * cos(angle) funcionan en radianes \\n // y = radius * sin(angle)\\n \\n vec2 xy = vec2(x,y);\\n \\n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n \\n \\n \\n \\n \\n}\"}", + "settings": { + "num": 120, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main ()\n{\n \n float ux = floor(vertexId/ 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 1.0), 2.0);\n\n float angle = ux/ 20.0 * radians(180.0) * 2.0; //el 20 es como la resolucion convertir, pi radianes por 2( gados de un circulo) , entre 20(ocupar 20 segmentos), lo que necesitas para formar un circulo \n float radius = vy + 1.0; // el radio del circulo es uno, va a ir girando, centro vacio 1\n // ux mas a la derecha , 0, 1 ,2 ,3 ...\n float x =radius * cos(angle);\n float y = radius * sin(angle);\n \n // x = radius * cos(angle) funcionan en radianes \n // y = radius * sin(angle)\n \n vec2 xy = vec2(x,y);\n \n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n \n \n \n \n \n}" + }, "screenshotURL": "data/images/images-ze7ujesz1usfvmy2g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RanZJwjv68Hjs5i4d/art.json b/art/RanZJwjv68Hjs5i4d/art.json index 5ab191e2..11e7bf04 100644 --- a/art/RanZJwjv68Hjs5i4d/art.json +++ b/art/RanZJwjv68Hjs5i4d/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":353,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Making a Grid\\n// CS250 Spring 2022\\n\\n\\nvoid main()\\n{\\n float down = floor(vertexCount / 2.0);\\n float isOdd = mod(vertexId, 2.0);\\n \\n float x = floor(mod(vertexId - isOdd, down));\\n \\n float u = x / (down - 2.0);\\n \\n float ux = u * 2.0 - 1.0;\\n \\n bool isVertical = vertexId < vertexCount / 2.0;\\n if (isVertical)\\n {\\n \\tgl_Position = vec4(ux, isOdd * 2.0 - 1.0, 0.0, 1.0);\\n }\\n else\\n {\\n \\tgl_Position = vec4(isOdd * 2.0 - 1.0, ux, 0.0, 1.0);\\n }\\n \\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 353, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Making a Grid\n// CS250 Spring 2022\n\n\nvoid main()\n{\n float down = floor(vertexCount / 2.0);\n float isOdd = mod(vertexId, 2.0);\n \n float x = floor(mod(vertexId - isOdd, down));\n \n float u = x / (down - 2.0);\n \n float ux = u * 2.0 - 1.0;\n \n bool isVertical = vertexId < vertexCount / 2.0;\n if (isVertical)\n {\n \tgl_Position = vec4(ux, isOdd * 2.0 - 1.0, 0.0, 1.0);\n }\n else\n {\n \tgl_Position = vec4(isOdd * 2.0 - 1.0, ux, 0.0, 1.0);\n }\n \n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-w9v42ee95ugh32azm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RbbKsGLiEeMtCfCjQ/art.json b/art/RbbKsGLiEeMtCfCjQ/art.json index 832863c6..aa777d6c 100644 --- a/art/RbbKsGLiEeMtCfCjQ/art.json +++ b/art/RbbKsGLiEeMtCfCjQ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":97200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 3, 3, s,\\n 0, c, s, 2,\\n 0, -s, c, 2,\\n s, 1, 1, c); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, c+s, 0, 0,\\n s, 0, c, 0,\\n 0, s, 0, c); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, s, time, \\n s, c, 0, 0,\\n time, 0, c, 0,\\n s, 0, 0, c); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 1, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, time);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, s,\\n 0, s, s, 0,\\n 0, s, s, 0,\\n s, 0, 0, 1.5);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) / around * PI * 2.)\\n );\\n \\n float tm = time * 1.1;\\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.5, 2.5, pow(s + .15, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float odd = mod(floor(quadId / 2.), 2.);\\n float hue = time * .1 +s * .15;\\n float sat = mix(0., 3., pow(s, 5.));\\n float val = mix(0.1, 1., pow(s + .4, 15.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 97200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 3, 3, s,\n 0, c, s, 2,\n 0, -s, c, 2,\n s, 1, 1, c); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, c+s, 0, 0,\n s, 0, c, 0,\n 0, s, 0, c); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, s, time, \n s, c, 0, 0,\n time, 0, c, 0,\n s, 0, 0, c); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 1, 1, 0, 0,\n 0, 0, 1, 0,\n trans, time);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, s,\n 0, s, s, 0,\n 0, s, s, 0,\n s, 0, 0, 1.5);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) / around * PI * 2.)\n );\n \n float tm = time * 1.1;\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.5, 2.5, pow(s + .15, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float odd = mod(floor(quadId / 2.), 2.);\n float hue = time * .1 +s * .15;\n float sat = mix(0., 3., pow(s, 5.));\n float val = mix(0.1, 1., pow(s + .4, 15.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-spypv3eti4ge0i3nf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RdimY5SHzK3msAHm4/art.json b/art/RdimY5SHzK3msAHm4/art.json index a8aa0560..b280f167 100644 --- a/art/RdimY5SHzK3msAHm4/art.json +++ b/art/RdimY5SHzK3msAHm4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":17762,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n//KVertices_Number=16666\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye-snd), -dot(-yAxis*snd, 0.-eye/snd), .5-dot(zAxis, eye-8.82+snd), 3.*snd); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5*mouse.y);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 2.);\\n float cv = cy / (down - 2.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(.2, 1.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .2 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*3.) * 9.5;\\n vec3 up = vec3(0.5,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 2.*-snd) * 1. + abs(ca)+snd * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 2. + abs(cd) * 6.);\\n float sc = mix(0.02, 1.25, pow(snd + 0.23, 2.));\\n mat *= scale(vec3(0.93 * sc-snd, sc, 0.6 * sc)*.6*snd);\\n \\n \\n gl_Position = mat * vec4(pos, 2);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.2 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd * 1.8, 5.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*.09*snd, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.15 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 17762, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n\n//KVertices_Number=16666\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye-snd), -dot(-yAxis*snd, 0.-eye/snd), .5-dot(zAxis, eye-8.82+snd), 3.*snd); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5*mouse.y);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 2.);\n float cv = cy / (down - 2.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(.2, 1.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .2 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*3.) * 9.5;\n vec3 up = vec3(0.5,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 2.*-snd) * 1. + abs(ca)+snd * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 2. + abs(cd) * 6.);\n float sc = mix(0.02, 1.25, pow(snd + 0.23, 2.));\n mat *= scale(vec3(0.93 * sc-snd, sc, 0.6 * sc)*.6*snd);\n \n \n gl_Position = mat * vec4(pos, 2);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.2 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd * 1.8, 5.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*.09*snd, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.15 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-f694wuro4td9j0k6g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RdipyP4yy3xT5cbP5/art.json b/art/RdipyP4yy3xT5cbP5/art.json index 7155cb1b..5348d0e6 100644 --- a/art/RdipyP4yy3xT5cbP5/art.json +++ b/art/RdipyP4yy3xT5cbP5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.28627450980392155,0.8117647058823529,0.24705882352941178,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.04) + 2.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0014) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.28627450980392155, + 0.8117647058823529, + 0.24705882352941178, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.04) + 2.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0014) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-nl7k0orbtsxiydsvx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RedmMGmXH2o8ZDTMQ/art.json b/art/RedmMGmXH2o8ZDTMQ/art.json index 274d04ab..4162c29a 100644 --- a/art/RedmMGmXH2o8ZDTMQ/art.json +++ b/art/RedmMGmXH2o8ZDTMQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-7im5d10evtvfaxewa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RfQDsEbCqannGyZe2/art.json b/art/RfQDsEbCqannGyZe2/art.json index 987773d8..33392352 100644 --- a/art/RfQDsEbCqannGyZe2/art.json +++ b/art/RfQDsEbCqannGyZe2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.141594\\n//#define FIT_VERTICAL\\n\\nvec3 computeVert(float angle, float H) {\\n float STEP = time*0.7;\\n float R = (cos(H * 2.6 + STEP * 2.5 + sin(STEP * 14.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\\n R *= sin((H + 4.0) * 0.375);\\n \\n float Q = cos(STEP * 0.54 + H * 0.7);\\n float dX = cos(H * 1.4) * Q * 1.5;\\n float dY = sin(H * 0.75) * Q * 0.4;\\n float dZ = sin(H * 0.5) * Q * 0.15;\\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\\n}\\n\\nvec3 computeNorm(float angle, float H) {\\n float dA = 0.01;\\n float dH = 0.01;\\n vec3 A = computeVert(angle, H);\\n vec3 B = computeVert(angle + dA, H);\\n vec3 C = computeVert(angle, H + dH);\\n return normalize(-cross((B-A)/dA,(C-A)/dH));\\n}\\n\\nvoid main() {\\n int NUM_ROT =76;\\n float dH = 0.05;\\n \\n float STEP = time*0.7;\\n \\n int base = int(vertexId) /5;\\n int level = int(base) / NUM_ROT;\\n int idx = int(mod(vertexId,8.0*sin(time*min(mouse.x+1.5,3.))));\\n vec3 xyz = vec3(0,0,0);\\n vec3 N = normalize(vec3(1,0,0));\\n \\n float dA = 2.0 * PI / float(NUM_ROT);\\n\\n float H = float(level) * dH - 4.0;\\n float angle = float(base) * dA;\\n \\n if (idx == 0) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n if (idx == 1) {\\n \\txyz = computeVert(angle + dA, H);\\n \\tN = computeNorm(angle + dA, H);\\n }\\n if (idx == 2) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n \\n if (idx == 3) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n if (idx == 4) {\\n \\txyz = computeVert(angle, H + dH);\\n \\tN = computeNorm(angle, H + dH);\\n }\\n if (idx == 5) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n \\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n \\n float Cs = cos(STEP);\\n float Si = sin(STEP);\\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\\n xyz *= 0.3;\\n //xyz *= rot;\\n //N *= rot;\\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\\n \\n vec3 light = normalize(vec3(1,1,-1));\\n vec3 V = vec3(0,0,1);\\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\\n vec3 A_col = vec3(1,1,1) * N * rot2;\\n vec3 D_col = vec3(1,1,1) * N;\\n vec3 S_col = vec3(1,1,1);\\n vec3 LUM = A * A_col + D * D_col +S * S_col;\\n v_color = vec4(LUM, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.141594\n//#define FIT_VERTICAL\n\nvec3 computeVert(float angle, float H) {\n float STEP = time*0.7;\n float R = (cos(H * 2.6 + STEP * 2.5 + sin(STEP * 14.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\n R *= sin((H + 4.0) * 0.375);\n \n float Q = cos(STEP * 0.54 + H * 0.7);\n float dX = cos(H * 1.4) * Q * 1.5;\n float dY = sin(H * 0.75) * Q * 0.4;\n float dZ = sin(H * 0.5) * Q * 0.15;\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\n}\n\nvec3 computeNorm(float angle, float H) {\n float dA = 0.01;\n float dH = 0.01;\n vec3 A = computeVert(angle, H);\n vec3 B = computeVert(angle + dA, H);\n vec3 C = computeVert(angle, H + dH);\n return normalize(-cross((B-A)/dA,(C-A)/dH));\n}\n\nvoid main() {\n int NUM_ROT =76;\n float dH = 0.05;\n \n float STEP = time*0.7;\n \n int base = int(vertexId) /5;\n int level = int(base) / NUM_ROT;\n int idx = int(mod(vertexId,8.0*sin(time*min(mouse.x+1.5,3.))));\n vec3 xyz = vec3(0,0,0);\n vec3 N = normalize(vec3(1,0,0));\n \n float dA = 2.0 * PI / float(NUM_ROT);\n\n float H = float(level) * dH - 4.0;\n float angle = float(base) * dA;\n \n if (idx == 0) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n if (idx == 1) {\n \txyz = computeVert(angle + dA, H);\n \tN = computeNorm(angle + dA, H);\n }\n if (idx == 2) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n \n if (idx == 3) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n if (idx == 4) {\n \txyz = computeVert(angle, H + dH);\n \tN = computeNorm(angle, H + dH);\n }\n if (idx == 5) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n \n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n \n float Cs = cos(STEP);\n float Si = sin(STEP);\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\n xyz *= 0.3;\n //xyz *= rot;\n //N *= rot;\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\n \n vec3 light = normalize(vec3(1,1,-1));\n vec3 V = vec3(0,0,1);\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\n vec3 A_col = vec3(1,1,1) * N * rot2;\n vec3 D_col = vec3(1,1,1) * N;\n vec3 S_col = vec3(1,1,1);\n vec3 LUM = A * A_col + D * D_col +S * S_col;\n v_color = vec4(LUM, 1);\n}" + }, "screenshotURL": "data/images/images-iflh54mfysjelrwja-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Rfe9EhWQ5Pe2SD9JR/art.json b/art/Rfe9EhWQ5Pe2SD9JR/art.json index 471ed57b..90ebe284 100644 --- a/art/Rfe9EhWQ5Pe2SD9JR/art.json +++ b/art/Rfe9EhWQ5Pe2SD9JR/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "jc", "avatarUrl": "https://lh6.googleusercontent.com/-wxkmpL8A-s0/AAAAAAAAAAI/AAAAAAAAAFg/cZuqYtkpOCI/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7803921568627451,0.7843137254901961,0.803921568627451,1],\"shader\":\"void circle()\\n{\\n float xC = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float yC = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = xC / 20.0 * radians(180.0) * 2.0;\\n float radius = yC + 1.0;\\n \\n float xPC = radius * cos(angle);\\n float yPC = radius * sin(angle);\\n \\n vec2 xyPC = vec2(xPC,yPC);\\n \\n gl_Position = vec4(xyPC * 0.1, 0.0, 1.0);\\n}\\n\\nvoid main()\\n{\\n \\n float width = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n \\n float u = x / (width);\\n float v = y / (width);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n vec2 xy = vec2(ux, vy) * 1.0;\\n \\n gl_Position = vec4 (xy, 0.0, 1.0);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 32.0 / width;\\n \\n v_color= vec4(0.0, 1.0, 0.0, 1.0);\\n \\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7803921568627451, + 0.7843137254901961, + 0.803921568627451, + 1 + ], + "shader": "void circle()\n{\n float xC = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float yC = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = xC / 20.0 * radians(180.0) * 2.0;\n float radius = yC + 1.0;\n \n float xPC = radius * cos(angle);\n float yPC = radius * sin(angle);\n \n vec2 xyPC = vec2(xPC,yPC);\n \n gl_Position = vec4(xyPC * 0.1, 0.0, 1.0);\n}\n\nvoid main()\n{\n \n float width = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n \n float u = x / (width);\n float v = y / (width);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n vec2 xy = vec2(ux, vy) * 1.0;\n \n gl_Position = vec4 (xy, 0.0, 1.0);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 32.0 / width;\n \n v_color= vec4(0.0, 1.0, 0.0, 1.0);\n \n}" + }, "screenshotURL": "data/images/images-08lgdtpg3jlma0m5l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RfnraoGGxrRDND4T8/art.json b/art/RfnraoGGxrRDND4T8/art.json index 17a5d74a..932c704a 100644 --- a/art/RfnraoGGxrRDND4T8/art.json +++ b/art/RfnraoGGxrRDND4T8/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "gitanely", "avatarUrl": "https://secure.gravatar.com/avatar/d5fdfe8b65ebd7057053c353e059209a?default=retro&size=200", - "settings": "{\"num\":1505,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main() {\\n vec2 scr = vec2(\\n \\t\\t vertexId / vertexCount * 2.0,\\n \\t\\t\\t vertexId / vertexCount * 2.0);\\n \\n \\n gl_Position.x = scr.x - 1.;//cos(time * scr.x) * scr.x;\\n gl_Position.y = sin(vertexId + time) * 1.;\\n gl_Position.y = tan(gl_Position.y + time) * 0.1;\\n gl_Position.z = 0.;\\n \\n \\n \\n\\n gl_Position.w = 1.; \\n gl_PointSize =2.5;\\n\\n v_color.xyz = hsv2rgb(vec3(time + scr.x * 0.1,1,1));\\n\\n\\n}\"}", + "settings": { + "num": 1505, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main() {\n vec2 scr = vec2(\n \t\t vertexId / vertexCount * 2.0,\n \t\t\t vertexId / vertexCount * 2.0);\n \n \n gl_Position.x = scr.x - 1.;//cos(time * scr.x) * scr.x;\n gl_Position.y = sin(vertexId + time) * 1.;\n gl_Position.y = tan(gl_Position.y + time) * 0.1;\n gl_Position.z = 0.;\n \n \n \n\n gl_Position.w = 1.; \n gl_PointSize =2.5;\n\n v_color.xyz = hsv2rgb(vec3(time + scr.x * 0.1,1,1));\n\n\n}" + }, "screenshotURL": "data/images/images-qq5t0i4xsj3bkg2tf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RfrwmKH4fQMA3Pmxf/art.json b/art/RfrwmKH4fQMA3Pmxf/art.json index 856da8b1..a933f683 100644 --- a/art/RfrwmKH4fQMA3Pmxf/art.json +++ b/art/RfrwmKH4fQMA3Pmxf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/powerglove/telecom\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// bleep bloop\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float numShapes = vertexCount / NUM_POINTS;\\n float cv = count / numShapes;\\n float offset = count * 0.02;\\n float ev = point / NUM_SEGMENTS;\\n float angle = ev * PI * 2.0 + offset * 0.1;\\n float radius = 0.2;\\n float c = cos(angle + time * 0.11) * radius;\\n float s = sin(angle + time * 0.11) * radius;\\n float orbitAngle = count * 0.01;\\n \\n float snd = texture2D(sound, vec2(ev * 0.1, cv * .1)).x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\\n\\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\\n vec2 xy = vec2(\\n c,\\n s);\\n gl_Position = vec4(xy * aspect * scale, 0, 1);\\n\\n float hue = cv * 0.2;\\n float unf = step(0.8, snd);\\n v_color = vec4(hsv2rgb(vec3(ev * 0.1 + 0.95, unf, hue + unf)), unf);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/powerglove/telecom", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// bleep bloop\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float numShapes = vertexCount / NUM_POINTS;\n float cv = count / numShapes;\n float offset = count * 0.02;\n float ev = point / NUM_SEGMENTS;\n float angle = ev * PI * 2.0 + offset * 0.1;\n float radius = 0.2;\n float c = cos(angle + time * 0.11) * radius;\n float s = sin(angle + time * 0.11) * radius;\n float orbitAngle = count * 0.01;\n \n float snd = texture2D(sound, vec2(ev * 0.1, cv * .1)).x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.;\n\n float scale = pow(cv + 0.5, 2.7) + pow(snd, 5.0) * 3.;\n vec2 xy = vec2(\n c,\n s);\n gl_Position = vec4(xy * aspect * scale, 0, 1);\n\n float hue = cv * 0.2;\n float unf = step(0.8, snd);\n v_color = vec4(hsv2rgb(vec3(ev * 0.1 + 0.95, unf, hue + unf)), unf);\n}" + }, "screenshotURL": "data/images/images-6q3paa8xndiwvos71-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RgpnRrekYqf65qH3v/art.json b/art/RgpnRrekYqf65qH3v/art.json index ed6c07b5..346524dc 100644 --- a/art/RgpnRrekYqf65qH3v/art.json +++ b/art/RgpnRrekYqf65qH3v/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":90,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0392156862745098,0.0392156862745098,0.0392156862745098,1],\"shader\":\"#define PI radians(180.0)\\n\\nmat4 proj() {\\n return mat4(\\n vec4(1.0, 0.0, 0.0, 0.0),\\n vec4(0.0, 1.0, 0.0, 0.0),\\n vec4(0.0, 0.0, 1.0, 0.0),\\n vec4(0.0, 0.0, 0.0, 1.0)\\n );\\n}\\n\\nvoid main() {\\n float pointId = vertexId;\\n float t = abs(0.01 * time) + (vertexId / vertexCount);\\n \\n \\n float theta = 37.*(PI) * t;\\n float phi = 71.*PI * t; \\n float r = 0.5;\\n\\n float x = r * sin(theta) * 1.;// cos(phi);\\n float y = r * cos(theta) * cos(phi);\\n \\n v_color = mix(\\n vec4(1.0, 0.0, 0.0, 1.0),\\n vec4(0.0, 1.0, 0.0, 1.0),\\n fract(t)\\n );\\n \\n x += 0.30;\\n x += 0.5 * mouse.x;\\n y += 0.5 * mouse.y;\\n\\n\\n y *= resolution.x/resolution.y;\\n vec3 pos = vec3(x, y, 0.0);\\n gl_Position = proj() * vec4(pos, 1.0);\\n gl_PointSize = 4.0;\\n \\n} \"}", + "settings": { + "num": 90, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0392156862745098, + 0.0392156862745098, + 0.0392156862745098, + 1 + ], + "shader": "#define PI radians(180.0)\n\nmat4 proj() {\n return mat4(\n vec4(1.0, 0.0, 0.0, 0.0),\n vec4(0.0, 1.0, 0.0, 0.0),\n vec4(0.0, 0.0, 1.0, 0.0),\n vec4(0.0, 0.0, 0.0, 1.0)\n );\n}\n\nvoid main() {\n float pointId = vertexId;\n float t = abs(0.01 * time) + (vertexId / vertexCount);\n \n \n float theta = 37.*(PI) * t;\n float phi = 71.*PI * t; \n float r = 0.5;\n\n float x = r * sin(theta) * 1.;// cos(phi);\n float y = r * cos(theta) * cos(phi);\n \n v_color = mix(\n vec4(1.0, 0.0, 0.0, 1.0),\n vec4(0.0, 1.0, 0.0, 1.0),\n fract(t)\n );\n \n x += 0.30;\n x += 0.5 * mouse.x;\n y += 0.5 * mouse.y;\n\n\n y *= resolution.x/resolution.y;\n vec3 pos = vec3(x, y, 0.0);\n gl_Position = proj() * vec4(pos, 1.0);\n gl_PointSize = 4.0;\n \n} " + }, "screenshotURL": "data/images/images-4altxb2xfowxhqt8w-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Ri8Y9A63oZsG2BkYf/art.json b/art/Ri8Y9A63oZsG2BkYf/art.json index b148e295..6695047c 100644 --- a/art/Ri8Y9A63oZsG2BkYf/art.json +++ b/art/Ri8Y9A63oZsG2BkYf/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ignacio-montero-villar/young-wild-and-free-ft-bruno\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Audio Reactive - Geumbi Yeo\\n// Course : CS250\\n// Term & Year : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main()\\n{\\n float PI = 3.1415926535;\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = (u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / (PI / 2.);\\n float av = length(vec2(sv, su));\\n float snd = texture2D(sound, vec2(av * .1, au * .3)).a * 1.2; \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 3.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.85, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1 * cos(time * 2.); //sin(time + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump * abs(sin(time * 4.))); //mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/ignacio-montero-villar/young-wild-and-free-ft-bruno", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Audio Reactive - Geumbi Yeo\n// Course : CS250\n// Term & Year : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main()\n{\n float PI = 3.1415926535;\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = (u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / (PI / 2.);\n float av = length(vec2(sv, su));\n float snd = texture2D(sound, vec2(av * .1, au * .3)).a * 1.2; \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 3.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.85, snd);\n float hue = u * .1 + snd * 0.2 + time * .1 * cos(time * 2.); //sin(time + v * 20.) * 0.05;\n float sat = mix(0., 1., pump * abs(sin(time * 4.))); //mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-6nu0eaxw0lt07eosb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Rj6BcdcHrfFGGfN27/art.json b/art/Rj6BcdcHrfFGGfN27/art.json index bab169f0..d19b1548 100644 --- a/art/Rj6BcdcHrfFGGfN27/art.json +++ b/art/Rj6BcdcHrfFGGfN27/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TWOPI 6.28318530718\\n#define PI 3.14159265359\\n#define DEG2RAD 0.01745329251\\n#define RAD2DEG 57.2957795131\\n#define HASHSCALE1 .1031\\n\\nfloat hash11(float p) {\\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat3 rotX(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat3(1.0, 0.0, 0.0, 0.0, c, s, 0.0, -s, c);\\n}\\n\\nmat3 rotY(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat3(c, 0.0, s, 0.0, 1.0, 0.0, -s, 0.0, c);\\n}\\n\\nmat3 rotZ(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat3(c, s, 0.0, -s, c, 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nmat4 perspective(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\\n vec3 vr = normalize(pb - pa);\\n vec3 vu = normalize(pc - pa);\\n vec3 vn = cross(vr, vu);\\n vec3 va = pa - pe;\\n vec3 vb = pb - pe;\\n vec3 vc = pc - pe;\\n float d = -dot(va, vn);\\n float nod = n / d;\\n float l = dot(vr, va) * nod;\\n float r = dot(vr, vb) * nod;\\n float b = dot(vu, va) * nod;\\n float t = dot(vu, vc) * nod;\\n\\n // glFrustum\\n float x = 2. * n / (r - l);\\n float y = 2. * n / (t - b);\\n float A = (r + l) / (r - l);\\n float B = (t + b) / (t - b);\\n float C = -(f + n) / (f - n);\\n float D = -2. * f * n / (f - n);\\n mat4 P = mat4(\\n x, 0, 0, 0,\\n 0, y, 0, 0,\\n A, B, C, -1,\\n 0, 0, D, 0\\n );\\n return P;\\n}\\n\\nmat4 camera(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\\n vec3 vr = normalize(pb - pa);\\n vec3 vu = normalize(pc - pa);\\n vec3 vn = cross(vr, vu);\\n mat4 cam = mat4(\\n vec4(vr, 0),\\n vec4(vu, 0),\\n vec4(vn, 0),\\n vec4(-pe, 1));\\n return cam;\\n}\\n\\nvec2 quad(float id) {\\n float ux = floor(id / 6.) + mod (id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n float x = ux;\\n float y = vy;\\n // generate vertices [-1, 1] x [-,1 1]\\n return 2. * mod(vec2(x, y), vec2(2, 2)) - 1.;\\n}\\n\\n\\nvoid main() {\\n // screen + camera setup\\n float screen_width_mm = 350.90;\\n float screen_height_mm = 247.1;\\n float aspect = screen_width_mm / screen_height_mm;\\n float head_to_screen_mm = 1000.;\\n vec3 pa = 0.5 * vec3(-screen_width_mm, -screen_height_mm, 0);\\n vec3 pb = 0.5 * vec3(screen_width_mm, -screen_height_mm, 0);\\n vec3 pc = 0.5 * vec3(-screen_width_mm, screen_height_mm, 0);\\n vec3 pe = vec3(0, 0, head_to_screen_mm);\\n float n = 0.01;\\n float f = 2000.;\\n mat4 P = perspective(pa, pb, pc, pe, n, f);\\n mat4 C = camera(pa, pb, pc, pe, n, f);\\n \\n float quad_id = floor(vertexId / 6.0);\\n float quad_count = floor(vertexCount / 6.0);\\n float quad_hash = hash11(quad_id + 5.0);\\n float quad_pct = quad_id / quad_count;\\n\\n vec2 quad_size = vec2(1.0);\\n quad_size.x *= aspect;\\n\\n float wrap = (0.5 + 0.5 * sin(0.15*time)) * 50.0;\\n float r = (0.2 + 0.1*sin(50.0*quad_pct * TWOPI)) * screen_height_mm;\\n float x = r * cos(wrap * quad_pct * TWOPI);\\n float y = r * sin(wrap * quad_pct * TWOPI);\\n float z = (quad_pct - 0.5) * 0.7 * screen_height_mm;\\n vec3 worldPos = \\n rotX(DEG2RAD * 45.0) * \\n rotY(DEG2RAD * 33.0) * \\n (vec3(quad_size * quad(vertexId), 0.0) + vec3(x,y,z));\\n vec4 camPos = C * vec4(worldPos, 1.0);\\n gl_Position = P *camPos;\\n\\n // write the color\\n vec3 hsv = vec3(0.5 + 0.2 * quad_pct, 0.9, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TWOPI 6.28318530718\n#define PI 3.14159265359\n#define DEG2RAD 0.01745329251\n#define RAD2DEG 57.2957795131\n#define HASHSCALE1 .1031\n\nfloat hash11(float p) {\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat3 rotX(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat3(1.0, 0.0, 0.0, 0.0, c, s, 0.0, -s, c);\n}\n\nmat3 rotY(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat3(c, 0.0, s, 0.0, 1.0, 0.0, -s, 0.0, c);\n}\n\nmat3 rotZ(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat3(c, s, 0.0, -s, c, 0.0, 0.0, 0.0, 1.0);\n}\n\nmat4 perspective(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\n vec3 vr = normalize(pb - pa);\n vec3 vu = normalize(pc - pa);\n vec3 vn = cross(vr, vu);\n vec3 va = pa - pe;\n vec3 vb = pb - pe;\n vec3 vc = pc - pe;\n float d = -dot(va, vn);\n float nod = n / d;\n float l = dot(vr, va) * nod;\n float r = dot(vr, vb) * nod;\n float b = dot(vu, va) * nod;\n float t = dot(vu, vc) * nod;\n\n // glFrustum\n float x = 2. * n / (r - l);\n float y = 2. * n / (t - b);\n float A = (r + l) / (r - l);\n float B = (t + b) / (t - b);\n float C = -(f + n) / (f - n);\n float D = -2. * f * n / (f - n);\n mat4 P = mat4(\n x, 0, 0, 0,\n 0, y, 0, 0,\n A, B, C, -1,\n 0, 0, D, 0\n );\n return P;\n}\n\nmat4 camera(vec3 pa, vec3 pb, vec3 pc, vec3 pe, float n, float f) {\n vec3 vr = normalize(pb - pa);\n vec3 vu = normalize(pc - pa);\n vec3 vn = cross(vr, vu);\n mat4 cam = mat4(\n vec4(vr, 0),\n vec4(vu, 0),\n vec4(vn, 0),\n vec4(-pe, 1));\n return cam;\n}\n\nvec2 quad(float id) {\n float ux = floor(id / 6.) + mod (id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n float x = ux;\n float y = vy;\n // generate vertices [-1, 1] x [-,1 1]\n return 2. * mod(vec2(x, y), vec2(2, 2)) - 1.;\n}\n\n\nvoid main() {\n // screen + camera setup\n float screen_width_mm = 350.90;\n float screen_height_mm = 247.1;\n float aspect = screen_width_mm / screen_height_mm;\n float head_to_screen_mm = 1000.;\n vec3 pa = 0.5 * vec3(-screen_width_mm, -screen_height_mm, 0);\n vec3 pb = 0.5 * vec3(screen_width_mm, -screen_height_mm, 0);\n vec3 pc = 0.5 * vec3(-screen_width_mm, screen_height_mm, 0);\n vec3 pe = vec3(0, 0, head_to_screen_mm);\n float n = 0.01;\n float f = 2000.;\n mat4 P = perspective(pa, pb, pc, pe, n, f);\n mat4 C = camera(pa, pb, pc, pe, n, f);\n \n float quad_id = floor(vertexId / 6.0);\n float quad_count = floor(vertexCount / 6.0);\n float quad_hash = hash11(quad_id + 5.0);\n float quad_pct = quad_id / quad_count;\n\n vec2 quad_size = vec2(1.0);\n quad_size.x *= aspect;\n\n float wrap = (0.5 + 0.5 * sin(0.15*time)) * 50.0;\n float r = (0.2 + 0.1*sin(50.0*quad_pct * TWOPI)) * screen_height_mm;\n float x = r * cos(wrap * quad_pct * TWOPI);\n float y = r * sin(wrap * quad_pct * TWOPI);\n float z = (quad_pct - 0.5) * 0.7 * screen_height_mm;\n vec3 worldPos = \n rotX(DEG2RAD * 45.0) * \n rotY(DEG2RAD * 33.0) * \n (vec3(quad_size * quad(vertexId), 0.0) + vec3(x,y,z));\n vec4 camPos = C * vec4(worldPos, 1.0);\n gl_Position = P *camPos;\n\n // write the color\n vec3 hsv = vec3(0.5 + 0.2 * quad_pct, 0.9, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n}" + }, "screenshotURL": "data/images/images-16qyqfa0chapelt6u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RjKNeXgMi8SchMEXg/art.json b/art/RjKNeXgMi8SchMEXg/art.json index 41b6157e..31b39243 100644 --- a/art/RjKNeXgMi8SchMEXg/art.json +++ b/art/RjKNeXgMi8SchMEXg/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "rubinhuang9239", "avatarUrl": "https://avatars.githubusercontent.com/Rubinhuang9239?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.11372549019607843,0.07450980392156863,0.26666666666666666,1],\"shader\":\"void main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor (vertexCount/down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x/ (across - 1.0);\\n \\tfloat v = y/ (across - 1.0);\\n \\n float ux = u*2.0-1.0;\\n float vy = v*2.0-1.0;\\n \\n\\tgl_Position = vec4(ux, vy,0.0,1.0);\\n\\tgl_PointSize = 10.0;\\n \\tgl_PointSize *= 20.0/across;\\t\\n \\tgl_PointSize *= resolution.x/600.0;\\t\\n \\n \\tv_color = vec4(1.0);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.11372549019607843, + 0.07450980392156863, + 0.26666666666666666, + 1 + ], + "shader": "void main() {\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor (vertexCount/down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x/ (across - 1.0);\n \tfloat v = y/ (across - 1.0);\n \n float ux = u*2.0-1.0;\n float vy = v*2.0-1.0;\n \n\tgl_Position = vec4(ux, vy,0.0,1.0);\n\tgl_PointSize = 10.0;\n \tgl_PointSize *= 20.0/across;\t\n \tgl_PointSize *= resolution.x/600.0;\t\n \n \tv_color = vec4(1.0);\n \n}" + }, "screenshotURL": "data/images/images-q7iznfg78f2yhau25-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RkS9eZ4fjYjak9w78/art.json b/art/RkS9eZ4fjYjak9w78/art.json index 88a8ce8c..fe7d8dc1 100644 --- a/art/RkS9eZ4fjYjak9w78/art.json +++ b/art/RkS9eZ4fjYjak9w78/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n #define PI radians(180.)\\n #define TAU 6.283185307179586\\n\\n float lerp(float a, float b, float amt)\\n {\\n return a + (b-a)*amt;\\n }\\n\\n float func(float t)\\n {\\n return t/pow(t,t);\\n }\\n\\n void main()\\n {\\n float ph = vertexId/vertexCount;\\n float angle = ph *TAU*20.;\\n float w = lerp(.2, 3.0, vertexId/ vertexCount);\\n vec2 pos = vec2(\\n cos(angle+ ph*5.)* w, \\n sin(angle +sin(PI/2.+time*0.1)*5.) *w\\n );\\n\\n vec2 aspect = vec2(1., resolution.x/resolution.y);\\n pos *= pow((mouse.x+1.)/2.,0.2);\\n //pos *= (mouse.y+1.)/2.;\\n gl_Position = vec4(pos * aspect * 1., 0.,1.);\\n\\n vec3 col = vec3(\\n 0.5,\\n sin(ph*PI +time * 0.13),\\n sin(ph*PI +time * 0.17)\\n );\\n col = abs(col);\\n\\n float ps = func(ph*6.);\\n gl_PointSize = pow(ps,0.4) * 10.;\\n v_color = vec4(col, 1.);\\n }\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n #define PI radians(180.)\n #define TAU 6.283185307179586\n\n float lerp(float a, float b, float amt)\n {\n return a + (b-a)*amt;\n }\n\n float func(float t)\n {\n return t/pow(t,t);\n }\n\n void main()\n {\n float ph = vertexId/vertexCount;\n float angle = ph *TAU*20.;\n float w = lerp(.2, 3.0, vertexId/ vertexCount);\n vec2 pos = vec2(\n cos(angle+ ph*5.)* w, \n sin(angle +sin(PI/2.+time*0.1)*5.) *w\n );\n\n vec2 aspect = vec2(1., resolution.x/resolution.y);\n pos *= pow((mouse.x+1.)/2.,0.2);\n //pos *= (mouse.y+1.)/2.;\n gl_Position = vec4(pos * aspect * 1., 0.,1.);\n\n vec3 col = vec3(\n 0.5,\n sin(ph*PI +time * 0.13),\n sin(ph*PI +time * 0.17)\n );\n col = abs(col);\n\n float ps = func(ph*6.);\n gl_PointSize = pow(ps,0.4) * 10.;\n v_color = vec4(col, 1.);\n }" + }, "screenshotURL": "data/images/images-cfufti5go80600sye-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RkZ8yDec9HRBYHmvX/art.json b/art/RkZ8yDec9HRBYHmvX/art.json index 25ebdeec..6dc39fe0 100644 --- a/art/RkZ8yDec9HRBYHmvX/art.json +++ b/art/RkZ8yDec9HRBYHmvX/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jan-ale", "avatarUrl": "https://avatars.githubusercontent.com/jan-ale?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/inabakumori/wasurenbounonekokaburi\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float size = 10.;\\n float xPos = mod(vertexId/size,1.);\\n xPos *= 2.;\\n xPos -= 1.;\\n float yPos = vertexId/size;\\n yPos = floor(yPos);\\n yPos /= size;\\n yPos *= 2.;\\n yPos -= 1.;\\n \\n float volume = texture2D(sound, vec2(0., time)).a;\\n xPos += 0.3 * mix(-volume, volume, mod(5.*yPos,2.));\\n \\n gl_Position = vec4(xPos, yPos, 0., 1.);\\n gl_PointSize = 10. * volume;\\n vec3 col = sin(time+vec3(0.,2.,4.));\\n v_color = vec4(col, 1.);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/inabakumori/wasurenbounonekokaburi", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float size = 10.;\n float xPos = mod(vertexId/size,1.);\n xPos *= 2.;\n xPos -= 1.;\n float yPos = vertexId/size;\n yPos = floor(yPos);\n yPos /= size;\n yPos *= 2.;\n yPos -= 1.;\n \n float volume = texture2D(sound, vec2(0., time)).a;\n xPos += 0.3 * mix(-volume, volume, mod(5.*yPos,2.));\n \n gl_Position = vec4(xPos, yPos, 0., 1.);\n gl_PointSize = 10. * volume;\n vec3 col = sin(time+vec3(0.,2.,4.));\n v_color = vec4(col, 1.);\n}" + }, "screenshotURL": "data/images/images-y8qreiss8zgwlri48-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Rkg7vqW56XS6yjEbT/art.json b/art/Rkg7vqW56XS6yjEbT/art.json index 235b9811..9ab700ce 100644 --- a/art/Rkg7vqW56XS6yjEbT/art.json +++ b/art/Rkg7vqW56XS6yjEbT/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/huilo-1/amon-tobin-bedtime-stories\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 3.27) + sin(t * 3.13) + sin(t * 3.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 2.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 1.)) * 0.05, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.5, 0.6, fract(circleId * 1.79));\\n float sat = 0.5;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/huilo-1/amon-tobin-bedtime-stories", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 3.27) + sin(t * 3.13) + sin(t * 3.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 2.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 1.)) * 0.05, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.5, 0.6, fract(circleId * 1.79));\n float sat = 0.5;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-jljp0py2vt0xtq07c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RnoNQS8C8DpLZCNWv/art.json b/art/RnoNQS8C8DpLZCNWv/art.json index 430eb75b..1577b76e 100644 --- a/art/RnoNQS8C8DpLZCNWv/art.json +++ b/art/RnoNQS8C8DpLZCNWv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":80185,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 3.//KParameter0 0.>>10.\\n#define parameter1 1.//KParameter1 0.>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>1.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n#define PI radians(90.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0 - parameter7), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n parameter3, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1,-0.5, parameter5,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.3 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 1., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][0], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 80185, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 3.//KParameter0 0.>>10.\n#define parameter1 1.//KParameter1 0.>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>1.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n#define PI radians(90.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0 - parameter7), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n parameter3, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1,-0.5, parameter5,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.3 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 1., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][0], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-h217x89h2825f41y3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RnwjSt42YXLcGjsgT/art.json b/art/RnwjSt42YXLcGjsgT/art.json index 211f1202..e3648fb6 100644 --- a/art/RnwjSt42YXLcGjsgT/art.json +++ b/art/RnwjSt42YXLcGjsgT/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/protector-101/protector-101-a-dancing-comet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/protector-101/protector-101-a-dancing-comet", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-6gm5l9yd2b2ojl1ot-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RowjyMjajikHuDp7Z/art.json b/art/RowjyMjajikHuDp7Z/art.json index 9f2ca31e..748c80d8 100644 --- a/art/RowjyMjajikHuDp7Z/art.json +++ b/art/RowjyMjajikHuDp7Z/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "rubbermonkey", "avatarUrl": "https://secure.gravatar.com/avatar/add0cfea84de9b6257e0883d8f1d391d?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-0cvpfnm7qs42whi35-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Rp7GgqLK79srZtBn3/art.json b/art/Rp7GgqLK79srZtBn3/art.json index 85d22111..e6edc65a 100644 --- a/art/Rp7GgqLK79srZtBn3/art.json +++ b/art/Rp7GgqLK79srZtBn3/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.60), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 1.9-s, 0.2, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 1, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, s, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, s/2.0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0.1, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 2, 0.1, 0);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, mouse.x, 0, 0,\\n 0, s-2., 0, .1,\\n 0.5, 0, s, -mouse.y,\\n 0, 0, 0, -1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 85.3983, p * 45.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 34.3137));\\n\\treturn fract(p2.x * p2.y * 51.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 3.2 - 2.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.81 - (0.1*v);\\n}\\n\\nfloat inv(float v) {\\n return 2. * v - mouse.x;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.1);\\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 1.5 ); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE * 0.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI - tan(sin((1.6, 0.2) * PI - 1.10));\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v -s*2.;\\n float y = s * v-c;\\n float z = 0.05 * v;\\n pos = vec3(x, y, z -s * u/3.); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\\n float end = start - 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x/ 1.8 - 1.3)-7.) * 0.5, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3(4, resolution.y / resolution.x , mouse.y* 1.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 0. + snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(2.1 *v_color.rgb * v_color.a, v_color.a /9.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.60), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 1.9-s, 0.2, 0, 0,\n s, 0, c, 0,\n 0, 0, 1, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, s, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, s/2.0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1,\n 0, -1, 1, -0.9,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0.1, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 2, 0.1, 0);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, mouse.x, 0, 0,\n 0, s-2., 0, .1,\n 0.5, 0, s, -mouse.y,\n 0, 0, 0, -1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 85.3983, p * 45.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 34.3137));\n\treturn fract(p2.x * p2.y * 51.4337);\n}\n\nfloat m1p1(float v) {\n return v * 3.2 - 2.;\n}\n\nfloat p1m1(float v) {\n return v * 1.81 - (0.1*v);\n}\n\nfloat inv(float v) {\n return 2. * v - mouse.x;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.1);\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 1.5 ); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE * 0.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI - tan(sin((1.6, 0.2) * PI - 1.10));\n float s = sin(a);\n float c = cos(a);\n float x = c * v -s*2.;\n float y = s * v-c;\n float z = 0.05 * v;\n pos = vec3(x, y, z -s * u/3.); \n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\n float end = start - 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x/ 1.8 - 1.3)-7.) * 0.5, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3(4, resolution.y / resolution.x , mouse.y* 1.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 0. + snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(2.1 *v_color.rgb * v_color.a, v_color.a /9.0);\n}" + }, "screenshotURL": "data/images/images-2vciih4t6ng70eoe0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RtPtBzZA48whTSdM4/art.json b/art/RtPtBzZA48whTSdM4/art.json index 8f77cb0e..94c2bb25 100644 --- a/art/RtPtBzZA48whTSdM4/art.json +++ b/art/RtPtBzZA48whTSdM4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 5.0\\n\\n#define PI 3.1415\\n\\n#define RESOLUTION vec3(45.0)\\n#define SIZE vec3(2.5)\\n\\n// New hash based on hash13() from \\\"Hash without Sine\\\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\\n// 4 in, 1 out\\nfloat Hash41(in vec4 p) {\\n\\tp = fract(p * 0.1031);\\n p += dot(p, p.zwyx + 31.32);\\n return fract((p.x + p.y) * p.z - p.x * p.w);\\n}\\n\\n\\nfloat SmoothNoise4D(in vec4 p) {\\n vec4 cell = floor(p);\\n vec4 local = fract(p);\\n local *= local * (3.0 - 2.0 * local);\\n\\n float ldbq = Hash41(cell);\\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\\n float rufw = Hash41(cell + 1.0);\\n\\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\\n mix(lubq, rubq, local.x),\\n local.y),\\n\\n mix(mix(ldfq, rdfq, local.x),\\n mix(lufq, rufq, local.x),\\n local.y),\\n\\n local.z),\\n\\n mix(mix(mix(ldbw, rdbw, local.x),\\n mix(lubw, rubw, local.x),\\n local.y),\\n\\n mix(mix(ldfw, rdfw, local.x),\\n mix(lufw, rufw, local.x),\\n local.y),\\n\\n local.z),\\n\\n local.w);\\n}\\n\\nfloat FractalNoise4D(in vec4 p) {\\n p *= 2.0;\\n\\n float nscale = 1.0;\\n float tscale = 0.0;\\n float value = 0.0;\\n\\n for (int octave=0; octave < 5; octave++) {\\n value += SmoothNoise4D(p) * nscale;\\n tscale += nscale;\\n nscale *= 0.5;\\n p *= 1.0;\\n }\\n\\n return value / tscale;\\n}\\n\\nfloat mapShape(vec3 p) {\\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\\n}\\n\\nvec3 mapColor(in vec3 p) {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, .40));\\n vec2 e = vec2(0.001, 0.0);\\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\\n\\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\\n}\\n\\nvoid main() {\\n float t = time * 0.25;\\n\\n float cellId = vertexId;\\n float gridX = mod(cellId, RESOLUTION.x);\\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\\n\\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\\n vec3 color = mapColor(vertex);\\n\\n vec2 mouseRot = mouse * PI;\\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 5.0\n\n#define PI 3.1415\n\n#define RESOLUTION vec3(45.0)\n#define SIZE vec3(2.5)\n\n// New hash based on hash13() from \"Hash without Sine\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\n// 4 in, 1 out\nfloat Hash41(in vec4 p) {\n\tp = fract(p * 0.1031);\n p += dot(p, p.zwyx + 31.32);\n return fract((p.x + p.y) * p.z - p.x * p.w);\n}\n\n\nfloat SmoothNoise4D(in vec4 p) {\n vec4 cell = floor(p);\n vec4 local = fract(p);\n local *= local * (3.0 - 2.0 * local);\n\n float ldbq = Hash41(cell);\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\n float rufw = Hash41(cell + 1.0);\n\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\n mix(lubq, rubq, local.x),\n local.y),\n\n mix(mix(ldfq, rdfq, local.x),\n mix(lufq, rufq, local.x),\n local.y),\n\n local.z),\n\n mix(mix(mix(ldbw, rdbw, local.x),\n mix(lubw, rubw, local.x),\n local.y),\n\n mix(mix(ldfw, rdfw, local.x),\n mix(lufw, rufw, local.x),\n local.y),\n\n local.z),\n\n local.w);\n}\n\nfloat FractalNoise4D(in vec4 p) {\n p *= 2.0;\n\n float nscale = 1.0;\n float tscale = 0.0;\n float value = 0.0;\n\n for (int octave=0; octave < 5; octave++) {\n value += SmoothNoise4D(p) * nscale;\n tscale += nscale;\n nscale *= 0.5;\n p *= 1.0;\n }\n\n return value / tscale;\n}\n\nfloat mapShape(vec3 p) {\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\n}\n\nvec3 mapColor(in vec3 p) {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, .40));\n vec2 e = vec2(0.001, 0.0);\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\n\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\n}\n\nvoid main() {\n float t = time * 0.25;\n\n float cellId = vertexId;\n float gridX = mod(cellId, RESOLUTION.x);\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\n\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\n vec3 color = mapColor(vertex);\n\n vec2 mouseRot = mouse * PI;\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-jw6fp556wmuk9cuu4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RtuoYT8CXLbyZSsWE/art.json b/art/RtuoYT8CXLbyZSsWE/art.json index 8796ca5b..db0a8fef 100644 --- a/art/RtuoYT8CXLbyZSsWE/art.json +++ b/art/RtuoYT8CXLbyZSsWE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 1.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 18.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n //xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*80.,10.);\\n lineId/=numberOfElement;\\n\\n cubep*= min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n \\n cubep.x += cos(xPos*2.*PI);\\n cubep.y += sin(xPos*2.*PI);\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 0., 6.2);//29./2.*abs(cos(time/5.))\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 1.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 18.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n //xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*80.,10.);\n lineId/=numberOfElement;\n\n cubep*= min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n \n cubep.x += cos(xPos*2.*PI);\n cubep.y += sin(xPos*2.*PI);\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 0., 6.2);//29./2.*abs(cos(time/5.))\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-j2k2wpxhc1cqttjtl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Rv7oW8vbcGty8AYPb/art.json b/art/Rv7oW8vbcGty8AYPb/art.json index 1f5b2730..b9e21e6e 100644 --- a/art/Rv7oW8vbcGty8AYPb/art.json +++ b/art/Rv7oW8vbcGty8AYPb/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aticatac", "avatarUrl": "https://secure.gravatar.com/avatar/16cf649c9adc34f00e2d2acd119c4b37?default=retro&size=200", - "settings": "{\"num\":10,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1411764705882353,0.11764705882352941,0.11764705882352941,1],\"shader\":\"void main() {\\n gl_PointSize = 4.0;\\n \\n vec2 xy = vec2(vertexId / 14.0, vertexId / 14.0);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0); \\n}\"}", + "settings": { + "num": 10, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1411764705882353, + 0.11764705882352941, + 0.11764705882352941, + 1 + ], + "shader": "void main() {\n gl_PointSize = 4.0;\n \n vec2 xy = vec2(vertexId / 14.0, vertexId / 14.0);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0); \n}" + }, "screenshotURL": "data/images/images-jwlxpyu6j0ien51i9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RvWJ6QMocJKvfzo6E/art.json b/art/RvWJ6QMocJKvfzo6E/art.json index ed917b5c..5645c29b 100644 --- a/art/RvWJ6QMocJKvfzo6E/art.json +++ b/art/RvWJ6QMocJKvfzo6E/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n parameter3, c, s, 0,\\n 0, -s, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 1,\\n s, 0, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians/parameter5);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0.2,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n parameter3, c, s, 0,\n 0, -s, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 1,\n s, 0, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians/parameter5);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0.2,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-y17yag1psmvdzn36y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RwniHjBDJSzrREKMm/art.json b/art/RwniHjBDJSzrREKMm/art.json index 0a270298..5f664e65 100644 --- a/art/RwniHjBDJSzrREKMm/art.json +++ b/art/RwniHjBDJSzrREKMm/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jluethi", "avatarUrl": "https://secure.gravatar.com/avatar/21e93db3614e6e91a28d7f82b4e44433?default=retro&size=200", - "settings": "{\"num\":10155,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/jaems_lu/agoraphobia-310719-1618\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8117647058823529,0.9450980392156862,0.7843137254901961,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 20.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / .01) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(point*.1 , count*.1 )).a;\\n float offset = count * (0.2+ snd*0.001);\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = sin(time*0.1);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * .5, 0., 1);\\n\\n float hue = (snd * 0.001 + count * 2. );\\n v_color = vec4(hsv2rgb(vec3(hue, 0.5+0.3*snd, 1)), 1);\\n}\"}", + "settings": { + "num": 10155, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/jaems_lu/agoraphobia-310719-1618", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8117647058823529, + 0.9450980392156862, + 0.7843137254901961, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 20.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / .01) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(point*.1 , count*.1 )).a;\n float offset = count * (0.2+ snd*0.001);\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = sin(time*0.1);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * .5, 0., 1);\n\n float hue = (snd * 0.001 + count * 2. );\n v_color = vec4(hsv2rgb(vec3(hue, 0.5+0.3*snd, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-0rfq5y91xobex4cij-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/RzDd4oDNK7htc9dqe/art.json b/art/RzDd4oDNK7htc9dqe/art.json index 3aad23e9..c7455fe0 100644 --- a/art/RzDd4oDNK7htc9dqe/art.json +++ b/art/RzDd4oDNK7htc9dqe/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":2590,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8784313725490196,0.9333333333333333,0.8313725490196079,1],\"shader\":\"\\nconst float line = 3. ; \\nvec2 drawTriangle(in float vertexId ,out vec3 color )\\n{\\n vec2 res = vec2(1.);\\n // res.x = floor(mod(vertexId , line))/line;\\n // res.y = floor(vertexId/ line) ; \\n if(vertexId < (vertexCount / 3. ))\\n {\\n res.x = -0.5 ; \\n res.y = -0.5 ; \\n color.r = 1.;\\n color.g = 0. ; \\n color.b = 0. ; \\n \\n } \\n else if (vertexId > (vertexCount * 2. /3. )) \\n {\\n res.x = 0.5 ; \\n res.y = -0.5 ; \\n color.r = 0.;\\n color.g = 1. ; \\n color.b = 0. ; \\n }\\n else\\n {\\n res.x = 0. ; \\n res.y = 0.5 ;\\n color.r = 0.;\\n color.g = 0. ; \\n color.b = 1. ; \\n }\\n return res; \\n \\n}\\n\\nvoid main()\\n{\\n vec3 color = vec3(0.);\\n \\n \\n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\\n \\n gl_PointSize = 10. ; \\n \\n v_color = vec4(color , 1.0);\\n}\"}", + "settings": { + "num": 2590, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8784313725490196, + 0.9333333333333333, + 0.8313725490196079, + 1 + ], + "shader": "\nconst float line = 3. ; \nvec2 drawTriangle(in float vertexId ,out vec3 color )\n{\n vec2 res = vec2(1.);\n // res.x = floor(mod(vertexId , line))/line;\n // res.y = floor(vertexId/ line) ; \n if(vertexId < (vertexCount / 3. ))\n {\n res.x = -0.5 ; \n res.y = -0.5 ; \n color.r = 1.;\n color.g = 0. ; \n color.b = 0. ; \n \n } \n else if (vertexId > (vertexCount * 2. /3. )) \n {\n res.x = 0.5 ; \n res.y = -0.5 ; \n color.r = 0.;\n color.g = 1. ; \n color.b = 0. ; \n }\n else\n {\n res.x = 0. ; \n res.y = 0.5 ;\n color.r = 0.;\n color.g = 0. ; \n color.b = 1. ; \n }\n return res; \n \n}\n\nvoid main()\n{\n vec3 color = vec3(0.);\n \n \n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\n \n gl_PointSize = 10. ; \n \n v_color = vec4(color , 1.0);\n}" + }, "screenshotURL": "data/images/images-lt1p0bstdg9fo98xw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/RzgNiz5tqPwJL9Hzq/art.json b/art/RzgNiz5tqPwJL9Hzq/art.json index 6f09b5ad..3f0bee61 100644 --- a/art/RzgNiz5tqPwJL9Hzq/art.json +++ b/art/RzgNiz5tqPwJL9Hzq/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2158,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 11.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = 0.02;\\n float angle = point * PI * 1.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 2158, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 11.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = 0.02;\n float angle = point * PI * 1.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-kesq0l8usm1zg015c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/S24QeFuvJgsKJ3gdB/art.json b/art/S24QeFuvJgsKJ3gdB/art.json index 817f82a7..dfc948af 100644 --- a/art/S24QeFuvJgsKJ3gdB/art.json +++ b/art/S24QeFuvJgsKJ3gdB/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "pöstpöp", "avatarUrl": "https://lh3.googleusercontent.com/-JUIeC9mYGbM/AAAAAAAAAAI/AAAAAAAAACE/f6C0Rr97fYs/photo.jpg", - "settings": "{\"num\":25000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n _ \\n _ _ ___ ___| |_ ___ _ _ \\n| | | -_| _| _| -_|_'_|\\n \\\\_/|___|_| |_| |___|_,_|\\n _ _ \\n ___| |_ ___ _| |___ ___ \\n|_ -| | .'| . | -_| _|\\n|___|_|_|__,|___|___|_| \\n _ \\n ___ ___| |_ \\n| .'| _| _| \\n|__,|_| |_| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomBoxPoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n p[2] = mix(-1., 1., step(0., p[2]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n p[0] = mix(-1., 1., step(0., p[0]));\\n }\\n return p;\\n}\\n\\nvec3 getRandomSpherePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319))));\\n}\\n\\nvec3 getRandomSphereVolumePoint(float seed) {\\n return normalize(vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\\n}\\n\\nvec3 getRandomCubeVolumePoint(float seed) {\\n return vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n}\\n\\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\\n}\\n\\nvec3 getPoint(float set, float seed) {\\n set = mod(set, 7.);\\n if (set < 1.) \\n {\\n return getRandomCubePoint(seed);\\n }\\n if (set < 2.) \\n {\\n return getRandomSphereVolumePoint(seed);\\n }\\n if (set < 3.) \\n {\\n return getRandomFunkPoint(seed, 3., 3.);\\n }\\n if (set < 4.) \\n {\\n return getRandomSpherePoint(seed);\\n }\\n if (set < 5.) \\n {\\n return getRandomBoxPoint(seed);\\n }\\n if (set < 6.)\\n {\\n return getRandomCubeVolumePoint(seed);\\n }\\n return getRandomFunkOutPoint(seed, 4., 3.);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, 3.);\\n }\\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\\n}\\n\\nvec3 getLerpedPoint(float time, float seed) {\\n float set = mod(time, 7.);\\n vec3 p0 = getPoint(set, seed);\\n vec3 p1 = getPoint(set + 1., seed);\\n return mix(p0, p1, easeInOutCubic(fract(time)));\\n}\\n\\n#define DOTS_PER 4000.\\n\\nvoid main() {\\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n\\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\\n \\n float cameraRadius = 13.;\\n float camAngle = time * 0.3;\\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n\\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(\\n m1p1(hash(thingId * 0.179)) * 6., \\n m1p1(hash(thingId * 0.317)) * 6., \\n m1p1(hash(thingId * 0.251)) * 6.));\\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\\n gl_Position = m * vec4(p, 1);\\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n\\n float hue = 0.8+ v * 0.1;\\n hue = mix(hue, 0.5, mod(floor(time * 60.0), 2.));\\n hue = mix(hue, .3, step(0.9, snd));\\n float sat = 1.;\\n float val = invClipZ * 150.;\\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n gl_PointSize = 18. / gl_Position.z;\\n}\"}", + "settings": { + "num": 25000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n _ \n _ _ ___ ___| |_ ___ _ _ \n| | | -_| _| _| -_|_'_|\n \\_/|___|_| |_| |___|_,_|\n _ _ \n ___| |_ ___ _| |___ ___ \n|_ -| | .'| . | -_| _|\n|___|_|_|__,|___|___|_| \n _ \n ___ ___| |_ \n| .'| _| _| \n|__,|_| |_| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvec3 getRandomBoxPoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n p[1] = mix(-1., 1., step(0., p[1]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n p[2] = mix(-1., 1., step(0., p[2]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n p[0] = mix(-1., 1., step(0., p[0]));\n }\n return p;\n}\n\nvec3 getRandomSpherePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319))));\n}\n\nvec3 getRandomSphereVolumePoint(float seed) {\n return normalize(vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)))) * hash(seed * 2.117);\n}\n\nvec3 getRandomCubeVolumePoint(float seed) {\n return vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n}\n\nvec3 getRandomFunkPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(hash(seed * 2.117), 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getRandomFunkOutPoint(float seed, float xDivs, float yDivs) {\n mat4 m = rotX(PI * 2.0 * floor(hash(seed) * xDivs) / xDivs);\n m *= rotY(PI * 2.0 * floor(hash(seed * 0.731) * yDivs) / yDivs);\n m *= rotZ(hash(seed * 0.311) * PI * 2.);\n return (m * vec4(vec2(1, 0) * 0.5, 1, 1)).xyz;\n}\n\nvec3 getPoint(float set, float seed) {\n set = mod(set, 7.);\n if (set < 1.) \n {\n return getRandomCubePoint(seed);\n }\n if (set < 2.) \n {\n return getRandomSphereVolumePoint(seed);\n }\n if (set < 3.) \n {\n return getRandomFunkPoint(seed, 3., 3.);\n }\n if (set < 4.) \n {\n return getRandomSpherePoint(seed);\n }\n if (set < 5.) \n {\n return getRandomBoxPoint(seed);\n }\n if (set < 6.)\n {\n return getRandomCubeVolumePoint(seed);\n }\n return getRandomFunkOutPoint(seed, 4., 3.);\n}\n\nfloat easeInOutCubic(float pos) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, 3.);\n }\n return 0.5 * (pow((pos - 2.), 3.) + 2.);\n}\n\nvec3 getLerpedPoint(float time, float seed) {\n float set = mod(time, 7.);\n vec3 p0 = getPoint(set, seed);\n vec3 p1 = getPoint(set + 1., seed);\n return mix(p0, p1, easeInOutCubic(fract(time)));\n}\n\n#define DOTS_PER 4000.\n\nvoid main() {\n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n\n// float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, mod(time + thingV * 4., 4.) * 60. / 240.)).a;\n float snd = texture2D(sound, vec2(thingV * 0.05 + 0.01, 0.)).a;\n vec3 p = getLerpedPoint(time + thingV + hash(thingId) * 7., v * 4. + time * 0.01);\n// vec3 p = getLerpedPoint(snd * 6., v * 4. + time * 0.01);\n \n float cameraRadius = 13.;\n float camAngle = time * 0.3;\n vec3 eye = vec3(cos(camAngle) * cameraRadius, sin(time) * 3., sin(camAngle) * cameraRadius);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n\n mat4 m = persp(radians(60.), resolution.x / resolution.y, 1., 29.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(\n m1p1(hash(thingId * 0.179)) * 6., \n m1p1(hash(thingId * 0.317)) * 6., \n m1p1(hash(thingId * 0.251)) * 6.));\n m *= uniformScale(mix(1.0, 1.5, hash(thingId * 0.799)));\n gl_Position = m * vec4(p, 1);\n float clipZ = p1m1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n\n float hue = 0.8+ v * 0.1;\n hue = mix(hue, 0.5, mod(floor(time * 60.0), 2.));\n hue = mix(hue, .3, step(0.9, snd));\n float sat = 1.;\n float val = invClipZ * 150.;\n v_color = vec4(mix(background.rgb, hsv2rgb(vec3(hue, sat, val)), pow(snd, 3.0)), 1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(0., 2.5, pow(snd, 4.0)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n gl_PointSize = 18. / gl_Position.z;\n}" + }, "screenshotURL": "data/images/images-4qmrm3k6bm7q94bfb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/S3G4ckMFZ5kpHq2Gz/art.json b/art/S3G4ckMFZ5kpHq2Gz/art.json index f0d67da5..d30d3c35 100644 --- a/art/S3G4ckMFZ5kpHq2Gz/art.json +++ b/art/S3G4ckMFZ5kpHq2Gz/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":8006,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float width = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 2.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n // vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4 (xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time + x * y * 0.12) * 1.0;\\n gl_PointSize = 11.0 + sizeOffset;\\n gl_PointSize -= 32.0 - width;\\n v_color= vec4(0.2, 1.1, 0.0, 0.2);\\n}\"}", + "settings": { + "num": 8006, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float width = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 2.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n // vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4 (xy, 0.0, 1.0);\n \n float sizeOffset = sin(time + x * y * 0.12) * 1.0;\n gl_PointSize = 11.0 + sizeOffset;\n gl_PointSize -= 32.0 - width;\n v_color= vec4(0.2, 1.1, 0.0, 0.2);\n}" + }, "screenshotURL": "data/images/images-q84bgmkvf1f39sjp4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/S3xrtQ73jjKSYCofF/art.json b/art/S3xrtQ73jjKSYCofF/art.json index ef836504..fbce3405 100644 --- a/art/S3xrtQ73jjKSYCofF/art.json +++ b/art/S3xrtQ73jjKSYCofF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n \\n float x = vertexId/100.-1.;\\n float y = tan(time/4.+vertexId)/20.;\\n \\n \\n \\n gl_Position = vec4(x, y, 0, 1);\\n gl_PointSize = (sin(time*2.+vertexId-1.)*20.)+(cos(time*1.)*10.+20.);\\n\\n v_color = vec4(sin(time*2.+vertexId),y+.3,.5,0.) ;\\n \\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n \n float x = vertexId/100.-1.;\n float y = tan(time/4.+vertexId)/20.;\n \n \n \n gl_Position = vec4(x, y, 0, 1);\n gl_PointSize = (sin(time*2.+vertexId-1.)*20.)+(cos(time*1.)*10.+20.);\n\n v_color = vec4(sin(time*2.+vertexId),y+.3,.5,0.) ;\n \n}" + }, "screenshotURL": "data/images/images-4nfmshuyd9yljy6p6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/S4DRdLKsky7bn3aHH/art.json b/art/S4DRdLKsky7bn3aHH/art.json index deafceb7..ed4ecdad 100644 --- a/art/S4DRdLKsky7bn3aHH/art.json +++ b/art/S4DRdLKsky7bn3aHH/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2980392156862745,0.2235294117647059,0.7254901960784313,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 1800.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float quadCount = POINTS_PER_LINE / 6.; \\n float v = vertexId / vertexCount;\\n float invV = 1. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = mod(vertexId, 100.) / 100.;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\\n \\n pos = getCenterPoint(time * 4. + vertexId * 0.0001, vec2(0,0));\\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * 5.11 + vertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(v);\\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 2.;\\n\\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\\n float sat = 0.2 + pow(snd0 + 0.2, 10.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.2);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2980392156862745, + 0.2235294117647059, + 0.7254901960784313, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 1800.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float quadCount = POINTS_PER_LINE / 6.; \n float v = vertexId / vertexCount;\n float invV = 1. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = mod(vertexId, 100.) / 100.;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\n \n pos = getCenterPoint(time * 4. + vertexId * 0.0001, vec2(0,0));\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * 5.11 + vertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(v);\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 2.;\n\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\n float sat = 0.2 + pow(snd0 + 0.2, 10.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.2);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-zu7tt9ei4vfrws73n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/S5Zy3N24yyhKqLNwc/art.json b/art/S5Zy3N24yyhKqLNwc/art.json index 53f85797..55362cdc 100644 --- a/art/S5Zy3N24yyhKqLNwc/art.json +++ b/art/S5Zy3N24yyhKqLNwc/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "anuar", "avatarUrl": "https://graph.facebook.com/1812741555404077/picture?type=large", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n \\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId/3.0), 2.0);\\n \\n float angle = ux / 100.0 * radians(180.0) *2.0;\\n float radius = vy +1.0;\\n\\n float x = radius* cos(angle);\\n float y = radius* sin(angle);\\n\\n vec2 xy = vec2(x,y);\\n\\ngl_Position = vec4(xy*.1, .0, 1.0);\\nv_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n \n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId/3.0), 2.0);\n \n float angle = ux / 100.0 * radians(180.0) *2.0;\n float radius = vy +1.0;\n\n float x = radius* cos(angle);\n float y = radius* sin(angle);\n\n vec2 xy = vec2(x,y);\n\ngl_Position = vec4(xy*.1, .0, 1.0);\nv_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-4dbiugmo9k3lcreea-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/S69GThF6s72FaScEz/art.json b/art/S69GThF6s72FaScEz/art.json index d565342f..0e796b86 100644 --- a/art/S69GThF6s72FaScEz/art.json +++ b/art/S69GThF6s72FaScEz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sherrysmcguire", "avatarUrl": "https://secure.gravatar.com/avatar/e564d0b2c878b6e32f2020459dc1c7b6?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\t \\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1, 0, 0, 1);\\n \\n \\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\t \n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(1, 0, 0, 1);\n \n \n \n}" + }, "screenshotURL": "data/images/images-afd0f4udclu71n3zk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/S73z5kLypn9BENeFt/art.json b/art/S73z5kLypn9BENeFt/art.json index 8ffe2d07..67b31cbb 100644 --- a/art/S73z5kLypn9BENeFt/art.json +++ b/art/S73z5kLypn9BENeFt/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "savaş", "avatarUrl": "https://lh5.googleusercontent.com/-L32C5KSaMA8/AAAAAAAAAAI/AAAAAAAABQU/h2MxUTSBUWc/photo.jpg", - "settings": "{\"num\":36,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.23529411764705882,0.23529411764705882,0.23529411764705882,1],\"shader\":\"void main(){\\n \\n float x = vertexId / vertexCount;\\n \\n gl_PointSize = 8.0;\\n \\n gl_Position = vec4(x, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 36, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.23529411764705882, + 0.23529411764705882, + 0.23529411764705882, + 1 + ], + "shader": "void main(){\n \n float x = vertexId / vertexCount;\n \n gl_PointSize = 8.0;\n \n gl_Position = vec4(x, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-6imgipg6kj62txjtd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/S7g7iMY2BZtMTZzuG/art.json b/art/S7g7iMY2BZtMTZzuG/art.json index e77cf525..418eacf4 100644 --- a/art/S7g7iMY2BZtMTZzuG/art.json +++ b/art/S7g7iMY2BZtMTZzuG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/christopher-camplin/qlabmilano\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 1\\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n\\n float ux = floor(id / 6.0) + mod(id, 2.);\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.0;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n \\t// \\n \\tfloat numSegments = 6.0;\\n \\tvec2 circleXY = getCirclePoint(vertexId, numSegments);\\n \\tfloat numPointsPerCircle = numSegments * 6.0;\\n \\tfloat circleId = floor(vertexId / numPointsPerCircle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\\n \\tfloat cols = floor(sqrt(numCircles));\\n \\tfloat rows = floor(numCircles / cols);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(circleId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat c = cos(PI * time + x * 0.25);\\n \\tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\\n \\tfloat yOff = sin(time + x * 0.25) * 0.2;\\n \\tfloat zOff = sin(time * x * y * 0.005) * 0.05;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\\\\\n\\n float ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + zOff;\\n\\n \\t// concentrate on center\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\n // circular - atan returns values between PI & -PI\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n // sound\\n\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\\n \\tscl *= 20. / rows;\\t\\n \\tvec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\\n \\tfloat z = -pow(snd + c, 10.) + zOff * snd;\\n \\tvec4 pos = vec4(circleXY, -pow(snd + 0.2, 10.), 1);\\n \\tmat4 mat = ident();\\n \\tmat *= scale(vec3(1, aspect, 1));\\n mat *= rotX(radians(45.));\\n //mat *= rotY(radians(-45.));\\n \\tmat *= rotZ(time * 0.1);\\n\\n \\tmat *= trans(vec3(ux, vy, 0) * 1.3);\\n \\tmat *= uniformScale(0.02 * scl);\\n \\tmat *= rotY(PI * snd * 0.1);\\n \\tmat *= rotZ(snd * 10.0 * sign(ux));\\n \\n\\tgl_Position = mat * pos;\\n\\n \\n \\tfloat pump = step(0.8, snd);\\n float hue = 0.5 - snd;\\n hue = hue + smoothstep(x, y, oddSlice);\\n float sat = 1.;\\n \\t// add more impact using pow\\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\\n \\t//val += oddSlice;\\n vec4 color = vec4(hsv2rgb(vec3(fract(hue), sat, val)), 1);\\n //color *= snd;\\n //background += 0.1;\\n \\tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\\n vec4 finalColor = mix(color, background, s);\\n\\tfinalColor = mix(color, newColor, c);\\n v_color = finalColor;\\n }\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/christopher-camplin/qlabmilano", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 1\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n\n float ux = floor(id / 6.0) + mod(id, 2.);\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 1 1 2 2 3 3 4 4 5 5 6\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.0;\n\n float x = c * radius;\n float y = s * radius;\n\n \n return vec2(x, y);\n}\n\nvoid main() {\n \t// \n \tfloat numSegments = 6.0;\n \tvec2 circleXY = getCirclePoint(vertexId, numSegments);\n \tfloat numPointsPerCircle = numSegments * 6.0;\n \tfloat circleId = floor(vertexId / numPointsPerCircle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCircle);\n \n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\n \tfloat cols = floor(sqrt(numCircles));\n \tfloat rows = floor(numCircles / cols);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(circleId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat c = cos(PI * time + x * 0.25);\n \tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\n \tfloat yOff = sin(time + x * 0.25) * 0.2;\n \tfloat zOff = sin(time * x * y * 0.005) * 0.05;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\\\n\n float ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + zOff;\n\n \t// concentrate on center\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat su = abs(u - 0.5) * 2.0;\n \n // circular - atan returns values between PI & -PI\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n // sound\n\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\n \tscl *= 20. / rows;\t\n \tvec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\n \tfloat z = -pow(snd + c, 10.) + zOff * snd;\n \tvec4 pos = vec4(circleXY, -pow(snd + 0.2, 10.), 1);\n \tmat4 mat = ident();\n \tmat *= scale(vec3(1, aspect, 1));\n mat *= rotX(radians(45.));\n //mat *= rotY(radians(-45.));\n \tmat *= rotZ(time * 0.1);\n\n \tmat *= trans(vec3(ux, vy, 0) * 1.3);\n \tmat *= uniformScale(0.02 * scl);\n \tmat *= rotY(PI * snd * 0.1);\n \tmat *= rotZ(snd * 10.0 * sign(ux));\n \n\tgl_Position = mat * pos;\n\n \n \tfloat pump = step(0.8, snd);\n float hue = 0.5 - snd;\n hue = hue + smoothstep(x, y, oddSlice);\n float sat = 1.;\n \t// add more impact using pow\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\n \t//val += oddSlice;\n vec4 color = vec4(hsv2rgb(vec3(fract(hue), sat, val)), 1);\n //color *= snd;\n //background += 0.1;\n \tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\n vec4 finalColor = mix(color, background, s);\n\tfinalColor = mix(color, newColor, c);\n v_color = finalColor;\n }\n\n" + }, "screenshotURL": "data/images/images-l1cgvtdhe4fn2nluq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/S7tQLj7rJ3Nyf4q8P/art.json b/art/S7tQLj7rJ3Nyf4q8P/art.json index 1b6dd06b..446e4d9f 100644 --- a/art/S7tQLj7rJ3Nyf4q8P/art.json +++ b/art/S7tQLj7rJ3Nyf4q8P/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lizell", "avatarUrl": "https://secure.gravatar.com/avatar/8cbc7cccd5a415ae64aab0284832279b?default=retro&size=200", - "settings": "{\"num\":25957,\"mode\":\"POINTS\",\"sound\":\"https://m.soundcloud.com/ahrix/electro-house-ahrix-nova\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.058823529411764705,0.058823529411764705,0.058823529411764705,1],\"shader\":\"// chrillo\\n\\n#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n\\nvoid main () {\\n float i = hash(vertexId);\\n float f = hash(i);\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 2.);\\n \\n \\n float ang = vertexId / 1000.;\\n float perspective = .5 * (1. - mouse.y);\\n float t = time * (f + .5) - mouse.x;\\n float x = i * sin(ang + t) * .8;\\n float y = i * cos(ang + t);\\n y += .1 * snd * (1. - y);\\n y *= perspective;\\n \\n float vis = snd / (y + 1.);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 5. * vis;\\n \\n v_color = vec4(\\n snd * .7 * (2. - f),\\n snd * .8 * cos(f * PI),\\n snd * 2.,\\n vis);\\n}\"}", + "settings": { + "num": 25957, + "mode": "POINTS", + "sound": "https://m.soundcloud.com/ahrix/electro-house-ahrix-nova", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.058823529411764705, + 0.058823529411764705, + 0.058823529411764705, + 1 + ], + "shader": "// chrillo\n\n#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n\nvoid main () {\n float i = hash(vertexId);\n float f = hash(i);\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 2.);\n \n \n float ang = vertexId / 1000.;\n float perspective = .5 * (1. - mouse.y);\n float t = time * (f + .5) - mouse.x;\n float x = i * sin(ang + t) * .8;\n float y = i * cos(ang + t);\n y += .1 * snd * (1. - y);\n y *= perspective;\n \n float vis = snd / (y + 1.);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 5. * vis;\n \n v_color = vec4(\n snd * .7 * (2. - f),\n snd * .8 * cos(f * PI),\n snd * 2.,\n vis);\n}" + }, "screenshotURL": "data/images/images-2qxfdby41lw91cwke-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/S8WjbT3dh5ZHhbpAS/art.json b/art/S8WjbT3dh5ZHhbpAS/art.json index 36d0c38c..6fec30ca 100644 --- a/art/S8WjbT3dh5ZHhbpAS/art.json +++ b/art/S8WjbT3dh5ZHhbpAS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":56050,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/uheplugins/bora\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 100.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float pointV = point / NUM_SEGMENTS;\\n float circleId = floor(vertexId / NUM_POINTS);\\n float numCircles = floor(vertexCount / NUM_POINTS);\\n float circleV = circleId / numCircles;\\n \\n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\\n \\n float angle = pointV * PI * 2.0 + snd * 5.;\\n float c = cos(angle) * mix(0.1, 1., circleV);\\n float s = sin(angle) * mix(0.25, 0.5, circleV);\\n \\n float r = mix(0., PI, circleV) + pow(snd, 5.0);\\n float rc = cos(r + sin(time * 4. + circleV * 4.));\\n float rs = sin(r + sin(time * 4. + circleV * 4.));\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\\n vec2 xy = vec2(\\n rc * c + rs * s,\\n -rs * c + rc * s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n float b = 1.0;\\n v_color.a = 1.;\\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\\n \\n gl_PointSize = 4.0;\\n gl_PointSize *= resolution.x / 1600.0;\\n}\"}", + "settings": { + "num": 56050, + "mode": "LINES", + "sound": "https://soundcloud.com/uheplugins/bora", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 100.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float pointV = point / NUM_SEGMENTS;\n float circleId = floor(vertexId / NUM_POINTS);\n float numCircles = floor(vertexCount / NUM_POINTS);\n float circleV = circleId / numCircles;\n \n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\n \n float angle = pointV * PI * 2.0 + snd * 5.;\n float c = cos(angle) * mix(0.1, 1., circleV);\n float s = sin(angle) * mix(0.25, 0.5, circleV);\n \n float r = mix(0., PI, circleV) + pow(snd, 5.0);\n float rc = cos(r + sin(time * 4. + circleV * 4.));\n float rs = sin(r + sin(time * 4. + circleV * 4.));\n \n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\n vec2 xy = vec2(\n rc * c + rs * s,\n -rs * c + rc * s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n float b = 1.0;\n v_color.a = 1.;\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\n \n gl_PointSize = 4.0;\n gl_PointSize *= resolution.x / 1600.0;\n}" + }, "screenshotURL": "data/images/images-fkxv007a9ez2a235x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SAToMsqc7PybLLEc2/art.json b/art/SAToMsqc7PybLLEc2/art.json index 8b2c0b28..ad577152 100644 --- a/art/SAToMsqc7PybLLEc2/art.json +++ b/art/SAToMsqc7PybLLEc2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\n// based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\nvec2 getHexPos(float vVertexId, float vPolySize, float vHexSpace)\\n{\\n\\tfloat indexTri = floor(vVertexId / 3.);\\n\\tfloat indexCircle = floor(indexTri / vPolySize);\\n\\t\\n\\tif (indexCircle == 0.) return vec2(0);\\n\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\\n\\n\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\tfloat side_number = floor(circleOffset / ringCircle);\\n\\tfloat side_offset = mod(circleOffset, ringCircle);\\n\\t\\t\\n\\tfloat as = _2pi / vPolySize;\\n\\t\\t\\n\\tfloat a = as * side_number;\\n\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\ta = as * mod((side_number + 1.), vPolySize);\\n\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\treturn ((hex0 * ringCircle) + (hex1 * side_offset)) * vHexSpace;\\n}\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 3.;\\n\\n\\tfloat polySize = floor(abs(mouse.x * 3.)+3.);\\n\\tfloat hexSpace = cos(radians(45.))*2.;\\n \\t\\n\\tfloat off = 360.0 * time * 0.2;\\n\\tfloat astep = -_2pi / polySize;\\n\\tfloat angleOffset = cos(radians(off))*2.;\\n\\tfloat indexTri = floor(vertexId / 3.);\\n\\tfloat indexShape = floor(indexTri / polySize);\\n\\t\\n\\tfloat angle0 = indexTri * astep + angleOffset;\\n\\tfloat angle1 = (indexTri + 1.) * astep + angleOffset;\\n \\n\\tfloat index = mod(vertexId, 3.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\tif (index == 0.) p = vec3(cos(angle0), -10, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), -10, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,1,0);\\n\\t\\n\\tvec3 col = vec3(0,p.y,0);\\n\\t\\n\\t//p.xz *= 2.;\\n p.xz -= getHexPos(vertexId, polySize, hexSpace);\\n\\t\\n\\tp.y += cos((indexShape * 2. + t)) * 2.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = -0.7;\\n\\tfloat ce = 1.57;\\n\\tfloat cd = 10.8;\\n\\tvec3 eye = vec3(0.2, 1, 0.) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = 1.0 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv, -1,\\n\\t\\t0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n#endif\\n \\n\\t}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\n// based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\nvec2 getHexPos(float vVertexId, float vPolySize, float vHexSpace)\n{\n\tfloat indexTri = floor(vVertexId / 3.);\n\tfloat indexCircle = floor(indexTri / vPolySize);\n\t\n\tif (indexCircle == 0.) return vec2(0);\n\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\n\n\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\tfloat side_number = floor(circleOffset / ringCircle);\n\tfloat side_offset = mod(circleOffset, ringCircle);\n\t\t\n\tfloat as = _2pi / vPolySize;\n\t\t\n\tfloat a = as * side_number;\n\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\ta = as * mod((side_number + 1.), vPolySize);\n\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\treturn ((hex0 * ringCircle) + (hex1 * side_offset)) * vHexSpace;\n}\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 3.;\n\n\tfloat polySize = floor(abs(mouse.x * 3.)+3.);\n\tfloat hexSpace = cos(radians(45.))*2.;\n \t\n\tfloat off = 360.0 * time * 0.2;\n\tfloat astep = -_2pi / polySize;\n\tfloat angleOffset = cos(radians(off))*2.;\n\tfloat indexTri = floor(vertexId / 3.);\n\tfloat indexShape = floor(indexTri / polySize);\n\t\n\tfloat angle0 = indexTri * astep + angleOffset;\n\tfloat angle1 = (indexTri + 1.) * astep + angleOffset;\n \n\tfloat index = mod(vertexId, 3.);\n\t\n\tvec3 p = vec3(0);\n\t\n\tif (index == 0.) p = vec3(cos(angle0), -10, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), -10, sin(angle1));\n\telse if (index == 2.) p = vec3(0,1,0);\n\t\n\tvec3 col = vec3(0,p.y,0);\n\t\n\t//p.xz *= 2.;\n p.xz -= getHexPos(vertexId, polySize, hexSpace);\n\t\n\tp.y += cos((indexShape * 2. + t)) * 2.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = -0.7;\n\tfloat ce = 1.57;\n\tfloat cd = 10.8;\n\tvec3 eye = vec3(0.2, 1, 0.) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = 1.0 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv, -1,\n\t\t0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n#endif\n \n\t}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-4lq2zemdh1lxl19ve-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SAxr7jfCpJMn2zJyG/art.json b/art/SAxr7jfCpJMn2zJyG/art.json index 1fdf9dae..fcd796c1 100644 --- a/art/SAxr7jfCpJMn2zJyG/art.json +++ b/art/SAxr7jfCpJMn2zJyG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "blackle", "avatarUrl": "https://secure.gravatar.com/avatar/32bd668863823ef987c1aa8d6f81ace6?default=retro&size=200", - "settings": "{\"num\":38763,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.16862745098039217,0.16862745098039217,0.16862745098039217,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvec3 posOnSphere(float latid, float longid, float numlat, float numlong) {\\n longid = longid/numlong*3.1415*2.-3.1415;\\n latid = latid/numlat*3.1415-3.1415/2.;\\n return vec3(sin(longid)*cos(latid), sin(latid), cos(longid)*cos(latid));\\n}\\n\\nfloat smin(float a, float b, float k) {\\n float h = max(0., k-abs(b-a))/k;\\n return min(a,b) - h*h*h*k/6.;\\n}\\n\\nvec3 closest(vec3 p) {\\n //return normalize(p);\\n //return mix(normalize(p), vec3(p.x, sign(p.y)*.5, p.z), step(.5,abs(p.y)));\\n p = normalize(p);\\n p.y = smin(p.y, .5, .2);\\n p.y = -smin(-p.y, .5, .2);\\n return p;\\n}\\nfloat dist(vec3 p) {\\n //return length(p) - 1.;\\n //return length(p-closest(p));\\n return -smin(1.-length(p),.5-abs(p.y),.2);\\n}\\n\\nvec3 norm(vec3 p) {\\n mat3 k = mat3(p,p,p)-mat3(0.001);\\n return normalize(dist(p) - vec3(dist(k[0]),dist(k[1]),dist(k[2])));\\n}\\n\\nvec3 posForId(float id) {\\n float vertid = mod(id, 3.);\\n float triid = floor(id/3.);\\n float qptid = mod(triid, 2.);\\n float quadid = floor(triid/2.);\\n \\n float numlat = 80.;\\n float numlong = 80.;\\n float latid = floor(quadid/numlong) + mix(floor(vertid/2.), 1.-floor(vertid/2.), qptid);\\n float longid = mod(quadid,numlong) + mix(mod(vertid,2.), 1.-mod(vertid,2.), qptid);\\n vec3 p = posOnSphere(latid, longid, numlat, numlong);\\n return closest(p);\\n}\\n\\nvec3 erot(vec3 p, vec3 ax, float ro) {\\n return mix(dot(p,ax)*ax,p,cos(ro))+sin(ro)*cross(ax,p);\\n}\\n\\nvoid main() {\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec3 pos = posForId(vertexId);\\n vec3 n = norm(pos);\\n vec3 on = n;\\n \\n vec3 cam = vec3(0,0,1);\\n vec3 r = reflect(cam,n);\\n n = erot(n, vec3(0,1,0), time);\\n n = erot(n, vec3(1,0,0), sin(time/2.)*.3);\\n //you need a proper projection matrix blackle...\\n //or do I? lmao\\n r = erot(r, vec3(0,1,0), time);\\n r = erot(r, vec3(1,0,0), sin(time/2.)*.3);\\n pos = erot(pos, vec3(0,1,0), time);\\n pos = erot(pos, vec3(1,0,0), sin(time/2.)*.3);\\n float fres = 1.-abs(dot(n,cam))*.98;\\n \\n gl_Position = vec4(pos.xy * aspect, pos.z, 2.);\\n gl_PointSize = 10.;\\n\\n float spec = length(sin(r*3.)*.5+.5)/sqrt(3.);\\n float diff = length(sin(on*2.)*.4+.6)/sqrt(3.);\\n //v_color = vec4(n*.5+.5,1);\\n v_color = smoothstep(0.,1.,sqrt(vec4(diff*vec3(.9,.5,.3) + pow(spec,8.)*fres, 1)));\\n}\"}", + "settings": { + "num": 38763, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.16862745098039217, + 0.16862745098039217, + 0.16862745098039217, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvec3 posOnSphere(float latid, float longid, float numlat, float numlong) {\n longid = longid/numlong*3.1415*2.-3.1415;\n latid = latid/numlat*3.1415-3.1415/2.;\n return vec3(sin(longid)*cos(latid), sin(latid), cos(longid)*cos(latid));\n}\n\nfloat smin(float a, float b, float k) {\n float h = max(0., k-abs(b-a))/k;\n return min(a,b) - h*h*h*k/6.;\n}\n\nvec3 closest(vec3 p) {\n //return normalize(p);\n //return mix(normalize(p), vec3(p.x, sign(p.y)*.5, p.z), step(.5,abs(p.y)));\n p = normalize(p);\n p.y = smin(p.y, .5, .2);\n p.y = -smin(-p.y, .5, .2);\n return p;\n}\nfloat dist(vec3 p) {\n //return length(p) - 1.;\n //return length(p-closest(p));\n return -smin(1.-length(p),.5-abs(p.y),.2);\n}\n\nvec3 norm(vec3 p) {\n mat3 k = mat3(p,p,p)-mat3(0.001);\n return normalize(dist(p) - vec3(dist(k[0]),dist(k[1]),dist(k[2])));\n}\n\nvec3 posForId(float id) {\n float vertid = mod(id, 3.);\n float triid = floor(id/3.);\n float qptid = mod(triid, 2.);\n float quadid = floor(triid/2.);\n \n float numlat = 80.;\n float numlong = 80.;\n float latid = floor(quadid/numlong) + mix(floor(vertid/2.), 1.-floor(vertid/2.), qptid);\n float longid = mod(quadid,numlong) + mix(mod(vertid,2.), 1.-mod(vertid,2.), qptid);\n vec3 p = posOnSphere(latid, longid, numlat, numlong);\n return closest(p);\n}\n\nvec3 erot(vec3 p, vec3 ax, float ro) {\n return mix(dot(p,ax)*ax,p,cos(ro))+sin(ro)*cross(ax,p);\n}\n\nvoid main() {\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec3 pos = posForId(vertexId);\n vec3 n = norm(pos);\n vec3 on = n;\n \n vec3 cam = vec3(0,0,1);\n vec3 r = reflect(cam,n);\n n = erot(n, vec3(0,1,0), time);\n n = erot(n, vec3(1,0,0), sin(time/2.)*.3);\n //you need a proper projection matrix blackle...\n //or do I? lmao\n r = erot(r, vec3(0,1,0), time);\n r = erot(r, vec3(1,0,0), sin(time/2.)*.3);\n pos = erot(pos, vec3(0,1,0), time);\n pos = erot(pos, vec3(1,0,0), sin(time/2.)*.3);\n float fres = 1.-abs(dot(n,cam))*.98;\n \n gl_Position = vec4(pos.xy * aspect, pos.z, 2.);\n gl_PointSize = 10.;\n\n float spec = length(sin(r*3.)*.5+.5)/sqrt(3.);\n float diff = length(sin(on*2.)*.4+.6)/sqrt(3.);\n //v_color = vec4(n*.5+.5,1);\n v_color = smoothstep(0.,1.,sqrt(vec4(diff*vec3(.9,.5,.3) + pow(spec,8.)*fres, 1)));\n}" + }, "screenshotURL": "data/images/images-i425uicasg8nyron8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SBPbXExASm2xdxtmi/art.json b/art/SBPbXExASm2xdxtmi/art.json index 0657f02c..a550ab39 100644 --- a/art/SBPbXExASm2xdxtmi/art.json +++ b/art/SBPbXExASm2xdxtmi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":11341,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles.\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n \\tfloat ux = floor(id/ 6.) + mod(id,2.);\\n \\tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\n \\n \\tfloat angle = ux / numCircleSegments * PI * 2.;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n\\n \\tfloat radius = vy + 1.;\\n \\n \\tfloat x = c * radius;\\n \\tfloat y = s * radius;\\n \\n \\treturn vec2(x,y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 36.;\\n \\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.5, av * .25)).a;\\n\\n\\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2,5.) + mix(1.,1.1,oddSlice);\\n \\n sc *= 20. / across ;\\n \\n vec4 pos = vec4(circleXY, 0 ,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03*sc);\\n mat *= rotZ(cos(time));\\n\\n \\n gl_Position = mat * pos;\\n \\n\\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n\\n \\n float pump = step(0.3, snd)* abs(sin(time));\\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1* oddSlice; //sin(time + v * 20.) * .05;\\n float sat = mix(0.5, 1., pump) * oddSlice;\\n float val = mix(.4, pow(snd + 0.2, 5.), pump );\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump* oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 11341, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles.\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n \tfloat ux = floor(id/ 6.) + mod(id,2.);\n \tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\n \n \tfloat angle = ux / numCircleSegments * PI * 2.;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n\n \tfloat radius = vy + 1.;\n \n \tfloat x = c * radius;\n \tfloat y = s * radius;\n \n \treturn vec2(x,y);\n}\n\n\nvoid main() {\n float numCircleSegments = 36.;\n \n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n \n float xoff = 0.;//sin(time + y * 0.2) * 0.;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.5, av * .25)).a;\n\n\n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2,5.) + mix(1.,1.1,oddSlice);\n \n sc *= 20. / across ;\n \n vec4 pos = vec4(circleXY, 0 ,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03*sc);\n mat *= rotZ(cos(time));\n\n \n gl_Position = mat * pos;\n \n\n float soff = 1.;//sin(time + x * y * .02) * 5.; \n\n \n float pump = step(0.3, snd)* abs(sin(time));\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1* oddSlice; //sin(time + v * 20.) * .05;\n float sat = mix(0.5, 1., pump) * oddSlice;\n float val = mix(.4, pow(snd + 0.2, 5.), pump );\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump* oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-8gf7xwput7dknynbr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SDv9RES4wtc8RQbg2/art.json b/art/SDv9RES4wtc8RQbg2/art.json index f9b771a0..4b3b7891 100644 --- a/art/SDv9RES4wtc8RQbg2/art.json +++ b/art/SDv9RES4wtc8RQbg2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 12.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd + 0., 5.0) + oddSlice * 0.1;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.1 * sc * 20. / across);\\n mat *= rotZ(snd * 10. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + oddSlice * 0.5;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 12.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd + 0., 5.0) + oddSlice * 0.1;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.1 * sc * 20. / across);\n mat *= rotZ(snd * 10. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + oddSlice * 0.5;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-nn67al4rjl4pyk6v2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SEd9sPy3A6AgCCbWG/art.json b/art/SEd9sPy3A6AgCCbWG/art.json index c1fc6bcd..3b0e6be6 100644 --- a/art/SEd9sPy3A6AgCCbWG/art.json +++ b/art/SEd9sPy3A6AgCCbWG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Motion\\n//Course : CS250\\n//Term : Spring 2023\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.9;\\n float yoff = sin(time + x * 0.1) * 0.7;\\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.009) * 20.;\\n \\n gl_PointSize = 1.0 + soff;\\n gl_PointSize *= 10. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(sin(time),1,cos(time),1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Motion\n//Course : CS250\n//Term : Spring 2023\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.9;\n float yoff = sin(time + x * 0.1) * 0.7;\n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.009) * 20.;\n \n gl_PointSize = 1.0 + soff;\n gl_PointSize *= 10. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(sin(time),1,cos(time),1);\n}\n" + }, "screenshotURL": "data/images/images-oym5zd6fnb788qsob-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SEk9EQMb8GksyQBhX/art.json b/art/SEk9EQMb8GksyQBhX/art.json index fc5fb81e..4e618f24 100644 --- a/art/SEk9EQMb8GksyQBhX/art.json +++ b/art/SEk9EQMb8GksyQBhX/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":8000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat anim(float t) {\\n float st = sin(t);\\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 100.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvec3 SampleSpherePos2(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\n\\nvec3 SampleCubePos(float idx, float num) {\\n float side = floor(pow(num, 1.0/3.0)+0.5);\\n vec3 res;\\n res.x = mod(idx, side);\\n res.y = floor( mod(idx, side*side)/side );\\n res.z = floor( mod(idx, side*side*side)/side/side );\\n res -= vec3(side * 0.5);\\n res *= 1.5/side;\\n return res;\\n}\\n\\nvoid main() {\\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n vec4 color2 = vec4(1,0,0,1);\\n v_color = mix(vec4(0,0,1,1), color2, anim(time));\\n}\"}", + "settings": { + "num": 8000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat anim(float t) {\n float st = sin(t);\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 100.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvec3 SampleSpherePos2(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\n\nvec3 SampleCubePos(float idx, float num) {\n float side = floor(pow(num, 1.0/3.0)+0.5);\n vec3 res;\n res.x = mod(idx, side);\n res.y = floor( mod(idx, side*side)/side );\n res.z = floor( mod(idx, side*side*side)/side/side );\n res -= vec3(side * 0.5);\n res *= 1.5/side;\n return res;\n}\n\nvoid main() {\n vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\n \n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n vec4 color2 = vec4(1,0,0,1);\n v_color = mix(vec4(0,0,1,1), color2, anim(time));\n}" + }, "screenshotURL": "data/images/images-87cqg0o3cqw57neo3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SFmNpx7c5RxJxfEnq/art.json b/art/SFmNpx7c5RxJxfEnq/art.json index b61029b8..38a6da07 100644 --- a/art/SFmNpx7c5RxJxfEnq/art.json +++ b/art/SFmNpx7c5RxJxfEnq/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n \\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n \n}" + }, "screenshotURL": "data/images/images-83fz9c908h2t909tv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SGSdWRQtcRJGxt6BP/art.json b/art/SGSdWRQtcRJGxt6BP/art.json index a02dac9c..064e5b00 100644 --- a/art/SGSdWRQtcRJGxt6BP/art.json +++ b/art/SGSdWRQtcRJGxt6BP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trevor", "avatarUrl": "https://lh6.googleusercontent.com/-5kLKsPjdMwg/AAAAAAAAAAI/AAAAAAAABpc/UHOkxSB_ZkQ/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/tennysonmusic/with-you?in=trevor-drury/sets/stuff\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + x * u) * 0.1;\\n float yoff = 0.;//sin(time + y * v) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .125, av * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8,snd);\\n float hue = u * .1 + snd + sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1.,pump);//1. - av;\\n float val = pow(snd + 0.2, 5.);//sin(time + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/tennysonmusic/with-you?in=trevor-drury/sets/stuff", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + x * u) * 0.1;\n float yoff = 0.;//sin(time + y * v) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .125, av * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8,snd);\n float hue = u * .1 + snd + sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1.,pump);//1. - av;\n float val = pow(snd + 0.2, 5.);//sin(time + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-e7gijqatbdtgnwl16-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SGm2qQjwmg7NGb4my/art.json b/art/SGm2qQjwmg7NGb4my/art.json index bb6dae92..1a09ce90 100644 --- a/art/SGm2qQjwmg7NGb4my/art.json +++ b/art/SGm2qQjwmg7NGb4my/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.1450980392156863,0.30980392156862746,1],\"shader\":\"void main ()\\n{\\n //\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize*resolution.x/resolution.y);\\n \\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across) * (across/resolution.x);// (across - 1.0);\\n float v = (y /down) * (across/resolution.x);// (down - 1.0);\\n \\n float ux = u - (across/resolution.x/2.);//(u * 2.0 - 1.0) * (across/resolution.x);\\n float vy = v - (across/resolution.x/2.);//(v * 2.0 - 1.0) * (across/resolution.x);\\n \\n\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n gl_PointSize = 1.;\\n \\n //////////\\n\\n\\n\\n /////////\\n \\n \\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.1450980392156863, + 0.30980392156862746, + 1 + ], + "shader": "void main ()\n{\n //\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize*resolution.x/resolution.y);\n \n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across) * (across/resolution.x);// (across - 1.0);\n float v = (y /down) * (across/resolution.x);// (down - 1.0);\n \n float ux = u - (across/resolution.x/2.);//(u * 2.0 - 1.0) * (across/resolution.x);\n float vy = v - (across/resolution.x/2.);//(v * 2.0 - 1.0) * (across/resolution.x);\n \n\n gl_Position = vec4(ux, vy, 0, 1);\n \n \n gl_PointSize = 1.;\n \n //////////\n\n\n\n /////////\n \n \n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-8ypdxj7vyzem83nv4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SHEuL7KCpNnj28Rmn/art.json b/art/SHEuL7KCpNnj28Rmn/art.json index 6e62d408..7ebad1f9 100644 --- a/art/SHEuL7KCpNnj28Rmn/art.json +++ b/art/SHEuL7KCpNnj28Rmn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\n/*\\nvoid main() {\\n const int hist = 8;\\n float s = 0.;\\n for (int i = 0; i < hist; ++i) {\\n s += texture2D(volume, vec2((vertexId + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n 1.;//float(hist - i);\\n }\\n// s /= float(hist * (hist - 1)) / 2.;\\n s /= float(hist);\\n \\n gl_Position = vec4(\\n mod(vertexId , 2.) - .5, \\n floor(vertexId / 2.) - .5, 0, 1);\\n gl_PointSize = s * resolution.y / 2.;\\n\\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1, 1)), 1);\\n}\\n*/\\n\\n/*\\n\\nWait for the music to pump \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nmat4 mixm(mat4 m1, mat4 m2, float m) {\\n return mat4(\\n mix(m1[0], m2[0], m),\\n mix(m1[1], m2[1], m),\\n mix(m1[2], m2[2], m),\\n mix(m1[3], m2[3], m));\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes) * .5);\\n float across = floor(numCubes / down);\\n float cv = cubeId / numCubes;\\n\\n float uu = mod(cubeId, across);\\n float vv = floor(cubeId / across);\\n vec2 uv = vec2(uu, vv) / vec2(across, down);\\n \\n// const int hist = 10;\\n// float s = 0.;\\n// for (int i = 0; i < hist; ++i) {\\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n// 1.;//float(hist - i);\\n// }\\n//// s /= float(hist * (hist - 1)) / 2.;\\n// s /= float(hist);\\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\\n \\n float tm = time * 0.;\\n float rd = 9.;\\n mat4 pmat = persp(radians(110.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up); \\n \\n mat4 mat = rotY(time * .1);\\n mat *= lookAt(\\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \\n mix(20., 24.1, s),\\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\\n vec3(0, 1, 0));\\n \\n mat4 mvmat = vmat * mat;\\n \\n vec3 npos = normalize(mvmat[3].xyz);\\n \\n float hue = mix(.0, time * 10., step(.8, s));\\n float val = mix(-1.0, 2.2, s);\\n float sat = 1.;//mix(1., 1., step(0.8, s));\\n\\n \\n float areaS = 1. - (npos.z * .5 + .5);\\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\\n smat *= uniformScale(0.5);\\n smat *= trans(vec3(0, 0, -1));\\n \\n \\n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1, 0.1, 1));\\n\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(0., 2., s);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\n/*\nvoid main() {\n const int hist = 8;\n float s = 0.;\n for (int i = 0; i < hist; ++i) {\n s += texture2D(volume, vec2((vertexId + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n 1.;//float(hist - i);\n }\n// s /= float(hist * (hist - 1)) / 2.;\n s /= float(hist);\n \n gl_Position = vec4(\n mod(vertexId , 2.) - .5, \n floor(vertexId / 2.) - .5, 0, 1);\n gl_PointSize = s * resolution.y / 2.;\n\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1, 1)), 1);\n}\n*/\n\n/*\n\nWait for the music to pump \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nmat4 mixm(mat4 m1, mat4 m2, float m) {\n return mat4(\n mix(m1[0], m2[0], m),\n mix(m1[1], m2[1], m),\n mix(m1[2], m2[2], m),\n mix(m1[3], m2[3], m));\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes) * .5);\n float across = floor(numCubes / down);\n float cv = cubeId / numCubes;\n\n float uu = mod(cubeId, across);\n float vv = floor(cubeId / across);\n vec2 uv = vec2(uu, vv) / vec2(across, down);\n \n// const int hist = 10;\n// float s = 0.;\n// for (int i = 0; i < hist; ++i) {\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n// 1.;//float(hist - i);\n// }\n//// s /= float(hist * (hist - 1)) / 2.;\n// s /= float(hist);\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\n \n float tm = time * 0.;\n float rd = 9.;\n mat4 pmat = persp(radians(110.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up); \n \n mat4 mat = rotY(time * .1);\n mat *= lookAt(\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \n mix(20., 24.1, s),\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\n vec3(0, 1, 0));\n \n mat4 mvmat = vmat * mat;\n \n vec3 npos = normalize(mvmat[3].xyz);\n \n float hue = mix(.0, time * 10., step(.8, s));\n float val = mix(-1.0, 2.2, s);\n float sat = 1.;//mix(1., 1., step(0.8, s));\n\n \n float areaS = 1. - (npos.z * .5 + .5);\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\n smat *= uniformScale(0.5);\n smat *= trans(vec3(0, 0, -1));\n \n \n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1, 0.1, 1));\n\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(0., 2., s);\n}\n\n" + }, "screenshotURL": "data/images/images-st6t541q80vyhczwm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SHK4CEcQDC3SgBnMt/art.json b/art/SHK4CEcQDC3SgBnMt/art.json index 4a0cdda6..2c24097b 100644 --- a/art/SHK4CEcQDC3SgBnMt/art.json +++ b/art/SHK4CEcQDC3SgBnMt/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jieunko", "avatarUrl": "https://avatars.githubusercontent.com/jieunko?s=200", - "settings": "{\"num\":4203,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n\\t\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x/ (across - 1.);\\n float v = y/ (across - 1.);\\n \\n float xoff = sin(time * 1.2 +y * 0.4) * 0.1;\\n float yoff = cos(time+x * 0.4) * 0.1;\\n float soff = sin(time + x * y*0.02) * 5.0;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n float snd = texture2D(sound, vec2(u, v)).a;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 5.0 + soff;\\n float hue = u * .1 + sin(time + v*20.) * 0.05;\\n float sat = 1.0;\\n float val = snd; //sin(time + v * u * 20.0) * 0.5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n\\n}\"}", + "settings": { + "num": 4203, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n\t\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x/ (across - 1.);\n float v = y/ (across - 1.);\n \n float xoff = sin(time * 1.2 +y * 0.4) * 0.1;\n float yoff = cos(time+x * 0.4) * 0.1;\n float soff = sin(time + x * y*0.02) * 5.0;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n float snd = texture2D(sound, vec2(u, v)).a;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 5.0 + soff;\n float hue = u * .1 + sin(time + v*20.) * 0.05;\n float sat = 1.0;\n float val = snd; //sin(time + v * u * 20.0) * 0.5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n\n}" + }, "screenshotURL": "data/images/images-ct6xvyjjbk229o05j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SJ68p365upswGjcG9/art.json b/art/SJ68p365upswGjcG9/art.json index f003ce41..61bae38e 100644 --- a/art/SJ68p365upswGjcG9/art.json +++ b/art/SJ68p365upswGjcG9/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/funieru-mihail/best-of-buddha-bar-ambient\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.27450980392156865,1],\"shader\":\"void main() {\\n float n = vertexId / vertexCount;\\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \\n float angle = n * 6.28;\\n float dx = cos(angle);\\n float dy = sin(angle * (time / 100.0));\\n\\n gl_Position = vec4(dx, dy, 0.0, 1);\\n gl_PointSize = pow(snd.a, 2.0) * 5.0;\\n v_color = vec4(snd.a, snd.b, cos(time), 1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/funieru-mihail/best-of-buddha-bar-ambient", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.27450980392156865, + 1 + ], + "shader": "void main() {\n float n = vertexId / vertexCount;\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \n float angle = n * 6.28;\n float dx = cos(angle);\n float dy = sin(angle * (time / 100.0));\n\n gl_Position = vec4(dx, dy, 0.0, 1);\n gl_PointSize = pow(snd.a, 2.0) * 5.0;\n v_color = vec4(snd.a, snd.b, cos(time), 1.0);\n}" + }, "screenshotURL": "data/images/images-eryfdt2xax3nc8qg3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SJYTAAwib5eJy8voP/art.json b/art/SJYTAAwib5eJy8voP/art.json index c03ca5c1..6b67a876 100644 --- a/art/SJYTAAwib5eJy8voP/art.json +++ b/art/SJYTAAwib5eJy8voP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "shu", "avatarUrl": "https://secure.gravatar.com/avatar/6dc8be209aeec21dc99956c1188c1b05?default=retro&size=200", - "settings": "{\"num\":6000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec3 f(vec3 c){c=vec3(c.x,clamp(c.yz,0.,1.));vec4 K=vec4(1.,2./3.,1./3.,3.);vec3 p=abs(fract(c.xxx+K.xyz)*6.-K.www);return c.z*mix(K.xxx,clamp(p-K.xxx,0.,1.),c.y);}void main(){float c=floor(vertexCount/6.);float i=floor(vertexId/6.);float j=mod(vertexId,6.);gl_Position=vec4(i/c*2.-1.+(mod(j,2.)>0.?2./c*9.:0.),j>1.&&j<5.?sin(i/c+mod(i,9.)+time):0.,-i/c,1);v_color=vec4(f(vec3(c/i+time,1,1)),.3);v_color.rgb*=.3}\"}", + "settings": { + "num": 6000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec3 f(vec3 c){c=vec3(c.x,clamp(c.yz,0.,1.));vec4 K=vec4(1.,2./3.,1./3.,3.);vec3 p=abs(fract(c.xxx+K.xyz)*6.-K.www);return c.z*mix(K.xxx,clamp(p-K.xxx,0.,1.),c.y);}void main(){float c=floor(vertexCount/6.);float i=floor(vertexId/6.);float j=mod(vertexId,6.);gl_Position=vec4(i/c*2.-1.+(mod(j,2.)>0.?2./c*9.:0.),j>1.&&j<5.?sin(i/c+mod(i,9.)+time):0.,-i/c,1);v_color=vec4(f(vec3(c/i+time,1,1)),.3);v_color.rgb*=.3}" + }, "screenshotURL": "data/images/images-v8gfosbtrnwvl14tm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SK2zDKBfJ2tqtnSHS/art.json b/art/SK2zDKBfJ2tqtnSHS/art.json index ba1e365a..e98f9eeb 100644 --- a/art/SK2zDKBfJ2tqtnSHS/art.json +++ b/art/SK2zDKBfJ2tqtnSHS/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":18599,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float NUM_SEGMENTS =3.0*(mouse.x+2.1);\\n float NUM_POINTS = (NUM_SEGMENTS * 1.5);\\n float STEP = time*0.0001;\\n if (STEP > 0.003) STEP = 0.003;\\n float localTime = time*0.1 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * localTime*0.0001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0-mouse.y);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.0025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\\n float oS = sin(orbitAngle / count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 0.5);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(1.0-b, 1.0-c*6.0, 1.0-s*10.0, 1);\\n}\"}", + "settings": { + "num": 18599, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvoid main() {\n float NUM_SEGMENTS =3.0*(mouse.x+2.1);\n float NUM_POINTS = (NUM_SEGMENTS * 1.5);\n float STEP = time*0.0001;\n if (STEP > 0.003) STEP = 0.003;\n float localTime = time*0.1 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * localTime*0.0001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0-mouse.y);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.0025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\n float oS = sin(orbitAngle / count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 0.5);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(1.0-b, 1.0-c*6.0, 1.0-s*10.0, 1);\n}" + }, "screenshotURL": "data/images/images-616lpwq3cb8wr71zk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SKXKQkxm2HZHdxdxm/art.json b/art/SKXKQkxm2HZHdxdxm/art.json index 502c555a..9775c57a 100644 --- a/art/SKXKQkxm2HZHdxdxm/art.json +++ b/art/SKXKQkxm2HZHdxdxm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "liaminjapan", "avatarUrl": "https://avatars.githubusercontent.com/LiamInJapan?s=200", - "settings": "{\"num\":57906,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3411764705882353,0.22745098039215686,0.27450980392156865,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = .0;// sin(time + y * 0.2) * .05;\\n float yoff = .0;// sin(time + x * 0.3) * .05;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;/*sin(time + x * y * 0.02) * 5.;*/\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across; \\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;// sin(time*1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1. ,pump);//mix(1., 0., av);\\n float val = mix(.1, pow(snd + 0.2, .5), pump);//sin(time*1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 57906, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3411764705882353, + 0.22745098039215686, + 0.27450980392156865, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = .0;// sin(time + y * 0.2) * .05;\n float yoff = .0;// sin(time + x * 0.3) * .05;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;/*sin(time + x * y * 0.02) * 5.;*/\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across; \n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;// sin(time*1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1. ,pump);//mix(1., 0., av);\n float val = mix(.1, pow(snd + 0.2, .5), pump);//sin(time*1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-1y9thcd97jzjil61t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SLcJWBndqbG7TnEvr/art.json b/art/SLcJWBndqbG7TnEvr/art.json index bcc7ff79..42e271da 100644 --- a/art/SLcJWBndqbG7TnEvr/art.json +++ b/art/SLcJWBndqbG7TnEvr/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":1997,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Motion\\n// CS250 Spring 2022\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = sin(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1997, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Motion\n// CS250 Spring 2022\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = sin(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float sizeOffset = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-v9176pb7l47lnjy5y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SLdjCgFb5gQiFcuAW/art.json b/art/SLdjCgFb5gQiFcuAW/art.json index 3e4f36c1..b6265ac3 100644 --- a/art/SLdjCgFb5gQiFcuAW/art.json +++ b/art/SLdjCgFb5gQiFcuAW/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14245,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 2.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 37.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\\n \\n vCubeCol.xyz = vec3(0,0,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.1;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0.0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, 25.0),1,1,1), color, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 14245, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 2.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 37.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\n \n vCubeCol.xyz = vec3(0,0,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.1;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0.0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, 25.0),1,1,1), color, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-qgxjyqpi1ctwvd7he-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SLhB3b923SkZwRno6/art.json b/art/SLhB3b923SkZwRno6/art.json index a1f3f721..16076a19 100644 --- a/art/SLhB3b923SkZwRno6/art.json +++ b/art/SLhB3b923SkZwRno6/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":80946,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 1, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 24.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float circlesPerRow = 33.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow) * 2.;\\n float cy = floor(circleId / circlesPerRow) * 2.;\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n float sx = cx - circlesPerRow;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx, cy, 0, 0);\\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\\n \\n // scale\\n gl_Position *= scale(1. / 16.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 80946, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 1, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 24.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float circlesPerRow = 33.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow) * 2.;\n float cy = floor(circleId / circlesPerRow) * 2.;\n \n vec2 soundTexCoords = vec2(0, 0);\n float sx = cx - circlesPerRow;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx, cy, 0, 0);\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\n \n // scale\n gl_Position *= scale(1. / 16.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-97f6di9i6t4vcwryg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SMeHXTzP7e6vTniKx/art.json b/art/SMeHXTzP7e6vTniKx/art.json index 6aadac2d..3e0c89ee 100644 --- a/art/SMeHXTzP7e6vTniKx/art.json +++ b/art/SMeHXTzP7e6vTniKx/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "gman", - "settings": "{\"num\":87554,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nilbog-the-band/escape-from-new-york-live-at\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol, \\n out float snd)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n snd = texture2D(sound, vec2(mix(0.05, 0.25, ur), vr * 0.05)).a;\\n float glow = mod(fCubeId, 2.);\\n float glowScale = glow * 1.;\\n //vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = 1. + glowScale * 0.01;\\n float height = mix(1.0, 8.0, pow(hash(posId), 3.0));\\n \\n vCubeOrigin.x = m1p1(u) * across * 1.2 + uBlock * 3.;\\n vCubeOrigin.y = height;\\n vCubeOrigin.z = m1p1(v) * down * 1.2 + vBlock * 3.;\\n \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.98, 0.92, 0.98);\\n \\n mat = ident();\\n // \\tmat *= rotZ(lng);\\n // \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n height * fScale + mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n vCubeCol.xyz = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol.xyz = mix(vCubeCol.xyz, vec3(1,0,0), step(0.95,s2));\\n vCubeCol.xyz = vec3(0,0,0);\\n\\n}\\n\\nvec3 getCameraPointLow(float t) {\\n t = mod(t, 4.);\\n if (t < 1.) return vec3( -28, 9,-26); // red\\n if (t < 2.) return vec3( -28, 9, 25); // yellow\\n if (t < 3.) return vec3( 22, 9, 25); // lime\\n if (t < 4.) return vec3( 22, 9,-26); // aqua-green\\n return vec3(0.0);\\n}\\n\\nvec3 getCameraPoint(float t) {\\n vec3 p0 = getCameraPointLow(t);\\n vec3 p1 = getCameraPointLow(t + 1.);\\n return mix(p0, p1, fract(t));\\n}\\n\\n/*\\nconst float tension = 1.;\\nvec3 getCameraPos(float t) {\\n vec3 p0 = getCameraPointLow(t);\\n vec3 p1 = getCameraPointLow(t + 1.);\\n vec3 p2 = getCameraPointLow(t + 2.);\\n vec3 p3 = getCameraPointLow(t + 3.);\\n \\n float subV = fract(t);\\n float s2 = pow(subV, 2.);\\n float s3 = pow(subV, 3.);\\n \\n float c1 = 2. * s3 - 3. * s2 + 1.;\\n float c2 = -(2. * s3) + 3. * s2; \\n float c3 = s3 - 2. * s2 + subV; \\n float c4 = s3 - s2; \\n\\n vec3 t1 = (p2 - p0) * tension;\\n vec3 t2 = (p3 - p1) * tension;\\n return c1 * p1 + c2 * p2 + c3 * t1 + c4 * t2; \\n}\\n*/\\n\\nvec3 getCameraPos(float t) {\\n return getCameraPoint(t);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time * 0.1;\\n \\n float cameraTime = time * 0.05;\\n vec3 vCameraPos = getCameraPos(cameraTime);\\n vCameraPos.y = mix(2., 22., p1m1(sin(cameraTime * 3.73)));\\n \\n vec3 vCameraTarget = getCameraPos(cameraTime + 0.2);\\n vec3 vT2 = getCameraPos(cameraTime + 0.4);\\n vCameraTarget.y = mix(2., 22., p1m1(sin(cameraTime * 3.73 + 0.2)));\\n \\tvec3 vCameraUp = vec3( 0.0, 1, 0);\\n float slide = 1. - p1m1(dot(\\n normalize(vCameraTarget.xz - vCameraPos.xz), \\n normalize(vT2.xz - vCameraTarget.xz)));\\n \\n mat4 matC = trans(vCameraPos);\\n matC *= rotY(atan(\\n vCameraPos.x - vCameraTarget.x, \\n vCameraPos.z - vCameraTarget.z));\\n matC *= rotZ(-0.6 * slide);\\n matC *= rotX((vCameraPos.y - vCameraTarget.y) * -0.2);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol, snd );\\n\\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= inverse(matC);//cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(hsv2rgb(vec3(floor(mod(cameraTime, 4.)) / 8., 1, 1)), 1);\\n \\tvec4 vFinalColor = mix(vec4(0,0,0,1), color, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n}\"}", + "settings": { + "num": 87554, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nilbog-the-band/escape-from-new-york-live-at", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol, \n out float snd)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n snd = texture2D(sound, vec2(mix(0.05, 0.25, ur), vr * 0.05)).a;\n float glow = mod(fCubeId, 2.);\n float glowScale = glow * 1.;\n //vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = 1. + glowScale * 0.01;\n float height = mix(1.0, 8.0, pow(hash(posId), 3.0));\n \n vCubeOrigin.x = m1p1(u) * across * 1.2 + uBlock * 3.;\n vCubeOrigin.y = height;\n vCubeOrigin.z = m1p1(v) * down * 1.2 + vBlock * 3.;\n \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.98, 0.92, 0.98);\n \n mat = ident();\n // \tmat *= rotZ(lng);\n // \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n height * fScale + mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n vCubeCol.xyz = mix(vec3(0.0), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol.xyz = mix(vCubeCol.xyz, vec3(1,0,0), step(0.95,s2));\n vCubeCol.xyz = vec3(0,0,0);\n\n}\n\nvec3 getCameraPointLow(float t) {\n t = mod(t, 4.);\n if (t < 1.) return vec3( -28, 9,-26); // red\n if (t < 2.) return vec3( -28, 9, 25); // yellow\n if (t < 3.) return vec3( 22, 9, 25); // lime\n if (t < 4.) return vec3( 22, 9,-26); // aqua-green\n return vec3(0.0);\n}\n\nvec3 getCameraPoint(float t) {\n vec3 p0 = getCameraPointLow(t);\n vec3 p1 = getCameraPointLow(t + 1.);\n return mix(p0, p1, fract(t));\n}\n\n/*\nconst float tension = 1.;\nvec3 getCameraPos(float t) {\n vec3 p0 = getCameraPointLow(t);\n vec3 p1 = getCameraPointLow(t + 1.);\n vec3 p2 = getCameraPointLow(t + 2.);\n vec3 p3 = getCameraPointLow(t + 3.);\n \n float subV = fract(t);\n float s2 = pow(subV, 2.);\n float s3 = pow(subV, 3.);\n \n float c1 = 2. * s3 - 3. * s2 + 1.;\n float c2 = -(2. * s3) + 3. * s2; \n float c3 = s3 - 2. * s2 + subV; \n float c4 = s3 - s2; \n\n vec3 t1 = (p2 - p0) * tension;\n vec3 t2 = (p3 - p1) * tension;\n return c1 * p1 + c2 * p2 + c3 * t1 + c4 * t2; \n}\n*/\n\nvec3 getCameraPos(float t) {\n return getCameraPoint(t);\n}\n\n\nvoid main()\n{ \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time * 0.1;\n \n float cameraTime = time * 0.05;\n vec3 vCameraPos = getCameraPos(cameraTime);\n vCameraPos.y = mix(2., 22., p1m1(sin(cameraTime * 3.73)));\n \n vec3 vCameraTarget = getCameraPos(cameraTime + 0.2);\n vec3 vT2 = getCameraPos(cameraTime + 0.4);\n vCameraTarget.y = mix(2., 22., p1m1(sin(cameraTime * 3.73 + 0.2)));\n \tvec3 vCameraUp = vec3( 0.0, 1, 0);\n float slide = 1. - p1m1(dot(\n normalize(vCameraTarget.xz - vCameraPos.xz), \n normalize(vT2.xz - vCameraTarget.xz)));\n \n mat4 matC = trans(vCameraPos);\n matC *= rotY(atan(\n vCameraPos.x - vCameraTarget.x, \n vCameraPos.z - vCameraTarget.z));\n matC *= rotZ(-0.6 * slide);\n matC *= rotX((vCameraPos.y - vCameraTarget.y) * -0.2);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol, snd );\n\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= inverse(matC);//cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(hsv2rgb(vec3(floor(mod(cameraTime, 4.)) / 8., 1, 1)), 1);\n \tvec4 vFinalColor = mix(vec4(0,0,0,1), color, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n}" + }, "screenshotURL": "data/images/images-9z3gelu9q8eyqrgb4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SNLk9sRqLuGqWmAYF/art.json b/art/SNLk9sRqLuGqWmAYF/art.json index 3c528147..39be875f 100644 --- a/art/SNLk9sRqLuGqWmAYF/art.json +++ b/art/SNLk9sRqLuGqWmAYF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00392156862745098,0,0.12156862745098039,1],\"shader\":\"void main() {\\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00392156862745098, + 0, + 0.12156862745098039, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-c5wu5gek5admbi9ng-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SNXZQdmk9EFczeXF6/art.json b/art/SNXZQdmk9EFczeXF6/art.json index 6219ce29..c59e52d1 100644 --- a/art/SNXZQdmk9EFczeXF6/art.json +++ b/art/SNXZQdmk9EFczeXF6/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "davide", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14Gi490kG9D7UEVvtNX8rZBCH1G4jKhV72cfZuabwxg", - "settings": "{\"num\":7063,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\nvoid main() {\\n\\n\\n float across = floor(sqrt(vertexCount));\\n float down = floor(vertexCount/ across);\\n float x = mod(vertexId,across);\\n float y = floor(vertexId/across);\\n \\n float x1 = x/(across - 1.);\\n float y1 = y/(across - 1.);\\n \\n float x2 = x1 * 2. -1.;\\n float y2 = y1 * 2. -1.;\\n \\n float xSineOff = sin(time + y*0.2)*0.1 ;\\n float ySineOff = sin(time + x*0.3)*0.1 ;\\n \\n float x3 = x2 + xSineOff;\\n float y3 = y2 + ySineOff;\\n vec2 xy = vec2(x3,y3) * 0.5;\\n \\n gl_Position = vec4(xy ,0,sin(time)*0.5+0.7);\\n\\n \\n float soff = sin(time);\\n \\n float verticalSize = resolution.y/down +soff;\\n float horizontalSize = resolution.x/across +soff;\\n \\n \\n \\n if(verticalSize 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 1.+time*0.001 - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 10.*time;\\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(3, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 1.;//0.5 + over * 0.7;\\n float sat = step(0.25,s2)*3.;\\n float val = pow(s2*0.01,0.3);\\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( mouse.y, mouse.x, 1.0 );\\n \\tvec3 vCameraPos = vec3(0., 0., 0.5);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hug-life/coppe-666ganstaz-guttertek-666", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 1.+time*0.001 - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\n \n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 10.*time;\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(3, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 1.;//0.5 + over * 0.7;\n float sat = step(0.25,s2)*3.;\n float val = pow(s2*0.01,0.3);\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( mouse.y, mouse.x, 1.0 );\n \tvec3 vCameraPos = vec3(0., 0., 0.5);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\n \tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-9xaplhmvf821ezaeh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SRbaWWFNYiYrDmj9H/art.json b/art/SRbaWWFNYiYrDmj9H/art.json index dae97908..d6e4058e 100644 --- a/art/SRbaWWFNYiYrDmj9H/art.json +++ b/art/SRbaWWFNYiYrDmj9H/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n 01/01/2019 \\n*/ \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n }\\n/*\\n vec3 getQPoint(const float id) \\n {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n }\\n*/\\n void GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n {\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n }\\n#pragma endregion \\n\\n/* -------------------------------- separator ------------------------------- */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/* -------------------------------- separator ------------------------------- */\\n\\t\\nvoid main()\\n{ \\n #pragma region ProjectionSetUp \\n mat4 m = persp(radians(45.),\\n resolution.x/ resolution.y, \\n NEARCLIPPED , \\n FARCLIPPED); \\n #pragma endregion \\n\\n #pragma region CameraSetUp/ViewSetUp\\n vec3 target = vec3(0. ) ;\\n vec3 up = vec3(0. ,1. , 0. ) ; \\n vec3 camTarget = target ; \\n vec3 camPos = vec3(1.); \\n vec3 camForward = normalize(camTarget - camPos);\\n m *= cameraLookAt(camPos , camTarget, normalize(up));\\n #pragma endregion \\n\\n #pragma region model \\n m *= uniformScale(0.7);\\n m *= trans(vec3(1.)) ;\\n m *= rotY(0.2);\\n #pragma endregion \\n \\n \\n #pragma region Light\\n \\t vec3 ambient = vec3(0.) ; \\n \\t vec3 diffuse = vec3(0.) ;\\n \\t vec3 specular = vec3(0.);\\n \\t vec3 result = ambient + diffuse + specular ;\\n #pragma endregion \\n \\n \\n \\n #pragma region TestDFS \\n \\t\\t\\n \\n \\n \\n \\n #pragma endregion\\n \\n \\n \\n #pragma region basic Element\\n gl_Position = m * vec4(1.) ; \\n gl_PointSize *= (vec4(1.0 , 0., 0., 0.)* uniformScale(10.)).x ; \\n v_color = vec4(result, 1. ) ;\\n #pragma endregion \\n \\n \\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n 01/01/2019 \n*/ \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n }\n/*\n vec3 getQPoint(const float id) \n {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n }\n*/\n void GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n {\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n }\n#pragma endregion \n\n/* -------------------------------- separator ------------------------------- */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* -------------------------------- separator ------------------------------- */\n\t\nvoid main()\n{ \n #pragma region ProjectionSetUp \n mat4 m = persp(radians(45.),\n resolution.x/ resolution.y, \n NEARCLIPPED , \n FARCLIPPED); \n #pragma endregion \n\n #pragma region CameraSetUp/ViewSetUp\n vec3 target = vec3(0. ) ;\n vec3 up = vec3(0. ,1. , 0. ) ; \n vec3 camTarget = target ; \n vec3 camPos = vec3(1.); \n vec3 camForward = normalize(camTarget - camPos);\n m *= cameraLookAt(camPos , camTarget, normalize(up));\n #pragma endregion \n\n #pragma region model \n m *= uniformScale(0.7);\n m *= trans(vec3(1.)) ;\n m *= rotY(0.2);\n #pragma endregion \n \n \n #pragma region Light\n \t vec3 ambient = vec3(0.) ; \n \t vec3 diffuse = vec3(0.) ;\n \t vec3 specular = vec3(0.);\n \t vec3 result = ambient + diffuse + specular ;\n #pragma endregion \n \n \n \n #pragma region TestDFS \n \t\t\n \n \n \n \n #pragma endregion\n \n \n \n #pragma region basic Element\n gl_Position = m * vec4(1.) ; \n gl_PointSize *= (vec4(1.0 , 0., 0., 0.)* uniformScale(10.)).x ; \n v_color = vec4(result, 1. ) ;\n #pragma endregion \n \n \n}" + }, "screenshotURL": "data/images/images-w582zuw7q83l2ja67-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SRpckdENpS5Hpem8o/art.json b/art/SRpckdENpS5Hpem8o/art.json index 5edf74fe..93a235d8 100644 --- a/art/SRpckdENpS5Hpem8o/art.json +++ b/art/SRpckdENpS5Hpem8o/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "marcoisaac", "avatarUrl": "https://lh6.googleusercontent.com/-jsbJZMoV7aw/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rczbGrsWSlymdrCUasJ8WzEUV3Ptg/mo/photo.jpg", - "settings": "{\"num\":1300,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\\n/*\\n\\nvoid main()\\n{\\n \\n float width = 20.0;\\n float x = floor(vertexId / width);\\n float y = mod(vertexId, 2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n float radius = 2.0 - y;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n float xOffset = cos(time * 2.0) * 0.2 ;\\n float yOffset = cos(time * 3.0) * 1.0 ;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 0.3;\\n \\n\\n gl_Position = vec4(xy, 0.0, 5.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\\n*/\"}", + "settings": { + "num": 1300, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n\n/*\n\nvoid main()\n{\n \n float width = 20.0;\n float x = floor(vertexId / width);\n float y = mod(vertexId, 2.0);\n \n float angle = x / 20.0 * radians(360.0);\n float radius = 2.0 - y;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n float xOffset = cos(time * 2.0) * 0.2 ;\n float yOffset = cos(time * 3.0) * 1.0 ;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 0.3;\n \n\n gl_Position = vec4(xy, 0.0, 5.0);\n gl_PointSize = 20.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n\n*/" + }, "screenshotURL": "data/images/images-d80ptcy074z1jw9ls-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SSfBNBsGgsKWG8SwQ/art.json b/art/SSfBNBsGgsKWG8SwQ/art.json index e3b1f61c..c1a8d7cf 100644 --- a/art/SSfBNBsGgsKWG8SwQ/art.json +++ b/art/SSfBNBsGgsKWG8SwQ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "liaminjapan", "avatarUrl": "https://avatars.githubusercontent.com/LiamInJapan?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12549019607843137,0,0.3411764705882353,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0,0,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12549019607843137, + 0, + 0.3411764705882353, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0,0,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-y1qh17i4d3kt3jkpc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/STMhyZ8zrQSiJqi7S/art.json b/art/STMhyZ8zrQSiJqi7S/art.json index 86062fa2..e35ffee7 100644 --- a/art/STMhyZ8zrQSiJqi7S/art.json +++ b/art/STMhyZ8zrQSiJqi7S/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define parameter0 0.6//KParameter -5.0>>5.\\n#define parameter1 0.4//KParameter 0.0>>10.\\n#define parameter2 100.//KParameter 10.0>>100.\\n#define parameter3 0.2//KParameter 0.0>>1.\\n#define parameter4 1.//KParameter 0.0>>2.\\n#define parameter5 1.//KParameter 0.0>>1.\\n#define parameter6 1.//KParameter 0.0>>1.\\n#define parameter7 1.//KParameter 0.0>>1.\\n\\n#define PI 3.14159265359\\n//#define time\\n\\nfloat random(float n) {\\n\\treturn fract(abs(sin(n * 55.753) * 367.34));\\n}\\n\\nmat2 rotate2d(float angle){\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\nvoid main( void ) {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n\\tvec2 uv = (simFragCoord.xy * 2.0 - vertexResolution.xy) / vertexResolution.x;\\n\\n\\tuv *= rotate2d(time * parameter3); //time * 0.2\\n\\n\\tfloat direction = 1.0;\\n\\tfloat speed = time * direction * parameter0;\\n\\tfloat distanceFromCenter = length(uv);\\n\\n\\tfloat meteorAngle = atan(uv.y, uv.x) * (180.0 / PI);\\n\\n\\tfloat flooredAngle = floor(meteorAngle);\\n\\tfloat randomAngle = pow(random(flooredAngle), 0.5);\\n\\tfloat t = speed + randomAngle;\\n\\n\\tfloat lightsCountOffset = parameter1;\\n\\tfloat adist = randomAngle / distanceFromCenter * lightsCountOffset;\\n\\tfloat dist = t + adist;\\n\\tfloat meteorDirection = (direction < 0.0) ? -1.0 : 0.0;\\n\\tdist = abs(fract(dist) + meteorDirection);\\n\\n\\tfloat lightLength = parameter2;\\n\\tfloat meteor = (5.0 / dist) * cos(sin(speed)) / lightLength;\\n\\tmeteor *= distanceFromCenter * 5.0;\\n\\n\\tvec3 color = vec3(0.);\\n\\tcolor += meteor;\\n\\n\\tv_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define parameter0 0.6//KParameter -5.0>>5.\n#define parameter1 0.4//KParameter 0.0>>10.\n#define parameter2 100.//KParameter 10.0>>100.\n#define parameter3 0.2//KParameter 0.0>>1.\n#define parameter4 1.//KParameter 0.0>>2.\n#define parameter5 1.//KParameter 0.0>>1.\n#define parameter6 1.//KParameter 0.0>>1.\n#define parameter7 1.//KParameter 0.0>>1.\n\n#define PI 3.14159265359\n//#define time\n\nfloat random(float n) {\n\treturn fract(abs(sin(n * 55.753) * 367.34));\n}\n\nmat2 rotate2d(float angle){\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\nvoid main( void ) {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n\tvec2 uv = (simFragCoord.xy * 2.0 - vertexResolution.xy) / vertexResolution.x;\n\n\tuv *= rotate2d(time * parameter3); //time * 0.2\n\n\tfloat direction = 1.0;\n\tfloat speed = time * direction * parameter0;\n\tfloat distanceFromCenter = length(uv);\n\n\tfloat meteorAngle = atan(uv.y, uv.x) * (180.0 / PI);\n\n\tfloat flooredAngle = floor(meteorAngle);\n\tfloat randomAngle = pow(random(flooredAngle), 0.5);\n\tfloat t = speed + randomAngle;\n\n\tfloat lightsCountOffset = parameter1;\n\tfloat adist = randomAngle / distanceFromCenter * lightsCountOffset;\n\tfloat dist = t + adist;\n\tfloat meteorDirection = (direction < 0.0) ? -1.0 : 0.0;\n\tdist = abs(fract(dist) + meteorDirection);\n\n\tfloat lightLength = parameter2;\n\tfloat meteor = (5.0 / dist) * cos(sin(speed)) / lightLength;\n\tmeteor *= distanceFromCenter * 5.0;\n\n\tvec3 color = vec3(0.);\n\tcolor += meteor;\n\n\tv_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-9f5fa8apiti9tbtb4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/STmreATrsBA7GMBzA/art.json b/art/STmreATrsBA7GMBzA/art.json index 41302314..e6dbc783 100644 --- a/art/STmreATrsBA7GMBzA/art.json +++ b/art/STmreATrsBA7GMBzA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(sin(ofs/max(length(ofs),1e-9))*.3+.7,0.0);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(sin(ofs/max(length(ofs),1e-9))*.3+.7,0.0);\n}" + }, "screenshotURL": "data/images/images-9j767p40uod9wwul3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/STvAdbbowvRQ7XfSb/art.json b/art/STvAdbbowvRQ7XfSb/art.json index a25fa9f1..c06f42ae 100644 --- a/art/STvAdbbowvRQ7XfSb/art.json +++ b/art/STvAdbbowvRQ7XfSb/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":30720,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmag-1/premiere-luigi-madonna-chaudfontaine-pan-pot-remix\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,0.14901960784313725,0,1],\"shader\":\"/*\\n\\n\\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \\n /_/\\\\ /\\\\_\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\_______)\\\\ /\\\\_____\\\\/\\\\ /\\\\ /\\\\/ ____/\\\\ /\\\\_\\\\ /_/\\\\ /\\\\___/\\\\ /\\\\ __/\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\___/\\\\ /_/\\\\__/\\\\ /\\\\_______)\\\\ \\n ) ) ) ( (( (_____/) ) ) ) )\\\\(___ __\\\\/( (_____/\\\\ \\\\ \\\\/ / /) ) __\\\\/( ( (_) ) ) / / _ \\\\ \\\\ ) ) \\\\ \\\\( (_____/) ) ) ) ) / / _ \\\\ \\\\ ) ) ) ) )\\\\(___ __\\\\/ \\n/_/ / \\\\ \\\\_\\\\\\\\ \\\\__\\\\ /_/ /_/_/ / / / \\\\ \\\\__\\\\ \\\\ \\\\ / / \\\\ \\\\ \\\\ \\\\ \\\\___/ / \\\\ \\\\(_)/ // / /\\\\ \\\\ \\\\\\\\ \\\\__\\\\ /_/ /_/_/ \\\\ \\\\(_)/ //_/ /_/_/ / / / \\n\\\\ \\\\ \\\\_/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( / /__/_ / / \\\\ \\\\ _\\\\ \\\\ \\\\ / / _ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( \\n \\\\ \\\\ / /( (_____\\\\)_) ) \\\\ \\\\ \\\\ \\\\ \\\\ ( (_____\\\\/ / /\\\\ \\\\ \\\\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\\\)_) ) \\\\ \\\\( (_( )_) ))_) ) \\\\ \\\\ \\\\ \\\\ \\\\ \\n \\\\_\\\\_/_/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ /_/_/ \\\\/_____/\\\\/__\\\\/__\\\\/\\\\____\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/___\\\\/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\_\\\\/ \\\\_\\\\/ /_/_/ \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 256.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 2.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float edgeId = mod(vertexId, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float u2 = floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE;\\n float snd = texture2D(sound, vec2(mix(0.0, 0.25, hash(u2)), 0.0)).a;\\n float inner = mix(0.5, 1.0, pow(snd + .3, 5.0));//0.9; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\\n float start = fract(hash(circleId * 0.33));\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n \\n vec3 offset = vec3(m1p1(hash(circleId * floor(time * 1.2) * 0.123)), m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset = vec3(0);\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.2, 0.3, pow(snd, 1.)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n vec3 cc = mix(vec3(1), vec3(0), mod(circleId, 2.0));\\n vec3 fl = mix(vec3(0,1,1), vec3(.5,1,1), mod(time * 60.0, 2.0)); \\n vec3 c2 = mix(cc, fl, step(0.8, snd));\\n float hue = fract(circleId);//, 1., step(0.75, snd));\\n float sat = step(0.5, snd);\\n float val = mod(circleId, 2.);step(0.50, snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb = c2;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}//sss\"}", + "settings": { + "num": 30720, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmag-1/premiere-luigi-madonna-chaudfontaine-pan-pot-remix", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 0.14901960784313725, + 0, + 1 + ], + "shader": "/*\n\n\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \n /_/\\ /\\_\\ /\\_____\\/_/\\__/\\ /\\_______)\\ /\\_____\\/\\ /\\ /\\/ ____/\\ /\\_\\ /_/\\ /\\___/\\ /\\ __/\\ /\\_____\\/_/\\__/\\ /\\___/\\ /_/\\__/\\ /\\_______)\\ \n ) ) ) ( (( (_____/) ) ) ) )\\(___ __\\/( (_____/\\ \\ \\/ / /) ) __\\/( ( (_) ) ) / / _ \\ \\ ) ) \\ \\( (_____/) ) ) ) ) / / _ \\ \\ ) ) ) ) )\\(___ __\\/ \n/_/ / \\ \\_\\\\ \\__\\ /_/ /_/_/ / / / \\ \\__\\ \\ \\ / / \\ \\ \\ \\ \\___/ / \\ \\(_)/ // / /\\ \\ \\\\ \\__\\ /_/ /_/_/ \\ \\(_)/ //_/ /_/_/ / / / \n\\ \\ \\_/ / // /__/_\\ \\ \\ \\ \\ ( ( ( / /__/_ / / \\ \\ _\\ \\ \\ / / _ \\ \\ / / _ \\ \\\\ \\ \\/ / // /__/_\\ \\ \\ \\ \\ / / _ \\ \\\\ \\ \\ \\ \\ ( ( ( \n \\ \\ / /( (_____\\)_) ) \\ \\ \\ \\ \\ ( (_____\\/ / /\\ \\ \\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\)_) ) \\ \\( (_( )_) ))_) ) \\ \\ \\ \\ \\ \n \\_\\_/_/ \\/_____/\\_\\/ \\_\\/ /_/_/ \\/_____/\\/__\\/__\\/\\____\\/ \\/_/ \\_\\/ \\/_/ \\_\\/ \\/___\\/ \\/_____/\\_\\/ \\_\\/ \\/_/ \\_\\/ \\_\\/ \\_\\/ /_/_/ \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 256.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 2.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float edgeId = mod(vertexId, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float u2 = floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE;\n float snd = texture2D(sound, vec2(mix(0.0, 0.25, hash(u2)), 0.0)).a;\n float inner = mix(0.5, 1.0, pow(snd + .3, 5.0));//0.9; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\n float start = fract(hash(circleId * 0.33));\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n \n vec3 offset = vec3(m1p1(hash(circleId * floor(time * 1.2) * 0.123)), m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset = vec3(0);\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.2, 0.3, pow(snd, 1.)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n vec3 cc = mix(vec3(1), vec3(0), mod(circleId, 2.0));\n vec3 fl = mix(vec3(0,1,1), vec3(.5,1,1), mod(time * 60.0, 2.0)); \n vec3 c2 = mix(cc, fl, step(0.8, snd));\n float hue = fract(circleId);//, 1., step(0.75, snd));\n float sat = step(0.5, snd);\n float val = mod(circleId, 2.);step(0.50, snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb = c2;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}//sss" + }, "screenshotURL": "data/images/images-ll09yg2jjjvmza1r3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SWCEzMNTmvcDAxs3n/art.json b/art/SWCEzMNTmvcDAxs3n/art.json index 96398d44..ccf3b537 100644 --- a/art/SWCEzMNTmvcDAxs3n/art.json +++ b/art/SWCEzMNTmvcDAxs3n/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":2527,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float resX = resolution.x;\\n float resY = resolution.y;\\n float resArea = resX * resY;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertCountX = floor(resX/vertLen);\\n float vertCountY = floor(resY/vertLen);\\n \\n float x = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\\n float y = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\\n \\n \\n \\n gl_Position = vec4((x - 0.5)*2., (y - 0.5)*2., 0, 1);\\n gl_PointSize = vertLen*1.05;\\n v_color = vec4(hsv2rgb(vec3(x+y+time/10., 1, 1)), 1);\\n}\"}", + "settings": { + "num": 2527, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float resX = resolution.x;\n float resY = resolution.y;\n float resArea = resX * resY;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertCountX = floor(resX/vertLen);\n float vertCountY = floor(resY/vertLen);\n \n float x = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\n float y = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\n \n \n \n gl_Position = vec4((x - 0.5)*2., (y - 0.5)*2., 0, 1);\n gl_PointSize = vertLen*1.05;\n v_color = vec4(hsv2rgb(vec3(x+y+time/10., 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-43doihtyjc2ogjpvn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SYLXTDKJmDrAcAiNE/art.json b/art/SYLXTDKJmDrAcAiNE/art.json index b32e67f6..91016878 100644 --- a/art/SYLXTDKJmDrAcAiNE/art.json +++ b/art/SYLXTDKJmDrAcAiNE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":5178,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/subjex/richard\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100536\\n\\n#define soundFactor 0.02 //KParameter0 0.>>1.\\n#define speedFactor 1.4//KParameter1 0.>>4.\\n#define sinFactor0 32.//KParameter2 1.>>100.\\n#define sinFactor1 11.//KParameter3 1.>>100.\\n\\n\\n\\n#define PI 3.1415926535898\\n#define HPI 1.570796326795\\n#define SF (soundFactor * 2.)\\nfloat SPF = (speedFactor*mouse.x);\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43658.5453123, 1345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI * SPF));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.3, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n \\n vec3 rgb;\\n vec3 lit = normalize(vec3(SF, 9.0, 4.0));\\n \\n float diffuse = max(0.70, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\\n }\\n \\n rgb = diffuse * (_dfscol *SF)+ specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvec3 giantWorm(vec3 a, float t) {\\n return vec3(sin(t*sinFactor0 * a.x), sin(t*sinFactor1 * a.y), cos(t * a.z));\\n}\\n\\n\\nvec3 transformation(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, SF, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, SF, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float lineId = 0.;//mod(shapeId, 3.0);\\n float SPF = speedFactor;\\n \\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 0.0) {\\n lineFactor = vec3(4.1, 6.7, 2.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else if(lineId == .0) {\\n lineFactor = vec3(4.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(0.0, 1.6, 0.0);\\n }\\n \\n float v = vertexId / vertexCount;\\n float distort = mod(vertexId, 100.) / (300. /v);\\n float snd = soundFactor*texture2D(sound, vec2(mix(0.1, 0.061, distort), mix(0.25, 0., v))).a;\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 shapeni;\\n vec3 shapep = shapeVertex(shapeVertexId, shapeni) * 0.04/sin(SPF+time);\\n \\n vec3 shapeHash = noise(vec3(log(shapeId)));\\n float factor = 0.3+snd;\\n float factor2 = 0.005;\\n vec3 shapeOffset = vec3(factor*sin(factor2*time*shapeId),factor*sin(factor2*time*shapeId),0.);\\n vec3 shapeRot = noise(shapeHash) * time * 2.0*speedFactor;\\n \\n shapep = rotX(rotY(rotZ(shapep, shapeRot.z), shapeRot.y), shapeRot.z);\\n shapeni.xyz = rotX(rotY(rotZ(shapeni.xyz, shapeRot.z), shapeRot.y), shapeRot.z);\\n \\n shapep = transformation(lineFactor, (t * time * 0.01/speedFactor) * 2.0) * vec3(aspect, 1.0, aspect) + (shapep + shapeOffset);\\n SPF * mouse.x;\\n \\n vec3 eye = vec3(0.0, SF, 3.0);\\n \\n color = shade(eye, shapep, shapeni.xyz, vec3(0.5 + shapeHash * 0.05), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookAt(shapep, eye, vec3(1.0), vec3(snd, 1.0, snd*8.));\\n gl_Position = perspective(p, 60.0, 0.01, 22.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color+mouse.x-p, 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 5178, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/subjex/richard", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100536\n\n#define soundFactor 0.02 //KParameter0 0.>>1.\n#define speedFactor 1.4//KParameter1 0.>>4.\n#define sinFactor0 32.//KParameter2 1.>>100.\n#define sinFactor1 11.//KParameter3 1.>>100.\n\n\n\n#define PI 3.1415926535898\n#define HPI 1.570796326795\n#define SF (soundFactor * 2.)\nfloat SPF = (speedFactor*mouse.x);\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43658.5453123, 1345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI * SPF));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.3, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n \n vec3 rgb;\n vec3 lit = normalize(vec3(SF, 9.0, 4.0));\n \n float diffuse = max(0.70, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\n }\n \n rgb = diffuse * (_dfscol *SF)+ specular * _spec.y;\n \n return rgb;\n}\n\n\nvec3 giantWorm(vec3 a, float t) {\n return vec3(sin(t*sinFactor0 * a.x), sin(t*sinFactor1 * a.y), cos(t * a.z));\n}\n\n\nvec3 transformation(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, SF, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, SF, faceId);\n }\n \n return v;\n}\n\n\n\n\n\n\nvoid main() {\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float lineId = 0.;//mod(shapeId, 3.0);\n float SPF = speedFactor;\n \n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 0.0) {\n lineFactor = vec3(4.1, 6.7, 2.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else if(lineId == .0) {\n lineFactor = vec3(4.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 1.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(0.0, 1.6, 0.0);\n }\n \n float v = vertexId / vertexCount;\n float distort = mod(vertexId, 100.) / (300. /v);\n float snd = soundFactor*texture2D(sound, vec2(mix(0.1, 0.061, distort), mix(0.25, 0., v))).a;\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 shapeni;\n vec3 shapep = shapeVertex(shapeVertexId, shapeni) * 0.04/sin(SPF+time);\n \n vec3 shapeHash = noise(vec3(log(shapeId)));\n float factor = 0.3+snd;\n float factor2 = 0.005;\n vec3 shapeOffset = vec3(factor*sin(factor2*time*shapeId),factor*sin(factor2*time*shapeId),0.);\n vec3 shapeRot = noise(shapeHash) * time * 2.0*speedFactor;\n \n shapep = rotX(rotY(rotZ(shapep, shapeRot.z), shapeRot.y), shapeRot.z);\n shapeni.xyz = rotX(rotY(rotZ(shapeni.xyz, shapeRot.z), shapeRot.y), shapeRot.z);\n \n shapep = transformation(lineFactor, (t * time * 0.01/speedFactor) * 2.0) * vec3(aspect, 1.0, aspect) + (shapep + shapeOffset);\n SPF * mouse.x;\n \n vec3 eye = vec3(0.0, SF, 3.0);\n \n color = shade(eye, shapep, shapeni.xyz, vec3(0.5 + shapeHash * 0.05), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookAt(shapep, eye, vec3(1.0), vec3(snd, 1.0, snd*8.));\n gl_Position = perspective(p, 60.0, 0.01, 22.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color+mouse.x-p, 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-rthmchh93i3ckvmwc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SZgEYFYSHKMqWSBCo/art.json b/art/SZgEYFYSHKMqWSBCo/art.json index 5b2cda6c..36a373b2 100644 --- a/art/SZgEYFYSHKMqWSBCo/art.json +++ b/art/SZgEYFYSHKMqWSBCo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "palazzol", "avatarUrl": "https://avatars.githubusercontent.com/palazzol?s=200", - "settings": "{\"num\":52720,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n // vertex_percent is vertexId mapped to [0..1]\\n float vertex_percent = vertexId / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\\n float x = vertex_percent*2.0 - 1.0; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\\n \\n // sound texture has (amplitude, history) for (u,v). \\n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\\n // It is all in the alpha channel of the sound texture\\n \\n // Set y position to amplitude in [0..1] range.\\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\\n float y = texture2D(sound,vec2(vertex_percent,0.0)).a; \\n \\n float q = floor(sqrt(vertexCount));\\n float x_percent = (mod(vertexId, q)) / q;\\n float y_percent = (floor(vertexId / q)) / q;\\n \\n x = (x_percent*2.0 - 1.0)*0.5;\\n y = -(y_percent*2.0 - 1.0)*0.5;\\n \\n x = x + x * 0.2*sin(vertex_percent*20.0+time*15.0);\\n y = y + y * 0.2*cos(vertex_percent*30.0+time*15.0);\\n \\n \\n gl_PointSize = 10.0; // Set point size in case want to render points instead of line, not used in line\\n gl_Position = vec4(x,y,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\\n v_color = vec4(1.0-x_percent, y_percent, x_percent, 1.0); // Just setting to the color white with opacity=1\\n\\n}\\n\"}", + "settings": { + "num": 52720, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n // vertex_percent is vertexId mapped to [0..1]\n float vertex_percent = vertexId / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\n float x = vertex_percent*2.0 - 1.0; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\n \n // sound texture has (amplitude, history) for (u,v). \n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\n // It is all in the alpha channel of the sound texture\n \n // Set y position to amplitude in [0..1] range.\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\n float y = texture2D(sound,vec2(vertex_percent,0.0)).a; \n \n float q = floor(sqrt(vertexCount));\n float x_percent = (mod(vertexId, q)) / q;\n float y_percent = (floor(vertexId / q)) / q;\n \n x = (x_percent*2.0 - 1.0)*0.5;\n y = -(y_percent*2.0 - 1.0)*0.5;\n \n x = x + x * 0.2*sin(vertex_percent*20.0+time*15.0);\n y = y + y * 0.2*cos(vertex_percent*30.0+time*15.0);\n \n \n gl_PointSize = 10.0; // Set point size in case want to render points instead of line, not used in line\n gl_Position = vec4(x,y,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\n v_color = vec4(1.0-x_percent, y_percent, x_percent, 1.0); // Just setting to the color white with opacity=1\n\n}\n" + }, "screenshotURL": "data/images/images-h2nnc5fphy29ryko5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SbtAs2XinPEhh4y92/art.json b/art/SbtAs2XinPEhh4y92/art.json index a75d4c89..928a91ea 100644 --- a/art/SbtAs2XinPEhh4y92/art.json +++ b/art/SbtAs2XinPEhh4y92/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juseungyang", "avatarUrl": "https://secure.gravatar.com/avatar/81eafc39caedbb2647494280a881bf6a?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotz(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(c,-s,0,0,s,c,0,0,0,0,1,0,0,0,0,1);\\n \\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n\\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, trans,1);\\n \\n}\\n\\nmat4 ident()\\n{\\n\\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1);\\n \\n}\\n\\nmat4 scale(vec3 s)\\n{\\n\\n return mat4(s[0],0,0,0, 0,s[1],0,0, 0,0,s[2],0, 0,0,0,1);\\n \\n}\\n\\nmat4 uniformScale(float s)\\n{\\n\\n return mat4(s,0,0,0, 0,s,0,0, 0,0,s,0, 0,0,0,1);\\n \\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\t\\n}\\nvoid main() \\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\\n \\n sc*= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotz(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotz(snd * 20. * sign(ux));\\n mat *= uniformScale(0.02 * sc);\\n \\n \\n vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0.5, 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n//name : Juseung Yang\\n//assignment name/number : Exercise - Vertexshaderart : Circles from Triangles\\n//course name : CS250\\n//term : 2023/05/31\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotz(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(c,-s,0,0,s,c,0,0,0,0,1,0,0,0,0,1);\n \n}\n\nmat4 trans(vec3 trans)\n{\n\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, trans,1);\n \n}\n\nmat4 ident()\n{\n\n return mat4(1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1);\n \n}\n\nmat4 scale(vec3 s)\n{\n\n return mat4(s[0],0,0,0, 0,s[1],0,0, 0,0,s[2],0, 0,0,0,1);\n \n}\n\nmat4 uniformScale(float s)\n{\n\n return mat4(s,0,0,0, 0,s,0,0, 0,0,s,0, 0,0,0,1);\n \n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\t\n}\nvoid main() \n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\n \n sc*= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= rotz(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotz(snd * 20. * sign(ux));\n mat *= uniformScale(0.02 * sc);\n \n \n vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0.5, 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n\n//name : Juseung Yang\n//assignment name/number : Exercise - Vertexshaderart : Circles from Triangles\n//course name : CS250\n//term : 2023/05/31\n\n" + }, "screenshotURL": "data/images/images-wyfd5cdovwto97799-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ScY8ZMw5DYqe8DXMk/art.json b/art/ScY8ZMw5DYqe8DXMk/art.json index 2fb6e321..19c34b1a 100644 --- a/art/ScY8ZMw5DYqe8DXMk/art.json +++ b/art/ScY8ZMw5DYqe8DXMk/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//Circles from Triangles exercise\\n//CS250\\n//2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI*2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 36.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down); \\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n \\n float aspect = resolution.x/resolution.y;\\n float sc = pow(snd + 0.2, 5.)*mix(1., 1.1 ,oddSlice);\\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = 1.;\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//Circles from Triangles exercise\n//CS250\n//2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\nvec2 getCirclePoint(float id, float numCircleSegments){\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI*2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n \n float numCircleSegments = 36.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down); \n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n \n float aspect = resolution.x/resolution.y;\n float sc = pow(snd + 0.2, 5.)*mix(1., 1.1 ,oddSlice);\n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = 1.;\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-ju77kwv6widwys1dc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ScnXYT2B8gmr2trfw/art.json b/art/ScnXYT2B8gmr2trfw/art.json index 81784f33..5d393667 100644 --- a/art/ScnXYT2B8gmr2trfw/art.json +++ b/art/ScnXYT2B8gmr2trfw/art.json @@ -17,7 +17,19 @@ "name": "disco ball", "private": false, "username": "-anon-", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\n\\n#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n \\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n for (int i = 0; i < 100; i++) {\\n float f=float(i);\\n light += pow(dot(normalize(vec3(sin(float(i)),sin(float(i)*1.3),cos(float(i)*1.43))),norm)*.5+.5,70.)*abs(vec3(sin(f*4.2),cos(f*2.5),cos(f*1.9)))*.4;\\n }\\n \\n \\n /*\\n \\n pow(dot(normalize(vec3(.3,.4,-.5)),norm)*.5+.5,50.)*vec3(.8,.3,.2)\\n \\t+ pow(dot(normalize(vec3(.1,-.2,-.5)),norm)*.5+.5,50.)*vec3(.2,.3,.8)\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,50.)*vec3(.2,.7,.4)\\n \\t+ pow(dot(normalize(vec3(.7,-.2,-.5)),norm)*.5+.5,50.)*vec3(.7,.6,.1);\\n */\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n v_color = vec4(vec3(light), 1);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\n\n#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n \n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n for (int i = 0; i < 100; i++) {\n float f=float(i);\n light += pow(dot(normalize(vec3(sin(float(i)),sin(float(i)*1.3),cos(float(i)*1.43))),norm)*.5+.5,70.)*abs(vec3(sin(f*4.2),cos(f*2.5),cos(f*1.9)))*.4;\n }\n \n \n /*\n \n pow(dot(normalize(vec3(.3,.4,-.5)),norm)*.5+.5,50.)*vec3(.8,.3,.2)\n \t+ pow(dot(normalize(vec3(.1,-.2,-.5)),norm)*.5+.5,50.)*vec3(.2,.3,.8)\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,50.)*vec3(.2,.7,.4)\n \t+ pow(dot(normalize(vec3(.7,-.2,-.5)),norm)*.5+.5,50.)*vec3(.7,.6,.1);\n */\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n v_color = vec4(vec3(light), 1);\n}" + }, "screenshotURL": "data/images/images-qfvn7dfci5ce9cu6t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SenDt74iq42gPkfJk/art.json b/art/SenDt74iq42gPkfJk/art.json index e201fe53..f4565f8b 100644 --- a/art/SenDt74iq42gPkfJk/art.json +++ b/art/SenDt74iq42gPkfJk/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":584,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Making A Grid\\n//cs250\\n//spring2023\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n float x = mod(vertexId ,across);\\n float y = floor(vertexId/across);\\n \\n float u= x /(across-1.);\\n float v= y/(across-1.);\\n \\n float ux = u* 2. -1.;\\n float vy = v* 2.-1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 584, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Making A Grid\n//cs250\n//spring2023\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount /down);\n float x = mod(vertexId ,across);\n float y = floor(vertexId/across);\n \n float u= x /(across-1.);\n float v= y/(across-1.);\n \n float ux = u* 2. -1.;\n float vy = v* 2.-1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n \n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-l7dxr8ig2smnbir0m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/SfWoZkJqAcdQ6baq5/art.json b/art/SfWoZkJqAcdQ6baq5/art.json index 36fefe9a..fb3e9884 100644 --- a/art/SfWoZkJqAcdQ6baq5/art.json +++ b/art/SfWoZkJqAcdQ6baq5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\\n{\\n vec2 finalRes = vec2(1.,1.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n _maxvertexCount = floor(vertexCount*ratioXforY);\\n \\n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\\n \\n return vec2(finalRes.x,finalRes.x/ratioXforY);\\n}\\n \\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float ratioXforY = resolution.y/resolution.x;\\n float ratioXforX = resolution.x/resolution.y;\\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalResolution = vec2(sqrt(ratioXforX * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n //float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n //float ratio = resolution.y/numAcrossDown;\\n \\n //float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n float x = mod(finalVertexId, finalResolution.x);\\n float y = floor(finalVertexId / finalResolution.y);\\n \\n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\\n float v = (y / finalResolution.y);\\n \\n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\\n \\n float vy = ( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n \\n //apply fragment logic\\n\\n vec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n \\n \\n\\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n //end of fragment logic\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 1.;(resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\n{\n vec2 finalRes = vec2(1.,1.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n _maxvertexCount = floor(vertexCount*ratioXforY);\n \n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\n \n return vec2(finalRes.x,finalRes.x/ratioXforY);\n}\n \nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float ratioXforY = resolution.y/resolution.x;\n float ratioXforX = resolution.x/resolution.y;\n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalResolution = vec2(sqrt(ratioXforX * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n //float numAcrossDown = floor(sqrt(finalVertexCount));\n \n //float ratio = resolution.y/numAcrossDown;\n \n //float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n float x = mod(finalVertexId, finalResolution.x);\n float y = floor(finalVertexId / finalResolution.y);\n \n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\n float v = (y / finalResolution.y);\n \n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\n \n float vy = ( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n \n //apply fragment logic\n\n vec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n \n \n\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n //end of fragment logic\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 1.;(resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-7k4gls9jj8w6s7pka-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SgSd9NeMcEY53XNTJ/art.json b/art/SgSd9NeMcEY53XNTJ/art.json index a697debf..8e9af89f 100644 --- a/art/SgSd9NeMcEY53XNTJ/art.json +++ b/art/SgSd9NeMcEY53XNTJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.7686274509803922,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.7686274509803922, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-nlqqsec09woe2pub0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SgsEwB5Ax2ySwLYpd/art.json b/art/SgsEwB5Ax2ySwLYpd/art.json index 8a6c5344..1e5648d3 100644 --- a/art/SgsEwB5Ax2ySwLYpd/art.json +++ b/art/SgsEwB5Ax2ySwLYpd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 1.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nvec3 getCurvePoint(const float id, vec3 pos) {\\n /*return vec3(\\n \\n sin(id),\\n sin(id),\\n cos(id));\\n*/\\n \\n return vec3(pos.x+sin(time+id*0.99), pos.y+sin(time+id*0.7), pos.z+sin(time+id*0.11));\\n}\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 15.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n //xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n //lineId+=mod(time*10.,1.);\\n //lineId/=numberOfElement;\\n\\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n \\n vec3 circleCenter = vec3(-1.5,0.,0.);\\n \\n //float xcircleRadius = 0.4;\\n //circleCenter.x -= 1.;\\n\\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\\n //cubep.z += sin(lineId*2.*PI);\\n //cubep = rot(circleCenter,PI/10.);\\n //cubep.x -= circleCenter.x;\\n \\n //cubep.x += cos(xPos*2.*PI)/10.;\\n //cubep.y += sin(xPos*2.*PI)/10.;\\n \\n cubep = getCurvePoint(shapeId, cubep);\\n \\n /*\\n cubep += circleCenter;\\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines);\\n cubep -= circleCenter;\\n*/\\n\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n //cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0.2, 10., .2);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(-1., 3., -1.);\\n //cubep += distance(cubep, eye)/7.;\\n \\n //cubep.x += 0.2;\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 1.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nvec3 getCurvePoint(const float id, vec3 pos) {\n /*return vec3(\n \n sin(id),\n sin(id),\n cos(id));\n*/\n \n return vec3(pos.x+sin(time+id*0.99), pos.y+sin(time+id*0.7), pos.z+sin(time+id*0.11));\n}\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 15.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n //xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n //lineId+=mod(time*10.,1.);\n //lineId/=numberOfElement;\n\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n \n vec3 circleCenter = vec3(-1.5,0.,0.);\n \n //float xcircleRadius = 0.4;\n //circleCenter.x -= 1.;\n\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\n //cubep.z += sin(lineId*2.*PI);\n //cubep = rot(circleCenter,PI/10.);\n //cubep.x -= circleCenter.x;\n \n //cubep.x += cos(xPos*2.*PI)/10.;\n //cubep.y += sin(xPos*2.*PI)/10.;\n \n cubep = getCurvePoint(shapeId, cubep);\n \n /*\n cubep += circleCenter;\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines);\n cubep -= circleCenter;\n*/\n\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n //cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0.2, 10., .2);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(-1., 3., -1.);\n //cubep += distance(cubep, eye)/7.;\n \n //cubep.x += 0.2;\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-u0hhmzltgfy17w64m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Siq7bKzSywBNKoE5B/art.json b/art/Siq7bKzSywBNKoE5B/art.json index f80cc7ea..60566f47 100644 --- a/art/Siq7bKzSywBNKoE5B/art.json +++ b/art/Siq7bKzSywBNKoE5B/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//woozy by gman\\n\\n//KDrawmode=GL_LINES\\n#define PointsCntrl 30.//KParameter0 15.>>45.\\n#define PumpCntrl 0.9//KParameter1 0.1>>0.9\\n#define SndCntrl 0.5//KParameter2 0.1>>0.9\\n#define AngleCntrl 21.//KParameter3 10.>>50.\\n#define ColorCntrl 5.//KParameter4 1.>>10.\\n#define ScaleCntrl 1.1//KParameter5 0.4>>1.4\\n#define RadiusCntrl 8.//KParameter6 1.>>20.\\n#define Squiggle 1.//KParameter7 1.>>10.\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float pointsPerLine = PointsCntrl;\\n float lineId = floor(vertexId / pointsPerLine);\\n float numLines = floor(vertexCount / pointsPerLine);\\n\\n float lineV = lineId / numLines;\\n float angle = lineV * PI * 2.;\\n \\n float pointId = mod(vertexId, pointsPerLine);\\n float pointV = pointId / (pointsPerLine - floor(pointsPerLine / Squiggle));\\n \\n float id = floor(pointId / 2.) + mod(pointId, 2.);\\n float idV = id / (pointsPerLine / 2. - 1.);\\n \\n float snd = texture2D(sound, vec2(abs(lineV - 0.5) * 0.15, pointV * SndCntrl)).a;\\n \\n float odd = mod(id, 2.);\\n angle += sin(time + idV * AngleCntrl) * odd * 0.2 + time * 0.1 + snd * 0.;\\n// angle += odd * 0.2;\\n \\n// float radius = pow(idV + 1., 2.) - 3.0;\\n float radius = pow(idV, 2.) + sin(time + lineV * PI * 2. * RadiusCntrl) * odd * idV * 0.1;\\n float c = cos(angle) * radius;\\n float s = sin(angle) * radius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y) * ScaleCntrl;\\n vec2 xy = vec2(c, s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n float p = 1. - pow(snd, ColorCntrl);\\n float pump = step(PumpCntrl, snd);\\n v_color = vec4(0, p, p, idV) + pump * vec4(0,10,10,0);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//woozy by gman\n\n//KDrawmode=GL_LINES\n#define PointsCntrl 30.//KParameter0 15.>>45.\n#define PumpCntrl 0.9//KParameter1 0.1>>0.9\n#define SndCntrl 0.5//KParameter2 0.1>>0.9\n#define AngleCntrl 21.//KParameter3 10.>>50.\n#define ColorCntrl 5.//KParameter4 1.>>10.\n#define ScaleCntrl 1.1//KParameter5 0.4>>1.4\n#define RadiusCntrl 8.//KParameter6 1.>>20.\n#define Squiggle 1.//KParameter7 1.>>10.\n\n#define PI radians(180.0)\n\nvoid main() {\n float pointsPerLine = PointsCntrl;\n float lineId = floor(vertexId / pointsPerLine);\n float numLines = floor(vertexCount / pointsPerLine);\n\n float lineV = lineId / numLines;\n float angle = lineV * PI * 2.;\n \n float pointId = mod(vertexId, pointsPerLine);\n float pointV = pointId / (pointsPerLine - floor(pointsPerLine / Squiggle));\n \n float id = floor(pointId / 2.) + mod(pointId, 2.);\n float idV = id / (pointsPerLine / 2. - 1.);\n \n float snd = texture2D(sound, vec2(abs(lineV - 0.5) * 0.15, pointV * SndCntrl)).a;\n \n float odd = mod(id, 2.);\n angle += sin(time + idV * AngleCntrl) * odd * 0.2 + time * 0.1 + snd * 0.;\n// angle += odd * 0.2;\n \n// float radius = pow(idV + 1., 2.) - 3.0;\n float radius = pow(idV, 2.) + sin(time + lineV * PI * 2. * RadiusCntrl) * odd * idV * 0.1;\n float c = cos(angle) * radius;\n float s = sin(angle) * radius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y) * ScaleCntrl;\n vec2 xy = vec2(c, s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n float p = 1. - pow(snd, ColorCntrl);\n float pump = step(PumpCntrl, snd);\n v_color = vec4(0, p, p, idV) + pump * vec4(0,10,10,0);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-v17gdabjoyhwwig1o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SnHzmTdr25on3o4Zs/art.json b/art/SnHzmTdr25on3o4Zs/art.json index 3ae065e2..02db0998 100644 --- a/art/SnHzmTdr25on3o4Zs/art.json +++ b/art/SnHzmTdr25on3o4Zs/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.25882352941176473,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Audio Reactive\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound,vec2(au* 0.05,av*0.25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd+0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8,snd);\\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\\n float sat = mix(0.0, 1.0, pump); //1.0 - av;\\n float val = mix(0.1, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.25882352941176473, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Audio Reactive\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound,vec2(au* 0.05,av*0.25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd+0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8,snd);\n float hue = u * 0.1 + snd * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\n float sat = mix(0.0, 1.0, pump); //1.0 - av;\n float val = mix(0.1, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-af528ljg6sc778rto-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SnqDnsfrYzTPyN2BA/art.json b/art/SnqDnsfrYzTPyN2BA/art.json index af411787..87d6a7d7 100644 --- a/art/SnqDnsfrYzTPyN2BA/art.json +++ b/art/SnqDnsfrYzTPyN2BA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "demofox", "avatarUrl": "https://secure.gravatar.com/avatar/9522425587344b887bcb7c65d236f3a3?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F26fe85a4d3a90c20c51e30967cac6501", - "settings": "{\"num\":24,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define VERTEX_DATA(inpos, inuv) vert += 1.0; if (vertexId == vert) {pos = inpos; uv = inuv;}\\n\\n\\nvoid main() {\\n \\n // vertices\\n const vec2 AP = vec2(0.4, 0.2);\\n const vec2 AU = vec2(0.0, 0.0);\\n \\n const vec2 BP = vec2(0.6, 0.2);\\n const vec2 BU = vec2(1.0, 0.0); \\n\\n const vec2 CP = vec2(0.4, 0.5);\\n const vec2 CU = vec2(0.0, 0.7);\\n \\n const vec2 DP = vec2(0.6, 0.5);\\n const vec2 DU = vec2(1.0, 0.7); \\n \\n const vec2 EP = vec2(0.5, 0.6);\\n const vec2 EU = vec2(0.5, 0.5);\\n \\n const vec2 FP = vec2(0.7, 0.8);\\n const vec2 FU = vec2(0.0, 1.0);\\n \\n const vec2 GP = vec2(0.8, 0.7);\\n const vec2 GU = vec2(1.0, 1.0);\\n \\n const vec2 HP = vec2(0.2, 0.7);\\n const vec2 HU = vec2(0.0, 1.0); \\n \\n const vec2 IP = vec2(0.3, 0.8);\\n const vec2 IU = vec2(1.0, 1.0); \\n \\n const vec2 JP = vec2(0.5, 0.5);\\n const vec2 JU = vec2(0.5, 0.7); \\n \\n const vec2 KP = vec2(0.5, 0.6);\\n const vec2 KU = vec2(1.0, 0.7); \\n \\n const vec2 LP = vec2(0.5, 0.6);\\n const vec2 LU = vec2(0.0, 0.7); \\n \\n \\n // make the mesh\\n vec2 pos = vec2(0.0, 0.0);\\n vec2 uv = vec2(0.0, 0.0); \\n float vert = -1.0;\\n \\n VERTEX_DATA(AP, AU);\\n VERTEX_DATA(DP, DU);\\n VERTEX_DATA(BP, BU);\\n \\n VERTEX_DATA(AP, AU);\\n VERTEX_DATA(CP, CU);\\n VERTEX_DATA(DP, DU); \\n \\n #if 0\\n \\n VERTEX_DATA(CP, CU);\\n VERTEX_DATA(EP, EU);\\n VERTEX_DATA(DP, DU); \\n \\n VERTEX_DATA(CP, CU);\\n VERTEX_DATA(IP, IU);\\n VERTEX_DATA(EP, EU); \\n \\n VERTEX_DATA(EP, EU);\\n VERTEX_DATA(FP, FU);\\n VERTEX_DATA(GP, GU); \\n \\n VERTEX_DATA(EP, EU);\\n VERTEX_DATA(GP, GU);\\n VERTEX_DATA(DP, DU);\\n \\n \\n #else\\n \\n VERTEX_DATA(CP, CU);\\n VERTEX_DATA(KP, KU);\\n VERTEX_DATA(JP, JU);\\n\\n VERTEX_DATA(JP, JU);\\n VERTEX_DATA(LP, LU);\\n VERTEX_DATA(DP, DU);\\n\\n VERTEX_DATA(CP, CU);\\n VERTEX_DATA(IP, IU);\\n VERTEX_DATA(KP, KU); \\n \\n VERTEX_DATA(LP, LU);\\n VERTEX_DATA(FP, FU);\\n VERTEX_DATA(GP, GU); \\n \\n VERTEX_DATA(LP, LU);\\n VERTEX_DATA(GP, GU);\\n VERTEX_DATA(DP, DU);\\n \\n #endif\\n\\n \\n VERTEX_DATA(CP, CU);\\n VERTEX_DATA(HP, HU);\\n VERTEX_DATA(IP, IU); \\n \\n float aspectRatio = resolution.y / resolution.x;\\n pos.x *= aspectRatio;\\n \\n gl_Position = vec4(pos*2.0-1.0, 0.0, 1.0);\\n v_color = vec4(uv, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 24, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define VERTEX_DATA(inpos, inuv) vert += 1.0; if (vertexId == vert) {pos = inpos; uv = inuv;}\n\n\nvoid main() {\n \n // vertices\n const vec2 AP = vec2(0.4, 0.2);\n const vec2 AU = vec2(0.0, 0.0);\n \n const vec2 BP = vec2(0.6, 0.2);\n const vec2 BU = vec2(1.0, 0.0); \n\n const vec2 CP = vec2(0.4, 0.5);\n const vec2 CU = vec2(0.0, 0.7);\n \n const vec2 DP = vec2(0.6, 0.5);\n const vec2 DU = vec2(1.0, 0.7); \n \n const vec2 EP = vec2(0.5, 0.6);\n const vec2 EU = vec2(0.5, 0.5);\n \n const vec2 FP = vec2(0.7, 0.8);\n const vec2 FU = vec2(0.0, 1.0);\n \n const vec2 GP = vec2(0.8, 0.7);\n const vec2 GU = vec2(1.0, 1.0);\n \n const vec2 HP = vec2(0.2, 0.7);\n const vec2 HU = vec2(0.0, 1.0); \n \n const vec2 IP = vec2(0.3, 0.8);\n const vec2 IU = vec2(1.0, 1.0); \n \n const vec2 JP = vec2(0.5, 0.5);\n const vec2 JU = vec2(0.5, 0.7); \n \n const vec2 KP = vec2(0.5, 0.6);\n const vec2 KU = vec2(1.0, 0.7); \n \n const vec2 LP = vec2(0.5, 0.6);\n const vec2 LU = vec2(0.0, 0.7); \n \n \n // make the mesh\n vec2 pos = vec2(0.0, 0.0);\n vec2 uv = vec2(0.0, 0.0); \n float vert = -1.0;\n \n VERTEX_DATA(AP, AU);\n VERTEX_DATA(DP, DU);\n VERTEX_DATA(BP, BU);\n \n VERTEX_DATA(AP, AU);\n VERTEX_DATA(CP, CU);\n VERTEX_DATA(DP, DU); \n \n #if 0\n \n VERTEX_DATA(CP, CU);\n VERTEX_DATA(EP, EU);\n VERTEX_DATA(DP, DU); \n \n VERTEX_DATA(CP, CU);\n VERTEX_DATA(IP, IU);\n VERTEX_DATA(EP, EU); \n \n VERTEX_DATA(EP, EU);\n VERTEX_DATA(FP, FU);\n VERTEX_DATA(GP, GU); \n \n VERTEX_DATA(EP, EU);\n VERTEX_DATA(GP, GU);\n VERTEX_DATA(DP, DU);\n \n \n #else\n \n VERTEX_DATA(CP, CU);\n VERTEX_DATA(KP, KU);\n VERTEX_DATA(JP, JU);\n\n VERTEX_DATA(JP, JU);\n VERTEX_DATA(LP, LU);\n VERTEX_DATA(DP, DU);\n\n VERTEX_DATA(CP, CU);\n VERTEX_DATA(IP, IU);\n VERTEX_DATA(KP, KU); \n \n VERTEX_DATA(LP, LU);\n VERTEX_DATA(FP, FU);\n VERTEX_DATA(GP, GU); \n \n VERTEX_DATA(LP, LU);\n VERTEX_DATA(GP, GU);\n VERTEX_DATA(DP, DU);\n \n #endif\n\n \n VERTEX_DATA(CP, CU);\n VERTEX_DATA(HP, HU);\n VERTEX_DATA(IP, IU); \n \n float aspectRatio = resolution.y / resolution.x;\n pos.x *= aspectRatio;\n \n gl_Position = vec4(pos*2.0-1.0, 0.0, 1.0);\n v_color = vec4(uv, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-13fyuj01llgb8ry44-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/So6hu3cdGNWJEi8HN/art.json b/art/So6hu3cdGNWJEi8HN/art.json index 6196f9ab..aa83e237 100644 --- a/art/So6hu3cdGNWJEi8HN/art.json +++ b/art/So6hu3cdGNWJEi8HN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":91574,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 1.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 0.25 + abs(cd) * 7.);\\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.14, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*mod(0.54,snd), sat, val));\\n v_color = vec4(color * (-dot(n, lightDir) * .125 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 91574, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 1.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 0.25 + abs(cd) * 7.);\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.14, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*mod(0.54,snd), sat, val));\n v_color = vec4(color * (-dot(n, lightDir) * .125 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-937xd567zr1ghpd86-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SoK3eJipBJGantxyd/art.json b/art/SoK3eJipBJGantxyd/art.json index ef993701..f2d3e074 100644 --- a/art/SoK3eJipBJGantxyd/art.json +++ b/art/SoK3eJipBJGantxyd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\n float x = vertexId;\\n float y = vertexId*2.;\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n \\n // base size 100, plus sin(time) between 0 and 1 * 100\\n gl_PointSize = 100. + (sin(time)/2.+.5)*100.;\\n\\n v_color = vec4(1., 0., 0., 1.);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\n float x = vertexId;\n float y = vertexId*2.;\n \n gl_Position = vec4(x, y, 0., 1.);\n \n // base size 100, plus sin(time) between 0 and 1 * 100\n gl_PointSize = 100. + (sin(time)/2.+.5)*100.;\n\n v_color = vec4(1., 0., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-othk2k0y1d7b1843e-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Soip5jkRuE4MTLibC/art.json b/art/Soip5jkRuE4MTLibC/art.json index 4a9e81f7..24776635 100644 --- a/art/Soip5jkRuE4MTLibC/art.json +++ b/art/Soip5jkRuE4MTLibC/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/leagueoflegends/rise-ft-the-glitch-mob-mako-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive Art\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / (0.8*PI);\\n float av = length(vec2(su, sv)* 0.9);\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = cos(time)*0.2;//sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time)*0.2;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.8;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 9.0) * 20.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 500.0;\\n gl_PointSize += soff / 8.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.7 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0.5, 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 4.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue-0.5, sat, val)*0.6), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/leagueoflegends/rise-ft-the-glitch-mob-mako-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive Art\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / (0.8*PI);\n float av = length(vec2(su, sv)* 0.9);\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = cos(time)*0.2;//sin(time + y * 0.2) * 0.1;\n float yoff = sin(time)*0.2;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.8;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 9.0) * 20.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 500.0;\n gl_PointSize += soff / 8.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.7 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0.5, 1., pump);\n float val = mix(.1, pow(snd + 0.2, 4.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue-0.5, sat, val)*0.6), 1);\n}\n" + }, "screenshotURL": "data/images/images-i65nyvxvdm5ou8olu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SqctCGQnp8j6NNnSE/art.json b/art/SqctCGQnp8j6NNnSE/art.json index f6645c10..609d6427 100644 --- a/art/SqctCGQnp8j6NNnSE/art.json +++ b/art/SqctCGQnp8j6NNnSE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4368,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n \\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n\\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // Set up vertices\\n vec3 vert;\\n if (vertexId == 0.0) {\\n \\tvert = vec3(0.5, 0.0, 0.0);\\n } else if (vertexId == 1.0) {\\n \\tvert = vec3(0.0, 0.5, 0.0);\\n } else if (vertexId == 2.0) {\\n \\tvert = vec3(0.0, -0.5, 0.0);\\n }\\n \\n gl_Position = vec4(vert, 1.0);\\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 4368, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n \tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // Set up vertices\n vec3 vert;\n if (vertexId == 0.0) {\n \tvert = vec3(0.5, 0.0, 0.0);\n } else if (vertexId == 1.0) {\n \tvert = vec3(0.0, 0.5, 0.0);\n } else if (vertexId == 2.0) {\n \tvert = vec3(0.0, -0.5, 0.0);\n }\n \n gl_Position = vec4(vert, 1.0);\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-7enfr76gdo3g4d4fi-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Suxnf3g4CqC5dLWw6/art.json b/art/Suxnf3g4CqC5dLWw6/art.json index a215d7ff..bb97e2eb 100644 --- a/art/Suxnf3g4CqC5dLWw6/art.json +++ b/art/Suxnf3g4CqC5dLWw6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":66252,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 65.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.1 + 1.1;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 0.6 + PI * 2.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.7) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 0.3)-7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3(2, resolution.x / resolution.y, 1.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 0.3 + snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a /2.0);\\n}\"}", + "settings": { + "num": 66252, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 65.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.1 + 1.1;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 0.6 + PI * 2.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.7) + tan((t * 0.13) + mouse.y -t) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 0.3)-7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3(2, resolution.x / resolution.y, 1.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 0.3 + snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a /2.0);\n}" + }, "screenshotURL": "data/images/images-tu7fo1pv64i7hs4z2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SvKBPm8HSm9yzW4F2/art.json b/art/SvKBPm8HSm9yzW4F2/art.json index 527429b2..46db0b7d 100644 --- a/art/SvKBPm8HSm9yzW4F2/art.json +++ b/art/SvKBPm8HSm9yzW4F2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":6431,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Seulbin Seo\\n// Exercise Motion with different motion pattern\\n// CS250 Spring 2023\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = cos(time + y * 0.2) * 0.2;\\n float yoff = cos(time + y * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 9.;\\n \\n gl_PointSize = 17.0 + soff;\\n gl_PointSize *= 20. / (across);\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4 (1, sin(time), cos(time), 1);\\n \\n}\"}", + "settings": { + "num": 6431, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Motion with different motion pattern\n// CS250 Spring 2023\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = cos(time + y * 0.2) * 0.2;\n float yoff = cos(time + y * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 9.;\n \n gl_PointSize = 17.0 + soff;\n gl_PointSize *= 20. / (across);\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4 (1, sin(time), cos(time), 1);\n \n}" + }, "screenshotURL": "data/images/images-t58l812jeag04npi1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/SvkxzENQ5fAgKSxZp/art.json b/art/SvkxzENQ5fAgKSxZp/art.json index 602d77fe..d561ba2b 100644 --- a/art/SvkxzENQ5fAgKSxZp/art.json +++ b/art/SvkxzENQ5fAgKSxZp/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount)); // gets the count of rows\\n float across = floor(vertexCount / down); // gets the count of columns\\n \\n // vertexId is the \\n float x = mod(vertexId, across); // always use floats\\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = sin(time + y * 0.2) * 0.1; \\n float yOffset = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset; // gets value from -1 to 1\\n float uy = v * 2.0 - 1.0 + yOffset; // gets value from -1 to 1\\n \\n vec2 xy = vec2(ux, uy) * 1.25;\\n \\n float sizeOffset = sin(time + x * y * 0.02) * 3.0;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 200.0 / across; // set point size\\n gl_PointSize *= resolution.x / 600.0 + sizeOffset;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1); // this is unique to vertex shader art\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount)); // gets the count of rows\n float across = floor(vertexCount / down); // gets the count of columns\n \n // vertexId is the \n float x = mod(vertexId, across); // always use floats\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = sin(time + y * 0.2) * 0.1; \n float yOffset = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset; // gets value from -1 to 1\n float uy = v * 2.0 - 1.0 + yOffset; // gets value from -1 to 1\n \n vec2 xy = vec2(ux, uy) * 1.25;\n \n float sizeOffset = sin(time + x * y * 0.02) * 3.0;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 200.0 / across; // set point size\n gl_PointSize *= resolution.x / 600.0 + sizeOffset;\n \n v_color = vec4(1.0, 0.0, 0.0, 1); // this is unique to vertex shader art\n}" + }, "screenshotURL": "data/images/images-f5tuz2l5kobbpvcpc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Sw2atuBHGBsutNYZf/art.json b/art/Sw2atuBHGBsutNYZf/art.json index 8e2b6dba..e194ad05 100644 --- a/art/Sw2atuBHGBsutNYZf/art.json +++ b/art/Sw2atuBHGBsutNYZf/art.json @@ -17,7 +17,19 @@ "name": "smoke spheres every day", "private": false, "username": "-anon-", - "settings": "{\"num\":43618,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = (fract(pos+.5)-.5);\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId*.13;\\n\\n vec3 pos = posf(t,i);\\t\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += 1.7;\\n \\n pos.xy *= (3.-pos.z)*.7;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.01;\\n}\"}", + "settings": { + "num": 43618, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = (fract(pos+.5)-.5);\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId*.13;\n\n vec3 pos = posf(t,i);\t\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += 1.7;\n \n pos.xy *= (3.-pos.z)*.7;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.01;\n}" + }, "screenshotURL": "data/images/images-zop8gbeietipdbo2g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Sx3Sk35wbBx2sGAxM/art.json b/art/Sx3Sk35wbBx2sGAxM/art.json index 187ca007..bb773af7 100644 --- a/art/Sx3Sk35wbBx2sGAxM/art.json +++ b/art/Sx3Sk35wbBx2sGAxM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/joe-blobs/naga-baba-the-jabberwocky-joe-blobs-rmx\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/**/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n\\nfloat sdSphere( vec3 p, float s )\\n{\\n return length(p)-s;\\n}\\n\\nfloat sdTorus( vec3 p, vec2 t )\\n{\\n vec2 q = vec2(length(p.xz)-t.x,p.y);\\n return length(q)-t.y;\\n}\\n\\nfloat sdCappedCylinder( vec3 p, float h, float r )\\n{\\n vec2 d = abs(vec2(length(p.xz),p.y)) - vec2(h,r);\\n return min(max(d.x,d.y),0.0) + length(max(d,0.0));\\n}\\n\\nfloat sdOctahedron( in vec3 p, in float s)\\n{\\n p = abs(p);\\n float m = p.x+p.y+p.z-s;\\n vec3 q;\\n if( 3.0*p.x < m ) q = p.xyz;\\n else if( 3.0*p.y < m ) q = p.yzx;\\n else if( 3.0*p.z < m ) q = p.zxy;\\n else return m*0.57735027;\\n \\n float k = clamp(0.5*(q.z-q.y+s),0.0,s); \\n return length(vec3(q.x,q.y-s+k,q.z-k)); \\n}\\n\\n\\nfloat sdHexPrism( vec3 p, vec2 h )\\n{\\n const vec3 k = vec3(-0.8660254, 0.5, 0.57735);\\n p = abs(p);\\n p.xy -= 2.0*min(dot(k.xy, p.xy), 0.0)*k.xy;\\n vec2 d = vec2(\\n length(p.xy-vec2(clamp(p.x,-k.z*h.x,k.z*h.x), h.x))*sign(p.y-h.x),\\n p.z-h.y );\\n return min(max(d.x,d.y),0.0) + length(max(d,0.0));\\n}\\n\\n#if 1\\nvoid main() {\\n float cubeSize = floor(pow(vertexCount, 1.0 / 3.0));\\n float uId = mod(vertexId, cubeSize);\\n float vId = mod(floor(vertexId / cubeSize), cubeSize);\\n float wId = floor(vertexId / cubeSize / cubeSize);\\n \\n vec3 uvw = vec3(uId, vId, wId) / cubeSize;\\n //vec3 pos = uvw * 2. - 1.;\\n float v = vertexId + time * 0.1;\\n vec3 pos = fract(time * 0. + vec3(hash(v * 0.135), hash(v * 1.237), hash(v * 1.721))) * 2.0 - 1.0;\\n pos *= 2.0;\\n \\n \\n mat4 pmat = persp(radians(45.0), resolution.x / resolution.y, 0.01, 15.0);\\n float cr = 3.;\\n float ct = time * 0.1;\\n vec3 cam = vec3(cos(ct) * cr, sin(ct * 0.9), sin(ct) * cr);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n mat4 cmat = cameraLookAt(cam, target, up);\\n \\n vec3 p1 = (rotX(time) * vec4(pos, 1)).xyz; \\n vec3 p2 = (trans(vec3(sin(time), 0, 0)) * vec4(pos, 1)).xyz;\\n vec3 p3 = (trans(vec3(0, sin(time), 0)) * rotX(time) * vec4(pos, 1)).xyz;\\n vec3 p4 = (trans(vec3(0, 0, sin(time))) * vec4(pos, 1)).xyz;\\n vec3 p5 = (trans(vec3(cos(time), sin(time), 0)) * rotX(time) * vec4(pos, 1)).xyz;\\n float dist2 = sdTorus(p1, vec2(1.1, 0.01));\\n float dist1 = sdSphere(p2, 0.5);\\n float dist3 = sdHexPrism(p3, vec2(.5, .1));\\n float dist4 = sdCappedCylinder(p4, 1., 0.5);\\n float dist5 = sdOctahedron(p5, 1.);\\n float dist = 1000.0;\\n dist = min(dist5, dist);\\n dist = min(dist4, dist);\\n dist = min(dist3, dist);\\n dist = min(dist2, dist);\\n dist = min(dist1, dist);\\n float off = max(0., dist);\\n pos -= normalize(pos) * off;\\n \\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.1, (abs(pos.x) * 0.3)),\\n fract(abs(atan(pos.y, pos.z)) / PI * 0.2 * 10.)\\n )).r;\\n \\n gl_Position = pmat * cmat * vec4(pos, 1);\\n gl_PointSize = 4. + pow(s, 10.) * 40.;\\n v_color = vec4(vec3(abs(off) * 50., s, s), 1);\\n v_color.rgb = hsv2rgb(vec3(time * 0.1 + s * 0.2, 1., pow(s + 0.25, 5.)));\\n v_color = mix(v_color, vec4(1, 1, 0, 1), pow(s + 0.2, 15.));\\n v_color.a = 0.4;\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/joe-blobs/naga-baba-the-jabberwocky-joe-blobs-rmx", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/**/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n\nfloat sdSphere( vec3 p, float s )\n{\n return length(p)-s;\n}\n\nfloat sdTorus( vec3 p, vec2 t )\n{\n vec2 q = vec2(length(p.xz)-t.x,p.y);\n return length(q)-t.y;\n}\n\nfloat sdCappedCylinder( vec3 p, float h, float r )\n{\n vec2 d = abs(vec2(length(p.xz),p.y)) - vec2(h,r);\n return min(max(d.x,d.y),0.0) + length(max(d,0.0));\n}\n\nfloat sdOctahedron( in vec3 p, in float s)\n{\n p = abs(p);\n float m = p.x+p.y+p.z-s;\n vec3 q;\n if( 3.0*p.x < m ) q = p.xyz;\n else if( 3.0*p.y < m ) q = p.yzx;\n else if( 3.0*p.z < m ) q = p.zxy;\n else return m*0.57735027;\n \n float k = clamp(0.5*(q.z-q.y+s),0.0,s); \n return length(vec3(q.x,q.y-s+k,q.z-k)); \n}\n\n\nfloat sdHexPrism( vec3 p, vec2 h )\n{\n const vec3 k = vec3(-0.8660254, 0.5, 0.57735);\n p = abs(p);\n p.xy -= 2.0*min(dot(k.xy, p.xy), 0.0)*k.xy;\n vec2 d = vec2(\n length(p.xy-vec2(clamp(p.x,-k.z*h.x,k.z*h.x), h.x))*sign(p.y-h.x),\n p.z-h.y );\n return min(max(d.x,d.y),0.0) + length(max(d,0.0));\n}\n\n#if 1\nvoid main() {\n float cubeSize = floor(pow(vertexCount, 1.0 / 3.0));\n float uId = mod(vertexId, cubeSize);\n float vId = mod(floor(vertexId / cubeSize), cubeSize);\n float wId = floor(vertexId / cubeSize / cubeSize);\n \n vec3 uvw = vec3(uId, vId, wId) / cubeSize;\n //vec3 pos = uvw * 2. - 1.;\n float v = vertexId + time * 0.1;\n vec3 pos = fract(time * 0. + vec3(hash(v * 0.135), hash(v * 1.237), hash(v * 1.721))) * 2.0 - 1.0;\n pos *= 2.0;\n \n \n mat4 pmat = persp(radians(45.0), resolution.x / resolution.y, 0.01, 15.0);\n float cr = 3.;\n float ct = time * 0.1;\n vec3 cam = vec3(cos(ct) * cr, sin(ct * 0.9), sin(ct) * cr);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n mat4 cmat = cameraLookAt(cam, target, up);\n \n vec3 p1 = (rotX(time) * vec4(pos, 1)).xyz; \n vec3 p2 = (trans(vec3(sin(time), 0, 0)) * vec4(pos, 1)).xyz;\n vec3 p3 = (trans(vec3(0, sin(time), 0)) * rotX(time) * vec4(pos, 1)).xyz;\n vec3 p4 = (trans(vec3(0, 0, sin(time))) * vec4(pos, 1)).xyz;\n vec3 p5 = (trans(vec3(cos(time), sin(time), 0)) * rotX(time) * vec4(pos, 1)).xyz;\n float dist2 = sdTorus(p1, vec2(1.1, 0.01));\n float dist1 = sdSphere(p2, 0.5);\n float dist3 = sdHexPrism(p3, vec2(.5, .1));\n float dist4 = sdCappedCylinder(p4, 1., 0.5);\n float dist5 = sdOctahedron(p5, 1.);\n float dist = 1000.0;\n dist = min(dist5, dist);\n dist = min(dist4, dist);\n dist = min(dist3, dist);\n dist = min(dist2, dist);\n dist = min(dist1, dist);\n float off = max(0., dist);\n pos -= normalize(pos) * off;\n \n float s = texture2D(sound, vec2(\n mix(0.01, 0.1, (abs(pos.x) * 0.3)),\n fract(abs(atan(pos.y, pos.z)) / PI * 0.2 * 10.)\n )).r;\n \n gl_Position = pmat * cmat * vec4(pos, 1);\n gl_PointSize = 4. + pow(s, 10.) * 40.;\n v_color = vec4(vec3(abs(off) * 50., s, s), 1);\n v_color.rgb = hsv2rgb(vec3(time * 0.1 + s * 0.2, 1., pow(s + 0.25, 5.)));\n v_color = mix(v_color, vec4(1, 1, 0, 1), pow(s + 0.2, 15.));\n v_color.a = 0.4;\n v_color.rgb *= v_color.a;\n}\n\n#endif\n\n" + }, "screenshotURL": "data/images/images-lv949vucjio91xr9b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/T2fikhe7Y9nsT6rrx/art.json b/art/T2fikhe7Y9nsT6rrx/art.json index 66b5409e..dd87bc49 100644 --- a/art/T2fikhe7Y9nsT6rrx/art.json +++ b/art/T2fikhe7Y9nsT6rrx/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.00784313725490196,0.00784313725490196,1],\"shader\":\"#define PI radians(180.)\\n#define SIZE 90.0\\n#define NUM_CUBES (SIZE*SIZE*SIZE)\\n#define NUM_TRIANGLES (NUM_CUBES*6)\\n#define NUM_VERTICES (NUM_TRIANGLES*6)\\n#define STEP 80.0\\n\\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nvec3 camPath(float t){\\n \\n //return vec3(0, 0, t); // Straight path.\\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\\n \\n //float s = sin(t/24.)*cos(t/12.);\\n //return vec3(s*12., 0., t);\\n \\n float a = -sin(t * 0.011);\\n float b = cos(t * 0.014);\\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\\n \\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nfloat map(vec3 p){\\n \\n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\\n \\n p *= 0.4;\\n \\n\\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\\n \\n \\n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\\n\\n // It's an easy field to create, but not so great to hone in one. The \\\"1.4\\\" fudge factor\\n // is there to get a little extra distance... Obtained by trial and error.\\n return (n - 1.025)*1.33;\\n \\n}\\n\\n\\nvoid main() {\\n \\n float speed = 10.0;\\n \\n vec3 wpos = vec3(0);\\n \\n vec3 pos = camPath(time*speed)*sin(-1.5*mouse.x);\\n \\n vec3 lookat = camPath(time*speed+2.0);\\n vec3 forward = normalize(lookat-pos);\\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\\n vec3 up = cross(forward,left);\\n \\n float id = vertexId;\\n \\n float numcube = floor(id/18.0);\\n float numquad = floor(id/6.0);\\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\\n float nori = mod(numquad,3.0);\\n //quadid = quadid ^ diri;\\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\\n \\n \\n vec3 mask;\\n if (nori < 0.5) {\\n mask = vec3(1,0,0);\\n } else if (nori < 1.5) {\\n mask = vec3(0,1,0);\\n } else {\\n mask = vec3(0,0,1);\\n }\\n \\n float size = floor(pow(vertexCount/18.0,1.0/3.0));\\n \\n vec3 blockpos = vec3(\\n mod(floor(numcube),size),\\n mod(floor(numcube/size),size),\\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\\n \\n bool a = map(blockpos) > 0.0;\\n bool b = map(blockpos+mask) > 0.0;\\n \\n float diri;\\n \\n if (a == b) {\\n gl_Position = vec4(0,0,0,1);\\n return;\\n } else {\\n \\n float diri = 1.0;\\n if (b) {\\n diri = -diri;\\n quad.xy = quad.yx;\\n }\\n \\n vec3 nor = mask*(diri*2.0-1.0);\\n\\n wpos += mask.zxy*quad.x;\\n wpos += mask.yzx*quad.y;\\n\\twpos += mask;\\n wpos += blockpos;\\n\\n wpos -= 0.5;\\n\\n //wpos += vec3(data.xyz);\\n //wpos += float(gl_VertexID/6);\\n //wpos += u_centerPosition;\\n\\n\\n\\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\\n \\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\\n \\n p.x *= resolution.y/resolution.x;\\n\\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\\n\\n\\n float hue = (id * 1.001);\\n v_color = vec4(nor*0.5+0.5, 1);\\n }\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.00784313725490196, + 0.00784313725490196, + 1 + ], + "shader": "#define PI radians(180.)\n#define SIZE 90.0\n#define NUM_CUBES (SIZE*SIZE*SIZE)\n#define NUM_TRIANGLES (NUM_CUBES*6)\n#define NUM_VERTICES (NUM_TRIANGLES*6)\n#define STEP 80.0\n\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n//https://www.shadertoy.com/view/4ttGDH\nvec3 camPath(float t){\n \n //return vec3(0, 0, t); // Straight path.\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\n \n //float s = sin(t/24.)*cos(t/12.);\n //return vec3(s*12., 0., t);\n \n float a = -sin(t * 0.011);\n float b = cos(t * 0.014);\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\n \n}\n\n//https://www.shadertoy.com/view/4ttGDH\nfloat map(vec3 p){\n \n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\n \n p *= 0.4;\n \n\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\n \n \n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\n\n // It's an easy field to create, but not so great to hone in one. The \"1.4\" fudge factor\n // is there to get a little extra distance... Obtained by trial and error.\n return (n - 1.025)*1.33;\n \n}\n\n\nvoid main() {\n \n float speed = 10.0;\n \n vec3 wpos = vec3(0);\n \n vec3 pos = camPath(time*speed)*sin(-1.5*mouse.x);\n \n vec3 lookat = camPath(time*speed+2.0);\n vec3 forward = normalize(lookat-pos);\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\n vec3 up = cross(forward,left);\n \n float id = vertexId;\n \n float numcube = floor(id/18.0);\n float numquad = floor(id/6.0);\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\n float nori = mod(numquad,3.0);\n //quadid = quadid ^ diri;\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\n \n \n vec3 mask;\n if (nori < 0.5) {\n mask = vec3(1,0,0);\n } else if (nori < 1.5) {\n mask = vec3(0,1,0);\n } else {\n mask = vec3(0,0,1);\n }\n \n float size = floor(pow(vertexCount/18.0,1.0/3.0));\n \n vec3 blockpos = vec3(\n mod(floor(numcube),size),\n mod(floor(numcube/size),size),\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\n \n bool a = map(blockpos) > 0.0;\n bool b = map(blockpos+mask) > 0.0;\n \n float diri;\n \n if (a == b) {\n gl_Position = vec4(0,0,0,1);\n return;\n } else {\n \n float diri = 1.0;\n if (b) {\n diri = -diri;\n quad.xy = quad.yx;\n }\n \n vec3 nor = mask*(diri*2.0-1.0);\n\n wpos += mask.zxy*quad.x;\n wpos += mask.yzx*quad.y;\n\twpos += mask;\n wpos += blockpos;\n\n wpos -= 0.5;\n\n //wpos += vec3(data.xyz);\n //wpos += float(gl_VertexID/6);\n //wpos += u_centerPosition;\n\n\n\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\n \n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\n \n p.x *= resolution.y/resolution.x;\n\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\n\n\n float hue = (id * 1.001);\n v_color = vec4(nor*0.5+0.5, 1);\n }\n}" + }, "screenshotURL": "data/images/images-g8dhl7ap8kyw2rx23-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/T3o69kd5wMtWNCj5k/art.json b/art/T3o69kd5wMtWNCj5k/art.json index 38bce64b..d3b0beee 100644 --- a/art/T3o69kd5wMtWNCj5k/art.json +++ b/art/T3o69kd5wMtWNCj5k/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "ray7551", "avatarUrl": "https://avatars.githubusercontent.com/ray7551?s=200", - "settings": "{\"num\":61000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/**\\n * LED Music Visualizer\\n * A tribute to La La Land\\n * Try these sound:\\n * https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\\n * https://soundcloud.com/thave-lex/another-day-of-sun-la-la-land-thave-lex-remix\\n */\\nfloat hash(float n) {\\n return fract(sin(n) * 777.1397);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\\n float gridWidth = resolution.x / xCount;\\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 100. / xCount; // if xCount > 100 then make pointSize smaller\\n \\n vec2 p = vec2(\\n mod(vertexId, xCount) * gridWidth,\\n floor(vertexId / xCount) * gridHeight\\n );\\n \\n gl_Position = vec4(\\n (p / resolution * 2. - vec2(1.)),\\n 0., 1.\\n ); \\n //v_color = vec4(vec3(1., 1., 1.0), 1.); // for debugging grid\\n \\n float tvGlitch = 400.;\\n float i = hash(vertexId) / tvGlitch;\\n vec4 snd = texture2D(sound, vec2(0., i)); \\n //vec4 snd = texture2D(sound, vec2(0., 0.));\\n vec3 s = vec3(snd.a * snd.a, pow(snd.b, 14.), pow(snd.z, 8.));\\n float glowFactor = s.x * floor(time / 50.) + 1.;\\n \\n // tweak variables below to see what happens\\n const float n = 3.0; // flower number\\n float petalNum = 3.0 + floor((time + s.x * 140.) / 50.); // petal number of each flower\\n float glowing = 0.03 * glowFactor;\\n float rotateSpeed = 0.07 + 0.015 * smoothstep(-0.1, 1.0, s.x);\\n float scale = 0.9 * (1. + s.y * 1.);\\n float variationX = 0.0 - 0.5 * sin(s.x);//0.25;\\n float variationY = 0.0 - 0.45 * sin(s.x) - 37. * sin(s.z);//0.25;\\n \\n vec2 pos = gl_Position.xy * vec2(max(resolution.x, resolution.y)) / vec2(resolution.yx); // make grid spacing equal in x and y, and fit window size\\n float radius = length(pos.xy) + 0.2;\\n float t = atan(\\n pos.y + variationY,\\n pos.x + variationX\\n );\\n\\n float color = 0.0;\\n for (float i = 1.; i <= n; i++) {\\n color += glowing / abs(\\n color + i / n * scale * sin(\\n petalNum * (t + i * time * rotateSpeed)\\n )\\n - radius\\n );\\n }\\n\\n vec3 debugColor = vec3(smoothstep(-0.1, 1.0, s.x));\\n v_color = vec4(\\n hsv2rgb(vec3(\\n 0.6 + sin(s.x * 2.6),// + cos(s.z * 73.),\\n 0.7 + 0.3 * (time / 120.),\\n 0.6 + 0.4 * (time / 120.)\\n )) * color\\n + step(1., length(pos * vec2(resolution.xy) / resolution)) * debugColor,\\n 1.\\n );\\n \\n}\"}", + "settings": { + "num": 61000, + "mode": "POINTS", + "sound": "https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/**\n * LED Music Visualizer\n * A tribute to La La Land\n * Try these sound:\n * https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\n * https://soundcloud.com/thave-lex/another-day-of-sun-la-la-land-thave-lex-remix\n */\nfloat hash(float n) {\n return fract(sin(n) * 777.1397);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\n float gridWidth = resolution.x / xCount;\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\n \n gl_PointSize = 10.;\n gl_PointSize *= 100. / xCount; // if xCount > 100 then make pointSize smaller\n \n vec2 p = vec2(\n mod(vertexId, xCount) * gridWidth,\n floor(vertexId / xCount) * gridHeight\n );\n \n gl_Position = vec4(\n (p / resolution * 2. - vec2(1.)),\n 0., 1.\n ); \n //v_color = vec4(vec3(1., 1., 1.0), 1.); // for debugging grid\n \n float tvGlitch = 400.;\n float i = hash(vertexId) / tvGlitch;\n vec4 snd = texture2D(sound, vec2(0., i)); \n //vec4 snd = texture2D(sound, vec2(0., 0.));\n vec3 s = vec3(snd.a * snd.a, pow(snd.b, 14.), pow(snd.z, 8.));\n float glowFactor = s.x * floor(time / 50.) + 1.;\n \n // tweak variables below to see what happens\n const float n = 3.0; // flower number\n float petalNum = 3.0 + floor((time + s.x * 140.) / 50.); // petal number of each flower\n float glowing = 0.03 * glowFactor;\n float rotateSpeed = 0.07 + 0.015 * smoothstep(-0.1, 1.0, s.x);\n float scale = 0.9 * (1. + s.y * 1.);\n float variationX = 0.0 - 0.5 * sin(s.x);//0.25;\n float variationY = 0.0 - 0.45 * sin(s.x) - 37. * sin(s.z);//0.25;\n \n vec2 pos = gl_Position.xy * vec2(max(resolution.x, resolution.y)) / vec2(resolution.yx); // make grid spacing equal in x and y, and fit window size\n float radius = length(pos.xy) + 0.2;\n float t = atan(\n pos.y + variationY,\n pos.x + variationX\n );\n\n float color = 0.0;\n for (float i = 1.; i <= n; i++) {\n color += glowing / abs(\n color + i / n * scale * sin(\n petalNum * (t + i * time * rotateSpeed)\n )\n - radius\n );\n }\n\n vec3 debugColor = vec3(smoothstep(-0.1, 1.0, s.x));\n v_color = vec4(\n hsv2rgb(vec3(\n 0.6 + sin(s.x * 2.6),// + cos(s.z * 73.),\n 0.7 + 0.3 * (time / 120.),\n 0.6 + 0.4 * (time / 120.)\n )) * color\n + step(1., length(pos * vec2(resolution.xy) / resolution)) * debugColor,\n 1.\n );\n \n}" + }, "screenshotURL": "data/images/images-va2v0rc3zix2hies9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/T3rPrhgzehKeaqZc6/art.json b/art/T3rPrhgzehKeaqZc6/art.json index c7f57744..0f56a421 100644 --- a/art/T3rPrhgzehKeaqZc6/art.json +++ b/art/T3rPrhgzehKeaqZc6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define KP0 1.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 195.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * .4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * .1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 2.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 1.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 0.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * .05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 1., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define KP0 1.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 195.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * .4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * .1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 2.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 1.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 0.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * .05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 1., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-x9y9q0rikyh0xu4d0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/T4tRxRrwSmzcLthgd/art.json b/art/T4tRxRrwSmzcLthgd/art.json index 6d6468e9..b5aa65e8 100644 --- a/art/T4tRxRrwSmzcLthgd/art.json +++ b/art/T4tRxRrwSmzcLthgd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0.2, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.2,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.81;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.*s;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf -= 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, qu, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\\n vec3 n0 = getQuadPoint(nId + 0.01, s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-(mouse.x*0.5));\\n \\n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y+1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0.2, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.2,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.81;\n\tf = 0.5000*noise( p ); p = mr*p*2.*s;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf -= 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, qu, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\n vec3 n0 = getQuadPoint(nId + 0.01, s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-(mouse.x*0.5));\n \n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y+1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-hp5xidm850pzcemqh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/T6vQzhdcHjvaZBNuN/art.json b/art/T6vQzhdcHjvaZBNuN/art.json index c69ca06f..e6e781f2 100644 --- a/art/T6vQzhdcHjvaZBNuN/art.json +++ b/art/T6vQzhdcHjvaZBNuN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dom-kolargones/krypton?in=dom-kolargones/sets/elements\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" \\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=100000 \\n\\n\\n#define KP0 5.//KParameter0 0.>>10.\\n#define KP1 5.//KParameter1 0.>>10.\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dom-kolargones/krypton?in=dom-kolargones/sets/elements", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " \n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=100000 \n\n\n#define KP0 5.//KParameter0 0.>>10.\n#define KP1 5.//KParameter1 0.>>10.\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-we3e1852e8ijmcoe7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/T9BE9jwspwHzixcM5/art.json b/art/T9BE9jwspwHzixcM5/art.json index 9025ceb8..40e01135 100644 --- a/art/T9BE9jwspwHzixcM5/art.json +++ b/art/T9BE9jwspwHzixcM5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define KP parameter0\\n#define parameter0 ( mouse.x)\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n float spd = 0.3;\\n float tm = time * spd-mouse.x;\\n c = sin(tan(pos.x) + sin(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0)/parameter0 / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px*2.5, py) * 4.0)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y /c + c * 0.15) / py, 0.0, 1);\\n gl_PointSize = c *c + 46.0* mouse.x;\\n\\n \\n v_color = vec4(2.2 + c, 0.24 + c, 1.7 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define KP parameter0\n#define parameter0 ( mouse.x)\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n float spd = 0.3;\n float tm = time * spd-mouse.x;\n c = sin(tan(pos.x) + sin(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0)/parameter0 / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px*2.5, py) * 4.0)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y /c + c * 0.15) / py, 0.0, 1);\n gl_PointSize = c *c + 46.0* mouse.x;\n\n \n v_color = vec4(2.2 + c, 0.24 + c, 1.7 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-f029a9tf87ouvxigj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/T9kEQ59LHfbYhaWxj/art.json b/art/T9kEQ59LHfbYhaWxj/art.json index ff9e73a2..0b6e93e4 100644 --- a/art/T9kEQ59LHfbYhaWxj/art.json +++ b/art/T9kEQ59LHfbYhaWxj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "random-yang", "avatarUrl": "https://avatars.githubusercontent.com/random-yang?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-d2m2e9116o91b7pb0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TAL5yA4piTpRpG2Qw/art.json b/art/TAL5yA4piTpRpG2Qw/art.json index 3031394b..7bd01e97 100644 --- a/art/TAL5yA4piTpRpG2Qw/art.json +++ b/art/TAL5yA4piTpRpG2Qw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "vincent", "avatarUrl": "https://lh6.googleusercontent.com/-ZIw9Jo6_Ag8/AAAAAAAAAAI/AAAAAAACTeU/UoDpgf0B1uA/photo.jpg", - "settings": "{\"num\":4000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/unpeuderepos\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = (vertexId/1000.0) - 1.0;\\n float sign = mod( vertexId, 2.0 ) * 2.0 - 1.0;\\n float y = x * sign; \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = (10.0 * x) * (x * 10.0) + 10.0;\\n v_color = vec4(x * 10.0 * x * 2.0 + 1.0,\\n x*x*x*x,\\n x * x * 2.0 - 1.0,\\n 1.0);\\n}\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\"}", + "settings": { + "num": 4000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/unpeuderepos", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = (vertexId/1000.0) - 1.0;\n float sign = mod( vertexId, 2.0 ) * 2.0 - 1.0;\n float y = x * sign; \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = (10.0 * x) * (x * 10.0) + 10.0;\n v_color = vec4(x * 10.0 * x * 2.0 + 1.0,\n x*x*x*x,\n x * x * 2.0 - 1.0,\n 1.0);\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n" + }, "screenshotURL": "data/images/images-s9rwyw46y33jk1p68-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TAT9Ad57HDZwRxXnf/art.json b/art/TAT9Ad57HDZwRxXnf/art.json index 43b5548b..339cc56c 100644 --- a/art/TAT9Ad57HDZwRxXnf/art.json +++ b/art/TAT9Ad57HDZwRxXnf/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":1388,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.10980392156862745,0.10980392156862745,1],\"shader\":\"// Lesson at \\n// https://www.youtube.com/watch?v=4hlKjlIUtIc&list=PLC80qbPkXBmw3IR6JVvh7jyKogIo5Bi-d&index=4\\n\\n// Every shader needs a main\\n// number of vertices fixed up there\\n\\n// Check the help to know which variables are available around\\n\\n// some code to convert HSV to RGB\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1., 2.0/ 3.0, 1.0/3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n# define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // Get x, y coordinates on a grid\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * .1;\\n float yoff = 0.;//sin(time + x * 0.3) * .1;\\n \\n // scale to get a fix number across the width\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n // scale it back to [-1, 1]\\n float ux = u*2. - 1. + xoff;\\n float vy = v*2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n //float snd = texture2D(sound, vec2(u * .05, v * .25)).a; // normal one history scrolling\\n //float snd = texture2D(sound, vec2(su * .15, sv * .25)).a; // symmetrical\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; // circular\\n \\n gl_Position = vec4(xy, 0, 1); // x, y, z, (w) (each one from -1 to 1\\n \\n // Adjust size of points by time too\\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd +0.02, 5.) * 25.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float punp = step(0.8, snd);\\n float hue = u * .1 + snd* 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\\n float sat = mix(0., 1., punp);//-av; // ,ix is like map in processing\\n float val = pow(snd + .1, 5.);//sin(time+ v * u * 20.) * .5 + .5; // check replace the \\\"+\\\" by a \\\"*\\\" in the sin\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); // v_color is specific to vertexshader.com (it's the gl_FragColor) equivalent\\n\\n}\"}", + "settings": { + "num": 1388, + "mode": "POINTS", + "sound": "https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.10980392156862745, + 0.10980392156862745, + 1 + ], + "shader": "// Lesson at \n// https://www.youtube.com/watch?v=4hlKjlIUtIc&list=PLC80qbPkXBmw3IR6JVvh7jyKogIo5Bi-d&index=4\n\n// Every shader needs a main\n// number of vertices fixed up there\n\n// Check the help to know which variables are available around\n\n// some code to convert HSV to RGB\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1., 2.0/ 3.0, 1.0/3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n# define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // Get x, y coordinates on a grid\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float xoff = 0.;//sin(time + y * 0.2) * .1;\n float yoff = 0.;//sin(time + x * 0.3) * .1;\n \n // scale to get a fix number across the width\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n // scale it back to [-1, 1]\n float ux = u*2. - 1. + xoff;\n float vy = v*2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n //float snd = texture2D(sound, vec2(u * .05, v * .25)).a; // normal one history scrolling\n //float snd = texture2D(sound, vec2(su * .15, sv * .25)).a; // symmetrical\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; // circular\n \n gl_Position = vec4(xy, 0, 1); // x, y, z, (w) (each one from -1 to 1\n \n // Adjust size of points by time too\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd +0.02, 5.) * 25.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float punp = step(0.8, snd);\n float hue = u * .1 + snd* 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\n float sat = mix(0., 1., punp);//-av; // ,ix is like map in processing\n float val = pow(snd + .1, 5.);//sin(time+ v * u * 20.) * .5 + .5; // check replace the \"+\" by a \"*\" in the sin\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); // v_color is specific to vertexshader.com (it's the gl_FragColor) equivalent\n\n}" + }, "screenshotURL": "data/images/images-o8ifs05wll2dzsaon-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TCDXMAgg5629wT79d/art.json b/art/TCDXMAgg5629wT79d/art.json index 12ffb08b..1c1a513a 100644 --- a/art/TCDXMAgg5629wT79d/art.json +++ b/art/TCDXMAgg5629wT79d/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "archer", "avatarUrl": "https://lh5.googleusercontent.com/-yNdyToHV35U/AAAAAAAAAAI/AAAAAAAABxw/qQAHdzq4gr8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/home-2001/resonance\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define MAX_RAY_STEPS 30\\n#define MIN_DISTANCE 0.0001\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 distanceEstimator(vec3 p) {\\n //float sx = mod(floor(p.y / 2.0) / 320.0, 1.0);\\n //float sy = mod(floor(p.z / 2.0) / 160.0, 1.0);\\n //float snd = texture2D(sound, vec2(sx, sy)).a;\\n \\n vec3 sphereCenter = vec3(4.0, 0.0, 0.0);\\n float radius = 1.0;\\n \\n vec3 pNew = vec3(p.x, mod(abs(p.y), 2.0) - 1.0, mod(abs(p.z), 2.0) - 1.0);\\n \\n float distance = length(pNew - sphereCenter) - radius;\\n \\n int eggi = int(p.z / (radius * 2.0)) * 2;\\n int eggj = int(p.y / (radius * 2.0)) * 2;\\n \\n return vec2(abs(distance), float(eggi + eggj) / 40.0 + time / 10.0);\\n}\\n\\nvec3 trace(vec3 from, vec3 direction) {\\n\\tfloat totalDistance = 0.0;\\n\\tint steps;\\n vec2 result;\\n\\tfor (int i=0; i < MAX_RAY_STEPS; i++) {\\n steps++;\\n\\t\\tvec3 p = from + totalDistance * direction;\\n result = distanceEstimator(p);\\n\\t\\tfloat distance = result.x;\\n\\t\\ttotalDistance += distance;\\n\\t\\tif (distance < MIN_DISTANCE) break;\\n\\t}\\n\\treturn vec3(result.y, 1.0, 1.0-float(steps)/float(MAX_RAY_STEPS));\\n}\\n\\nvoid main() {\\n \\n float wh = floor(sqrt(vertexCount));\\n gl_PointSize = max(resolution.x, resolution.y) / wh;\\n \\n float sx = (mod(vertexId, wh) / wh) * 2.0 - 1.0;\\n float sy = (ceil(vertexId / wh) / wh) * 2.0 - 1.0;\\n \\n gl_Position = vec4(sx, sy, 0.0, 1.0);\\n \\n float trueX = sx * resolution.x / 500.0;\\n float trueY = sy * resolution.y / 500.0;\\n \\n vec3 camera = vec3(-1.0, 0.0, 0.0);\\n vec3 direction = normalize(vec3(1.0, trueX, trueY));\\n vec3 pixelColor = trace(camera, direction);\\n \\n v_color = vec4(hsv2rgb(pixelColor), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/home-2001/resonance", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define MAX_RAY_STEPS 30\n#define MIN_DISTANCE 0.0001\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 distanceEstimator(vec3 p) {\n //float sx = mod(floor(p.y / 2.0) / 320.0, 1.0);\n //float sy = mod(floor(p.z / 2.0) / 160.0, 1.0);\n //float snd = texture2D(sound, vec2(sx, sy)).a;\n \n vec3 sphereCenter = vec3(4.0, 0.0, 0.0);\n float radius = 1.0;\n \n vec3 pNew = vec3(p.x, mod(abs(p.y), 2.0) - 1.0, mod(abs(p.z), 2.0) - 1.0);\n \n float distance = length(pNew - sphereCenter) - radius;\n \n int eggi = int(p.z / (radius * 2.0)) * 2;\n int eggj = int(p.y / (radius * 2.0)) * 2;\n \n return vec2(abs(distance), float(eggi + eggj) / 40.0 + time / 10.0);\n}\n\nvec3 trace(vec3 from, vec3 direction) {\n\tfloat totalDistance = 0.0;\n\tint steps;\n vec2 result;\n\tfor (int i=0; i < MAX_RAY_STEPS; i++) {\n steps++;\n\t\tvec3 p = from + totalDistance * direction;\n result = distanceEstimator(p);\n\t\tfloat distance = result.x;\n\t\ttotalDistance += distance;\n\t\tif (distance < MIN_DISTANCE) break;\n\t}\n\treturn vec3(result.y, 1.0, 1.0-float(steps)/float(MAX_RAY_STEPS));\n}\n\nvoid main() {\n \n float wh = floor(sqrt(vertexCount));\n gl_PointSize = max(resolution.x, resolution.y) / wh;\n \n float sx = (mod(vertexId, wh) / wh) * 2.0 - 1.0;\n float sy = (ceil(vertexId / wh) / wh) * 2.0 - 1.0;\n \n gl_Position = vec4(sx, sy, 0.0, 1.0);\n \n float trueX = sx * resolution.x / 500.0;\n float trueY = sy * resolution.y / 500.0;\n \n vec3 camera = vec3(-1.0, 0.0, 0.0);\n vec3 direction = normalize(vec3(1.0, trueX, trueY));\n vec3 pixelColor = trace(camera, direction);\n \n v_color = vec4(hsv2rgb(pixelColor), 1.0);\n}" + }, "screenshotURL": "data/images/images-9nf4nyg6x9n40501j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TDjh9ML39vLzhGboy/art.json b/art/TDjh9ML39vLzhGboy/art.json index 5c4f08d2..83a37898 100644 --- a/art/TDjh9ML39vLzhGboy/art.json +++ b/art/TDjh9ML39vLzhGboy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20873,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jackwallmusic/mass-effect-2-suicide-mission\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Music visualizer by Nick Powers\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n vec2 segments = resolution / 45.0;\\n vec2 coord = vec2(mod(vertexId, segments.x), vertexId / segments.x);\\n coord -= segments * 0.5;\\n coord /= segments / 2.0;\\n \\n\\n float aspect = resolution.x / resolution.y;\\n gl_Position = vec4(coord.x, coord.y, 0, 1);\\n \\n coord.x *= aspect;\\n \\n float d = length(coord);\\n float hue = mod(d + (time * 0.0), 1.0);\\n hue -= mod(hue, 0.15);\\n float snd = texture2D(sound, vec2(0.5 - hue, 0.0)).a;\\n gl_PointSize = snd * 50.0 * (0.5 + 0.5 * sin(time * d * 5.0));\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 20873, + "mode": "POINTS", + "sound": "https://soundcloud.com/jackwallmusic/mass-effect-2-suicide-mission", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Music visualizer by Nick Powers\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n vec2 segments = resolution / 45.0;\n vec2 coord = vec2(mod(vertexId, segments.x), vertexId / segments.x);\n coord -= segments * 0.5;\n coord /= segments / 2.0;\n \n\n float aspect = resolution.x / resolution.y;\n gl_Position = vec4(coord.x, coord.y, 0, 1);\n \n coord.x *= aspect;\n \n float d = length(coord);\n float hue = mod(d + (time * 0.0), 1.0);\n hue -= mod(hue, 0.15);\n float snd = texture2D(sound, vec2(0.5 - hue, 0.0)).a;\n gl_PointSize = snd * 50.0 * (0.5 + 0.5 * sin(time * d * 5.0));\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-e4fiego45kkw9a7kp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TDswsR4bMAPBnsQLT/art.json b/art/TDswsR4bMAPBnsQLT/art.json index d5ee5071..47b6ad0b 100644 --- a/art/TDswsR4bMAPBnsQLT/art.json +++ b/art/TDswsR4bMAPBnsQLT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x ) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x ) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-d68f6msei862fv8nx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TFMzciLhhyBhYRKW5/art.json b/art/TFMzciLhhyBhYRKW5/art.json index 57d6348c..c930e65d 100644 --- a/art/TFMzciLhhyBhYRKW5/art.json +++ b/art/TFMzciLhhyBhYRKW5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float move = vertexId*2.0;\\n \\n float x= mouse.x ;\\n float y=mouse.y;\\n \\n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\\n \\n gl_PointSize = 30.0;\\n \\n float red=sin(time);\\n float blue=cos(time);\\n float green=tan(time);\\n \\n v_color=vec4(red,green,blue,1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float move = vertexId*2.0;\n \n float x= mouse.x ;\n float y=mouse.y;\n \n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\n \n gl_PointSize = 30.0;\n \n float red=sin(time);\n float blue=cos(time);\n float green=tan(time);\n \n v_color=vec4(red,green,blue,1.0);\n}" + }, "screenshotURL": "data/images/images-npj9ix2ygyep1nlk7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TFXxrMbQQXNqtcTE8/art.json b/art/TFXxrMbQQXNqtcTE8/art.json index 1f093c45..2089c8cb 100644 --- a/art/TFXxrMbQQXNqtcTE8/art.json +++ b/art/TFXxrMbQQXNqtcTE8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "morimea", "avatarUrl": "https://secure.gravatar.com/avatar/8ff4b4cacdf52d8d31a020cd244c5269?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" \\n// test shader\\n\\n#define xpoints\\n\\n#define NUM 30.0\\n void main() {\\n \\n // points\\n \\n #ifdef points\\n gl_PointSize = 64.0;\\n float col = mod(vertexId, NUM + 1.0);\\n float row = mod(floor(vertexId / NUM), NUM + 1.0); \\n float x = col / NUM * 2.0 - 1.0;\\n float y = row / NUM * 2.0 - 1.0;\\n gl_Position = vec4(x, y, 0, 1);\\n v_color = vec4(fract( (col) / NUM)*100., ( mod(col , 2.)), 0, 1);\\n if(vertexId==50.)v_color.rgb=vec3(1.,0.,1.);\\n if(vertexId==10.)v_color.rgb=vec3(0.,1.,1.);\\n if(vertexId==vertexCount-1.)v_color.rgb=vec3(.25,.25,1.);\\n #else\\n \\n //trianlges\\n gl_PointSize = 14.0;\\n float vertexId_triangle=floor(vertexId/3.);\\n float tri_vtx=mod(vertexId,3.);\\n float col = mod(vertexId_triangle, NUM + 1.0);\\n float row = mod(floor(vertexId_triangle / NUM), NUM + 1.0); \\n float x = col / NUM * 2.0 - 1.0;\\n float y = row / NUM * 2.0 - 1.0;\\n float a=0.;\\n if(tri_vtx==1.)a=1.;\\n if(tri_vtx==2.)a=0.;\\n x+=(a)*.1;\\n y+=(1.-tri_vtx)*.1;\\n gl_Position = vec4(x, y, 0, 1);\\n v_color = vec4(fract( (col) / NUM)*100., ( mod(col , 2.)), 0, 1);\\n if(vertexId_triangle==0.)v_color.rgb=vec3(1.,1.,1.);\\n if(vertexId_triangle==20.)v_color.rgb=vec3(1.,0.,1.);\\n if(vertexId_triangle==10.)v_color.rgb=vec3(0.,1.,1.);\\n if(vertexId_triangle==floor(vertexCount/3.)-1.)v_color.rgb=vec3(.25,.25,1.);\\n #endif\\n \\n }\"}", + "settings": { + "num": 100, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " \n// test shader\n\n#define xpoints\n\n#define NUM 30.0\n void main() {\n \n // points\n \n #ifdef points\n gl_PointSize = 64.0;\n float col = mod(vertexId, NUM + 1.0);\n float row = mod(floor(vertexId / NUM), NUM + 1.0); \n float x = col / NUM * 2.0 - 1.0;\n float y = row / NUM * 2.0 - 1.0;\n gl_Position = vec4(x, y, 0, 1);\n v_color = vec4(fract( (col) / NUM)*100., ( mod(col , 2.)), 0, 1);\n if(vertexId==50.)v_color.rgb=vec3(1.,0.,1.);\n if(vertexId==10.)v_color.rgb=vec3(0.,1.,1.);\n if(vertexId==vertexCount-1.)v_color.rgb=vec3(.25,.25,1.);\n #else\n \n //trianlges\n gl_PointSize = 14.0;\n float vertexId_triangle=floor(vertexId/3.);\n float tri_vtx=mod(vertexId,3.);\n float col = mod(vertexId_triangle, NUM + 1.0);\n float row = mod(floor(vertexId_triangle / NUM), NUM + 1.0); \n float x = col / NUM * 2.0 - 1.0;\n float y = row / NUM * 2.0 - 1.0;\n float a=0.;\n if(tri_vtx==1.)a=1.;\n if(tri_vtx==2.)a=0.;\n x+=(a)*.1;\n y+=(1.-tri_vtx)*.1;\n gl_Position = vec4(x, y, 0, 1);\n v_color = vec4(fract( (col) / NUM)*100., ( mod(col , 2.)), 0, 1);\n if(vertexId_triangle==0.)v_color.rgb=vec3(1.,1.,1.);\n if(vertexId_triangle==20.)v_color.rgb=vec3(1.,0.,1.);\n if(vertexId_triangle==10.)v_color.rgb=vec3(0.,1.,1.);\n if(vertexId_triangle==floor(vertexCount/3.)-1.)v_color.rgb=vec3(.25,.25,1.);\n #endif\n \n }" + }, "screenshotURL": "data/images/images-chkqwx7w9mwtg4lbd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TFoeAMv4JnW8NxM4N/art.json b/art/TFoeAMv4JnW8NxM4N/art.json index 1097f182..973f2b3a 100644 --- a/art/TFoeAMv4JnW8NxM4N/art.json +++ b/art/TFoeAMv4JnW8NxM4N/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\n\\n/*\\nvoid main() {\\n const int hist = 8;\\n float s = 0.;\\n for (int i = 0; i < hist; ++i) {\\n s += texture2D(volume, vec2((vertexId + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n 1.;//float(hist - i);\\n }\\n// s /= float(hist * (hist - 1)) / 2.;\\n s /= float(hist);\\n \\n gl_Position = vec4(\\n mod(vertexId , 2.) - .5, \\n floor(vertexId / 2.) - .5, 0, 1);\\n gl_PointSize = s * resolution.y / 2.;\\n\\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1, 1)), 1);\\n}\\n*/\\n\\n/*\\n\\nWait for the music to pump \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 0.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0* parameter2, 2.0 / 3.0 / parameter1, 0.0 / 4.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, -1,\\n parameter3, c, s, 1,\\n 0, -s, c, 0,\\n 0, parameter4, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, s*parameter4, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nmat4 mixm(mat4 m1, mat4 m2, float m) {\\n return mat4(\\n mix(m1[0], m2[0], m),\\n mix(m1[1], m2[1], m),\\n mix(m1[2], m2[2], m),\\n mix(m1[3], m2[3], m));\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes) * .5);\\n float across = floor(numCubes / down);\\n float cv = cubeId / numCubes;\\n\\n float uu = mod(cubeId, across);\\n float vv = floor(cubeId / across);\\n vec2 uv = vec2(uu, vv) / vec2(across, down);\\n \\n// const int hist = 10;\\n// float s = 0.;\\n// for (int i = 0; i < hist; ++i) {\\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n// 1.;//float(hist - i);\\n// }\\n//// s /= float(hist * (hist - 1)) / 2.;\\n// s /= float(hist);\\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\\n \\n float tm = time * 0.;\\n float rd = 9.;\\n mat4 pmat = persp(radians(110.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up); \\n \\n mat4 mat = rotY(time * .1);\\n mat *= lookAt(\\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \\n mix(20., 24.1, s),\\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\\n vec3(0, 1, 0));\\n \\n mat4 mvmat = vmat * mat;\\n \\n vec3 npos = normalize(mvmat[3].xyz);\\n \\n float hue = mix(.0, time * 10., step(.8, s));\\n float sat = mix(-1.0, 2.2, s);\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n\\n \\n float areaS = 1. - (npos.z * .5 + .5);\\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\\n smat *= uniformScale(0.5);\\n smat *= trans(vec3(0, 0, -1));\\n \\n \\n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1, 0.1, 1));\\n\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(0., 2., s);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\n\n/*\nvoid main() {\n const int hist = 8;\n float s = 0.;\n for (int i = 0; i < hist; ++i) {\n s += texture2D(volume, vec2((vertexId + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n 1.;//float(hist - i);\n }\n// s /= float(hist * (hist - 1)) / 2.;\n s /= float(hist);\n \n gl_Position = vec4(\n mod(vertexId , 2.) - .5, \n floor(vertexId / 2.) - .5, 0, 1);\n gl_PointSize = s * resolution.y / 2.;\n\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1, 1)), 1);\n}\n*/\n\n/*\n\nWait for the music to pump \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 0.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0* parameter2, 2.0 / 3.0 / parameter1, 0.0 / 4.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, -1,\n parameter3, c, s, 1,\n 0, -s, c, 0,\n 0, parameter4, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, s*parameter4, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nmat4 mixm(mat4 m1, mat4 m2, float m) {\n return mat4(\n mix(m1[0], m2[0], m),\n mix(m1[1], m2[1], m),\n mix(m1[2], m2[2], m),\n mix(m1[3], m2[3], m));\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes) * .5);\n float across = floor(numCubes / down);\n float cv = cubeId / numCubes;\n\n float uu = mod(cubeId, across);\n float vv = floor(cubeId / across);\n vec2 uv = vec2(uu, vv) / vec2(across, down);\n \n// const int hist = 10;\n// float s = 0.;\n// for (int i = 0; i < hist; ++i) {\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n// 1.;//float(hist - i);\n// }\n//// s /= float(hist * (hist - 1)) / 2.;\n// s /= float(hist);\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\n \n float tm = time * 0.;\n float rd = 9.;\n mat4 pmat = persp(radians(110.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up); \n \n mat4 mat = rotY(time * .1);\n mat *= lookAt(\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \n mix(20., 24.1, s),\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\n vec3(0, 1, 0));\n \n mat4 mvmat = vmat * mat;\n \n vec3 npos = normalize(mvmat[3].xyz);\n \n float hue = mix(.0, time * 10., step(.8, s));\n float sat = mix(-1.0, 2.2, s);\n float val = 1.;//mix(1., 1., step(0.8, s));\n\n \n float areaS = 1. - (npos.z * .5 + .5);\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\n smat *= uniformScale(0.5);\n smat *= trans(vec3(0, 0, -1));\n \n \n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1, 0.1, 1));\n\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(0., 2., s);\n}\n\n" + }, "screenshotURL": "data/images/images-ax7gm4izaqz3adh28-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TFqk3nQR5AQxhWWKn/art.json b/art/TFqk3nQR5AQxhWWKn/art.json index 2502d694..a34982b2 100644 --- a/art/TFqk3nQR5AQxhWWKn/art.json +++ b/art/TFqk3nQR5AQxhWWKn/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "unnamed", "username": "-anon-", - "settings": "{\"num\":14956,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 2.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 14956, + "mode": "POINTS", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 2.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-jllyv458pit4wbtb8-thumbnail.jpg", "views": { "$numberInt": "53" diff --git a/art/TGAHpg3tJBt7nTsRy/art.json b/art/TGAHpg3tJBt7nTsRy/art.json index f3e72105..b7fe77ce 100644 --- a/art/TGAHpg3tJBt7nTsRy/art.json +++ b/art/TGAHpg3tJBt7nTsRy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jorenvo", "avatarUrl": "https://avatars.githubusercontent.com/jorenvo?s=200", - "settings": "{\"num\":19366,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// from https://www.laurivan.com/rgb-to-hsv-to-rgb-for-shaders/\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat norm_sin(float x) {\\n \\treturn (sin(x) + 1.) / 2.;\\n}\\n\\nvoid main() {\\n float size = floor(sqrt(vertexCount));\\n vec2 c = vec2(mod(vertexId, size),\\n floor(vertexId / size));\\n \\n float xoff = sin(time + c.y * 0.3) * .1;\\n float yoff = sin(time + c.x * 0.2) * .1;\\n float soff = sin(time + c.x * c.y * 0.04) * 4.;\\n\\n vec3 color = vec3(norm_sin(time + c.x / .1 + c.y / .1), 1, 1);\\n \\n // divide by the maximum to normalize to [0, 1]\\n float normalizer_x = size - 1.0;\\n float normalizer_y = floor((vertexCount - 1.0) / size);\\n c /= vec2(normalizer_x, normalizer_y);\\n \\n // go from [0,1] -> [0,2]\\n c *= 2.0;\\n \\n // go from [0,2] -> [-1, 1]\\n c -= 1.0;\\n \\n c += vec2(xoff, yoff);\\n \\n c *= 1.2;\\n \\n gl_Position = vec4(c, 0, .5 + norm_sin(time + c.x * .9 + c.y * 1.1) / 2.);\\n \\n float point_size_scale = 16.0 / size;\\n gl_PointSize = 15. + soff;\\n gl_PointSize *= point_size_scale;\\n v_color = vec4(hsv2rgb(color), 1);\\n}\"}", + "settings": { + "num": 19366, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// from https://www.laurivan.com/rgb-to-hsv-to-rgb-for-shaders/\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat norm_sin(float x) {\n \treturn (sin(x) + 1.) / 2.;\n}\n\nvoid main() {\n float size = floor(sqrt(vertexCount));\n vec2 c = vec2(mod(vertexId, size),\n floor(vertexId / size));\n \n float xoff = sin(time + c.y * 0.3) * .1;\n float yoff = sin(time + c.x * 0.2) * .1;\n float soff = sin(time + c.x * c.y * 0.04) * 4.;\n\n vec3 color = vec3(norm_sin(time + c.x / .1 + c.y / .1), 1, 1);\n \n // divide by the maximum to normalize to [0, 1]\n float normalizer_x = size - 1.0;\n float normalizer_y = floor((vertexCount - 1.0) / size);\n c /= vec2(normalizer_x, normalizer_y);\n \n // go from [0,1] -> [0,2]\n c *= 2.0;\n \n // go from [0,2] -> [-1, 1]\n c -= 1.0;\n \n c += vec2(xoff, yoff);\n \n c *= 1.2;\n \n gl_Position = vec4(c, 0, .5 + norm_sin(time + c.x * .9 + c.y * 1.1) / 2.);\n \n float point_size_scale = 16.0 / size;\n gl_PointSize = 15. + soff;\n gl_PointSize *= point_size_scale;\n v_color = vec4(hsv2rgb(color), 1);\n}" + }, "screenshotURL": "data/images/images-mffzvs4kneuf2w9u0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TGGLggjxQgLPEFHWx/art.json b/art/TGGLggjxQgLPEFHWx/art.json index e93a599b..dac88e4f 100644 --- a/art/TGGLggjxQgLPEFHWx/art.json +++ b/art/TGGLggjxQgLPEFHWx/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "dzozef", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 2.0 * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 2.0 * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-196eqbwwif1xb8f6r-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TH2CTrKcW6GQ4Y9q9/art.json b/art/TH2CTrKcW6GQ4Y9q9/art.json index d99abb8d..009b4f59 100644 --- a/art/TH2CTrKcW6GQ4Y9q9/art.json +++ b/art/TH2CTrKcW6GQ4Y9q9/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "unnamed", "username": "-anon-", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 5.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 5.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-fxot0gtbjrkyfqy9j-thumbnail.jpg", "views": { "$numberInt": "240" diff --git a/art/TKku4LqhCCgDpnKTd/art.json b/art/TKku4LqhCCgDpnKTd/art.json index c68abc2e..f072bb5a 100644 --- a/art/TKku4LqhCCgDpnKTd/art.json +++ b/art/TKku4LqhCCgDpnKTd/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5460,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=LINES\\n//KVerticesNumber=10000\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 + 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, -.02, 0, 0,\\n 0, f, 0, 0,\\n -f-2., 1.0-mouse.y, -(zNear + zFar) * rangeInv, -3,\\n 0, 0, zNear - zFar * rangeInv / 1.25, f);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target*1.6)*2.;\\n vec3 xAxis = normalize(cross(up, zAxis)*5.);\\n vec3 yAxis = cross(zAxis, xAxis* mouse.y)*2.;\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, sin( fract(mouse.x+ 0.2)));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * sin(a11 - a01 * a10),\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a11 / sin(mouse.x / 5.0 * a02) * a11,\\n b04 = a00 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 +\\n a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 3.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\t\\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat countSection = floor(6.);\\n\\t\\n\\tfloat indexCircle = floor(indexQuad / countSection);\\n\\t\\n\\tfloat astep = 3.14159 * 2.0 / countSection;\\n\\t\\n\\tfloat angle0 = indexQuad * astep;\\n\\tfloat angle1 = (indexQuad + 1.) * astep;\\n\\t\\n\\tfloat astepTorus = 3.14159 * 1.0 / floor(666.);\\n\\tfloat angleTorus = indexCircle * astepTorus;\\n\\t\\n\\tfloat radius = 4. *- cos(angleTorus * 1.5 + time) * 2.;\\n\\t\\n\\t// triangle 1\\n\\tif (index == 0.) p = vec3(cos(angle0) * radius, 1.3, tan(angle0) * radius);\\n\\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) -23.8+ radius);\\n\\tif (index == 2.) p = vec3(cos(angle1) * radius, 1.3, cos(angle1) * radius);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) p = vec3(cos(angle0) * radius, 0.6, sin(angle0) * radius);\\n\\tif (index == 4.) p = vec3(cos(angle1) * radius/mouse.y, 1., sin(angle1) * radius);\\n\\tif (index == 5.) p = vec3(cos(angle0) - radius, 1., sin(angle0) * radius);\\n\\t\\n \\tfloat atten = p.z;\\n \\n\\tp *= RotX(-angleTorus);\\n\\t\\n\\tp.z += 11. * cos(angleTorus);\\n\\tp.y += 11. * sin(angleTorus);\\n\\t\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 3.14159 * 0.6;\\n\\tfloat cd = 50.;\\n\\tvec3 eye = vec3(sin(ca), 0.15, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(65. * PI / 180., resolution.x / resolution.y, 0.01, 1000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 2.1);\\n\\t\\n \\tp /= atten;\\n \\n\\tv_color = vec4(normalize(p) * 0.5 + 0.2, 0.4);\\n}\"}", + "settings": { + "num": 5460, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=LINES\n//KVerticesNumber=10000\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 + 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, -.02, 0, 0,\n 0, f, 0, 0,\n -f-2., 1.0-mouse.y, -(zNear + zFar) * rangeInv, -3,\n 0, 0, zNear - zFar * rangeInv / 1.25, f);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target*1.6)*2.;\n vec3 xAxis = normalize(cross(up, zAxis)*5.);\n vec3 yAxis = cross(zAxis, xAxis* mouse.y)*2.;\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, sin( fract(mouse.x+ 0.2)));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * sin(a11 - a01 * a10),\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a11 / sin(mouse.x / 5.0 * a02) * a11,\n b04 = a00 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 +\n a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvoid main()\n{\n\tgl_PointSize = 3.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tvec3 p = vec3(0);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\t\n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat countSection = floor(6.);\n\t\n\tfloat indexCircle = floor(indexQuad / countSection);\n\t\n\tfloat astep = 3.14159 * 2.0 / countSection;\n\t\n\tfloat angle0 = indexQuad * astep;\n\tfloat angle1 = (indexQuad + 1.) * astep;\n\t\n\tfloat astepTorus = 3.14159 * 1.0 / floor(666.);\n\tfloat angleTorus = indexCircle * astepTorus;\n\t\n\tfloat radius = 4. *- cos(angleTorus * 1.5 + time) * 2.;\n\t\n\t// triangle 1\n\tif (index == 0.) p = vec3(cos(angle0) * radius, 1.3, tan(angle0) * radius);\n\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) -23.8+ radius);\n\tif (index == 2.) p = vec3(cos(angle1) * radius, 1.3, cos(angle1) * radius);\n\t\n\t// triangle 2\n\tif (index == 3.) p = vec3(cos(angle0) * radius, 0.6, sin(angle0) * radius);\n\tif (index == 4.) p = vec3(cos(angle1) * radius/mouse.y, 1., sin(angle1) * radius);\n\tif (index == 5.) p = vec3(cos(angle0) - radius, 1., sin(angle0) * radius);\n\t\n \tfloat atten = p.z;\n \n\tp *= RotX(-angleTorus);\n\t\n\tp.z += 11. * cos(angleTorus);\n\tp.y += 11. * sin(angleTorus);\n\t\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 3.14159 * 0.6;\n\tfloat cd = 50.;\n\tvec3 eye = vec3(sin(ca), 0.15, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(65. * PI / 180., resolution.x / resolution.y, 0.01, 1000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 2.1);\n\t\n \tp /= atten;\n \n\tv_color = vec4(normalize(p) * 0.5 + 0.2, 0.4);\n}" + }, "screenshotURL": "data/images/images-5uexyao2ms42c8sot-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TMG34LHftperZZKZm/art.json b/art/TMG34LHftperZZKZm/art.json index e5a321d9..450a83ce 100644 --- a/art/TMG34LHftperZZKZm/art.json +++ b/art/TMG34LHftperZZKZm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-13m17rjl5l9u5tbm5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TPrujGdAaBfqpYpvT/art.json b/art/TPrujGdAaBfqpYpvT/art.json index ddbcc5d2..54f9e36d 100644 --- a/art/TPrujGdAaBfqpYpvT/art.json +++ b/art/TPrujGdAaBfqpYpvT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float phi = vertexId / vertexCount * 3.14159265*2.0;\\n \\n float x = cos(phi);\\n float y = sin(phi);\\n float z = 0.0;\\n \\n float theta = 20.0 * sin(cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\\n \\n y *= cos(theta);\\n z = sin(theta) * sin(phi);\\n \\n vec4 pos = vec4(x, y, z, 1.0);\\n \\n vec3 eye = vec3(sin(time*0.3), 0, cos(time*0.3));\\n vec3 right = vec3(-eye.z, 0, eye.x);\\n vec3 look = -eye;\\n\\n mat4 L = mat4(vec4(right, 0),\\n vec4(0, 1, 0, 0),\\n vec4(look, 0),\\n vec4(0, 0, 0, 1));\\n \\n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\\n v_color = vec4(sin(theta) * 0.5 + 0.5,\\n cos(phi) * 0.5 + 0.5,\\n sin(time) * 0.5 + 0.5,\\n 1.0);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float phi = vertexId / vertexCount * 3.14159265*2.0;\n \n float x = cos(phi);\n float y = sin(phi);\n float z = 0.0;\n \n float theta = 20.0 * sin(cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\n \n y *= cos(theta);\n z = sin(theta) * sin(phi);\n \n vec4 pos = vec4(x, y, z, 1.0);\n \n vec3 eye = vec3(sin(time*0.3), 0, cos(time*0.3));\n vec3 right = vec3(-eye.z, 0, eye.x);\n vec3 look = -eye;\n\n mat4 L = mat4(vec4(right, 0),\n vec4(0, 1, 0, 0),\n vec4(look, 0),\n vec4(0, 0, 0, 1));\n \n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\n v_color = vec4(sin(theta) * 0.5 + 0.5,\n cos(phi) * 0.5 + 0.5,\n sin(time) * 0.5 + 0.5,\n 1.0);\n}" + }, "screenshotURL": "data/images/images-0jwrasq7zltr4fxm8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TTsbi8YxPA9GcqRmJ/art.json b/art/TTsbi8YxPA9GcqRmJ/art.json index 994a6609..81670b6f 100644 --- a/art/TTsbi8YxPA9GcqRmJ/art.json +++ b/art/TTsbi8YxPA9GcqRmJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 16.0, 1.00);\\n vec3 p = tan(fract(c.xxx + K.xyz) * 2.0 * K.www /2.);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 1.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 2.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, c*0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle *3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id - 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI - 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod(c+ s, v);\\n float y = s = v + 11.* s *.04;\\n float z = c/ 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 1.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 1.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 12.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin((time * .03)+ circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) /.4;\\n offset.y += goop(circleId + time * 0.13) * 1.31 / (mouse.y- sin(time));\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -2.79));\\n float sat = 0.2 * circleId/snd;\\n float val = .9;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) * tan(pos / 83.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 16.0, 1.00);\n vec3 p = tan(fract(c.xxx + K.xyz) * 2.0 * K.www /2.);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 1.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 2.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, c*0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle *3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id - 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI - 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod(c+ s, v);\n float y = s = v + 11.* s *.04;\n float z = c/ 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 1.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 1.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 12.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin((time * .03)+ circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) /.4;\n offset.y += goop(circleId + time * 0.13) * 1.31 / (mouse.y- sin(time));\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -2.79));\n float sat = 0.2 * circleId/snd;\n float val = .9;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) * tan(pos / 83.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\n}" + }, "screenshotURL": "data/images/images-02wh8dgy7pkg8hsij-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TWsa59dHZ4GX5bsnG/art.json b/art/TWsa59dHZ4GX5bsnG/art.json index a38c120d..546fc78b 100644 --- a/art/TWsa59dHZ4GX5bsnG/art.json +++ b/art/TWsa59dHZ4GX5bsnG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gyabo", "avatarUrl": "https://secure.gravatar.com/avatar/4c346a45401eb00f419d66174540a232?default=retro&size=200", - "settings": "{\"num\":4,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n vec3 p = vec3(\\n floor(vertexId / 2.0),\\n floor(mod(vertexId, 2.0)), 0.0) * 2.0 - 1.0;\\n \\n gl_Position = vec4(p.xy, 0.01, 1.0);\\n \\n v_color = vec4(0.0);\\n v_color.xy = p.xy;\\n \\n v_color = max(vec4(0.0), v_color);\\n v_color.a = 1.0;\\n}\\n\\n\"}", + "settings": { + "num": 4, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n vec3 p = vec3(\n floor(vertexId / 2.0),\n floor(mod(vertexId, 2.0)), 0.0) * 2.0 - 1.0;\n \n gl_Position = vec4(p.xy, 0.01, 1.0);\n \n v_color = vec4(0.0);\n v_color.xy = p.xy;\n \n v_color = max(vec4(0.0), v_color);\n v_color.a = 1.0;\n}\n\n" + }, "screenshotURL": "data/images/images-d20f5cpkea0rd9mfh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TYoTaksHA6DWsP4aD/art.json b/art/TYoTaksHA6DWsP4aD/art.json index 0d53c307..3222722b 100644 --- a/art/TYoTaksHA6DWsP4aD/art.json +++ b/art/TYoTaksHA6DWsP4aD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":6272,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/robotandproud/sets/songs-from-different-places\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ⏆ */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nfloat select(float v, float t) {\\n return step(t * 0.9, v) * step(v, t * 1.1);\\n}\\n\\nvoid main() {\\n float GRID_YOFF = 1./40.;\\n float GRID_DOWN = 17.;\\n float GRID_ACROSS = 64.0;\\n float NUM_PER_DOWN = GRID_DOWN * 2.;\\n float NUM_PER_ACROSS = GRID_ACROSS * 2.;\\n float NUM_PER_GRID = NUM_PER_DOWN + NUM_PER_ACROSS;\\n float NUM_GRIDS = 4.;\\n float NUM_GRID_TOTAL = NUM_PER_GRID * NUM_GRIDS;\\n float NUM_POINTS = (vertexCount - NUM_GRID_TOTAL) / 4.;\\n float NUM_SEGMENTS = NUM_POINTS / 2.;\\n \\n \\n float id = vertexId - NUM_GRID_TOTAL;\\n \\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(id, NUM_POINTS) / 2.0) + mod(id, 2.0);\\n // line count\\n float grid = floor(id / NUM_POINTS);\\n\\n float u = point / (NUM_SEGMENTS - 1.); // 0 <-> 1 across line\\n float v = grid / NUM_GRIDS; // 0 <-> 1 by line\\n\\n float snd0 = texture2D(sound, vec2(u * 1., 0)).a;\\n float snd1 = texture2D(sound, vec2(u * 0.5, 0)).a;\\n float snd2 = texture2D(sound, vec2(u * 0.25, 0)).a;\\n float snd3 = texture2D(sound, vec2(u * 0.125, 0)).a;\\n \\n float s = \\n snd0 * select(grid, 0.) + \\n snd1 * select(grid, 1.) +\\n snd2 * select(grid, 2.) + \\n snd3 * select(grid, 3.) +\\n 0.;\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x,\\n s * 0.4 + y + GRID_YOFF);\\n gl_Position = vec4(xy, 0, 1);\\n \\n float hue = grid * 0.25;\\n float sat = 1.0;\\n float val = 1.0;\\n \\n if (id < 0.0) {\\n if (vertexId < NUM_PER_DOWN * NUM_GRIDS) {\\n float hgx = mod(vertexId, 2.0);\\n float hgy = mod(floor(vertexId / 2.), GRID_DOWN);\\n float hgId = floor(vertexId / NUM_PER_DOWN);\\n gl_Position = vec4(\\n hgx * 2. - 1.,\\n hgy / (GRID_DOWN - 1.) * 0.4 + \\n (hgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\\n 0.1,\\n 1);\\n \\n hue = hgId * 0.25;\\n sat = 0.5;\\n val = 0.3;\\n } else {\\n float vid = vertexId - NUM_PER_DOWN * NUM_GRIDS;\\n float vgy = mod(vid, 2.0);\\n float vgx = mod(floor(vid / 2.), GRID_ACROSS);\\n float vgId = floor(vid / NUM_PER_ACROSS);\\n gl_Position = vec4(\\n ((vgx / GRID_ACROSS) * 2. - 1.) * pow(2., vgId),\\n vgy * 0.4 + \\n (vgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\\n 0.1,\\n 1);\\n \\n hue = vgId * 0.25;\\n sat = 0.5;\\n val = 0.3;\\n \\n }\\n }\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 6272, + "mode": "LINES", + "sound": "https://soundcloud.com/robotandproud/sets/songs-from-different-places", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ⏆ */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nfloat select(float v, float t) {\n return step(t * 0.9, v) * step(v, t * 1.1);\n}\n\nvoid main() {\n float GRID_YOFF = 1./40.;\n float GRID_DOWN = 17.;\n float GRID_ACROSS = 64.0;\n float NUM_PER_DOWN = GRID_DOWN * 2.;\n float NUM_PER_ACROSS = GRID_ACROSS * 2.;\n float NUM_PER_GRID = NUM_PER_DOWN + NUM_PER_ACROSS;\n float NUM_GRIDS = 4.;\n float NUM_GRID_TOTAL = NUM_PER_GRID * NUM_GRIDS;\n float NUM_POINTS = (vertexCount - NUM_GRID_TOTAL) / 4.;\n float NUM_SEGMENTS = NUM_POINTS / 2.;\n \n \n float id = vertexId - NUM_GRID_TOTAL;\n \n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(id, NUM_POINTS) / 2.0) + mod(id, 2.0);\n // line count\n float grid = floor(id / NUM_POINTS);\n\n float u = point / (NUM_SEGMENTS - 1.); // 0 <-> 1 across line\n float v = grid / NUM_GRIDS; // 0 <-> 1 by line\n\n float snd0 = texture2D(sound, vec2(u * 1., 0)).a;\n float snd1 = texture2D(sound, vec2(u * 0.5, 0)).a;\n float snd2 = texture2D(sound, vec2(u * 0.25, 0)).a;\n float snd3 = texture2D(sound, vec2(u * 0.125, 0)).a;\n \n float s = \n snd0 * select(grid, 0.) + \n snd1 * select(grid, 1.) +\n snd2 * select(grid, 2.) + \n snd3 * select(grid, 3.) +\n 0.;\n \n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x,\n s * 0.4 + y + GRID_YOFF);\n gl_Position = vec4(xy, 0, 1);\n \n float hue = grid * 0.25;\n float sat = 1.0;\n float val = 1.0;\n \n if (id < 0.0) {\n if (vertexId < NUM_PER_DOWN * NUM_GRIDS) {\n float hgx = mod(vertexId, 2.0);\n float hgy = mod(floor(vertexId / 2.), GRID_DOWN);\n float hgId = floor(vertexId / NUM_PER_DOWN);\n gl_Position = vec4(\n hgx * 2. - 1.,\n hgy / (GRID_DOWN - 1.) * 0.4 + \n (hgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\n 0.1,\n 1);\n \n hue = hgId * 0.25;\n sat = 0.5;\n val = 0.3;\n } else {\n float vid = vertexId - NUM_PER_DOWN * NUM_GRIDS;\n float vgy = mod(vid, 2.0);\n float vgx = mod(floor(vid / 2.), GRID_ACROSS);\n float vgId = floor(vid / NUM_PER_ACROSS);\n gl_Position = vec4(\n ((vgx / GRID_ACROSS) * 2. - 1.) * pow(2., vgId),\n vgy * 0.4 + \n (vgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\n 0.1,\n 1);\n \n hue = vgId * 0.25;\n sat = 0.5;\n val = 0.3;\n \n }\n }\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-pntovum9yxo1r8mp1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TZ58peuETd4DLzbYC/art.json b/art/TZ58peuETd4DLzbYC/art.json index ed324d90..96544858 100644 --- a/art/TZ58peuETd4DLzbYC/art.json +++ b/art/TZ58peuETd4DLzbYC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1920,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec2 createCircle(float vertexId){\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor (vertexId /3.0), 2.0);\\n \\n float angle = ux /20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n vec2 xy = vec2(x,y);\\n return xy; \\n}\\n\\nvoid main() \\n{ \\n \\n \\n \\n float circleId = floor(vertexId/(20.0*6.0));\\n float numCircles = floor(vertexCount / (20.0*6.0));\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n vec2 xy = createCircle(vertexId) * 0.1 + vec2(ux,vy)*0.7;\\n \\n gl_Position= vec4(xy , 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1920, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec2 createCircle(float vertexId){\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor (vertexId /3.0), 2.0);\n \n float angle = ux /20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n vec2 xy = vec2(x,y);\n return xy; \n}\n\nvoid main() \n{ \n \n \n \n float circleId = floor(vertexId/(20.0*6.0));\n float numCircles = floor(vertexCount / (20.0*6.0));\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n vec2 xy = createCircle(vertexId) * 0.1 + vec2(ux,vy)*0.7;\n \n gl_Position= vec4(xy , 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-xsqe39n7zycs1psmt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TZBvEoNYkzhB8PtQR/art.json b/art/TZBvEoNYkzhB8PtQR/art.json index 65fb0b62..2709679a 100644 --- a/art/TZBvEoNYkzhB8PtQR/art.json +++ b/art/TZBvEoNYkzhB8PtQR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/grimmlins/jeff-mills\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 1.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n //snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = pow(snd2, 6.);//pow(snd,2.);//mix(0.0, 1. - pow(snd, 4.), cgId);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n\\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 4.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n// mat *= ident();\\n// mat *= scale(aspect * (0.4 + sin(time) * 0.0));\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n// mat *= trans(offset);\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));//pow(snd, 0.5) * -6. * sign(offset.x));\\n mat *= uniformScale(0.05);// * sp);// + -sin((time + 0.5) * 6.) * 0.01);\\n mat *= rotZ(PI * 0.66 * 0.25);\\n mat *= uniformScale(\\n mix(1.,\\n mix(snd, snd2, mod(time * 60., 2.)) + sliceId * sin(time) * 0.5,\\n easeInOutSine(time * 0.1))\\n );\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = hash(mod(abs(gx - gAcross / 2.), 3.)) + time * 0.1;//tm * 0.0 + mix(0., .02, length(offset));\\n float sat = pow(snd + 1.- gy / gDown, 5.);\\n float val = pow(snd2, 4.);//pow(snd + pow(gy / gDown, 0.3), 15.);//step(0.90, snd); //0.;//mix(hash(groupId), 1.0, step(0.99, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/grimmlins/jeff-mills", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 1.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n //snd = pow(snd, mix(2., 0.5, su));\n \n \n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = pow(snd2, 6.);//pow(snd,2.);//mix(0.0, 1. - pow(snd, 4.), cgId);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 4.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n// mat *= ident();\n// mat *= scale(aspect * (0.4 + sin(time) * 0.0));\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n// mat *= trans(offset);\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));//pow(snd, 0.5) * -6. * sign(offset.x));\n mat *= uniformScale(0.05);// * sp);// + -sin((time + 0.5) * 6.) * 0.01);\n mat *= rotZ(PI * 0.66 * 0.25);\n mat *= uniformScale(\n mix(1.,\n mix(snd, snd2, mod(time * 60., 2.)) + sliceId * sin(time) * 0.5,\n easeInOutSine(time * 0.1))\n );\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = hash(mod(abs(gx - gAcross / 2.), 3.)) + time * 0.1;//tm * 0.0 + mix(0., .02, length(offset));\n float sat = pow(snd + 1.- gy / gDown, 5.);\n float val = pow(snd2, 4.);//pow(snd + pow(gy / gDown, 0.3), 15.);//step(0.90, snd); //0.;//mix(hash(groupId), 1.0, step(0.99, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-dgsde2jx3xio85xi3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ta4jCjwCjoL5iw4gY/art.json b/art/Ta4jCjwCjoL5iw4gY/art.json index 518854ec..ad6d2735 100644 --- a/art/Ta4jCjwCjoL5iw4gY/art.json +++ b/art/Ta4jCjwCjoL5iw4gY/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":8666,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Colors\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * abs(sin(time) + 100.)/10.) * 0.1;\\n float yoff = cos(time + x * 0.03) * 0.5;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(tan(xy), 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 8666, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Colors\ncourse name : CS250\nterm : 2022 Spring\n*/\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * abs(sin(time) + 100.)/10.) * 0.1;\n float yoff = cos(time + x * 0.03) * 0.5;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(tan(xy), 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-k5drgoqh9zi3fkxji-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TaRwiuErKL5fkN24p/art.json b/art/TaRwiuErKL5fkN24p/art.json index 794e143d..5fcdbd10 100644 --- a/art/TaRwiuErKL5fkN24p/art.json +++ b/art/TaRwiuErKL5fkN24p/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":33245,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 2.//KParameter1 0.1>>3.\\n#define parameter2 1.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 1.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx - K.xyz) - 8.0 + K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 2.5, 1.8)*parameter1, c.x);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle+time );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *17.,s)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 33245, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 2.//KParameter1 0.1>>3.\n#define parameter2 1.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 1.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx - K.xyz) - 8.0 + K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 2.5, 1.8)*parameter1, c.x);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle+time );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *17.,s)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-urg0yvvgn6s8zpuh8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TcJgksCcEE95aJXZc/art.json b/art/TcJgksCcEE95aJXZc/art.json index ce4455eb..00a01ba2 100644 --- a/art/TcJgksCcEE95aJXZc/art.json +++ b/art/TcJgksCcEE95aJXZc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":9,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.027450980392156862,0.08627450980392157,1],\"shader\":\"#define TAU radians(360.)\\n#define TAU_2 radians(180.)\\n#define TAU_3 radians(120.)\\n#define TAU_4 radians(90.)\\n\\n#define PI TAU_2\\n\\nvec3 hsv2rgb(vec3 c);\\nvec2 triangle(int vtx);\\n\\nvoid main() {\\n float triangleId = floor(vertexId / 3.0);\\n float triangleCount = floor(vertexCount / 3.0);\\n float triVtx = mod(vertexId, 3.0);\\n \\n float angle = TAU_3 * triangleId;\\n vec3 pos = vec3(triangle(int(triVtx)), 1.0);\\n \\n mat3 rot = mat3(\\n vec3(cos(angle), sin(angle), 0.0),\\n vec3(-sin(angle), cos(angle), 0.0),\\n vec3(0.0, 0.0, 1.0)\\n );\\n mat3 scal = mat3(0.6);\\n pos = scal * rot * pos;\\n \\n // correct for aspect ratio\\n pos.y *= resolution.x/resolution.y;\\n gl_Position = vec4(pos, 1.0);\\n \\n float t = mix(triangleId/triangleCount, (triangleId+1.)/triangleCount, 0.5);\\n vec3 col = hsv2rgb(vec3(0.25 * mod(triangleId, 4.0), 0.7, 0.7));\\n v_color = vec4(col, 1.0);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 triangle(int vtx) {\\n if (vtx == 0) {\\n return vec2(-0.5, -0.5);\\n } else if (vtx == 1) {\\n return vec2(0.0, 0.0);\\n } else if (vtx == 2) {\\n return vec2(0.5, -0.5);\\n } else {\\n return vec2(0.0, sin(time)*sin(time));\\n }\\n}\\n\"}", + "settings": { + "num": 9, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.027450980392156862, + 0.08627450980392157, + 1 + ], + "shader": "#define TAU radians(360.)\n#define TAU_2 radians(180.)\n#define TAU_3 radians(120.)\n#define TAU_4 radians(90.)\n\n#define PI TAU_2\n\nvec3 hsv2rgb(vec3 c);\nvec2 triangle(int vtx);\n\nvoid main() {\n float triangleId = floor(vertexId / 3.0);\n float triangleCount = floor(vertexCount / 3.0);\n float triVtx = mod(vertexId, 3.0);\n \n float angle = TAU_3 * triangleId;\n vec3 pos = vec3(triangle(int(triVtx)), 1.0);\n \n mat3 rot = mat3(\n vec3(cos(angle), sin(angle), 0.0),\n vec3(-sin(angle), cos(angle), 0.0),\n vec3(0.0, 0.0, 1.0)\n );\n mat3 scal = mat3(0.6);\n pos = scal * rot * pos;\n \n // correct for aspect ratio\n pos.y *= resolution.x/resolution.y;\n gl_Position = vec4(pos, 1.0);\n \n float t = mix(triangleId/triangleCount, (triangleId+1.)/triangleCount, 0.5);\n vec3 col = hsv2rgb(vec3(0.25 * mod(triangleId, 4.0), 0.7, 0.7));\n v_color = vec4(col, 1.0);\n}\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 triangle(int vtx) {\n if (vtx == 0) {\n return vec2(-0.5, -0.5);\n } else if (vtx == 1) {\n return vec2(0.0, 0.0);\n } else if (vtx == 2) {\n return vec2(0.5, -0.5);\n } else {\n return vec2(0.0, sin(time)*sin(time));\n }\n}\n" + }, "screenshotURL": "data/images/images-9rfky2urbj9c7knas-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TdqvseMQyoJ3ZrjrD/art.json b/art/TdqvseMQyoJ3ZrjrD/art.json index a871b761..0dd92b07 100644 --- a/art/TdqvseMQyoJ3ZrjrD/art.json +++ b/art/TdqvseMQyoJ3ZrjrD/art.json @@ -27,7 +27,19 @@ "name": "Garden Fireworks", "private": false, "username": "P_Malin", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Garden Fireworks - @P_Malin\\n// Playing with motion blurred hexagonal bokeh\\n\\n#define SHAKY_CAM\\n\\nfloat Cross( const in vec2 A, const in vec2 B )\\n{\\n return A.x * B.y - A.y * B.x;\\n}\\n\\nvoid GetTriInfo( const float vertexIndex, out vec2 triVertId, out float triId )\\n{\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( triVertexIndex < 0.5 ) \\ttriVertId = vec2( 0.0, 0.0 );\\n else if\\t( triVertexIndex < 1.5 )\\ttriVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\ttriVertId = vec2( 0.0, 1.0 );\\n\\n triId = floor( vertexIndex / 3.0 );\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nmat3 RotMatrixX( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( 1.0, 0.0, 0.0, \\n 0.0, c, s,\\n 0.0, -s, c ); \\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat Hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nvec3 Hash3(float p)\\n{\\n vec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\\n}\\n\\nvec3 Hash32(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\\n p3 += dot(p3, p3.yxz+19.19);\\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\\n}\\n\\n\\nvec3 Noise23( vec2 p )\\n{\\n\\tvec2 fl = floor(p);\\n\\n\\tvec3 h00 = Hash32( fl + vec2( 0.0, 0.0 ) );\\n\\tvec3 h10 = Hash32( fl + vec2( 1.0, 0.0 ) );\\n\\tvec3 h01 = Hash32( fl + vec2( 0.0, 1.0 ) );\\n\\tvec3 h11 = Hash32( fl + vec2( 1.0, 1.0 ) );\\n\\n\\tvec2 fr = p - fl;\\n\\t\\n\\tvec2 fr2 = fr * fr;\\n\\tvec2 fr3 = fr2 * fr;\\n\\t\\n\\tvec2 t1 = 3.0 * fr2 - 2.0 * fr3;\\t\\n\\tvec2 t0 = 1.0 - t1;\\n\\t\\n\\treturn h00 * t0.x * t0.y\\n\\t\\t + h10 * t1.x * t0.y\\n\\t\\t + h01 * t0.x * t1.y\\n\\t\\t + h11 * t1.x * t1.y;\\n}\\n\\nstruct CameraSettings\\n{\\n float fAperture;\\n float fFocalLength;\\n float fPlaneInFocus; \\n float fExposure;\\n};\\n\\nstruct CameraPosition\\n{\\n \\tvec3 vPosition;\\n \\tvec3 vTarget;\\n \\tvec3 vUp;\\n \\n \\tmat3 mRotation;\\n};\\n \\nstruct OutVertex\\n{\\n \\tvec2 vPos;\\n \\tvec3 vColor;\\n}; \\n \\n#define HEXAGON_OUTLINE_VERTEX_COUNT \\t6.0 * (6.0 + 2.0)\\n\\nvoid GetHexagonOutlineVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r0, const float r1, const vec3 col0, const vec3 col1, inout OutVertex vertex )\\n{\\n \\tfloat fAngleOffset = settings.fAperture * 0.5;\\n \\n \\tif ( fVertexIndex < 6.0 * 6.0 ) \\n {\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndex, vQuadVertId, fQuadId );\\n\\n float fIndex = fQuadId + vQuadVertId.x;\\n\\n float fAngle = fIndex * radians(360.0) / 6.0;\\n\\n float fRadius = mix( r0, r1, vQuadVertId.y);\\n\\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\\n\\n float fCurrIndex = fQuadId;\\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\\n\\n float fNextIndex = fQuadId + 1.0;\\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\\n\\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\\n {\\n vPos += vDir;\\n }\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n else\\n {\\n\\t float fVertexIndexB = fVertexIndex - 6.0 * 6.0;\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\\n \\n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\\n \\n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\\n \\n if ( fQuadId > 0.0 )\\n {\\n\\t\\tfEdgeAngle += radians( 180.0 );\\n }\\n \\n float fRadius = mix( r0, r1, vQuadVertId.y);\\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\\n vPos += vDir * vQuadVertId.x;\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n}\\n \\n#define HEXAGON_VERTEX_COUNT (6.0 * 3.0 + 6.0 * 2.0)\\nvoid GetHexagonVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r, const vec3 col0, const vec3 col1, inout OutVertex vertex )\\n{\\n \\tfloat fAngleOffset = settings.fAperture * 0.5;\\n \\n \\tif ( fVertexIndex < 6.0 * 3.0 ) \\n {\\n float fTriId;\\n\\n vec2 vTriVertId;\\n GetTriInfo( fVertexIndex, vTriVertId, fTriId );\\n\\n float fIndex = fTriId + vTriVertId.x;\\n\\n float fAngle = fIndex * radians(360.0) / 6.0;\\n\\n float fRadius = vTriVertId.y * r;\\n\\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\\n\\n float fCurrIndex = fTriId;\\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\\n\\n float fNextIndex = fTriId + 1.0;\\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\\n\\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\\n {\\n vPos += vDir;\\n }\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vTriVertId.y );\\n }\\n else\\n {\\n\\t float fVertexIndexB = fVertexIndex - 6.0 * 3.0;\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\\n \\n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\\n \\n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\\n \\n if ( fQuadId > 0.0 )\\n {\\n\\t\\tfEdgeAngle += radians( 180.0 );\\n }\\n \\n float fRadius = vQuadVertId.y * r;\\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\\n vPos += vDir * vQuadVertId.x;\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n}\\n\\n\\n#define BOKEH_VERTEX_COUNT ( HEXAGON_VERTEX_COUNT + HEXAGON_OUTLINE_VERTEX_COUNT ) \\nvoid GetBokehVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float fSize, const float fCoC, const vec3 vCol, out OutVertex vertex )\\n{\\n \\tfloat fInnerSize = fSize + fCoC;\\n \\tfloat fGlowSize = 0.02;\\n \\tfloat fOuterSize = fInnerSize + fGlowSize;\\n \\n \\tif ( fVertexIndex < HEXAGON_VERTEX_COUNT )\\n {\\n \\t\\tGetHexagonVertex( settings, fVertexIndex, vOrigin, vDir, fInnerSize, vCol, vCol, vertex );\\n }\\n \\telse\\n {\\n\\t \\tvec3 vGlowCol = pow(vCol, vec3(0.5)) * 0.0001; \\n \\tif ( length( vGlowCol ) > 0.0000001 )\\n {\\n \\t\\t\\tGetHexagonOutlineVertex( settings, fVertexIndex - HEXAGON_VERTEX_COUNT, vOrigin, vDir, fInnerSize, fOuterSize, vGlowCol, vCol * 0.0, vertex );\\n }\\n else\\n {\\n \\tvertex.vPos.xy = vec2(0.0);\\n \\tvertex.vColor.rgb = vec3(0.0);\\n }\\n }\\n}\\n\\nfloat GetCoC( CameraSettings settings, float objectdistance )\\n{\\n // http://http.developer.nvidia.com/GPUGems/gpugems_ch23.html\\n\\n\\treturn abs(settings.fAperture * (settings.fFocalLength * (objectdistance - settings.fPlaneInFocus)) /\\n (objectdistance * (settings.fPlaneInFocus - settings.fFocalLength))); \\n}\\n\\n\\nvec3 GetViewPos( CameraSettings settings, CameraPosition cameraPos, vec3 vWorldPos )\\n{\\n \\treturn (vWorldPos - cameraPos.vPosition) * cameraPos.mRotation;\\n}\\n\\nvec2 GetScreenPos( CameraSettings settings, vec3 vViewPos )\\n{ \\n \\treturn vViewPos.xy * settings.fFocalLength * 5.0 / vViewPos.z;\\n}\\n\\nCameraSettings GetCameraSettings( CameraPosition cameraPosition )\\n{\\n \\tCameraSettings settings;\\n \\n \\tfloat aVal = sin(time * 0.25) * 0.5 + 0.5;\\n \\taVal = aVal * aVal;\\n \\tsettings.fAperture = aVal * 2.9 + 0.1;\\n \\tfloat fVal = sin(time * 0.123) * 0.5 + 0.5;\\n \\tsettings.fFocalLength = 0.2 + 0.2 * fVal;\\n \\tsettings.fPlaneInFocus = length(cameraPosition.vTarget - cameraPosition.vPosition);\\n \\n \\tfloat oldAVal = sin((time - 0.5) * 0.25) * 0.5 + 0.5;\\n \\toldAVal = oldAVal * oldAVal;\\n \\n\\tsettings.fExposure = 3.0 + oldAVal *3.0;\\n\\n \\treturn settings;\\n}\\n\\nstruct LightInfo\\n{\\n\\tvec3 vWorldPos;\\n \\tfloat fRadius;\\n \\tvec3 vColor;\\n};\\n \\n \\nvec2 SolveQuadratic( float a, float b, float c )\\n{\\n float d = sqrt( b * b - 4.0 * a * c );\\n vec2 dV = vec2( d, -d );\\n return (-b + dV) / (2.0 * a);\\n}\\n\\n\\nvec3 BounceParticle( vec3 vOrigin, vec3 vInitialVel, float fGravity, float fFloorHeight, float fTime )\\n{\\n \\tvec3 u = vInitialVel;\\n \\tvec3 a = vec3(0.0, fGravity, 0.0);\\n \\tvec3 vPos = vOrigin;\\n\\n \\tfloat t = fTime;\\n \\t \\t\\n \\tfor( int iBounce=0; iBounce < 3; iBounce++)\\n {\\n // When will we hit the ground?\\n vec2 q = SolveQuadratic( 0.5 * a.y, u.y, -fFloorHeight + vPos.y);\\n float tInt = max( q.x, q.y );\\n tInt -= 0.0001;\\n \\n\\n if ( t < tInt )\\n {\\n\\t vPos += u * t + 0.5 * a * t * t;\\n break;\\n }\\n else\\n { \\n // Calculate velocity at intersect time\\n vec3 v = u + a * tInt;\\n\\n // step to intersect time\\n vPos += u * tInt + 0.5 * a * tInt * tInt;\\n \\t u = v;\\n \\n // bounce\\n u.y = -u.y * 0.3;\\n u.xz *= 0.6;\\n\\n t -= tInt;\\n }\\n }\\n\\n \\treturn vPos;\\n}\\n\\nfloat fFloorHeight = 0.0;\\n\\nLightInfo Fountain( const in float fLightIndex, const in vec3 vPos, float fTime, vec3 vCol, float fSpread )\\n{\\n float fParticleLifetime = 1.5;\\n \\tLightInfo lightInfo;\\n \\n \\tfloat h = Hash( fLightIndex + 12.0 );\\n \\tvec3 h3 = Hash3( fLightIndex + 13.0 );\\n \\n \\tfloat fAngle = fLightIndex;\\n \\n \\tvec3 vInitialVel = (normalize(h3 * 2.0 - 1.0) * fSpread + vec3( 0.0, 10.0 - fSpread * 1.3, 0.0 )) * (0.4 + h * 0.4);\\n \\tvec3 vOrigin = vPos + vec3( 0.0, fFloorHeight + 0.1, 0.0 ) + vInitialVel * 0.1;\\n \\tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fTime );\\n\\n \\n \\tlightInfo.fRadius = 0.01; \\n// \\tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\\n \\tlightInfo.vColor = vCol;\\n \\tlightInfo.vColor *= clamp( 1.0 - fTime + fParticleLifetime - 1.0, 0.0, 1.0);\\n\\treturn lightInfo; \\n}\\n\\nLightInfo CatherineWheel( const in float fLightIndex, const in vec3 vPos, float fSequenceStart, float fSpawnTime, float fParticleT, vec3 vCol )\\n{\\n \\tfloat h = Hash( fLightIndex + 4.0 );\\n\\n\\t float fParticleLifetime = 0.3 + h *0.5;\\n \\tLightInfo lightInfo;\\n\\n \\tvec3 h3 = Hash3( fLightIndex + 12.0 );\\n \\tfloat t = fSpawnTime - fSequenceStart;\\n \\tif( t < 5.0 ) t = t * t;\\n \\telse t = t * 5.0 + 5.0 * 5.0;\\n \\t\\n \\tfloat fSpawnAngle = t * 5.0;\\n \\n \\tif ( h > 0.5 )\\n {\\n fSpawnAngle += radians( 180.0 );\\n }\\n \\n \\tmat3 m = RotMatrixZ(fSpawnAngle);\\n \\n \\tvec3 vInitialVel = vec3(-3.0, 0.0, 0.0 ) + h3 * 0.5;\\n \\tvInitialVel = vInitialVel * m;\\n \\tvec3 vOffset = vec3( 0.0, 0.03, 0.0 * m);\\n \\tvec3 vOrigin = vPos + vOffset + vInitialVel * 0.1;\\n \\tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fParticleT );\\n\\n \\n \\tlightInfo.fRadius = 0.01; \\n// \\tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\\n \\tlightInfo.vColor = vCol;\\n \\tlightInfo.vColor *= clamp( 1.0 - fParticleT + fParticleLifetime - 1.0, 0.0, 1.0);\\n\\treturn lightInfo; \\n}\\n\\n\\nstruct SequenceInfo\\n{\\n \\tfloat fSequenceSet;\\n \\tfloat fSequenceSetLength;\\n \\n \\tfloat fSequenceIndex;\\n \\tfloat fSequenceStartTime;\\n \\n \\tfloat fSequenceSeed;\\n \\tvec3 vSequenceHash;\\n \\n \\tvec3 vCol;\\n \\n \\tfloat fType;\\n \\tvec3 vPos;\\n \\tvec3 vTarget;\\n};\\n \\nSequenceInfo GetSequenceInfo( float fSetIndex, float fTime )\\n{\\n \\tSequenceInfo sequenceInfo;\\n\\n \\t\\tfloat fSequenceSetCount = 2.0;\\n \\tsequenceInfo.fSequenceSet = mod(fSetIndex, fSequenceSetCount);\\n\\n \\t\\tfloat sh = Hash( sequenceInfo.fSequenceSet );\\n \\t\\tfloat fSequenceSetLength = 10.0 + sh * 5.0;\\n \\n\\n \\t\\tsequenceInfo.fSequenceIndex = floor( fTime / fSequenceSetLength );\\n \\t\\tsequenceInfo.fSequenceStartTime = (sequenceInfo.fSequenceIndex * fSequenceSetLength);\\n \\n \\t\\tsequenceInfo.fSequenceSeed = sequenceInfo.fSequenceIndex + sequenceInfo.fSequenceSet * 12.3;\\n \\t\\tsequenceInfo.vSequenceHash = Hash3(sequenceInfo.fSequenceSeed);\\n\\n \\t\\tfloat ch = Hash( sequenceInfo.fSequenceSeed * 2.34 );\\n \\t\\tsequenceInfo.vCol = vec3(1.0, 0.4, 0.1);\\n \\n \\t\\tif( ch < 0.25 )\\n {\\n sequenceInfo.vCol = vec3(1.0, 0.08, 0.08);\\n }\\n \\t\\telse if( ch < 0.5 )\\n {\\n sequenceInfo.vCol = vec3(0.08, 0.08, 1.0);\\n }\\n \\t\\telse if( ch < 0.75 )\\n {\\n sequenceInfo.vCol = vec3(0.08, 1.0, 0.08 );\\n }\\n \\n \\n \\tif ( sequenceInfo.vSequenceHash.x < 0.7)\\n {\\n \\t\\t\\tsequenceInfo.vPos = vec3(0.0);\\n\\t \\t\\tsequenceInfo.vPos.xz = sequenceInfo.vSequenceHash.yz * 6.0 - 3.0;\\n\\t \\t\\tsequenceInfo.fType = 0.0;\\n \\tsequenceInfo.vTarget = sequenceInfo.vPos;\\n \\tsequenceInfo.vTarget.y = 1.5;\\n }\\n \\t\\telse\\n {\\n \\tsequenceInfo.vPos = vec3(0.0, 2.5, 7.0);\\n\\t \\t\\tsequenceInfo.vPos += (sequenceInfo.vSequenceHash.xyz * 2.0 - 1.0) * vec3(5.0, 1.5, 3.0);\\n\\t \\t\\tsequenceInfo.fType = 1.0;\\n \\tsequenceInfo.vTarget = sequenceInfo.vPos;\\n } \\n \\n \\treturn sequenceInfo;\\n}\\n\\nLightInfo GetFireworkSparkInfo( in float fLightIndex, float fTime, float fDeltaTime, vec3 h3 )\\n{ \\n\\t float fParticleLifetime = 1.5;\\n \\tfloat fParticleSpawnTime = (floor( (fTime / fParticleLifetime) + h3.x) - h3.x) * fParticleLifetime;\\n \\tfloat fParticleEndTime = fParticleSpawnTime + fParticleLifetime;\\n \\tfloat fParticleGlobalT = fTime - fParticleSpawnTime;\\n \\tfloat fParticleT = mod( fParticleGlobalT, fParticleLifetime ) + fDeltaTime;\\n \\n \\t\\tSequenceInfo sequenceInfo = GetSequenceInfo( fLightIndex, fParticleSpawnTime );\\n \\n \\tLightInfo lightInfo;\\n \\n \\t\\tif ( sequenceInfo.fType < 0.5)\\n {\\n \\tfloat fSpread = fract( sequenceInfo.vSequenceHash.z + sequenceInfo.vSequenceHash.y ) + 1.0;\\n\\t \\t\\tlightInfo = Fountain( fLightIndex, sequenceInfo.vPos, fParticleT, sequenceInfo.vCol, fSpread );\\n }\\n \\t\\telse\\n {\\n \\tlightInfo = CatherineWheel( fLightIndex, sequenceInfo.vPos, sequenceInfo.fSequenceStartTime, fParticleSpawnTime, fParticleT, sequenceInfo.vCol );\\n } \\n \\n return lightInfo; \\n}\\n\\nLightInfo GetLightInfo( const in float fLightIndex, float fTime, float fDeltaTime, CameraPosition cameraPos )\\n{\\n \\tLightInfo lightInfo;\\n\\n \\t//float h = Hash( fLightIndex );\\n \\tvec3 h3 = Hash3(fLightIndex);\\n\\n \\tfloat kHangingLightCount = 32.0;\\n \\tfloat kHangingLightMax = 0.0 + kHangingLightCount;\\n \\n \\tfloat kStarCount = 0.0;\\n \\tfloat kStarMax = kHangingLightMax + kStarCount;\\n \\t\\n \\tfloat kDirtCount = 16.0;\\n \\tfloat kDirtMax = kStarMax + kDirtCount;\\n\\n \\tfloat kStreetLightCount = 64.0;\\n \\tfloat kStreetLightMax = kDirtMax + kStreetLightCount;\\n \\n \\tfloat kGardenLightCount = 16.0;\\n \\tfloat kGardenLightMax = kStreetLightMax + kGardenLightCount;\\n\\n \\tif( fLightIndex < kHangingLightMax )\\n \\t{\\n \\t// hanging lights\\n \\tlightInfo.vWorldPos.x = ((fLightIndex / 10.0) * 2.0 - 1.0) * 3.0;\\n \\tlightInfo.vWorldPos.y = 2.0 + -abs( cos( fLightIndex * 0.4 ) * 0.8 ); \\n \\tlightInfo.vWorldPos.z = 20.0;\\n \\t\\tlightInfo.vColor = vec3(0.01) * 0.5;\\n \\tfloat fColIndex = mod(fLightIndex, 3.0);\\n \\tif ( fColIndex == 0.0 ) lightInfo.vColor.x = 1.0;\\n \\tif ( fColIndex == 1.0 ) lightInfo.vColor.y = 1.0;\\n \\tif ( fColIndex == 2.0 ) lightInfo.vColor.z = 1.0;\\n\\t lightInfo.vColor *= 0.05;\\n \\t\\t//lightInfo.vColor = normalize(vec3(sin(fLightIndex) * .5 + 0.5, sin(fLightIndex * 3.45) * .5 + 0.5, sin(fLightIndex * 4.56) * .5 + 0.5)) * 0.5;\\n \\n \\t\\tlightInfo.fRadius = 0.05;\\n\\t}\\n \\telse\\n \\tif( fLightIndex < kStarMax )\\n \\t{\\n // stars\\n \\tlightInfo.vWorldPos = normalize( h3 * 2.0 - 1.0 ) * 5000.0;\\n \\tlightInfo.vWorldPos.y = abs(lightInfo.vWorldPos.y);\\n \\t\\tlightInfo.vColor = vec3(0.01);\\n \\t\\tlightInfo.fRadius = 0.001;\\n }\\n \\telse\\n \\tif( fLightIndex < kDirtMax )\\n \\t{\\n // lens dirt\\n \\tlightInfo.vWorldPos.xy = (Hash3(fLightIndex).xy * 2.0 - 1.0);\\n \\tlightInfo.vWorldPos.xy = normalize(lightInfo.vWorldPos.xy) * pow( length(lightInfo.vWorldPos.xy), 0.3 ) * 0.35;\\n\\t lightInfo.vWorldPos.y *= resolution.y / resolution.x;\\n \\tlightInfo.vWorldPos.z = 0.3;\\n \\tvec3 vOffset = cameraPos.mRotation * lightInfo.vWorldPos;\\n \\tlightInfo.vWorldPos = vOffset + cameraPos.vPosition;\\n \\t\\tlightInfo.vColor = vec3(0.2, 0.18, 0.1) * abs( dot(normalize(vOffset), vec3(0.0, 0.0, 1.0)) ) * 10.0;\\n \\t\\tlightInfo.fRadius = 0.0001;\\n }\\n \\telse\\n // street lights\\n \\tif( fLightIndex < kStreetLightMax )\\n \\t{\\n \\tlightInfo.vWorldPos.xz = (h3.xy * 2.0 - 1.0) * 500.0;\\n \\tlightInfo.vWorldPos.y = 10.0; \\n \\t\\tlightInfo.vColor = vec3(1.0, 0.3, 0.01) * 0.5;\\n \\n \\t\\tlightInfo.fRadius = 0.2;\\n\\t}\\n \\telse if( fLightIndex < kGardenLightMax )\\n \\t{\\n \\tlightInfo.vWorldPos.y = 0.05 + h3.y * 0.5; \\n \\tvec2 vOffset = (h3.xz * 2.0 - 1.0);\\n \\tlightInfo.vWorldPos.xz = vOffset * 50.0 + normalize( vOffset ) * 10.0;\\n \\t\\tlightInfo.vColor = sin(h3 * 10.0 + vec3(0.1, 0.2, 0.3)) * 0.5 + 0.5;\\n \\tlightInfo.vColor = normalize(lightInfo.vColor);\\n\\t lightInfo.vColor *= 0.005;\\n \\n \\t\\tlightInfo.fRadius = 0.05;\\n\\t}\\n \\telse\\n {\\n \\tlightInfo = GetFireworkSparkInfo( fLightIndex, fTime, fDeltaTime, h3 );\\n }\\n \\n\\n \\treturn lightInfo;\\n}\\n\\n\\nvec3 GetCameraTarget( float fTime )\\n{\\n \\t//return vec3(0.0, 1.8, 0.0);\\n\\n \\tfloat fInterval = 8.0;\\n \\n \\tfloat t0 = floor(fTime / fInterval) * fInterval; \\n \\tfloat t1 = (floor(fTime / fInterval+ 1.0) ) * fInterval; \\n \\n \\tSequenceInfo inf0 = GetSequenceInfo( 0.0, t0 );\\n \\tSequenceInfo inf1 = GetSequenceInfo( 0.0, t1 );\\n \\n \\tfloat fBlend = (fTime - t0) / fInterval;\\n \\n \\tfBlend = smoothstep( 0.0, 1.0, fBlend);\\n \\n \\treturn mix( inf0.vTarget, inf1.vTarget, fBlend );\\n}\\n\\nCameraPosition GetCameraPosition( float fTime, vec2 vTouch )\\n{\\n \\tCameraPosition cameraPos;\\n \\n \\tif( (vTouch.y > 0.9) && (vTouch.x > -0.83) && (vTouch.x < -0.80) )\\n {\\t\\n \\tvTouch.xy = vec2(0.0);\\n }\\n \\n \\tcameraPos.vTarget = GetCameraTarget( fTime );\\n \\n \\tcameraPos.vPosition += cameraPos.vTarget;\\n \\t\\n \\tcameraPos.vPosition = vec3( sin(fTime * 0.2) * 5.0, 2.0, -6.0 + sin(fTime * 0.0567) * 3.0);\\n \\tcameraPos.vUp = vec3( 0.0, 1.0, 0.0 );\\n \\n \\tGetMatrixFromZY( normalize(cameraPos.vTarget - cameraPos.vPosition), cameraPos.vUp, cameraPos.mRotation );\\n \\n \\tvec3 vRot = vec3( vTouch.y * 0.5, vTouch.x * 0.5, 0.0 );\\n \\n#ifdef SHAKY_CAM\\n\\tvRot += Noise23( cameraPos.vPosition.xz * 4.0 ) * vec3( 0.05, 0.03, 0.01 ); //shaky cam\\n#endif\\n \\n \\tcameraPos.mRotation = cameraPos.mRotation * RotMatrixZ(vRot.z) * RotMatrixY(vRot.y) * RotMatrixX( vRot.x ) ; \\n \\n \\treturn cameraPos;\\n}\\n\\nvoid main() \\n{\\n float fVertexIndex = vertexId;\\n\\n vec4 touch1 = texture2D(touch, vec2(0.0, 0.0));\\n vec4 touch2 = texture2D(touch, vec2(0.0, 0.01)); \\n\\n\\tfloat fShutterSpeed = 1.0 / 60.0;\\n \\n CameraPosition cameraPos = GetCameraPosition( time, touch1.xy );\\n CameraPosition lastCameraPos = GetCameraPosition( time - fShutterSpeed, touch2.xy );\\n\\n CameraSettings cameraSettings = GetCameraSettings( cameraPos );\\n\\n OutVertex vertex;\\n\\n float fBokehIndex = floor( fVertexIndex / BOKEH_VERTEX_COUNT );\\n \\n LightInfo lightInfo = GetLightInfo( fBokehIndex, time, 0.0, cameraPos );\\n LightInfo prevLightInfo = GetLightInfo( fBokehIndex, time, -fShutterSpeed, lastCameraPos );\\n \\n vec3 vViewPos = GetViewPos( cameraSettings, cameraPos, lightInfo.vWorldPos );\\n vec3 vLastViewPos = GetViewPos( cameraSettings, lastCameraPos, prevLightInfo.vWorldPos );\\n\\n vec2 vScreenPos = GetScreenPos( cameraSettings, vViewPos );\\n vec2 vLastScreenPos = GetScreenPos( cameraSettings, vLastViewPos ); \\n\\n float fScreenSize = GetScreenPos( cameraSettings, vec3( lightInfo.fRadius, lightInfo.fRadius, vViewPos.z ) ).x;\\n \\n vec2 vOrigin = vScreenPos.xy;\\n vec2 vDir = vLastScreenPos.xy - vScreenPos.xy;\\n \\n float fCoC = GetCoC( cameraSettings, vViewPos.z );\\n\\n vec3 vCol = lightInfo.vColor;\\n\\n float fSize = fCoC + fScreenSize;\\n vCol *= fScreenSize * fScreenSize * 3.14 / (length( vDir ) * fSize + fSize * fSize * 3.14);\\n \\n float fBokehVertexIndex = mod( fVertexIndex, BOKEH_VERTEX_COUNT );\\n GetBokehVertex( cameraSettings, fBokehVertexIndex, vOrigin, vDir, fScreenSize, fCoC, vCol, vertex );\\n \\n vertex.vPos.y *= resolution.x / resolution.y;\\n \\n gl_Position = vec4(vertex.vPos.x, vertex.vPos.y, 1.0 / vertexId, 1);\\n float fFinalExposure = cameraSettings.fExposure / (cameraSettings.fAperture * cameraSettings.fAperture);\\n v_color.rgb = 1.0 - exp2( vertex.vColor * -fFinalExposure );\\n v_color.rgb = pow( v_color.rgb, vec3(1.0 / 2.2) );\\n v_color.a = 0.0;\\n \\n float fNearClip = 0.25;\\n if ( vViewPos.z <= fNearClip || vLastViewPos.z <= fNearClip)\\n {\\n gl_Position = vec4(0.0);\\n v_color = vec4(0.0);\\n }\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Garden Fireworks - @P_Malin\n// Playing with motion blurred hexagonal bokeh\n\n#define SHAKY_CAM\n\nfloat Cross( const in vec2 A, const in vec2 B )\n{\n return A.x * B.y - A.y * B.x;\n}\n\nvoid GetTriInfo( const float vertexIndex, out vec2 triVertId, out float triId )\n{\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( triVertexIndex < 0.5 ) \ttriVertId = vec2( 0.0, 0.0 );\n else if\t( triVertexIndex < 1.5 )\ttriVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\ttriVertId = vec2( 0.0, 1.0 );\n\n triId = floor( vertexIndex / 3.0 );\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nmat3 RotMatrixX( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( 1.0, 0.0, 0.0, \n 0.0, c, s,\n 0.0, -s, c ); \n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat Hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nvec3 Hash3(float p)\n{\n vec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\n}\n\nvec3 Hash32(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\n p3 += dot(p3, p3.yxz+19.19);\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\n}\n\n\nvec3 Noise23( vec2 p )\n{\n\tvec2 fl = floor(p);\n\n\tvec3 h00 = Hash32( fl + vec2( 0.0, 0.0 ) );\n\tvec3 h10 = Hash32( fl + vec2( 1.0, 0.0 ) );\n\tvec3 h01 = Hash32( fl + vec2( 0.0, 1.0 ) );\n\tvec3 h11 = Hash32( fl + vec2( 1.0, 1.0 ) );\n\n\tvec2 fr = p - fl;\n\t\n\tvec2 fr2 = fr * fr;\n\tvec2 fr3 = fr2 * fr;\n\t\n\tvec2 t1 = 3.0 * fr2 - 2.0 * fr3;\t\n\tvec2 t0 = 1.0 - t1;\n\t\n\treturn h00 * t0.x * t0.y\n\t\t + h10 * t1.x * t0.y\n\t\t + h01 * t0.x * t1.y\n\t\t + h11 * t1.x * t1.y;\n}\n\nstruct CameraSettings\n{\n float fAperture;\n float fFocalLength;\n float fPlaneInFocus; \n float fExposure;\n};\n\nstruct CameraPosition\n{\n \tvec3 vPosition;\n \tvec3 vTarget;\n \tvec3 vUp;\n \n \tmat3 mRotation;\n};\n \nstruct OutVertex\n{\n \tvec2 vPos;\n \tvec3 vColor;\n}; \n \n#define HEXAGON_OUTLINE_VERTEX_COUNT \t6.0 * (6.0 + 2.0)\n\nvoid GetHexagonOutlineVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r0, const float r1, const vec3 col0, const vec3 col1, inout OutVertex vertex )\n{\n \tfloat fAngleOffset = settings.fAperture * 0.5;\n \n \tif ( fVertexIndex < 6.0 * 6.0 ) \n {\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndex, vQuadVertId, fQuadId );\n\n float fIndex = fQuadId + vQuadVertId.x;\n\n float fAngle = fIndex * radians(360.0) / 6.0;\n\n float fRadius = mix( r0, r1, vQuadVertId.y);\n\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\n\n float fCurrIndex = fQuadId;\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\n\n float fNextIndex = fQuadId + 1.0;\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\n\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\n {\n vPos += vDir;\n }\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n else\n {\n\t float fVertexIndexB = fVertexIndex - 6.0 * 6.0;\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\n \n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\n \n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\n \n if ( fQuadId > 0.0 )\n {\n\t\tfEdgeAngle += radians( 180.0 );\n }\n \n float fRadius = mix( r0, r1, vQuadVertId.y);\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\n vPos += vDir * vQuadVertId.x;\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n}\n \n#define HEXAGON_VERTEX_COUNT (6.0 * 3.0 + 6.0 * 2.0)\nvoid GetHexagonVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r, const vec3 col0, const vec3 col1, inout OutVertex vertex )\n{\n \tfloat fAngleOffset = settings.fAperture * 0.5;\n \n \tif ( fVertexIndex < 6.0 * 3.0 ) \n {\n float fTriId;\n\n vec2 vTriVertId;\n GetTriInfo( fVertexIndex, vTriVertId, fTriId );\n\n float fIndex = fTriId + vTriVertId.x;\n\n float fAngle = fIndex * radians(360.0) / 6.0;\n\n float fRadius = vTriVertId.y * r;\n\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\n\n float fCurrIndex = fTriId;\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\n\n float fNextIndex = fTriId + 1.0;\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\n\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\n {\n vPos += vDir;\n }\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vTriVertId.y );\n }\n else\n {\n\t float fVertexIndexB = fVertexIndex - 6.0 * 3.0;\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\n \n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\n \n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\n \n if ( fQuadId > 0.0 )\n {\n\t\tfEdgeAngle += radians( 180.0 );\n }\n \n float fRadius = vQuadVertId.y * r;\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\n vPos += vDir * vQuadVertId.x;\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n}\n\n\n#define BOKEH_VERTEX_COUNT ( HEXAGON_VERTEX_COUNT + HEXAGON_OUTLINE_VERTEX_COUNT ) \nvoid GetBokehVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float fSize, const float fCoC, const vec3 vCol, out OutVertex vertex )\n{\n \tfloat fInnerSize = fSize + fCoC;\n \tfloat fGlowSize = 0.02;\n \tfloat fOuterSize = fInnerSize + fGlowSize;\n \n \tif ( fVertexIndex < HEXAGON_VERTEX_COUNT )\n {\n \t\tGetHexagonVertex( settings, fVertexIndex, vOrigin, vDir, fInnerSize, vCol, vCol, vertex );\n }\n \telse\n {\n\t \tvec3 vGlowCol = pow(vCol, vec3(0.5)) * 0.0001; \n \tif ( length( vGlowCol ) > 0.0000001 )\n {\n \t\t\tGetHexagonOutlineVertex( settings, fVertexIndex - HEXAGON_VERTEX_COUNT, vOrigin, vDir, fInnerSize, fOuterSize, vGlowCol, vCol * 0.0, vertex );\n }\n else\n {\n \tvertex.vPos.xy = vec2(0.0);\n \tvertex.vColor.rgb = vec3(0.0);\n }\n }\n}\n\nfloat GetCoC( CameraSettings settings, float objectdistance )\n{\n // http://http.developer.nvidia.com/GPUGems/gpugems_ch23.html\n\n\treturn abs(settings.fAperture * (settings.fFocalLength * (objectdistance - settings.fPlaneInFocus)) /\n (objectdistance * (settings.fPlaneInFocus - settings.fFocalLength))); \n}\n\n\nvec3 GetViewPos( CameraSettings settings, CameraPosition cameraPos, vec3 vWorldPos )\n{\n \treturn (vWorldPos - cameraPos.vPosition) * cameraPos.mRotation;\n}\n\nvec2 GetScreenPos( CameraSettings settings, vec3 vViewPos )\n{ \n \treturn vViewPos.xy * settings.fFocalLength * 5.0 / vViewPos.z;\n}\n\nCameraSettings GetCameraSettings( CameraPosition cameraPosition )\n{\n \tCameraSettings settings;\n \n \tfloat aVal = sin(time * 0.25) * 0.5 + 0.5;\n \taVal = aVal * aVal;\n \tsettings.fAperture = aVal * 2.9 + 0.1;\n \tfloat fVal = sin(time * 0.123) * 0.5 + 0.5;\n \tsettings.fFocalLength = 0.2 + 0.2 * fVal;\n \tsettings.fPlaneInFocus = length(cameraPosition.vTarget - cameraPosition.vPosition);\n \n \tfloat oldAVal = sin((time - 0.5) * 0.25) * 0.5 + 0.5;\n \toldAVal = oldAVal * oldAVal;\n \n\tsettings.fExposure = 3.0 + oldAVal *3.0;\n\n \treturn settings;\n}\n\nstruct LightInfo\n{\n\tvec3 vWorldPos;\n \tfloat fRadius;\n \tvec3 vColor;\n};\n \n \nvec2 SolveQuadratic( float a, float b, float c )\n{\n float d = sqrt( b * b - 4.0 * a * c );\n vec2 dV = vec2( d, -d );\n return (-b + dV) / (2.0 * a);\n}\n\n\nvec3 BounceParticle( vec3 vOrigin, vec3 vInitialVel, float fGravity, float fFloorHeight, float fTime )\n{\n \tvec3 u = vInitialVel;\n \tvec3 a = vec3(0.0, fGravity, 0.0);\n \tvec3 vPos = vOrigin;\n\n \tfloat t = fTime;\n \t \t\n \tfor( int iBounce=0; iBounce < 3; iBounce++)\n {\n // When will we hit the ground?\n vec2 q = SolveQuadratic( 0.5 * a.y, u.y, -fFloorHeight + vPos.y);\n float tInt = max( q.x, q.y );\n tInt -= 0.0001;\n \n\n if ( t < tInt )\n {\n\t vPos += u * t + 0.5 * a * t * t;\n break;\n }\n else\n { \n // Calculate velocity at intersect time\n vec3 v = u + a * tInt;\n\n // step to intersect time\n vPos += u * tInt + 0.5 * a * tInt * tInt;\n \t u = v;\n \n // bounce\n u.y = -u.y * 0.3;\n u.xz *= 0.6;\n\n t -= tInt;\n }\n }\n\n \treturn vPos;\n}\n\nfloat fFloorHeight = 0.0;\n\nLightInfo Fountain( const in float fLightIndex, const in vec3 vPos, float fTime, vec3 vCol, float fSpread )\n{\n float fParticleLifetime = 1.5;\n \tLightInfo lightInfo;\n \n \tfloat h = Hash( fLightIndex + 12.0 );\n \tvec3 h3 = Hash3( fLightIndex + 13.0 );\n \n \tfloat fAngle = fLightIndex;\n \n \tvec3 vInitialVel = (normalize(h3 * 2.0 - 1.0) * fSpread + vec3( 0.0, 10.0 - fSpread * 1.3, 0.0 )) * (0.4 + h * 0.4);\n \tvec3 vOrigin = vPos + vec3( 0.0, fFloorHeight + 0.1, 0.0 ) + vInitialVel * 0.1;\n \tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fTime );\n\n \n \tlightInfo.fRadius = 0.01; \n// \tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\n \tlightInfo.vColor = vCol;\n \tlightInfo.vColor *= clamp( 1.0 - fTime + fParticleLifetime - 1.0, 0.0, 1.0);\n\treturn lightInfo; \n}\n\nLightInfo CatherineWheel( const in float fLightIndex, const in vec3 vPos, float fSequenceStart, float fSpawnTime, float fParticleT, vec3 vCol )\n{\n \tfloat h = Hash( fLightIndex + 4.0 );\n\n\t float fParticleLifetime = 0.3 + h *0.5;\n \tLightInfo lightInfo;\n\n \tvec3 h3 = Hash3( fLightIndex + 12.0 );\n \tfloat t = fSpawnTime - fSequenceStart;\n \tif( t < 5.0 ) t = t * t;\n \telse t = t * 5.0 + 5.0 * 5.0;\n \t\n \tfloat fSpawnAngle = t * 5.0;\n \n \tif ( h > 0.5 )\n {\n fSpawnAngle += radians( 180.0 );\n }\n \n \tmat3 m = RotMatrixZ(fSpawnAngle);\n \n \tvec3 vInitialVel = vec3(-3.0, 0.0, 0.0 ) + h3 * 0.5;\n \tvInitialVel = vInitialVel * m;\n \tvec3 vOffset = vec3( 0.0, 0.03, 0.0 * m);\n \tvec3 vOrigin = vPos + vOffset + vInitialVel * 0.1;\n \tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fParticleT );\n\n \n \tlightInfo.fRadius = 0.01; \n// \tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\n \tlightInfo.vColor = vCol;\n \tlightInfo.vColor *= clamp( 1.0 - fParticleT + fParticleLifetime - 1.0, 0.0, 1.0);\n\treturn lightInfo; \n}\n\n\nstruct SequenceInfo\n{\n \tfloat fSequenceSet;\n \tfloat fSequenceSetLength;\n \n \tfloat fSequenceIndex;\n \tfloat fSequenceStartTime;\n \n \tfloat fSequenceSeed;\n \tvec3 vSequenceHash;\n \n \tvec3 vCol;\n \n \tfloat fType;\n \tvec3 vPos;\n \tvec3 vTarget;\n};\n \nSequenceInfo GetSequenceInfo( float fSetIndex, float fTime )\n{\n \tSequenceInfo sequenceInfo;\n\n \t\tfloat fSequenceSetCount = 2.0;\n \tsequenceInfo.fSequenceSet = mod(fSetIndex, fSequenceSetCount);\n\n \t\tfloat sh = Hash( sequenceInfo.fSequenceSet );\n \t\tfloat fSequenceSetLength = 10.0 + sh * 5.0;\n \n\n \t\tsequenceInfo.fSequenceIndex = floor( fTime / fSequenceSetLength );\n \t\tsequenceInfo.fSequenceStartTime = (sequenceInfo.fSequenceIndex * fSequenceSetLength);\n \n \t\tsequenceInfo.fSequenceSeed = sequenceInfo.fSequenceIndex + sequenceInfo.fSequenceSet * 12.3;\n \t\tsequenceInfo.vSequenceHash = Hash3(sequenceInfo.fSequenceSeed);\n\n \t\tfloat ch = Hash( sequenceInfo.fSequenceSeed * 2.34 );\n \t\tsequenceInfo.vCol = vec3(1.0, 0.4, 0.1);\n \n \t\tif( ch < 0.25 )\n {\n sequenceInfo.vCol = vec3(1.0, 0.08, 0.08);\n }\n \t\telse if( ch < 0.5 )\n {\n sequenceInfo.vCol = vec3(0.08, 0.08, 1.0);\n }\n \t\telse if( ch < 0.75 )\n {\n sequenceInfo.vCol = vec3(0.08, 1.0, 0.08 );\n }\n \n \n \tif ( sequenceInfo.vSequenceHash.x < 0.7)\n {\n \t\t\tsequenceInfo.vPos = vec3(0.0);\n\t \t\tsequenceInfo.vPos.xz = sequenceInfo.vSequenceHash.yz * 6.0 - 3.0;\n\t \t\tsequenceInfo.fType = 0.0;\n \tsequenceInfo.vTarget = sequenceInfo.vPos;\n \tsequenceInfo.vTarget.y = 1.5;\n }\n \t\telse\n {\n \tsequenceInfo.vPos = vec3(0.0, 2.5, 7.0);\n\t \t\tsequenceInfo.vPos += (sequenceInfo.vSequenceHash.xyz * 2.0 - 1.0) * vec3(5.0, 1.5, 3.0);\n\t \t\tsequenceInfo.fType = 1.0;\n \tsequenceInfo.vTarget = sequenceInfo.vPos;\n } \n \n \treturn sequenceInfo;\n}\n\nLightInfo GetFireworkSparkInfo( in float fLightIndex, float fTime, float fDeltaTime, vec3 h3 )\n{ \n\t float fParticleLifetime = 1.5;\n \tfloat fParticleSpawnTime = (floor( (fTime / fParticleLifetime) + h3.x) - h3.x) * fParticleLifetime;\n \tfloat fParticleEndTime = fParticleSpawnTime + fParticleLifetime;\n \tfloat fParticleGlobalT = fTime - fParticleSpawnTime;\n \tfloat fParticleT = mod( fParticleGlobalT, fParticleLifetime ) + fDeltaTime;\n \n \t\tSequenceInfo sequenceInfo = GetSequenceInfo( fLightIndex, fParticleSpawnTime );\n \n \tLightInfo lightInfo;\n \n \t\tif ( sequenceInfo.fType < 0.5)\n {\n \tfloat fSpread = fract( sequenceInfo.vSequenceHash.z + sequenceInfo.vSequenceHash.y ) + 1.0;\n\t \t\tlightInfo = Fountain( fLightIndex, sequenceInfo.vPos, fParticleT, sequenceInfo.vCol, fSpread );\n }\n \t\telse\n {\n \tlightInfo = CatherineWheel( fLightIndex, sequenceInfo.vPos, sequenceInfo.fSequenceStartTime, fParticleSpawnTime, fParticleT, sequenceInfo.vCol );\n } \n \n return lightInfo; \n}\n\nLightInfo GetLightInfo( const in float fLightIndex, float fTime, float fDeltaTime, CameraPosition cameraPos )\n{\n \tLightInfo lightInfo;\n\n \t//float h = Hash( fLightIndex );\n \tvec3 h3 = Hash3(fLightIndex);\n\n \tfloat kHangingLightCount = 32.0;\n \tfloat kHangingLightMax = 0.0 + kHangingLightCount;\n \n \tfloat kStarCount = 0.0;\n \tfloat kStarMax = kHangingLightMax + kStarCount;\n \t\n \tfloat kDirtCount = 16.0;\n \tfloat kDirtMax = kStarMax + kDirtCount;\n\n \tfloat kStreetLightCount = 64.0;\n \tfloat kStreetLightMax = kDirtMax + kStreetLightCount;\n \n \tfloat kGardenLightCount = 16.0;\n \tfloat kGardenLightMax = kStreetLightMax + kGardenLightCount;\n\n \tif( fLightIndex < kHangingLightMax )\n \t{\n \t// hanging lights\n \tlightInfo.vWorldPos.x = ((fLightIndex / 10.0) * 2.0 - 1.0) * 3.0;\n \tlightInfo.vWorldPos.y = 2.0 + -abs( cos( fLightIndex * 0.4 ) * 0.8 ); \n \tlightInfo.vWorldPos.z = 20.0;\n \t\tlightInfo.vColor = vec3(0.01) * 0.5;\n \tfloat fColIndex = mod(fLightIndex, 3.0);\n \tif ( fColIndex == 0.0 ) lightInfo.vColor.x = 1.0;\n \tif ( fColIndex == 1.0 ) lightInfo.vColor.y = 1.0;\n \tif ( fColIndex == 2.0 ) lightInfo.vColor.z = 1.0;\n\t lightInfo.vColor *= 0.05;\n \t\t//lightInfo.vColor = normalize(vec3(sin(fLightIndex) * .5 + 0.5, sin(fLightIndex * 3.45) * .5 + 0.5, sin(fLightIndex * 4.56) * .5 + 0.5)) * 0.5;\n \n \t\tlightInfo.fRadius = 0.05;\n\t}\n \telse\n \tif( fLightIndex < kStarMax )\n \t{\n // stars\n \tlightInfo.vWorldPos = normalize( h3 * 2.0 - 1.0 ) * 5000.0;\n \tlightInfo.vWorldPos.y = abs(lightInfo.vWorldPos.y);\n \t\tlightInfo.vColor = vec3(0.01);\n \t\tlightInfo.fRadius = 0.001;\n }\n \telse\n \tif( fLightIndex < kDirtMax )\n \t{\n // lens dirt\n \tlightInfo.vWorldPos.xy = (Hash3(fLightIndex).xy * 2.0 - 1.0);\n \tlightInfo.vWorldPos.xy = normalize(lightInfo.vWorldPos.xy) * pow( length(lightInfo.vWorldPos.xy), 0.3 ) * 0.35;\n\t lightInfo.vWorldPos.y *= resolution.y / resolution.x;\n \tlightInfo.vWorldPos.z = 0.3;\n \tvec3 vOffset = cameraPos.mRotation * lightInfo.vWorldPos;\n \tlightInfo.vWorldPos = vOffset + cameraPos.vPosition;\n \t\tlightInfo.vColor = vec3(0.2, 0.18, 0.1) * abs( dot(normalize(vOffset), vec3(0.0, 0.0, 1.0)) ) * 10.0;\n \t\tlightInfo.fRadius = 0.0001;\n }\n \telse\n // street lights\n \tif( fLightIndex < kStreetLightMax )\n \t{\n \tlightInfo.vWorldPos.xz = (h3.xy * 2.0 - 1.0) * 500.0;\n \tlightInfo.vWorldPos.y = 10.0; \n \t\tlightInfo.vColor = vec3(1.0, 0.3, 0.01) * 0.5;\n \n \t\tlightInfo.fRadius = 0.2;\n\t}\n \telse if( fLightIndex < kGardenLightMax )\n \t{\n \tlightInfo.vWorldPos.y = 0.05 + h3.y * 0.5; \n \tvec2 vOffset = (h3.xz * 2.0 - 1.0);\n \tlightInfo.vWorldPos.xz = vOffset * 50.0 + normalize( vOffset ) * 10.0;\n \t\tlightInfo.vColor = sin(h3 * 10.0 + vec3(0.1, 0.2, 0.3)) * 0.5 + 0.5;\n \tlightInfo.vColor = normalize(lightInfo.vColor);\n\t lightInfo.vColor *= 0.005;\n \n \t\tlightInfo.fRadius = 0.05;\n\t}\n \telse\n {\n \tlightInfo = GetFireworkSparkInfo( fLightIndex, fTime, fDeltaTime, h3 );\n }\n \n\n \treturn lightInfo;\n}\n\n\nvec3 GetCameraTarget( float fTime )\n{\n \t//return vec3(0.0, 1.8, 0.0);\n\n \tfloat fInterval = 8.0;\n \n \tfloat t0 = floor(fTime / fInterval) * fInterval; \n \tfloat t1 = (floor(fTime / fInterval+ 1.0) ) * fInterval; \n \n \tSequenceInfo inf0 = GetSequenceInfo( 0.0, t0 );\n \tSequenceInfo inf1 = GetSequenceInfo( 0.0, t1 );\n \n \tfloat fBlend = (fTime - t0) / fInterval;\n \n \tfBlend = smoothstep( 0.0, 1.0, fBlend);\n \n \treturn mix( inf0.vTarget, inf1.vTarget, fBlend );\n}\n\nCameraPosition GetCameraPosition( float fTime, vec2 vTouch )\n{\n \tCameraPosition cameraPos;\n \n \tif( (vTouch.y > 0.9) && (vTouch.x > -0.83) && (vTouch.x < -0.80) )\n {\t\n \tvTouch.xy = vec2(0.0);\n }\n \n \tcameraPos.vTarget = GetCameraTarget( fTime );\n \n \tcameraPos.vPosition += cameraPos.vTarget;\n \t\n \tcameraPos.vPosition = vec3( sin(fTime * 0.2) * 5.0, 2.0, -6.0 + sin(fTime * 0.0567) * 3.0);\n \tcameraPos.vUp = vec3( 0.0, 1.0, 0.0 );\n \n \tGetMatrixFromZY( normalize(cameraPos.vTarget - cameraPos.vPosition), cameraPos.vUp, cameraPos.mRotation );\n \n \tvec3 vRot = vec3( vTouch.y * 0.5, vTouch.x * 0.5, 0.0 );\n \n#ifdef SHAKY_CAM\n\tvRot += Noise23( cameraPos.vPosition.xz * 4.0 ) * vec3( 0.05, 0.03, 0.01 ); //shaky cam\n#endif\n \n \tcameraPos.mRotation = cameraPos.mRotation * RotMatrixZ(vRot.z) * RotMatrixY(vRot.y) * RotMatrixX( vRot.x ) ; \n \n \treturn cameraPos;\n}\n\nvoid main() \n{\n float fVertexIndex = vertexId;\n\n vec4 touch1 = texture2D(touch, vec2(0.0, 0.0));\n vec4 touch2 = texture2D(touch, vec2(0.0, 0.01)); \n\n\tfloat fShutterSpeed = 1.0 / 60.0;\n \n CameraPosition cameraPos = GetCameraPosition( time, touch1.xy );\n CameraPosition lastCameraPos = GetCameraPosition( time - fShutterSpeed, touch2.xy );\n\n CameraSettings cameraSettings = GetCameraSettings( cameraPos );\n\n OutVertex vertex;\n\n float fBokehIndex = floor( fVertexIndex / BOKEH_VERTEX_COUNT );\n \n LightInfo lightInfo = GetLightInfo( fBokehIndex, time, 0.0, cameraPos );\n LightInfo prevLightInfo = GetLightInfo( fBokehIndex, time, -fShutterSpeed, lastCameraPos );\n \n vec3 vViewPos = GetViewPos( cameraSettings, cameraPos, lightInfo.vWorldPos );\n vec3 vLastViewPos = GetViewPos( cameraSettings, lastCameraPos, prevLightInfo.vWorldPos );\n\n vec2 vScreenPos = GetScreenPos( cameraSettings, vViewPos );\n vec2 vLastScreenPos = GetScreenPos( cameraSettings, vLastViewPos ); \n\n float fScreenSize = GetScreenPos( cameraSettings, vec3( lightInfo.fRadius, lightInfo.fRadius, vViewPos.z ) ).x;\n \n vec2 vOrigin = vScreenPos.xy;\n vec2 vDir = vLastScreenPos.xy - vScreenPos.xy;\n \n float fCoC = GetCoC( cameraSettings, vViewPos.z );\n\n vec3 vCol = lightInfo.vColor;\n\n float fSize = fCoC + fScreenSize;\n vCol *= fScreenSize * fScreenSize * 3.14 / (length( vDir ) * fSize + fSize * fSize * 3.14);\n \n float fBokehVertexIndex = mod( fVertexIndex, BOKEH_VERTEX_COUNT );\n GetBokehVertex( cameraSettings, fBokehVertexIndex, vOrigin, vDir, fScreenSize, fCoC, vCol, vertex );\n \n vertex.vPos.y *= resolution.x / resolution.y;\n \n gl_Position = vec4(vertex.vPos.x, vertex.vPos.y, 1.0 / vertexId, 1);\n float fFinalExposure = cameraSettings.fExposure / (cameraSettings.fAperture * cameraSettings.fAperture);\n v_color.rgb = 1.0 - exp2( vertex.vColor * -fFinalExposure );\n v_color.rgb = pow( v_color.rgb, vec3(1.0 / 2.2) );\n v_color.a = 0.0;\n \n float fNearClip = 0.25;\n if ( vViewPos.z <= fNearClip || vLastViewPos.z <= fNearClip)\n {\n gl_Position = vec4(0.0);\n v_color = vec4(0.0);\n }\n \n}" + }, "screenshotURL": "data/images/images-e5i54ral7oq73t97q-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TiyZJh7nekQSquxTK/art.json b/art/TiyZJh7nekQSquxTK/art.json index 065a24cd..2e26c33c 100644 --- a/art/TiyZJh7nekQSquxTK/art.json +++ b/art/TiyZJh7nekQSquxTK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":34919,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 3.0\\nfloat SCALE = 2.0 * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 77.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 555.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.833;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 444., 44468., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 34919, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 3.0\nfloat SCALE = 2.0 * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 77.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 555.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.833;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 444., 44468., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-ss07xal3icapvzy1u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Tj6QZbDv6jioYkJtb/art.json b/art/Tj6QZbDv6jioYkJtb/art.json index c2f779fa..211a5cce 100644 --- a/art/Tj6QZbDv6jioYkJtb/art.json +++ b/art/Tj6QZbDv6jioYkJtb/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nfloat lerp(float min, float max, float norm) {\\n return (max - min) * norm + min;\\n}\\n\\nvoid main() {\\n float normal = (vertexId + 1.0) / vertexCount;\\n float xExp = abs(mouse.x);\\n float yExp = abs(mouse.y) * 2.0; \\n \\n float x = lerp(-1.0, 1.0, pow(normal, xExp)) - 0.5;\\n float y = lerp(-1.0, 1.0, pow(normal, yExp));\\n \\n gl_Position = vec4(x * 0.5, y * 0.5, 0.0, 1.0);\\n gl_PointSize = normal * 10.0 + 4.0;\\n v_color = vec4(normal * normal * normal, 1.0, 1.0 - normal, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nfloat lerp(float min, float max, float norm) {\n return (max - min) * norm + min;\n}\n\nvoid main() {\n float normal = (vertexId + 1.0) / vertexCount;\n float xExp = abs(mouse.x);\n float yExp = abs(mouse.y) * 2.0; \n \n float x = lerp(-1.0, 1.0, pow(normal, xExp)) - 0.5;\n float y = lerp(-1.0, 1.0, pow(normal, yExp));\n \n gl_Position = vec4(x * 0.5, y * 0.5, 0.0, 1.0);\n gl_PointSize = normal * 10.0 + 4.0;\n v_color = vec4(normal * normal * normal, 1.0, 1.0 - normal, 1);\n}" + }, "screenshotURL": "data/images/images-bt1tvz9tj6tychd34-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TjYfbRFifgzMfDFfg/art.json b/art/TjYfbRFifgzMfDFfg/art.json index 0494d820..6481aaf9 100644 --- a/art/TjYfbRFifgzMfDFfg/art.json +++ b/art/TjYfbRFifgzMfDFfg/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":9,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//\\n#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n vec4 vertPos = rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 9, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//\n#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n vec4 vertPos = rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-sgree9tktys6mcf21-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TjsWhmhbezg59ibvb/art.json b/art/TjsWhmhbezg59ibvb/art.json index 8acd6204..ddcc9f9c 100644 --- a/art/TjsWhmhbezg59ibvb/art.json +++ b/art/TjsWhmhbezg59ibvb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n \n}" + }, "screenshotURL": "data/images/images-dnlsnmugcpnazhqki-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TkKCcbsYG7ubBaXDq/art.json b/art/TkKCcbsYG7ubBaXDq/art.json index a2aa4519..94458a6a 100644 --- a/art/TkKCcbsYG7ubBaXDq/art.json +++ b/art/TkKCcbsYG7ubBaXDq/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "yejin-shin", "avatarUrl": "https://avatars.githubusercontent.com/yejin-shin?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name : Yejin Shin\\n//Assignment : Making a Grid\\n//Course : CS250\\n//Spring, 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n\\tfloat across = floor(vertexCount/down);\\n\\n \\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId / across);\\n\\n\\tfloat u = x / (across - 1.);\\n\\tfloat v = y / (across - 1.);\\n\\n\\tfloat ux = u * 5. - 1.;\\n\\tfloat vy = v * 5. - 1.;\\n\\t\\n\\tgl_Position = vec4(ux, vy, 0, 1);\\n\\t\\n\\tgl_PointSize = 10.0;\\n\\tgl_PointSize *= 20. / across;\\n\\tgl_PointSize *= resolution.x /200.;\\t\\n\\t\\n\\n \\tv_color = vec4(0.3, 0.8, 0.8, 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name : Yejin Shin\n//Assignment : Making a Grid\n//Course : CS250\n//Spring, 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n\tfloat across = floor(vertexCount/down);\n\n \tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId / across);\n\n\tfloat u = x / (across - 1.);\n\tfloat v = y / (across - 1.);\n\n\tfloat ux = u * 5. - 1.;\n\tfloat vy = v * 5. - 1.;\n\t\n\tgl_Position = vec4(ux, vy, 0, 1);\n\t\n\tgl_PointSize = 10.0;\n\tgl_PointSize *= 20. / across;\n\tgl_PointSize *= resolution.x /200.;\t\n\t\n\n \tv_color = vec4(0.3, 0.8, 0.8, 1);\n\n}" + }, "screenshotURL": "data/images/images-rnd67cs6p1anqpkzb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TkQY6zwRTeGzEqbCb/art.json b/art/TkQY6zwRTeGzEqbCb/art.json index 75c2ff7d..63890bca 100644 --- a/art/TkQY6zwRTeGzEqbCb/art.json +++ b/art/TkQY6zwRTeGzEqbCb/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "clydepashley", "avatarUrl": "https://avatars.githubusercontent.com/clydepashley?s=200", - "settings": "{\"num\":22,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/wondem/01-veggie-wondem-ras-g-sd-master01wav\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt (vertexCount));\\n float across = floor (vertexCount / down);\\n \\n //Create Grid\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n //Respace out\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n x = u;\\n y = v;\\n \\n //Move back around origin\\n x = x * 2. - 1.;\\n y = y * 2. - 1.;\\n \\n\\n float snd = texture2D(sound, vec2(u, 0.)).a;\\n float sin_thing = sin(vertexId + snd); \\n //Sin\\n \\n x = tan(x+(snd/10.)/y);\\n y = sin(x/y);\\n \\n\\n \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = sin_thing * 10.;\\n //v_color = vec4(snd * 4., sin_thing * 20.,mod(snd,1.),1);\\n v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\\n //v_color = vec4(snd * snd, sin_thing * 20.,mod(snd,1.),1);\\n}\"}", + "settings": { + "num": 22, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/wondem/01-veggie-wondem-ras-g-sd-master01wav", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt (vertexCount));\n float across = floor (vertexCount / down);\n \n //Create Grid\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n //Respace out\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n x = u;\n y = v;\n \n //Move back around origin\n x = x * 2. - 1.;\n y = y * 2. - 1.;\n \n\n float snd = texture2D(sound, vec2(u, 0.)).a;\n float sin_thing = sin(vertexId + snd); \n //Sin\n \n x = tan(x+(snd/10.)/y);\n y = sin(x/y);\n \n\n \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = sin_thing * 10.;\n //v_color = vec4(snd * 4., sin_thing * 20.,mod(snd,1.),1);\n v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\n //v_color = vec4(snd * snd, sin_thing * 20.,mod(snd,1.),1);\n}" + }, "screenshotURL": "data/images/images-l69t7w9hln6zevamk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TmsGWvgfvS9T75Fii/art.json b/art/TmsGWvgfvS9T75Fii/art.json index 6a778ca6..02206723 100644 --- a/art/TmsGWvgfvS9T75Fii/art.json +++ b/art/TmsGWvgfvS9T75Fii/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":13226,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n float z = 1. + vertexId/vertexCount * (sin(time)+1.);\\n gl_Position = vec4(xy * aspect + mouse * 0.8 * vertexId/vertexCount, 1./z, z);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 13226, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n float z = 1. + vertexId/vertexCount * (sin(time)+1.);\n gl_Position = vec4(xy * aspect + mouse * 0.8 * vertexId/vertexCount, 1./z, z);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-tqzq1mp4blmp9psr4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Tn26s3ARMWt6vkHkk/art.json b/art/Tn26s3ARMWt6vkHkk/art.json index 19f37c0e..d1aa0b31 100644 --- a/art/Tn26s3ARMWt6vkHkk/art.json +++ b/art/Tn26s3ARMWt6vkHkk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/thomas-vx/concrete-jungle\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 🦍 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n float odd = mod(circleId, 2.);\\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float sv = abs(gx / gAcross - 0.5) * 2.; \\n float snd = texture2D(sound, vec2(\\n mix(0.305, 0.01, gy / gDown), \\n sv * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = sv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = scale(vec3(1, resolution.x / resolution.y, 1) * .2);\\n mat *= trans(vec3(offset) * snd * .8);\\n mat *= uniformScale(mix(0.05, 0.5, pow(snd, 5.)));\\n mat *= rotZ(PI * .17 + odd * PI + snd * sign(offset.x));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 0.6 + fract(snd * 9.) * .1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.a = 1. - sv;\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/thomas-vx/concrete-jungle", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 🦍 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n float odd = mod(circleId, 2.);\n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float sv = abs(gx / gAcross - 0.5) * 2.; \n float snd = texture2D(sound, vec2(\n mix(0.305, 0.01, gy / gDown), \n sv * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = sv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = scale(vec3(1, resolution.x / resolution.y, 1) * .2);\n mat *= trans(vec3(offset) * snd * .8);\n mat *= uniformScale(mix(0.05, 0.5, pow(snd, 5.)));\n mat *= rotZ(PI * .17 + odd * PI + snd * sign(offset.x));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 0.6 + fract(snd * 9.) * .1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.a = 1. - sv;\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-hcj5z3k9mr1m4eyt3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TnA8pckZzDwoPmYvM/art.json b/art/TnA8pckZzDwoPmYvM/art.json index aa7b9e0d..b27f891d 100644 --- a/art/TnA8pckZzDwoPmYvM/art.json +++ b/art/TnA8pckZzDwoPmYvM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alejandrocamara", "avatarUrl": "https://avatars.githubusercontent.com/AlejandroCamara?s=200", - "settings": "{\"num\":8280,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n \\n //float phi = mod((vertexId / 180.0), 180.0);\\n //float theta = mod(vertexId, 360.0);\\n \\n\\n //float phi = floor(vertexId/ 180.0);\\n //float theta = floor(vertexId/ 360.0);\\n \\n \\n \\n //float phi = (floor(vertexId / 180.0));\\n //float theta = (mod(vertexId, 360.0)) ;\\n \\n float phi = radians(floor(vertexId / 180.0)) * 4.0;\\n float theta = radians(mod(vertexId, 360.0)) * 4.0;\\n float p = 1.0;\\n \\n mat4 rotX = mat4(\\n 1, \\t0,\\t\\t \\t0,\\t\\t\\t0,\\n \\t0, \\tcos(time ), -sin(time),\\t0,\\n 0, \\tsin(time ), cos(time ),\\t0,\\n 0,\\t0,\\t\\t\\t0,\\t\\t\\t1\\n );\\n \\n mat4 rotY = mat4(\\n \\tcos(time ), \\t0,\\tsin(time),\\t0,\\n \\t0,\\t\\t\\t\\t1,\\t0,\\t\\t\\t0,\\n -sin(time), \\t0, \\tcos(time ),\\t0,\\n 0,\\t\\t\\t\\t0,\\t0,\\t\\t\\t1\\n );\\n \\n mat4 rotZ = mat4(\\n \\tcos(time), \\t-sin(time ),\\t0,\\t0,\\n \\tsin(time),\\tcos(time ),\\t\\t0,\\t0,\\n 0, \\t\\t\\t0, \\t\\t\\t\\t1,\\t0,\\n 0,\\t\\t\\t0,\\t\\t\\t\\t0,\\t1\\n );\\n \\n float x = p * sin(phi) * cos(theta);\\n float y = p * sin(phi) * sin(theta);\\n float z = p * cos(phi);\\n \\n vec4 pos = vec4(x,y,z, 1.0);\\n //gl_Position = vec4(pos) / 0.1;\\n gl_Position = vec4(rotX * rotZ * pos) / 0.1;\\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\\n gl_PointSize = 3.0;\\n \\n}\"}", + "settings": { + "num": 8280, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n \n //float phi = mod((vertexId / 180.0), 180.0);\n //float theta = mod(vertexId, 360.0);\n \n\n //float phi = floor(vertexId/ 180.0);\n //float theta = floor(vertexId/ 360.0);\n \n \n \n //float phi = (floor(vertexId / 180.0));\n //float theta = (mod(vertexId, 360.0)) ;\n \n float phi = radians(floor(vertexId / 180.0)) * 4.0;\n float theta = radians(mod(vertexId, 360.0)) * 4.0;\n float p = 1.0;\n \n mat4 rotX = mat4(\n 1, \t0,\t\t \t0,\t\t\t0,\n \t0, \tcos(time ), -sin(time),\t0,\n 0, \tsin(time ), cos(time ),\t0,\n 0,\t0,\t\t\t0,\t\t\t1\n );\n \n mat4 rotY = mat4(\n \tcos(time ), \t0,\tsin(time),\t0,\n \t0,\t\t\t\t1,\t0,\t\t\t0,\n -sin(time), \t0, \tcos(time ),\t0,\n 0,\t\t\t\t0,\t0,\t\t\t1\n );\n \n mat4 rotZ = mat4(\n \tcos(time), \t-sin(time ),\t0,\t0,\n \tsin(time),\tcos(time ),\t\t0,\t0,\n 0, \t\t\t0, \t\t\t\t1,\t0,\n 0,\t\t\t0,\t\t\t\t0,\t1\n );\n \n float x = p * sin(phi) * cos(theta);\n float y = p * sin(phi) * sin(theta);\n float z = p * cos(phi);\n \n vec4 pos = vec4(x,y,z, 1.0);\n //gl_Position = vec4(pos) / 0.1;\n gl_Position = vec4(rotX * rotZ * pos) / 0.1;\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\n gl_PointSize = 3.0;\n \n}" + }, "screenshotURL": "data/images/images-hp32xqbsjdtwnwxxp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TnXzsnYqaPym78gQ8/art.json b/art/TnXzsnYqaPym78gQ8/art.json index d15af2ee..345d2edd 100644 --- a/art/TnXzsnYqaPym78gQ8/art.json +++ b/art/TnXzsnYqaPym78gQ8/art.json @@ -11,7 +11,19 @@ "origId": "h6BvsMWiHpgwT5Nhh", "name": "julia", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos, float w, float h)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n float newRe = 1.5 * (pos.x - w / 2.0) / (0.5 * w);\\n float newIm = (pos.y - h / 2.0) / (0.5 * h);\\n float oldRe;\\n float oldIm;\\n float j = 0.0;\\n for(int i = 0; i < 128; i++)\\n {\\n j+=1.0;\\n oldRe = newRe;\\n oldIm = newIm;\\n newRe = oldRe * oldRe - oldIm * oldIm + 0.4;\\n newIm = 2.0 * oldRe * oldIm + sin(time/1.0);\\n if((newRe * newRe + newIm * newIm) > 4.0) break;\\n }\\n return j/64.0;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px+0.5, py+0.5)*100.0,w/2.0,h/2.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos, float w, float h)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n float newRe = 1.5 * (pos.x - w / 2.0) / (0.5 * w);\n float newIm = (pos.y - h / 2.0) / (0.5 * h);\n float oldRe;\n float oldIm;\n float j = 0.0;\n for(int i = 0; i < 128; i++)\n {\n j+=1.0;\n oldRe = newRe;\n oldIm = newIm;\n newRe = oldRe * oldRe - oldIm * oldIm + 0.4;\n newIm = 2.0 * oldRe * oldIm + sin(time/1.0);\n if((newRe * newRe + newIm * newIm) > 4.0) break;\n }\n return j/64.0;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px+0.5, py+0.5)*100.0,w/2.0,h/2.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-jyz5mtdesuiwpq0yb-thumbnail.jpg", "views": { "$numberInt": "469" diff --git a/art/ToJKAtGKcN3vg5MJY/art.json b/art/ToJKAtGKcN3vg5MJY/art.json index e56c8bc8..004d3383 100644 --- a/art/ToJKAtGKcN3vg5MJY/art.json +++ b/art/ToJKAtGKcN3vg5MJY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":43028,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/katabatik/dj-atlea-musick-of-barrett-clark-vol-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 2.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 37.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.*mouse.y;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 1.))));\\n \\n vCubeCol.xyz = vec3(1.-mouse.x,mouse.r,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.1;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0.0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\nfloat sndx = texture2D(sound, vec2(hash(11.-fCubeId) * mouse.y*8.125, 10.*mouse)).a;\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * mouse.y*1.125, 0)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId*snd*22., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos-snd, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,0,0,1); \\n // hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, .07770),1,-1,-1.+snd*sin(time*3.)), color*4.*sndx, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 43028, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/katabatik/dj-atlea-musick-of-barrett-clark-vol-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 2.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 37.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.*mouse.y;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 1.))));\n \n vCubeCol.xyz = vec3(1.-mouse.x,mouse.r,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.1;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0.0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\nfloat sndx = texture2D(sound, vec2(hash(11.-fCubeId) * mouse.y*8.125, 10.*mouse)).a;\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * mouse.y*1.125, 0)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId*snd*22., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos-snd, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,0,0,1); \n // hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, .07770),1,-1,-1.+snd*sin(time*3.)), color*4.*sndx, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-4ucsh9d2402ttbrbf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Toiefpwj7bhJqsYxd/art.json b/art/Toiefpwj7bhJqsYxd/art.json index 129bc831..22bcc545 100644 --- a/art/Toiefpwj7bhJqsYxd/art.json +++ b/art/Toiefpwj7bhJqsYxd/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "unnamed", "username": "-anon-", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 8.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 8.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ytsdswuq7vvj56y6s-thumbnail.jpg", "views": { "$numberInt": "192" diff --git a/art/TrexNrcNFyQ7FrJjb/art.json b/art/TrexNrcNFyQ7FrJjb/art.json index 5b0b778d..ef07a2f3 100644 --- a/art/TrexNrcNFyQ7FrJjb/art.json +++ b/art/TrexNrcNFyQ7FrJjb/art.json @@ -27,7 +27,19 @@ "name": "shapeshift", "private": false, "username": "gman", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.996078431372549,0.9921568627450981,1,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float t = time * 0.2;\\n float NUM_SEGMENTS = 3. + mod(floor(t), 20.);\\n float NUM_POINTS = NUM_SEGMENTS * 2.0;\\n float STEP = 3.0 + mod(floor(t * 4.), NUM_SEGMENTS);\\n float PI = 3.14159 + mod(floor(t * 8.), 30.0);\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00024, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.9, 0.8);\\n float innerRadius = pow(count * 0.0025, 1.10);\\n float oC = cos(orbitAngle + count * 0.01) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y); \\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n \\n float hue = floor(time) / 0.23;\\n float sat = 1.;\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "CSS", + "backgroundColor": [ + 0.996078431372549, + 0.9921568627450981, + 1, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float t = time * 0.2;\n float NUM_SEGMENTS = 3. + mod(floor(t), 20.);\n float NUM_POINTS = NUM_SEGMENTS * 2.0;\n float STEP = 3.0 + mod(floor(t * 4.), NUM_SEGMENTS);\n float PI = 3.14159 + mod(floor(t * 8.), 30.0);\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00024, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.9, 0.8);\n float innerRadius = pow(count * 0.0025, 1.10);\n float oC = cos(orbitAngle + count * 0.01) * innerRadius;\n float oS = sin(orbitAngle + count * 0.01) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y); \n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n \n float hue = floor(time) / 0.23;\n float sat = 1.;\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-q8ud09emoqpfjkx2f-thumbnail.jpg", "views": { "$numberInt": "229" diff --git a/art/TrfCHd7Prkiad7Fox/art.json b/art/TrfCHd7Prkiad7Fox/art.json index 513a3e58..3824b341 100644 --- a/art/TrfCHd7Prkiad7Fox/art.json +++ b/art/TrfCHd7Prkiad7Fox/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9542,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_FAN\\n#define parameter0 5.//KParameter0 -8.>>15.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 4.//KParameter3 -4.5>>4.\\n#define parameter4 0.2//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n\\n\\n#define PI 3.14159\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n sin(i*14.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76)* i,\\n sin(i*.79553+2.1) +\\n sin(i*1.1311+2.1) +\\n sin(i*1.353-2.1) +\\n sin(i*.476/2.1) * cos(i * 3.0),\\n mod(i*4.5553, i *0.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*9.36*10.1)\\n\\t)* parameter3;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n tan(i*.553)*.9553 +\\n cos(i) +\\n cos(i*1.53)/1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*4.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*11.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n tan(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*3.2;\\n}\\n\\nvec3 hilbert(float s) {\\n\\t\\t vec3 p;\\n\\t\\t {\\n\\t\\t\\t float zi = mod(s, parameter0 *2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,3.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\t\\t p = vec3(xi,yi,zi);\\n\\t\\t }\\n\\tfloat n = 2. - parameter5;\\n\\t\\t for (int i = 1; i < 7; i++) {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,2.2 *parameter2);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\n\\t \\n\\tif (xi > .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z/parameter4;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < .5) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0)-parameter5);\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*510.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = sin(t- .5);\\n \\n vec3 colour = vec3( 0.0);\\n//vec3 colour = vec3(parameter6* .003)\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*0.2+parameter7, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n\\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/180.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,-22.);\\n}\"}", + "settings": { + "num": 9542, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_FAN\n#define parameter0 5.//KParameter0 -8.>>15.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 4.//KParameter3 -4.5>>4.\n#define parameter4 0.2//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*14.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76)* i,\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476/2.1) * cos(i * 3.0),\n mod(i*4.5553, i *0.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*9.36*10.1)\n\t)* parameter3;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n tan(i*.553)*.9553 +\n cos(i) +\n cos(i*1.53)/1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*4.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*11.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n tan(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*3.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s, parameter0 *2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,3.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2. - parameter5;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.2 *parameter2);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z/parameter4;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < .5) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0)-parameter5);\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*510.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = sin(t- .5);\n \n vec3 colour = vec3( 0.0);\n//vec3 colour = vec3(parameter6* .003)\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*0.2+parameter7, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n\n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/180.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,-22.);\n}" + }, "screenshotURL": "data/images/images-7dl5oi7clcjogmhoh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TsDPjH9MzsLF4uHdo/art.json b/art/TsDPjH9MzsLF4uHdo/art.json index 794a6b0f..febe2ba1 100644 --- a/art/TsDPjH9MzsLF4uHdo/art.json +++ b/art/TsDPjH9MzsLF4uHdo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":96073,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/itsbrillz/sets/world-wide-weirdos-vol-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#29475.0\\n\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\nvec2 project(vec2 position, vec2 a, vec2 b); \\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 4.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n\\tfor(int i = 0; i < 48; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\tb += box(p, vec2(.5));\\n\\t\\tt += triangle(p, vec2(.5));\\n\\t\\tp *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\t\\n\\t//gl_FragColor = result;\\n \\n gl_Position = vec4(ux, vy*snd, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = result;\\n \\n\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.505080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t-= .602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(c-t);\\n\\treturn mat2(c,1.-c*s, .18-s, c);\\n}\\n\"}", + "settings": { + "num": 96073, + "mode": "POINTS", + "sound": "https://soundcloud.com/itsbrillz/sets/world-wide-weirdos-vol-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#29475.0\n\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\nvec2 project(vec2 position, vec2 a, vec2 b); \nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 4.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n\tfor(int i = 0; i < 48; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\tb += box(p, vec2(.5));\n\t\tt += triangle(p, vec2(.5));\n\t\tp *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\t\n\t//gl_FragColor = result;\n \n gl_Position = vec4(ux, vy*snd, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = result;\n \n\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.505080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t-= .602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(c-t);\n\treturn mat2(c,1.-c*s, .18-s, c);\n}\n" + }, "screenshotURL": "data/images/images-fzg9eyxsgmr1yisnf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TtKHBfMCFHuz5PKm7/art.json b/art/TtKHBfMCFHuz5PKm7/art.json index df4754e0..6b321a17 100644 --- a/art/TtKHBfMCFHuz5PKm7/art.json +++ b/art/TtKHBfMCFHuz5PKm7/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.1450980392156863,0.30980392156862746,1],\"shader\":\"#define ITERS 30\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n //float snd = texture2D(sound, vec2(0.1, 0.)).a;\\n //float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n vec2 p = vec2(ux , vy);\\n float z = fract(0.02*time);\\n\\n int acc = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float a = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n acc += (z > p.y && z <= p.y + 1. / resolution.y) ? 1 : 0;\\n z = a * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(acc) / iters;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 4.;\\n\\n v_color = vec4(g /8., g, g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.1450980392156863, + 0.30980392156862746, + 1 + ], + "shader": "#define ITERS 30\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n //float snd = texture2D(sound, vec2(0.1, 0.)).a;\n //float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n vec2 p = vec2(ux , vy);\n float z = fract(0.02*time);\n\n int acc = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float a = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n acc += (z > p.y && z <= p.y + 1. / resolution.y) ? 1 : 0;\n z = a * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(acc) / iters;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 4.;\n\n v_color = vec4(g /8., g, g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-uteeu8t96stuzj9zu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/TtKakFtTdMbTCbaQj/art.json b/art/TtKakFtTdMbTCbaQj/art.json index ca72b816..2be54ae1 100644 --- a/art/TtKakFtTdMbTCbaQj/art.json +++ b/art/TtKakFtTdMbTCbaQj/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mattsonic", "avatarUrl": "https://secure.gravatar.com/avatar/4b4ea9969843f3808dccbabf78ea4289?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1568627450980392,0.15294117647058825,0.2627450980392157,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1568627450980392, + 0.15294117647058825, + 0.2627450980392157, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-i9vztkv3xyxhb9hl0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Tv6txjYWJaTTTbyRp/art.json b/art/Tv6txjYWJaTTTbyRp/art.json index cfd09fc9..43093e1d 100644 --- a/art/Tv6txjYWJaTTTbyRp/art.json +++ b/art/Tv6txjYWJaTTTbyRp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":12378,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/a-boogie-wit-da-hoodie/drowning-feat-kodak-black-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*a ) + exp( -k*b );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.00570;\\n \\tfloat transitionStrength = 1.5;\\n \\tvec3 colKernel0 = vec3(1,0,1);\\n \\tvec3 colKernel1 = vec3(0,0 ,0);\\n \\tvec3 colTransition = vec3(1,1,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - 1.));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*0.5;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).x*0.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 0.5 - mouse.x * 0.5;\\n\\tfloat ce = -1.5+mouse.y * 3.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(76.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = 1.0 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv, -1,\\n\\t\\t0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 12378, + "mode": "LINES", + "sound": "https://soundcloud.com/a-boogie-wit-da-hoodie/drowning-feat-kodak-black-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*a ) + exp( -k*b );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.00570;\n \tfloat transitionStrength = 1.5;\n \tvec3 colKernel0 = vec3(1,0,1);\n \tvec3 colKernel1 = vec3(0,0 ,0);\n \tvec3 colTransition = vec3(1,1,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - 1.));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*0.5;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).x*0.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 0.5 - mouse.x * 0.5;\n\tfloat ce = -1.5+mouse.y * 3.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(76.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = 1.0 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv, -1,\n\t\t0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-f65q6jvwpn6bcvn5f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Tw8ymmpoiv7MwrjWv/art.json b/art/Tw8ymmpoiv7MwrjWv/art.json index 9df720f2..ed082719 100644 --- a/art/Tw8ymmpoiv7MwrjWv/art.json +++ b/art/Tw8ymmpoiv7MwrjWv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":1868,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Colors\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1868, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Colors\ncourse name : CS250\nterm : 2022 Spring\n*/\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-cvyesdo586g77jo0v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/TyWsHgdd6xGj8uYSg/art.json b/art/TyWsHgdd6xGj8uYSg/art.json index f1e144ed..c4ef3bf4 100644 --- a/art/TyWsHgdd6xGj8uYSg/art.json +++ b/art/TyWsHgdd6xGj8uYSg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 1.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n float elemSize = 0.09;\\n \\n float numberOfElement = 9.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n \\n //float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*1.,1.);\\n lineId/=numberOfElement;\\n\\n cubep*= min(lineId/20., elemSize);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+7.*sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+= xPos;\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.+PI/2.);\\n \\n cubep.z+=lineId*(elemSize+elemSize/2.)*20.;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 5., 10.2);//29./2.*abs(cos(time/5.))\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 5.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 1.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n float elemSize = 0.09;\n \n float numberOfElement = 9.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n \n //float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*1.,1.);\n lineId/=numberOfElement;\n\n cubep*= min(lineId/20., elemSize);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+7.*sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+= xPos;\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.+PI/2.);\n \n cubep.z+=lineId*(elemSize+elemSize/2.)*20.;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 5., 10.2);//29./2.*abs(cos(time/5.))\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 5.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-wrw32quxiiitu0ae5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/W5AaXFFJk2ZggnWEk/art.json b/art/W5AaXFFJk2ZggnWEk/art.json index a6ec74be..746fcf90 100644 --- a/art/W5AaXFFJk2ZggnWEk/art.json +++ b/art/W5AaXFFJk2ZggnWEk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nightclubband/freak-like-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float u = vertexId / (vertexCount - 1.);\\n float x = u * 2. - 1.;\\n float s = texture2D(sound, vec2(u, 0.)).a;\\n float y = s * 2. - 1.;\\n \\n gl_Position = vec4(x, y, 0, 1);\\n\\n float hue = u;\\n float sat = 1.0;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nightclubband/freak-like-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float u = vertexId / (vertexCount - 1.);\n float x = u * 2. - 1.;\n float s = texture2D(sound, vec2(u, 0.)).a;\n float y = s * 2. - 1.;\n \n gl_Position = vec4(x, y, 0, 1);\n\n float hue = u;\n float sat = 1.0;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-gqn7s6jwfzts85hzz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/W5pb4uwKJ9dzEF9oz/art.json b/art/W5pb4uwKJ9dzEF9oz/art.json index 00cd3e7a..16455c5c 100644 --- a/art/W5pb4uwKJ9dzEF9oz/art.json +++ b/art/W5pb4uwKJ9dzEF9oz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "8bitrick", "avatarUrl": "https://avatars.githubusercontent.com/8BitRick?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.1416\\n#define TWOPI 6.28\\nfloat face_radius = 0.5;\\nfloat face_height = face_radius * 2.;\\nfloat face_ratio = 1.15 * face_height;\\nfloat eye_pos = 0.56 * face_height;\\n//float eye_radius = 0.05 * face_height;\\n//float eye_ratio = 5.66 * face_height;\\nfloat eye_width = 0.26 * face_height;\\nfloat eye_height = 0.2 * face_height;\\nfloat eye_ratio = eye_width / eye_height;\\nfloat eye_sep = 0.54 * face_height; // -1 to 1 so sep is 2 * face width percentage\\n\\nfloat nose_pos = 0.77 * face_height;\\nfloat nose_radius = 0.012 * face_height;\\n\\nfloat mouth_pos = 0.85 * face_height;\\nfloat mouth_width = 0.31 * face_height;\\nfloat mouth_radius = mouth_width * 0.5;\\n\\nconst float face_verts_percent = 0.4;\\nconst float eye_verts_percent = 0.45;\\nconst float nose_verts_percent = 0.05;\\nconst float mouth_verts_percent = 0.10;\\n\\nmat4 mvp = mat4(1.0);\\nmat4 face_mat = mat4(1.0);\\n\\nfloat m1p1(float v) { return v * 2. - 1.; }\\n\\nmat4 build_mvp() {\\n mvp[0][0] = resolution.y/resolution.x;\\n mvp[1][1] = 1.0;\\n return mvp;\\n}\\nmat4 build_face_mat() {\\n face_mat[0][0] = face_radius;\\n face_mat[1][1] = face_radius;\\n return face_mat;\\n}\\n\\nvoid draw_head(float vert_per, mat4 curMat)\\n{\\n float angle = vert_per * TWOPI;\\n\\n float x = cos(angle) * face_ratio;\\n float y = sin(angle) * 1.;\\n gl_Position = curMat * vec4(x,y,0.0,1.0);\\n v_color = vec4(1.0);\\n}\\n\\nvoid draw_eyes(float vert_per, mat4 curMat) {\\n // TODO: should be able to replace these eye conditions \\n // with a multiplier for left eye / right eye\\n bool left_eye = (vert_per < 0.5);\\n float eye_per = vert_per / 0.5;\\n if(left_eye)\\n eye_per -= 0.5;\\n \\n mat4 eye_mat = mat4(1.0);\\n eye_mat[0][0] = eye_height;\\n eye_mat[1][1] = eye_height;\\n eye_mat[3][0] = eye_sep * (left_eye ? -1.0 : 1.0);\\n eye_mat[3][1] = -m1p1(eye_pos);\\n \\n curMat *= eye_mat;\\n \\n float angle = eye_per * TWOPI;\\n //float angle = eye_per * PI;\\n\\n float x = cos(angle) * eye_ratio;\\n float y = sin(angle) ;\\n gl_Position = curMat * vec4(x,y,0.0,1.0);\\n v_color = vec4((left_eye ? 1.0 : 0.0),0.0,(left_eye ? 0.0 : 1.0),1.0);\\n}\\n\\nvoid draw_nose(float vert_per, mat4 curMat)\\n{\\n float angle = vert_per * TWOPI;\\n\\n float x = cos(angle) * nose_radius;\\n float y = sin(angle) * nose_radius - (nose_pos * 0.5);\\n gl_Position = curMat * vec4(x,y,0.0,1.0);\\n v_color = vec4(1.0);\\n}\\n\\nvoid draw_mouth(float vert_per, mat4 curMat)\\n{\\n float angle = vert_per * TWOPI;\\n\\n //float x = cos(angle) * nose_radius;\\n float x = vert_per * mouth_width * 2. - mouth_radius * 2.;\\n float y = -m1p1(mouth_pos);\\n //float y = sin(angle) * nose_radius - (nose_pos * 0.5);\\n gl_Position = curMat * vec4(x,y,0.0,1.0);\\n v_color = vec4(1.0);\\n}\\n\\nvoid main()\\n{\\n mat4 curMat = build_mvp();\\n curMat *= build_face_mat();\\n \\n float total_per = vertexId / vertexCount;\\n if(total_per < face_verts_percent) {\\n float vert_per = total_per / face_verts_percent;\\n draw_head(vert_per, curMat);\\n } else if (total_per >= face_verts_percent && total_per < (face_verts_percent + eye_verts_percent)){\\n float vert_per = (total_per - face_verts_percent) / eye_verts_percent;\\n draw_eyes(vert_per, curMat);\\n } else if (total_per >= (face_verts_percent + eye_verts_percent) && total_per < (face_verts_percent + eye_verts_percent + nose_verts_percent)){\\n float vert_per = (total_per - (face_verts_percent + eye_verts_percent)) / nose_verts_percent;\\n draw_nose(vert_per, curMat);\\n } else {\\n float vert_per = (total_per - (face_verts_percent + eye_verts_percent + nose_verts_percent)) / mouth_verts_percent;\\n draw_mouth(vert_per, curMat);\\n }\\n \\n gl_PointSize = 5.0;\\n //gl_Position = vec4(0.5,0.5,0.0,1.0);\\n}\\n\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.1416\n#define TWOPI 6.28\nfloat face_radius = 0.5;\nfloat face_height = face_radius * 2.;\nfloat face_ratio = 1.15 * face_height;\nfloat eye_pos = 0.56 * face_height;\n//float eye_radius = 0.05 * face_height;\n//float eye_ratio = 5.66 * face_height;\nfloat eye_width = 0.26 * face_height;\nfloat eye_height = 0.2 * face_height;\nfloat eye_ratio = eye_width / eye_height;\nfloat eye_sep = 0.54 * face_height; // -1 to 1 so sep is 2 * face width percentage\n\nfloat nose_pos = 0.77 * face_height;\nfloat nose_radius = 0.012 * face_height;\n\nfloat mouth_pos = 0.85 * face_height;\nfloat mouth_width = 0.31 * face_height;\nfloat mouth_radius = mouth_width * 0.5;\n\nconst float face_verts_percent = 0.4;\nconst float eye_verts_percent = 0.45;\nconst float nose_verts_percent = 0.05;\nconst float mouth_verts_percent = 0.10;\n\nmat4 mvp = mat4(1.0);\nmat4 face_mat = mat4(1.0);\n\nfloat m1p1(float v) { return v * 2. - 1.; }\n\nmat4 build_mvp() {\n mvp[0][0] = resolution.y/resolution.x;\n mvp[1][1] = 1.0;\n return mvp;\n}\nmat4 build_face_mat() {\n face_mat[0][0] = face_radius;\n face_mat[1][1] = face_radius;\n return face_mat;\n}\n\nvoid draw_head(float vert_per, mat4 curMat)\n{\n float angle = vert_per * TWOPI;\n\n float x = cos(angle) * face_ratio;\n float y = sin(angle) * 1.;\n gl_Position = curMat * vec4(x,y,0.0,1.0);\n v_color = vec4(1.0);\n}\n\nvoid draw_eyes(float vert_per, mat4 curMat) {\n // TODO: should be able to replace these eye conditions \n // with a multiplier for left eye / right eye\n bool left_eye = (vert_per < 0.5);\n float eye_per = vert_per / 0.5;\n if(left_eye)\n eye_per -= 0.5;\n \n mat4 eye_mat = mat4(1.0);\n eye_mat[0][0] = eye_height;\n eye_mat[1][1] = eye_height;\n eye_mat[3][0] = eye_sep * (left_eye ? -1.0 : 1.0);\n eye_mat[3][1] = -m1p1(eye_pos);\n \n curMat *= eye_mat;\n \n float angle = eye_per * TWOPI;\n //float angle = eye_per * PI;\n\n float x = cos(angle) * eye_ratio;\n float y = sin(angle) ;\n gl_Position = curMat * vec4(x,y,0.0,1.0);\n v_color = vec4((left_eye ? 1.0 : 0.0),0.0,(left_eye ? 0.0 : 1.0),1.0);\n}\n\nvoid draw_nose(float vert_per, mat4 curMat)\n{\n float angle = vert_per * TWOPI;\n\n float x = cos(angle) * nose_radius;\n float y = sin(angle) * nose_radius - (nose_pos * 0.5);\n gl_Position = curMat * vec4(x,y,0.0,1.0);\n v_color = vec4(1.0);\n}\n\nvoid draw_mouth(float vert_per, mat4 curMat)\n{\n float angle = vert_per * TWOPI;\n\n //float x = cos(angle) * nose_radius;\n float x = vert_per * mouth_width * 2. - mouth_radius * 2.;\n float y = -m1p1(mouth_pos);\n //float y = sin(angle) * nose_radius - (nose_pos * 0.5);\n gl_Position = curMat * vec4(x,y,0.0,1.0);\n v_color = vec4(1.0);\n}\n\nvoid main()\n{\n mat4 curMat = build_mvp();\n curMat *= build_face_mat();\n \n float total_per = vertexId / vertexCount;\n if(total_per < face_verts_percent) {\n float vert_per = total_per / face_verts_percent;\n draw_head(vert_per, curMat);\n } else if (total_per >= face_verts_percent && total_per < (face_verts_percent + eye_verts_percent)){\n float vert_per = (total_per - face_verts_percent) / eye_verts_percent;\n draw_eyes(vert_per, curMat);\n } else if (total_per >= (face_verts_percent + eye_verts_percent) && total_per < (face_verts_percent + eye_verts_percent + nose_verts_percent)){\n float vert_per = (total_per - (face_verts_percent + eye_verts_percent)) / nose_verts_percent;\n draw_nose(vert_per, curMat);\n } else {\n float vert_per = (total_per - (face_verts_percent + eye_verts_percent + nose_verts_percent)) / mouth_verts_percent;\n draw_mouth(vert_per, curMat);\n }\n \n gl_PointSize = 5.0;\n //gl_Position = vec4(0.5,0.5,0.0,1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-c5bxxuqmk216xyega-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/W5vsi9uadatWRg8XJ/art.json b/art/W5vsi9uadatWRg8XJ/art.json index c68902d8..8f9322eb 100644 --- a/art/W5vsi9uadatWRg8XJ/art.json +++ b/art/W5vsi9uadatWRg8XJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define KP parameter0\\n#define parameter0 sin( mouse.y)\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos) \\n{\\n float c = 0.2;\\n float spd = 0.3;\\n float tm = time * spd-mouse.x;\\n c = sin(tan(pos.x) - sin(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + KP * sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) - 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = ((mod(vId, w) - w / 2.0)-parameter0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px*2.5, py) * 4.0)) * 0.5 - 0.25;\\n gl_Position = vec4(px / py, (y /- + c * 0.15) /-py, 0.0, 1);\\n gl_PointSize = c *c + 46.0* mouse.x;\\n\\n \\n v_color = vec4(0.2 / c, 0.24 + c, 1.7 + c, (1.0- vId)) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define KP parameter0\n#define parameter0 sin( mouse.y)\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos) \n{\n float c = 0.2;\n float spd = 0.3;\n float tm = time * spd-mouse.x;\n c = sin(tan(pos.x) - sin(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + KP * sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) - 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = ((mod(vId, w) - w / 2.0)-parameter0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px*2.5, py) * 4.0)) * 0.5 - 0.25;\n gl_Position = vec4(px / py, (y /- + c * 0.15) /-py, 0.0, 1);\n gl_PointSize = c *c + 46.0* mouse.x;\n\n \n v_color = vec4(0.2 / c, 0.24 + c, 1.7 + c, (1.0- vId)) * 0.75;\n}" + }, "screenshotURL": "data/images/images-5sgozfaq4i3rn2ifd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/W6AZjsv3rqioGwCLa/art.json b/art/W6AZjsv3rqioGwCLa/art.json index 49980cc7..44690ce3 100644 --- a/art/W6AZjsv3rqioGwCLa/art.json +++ b/art/W6AZjsv3rqioGwCLa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":11111,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27058823529411763,0.050980392156862744,0.34901960784313724,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 1.0)\\n#define STEP 1.93\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 12.0) * -mod(vertexId, 12.0) * STEP, NUM_SEGMENTS));\\n\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * .006- mouse.y) + 11.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.0014, 2.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.0025, .9);\\n float innerRadius = pow(count * 0.005, 1.2);\\n float oC = cos(orbitAngle + count * 0.003) * innerRadius*mouse.y*sin(time);\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius-mouse.x+sin(time);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC -1.+ c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\\n\\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 2.3 + 0.17, .28);\\n b = 0.1920;mix(-.3, mouse.x/0.9/T, b)/-T;\\n v_color = vec4(c, c, sin(T*2./b)+b/c-b, .489);\\n}\\n\"}", + "settings": { + "num": 11111, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27058823529411763, + 0.050980392156862744, + 0.34901960784313724, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 1.0)\n#define STEP 1.93\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 12.0) * -mod(vertexId, 12.0) * STEP, NUM_SEGMENTS));\n\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * .006- mouse.y) + 11.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.0014, 2.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.0025, .9);\n float innerRadius = pow(count * 0.005, 1.2);\n float oC = cos(orbitAngle + count * 0.003) * innerRadius*mouse.y*sin(time);\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius-mouse.x+sin(time);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC -1.+ c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\n\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 2.3 + 0.17, .28);\n b = 0.1920;mix(-.3, mouse.x/0.9/T, b)/-T;\n v_color = vec4(c, c, sin(T*2./b)+b/c-b, .489);\n}\n" + }, "screenshotURL": "data/images/images-go3bn66wd32dq2ctc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/W759Kzfq4jJb5dL5v/art.json b/art/W759Kzfq4jJb5dL5v/art.json index 99ad7152..30d94155 100644 --- a/art/W759Kzfq4jJb5dL5v/art.json +++ b/art/W759Kzfq4jJb5dL5v/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\nvec2 project(vec2 position, vec2 a, vec2 b); \\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 4.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n\\tfor(int i = 0; i < 48; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\tb += box(p, vec2(.5));\\n\\t\\tt += triangle(p, vec2(.5));\\n\\t\\tp *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\t\\n\\t//gl_FragColor = result;\\n \\n gl_Position = vec4(ux, vy*snd, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = result;\\n \\n\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.73205080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t*= .86602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(t);\\n\\treturn mat2(c, s, -s, c);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\nvec2 project(vec2 position, vec2 a, vec2 b); \nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 4.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(time*.004), cos(time*.003)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n\tfor(int i = 0; i < 48; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\tb += box(p, vec2(.5));\n\t\tt += triangle(p, vec2(.5));\n\t\tp *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\t\n\t//gl_FragColor = result;\n \n gl_Position = vec4(ux, vy*snd, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = result;\n \n\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.73205080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t*= .86602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(t);\n\treturn mat2(c, s, -s, c);\n}\n" + }, "screenshotURL": "data/images/images-ny73dom7vfjq3iblt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/W7N52DhuhNz27EPxw/art.json b/art/W7N52DhuhNz27EPxw/art.json index 2eb98fae..b45356b7 100644 --- a/art/W7N52DhuhNz27EPxw/art.json +++ b/art/W7N52DhuhNz27EPxw/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sina5an", "avatarUrl": "https://secure.gravatar.com/avatar/8ea2eb4d1d5da005eca6f4aae81d9e15?default=retro&size=200", - "settings": "{\"num\":72900,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.058823529411764705,0.054901960784313725,0.0784313725490196,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float kenarKat = (abs(sin(time * 0.1)) * 0.1 + 0.8);\\n \\n float kenar = floor(sqrt(vertexCount)) * kenarKat;\\n \\n float x = floor(vertexId / kenar);\\n float y = mod( vertexId, kenar);\\n \\n float u = x / (kenar - 1.0) * abs(sin(time + y * 0.1));\\n float v = y / (kenar - 1.0) + cos(x * 0.05);\\n \\n float ux = (u - 0.5) * 1.1 * (sin(4.0 * time + v) * 0.3 + 0.6);\\n float vy = (v - 0.5) * 2.1;\\n \\n gl_PointSize = 45.0 * 10.0 / kenar;\\n \\n gl_Position = vec4(ux,vy,0.0,1.0);\\n \\n vec3 hsv = vec3(u * sin(time * 0.3), abs(sin(time * vy * ux + u)), sin(time*v));\\n \\n v_color = vec4(hsv2rgb(hsv),1.0);\\n}\"}", + "settings": { + "num": 72900, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.058823529411764705, + 0.054901960784313725, + 0.0784313725490196, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float kenarKat = (abs(sin(time * 0.1)) * 0.1 + 0.8);\n \n float kenar = floor(sqrt(vertexCount)) * kenarKat;\n \n float x = floor(vertexId / kenar);\n float y = mod( vertexId, kenar);\n \n float u = x / (kenar - 1.0) * abs(sin(time + y * 0.1));\n float v = y / (kenar - 1.0) + cos(x * 0.05);\n \n float ux = (u - 0.5) * 1.1 * (sin(4.0 * time + v) * 0.3 + 0.6);\n float vy = (v - 0.5) * 2.1;\n \n gl_PointSize = 45.0 * 10.0 / kenar;\n \n gl_Position = vec4(ux,vy,0.0,1.0);\n \n vec3 hsv = vec3(u * sin(time * 0.3), abs(sin(time * vy * ux + u)), sin(time*v));\n \n v_color = vec4(hsv2rgb(hsv),1.0);\n}" + }, "screenshotURL": "data/images/images-c4b5x71ah1ff8yjd1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/W9WTPxA9AXtFxZRqq/art.json b/art/W9WTPxA9AXtFxZRqq/art.json index f444a4af..f7a1ba45 100644 --- a/art/W9WTPxA9AXtFxZRqq/art.json +++ b/art/W9WTPxA9AXtFxZRqq/art.json @@ -28,7 +28,19 @@ "name": "sines", "private": false, "username": "jason", - "settings": "{\"num\":49533,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n /*\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n */\\n \\n float traces = 5.0;\\n float trace = mod(vertexId, traces);\\n float x = -1.0 + 2.0 * vertexId / vertexCount;\\n \\n float speed = 1.0 * time;\\n float amp = sin(time) * (1.0 + trace) / traces;\\n float y = amp * sin(speed + PI * x);\\n \\n gl_Position = vec4(x, y, 0, 1);\\n float c = trace / traces;\\n v_color = vec4(hsv2rgb(vec3(x, 0.5, 1)), 1);\\n //v_color = vec4(c, c, 1, 0);\\n}\"}", + "settings": { + "num": 49533, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n /*\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n */\n \n float traces = 5.0;\n float trace = mod(vertexId, traces);\n float x = -1.0 + 2.0 * vertexId / vertexCount;\n \n float speed = 1.0 * time;\n float amp = sin(time) * (1.0 + trace) / traces;\n float y = amp * sin(speed + PI * x);\n \n gl_Position = vec4(x, y, 0, 1);\n float c = trace / traces;\n v_color = vec4(hsv2rgb(vec3(x, 0.5, 1)), 1);\n //v_color = vec4(c, c, 1, 0);\n}" + }, "screenshotURL": "data/images/images-mq97m9nxjsgg7i0pe-thumbnail.jpg", "views": { "$numberInt": "169" diff --git a/art/WARdzeaiQZaiSy6Hj/art.json b/art/WARdzeaiQZaiSy6Hj/art.json index 5bcdfbc6..ac968986 100644 --- a/art/WARdzeaiQZaiSy6Hj/art.json +++ b/art/WARdzeaiQZaiSy6Hj/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "gman", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/ambientmusicalgenre/alicks-giants-under-the-sea\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7098039215686275,0.27058823529411763,0.24313725490196078,1],\"shader\":\"/*\\n\\n __ __ _ _ ____ __ __ _ _ ____ \\n( )( )( \\\\( )(_ _)( )( )( \\\\( )(_ _)\\n )(__)( ) ( _)(_ )(__)( ) ( _)(_ \\n(______)(_)\\\\_)(____)(______)(_)\\\\_)(____)\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float maxCount = floor(vertexCount / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n \\n const int numSamples = 8;\\n float snd = 0.;\\n for (int i = 0; i < numSamples; ++i) {\\n snd = max(texture2D(sound, vec2(\\n 0.05+ float(i) / float(numSamples) * 0.00 + 0.01, \\n count / maxCount)).a, snd);\\n }\\n \\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow((maxCount - count) * mix(0.125, 0.25, sin(time * 0.25)), 0.8);\\n float innerRadius = pow((maxCount - count) * 0.00005, 1.5);\\n float oC = cos(orbitAngle + count * 0.001 + time) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.002 + time * 0.01) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * 40. + mouse * 0.0, 0, 1);\\n\\n float b = 1.0 - pow(abs(sin(count * 0.2)) * 0.5 + 0.5, 2.0 + pow(snd+0.3, 5.) * 5.);\\n v_color = vec4(vec3(b), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/ambientmusicalgenre/alicks-giants-under-the-sea", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7098039215686275, + 0.27058823529411763, + 0.24313725490196078, + 1 + ], + "shader": "/*\n\n __ __ _ _ ____ __ __ _ _ ____ \n( )( )( \\( )(_ _)( )( )( \\( )(_ _)\n )(__)( ) ( _)(_ )(__)( ) ( _)(_ \n(______)(_)\\_)(____)(______)(_)\\_)(____)\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float maxCount = floor(vertexCount / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n \n const int numSamples = 8;\n float snd = 0.;\n for (int i = 0; i < numSamples; ++i) {\n snd = max(texture2D(sound, vec2(\n 0.05+ float(i) / float(numSamples) * 0.00 + 0.01, \n count / maxCount)).a, snd);\n }\n \n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow((maxCount - count) * mix(0.125, 0.25, sin(time * 0.25)), 0.8);\n float innerRadius = pow((maxCount - count) * 0.00005, 1.5);\n float oC = cos(orbitAngle + count * 0.001 + time) * innerRadius;\n float oS = sin(orbitAngle + count * 0.002 + time * 0.01) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * 40. + mouse * 0.0, 0, 1);\n\n float b = 1.0 - pow(abs(sin(count * 0.2)) * 0.5 + 0.5, 2.0 + pow(snd+0.3, 5.) * 5.);\n v_color = vec4(vec3(b), 1);\n}" + }, "screenshotURL": "data/images/images-fprrdobp2yiuwmr8l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WBgJQrq6H2sZ2gzyb/art.json b/art/WBgJQrq6H2sZ2gzyb/art.json index 42eab54f..ece0ae1b 100644 --- a/art/WBgJQrq6H2sZ2gzyb/art.json +++ b/art/WBgJQrq6H2sZ2gzyb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.1450980392156863,0.30980392156862746,1],\"shader\":\"void main ()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.1450980392156863, + 0.30980392156862746, + 1 + ], + "shader": "void main ()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-vw8arwvvehovcvucq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WC5fhEkctfmHrGz6m/art.json b/art/WC5fhEkctfmHrGz6m/art.json index a62c027a..1659d09b 100644 --- a/art/WC5fhEkctfmHrGz6m/art.json +++ b/art/WC5fhEkctfmHrGz6m/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":4203,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Term : Spring 2023\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n float utime = time;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n \\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(cos(utime),sin(utime),1,1);\\n \\n}\\n\"}", + "settings": { + "num": 4203, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Term : Spring 2023\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n float utime = time;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n \n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(cos(utime),sin(utime),1,1);\n \n}\n" + }, "screenshotURL": "data/images/images-jvnygw42dvb174q3r-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WE4yq93CEqrBtHvQ9/art.json b/art/WE4yq93CEqrBtHvQ9/art.json index 0e6d5b8c..bda84d4e 100644 --- a/art/WE4yq93CEqrBtHvQ9/art.json +++ b/art/WE4yq93CEqrBtHvQ9/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 5;\\t\\n \\n \\n \\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\\n }\\n \\n else if(num == 5) {\\n gl_Position = vec4(cos(vertexId/5.0)/vertexId*50000.0,\\n sin(vertexId/5.0)/vertexId*50000.0,\\n tan(vertexId/5.0),1.0);\\n }\\n\\n // gl_PointSize = -gl_Position.z*sin(1.0)+sin(time*vertexId/500.0); \\n //gl_PointSize = 1.0;\\n \\n v_color = vec4(sin(vertexId/122.0),\\n sin(vertexId/122.0),\\n sin(vertexId/122.0),1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 5;\t\n \n \n \n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\n }\n \n else if(num == 5) {\n gl_Position = vec4(cos(vertexId/5.0)/vertexId*50000.0,\n sin(vertexId/5.0)/vertexId*50000.0,\n tan(vertexId/5.0),1.0);\n }\n\n // gl_PointSize = -gl_Position.z*sin(1.0)+sin(time*vertexId/500.0); \n //gl_PointSize = 1.0;\n \n v_color = vec4(sin(vertexId/122.0),\n sin(vertexId/122.0),\n sin(vertexId/122.0),1);\n}" + }, "screenshotURL": "data/images/images-brs2ychg4b9cseatp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WEKX8jLk432REZLJq/art.json b/art/WEKX8jLk432REZLJq/art.json index 0660174a..0040c411 100644 --- a/art/WEKX8jLk432REZLJq/art.json +++ b/art/WEKX8jLk432REZLJq/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":18432,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/geotheorymusic/work-it-girl\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9921568627450981,0.984313725490196,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = mix(inner, 1., level);\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.5;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += 10.;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n mat *= scale(vec3(0.25, 0.25, -20.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(.65, 1., step(0.75, snd));\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n v_color.a = 1.0 - uvf.y;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 18432, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/geotheorymusic/work-it-girl", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9921568627450981, + 0.984313725490196, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = mix(inner, 1., level);\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.5;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += 10.;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n mat *= scale(vec3(0.25, 0.25, -20.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = mix(.65, 1., step(0.75, snd));\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n v_color.a = 1.0 - uvf.y;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-x1xom7jgfgpv7zcsl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WGdY3o9Nv6AqRvu5E/art.json b/art/WGdY3o9Nv6AqRvu5E/art.json index 5b52498e..ae2c0b14 100644 --- a/art/WGdY3o9Nv6AqRvu5E/art.json +++ b/art/WGdY3o9Nv6AqRvu5E/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec2 field(vec2 pos) {\\n // just for easier readability\\n float x = pos.x;\\n float y = pos.y;\\n \\n // vector field mapping\\n return vec2(\\n\\n -y,\\n x\\n );\\n}\\n\\nvoid main() {\\n // mouse position is the droplets position in this example\\n gl_Position = vec4(mouse.x, mouse.y, 0,1);\\n \\n // apply vector field to the next point\\n // to demonstrate effect of vector field\\n if (vertexId == 1.) {\\n vec2 d = field(mouse.xy);\\n d = normalize(d);\\n gl_Position += vec4(d.x, d.y, 0,1);\\n }\\n \\n \\n gl_PointSize = vertexId * 2.;\\n v_color = vec4(1.0 - vertexId,1,1,1);\\n}\"}", + "settings": { + "num": 2, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec2 field(vec2 pos) {\n // just for easier readability\n float x = pos.x;\n float y = pos.y;\n \n // vector field mapping\n return vec2(\n\n -y,\n x\n );\n}\n\nvoid main() {\n // mouse position is the droplets position in this example\n gl_Position = vec4(mouse.x, mouse.y, 0,1);\n \n // apply vector field to the next point\n // to demonstrate effect of vector field\n if (vertexId == 1.) {\n vec2 d = field(mouse.xy);\n d = normalize(d);\n gl_Position += vec4(d.x, d.y, 0,1);\n }\n \n \n gl_PointSize = vertexId * 2.;\n v_color = vec4(1.0 - vertexId,1,1,1);\n}" + }, "screenshotURL": "data/images/images-u7x7y5e7l25hu68z2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WHQLcLQnN57rPtGJC/art.json b/art/WHQLcLQnN57rPtGJC/art.json index 66a09c33..2b0bb1aa 100644 --- a/art/WHQLcLQnN57rPtGJC/art.json +++ b/art/WHQLcLQnN57rPtGJC/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":274,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n\\t\\n if(vertexId > 200.0){\\n\\tgl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n gl_PointSize = 10.0; \\n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n \\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\\n v_color = vec4(1,vertexId,0.5,1);\\n}\"}", + "settings": { + "num": 274, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n\t\n if(vertexId > 200.0){\n\tgl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n gl_PointSize = 10.0; \n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n \n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\n v_color = vec4(1,vertexId,0.5,1);\n}" + }, "screenshotURL": "data/images/images-7f3zjb0svtzpvaxe9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WKkAZ9su88ypqH9da/art.json b/art/WKkAZ9su88ypqH9da/art.json index 06200f2a..1fd05102 100644 --- a/art/WKkAZ9su88ypqH9da/art.json +++ b/art/WKkAZ9su88ypqH9da/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":12010,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.01) * 0.5;\\n float yoff = sin(time + x ) * sin(time);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(sin(xy), 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 500.0;\\n v_color = (vec4(0.75-ux*ux, 0.75-vy*vy, 0.75-ux*vy, 1));\\n}\"}", + "settings": { + "num": 12010, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.01) * 0.5;\n float yoff = sin(time + x ) * sin(time);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(sin(xy), 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 500.0;\n v_color = (vec4(0.75-ux*ux, 0.75-vy*vy, 0.75-ux*vy, 1));\n}" + }, "screenshotURL": "data/images/images-z3aw97e71l40pgibb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WM2T8Fz7ftcgqwgYn/art.json b/art/WM2T8Fz7ftcgqwgYn/art.json index a28d710c..944ba62c 100644 --- a/art/WM2T8Fz7ftcgqwgYn/art.json +++ b/art/WM2T8Fz7ftcgqwgYn/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"plasma grid\\\" by johanberonius\\n\\nvoid main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 4.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.9) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"plasma grid\" by johanberonius\n\nvoid main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 4.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.9) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-n5jqyci8gywvyqlgw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WMSNZ3Scdfw2fZJyw/art.json b/art/WMSNZ3Scdfw2fZJyw/art.json index 2ec38704..c3aa8d26 100644 --- a/art/WMSNZ3Scdfw2fZJyw/art.json +++ b/art/WMSNZ3Scdfw2fZJyw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":56050,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/uheplugins/bora\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 100.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float pointV = point / NUM_SEGMENTS;\\n float circleId = floor(vertexId / NUM_POINTS);\\n float numCircles = floor(vertexCount / NUM_POINTS);\\n float circleV = circleId / numCircles;\\n \\n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\\n \\n float angle = pointV * PI * 2.0 + snd * 5.;\\n float c = cos(angle) * mix(0.1, 1., circleV);\\n float s = sin(angle) * mix(0.25, 0.5, circleV);\\n \\n float r = mix(0., PI, circleV) + pow(snd, 5.0);\\n float rc = cos(r + sin(time * 4. + circleV * 4.));\\n float rs = sin(r + sin(time * 4. + circleV * 4.));\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\\n vec2 xy = vec2(\\n rc * c + rs * s,\\n -rs * c + rc * s);\\n gl_Position = vec4(xy * aspect*snd, 0, 1);\\n\\n float b = 1.0;\\n v_color.a = 1.;\\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\\n \\n gl_PointSize = 4.0;\\n gl_PointSize *= resolution.x / 1600.0;\\n}\"}", + "settings": { + "num": 56050, + "mode": "LINES", + "sound": "https://soundcloud.com/uheplugins/bora", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 100.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float pointV = point / NUM_SEGMENTS;\n float circleId = floor(vertexId / NUM_POINTS);\n float numCircles = floor(vertexCount / NUM_POINTS);\n float circleV = circleId / numCircles;\n \n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\n \n float angle = pointV * PI * 2.0 + snd * 5.;\n float c = cos(angle) * mix(0.1, 1., circleV);\n float s = sin(angle) * mix(0.25, 0.5, circleV);\n \n float r = mix(0., PI, circleV) + pow(snd, 5.0);\n float rc = cos(r + sin(time * 4. + circleV * 4.));\n float rs = sin(r + sin(time * 4. + circleV * 4.));\n \n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\n vec2 xy = vec2(\n rc * c + rs * s,\n -rs * c + rc * s);\n gl_Position = vec4(xy * aspect*snd, 0, 1);\n\n float b = 1.0;\n v_color.a = 1.;\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\n \n gl_PointSize = 4.0;\n gl_PointSize *= resolution.x / 1600.0;\n}" + }, "screenshotURL": "data/images/images-m03374aefkhqmhnyh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WMeytAXb53i6LtrWm/art.json b/art/WMeytAXb53i6LtrWm/art.json index 1059693d..a31e0949 100644 --- a/art/WMeytAXb53i6LtrWm/art.json +++ b/art/WMeytAXb53i6LtrWm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":6000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/robotandproud/401-circuit\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"/*\\n\\n \\n___ _____________ \\n\\\\ \\\\/ / ___/\\\\__ \\\\ \\n \\\\ /\\\\___ \\\\ / __ \\\\_\\n \\\\_//____ >(____ /\\n \\\\/ \\\\/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float pointsPerLine = 30.;\\n float lineId = floor(vertexId / pointsPerLine);\\n float numLines = floor(vertexCount / pointsPerLine);\\n\\n float lineV = lineId / numLines;\\n float angle = lineV * PI * 2.;\\n \\n float pointId = mod(vertexId, pointsPerLine);\\n float pointV = pointId / (pointsPerLine - 1.);\\n \\n float id = floor(pointId / 2.) + mod(pointId, 2.);\\n float idV = id / (pointsPerLine / 2. - 1.);\\n \\n float snd = texture2D(sound, vec2(abs(lineV - 0.5) * 0.15, pointV * 0.5)).a;\\n \\n float odd = mod(id, 2.);\\n angle += sin(time + idV * 21.) * odd * 0.2 + time * 0.1 + snd * 0.;\\n// angle += odd * 0.2;\\n \\n// float radius = pow(idV + 1., 2.) - 3.0;\\n float radius = pow(idV, 2.) + sin(time + lineV * PI * 2. * 8.) * odd * idV * 0.1;\\n float c = cos(angle) * radius;\\n float s = sin(angle) * radius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.1;\\n vec2 xy = vec2(c, s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n float p = 1. - pow(snd, 5.);\\n float pump = step(0.9, snd);\\n v_color = vec4(0, p, p, idV) + pump * vec4(0,10,10,0);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 6000, + "mode": "LINES", + "sound": "https://soundcloud.com/robotandproud/401-circuit", + "lineSize": "CSS", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "/*\n\n \n___ _____________ \n\\ \\/ / ___/\\__ \\ \n \\ /\\___ \\ / __ \\_\n \\_//____ >(____ /\n \\/ \\/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvoid main() {\n float pointsPerLine = 30.;\n float lineId = floor(vertexId / pointsPerLine);\n float numLines = floor(vertexCount / pointsPerLine);\n\n float lineV = lineId / numLines;\n float angle = lineV * PI * 2.;\n \n float pointId = mod(vertexId, pointsPerLine);\n float pointV = pointId / (pointsPerLine - 1.);\n \n float id = floor(pointId / 2.) + mod(pointId, 2.);\n float idV = id / (pointsPerLine / 2. - 1.);\n \n float snd = texture2D(sound, vec2(abs(lineV - 0.5) * 0.15, pointV * 0.5)).a;\n \n float odd = mod(id, 2.);\n angle += sin(time + idV * 21.) * odd * 0.2 + time * 0.1 + snd * 0.;\n// angle += odd * 0.2;\n \n// float radius = pow(idV + 1., 2.) - 3.0;\n float radius = pow(idV, 2.) + sin(time + lineV * PI * 2. * 8.) * odd * idV * 0.1;\n float c = cos(angle) * radius;\n float s = sin(angle) * radius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 1.1;\n vec2 xy = vec2(c, s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n float p = 1. - pow(snd, 5.);\n float pump = step(0.9, snd);\n v_color = vec4(0, p, p, idV) + pump * vec4(0,10,10,0);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-ro2r5d7ydpdn4wpyz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WQxKx3Pee7i5gEdzG/art.json b/art/WQxKx3Pee7i5gEdzG/art.json index 556aa9a9..c06fed49 100644 --- a/art/WQxKx3Pee7i5gEdzG/art.json +++ b/art/WQxKx3Pee7i5gEdzG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":11477,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/subjex/richard\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=11556\\n\\n#define soundFactor -.2 //KParameter -1.0>>1.\\n#define speedFactor 0.10//Kparameter 0.>>4.\\n#define sinFactor0 32.//KParameter 1.>>100.\\n#define sinFactor1 55.//Parameter 1.>>100.\\n\\n\\n\\n#define PI 3.1415926535898\\n#define HPI 1.570796326795\\n\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43658.5453123, 1345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.3, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(0.0, 9.0, 4.0));\\n \\n float diffuse = max(0.70, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvec3 giantWorm(vec3 a, float t) {\\n return vec3(sin(t*sinFactor0 * a.x), sin(t*sinFactor1 * a.y), cos(t * a.z));\\n}\\n\\n\\nvec3 transformation(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount-1.1);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float lineId = 0.;//\\n mod(shapeId, 3.0);\\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 0.0) {\\n lineFactor = vec3(4.1, 6.7, 2.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else if(lineId == .0) {\\n lineFactor = vec3(4.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(0.60, 0.6, 1.0);\\n }\\n \\n float v = vertexId / vertexCount;\\n float distort = mod(vertexId, 100.) / 100.;\\n float snd = soundFactor*texture2D(sound, vec2(mix(0.01, 0.061, distort), mix(0.25, 0., v))).a;\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 shapeni;\\n vec3 shapep = shapeVertex(shapeVertexId, shapeni) * 0.04;\\n \\n vec3 shapeHash = noise(vec3(log(shapeId)));\\n float factor = -0.6+snd;\\n float factor2 = 0.0005 ;\\n vec3 shapeOffset = vec3(factor*cos(factor2*time*shapeId),factor*sin(factor2*time*shapeId),0.);\\n vec3 shapeRot = noise(shapeHash) * time * 2.0*speedFactor;\\n \\t\\n shapep = rotX(rotY(rotZ(shapep, shapeRot.z), shapeRot.y), shapeRot.z);\\n shapeni.xyz = rotX(rotY(rotZ(shapeni.xyz, shapeRot.z), shapeRot.y), shapeRot.z);\\n \\n shapep = transformation(lineFactor, (t + time * 0.1*speedFactor) * 2.0) * vec3(aspect, 1.0, aspect) + (shapep + shapeOffset);\\n \\n \\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, shapep, shapeni.xyz, vec3(.005 + shapeHash * 0.05), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookAt(shapep, eye, vec3(0.0), vec3(0.0, 3.0, 0.0));\\n gl_Position = perspective(p, mix(113.*-snd,dot(snd,aspect),mouse.x-2.), 1., 10.0, resolution);\\n gl_PointSize = 2.0;\\n vec3 col = vec3(color.r-snd*0.2,color.g-mouse.x*snd,color.b*3.);\\n v_color = vec4(col, 1.1);\\n}\\n\\n\"}", + "settings": { + "num": 11477, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/subjex/richard", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=11556\n\n#define soundFactor -.2 //KParameter -1.0>>1.\n#define speedFactor 0.10//Kparameter 0.>>4.\n#define sinFactor0 32.//KParameter 1.>>100.\n#define sinFactor1 55.//Parameter 1.>>100.\n\n\n\n#define PI 3.1415926535898\n#define HPI 1.570796326795\n\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43658.5453123, 1345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.3, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(0.0, 9.0, 4.0));\n \n float diffuse = max(0.70, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvec3 giantWorm(vec3 a, float t) {\n return vec3(sin(t*sinFactor0 * a.x), sin(t*sinFactor1 * a.y), cos(t * a.z));\n}\n\n\nvec3 transformation(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\n\n\n\nvoid main() {\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount-1.1);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float lineId = 0.;//\n mod(shapeId, 3.0);\n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 0.0) {\n lineFactor = vec3(4.1, 6.7, 2.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else if(lineId == .0) {\n lineFactor = vec3(4.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 1.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(0.60, 0.6, 1.0);\n }\n \n float v = vertexId / vertexCount;\n float distort = mod(vertexId, 100.) / 100.;\n float snd = soundFactor*texture2D(sound, vec2(mix(0.01, 0.061, distort), mix(0.25, 0., v))).a;\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 shapeni;\n vec3 shapep = shapeVertex(shapeVertexId, shapeni) * 0.04;\n \n vec3 shapeHash = noise(vec3(log(shapeId)));\n float factor = -0.6+snd;\n float factor2 = 0.0005 ;\n vec3 shapeOffset = vec3(factor*cos(factor2*time*shapeId),factor*sin(factor2*time*shapeId),0.);\n vec3 shapeRot = noise(shapeHash) * time * 2.0*speedFactor;\n \t\n shapep = rotX(rotY(rotZ(shapep, shapeRot.z), shapeRot.y), shapeRot.z);\n shapeni.xyz = rotX(rotY(rotZ(shapeni.xyz, shapeRot.z), shapeRot.y), shapeRot.z);\n \n shapep = transformation(lineFactor, (t + time * 0.1*speedFactor) * 2.0) * vec3(aspect, 1.0, aspect) + (shapep + shapeOffset);\n \n \n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, shapep, shapeni.xyz, vec3(.005 + shapeHash * 0.05), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookAt(shapep, eye, vec3(0.0), vec3(0.0, 3.0, 0.0));\n gl_Position = perspective(p, mix(113.*-snd,dot(snd,aspect),mouse.x-2.), 1., 10.0, resolution);\n gl_PointSize = 2.0;\n vec3 col = vec3(color.r-snd*0.2,color.g-mouse.x*snd,color.b*3.);\n v_color = vec4(col, 1.1);\n}\n\n" + }, "screenshotURL": "data/images/images-15wxwg3goxvxugzxu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WRmESL9HBySX6ujn5/art.json b/art/WRmESL9HBySX6ujn5/art.json index acc48829..e7b5f0fe 100644 --- a/art/WRmESL9HBySX6ujn5/art.json +++ b/art/WRmESL9HBySX6ujn5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jieunko", "avatarUrl": "https://avatars.githubusercontent.com/jieunko?s=200", - "settings": "{\"num\":1265,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n\\t\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x/ (across - 1.);\\n float v = y/ (across - 1.);\\n \\n float xoff = 0.0; //sin(time+y * 0.4) * 0.1;\\n float yoff = 0.0; //cos(time+x * 0.4) * 0.1;\\n float soff = 0.0; //sin(time + x * y*0.02) * 5.0;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 5.0 + soff;\\n v_color = vec4(0.0, u, v, 1);\\n\\n}\"}", + "settings": { + "num": 1265, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n\t\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x/ (across - 1.);\n float v = y/ (across - 1.);\n \n float xoff = 0.0; //sin(time+y * 0.4) * 0.1;\n float yoff = 0.0; //cos(time+x * 0.4) * 0.1;\n float soff = 0.0; //sin(time + x * y*0.02) * 5.0;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 5.0 + soff;\n v_color = vec4(0.0, u, v, 1);\n\n}" + }, "screenshotURL": "data/images/images-86xo6rgk5recmjaqh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WWDNZ5h4zR4H9dqPn/art.json b/art/WWDNZ5h4zR4H9dqPn/art.json index 1a85453d..c7f23f99 100644 --- a/art/WWDNZ5h4zR4H9dqPn/art.json +++ b/art/WWDNZ5h4zR4H9dqPn/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minjae-yu", "avatarUrl": "https://avatars.githubusercontent.com/minjae-yu?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.24705882352941178,0.5294117647058824,1],\"shader\":\"//Name : MINJAE YU\\n//Assignment : Motion\\n//Course : CS250\\n//Term : Spring 2023\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.5;\\n float yoff = sin(time + x * 0.2);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * cos(time) * 10.;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(sin(time), 0,cos(time), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.24705882352941178, + 0.5294117647058824, + 1 + ], + "shader": "//Name : MINJAE YU\n//Assignment : Motion\n//Course : CS250\n//Term : Spring 2023\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.5;\n float yoff = sin(time + x * 0.2);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * cos(time) * 10.;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(sin(time), 0,cos(time), 1);\n}" + }, "screenshotURL": "data/images/images-s261xcsh36qdgv4ac-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WWd3sxvrHtZpty96D/art.json b/art/WWd3sxvrHtZpty96D/art.json index b8a99f4e..79cbe1c3 100644 --- a/art/WWd3sxvrHtZpty96D/art.json +++ b/art/WWd3sxvrHtZpty96D/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/dj-wonkar/easy-funk-edit\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n#define PI 3.14159\\n#define ACROSS 8.\\n#define DOWN 10.\\n#define PER_AREA ((ACROSS - 0.61) * (DOWN + 12.) *1.1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz,.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0,1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx-0.1, 0.14,0.5), c.y);\\n}\\n\\nvec4 area(float vertexId, float areaId) {\\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 1.)) * 2., 5.);\\n float thingId = floor(vertexId - 1.);\\n float col = mod(thingId, ACROSS +0.5);\\n float row = floor(thingId / (ACROSS - 10.5));\\n float u = col / ACROSS;\\n float v = row / DOWN;\\n float x = u * 2. - 1.;\\n float y = v * 1. - 1.;\\n \\n float d = length(vec2(x, y) *2.);\\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / 11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\\n float sv = d * 0.1;\\n float snd = texture2D(sound, vec2(su * 0.25 / 8. * areaId, sv)).a;\\n \\n float r = 0.4 + pow(snd, 8.) * -3.15;\\n float a = pointId / 5. * PI * (2. + thingId * 0.005 + time) / 12.;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = cs * y - r;\\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\\n \\n float hue = (time * 0.01) * areaId / 2.;\\n \\n return vec4(\\n vec2(x * snd, y * snd) - 0.1 / xy / aspect,\\n snd,\\n hue) * 2.5 ;\\n}\\n\\nvoid main() {\\n gl_PointSize =1.0;\\n\\n float areaId = floor(vertexId / PER_AREA);\\n float aCol = mod(areaId,2.);\\n float aRow = floor(areaId / 3.)/3.2;\\n float ax = (aCol - 0.01) - (0.4 / 2.) /12.2;\\n float ay = (aRow - 0.5) / 2. * 1.8 * .21;\\n float avId = mod(vertexId, PER_AREA)*112.01; \\n \\n vec4 a = area(avId, areaId);\\n \\n gl_Position = vec4(a.xy *- vec2(1.125, -0.4) * vec2(ax, ay), 0.01, 2);\\n float snd = a.z;\\n float hue = a.w;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/dj-wonkar/easy-funk-edit", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n#define PI 3.14159\n#define ACROSS 8.\n#define DOWN 10.\n#define PER_AREA ((ACROSS - 0.61) * (DOWN + 12.) *1.1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz,.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0,1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx-0.1, 0.14,0.5), c.y);\n}\n\nvec4 area(float vertexId, float areaId) {\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 1.)) * 2., 5.);\n float thingId = floor(vertexId - 1.);\n float col = mod(thingId, ACROSS +0.5);\n float row = floor(thingId / (ACROSS - 10.5));\n float u = col / ACROSS;\n float v = row / DOWN;\n float x = u * 2. - 1.;\n float y = v * 1. - 1.;\n \n float d = length(vec2(x, y) *2.);\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / 11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\n float sv = d * 0.1;\n float snd = texture2D(sound, vec2(su * 0.25 / 8. * areaId, sv)).a;\n \n float r = 0.4 + pow(snd, 8.) * -3.15;\n float a = pointId / 5. * PI * (2. + thingId * 0.005 + time) / 12.;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = cs * y - r;\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\n \n float hue = (time * 0.01) * areaId / 2.;\n \n return vec4(\n vec2(x * snd, y * snd) - 0.1 / xy / aspect,\n snd,\n hue) * 2.5 ;\n}\n\nvoid main() {\n gl_PointSize =1.0;\n\n float areaId = floor(vertexId / PER_AREA);\n float aCol = mod(areaId,2.);\n float aRow = floor(areaId / 3.)/3.2;\n float ax = (aCol - 0.01) - (0.4 / 2.) /12.2;\n float ay = (aRow - 0.5) / 2. * 1.8 * .21;\n float avId = mod(vertexId, PER_AREA)*112.01; \n \n vec4 a = area(avId, areaId);\n \n gl_Position = vec4(a.xy *- vec2(1.125, -0.4) * vec2(ax, ay), 0.01, 2);\n float snd = a.z;\n float hue = a.w;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-v83g9wskj1yod6e59-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WXAP9xy4D98Qz6J8f/art.json b/art/WXAP9xy4D98Qz6J8f/art.json index 2ea9287a..d2ad317e 100644 --- a/art/WXAP9xy4D98Qz6J8f/art.json +++ b/art/WXAP9xy4D98Qz6J8f/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "robsouthgate4", "avatarUrl": "https://avatars.githubusercontent.com/robsouthgate4?s=200", - "settings": "{\"num\":500,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\n \\n float across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across); \\n float y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across -1.);\\n float v = y / (across - 1.);\\n \\n \\tfloat ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n\\tgl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n \\tgl_PointSize *= 20. / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\tv_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 500, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \tfloat down = floor(sqrt(vertexCount));\n \n \n float across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across); \n float y = floor(vertexId / across);\n \n \tfloat u = x / (across -1.);\n float v = y / (across - 1.);\n \n \tfloat ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n\tgl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n \tgl_PointSize *= 20. / across;\n \tgl_PointSize *= resolution.x / 600.;\n \tv_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-rew6f0ip4abwtbsen-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WYLzRpCTKdWsrCPkZ/art.json b/art/WYLzRpCTKdWsrCPkZ/art.json index 85a1ee65..5c53d88d 100644 --- a/art/WYLzRpCTKdWsrCPkZ/art.json +++ b/art/WYLzRpCTKdWsrCPkZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14800,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 850.;\\n float vertsPerSegment = 25.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float circlesPerRow = 33.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow) * 2.;\\n float cy = floor(circleId / circlesPerRow) * 2.;\\n \\n vec2 soundTexCoords = vec2(3, 3);\\n float sx = cx - circlesPerRow;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx, cy, 0, 0);\\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\\n \\n // scale\\n gl_Position *= scale(1. / 64.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 43, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 1.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 14800, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 850.;\n float vertsPerSegment = 25.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float circlesPerRow = 33.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow) * 2.;\n float cy = floor(circleId / circlesPerRow) * 2.;\n \n vec2 soundTexCoords = vec2(3, 3);\n float sx = cx - circlesPerRow;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx, cy, 0, 0);\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\n \n // scale\n gl_Position *= scale(1. / 64.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 43, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 1.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-0enzij7j6btlo410r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WZ4EToBv8LTc3N3Tn/art.json b/art/WZ4EToBv8LTc3N3Tn/art.json index 3ecf9d38..a3a5ec03 100644 --- a/art/WZ4EToBv8LTc3N3Tn/art.json +++ b/art/WZ4EToBv8LTc3N3Tn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "atomim", "avatarUrl": "https://avatars.githubusercontent.com/atomim?s=200", - "settings": "{\"num\":4311,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvec3 getPosition(float t){\\n float p_time=time*1.+97.;\\n float t2=t*20.;\\n t2+=0.01*sin(p_time)+(p_time-110.)*3.;//speed\\n float dist=20.+sin(t2*1.3)*5.;\\n return vec3(sin(t2+(1.-t)*2.+sin(t2*2.)*0.6)*dist,0.,cos(t2+(1.-t)*2.+sin(t2*2.)*0.7)*dist)*(1.2-t*t)*1.2//around\\n + vec3(0.,t2*2.+cos(t2)*15.+cos(t2*3.5)*5.,0.)-vec3(0.,(1.-t*t*t)*10.,0.)//forward\\n + vec3(sin(t2*2.3),sin(t2*1.32)+(t+1.)*(t-1.)*2.,sin(t2*3.6754))*(1.-t)*15.//tail movement\\n \\n\\t;\\n}\\n\\n\\nvec3 getDiff(float t){\\n\\treturn getPosition(t)-getPosition(t+0.21);\\n}\\n\\nvoid main() {\\n float point = vertexId;\\n float pos = float(vertexId+mod(vertexId,2.)) / vertexCount;\\n float side = mod(vertexId,2.);\\n \\n vec3 nor=vec3(0.);\\n for(int i=0;i<15;i++){\\n vec3 tmp=normalize(cross(normalize(getDiff(pos+0.1 *float(i))),normalize(getDiff(pos+0.1*(float(i)+1.)))));\\n if(!(tmp!=tmp))nor+=tmp;\\n }\\n \\n vec3 pos2=getPosition(pos)+normalize(nor)*side*3.;\\n\\t\\n\\n \\n vec3 xyz=pos2*0.02;\\n \\n gl_Position = vec4(xyz * 0.5, 1);\\n\\n v_color = min(vec4(2.),vec4(xyz.x,xyz.y,2,1))/max(0.,(-xyz.z*5.+5.));\\n}\"}", + "settings": { + "num": 4311, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvec3 getPosition(float t){\n float p_time=time*1.+97.;\n float t2=t*20.;\n t2+=0.01*sin(p_time)+(p_time-110.)*3.;//speed\n float dist=20.+sin(t2*1.3)*5.;\n return vec3(sin(t2+(1.-t)*2.+sin(t2*2.)*0.6)*dist,0.,cos(t2+(1.-t)*2.+sin(t2*2.)*0.7)*dist)*(1.2-t*t)*1.2//around\n + vec3(0.,t2*2.+cos(t2)*15.+cos(t2*3.5)*5.,0.)-vec3(0.,(1.-t*t*t)*10.,0.)//forward\n + vec3(sin(t2*2.3),sin(t2*1.32)+(t+1.)*(t-1.)*2.,sin(t2*3.6754))*(1.-t)*15.//tail movement\n \n\t;\n}\n\n\nvec3 getDiff(float t){\n\treturn getPosition(t)-getPosition(t+0.21);\n}\n\nvoid main() {\n float point = vertexId;\n float pos = float(vertexId+mod(vertexId,2.)) / vertexCount;\n float side = mod(vertexId,2.);\n \n vec3 nor=vec3(0.);\n for(int i=0;i<15;i++){\n vec3 tmp=normalize(cross(normalize(getDiff(pos+0.1 *float(i))),normalize(getDiff(pos+0.1*(float(i)+1.)))));\n if(!(tmp!=tmp))nor+=tmp;\n }\n \n vec3 pos2=getPosition(pos)+normalize(nor)*side*3.;\n\t\n\n \n vec3 xyz=pos2*0.02;\n \n gl_Position = vec4(xyz * 0.5, 1);\n\n v_color = min(vec4(2.),vec4(xyz.x,xyz.y,2,1))/max(0.,(-xyz.z*5.+5.));\n}" + }, "screenshotURL": "data/images/images-dds4ppnhrsidjttxp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WZNDshPHXJPBR52fb/art.json b/art/WZNDshPHXJPBR52fb/art.json index 08b6df40..c5f0080b 100644 --- a/art/WZNDshPHXJPBR52fb/art.json +++ b/art/WZNDshPHXJPBR52fb/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/lio-mass-it-apsara-mas-frequency-original-mix-open-your-mind-music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 11.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.7;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.15 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0-mouse.x, 1.0+mouse.x );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 0.20, 1.3*mouse.r, mouse.t*0.6 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.;//0.5 + over * 0.7;\\n float sat = step(0.75,s2);\\n float val = pow(s2, 16.);\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 11.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 2.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0.1, 0.30, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.3;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 020 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/lio-mass-it-apsara-mas-frequency-original-mix-open-your-mind-music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(1.0, 1.2, 11.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.7;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.15 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0-mouse.x, 1.0+mouse.x );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 0.20, 1.3*mouse.r, mouse.t*0.6 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.0, 0.2, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.;//0.5 + over * 0.7;\n float sat = step(0.75,s2);\n float val = pow(s2, 16.);\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 11.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 2.8;\n \n \tvec3 vCameraTarget = vec3( 0.1, 0.30, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.3;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 020 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-vs3jnysqkizh56ms4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WbN969kWgnCsYXofi/art.json b/art/WbN969kWgnCsYXofi/art.json index cf7a6723..bc092ab5 100644 --- a/art/WbN969kWgnCsYXofi/art.json +++ b/art/WbN969kWgnCsYXofi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chris-camplin/htaf30\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n float v=vertexId/30.0;\\n int num=int(mouse.x*10.0+10.0);\\n int den=int(exp(mouse.y*3.0+3.0));\\n float frac=1.0-float(num)/float(den);\\n vec2 xy=vec2(sin(v),cos(v)*sin(v*frac))/2.0;\\n for(int i = 0; i < 2; i++) {\\n xy*=abs(xy)/dot(xy, xy)-vec2(frac);\\n }\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n v_color = vec4(0,0,0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chris-camplin/htaf30", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n float v=vertexId/30.0;\n int num=int(mouse.x*10.0+10.0);\n int den=int(exp(mouse.y*3.0+3.0));\n float frac=1.0-float(num)/float(den);\n vec2 xy=vec2(sin(v),cos(v)*sin(v*frac))/2.0;\n for(int i = 0; i < 2; i++) {\n xy*=abs(xy)/dot(xy, xy)-vec2(frac);\n }\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(xy * aspect, 0, 1);\n v_color = vec4(0,0,0, 1);\n}" + }, "screenshotURL": "data/images/images-aj17rdnpw6vpj68vg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WcpXFp2FfMH7gwc6m/art.json b/art/WcpXFp2FfMH7gwc6m/art.json index 27001815..9cd2af47 100644 --- a/art/WcpXFp2FfMH7gwc6m/art.json +++ b/art/WcpXFp2FfMH7gwc6m/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":52625,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Audio Reactive\\n//cs250\\n//spring2023\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount /down);\\n \\n \\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1*PI;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2 /PI;\\n \\n float xoff2=texture2D(sound,vec2(xoff * .05, xoff * .25)).a -0.;\\n \\n float ux = u * 2. - 1. + xoff2;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float su = abs(u -0.5) * 2.;\\n float sv = abs(v-0.5)*2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound,vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.)*30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x /600.;\\n \\n float pump = step(0.8,snd);\\n float hue = u * .1 + time * .1;\\n float sat = mix(0., 1.,pump);\\n float val = mix(.1, pow(snd + 0.2,5.), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 52625, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Audio Reactive\n//cs250\n//spring2023\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount /down);\n \n \tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1*PI;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2 /PI;\n \n float xoff2=texture2D(sound,vec2(xoff * .05, xoff * .25)).a -0.;\n \n float ux = u * 2. - 1. + xoff2;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float su = abs(u -0.5) * 2.;\n float sv = abs(v-0.5)*2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound,vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;\n \n gl_PointSize = pow(snd + 0.2, 5.)*30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x /600.;\n \n float pump = step(0.8,snd);\n float hue = u * .1 + time * .1;\n float sat = mix(0., 1.,pump);\n float val = mix(.1, pow(snd + 0.2,5.), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-qmm70n2wwv3b7o1vb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WfwMFdL3M3qEpW4zy/art.json b/art/WfwMFdL3M3qEpW4zy/art.json index 66417fa6..e8f1fd60 100644 --- a/art/WfwMFdL3M3qEpW4zy/art.json +++ b/art/WfwMFdL3M3qEpW4zy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Circles from Triangles\\n// Course : CS250\\n// Spring 2023\\n\\n\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main()\\n{\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u -.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n // [0, 1)\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \\n float sat = 1.;//mix(0.5, 1., pump);//mix(1., -10., 1. - av);\\n float val = mix(.4, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n hue += pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n} \"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Circles from Triangles\n// Course : CS250\n// Spring 2023\n\n\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main()\n{\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u -.5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n // [0, 1)\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \n float sat = 1.;//mix(0.5, 1., pump);//mix(1., -10., 1. - av);\n float val = mix(.4, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n hue += pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n} " + }, "screenshotURL": "data/images/images-72jahw7kmqc9ayvgd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WgAGyf4sc6LfsH2bd/art.json b/art/WgAGyf4sc6LfsH2bd/art.json index fabc53c0..c07b6495 100644 --- a/art/WgAGyf4sc6LfsH2bd/art.json +++ b/art/WgAGyf4sc6LfsH2bd/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "squiro", "username": "gman", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.21 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.21 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "az6MaCyqZHBJcj8u6", "views": { "$numberInt": "736" diff --git a/art/WhEz6A2JeXrzqtrhZ/art.json b/art/WhEz6A2JeXrzqtrhZ/art.json index 8f2deca0..dc81d72d 100644 --- a/art/WhEz6A2JeXrzqtrhZ/art.json +++ b/art/WhEz6A2JeXrzqtrhZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "colin3dmax", "avatarUrl": "https://avatars.githubusercontent.com/colin3dmax?s=200", - "settings": "{\"num\":9732,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.01568627450980392,0.047058823529411764,1],\"shader\":\"void main(){\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId , across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\n \\tfloat ux = u * 2. - 1.;\\n \\tfloat vy = v * 2. - 1.;\\n \\n\\tgl_Position = vec4(ux, vy, 0.0, 1.0);\\n \\n \\n \\tgl_PointSize = 10.0;\\n \\tgl_PointSize *= 20./across;\\n\\t \\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 9732, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.01568627450980392, + 0.047058823529411764, + 1 + ], + "shader": "void main(){\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId , across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \n \tfloat ux = u * 2. - 1.;\n \tfloat vy = v * 2. - 1.;\n \n\tgl_Position = vec4(ux, vy, 0.0, 1.0);\n \n \n \tgl_PointSize = 10.0;\n \tgl_PointSize *= 20./across;\n\t \n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-aaiqticnwvpz7avem-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Wjh598Fb6DK7AzRda/art.json b/art/Wjh598Fb6DK7AzRda/art.json index c5f1c5a9..e67d4411 100644 --- a/art/Wjh598Fb6DK7AzRda/art.json +++ b/art/Wjh598Fb6DK7AzRda/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.16470588235294117,0.22745098039215686,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.4;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x*y*0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.16470588235294117, + 0.22745098039215686, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.4;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x*y*0.02) * 5.0;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-8bhori5cu4ycozxfb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WnMNfRSbiZgpHz3xc/art.json b/art/WnMNfRSbiZgpHz3xc/art.json index ce3902b3..f6cefaf9 100644 --- a/art/WnMNfRSbiZgpHz3xc/art.json +++ b/art/WnMNfRSbiZgpHz3xc/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "julio", "avatarUrl": "https://lh4.googleusercontent.com/-_qIuSe0i5BM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3re8EYbgzIrdnuAsoVZKmC72bCiiKQ/mo/photo.jpg", - "settings": "{\"num\":15108,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\tfloat p = 0.8;\\n \\tfloat phi = radians(floor(vertexId / 45.0)) * 4.0;\\n \\tfloat theta = radians(mod(vertexId, 45.0)) * 4.0;\\n \\tfloat x = p * sin(phi) * cos(theta);\\n \\tfloat y = p * sin(phi) * sin(theta);\\n \\tfloat z = p * cos(phi);\\n \\n \\tmat4 rotz = mat4(cos(time), -sin(time), 0, 0,\\n sin(time), cos(time), 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n \\tmat4 rotx = mat4(1, 0, 0, 0,\\n 0, cos(time), -sin(time), 0,\\n 0, sin(time), cos(time), 0,\\n 0, 0, 0, 1);\\n \\tgl_Position = rotz * rotx * vec4(x, y, z, 1.0);\\n gl_PointSize = 2.0;\\n \\tv_color = vec4(0.949, 0.74, 0.2472, 1.0);\\n}\"}", + "settings": { + "num": 15108, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\tfloat p = 0.8;\n \tfloat phi = radians(floor(vertexId / 45.0)) * 4.0;\n \tfloat theta = radians(mod(vertexId, 45.0)) * 4.0;\n \tfloat x = p * sin(phi) * cos(theta);\n \tfloat y = p * sin(phi) * sin(theta);\n \tfloat z = p * cos(phi);\n \n \tmat4 rotz = mat4(cos(time), -sin(time), 0, 0,\n sin(time), cos(time), 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n \tmat4 rotx = mat4(1, 0, 0, 0,\n 0, cos(time), -sin(time), 0,\n 0, sin(time), cos(time), 0,\n 0, 0, 0, 1);\n \tgl_Position = rotz * rotx * vec4(x, y, z, 1.0);\n gl_PointSize = 2.0;\n \tv_color = vec4(0.949, 0.74, 0.2472, 1.0);\n}" + }, "screenshotURL": "data/images/images-a3mjywi1rwuzrv96w-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Wo2pq9yKds3mQYWaX/art.json b/art/Wo2pq9yKds3mQYWaX/art.json index 0b1d16dd..eb39d071 100644 --- a/art/Wo2pq9yKds3mQYWaX/art.json +++ b/art/Wo2pq9yKds3mQYWaX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":80376,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 * mouse.x\\n#define KP1 3.0 * mouse.y\\n#define K0 KP0 KP0//KParameter0 0.>>1000.\\n#define K1 KP1 KP1//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>10.\\n#define KP3 0.0//KParameter3 0.000>>0.5\\n#define KP4 5.0//KParameter4 0.000>>5.\\n#define KP5 10000.0//KParameter5 30.000>>100000.0\\n\\n\\n#define PI radians(180. -KP1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0.4, 0, 0,\\n 0, (2.*c), s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[2][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][2], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP5 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 10.01;\\n float end = 2.*sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv*4.,mouse.xy;\\n \\n vec3 eye = vec3(-s, s/KP1, 1)*KP1;//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 1.-s2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(s-0.5),1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(2, aspect, s) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.-s2)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) *-h + pow(s2+22.2, 5.) * KP3 - 110. * sign(h));\\n mat *= scale(vec3(1.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 1.3 + cgId * s /0.4;\\n float sat = 11. * step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 1.*s2;\\n v_color = vec4(hsv2rgb(vec3(hue*s *mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 80376, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 * mouse.x\n#define KP1 3.0 * mouse.y\n#define K0 KP0 KP0//KParameter0 0.>>1000.\n#define K1 KP1 KP1//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>10.\n#define KP3 0.0//KParameter3 0.000>>0.5\n#define KP4 5.0//KParameter4 0.000>>5.\n#define KP5 10000.0//KParameter5 30.000>>100000.0\n\n\n#define PI radians(180. -KP1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0.4, 0, 0,\n 0, (2.*c), s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[2][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][2], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP5 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 10.01;\n float end = 2.*sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv*4.,mouse.xy;\n \n vec3 eye = vec3(-s, s/KP1, 1)*KP1;//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 1.-s2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(s-0.5),1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(2, aspect, s) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.-s2)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) *-h + pow(s2+22.2, 5.) * KP3 - 110. * sign(h));\n mat *= scale(vec3(1.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 1.3 + cgId * s /0.4;\n float sat = 11. * step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 1.*s2;\n v_color = vec4(hsv2rgb(vec3(hue*s *mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-ce3lagigslp9dx0wl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Wova8i2L3H2AtWPkQ/art.json b/art/Wova8i2L3H2AtWPkQ/art.json index 71c37f6b..74ef2d04 100644 --- a/art/Wova8i2L3H2AtWPkQ/art.json +++ b/art/Wova8i2L3H2AtWPkQ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "theredbaron", "avatarUrl": "https://secure.gravatar.com/avatar/5b70bbd6b0bf84bc91de321b81122414?default=retro&size=200", - "settings": "{\"num\":12618,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c= vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n# define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = (floor(vertexCount / down));\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y/ (across - 1.);\\n \\n float xoffset = 0.; // sin(time + y * 0.2) * 0.1;\\n float yoffset = 0.;sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoffset;\\n float vy = v * 2. - 1. + yoffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su/ sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soffset = 0.; // sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soffset;\\n gl_PointSize *= 20./ across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.0) * 0.05;\\n float sat = mix(0., 1., pump);//mix(1., -10.0, av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color= vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 12618, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c= vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n# define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = (floor(vertexCount / down));\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y/ (across - 1.);\n \n float xoffset = 0.; // sin(time + y * 0.2) * 0.1;\n float yoffset = 0.;sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoffset;\n float vy = v * 2. - 1. + yoffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su/ sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soffset = 0.; // sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soffset;\n gl_PointSize *= 20./ across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.0) * 0.05;\n float sat = mix(0., 1., pump);//mix(1., -10.0, av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n v_color= vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-751rwpodvlljz1xfl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WrX5cRT7BypxGrBFk/art.json b/art/WrX5cRT7BypxGrBFk/art.json index b71929b3..5ba314fe 100644 --- a/art/WrX5cRT7BypxGrBFk/art.json +++ b/art/WrX5cRT7BypxGrBFk/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Colors\\n// CS250 \\n// Spring/2022\\n\\nvec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time *1.1+ x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time*1.2 + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u*0.1+sin(time*1.3+v*20.)*0.05;\\n float sat = 1.;\\n float val = sin(time *1.4 + v*u*20.0)*0.5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Colors\n// CS250 \n// Spring/2022\n\nvec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time *1.1+ x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time*1.2 + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u*0.1+sin(time*1.3+v*20.)*0.05;\n float sat = 1.;\n float val = sin(time *1.4 + v*u*20.0)*0.5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}" + }, "screenshotURL": "data/images/images-aru8107anzhkgktyz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WriDgXxvrtaB7q77s/art.json b/art/WriDgXxvrtaB7q77s/art.json index 9665f51c..aebe026f 100644 --- a/art/WriDgXxvrtaB7q77s/art.json +++ b/art/WriDgXxvrtaB7q77s/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":89344,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09019607843137255,0.08235294117647059,0.09019607843137255,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle + 3. );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 2.); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], -0.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n\\n -0.1 -s, 0, 0, 0.1,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 2) /2.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. + 0.1;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.07;\\n pos = vec3(x, y +1., z +2. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.12, mod(circleId, 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.0203) * 1.4;\\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\\n float sat = 0.9 - circleId;\\n float val = .75;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9, 0.2));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 89344, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09019607843137255, + 0.08235294117647059, + 0.09019607843137255, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle + 3. );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 2.); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], -0.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n\n -0.1 -s, 0, 0, 0.1,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 2) /2.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. + 0.1;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.07;\n pos = vec3(x, y +1., z +2. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.12, mod(circleId, 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.0203) * 1.4;\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\n float sat = 0.9 - circleId;\n float val = .75;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9, 0.2));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-mm2uuteaknr0mli7v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WsESfm8ByGEmnFBkE/art.json b/art/WsESfm8ByGEmnFBkE/art.json index ad20a85c..93e58b9f 100644 --- a/art/WsESfm8ByGEmnFBkE/art.json +++ b/art/WsESfm8ByGEmnFBkE/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 ctr = vec2(0.5);\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\\n float xOff = sin(PI * count + x * 0.5) * 2.0;\\n float yOff = cos(PI * count + y * 0.5) * 4.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n float d = length(xy - ctr);\\n\\n gl_PointSize = snd * 80. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown * snd; \\n gl_PointSize *= resolution.x / 30. * xOff; \\n xy -= ctr;\\n xy *= rotate2D(snd * PI * 2.0 +s);\\n xy += ctr;\\n xy *= pow(xy, ctr + xy * d);\\n xy *= 3. * d;\\n //xy = fract(xy / 0.1);\\n xy -= ctr;\\n xy *= rotate2D(-snd * -PI * 2.0);\\n xy += ctr;\\n xy *= mouse;\\n ctr *= mouse;\\n vec4 pos = vec4(xy / yOff, xOff , 1.-xOff);\\n //pos *= fract(pos);\\n pos *= rotY(PI * 0.025 * s);\\n pos *= rotX(PI * 0.05 * s);\\n gl_Position = pos;\\n float hue = s;\\n hue = smoothstep(xy.x, xy.y, snd * s);\\n float sat = 1.0 - s;\\n float val = invV +s;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(PI * snd * s);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n \\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n vec2 ctr = vec2(0.5);\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\n float xOff = sin(PI * count + x * 0.5) * 2.0;\n float yOff = cos(PI * count + y * 0.5) * 4.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n float d = length(xy - ctr);\n\n gl_PointSize = snd * 80. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown * snd; \n gl_PointSize *= resolution.x / 30. * xOff; \n xy -= ctr;\n xy *= rotate2D(snd * PI * 2.0 +s);\n xy += ctr;\n xy *= pow(xy, ctr + xy * d);\n xy *= 3. * d;\n //xy = fract(xy / 0.1);\n xy -= ctr;\n xy *= rotate2D(-snd * -PI * 2.0);\n xy += ctr;\n xy *= mouse;\n ctr *= mouse;\n vec4 pos = vec4(xy / yOff, xOff , 1.-xOff);\n //pos *= fract(pos);\n pos *= rotY(PI * 0.025 * s);\n pos *= rotX(PI * 0.05 * s);\n gl_Position = pos;\n float hue = s;\n hue = smoothstep(xy.x, xy.y, snd * s);\n float sat = 1.0 - s;\n float val = invV +s;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(PI * snd * s);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n \n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-hf8a6s6m74vo1af3o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WswhQKGQNaZzQhtqz/art.json b/art/WswhQKGQNaZzQhtqz/art.json index ecd3e5e5..9c0dcb75 100644 --- a/art/WswhQKGQNaZzQhtqz/art.json +++ b/art/WswhQKGQNaZzQhtqz/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/grimmlins/jeff-mills\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//axcx\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 1.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n //snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = pow(snd2, 6.);//pow(snd,2.);//mix(0.0, 1. - pow(snd, 4.), cgId);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n\\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 4.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n// mat *= ident();\\n// mat *= scale(aspect * (0.4 + sin(time) * 0.0));\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n// mat *= trans(offset);\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));//pow(snd, 0.5) * -6. * sign(offset.x));\\n mat *= uniformScale(0.05);// * sp);// + -sin((time + 0.5) * 6.) * 0.01);\\n mat *= rotZ(PI * 0.66 * 0.25);\\n mat *= uniformScale(\\n mix(1.,\\n mix(snd, snd2, mod(time * 60., 2.)) + sliceId * sin(time) * 0.5,\\n easeInOutSine(time * 0.1))\\n );\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = hash(mod(abs(gx - gAcross / 2.), 3.)) + time * 0.1;//tm * 0.0 + mix(0., .02, length(offset));\\n float sat = pow(snd + 1.- gy / gDown, 5.);\\n float val = pow(snd2, 4.);//pow(snd + pow(gy / gDown, 0.3), 15.);//step(0.90, snd); //0.;//mix(hash(groupId), 1.0, step(0.99, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/grimmlins/jeff-mills", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//axcx\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 1.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n //snd = pow(snd, mix(2., 0.5, su));\n \n \n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = pow(snd2, 6.);//pow(snd,2.);//mix(0.0, 1. - pow(snd, 4.), cgId);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 4.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n// mat *= ident();\n// mat *= scale(aspect * (0.4 + sin(time) * 0.0));\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n// mat *= trans(offset);\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));//pow(snd, 0.5) * -6. * sign(offset.x));\n mat *= uniformScale(0.05);// * sp);// + -sin((time + 0.5) * 6.) * 0.01);\n mat *= rotZ(PI * 0.66 * 0.25);\n mat *= uniformScale(\n mix(1.,\n mix(snd, snd2, mod(time * 60., 2.)) + sliceId * sin(time) * 0.5,\n easeInOutSine(time * 0.1))\n );\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = hash(mod(abs(gx - gAcross / 2.), 3.)) + time * 0.1;//tm * 0.0 + mix(0., .02, length(offset));\n float sat = pow(snd + 1.- gy / gDown, 5.);\n float val = pow(snd2, 4.);//pow(snd + pow(gy / gDown, 0.3), 15.);//step(0.90, snd); //0.;//mix(hash(groupId), 1.0, step(0.99, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-m9rvxrh9bdfjksi7l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WuRAKg77S8gD366A8/art.json b/art/WuRAKg77S8gD366A8/art.json index 20db2512..ba3327c0 100644 --- a/art/WuRAKg77S8gD366A8/art.json +++ b/art/WuRAKg77S8gD366A8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "polacienta", "avatarUrl": "https://avatars.githubusercontent.com/polacienta?s=200", - "settings": "{\"num\":42,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width=20.0;\\n float total =20.0;\\n \\n //x= r cos\\n //y= r*sin\\n // a= x/total*2pi\\n //radio = cuadrado\\n \\n float y=mod(vertexId+1.0,2.0);\\n float x=floor(vertexId/2.0);\\n \\n float angle= (x/total)*radians(360.0);\\n float radio= 2.0+y;\\n \\n float ux=radio*cos(angle);\\n float uy= radio*sin(angle);\\n \\n //float u= x/(width-1.0);\\n //float v= y/(width-1.0);\\n \\n //float xOffset= cos(time+y)*0.1;\\n //float yOffset= sin(time+x*0.1);\\n \\n //float ux=u*2.0-1.0+xOffset;\\n //float uy= v*2.0-1.0+yOffset;\\n \\n vec2 xy= vec2(ux,uy)*0.1;\\n \\n \\n gl_Position= vec4(xy,0.0,1.0);\\n v_color=vec4 (1.0,0.0,1.0,1.0);\\n gl_PointSize=10.0;\\n}\"}", + "settings": { + "num": 42, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width=20.0;\n float total =20.0;\n \n //x= r cos\n //y= r*sin\n // a= x/total*2pi\n //radio = cuadrado\n \n float y=mod(vertexId+1.0,2.0);\n float x=floor(vertexId/2.0);\n \n float angle= (x/total)*radians(360.0);\n float radio= 2.0+y;\n \n float ux=radio*cos(angle);\n float uy= radio*sin(angle);\n \n //float u= x/(width-1.0);\n //float v= y/(width-1.0);\n \n //float xOffset= cos(time+y)*0.1;\n //float yOffset= sin(time+x*0.1);\n \n //float ux=u*2.0-1.0+xOffset;\n //float uy= v*2.0-1.0+yOffset;\n \n vec2 xy= vec2(ux,uy)*0.1;\n \n \n gl_Position= vec4(xy,0.0,1.0);\n v_color=vec4 (1.0,0.0,1.0,1.0);\n gl_PointSize=10.0;\n}" + }, "screenshotURL": "data/images/images-1nycxnqka0p0kno13-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WurZPAe5kYjd8bBB6/art.json b/art/WurZPAe5kYjd8bBB6/art.json index 4b0fdbe0..4f4b9538 100644 --- a/art/WurZPAe5kYjd8bBB6/art.json +++ b/art/WurZPAe5kYjd8bBB6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "kcha", "avatarUrl": "https://secure.gravatar.com/avatar/393683f94ba2c18293b67ab3d3eb6f10?default=retro&size=200", - "settings": "{\"num\":786,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2627450980392157,0.49019607843137253,0.9607843137254902,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across); // 0, 1, 2, ..., 9\\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 786, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2627450980392157, + 0.49019607843137253, + 0.9607843137254902, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across); // 0, 1, 2, ..., 9\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-wqix1rs8sm0mzovz8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/WvKKxjSusH6cFyYcx/art.json b/art/WvKKxjSusH6cFyYcx/art.json index aba688ec..a9385c4e 100644 --- a/art/WvKKxjSusH6cFyYcx/art.json +++ b/art/WvKKxjSusH6cFyYcx/art.json @@ -22,7 +22,19 @@ "origId": "wTaKE9X796qNFqgEM", "name": "neurovelho2", "username": "visy", - "settings": "{\"num\":59825,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float NUM_SEGMENTS =2.0;\\n float NUM_POINTS = (NUM_SEGMENTS * 1.0);\\n float STEP = time*0.0001;\\n if (STEP > 0.003) STEP = 0.003;\\n float localTime = time*0.1 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * localTime*0.0001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(1.0-b, 1.0-c*10.0, 1.0-s*10.0, 1);\\n}\"}", + "settings": { + "num": 59825, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvoid main() {\n float NUM_SEGMENTS =2.0;\n float NUM_POINTS = (NUM_SEGMENTS * 1.0);\n float STEP = time*0.0001;\n if (STEP > 0.003) STEP = 0.003;\n float localTime = time*0.1 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * localTime*0.0001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(1.0-b, 1.0-c*10.0, 1.0-s*10.0, 1);\n}" + }, "screenshotDataId": "2TcZG9cG5pSJ7Sjgo", "views": { "$numberInt": "1601" diff --git a/art/WwHWSfGf9LMF8vSAs/art.json b/art/WwHWSfGf9LMF8vSAs/art.json index f23619f5..2e070507 100644 --- a/art/WwHWSfGf9LMF8vSAs/art.json +++ b/art/WwHWSfGf9LMF8vSAs/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":11341,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles.\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n \\tfloat ux = floor(id/ 6.) + mod(id,2.);\\n \\tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\n \\n \\tfloat angle = ux / numCircleSegments * PI * 2.;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n\\n \\tfloat radius = vy + 1.;\\n \\n \\tfloat x = c * radius;\\n \\tfloat y = s * radius;\\n \\n \\treturn vec2(x,y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 36.;\\n \\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.5, av * .25)).a;\\n\\n\\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2,5.) + mix(1.,1.1,oddSlice);\\n \\n sc *= 20. / across ;\\n \\n vec4 pos = vec4(circleXY, 0 ,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03*sc);\\n mat *= rotZ(cos(time));\\n\\n \\n gl_Position = mat * pos* oddSlice;\\n \\n\\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n\\n \\n float pump = step(0.3, snd)* abs(sin(time));\\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1* oddSlice; //sin(time + v * 20.) * .05;\\n float sat = mix(0.5, 1., pump) * oddSlice;\\n float val = mix(.4, pow(snd + 0.2, 5.), pump );\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump* oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 11341, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles.\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n \tfloat ux = floor(id/ 6.) + mod(id,2.);\n \tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\n \n \tfloat angle = ux / numCircleSegments * PI * 2.;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n\n \tfloat radius = vy + 1.;\n \n \tfloat x = c * radius;\n \tfloat y = s * radius;\n \n \treturn vec2(x,y);\n}\n\n\nvoid main() {\n float numCircleSegments = 36.;\n \n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.5, av * .25)).a;\n\n\n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2,5.) + mix(1.,1.1,oddSlice);\n \n sc *= 20. / across ;\n \n vec4 pos = vec4(circleXY, 0 ,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03*sc);\n mat *= rotZ(cos(time));\n\n \n gl_Position = mat * pos* oddSlice;\n \n\n float soff = 1.;//sin(time + x * y * .02) * 5.; \n\n \n float pump = step(0.3, snd)* abs(sin(time));\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1* oddSlice; //sin(time + v * 20.) * .05;\n float sat = mix(0.5, 1., pump) * oddSlice;\n float val = mix(.4, pow(snd + 0.2, 5.), pump );\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump* oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-sadk8hul2ubhz5eqz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WxF9C4KTpRRskgmYF/art.json b/art/WxF9C4KTpRRskgmYF/art.json index a13c7d0b..14c01aa5 100644 --- a/art/WxF9C4KTpRRskgmYF/art.json +++ b/art/WxF9C4KTpRRskgmYF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":32875,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.08235294117647059,0.08235294117647059,1],\"shader\":\"\\n#define parameter0 0.//KParameter 0.>>6.\\n#define P2 -3.//KParameter -5.>>10.\\n#define P3 0.1//KParameter 0.1>>3.\\n#define P6 9.//KParameter 0.1>>10.\\n#define P5 1.//KParameter -1.>>1.\\n#define P4 0.5//KParameter 0.0>>1.\\n\\n//KVerticesNumber=880\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 12. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.25;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 12.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qx * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI - .525+parameter0, resolution.x / resolution.y, 1.2, 22.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mouse.x *3.0) + 2.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos,sin(1.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *.01;\\n float sat = P4;\\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 32875, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.08235294117647059, + 0.08235294117647059, + 1 + ], + "shader": "\n#define parameter0 0.//KParameter 0.>>6.\n#define P2 -3.//KParameter -5.>>10.\n#define P3 0.1//KParameter 0.1>>3.\n#define P6 9.//KParameter 0.1>>10.\n#define P5 1.//KParameter -1.>>1.\n#define P4 0.5//KParameter 0.0>>1.\n\n//KVerticesNumber=880\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 12. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.25;\n float down = numQuads / around;\n float quadId = floor(vertexId / 12.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qx * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI - .525+parameter0, resolution.x / resolution.y, 1.2, 22.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mouse.x *3.0) + 2.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos,sin(1.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *.01;\n float sat = P4;\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-fkiqkxuysvhgobuwt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WxsiG7yWNKj8rH2Qe/art.json b/art/WxsiG7yWNKj8rH2Qe/art.json index 36f19aaf..08d94784 100644 --- a/art/WxsiG7yWNKj8rH2Qe/art.json +++ b/art/WxsiG7yWNKj8rH2Qe/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/loose-connection/loose-connection-biche?in=pierre-schulte-1/sets/hightech\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvec2 modPolar(vec2 uv, float n, float _fact) { \\n\\tfloat a = atan(uv.x, uv.y);\\n\\tn = _fact*6.28 / n;\\n\\ta = mod(a + n * .5, n) - n * .5;\\n\\tfloat l = length(uv);\\n\\treturn l * vec2(cos(a), sin(a));\\n}\\n\\nvoid main ()\\n{\\n\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n //simfragCoord <=> gl_FragCoord in the vertex shader\\n \\n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (simfragCoord.x /vertexResolution.x);\\n float v = (simfragCoord.y /vertexResolution.y);\\n \\n //calculate coordinates in -1.>>1.0 space\\n float sizeFactor = 1.;\\n float fact = 2.*sizeFactor;\\n float ux = fact*(u - 0.5);\\n float vy = fact*(v - 0.5);\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n \\n vec2 p3 = vec2(ux , vy);\\n \\n /*\\n //https://www.shadertoy.com/view/XllGDH\\n\\n\\n\\tfloat t = 0.;//iTime/11.;\\n vec2 uv = (.2 + .05 * sin(t*1.1)) * simfragCoord.xy / vertexResolution.y + .2 * vec2(2.2+1.*sin(t), .4+.4*cos(t*.9));\\n \\n for (int i=0; i<11; ++i)\\n uv = abs(uv) / dot(uv,uv) - vec2( (0.2*sin(time)+.81)-.1*uv.y);\\n \\n\\tv_color = vec4(uv*uv, uv.y-uv.x, 1.);\\n */\\n \\n vec2 uv = vec2(gl_Position.x,gl_Position.y);//(2. * simfragCoord.xy - resolution) / resolution.y;\\n\\tuv = modPolar(uv, 3., snd2);\\n\\tvec3 p = vec3(uv, .5 * sin(time * 1.1));\\n\\tvec3 col = vec3(0.);\\n\\t\\n\\t\\n\\t\\n\\tfor (int i = 0; i < 8; i++) {\\n\\t\\tp = abs(abs(p) / dot(p, p) - vec3(.4, .6, 1.)) - .1;\\n\\t\\tcol.xyz = abs(vec3(1., 1., 1.) * p);\\n\\t}\\n \\t\\n\\tv_color = vec4(col, 1.);\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = (resolution.y/vertexResolution.y) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\\n\\n //v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/loose-connection/loose-connection-biche?in=pierre-schulte-1/sets/hightech", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvec2 modPolar(vec2 uv, float n, float _fact) { \n\tfloat a = atan(uv.x, uv.y);\n\tn = _fact*6.28 / n;\n\ta = mod(a + n * .5, n) - n * .5;\n\tfloat l = length(uv);\n\treturn l * vec2(cos(a), sin(a));\n}\n\nvoid main ()\n{\n\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n //simfragCoord <=> gl_FragCoord in the vertex shader\n \n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (simfragCoord.x /vertexResolution.x);\n float v = (simfragCoord.y /vertexResolution.y);\n \n //calculate coordinates in -1.>>1.0 space\n float sizeFactor = 1.;\n float fact = 2.*sizeFactor;\n float ux = fact*(u - 0.5);\n float vy = fact*(v - 0.5);\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n \n vec2 p3 = vec2(ux , vy);\n \n /*\n //https://www.shadertoy.com/view/XllGDH\n\n\n\tfloat t = 0.;//iTime/11.;\n vec2 uv = (.2 + .05 * sin(t*1.1)) * simfragCoord.xy / vertexResolution.y + .2 * vec2(2.2+1.*sin(t), .4+.4*cos(t*.9));\n \n for (int i=0; i<11; ++i)\n uv = abs(uv) / dot(uv,uv) - vec2( (0.2*sin(time)+.81)-.1*uv.y);\n \n\tv_color = vec4(uv*uv, uv.y-uv.x, 1.);\n */\n \n vec2 uv = vec2(gl_Position.x,gl_Position.y);//(2. * simfragCoord.xy - resolution) / resolution.y;\n\tuv = modPolar(uv, 3., snd2);\n\tvec3 p = vec3(uv, .5 * sin(time * 1.1));\n\tvec3 col = vec3(0.);\n\t\n\t\n\t\n\tfor (int i = 0; i < 8; i++) {\n\t\tp = abs(abs(p) / dot(p, p) - vec3(.4, .6, 1.)) - .1;\n\t\tcol.xyz = abs(vec3(1., 1., 1.) * p);\n\t}\n \t\n\tv_color = vec4(col, 1.);\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = (resolution.y/vertexResolution.y) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\n\n //v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-4e6xdihx2yx6yrc6c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WyifmdumQtSdpJgcb/art.json b/art/WyifmdumQtSdpJgcb/art.json index b24d2e11..6a5af42d 100644 --- a/art/WyifmdumQtSdpJgcb/art.json +++ b/art/WyifmdumQtSdpJgcb/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/world-records-dnb/thoughts\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down); \\n\\n float x = mod(vertexId, across); \\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float snd = texture2D(sound, vec2(u * y * 0.0001, v * 0.25)).a;\\n \\n float yOffset = pow(snd, 3.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float uy = v * 2.0 - 1.0 + yOffset - 0.75;\\n \\n vec2 xy = vec2(ux, uy) * 0.5;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 200.0 / across; \\n \\n float hue = v * u * pow(snd, 2.0); \\n float sat = 1.0 + v * u * snd;\\n float value = pow(snd + 0.25, 5.0); \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1); \\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/world-records-dnb/thoughts", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down); \n\n float x = mod(vertexId, across); \n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float snd = texture2D(sound, vec2(u * y * 0.0001, v * 0.25)).a;\n \n float yOffset = pow(snd, 3.0);\n \n float ux = u * 2.0 - 1.0;\n float uy = v * 2.0 - 1.0 + yOffset - 0.75;\n \n vec2 xy = vec2(ux, uy) * 0.5;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 200.0 / across; \n \n float hue = v * u * pow(snd, 2.0); \n float sat = 1.0 + v * u * snd;\n float value = pow(snd + 0.25, 5.0); \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1); \n}" + }, "screenshotURL": "data/images/images-9yn4vpfiik3fufu2p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/WzeZofWAP8mZ2aNBz/art.json b/art/WzeZofWAP8mZ2aNBz/art.json index 6f131608..3f1d7cf4 100644 --- a/art/WzeZofWAP8mZ2aNBz/art.json +++ b/art/WzeZofWAP8mZ2aNBz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount));\\n \\tfloat cols = floor(vertexCount / rows);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.1;\\n \\tfloat yOff = cos(time + x * 0.25) * 0.1;\\n \\tfloat soff = cos(time * 1.4 + x * y * 0.0005) * 0.5;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n vec4 pos = vec4(ux, vy, s, 1);\\n \\tpos*=rotY(PI*time*.125);\\n \\tpos*=rotX(PI*time*.125);\\n\\tgl_Position = pos;\\n \\tgl_PointSize = 3.0 + soff; \\n \\t//gl_PointSize *= 20.0 / cols; \\n \\t//gl_PointSize *= resolution.x / 600.; \\n float hue = s;\\n hue = smoothstep(x, y, xOff);\\n float sat = v * xOff;\\n float val = u;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(PI * soff);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n\\n v_color = finalColor;\\n }\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount));\n \tfloat cols = floor(vertexCount / rows);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.1;\n \tfloat yOff = cos(time + x * 0.25) * 0.1;\n \tfloat soff = cos(time * 1.4 + x * y * 0.0005) * 0.5;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n vec4 pos = vec4(ux, vy, s, 1);\n \tpos*=rotY(PI*time*.125);\n \tpos*=rotX(PI*time*.125);\n\tgl_Position = pos;\n \tgl_PointSize = 3.0 + soff; \n \t//gl_PointSize *= 20.0 / cols; \n \t//gl_PointSize *= resolution.x / 600.; \n float hue = s;\n hue = smoothstep(x, y, xOff);\n float sat = v * xOff;\n float val = u;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(PI * soff);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n\n v_color = finalColor;\n }" + }, "screenshotURL": "data/images/images-f7hwnjpkxtelesz4b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/X2DfX3YZvHG8KrEhj/art.json b/art/X2DfX3YZvHG8KrEhj/art.json index f21374c8..37f1991d 100644 --- a/art/X2DfX3YZvHG8KrEhj/art.json +++ b/art/X2DfX3YZvHG8KrEhj/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jonnynewo", "avatarUrl": "https://secure.gravatar.com/avatar/2ee3fa32fc5fe43ece0455f4e45b5c3b?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.011764705882352941,0.2196078431372549,1],\"shader\":\"void main() {\\n \\n // float across = 10.; // corr to res of 100\\n // float across = 31.; // corr to res of 1000\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down); \\n \\t\\n // needs to be changed to square root (sqrt) of total res (100, 1000, etc)\\n // this was coded to adjust to resolution changes from manually setting sqrt\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\t// NOTE: has to be in decimal becase \\\"vertexId\\\" is already a\\n \\t// decimal and you can only divide decimals by decimals\\n \\t// MOD - divides, but only keeps the remainder\\n \\t// floor - is a function that throws away the remainder\\n \\n float u = x / (across -1.); // the minus one makes it symmetrical\\n float v = y / (across -1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\t// setting to normalized device coordinate, X,Y,Z\\n \\t// gl_Position = vec4(0, 0, 0, 1); orig code\\n \\t// gl_Position = vec4(u, v, 0, 1); 1st pass\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0; \\t// refers to 10 pixels!\\n gl_PointSize *= 20. / across; // dividing point size by number across, divided by how many we have across now\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1); \\t// refers to R, G, B, alpha\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.011764705882352941, + 0.2196078431372549, + 1 + ], + "shader": "void main() {\n \n // float across = 10.; // corr to res of 100\n // float across = 31.; // corr to res of 1000\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down); \n \t\n // needs to be changed to square root (sqrt) of total res (100, 1000, etc)\n // this was coded to adjust to resolution changes from manually setting sqrt\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \t// NOTE: has to be in decimal becase \"vertexId\" is already a\n \t// decimal and you can only divide decimals by decimals\n \t// MOD - divides, but only keeps the remainder\n \t// floor - is a function that throws away the remainder\n \n float u = x / (across -1.); // the minus one makes it symmetrical\n float v = y / (across -1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \t// setting to normalized device coordinate, X,Y,Z\n \t// gl_Position = vec4(0, 0, 0, 1); orig code\n \t// gl_Position = vec4(u, v, 0, 1); 1st pass\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0; \t// refers to 10 pixels!\n gl_PointSize *= 20. / across; // dividing point size by number across, divided by how many we have across now\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1); \t// refers to R, G, B, alpha\n \n}" + }, "screenshotURL": "data/images/images-6jmy3jy0sl553997e-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/X4p3ogDk8g7e5CvmA/art.json b/art/X4p3ogDk8g7e5CvmA/art.json index faab8120..fd0f1cd9 100644 --- a/art/X4p3ogDk8g7e5CvmA/art.json +++ b/art/X4p3ogDk8g7e5CvmA/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n parameter3, c, s, 0,\\n 0, -s, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 1,\\n s, 0, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians/parameter5);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0.2,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, parameter7 *4.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337 * parameter6);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 2.5 - parameter5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1. , mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (parameter2 - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd / 3. * parameter3);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.5, snd);\\n float hue = 1. + cgId * 1. + pump * .9;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + (2. * parameter6), 2. );\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(2), pump);\\n v_color.rgb *= v_color.a * (parameter5 );\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n parameter3, c, s, 0,\n 0, -s, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 1,\n s, 0, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians/parameter5);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0.2,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, parameter7 *4.3137));\n\treturn fract(p2.x * p2.y * 95.4337 * parameter6);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 2.5 - parameter5);\n mat *= rotZ(time * 0.1 * mix(-1., 1. , mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (parameter2 - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd / 3. * parameter3);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.5, snd);\n float hue = 1. + cgId * 1. + pump * .9;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + (2. * parameter6), 2. );\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(2), pump);\n v_color.rgb *= v_color.a * (parameter5 );\n}\n\n" + }, "screenshotURL": "data/images/images-atvk1btbynkev6gw1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/X74uYKiDLZJmqhLnh/art.json b/art/X74uYKiDLZJmqhLnh/art.json index e1f9a4ec..25db6fef 100644 --- a/art/X74uYKiDLZJmqhLnh/art.json +++ b/art/X74uYKiDLZJmqhLnh/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "Planet Polygon", "username": "P_Malin", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/feuerhaus/donauwalzer-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7372549019607844,0.7372549019607844,0.7372549019607844,1],\"shader\":\"// Planet Polygon - @P_Malin\\n\\n// Switch the primitive type to LINES to see how the background sun flare is rendered!\\n\\nfloat g_cameraFar = 8000.0;\\n\\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\n\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\nfloat GetCosSunRadius( vec3 vCameraPos )\\n{\\n \\tfloat d = length( vCameraPos - GetSunPosition() );\\n \\treturn 100.0 / d;\\n}\\n\\nfloat GetSunIntensity( vec3 vCameraPos )\\n{\\n \\tfloat d = length( vCameraPos - GetSunPosition() );\\n \\treturn 1000.0 / (d * d);\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n\\tfloat fGloss;\\n};\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = surfaceInfo.fGloss;\\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\\n}\\n\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n AddDirectionalLight( GetSunDir(vCameraPos), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor, float fExposure )\\n{\\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n\\tfloat fAlpha;\\n};\\n\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir(vCameraPos) );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity( vCameraPos ) / pow(fShade, 1.5);\\n \\n return vec3( fShade * g_sunColor ); \\n}\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t32.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(vCameraPos), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos, vCameraPos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0.0) && (fMinDist < 100.0 ) )\\n {\\n \\tfShadowAttn = (fClosestDist2 - fSphereRadius2) + 10.0;\\n \\tfShadowAttn *= 0.025;\\n \\tfShadowAttn = clamp( fShadowAttn, 0.0, 1.0);\\n }\\n\\t} \\n \\n \\treturn fShadowAttn;\\n}\\n\\n#define g_ringSegments \\t\\t\\t128.0\\n#define g_ringQuads \\t\\t\\t( g_ringSegments * 3.0 )\\n#define g_ringVertexCount \\t\\t( g_ringQuads * 6.0 )\\n\\nvoid GenerateRingVertex( const float vertexIndex, const vec3 vCameraPos, PlanetInfo planetInfo, out SceneVertex outSceneVertex, float fInnerRadius, float fOuterRadius, float fRandom )\\n{\\n vec2 vDim = vec2( g_ringSegments, 3 );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vUV );\\n\\n \\tvec3 vRingPos;\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\n \\tfloat fRadiusPos = vUV.y;\\n \\n \\tif( vUV.y < 0.5 ) fRadiusPos = 0.0; else fRadiusPos = 1.0;\\n\\n \\n \\tfloat fRadius = fInnerRadius + fRadiusPos * (fOuterRadius - fInnerRadius);\\n\\n \\tif ( vUV.y < 0.01 ) fRadius-= 0.02;\\n \\tif ( vUV.y > 0.99 ) fRadius+= 0.02;\\n \\n \\tvRingPos.y = 0.0;\\n \\tvRingPos.x = sin( fHeading ) * fRadius;\\n \\tvRingPos.z = cos( fHeading ) * fRadius;\\n \\n outSceneVertex.vWorldPos = PlanetPosToWorld( planetInfo, vRingPos );\\n \\n \\tfloat fShadow = GetPlanetShadow( outSceneVertex.vWorldPos, vCameraPos, planetInfo );\\n \\n \\tfloat fAlpha = ( fRandom * 0.5 + 0.5);\\n\\tfAlpha = fAlpha * fAlpha;\\n \\n \\tvec3 vAlbedo = mix( planetInfo.vRingColor0, planetInfo.vRingColor1, fRandom );\\n \\n \\tSurfaceInfo surfaceInfo;\\n \\tsurfaceInfo.vPos = outSceneVertex.vWorldPos;\\n \\tsurfaceInfo.vNormal = PlanetNormalToWorld( planetInfo, vec3(0.0, 1.0, 0.0) );\\n \\tsurfaceInfo.fGloss = 20.0;\\n\\n outSceneVertex.vColor = LightSurface( surfaceInfo, vCameraPos, vAlbedo, fShadow );\\n\\n \\t// Hack lighting from other side\\n \\tvec3 vCameraDir = vCameraPos - surfaceInfo.vPos;\\n \\tvCameraDir = reflect( vCameraDir, surfaceInfo.vNormal );\\n \\tvec3 otherSideCameraPos = vCameraDir + surfaceInfo.vPos;\\n outSceneVertex.vColor += LightSurface( surfaceInfo, otherSideCameraPos, vAlbedo, fShadow ) * 0.1;\\n\\n \\tfAlpha *= 1.0 - abs( vUV.y * 2.0 - 1.0 );\\n \\n \\tfloat NdotV = normalize(vCameraPos).y;\\n \\tfAlpha = mix( fAlpha, 1.0, exp2( abs(NdotV) * -5.0 ) );\\n \\n \\toutSceneVertex.fAlpha = fAlpha;\\n} \\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\tfloat orbitAngle = time * 0.4 + 2.5;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tPlanetInfo planetInfo;\\n \\n#if 1\\n \\tplanetInfo.vSurfaceColor0 = vec3(0.36, 0.16, 0.0001);\\n \\tplanetInfo.vSurfaceColor1 = vec3(1.0, 0.36, 0.000001);\\n \\n \\tplanetInfo.textureScale = 100.0;\\n planetInfo.texturePersistence = 0.5;\\n \\tplanetInfo.surfaceType = 0.3;\\n \\n \\n \\tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n \\tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n \\n \\tplanetInfo.hasRings = true;\\n \\n \\tplanetInfo.vOrigin = vec3(0.0);\\n \\tplanetInfo.fRadius = 5.0;\\n \\n \\tplanetInfo.fSegments = 32.0;\\n \\tplanetInfo.fSlices = 48.0;\\n \\n \\tplanetInfo.iMoonCount = 10;\\n#else\\n \\tplanetInfo.vSurfaceColor0 = vec3(0.01, 0.01, 0.5);\\n \\tplanetInfo.vSurfaceColor1 = vec3(0.01, 1.0, 0.01);\\n \\n \\tplanetInfo.textureScale = 16.0;\\n planetInfo.texturePersistence = 0.5;\\n \\tplanetInfo.surfaceType = 0.8;\\n \\n \\n \\tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n \\tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n \\n \\tplanetInfo.hasRings = false;\\n \\n \\tplanetInfo.vOrigin = vec3(0.0);\\n \\tplanetInfo.fRadius = 0.1;\\n \\n \\tplanetInfo.fSegments = 32.0;\\n \\tplanetInfo.fSlices = 48.0;\\n \\n \\tplanetInfo.iMoonCount = 1;\\n#endif \\n \\n \\tfloat fOrbitDistance = (planetInfo.fRadius * 2.0) + exp2( fMouseX * 20.0 );\\n \\n \\tvec3 vCameraPos = vec3( sin(orbitAngle), 0.2 + vMouse.y * 0.5, cos(orbitAngle) ) * fOrbitDistance;\\n \\tvec3 vCameraTarget = vec3( 0.0, planetInfo.fRadius * 0.2, 0.0 );\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\t// Backdrop\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n\\n \\t// Stars\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_starVertexCount )\\n {\\n \\tGenerateStarVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_starVertexCount;\\n \\n \\t// Planet\\n \\tfloat fPlanetVertexCount = GetPlanetVertexCount(planetInfo);\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < fPlanetVertexCount )\\n {\\n \\tGeneratePlanetVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex );\\n }\\n \\tvertexIndex -= fPlanetVertexCount;\\n\\n \\t// Moon \\n \\tconst int kMaxMoonCount = 5;\\n \\tfloat fMoonDist = planetInfo.fRadius * 6.0;\\n \\tfor( int moonIndex=0; moonIndex < kMaxMoonCount; moonIndex++ )\\n {\\n \\tif(moonIndex < planetInfo.iMoonCount)\\n {\\n PlanetInfo moonInfo;\\n\\n moonInfo.vSurfaceColor0 = vec3(0.7);\\n moonInfo.vSurfaceColor1 = vec3(0.5);\\n\\n moonInfo.textureScale = 100.0;\\n moonInfo.texturePersistence = 0.5;\\n moonInfo.surfaceType = 0.9;\\n\\n\\n moonInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n moonInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n\\n moonInfo.hasRings = false;\\n\\n float fAngle = hash11(fMoonDist) * 12.345 + time * 0.1 / fMoonDist;\\n moonInfo.vOrigin = vec3(sin(fAngle), 0.0, cos(fAngle)) * fMoonDist;\\n moonInfo.fRadius = planetInfo.fRadius * 0.025;\\n fMoonDist = fMoonDist * 1.8;\\n\\n moonInfo.fSegments = 16.0;\\n moonInfo.fSlices = 16.0;\\n\\n moonInfo.iMoonCount = 0;\\n \\n float fMoonVertexCount = GetPlanetVertexCount(moonInfo);\\n if ( vertexIndex >= 0.0 && vertexIndex < fMoonVertexCount )\\n {\\n GeneratePlanetVertex( vertexIndex, vCameraPos, moonInfo, sceneVertex );\\n }\\n vertexIndex -= fMoonVertexCount;\\n \\n } \\n }\\n \\n \\n \\t// Ring\\n \\tif ( planetInfo.hasRings )\\n {\\n float fRingInner = 8.0;\\n float fRingSize = 2.0;\\n float fRingSeed = 0.0; \\t\\n for ( int ringIndex = 0; ringIndex < 6; ringIndex++ )\\n {\\n if ( vertexIndex >= 0.0 && vertexIndex < g_ringVertexCount )\\n {\\n GenerateRingVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex, fRingInner, fRingInner + fRingSize, hash11(fRingInner) );\\n }\\n vertexIndex -= g_ringVertexCount;\\n\\n fRingInner += fRingSize;\\n fRingInner += 0.02 + (sin( fRingSeed * 123.432 ) * 0.5 + 0.5) * 0.25;\\n float fSizeRandom = sin( fRingSeed * 423.432 ) * 0.5 + 0.5;\\n fRingSize = 0.1 + fSizeRandom * fSizeRandom * 2.0;\\n fRingSeed += 1.0;\\n }\\n }\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n sceneVertex.vWorldPos = vec3(0.0);\\n sceneVertex.vColor = vec3(0.0);\\n sceneVertex.fAlpha = 0.0;\\n }\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tvec3 vFinalColor = sceneVertex.vColor;\\n \\n \\tvFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \\n \\n \\tfloat VdotL = dot( vCameraForwards, -GetSunDir(vCameraPos) );\\n \\n \\t// Adjust exposure if we are looking towards the sun\\n \\tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\\n \\n \\tfExposure /= GetSunIntensity( vCameraPos ) * 100000.0;\\n \\n \\tfExposure += 0.5;\\n \\n \\tfExposure *= min( 1.0, time / 5.0 );\\n \\n \\tvFinalColor = PostProcess( vFinalColor, fExposure );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/feuerhaus/donauwalzer-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7372549019607844, + 0.7372549019607844, + 0.7372549019607844, + 1 + ], + "shader": "// Planet Polygon - @P_Malin\n\n// Switch the primitive type to LINES to see how the background sun flare is rendered!\n\nfloat g_cameraFar = 8000.0;\n\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\n\n\n#define PI radians( 180.0 )\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\n\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\nfloat GetCosSunRadius( vec3 vCameraPos )\n{\n \tfloat d = length( vCameraPos - GetSunPosition() );\n \treturn 100.0 / d;\n}\n\nfloat GetSunIntensity( vec3 vCameraPos )\n{\n \tfloat d = length( vCameraPos - GetSunPosition() );\n \treturn 1000.0 / (d * d);\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n\tfloat fGloss;\n};\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = surfaceInfo.fGloss;\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\n}\n\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n AddDirectionalLight( GetSunDir(vCameraPos), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor, float fExposure )\n{\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n\tfloat fAlpha;\n};\n\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir(vCameraPos) );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity( vCameraPos ) / pow(fShade, 1.5);\n \n return vec3( fShade * g_sunColor ); \n}\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t32.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(vCameraPos), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos, vCameraPos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0.0) && (fMinDist < 100.0 ) )\n {\n \tfShadowAttn = (fClosestDist2 - fSphereRadius2) + 10.0;\n \tfShadowAttn *= 0.025;\n \tfShadowAttn = clamp( fShadowAttn, 0.0, 1.0);\n }\n\t} \n \n \treturn fShadowAttn;\n}\n\n#define g_ringSegments \t\t\t128.0\n#define g_ringQuads \t\t\t( g_ringSegments * 3.0 )\n#define g_ringVertexCount \t\t( g_ringQuads * 6.0 )\n\nvoid GenerateRingVertex( const float vertexIndex, const vec3 vCameraPos, PlanetInfo planetInfo, out SceneVertex outSceneVertex, float fInnerRadius, float fOuterRadius, float fRandom )\n{\n vec2 vDim = vec2( g_ringSegments, 3 );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vUV );\n\n \tvec3 vRingPos;\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \n \tfloat fRadiusPos = vUV.y;\n \n \tif( vUV.y < 0.5 ) fRadiusPos = 0.0; else fRadiusPos = 1.0;\n\n \n \tfloat fRadius = fInnerRadius + fRadiusPos * (fOuterRadius - fInnerRadius);\n\n \tif ( vUV.y < 0.01 ) fRadius-= 0.02;\n \tif ( vUV.y > 0.99 ) fRadius+= 0.02;\n \n \tvRingPos.y = 0.0;\n \tvRingPos.x = sin( fHeading ) * fRadius;\n \tvRingPos.z = cos( fHeading ) * fRadius;\n \n outSceneVertex.vWorldPos = PlanetPosToWorld( planetInfo, vRingPos );\n \n \tfloat fShadow = GetPlanetShadow( outSceneVertex.vWorldPos, vCameraPos, planetInfo );\n \n \tfloat fAlpha = ( fRandom * 0.5 + 0.5);\n\tfAlpha = fAlpha * fAlpha;\n \n \tvec3 vAlbedo = mix( planetInfo.vRingColor0, planetInfo.vRingColor1, fRandom );\n \n \tSurfaceInfo surfaceInfo;\n \tsurfaceInfo.vPos = outSceneVertex.vWorldPos;\n \tsurfaceInfo.vNormal = PlanetNormalToWorld( planetInfo, vec3(0.0, 1.0, 0.0) );\n \tsurfaceInfo.fGloss = 20.0;\n\n outSceneVertex.vColor = LightSurface( surfaceInfo, vCameraPos, vAlbedo, fShadow );\n\n \t// Hack lighting from other side\n \tvec3 vCameraDir = vCameraPos - surfaceInfo.vPos;\n \tvCameraDir = reflect( vCameraDir, surfaceInfo.vNormal );\n \tvec3 otherSideCameraPos = vCameraDir + surfaceInfo.vPos;\n outSceneVertex.vColor += LightSurface( surfaceInfo, otherSideCameraPos, vAlbedo, fShadow ) * 0.1;\n\n \tfAlpha *= 1.0 - abs( vUV.y * 2.0 - 1.0 );\n \n \tfloat NdotV = normalize(vCameraPos).y;\n \tfAlpha = mix( fAlpha, 1.0, exp2( abs(NdotV) * -5.0 ) );\n \n \toutSceneVertex.fAlpha = fAlpha;\n} \n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \tfloat orbitAngle = time * 0.4 + 2.5;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tPlanetInfo planetInfo;\n \n#if 1\n \tplanetInfo.vSurfaceColor0 = vec3(0.36, 0.16, 0.0001);\n \tplanetInfo.vSurfaceColor1 = vec3(1.0, 0.36, 0.000001);\n \n \tplanetInfo.textureScale = 100.0;\n planetInfo.texturePersistence = 0.5;\n \tplanetInfo.surfaceType = 0.3;\n \n \n \tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n \tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n \n \tplanetInfo.hasRings = true;\n \n \tplanetInfo.vOrigin = vec3(0.0);\n \tplanetInfo.fRadius = 5.0;\n \n \tplanetInfo.fSegments = 32.0;\n \tplanetInfo.fSlices = 48.0;\n \n \tplanetInfo.iMoonCount = 10;\n#else\n \tplanetInfo.vSurfaceColor0 = vec3(0.01, 0.01, 0.5);\n \tplanetInfo.vSurfaceColor1 = vec3(0.01, 1.0, 0.01);\n \n \tplanetInfo.textureScale = 16.0;\n planetInfo.texturePersistence = 0.5;\n \tplanetInfo.surfaceType = 0.8;\n \n \n \tplanetInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n \tplanetInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n \n \tplanetInfo.hasRings = false;\n \n \tplanetInfo.vOrigin = vec3(0.0);\n \tplanetInfo.fRadius = 0.1;\n \n \tplanetInfo.fSegments = 32.0;\n \tplanetInfo.fSlices = 48.0;\n \n \tplanetInfo.iMoonCount = 1;\n#endif \n \n \tfloat fOrbitDistance = (planetInfo.fRadius * 2.0) + exp2( fMouseX * 20.0 );\n \n \tvec3 vCameraPos = vec3( sin(orbitAngle), 0.2 + vMouse.y * 0.5, cos(orbitAngle) ) * fOrbitDistance;\n \tvec3 vCameraTarget = vec3( 0.0, planetInfo.fRadius * 0.2, 0.0 );\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \t// Backdrop\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n\n \t// Stars\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_starVertexCount )\n {\n \tGenerateStarVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_starVertexCount;\n \n \t// Planet\n \tfloat fPlanetVertexCount = GetPlanetVertexCount(planetInfo);\n \tif ( vertexIndex >= 0.0 && vertexIndex < fPlanetVertexCount )\n {\n \tGeneratePlanetVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex );\n }\n \tvertexIndex -= fPlanetVertexCount;\n\n \t// Moon \n \tconst int kMaxMoonCount = 5;\n \tfloat fMoonDist = planetInfo.fRadius * 6.0;\n \tfor( int moonIndex=0; moonIndex < kMaxMoonCount; moonIndex++ )\n {\n \tif(moonIndex < planetInfo.iMoonCount)\n {\n PlanetInfo moonInfo;\n\n moonInfo.vSurfaceColor0 = vec3(0.7);\n moonInfo.vSurfaceColor1 = vec3(0.5);\n\n moonInfo.textureScale = 100.0;\n moonInfo.texturePersistence = 0.5;\n moonInfo.surfaceType = 0.9;\n\n\n moonInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n moonInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n\n moonInfo.hasRings = false;\n\n float fAngle = hash11(fMoonDist) * 12.345 + time * 0.1 / fMoonDist;\n moonInfo.vOrigin = vec3(sin(fAngle), 0.0, cos(fAngle)) * fMoonDist;\n moonInfo.fRadius = planetInfo.fRadius * 0.025;\n fMoonDist = fMoonDist * 1.8;\n\n moonInfo.fSegments = 16.0;\n moonInfo.fSlices = 16.0;\n\n moonInfo.iMoonCount = 0;\n \n float fMoonVertexCount = GetPlanetVertexCount(moonInfo);\n if ( vertexIndex >= 0.0 && vertexIndex < fMoonVertexCount )\n {\n GeneratePlanetVertex( vertexIndex, vCameraPos, moonInfo, sceneVertex );\n }\n vertexIndex -= fMoonVertexCount;\n \n } \n }\n \n \n \t// Ring\n \tif ( planetInfo.hasRings )\n {\n float fRingInner = 8.0;\n float fRingSize = 2.0;\n float fRingSeed = 0.0; \t\n for ( int ringIndex = 0; ringIndex < 6; ringIndex++ )\n {\n if ( vertexIndex >= 0.0 && vertexIndex < g_ringVertexCount )\n {\n GenerateRingVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex, fRingInner, fRingInner + fRingSize, hash11(fRingInner) );\n }\n vertexIndex -= g_ringVertexCount;\n\n fRingInner += fRingSize;\n fRingInner += 0.02 + (sin( fRingSeed * 123.432 ) * 0.5 + 0.5) * 0.25;\n float fSizeRandom = sin( fRingSeed * 423.432 ) * 0.5 + 0.5;\n fRingSize = 0.1 + fSizeRandom * fSizeRandom * 2.0;\n fRingSeed += 1.0;\n }\n }\n \n \tif ( vertexIndex >= 0.0 )\n {\n sceneVertex.vWorldPos = vec3(0.0);\n sceneVertex.vColor = vec3(0.0);\n sceneVertex.fAlpha = 0.0;\n }\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tvec3 vFinalColor = sceneVertex.vColor;\n \n \tvFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \n \n \tfloat VdotL = dot( vCameraForwards, -GetSunDir(vCameraPos) );\n \n \t// Adjust exposure if we are looking towards the sun\n \tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\n \n \tfExposure /= GetSunIntensity( vCameraPos ) * 100000.0;\n \n \tfExposure += 0.5;\n \n \tfExposure *= min( 1.0, time / 5.0 );\n \n \tvFinalColor = PostProcess( vFinalColor, fExposure );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}\n" + }, "screenshotURL": "data/images/images-ap0k4nriqs0j3ezco-thumbnail.jpg", "views": { "$numberInt": "6288" diff --git a/art/XASP5MBqwovRLqzqg/art.json b/art/XASP5MBqwovRLqzqg/art.json index c6a91eb1..77b6410d 100644 --- a/art/XASP5MBqwovRLqzqg/art.json +++ b/art/XASP5MBqwovRLqzqg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\\n float r = sqrt(10. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\n float r = sqrt(10. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-quwpp2v0w25pc3xoy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XBTFxPgMSdyM7HXum/art.json b/art/XBTFxPgMSdyM7HXum/art.json index edf83c13..02744562 100644 --- a/art/XBTFxPgMSdyM7HXum/art.json +++ b/art/XBTFxPgMSdyM7HXum/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "alakar", "avatarUrl": "https://i1.sndcdn.com/avatars-000229270477-3hb23h-large.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ntreboot/touch\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//hsv to rgb\\nvec3 hsv2rgb(vec3 c){\\n c= vec3(c.x, clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0,3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix (k.xxx, clamp(p- k.xxx, 0.0, 1.0), c.y);\\n}\\n \\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n //float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12...\\n // 0 0 0 0 0 0 1 1 1 1 1 1 2\\n //\\t 0 1 0 1 0 1 0 1 0 1 0 1 0\\n //\\t 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12...\\n //\\t 0 0 1 1 2 2 3 3 4 4 5 5 6\\n //\\t 0 0 0 1 1 1 2 2 2 3 3 3 4\\n //\\t 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n //vec2 xy = vec2(x, y);\\n //gl_Position = vec4(xy * 0.1, 0, 1);\\n //v_color = vec4(1,0,0,1);\\n}\\n\\n//#if 0\\nvoid main(){\\n float numCircleSegments = 16.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 16.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x=mod(circleId, across);\\n float y=floor(circleId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff= 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff= 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n float sv = abs(v - 0.5) * 2.;\\n float su = abs(u - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n //float snd = texture2D(sound, vec2(su * .125 ,sv * .25)).a;\\n float snd = texture2D(sound, vec2(au * .125 ,av * .25)).a;\\n\\n \\n // mantener los circulos redondos\\n float aspect = resolution.x / resolution.y;\\n \\n //escala de los circulos\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.5);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 10. * sign(ux));\\n mat *= uniformScale(0.05 * sc);\\n \\n gl_Position = mat * pos;\\n \\n //caber dentro de la pantalla\\n //vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\\n \\n //gl_Position=vec4(ux,vy,0,1); \\n //gl_Position = vec4(xy, 0, 1) * vec4(1, aspect, 1, 1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n //gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff; \\n //gl_PointSize *= 20. / across;\\n //gl_PointSize *= resolution.x / 600.;\\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .1 + time * 0.5;//u * .1 + sin(time + v * 20.) * 0.05;\\n float sat = mix(0.5, 1., pump);//mix(1., 0., av);//1. - av;\\n float val =1.;mix(1., pow(snd + .2, 5.),pump);//snd; //sin(time + v * u *20.) * 0.5 + 0.5;\\n \\n hue = hue + oddSlice * 0.5;\\n val += oddSlice;\\n \\n v_color=vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n \\n}\\n//#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ntreboot/touch", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//hsv to rgb\nvec3 hsv2rgb(vec3 c){\n c= vec3(c.x, clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0,3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix (k.xxx, clamp(p- k.xxx, 0.0, 1.0), c.y);\n}\n \n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments){\n //float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12...\n // 0 0 0 0 0 0 1 1 1 1 1 1 2\n //\t 0 1 0 1 0 1 0 1 0 1 0 1 0\n //\t 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12...\n //\t 0 0 1 1 2 2 3 3 4 4 5 5 6\n //\t 0 0 0 1 1 1 2 2 2 3 3 3 4\n //\t 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n //vec2 xy = vec2(x, y);\n //gl_Position = vec4(xy * 0.1, 0, 1);\n //v_color = vec4(1,0,0,1);\n}\n\n//#if 0\nvoid main(){\n float numCircleSegments = 16.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 16.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x=mod(circleId, across);\n float y=floor(circleId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff= 0.;//sin(time + y * 0.2) * 0.1;\n float yoff= 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n float sv = abs(v - 0.5) * 2.;\n float su = abs(u - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n //float snd = texture2D(sound, vec2(su * .125 ,sv * .25)).a;\n float snd = texture2D(sound, vec2(au * .125 ,av * .25)).a;\n\n \n // mantener los circulos redondos\n float aspect = resolution.x / resolution.y;\n \n //escala de los circulos\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.5);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 10. * sign(ux));\n mat *= uniformScale(0.05 * sc);\n \n gl_Position = mat * pos;\n \n //caber dentro de la pantalla\n //vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\n \n //gl_Position=vec4(ux,vy,0,1); \n //gl_Position = vec4(xy, 0, 1) * vec4(1, aspect, 1, 1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n //gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff; \n //gl_PointSize *= 20. / across;\n //gl_PointSize *= resolution.x / 600.;\n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .1 + time * 0.5;//u * .1 + sin(time + v * 20.) * 0.05;\n float sat = mix(0.5, 1., pump);//mix(1., 0., av);//1. - av;\n float val =1.;mix(1., pow(snd + .2, 5.),pump);//snd; //sin(time + v * u *20.) * 0.5 + 0.5;\n \n hue = hue + oddSlice * 0.5;\n val += oddSlice;\n \n v_color=vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n \n}\n//#endif" + }, "screenshotURL": "data/images/images-99en3q31gv4zrfq0n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XBmtPpZobE3xxRQ9e/art.json b/art/XBmtPpZobE3xxRQ9e/art.json index 7ccf7ef3..3304f68d 100644 --- a/art/XBmtPpZobE3xxRQ9e/art.json +++ b/art/XBmtPpZobE3xxRQ9e/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "orange4glace", "avatarUrl": "https://avatars.githubusercontent.com/orange4glace?s=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n float t = vertexId / vertexCount * PI * 2.;\\n float t2 = vertexId / vertexCount * PI * 4.;\\n float m = mod(time, 4.) / 2.;\\n float y = cos(t);\\n float x= sin(t) * pow(sin(0.5 * t), m);\\n \\n gl_Position = vec4(x / resolution.x * 800., y / resolution.y * 800., 0, 1.0);\\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n float t = vertexId / vertexCount * PI * 2.;\n float t2 = vertexId / vertexCount * PI * 4.;\n float m = mod(time, 4.) / 2.;\n float y = cos(t);\n float x= sin(t) * pow(sin(0.5 * t), m);\n \n gl_Position = vec4(x / resolution.x * 800., y / resolution.y * 800., 0, 1.0);\n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-c3y7uuu31nci2b9ox-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XCcCm2KWsWPqG7Puh/art.json b/art/XCcCm2KWsWPqG7Puh/art.json index 8a94b643..7eb57eeb 100644 --- a/art/XCcCm2KWsWPqG7Puh/art.json +++ b/art/XCcCm2KWsWPqG7Puh/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/globalliquidity/until-that-time\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * ((snd * 0.5) * abs(sin(time *4.5)));\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= -rotateX;\\n p1.position.xz *= -rotateY;\\n p1.position.xy *= -rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n \\n float tm = PI * 1.75;time * 0.1;\\n \\n mat4 mat = persp(radians(120.0), resolution.x / resolution.y, 0.1, 1.0);\\n gl_Position = mat * vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n \\n\\n\\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/globalliquidity/until-that-time", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * ((snd * 0.5) * abs(sin(time *4.5)));\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= -rotateX;\n p1.position.xz *= -rotateY;\n p1.position.xy *= -rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n \n float tm = PI * 1.75;time * 0.1;\n \n mat4 mat = persp(radians(120.0), resolution.x / resolution.y, 0.1, 1.0);\n gl_Position = mat * vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n \n\n\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-t55qqohod9fuexw2p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XDJPeMfrdhMBhw4XD/art.json b/art/XDJPeMfrdhMBhw4XD/art.json index 2f94f9ee..0674e656 100644 --- a/art/XDJPeMfrdhMBhw4XD/art.json +++ b/art/XDJPeMfrdhMBhw4XD/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "GitchColor", "username": "-anon-", - "settings": "{\"num\":80041,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 40.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 80041, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 40.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "Ahemx2XwPNGX7PhZs", "views": { "$numberInt": "288" diff --git a/art/XJecoKnhhsWTTNp4Z/art.json b/art/XJecoKnhhsWTTNp4Z/art.json index 231edb2c..76feea64 100644 --- a/art/XJecoKnhhsWTTNp4Z/art.json +++ b/art/XJecoKnhhsWTTNp4Z/art.json @@ -11,7 +11,19 @@ "origId": "PoyGoZL5Lmmn9N5SF", "name": "Jack-o'-lantern in a circle", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\n// Jack-o'-lantern\\n// @P_Malin\\n\\n#define kRaymarchMaxIter 64\\n\\n#define kBounceCount 1\\n\\n//#define SCENE_DOMAIN_REPEAT\\n\\nfloat kFarClip=100.0;\\n\\nvec2 GetWindowCoord( const in vec2 vUV );\\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget );\\nvec3 GetSceneColour( in vec3 vRayOrigin, in vec3 vRayDir );\\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput );\\n\\nfloat GetCarving2dDistance(const in vec2 vPos );\\n\\nvec3 vLightPos = vec3(0.0, -0.5, 0.0);\\t\\t\\t\\nvec3 vLightColour = vec3(1.0, 0.8, 0.4);\\n\\nfloat fCarving = 1.0;\\n\\n// from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// CAMERA\\n\\nvec2 GetWindowCoord( const in vec2 vUV )\\n{\\n\\tvec2 vWindow = vUV * 2.0 - 1.0;\\n\\tvWindow.x *= resolution.x / resolution.y;\\n\\n\\treturn vWindow;\\t\\n}\\n\\n\\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget )\\n{\\n\\tvec3 vForward = normalize(vCameraTarget - vCameraPos);\\n\\tvec3 vRight = normalize(cross(vec3(0.0, 1.0, 0.0), vForward));\\n\\tvec3 vUp = normalize(cross(vForward, vRight));\\n\\t\\t\\t\\t\\t\\t\\t \\n\\tvec3 vDir = normalize(vWindow.x * vRight + vWindow.y * vUp + vForward * 1.5);\\n\\n\\treturn vDir;\\n}\\n\\n// POSTFX\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvec3 ApplyTonemap( const in vec3 vLinear )\\n{\\n\\tfloat kExposure = 1.0;\\n \\n\\treturn 1.0 - exp2(vLinear * -kExposure);\\t\\n}\\n\\nvec3 ApplyGamma( const in vec3 vLinear )\\n{\\n\\tconst float kGamma = 2.2;\\n\\n\\treturn pow(vLinear, vec3(1.0/kGamma));\\t\\n}\\n\\nvec3 ApplyBlackLevel( const in vec3 vColour )\\n{\\n float fBlackLevel = 0.1;\\n return vColour / (1.0 - fBlackLevel) - fBlackLevel;\\n}\\n\\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec3 vTemp = ApplyVignetting( vUV, vInput );\\t\\n\\t\\n\\tvTemp = ApplyTonemap(vTemp);\\n\\t\\n\\tvTemp = ApplyGamma(vTemp);\\t\\t\\n \\n vTemp = ApplyBlackLevel(vTemp);\\n \\n return vTemp;\\n}\\n\\t\\n// RAYTRACE\\n\\nstruct C_Intersection\\n{\\n\\tvec3 vPos;\\n\\tfloat fDist;\\t\\n\\tvec3 vNormal;\\n\\tvec3 vUVW;\\n\\tfloat fObjectId;\\n};\\n\\nfloat GetCarving2dDistance(const in vec2 vPos )\\n{\\n if(fCarving < 0.0)\\n return 10.0;\\n \\n\\tfloat fMouthDist = length(vPos.xy + vec2(0.0, -0.5)) - 1.5;\\n\\tfloat fMouthDist2 = length(vPos.xy + vec2(0.0, -1.1 - 0.5)) - 2.0;\\n\\t\\n\\tif(-fMouthDist2 > fMouthDist )\\n\\t{\\n\\t\\tfMouthDist = -fMouthDist2;\\n\\t}\\n\\n float fFaceDist = fMouthDist;\\n\\n vec2 vNosePos = vPos.xy + vec2(0.0, -0.5);\\n vNosePos.x = abs(vNosePos.x);\\n float fNoseDist = dot(vNosePos.xy, normalize(vec2(1.0, 0.5)));\\n fNoseDist = max(fNoseDist, -(vNosePos.y + 0.5));\\n if(fNoseDist < fFaceDist)\\n {\\n fFaceDist = fNoseDist;\\n }\\n\\n\\n vec2 vEyePos = vPos.xy;\\n vEyePos.x = abs(vEyePos.x);\\n vEyePos.x -= 1.0;\\n vEyePos.y -= 1.0;\\n float fEyeDist = dot(vEyePos.xy, normalize(vec2(-1.0, 1.5)));\\n fEyeDist = max(fEyeDist, dot(vEyePos.xy, normalize(vec2(1.0, 0.5))));\\n fEyeDist = max(fEyeDist, -0.5+dot(vEyePos.xy, normalize(vec2(0.0, -1.0))));\\n if(fEyeDist < fFaceDist)\\n {\\n fFaceDist = fEyeDist;\\n }\\n \\n return fFaceDist;\\n}\\n\\nfloat GetCarvingDistance(const in vec3 vPos )\\n{\\n\\tfloat fDist = (length(vPos * vec3(1.0, 1.4, 1.0)) - 2.7) / 1.5;\\n\\n float fFaceDist = GetCarving2dDistance(vPos.xy);\\n \\n\\tfloat fRearDist = vPos.z;\\n\\t\\n\\tif(fRearDist > fFaceDist)\\n\\t{\\n\\t\\tfFaceDist = fRearDist;\\n\\t}\\t\\n\\t\\n\\tif(fFaceDist < fDist )\\n\\t{\\n\\t\\tfDist = fFaceDist;\\n\\t}\\n\\n float fR = length(vPos.xz);\\n \\n float fLidDist = dot( vec2(fR, vPos.y), normalize(vec2(1.0, -1.5)));\\n \\n fLidDist = abs(fLidDist) - 0.03;\\n\\tif(fLidDist < fDist )\\n\\t{\\n\\t\\tfDist = fLidDist;\\n\\t}\\n \\n\\treturn fDist;\\n}\\n\\nfloat GetPumpkinDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\\n{\\n vec3 vSphereOrigin = vec3(0.0, 0.0, 0.0);\\n float fSphereRadius = 3.0;\\n\\n\\tvec3 vOffset = vPos - vSphereOrigin;\\n\\tfloat fFirstDist = length(vOffset);\\n\\t\\n\\tfloat fOutDist;\\n\\tif(fFirstDist > 3.5)\\n\\t{\\n\\t\\tfOutDist = fFirstDist - fSphereRadius;\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tfloat fAngle1 = atan(vOffset.x, vOffset.z);\\n\\t\\tfloat fSin = sin(fAngle1 * 10.0);\\n\\t\\tfSin = 1.0 - sqrt(abs(fSin));\\n\\t\\tvOffset *= 1.0 + fSin * vec3(0.05, 0.025, 0.05);\\n\\t\\tvOffset.y *= 1.0 + 0.5 * (fSphereRadius - length(vOffset.xz)) / fSphereRadius;\\n\\t\\tfOutDist = length(vOffset) - fSphereRadius;\\n\\t}\\n\\t\\n\\n\\tvec4 vSphere1UVW_Id = vec4(normalize(vPos - vSphereOrigin), 3.0);\\n\\tvOutUVW_Id = vSphere1UVW_Id;\\n\\t\\n\\tvec3 vStalkOffset = vPos;\\n\\tvStalkOffset.x += -(vStalkOffset.y - fSphereRadius) * 0.1;\\n\\tfloat fDist2d = length(vStalkOffset.xz);\\n\\tfloat fStalkDist = fDist2d - 0.2;\\n\\tfStalkDist = max(fStalkDist, vPos.y - 2.5 + vPos.x * 0.25);\\n\\tfStalkDist = max(fStalkDist, -vPos.y);\\n\\tif( fStalkDist < fOutDist )\\n\\t{\\n\\t\\tfOutDist = fStalkDist;\\n\\t\\tvOutUVW_Id = vSphere1UVW_Id;\\n\\t\\tvOutUVW_Id.w = 2.0;\\n\\t}\\n\\n\\treturn fOutDist;\\n}\\n\\nfloat GetSceneDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\\n{\\n\\tfloat fFloorDist = vPos.y + 2.0;\\n\\tvec4 vFloorUVW_Id = vec4(vPos.xz, 0.0, 1.0);\\n\\n\\t\\n\\tvec3 vPumpkinDomain = vPos;\\n\\n#ifdef SCENE_DOMAIN_REPEAT\\n\\tfloat fRepeat = 12.0;\\n\\tfloat fOffset = (fRepeat * 0.5);\\n\\tvPumpkinDomain.xz = fract((vPos.xz + fOffset) / fRepeat) * fRepeat - fOffset;\\n#endif \\n \\n\\tfloat fOutDist = fFloorDist;\\n\\tvOutUVW_Id = vFloorUVW_Id;\\n\\n\\tvec4 vPumpkinUVW_Id;\\n\\tfloat fPumpkinDist = GetPumpkinDistance( vPumpkinUVW_Id, vPumpkinDomain );\\n\\n\\tfloat fCarvingDist = GetCarvingDistance( vPumpkinDomain );\\n\\t\\n\\tif(-fCarvingDist > fPumpkinDist)\\n\\t{\\n\\t\\tfPumpkinDist = -fCarvingDist;\\n\\t\\tvPumpkinUVW_Id = vec4(4.0);\\n\\t}\\n\\n\\t\\n\\tif(fPumpkinDist < fOutDist)\\n\\t{\\n\\t\\tfOutDist = fPumpkinDist;\\n\\t\\tvOutUVW_Id = vPumpkinUVW_Id;\\n\\t}\\n\\t\\n\\treturn fOutDist;\\n}\\n\\nvec3 GetSceneNormal(const in vec3 vPos)\\n{\\n const float fDelta = 0.001;\\n\\n vec3 vDir1 = vec3( 1.0, -1.0, -1.0);\\n vec3 vDir2 = vec3(-1.0, -1.0, 1.0);\\n vec3 vDir3 = vec3(-1.0, 1.0, -1.0);\\n vec3 vDir4 = vec3( 1.0, 1.0, 1.0);\\n\\t\\n vec3 vOffset1 = vDir1 * fDelta;\\n vec3 vOffset2 = vDir2 * fDelta;\\n vec3 vOffset3 = vDir3 * fDelta;\\n vec3 vOffset4 = vDir4 * fDelta;\\n\\n\\tvec4 vUnused;\\n float f1 = GetSceneDistance( vUnused, vPos + vOffset1 );\\n float f2 = GetSceneDistance( vUnused, vPos + vOffset2 );\\n float f3 = GetSceneDistance( vUnused, vPos + vOffset3 );\\n float f4 = GetSceneDistance( vUnused, vPos + vOffset4 );\\n\\t\\n vec3 vNormal = vDir1 * f1 + vDir2 * f2 + vDir3 * f3 + vDir4 * f4;\\t\\n\\t\\t\\n return normalize( vNormal );\\n}\\n\\nvoid TraceScene( out C_Intersection outIntersection, const in vec3 vOrigin, const in vec3 vDir )\\n{\\t\\n\\tvec4 vUVW_Id = vec4(0.0);\\t\\t\\n\\tvec3 vPos = vec3(0.0);\\n\\t\\n\\tfloat t = 0.01;\\n\\tfor(int i=0; i 100.0)\\n\\t\\t{\\n\\t\\t\\tt = kFarClip;\\n\\t\\t\\tvPos = vOrigin + vDir * t;\\n\\t\\t\\tvUVW_Id = vec4(0.0);\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t}\\n\\t\\n\\toutIntersection.fDist = t;\\n\\toutIntersection.vPos = vPos;\\n\\toutIntersection.vNormal = GetSceneNormal(vPos);\\n\\toutIntersection.vUVW = vUVW_Id.xyz;\\n\\toutIntersection.fObjectId = vUVW_Id.w;\\n}\\n\\n\\nfloat TraceShadow( const in vec3 vOrigin, const in vec3 vDir, const in float fDist )\\n{\\n C_Intersection shadowIntersection;\\n\\tTraceScene(shadowIntersection, vOrigin, vDir);\\n\\tif(shadowIntersection.fDist < fDist) \\n\\t{\\n\\t\\treturn 0.0;\\t\\t\\n\\t}\\n\\t\\n\\treturn 1.0;\\n}\\n\\nfloat GetSSS( const in vec3 vPos, const in vec3 vLightPos )\\n{\\n vec3 vLightToPos = vPos - vLightPos;\\n vec3 vDir = normalize(vLightToPos);\\n \\n\\tC_Intersection intersection;\\n\\tTraceScene(intersection, vLightPos, vDir);\\n\\tfloat fOpticalDepth = length(vLightToPos) - intersection.fDist;\\n\\n fOpticalDepth = max(0.00001, fOpticalDepth);\\n \\n\\treturn exp2( fOpticalDepth * -8.0 );\\n}\\n\\n// LIGHTING\\n\\nfloat GIV( float dotNV, float k)\\n{\\n\\treturn 1.0 / ((dotNV + 0.0001) * (1.0 - k)+k);\\n}\\n\\nvoid AddLighting(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightColour)\\n{\\n\\tvec3 vH = normalize( -vViewDir + vLightDir );\\n\\tfloat fNDotL = clamp(dot(vLightDir, vNormal), 0.0, 1.0);\\n\\tfloat fNDotV = clamp(dot(-vViewDir, vNormal), 0.0, 1.0);\\n\\tfloat fNDotH = clamp(dot(vNormal, vH), 0.0, 1.0);\\n\\t\\n\\tfloat alpha = 1.0 - fSmoothness;\\n\\talpha = alpha * alpha;\\n\\t// D\\n\\n\\tfloat alphaSqr = alpha * alpha;\\n\\tfloat pi = 3.14159;\\n\\tfloat denom = fNDotH * fNDotH * (alphaSqr - 1.0) + 1.0;\\n\\tfloat d = alphaSqr / (pi * denom * denom);\\n\\n\\tfloat k = alpha / 2.0;\\n\\tfloat vis = GIV(fNDotL, k) * GIV(fNDotV, k);\\n\\n\\tfloat fSpecularIntensity = d * vis * fNDotL;\\n\\tvSpecularLight += vLightColour * fSpecularIntensity;\\n\\n\\tvDiffuseLight += vLightColour * fNDotL;\\n}\\n\\nvoid AddPointLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightPos, const in vec3 vLightColour)\\n{\\n\\tvec3 vToLight = vLightPos - vPos;\\t\\n\\tfloat fDistance2 = dot(vToLight, vToLight);\\n\\tfloat fAttenuation = 100.0 / (fDistance2);\\n\\tvec3 vLightDir = normalize(vToLight);\\n\\t\\n\\tvec3 vShadowRayDir = vLightDir;\\n\\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\\n\\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, length(vToLight));\\n\\t\\n\\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\\n}\\n\\nfloat AddDirectionalLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightDir, const in vec3 vLightColour)\\n{\\t\\n\\tfloat fAttenuation = 1.0;\\n\\n\\tvec3 vShadowRayDir = -vLightDir;\\n\\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\\n\\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, 10.0);\\n\\t\\n\\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, -vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\\t\\n \\n return fShadowFactor;\\n}\\n\\nvoid AddDirectionalLightFlareToFog(inout vec3 vFogColour, const in vec3 vRayDir, const in vec3 vLightDir, const in vec3 vLightColour)\\n{\\n\\tfloat fDirDot = clamp(dot(-vLightDir, vRayDir), 0.0, 1.0);\\n\\tfloat kSpreadPower = 4.0;\\n\\tvFogColour += vLightColour * pow(fDirDot, kSpreadPower);\\n}\\n\\n// SCENE MATERIALS\\n\\n#define MOD2 vec2(4.438975,3.972973)\\n\\nfloat Hash( float p ) \\n{\\n // https://www.shadertoy.com/view/4djSRW - Dave Hoskins\\n\\tvec2 p2 = fract(vec2(p) * MOD2);\\n p2 += dot(p2.yx, p2.xy+19.19);\\n\\treturn fract(p2.x * p2.y); \\n\\t//return fract(sin(n)*43758.5453);\\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = Hash(n+ 0.0);\\n\\tfloat b = Hash(n+ 1.0);\\n\\tfloat c = Hash(n+ 57.0);\\n\\tfloat d = Hash(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0;\\n for( int i=0; i= 3.0)\\n {\\n vDiffuseLight += GetSSS(intersection.vPos, vPointLightPos) * vLightColour;\\n }\\n else\\n {\\n vec3 vToLight = vPointLightPos - intersection.vPos;\\n float fNdotL = dot(normalize(vToLight), vBumpNormal) * 0.5 + 0.5;\\n\\t\\t\\t\\tvDiffuseLight += max(0.0, 1.0 - length(vToLight)/5.0) * vLightColour * fNdotL; \\n }\\n\\n\\t\\t\\tfloat fSmoothFactor = fSmoothness * 0.9 + 0.1;\\n float fFresnelClamp = 0.25; // too much fresnel produces sparkly artefacts\\n float fNdotD = clamp(dot(vBumpNormal, -vRayDir), fFresnelClamp, 1.0);\\n\\t\\t\\tvec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0) * fSmoothFactor;\\n\\n \\n\\t\\t\\tvResult = mix(vAlbedo * vDiffuseLight, vSpecularLight, vFresnel);\\t\\t\\n\\t\\t\\tvBlendFactor = vFresnel;\\n\\t\\t\\t\\n\\t\\t\\tApplyAtmosphere(vResult, intersection.fDist, vRayOrigin, vRayDir);\\t\\t\\n\\t\\t\\t\\n\\t\\t\\tvRemaining *= vBlendFactor;\\t\\t\\t\\t\\n\\t\\t\\tvRayDir = normalize(reflect(vRayDir, vBumpNormal));\\n\\t\\t\\tvRayOrigin = intersection.vPos;\\n\\t\\t}\\t\\t\\t\\n\\n\\t\\tvColour += vResult * vCurrRemaining * fShouldApply;\\t\\n\\t}\\n\\n\\tvec3 vSkyColor = GetSkyColour(vRayDir);\\n\\t\\n\\tApplyAtmosphere(vSkyColor, kFarClip, vRayOrigin, vRayDir);\\t\\t\\n\\t\\n // Hack for this scene when using 1 bounce.\\n // remove final sky reflection when in shadow\\n vSkyColor *= fLastShadow; \\n \\n\\tvColour += vSkyColor * vRemaining;\\n\\t\\n // Face glow\\n float t = -(_vRayOrigin.z + 2.8) / _vRayDir.z;\\n \\n if( t > 0.0 )\\n {\\n vec3 vPos = _vRayOrigin + _vRayDir * t;\\n\\n float fDist = abs(GetCarving2dDistance(vPos.xy * vec2(1.0, 1.0)));\\n float fDot = max(0.0, _vRayDir.z);\\n fDot = fDot * fDot;\\n vColour += exp2(-fDist * 10.0) * fDot * vLightColour * 0.25;\\n }\\n \\n \\n\\treturn vColour;\\n}\\n\\n\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\n#define TAU 6.283\\n\\nvec2 hash21(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n\\tp3 += dot(p3, p3.yzx + 19.19);\\n\\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\n/// radius, angle to x, y\\nvec2 euclidFromRadial(in vec2 rad)\\n{\\n float s = sin(rad.y * TAU);\\n float c = cos(rad.y * TAU);\\n float xf = resolution.y / resolution.x;\\n float yf = 1.0;\\n if (xf > 1.0) {yf = 1.0 / xf; xf = 1.0;}\\n return vec2(rad.x * xf * 0.5 * c + 0.5, rad.x * yf * 0.5 * s + 0.5);\\n}\\n\\nvoid main() \\n{\\n float fTriangleIndex = floor( vertexId / 3.0 ) + time;\\n float fTriangleVertexIndex = mod( vertexId, 3.0 );\\n \\n vec2 vUV = hash21( fTriangleIndex );\\n vUV = euclidFromRadial(vUV);\\n \\n \\tfloat fSize = 1.0;\\n\\n float fDist = 7.0;\\n\\n float fAngle = radians(190.0) + sin(time * 0.25) * 0.2;\\n float fHeight = 2.0 + sin(time * 0.1567) * 1.5;\\n \\n\\tvec3 vCameraPos = vec3(sin(fAngle) * fDist, fHeight, cos(fAngle) * fDist);\\n\\tvec3 vCameraTarget = vec3(0.0, -0.5, 0.0);\\n \\n\\tvec3 vRayOrigin = vCameraPos;\\n\\tvec3 vRayDir = GetCameraRayDir( GetWindowCoord(vUV), vCameraPos, vCameraTarget );\\n\\t\\n \\tfloat fHitDist = 0.0;\\n \\tvec3 vHitNormal = vec3(0.0);\\n\\tvec3 vResult = GetSceneColour(vRayOrigin, vRayDir, fHitDist, vHitNormal);\\n\\t \\n\\tvec3 vFinal = ApplyPostFX( vUV, vResult );\\n\\n\\n //fSize = 0.05 / fHitDist;\\n fSize *= 0.01;\\n fSize *= 0.5 + vFinal.x * vFinal.y * 0.5;\\n vec2 vOffset = vec2(0.0);\\n \\n \\n if( fTriangleVertexIndex < 0.5 )\\n {\\n vOffset.y += fSize;\\n }\\n else if( fTriangleVertexIndex < 1.5 )\\n {\\n vOffset.x -= fSize;\\n }\\n else if( fTriangleVertexIndex < 2.5 )\\n {\\n vOffset.x += fSize;\\n }\\n \\n vOffset = Rotate( vOffset, fTriangleIndex );\\n vUV += vOffset;\\n\\n vUV.xy = vUV.xy * 2.0 - 1.0;\\n \\n gl_Position = vec4(vUV.xy * fHitDist, 0, fHitDist);\\n v_color = vec4(vFinal, 1.0);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\n// Jack-o'-lantern\n// @P_Malin\n\n#define kRaymarchMaxIter 64\n\n#define kBounceCount 1\n\n//#define SCENE_DOMAIN_REPEAT\n\nfloat kFarClip=100.0;\n\nvec2 GetWindowCoord( const in vec2 vUV );\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget );\nvec3 GetSceneColour( in vec3 vRayOrigin, in vec3 vRayDir );\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput );\n\nfloat GetCarving2dDistance(const in vec2 vPos );\n\nvec3 vLightPos = vec3(0.0, -0.5, 0.0);\t\t\t\nvec3 vLightColour = vec3(1.0, 0.8, 0.4);\n\nfloat fCarving = 1.0;\n\n// from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// CAMERA\n\nvec2 GetWindowCoord( const in vec2 vUV )\n{\n\tvec2 vWindow = vUV * 2.0 - 1.0;\n\tvWindow.x *= resolution.x / resolution.y;\n\n\treturn vWindow;\t\n}\n\n\nvec3 GetCameraRayDir( const in vec2 vWindow, const in vec3 vCameraPos, const in vec3 vCameraTarget )\n{\n\tvec3 vForward = normalize(vCameraTarget - vCameraPos);\n\tvec3 vRight = normalize(cross(vec3(0.0, 1.0, 0.0), vForward));\n\tvec3 vUp = normalize(cross(vForward, vRight));\n\t\t\t\t\t\t\t \n\tvec3 vDir = normalize(vWindow.x * vRight + vWindow.y * vUp + vForward * 1.5);\n\n\treturn vDir;\n}\n\n// POSTFX\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvec3 ApplyTonemap( const in vec3 vLinear )\n{\n\tfloat kExposure = 1.0;\n \n\treturn 1.0 - exp2(vLinear * -kExposure);\t\n}\n\nvec3 ApplyGamma( const in vec3 vLinear )\n{\n\tconst float kGamma = 2.2;\n\n\treturn pow(vLinear, vec3(1.0/kGamma));\t\n}\n\nvec3 ApplyBlackLevel( const in vec3 vColour )\n{\n float fBlackLevel = 0.1;\n return vColour / (1.0 - fBlackLevel) - fBlackLevel;\n}\n\nvec3 ApplyPostFX( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec3 vTemp = ApplyVignetting( vUV, vInput );\t\n\t\n\tvTemp = ApplyTonemap(vTemp);\n\t\n\tvTemp = ApplyGamma(vTemp);\t\t\n \n vTemp = ApplyBlackLevel(vTemp);\n \n return vTemp;\n}\n\t\n// RAYTRACE\n\nstruct C_Intersection\n{\n\tvec3 vPos;\n\tfloat fDist;\t\n\tvec3 vNormal;\n\tvec3 vUVW;\n\tfloat fObjectId;\n};\n\nfloat GetCarving2dDistance(const in vec2 vPos )\n{\n if(fCarving < 0.0)\n return 10.0;\n \n\tfloat fMouthDist = length(vPos.xy + vec2(0.0, -0.5)) - 1.5;\n\tfloat fMouthDist2 = length(vPos.xy + vec2(0.0, -1.1 - 0.5)) - 2.0;\n\t\n\tif(-fMouthDist2 > fMouthDist )\n\t{\n\t\tfMouthDist = -fMouthDist2;\n\t}\n\n float fFaceDist = fMouthDist;\n\n vec2 vNosePos = vPos.xy + vec2(0.0, -0.5);\n vNosePos.x = abs(vNosePos.x);\n float fNoseDist = dot(vNosePos.xy, normalize(vec2(1.0, 0.5)));\n fNoseDist = max(fNoseDist, -(vNosePos.y + 0.5));\n if(fNoseDist < fFaceDist)\n {\n fFaceDist = fNoseDist;\n }\n\n\n vec2 vEyePos = vPos.xy;\n vEyePos.x = abs(vEyePos.x);\n vEyePos.x -= 1.0;\n vEyePos.y -= 1.0;\n float fEyeDist = dot(vEyePos.xy, normalize(vec2(-1.0, 1.5)));\n fEyeDist = max(fEyeDist, dot(vEyePos.xy, normalize(vec2(1.0, 0.5))));\n fEyeDist = max(fEyeDist, -0.5+dot(vEyePos.xy, normalize(vec2(0.0, -1.0))));\n if(fEyeDist < fFaceDist)\n {\n fFaceDist = fEyeDist;\n }\n \n return fFaceDist;\n}\n\nfloat GetCarvingDistance(const in vec3 vPos )\n{\n\tfloat fDist = (length(vPos * vec3(1.0, 1.4, 1.0)) - 2.7) / 1.5;\n\n float fFaceDist = GetCarving2dDistance(vPos.xy);\n \n\tfloat fRearDist = vPos.z;\n\t\n\tif(fRearDist > fFaceDist)\n\t{\n\t\tfFaceDist = fRearDist;\n\t}\t\n\t\n\tif(fFaceDist < fDist )\n\t{\n\t\tfDist = fFaceDist;\n\t}\n\n float fR = length(vPos.xz);\n \n float fLidDist = dot( vec2(fR, vPos.y), normalize(vec2(1.0, -1.5)));\n \n fLidDist = abs(fLidDist) - 0.03;\n\tif(fLidDist < fDist )\n\t{\n\t\tfDist = fLidDist;\n\t}\n \n\treturn fDist;\n}\n\nfloat GetPumpkinDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\n{\n vec3 vSphereOrigin = vec3(0.0, 0.0, 0.0);\n float fSphereRadius = 3.0;\n\n\tvec3 vOffset = vPos - vSphereOrigin;\n\tfloat fFirstDist = length(vOffset);\n\t\n\tfloat fOutDist;\n\tif(fFirstDist > 3.5)\n\t{\n\t\tfOutDist = fFirstDist - fSphereRadius;\n\t}\n\telse\n\t{\n\t\tfloat fAngle1 = atan(vOffset.x, vOffset.z);\n\t\tfloat fSin = sin(fAngle1 * 10.0);\n\t\tfSin = 1.0 - sqrt(abs(fSin));\n\t\tvOffset *= 1.0 + fSin * vec3(0.05, 0.025, 0.05);\n\t\tvOffset.y *= 1.0 + 0.5 * (fSphereRadius - length(vOffset.xz)) / fSphereRadius;\n\t\tfOutDist = length(vOffset) - fSphereRadius;\n\t}\n\t\n\n\tvec4 vSphere1UVW_Id = vec4(normalize(vPos - vSphereOrigin), 3.0);\n\tvOutUVW_Id = vSphere1UVW_Id;\n\t\n\tvec3 vStalkOffset = vPos;\n\tvStalkOffset.x += -(vStalkOffset.y - fSphereRadius) * 0.1;\n\tfloat fDist2d = length(vStalkOffset.xz);\n\tfloat fStalkDist = fDist2d - 0.2;\n\tfStalkDist = max(fStalkDist, vPos.y - 2.5 + vPos.x * 0.25);\n\tfStalkDist = max(fStalkDist, -vPos.y);\n\tif( fStalkDist < fOutDist )\n\t{\n\t\tfOutDist = fStalkDist;\n\t\tvOutUVW_Id = vSphere1UVW_Id;\n\t\tvOutUVW_Id.w = 2.0;\n\t}\n\n\treturn fOutDist;\n}\n\nfloat GetSceneDistance( out vec4 vOutUVW_Id, const in vec3 vPos )\n{\n\tfloat fFloorDist = vPos.y + 2.0;\n\tvec4 vFloorUVW_Id = vec4(vPos.xz, 0.0, 1.0);\n\n\t\n\tvec3 vPumpkinDomain = vPos;\n\n#ifdef SCENE_DOMAIN_REPEAT\n\tfloat fRepeat = 12.0;\n\tfloat fOffset = (fRepeat * 0.5);\n\tvPumpkinDomain.xz = fract((vPos.xz + fOffset) / fRepeat) * fRepeat - fOffset;\n#endif \n \n\tfloat fOutDist = fFloorDist;\n\tvOutUVW_Id = vFloorUVW_Id;\n\n\tvec4 vPumpkinUVW_Id;\n\tfloat fPumpkinDist = GetPumpkinDistance( vPumpkinUVW_Id, vPumpkinDomain );\n\n\tfloat fCarvingDist = GetCarvingDistance( vPumpkinDomain );\n\t\n\tif(-fCarvingDist > fPumpkinDist)\n\t{\n\t\tfPumpkinDist = -fCarvingDist;\n\t\tvPumpkinUVW_Id = vec4(4.0);\n\t}\n\n\t\n\tif(fPumpkinDist < fOutDist)\n\t{\n\t\tfOutDist = fPumpkinDist;\n\t\tvOutUVW_Id = vPumpkinUVW_Id;\n\t}\n\t\n\treturn fOutDist;\n}\n\nvec3 GetSceneNormal(const in vec3 vPos)\n{\n const float fDelta = 0.001;\n\n vec3 vDir1 = vec3( 1.0, -1.0, -1.0);\n vec3 vDir2 = vec3(-1.0, -1.0, 1.0);\n vec3 vDir3 = vec3(-1.0, 1.0, -1.0);\n vec3 vDir4 = vec3( 1.0, 1.0, 1.0);\n\t\n vec3 vOffset1 = vDir1 * fDelta;\n vec3 vOffset2 = vDir2 * fDelta;\n vec3 vOffset3 = vDir3 * fDelta;\n vec3 vOffset4 = vDir4 * fDelta;\n\n\tvec4 vUnused;\n float f1 = GetSceneDistance( vUnused, vPos + vOffset1 );\n float f2 = GetSceneDistance( vUnused, vPos + vOffset2 );\n float f3 = GetSceneDistance( vUnused, vPos + vOffset3 );\n float f4 = GetSceneDistance( vUnused, vPos + vOffset4 );\n\t\n vec3 vNormal = vDir1 * f1 + vDir2 * f2 + vDir3 * f3 + vDir4 * f4;\t\n\t\t\n return normalize( vNormal );\n}\n\nvoid TraceScene( out C_Intersection outIntersection, const in vec3 vOrigin, const in vec3 vDir )\n{\t\n\tvec4 vUVW_Id = vec4(0.0);\t\t\n\tvec3 vPos = vec3(0.0);\n\t\n\tfloat t = 0.01;\n\tfor(int i=0; i 100.0)\n\t\t{\n\t\t\tt = kFarClip;\n\t\t\tvPos = vOrigin + vDir * t;\n\t\t\tvUVW_Id = vec4(0.0);\n\t\t\tbreak;\n\t\t}\n\t}\n\t\n\toutIntersection.fDist = t;\n\toutIntersection.vPos = vPos;\n\toutIntersection.vNormal = GetSceneNormal(vPos);\n\toutIntersection.vUVW = vUVW_Id.xyz;\n\toutIntersection.fObjectId = vUVW_Id.w;\n}\n\n\nfloat TraceShadow( const in vec3 vOrigin, const in vec3 vDir, const in float fDist )\n{\n C_Intersection shadowIntersection;\n\tTraceScene(shadowIntersection, vOrigin, vDir);\n\tif(shadowIntersection.fDist < fDist) \n\t{\n\t\treturn 0.0;\t\t\n\t}\n\t\n\treturn 1.0;\n}\n\nfloat GetSSS( const in vec3 vPos, const in vec3 vLightPos )\n{\n vec3 vLightToPos = vPos - vLightPos;\n vec3 vDir = normalize(vLightToPos);\n \n\tC_Intersection intersection;\n\tTraceScene(intersection, vLightPos, vDir);\n\tfloat fOpticalDepth = length(vLightToPos) - intersection.fDist;\n\n fOpticalDepth = max(0.00001, fOpticalDepth);\n \n\treturn exp2( fOpticalDepth * -8.0 );\n}\n\n// LIGHTING\n\nfloat GIV( float dotNV, float k)\n{\n\treturn 1.0 / ((dotNV + 0.0001) * (1.0 - k)+k);\n}\n\nvoid AddLighting(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightColour)\n{\n\tvec3 vH = normalize( -vViewDir + vLightDir );\n\tfloat fNDotL = clamp(dot(vLightDir, vNormal), 0.0, 1.0);\n\tfloat fNDotV = clamp(dot(-vViewDir, vNormal), 0.0, 1.0);\n\tfloat fNDotH = clamp(dot(vNormal, vH), 0.0, 1.0);\n\t\n\tfloat alpha = 1.0 - fSmoothness;\n\talpha = alpha * alpha;\n\t// D\n\n\tfloat alphaSqr = alpha * alpha;\n\tfloat pi = 3.14159;\n\tfloat denom = fNDotH * fNDotH * (alphaSqr - 1.0) + 1.0;\n\tfloat d = alphaSqr / (pi * denom * denom);\n\n\tfloat k = alpha / 2.0;\n\tfloat vis = GIV(fNDotL, k) * GIV(fNDotV, k);\n\n\tfloat fSpecularIntensity = d * vis * fNDotL;\n\tvSpecularLight += vLightColour * fSpecularIntensity;\n\n\tvDiffuseLight += vLightColour * fNDotL;\n}\n\nvoid AddPointLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightPos, const in vec3 vLightColour)\n{\n\tvec3 vToLight = vLightPos - vPos;\t\n\tfloat fDistance2 = dot(vToLight, vToLight);\n\tfloat fAttenuation = 100.0 / (fDistance2);\n\tvec3 vLightDir = normalize(vToLight);\n\t\n\tvec3 vShadowRayDir = vLightDir;\n\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\n\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, length(vToLight));\n\t\n\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\n}\n\nfloat AddDirectionalLight(inout vec3 vDiffuseLight, inout vec3 vSpecularLight, const in vec3 vViewDir, const in vec3 vPos, const in vec3 vNormal, const in float fSmoothness, const in vec3 vLightDir, const in vec3 vLightColour)\n{\t\n\tfloat fAttenuation = 1.0;\n\n\tvec3 vShadowRayDir = -vLightDir;\n\tvec3 vShadowRayOrigin = vPos + vShadowRayDir * 0.01;\n\tfloat fShadowFactor = TraceShadow(vShadowRayOrigin, vShadowRayDir, 10.0);\n\t\n\tAddLighting(vDiffuseLight, vSpecularLight, vViewDir, -vLightDir, vNormal, fSmoothness, vLightColour * fShadowFactor * fAttenuation);\t\n \n return fShadowFactor;\n}\n\nvoid AddDirectionalLightFlareToFog(inout vec3 vFogColour, const in vec3 vRayDir, const in vec3 vLightDir, const in vec3 vLightColour)\n{\n\tfloat fDirDot = clamp(dot(-vLightDir, vRayDir), 0.0, 1.0);\n\tfloat kSpreadPower = 4.0;\n\tvFogColour += vLightColour * pow(fDirDot, kSpreadPower);\n}\n\n// SCENE MATERIALS\n\n#define MOD2 vec2(4.438975,3.972973)\n\nfloat Hash( float p ) \n{\n // https://www.shadertoy.com/view/4djSRW - Dave Hoskins\n\tvec2 p2 = fract(vec2(p) * MOD2);\n p2 += dot(p2.yx, p2.xy+19.19);\n\treturn fract(p2.x * p2.y); \n\t//return fract(sin(n)*43758.5453);\n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = Hash(n+ 0.0);\n\tfloat b = Hash(n+ 1.0);\n\tfloat c = Hash(n+ 57.0);\n\tfloat d = Hash(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n#define k_fmbSteps 10\nfloat FBM( vec2 p, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0;\n for( int i=0; i= 3.0)\n {\n vDiffuseLight += GetSSS(intersection.vPos, vPointLightPos) * vLightColour;\n }\n else\n {\n vec3 vToLight = vPointLightPos - intersection.vPos;\n float fNdotL = dot(normalize(vToLight), vBumpNormal) * 0.5 + 0.5;\n\t\t\t\tvDiffuseLight += max(0.0, 1.0 - length(vToLight)/5.0) * vLightColour * fNdotL; \n }\n\n\t\t\tfloat fSmoothFactor = fSmoothness * 0.9 + 0.1;\n float fFresnelClamp = 0.25; // too much fresnel produces sparkly artefacts\n float fNdotD = clamp(dot(vBumpNormal, -vRayDir), fFresnelClamp, 1.0);\n\t\t\tvec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0) * fSmoothFactor;\n\n \n\t\t\tvResult = mix(vAlbedo * vDiffuseLight, vSpecularLight, vFresnel);\t\t\n\t\t\tvBlendFactor = vFresnel;\n\t\t\t\n\t\t\tApplyAtmosphere(vResult, intersection.fDist, vRayOrigin, vRayDir);\t\t\n\t\t\t\n\t\t\tvRemaining *= vBlendFactor;\t\t\t\t\n\t\t\tvRayDir = normalize(reflect(vRayDir, vBumpNormal));\n\t\t\tvRayOrigin = intersection.vPos;\n\t\t}\t\t\t\n\n\t\tvColour += vResult * vCurrRemaining * fShouldApply;\t\n\t}\n\n\tvec3 vSkyColor = GetSkyColour(vRayDir);\n\t\n\tApplyAtmosphere(vSkyColor, kFarClip, vRayOrigin, vRayDir);\t\t\n\t\n // Hack for this scene when using 1 bounce.\n // remove final sky reflection when in shadow\n vSkyColor *= fLastShadow; \n \n\tvColour += vSkyColor * vRemaining;\n\t\n // Face glow\n float t = -(_vRayOrigin.z + 2.8) / _vRayDir.z;\n \n if( t > 0.0 )\n {\n vec3 vPos = _vRayOrigin + _vRayDir * t;\n\n float fDist = abs(GetCarving2dDistance(vPos.xy * vec2(1.0, 1.0)));\n float fDot = max(0.0, _vRayDir.z);\n fDot = fDot * fDot;\n vColour += exp2(-fDist * 10.0) * fDot * vLightColour * 0.25;\n }\n \n \n\treturn vColour;\n}\n\n\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\n#define TAU 6.283\n\nvec2 hash21(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n\tp3 += dot(p3, p3.yzx + 19.19);\n\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\n/// radius, angle to x, y\nvec2 euclidFromRadial(in vec2 rad)\n{\n float s = sin(rad.y * TAU);\n float c = cos(rad.y * TAU);\n float xf = resolution.y / resolution.x;\n float yf = 1.0;\n if (xf > 1.0) {yf = 1.0 / xf; xf = 1.0;}\n return vec2(rad.x * xf * 0.5 * c + 0.5, rad.x * yf * 0.5 * s + 0.5);\n}\n\nvoid main() \n{\n float fTriangleIndex = floor( vertexId / 3.0 ) + time;\n float fTriangleVertexIndex = mod( vertexId, 3.0 );\n \n vec2 vUV = hash21( fTriangleIndex );\n vUV = euclidFromRadial(vUV);\n \n \tfloat fSize = 1.0;\n\n float fDist = 7.0;\n\n float fAngle = radians(190.0) + sin(time * 0.25) * 0.2;\n float fHeight = 2.0 + sin(time * 0.1567) * 1.5;\n \n\tvec3 vCameraPos = vec3(sin(fAngle) * fDist, fHeight, cos(fAngle) * fDist);\n\tvec3 vCameraTarget = vec3(0.0, -0.5, 0.0);\n \n\tvec3 vRayOrigin = vCameraPos;\n\tvec3 vRayDir = GetCameraRayDir( GetWindowCoord(vUV), vCameraPos, vCameraTarget );\n\t\n \tfloat fHitDist = 0.0;\n \tvec3 vHitNormal = vec3(0.0);\n\tvec3 vResult = GetSceneColour(vRayOrigin, vRayDir, fHitDist, vHitNormal);\n\t \n\tvec3 vFinal = ApplyPostFX( vUV, vResult );\n\n\n //fSize = 0.05 / fHitDist;\n fSize *= 0.01;\n fSize *= 0.5 + vFinal.x * vFinal.y * 0.5;\n vec2 vOffset = vec2(0.0);\n \n \n if( fTriangleVertexIndex < 0.5 )\n {\n vOffset.y += fSize;\n }\n else if( fTriangleVertexIndex < 1.5 )\n {\n vOffset.x -= fSize;\n }\n else if( fTriangleVertexIndex < 2.5 )\n {\n vOffset.x += fSize;\n }\n \n vOffset = Rotate( vOffset, fTriangleIndex );\n vUV += vOffset;\n\n vUV.xy = vUV.xy * 2.0 - 1.0;\n \n gl_Position = vec4(vUV.xy * fHitDist, 0, fHitDist);\n v_color = vec4(vFinal, 1.0);\n\n}" + }, "screenshotURL": "data/images/images-yk73gvuuppe0thfs6-thumbnail.jpg", "views": { "$numberInt": "575" diff --git a/art/XK2y2Cy63Ez45E7pm/art.json b/art/XK2y2Cy63Ez45E7pm/art.json index ecdb3ff5..e131dcf3 100644 --- a/art/XK2y2Cy63Ez45E7pm/art.json +++ b/art/XK2y2Cy63Ez45E7pm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":19140,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/subjex/richard\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=65536\\n\\n#define soundFactor 0.2 //KParameter0 0.>>1.\\n#define speedFactor 0.4+(mouse.x *1.3)//KParameter1 0.>>4.\\n#define sinFactor0 32.//KParameter2 1.>>100.\\n#define sinFactor1 1.*mouse.t//KParameter3 1.>>100.\\n\\n\\n\\n#define PI 3.1415926535898\\n#define HPI 1.570796326795\\n\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43658.5453123, 1345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.3, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(0.0, 9.0, 4.0));\\n \\n float diffuse = max(0.70, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvec3 giantWorm(vec3 a, float t) {\\n return vec3(sin(t*sinFactor0 * a.x), sin(t*sinFactor1 * a.y), cos(t * a.z));\\n}\\n\\n\\nvec3 transformation(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float lineId = 0.;//mod(shapeId, 3.0);\\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 0.0) {\\n lineFactor = vec3(4.1, 6.7, 2.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else if(lineId == .0) {\\n lineFactor = vec3(4.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(0.0, 1.6, 0.0);\\n }\\n \\n float v = vertexId / vertexCount;\\n float distort = mod(vertexId, 100.) / 100.;\\n float snd = soundFactor*texture2D(sound, vec2(mix(0.01, 0.061, distort), mix(0.25, 0., v))).a;\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 shapeni;\\n vec3 shapep = shapeVertex(shapeVertexId, shapeni) * 0.04;\\n \\n vec3 shapeHash = noise(vec3(log(shapeId)));\\n float factor = 0.3+snd;\\n float factor2 = 0.005;\\n vec3 shapeOffset = vec3(factor*cos(factor2*time*shapeId),factor*sin(factor2*time*shapeId),0.);\\n vec3 shapeRot = noise(shapeHash) * time * 2.0*speedFactor;\\n \\n shapep = rotX(rotY(rotZ(shapep, shapeRot.z), shapeRot.y), shapeRot.z);\\n shapeni.xyz = rotX(rotY(rotZ(shapeni.xyz, shapeRot.z), shapeRot.y), shapeRot.z);\\n \\n shapep = transformation(lineFactor, (t + time * 0.1*speedFactor) * 2.0) * vec3(aspect, 1.0, aspect) + (shapep + shapeOffset);\\n \\n \\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, shapep, shapeni.xyz, vec3(0.5 + shapeHash * 0.05), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookAt(shapep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 19140, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/subjex/richard", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=65536\n\n#define soundFactor 0.2 //KParameter0 0.>>1.\n#define speedFactor 0.4+(mouse.x *1.3)//KParameter1 0.>>4.\n#define sinFactor0 32.//KParameter2 1.>>100.\n#define sinFactor1 1.*mouse.t//KParameter3 1.>>100.\n\n\n\n#define PI 3.1415926535898\n#define HPI 1.570796326795\n\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43658.5453123, 1345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.3, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(0.0, 9.0, 4.0));\n \n float diffuse = max(0.70, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));//specular = max(0.0, pow(dot(_n, h), _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvec3 giantWorm(vec3 a, float t) {\n return vec3(sin(t*sinFactor0 * a.x), sin(t*sinFactor1 * a.y), cos(t * a.z));\n}\n\n\nvec3 transformation(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\n\n\n\nvoid main() {\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float lineId = 0.;//mod(shapeId, 3.0);\n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 0.0) {\n lineFactor = vec3(4.1, 6.7, 2.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else if(lineId == .0) {\n lineFactor = vec3(4.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 1.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(0.0, 1.6, 0.0);\n }\n \n float v = vertexId / vertexCount;\n float distort = mod(vertexId, 100.) / 100.;\n float snd = soundFactor*texture2D(sound, vec2(mix(0.01, 0.061, distort), mix(0.25, 0., v))).a;\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 shapeni;\n vec3 shapep = shapeVertex(shapeVertexId, shapeni) * 0.04;\n \n vec3 shapeHash = noise(vec3(log(shapeId)));\n float factor = 0.3+snd;\n float factor2 = 0.005;\n vec3 shapeOffset = vec3(factor*cos(factor2*time*shapeId),factor*sin(factor2*time*shapeId),0.);\n vec3 shapeRot = noise(shapeHash) * time * 2.0*speedFactor;\n \n shapep = rotX(rotY(rotZ(shapep, shapeRot.z), shapeRot.y), shapeRot.z);\n shapeni.xyz = rotX(rotY(rotZ(shapeni.xyz, shapeRot.z), shapeRot.y), shapeRot.z);\n \n shapep = transformation(lineFactor, (t + time * 0.1*speedFactor) * 2.0) * vec3(aspect, 1.0, aspect) + (shapep + shapeOffset);\n \n \n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, shapep, shapeni.xyz, vec3(0.5 + shapeHash * 0.05), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookAt(shapep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-vmbz8fi0evme0msb6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XLRYpFJ4uH4fWk2Tn/art.json b/art/XLRYpFJ4uH4fWk2Tn/art.json index 99030835..f5967c47 100644 --- a/art/XLRYpFJ4uH4fWk2Tn/art.json +++ b/art/XLRYpFJ4uH4fWk2Tn/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "bene2002", "avatarUrl": "https://secure.gravatar.com/avatar/08b4d8a2c513dbbd32686b69f0d14fc6?default=retro&size=200", - "settings": "{\"num\":2995,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0.6823529411764706,0.788235294117647,1],\"shader\":\"#define PI radians(180.)\\n//#define numX 10.\\n\\nvoid main() {\\n float numY = floor(sqrt(vertexCount));\\n float numX = floor(vertexCount/numY);\\n \\n float x = mod(vertexId, numX);\\n float y = floor(vertexId / numX);\\n \\n float u = x / (numX - 1.);\\n float v = y / (numY - 1.);\\n \\n gl_Position = vec4(-1.+u*2.,1.-v*2.,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize = gl_PointSize * 20. / numX;\\n gl_PointSize = gl_PointSize * resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 2995, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0.6823529411764706, + 0.788235294117647, + 1 + ], + "shader": "#define PI radians(180.)\n//#define numX 10.\n\nvoid main() {\n float numY = floor(sqrt(vertexCount));\n float numX = floor(vertexCount/numY);\n \n float x = mod(vertexId, numX);\n float y = floor(vertexId / numX);\n \n float u = x / (numX - 1.);\n float v = y / (numY - 1.);\n \n gl_Position = vec4(-1.+u*2.,1.-v*2.,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize = gl_PointSize * 20. / numX;\n gl_PointSize = gl_PointSize * resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-9jc8imup47bxeo64u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XMfocB69HDJbjh5Sf/art.json b/art/XMfocB69HDJbjh5Sf/art.json index 293b4560..a1dd9b99 100644 --- a/art/XMfocB69HDJbjh5Sf/art.json +++ b/art/XMfocB69HDJbjh5Sf/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sherrysmcguire", "avatarUrl": "https://secure.gravatar.com/avatar/e564d0b2c878b6e32f2020459dc1c7b6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25882352941176473,1],\"shader\":\"// music track: https://soundcloud.com/graham-panter/fly-by-light\\n// mcguirev10: very long playlist:\\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.0; //sin(time * 1.2 + x * y * 0.2) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\\n float sat = mix(0.0, 1.0, pump); //mix(1.0, -10.0, av);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25882352941176473, + 1 + ], + "shader": "// music track: https://soundcloud.com/graham-panter/fly-by-light\n// mcguirev10: very long playlist:\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.0; //sin(time * 1.2 + x * y * 0.2) * 5.0;\n \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\n float sat = mix(0.0, 1.0, pump); //mix(1.0, -10.0, av);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n \n \n}" + }, "screenshotURL": "data/images/images-4hhzgkbnxg6oygfkc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XQQfnaTej5ZuzxNaf/art.json b/art/XQQfnaTej5ZuzxNaf/art.json index 4d67f452..3af8f6ad 100644 --- a/art/XQQfnaTej5ZuzxNaf/art.json +++ b/art/XQQfnaTej5ZuzxNaf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * .4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(floor(time * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * .1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 2. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.z)), abs(t.z) * 1.)).a;\\n\\n float pump = step(10.7, s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\\n hue = time * .1 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + .2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 0.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * .05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 0., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * .4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(floor(time * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * .1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 2. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.z)), abs(t.z) * 1.)).a;\n\n float pump = step(10.7, s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\n hue = time * .1 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + .2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 0.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * .05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 0., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-45ab77rsq4obimrej-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XQjMFcAi9qguPBnBG/art.json b/art/XQjMFcAi9qguPBnBG/art.json index 62f53b8e..e328511b 100644 --- a/art/XQjMFcAi9qguPBnBG/art.json +++ b/art/XQjMFcAi9qguPBnBG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":27167,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Making a Grid Assignment\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 27167, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Making a Grid Assignment\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-medcu0fyov4d63apv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XRdg3Wi744WAEMHKZ/art.json b/art/XRdg3Wi744WAEMHKZ/art.json index b4e3dcd0..30a20338 100644 --- a/art/XRdg3Wi744WAEMHKZ/art.json +++ b/art/XRdg3Wi744WAEMHKZ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":69117,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\n//\\n// Move the mouse\\n//\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 21.0 / 3.0* 3., 0.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\nvoid main() {\\n float tm = cos(time) *120.;\\n vec2 aspect = vec2(0.11, resolution.x / resolution.y);\\n float t = (vertexId* 0.9+mod(vertexId,2.0))*0.03;\\n float phase = -tm*mod(vertexId,2.0);\\n float a = 0.173;\\n float b = 0.3063489;\\n float x = a * exp(b+t*1.3)*cos(t+phase)*0.015;\\n float y = a * exp(-b*1.3)*sin(t*phase)*0.015;\\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.05));\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\\n\\n \\n float hue = (floor(vertexId * -.005) * 0.5 - time * 0.01);\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*3.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 69117, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \n//\n// Move the mouse\n//\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 21.0 / 3.0* 3., 0.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\nvoid main() {\n float tm = cos(time) *120.;\n vec2 aspect = vec2(0.11, resolution.x / resolution.y);\n float t = (vertexId* 0.9+mod(vertexId,2.0))*0.03;\n float phase = -tm*mod(vertexId,2.0);\n float a = 0.173;\n float b = 0.3063489;\n float x = a * exp(b+t*1.3)*cos(t+phase)*0.015;\n float y = a * exp(-b*1.3)*sin(t*phase)*0.015;\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.05));\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\n\n \n float hue = (floor(vertexId * -.005) * 0.5 - time * 0.01);\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*3.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-vqx4b2zvj61yf3hhm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XTMgvDzrnXxm3gSZQ/art.json b/art/XTMgvDzrnXxm3gSZQ/art.json index 5a8f21d0..9870f30e 100644 --- a/art/XTMgvDzrnXxm3gSZQ/art.json +++ b/art/XTMgvDzrnXxm3gSZQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":12969,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/jahtari_records/hail-the-robots?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.;\\n float down = numQuads / around -1.1;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI *.1+r) * r;\\n float y = sin(qu * PI *-1.012) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * mix(0.01,mouse.x,-.05) * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = sin(quadId *.01813333333);\\n float sat = 1.;\\n float val = .57;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.bg = v_color.rb;\\n}\"}", + "settings": { + "num": 12969, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/jahtari_records/hail-the-robots?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.;\n float down = numQuads / around -1.1;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI *.1+r) * r;\n float y = sin(qu * PI *-1.012) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * mix(0.01,mouse.x,-.05) * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = sin(quadId *.01813333333);\n float sat = 1.;\n float val = .57;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.bg = v_color.rb;\n}" + }, "screenshotURL": "data/images/images-thzo5hkb0awoyfmxv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XTxHzHEnG5mRTTYnm/art.json b/art/XTxHzHEnG5mRTTYnm/art.json index 60d10894..bf626539 100644 --- a/art/XTxHzHEnG5mRTTYnm/art.json +++ b/art/XTxHzHEnG5mRTTYnm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":5614,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define PHI_A (3.-sqrt(5.))* PI\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec4 rotate(vec4 v, float a) {\\n \\t//mat4 rot = mat4(cos(a), sin(a), 0, 0,\\n // -sin(a), cos(a), 0, 0,\\n // 0, 0, 1, 0,\\n// 0, 0, 0, 1);\\n mat4 rot = mat4(cos(a), sin(a), 0, 0,\\n 0, 1, 0, 0,\\n -sin(a), cos(a), 1, 0,\\n 0, 0, 0, 1);\\n vec4 res = rot * v;\\n return res;\\n}\\n\\nvoid main() {\\n float scale = .35; // repeats/extends\\n float size = 0.001; // stretch/squeeze\\n float rad_max = (vertexCount * size);\\n \\n float y = floor(vertexId / 50.);\\n float v = y/100.;\\n float phi = acos(1. - 2. * v);\\n \\n float theta = PHI_A * vertexId;// * PHI_A;\\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\\n float snd = texture2D(sound, vec2(fract(theta / 35.0), fract(theta / 80000.0))).a;\\n float radius = sqrt(vertexId * size) + snd*0.1;\\n \\n radius = radius * scale;\\n \\n float xoff = sin(time*0.8) * 0.8;\\n float yoff = sin(time*1.3) * 0.1;\\n gl_Position = rotate(vec4(cos(theta) * sin(phi) * radius,\\n \\tsin(theta) * sin(phi) * radius,\\n \\tcos(phi) * radius, 1), time * 0.5);\\n \\n float soff = pow(snd + 0.2, 8.);\\n gl_PointSize = (soff + 2.) * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\\n\\n float hue = snd*0.01 + time * 0.1;\\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\\n 1. // change step to 0. (all pass) for no blackening\\n )), pow(snd, 5.));\\n}\"}", + "settings": { + "num": 5614, + "mode": "POINTS", + "sound": "https://soundcloud.com/fennec-inc/dj-la-cream-feat-monsieur-pote", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define PHI_A (3.-sqrt(5.))* PI\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec4 rotate(vec4 v, float a) {\n \t//mat4 rot = mat4(cos(a), sin(a), 0, 0,\n // -sin(a), cos(a), 0, 0,\n // 0, 0, 1, 0,\n// 0, 0, 0, 1);\n mat4 rot = mat4(cos(a), sin(a), 0, 0,\n 0, 1, 0, 0,\n -sin(a), cos(a), 1, 0,\n 0, 0, 0, 1);\n vec4 res = rot * v;\n return res;\n}\n\nvoid main() {\n float scale = .35; // repeats/extends\n float size = 0.001; // stretch/squeeze\n float rad_max = (vertexCount * size);\n \n float y = floor(vertexId / 50.);\n float v = y/100.;\n float phi = acos(1. - 2. * v);\n \n float theta = PHI_A * vertexId;// * PHI_A;\n //float snd = texture2D(sound, vec2(cos(theta)/2.+.5, abs(sin(theta))*0.25));\n float snd = texture2D(sound, vec2(fract(theta / 35.0), fract(theta / 80000.0))).a;\n float radius = sqrt(vertexId * size) + snd*0.1;\n \n radius = radius * scale;\n \n float xoff = sin(time*0.8) * 0.8;\n float yoff = sin(time*1.3) * 0.1;\n gl_Position = rotate(vec4(cos(theta) * sin(phi) * radius,\n \tsin(theta) * sin(phi) * radius,\n \tcos(phi) * radius, 1), time * 0.5);\n \n float soff = pow(snd + 0.2, 8.);\n gl_PointSize = (soff + 2.) * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\n\n float hue = snd*0.01 + time * 0.1;\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1,\n 1. // change step to 0. (all pass) for no blackening\n )), pow(snd, 5.));\n}" + }, "screenshotURL": "data/images/images-le42lmcsp0b5a343u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XW2ueZpHcoWqtkuqD/art.json b/art/XW2ueZpHcoWqtkuqD/art.json index a46a13ea..a59308d5 100644 --- a/art/XW2ueZpHcoWqtkuqD/art.json +++ b/art/XW2ueZpHcoWqtkuqD/art.json @@ -20,7 +20,19 @@ "origId": null, "name": "lorenz attractor", "username": "xt95", - "settings": "{\"num\":6079,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/melokind/klangtherapeuten-perlentaucher\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.07450980392156863,0.06666666666666667,1],\"shader\":\"const float PI = 3.14159265;\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\nvec3 project(vec3 p) { return vec3(p.xy / p.z, p.z); }\\n\\nvoid main()\\n{\\n float id = float(vertexId)/7602.;\\n \\n vec3 p = vec3(.1);\\n //Lorenz attractor\\n if(vertexId>2000.)\\n {\\n float snd = texture2D(sound, vec2(1./128.,.0)).a;\\n float\\ta = -0.966918-snd,b = 2.879879+pow(snd,4.),c = 0.765145,d = 0.744728;\\n for(int i=2000; i<7000; i++)\\n {\\n if(i2000.)\n {\n float snd = texture2D(sound, vec2(1./128.,.0)).a;\n float\ta = -0.966918-snd,b = 2.879879+pow(snd,4.),c = 0.765145,d = 0.744728;\n for(int i=2000; i<7000; i++)\n {\n if(i < \\n \\\\___/ \\\\___ >__| |__| \\\\___ >__/\\\\_ \\\\ \\n \\\\/ \\\\/ \\\\/ \\n _________.__ .___ \\n / _____/| |__ _____ __| _/___________ \\n \\\\_____ \\\\ | | \\\\\\\\__ \\\\ / __ |/ __ \\\\_ __ \\\\\\n / \\\\| Y \\\\/ __ \\\\_/ /_/ \\\\ ___/| | \\\\/\\n/_______ /|___| (____ /\\\\____ |\\\\___ >__| \\n \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\n _____ __ \\n / _ \\\\________/ |_ \\n / /_\\\\ \\\\_ __ \\\\ __\\\\ \\n/ | \\\\ | \\\\/| | \\n\\\\____|__ /__| |__| \\n \\\\/ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define QUADS_PER_LINE 256.\\n#define SUBDIVISIONS_PER_QUAD 16.\\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\\nconst float tension = 0.5;\\n\\nvec2 funky(const float id) {\\n float v = id / QUADS_PER_LINE * 4.;\\n float t = time;\\n return vec2(\\n (sin(v + t) + sin(v * .37 + t) + sin(v * 2.951 + t)) / 3.,\\n (cos(v * 9.12 + t) + cos(v * .37 + t) + cos(v * 2.951 + t)) / 3.\\n );\\n}\\n\\nvec3 getCenterPoint(const float id) {\\n vec4 t = vec4(0);\\n const int samples = 4;\\n for (int ii = 0; ii < samples; ++ii) {\\n t += texture2D(touch, \\n vec2(0.,\\n (id + 0.1) / (soundRes.y * 1.) \\n + float(ii) / float(samples) * 0.01));\\n }\\n t /= 4.;\\n t.xy = funky(id);\\n return vec3(t.x, t.y, 0);\\n}\\n\\nvec3 getCurvePoint(const float superId) {\\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n vec3 q0 = getCenterPoint(quadId - 1.);\\n vec3 q1 = getCenterPoint(quadId + 0.);\\n vec3 q2 = getCenterPoint(quadId + 1.);\\n vec3 q3 = getCenterPoint(quadId + 2.);\\n vec3 q4 = getCenterPoint(quadId + 3.);\\n vec3 q5 = getCenterPoint(quadId + 4.);\\n \\n float s2 = pow(subV, 2.);\\n float s3 = pow(subV, 3.);\\n \\n float c1 = 2. * s3 - 3. * s2 + 1.;\\n float c2 = -(2. * s3) + 3. * s2; \\n float c3 = s3 - 2. * s2 + subV; \\n float c4 = s3 - s2; \\n\\n vec3 t1 = (q2 - q0) * tension;\\n vec3 t2 = (q3 - q1) * tension;\\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \\n}\\n\\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n \\n vec3 q0 = getCurvePoint(cpId + 0.);\\n vec3 q1 = getCurvePoint(cpId + 1.);\\n vec3 q2 = getCurvePoint(cpId + 2.);\\n vec3 q3 = getCurvePoint(cpId + 3.);\\n vec3 q4 = getCurvePoint(cpId + 4.);\\n vec3 q5 = getCurvePoint(cpId + 5.);\\n\\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n #if 0\\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #else\\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #endif\\n \\n uv = vec2(ux, vy);\\n}\\n\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n float quadV = quadId / quadCount;\\n float invQuadV = inv(quadV);\\n vec3 pos;\\n vec2 uv;\\n\\n float snd0 = texture2D(sound, vec2(0.03, quadV * 0.2)).a;\\n float snd1 = 0.6;\\n float snd2 = texture2D(sound, vec2(0.01 * 0.25, 0.)).a;\\n \\n getQuadPoint(quadId, pointId, mix(0.01, 0.20, pow(snd0 + 0.2, 15.)) + pow(snd2, 10.0) * 0.05, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n pos.z = quadV;\\n \\n// vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(vec3(\\n mix(1., -1., mod(lineId, 2.)),\\n mix(1., -1., mod(floor(lineId / 2.), 2.)),\\n 1));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n// gl_Position.z = -m1p1(quadId / quadCount);\\n// gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.95, snd0);\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invQuadV);\\n //v_color = mix(v_color, vec4(1,0,0,1), pow(snd2, 15.));\\n //v_color.a = mix(1.0, 0.0, step(50., mod(quadId, 100.)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n\\n}\\n\\n\"}", + "settings": { + "num": 98304, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nautylus-productions/falomir-feat-dila-libertine-lounge-deep-mix", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n____ ____ __ \n\\ \\ / /____________/ |_ ____ ___ ___ \n \\ Y // __ \\_ __ \\ __\\/ __ \\\\ \\/ / \n \\ /\\ ___/| | \\/| | \\ ___/ > < \n \\___/ \\___ >__| |__| \\___ >__/\\_ \\ \n \\/ \\/ \\/ \n _________.__ .___ \n / _____/| |__ _____ __| _/___________ \n \\_____ \\ | | \\\\__ \\ / __ |/ __ \\_ __ \\\n / \\| Y \\/ __ \\_/ /_/ \\ ___/| | \\/\n/_______ /|___| (____ /\\____ |\\___ >__| \n \\/ \\/ \\/ \\/ \\/ \n _____ __ \n / _ \\________/ |_ \n / /_\\ \\_ __ \\ __\\ \n/ | \\ | \\/| | \n\\____|__ /__| |__| \n \\/ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define QUADS_PER_LINE 256.\n#define SUBDIVISIONS_PER_QUAD 16.\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\nconst float tension = 0.5;\n\nvec2 funky(const float id) {\n float v = id / QUADS_PER_LINE * 4.;\n float t = time;\n return vec2(\n (sin(v + t) + sin(v * .37 + t) + sin(v * 2.951 + t)) / 3.,\n (cos(v * 9.12 + t) + cos(v * .37 + t) + cos(v * 2.951 + t)) / 3.\n );\n}\n\nvec3 getCenterPoint(const float id) {\n vec4 t = vec4(0);\n const int samples = 4;\n for (int ii = 0; ii < samples; ++ii) {\n t += texture2D(touch, \n vec2(0.,\n (id + 0.1) / (soundRes.y * 1.) \n + float(ii) / float(samples) * 0.01));\n }\n t /= 4.;\n t.xy = funky(id);\n return vec3(t.x, t.y, 0);\n}\n\nvec3 getCurvePoint(const float superId) {\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n vec3 q0 = getCenterPoint(quadId - 1.);\n vec3 q1 = getCenterPoint(quadId + 0.);\n vec3 q2 = getCenterPoint(quadId + 1.);\n vec3 q3 = getCenterPoint(quadId + 2.);\n vec3 q4 = getCenterPoint(quadId + 3.);\n vec3 q5 = getCenterPoint(quadId + 4.);\n \n float s2 = pow(subV, 2.);\n float s3 = pow(subV, 3.);\n \n float c1 = 2. * s3 - 3. * s2 + 1.;\n float c2 = -(2. * s3) + 3. * s2; \n float c3 = s3 - 2. * s2 + subV; \n float c4 = s3 - s2; \n\n vec3 t1 = (q2 - q0) * tension;\n vec3 t2 = (q3 - q1) * tension;\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \n}\n\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n \n vec3 q0 = getCurvePoint(cpId + 0.);\n vec3 q1 = getCurvePoint(cpId + 1.);\n vec3 q2 = getCurvePoint(cpId + 2.);\n vec3 q3 = getCurvePoint(cpId + 3.);\n vec3 q4 = getCurvePoint(cpId + 4.);\n vec3 q5 = getCurvePoint(cpId + 5.);\n\n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n #if 0\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #else\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #endif\n \n uv = vec2(ux, vy);\n}\n\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n float quadV = quadId / quadCount;\n float invQuadV = inv(quadV);\n vec3 pos;\n vec2 uv;\n\n float snd0 = texture2D(sound, vec2(0.03, quadV * 0.2)).a;\n float snd1 = 0.6;\n float snd2 = texture2D(sound, vec2(0.01 * 0.25, 0.)).a;\n \n getQuadPoint(quadId, pointId, mix(0.01, 0.20, pow(snd0 + 0.2, 15.)) + pow(snd2, 10.0) * 0.05, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n pos.z = quadV;\n \n// vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(vec3(\n mix(1., -1., mod(lineId, 2.)),\n mix(1., -1., mod(floor(lineId / 2.), 2.)),\n 1));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n// gl_Position.z = -m1p1(quadId / quadCount);\n// gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.95, snd0);\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invQuadV);\n //v_color = mix(v_color, vec4(1,0,0,1), pow(snd2, 15.));\n //v_color.a = mix(1.0, 0.0, step(50., mod(quadId, 100.)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n\n}\n\n" + }, "screenshotURL": "data/images/images-su2jo7ouvr74mcfou-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XXe4P5TiPiesZgiJj/art.json b/art/XXe4P5TiPiesZgiJj/art.json index df11b32b..28b0b353 100644 --- a/art/XXe4P5TiPiesZgiJj/art.json +++ b/art/XXe4P5TiPiesZgiJj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":64800,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/massc4line/massc4line-diamonds\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// add-em-up\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(\\n const float numEdgePointsPerCircle, \\n const float id, \\n const float inner, \\n const float start, \\n const float end, \\n out vec3 pos,\\n out vec2 cuv) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n cuv = vec2(u, v);\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 150.\\n#define NUM_RINGS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_RING (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_POINTS_PER_RING * NUM_RINGS_PER_CIRCLE)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cv = circleId / numCircles;\\n float ringId = floor(mod(vertexId, NUM_POINTS_PER_CIRCLE) / NUM_POINTS_PER_RING);\\n float ringV = ringId / NUM_RINGS_PER_CIRCLE;\\n \\n vec3 pos;\\n vec2 uv;\\n float inner = 0.5;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, vertexId, inner, start, end, pos, uv);\\n\\n float t = time * 0.03;\\n float snd = texture2D(\\n sound, \\n vec2(mix(cv * 0.1 + 0.1, cv * 0.1 + 0.2, fract(uv.x)), \\n 0)).a;\\n\\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 5.);\\n mat *= rotZ(time * -cv + length(pos) * sin(time));\\n mat *= trans(vec3(vec2(snd, snd) * 0.05, -cv));\\n mat *= uniformScale(mix(0.2, 3.8, pow(snd, 2.)));\\n mat *= uniformScale(ringV);\\n gl_Position = mat * vec4(pos, 1);\\n\\n float hue = circleId * 0.33 + floor(vertexId / 12.) * .5;\\n float sat = 1.; //mix(0., 1., mod(circleId, 3.) / 3.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.2);\\n}\\n\"}", + "settings": { + "num": 64800, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/massc4line/massc4line-diamonds", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// add-em-up\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(\n const float numEdgePointsPerCircle, \n const float id, \n const float inner, \n const float start, \n const float end, \n out vec3 pos,\n out vec2 cuv) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n cuv = vec2(u, v);\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 150.\n#define NUM_RINGS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_RING (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_POINTS_PER_RING * NUM_RINGS_PER_CIRCLE)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cv = circleId / numCircles;\n float ringId = floor(mod(vertexId, NUM_POINTS_PER_CIRCLE) / NUM_POINTS_PER_RING);\n float ringV = ringId / NUM_RINGS_PER_CIRCLE;\n \n vec3 pos;\n vec2 uv;\n float inner = 0.5;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, vertexId, inner, start, end, pos, uv);\n\n float t = time * 0.03;\n float snd = texture2D(\n sound, \n vec2(mix(cv * 0.1 + 0.1, cv * 0.1 + 0.2, fract(uv.x)), \n 0)).a;\n\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 5.);\n mat *= rotZ(time * -cv + length(pos) * sin(time));\n mat *= trans(vec3(vec2(snd, snd) * 0.05, -cv));\n mat *= uniformScale(mix(0.2, 3.8, pow(snd, 2.)));\n mat *= uniformScale(ringV);\n gl_Position = mat * vec4(pos, 1);\n\n float hue = circleId * 0.33 + floor(vertexId / 12.) * .5;\n float sat = 1.; //mix(0., 1., mod(circleId, 3.) / 3.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.2);\n}\n" + }, "screenshotURL": "data/images/images-tnzes9mzme5czmft7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XYGETLizFzAGcWS7N/art.json b/art/XYGETLizFzAGcWS7N/art.json index 0cba3a70..682fa731 100644 --- a/art/XYGETLizFzAGcWS7N/art.json +++ b/art/XYGETLizFzAGcWS7N/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() \\n{ \\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n \\n vec2 xy = vec2(0.0, 0.0);\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() \n{ \n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n \n vec2 xy = vec2(0.0, 0.0);\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-pvu1mjo3k22dquxr5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XZqZoCpsyifWWi6up/art.json b/art/XZqZoCpsyifWWi6up/art.json index 3f52cbb2..4aac287a 100644 --- a/art/XZqZoCpsyifWWi6up/art.json +++ b/art/XZqZoCpsyifWWi6up/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-gxy84npd5g6cdhq5v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XZuNgqyPsK9ePg5Xv/art.json b/art/XZuNgqyPsK9ePg5Xv/art.json index ed4ab854..f46ec54b 100644 --- a/art/XZuNgqyPsK9ePg5Xv/art.json +++ b/art/XZuNgqyPsK9ePg5Xv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lapixmusic/fugene2crossfade\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n\\n#define r 1.3 //KParameter 0.5>>4.\\n#define ocsFreq 1. //KParameter 1.>>4.\\n#define oscAmpFact 10. //KParameter 0.9>>2.\\n#define ocsFreq2 .05 //KParameter 1.>>4.\\n#define propagationFactor 0.5 //KParameter 1.>>4.\\n#define soundFactor 1. //KParameter 1.>>4.\\n#define shapeFactor0 1.25//KParameter 0.>>1.8\\n#define shapeFactor1 10.5 //KParameter 1.25>>2.\\n\\n//Shader functions\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\n}\\n\\nvec2 fSym(vec2 _p,float _s, float _h){\\n\\tvec2 k1 = v(_p,_s);\\n\\tvec2 k2 = v(_p+shapeFactor1*_h*k1,_s);\\n\\tvec2 k3 = v(_p+0.5*_h*k2,_s);\\n\\tvec2 k4 = v(_p+_h*k3,_s);\\n\\treturn _h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 colorize(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n //float finalDesiredPointSize = 1.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n float finalDesiredPointSize = resolution.x/across;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n u>0.5?u = 1.-u:u;\\n v>0.5?v = 1.- v:v;\\n \\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t\\n vec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\n \\tfor(int i = 0; i<20; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*propagationFactor + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=fSym(uv,s,hh);\\n\\t\\ts*=shapeFactor0;\\n\\t\\th/=1.25;\\n\\t }\\n\\t\\n v_color = vec4(colorize(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n\\n float tm = ocsFreq *time;\\n float tm2 = ocsFreq2*time;\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r/oscAmpFact, 0.3, r);\\n\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n float depth = soundFactor*(v_color.x+v_color.y+v_color.z)/3.;\\n \\n\\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = finalDesiredPointSize;\\n \\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lapixmusic/fugene2crossfade", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n\n#define r 1.3 //KParameter 0.5>>4.\n#define ocsFreq 1. //KParameter 1.>>4.\n#define oscAmpFact 10. //KParameter 0.9>>2.\n#define ocsFreq2 .05 //KParameter 1.>>4.\n#define propagationFactor 0.5 //KParameter 1.>>4.\n#define soundFactor 1. //KParameter 1.>>4.\n#define shapeFactor0 1.25//KParameter 0.>>1.8\n#define shapeFactor1 10.5 //KParameter 1.25>>2.\n\n//Shader functions\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\n}\n\nvec2 fSym(vec2 _p,float _s, float _h){\n\tvec2 k1 = v(_p,_s);\n\tvec2 k2 = v(_p+shapeFactor1*_h*k1,_s);\n\tvec2 k3 = v(_p+0.5*_h*k2,_s);\n\tvec2 k4 = v(_p+_h*k3,_s);\n\treturn _h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 colorize(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n //float finalDesiredPointSize = 1.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n float finalDesiredPointSize = resolution.x/across;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n u>0.5?u = 1.-u:u;\n v>0.5?v = 1.- v:v;\n \n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t\n vec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \n \tfor(int i = 0; i<20; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*propagationFactor + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=fSym(uv,s,hh);\n\t\ts*=shapeFactor0;\n\t\th/=1.25;\n\t }\n\t\n v_color = vec4(colorize(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n\n float tm = ocsFreq *time;\n float tm2 = ocsFreq2*time;\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r/oscAmpFact, 0.3, r);\n\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n float depth = soundFactor*(v_color.x+v_color.y+v_color.z)/3.;\n \n\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = finalDesiredPointSize;\n \n}\n\n" + }, "screenshotURL": "data/images/images-nlpto5wczbp2d0dbb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XbaHQ2ETsxu6kZKno/art.json b/art/XbaHQ2ETsxu6kZKno/art.json index 1a3bf19e..6c9ac23d 100644 --- a/art/XbaHQ2ETsxu6kZKno/art.json +++ b/art/XbaHQ2ETsxu6kZKno/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "luis", "avatarUrl": "https://graph.facebook.com/10208687216256743/picture?type=large", - "settings": "{\"num\":34737,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec2 func(float vertexId){\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = ux /20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n vec2 xy = vec2(x, y);\\n return xy;\\n}\\n\\n\\n\\nvoid main()\\n{\\n float circleID = floor(vertexId/120.0);\\n float circleCount = floor(vertexCount/120.0);\\n \\n float sqrTotal = floor(sqrt(circleCount));\\n float width = sqrTotal;\\n \\n float x = mod(circleID, width); // [0, width - 1]\\n float y = floor(circleID / width); // [0, inf]\\n\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float ux = u * 2.0 - 1.0 ;\\n float vy = v * 2.0 - 1.0 ;\\n \\n vec2 xy = vec2(ux, vy)* 1.1;\\n \\n \\n gl_Position = vec4(xy + (func(vertexId)* 0.02), 0.0, 1.0);\\n \\n \\n gl_PointSize = 15.0 ;\\n gl_PointSize *= 32.0 / width;\\n \\n \\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 34737, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec2 func(float vertexId){\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = ux /20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n vec2 xy = vec2(x, y);\n return xy;\n}\n\n\n\nvoid main()\n{\n float circleID = floor(vertexId/120.0);\n float circleCount = floor(vertexCount/120.0);\n \n float sqrTotal = floor(sqrt(circleCount));\n float width = sqrTotal;\n \n float x = mod(circleID, width); // [0, width - 1]\n float y = floor(circleID / width); // [0, inf]\n\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float ux = u * 2.0 - 1.0 ;\n float vy = v * 2.0 - 1.0 ;\n \n vec2 xy = vec2(ux, vy)* 1.1;\n \n \n gl_Position = vec4(xy + (func(vertexId)* 0.02), 0.0, 1.0);\n \n \n gl_PointSize = 15.0 ;\n gl_PointSize *= 32.0 / width;\n \n \n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-qp1aq8oim1pyzqk6w-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XcHuNB7GLk9BmQRap/art.json b/art/XcHuNB7GLk9BmQRap/art.json index 595276d2..e16ff298 100644 --- a/art/XcHuNB7GLk9BmQRap/art.json +++ b/art/XcHuNB7GLk9BmQRap/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n} \\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\n\\nvec2 getFragCoord(in float _finalDesiredPointSize, out float _finalVertexCount, out float _finalVertexId, out vec2 _finalResolution )\\n{\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n _finalVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n _finalResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n _finalResolution.y = floor(_finalVertexCount / _finalResolution.x);\\n _finalVertexId = mod(vertexId,_finalVertexCount);\\n return vec2(0.,0.);\\n}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n vec2 vertexResolution = vec2(0.);\\n \\n //first the number of elements in a line\\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n\\n //then the number of possible lines with the given vertexCount\\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //vec2 vfragCoord = vec2((x /vertexResolution.x),(y /vertexResolution.y));\\n vec2 vfragCoord = vec2((x /vertexResolution.x),(y /vertexResolution.y));\\n \\n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\\n \\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 st = uv;\\n\\tst.x *= resolution.x / resolution.y;\\n\\n\\tvec2 pos = st.yx* vec2(10.0, 3.0);\\n\\t\\n\\tfloat pattern = pos.x;\\n\\t\\n\\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\\n\\t\\n\\tpattern = lines(pos, 0.5);\\n\\t\\n\\t\\n\\n //camera\\n float r = 2.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(vec3(pattern), 1.0);\\n \\n vec4 finalPos = vec4(ux, vy, 0., 1.);\\n \\n gl_Position = finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n} \n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\n\nvec2 getFragCoord(in float _finalDesiredPointSize, out float _finalVertexCount, out float _finalVertexId, out vec2 _finalResolution )\n{\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n _finalVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n _finalResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n _finalResolution.y = floor(_finalVertexCount / _finalResolution.x);\n _finalVertexId = mod(vertexId,_finalVertexCount);\n return vec2(0.,0.);\n}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n vec2 vertexResolution = vec2(0.);\n \n //first the number of elements in a line\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n\n //then the number of possible lines with the given vertexCount\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //vec2 vfragCoord = vec2((x /vertexResolution.x),(y /vertexResolution.y));\n vec2 vfragCoord = vec2((x /vertexResolution.x),(y /vertexResolution.y));\n \n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\n \n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 st = uv;\n\tst.x *= resolution.x / resolution.y;\n\n\tvec2 pos = st.yx* vec2(10.0, 3.0);\n\t\n\tfloat pattern = pos.x;\n\t\n\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\n\t\n\tpattern = lines(pos, 0.5);\n\t\n\t\n\n //camera\n float r = 2.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(vec3(pattern), 1.0);\n \n vec4 finalPos = vec4(ux, vy, 0., 1.);\n \n gl_Position = finalPos;\n}" + }, "screenshotURL": "data/images/images-zqjuqnuy7oyx87s34-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XcY8PN835BKPhMe3Z/art.json b/art/XcY8PN835BKPhMe3Z/art.json index d3433bdf..16cc9572 100644 --- a/art/XcY8PN835BKPhMe3Z/art.json +++ b/art/XcY8PN835BKPhMe3Z/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "Magic #s", "username": "-anon-", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define TAU 6.2831853\\n#define NUM_SEGMENTS (1.61803 * 4.0)\\n#define NUM_POINTS (NUM_SEGMENTS * 1.61803)\\n#define STEP 5.0\\n#define GOLDEN 1.61803\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + (TAU - PI);\\n float point = mod(floor(vertexId / PI) + mod(vertexId, PI) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * TAU * PI / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * GOLDEN);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define TAU 6.2831853\n#define NUM_SEGMENTS (1.61803 * 4.0)\n#define NUM_POINTS (NUM_SEGMENTS * 1.61803)\n#define STEP 5.0\n#define GOLDEN 1.61803\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + (TAU - PI);\n float point = mod(floor(vertexId / PI) + mod(vertexId, PI) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * TAU * PI / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * GOLDEN);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-c5c0itdfj2wtbccig-thumbnail.jpg", "views": { "$numberInt": "163" diff --git a/art/XdrvWYBfFbiFtfmNL/art.json b/art/XdrvWYBfFbiFtfmNL/art.json index c7707efe..1a261deb 100644 --- a/art/XdrvWYBfFbiFtfmNL/art.json +++ b/art/XdrvWYBfFbiFtfmNL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Motion\\n// Course : CS250\\n// Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n \\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Motion\n// Course : CS250\n// Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n \n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-4n1at5gk9bbp8u6kg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Xf8ywY5kqr6qLRr2F/art.json b/art/Xf8ywY5kqr6qLRr2F/art.json index 9ca1b7b7..0f05f848 100644 --- a/art/Xf8ywY5kqr6qLRr2F/art.json +++ b/art/Xf8ywY5kqr6qLRr2F/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chris-camplin/arpo-marx\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n \\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float numPointsPerCircle = 3.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n\\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\\n float cols = floor(sqrt(numCircles));\\n float rows = floor(numCircles / cols);\\n // vertex ID is number of the vertex\\n float x = mod(circleId, rows); // divide by 10 keep the remainder, \\n float y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n float snd = pow(texture2D(sound, vec2(0.00025, 0.00025)).a, 20.);\\n\\n float v=vertexId/10.0;\\n int num=int(mouse.x*15.0+15.0+snd);\\n int den=int(exp(mouse.y*5.0+5.0*snd)+snd);\\n float frac=1.0-float(num)/float(den);\\n vec3 xyz=vec3(sin(v),cos(v)*sin(v*frac), cos(v))*2.0;\\n\\n for(int i = 0; i < 1; i++) {\\n xyz*=abs(xyz)/dot(xyz, xyz)-vec3(snd);\\n //xyz*=abs(xyz)/dot(xyz, xyz)-vec3(snd);\\n }\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\tvec4 pos = vec4(xyz * aspect, 1);\\n \\tmat4 mat = ident();\\n \\t//mat *= scale(vec3(1, aspect, 1));\\n mat *= rotX(time);\\n mat *= rotY(radians(-45.)*time*.5);\\n \\tmat *= rotZ(time);\\n gl_Position = pos*mat;\\n \\n vec4 color = vec4(1,1,snd, 1);\\n\\n vec4 finalColor = mix(color, background, snd);\\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chris-camplin/arpo-marx", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n \nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float numPointsPerCircle = 3.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n\n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\n float cols = floor(sqrt(numCircles));\n float rows = floor(numCircles / cols);\n // vertex ID is number of the vertex\n float x = mod(circleId, rows); // divide by 10 keep the remainder, \n float y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\n\n float snd = pow(texture2D(sound, vec2(0.00025, 0.00025)).a, 20.);\n\n float v=vertexId/10.0;\n int num=int(mouse.x*15.0+15.0+snd);\n int den=int(exp(mouse.y*5.0+5.0*snd)+snd);\n float frac=1.0-float(num)/float(den);\n vec3 xyz=vec3(sin(v),cos(v)*sin(v*frac), cos(v))*2.0;\n\n for(int i = 0; i < 1; i++) {\n xyz*=abs(xyz)/dot(xyz, xyz)-vec3(snd);\n //xyz*=abs(xyz)/dot(xyz, xyz)-vec3(snd);\n }\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \tvec4 pos = vec4(xyz * aspect, 1);\n \tmat4 mat = ident();\n \t//mat *= scale(vec3(1, aspect, 1));\n mat *= rotX(time);\n mat *= rotY(radians(-45.)*time*.5);\n \tmat *= rotZ(time);\n gl_Position = pos*mat;\n \n vec4 color = vec4(1,1,snd, 1);\n\n vec4 finalColor = mix(color, background, snd);\n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-g5rjv9b4talrgrvqh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Xh6Hmvi8yPW6A6rFG/art.json b/art/Xh6Hmvi8yPW6A6rFG/art.json index 71aa21d9..e50c2a3f 100644 --- a/art/Xh6Hmvi8yPW6A6rFG/art.json +++ b/art/Xh6Hmvi8yPW6A6rFG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Vertexshaderart : Motion_Extra\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float yoff = sin(time + y * 0.2) * 0.1;\\n float xoff = sin(time + x * 0.3) * 0.2;\\n xoff += abs(sin(time) * 0.2);\\n yoff += cos(time) * 0.3;\\n\\n float ux = u * 2. - 1. + xoff;\\n ux += u * 2. - 1. + yoff;\\n\\n float vy = v * 2. - 1. + yoff;\\n vy = v * 2. - 1. + xoff;\\n\\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.9, 1) + sin(time) * 0.5;\\n gl_Position += xoff;\\n gl_Position += yoff;\\n\\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(abs(sin(time)), abs(ux), cos(time) * vy, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Vertexshaderart : Motion_Extra\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float yoff = sin(time + y * 0.2) * 0.1;\n float xoff = sin(time + x * 0.3) * 0.2;\n xoff += abs(sin(time) * 0.2);\n yoff += cos(time) * 0.3;\n\n float ux = u * 2. - 1. + xoff;\n ux += u * 2. - 1. + yoff;\n\n float vy = v * 2. - 1. + yoff;\n vy = v * 2. - 1. + xoff;\n\n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.9, 1) + sin(time) * 0.5;\n gl_Position += xoff;\n gl_Position += yoff;\n\n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(abs(sin(time)), abs(ux), cos(time) * vy, 1);\n}" + }, "screenshotURL": "data/images/images-r9jsbh0rduq2vpdfo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Xhey4x8tEsNyKymgw/art.json b/art/Xhey4x8tEsNyKymgw/art.json index 1786bcac..a8a339bd 100644 --- a/art/Xhey4x8tEsNyKymgw/art.json +++ b/art/Xhey4x8tEsNyKymgw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/maslyastar/capsule-world-of-fantasy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.611764705882353,0.9921568627450981,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.08, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * across * 1.1; - bxId * perBlock * 2.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * -5.;\\n vCubeOrigin.y += 10. + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 0.5 + PI * 0.5 + snd);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = mix(0.4, 0.6, s2) + step(0.98, s2) * 0.4;\\n float sat = step(0.45,s2);\\n float val = 1.;\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -0.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/maslyastar/capsule-world-of-fantasy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.611764705882353, + 0.9921568627450981, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.08, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * across * 1.1; - bxId * perBlock * 2.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * -5.;\n vCubeOrigin.y += 10. + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 0.5 + PI * 0.5 + snd);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = mix(0.4, 0.6, s2) + step(0.98, s2) * 0.4;\n float sat = step(0.45,s2);\n float val = 1.;\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -0.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-sdcdks3izd740nbmv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XjN7HgsDKsJeibek9/art.json b/art/XjN7HgsDKsJeibek9/art.json index 1b6b13f1..0f0abb3f 100644 --- a/art/XjN7HgsDKsJeibek9/art.json +++ b/art/XjN7HgsDKsJeibek9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":33211,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/didrec/ken-ishii-malfunction-10\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner =mouse.y;\\n float start = mouse.x;\\n float end =step(0.3,0.5+s);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.0123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(t * .1) * 20., sin(t * .3) * 10.*s, 0.2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .017);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\\n float sat =1.0;step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb /= v_color.a*s;\\n \\n float super = step(0.9, 1.-s);\\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\\n \\n}\\n\"}", + "settings": { + "num": 33211, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/didrec/ken-ishii-malfunction-10", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner =mouse.y;\n float start = mouse.x;\n float end =step(0.3,0.5+s);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.0123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(t * .1) * 20., sin(t * .3) * 10.*s, 0.2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .017);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\n float sat =1.0;step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb /= v_color.a*s;\n \n float super = step(0.9, 1.-s);\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\n \n}\n" + }, "screenshotURL": "data/images/images-xwv98khs20vbw6xzn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Xo2HRcvBcs4Q8Cc7v/art.json b/art/Xo2HRcvBcs4Q8Cc7v/art.json index 71d4c428..e5b18a02 100644 --- a/art/Xo2HRcvBcs4Q8Cc7v/art.json +++ b/art/Xo2HRcvBcs4Q8Cc7v/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3411764705882353,0,0.23137254901960785,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Motion is due\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = cos(time + y *(mouse.x + 1.) / 2.) * 0.03;\\n float yoff = sin(time + x * (mouse.x + 1.) / 2.) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.05) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(0, 1, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3411764705882353, + 0, + 0.23137254901960785, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Motion is due\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = cos(time + y *(mouse.x + 1.) / 2.) * 0.03;\n float yoff = sin(time + x * (mouse.x + 1.) / 2.) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.05) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(0, 1, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-f3qz3pra1bjgddsjk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XpfxjsLJWz8DSuALM/art.json b/art/XpfxjsLJWz8DSuALM/art.json index 95960be3..0fc2e54c 100644 --- a/art/XpfxjsLJWz8DSuALM/art.json +++ b/art/XpfxjsLJWz8DSuALM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.058823529411764705,0.12156862745098039,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\\n \\n gl_PointSize = pow(snd+0.2,5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n float pump = step(0.8,snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1;//+ sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1.,pump);\\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.058823529411764705, + 0.12156862745098039, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\n \n gl_PointSize = pow(snd+0.2,5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n float pump = step(0.8,snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1;//+ sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1.,pump);\n float val = mix(.1,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}" + }, "screenshotURL": "data/images/images-7gida2zt5jd8v3gqe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XqxXcf4LvJjKuyAk6/art.json b/art/XqxXcf4LvJjKuyAk6/art.json index 5344b73f..e8cdf29c 100644 --- a/art/XqxXcf4LvJjKuyAk6/art.json +++ b/art/XqxXcf4LvJjKuyAk6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/psychofilthrecords/pfsa003\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#45963.0\\nvec2 vertexResolution = resolution;\\n\\n#define sndFactor 1.0//KParameter 0.>>1.\\n#define timeFactor 0.1;//KParameter 0.1>>5..\\n\\n\\n//#ifdef GL_ES\\n//precision highp float;\\n//#endif \\n\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n \\n//#define time (time + 100.0)\\n#define PI 3.14159265358979323846\\n\\nfloat box(vec2 _st, vec2 _size, float _smoothEdges){\\n _size = vec2(1.75)-_size*0.75;\\n vec2 aa = vec2(_smoothEdges*0.5);\\n vec2 uv = smoothstep(_size,_size+aa,_st);\\n uv *= smoothstep(_size,_size+aa,vec2(1.0)-_st);\\n return uv.x*uv.y;\\n}\\n\\nvec2 tile(vec2 _st, float _zoom){\\n _st *= _zoom;\\n return fract(_st);\\n}\\n\\nvec2 rotate2D(vec2 _st, float _angle, vec2 shift){\\n _st -= 0.5 + shift.x;\\n _st = mat2(cos(_angle),-sin(_angle),\\n sin(_angle),cos(_angle)) * _st;\\n _st += 0.5 + shift.y;\\n return _st;\\n}\\n\\nvoid main(void){\\nfloat finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\n \\n float snd = 1.*texture2D(sound, vec2(0., 1./finalVertexId)).a;\\n \\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n\\tvec2 v = (simFragCoord.xy - vertexResolution/2.0) / min(vertexResolution.y,vertexResolution.x) * 5.0;\\n\\tvec2 vv = v; vec2 vvv = v;\\n\\tfloat tm = time*timeFactor;\\n\\tvec2 mspt = (vec2(\\n\\t\\t\\tsin(tm)+cos(tm*snd)+sin(tm*snd)+cos(tm*-snd)+sin(tm*snd),\\n\\t\\t\\tcos(tm)+sin(tm*snd)+cos(tm*snd)+sin(tm*-1.1)+cos(tm*snd)\\n\\t\\t\\t)+15.0)*0.03;\\n\\t\\n\\t\\n\\tvec2 simple = (vec2(sin(tm), cos(tm)) + 1.5) * 0.15;\\n\\tfloat R = 0.0;\\n\\tfloat RR = 0.0;\\n\\tfloat RRR = 0.0;\\n\\tfloat a = (.6-simple.x)*6.2;\\n\\tfloat C = cos(a);\\n\\tfloat S = sin(a);\\n\\tvec2 xa=vec2(C, -S);\\n\\tvec2 ya=vec2(S, C);\\n\\tvec2 shift = vec2( 1.2, 1.62);\\n\\tfloat Z = 1.0 + simple.y*6.0;\\n\\tfloat ZZ = 1.0 + (simple.y)*6.2;\\n\\tfloat ZZZ = 1.0 + (simple.y)*6.9;\\n\\t\\n\\tvec2 b = simFragCoord.xy/(vertexResolution);\\n\\tb = rotate2D(b, PI*Z, 0.05*xa);\\n\\t//b = vec2(box(b,vec2(1.1),0.95));\\n\\tfloat linit = 25.;//*snd;\\n\\tfor ( int i = 0; i < 25; i++ ){\\n\\t\\tfloat br = dot(b,b);\\n\\t\\tfloat r = dot(v,v);\\n\\t\\tif ( r > sin(tm) + 3.0 )\\n\\t\\t{\\n\\t\\t\\tr = (sin(tm) + 3.0)/r ;\\n\\t\\t\\tv.x = v.x * r + 0.;\\n\\t\\t\\tv.y = v.y * r + 0.;\\n\\t\\t}\\n\\t\\tif ( br > 0.75 )\\n\\t\\t{\\n\\t\\t\\tbr = (0.56)/br ;\\n\\t\\t\\t//v.x = v.x * r + 0.;\\n\\t\\t\\t//v.y = v.y * r + 0.;\\n\\t\\t}\\n\\t\\t\\n\\t\\tR *= 1.05;\\n\\t\\tR += br;//b.x;\\n\\t\\tif(i < 24){\\n\\t\\t\\tRR *= 1.05;\\n\\t\\t\\tRR += br;//b.x;\\n\\t\\t\\tif(i <23){\\n\\t\\t\\t\\tRRR *= snd*1.05;\\n\\t\\t\\t\\tRRR += br;//b.x;\\n\\t\\t\\t}\\n\\t\\t}\\n\\t\\t\\n\\t\\tv = vec2( dot(v, xa), dot(v, ya)) * Z + shift;\\n\\t\\t//b = vec2( dot(b.xy, xa), dot(b.xy, ya)) * Z + shift;\\n\\t\\t//b = rotate2D(vec2( dot(v, xa), dot(v, ya)), PI*Z, ya);\\n\\t\\t//b = vec2( dot(b, xa), dot(b, ya));\\n\\t\\tb = vec2(box(v,vec2(5.),0.9)) + shift * 0.42;\\n\\t}\\n\\tfloat c = ((mod(R,2.0)>1.0)?1.0-fract(R):fract(R));\\n\\tfloat cc = ((mod(RR,2.0)>1.0)?1.0-fract(RR):fract(RR));\\n\\tfloat ccc = ((mod(RRR,2.0)>1.0)?1.0-fract(RRR):fract(RRR));\\n\\tv_color = vec4(ccc,cc,c, 1.0);\\n //gl_Position.y +=snd*0.1*ccc;\\n gl_Position.xy+=snd*sndFactor*v_color.xy;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/psychofilthrecords/pfsa003", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#45963.0\nvec2 vertexResolution = resolution;\n\n#define sndFactor 1.0//KParameter 0.>>1.\n#define timeFactor 0.1;//KParameter 0.1>>5..\n\n\n//#ifdef GL_ES\n//precision highp float;\n//#endif \n\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n \n//#define time (time + 100.0)\n#define PI 3.14159265358979323846\n\nfloat box(vec2 _st, vec2 _size, float _smoothEdges){\n _size = vec2(1.75)-_size*0.75;\n vec2 aa = vec2(_smoothEdges*0.5);\n vec2 uv = smoothstep(_size,_size+aa,_st);\n uv *= smoothstep(_size,_size+aa,vec2(1.0)-_st);\n return uv.x*uv.y;\n}\n\nvec2 tile(vec2 _st, float _zoom){\n _st *= _zoom;\n return fract(_st);\n}\n\nvec2 rotate2D(vec2 _st, float _angle, vec2 shift){\n _st -= 0.5 + shift.x;\n _st = mat2(cos(_angle),-sin(_angle),\n sin(_angle),cos(_angle)) * _st;\n _st += 0.5 + shift.y;\n return _st;\n}\n\nvoid main(void){\nfloat finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\n \n float snd = 1.*texture2D(sound, vec2(0., 1./finalVertexId)).a;\n \ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n\tvec2 v = (simFragCoord.xy - vertexResolution/2.0) / min(vertexResolution.y,vertexResolution.x) * 5.0;\n\tvec2 vv = v; vec2 vvv = v;\n\tfloat tm = time*timeFactor;\n\tvec2 mspt = (vec2(\n\t\t\tsin(tm)+cos(tm*snd)+sin(tm*snd)+cos(tm*-snd)+sin(tm*snd),\n\t\t\tcos(tm)+sin(tm*snd)+cos(tm*snd)+sin(tm*-1.1)+cos(tm*snd)\n\t\t\t)+15.0)*0.03;\n\t\n\t\n\tvec2 simple = (vec2(sin(tm), cos(tm)) + 1.5) * 0.15;\n\tfloat R = 0.0;\n\tfloat RR = 0.0;\n\tfloat RRR = 0.0;\n\tfloat a = (.6-simple.x)*6.2;\n\tfloat C = cos(a);\n\tfloat S = sin(a);\n\tvec2 xa=vec2(C, -S);\n\tvec2 ya=vec2(S, C);\n\tvec2 shift = vec2( 1.2, 1.62);\n\tfloat Z = 1.0 + simple.y*6.0;\n\tfloat ZZ = 1.0 + (simple.y)*6.2;\n\tfloat ZZZ = 1.0 + (simple.y)*6.9;\n\t\n\tvec2 b = simFragCoord.xy/(vertexResolution);\n\tb = rotate2D(b, PI*Z, 0.05*xa);\n\t//b = vec2(box(b,vec2(1.1),0.95));\n\tfloat linit = 25.;//*snd;\n\tfor ( int i = 0; i < 25; i++ ){\n\t\tfloat br = dot(b,b);\n\t\tfloat r = dot(v,v);\n\t\tif ( r > sin(tm) + 3.0 )\n\t\t{\n\t\t\tr = (sin(tm) + 3.0)/r ;\n\t\t\tv.x = v.x * r + 0.;\n\t\t\tv.y = v.y * r + 0.;\n\t\t}\n\t\tif ( br > 0.75 )\n\t\t{\n\t\t\tbr = (0.56)/br ;\n\t\t\t//v.x = v.x * r + 0.;\n\t\t\t//v.y = v.y * r + 0.;\n\t\t}\n\t\t\n\t\tR *= 1.05;\n\t\tR += br;//b.x;\n\t\tif(i < 24){\n\t\t\tRR *= 1.05;\n\t\t\tRR += br;//b.x;\n\t\t\tif(i <23){\n\t\t\t\tRRR *= snd*1.05;\n\t\t\t\tRRR += br;//b.x;\n\t\t\t}\n\t\t}\n\t\t\n\t\tv = vec2( dot(v, xa), dot(v, ya)) * Z + shift;\n\t\t//b = vec2( dot(b.xy, xa), dot(b.xy, ya)) * Z + shift;\n\t\t//b = rotate2D(vec2( dot(v, xa), dot(v, ya)), PI*Z, ya);\n\t\t//b = vec2( dot(b, xa), dot(b, ya));\n\t\tb = vec2(box(v,vec2(5.),0.9)) + shift * 0.42;\n\t}\n\tfloat c = ((mod(R,2.0)>1.0)?1.0-fract(R):fract(R));\n\tfloat cc = ((mod(RR,2.0)>1.0)?1.0-fract(RR):fract(RR));\n\tfloat ccc = ((mod(RRR,2.0)>1.0)?1.0-fract(RRR):fract(RRR));\n\tv_color = vec4(ccc,cc,c, 1.0);\n //gl_Position.y +=snd*0.1*ccc;\n gl_Position.xy+=snd*sndFactor*v_color.xy;\n}" + }, "screenshotURL": "data/images/images-mtau5n6nxckkz4fyx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Xr5DemAP52ZcKLRbQ/art.json b/art/Xr5DemAP52ZcKLRbQ/art.json index 5379806a..ba8ca726 100644 --- a/art/Xr5DemAP52ZcKLRbQ/art.json +++ b/art/Xr5DemAP52ZcKLRbQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":95635,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/cloudchord/twitter-telephone\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0.25098039215686274,0.25098039215686274,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 64.0;\\n float pointsPerCircle = segmentsPerCircle * 2.0;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n \\n float vId = mod(vertexId, pointsPerCircle);\\n float cId = floor(vertexId / pointsPerCircle);\\n float cv = cId / numCircles;\\n float u = floor(vId / 2.0) + mod(vId, 2.0);\\n float v = u / segmentsPerCircle;\\n float a = v * PI * 2.0 + cv;\\n\\n vec2 p = vec2(\\n cos(a),\\n sin(a));\\n \\n float distFromCenter = length(p);\\n\\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.1, abs(v * 2. - 1.)),\\n abs(cv * 2. - 1.) * 1.0)\\n ).r;\\n \\n \\n float cvv = cv * 2. - 1.;\\n vec3 pos = vec3(\\n sin(cvv * PI * 0.5),\\n p * mix(0., 1., sin(cv * PI)) * s);\\n \\n \\n \\n float ct = time * 0.1;\\n vec3 eye = vec3(sin(ct), 0, cos(ct)) * 2.5;\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \\n mat *= cameraLookAt(eye, target, up);\\n gl_Position = mat * vec4(pos, 1);\\n\\n\\n float boost = step(0.7, s);\\n \\n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\\n float val = mix(0.25, 2.0, pow(s, 2.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 95635, + "mode": "LINES", + "sound": "https://soundcloud.com/cloudchord/twitter-telephone", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0.25098039215686274, + 0.25098039215686274, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid main() {\n float segmentsPerCircle = 64.0;\n float pointsPerCircle = segmentsPerCircle * 2.0;\n float numCircles = floor(vertexCount / pointsPerCircle);\n \n float vId = mod(vertexId, pointsPerCircle);\n float cId = floor(vertexId / pointsPerCircle);\n float cv = cId / numCircles;\n float u = floor(vId / 2.0) + mod(vId, 2.0);\n float v = u / segmentsPerCircle;\n float a = v * PI * 2.0 + cv;\n\n vec2 p = vec2(\n cos(a),\n sin(a));\n \n float distFromCenter = length(p);\n\n float s = texture2D(sound, vec2(\n mix(0.01, 0.1, abs(v * 2. - 1.)),\n abs(cv * 2. - 1.) * 1.0)\n ).r;\n \n \n float cvv = cv * 2. - 1.;\n vec3 pos = vec3(\n sin(cvv * PI * 0.5),\n p * mix(0., 1., sin(cv * PI)) * s);\n \n \n \n float ct = time * 0.1;\n vec3 eye = vec3(sin(ct), 0, cos(ct)) * 2.5;\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \n mat *= cameraLookAt(eye, target, up);\n gl_Position = mat * vec4(pos, 1);\n\n\n float boost = step(0.7, s);\n \n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\n float val = mix(0.25, 2.0, pow(s, 2.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-t7fxkyq6w8phdipef-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Xr7T9xN4h3JyWhJ4M/art.json b/art/Xr7T9xN4h3JyWhJ4M/art.json index 78141a51..f4649fd4 100644 --- a/art/Xr7T9xN4h3JyWhJ4M/art.json +++ b/art/Xr7T9xN4h3JyWhJ4M/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#40190.0\\n//Another experiment of 'vertexification' of a fragment shader \\n\\n#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\tif(v>0.5)\\n v = 1.- v;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 1.3;\\n float tm = 1.5 *time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\\n //vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 2.;///abs(gl_Position.z);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#40190.0\n//Another experiment of 'vertexification' of a fragment shader \n\n#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\tif(v>0.5)\n v = 1.- v;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 1.3;\n float tm = 1.5 *time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\n //vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 2.;///abs(gl_Position.z);\n \n //v_color = vec4(1.,1.,1.,1.);\n}\n\n" + }, "screenshotURL": "data/images/images-0ducgjhu9xqhgw85j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XreNJG2gcwCcsQqfL/art.json b/art/XreNJG2gcwCcsQqfL/art.json index cd49259b..e78dbc0e 100644 --- a/art/XreNJG2gcwCcsQqfL/art.json +++ b/art/XreNJG2gcwCcsQqfL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-d07yy56eho5p30wdd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XsyLRu9hP28JhAank/art.json b/art/XsyLRu9hP28JhAank/art.json index a56445e5..fb8a705f 100644 --- a/art/XsyLRu9hP28JhAank/art.json +++ b/art/XsyLRu9hP28JhAank/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES \\n\\n#define KP0 2.0 //KParameter0 0.>>10.\\n#define KP1 3.0//Kparameter1 0.>>5.\\n#define KP2 2.0//KParameter2 0.>>5.\\n#define KP3 0.0//KParameter3 0.>>0.5\\n#define KP4 2.0//KParameter4 0.>>2.0\\n\\n#define PI radians(180.)\\n#define SIZE 90.0\\n#define NUM_CUBES (SIZE*SIZE*SIZE)\\n#define NUM_TRIANGLES (NUM_CUBES*6)\\n#define NUM_VERTICES (NUM_TRIANGLES*6)\\n#define STEP 80.0\\n\\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nvec3 camPath(float t){\\n \\n //return vec3(0, 0, t); // Straight path.\\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\\n \\n //float s = sin(t/24.)*cos(t/12.);\\n //return vec3(s*12., 0., t);\\n \\n float a = -sin(t * 0.011);\\n float b = cos(t * 0.014);\\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\\n \\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nfloat map(vec3 p){\\n \\n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\\n \\n p *= 0.4;\\n \\n\\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\\n \\n \\n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\\n\\n // It's an easy field to create, but not so great to hone in one. The \\\"1.4\\\" fudge factor\\n // is there to get a little extra distance... Obtained by trial and error.\\n return (n - 1.025)*1.33;\\n \\n}\\n\\n\\nvoid main() {\\n \\n float speed = 10.0;\\n \\n vec3 wpos = vec3(0);\\n \\n vec3 pos = camPath(time*speed)*sin(-1.5*mouse.x);\\n \\n vec3 lookat = camPath(time*speed+2.0);\\n vec3 forward = normalize(lookat-pos);\\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\\n vec3 up = cross(forward,left);\\n \\n float id = vertexId;\\n \\n float numcube = floor(id/18.0);\\n float numquad = floor(id/6.0);\\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\\n float nori = mod(numquad,3.0);\\n //quadid = quadid ^ diri;\\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\\n \\n \\n vec3 mask;\\n if (nori < 0.5) {\\n mask = vec3(1,0,0);\\n } else if (nori < 1.5) {\\n mask = vec3(0,1,0);\\n } else {\\n mask = vec3(0,0,1);\\n }\\n \\n float size = floor(pow(vertexCount/23.0,1.0/3.0)*mouse.y)*2.;\\n \\n vec3 blockpos = vec3(\\n mod(floor(numcube),size),\\n mod(floor(numcube/size),size),\\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\\n \\n bool a = map(blockpos) > 0.0;\\n bool b = map(blockpos+mask) > 0.0;\\n \\n float diri;\\n \\n if (a == b) {\\n gl_Position = vec4(0,0,0,1);\\n return;\\n } else {\\n \\n float diri = 1.0;\\n if (b) {\\n diri = -diri;\\n quad.xy = quad.yx;\\n }\\n \\n vec3 nor = mask*(diri*2.0-1.0);\\n\\n wpos += mask.zxy*quad.x;\\n wpos += mask.yzx*quad.y;\\n\\twpos += mask;\\n wpos += blockpos;\\n\\n wpos -= 0.5;\\n\\n //wpos += vec3(data.xyz);\\n //wpos += float(gl_VertexID/6);\\n //wpos += u_centerPosition;\\n\\n\\n\\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\\n \\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\\n \\n p.x *= resolution.y/resolution.x;\\n\\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\\n\\n\\n float hue = (id * 1.001);\\n v_color = vec4(nor*0.5+0.5, 1);\\n }\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES \n\n#define KP0 2.0 //KParameter0 0.>>10.\n#define KP1 3.0//Kparameter1 0.>>5.\n#define KP2 2.0//KParameter2 0.>>5.\n#define KP3 0.0//KParameter3 0.>>0.5\n#define KP4 2.0//KParameter4 0.>>2.0\n\n#define PI radians(180.)\n#define SIZE 90.0\n#define NUM_CUBES (SIZE*SIZE*SIZE)\n#define NUM_TRIANGLES (NUM_CUBES*6)\n#define NUM_VERTICES (NUM_TRIANGLES*6)\n#define STEP 80.0\n\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n//https://www.shadertoy.com/view/4ttGDH\nvec3 camPath(float t){\n \n //return vec3(0, 0, t); // Straight path.\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\n \n //float s = sin(t/24.)*cos(t/12.);\n //return vec3(s*12., 0., t);\n \n float a = -sin(t * 0.011);\n float b = cos(t * 0.014);\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\n \n}\n\n//https://www.shadertoy.com/view/4ttGDH\nfloat map(vec3 p){\n \n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\n \n p *= 0.4;\n \n\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\n \n \n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\n\n // It's an easy field to create, but not so great to hone in one. The \"1.4\" fudge factor\n // is there to get a little extra distance... Obtained by trial and error.\n return (n - 1.025)*1.33;\n \n}\n\n\nvoid main() {\n \n float speed = 10.0;\n \n vec3 wpos = vec3(0);\n \n vec3 pos = camPath(time*speed)*sin(-1.5*mouse.x);\n \n vec3 lookat = camPath(time*speed+2.0);\n vec3 forward = normalize(lookat-pos);\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\n vec3 up = cross(forward,left);\n \n float id = vertexId;\n \n float numcube = floor(id/18.0);\n float numquad = floor(id/6.0);\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\n float nori = mod(numquad,3.0);\n //quadid = quadid ^ diri;\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\n \n \n vec3 mask;\n if (nori < 0.5) {\n mask = vec3(1,0,0);\n } else if (nori < 1.5) {\n mask = vec3(0,1,0);\n } else {\n mask = vec3(0,0,1);\n }\n \n float size = floor(pow(vertexCount/23.0,1.0/3.0)*mouse.y)*2.;\n \n vec3 blockpos = vec3(\n mod(floor(numcube),size),\n mod(floor(numcube/size),size),\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\n \n bool a = map(blockpos) > 0.0;\n bool b = map(blockpos+mask) > 0.0;\n \n float diri;\n \n if (a == b) {\n gl_Position = vec4(0,0,0,1);\n return;\n } else {\n \n float diri = 1.0;\n if (b) {\n diri = -diri;\n quad.xy = quad.yx;\n }\n \n vec3 nor = mask*(diri*2.0-1.0);\n\n wpos += mask.zxy*quad.x;\n wpos += mask.yzx*quad.y;\n\twpos += mask;\n wpos += blockpos;\n\n wpos -= 0.5;\n\n //wpos += vec3(data.xyz);\n //wpos += float(gl_VertexID/6);\n //wpos += u_centerPosition;\n\n\n\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\n \n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\n \n p.x *= resolution.y/resolution.x;\n\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\n\n\n float hue = (id * 1.001);\n v_color = vec4(nor*0.5+0.5, 1);\n }\n}" + }, "screenshotURL": "data/images/images-da96k3zyasin0n5tw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XszYFmoC9KohYbbBD/art.json b/art/XszYFmoC9KohYbbBD/art.json index 5831cd81..47d6f3ca 100644 --- a/art/XszYFmoC9KohYbbBD/art.json +++ b/art/XszYFmoC9KohYbbBD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"void main() {\\n \\n float density = 10.;\\n \\n float xoff = -0.5;\\n \\n float yoff = -0.5;\\n \\n float ux = 0.1;\\n \\n float uy = 0.1;\\n \\n float x = mod(vertexId , density);\\n \\n float y = mod(floor(vertexId / density), density);\\n \\n float step = mod(vertexId, density * density);\\n \\n float psize = 50.0 * sin(x) * sin(y) * (sin(time) + 2.);\\n \\n \\n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n \\n \\n gl_PointSize = psize;\\n\\n v_color = vec4(y / 10. ,x / 10. , x + y / 20., 1);\\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "void main() {\n \n float density = 10.;\n \n float xoff = -0.5;\n \n float yoff = -0.5;\n \n float ux = 0.1;\n \n float uy = 0.1;\n \n float x = mod(vertexId , density);\n \n float y = mod(floor(vertexId / density), density);\n \n float step = mod(vertexId, density * density);\n \n float psize = 50.0 * sin(x) * sin(y) * (sin(time) + 2.);\n \n \n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n \n \n gl_PointSize = psize;\n\n v_color = vec4(y / 10. ,x / 10. , x + y / 20., 1);\n\n}" + }, "screenshotURL": "data/images/images-xyirzksacdbsc57zg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Xt8cDbEMoZH7W7AFh/art.json b/art/Xt8cDbEMoZH7W7AFh/art.json index 80eb6f2e..7fa46461 100644 --- a/art/Xt8cDbEMoZH7W7AFh/art.json +++ b/art/Xt8cDbEMoZH7W7AFh/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":81691,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define KP0 mouse.x\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[1], 0, 0, 0,\\n s[2], s[1], 1, 0,\\n 0, 0, -s[3,1], 0,\\n 0, 0, s[1], 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 1800.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\\nvoid main() {\\n float quadCount = POINTS_PER_LINE / 2.; \\n float v = vertexId / vertexCount;\\n float invV = 1. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = sin(vertexId* 2.) / 1200.;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.006, 0.61, spread), mix(0.25, 1., v))).a;\\n \\n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * .11 + vertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\\n time-sin(snd1*KP0);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 5.4)).xyz, 0.82);\\n gl_Position.z = -m1p1(v);\\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 2.;\\n\\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\\n float sat = 0.2 + pow(snd0 + 0.2, 1.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), .2);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 81691, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n#define KP0 mouse.x\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[1], 0, 0, 0,\n s[2], s[1], 1, 0,\n 0, 0, -s[3,1], 0,\n 0, 0, s[1], 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 1800.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\nvoid main() {\n float quadCount = POINTS_PER_LINE / 2.; \n float v = vertexId / vertexCount;\n float invV = 1. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = sin(vertexId* 2.) / 1200.;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.006, 0.61, spread), mix(0.25, 1., v))).a;\n \n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * .11 + vertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\n time-sin(snd1*KP0);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 5.4)).xyz, 0.82);\n gl_Position.z = -m1p1(v);\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 2.;\n\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\n float sat = 0.2 + pow(snd0 + 0.2, 1.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), .2);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-3ayocf813zqisyo8b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XtozrhtGYyW42zNSp/art.json b/art/XtozrhtGYyW42zNSp/art.json index e40f0984..a65e0718 100644 --- a/art/XtozrhtGYyW42zNSp/art.json +++ b/art/XtozrhtGYyW42zNSp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvoid main() {\\n \\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvoid main() {\n \n}" + }, "screenshotURL": "data/images/images-b9dtwgaui22y3vbn2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XuJSbKXb7qtAKJ6AQ/art.json b/art/XuJSbKXb7qtAKJ6AQ/art.json index ed27f09f..ddcb8697 100644 --- a/art/XuJSbKXb7qtAKJ6AQ/art.json +++ b/art/XuJSbKXb7qtAKJ6AQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 75.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(1, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 4, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 75.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(1, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 4, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-9f98n7x11dbzkcko8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XuPDhjysnqKsPCbGK/art.json b/art/XuPDhjysnqKsPCbGK/art.json index 303f45db..93f97c9c 100644 --- a/art/XuPDhjysnqKsPCbGK/art.json +++ b/art/XuPDhjysnqKsPCbGK/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":5087,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Audio Reactive\\n// CS250 \\n// Spring/2022\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / (PI);\\n float av = length(vec2(su, sv));\\n \\n vec4 soundVal = texture2D(sound, vec2(au * 0.05, av * .25));\\n \\n \\n float snd = soundVal.a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.1, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 5087, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Audio Reactive\n// CS250 \n// Spring/2022\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / (PI);\n float av = length(vec2(su, sv));\n \n vec4 soundVal = texture2D(sound, vec2(au * 0.05, av * .25));\n \n \n float snd = soundVal.a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.1, snd);\n \n float hue = u * .1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-atr4yhag7r26codwj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XwLcGCStsrbhX6jFY/art.json b/art/XwLcGCStsrbhX6jFY/art.json index 095a0870..f3954264 100644 --- a/art/XwLcGCStsrbhX6jFY/art.json +++ b/art/XwLcGCStsrbhX6jFY/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/moods-grooves-records/phaze-dee-game-of-life-web\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25882352941176473,0.25882352941176473,0.25882352941176473,1],\"shader\":\"// data from https://github.com/Jezzamonn/fourier\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec2 fft(int freq, float amplitude, float phase, float time) {\\n float angle = PI * 2.0 * float(freq) * time + phase;\\n return vec2(cos(angle), sin(angle)) * amplitude;\\n}\\n\\nvec2 computeFFT(float t) {\\n vec2 p = vec2(0);\\n p += fft(0, 296.524077607952, 0.5328692201872761, t);\\n p += fft(1, 129.16512258296828, -2.90016335218518, t);\\n p += fft(-1, 63.77796615668684, 2.9224545501551584, t);\\n p += fft(3, 19.64466960507052, -2.4341521827648407, t);\\n p += fft(2, 15.225563957670408, 2.1065920733999985, t);\\n p += fft(4, 10.816890879510945, 2.768243749294925, t);\\n p += fft(6, 7.7798714613757785, 2.790776515902791, t);\\n p += fft(8, 6.679135366586027, -2.691421192706561, t);\\n p += fft(18, 6.618481262601785, -2.7811427287619805, t);\\n p += fft(-17, 6.194427860122354, 1.0295557956864945, t);\\n p += fft(-20, 6.068497179066321, 2.0845633129083545, t);\\n p += fft(13, 6.026155883530845, -2.9082280887418843, t);\\n p += fft(20, 5.87547467169867, 0.6567893346845978, t);\\n p += fft(12, 5.664082795931505, -0.7736185409154058, t);\\n p += fft(22, 5.504599257383946, -0.5566360694751388, t);\\n p += fft(-22, 5.146718591504782, -2.7391457150277336, t);\\n p += fft(-19, 4.967122293367857, -1.4319471520699776, t);\\n p += fft(-11, 4.537800748903001, 0.7806248091011616, t);\\n p += fft(16, 4.409897469465315, 2.5618942112767407, t);\\n p += fft(-25, 4.3819383386473865, -1.5151030062564892, t);\\n p += fft(-16, 4.149297744113447, 0.575845737238003, t);\\n p += fft(-12, 4.139174393444163, 2.982857273406526, t);\\n p += fft(-34, 4.07501017913087, 1.5981185989542064, t);\\n p += fft(-8, 4.074809962485297, -0.42486073575722444, t);\\n p += fft(5, 4.0206048747056125, -2.3082375418458945, t);\\n p += fft(11, 3.990542905551988, 2.3627881868284972, t);\\n p += fft(17, 3.955727644969372, 2.456663236004692, t);\\n p += fft(19, 3.8658362150758534, -1.6701042175865948, t);\\n p += fft(10, 3.8517952416210557, -1.9882991837519308, t);\\n p += fft(25, 3.8215186298010257, -0.9536339281017274, t);\\n p += fft(-6, 3.6465818944687634, -0.4459221391524853, t);\\n p += fft(-29, 3.2133268799952712, 2.9249873354735345, t);\\n p += fft(-13, 3.172984702723984, -0.25267920294558227, t);\\n p += fft(15, 3.1374261306697373, 2.4403069911326685, t);\\n p += fft(7, 3.0955422513620245, -1.711872929589281, t);\\n p += fft(-9, 2.880155339148816, 0.32676693145089336, t);\\n p += fft(-15, 2.8798999832519403, 0.9375984752072446, t);\\n p += fft(26, 2.79967174195265, -2.049901239880178, t);\\n p += fft(29, 2.7803332403386336, 0.5231959777340147, t);\\n p += fft(28, 2.7414647126009593, 0.4708642708868981, t);\\n p += fft(41, 2.6437612024221844, -2.9636977093225685, t);\\n p += fft(39, 2.6295641656754234, -2.277801278923058, t);\\n p += fft(27, 2.6183263816781324, 2.784381034343638, t);\\n p += fft(-4, 2.612279805775902, 1.1701981679810707, t);\\n p += fft(34, 2.5896488928989925, 0.8874838650026977, t);\\n p += fft(-18, 2.568509187236616, -0.9803167206473404, t);\\n p += fft(-28, 2.507964971759851, 3.026960979082897, t);\\n p += fft(-14, 2.4945338840886677, -0.18814398163405743, t);\\n p += fft(-3, 2.4553487715159696, -2.515704298686429, t);\\n p += fft(-10, 2.347972482924663, -0.9661461748548102, t);\\n p += fft(9, 2.3353227667810943, 2.6662410983119873, t);\\n p += fft(-27, 2.2841877482065778, 0.6357945200731572, t);\\n p += fft(-33, 2.2359717418821874, -2.6756775052827853, t);\\n p += fft(37, 2.0731181353939196, -2.8767957104561597, t);\\n p += fft(43, 2.046908477381298, -0.848325445419195, t);\\n p += fft(40, 1.9650400072060998, 1.4954865245732736, t);\\n p += fft(31, 1.920647139346876, -0.8820561267540269, t);\\n p += fft(-37, 1.8264609429322551, -0.6283518255686783, t);\\n p += fft(-30, 1.8191188807994465, -2.078648696472338, t);\\n p += fft(-21, 1.7570644633051382, 2.614905728603112, t);\\n p += fft(24, 1.7380651990304348, 1.797588764641598, t);\\n p += fft(44, 1.6560026933156917, 0.27276010910919374, t);\\n p += fft(-44, 1.649213368528592, -2.697758361982687, t);\\n p += fft(-32, 1.6482613051000077, 1.7281181963111363, t);\\n p += fft(-38, 1.5957955338176892, 3.0229778848579327, t);\\n p += fft(50, 1.594057606604889, -2.705446593070425, t);\\n p += fft(33, 1.5853686682207064, -0.5898590645559981, t);\\n p += fft(-26, 1.567072721585987, -0.6245687779647491, t);\\n p += fft(23, 1.5345223856234949, -2.2815578356210735, t);\\n p += fft(36, 1.5087867231807512, -0.5742399182534951, t);\\n p += fft(-24, 1.4664813474877614, 2.7549795210299215, t);\\n p += fft(57, 1.4430652246678877, 2.1241473623512697, t);\\n p += fft(32, 1.406056560977162, 2.4473930566249096, t);\\n p += fft(54, 1.397187168634832, -1.5290316283596388, t);\\n p += fft(-35, 1.378962288401975, 1.030170830294626, t);\\n p += fft(-51, 1.3443697534460952, 0.7824834836125082, t);\\n p += fft(38, 1.2073849482228887, -1.417621395841823, t);\\n p += fft(52, 1.1813148530266455, -2.7146718708831226, t);\\n p += fft(58, 1.1546285984367923, -2.0469226839957546, t);\\n p += fft(-2, 1.148242184394193, 1.1600574990999488, t);\\n p += fft(-49, 1.1389035886326317, 2.536779536914916, t);\\n p += fft(14, 1.1329760186659397, 3.040831768189552, t);\\n p += fft(45, 1.1260078033316239, -2.6485676515902887, t);\\n p += fft(-36, 1.0505189643915007, 1.1512408246664814, t);\\n p += fft(48, 1.0434710403748044, -1.587473666465379, t);\\n p += fft(35, 1.0264643367771464, 0.8533152135907922, t);\\n p += fft(-77, 0.9957083595939865, 2.3018398053793176, t);\\n p += fft(-50, 0.9539520583808928, -1.8737321231607105, t);\\n p += fft(-23, 0.9292718478810791, -1.6156932158409079, t);\\n p += fft(-43, 0.9257761649922747, -0.9528711445133002, t);\\n p += fft(-46, 0.868581952908317, -1.7531859162182506, t);\\n p += fft(-47, 0.8477347332294584, 1.5654529539919164, t);\\n p += fft(-45, 0.8130585468017898, -0.6663785358206237, t);\\n p += fft(60, 0.7908050200984377, -0.1023181049126883, t);\\n p += fft(62, 0.7872325903381513, 1.030198597230489, t);\\n p += fft(-48, 0.7858142817398769, 1.387565504131415, t);\\n p += fft(49, 0.7704030031060537, 2.627354289464034, t);\\n p += fft(-84, 0.7688630997732272, -2.564222992505424, t);\\n p += fft(-39, 0.761830091495416, -2.4526438973987954, t);\\n p += fft(78, 0.7543732213279061, 2.343001847272033, t);\\n p += fft(-59, 0.7488095838105383, -3.1131016762144443, t);\\n p += fft(55, 0.7285003537607938, -0.9786713526593741, t);\\n p += fft(-31, 0.7248134830134255, -0.5543123381122909, t);\\n p += fft(-54, 0.7219542814654896, 2.94943367544441, t);\\n p += fft(-53, 0.7139986380620472, -1.2338229580467204, t);\\n p += fft(46, 0.6985299047036991, -0.3033719700149987, t);\\n p += fft(69, 0.6940778952546749, -1.0238518940571633, t);\\n p += fft(-40, 0.6927457316683343, 2.0054202454179775, t);\\n p += fft(-57, 0.67709432212438, -2.783806233466308, t);\\n p += fft(47, 0.6602293673831037, 1.1829982386683053, t);\\n p += fft(74, 0.6545825289163747, -0.6313191364037845, t);\\n p += fft(-5, 0.6200531105206556, -1.012708917351053, t);\\n p += fft(30, 0.6145303942405808, -0.006575553587373788, t);\\n p += fft(-65, 0.6130907552103994, -1.2775992452682625, t);\\n p += fft(83, 0.6078433173163771, -1.3921353502568135, t);\\n p += fft(53, 0.6029346402536699, 3.118126806639058, t);\\n p += fft(64, 0.593655747614559, -0.12929981693431084, t);\\n p += fft(87, 0.5917638000158103, 2.8165282828931195, t);\\n p += fft(75, 0.562070427870424, 2.935821150408132, t);\\n p += fft(51, 0.553965684266993, 0.8857804427580288, t);\\n p += fft(-69, 0.5402011495014111, -2.393077154815434, t);\\n p += fft(-67, 0.5247046263885512, -0.12626924765950584, t);\\n p += fft(80, 0.5211530645039045, -2.313552855619569, t);\\n p += fft(56, 0.5057370766773879, -2.628846336188085, t);\\n p += fft(-75, 0.5038585813938068, -1.8904143929736488, t);\\n p += fft(-73, 0.48644277854405304, 1.3709055508801584, t);\\n p += fft(-7, 0.47307925137425644, -2.55202847874333, t);\\n p += fft(94, 0.4614308523932489, 2.545636098697929, t);\\n p += fft(-74, 0.4419918759755517, 0.11529437409844774, t);\\n p += fft(65, 0.44169553192805927, 2.439841086433652, t);\\n p += fft(72, 0.43611612862779375, 0.9074545441173122, t);\\n p += fft(-66, 0.43502792411907976, -2.063079991837712, t);\\n p += fft(-42, 0.4314569651112275, 0.33687123321689777, t);\\n p += fft(-64, 0.40521665336797635, 0.003486215133649564, t);\\n p += fft(99, 0.40417092365602253, -1.8240004200677489, t);\\n p += fft(59, 0.3936963912394369, -1.6362215309246326, t);\\n p += fft(-60, 0.3815954958269982, -0.7754496988180308, t);\\n p += fft(-63, 0.3792381066868484, -1.9391548308871835, t);\\n p += fft(73, 0.37854582778783324, 0.043442146165603684, t);\\n p += fft(42, 0.37453717681808335, 2.38737562405369, t);\\n p += fft(21, 0.35583878846131595, -2.7839176861684014, t);\\n p += fft(112, 0.3547233494213232, 2.954248286045894, t);\\n p += fft(108, 0.35083273251102737, 2.5458627704061483, t);\\n p += fft(93, 0.35040473622512436, -0.029550910229384195, t);\\n p += fft(89, 0.3403049133299473, -2.885129447081889, t);\\n p += fft(-70, 0.3370256731757577, -0.46771663832106974, t);\\n p += fft(-78, 0.3366544726218109, -0.24724720507658238, t);\\n p += fft(82, 0.32610868403027304, -1.4954241039751592, t);\\n p += fft(-91, 0.32419682164009966, -1.3417496079852937, t);\\n p += fft(-90, 0.3234753025960112, -3.0133578986946814, t);\\n p += fft(-80, 0.2998816486209547, 3.096207886158368, t);\\n p += fft(71, 0.2984964350635909, -0.6377008416229164, t);\\n p += fft(85, 0.2961360685518227, 2.9392297581041658, t);\\n p += fft(111, 0.2939868074077519, 1.066357674174694, t);\\n p += fft(84, 0.2882922892341542, -0.2824472092836136, t);\\n p += fft(-62, 0.2823355494458707, 0.5392478382746477, t);\\n p += fft(101, 0.28043862110007006, 1.8969467658422987, t);\\n p += fft(-58, 0.27927463219687665, -2.5066886208410595, t);\\n p += fft(-114, 0.2787101344869982, -2.3945575768789205, t);\\n p += fft(-81, 0.27344747273177633, 0.19849972308144362, t);\\n p += fft(96, 0.268848539128237, 2.352065707231053, t);\\n p += fft(104, 0.2667328677077002, -2.6894745409478773, t);\\n p += fft(90, 0.2623194708267266, 2.6305846168436604, t);\\n p += fft(105, 0.2587320115138661, -0.44809280212853925, t);\\n p += fft(91, 0.25666403259093135, -0.42872274693200485, t);\\n p += fft(-94, 0.25344187481961844, -1.1325746386338256, t);\\n p += fft(67, 0.24928071126959497, 1.783113342037483, t);\\n p += fft(-61, 0.2486431701299056, -3.0289630409059964, t);\\n p += fft(-102, 0.24833449653800949, 2.814031321792728, t);\\n p += fft(115, 0.24216361168985745, 2.5259661057434784, t);\\n p += fft(-83, 0.24082180762961733, 2.327373899411901, t);\\n p += fft(-71, 0.2404736569240409, 2.8270765856325983, t);\\n p += fft(-95, 0.23819976781292496, 0.25934694371445854, t);\\n p += fft(128, 0.23600151920093423, -2.2635194564211036, t);\\n p += fft(-82, 0.23162812218159617, -0.40811639028183505, t);\\n p += fft(63, 0.231108841604306, 0.7896297030534211, t);\\n p += fft(66, 0.22876820962806374, -2.20689386652509, t);\\n p += fft(145, 0.22683296568648012, -2.871130626679519, t);\\n p += fft(114, 0.22579541537273998, -0.03888650023606557, t);\\n p += fft(-115, 0.22449806848298495, 1.7267840321105514, t);\\n p += fft(-101, 0.2201367259955669, -1.2160405006932076, t);\\n p += fft(70, 0.21924416034549526, -1.8300948469474085, t);\\n p += fft(-41, 0.2167988567102195, -0.8439248313023797, t);\\n p += fft(110, 0.21645852077265354, -0.959164313163234, t);\\n p += fft(158, 0.2151250144734518, 1.0174468948847888, t);\\n p += fft(106, 0.21196244851082488, -0.7429833668933534, t);\\n p += fft(-137, 0.20545059106326097, 2.8523980589526516, t);\\n p += fft(-99, 0.20544620480189876, 2.378277723073504, t);\\n p += fft(157, 0.20466861943591227, 1.5525202358047085, t);\\n p += fft(-97, 0.20297792194129058, -0.24324542189056148, t);\\n p += fft(168, 0.20130500227008466, -1.094673594091641, t);\\n p += fft(117, 0.19993871414763503, 2.850736702421766, t);\\n p += fft(98, 0.19737263515643355, 0.5877762863368731, t);\\n p += fft(-72, 0.1929911058483345, 0.010089217287886454, t);\\n p += fft(107, 0.19264056832987778, 0.704220700877197, t);\\n p += fft(-112, 0.19130748611122012, -2.392875008529597, t);\\n p += fft(-89, 0.1896856318579048, -1.952634273837995, t);\\n p += fft(-118, 0.1840849374841271, 2.66760266379526, t);\\n p += fft(-106, 0.1831571823504252, -0.22353534215395926, t);\\n p += fft(68, 0.18268583480820008, -1.6209797108511708, t);\\n p += fft(-55, 0.18120542886859284, 0.467068135124605, t);\\n p += fft(95, 0.17907416077732574, 1.0948396281940986, t);\\n p += fft(148, 0.17866061557325139, 2.3602934407666574, t);\\n p += fft(177, 0.17832736193972554, -1.6046679924839198, t);\\n p += fft(-108, 0.17809221310240264, -1.3634658504175172, t);\\n p += fft(-98, 0.17770123200232602, -2.319713221578887, t);\\n p += fft(100, 0.176886631202939, -1.121794475824346, t);\\n p += fft(124, 0.17654047192131325, -2.379198871802532, t);\\n p += fft(-88, 0.17639283951454524, -2.402190307443758, t);\\n p += fft(-174, 0.1759528058963321, -2.2025378411458227, t);\\n p += fft(140, 0.1753854668907291, 0.42397843457703155, t);\\n p += fft(-96, 0.1753429914194849, -2.5609307243169104, t);\\n p += fft(86, 0.17047016491561567, -2.1287646574123906, t);\\n p += fft(-116, 0.16955079792541142, 1.330523857460539, t);\\n p += fft(61, 0.16905959469199813, -2.6057097347432614, t);\\n p += fft(-121, 0.1688420653965695, -0.5090905584523955, t);\\n p += fft(155, 0.16680443183652535, -1.2332547487780734, t);\\n p += fft(171, 0.16582399968407263, -0.8747323409363787, t);\\n p += fft(-87, 0.1652225600618143, -2.085937535924309, t);\\n p += fft(-131, 0.16214898761358187, 1.9650981796384732, t);\\n p += fft(92, 0.15699998077784863, -0.18853113336883437, t);\\n p += fft(166, 0.1554844992569468, 2.2850556504133888, t);\\n p += fft(161, 0.15373402046283416, -0.7486102426340269, t);\\n p += fft(144, 0.15312278232769228, -0.3587853130578195, t);\\n p += fft(125, 0.15278331508565252, 0.6417517362772722, t);\\n p += fft(97, 0.15144010052991969, 1.0282568217837087, t);\\n p += fft(135, 0.15129294602934487, -0.6387137369146754, t);\\n p += fft(-56, 0.1457904354443015, 2.356685746244658, t);\\n p += fft(103, 0.1453915874749691, -0.6785631327279983, t);\\n p += fft(146, 0.14379520492495512, -0.7855888994349319, t);\\n p += fft(142, 0.1412707218042313, -0.1618563085599607, t);\\n p += fft(126, 0.13936676935400355, -2.4453404815078725, t);\\n p += fft(81, 0.13772359181353372, 0.5044424044942989, t);\\n p += fft(163, 0.13762314582762275, 1.639822161059763, t);\\n p += fft(134, 0.13545232146341332, 2.3024168785102312, t);\\n p += fft(165, 0.13509475913506178, -0.8279398617821645, t);\\n p += fft(-76, 0.13455680964642944, -3.0716219607883164, t);\\n p += fft(-127, 0.13207374762677063, -2.6599668223479727, t);\\n p += fft(-152, 0.13117632063169987, -2.5293527274604246, t);\\n p += fft(-105, 0.1311202673313172, -2.693197028055788, t);\\n p += fft(-145, 0.12945158970649637, 2.3951255425463125, t);\\n p += fft(119, 0.12925458048582072, 2.1883428437365144, t);\\n p += fft(132, 0.12746981347132513, -3.033026520788066, t);\\n p += fft(-85, 0.12653240774860508, -2.8680500174257837, t);\\n p += fft(-144, 0.12465405936107726, -0.37790452498667604, t);\\n p += fft(76, 0.12463110048880623, 0.12012177237288406, t);\\n p += fft(-142, 0.12459485706573038, 0.3051081828140754, t);\\n p += fft(-138, 0.12451331383970095, 0.584148256098649, t);\\n p += fft(149, 0.12401784752155019, -1.8125703421505832, t);\\n p += fft(-147, 0.12362040139712106, 0.03028190421886324, t);\\n p += fft(131, 0.12297013103130192, -1.7612969157441667, t);\\n p += fft(-148, 0.12201071321640686, -2.0282746264394236, t);\\n p += fft(-68, 0.12130140373799272, -0.9290611617024176, t);\\n p += fft(116, 0.12128775362324593, -1.5007597875190253, t);\\n p += fft(-135, 0.12111941530251287, -0.9133882438391181, t);\\n p += fft(-104, 0.12079045102618642, 0.9539883001598056, t);\\n p += fft(-86, 0.12063181239660088, -1.9105367933076451, t);\\n p += fft(102, 0.11858318427484749, 3.116549695906647, t);\\n p += fft(162, 0.11672334871059657, -0.43512865812715645, t);\\n p += fft(-128, 0.11555594493778179, 1.594914753823693, t);\\n p += fft(147, 0.11507078486852833, -1.8015902273798317, t);\\n p += fft(-125, 0.11380569936104315, -0.02432076846797433, t);\\n p += fft(-129, 0.1137850317216325, -2.6266191242164822, t);\\n p += fft(77, 0.11284625921171428, 0.6500879168724161, t);\\n p += fft(159, 0.11039859551711936, -2.8651146672170977, t);\\n p += fft(-206, 0.10898089539528502, 1.0381666149725348, t);\\n p += fft(-92, 0.10835773802225089, 0.6916172775229433, t);\\n p += fft(127, 0.10811810875499965, -2.998228956999233, t);\\n p += fft(-199, 0.10803687786223723, -2.46851901448902, t);\\n p += fft(-184, 0.1079436817269362, 1.3191475812437883, t);\\n p += fft(-161, 0.10743289221697289, 1.3169047201119328, t);\\n p += fft(-139, 0.10723255868931553, -1.7855768275688515, t);\\n p += fft(-130, 0.10575112607516497, 1.2885726884003454, t);\\n p += fft(-198, 0.10555774123223534, 2.3378343445027423, t);\\n p += fft(88, 0.1037982678523408, -2.57743331926905, t);\\n p += fft(-219, 0.10310221059641228, -1.2625859044047876, t);\\n p += fft(-103, 0.10235558593739706, 0.7768959419271573, t);\\n p += fft(-201, 0.10189587875806011, 2.395004608187347, t);\\n p += fft(174, 0.10047600105014917, -1.7769904121389015, t);\\n p += fft(113, 0.10019192995096364, 0.6613060769884679, t);\\n p += fft(186, 0.09888320495036292, 2.4232322332757033, t);\\n p += fft(143, 0.09873568608937729, -0.6230636594392547, t);\\n p += fft(-155, 0.0967869591188688, -1.7298363196681086, t);\\n p += fft(185, 0.09658335995961313, 1.1754529148166517, t);\\n p += fft(-177, 0.09656910791483884, 2.0163242572983346, t);\\n p += fft(-167, 0.09620604020928483, 2.643429513987398, t);\\n p += fft(170, 0.09573558303359174, -0.30695931132003684, t);\\n p += fft(180, 0.09461328604462575, -1.6239251039930218, t);\\n p += fft(-220, 0.0943272029181478, -1.4319742082110574, t);\\n p += fft(-52, 0.09420059423208178, 0.34189504423155104, t);\\n p += fft(-172, 0.09359535175565478, -0.6516984922913376, t);\\n p += fft(-110, 0.0928047006450446, 1.6652587522465396, t);\\n p += fft(151, 0.09250606338361644, -1.9756734220597145, t);\\n p += fft(-93, 0.09207328457476618, -1.8386442351917063, t);\\n p += fft(-136, 0.09192815271017309, 1.7852892175474182, t);\\n p += fft(-113, 0.09189336119191194, 0.1795575241258869, t);\\n p += fft(195, 0.09021546713204244, 2.2961250797130024, t);\\n p += fft(-150, 0.0890214588284327, -0.4242294361284968, t);\\n p += fft(-193, 0.08814677822860856, -3.032675290767406, t);\\n p += fft(172, 0.08787933668637724, 0.8937743898253856, t);\\n p += fft(-132, 0.08776566211120278, 1.6786784797215824, t);\\n p += fft(120, 0.08739819001501205, 2.0491345267796923, t);\\n p += fft(-237, 0.08676446852578372, -2.7506065977853367, t);\\n p += fft(-195, 0.08631820577015377, -2.292066178728447, t);\\n p += fft(-178, 0.08621869133141169, -2.289445548826154, t);\\n p += fft(-160, 0.0859070990539687, 0.8565575603400595, t);\\n p += fft(169, 0.08564275849176227, 1.4922004704741865, t);\\n p += fft(150, 0.08528562752062617, -2.271332020864171, t);\\n p += fft(136, 0.08341789857084404, 1.0652798481992052, t);\\n p += fft(199, 0.08332375555828694, -2.172498972819133, t);\\n p += fft(-235, 0.08327425440106223, -0.8722079224698919, t);\\n p += fft(-141, 0.08287851144036412, -0.2817694914314737, t);\\n p += fft(138, 0.08255129464089862, 2.481725429548499, t);\\n p += fft(-109, 0.0814238813994593, 2.810607915964862, t);\\n p += fft(-79, 0.08115343666484522, 3.0130919888081964, t);\\n p += fft(153, 0.0806615747018418, -2.90631621064385, t);\\n p += fft(-175, 0.0803741234494402, 2.4278323040306384, t);\\n p += fft(-143, 0.07972332355377411, -0.14610097282743986, t);\\n p += fft(-202, 0.07962980675194098, -0.2920969138999907, t);\\n p += fft(-120, 0.07894459678944289, -1.0822564599135749, t);\\n p += fft(-249, 0.07849391554379236, -1.5893682918262941, t);\\n p += fft(156, 0.07754124056908816, 2.6380926428153773, t);\\n p += fft(-158, 0.07639110613035878, -2.2498824982419814, t);\\n p += fft(191, 0.07543660088489744, 1.53576512075985, t);\\n p += fft(133, 0.07531833041051382, -0.29986287547697626, t);\\n p += fft(-176, 0.07501869195137476, -1.095228282011871, t);\\n p += fft(-173, 0.07438185135275685, -2.8547930590312265, t);\\n p += fft(-246, 0.07320459577858625, 3.004959078587308, t);\\n p += fft(-163, 0.07264231502260868, 0.5663326139154473, t);\\n /* ------ move this line up for more speed, down for more precision ----------\\n p += fft(206, 0.07185257960899775, -1.2074544409708887, t);\\n p += fft(-123, 0.07180358234742663, 1.177001822427382, t);\\n p += fft(164, 0.07179115512969167, 2.1602573633251723, t);\\n p += fft(188, 0.07150545575062967, 1.7193031745778165, t);\\n p += fft(224, 0.06999271922532711, -2.208456590100925, t);\\n p += fft(-194, 0.06998312687642928, -2.18523653052791, t);\\n p += fft(79, 0.06890472640127111, 1.3075753662847636, t);\\n p += fft(109, 0.06860075505611797, 1.6822381082814495, t);\\n p += fft(-212, 0.0678853204605727, 2.1130583033793853, t);\\n p += fft(160, 0.06721168671629134, 1.5355417936258289, t);\\n p += fft(-168, 0.06478428292880746, 1.8082125748786089, t);\\n p += fft(-100, 0.06418217011920442, 0.7154587151883682, t);\\n p += fft(-208, 0.06360704141059366, -2.403277839995585, t);\\n p += fft(137, 0.06324033312067673, -2.2610437967492656, t);\\n p += fft(123, 0.06295636338637589, 0.3970547395559689, t);\\n p += fft(-196, 0.0627324819432708, -2.6051526033441235, t);\\n p += fft(219, 0.06250233205660669, 2.203023925786526, t);\\n p += fft(-185, 0.0621114667768006, -0.5698975168684676, t);\\n p += fft(-166, 0.06210684036807704, 2.607205641731383, t);\\n p += fft(-205, 0.06175529499391064, 1.9171825820936816, t);\\n p += fft(-156, 0.061488097661469475, 1.4966065847312549, t);\\n p += fft(154, 0.061272027059191166, -2.6984551455468564, t);\\n p += fft(-231, 0.06035266134446573, 1.3615530640708646, t);\\n p += fft(141, 0.05955849823049297, 1.5515335051172228, t);\\n p += fft(-254, 0.05936948658056223, 0.08947841208696573, t);\\n p += fft(-223, 0.05924934830234196, -2.5888981145084804, t);\\n p += fft(-232, 0.05887059032744145, 0.01941763325695256, t);\\n p += fft(167, 0.05881968845436434, -1.0357803375284511, t);\\n p += fft(193, 0.058152494480082216, -0.4725096726740279, t);\\n p += fft(121, 0.05729621516472733, 1.7676238462353928, t);\\n p += fft(-268, 0.05725394282425765, -2.613958061844803, t);\\n p += fft(-302, 0.05709087761847913, 1.7622838278216528, t);\\n p += fft(-169, 0.05703481887597677, -0.6061202003738857, t);\\n p += fft(-228, 0.05673330948726983, 1.5024729233397405, t);\\n p += fft(222, 0.05638702685887402, -1.2302130026999638, t);\\n p += fft(-260, 0.05595371621472635, 1.2791472131268498, t);\\n p += fft(211, 0.05588512333449684, -1.8863675524330432, t);\\n p += fft(237, 0.05577640817605678, 0.9044485733453621, t);\\n p += fft(-210, 0.055436889934911734, -2.17570469763129, t);\\n p += fft(-107, 0.054515606954931885, 1.6064878994455691, t);\\n p += fft(-192, 0.054378774601921455, 0.177220838503605, t);\\n p += fft(-182, 0.053953358377995975, -2.1280204079638576, t);\\n p += fft(-263, 0.0538060156192732, -1.6125700112210792, t);\\n p += fft(212, 0.05372692488622374, 0.9420856343907927, t);\\n p += fft(-213, 0.053418601872005124, 2.7878022389569965, t);\\n p += fft(-248, 0.05287392885207208, 0.18442109948336485, t);\\n p += fft(226, 0.05219567026185329, -1.9364295452150295, t);\\n p += fft(198, 0.05216791125481548, -1.3500769286288878, t);\\n p += fft(-282, 0.05185758906196177, -1.0531164762937948, t);\\n p += fft(-111, 0.051505065799642175, -1.5496533180287155, t);\\n p += fft(-241, 0.05085304364706675, -0.46354003864012305, t);\\n p += fft(-124, 0.05032731737587234, -0.9525802310682452, t);\\n p += fft(-250, 0.050246365262025194, 0.8026967297965477, t);\\n p += fft(-211, 0.05012936662149643, 0.7247623593388082, t);\\n p += fft(-209, 0.05002408512494514, 1.8132755265361036, t);\\n p += fft(-252, 0.049775105705583016, 0.5996942868760795, t);\\n p += fft(223, 0.04939534137917373, -2.695791674918428, t);\\n p += fft(122, 0.04894575970718128, 2.8830421586085544, t);\\n p += fft(-153, 0.04887699031380359, 0.3334054103895581, t);\\n p += fft(-181, 0.047900428231714746, -2.21806751268122, t);\\n p += fft(299, 0.04768730955214819, 0.3243053297596023, t);\\n p += fft(-259, 0.04760097318206576, -0.8705493020585283, t);\\n p += fft(-227, 0.04622658586057274, 1.2806504451219154, t);\\n p += fft(-226, 0.04575599938137761, 2.99718633620427, t);\\n p += fft(-165, 0.04562578928136969, -0.9599207008754989, t);\\n p += fft(-119, 0.0452353353928757, -2.8588596616336357, t);\\n p += fft(-151, 0.04518238397772298, -0.13718441224107195, t);\\n p += fft(-255, 0.04513692897501351, 1.860335619309556, t);\\n p += fft(173, 0.04502237604956329, -0.810579987098727, t);\\n p += fft(-164, 0.04491854079446375, -2.2251696607200238, t);\\n p += fft(367, 0.04463225444542998, -1.3682718846259723, t);\\n p += fft(-238, 0.044492812350265004, -1.30018967859005, t);\\n p += fft(213, 0.04433393493985305, -2.5049897246887496, t);\\n p += fft(-217, 0.04394773639883994, 0.3578708012733398, t);\\n p += fft(-191, 0.04378025799588553, -0.0033036474870014217, t);\\n p += fft(252, 0.04323472173070737, -0.6242705523897715, t);\\n p += fft(208, 0.04304212913333182, 1.2308490125522018, t);\\n p += fft(-303, 0.04296800234600092, 0.5114427759851766, t);\\n p += fft(-224, 0.04272023945142006, 1.7783110640430169, t);\\n p += fft(-239, 0.04266679157025011, 1.9482200717681597, t);\\n p += fft(-299, 0.04173701435724602, 0.13365408028225706, t);\\n p += fft(-157, 0.04146038143450164, -2.27864544691768, t);\\n p += fft(-122, 0.04130127409599373, 1.0179985736718389, t);\\n p += fft(244, 0.04122532274063034, -3.067112795949472, t);\\n p += fft(-257, 0.04120260956232949, -0.542088172379074, t);\\n p += fft(243, 0.0411840750974049, -1.1270227690299983, t);\\n p += fft(-197, 0.04049657874199362, -1.3153250227799558, t);\\n p += fft(-245, 0.040487242733518884, -0.8056762003801902, t);\\n p += fft(-159, 0.039968494906456264, 2.131425507643933, t);\\n p += fft(-307, 0.03996735676224505, -2.953588109997123, t);\\n p += fft(-117, 0.03996366100725931, -0.49760194876592045, t);\\n p += fft(196, 0.03980123228825173, -2.4873720845122835, t);\\n p += fft(129, 0.03949030893082138, 2.6844282955405814, t);\\n p += fft(-229, 0.03917242300752811, 0.4902693841571348, t);\\n p += fft(139, 0.03902865341873541, 0.25084178188044515, t);\\n p += fft(181, 0.03890376427607834, 1.0907389035558301, t);\\n p += fft(205, 0.038225435143225045, 3.038754339328246, t);\\n p += fft(-270, 0.03814390562327705, -1.8861478767357396, t);\\n p += fft(-322, 0.0377875627108128, 2.054761498465224, t);\\n p += fft(254, 0.037644552308180375, 1.226339480136378, t);\\n p += fft(118, 0.0376169651010232, -2.950034729024326, t);\\n p += fft(178, 0.03755225537409213, -2.0429020234266275, t);\\n p += fft(-171, 0.037539637959647765, -2.628755546161329, t);\\n p += fft(-285, 0.03747836134545755, 1.6722531286069764, t);\\n p += fft(-180, 0.037460621587516375, 0.24951421594634987, t);\\n p += fft(-247, 0.03717014294939771, 0.4975746705003909, t);\\n p += fft(-243, 0.037110747818183125, -2.0522437006131544, t);\\n p += fft(-216, 0.03709475821552742, -2.3116936028551125, t);\\n p += fft(220, 0.036592206760702885, -1.1344479951397493, t);\\n p += fft(-179, 0.03633519628480489, 3.112577471269461, t);\\n p += fft(176, 0.03587107527180269, 2.0913103131787256, t);\\n p += fft(-207, 0.035809732499114115, 1.927035559915993, t);\\n p += fft(263, 0.03562581086066016, 2.1725008985745626, t);\\n p += fft(-233, 0.0354009108649777, 3.090965188758471, t);\\n p += fft(-274, 0.03518550659845451, -2.609254318579163, t);\\n p += fft(255, 0.03514669947246087, -0.5836113629270486, t);\\n p += fft(-319, 0.035071528591647944, -0.9287687613033353, t);\\n p += fft(250, 0.035032432208899206, -1.3555387953817497, t);\\n p += fft(246, 0.03497955004685989, -2.900549119786685, t);\\n p += fft(187, 0.03497207390971293, 0.6419092201499581, t);\\n p += fft(-261, 0.034866141687325505, -2.8459055041516237, t);\\n p += fft(235, 0.03476696606441066, -2.0933815844908445, t);\\n p += fft(-323, 0.03432989757242964, 3.043376257611318, t);\\n p += fft(217, 0.03432513334072705, -2.870512549124132, t);\\n p += fft(-162, 0.034206181317519346, 1.7603609329802217, t);\\n p += fft(228, 0.033806131017560914, 2.744224194820961, t);\\n p += fft(-214, 0.03361470625565273, 1.3269768758946363, t);\\n p += fft(-215, 0.033529573748044716, -0.6672480021154472, t);\\n p += fft(218, 0.033108296214315436, -0.745234197490618, t);\\n p += fft(-146, 0.03308604353605592, 3.1073329337196274, t);\\n p += fft(-304, 0.03303159902623534, -2.4351923422168493, t);\\n p += fft(311, 0.032929142894730805, -1.2404835833846408, t);\\n p += fft(242, 0.03292110918943753, -2.843217129365357, t);\\n p += fft(-134, 0.03288854877053813, 0.9130453422359837, t);\\n p += fft(-351, 0.03216220452946286, 2.9238550334113036, t);\\n p += fft(370, 0.032067363608954395, -2.7224346201619336, t);\\n p += fft(-272, 0.0320561856904509, -2.2145797900542075, t);\\n p += fft(-154, 0.031753153031045644, -0.16349530311453386, t);\\n p += fft(-297, 0.03170814258815033, 1.4299668847082438, t);\\n p += fft(182, 0.031686346431849116, 1.0404018878433685, t);\\n p += fft(209, 0.031631761114312575, 2.68111660535219, t);\\n p += fft(-170, 0.03155091422698183, 0.025639469483387113, t);\\n p += fft(-186, 0.031481161179575994, -2.4201773456994196, t);\\n p += fft(-149, 0.031378407408703936, -0.29780149545874124, t);\\n p += fft(-189, 0.03115713943498147, -2.644731527056393, t);\\n p += fft(-140, 0.031108294831552176, -2.15723791130607, t);\\n p += fft(-230, 0.031069499597997076, -1.8351044204097733, t);\\n p += fft(-347, 0.030916908832951683, 2.4988906781918887, t);\\n p += fft(179, 0.030863310224088517, -2.7337664596225717, t);\\n p += fft(403, 0.03079754590699015, 2.304354929974498, t);\\n p += fft(-327, 0.030401389085025158, 0.6776045430119092, t);\\n p += fft(348, 0.030373006761288658, -0.8679493927914637, t);\\n p += fft(-283, 0.030223082183547217, 2.321654263572609, t);\\n p += fft(363, 0.029978631780089162, -2.0372134669252153, t);\\n p += fft(300, 0.029897933119460138, -0.6676919620602354, t);\\n p += fft(-291, 0.029861596312070346, 1.7523875509536528, t);\\n p += fft(-188, 0.029753115428544207, 1.9857575444023974, t);\\n p += fft(225, 0.02930280842219607, -2.476715232579848, t);\\n p += fft(429, 0.029179633135401076, -1.1583720910674902, t);\\n p += fft(-244, 0.028727529620259963, -2.1143873737131402, t);\\n p += fft(-262, 0.02871955668992869, -3.0313512511556326, t);\\n p += fft(183, 0.02846822983732852, -2.748892137103645, t);\\n p += fft(371, 0.02837026069110045, 0.01709695974620803, t);\\n p += fft(261, 0.02827365028172563, -3.1104354673121124, t);\\n p += fft(265, 0.028272672120935843, 2.3187637649532733, t);\\n p += fft(-225, 0.02812970136713906, -2.391287474012119, t);\\n p += fft(-498, 0.027947522439068676, -2.2990766978458765, t);\\n p += fft(-280, 0.027914429972500227, 1.013046879856245, t);\\n p += fft(-286, 0.027473151353735275, -2.49136323587289, t);\\n p += fft(175, 0.027082599263012368, -1.5491745606494223, t);\\n p += fft(-312, 0.027012987931504247, 2.04498781689676, t);\\n p += fft(-269, 0.02695999871732734, 1.9901497475231744, t);\\n p += fft(-360, 0.026873297237023055, -0.1910603902232436, t);\\n p += fft(210, 0.026869883314267793, 2.2196865134172485, t);\\n p += fft(297, 0.026812580694708738, -0.9588922853385715, t);\\n p += fft(-301, 0.026740603460076486, 3.129150821124547, t);\\n p += fft(249, 0.026705638457446366, 1.222748808928071, t);\\n p += fft(-265, 0.02664609481949143, -2.053872209655098, t);\\n p += fft(234, 0.026552097720191792, 1.791539306291776, t);\\n p += fft(227, 0.026483242165273254, 1.820370612047031, t);\\n p += fft(-278, 0.026454482953384536, -0.05035777064958111, t);\\n p += fft(130, 0.02643932663595854, -0.99756238511126, t);\\n p += fft(231, 0.026426198746353186, 0.5809494198615022, t);\\n p += fft(259, 0.026227035759586497, 0.048293120841955764, t);\\n p += fft(-484, 0.025920236965447943, -1.3145326416833631, t);\\n p += fft(-200, 0.02582688982027274, 2.9933704442672058, t);\\n p += fft(306, 0.025717614417685275, 1.8836489796514166, t);\\n p += fft(325, 0.025633895244435108, 1.3357894296294839, t);\\n p += fft(347, 0.025591567492861077, 0.7714686164660547, t);\\n p += fft(350, 0.02537545484909361, 1.0770352597787496, t);\\n p += fft(269, 0.025281161653424446, -0.8907061117584099, t);\\n p += fft(-133, 0.025264087654711557, -2.2018152563461086, t);\\n p += fft(302, 0.025261769856955805, -2.355108757850705, t);\\n p += fft(-386, 0.02501819794981099, -2.1477266907940398, t);\\n p += fft(-350, 0.025002909823313272, -0.918163604040018, t);\\n p += fft(333, 0.02498494266415943, -2.4432604967090743, t);\\n p += fft(-126, 0.024859518286652924, -1.6045017067489493, t);\\n p += fft(387, 0.02467625356087282, 1.3070718064311373, t);\\n p += fft(334, 0.024653917539731205, -1.2008707105925764, t);\\n p += fft(-240, 0.024383901745244567, -2.988241565566239, t);\\n p += fft(-264, 0.024335184695854287, -2.6872316547229813, t);\\n p += fft(-295, 0.024162332511406915, 2.688135808330894, t);\\n p += fft(-276, 0.023836127347152083, 1.7406463579323161, t);\\n p += fft(203, 0.02379133257240037, -0.3391371830055463, t);\\n p += fft(238, 0.023765709007479915, -0.5242076860175524, t);\\n p += fft(-483, 0.023685530454379034, -2.7588368682276188, t);\\n p += fft(-342, 0.023608418137766377, -2.8422263956774603, t);\\n p += fft(-329, 0.02352667163920514, -1.3751865534697134, t);\\n p += fft(-325, 0.023484462227501834, 0.9927626044567095, t);\\n p += fft(230, 0.023456797688559062, 2.986455504190948, t);\\n p += fft(-251, 0.023318098398379915, 0.001782273200166798, t);\\n p += fft(349, 0.023228733757422806, -1.072303089214612, t);\\n p += fft(-187, 0.02322820420005635, -1.3088872022943903, t);\\n p += fft(207, 0.023124953262124194, 2.861078526577945, t);\\n p += fft(202, 0.023092047214425013, 1.0903724835034125, t);\\n p += fft(256, 0.022985204913763314, -2.423841790239499, t);\\n p += fft(275, 0.022818988303534807, 0.6902607477729654, t);\\n p += fft(241, 0.022704874638607323, -2.7649106335200497, t);\\n p += fft(425, 0.0227031562735846, -0.012766251035448749, t);\\n p += fft(341, 0.022687393671458885, 2.5287999264265917, t);\\n p += fft(365, 0.02259089981517188, -3.0023071719734364, t);\\n p += fft(298, 0.022430755305941547, 2.1440768785920277, t);\\n p += fft(282, 0.022286640564131238, 1.6952796376817658, t);\\n p += fft(-222, 0.02225904133709741, -0.11321484605745279, t);\\n p += fft(-358, 0.02217999232999693, 1.7758821914468246, t);\\n p += fft(-279, 0.022095177947215737, -0.5192730492996941, t);\\n p += fft(-321, 0.022090473578627715, -0.07844498829588367, t);\\n p += fft(-359, 0.021942659529941247, -1.4465606944335514, t);\\n p += fft(295, 0.021938469715302247, -2.262517021888232, t);\\n p += fft(276, 0.02187149419277873, -0.48075610553317366, t);\\n p += fft(502, 0.021702319512468666, 3.0296543113191032, t);\\n p += fft(-330, 0.021623659938299806, 1.125358184849381, t);\\n p += fft(437, 0.021598487358667418, -3.140123913594686, t);\\n p += fft(329, 0.02151039012029828, 2.581279012552966, t);\\n p += fft(316, 0.021367306895449877, -1.4951973637160159, t);\\n p += fft(-267, 0.021347948106670487, -2.131762505311679, t);\\n p += fft(-357, 0.02130909397626576, -1.6191594501730688, t);\\n p += fft(267, 0.021293781075476997, -1.8017482889635452, t);\\n p += fft(-345, 0.021048837931442004, -2.7069477620313958, t);\\n p += fft(-408, 0.02091001972463279, -1.769848404933256, t);\\n p += fft(320, 0.02088425179811783, -2.0704408556221447, t);\\n p += fft(-387, 0.020820573842865432, -1.0930901397929305, t);\\n p += fft(-242, 0.020794137395108606, -2.9605829129168324, t);\\n p += fft(-344, 0.020671452626722698, -1.7987821089995277, t);\\n p += fft(322, 0.02067088832181214, -0.22912612763676568, t);\\n p += fft(-253, 0.02061794621791137, -2.0073683043484953, t);\\n p += fft(152, 0.020610241493015494, 0.7098290286508013, t);\\n p += fft(303, 0.020592932879901157, 0.2719935974041692, t);\\n p += fft(369, 0.020565205999609194, 1.1339865732671597, t);\\n p += fft(-273, 0.020564513440436215, 0.7955462603371597, t);\\n p += fft(215, 0.020563199492889896, -2.73682346996378, t);\\n p += fft(491, 0.020543180022284717, -0.666788850668437, t);\\n p += fft(-356, 0.020468707035038124, 0.6390339134967551, t);\\n p += fft(293, 0.02045422037494547, 2.0389477913494334, t);\\n p += fft(201, 0.02044920037993446, 0.020014295722637722, t);\\n p += fft(346, 0.020343417891833488, -0.725558513377337, t);\\n p += fft(-399, 0.020300294108822257, 0.4272740878635683, t);\\n p += fft(464, 0.020245436748592072, -1.684969251038007, t);\\n p += fft(221, 0.020152569151655777, 3.0652577733184607, t);\\n p += fft(489, 0.020112656771664496, -1.8042417759245823, t);\\n p += fft(318, 0.020056388889540793, -0.6707185351758385, t);\\n p += fft(-339, 0.02001479126183757, 2.949145490351578, t);\\n p += fft(236, 0.019954859133684905, -2.5428580801661353, t);\\n p += fft(270, 0.0199321804912115, 0.37878519439460373, t);\\n p += fft(379, 0.01983906743081143, -0.6343495825544784, t);\\n p += fft(397, 0.019807948769945526, 1.8820880074650208, t);\\n p += fft(-221, 0.019691977663300008, 1.0514616478563783, t);\\n p += fft(421, 0.019623337934699885, 2.745363616281166, t);\\n p += fft(290, 0.01953008037132682, 0.8843912942541152, t);\\n p += fft(197, 0.019375944562943694, 2.0356527234870283, t);\\n p += fft(308, 0.0193527600669189, 2.81162774010797, t);\\n p += fft(-328, 0.019285400376087076, -0.19114063563029987, t);\\n p += fft(467, 0.019178891795281015, -1.1263460951000444, t);\\n p += fft(-277, 0.019079718249143097, 2.6331532845129404, t);\\n p += fft(280, 0.018994654616752097, 0.1675185745565849, t);\\n p += fft(260, 0.018913994053827352, -0.5044184838532041, t);\\n p += fft(427, 0.018852739951118917, 2.662217288999046, t);\\n p += fft(499, 0.01882350931017547, -3.0149846935153795, t);\\n p += fft(189, 0.018757809943370472, -2.674046839704885, t);\\n p += fft(342, 0.01874747510581987, -0.5786367177428741, t);\\n p += fft(416, 0.018566064359446622, -2.4176951579501798, t);\\n p += fft(-348, 0.018437843583245718, -2.43964557130452, t);\\n p += fft(465, 0.018437257369033726, 1.9214782275571987, t);\\n p += fft(284, 0.01833544793734469, 1.9968963624882772, t);\\n p += fft(-470, 0.01831002225764508, 0.5156559884673433, t);\\n p += fft(-309, 0.018308015252553246, 2.312871173198566, t);\\n p += fft(490, 0.018216767412652893, 1.0140583098689544, t);\\n p += fft(410, 0.0182153814183295, -0.7582160151193984, t);\\n p += fft(-258, 0.018128466510949046, 1.1118990006128406, t);\\n p += fft(375, 0.018057552391933036, -3.1017254547912794, t);\\n p += fft(321, 0.01794587346556815, -1.8663932495219484, t);\\n p += fft(248, 0.017863597777448885, -0.5496798132550856, t);\\n p += fft(-317, 0.01782644768907149, 2.2802015955382537, t);\\n p += fft(-452, 0.01780336641082023, 2.690346714053042, t);\\n p += fft(-353, 0.0176913084429108, 2.711049147139238, t);\\n p += fft(-306, 0.017552300595371273, 2.9506692681038973, t);\\n p += fft(-288, 0.017544324110289406, 2.6323855434673655, t);\\n p += fft(-460, 0.017443786885044096, -0.9299541940735817, t);\\n p += fft(309, 0.017419145135487844, 1.3460311128048443, t);\\n p += fft(305, 0.017152445993384516, -1.7361791397832658, t);\\n p += fft(-256, 0.01714047466479905, 2.2799787723913836, t);\\n p += fft(355, 0.017058849062613846, -0.6615483742229916, t);\\n p += fft(-320, 0.016979227333377315, 2.6388512636510377, t);\\n p += fft(-382, 0.01695615705889803, 2.555957382259133, t);\\n p += fft(390, 0.016953475958207665, 2.3322367819625027, t);\\n p += fft(-398, 0.01694687182836866, 2.171099613653392, t);\\n p += fft(411, 0.01692398609281921, -2.3970294940597237, t);\\n p += fft(391, 0.01688742438332487, -2.6741985703550384, t);\\n p += fft(-383, 0.01671254896861024, -1.809831893039911, t);\\n p += fft(-438, 0.016700025869992145, -3.0263950471937577, t);\\n p += fft(498, 0.016577067431832987, 1.4628404900222298, t);\\n p += fft(441, 0.016528444933087572, -2.5534170728688195, t);\\n p += fft(396, 0.016469294170931584, -1.0778883003395043, t);\\n p += fft(194, 0.016387929541844138, 0.27285370222194255, t);\\n p += fft(288, 0.01632089028121901, -2.499948895627382, t);\\n p += fft(-453, 0.016282171657074507, -1.8352466594182715, t);\\n p += fft(-491, 0.0162466408620674, 0.751075739658446, t);\\n p += fft(-271, 0.01618413446166483, -1.9240760733216773, t);\\n p += fft(374, 0.01597286278830038, 1.4727297170481586, t);\\n p += fft(245, 0.01595638314751546, -2.5020467251265117, t);\\n p += fft(492, 0.015955522695669654, -2.11250121739465, t);\\n p += fft(292, 0.015938735781863788, 2.8886197298108702, t);\\n p += fft(356, 0.015930093359693635, 3.119487581363237, t);\\n p += fft(-336, 0.01588376130850545, 0.28597008022586234, t);\\n p += fft(386, 0.01579744464348149, -0.6427892645860717, t);\\n p += fft(424, 0.015781071608576305, 0.06038150421307685, t);\\n p += fft(286, 0.015677276287429535, 2.6843830865968843, t);\\n p += fft(-439, 0.01566577624464125, -0.40437157307800353, t);\\n p += fft(-316, 0.015653156388410593, -0.49543109291627363, t);\\n p += fft(-480, 0.015631631437216433, 2.2355153900157636, t);\\n p += fft(400, 0.015537542523719335, -2.445474568008316, t);\\n p += fft(-447, 0.015437071879756518, 2.7865636796309072, t);\\n p += fft(366, 0.015353947913814526, 2.0058503224480564, t);\\n p += fft(-492, 0.015303110265234265, 2.3874477585758074, t);\\n p += fft(-445, 0.015280750696461273, 0.444334272791586, t);\\n p += fft(353, 0.015251950793442146, -2.7836080531188006, t);\\n p += fft(-500, 0.015226472622413946, -2.6103075874608708, t);\\n p += fft(-380, 0.015222967220547282, -2.881867749906817, t);\\n p += fft(506, 0.015150418703193842, 2.0075105204746566, t);\\n p += fft(-335, 0.015124331759979636, 1.009943322524843, t);\\n p += fft(483, 0.015097172526301886, 2.0959180943388027, t);\\n p += fft(240, 0.015078862676021213, -1.2930571972964564, t);\\n p += fft(-401, 0.01507870517510355, 2.715454154162096, t);\\n p += fft(449, 0.015061353079694497, 1.8733248116188075, t);\\n p += fft(412, 0.015050927296007339, 2.2976965232943307, t);\\n p += fft(323, 0.014984653022696854, -3.0935557999938292, t);\\n p += fft(-396, 0.014977404461351117, 0.30211159558289086, t);\\n p += fft(273, 0.01483460564366501, -1.4596850118087714, t);\\n p += fft(345, 0.014833234000572936, -0.32539675758169934, t);\\n p += fft(-417, 0.014811822655002693, -2.5447030635824297, t);\\n p += fft(-394, 0.014768485010995914, 0.8420120899555257, t);\\n p += fft(-326, 0.014757622857210374, -0.9559941626829623, t);\\n p += fft(-373, 0.01470773104483892, 2.794549031160765, t);\\n p += fft(340, 0.014690011817124374, -2.2126006109671352, t);\\n p += fft(-390, 0.014674589859169042, -0.9855117184354396, t);\\n p += fft(317, 0.014671770616686048, -0.4111710755329078, t);\\n p += fft(-308, 0.014630448864418246, -2.6132662944333247, t);\\n p += fft(-419, 0.014612974424031182, 1.890332423869268, t);\\n p += fft(472, 0.014573773093057102, -0.15746800733732982, t);\\n p += fft(257, 0.014541893370249208, -1.3953361182084414, t);\\n p += fft(436, 0.014503458130718185, 1.473439813394881, t);\\n p += fft(-218, 0.014473405505827206, -2.2614161401120723, t);\\n p += fft(-384, 0.014387460588666384, 0.4846527714087321, t);\\n p += fft(214, 0.014373508138361935, -0.9929984801205258, t);\\n p += fft(327, 0.014363924720838923, 0.6705953026310363, t);\\n p += fft(-443, 0.014247709886683415, 0.6588561068584213, t);\\n p += fft(216, 0.014201020492534005, 2.6741170951719297, t);\\n p += fft(278, 0.014195739673546514, 0.45380564178946164, t);\\n p += fft(474, 0.01417224313980241, -2.946490401046988, t);\\n p += fft(361, 0.014169743346048109, 0.7656558005070042, t);\\n p += fft(418, 0.014153025125774113, 0.6544601775463792, t);\\n p += fft(-204, 0.014098068158582331, 1.570589753704267, t);\\n p += fft(409, 0.01408416890434566, 0.5791110199136934, t);\\n p += fft(332, 0.014064077521337141, -1.96196450322835, t);\\n p += fft(-411, 0.014055381190387442, -2.1050532273937193, t);\\n p += fft(-504, 0.014042491970392819, -2.4507746476472416, t);\\n p += fft(-331, 0.014021056796023198, -0.9466573694669207, t);\\n p += fft(331, 0.01401815399131699, 2.9486255021269, t);\\n p += fft(381, 0.014006914694692865, -1.1186058737646056, t);\\n p += fft(291, 0.013994629362131503, 1.9007976843424446, t);\\n p += fft(330, 0.013949517263636396, -0.49986286341122593, t);\\n p += fft(312, 0.013936760778201074, 3.0721230148366017, t);\\n p += fft(417, 0.013934783414901307, -2.257422367097522, t);\\n p += fft(-337, 0.01391371567127865, 2.895113197666846, t);\\n p += fft(385, 0.013891315233703376, -1.1352978862346337, t);\\n p += fft(-435, 0.013873332760801304, -0.32090186205450033, t);\\n p += fft(-385, 0.013844120558174551, -3.119969137357533, t);\\n p += fft(315, 0.013828233021495205, -3.0524501599722305, t);\\n p += fft(-343, 0.01378875650901319, -0.6263451828356061, t);\\n p += fft(459, 0.013771797001534768, 1.3512327925116, t);\\n p += fft(319, 0.013701983237761646, -3.0552359101211772, t);\\n p += fft(-421, 0.013685546780447071, 0.6168243016650519, t);\\n p += fft(307, 0.013681679811588384, -0.8864069492779628, t);\\n p += fft(-477, 0.01367630727868223, 2.7521796191613754, t);\\n p += fft(-465, 0.013581831625402187, -1.220520995405941, t);\\n p += fft(326, 0.013574391629771329, -3.1202874287266082, t);\\n p += fft(360, 0.0135341266402344, 2.664064685853016, t);\\n p += fft(-377, 0.013529068169515567, 0.2646391557351839, t);\\n p += fft(-459, 0.013509914775589568, -1.0462062859265808, t);\\n p += fft(-436, 0.013509169672166503, 3.060808353213404, t);\\n p += fft(-442, 0.013378848325932797, -2.943169899395721, t);\\n p += fft(281, 0.013324886668795041, 0.7702604219139404, t);\\n p += fft(402, 0.013309784889240976, 3.0462417371183212, t);\\n p += fft(413, 0.0133092395072314, -2.5644879288039295, t);\\n p += fft(-289, 0.013200751727554779, -0.42679700259876185, t);\\n p += fft(484, 0.013164831415710608, 1.1147833223969785, t);\\n p += fft(401, 0.01310573625374175, -0.45440514371321855, t);\\n p += fft(277, 0.013041278781405874, 2.710518166070806, t);\\n p += fft(-349, 0.013024136574205064, 0.368816551131045, t);\\n p += fft(-346, 0.012977337347580263, -0.26417451603147596, t);\\n p += fft(420, 0.012845882619135234, 2.002998951036915, t);\\n p += fft(445, 0.01284579635338418, -2.0677013276140324, t);\\n p += fft(428, 0.01279398105157776, 1.2926796180614086, t);\\n p += fft(376, 0.01276786373111407, 1.9367911037174024, t);\\n p += fft(-376, 0.01272502179107737, -3.1282891850863908, t);\\n p += fft(-507, 0.012722242687719345, 1.8939443453134572, t);\\n p += fft(-294, 0.012712310194407102, -1.188628976570537, t);\\n p += fft(-415, 0.012670552135729969, -0.9868907915235011, t);\\n p += fft(-428, 0.012607664240827194, -0.031095597497390378, t);\\n p += fft(473, 0.012543542480353977, -3.0690769712824704, t);\\n p += fft(430, 0.012541336274083313, -2.048475426543982, t);\\n p += fft(-341, 0.012469363963888485, 1.1697948865306476, t);\\n p += fft(-509, 0.012466468154148012, 0.38059867841898043, t);\\n p += fft(-481, 0.01242592353445654, -1.913914863175826, t);\\n p += fft(-314, 0.01239765783707375, -2.1235472871525767, t);\\n p += fft(-313, 0.012376173120752695, 1.03944125297012, t);\\n p += fft(-471, 0.012345159783470094, 2.6516490082388215, t);\\n p += fft(-310, 0.012284310170666665, -2.1698685017205785, t);\\n p += fft(-300, 0.01227542981113322, -2.017710213505234, t);\\n p += fft(247, 0.012240477217121775, 0.41935200430886505, t);\\n p += fft(-466, 0.012240125520371849, 0.019480587267466563, t);\\n p += fft(503, 0.01222533405281694, 0.6840099173444322, t);\\n p += fft(200, 0.012220403742265044, 2.887981253820241, t);\\n p += fft(304, 0.012182539431900842, 2.632403848640596, t);\\n p += fft(-425, 0.01215230910385176, 0.8806489351275139, t);\\n p += fft(351, 0.01214911658400834, -2.451703539504316, t);\\n p += fft(404, 0.012113298811467181, -0.1782921248032119, t);\\n p += fft(-404, 0.012098227853860725, -1.9073495889414767, t);\\n p += fft(500, 0.01206287854228493, 1.0185472742352673, t);\\n p += fft(-499, 0.012052977984837707, -2.947829310783775, t);\\n p += fft(296, 0.01203564352441712, -2.5371259687889496, t);\\n p += fft(344, 0.012030880992025202, -1.5507150201535012, t);\\n p += fft(-490, 0.011980159644615596, -0.06316472136582, t);\\n p += fft(-352, 0.011969909686558968, -0.40224393964822713, t);\\n p += fft(-506, 0.01193447069907937, -1.174788671161676, t);\\n p += fft(268, 0.011916136745930814, 1.8609641665108294, t);\\n p += fft(456, 0.011855122323403295, -0.25549478912944407, t);\\n p += fft(477, 0.011851778387300449, -0.7824493403677418, t);\\n p += fft(258, 0.011823107744589997, 0.4702714456912564, t);\\n p += fft(504, 0.011813789783172548, -2.1593068285941017, t);\\n p += fft(285, 0.01180532967217003, 1.9107235273443852, t);\\n p += fft(294, 0.011771073591615677, -3.0221374579820486, t);\\n p += fft(-340, 0.011737380405027845, -0.09560932985103796, t);\\n p += fft(-412, 0.011693563396162478, 0.03547230271148827, t);\\n p += fft(-473, 0.01167087995314407, -2.983087290342926, t);\\n p += fft(-381, 0.011633614975664468, 0.05696443428106514, t);\\n p += fft(423, 0.011627989857404918, 0.07675195602888493, t);\\n p += fft(-324, 0.01161418553014038, -2.471424070407224, t);\\n p += fft(399, 0.011577011391338602, 0.8371784427311489, t);\\n p += fft(-478, 0.011557125479527306, -2.2282000740788677, t);\\n p += fft(283, 0.011531997122870051, -0.7010609826477285, t);\\n p += fft(511, 0.0114760434011943, 1.734049648533497, t);\\n p += fft(279, 0.011460842192281833, 1.4668325872315813, t);\\n p += fft(447, 0.011454898078003161, -0.13946735136066804, t);\\n p += fft(-485, 0.011428486636959046, 0.34886175616311715, t);\\n p += fft(-472, 0.011389433654382263, 0.45069667769887467, t);\\n p += fft(-505, 0.011374024792638228, -0.16038515681074883, t);\\n p += fft(496, 0.011367209747096613, -0.5789335748725059, t);\\n p += fft(287, 0.011353094401163121, -2.6544713993331595, t);\\n p += fft(-476, 0.011339897348846054, 2.760999701731875, t);\\n p += fft(-203, 0.011246318318210755, -2.655330740012455, t);\\n p += fft(-298, 0.011240592231092321, -0.8535304917183064, t);\\n p += fft(435, 0.011199052278348127, -2.221842104143809, t);\\n p += fft(-397, 0.011179697495765209, 1.9050162197469025, t);\\n p += fft(339, 0.011177696172867731, -1.5279335419082853, t);\\n p += fft(314, 0.01113945595405601, -2.665298378120776, t);\\n p += fft(408, 0.011075489731786133, -1.6517945429682814, t);\\n p += fft(446, 0.01101171854080183, -0.48257443448194115, t);\\n p += fft(-333, 0.011005844536439355, -2.23571436410032, t);\\n p += fft(450, 0.01098336159814381, -2.3282935745461235, t);\\n p += fft(-293, 0.010866838807767636, -2.08175340759797, t);\\n p += fft(336, 0.010820760748971349, 1.7112356086996947, t);\\n p += fft(414, 0.010787409392539691, 2.807079317517186, t);\\n p += fft(-318, 0.010742470447882757, 2.8752872175583497, t);\\n p += fft(406, 0.010725007874053354, 3.063825957806161, t);\\n p += fft(-413, 0.010690874318868027, -3.119832148809836, t);\\n p += fft(415, 0.010685727067395259, 0.8983819808171652, t);\\n p += fft(-503, 0.010659993246209611, 0.3133119607095941, t);\\n p += fft(-355, 0.010621606166054188, -2.3472131268696774, t);\\n p += fft(-281, 0.01061443706876594, -0.7561374672674868, t);\\n p += fft(-366, 0.010605967113792601, -2.711774616807628, t);\\n p += fft(-479, 0.010586221430330002, -2.5484256879947855, t);\\n p += fft(-426, 0.010490344441220769, 1.0668022268161381, t);\\n p += fft(-405, 0.010385062881632077, 2.306115157954148, t);\\n p += fft(-290, 0.010384484051949614, -2.2711503576547094, t);\\n p += fft(364, 0.010311227119556366, 1.3569201451071267, t);\\n p += fft(239, 0.01030448004807976, -1.9386533731670805, t);\\n p += fft(-424, 0.010283240609725826, 0.8760921385535031, t);\\n p += fft(338, 0.010272254653901589, -1.0871306303800126, t);\\n p += fft(-482, 0.01024776632548479, -0.6515462866676507, t);\\n p += fft(-494, 0.01024564906483858, 2.395078651689155, t);\\n p += fft(-236, 0.010162897249939504, 1.9785592807626329, t);\\n p += fft(494, 0.010150992333137729, -0.01780121101171699, t);\\n p += fft(233, 0.010096455886289615, -2.5741668393876806, t);\\n p += fft(192, 0.010084734213336314, -0.8855447372541574, t);\\n p += fft(-234, 0.010056081638657548, 1.9417984487245914, t);\\n p += fft(-266, 0.010020076168818585, -0.561779230785278, t);\\n*/\\n return (p + vec2(-250, -150)) * 0.01 /* center and scale */\\n ;\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 640.0;\\n float pointsPerCircle = segmentsPerCircle * 2.0;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n \\n float vId = mod(vertexId, pointsPerCircle);\\n float cId = floor(vertexId / pointsPerCircle);\\n float cv = cId / numCircles;\\n float u = floor(vId / 2.0) + mod(vId, 2.0);\\n float v = u / segmentsPerCircle;\\n float a = v * PI * 2.0 + cv;\\n\\n vec2 p = computeFFT(v + time + cv);\\n \\n float distFromCenter = length(p);\\n\\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.1, abs(v * 2. - 1.)),\\n cv * 0.2)).r;\\n float s2 = texture2D(sound, vec2(0.1, cv*0.1)).r;\\n \\n vec3 pos = vec3(p, 0); \\n \\n \\n float ct = time * 0.3;\\n vec3 eye = vec3(vec2(sin(ct), cos(ct)) * 2.5, -5.0);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 250.); \\n mat *= cameraLookAt(eye, target, up);\\n //mat *= trans(vec3(computeFFT(cv + time), 0));\\n mat *= trans(vec3(0, 0, cv * 2. - 1.) * 0.3);\\n mat *= rotZ(PI + pow(s, 5.0) * 0.2 - 0.1);\\n mat *= uniformScale(mix(0.9, 1.2, pow(s, 5.0)) + s2);\\n gl_Position = mat * vec4(pos, 1);\\n\\n\\n float boost = step(0.7, s);\\n \\n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\\n float sat = 1.0;1.0 - pow(pos.z, 1.) - pow(s, 4.);\\n float val = sin(v) * 0.5 + 0.5;mix(0.25, 2.0, pow(s, 2.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/moods-grooves-records/phaze-dee-game-of-life-web", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25882352941176473, + 0.25882352941176473, + 0.25882352941176473, + 1 + ], + "shader": "// data from https://github.com/Jezzamonn/fourier\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec2 fft(int freq, float amplitude, float phase, float time) {\n float angle = PI * 2.0 * float(freq) * time + phase;\n return vec2(cos(angle), sin(angle)) * amplitude;\n}\n\nvec2 computeFFT(float t) {\n vec2 p = vec2(0);\n p += fft(0, 296.524077607952, 0.5328692201872761, t);\n p += fft(1, 129.16512258296828, -2.90016335218518, t);\n p += fft(-1, 63.77796615668684, 2.9224545501551584, t);\n p += fft(3, 19.64466960507052, -2.4341521827648407, t);\n p += fft(2, 15.225563957670408, 2.1065920733999985, t);\n p += fft(4, 10.816890879510945, 2.768243749294925, t);\n p += fft(6, 7.7798714613757785, 2.790776515902791, t);\n p += fft(8, 6.679135366586027, -2.691421192706561, t);\n p += fft(18, 6.618481262601785, -2.7811427287619805, t);\n p += fft(-17, 6.194427860122354, 1.0295557956864945, t);\n p += fft(-20, 6.068497179066321, 2.0845633129083545, t);\n p += fft(13, 6.026155883530845, -2.9082280887418843, t);\n p += fft(20, 5.87547467169867, 0.6567893346845978, t);\n p += fft(12, 5.664082795931505, -0.7736185409154058, t);\n p += fft(22, 5.504599257383946, -0.5566360694751388, t);\n p += fft(-22, 5.146718591504782, -2.7391457150277336, t);\n p += fft(-19, 4.967122293367857, -1.4319471520699776, t);\n p += fft(-11, 4.537800748903001, 0.7806248091011616, t);\n p += fft(16, 4.409897469465315, 2.5618942112767407, t);\n p += fft(-25, 4.3819383386473865, -1.5151030062564892, t);\n p += fft(-16, 4.149297744113447, 0.575845737238003, t);\n p += fft(-12, 4.139174393444163, 2.982857273406526, t);\n p += fft(-34, 4.07501017913087, 1.5981185989542064, t);\n p += fft(-8, 4.074809962485297, -0.42486073575722444, t);\n p += fft(5, 4.0206048747056125, -2.3082375418458945, t);\n p += fft(11, 3.990542905551988, 2.3627881868284972, t);\n p += fft(17, 3.955727644969372, 2.456663236004692, t);\n p += fft(19, 3.8658362150758534, -1.6701042175865948, t);\n p += fft(10, 3.8517952416210557, -1.9882991837519308, t);\n p += fft(25, 3.8215186298010257, -0.9536339281017274, t);\n p += fft(-6, 3.6465818944687634, -0.4459221391524853, t);\n p += fft(-29, 3.2133268799952712, 2.9249873354735345, t);\n p += fft(-13, 3.172984702723984, -0.25267920294558227, t);\n p += fft(15, 3.1374261306697373, 2.4403069911326685, t);\n p += fft(7, 3.0955422513620245, -1.711872929589281, t);\n p += fft(-9, 2.880155339148816, 0.32676693145089336, t);\n p += fft(-15, 2.8798999832519403, 0.9375984752072446, t);\n p += fft(26, 2.79967174195265, -2.049901239880178, t);\n p += fft(29, 2.7803332403386336, 0.5231959777340147, t);\n p += fft(28, 2.7414647126009593, 0.4708642708868981, t);\n p += fft(41, 2.6437612024221844, -2.9636977093225685, t);\n p += fft(39, 2.6295641656754234, -2.277801278923058, t);\n p += fft(27, 2.6183263816781324, 2.784381034343638, t);\n p += fft(-4, 2.612279805775902, 1.1701981679810707, t);\n p += fft(34, 2.5896488928989925, 0.8874838650026977, t);\n p += fft(-18, 2.568509187236616, -0.9803167206473404, t);\n p += fft(-28, 2.507964971759851, 3.026960979082897, t);\n p += fft(-14, 2.4945338840886677, -0.18814398163405743, t);\n p += fft(-3, 2.4553487715159696, -2.515704298686429, t);\n p += fft(-10, 2.347972482924663, -0.9661461748548102, t);\n p += fft(9, 2.3353227667810943, 2.6662410983119873, t);\n p += fft(-27, 2.2841877482065778, 0.6357945200731572, t);\n p += fft(-33, 2.2359717418821874, -2.6756775052827853, t);\n p += fft(37, 2.0731181353939196, -2.8767957104561597, t);\n p += fft(43, 2.046908477381298, -0.848325445419195, t);\n p += fft(40, 1.9650400072060998, 1.4954865245732736, t);\n p += fft(31, 1.920647139346876, -0.8820561267540269, t);\n p += fft(-37, 1.8264609429322551, -0.6283518255686783, t);\n p += fft(-30, 1.8191188807994465, -2.078648696472338, t);\n p += fft(-21, 1.7570644633051382, 2.614905728603112, t);\n p += fft(24, 1.7380651990304348, 1.797588764641598, t);\n p += fft(44, 1.6560026933156917, 0.27276010910919374, t);\n p += fft(-44, 1.649213368528592, -2.697758361982687, t);\n p += fft(-32, 1.6482613051000077, 1.7281181963111363, t);\n p += fft(-38, 1.5957955338176892, 3.0229778848579327, t);\n p += fft(50, 1.594057606604889, -2.705446593070425, t);\n p += fft(33, 1.5853686682207064, -0.5898590645559981, t);\n p += fft(-26, 1.567072721585987, -0.6245687779647491, t);\n p += fft(23, 1.5345223856234949, -2.2815578356210735, t);\n p += fft(36, 1.5087867231807512, -0.5742399182534951, t);\n p += fft(-24, 1.4664813474877614, 2.7549795210299215, t);\n p += fft(57, 1.4430652246678877, 2.1241473623512697, t);\n p += fft(32, 1.406056560977162, 2.4473930566249096, t);\n p += fft(54, 1.397187168634832, -1.5290316283596388, t);\n p += fft(-35, 1.378962288401975, 1.030170830294626, t);\n p += fft(-51, 1.3443697534460952, 0.7824834836125082, t);\n p += fft(38, 1.2073849482228887, -1.417621395841823, t);\n p += fft(52, 1.1813148530266455, -2.7146718708831226, t);\n p += fft(58, 1.1546285984367923, -2.0469226839957546, t);\n p += fft(-2, 1.148242184394193, 1.1600574990999488, t);\n p += fft(-49, 1.1389035886326317, 2.536779536914916, t);\n p += fft(14, 1.1329760186659397, 3.040831768189552, t);\n p += fft(45, 1.1260078033316239, -2.6485676515902887, t);\n p += fft(-36, 1.0505189643915007, 1.1512408246664814, t);\n p += fft(48, 1.0434710403748044, -1.587473666465379, t);\n p += fft(35, 1.0264643367771464, 0.8533152135907922, t);\n p += fft(-77, 0.9957083595939865, 2.3018398053793176, t);\n p += fft(-50, 0.9539520583808928, -1.8737321231607105, t);\n p += fft(-23, 0.9292718478810791, -1.6156932158409079, t);\n p += fft(-43, 0.9257761649922747, -0.9528711445133002, t);\n p += fft(-46, 0.868581952908317, -1.7531859162182506, t);\n p += fft(-47, 0.8477347332294584, 1.5654529539919164, t);\n p += fft(-45, 0.8130585468017898, -0.6663785358206237, t);\n p += fft(60, 0.7908050200984377, -0.1023181049126883, t);\n p += fft(62, 0.7872325903381513, 1.030198597230489, t);\n p += fft(-48, 0.7858142817398769, 1.387565504131415, t);\n p += fft(49, 0.7704030031060537, 2.627354289464034, t);\n p += fft(-84, 0.7688630997732272, -2.564222992505424, t);\n p += fft(-39, 0.761830091495416, -2.4526438973987954, t);\n p += fft(78, 0.7543732213279061, 2.343001847272033, t);\n p += fft(-59, 0.7488095838105383, -3.1131016762144443, t);\n p += fft(55, 0.7285003537607938, -0.9786713526593741, t);\n p += fft(-31, 0.7248134830134255, -0.5543123381122909, t);\n p += fft(-54, 0.7219542814654896, 2.94943367544441, t);\n p += fft(-53, 0.7139986380620472, -1.2338229580467204, t);\n p += fft(46, 0.6985299047036991, -0.3033719700149987, t);\n p += fft(69, 0.6940778952546749, -1.0238518940571633, t);\n p += fft(-40, 0.6927457316683343, 2.0054202454179775, t);\n p += fft(-57, 0.67709432212438, -2.783806233466308, t);\n p += fft(47, 0.6602293673831037, 1.1829982386683053, t);\n p += fft(74, 0.6545825289163747, -0.6313191364037845, t);\n p += fft(-5, 0.6200531105206556, -1.012708917351053, t);\n p += fft(30, 0.6145303942405808, -0.006575553587373788, t);\n p += fft(-65, 0.6130907552103994, -1.2775992452682625, t);\n p += fft(83, 0.6078433173163771, -1.3921353502568135, t);\n p += fft(53, 0.6029346402536699, 3.118126806639058, t);\n p += fft(64, 0.593655747614559, -0.12929981693431084, t);\n p += fft(87, 0.5917638000158103, 2.8165282828931195, t);\n p += fft(75, 0.562070427870424, 2.935821150408132, t);\n p += fft(51, 0.553965684266993, 0.8857804427580288, t);\n p += fft(-69, 0.5402011495014111, -2.393077154815434, t);\n p += fft(-67, 0.5247046263885512, -0.12626924765950584, t);\n p += fft(80, 0.5211530645039045, -2.313552855619569, t);\n p += fft(56, 0.5057370766773879, -2.628846336188085, t);\n p += fft(-75, 0.5038585813938068, -1.8904143929736488, t);\n p += fft(-73, 0.48644277854405304, 1.3709055508801584, t);\n p += fft(-7, 0.47307925137425644, -2.55202847874333, t);\n p += fft(94, 0.4614308523932489, 2.545636098697929, t);\n p += fft(-74, 0.4419918759755517, 0.11529437409844774, t);\n p += fft(65, 0.44169553192805927, 2.439841086433652, t);\n p += fft(72, 0.43611612862779375, 0.9074545441173122, t);\n p += fft(-66, 0.43502792411907976, -2.063079991837712, t);\n p += fft(-42, 0.4314569651112275, 0.33687123321689777, t);\n p += fft(-64, 0.40521665336797635, 0.003486215133649564, t);\n p += fft(99, 0.40417092365602253, -1.8240004200677489, t);\n p += fft(59, 0.3936963912394369, -1.6362215309246326, t);\n p += fft(-60, 0.3815954958269982, -0.7754496988180308, t);\n p += fft(-63, 0.3792381066868484, -1.9391548308871835, t);\n p += fft(73, 0.37854582778783324, 0.043442146165603684, t);\n p += fft(42, 0.37453717681808335, 2.38737562405369, t);\n p += fft(21, 0.35583878846131595, -2.7839176861684014, t);\n p += fft(112, 0.3547233494213232, 2.954248286045894, t);\n p += fft(108, 0.35083273251102737, 2.5458627704061483, t);\n p += fft(93, 0.35040473622512436, -0.029550910229384195, t);\n p += fft(89, 0.3403049133299473, -2.885129447081889, t);\n p += fft(-70, 0.3370256731757577, -0.46771663832106974, t);\n p += fft(-78, 0.3366544726218109, -0.24724720507658238, t);\n p += fft(82, 0.32610868403027304, -1.4954241039751592, t);\n p += fft(-91, 0.32419682164009966, -1.3417496079852937, t);\n p += fft(-90, 0.3234753025960112, -3.0133578986946814, t);\n p += fft(-80, 0.2998816486209547, 3.096207886158368, t);\n p += fft(71, 0.2984964350635909, -0.6377008416229164, t);\n p += fft(85, 0.2961360685518227, 2.9392297581041658, t);\n p += fft(111, 0.2939868074077519, 1.066357674174694, t);\n p += fft(84, 0.2882922892341542, -0.2824472092836136, t);\n p += fft(-62, 0.2823355494458707, 0.5392478382746477, t);\n p += fft(101, 0.28043862110007006, 1.8969467658422987, t);\n p += fft(-58, 0.27927463219687665, -2.5066886208410595, t);\n p += fft(-114, 0.2787101344869982, -2.3945575768789205, t);\n p += fft(-81, 0.27344747273177633, 0.19849972308144362, t);\n p += fft(96, 0.268848539128237, 2.352065707231053, t);\n p += fft(104, 0.2667328677077002, -2.6894745409478773, t);\n p += fft(90, 0.2623194708267266, 2.6305846168436604, t);\n p += fft(105, 0.2587320115138661, -0.44809280212853925, t);\n p += fft(91, 0.25666403259093135, -0.42872274693200485, t);\n p += fft(-94, 0.25344187481961844, -1.1325746386338256, t);\n p += fft(67, 0.24928071126959497, 1.783113342037483, t);\n p += fft(-61, 0.2486431701299056, -3.0289630409059964, t);\n p += fft(-102, 0.24833449653800949, 2.814031321792728, t);\n p += fft(115, 0.24216361168985745, 2.5259661057434784, t);\n p += fft(-83, 0.24082180762961733, 2.327373899411901, t);\n p += fft(-71, 0.2404736569240409, 2.8270765856325983, t);\n p += fft(-95, 0.23819976781292496, 0.25934694371445854, t);\n p += fft(128, 0.23600151920093423, -2.2635194564211036, t);\n p += fft(-82, 0.23162812218159617, -0.40811639028183505, t);\n p += fft(63, 0.231108841604306, 0.7896297030534211, t);\n p += fft(66, 0.22876820962806374, -2.20689386652509, t);\n p += fft(145, 0.22683296568648012, -2.871130626679519, t);\n p += fft(114, 0.22579541537273998, -0.03888650023606557, t);\n p += fft(-115, 0.22449806848298495, 1.7267840321105514, t);\n p += fft(-101, 0.2201367259955669, -1.2160405006932076, t);\n p += fft(70, 0.21924416034549526, -1.8300948469474085, t);\n p += fft(-41, 0.2167988567102195, -0.8439248313023797, t);\n p += fft(110, 0.21645852077265354, -0.959164313163234, t);\n p += fft(158, 0.2151250144734518, 1.0174468948847888, t);\n p += fft(106, 0.21196244851082488, -0.7429833668933534, t);\n p += fft(-137, 0.20545059106326097, 2.8523980589526516, t);\n p += fft(-99, 0.20544620480189876, 2.378277723073504, t);\n p += fft(157, 0.20466861943591227, 1.5525202358047085, t);\n p += fft(-97, 0.20297792194129058, -0.24324542189056148, t);\n p += fft(168, 0.20130500227008466, -1.094673594091641, t);\n p += fft(117, 0.19993871414763503, 2.850736702421766, t);\n p += fft(98, 0.19737263515643355, 0.5877762863368731, t);\n p += fft(-72, 0.1929911058483345, 0.010089217287886454, t);\n p += fft(107, 0.19264056832987778, 0.704220700877197, t);\n p += fft(-112, 0.19130748611122012, -2.392875008529597, t);\n p += fft(-89, 0.1896856318579048, -1.952634273837995, t);\n p += fft(-118, 0.1840849374841271, 2.66760266379526, t);\n p += fft(-106, 0.1831571823504252, -0.22353534215395926, t);\n p += fft(68, 0.18268583480820008, -1.6209797108511708, t);\n p += fft(-55, 0.18120542886859284, 0.467068135124605, t);\n p += fft(95, 0.17907416077732574, 1.0948396281940986, t);\n p += fft(148, 0.17866061557325139, 2.3602934407666574, t);\n p += fft(177, 0.17832736193972554, -1.6046679924839198, t);\n p += fft(-108, 0.17809221310240264, -1.3634658504175172, t);\n p += fft(-98, 0.17770123200232602, -2.319713221578887, t);\n p += fft(100, 0.176886631202939, -1.121794475824346, t);\n p += fft(124, 0.17654047192131325, -2.379198871802532, t);\n p += fft(-88, 0.17639283951454524, -2.402190307443758, t);\n p += fft(-174, 0.1759528058963321, -2.2025378411458227, t);\n p += fft(140, 0.1753854668907291, 0.42397843457703155, t);\n p += fft(-96, 0.1753429914194849, -2.5609307243169104, t);\n p += fft(86, 0.17047016491561567, -2.1287646574123906, t);\n p += fft(-116, 0.16955079792541142, 1.330523857460539, t);\n p += fft(61, 0.16905959469199813, -2.6057097347432614, t);\n p += fft(-121, 0.1688420653965695, -0.5090905584523955, t);\n p += fft(155, 0.16680443183652535, -1.2332547487780734, t);\n p += fft(171, 0.16582399968407263, -0.8747323409363787, t);\n p += fft(-87, 0.1652225600618143, -2.085937535924309, t);\n p += fft(-131, 0.16214898761358187, 1.9650981796384732, t);\n p += fft(92, 0.15699998077784863, -0.18853113336883437, t);\n p += fft(166, 0.1554844992569468, 2.2850556504133888, t);\n p += fft(161, 0.15373402046283416, -0.7486102426340269, t);\n p += fft(144, 0.15312278232769228, -0.3587853130578195, t);\n p += fft(125, 0.15278331508565252, 0.6417517362772722, t);\n p += fft(97, 0.15144010052991969, 1.0282568217837087, t);\n p += fft(135, 0.15129294602934487, -0.6387137369146754, t);\n p += fft(-56, 0.1457904354443015, 2.356685746244658, t);\n p += fft(103, 0.1453915874749691, -0.6785631327279983, t);\n p += fft(146, 0.14379520492495512, -0.7855888994349319, t);\n p += fft(142, 0.1412707218042313, -0.1618563085599607, t);\n p += fft(126, 0.13936676935400355, -2.4453404815078725, t);\n p += fft(81, 0.13772359181353372, 0.5044424044942989, t);\n p += fft(163, 0.13762314582762275, 1.639822161059763, t);\n p += fft(134, 0.13545232146341332, 2.3024168785102312, t);\n p += fft(165, 0.13509475913506178, -0.8279398617821645, t);\n p += fft(-76, 0.13455680964642944, -3.0716219607883164, t);\n p += fft(-127, 0.13207374762677063, -2.6599668223479727, t);\n p += fft(-152, 0.13117632063169987, -2.5293527274604246, t);\n p += fft(-105, 0.1311202673313172, -2.693197028055788, t);\n p += fft(-145, 0.12945158970649637, 2.3951255425463125, t);\n p += fft(119, 0.12925458048582072, 2.1883428437365144, t);\n p += fft(132, 0.12746981347132513, -3.033026520788066, t);\n p += fft(-85, 0.12653240774860508, -2.8680500174257837, t);\n p += fft(-144, 0.12465405936107726, -0.37790452498667604, t);\n p += fft(76, 0.12463110048880623, 0.12012177237288406, t);\n p += fft(-142, 0.12459485706573038, 0.3051081828140754, t);\n p += fft(-138, 0.12451331383970095, 0.584148256098649, t);\n p += fft(149, 0.12401784752155019, -1.8125703421505832, t);\n p += fft(-147, 0.12362040139712106, 0.03028190421886324, t);\n p += fft(131, 0.12297013103130192, -1.7612969157441667, t);\n p += fft(-148, 0.12201071321640686, -2.0282746264394236, t);\n p += fft(-68, 0.12130140373799272, -0.9290611617024176, t);\n p += fft(116, 0.12128775362324593, -1.5007597875190253, t);\n p += fft(-135, 0.12111941530251287, -0.9133882438391181, t);\n p += fft(-104, 0.12079045102618642, 0.9539883001598056, t);\n p += fft(-86, 0.12063181239660088, -1.9105367933076451, t);\n p += fft(102, 0.11858318427484749, 3.116549695906647, t);\n p += fft(162, 0.11672334871059657, -0.43512865812715645, t);\n p += fft(-128, 0.11555594493778179, 1.594914753823693, t);\n p += fft(147, 0.11507078486852833, -1.8015902273798317, t);\n p += fft(-125, 0.11380569936104315, -0.02432076846797433, t);\n p += fft(-129, 0.1137850317216325, -2.6266191242164822, t);\n p += fft(77, 0.11284625921171428, 0.6500879168724161, t);\n p += fft(159, 0.11039859551711936, -2.8651146672170977, t);\n p += fft(-206, 0.10898089539528502, 1.0381666149725348, t);\n p += fft(-92, 0.10835773802225089, 0.6916172775229433, t);\n p += fft(127, 0.10811810875499965, -2.998228956999233, t);\n p += fft(-199, 0.10803687786223723, -2.46851901448902, t);\n p += fft(-184, 0.1079436817269362, 1.3191475812437883, t);\n p += fft(-161, 0.10743289221697289, 1.3169047201119328, t);\n p += fft(-139, 0.10723255868931553, -1.7855768275688515, t);\n p += fft(-130, 0.10575112607516497, 1.2885726884003454, t);\n p += fft(-198, 0.10555774123223534, 2.3378343445027423, t);\n p += fft(88, 0.1037982678523408, -2.57743331926905, t);\n p += fft(-219, 0.10310221059641228, -1.2625859044047876, t);\n p += fft(-103, 0.10235558593739706, 0.7768959419271573, t);\n p += fft(-201, 0.10189587875806011, 2.395004608187347, t);\n p += fft(174, 0.10047600105014917, -1.7769904121389015, t);\n p += fft(113, 0.10019192995096364, 0.6613060769884679, t);\n p += fft(186, 0.09888320495036292, 2.4232322332757033, t);\n p += fft(143, 0.09873568608937729, -0.6230636594392547, t);\n p += fft(-155, 0.0967869591188688, -1.7298363196681086, t);\n p += fft(185, 0.09658335995961313, 1.1754529148166517, t);\n p += fft(-177, 0.09656910791483884, 2.0163242572983346, t);\n p += fft(-167, 0.09620604020928483, 2.643429513987398, t);\n p += fft(170, 0.09573558303359174, -0.30695931132003684, t);\n p += fft(180, 0.09461328604462575, -1.6239251039930218, t);\n p += fft(-220, 0.0943272029181478, -1.4319742082110574, t);\n p += fft(-52, 0.09420059423208178, 0.34189504423155104, t);\n p += fft(-172, 0.09359535175565478, -0.6516984922913376, t);\n p += fft(-110, 0.0928047006450446, 1.6652587522465396, t);\n p += fft(151, 0.09250606338361644, -1.9756734220597145, t);\n p += fft(-93, 0.09207328457476618, -1.8386442351917063, t);\n p += fft(-136, 0.09192815271017309, 1.7852892175474182, t);\n p += fft(-113, 0.09189336119191194, 0.1795575241258869, t);\n p += fft(195, 0.09021546713204244, 2.2961250797130024, t);\n p += fft(-150, 0.0890214588284327, -0.4242294361284968, t);\n p += fft(-193, 0.08814677822860856, -3.032675290767406, t);\n p += fft(172, 0.08787933668637724, 0.8937743898253856, t);\n p += fft(-132, 0.08776566211120278, 1.6786784797215824, t);\n p += fft(120, 0.08739819001501205, 2.0491345267796923, t);\n p += fft(-237, 0.08676446852578372, -2.7506065977853367, t);\n p += fft(-195, 0.08631820577015377, -2.292066178728447, t);\n p += fft(-178, 0.08621869133141169, -2.289445548826154, t);\n p += fft(-160, 0.0859070990539687, 0.8565575603400595, t);\n p += fft(169, 0.08564275849176227, 1.4922004704741865, t);\n p += fft(150, 0.08528562752062617, -2.271332020864171, t);\n p += fft(136, 0.08341789857084404, 1.0652798481992052, t);\n p += fft(199, 0.08332375555828694, -2.172498972819133, t);\n p += fft(-235, 0.08327425440106223, -0.8722079224698919, t);\n p += fft(-141, 0.08287851144036412, -0.2817694914314737, t);\n p += fft(138, 0.08255129464089862, 2.481725429548499, t);\n p += fft(-109, 0.0814238813994593, 2.810607915964862, t);\n p += fft(-79, 0.08115343666484522, 3.0130919888081964, t);\n p += fft(153, 0.0806615747018418, -2.90631621064385, t);\n p += fft(-175, 0.0803741234494402, 2.4278323040306384, t);\n p += fft(-143, 0.07972332355377411, -0.14610097282743986, t);\n p += fft(-202, 0.07962980675194098, -0.2920969138999907, t);\n p += fft(-120, 0.07894459678944289, -1.0822564599135749, t);\n p += fft(-249, 0.07849391554379236, -1.5893682918262941, t);\n p += fft(156, 0.07754124056908816, 2.6380926428153773, t);\n p += fft(-158, 0.07639110613035878, -2.2498824982419814, t);\n p += fft(191, 0.07543660088489744, 1.53576512075985, t);\n p += fft(133, 0.07531833041051382, -0.29986287547697626, t);\n p += fft(-176, 0.07501869195137476, -1.095228282011871, t);\n p += fft(-173, 0.07438185135275685, -2.8547930590312265, t);\n p += fft(-246, 0.07320459577858625, 3.004959078587308, t);\n p += fft(-163, 0.07264231502260868, 0.5663326139154473, t);\n /* ------ move this line up for more speed, down for more precision ----------\n p += fft(206, 0.07185257960899775, -1.2074544409708887, t);\n p += fft(-123, 0.07180358234742663, 1.177001822427382, t);\n p += fft(164, 0.07179115512969167, 2.1602573633251723, t);\n p += fft(188, 0.07150545575062967, 1.7193031745778165, t);\n p += fft(224, 0.06999271922532711, -2.208456590100925, t);\n p += fft(-194, 0.06998312687642928, -2.18523653052791, t);\n p += fft(79, 0.06890472640127111, 1.3075753662847636, t);\n p += fft(109, 0.06860075505611797, 1.6822381082814495, t);\n p += fft(-212, 0.0678853204605727, 2.1130583033793853, t);\n p += fft(160, 0.06721168671629134, 1.5355417936258289, t);\n p += fft(-168, 0.06478428292880746, 1.8082125748786089, t);\n p += fft(-100, 0.06418217011920442, 0.7154587151883682, t);\n p += fft(-208, 0.06360704141059366, -2.403277839995585, t);\n p += fft(137, 0.06324033312067673, -2.2610437967492656, t);\n p += fft(123, 0.06295636338637589, 0.3970547395559689, t);\n p += fft(-196, 0.0627324819432708, -2.6051526033441235, t);\n p += fft(219, 0.06250233205660669, 2.203023925786526, t);\n p += fft(-185, 0.0621114667768006, -0.5698975168684676, t);\n p += fft(-166, 0.06210684036807704, 2.607205641731383, t);\n p += fft(-205, 0.06175529499391064, 1.9171825820936816, t);\n p += fft(-156, 0.061488097661469475, 1.4966065847312549, t);\n p += fft(154, 0.061272027059191166, -2.6984551455468564, t);\n p += fft(-231, 0.06035266134446573, 1.3615530640708646, t);\n p += fft(141, 0.05955849823049297, 1.5515335051172228, t);\n p += fft(-254, 0.05936948658056223, 0.08947841208696573, t);\n p += fft(-223, 0.05924934830234196, -2.5888981145084804, t);\n p += fft(-232, 0.05887059032744145, 0.01941763325695256, t);\n p += fft(167, 0.05881968845436434, -1.0357803375284511, t);\n p += fft(193, 0.058152494480082216, -0.4725096726740279, t);\n p += fft(121, 0.05729621516472733, 1.7676238462353928, t);\n p += fft(-268, 0.05725394282425765, -2.613958061844803, t);\n p += fft(-302, 0.05709087761847913, 1.7622838278216528, t);\n p += fft(-169, 0.05703481887597677, -0.6061202003738857, t);\n p += fft(-228, 0.05673330948726983, 1.5024729233397405, t);\n p += fft(222, 0.05638702685887402, -1.2302130026999638, t);\n p += fft(-260, 0.05595371621472635, 1.2791472131268498, t);\n p += fft(211, 0.05588512333449684, -1.8863675524330432, t);\n p += fft(237, 0.05577640817605678, 0.9044485733453621, t);\n p += fft(-210, 0.055436889934911734, -2.17570469763129, t);\n p += fft(-107, 0.054515606954931885, 1.6064878994455691, t);\n p += fft(-192, 0.054378774601921455, 0.177220838503605, t);\n p += fft(-182, 0.053953358377995975, -2.1280204079638576, t);\n p += fft(-263, 0.0538060156192732, -1.6125700112210792, t);\n p += fft(212, 0.05372692488622374, 0.9420856343907927, t);\n p += fft(-213, 0.053418601872005124, 2.7878022389569965, t);\n p += fft(-248, 0.05287392885207208, 0.18442109948336485, t);\n p += fft(226, 0.05219567026185329, -1.9364295452150295, t);\n p += fft(198, 0.05216791125481548, -1.3500769286288878, t);\n p += fft(-282, 0.05185758906196177, -1.0531164762937948, t);\n p += fft(-111, 0.051505065799642175, -1.5496533180287155, t);\n p += fft(-241, 0.05085304364706675, -0.46354003864012305, t);\n p += fft(-124, 0.05032731737587234, -0.9525802310682452, t);\n p += fft(-250, 0.050246365262025194, 0.8026967297965477, t);\n p += fft(-211, 0.05012936662149643, 0.7247623593388082, t);\n p += fft(-209, 0.05002408512494514, 1.8132755265361036, t);\n p += fft(-252, 0.049775105705583016, 0.5996942868760795, t);\n p += fft(223, 0.04939534137917373, -2.695791674918428, t);\n p += fft(122, 0.04894575970718128, 2.8830421586085544, t);\n p += fft(-153, 0.04887699031380359, 0.3334054103895581, t);\n p += fft(-181, 0.047900428231714746, -2.21806751268122, t);\n p += fft(299, 0.04768730955214819, 0.3243053297596023, t);\n p += fft(-259, 0.04760097318206576, -0.8705493020585283, t);\n p += fft(-227, 0.04622658586057274, 1.2806504451219154, t);\n p += fft(-226, 0.04575599938137761, 2.99718633620427, t);\n p += fft(-165, 0.04562578928136969, -0.9599207008754989, t);\n p += fft(-119, 0.0452353353928757, -2.8588596616336357, t);\n p += fft(-151, 0.04518238397772298, -0.13718441224107195, t);\n p += fft(-255, 0.04513692897501351, 1.860335619309556, t);\n p += fft(173, 0.04502237604956329, -0.810579987098727, t);\n p += fft(-164, 0.04491854079446375, -2.2251696607200238, t);\n p += fft(367, 0.04463225444542998, -1.3682718846259723, t);\n p += fft(-238, 0.044492812350265004, -1.30018967859005, t);\n p += fft(213, 0.04433393493985305, -2.5049897246887496, t);\n p += fft(-217, 0.04394773639883994, 0.3578708012733398, t);\n p += fft(-191, 0.04378025799588553, -0.0033036474870014217, t);\n p += fft(252, 0.04323472173070737, -0.6242705523897715, t);\n p += fft(208, 0.04304212913333182, 1.2308490125522018, t);\n p += fft(-303, 0.04296800234600092, 0.5114427759851766, t);\n p += fft(-224, 0.04272023945142006, 1.7783110640430169, t);\n p += fft(-239, 0.04266679157025011, 1.9482200717681597, t);\n p += fft(-299, 0.04173701435724602, 0.13365408028225706, t);\n p += fft(-157, 0.04146038143450164, -2.27864544691768, t);\n p += fft(-122, 0.04130127409599373, 1.0179985736718389, t);\n p += fft(244, 0.04122532274063034, -3.067112795949472, t);\n p += fft(-257, 0.04120260956232949, -0.542088172379074, t);\n p += fft(243, 0.0411840750974049, -1.1270227690299983, t);\n p += fft(-197, 0.04049657874199362, -1.3153250227799558, t);\n p += fft(-245, 0.040487242733518884, -0.8056762003801902, t);\n p += fft(-159, 0.039968494906456264, 2.131425507643933, t);\n p += fft(-307, 0.03996735676224505, -2.953588109997123, t);\n p += fft(-117, 0.03996366100725931, -0.49760194876592045, t);\n p += fft(196, 0.03980123228825173, -2.4873720845122835, t);\n p += fft(129, 0.03949030893082138, 2.6844282955405814, t);\n p += fft(-229, 0.03917242300752811, 0.4902693841571348, t);\n p += fft(139, 0.03902865341873541, 0.25084178188044515, t);\n p += fft(181, 0.03890376427607834, 1.0907389035558301, t);\n p += fft(205, 0.038225435143225045, 3.038754339328246, t);\n p += fft(-270, 0.03814390562327705, -1.8861478767357396, t);\n p += fft(-322, 0.0377875627108128, 2.054761498465224, t);\n p += fft(254, 0.037644552308180375, 1.226339480136378, t);\n p += fft(118, 0.0376169651010232, -2.950034729024326, t);\n p += fft(178, 0.03755225537409213, -2.0429020234266275, t);\n p += fft(-171, 0.037539637959647765, -2.628755546161329, t);\n p += fft(-285, 0.03747836134545755, 1.6722531286069764, t);\n p += fft(-180, 0.037460621587516375, 0.24951421594634987, t);\n p += fft(-247, 0.03717014294939771, 0.4975746705003909, t);\n p += fft(-243, 0.037110747818183125, -2.0522437006131544, t);\n p += fft(-216, 0.03709475821552742, -2.3116936028551125, t);\n p += fft(220, 0.036592206760702885, -1.1344479951397493, t);\n p += fft(-179, 0.03633519628480489, 3.112577471269461, t);\n p += fft(176, 0.03587107527180269, 2.0913103131787256, t);\n p += fft(-207, 0.035809732499114115, 1.927035559915993, t);\n p += fft(263, 0.03562581086066016, 2.1725008985745626, t);\n p += fft(-233, 0.0354009108649777, 3.090965188758471, t);\n p += fft(-274, 0.03518550659845451, -2.609254318579163, t);\n p += fft(255, 0.03514669947246087, -0.5836113629270486, t);\n p += fft(-319, 0.035071528591647944, -0.9287687613033353, t);\n p += fft(250, 0.035032432208899206, -1.3555387953817497, t);\n p += fft(246, 0.03497955004685989, -2.900549119786685, t);\n p += fft(187, 0.03497207390971293, 0.6419092201499581, t);\n p += fft(-261, 0.034866141687325505, -2.8459055041516237, t);\n p += fft(235, 0.03476696606441066, -2.0933815844908445, t);\n p += fft(-323, 0.03432989757242964, 3.043376257611318, t);\n p += fft(217, 0.03432513334072705, -2.870512549124132, t);\n p += fft(-162, 0.034206181317519346, 1.7603609329802217, t);\n p += fft(228, 0.033806131017560914, 2.744224194820961, t);\n p += fft(-214, 0.03361470625565273, 1.3269768758946363, t);\n p += fft(-215, 0.033529573748044716, -0.6672480021154472, t);\n p += fft(218, 0.033108296214315436, -0.745234197490618, t);\n p += fft(-146, 0.03308604353605592, 3.1073329337196274, t);\n p += fft(-304, 0.03303159902623534, -2.4351923422168493, t);\n p += fft(311, 0.032929142894730805, -1.2404835833846408, t);\n p += fft(242, 0.03292110918943753, -2.843217129365357, t);\n p += fft(-134, 0.03288854877053813, 0.9130453422359837, t);\n p += fft(-351, 0.03216220452946286, 2.9238550334113036, t);\n p += fft(370, 0.032067363608954395, -2.7224346201619336, t);\n p += fft(-272, 0.0320561856904509, -2.2145797900542075, t);\n p += fft(-154, 0.031753153031045644, -0.16349530311453386, t);\n p += fft(-297, 0.03170814258815033, 1.4299668847082438, t);\n p += fft(182, 0.031686346431849116, 1.0404018878433685, t);\n p += fft(209, 0.031631761114312575, 2.68111660535219, t);\n p += fft(-170, 0.03155091422698183, 0.025639469483387113, t);\n p += fft(-186, 0.031481161179575994, -2.4201773456994196, t);\n p += fft(-149, 0.031378407408703936, -0.29780149545874124, t);\n p += fft(-189, 0.03115713943498147, -2.644731527056393, t);\n p += fft(-140, 0.031108294831552176, -2.15723791130607, t);\n p += fft(-230, 0.031069499597997076, -1.8351044204097733, t);\n p += fft(-347, 0.030916908832951683, 2.4988906781918887, t);\n p += fft(179, 0.030863310224088517, -2.7337664596225717, t);\n p += fft(403, 0.03079754590699015, 2.304354929974498, t);\n p += fft(-327, 0.030401389085025158, 0.6776045430119092, t);\n p += fft(348, 0.030373006761288658, -0.8679493927914637, t);\n p += fft(-283, 0.030223082183547217, 2.321654263572609, t);\n p += fft(363, 0.029978631780089162, -2.0372134669252153, t);\n p += fft(300, 0.029897933119460138, -0.6676919620602354, t);\n p += fft(-291, 0.029861596312070346, 1.7523875509536528, t);\n p += fft(-188, 0.029753115428544207, 1.9857575444023974, t);\n p += fft(225, 0.02930280842219607, -2.476715232579848, t);\n p += fft(429, 0.029179633135401076, -1.1583720910674902, t);\n p += fft(-244, 0.028727529620259963, -2.1143873737131402, t);\n p += fft(-262, 0.02871955668992869, -3.0313512511556326, t);\n p += fft(183, 0.02846822983732852, -2.748892137103645, t);\n p += fft(371, 0.02837026069110045, 0.01709695974620803, t);\n p += fft(261, 0.02827365028172563, -3.1104354673121124, t);\n p += fft(265, 0.028272672120935843, 2.3187637649532733, t);\n p += fft(-225, 0.02812970136713906, -2.391287474012119, t);\n p += fft(-498, 0.027947522439068676, -2.2990766978458765, t);\n p += fft(-280, 0.027914429972500227, 1.013046879856245, t);\n p += fft(-286, 0.027473151353735275, -2.49136323587289, t);\n p += fft(175, 0.027082599263012368, -1.5491745606494223, t);\n p += fft(-312, 0.027012987931504247, 2.04498781689676, t);\n p += fft(-269, 0.02695999871732734, 1.9901497475231744, t);\n p += fft(-360, 0.026873297237023055, -0.1910603902232436, t);\n p += fft(210, 0.026869883314267793, 2.2196865134172485, t);\n p += fft(297, 0.026812580694708738, -0.9588922853385715, t);\n p += fft(-301, 0.026740603460076486, 3.129150821124547, t);\n p += fft(249, 0.026705638457446366, 1.222748808928071, t);\n p += fft(-265, 0.02664609481949143, -2.053872209655098, t);\n p += fft(234, 0.026552097720191792, 1.791539306291776, t);\n p += fft(227, 0.026483242165273254, 1.820370612047031, t);\n p += fft(-278, 0.026454482953384536, -0.05035777064958111, t);\n p += fft(130, 0.02643932663595854, -0.99756238511126, t);\n p += fft(231, 0.026426198746353186, 0.5809494198615022, t);\n p += fft(259, 0.026227035759586497, 0.048293120841955764, t);\n p += fft(-484, 0.025920236965447943, -1.3145326416833631, t);\n p += fft(-200, 0.02582688982027274, 2.9933704442672058, t);\n p += fft(306, 0.025717614417685275, 1.8836489796514166, t);\n p += fft(325, 0.025633895244435108, 1.3357894296294839, t);\n p += fft(347, 0.025591567492861077, 0.7714686164660547, t);\n p += fft(350, 0.02537545484909361, 1.0770352597787496, t);\n p += fft(269, 0.025281161653424446, -0.8907061117584099, t);\n p += fft(-133, 0.025264087654711557, -2.2018152563461086, t);\n p += fft(302, 0.025261769856955805, -2.355108757850705, t);\n p += fft(-386, 0.02501819794981099, -2.1477266907940398, t);\n p += fft(-350, 0.025002909823313272, -0.918163604040018, t);\n p += fft(333, 0.02498494266415943, -2.4432604967090743, t);\n p += fft(-126, 0.024859518286652924, -1.6045017067489493, t);\n p += fft(387, 0.02467625356087282, 1.3070718064311373, t);\n p += fft(334, 0.024653917539731205, -1.2008707105925764, t);\n p += fft(-240, 0.024383901745244567, -2.988241565566239, t);\n p += fft(-264, 0.024335184695854287, -2.6872316547229813, t);\n p += fft(-295, 0.024162332511406915, 2.688135808330894, t);\n p += fft(-276, 0.023836127347152083, 1.7406463579323161, t);\n p += fft(203, 0.02379133257240037, -0.3391371830055463, t);\n p += fft(238, 0.023765709007479915, -0.5242076860175524, t);\n p += fft(-483, 0.023685530454379034, -2.7588368682276188, t);\n p += fft(-342, 0.023608418137766377, -2.8422263956774603, t);\n p += fft(-329, 0.02352667163920514, -1.3751865534697134, t);\n p += fft(-325, 0.023484462227501834, 0.9927626044567095, t);\n p += fft(230, 0.023456797688559062, 2.986455504190948, t);\n p += fft(-251, 0.023318098398379915, 0.001782273200166798, t);\n p += fft(349, 0.023228733757422806, -1.072303089214612, t);\n p += fft(-187, 0.02322820420005635, -1.3088872022943903, t);\n p += fft(207, 0.023124953262124194, 2.861078526577945, t);\n p += fft(202, 0.023092047214425013, 1.0903724835034125, t);\n p += fft(256, 0.022985204913763314, -2.423841790239499, t);\n p += fft(275, 0.022818988303534807, 0.6902607477729654, t);\n p += fft(241, 0.022704874638607323, -2.7649106335200497, t);\n p += fft(425, 0.0227031562735846, -0.012766251035448749, t);\n p += fft(341, 0.022687393671458885, 2.5287999264265917, t);\n p += fft(365, 0.02259089981517188, -3.0023071719734364, t);\n p += fft(298, 0.022430755305941547, 2.1440768785920277, t);\n p += fft(282, 0.022286640564131238, 1.6952796376817658, t);\n p += fft(-222, 0.02225904133709741, -0.11321484605745279, t);\n p += fft(-358, 0.02217999232999693, 1.7758821914468246, t);\n p += fft(-279, 0.022095177947215737, -0.5192730492996941, t);\n p += fft(-321, 0.022090473578627715, -0.07844498829588367, t);\n p += fft(-359, 0.021942659529941247, -1.4465606944335514, t);\n p += fft(295, 0.021938469715302247, -2.262517021888232, t);\n p += fft(276, 0.02187149419277873, -0.48075610553317366, t);\n p += fft(502, 0.021702319512468666, 3.0296543113191032, t);\n p += fft(-330, 0.021623659938299806, 1.125358184849381, t);\n p += fft(437, 0.021598487358667418, -3.140123913594686, t);\n p += fft(329, 0.02151039012029828, 2.581279012552966, t);\n p += fft(316, 0.021367306895449877, -1.4951973637160159, t);\n p += fft(-267, 0.021347948106670487, -2.131762505311679, t);\n p += fft(-357, 0.02130909397626576, -1.6191594501730688, t);\n p += fft(267, 0.021293781075476997, -1.8017482889635452, t);\n p += fft(-345, 0.021048837931442004, -2.7069477620313958, t);\n p += fft(-408, 0.02091001972463279, -1.769848404933256, t);\n p += fft(320, 0.02088425179811783, -2.0704408556221447, t);\n p += fft(-387, 0.020820573842865432, -1.0930901397929305, t);\n p += fft(-242, 0.020794137395108606, -2.9605829129168324, t);\n p += fft(-344, 0.020671452626722698, -1.7987821089995277, t);\n p += fft(322, 0.02067088832181214, -0.22912612763676568, t);\n p += fft(-253, 0.02061794621791137, -2.0073683043484953, t);\n p += fft(152, 0.020610241493015494, 0.7098290286508013, t);\n p += fft(303, 0.020592932879901157, 0.2719935974041692, t);\n p += fft(369, 0.020565205999609194, 1.1339865732671597, t);\n p += fft(-273, 0.020564513440436215, 0.7955462603371597, t);\n p += fft(215, 0.020563199492889896, -2.73682346996378, t);\n p += fft(491, 0.020543180022284717, -0.666788850668437, t);\n p += fft(-356, 0.020468707035038124, 0.6390339134967551, t);\n p += fft(293, 0.02045422037494547, 2.0389477913494334, t);\n p += fft(201, 0.02044920037993446, 0.020014295722637722, t);\n p += fft(346, 0.020343417891833488, -0.725558513377337, t);\n p += fft(-399, 0.020300294108822257, 0.4272740878635683, t);\n p += fft(464, 0.020245436748592072, -1.684969251038007, t);\n p += fft(221, 0.020152569151655777, 3.0652577733184607, t);\n p += fft(489, 0.020112656771664496, -1.8042417759245823, t);\n p += fft(318, 0.020056388889540793, -0.6707185351758385, t);\n p += fft(-339, 0.02001479126183757, 2.949145490351578, t);\n p += fft(236, 0.019954859133684905, -2.5428580801661353, t);\n p += fft(270, 0.0199321804912115, 0.37878519439460373, t);\n p += fft(379, 0.01983906743081143, -0.6343495825544784, t);\n p += fft(397, 0.019807948769945526, 1.8820880074650208, t);\n p += fft(-221, 0.019691977663300008, 1.0514616478563783, t);\n p += fft(421, 0.019623337934699885, 2.745363616281166, t);\n p += fft(290, 0.01953008037132682, 0.8843912942541152, t);\n p += fft(197, 0.019375944562943694, 2.0356527234870283, t);\n p += fft(308, 0.0193527600669189, 2.81162774010797, t);\n p += fft(-328, 0.019285400376087076, -0.19114063563029987, t);\n p += fft(467, 0.019178891795281015, -1.1263460951000444, t);\n p += fft(-277, 0.019079718249143097, 2.6331532845129404, t);\n p += fft(280, 0.018994654616752097, 0.1675185745565849, t);\n p += fft(260, 0.018913994053827352, -0.5044184838532041, t);\n p += fft(427, 0.018852739951118917, 2.662217288999046, t);\n p += fft(499, 0.01882350931017547, -3.0149846935153795, t);\n p += fft(189, 0.018757809943370472, -2.674046839704885, t);\n p += fft(342, 0.01874747510581987, -0.5786367177428741, t);\n p += fft(416, 0.018566064359446622, -2.4176951579501798, t);\n p += fft(-348, 0.018437843583245718, -2.43964557130452, t);\n p += fft(465, 0.018437257369033726, 1.9214782275571987, t);\n p += fft(284, 0.01833544793734469, 1.9968963624882772, t);\n p += fft(-470, 0.01831002225764508, 0.5156559884673433, t);\n p += fft(-309, 0.018308015252553246, 2.312871173198566, t);\n p += fft(490, 0.018216767412652893, 1.0140583098689544, t);\n p += fft(410, 0.0182153814183295, -0.7582160151193984, t);\n p += fft(-258, 0.018128466510949046, 1.1118990006128406, t);\n p += fft(375, 0.018057552391933036, -3.1017254547912794, t);\n p += fft(321, 0.01794587346556815, -1.8663932495219484, t);\n p += fft(248, 0.017863597777448885, -0.5496798132550856, t);\n p += fft(-317, 0.01782644768907149, 2.2802015955382537, t);\n p += fft(-452, 0.01780336641082023, 2.690346714053042, t);\n p += fft(-353, 0.0176913084429108, 2.711049147139238, t);\n p += fft(-306, 0.017552300595371273, 2.9506692681038973, t);\n p += fft(-288, 0.017544324110289406, 2.6323855434673655, t);\n p += fft(-460, 0.017443786885044096, -0.9299541940735817, t);\n p += fft(309, 0.017419145135487844, 1.3460311128048443, t);\n p += fft(305, 0.017152445993384516, -1.7361791397832658, t);\n p += fft(-256, 0.01714047466479905, 2.2799787723913836, t);\n p += fft(355, 0.017058849062613846, -0.6615483742229916, t);\n p += fft(-320, 0.016979227333377315, 2.6388512636510377, t);\n p += fft(-382, 0.01695615705889803, 2.555957382259133, t);\n p += fft(390, 0.016953475958207665, 2.3322367819625027, t);\n p += fft(-398, 0.01694687182836866, 2.171099613653392, t);\n p += fft(411, 0.01692398609281921, -2.3970294940597237, t);\n p += fft(391, 0.01688742438332487, -2.6741985703550384, t);\n p += fft(-383, 0.01671254896861024, -1.809831893039911, t);\n p += fft(-438, 0.016700025869992145, -3.0263950471937577, t);\n p += fft(498, 0.016577067431832987, 1.4628404900222298, t);\n p += fft(441, 0.016528444933087572, -2.5534170728688195, t);\n p += fft(396, 0.016469294170931584, -1.0778883003395043, t);\n p += fft(194, 0.016387929541844138, 0.27285370222194255, t);\n p += fft(288, 0.01632089028121901, -2.499948895627382, t);\n p += fft(-453, 0.016282171657074507, -1.8352466594182715, t);\n p += fft(-491, 0.0162466408620674, 0.751075739658446, t);\n p += fft(-271, 0.01618413446166483, -1.9240760733216773, t);\n p += fft(374, 0.01597286278830038, 1.4727297170481586, t);\n p += fft(245, 0.01595638314751546, -2.5020467251265117, t);\n p += fft(492, 0.015955522695669654, -2.11250121739465, t);\n p += fft(292, 0.015938735781863788, 2.8886197298108702, t);\n p += fft(356, 0.015930093359693635, 3.119487581363237, t);\n p += fft(-336, 0.01588376130850545, 0.28597008022586234, t);\n p += fft(386, 0.01579744464348149, -0.6427892645860717, t);\n p += fft(424, 0.015781071608576305, 0.06038150421307685, t);\n p += fft(286, 0.015677276287429535, 2.6843830865968843, t);\n p += fft(-439, 0.01566577624464125, -0.40437157307800353, t);\n p += fft(-316, 0.015653156388410593, -0.49543109291627363, t);\n p += fft(-480, 0.015631631437216433, 2.2355153900157636, t);\n p += fft(400, 0.015537542523719335, -2.445474568008316, t);\n p += fft(-447, 0.015437071879756518, 2.7865636796309072, t);\n p += fft(366, 0.015353947913814526, 2.0058503224480564, t);\n p += fft(-492, 0.015303110265234265, 2.3874477585758074, t);\n p += fft(-445, 0.015280750696461273, 0.444334272791586, t);\n p += fft(353, 0.015251950793442146, -2.7836080531188006, t);\n p += fft(-500, 0.015226472622413946, -2.6103075874608708, t);\n p += fft(-380, 0.015222967220547282, -2.881867749906817, t);\n p += fft(506, 0.015150418703193842, 2.0075105204746566, t);\n p += fft(-335, 0.015124331759979636, 1.009943322524843, t);\n p += fft(483, 0.015097172526301886, 2.0959180943388027, t);\n p += fft(240, 0.015078862676021213, -1.2930571972964564, t);\n p += fft(-401, 0.01507870517510355, 2.715454154162096, t);\n p += fft(449, 0.015061353079694497, 1.8733248116188075, t);\n p += fft(412, 0.015050927296007339, 2.2976965232943307, t);\n p += fft(323, 0.014984653022696854, -3.0935557999938292, t);\n p += fft(-396, 0.014977404461351117, 0.30211159558289086, t);\n p += fft(273, 0.01483460564366501, -1.4596850118087714, t);\n p += fft(345, 0.014833234000572936, -0.32539675758169934, t);\n p += fft(-417, 0.014811822655002693, -2.5447030635824297, t);\n p += fft(-394, 0.014768485010995914, 0.8420120899555257, t);\n p += fft(-326, 0.014757622857210374, -0.9559941626829623, t);\n p += fft(-373, 0.01470773104483892, 2.794549031160765, t);\n p += fft(340, 0.014690011817124374, -2.2126006109671352, t);\n p += fft(-390, 0.014674589859169042, -0.9855117184354396, t);\n p += fft(317, 0.014671770616686048, -0.4111710755329078, t);\n p += fft(-308, 0.014630448864418246, -2.6132662944333247, t);\n p += fft(-419, 0.014612974424031182, 1.890332423869268, t);\n p += fft(472, 0.014573773093057102, -0.15746800733732982, t);\n p += fft(257, 0.014541893370249208, -1.3953361182084414, t);\n p += fft(436, 0.014503458130718185, 1.473439813394881, t);\n p += fft(-218, 0.014473405505827206, -2.2614161401120723, t);\n p += fft(-384, 0.014387460588666384, 0.4846527714087321, t);\n p += fft(214, 0.014373508138361935, -0.9929984801205258, t);\n p += fft(327, 0.014363924720838923, 0.6705953026310363, t);\n p += fft(-443, 0.014247709886683415, 0.6588561068584213, t);\n p += fft(216, 0.014201020492534005, 2.6741170951719297, t);\n p += fft(278, 0.014195739673546514, 0.45380564178946164, t);\n p += fft(474, 0.01417224313980241, -2.946490401046988, t);\n p += fft(361, 0.014169743346048109, 0.7656558005070042, t);\n p += fft(418, 0.014153025125774113, 0.6544601775463792, t);\n p += fft(-204, 0.014098068158582331, 1.570589753704267, t);\n p += fft(409, 0.01408416890434566, 0.5791110199136934, t);\n p += fft(332, 0.014064077521337141, -1.96196450322835, t);\n p += fft(-411, 0.014055381190387442, -2.1050532273937193, t);\n p += fft(-504, 0.014042491970392819, -2.4507746476472416, t);\n p += fft(-331, 0.014021056796023198, -0.9466573694669207, t);\n p += fft(331, 0.01401815399131699, 2.9486255021269, t);\n p += fft(381, 0.014006914694692865, -1.1186058737646056, t);\n p += fft(291, 0.013994629362131503, 1.9007976843424446, t);\n p += fft(330, 0.013949517263636396, -0.49986286341122593, t);\n p += fft(312, 0.013936760778201074, 3.0721230148366017, t);\n p += fft(417, 0.013934783414901307, -2.257422367097522, t);\n p += fft(-337, 0.01391371567127865, 2.895113197666846, t);\n p += fft(385, 0.013891315233703376, -1.1352978862346337, t);\n p += fft(-435, 0.013873332760801304, -0.32090186205450033, t);\n p += fft(-385, 0.013844120558174551, -3.119969137357533, t);\n p += fft(315, 0.013828233021495205, -3.0524501599722305, t);\n p += fft(-343, 0.01378875650901319, -0.6263451828356061, t);\n p += fft(459, 0.013771797001534768, 1.3512327925116, t);\n p += fft(319, 0.013701983237761646, -3.0552359101211772, t);\n p += fft(-421, 0.013685546780447071, 0.6168243016650519, t);\n p += fft(307, 0.013681679811588384, -0.8864069492779628, t);\n p += fft(-477, 0.01367630727868223, 2.7521796191613754, t);\n p += fft(-465, 0.013581831625402187, -1.220520995405941, t);\n p += fft(326, 0.013574391629771329, -3.1202874287266082, t);\n p += fft(360, 0.0135341266402344, 2.664064685853016, t);\n p += fft(-377, 0.013529068169515567, 0.2646391557351839, t);\n p += fft(-459, 0.013509914775589568, -1.0462062859265808, t);\n p += fft(-436, 0.013509169672166503, 3.060808353213404, t);\n p += fft(-442, 0.013378848325932797, -2.943169899395721, t);\n p += fft(281, 0.013324886668795041, 0.7702604219139404, t);\n p += fft(402, 0.013309784889240976, 3.0462417371183212, t);\n p += fft(413, 0.0133092395072314, -2.5644879288039295, t);\n p += fft(-289, 0.013200751727554779, -0.42679700259876185, t);\n p += fft(484, 0.013164831415710608, 1.1147833223969785, t);\n p += fft(401, 0.01310573625374175, -0.45440514371321855, t);\n p += fft(277, 0.013041278781405874, 2.710518166070806, t);\n p += fft(-349, 0.013024136574205064, 0.368816551131045, t);\n p += fft(-346, 0.012977337347580263, -0.26417451603147596, t);\n p += fft(420, 0.012845882619135234, 2.002998951036915, t);\n p += fft(445, 0.01284579635338418, -2.0677013276140324, t);\n p += fft(428, 0.01279398105157776, 1.2926796180614086, t);\n p += fft(376, 0.01276786373111407, 1.9367911037174024, t);\n p += fft(-376, 0.01272502179107737, -3.1282891850863908, t);\n p += fft(-507, 0.012722242687719345, 1.8939443453134572, t);\n p += fft(-294, 0.012712310194407102, -1.188628976570537, t);\n p += fft(-415, 0.012670552135729969, -0.9868907915235011, t);\n p += fft(-428, 0.012607664240827194, -0.031095597497390378, t);\n p += fft(473, 0.012543542480353977, -3.0690769712824704, t);\n p += fft(430, 0.012541336274083313, -2.048475426543982, t);\n p += fft(-341, 0.012469363963888485, 1.1697948865306476, t);\n p += fft(-509, 0.012466468154148012, 0.38059867841898043, t);\n p += fft(-481, 0.01242592353445654, -1.913914863175826, t);\n p += fft(-314, 0.01239765783707375, -2.1235472871525767, t);\n p += fft(-313, 0.012376173120752695, 1.03944125297012, t);\n p += fft(-471, 0.012345159783470094, 2.6516490082388215, t);\n p += fft(-310, 0.012284310170666665, -2.1698685017205785, t);\n p += fft(-300, 0.01227542981113322, -2.017710213505234, t);\n p += fft(247, 0.012240477217121775, 0.41935200430886505, t);\n p += fft(-466, 0.012240125520371849, 0.019480587267466563, t);\n p += fft(503, 0.01222533405281694, 0.6840099173444322, t);\n p += fft(200, 0.012220403742265044, 2.887981253820241, t);\n p += fft(304, 0.012182539431900842, 2.632403848640596, t);\n p += fft(-425, 0.01215230910385176, 0.8806489351275139, t);\n p += fft(351, 0.01214911658400834, -2.451703539504316, t);\n p += fft(404, 0.012113298811467181, -0.1782921248032119, t);\n p += fft(-404, 0.012098227853860725, -1.9073495889414767, t);\n p += fft(500, 0.01206287854228493, 1.0185472742352673, t);\n p += fft(-499, 0.012052977984837707, -2.947829310783775, t);\n p += fft(296, 0.01203564352441712, -2.5371259687889496, t);\n p += fft(344, 0.012030880992025202, -1.5507150201535012, t);\n p += fft(-490, 0.011980159644615596, -0.06316472136582, t);\n p += fft(-352, 0.011969909686558968, -0.40224393964822713, t);\n p += fft(-506, 0.01193447069907937, -1.174788671161676, t);\n p += fft(268, 0.011916136745930814, 1.8609641665108294, t);\n p += fft(456, 0.011855122323403295, -0.25549478912944407, t);\n p += fft(477, 0.011851778387300449, -0.7824493403677418, t);\n p += fft(258, 0.011823107744589997, 0.4702714456912564, t);\n p += fft(504, 0.011813789783172548, -2.1593068285941017, t);\n p += fft(285, 0.01180532967217003, 1.9107235273443852, t);\n p += fft(294, 0.011771073591615677, -3.0221374579820486, t);\n p += fft(-340, 0.011737380405027845, -0.09560932985103796, t);\n p += fft(-412, 0.011693563396162478, 0.03547230271148827, t);\n p += fft(-473, 0.01167087995314407, -2.983087290342926, t);\n p += fft(-381, 0.011633614975664468, 0.05696443428106514, t);\n p += fft(423, 0.011627989857404918, 0.07675195602888493, t);\n p += fft(-324, 0.01161418553014038, -2.471424070407224, t);\n p += fft(399, 0.011577011391338602, 0.8371784427311489, t);\n p += fft(-478, 0.011557125479527306, -2.2282000740788677, t);\n p += fft(283, 0.011531997122870051, -0.7010609826477285, t);\n p += fft(511, 0.0114760434011943, 1.734049648533497, t);\n p += fft(279, 0.011460842192281833, 1.4668325872315813, t);\n p += fft(447, 0.011454898078003161, -0.13946735136066804, t);\n p += fft(-485, 0.011428486636959046, 0.34886175616311715, t);\n p += fft(-472, 0.011389433654382263, 0.45069667769887467, t);\n p += fft(-505, 0.011374024792638228, -0.16038515681074883, t);\n p += fft(496, 0.011367209747096613, -0.5789335748725059, t);\n p += fft(287, 0.011353094401163121, -2.6544713993331595, t);\n p += fft(-476, 0.011339897348846054, 2.760999701731875, t);\n p += fft(-203, 0.011246318318210755, -2.655330740012455, t);\n p += fft(-298, 0.011240592231092321, -0.8535304917183064, t);\n p += fft(435, 0.011199052278348127, -2.221842104143809, t);\n p += fft(-397, 0.011179697495765209, 1.9050162197469025, t);\n p += fft(339, 0.011177696172867731, -1.5279335419082853, t);\n p += fft(314, 0.01113945595405601, -2.665298378120776, t);\n p += fft(408, 0.011075489731786133, -1.6517945429682814, t);\n p += fft(446, 0.01101171854080183, -0.48257443448194115, t);\n p += fft(-333, 0.011005844536439355, -2.23571436410032, t);\n p += fft(450, 0.01098336159814381, -2.3282935745461235, t);\n p += fft(-293, 0.010866838807767636, -2.08175340759797, t);\n p += fft(336, 0.010820760748971349, 1.7112356086996947, t);\n p += fft(414, 0.010787409392539691, 2.807079317517186, t);\n p += fft(-318, 0.010742470447882757, 2.8752872175583497, t);\n p += fft(406, 0.010725007874053354, 3.063825957806161, t);\n p += fft(-413, 0.010690874318868027, -3.119832148809836, t);\n p += fft(415, 0.010685727067395259, 0.8983819808171652, t);\n p += fft(-503, 0.010659993246209611, 0.3133119607095941, t);\n p += fft(-355, 0.010621606166054188, -2.3472131268696774, t);\n p += fft(-281, 0.01061443706876594, -0.7561374672674868, t);\n p += fft(-366, 0.010605967113792601, -2.711774616807628, t);\n p += fft(-479, 0.010586221430330002, -2.5484256879947855, t);\n p += fft(-426, 0.010490344441220769, 1.0668022268161381, t);\n p += fft(-405, 0.010385062881632077, 2.306115157954148, t);\n p += fft(-290, 0.010384484051949614, -2.2711503576547094, t);\n p += fft(364, 0.010311227119556366, 1.3569201451071267, t);\n p += fft(239, 0.01030448004807976, -1.9386533731670805, t);\n p += fft(-424, 0.010283240609725826, 0.8760921385535031, t);\n p += fft(338, 0.010272254653901589, -1.0871306303800126, t);\n p += fft(-482, 0.01024776632548479, -0.6515462866676507, t);\n p += fft(-494, 0.01024564906483858, 2.395078651689155, t);\n p += fft(-236, 0.010162897249939504, 1.9785592807626329, t);\n p += fft(494, 0.010150992333137729, -0.01780121101171699, t);\n p += fft(233, 0.010096455886289615, -2.5741668393876806, t);\n p += fft(192, 0.010084734213336314, -0.8855447372541574, t);\n p += fft(-234, 0.010056081638657548, 1.9417984487245914, t);\n p += fft(-266, 0.010020076168818585, -0.561779230785278, t);\n*/\n return (p + vec2(-250, -150)) * 0.01 /* center and scale */\n ;\n}\n\nvoid main() {\n float segmentsPerCircle = 640.0;\n float pointsPerCircle = segmentsPerCircle * 2.0;\n float numCircles = floor(vertexCount / pointsPerCircle);\n \n float vId = mod(vertexId, pointsPerCircle);\n float cId = floor(vertexId / pointsPerCircle);\n float cv = cId / numCircles;\n float u = floor(vId / 2.0) + mod(vId, 2.0);\n float v = u / segmentsPerCircle;\n float a = v * PI * 2.0 + cv;\n\n vec2 p = computeFFT(v + time + cv);\n \n float distFromCenter = length(p);\n\n float s = texture2D(sound, vec2(\n mix(0.01, 0.1, abs(v * 2. - 1.)),\n cv * 0.2)).r;\n float s2 = texture2D(sound, vec2(0.1, cv*0.1)).r;\n \n vec3 pos = vec3(p, 0); \n \n \n float ct = time * 0.3;\n vec3 eye = vec3(vec2(sin(ct), cos(ct)) * 2.5, -5.0);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 250.); \n mat *= cameraLookAt(eye, target, up);\n //mat *= trans(vec3(computeFFT(cv + time), 0));\n mat *= trans(vec3(0, 0, cv * 2. - 1.) * 0.3);\n mat *= rotZ(PI + pow(s, 5.0) * 0.2 - 0.1);\n mat *= uniformScale(mix(0.9, 1.2, pow(s, 5.0)) + s2);\n gl_Position = mat * vec4(pos, 1);\n\n\n float boost = step(0.7, s);\n \n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\n float sat = 1.0;1.0 - pow(pos.z, 1.) - pow(s, 4.);\n float val = sin(v) * 0.5 + 0.5;mix(0.25, 2.0, pow(s, 2.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-4ai6dzvj6atvpy3e9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XwmMeBkJu6Bk2vv9o/art.json b/art/XwmMeBkJu6Bk2vv9o/art.json index f81ed0c1..efec6c36 100644 --- a/art/XwmMeBkJu6Bk2vv9o/art.json +++ b/art/XwmMeBkJu6Bk2vv9o/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/prokobass/sets/first-contact-e-p\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS \\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3(2.+ mouse.x*10. , 40.3*mouse.y, 0.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 1.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 10.6, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, -mouse.t );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( mouse.x, 11.0+\\n mouse.y );\\n\\n quadId = floor( vertexIndex / 16.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 1.+time*0.001 - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v - q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( -0.80, 0.3, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across * perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(11.0, (12.), u+16.), u - 14.2)).a*10.;\\n float s2 = texture2D(sound, vec2(mix(0.2, 1.2-cos(time/u), v), v + 1.05)).a/2.01/sin(mouse.x*snd);\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\\n float vSpace = numRows * 2.05 + numBlocks * 9.0;\\n float z = v * down * 2.05 + bzId * 210.;\\n vCubeOrigin.z += fract(-time * 0.201+ z / vSpace) * vSpace;\\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 0.6, s2) * 0.5;\\n vCubeOrigin.y += perBlock * + height;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(s2, height, 1.-snd));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 1.;//0.5 + over * 0.7;\\n float sat = step(0.25,s2)*3.;\\n float val = pow(s2*0.01,0.3);\\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.027) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 00.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 1.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 1.1*abs(cos(time)), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\tvFinalColor -= vec3(0.0-sin(time*1.0)*sceneVertex.vColor.r,0.70,1.0-cos(time*1.2));\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/prokobass/sets/first-contact-e-p", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS \n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3(2.+ mouse.x*10. , 40.3*mouse.y, 0.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 1.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 10.6, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, -mouse.t );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( mouse.x, 11.0+\n mouse.y );\n\n quadId = floor( vertexIndex / 16.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 1.+time*0.001 - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v - q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( -0.80, 0.3, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across * perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(11.0, (12.), u+16.), u - 14.2)).a*10.;\n float s2 = texture2D(sound, vec2(mix(0.2, 1.2-cos(time/u), v), v + 1.05)).a/2.01/sin(mouse.x*snd);\n \n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\n float vSpace = numRows * 2.05 + numBlocks * 9.0;\n float z = v * down * 2.05 + bzId * 210.;\n vCubeOrigin.z += fract(-time * 0.201+ z / vSpace) * vSpace;\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 0.6, s2) * 0.5;\n vCubeOrigin.y += perBlock * + height;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(s2, height, 1.-snd));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 1.;//0.5 + over * 0.7;\n float sat = step(0.25,s2)*3.;\n float val = pow(s2*0.01,0.3);\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.027) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 00.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 1.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 1.1*abs(cos(time)), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\n \tvFinalColor -= vec3(0.0-sin(time*1.0)*sceneVertex.vColor.r,0.70,1.0-cos(time*1.2));\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-cedms3b6qdz6p07bo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XxN2enyHa2MMbayT5/art.json b/art/XxN2enyHa2MMbayT5/art.json index 2849635f..7996cc40 100644 --- a/art/XxN2enyHa2MMbayT5/art.json +++ b/art/XxN2enyHa2MMbayT5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2980392156862745,0.2235294117647059,0.7254901960784313,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 1800.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float quadCount = POINTS_PER_LINE / 6.; \\n float v = vertexId / vertexCount;\\n float invV = 1. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = mod(vertexId, 100.) / 100.;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\\n \\n pos = getCenterPoint(time * 4. + vertexId * 0.0001, vec2(0,0));\\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * 5.11 + vertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(v);\\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 2.;\\n\\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\\n float sat = 0.2 + pow(snd0 + 0.2, 10.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.2);\\n v_color = vec4(v_color.rgb * v_color.a, 0.1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2980392156862745, + 0.2235294117647059, + 0.7254901960784313, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 1800.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float quadCount = POINTS_PER_LINE / 6.; \n float v = vertexId / vertexCount;\n float invV = 1. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = mod(vertexId, 100.) / 100.;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\n \n pos = getCenterPoint(time * 4. + vertexId * 0.0001, vec2(0,0));\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * 5.11 + vertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(v);\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 2.;\n\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\n float sat = 0.2 + pow(snd0 + 0.2, 10.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.2);\n v_color = vec4(v_color.rgb * v_color.a, 0.1);\n}" + }, "screenshotURL": "data/images/images-reivvzf3jsx8b92xj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XxsoGmBRve3XhR5q3/art.json b/art/XxsoGmBRve3XhR5q3/art.json index 483575bb..28a9dfec 100644 --- a/art/XxsoGmBRve3XhR5q3/art.json +++ b/art/XxsoGmBRve3XhR5q3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/didlybom/ryuichi-sakamoto-merry-christmas-mr-lawrence\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < -6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float maxCubes = floor(vertexCount / 36.);\\n float numCubes = maxCubes * mix(0.1, 1., t5p5(sin(time * .05)));\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = (cv);\\n //su = hash(cubeId / maxCubes);\\n float s1 = texture2D(sound, vec2(mix(.2, .0, su), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(.2, .0, su), 1. / soundRes.y)).a;\\n float s3 = texture2D(sound, vec2(mix(.2, .0, su), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(.2, .0, su), 3. / soundRes.y)).a;\\n \\n float s = mix(0.0, 0.25, s1 + s2 + s3 + s4);\\n \\n float tm = time * .1;\\n float r = 50.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\\n mat *= trans(vec3(0, 0, 1));\\n mat *= rotZ(s * PI * 2.);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = .4 + s * .15;\\n float sat = .2 + s;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt, 1);\\n v_color.a = s;\\n v_color.rgb *= v_color.a; \\n if (s < .2) {\\n gl_Position.z = 10000.;\\n }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/didlybom/ryuichi-sakamoto-merry-christmas-mr-lawrence", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < -6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float maxCubes = floor(vertexCount / 36.);\n float numCubes = maxCubes * mix(0.1, 1., t5p5(sin(time * .05)));\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = (cv);\n //su = hash(cubeId / maxCubes);\n float s1 = texture2D(sound, vec2(mix(.2, .0, su), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(.2, .0, su), 1. / soundRes.y)).a;\n float s3 = texture2D(sound, vec2(mix(.2, .0, su), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(.2, .0, su), 3. / soundRes.y)).a;\n \n float s = mix(0.0, 0.25, s1 + s2 + s3 + s4);\n \n float tm = time * .1;\n float r = 50.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(sc, sc, mix(1., 2.5, pow(s, 1.0))));\n mat *= trans(vec3(0, 0, 1));\n mat *= rotZ(s * PI * 2.);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = .4 + s * .15;\n float sat = .2 + s;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt, 1);\n v_color.a = s;\n v_color.rgb *= v_color.a; \n if (s < .2) {\n gl_Position.z = 10000.;\n }\n}\n\n" + }, "screenshotURL": "data/images/images-4ojod4zswqcew90ls-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/XzD6NxAZ99yMTnE2v/art.json b/art/XzD6NxAZ99yMTnE2v/art.json index 2468ba2d..bf4f20ab 100644 --- a/art/XzD6NxAZ99yMTnE2v/art.json +++ b/art/XzD6NxAZ99yMTnE2v/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Motion\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Motion\ncourse name : CS250\nterm : 2022 Spring\n*/\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ynt32ob61d9mt7th8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/XzeZ7nA6eLt5GmJfj/art.json b/art/XzeZ7nA6eLt5GmJfj/art.json index c61ca197..402da6c5 100644 --- a/art/XzeZ7nA6eLt5GmJfj/art.json +++ b/art/XzeZ7nA6eLt5GmJfj/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "pgan", "avatarUrl": "https://secure.gravatar.com/avatar/b786c3cea88eff238ced38e7ee896997?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rotr3(float x, float n) {\\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.0);\\n}\\n\\nvec3 cubePos(float x) {\\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n float near = -1.0;\\n float far = 0.99;\\n float aspectRatio = resolution.y / resolution.x;\\n float cubeIdx = floor(vertexId / 36.0);\\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\\n float faceDiv3 = floor(faceIdx / 3.0);\\n float faceMod3 = mod(faceIdx, 3.0);\\n float quadIdx = mod(vertexId, 6.0);\\n float baseIdx = faceIdx * 6.0;\\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\\n pos -= 0.5;\\n pos *= 0.02;\\n \\n float ct = time + mod(cubeIdx, 20.0);\\n float ct1 = time + floor(cubeIdx / 20.0);\\n float s = sin(ct*0.37), c = cos(ct*0.37);\\n float s1 = sin(ct1), c1 = cos(ct1);\\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n gl_Position = vec4(pos, 1.0) * rot * rot2;\\n\\n gl_Position.x += (mod(cubeIdx, 20.0) - 10.0) * 0.05;\\n gl_Position.y += (floor(cubeIdx / 20.0) - 10.0) * 0.05;\\n \\n gl_Position.y /= aspectRatio;\\n float zDist = gl_Position.z - near;\\n gl_Position.w = zDist;\\n\\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rotr3(float x, float n) {\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.0);\n}\n\nvec3 cubePos(float x) {\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n float near = -1.0;\n float far = 0.99;\n float aspectRatio = resolution.y / resolution.x;\n float cubeIdx = floor(vertexId / 36.0);\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\n float faceDiv3 = floor(faceIdx / 3.0);\n float faceMod3 = mod(faceIdx, 3.0);\n float quadIdx = mod(vertexId, 6.0);\n float baseIdx = faceIdx * 6.0;\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\n pos -= 0.5;\n pos *= 0.02;\n \n float ct = time + mod(cubeIdx, 20.0);\n float ct1 = time + floor(cubeIdx / 20.0);\n float s = sin(ct*0.37), c = cos(ct*0.37);\n float s1 = sin(ct1), c1 = cos(ct1);\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n gl_Position = vec4(pos, 1.0) * rot * rot2;\n\n gl_Position.x += (mod(cubeIdx, 20.0) - 10.0) * 0.05;\n gl_Position.y += (floor(cubeIdx / 20.0) - 10.0) * 0.05;\n \n gl_Position.y /= aspectRatio;\n float zDist = gl_Position.z - near;\n gl_Position.w = zDist;\n\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-aurrh94slkrr23uks-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Xznj9hZq3fxvAtz4c/art.json b/art/Xznj9hZq3fxvAtz4c/art.json index c23a0542..5c870e0c 100644 --- a/art/Xznj9hZq3fxvAtz4c/art.json +++ b/art/Xznj9hZq3fxvAtz4c/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, 0.)).a;\\n //float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n vec2 p = vec2(ux , vy);\\n //float z = fract(0.86);\\n float z = fract(0.9*snd*2.+cos(time/2.)/40.);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, 0.)).a;\n //float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n vec2 p = vec2(ux , vy);\n //float z = fract(0.86);\n float z = fract(0.9*snd*2.+cos(time/2.)/40.);\n int a = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-njsa8sq3ky3k4u7eb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Y3YjiM7wZKEsfDvmw/art.json b/art/Y3YjiM7wZKEsfDvmw/art.json index ca5c4595..8a89c195 100644 --- a/art/Y3YjiM7wZKEsfDvmw/art.json +++ b/art/Y3YjiM7wZKEsfDvmw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0,0.23921568627450981,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Colors\\n// Course : CS250\\n// Term & Year : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0, + 0.23921568627450981, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Colors\n// Course : CS250\n// Term & Year : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-92qdjchj8firh6z0b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Y3bsPmhHZNkBkDdhQ/art.json b/art/Y3bsPmhHZNkBkDdhQ/art.json index 4131de42..210c8e81 100644 --- a/art/Y3bsPmhHZNkBkDdhQ/art.json +++ b/art/Y3bsPmhHZNkBkDdhQ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":600,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DIST 2.0\\n\\nvoid main() {\\n float pointId = mod(vertexId, 100.0);\\n float faceId = floor(vertexId / 100.0);\\n\\n /*\\n Face ID:\\n Right - 0\\n Left - 1\\n Top - 2\\n Bottom - 3\\n Front - 4\\n Back - 5\\n */\\n\\n vec3 pos = vec3(0.0, mod(pointId, 10.0), 0.5);\\n pos.x = (pointId - pos.y) / 10.0;\\n pos.xy = pos.xy / 10.0 - 0.5;\\n\\n if (mod(faceId, 2.0) == 1.0) pos.z *= -1.0;\\n if (faceId == 0.0 || faceId == 1.0) pos = pos.zyx;\\n if (faceId == 2.0 || faceId == 3.0) pos = pos.xzy;\\n\\n // Set color before transforms so the colors don't slip\\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\\n\\n float c = cos(time), s = sin(time);\\n pos.xz *= mat2(c, s, -s, c);\\n pos.yz *= mat2(c, s, -s, c);\\n pos *= 1.5;\\n\\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\\n gl_Position.x *= resolution.y / resolution.x;\\n gl_PointSize = 5.0 / (EYE_DIST - pos.z);\\n}\"}", + "settings": { + "num": 600, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DIST 2.0\n\nvoid main() {\n float pointId = mod(vertexId, 100.0);\n float faceId = floor(vertexId / 100.0);\n\n /*\n Face ID:\n Right - 0\n Left - 1\n Top - 2\n Bottom - 3\n Front - 4\n Back - 5\n */\n\n vec3 pos = vec3(0.0, mod(pointId, 10.0), 0.5);\n pos.x = (pointId - pos.y) / 10.0;\n pos.xy = pos.xy / 10.0 - 0.5;\n\n if (mod(faceId, 2.0) == 1.0) pos.z *= -1.0;\n if (faceId == 0.0 || faceId == 1.0) pos = pos.zyx;\n if (faceId == 2.0 || faceId == 3.0) pos = pos.xzy;\n\n // Set color before transforms so the colors don't slip\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\n\n float c = cos(time), s = sin(time);\n pos.xz *= mat2(c, s, -s, c);\n pos.yz *= mat2(c, s, -s, c);\n pos *= 1.5;\n\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\n gl_Position.x *= resolution.y / resolution.x;\n gl_PointSize = 5.0 / (EYE_DIST - pos.z);\n}" + }, "screenshotURL": "data/images/images-79ikv67atb29a7z4m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Y8qbp8kqR8R9rigM7/art.json b/art/Y8qbp8kqR8R9rigM7/art.json index e6308028..efcbf83b 100644 --- a/art/Y8qbp8kqR8R9rigM7/art.json +++ b/art/Y8qbp8kqR8R9rigM7/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 40.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 10.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 40.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 10.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-a646mkb6wr9fpzaun-thumbnail.jpg", "views": { "$numberInt": "32" diff --git a/art/YFECqw3LmKnaojReb/art.json b/art/YFECqw3LmKnaojReb/art.json index 214df8c7..78ed83e6 100644 --- a/art/YFECqw3LmKnaojReb/art.json +++ b/art/YFECqw3LmKnaojReb/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/merzbow/pulse-vegan-part-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n\\n#define patternFactor0 0.0012//KParameter 0.0012>>0.12\\n#define timeFactor0 0.1//KParameter 0.1>>1.\\n#define timeFactorAmp 10.//KParameter 1.>>40.\\n#define timeFactorAmp2 10.//KParameter 1.>>40.\\n#define patternFactor1Rot 10.//KParameter 1.>>100.\\n#define sizeFactor 1.//KParameter 1.>>4.\\n#define shapeFactor1 0.4//KParameter 0.4>>1.0\\n#define shapeFactor0 9.0//KParameter 9.0>>30.\\n\\nvec2 pattern(vec2 p) {\\n\\t\\n\\tfloat a = atan(p.x,p.y);\\n\\tfloat r = shapeFactor0 * pow(1.0/length(p), shapeFactor1);\\n\\tfloat t = time + length(p) * patternFactor0;\\n\\treturn vec2(sin(a*3.0+cos(t*0.25)*patternFactor1Rot), sin(r*2.+sin(time*timeFactor0)*timeFactorAmp));\\n}\\n\\nvoid main( void ) {\\n\\n //Step 2 >> replace gl_FragCoord\\n\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n //simfragCoord <=> gl_FragCoord in the vertex shader\\n \\n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (simfragCoord.x /vertexResolution.x);\\n float v = (simfragCoord.y /vertexResolution.y);\\n \\n //calculate coordinates in -1.>>1.0 space\\n float fact = 2.*sizeFactor;\\n float ux = fact*(u - 0.5);\\n float vy = fact*(v - 0.5);\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //Calculate the best possible pointSize to fill the screen\\n //based on the current vertexCount (finalVertexCount)\\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by vfragCoord \\n //replace gl_FragColor by v_color\\n \\n\\n\\tvec2 p = surfacePosition * 99.0;\\n\\tvec3 col = vec3(0.0);\\n\\t\\n\\tfor (int i=0; i<3; i++)\\n\\t\\tp.xy = pattern(p);\\n\\t\\n\\tcol.xy = sin(p.xy);\\n\\tcol.z = max(step(abs(p.x*p.x),0.5), -1.0 / abs(p.y));\\n\\t\\n\\tv_color = vec4( col, 1.0 );\\n\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/merzbow/pulse-vegan-part-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n\n#define patternFactor0 0.0012//KParameter 0.0012>>0.12\n#define timeFactor0 0.1//KParameter 0.1>>1.\n#define timeFactorAmp 10.//KParameter 1.>>40.\n#define timeFactorAmp2 10.//KParameter 1.>>40.\n#define patternFactor1Rot 10.//KParameter 1.>>100.\n#define sizeFactor 1.//KParameter 1.>>4.\n#define shapeFactor1 0.4//KParameter 0.4>>1.0\n#define shapeFactor0 9.0//KParameter 9.0>>30.\n\nvec2 pattern(vec2 p) {\n\t\n\tfloat a = atan(p.x,p.y);\n\tfloat r = shapeFactor0 * pow(1.0/length(p), shapeFactor1);\n\tfloat t = time + length(p) * patternFactor0;\n\treturn vec2(sin(a*3.0+cos(t*0.25)*patternFactor1Rot), sin(r*2.+sin(time*timeFactor0)*timeFactorAmp));\n}\n\nvoid main( void ) {\n\n //Step 2 >> replace gl_FragCoord\n\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n //simfragCoord <=> gl_FragCoord in the vertex shader\n \n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (simfragCoord.x /vertexResolution.x);\n float v = (simfragCoord.y /vertexResolution.y);\n \n //calculate coordinates in -1.>>1.0 space\n float fact = 2.*sizeFactor;\n float ux = fact*(u - 0.5);\n float vy = fact*(v - 0.5);\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n //Calculate the best possible pointSize to fill the screen\n //based on the current vertexCount (finalVertexCount)\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by vfragCoord \n //replace gl_FragColor by v_color\n \n\n\tvec2 p = surfacePosition * 99.0;\n\tvec3 col = vec3(0.0);\n\t\n\tfor (int i=0; i<3; i++)\n\t\tp.xy = pattern(p);\n\t\n\tcol.xy = sin(p.xy);\n\tcol.z = max(step(abs(p.x*p.x),0.5), -1.0 / abs(p.y));\n\t\n\tv_color = vec4( col, 1.0 );\n\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-xnzqfyvyk3nlvdgke-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YNECMxcrupx4erT4u/art.json b/art/YNECMxcrupx4erT4u/art.json index a7734c17..003dcf22 100644 --- a/art/YNECMxcrupx4erT4u/art.json +++ b/art/YNECMxcrupx4erT4u/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":300,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat2 Rotate2D(float x) {\\n float a=sin(x), b=cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main () {\\n vec3 pos = vec3((vertexId/vertexCount)*2.0, 0.0, 0.0);\\n pos.xy *= Rotate2D(time+vertexId*2.0);\\n vec3 clr = vec3(pos.x, pos.y, -pos.x)+0.3;\\n pos.y*=0.3;\\n pos.yz *= Rotate2D(time)*2.0;\\n \\n gl_PointSize = 3.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(clr, 1.0);\\n}\"}", + "settings": { + "num": 300, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat2 Rotate2D(float x) {\n float a=sin(x), b=cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main () {\n vec3 pos = vec3((vertexId/vertexCount)*2.0, 0.0, 0.0);\n pos.xy *= Rotate2D(time+vertexId*2.0);\n vec3 clr = vec3(pos.x, pos.y, -pos.x)+0.3;\n pos.y*=0.3;\n pos.yz *= Rotate2D(time)*2.0;\n \n gl_PointSize = 3.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(clr, 1.0);\n}" + }, "screenshotURL": "data/images/images-httx5njufis10g6h6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YNrYu5vLMifYXQAyj/art.json b/art/YNrYu5vLMifYXQAyj/art.json index 574c925a..ef69306e 100644 --- a/art/YNrYu5vLMifYXQAyj/art.json +++ b/art/YNrYu5vLMifYXQAyj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.9333333333333333,0.7333333333333333,1],\"shader\":\"\\nvoid main() {\\n \\n float x = vertexId/15000.;\\n float y = vertexId/20000. + atan(time/23.) + tan(vertexId/200.+time/40.)+0.5;\\n \\n \\n \\n gl_Position = vec4(x*2.2-1.3, y*1.-1., y, 1) * (sin(time/3.) +2.);\\n gl_PointSize = vertexId/21. + 503. * (sin(time/5.)+1.);\\n\\n v_color = vec4(x,y/2.+0.5,1.,1.);\\n} \"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.9333333333333333, + 0.7333333333333333, + 1 + ], + "shader": "\nvoid main() {\n \n float x = vertexId/15000.;\n float y = vertexId/20000. + atan(time/23.) + tan(vertexId/200.+time/40.)+0.5;\n \n \n \n gl_Position = vec4(x*2.2-1.3, y*1.-1., y, 1) * (sin(time/3.) +2.);\n gl_PointSize = vertexId/21. + 503. * (sin(time/5.)+1.);\n\n v_color = vec4(x,y/2.+0.5,1.,1.);\n} " + }, "screenshotURL": "data/images/images-w18wzkv0l0uqbcxj9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YPJmHpa7pwzhxgBkq/art.json b/art/YPJmHpa7pwzhxgBkq/art.json index 8e2cba5f..53bd3059 100644 --- a/art/YPJmHpa7pwzhxgBkq/art.json +++ b/art/YPJmHpa7pwzhxgBkq/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( true )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( true )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-wwarm5phdngsauee4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YQhEmHqKTgrDSD3AM/art.json b/art/YQhEmHqKTgrDSD3AM/art.json index 0a1ebd68..64ffcb76 100644 --- a/art/YQhEmHqKTgrDSD3AM/art.json +++ b/art/YQhEmHqKTgrDSD3AM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/groove-delight-the-voices-feature019\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, gs), 0.)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * 0.05)).a; \\n \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(0, 0, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * 10. * sign(h));\\n mat *= scale(vec3(0.08, 0.19, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/groove-delight-the-voices-feature019", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, gs), 0.)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * 0.05)).a; \n \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(0, 0, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * 10. * sign(h));\n mat *= scale(vec3(0.08, 0.19, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-z2boocj2rzbvd7qfe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YQrEtnLC8h7QHDNsd/art.json b/art/YQrEtnLC8h7QHDNsd/art.json index 244c8b14..bb339ab8 100644 --- a/art/YQrEtnLC8h7QHDNsd/art.json +++ b/art/YQrEtnLC8h7QHDNsd/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wbgldn/track-01\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\\n vec4 K = vec4(1.0, 2.5 / 1.0, 1.0 / 3.0, (parameter5 - 3.0 * parameter1));\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians -parameter2);\\n \\t\\n return mat4( \\n 1, 0, 0, parameter2,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, parameter6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians- parameter3);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n parameter6, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, (2. - parameter4));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1. / parameter3,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1 + parameter3 / 2.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wbgldn/track-01", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\n vec4 K = vec4(1.0, 2.5 / 1.0, 1.0 / 3.0, (parameter5 - 3.0 * parameter1));\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians -parameter2);\n \t\n return mat4( \n 1, 0, 0, parameter2,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, parameter6, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians- parameter3);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n parameter6, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, (2. - parameter4));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1. / parameter3,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1 + parameter3 / 2.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-d4idjsbg5t17i6a47-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YRrZ7fHmFhtoKpyrq/art.json b/art/YRrZ7fHmFhtoKpyrq/art.json index 3220e199..2570dfb5 100644 --- a/art/YRrZ7fHmFhtoKpyrq/art.json +++ b/art/YRrZ7fHmFhtoKpyrq/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/les-yeux-orange/premiere-idr-clint\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float maxPoints = vertexCount;\\n float numPoints = maxPoints; //mix(2000., maxPoints, sin(time * .1) * .5 + .5);\\n float pointId = vertexId; \\n float mv = numPoints / maxPoints;\\n \\n if (pointId > numPoints) {\\n gl_Position = vec4(0, 0, 100, 1);\\n return;\\n }\\n\\n vec3 loc = fibonacciSphere(numPoints, pointId);\\n\\n float cv = pointId / numPoints;\\n float su = fract(cv + -time);\\n //su = hash(cubeId / maxCubes);\\n float s = texture2D(sound, vec2(mix(.1, .5, su), 0.)).a;\\n \\n float tm = time * .0;\\n float r = 30.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - cv, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(time * 0.37);\\n mat *= rotY(time * 0.21);\\n \\n \\n gl_Position = mat * vec4(loc * 45. * s, 1);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = .4 + floor(pow(s, 5.) * 20.) * .33 + time * 0.1;\\n float sat = .1 + pow(s + .5, 5.);\\n float val = 1.;\\n v_color.rgb = hsv2rgb(vec3(hue, sat, val));\\n v_color.a = 1. + s;\\n v_color.rgb *= v_color.a; \\n if (s < .2) {\\n gl_Position.z = 10000.;\\n }\\n \\n gl_PointSize = 1.; //mix(6., 0.1, 1. - pow(1. - mv, 1.5));\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/les-yeux-orange/premiere-idr-clint", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float maxPoints = vertexCount;\n float numPoints = maxPoints; //mix(2000., maxPoints, sin(time * .1) * .5 + .5);\n float pointId = vertexId; \n float mv = numPoints / maxPoints;\n \n if (pointId > numPoints) {\n gl_Position = vec4(0, 0, 100, 1);\n return;\n }\n\n vec3 loc = fibonacciSphere(numPoints, pointId);\n\n float cv = pointId / numPoints;\n float su = fract(cv + -time);\n //su = hash(cubeId / maxCubes);\n float s = texture2D(sound, vec2(mix(.1, .5, su), 0.)).a;\n \n float tm = time * .0;\n float r = 30.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - cv, 10.));\n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(time * 0.37);\n mat *= rotY(time * 0.21);\n \n \n gl_Position = mat * vec4(loc * 45. * s, 1);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = .4 + floor(pow(s, 5.) * 20.) * .33 + time * 0.1;\n float sat = .1 + pow(s + .5, 5.);\n float val = 1.;\n v_color.rgb = hsv2rgb(vec3(hue, sat, val));\n v_color.a = 1. + s;\n v_color.rgb *= v_color.a; \n if (s < .2) {\n gl_Position.z = 10000.;\n }\n \n gl_PointSize = 1.; //mix(6., 0.1, 1. - pow(1. - mv, 1.5));\n}\n\n" + }, "screenshotURL": "data/images/images-rtaa1k3eekpdz5dk7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YSrCe2ZHmwiB2d6Kz/art.json b/art/YSrCe2ZHmwiB2d6Kz/art.json index 81f4e045..7cdef3f0 100644 --- a/art/YSrCe2ZHmwiB2d6Kz/art.json +++ b/art/YSrCe2ZHmwiB2d6Kz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/guigoo-official/acido\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\n\\n\\nvoid main ()\\n{\\n //float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n \\n\\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n float snd = 10.*texture2D(sound, vec2(0., 0.2)).a;\\n //apply fragment logic\\n\\n\\t//vec2 position = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);\\n\\tvec2 position = vec2(x, y);\\n\\t\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n vec2 res = vec2(numAcrossDown, numAcrossDown);\\n vec2 fragCoord = vec2(u,v);\\n \\n vec3 d = normalize( vec3( (position.xy - res.xy * .5) / numAcrossDown, .15));\\n \\n\\tvec3 p, c, f, g=d, o, y1=vec3(1.0,1.5,0.0);\\n \\n \\n \\to.y = 4. + 4.8*cos((o.x=0.1)*(o.z=time * 20.0));\\n\\to.x -= sin(time) + 3.0;\\n\\n for( float i=.0; i<8.; i+=.05 ) {\\n f = fract(c = o += d*i*.1); \\n\\tp = floor( c )*.4;\\n if( cos(p.z) + sin(p.x) > ++p.y/snd ) {\\n\\t \\tg = (f.y-.04*cos((c.x+c.z)*10.)>.7?y1:f.x*y1.yxz) / i;\\n break;\\n }\\n }\\n //gl_FragColor = vec4(g,1.0);\\n\\t\\n \\n \\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g,1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/guigoo-official/acido", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\n\n\nvoid main ()\n{\n //float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n \n\n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n float snd = 10.*texture2D(sound, vec2(0., 0.2)).a;\n //apply fragment logic\n\n\t//vec2 position = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);\n\tvec2 position = vec2(x, y);\n\t\n gl_Position = vec4(ux, vy, 0, 1);\n \n vec2 res = vec2(numAcrossDown, numAcrossDown);\n vec2 fragCoord = vec2(u,v);\n \n vec3 d = normalize( vec3( (position.xy - res.xy * .5) / numAcrossDown, .15));\n \n\tvec3 p, c, f, g=d, o, y1=vec3(1.0,1.5,0.0);\n \n \n \to.y = 4. + 4.8*cos((o.x=0.1)*(o.z=time * 20.0));\n\to.x -= sin(time) + 3.0;\n\n for( float i=.0; i<8.; i+=.05 ) {\n f = fract(c = o += d*i*.1); \n\tp = floor( c )*.4;\n if( cos(p.z) + sin(p.x) > ++p.y/snd ) {\n\t \tg = (f.y-.04*cos((c.x+c.z)*10.)>.7?y1:f.x*y1.yxz) / i;\n break;\n }\n }\n //gl_FragColor = vec4(g,1.0);\n\t\n \n \n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g,1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-otmnz90egqd1vj0gv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YSzcySDB7rcbwJmTP/art.json b/art/YSzcySDB7rcbwJmTP/art.json index ee0999dd..4cf05a51 100644 --- a/art/YSzcySDB7rcbwJmTP/art.json +++ b/art/YSzcySDB7rcbwJmTP/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "mfx01", "username": "-anon-", - "settings": "{\"num\":2000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 7.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 2000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 7.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-00mmdgkif42g500zg-thumbnail.jpg", "views": { "$numberInt": "95" diff --git a/art/YTKN84yNr6RB2aDbB/art.json b/art/YTKN84yNr6RB2aDbB/art.json index 0afd5f2c..db20ceae 100644 --- a/art/YTKN84yNr6RB2aDbB/art.json +++ b/art/YTKN84yNr6RB2aDbB/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "muffin", "avatarUrl": "https://secure.gravatar.com/avatar/62e506fb8f0b1139bce884d6e6fc93e7?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vx = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vx) * 1.3;\\n \\n float soff = sin(time * 5.);\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vx = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vx) * 1.3;\n \n float soff = sin(time * 5.);\n \n gl_Position = vec4(xy, 0, 1);\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-qq17maop7exb5hr97-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YTqaQuCP9GEF532DP/art.json b/art/YTqaQuCP9GEF532DP/art.json index 2e226788..881185b9 100644 --- a/art/YTqaQuCP9GEF532DP/art.json +++ b/art/YTqaQuCP9GEF532DP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via SoShade\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1. / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 1, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 1.7, 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, sin(mouse.y*0.01),\\n zAxis, 0,\\n eye,1. +mouse.x);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][2], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a12,\\n b05 = a02 * a13 + a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a32,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 + a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 - b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - (eye *1.5));\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, -1,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nfloat df(vec2 p)\\n{\\n\\treturn length(p) -0.1;\\n}\\n\\nvec3 getQuad(float idx)\\n{\\n\\tfloat quadIndex = floor(idx / 6.);\\n\\t\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 pos = vec2(0);\\n\\tif (index == 0.) pos = vec2(0,0);\\n\\tif (index == 1.) pos = vec2(1,0);\\n\\tif (index == 2.) pos = vec2(1,1);\\n\\t\\n\\tif (index == 3.) pos = vec2(0,0);\\n\\tif (index == 4.) pos = vec2(1,1);\\n\\tif (index == 5.) pos = vec2(1,1);\\n\\t\\n\\treturn vec3(pos, quadIndex);\\n}\\n\\nvec2 getGridMesh(float idx, float countQuadX)\\n{\\n\\tvec3 pi = getQuad(idx);\\n\\t\\n\\tpi.x += mod(pi.z, countQuadX);\\n\\tpi.y += floor(pi.z / countQuadX);\\n\\t\\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\n\\tpi.x -= nx * 0.125;\\n\\tpi.y -= ny * 0.15;\\n\\t\\n\\treturn pi.xy;\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 1.;\\n\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat edgeSize = floor( sqrt(countMax) );\\n\\tvec2 pg = getGridMesh(vertexId, edgeSize);\\n\\t\\n\\tfloat t = time;\\n\\t\\n\\tfloat r = length(pg);\\n\\tvec3 p = vec3(pg.x, cos(t*10.+r) * 7., pg.y);\\n\\tp.xz += df(p.xz) * sign(p.xz);\\n\\tfloat a = r * 0.04 * sin(t * 0.93);\\n\\tp.xz *= mat2(cos(a),-sin(a),sin(a),cos(a));\\n\\t\\n\\tv_color = vec4(0.8, p.y, 0.5, 1);\\n\\t\\n\\tp.y += r*cos(r*0.1);\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 0.;\\n\\tfloat cd = 500.;\\n\\tvec3 eye = vec3(sin(ca), 0.98, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 1);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(33. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tgl_Position = camera * vec4(p, 2);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via SoShade\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1. / (zNear - zFar);\n\n return mat4(\n f / aspect, 1, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 1.7, 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, sin(mouse.y*0.01),\n zAxis, 0,\n eye,1. +mouse.x);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][2], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a12,\n b05 = a02 * a13 + a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a32,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 + a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 - b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - (eye *1.5));\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, -1,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nfloat df(vec2 p)\n{\n\treturn length(p) -0.1;\n}\n\nvec3 getQuad(float idx)\n{\n\tfloat quadIndex = floor(idx / 6.);\n\t\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 pos = vec2(0);\n\tif (index == 0.) pos = vec2(0,0);\n\tif (index == 1.) pos = vec2(1,0);\n\tif (index == 2.) pos = vec2(1,1);\n\t\n\tif (index == 3.) pos = vec2(0,0);\n\tif (index == 4.) pos = vec2(1,1);\n\tif (index == 5.) pos = vec2(1,1);\n\t\n\treturn vec3(pos, quadIndex);\n}\n\nvec2 getGridMesh(float idx, float countQuadX)\n{\n\tvec3 pi = getQuad(idx);\n\t\n\tpi.x += mod(pi.z, countQuadX);\n\tpi.y += floor(pi.z / countQuadX);\n\t\n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadX;\n\tfloat ny = floor(countQuads / nx);\n\t\n\tpi.x -= nx * 0.125;\n\tpi.y -= ny * 0.15;\n\t\n\treturn pi.xy;\n}\n\nvoid main()\n{\n\tgl_PointSize = 1.;\n\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat edgeSize = floor( sqrt(countMax) );\n\tvec2 pg = getGridMesh(vertexId, edgeSize);\n\t\n\tfloat t = time;\n\t\n\tfloat r = length(pg);\n\tvec3 p = vec3(pg.x, cos(t*10.+r) * 7., pg.y);\n\tp.xz += df(p.xz) * sign(p.xz);\n\tfloat a = r * 0.04 * sin(t * 0.93);\n\tp.xz *= mat2(cos(a),-sin(a),sin(a),cos(a));\n\t\n\tv_color = vec4(0.8, p.y, 0.5, 1);\n\t\n\tp.y += r*cos(r*0.1);\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 0.;\n\tfloat cd = 500.;\n\tvec3 eye = vec3(sin(ca), 0.98, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 1);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(33. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tgl_Position = camera * vec4(p, 2);\n}" + }, "screenshotURL": "data/images/images-8bygdn0kxsom7ldng-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YWMRwMd62Rwyig8hP/art.json b/art/YWMRwMd62Rwyig8hP/art.json index 52578e74..f5075bd2 100644 --- a/art/YWMRwMd62Rwyig8hP/art.json +++ b/art/YWMRwMd62Rwyig8hP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":18213,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KVerticesNumber=18000 \\n\\n\\n\\n//KDrawmode=GL_LINES_LOOP\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.5>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n parameter3, c, s, 0,\\n 0, -s, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 1,\\n s, 0, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians/parameter5);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0.2,\\n trans, 2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.5 - (parameter6 / 3.)), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 18213, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n//KVerticesNumber=18000 \n\n\n\n//KDrawmode=GL_LINES_LOOP\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.5>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n parameter3, c, s, 0,\n 0, -s, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 1,\n s, 0, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians/parameter5);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0.2,\n trans, 2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.5 - (parameter6 / 3.)), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-y7jvzhbw75rcxzit5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YXfLo5Yw55muQ7MZn/art.json b/art/YXfLo5Yw55muQ7MZn/art.json index d6d6a79d..aea1d0c8 100644 --- a/art/YXfLo5Yw55muQ7MZn/art.json +++ b/art/YXfLo5Yw55muQ7MZn/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":15238,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 4.);\\n float quadId = floor(vertexId / 4.);\\n float down = floor(sqrt(numQuads));\\n float across = floor(numQuads / down);\\n \\n float gx = mod(quadId, across);\\n float gy = floor(quadId / across);\\n \\n float vId = mod(vertexId, 4.);\\n \\n float x = gx + mod(vId, 2.) - step(3., vId);\\n float y = gy + step(3., vId);\\n\\n \\n \\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\\n \\n vec2 sp = xy * aspect * 1.1;\\n \\n const int count = 60;\\n for (int i = 0; i < count; ++i) {\\n float iv = 1. - float(i) / float(count - 1);\\n vec2 m = texture2D(touch, vec2(0, (float(i) + 0.5) / soundRes.y)).xy;\\n\\n vec2 dm = m - sp;\\n float dist = length(dm);\\n float effect = mix(1., 0., clamp(dist * 3., 0., 1.));\\n sp = sp - dm * pow(abs(effect), 2.5) * 0.5 * pow(iv, 5.);\\n }\\n \\n \\n \\n gl_Position = vec4(sp, 0, 1);\\n\\n v_color = vec4(vec3(0), 1);\\n}\"}", + "settings": { + "num": 15238, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n float numQuads = floor(vertexCount / 4.);\n float quadId = floor(vertexId / 4.);\n float down = floor(sqrt(numQuads));\n float across = floor(numQuads / down);\n \n float gx = mod(quadId, across);\n float gy = floor(quadId / across);\n \n float vId = mod(vertexId, 4.);\n \n float x = gx + mod(vId, 2.) - step(3., vId);\n float y = gy + step(3., vId);\n\n \n \n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\n \n vec2 sp = xy * aspect * 1.1;\n \n const int count = 60;\n for (int i = 0; i < count; ++i) {\n float iv = 1. - float(i) / float(count - 1);\n vec2 m = texture2D(touch, vec2(0, (float(i) + 0.5) / soundRes.y)).xy;\n\n vec2 dm = m - sp;\n float dist = length(dm);\n float effect = mix(1., 0., clamp(dist * 3., 0., 1.));\n sp = sp - dm * pow(abs(effect), 2.5) * 0.5 * pow(iv, 5.);\n }\n \n \n \n gl_Position = vec4(sp, 0, 1);\n\n v_color = vec4(vec3(0), 1);\n}" + }, "screenshotURL": "data/images/images-n5suzffth9sqqycz0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YXzZv8FqoYXqAXDdk/art.json b/art/YXzZv8FqoYXqAXDdk/art.json index 8c1b94a3..585e50e5 100644 --- a/art/YXzZv8FqoYXqAXDdk/art.json +++ b/art/YXzZv8FqoYXqAXDdk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Motion\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tv_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Motion\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tv_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-h2zw4virnnp5i5cv3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YazT6iXD9eAmLY6qD/art.json b/art/YazT6iXD9eAmLY6qD/art.json index 82add16a..8c26f449 100644 --- a/art/YazT6iXD9eAmLY6qD/art.json +++ b/art/YazT6iXD9eAmLY6qD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2539,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.17647058823529413,0.25098039215686274,0.3215686274509804,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 1.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.3\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\\n\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, .9);\\n float innerRadius = pow(count * 0.0005, .2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius*mouse.y;\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius*mouse.x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\\n\\n float b = 1.2 - pow(sin(count * 0.4+T) * 1.3 + 0.7, 1.8);\\n b = 0.0;mix(0.3, 0.7, b);\\n v_color = vec4(c, b, sin(time*3.1)+c*b, 0.6);\\n}\\n\"}", + "settings": { + "num": 2539, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.17647058823529413, + 0.25098039215686274, + 0.3215686274509804, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 1.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.3\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\n\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, .9);\n float innerRadius = pow(count * 0.0005, .2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius*mouse.y;\n float oS = sin(orbitAngle + count * 0.01) * innerRadius*mouse.x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\n\n float b = 1.2 - pow(sin(count * 0.4+T) * 1.3 + 0.7, 1.8);\n b = 0.0;mix(0.3, 0.7, b);\n v_color = vec4(c, b, sin(time*3.1)+c*b, 0.6);\n}\n" + }, "screenshotURL": "data/images/images-3hnnrwslmrr7bylwo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YbA3f6xnjbmXzkwHx/art.json b/art/YbA3f6xnjbmXzkwHx/art.json index b6c85b02..ee9a97c1 100644 --- a/art/YbA3f6xnjbmXzkwHx/art.json +++ b/art/YbA3f6xnjbmXzkwHx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":40000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=40000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>30.\\n#define parameter1 1.1//KParameter1 0.>>1.\\n#define parameter2 0.1//KParameter2 0.>>1.\\n#define parameter3 0.5//KParameter3 0.>>0.5\\n#define parameter4 0.//KParameter4 0.>>1.\\n#define parameter5 0.//KParameter5 0.>>1.\\n#define parameter6 0.//KParameter6 0.>>1.\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n //snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = 0.8;//mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount/2. / NUM_POINTS_PER_DIVISION);\\n float fVertexId = mod(vertexId,vertexCount/2.);\\n float circleId = floor(fVertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(fVertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = parameter3;\\n float start = 0.0;\\n float end = start + parameter2;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \\n mat *= rotZ((parameter0 + uvfl.y * PI) * time * parameter1);\\n \\n /*\\n if(vertexId>vertexCount/2.)\\n pos.x += 0.5;\\n */\\n if(vertexId>vertexCount/2.)\\n pos.x += (0.5-pos.x);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n \\n \\n v_color = vec4(parameter4,parameter5, parameter6, 1.);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 40000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=40000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>30.\n#define parameter1 1.1//KParameter1 0.>>1.\n#define parameter2 0.1//KParameter2 0.>>1.\n#define parameter3 0.5//KParameter3 0.>>0.5\n#define parameter4 0.//KParameter4 0.>>1.\n#define parameter5 0.//KParameter5 0.>>1.\n#define parameter6 0.//KParameter6 0.>>1.\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n //snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = 0.8;//mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount/2. / NUM_POINTS_PER_DIVISION);\n float fVertexId = mod(vertexId,vertexCount/2.);\n float circleId = floor(fVertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(fVertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = parameter3;\n float start = 0.0;\n float end = start + parameter2;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \n mat *= rotZ((parameter0 + uvfl.y * PI) * time * parameter1);\n \n /*\n if(vertexId>vertexCount/2.)\n pos.x += 0.5;\n */\n if(vertexId>vertexCount/2.)\n pos.x += (0.5-pos.x);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n \n \n v_color = vec4(parameter4,parameter5, parameter6, 1.);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-hq7sgqfity9trscld-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Yd2HBe825wEYTar8Y/art.json b/art/Yd2HBe825wEYTar8Y/art.json index 37e686fe..120e2fc3 100644 --- a/art/Yd2HBe825wEYTar8Y/art.json +++ b/art/Yd2HBe825wEYTar8Y/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.5019607843137255,1,1],\"shader\":\"//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tMotion\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tv_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.5019607843137255, + 1, + 1 + ], + "shader": "//\tseongryul.park\n//\tCS250 spring 2023\n//\tMotion\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n \tv_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-o87xwqhn4wubbibfg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YdpjoX8LmWLnbtXQv/art.json b/art/YdpjoX8LmWLnbtXQv/art.json index 271dde66..0aed9519 100644 --- a/art/YdpjoX8LmWLnbtXQv/art.json +++ b/art/YdpjoX8LmWLnbtXQv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":78520,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 1.0;\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\nfloat HSCALE = 1.0;\\n\\n// sea\\nconst int ITER_GEOMETRY = 3;\\nconst int ITER_FRAGMENT = 5;\\nconst float SEA_HEIGHT = 1.6;\\nconst float SEA_CHOPPY = 4.0;\\nconst float SEA_SPEED = 0.8;\\nconst float SEA_FREQ = 0.16;\\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\\n#define SEA_TIME (1.0 + time * SEA_SPEED)\\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54031230, -0.84147 );\\n\\n\\nfloat hash( vec2 p ) {\\n\\tfloat h = dot(p,vec2(127.1,311.7));\\t\\n return fract(sin(h)*43758.5453123);\\n}\\nfloat noise( in vec2 p ) {\\n vec2 i = floor( p );\\n vec2 f = fract( p );\\t\\n\\tvec2 u = f*f*(3.0-2.0*f);\\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \\n hash( i + vec2(1.0,0.0) ), u.x),\\n mix( hash( i + vec2(0.0,1.0) ), \\n hash( i + vec2(1.0,1.0) ), u.x), u.y);\\n}\\nfloat fbm( vec2 uv, float choppy )\\n{\\n uv += noise(uv); \\n vec2 wv = 1.0-abs(sin(uv));\\n vec2 swv = abs(cos(uv)); \\n wv = mix(wv,swv,wv);\\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\\n}\\n\\n\\n\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n\\n \\n float freq = SEA_FREQ;\\n float amp = SEA_HEIGHT;\\n float choppy = SEA_CHOPPY;\\n vec2 uv = vec2((-SIZE/2.0 + x) * SPACING,(-SIZE/2.0 + y) * SPACING);\\n \\n uv.x *= 0.75;\\n\\n float d, h = 0.0; \\n for(int i = 0; i < ITER_GEOMETRY; i++) { \\n d = fbm((uv+SEA_TIME)*freq,SEA_CHOPPY);\\n d += fbm((uv-+SEA_TIME)*freq,SEA_CHOPPY);\\n h += d * amp; \\n uv *= octave_m; freq *= 1.9; amp *= 0.22;\\n choppy = mix(choppy,1.0,0.2);\\n }\\n \\n return vec3((-SIZE/2.0 + x) * SPACING,HSCALE*h,(-SIZE/2.0 + y) * SPACING);\\n\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 78520, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 1.0;\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\nfloat HSCALE = 1.0;\n\n// sea\nconst int ITER_GEOMETRY = 3;\nconst int ITER_FRAGMENT = 5;\nconst float SEA_HEIGHT = 1.6;\nconst float SEA_CHOPPY = 4.0;\nconst float SEA_SPEED = 0.8;\nconst float SEA_FREQ = 0.16;\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\n#define SEA_TIME (1.0 + time * SEA_SPEED)\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54031230, -0.84147 );\n\n\nfloat hash( vec2 p ) {\n\tfloat h = dot(p,vec2(127.1,311.7));\t\n return fract(sin(h)*43758.5453123);\n}\nfloat noise( in vec2 p ) {\n vec2 i = floor( p );\n vec2 f = fract( p );\t\n\tvec2 u = f*f*(3.0-2.0*f);\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \n hash( i + vec2(1.0,0.0) ), u.x),\n mix( hash( i + vec2(0.0,1.0) ), \n hash( i + vec2(1.0,1.0) ), u.x), u.y);\n}\nfloat fbm( vec2 uv, float choppy )\n{\n uv += noise(uv); \n vec2 wv = 1.0-abs(sin(uv));\n vec2 swv = abs(cos(uv)); \n wv = mix(wv,swv,wv);\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\n}\n\n\n\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n\n \n float freq = SEA_FREQ;\n float amp = SEA_HEIGHT;\n float choppy = SEA_CHOPPY;\n vec2 uv = vec2((-SIZE/2.0 + x) * SPACING,(-SIZE/2.0 + y) * SPACING);\n \n uv.x *= 0.75;\n\n float d, h = 0.0; \n for(int i = 0; i < ITER_GEOMETRY; i++) { \n d = fbm((uv+SEA_TIME)*freq,SEA_CHOPPY);\n d += fbm((uv-+SEA_TIME)*freq,SEA_CHOPPY);\n h += d * amp; \n uv *= octave_m; freq *= 1.9; amp *= 0.22;\n choppy = mix(choppy,1.0,0.2);\n }\n \n return vec3((-SIZE/2.0 + x) * SPACING,HSCALE*h,(-SIZE/2.0 + y) * SPACING);\n\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-3jiyb7ob50ek0lqm3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YfY3PKQ4Mk78so4bP/art.json b/art/YfY3PKQ4Mk78so4bP/art.json index c8c595fc..93edd076 100644 --- a/art/YfY3PKQ4Mk78so4bP/art.json +++ b/art/YfY3PKQ4Mk78so4bP/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":72173,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n\\n gl_PointSize = 10.0; \\n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n gl_Position = vec4(-1.0+cos(time)*vertexId/100.0, vertexId/10000.0*cos(vertexId),0,1.0);\\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\\n v_color = vec4(1,cos(time),0.5,1);\\n}\"}", + "settings": { + "num": 72173, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n\n gl_PointSize = 10.0; \n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n gl_Position = vec4(-1.0+cos(time)*vertexId/100.0, vertexId/10000.0*cos(vertexId),0,1.0);\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\n v_color = vec4(1,cos(time),0.5,1);\n}" + }, "screenshotURL": "data/images/images-fcqnv7sqogkr9kxso-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Yg2urWWiE8sAJEo8W/art.json b/art/Yg2urWWiE8sAJEo8W/art.json index efe5cc4a..b0491e8b 100644 --- a/art/Yg2urWWiE8sAJEo8W/art.json +++ b/art/Yg2urWWiE8sAJEo8W/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":70101,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// complex numbers\\n// vec2(real part, complex part)\\nvec2 cProd(vec2 a, vec2 b) {\\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\\n}\\nfloat cModSqrd(vec2 a) {\\n return (a.x*a.x + a.y*a.y);\\n}\\nint mandelbrot(float x, float y) {\\n int n = 0;\\n vec2 z = vec2(0,0);\\n vec2 c = vec2(x,y);\\n \\n // no loops in glsl so jsut repeat\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n \\n return n;\\n}\\n\\nvoid main() {\\n float resX = resolution.x;\\n float resY = resolution.y;\\n float resArea = resX * resY;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertCountX = floor(resX/vertLen);\\n float vertCountY = floor(resY/vertLen);\\n \\n float x = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\\n float y = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\\n \\n \\n \\n gl_Position = vec4((x - 0.5)*2., (y - 0.5)*2., 0, 1);\\n gl_PointSize = vertLen*1.05;\\n v_color = vec4(hsv2rgb(vec3(float(mandelbrot((x-.5)*10.,(y-.5)*10.))/100., 1, 1)), 1);\\n}\"}", + "settings": { + "num": 70101, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// complex numbers\n// vec2(real part, complex part)\nvec2 cProd(vec2 a, vec2 b) {\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\n}\nfloat cModSqrd(vec2 a) {\n return (a.x*a.x + a.y*a.y);\n}\nint mandelbrot(float x, float y) {\n int n = 0;\n vec2 z = vec2(0,0);\n vec2 c = vec2(x,y);\n \n // no loops in glsl so jsut repeat\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n \n return n;\n}\n\nvoid main() {\n float resX = resolution.x;\n float resY = resolution.y;\n float resArea = resX * resY;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertCountX = floor(resX/vertLen);\n float vertCountY = floor(resY/vertLen);\n \n float x = (mod(vertexId, vertCountX)-0.5)/(vertCountX-1.);\n float y = (floor(vertexId / vertCountX)-0.5)/(vertCountY-1.);\n \n \n \n gl_Position = vec4((x - 0.5)*2., (y - 0.5)*2., 0, 1);\n gl_PointSize = vertLen*1.05;\n v_color = vec4(hsv2rgb(vec3(float(mandelbrot((x-.5)*10.,(y-.5)*10.))/100., 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-meg2sgs3a6m1n2yqe-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Yg9JRZQhtaWe3dpis/art.json b/art/Yg9JRZQhtaWe3dpis/art.json index 58485960..caf35655 100644 --- a/art/Yg9JRZQhtaWe3dpis/art.json +++ b/art/Yg9JRZQhtaWe3dpis/art.json @@ -28,7 +28,19 @@ "name": "sphere", "private": true, "username": "mark", - "settings": "{\"num\":13503,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fionabechmann/debussy-clair-de-lune\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9058823529411765,0.9058823529411765,0.9058823529411765,1],\"shader\":\"#define PI 3.14159\\n#define N_SAMPLES 10000.\\n\\nbool in_triangle(vec2 p, vec2 a, vec2 b, vec2 c) {\\n // Compute vectors \\n vec2 v0 = c - a;\\n vec2 v1 = b - a;\\n vec2 v2 = p - a;\\n\\n // Compute dot products\\n float dot00 = dot(v0, v0);\\n float dot01 = dot(v0, v1);\\n float dot02 = dot(v0, v2);\\n float dot11 = dot(v1, v1);\\n float dot12 = dot(v1, v2);\\n\\n // Compute barycentric coordinates\\n float invDenom = 1. / (dot00 * dot11 - dot01 * dot01);\\n float u = (dot11 * dot02 - dot01 * dot12) * invDenom;\\n float v = (dot00 * dot12 - dot01 * dot02) * invDenom;\\n\\n // Check if point is in triangle\\n return (u >= 0.) && (v >= 0.) && (u + v < 1.);\\n}\\nvec3 lla2xyz(vec2 latlon, float rad) {\\n float rxz = rad * cos(latlon.y);\\n \\n return vec3(\\n rxz * cos(latlon.x),\\n rad * sin(latlon.y),\\n rxz * sin(latlon.x)\\n );\\n}\\n\\nvec3 aspect(vec3 p) {\\n float ratio = resolution.y / resolution.x;\\n if (ratio < 1.)\\n return vec3(p.x * ratio, p.yz);\\n else if (ratio > 1.)\\n return vec3(p.x, p.y / ratio, p.z);\\n return p;\\n}\\nvec3 project(vec3 p) { return aspect(vec3(p.xy/p.z, -p.z)); }\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvec2 sphere_point(float i) {\\n // golden ratio\\n float phi = (sqrt(5.) + 1.) / 2. - 1.;\\n // golden angle\\n float ga = phi * 2. * PI;\\n \\n \\n vec2 p = vec2(0.);\\n if (i > N_SAMPLES + 50.)\\n return p;\\n \\n p.x = ga * i;\\n p.x /= 2. * PI;\\n p.x = fract(p.x);\\n p.x *= 2. * PI;\\n \\n p.y = asin(-1. + 2. * i / N_SAMPLES);\\n return p;\\n}\\n\\nvoid main () {\\n \\n gl_PointSize = 20.;\\n \\n vec2 latlon = sphere_point(vertexId);\\n //float f = sin(abs(latlon.y)) / 32.;\\n //float t = fract(abs(latlon.x - PI) / PI);\\n float t = sqrt(pow((latlon.x - PI) / PI, 2.) +\\n pow((latlon.y) / PI, 2.));\\n \\n\\n float max_f = 0.;\\n float snd = 0.;\\n for (int i = 0; i < 100; i++) {\\n float f = float(i)/soundRes.x;\\n \\tvec2 sp = vec2(.2 * f, t);\\n float new_snd = pow(texture2D(sound, sp).a, 5.);\\n if (new_snd > snd) {\\n snd = new_snd;\\n max_f = f;\\n }\\n }\\n v_color = vec4(\\n .5, .5 + sin(max_f * PI), cos(max_f * PI), 1.\\n );\\n v_color.rgb *= 1. - snd;\\n \\n float rad = .3 + .025 * snd;\\n latlon.x += mouse.x * PI;\\n \\n vec3 pos = lla2xyz(latlon, rad);\\n float near = .5 + .5 * (pos.z / .325);\\n v_color *= near;\\n gl_PointSize = 20.;\\n \\n pos -= vec3(0., 0., .6);\\n pos = project(pos);\\n \\n gl_Position = vec4(pos, 1.);\\n}\"}", + "settings": { + "num": 13503, + "mode": "POINTS", + "sound": "https://soundcloud.com/fionabechmann/debussy-clair-de-lune", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9058823529411765, + 0.9058823529411765, + 0.9058823529411765, + 1 + ], + "shader": "#define PI 3.14159\n#define N_SAMPLES 10000.\n\nbool in_triangle(vec2 p, vec2 a, vec2 b, vec2 c) {\n // Compute vectors \n vec2 v0 = c - a;\n vec2 v1 = b - a;\n vec2 v2 = p - a;\n\n // Compute dot products\n float dot00 = dot(v0, v0);\n float dot01 = dot(v0, v1);\n float dot02 = dot(v0, v2);\n float dot11 = dot(v1, v1);\n float dot12 = dot(v1, v2);\n\n // Compute barycentric coordinates\n float invDenom = 1. / (dot00 * dot11 - dot01 * dot01);\n float u = (dot11 * dot02 - dot01 * dot12) * invDenom;\n float v = (dot00 * dot12 - dot01 * dot02) * invDenom;\n\n // Check if point is in triangle\n return (u >= 0.) && (v >= 0.) && (u + v < 1.);\n}\nvec3 lla2xyz(vec2 latlon, float rad) {\n float rxz = rad * cos(latlon.y);\n \n return vec3(\n rxz * cos(latlon.x),\n rad * sin(latlon.y),\n rxz * sin(latlon.x)\n );\n}\n\nvec3 aspect(vec3 p) {\n float ratio = resolution.y / resolution.x;\n if (ratio < 1.)\n return vec3(p.x * ratio, p.yz);\n else if (ratio > 1.)\n return vec3(p.x, p.y / ratio, p.z);\n return p;\n}\nvec3 project(vec3 p) { return aspect(vec3(p.xy/p.z, -p.z)); }\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvec2 sphere_point(float i) {\n // golden ratio\n float phi = (sqrt(5.) + 1.) / 2. - 1.;\n // golden angle\n float ga = phi * 2. * PI;\n \n \n vec2 p = vec2(0.);\n if (i > N_SAMPLES + 50.)\n return p;\n \n p.x = ga * i;\n p.x /= 2. * PI;\n p.x = fract(p.x);\n p.x *= 2. * PI;\n \n p.y = asin(-1. + 2. * i / N_SAMPLES);\n return p;\n}\n\nvoid main () {\n \n gl_PointSize = 20.;\n \n vec2 latlon = sphere_point(vertexId);\n //float f = sin(abs(latlon.y)) / 32.;\n //float t = fract(abs(latlon.x - PI) / PI);\n float t = sqrt(pow((latlon.x - PI) / PI, 2.) +\n pow((latlon.y) / PI, 2.));\n \n\n float max_f = 0.;\n float snd = 0.;\n for (int i = 0; i < 100; i++) {\n float f = float(i)/soundRes.x;\n \tvec2 sp = vec2(.2 * f, t);\n float new_snd = pow(texture2D(sound, sp).a, 5.);\n if (new_snd > snd) {\n snd = new_snd;\n max_f = f;\n }\n }\n v_color = vec4(\n .5, .5 + sin(max_f * PI), cos(max_f * PI), 1.\n );\n v_color.rgb *= 1. - snd;\n \n float rad = .3 + .025 * snd;\n latlon.x += mouse.x * PI;\n \n vec3 pos = lla2xyz(latlon, rad);\n float near = .5 + .5 * (pos.z / .325);\n v_color *= near;\n gl_PointSize = 20.;\n \n pos -= vec3(0., 0., .6);\n pos = project(pos);\n \n gl_Position = vec4(pos, 1.);\n}" + }, "screenshotURL": "data/images/images-8btn52nmxvoubdi31-thumbnail.jpg", "views": { "$numberInt": "45" diff --git a/art/YgBq9NXqcsYsRmpBe/art.json b/art/YgBq9NXqcsYsRmpBe/art.json index 1e3c2383..b6125236 100644 --- a/art/YgBq9NXqcsYsRmpBe/art.json +++ b/art/YgBq9NXqcsYsRmpBe/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":168,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/********Ejecicio #1 *********/\\n/*void main(){\\n//Vector 4\\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 -1.0 + xOffset;\\n float uy = v * 2.0 -1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(ux, uy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\\n*/\\n\\n\\nvoid main(){\\n//Vector 4\\n float width = 20.0;\\n \\n float y = mod(vertexId + 1.0, 2.0);\\n float x = floor(vertexId / 2.0);\\n float ang = (x/20.0)*radians(360.0);\\n float r = y + 1.0;\\n float rx = r * cos(ang);\\n float ry = r *sin (ang);\\n \\n float u = rx / (width - 1.0);\\n float v = ry / (width - 1.0);\\n \\n float xOffset = cos(time + ry * 0.2) * 0.1;\\n float yOffset = sin(time + rx * 0.3) * 0.1;\\n \\n float mov = (floor(vertexId /42.0));\\n \\n float ux = u * 2.0 - mov + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2 (ux, uy) * 0.2;\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n}\\n\"}", + "settings": { + "num": 168, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/********Ejecicio #1 *********/\n/*void main(){\n//Vector 4\n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 -1.0 + xOffset;\n float uy = v * 2.0 -1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(ux, uy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}\n*/\n\n\nvoid main(){\n//Vector 4\n float width = 20.0;\n \n float y = mod(vertexId + 1.0, 2.0);\n float x = floor(vertexId / 2.0);\n float ang = (x/20.0)*radians(360.0);\n float r = y + 1.0;\n float rx = r * cos(ang);\n float ry = r *sin (ang);\n \n float u = rx / (width - 1.0);\n float v = ry / (width - 1.0);\n \n float xOffset = cos(time + ry * 0.2) * 0.1;\n float yOffset = sin(time + rx * 0.3) * 0.1;\n \n float mov = (floor(vertexId /42.0));\n \n float ux = u * 2.0 - mov + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2 (ux, uy) * 0.2;\n \n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n}\n" + }, "screenshotURL": "data/images/images-9sq3twzp9riypfrqk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Yhoy3z7NY6qCX3cnx/art.json b/art/Yhoy3z7NY6qCX3cnx/art.json index 480d25f9..476bdf79 100644 --- a/art/Yhoy3z7NY6qCX3cnx/art.json +++ b/art/Yhoy3z7NY6qCX3cnx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jluethi", "avatarUrl": "https://secure.gravatar.com/avatar/21e93db3614e6e91a28d7f82b4e44433?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/jaems_lu/hhh-31-03-18-14-11?in=jaems_lu/sets/ch3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n//test\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = sin(0.1*time)*abs(u - 0.5) * 2.;\\n float sv = sin(0.1*time) *abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.1, av )).a;\\n\\n float xoff = sin(time*.5*y * 0.2) * 0.1;\\n float yoff = 0.;sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd; //sin(time + v * 20.) * .05;\\n float sat = mix(0.1, 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/jaems_lu/hhh-31-03-18-14-11?in=jaems_lu/sets/ch3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n//test\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = sin(0.1*time)*abs(u - 0.5) * 2.;\n float sv = sin(0.1*time) *abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.1, av )).a;\n\n float xoff = sin(time*.5*y * 0.2) * 0.1;\n float yoff = 0.;sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd; //sin(time + v * 20.) * .05;\n float sat = mix(0.1, 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-t6p8ow95hy85zgak3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YiboJk6SvJNEAPSGR/art.json b/art/YiboJk6SvJNEAPSGR/art.json index c8d371a9..29206efd 100644 --- a/art/YiboJk6SvJNEAPSGR/art.json +++ b/art/YiboJk6SvJNEAPSGR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":26523,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/elektrik-dreams-music/analog-trip-for-love-chill-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = start + 1.;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n \\n float tm = 0.;\\n float r = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .0 + 0., sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n float rot = uvfl.y * -PI * 2. * abs(sin(time * 0.1)) + time;\\n mat *= rotY(rot);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * 0.1 + modStep(uvfl.w, 2.) * abs(sin(time * 0.13));\\n float sat = .2 + sin(time * 0.07) * 0.3;\\n float val = t5p5(abs(sin(rot)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 26523, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/elektrik-dreams-music/analog-trip-for-love-chill-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = start + 1.;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n \n float tm = 0.;\n float r = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * .0 + 0., sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n float rot = uvfl.y * -PI * 2. * abs(sin(time * 0.1)) + time;\n mat *= rotY(rot);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * 0.1 + modStep(uvfl.w, 2.) * abs(sin(time * 0.13));\n float sat = .2 + sin(time * 0.07) * 0.3;\n float val = t5p5(abs(sin(rot)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-xs5j37ax2dkigjmj2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ykt3ZLD52Wnphvaak/art.json b/art/Ykt3ZLD52Wnphvaak/art.json index aead09f5..b64ff1a2 100644 --- a/art/Ykt3ZLD52Wnphvaak/art.json +++ b/art/Ykt3ZLD52Wnphvaak/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":800,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.4549019607843137,0.5058823529411764,1],\"shader\":\"// Simple Line which responds to music\\n// This is intended to be super simple, to learn how to use VertexShaderArt\\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\\n\\nvoid main()\\n{\\n // vertex_percent is vertexId mapped to [0..1]\\n float nb_circles = 10.0;\\n float nbpointspercircle = vertexCount/nb_circles;\\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\\n \\n // sound texture has (amplitude, history) for (u,v). \\n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\\n // It is all in the alpha channel of the sound texture\\n \\n // Set y position to amplitude in [0..1] range.\\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\\n float circ_num= mod(vertexId, nb_circles)/nb_circles;\\n float y = -0.5+2.0*texture2D(sound,vec2(circ_num,0.0)).a*0.5; \\n \\n float r = 0.3;\\n float posx = (0.01*sin(r*time)+r)*(circ_num+1.0) * cos(vertex_percent*2.0*3.14+0.05*time)*0.8*((y*2.0)-1.0);\\n float posy = (0.01*sin(r*time)+r)*(circ_num+1.0) * sin(vertex_percent*2.0*3.14+0.0501*time)*0.8*((y*2.0)-1.0);\\n \\n \\n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\\n gl_Position = vec4(posx,posy,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\\n v_color = vec4(sin(time)*sin(time), y+1.0, circ_num, 1.0);\\n vec4 aa = background;\\n} \\n\\n\"}", + "settings": { + "num": 800, + "mode": "POINTS", + "sound": "https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.4549019607843137, + 0.5058823529411764, + 1 + ], + "shader": "// Simple Line which responds to music\n// This is intended to be super simple, to learn how to use VertexShaderArt\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\n\nvoid main()\n{\n // vertex_percent is vertexId mapped to [0..1]\n float nb_circles = 10.0;\n float nbpointspercircle = vertexCount/nb_circles;\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\n \n // sound texture has (amplitude, history) for (u,v). \n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\n // It is all in the alpha channel of the sound texture\n \n // Set y position to amplitude in [0..1] range.\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\n float circ_num= mod(vertexId, nb_circles)/nb_circles;\n float y = -0.5+2.0*texture2D(sound,vec2(circ_num,0.0)).a*0.5; \n \n float r = 0.3;\n float posx = (0.01*sin(r*time)+r)*(circ_num+1.0) * cos(vertex_percent*2.0*3.14+0.05*time)*0.8*((y*2.0)-1.0);\n float posy = (0.01*sin(r*time)+r)*(circ_num+1.0) * sin(vertex_percent*2.0*3.14+0.0501*time)*0.8*((y*2.0)-1.0);\n \n \n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\n gl_Position = vec4(posx,posy,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\n v_color = vec4(sin(time)*sin(time), y+1.0, circ_num, 1.0);\n vec4 aa = background;\n} \n\n" + }, "screenshotURL": "data/images/images-jvp0zeph8xd1ph5jr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Ym2ek7eMQNEDspKJd/art.json b/art/Ym2ek7eMQNEDspKJd/art.json index bda55b37..4ccfa25d 100644 --- a/art/Ym2ek7eMQNEDspKJd/art.json +++ b/art/Ym2ek7eMQNEDspKJd/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 9.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.90, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 1.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 3.0) + mod(vertexId, 4.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 9.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.90, 1.0));\n vec4 K = vec4(1.0, 2.0 / 1.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 3.0) + mod(vertexId, 4.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-du9z3rdxfn4axc2ua-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Yn396rtWBPwEkd3fo/art.json b/art/Yn396rtWBPwEkd3fo/art.json index 8dabe9e4..7a2d59be 100644 --- a/art/Yn396rtWBPwEkd3fo/art.json +++ b/art/Yn396rtWBPwEkd3fo/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":55940,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define T radians(360.)\\n#define N 100.\\n#define f float\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\nfloat h(float p) { vec2 p2 = fract(vec2(p*5.3983, p*5.4427)); p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x*p2.y*95.4337);\\n}\\nvec3 h3(f s) { return vec3(h(s),h(s*.731),h(s*1.319))*2.-1.; }\\nvec2 r(vec2 p,f a) { return vec2(p.x*cos(a)-p.y*sin(a), p.x*sin(a)+p.y*cos(a)); }\\nvec3 c(f s, f b) {\\n f a = h(s*0.911)*3.;\\n vec3 p = h3(s), A = vec3(1.-step(.5,a));\\n A.y = 1.-step(1.5,a)-A.x;\\n A.z = 1.-step(2.5,a)-A.x-A.y;\\n p = mix(step(0.,p)*2.-1.,p,mix(1.-A,A,b));\\n return p;\\n}\\nvoid main() {\\n f v = vertexId, t = time*3., w = resolution.x / resolution.y;\\n float cc = floor(vertexId / 8.);\\n vec3 p0 = c(v+t*0.132,sin(t*.2));\\n f n = length(p0);\\n float snd = texture2D(sound, vec2(n/2.,0)).a;\\n vec3 p = mix(p0/n*(1.0+snd),vec3(r(p0.xy,snd),p0.z),cos(t*.54));\\n p.xy = r(p.xy,t*5.*snd*0.00001);\\n p.xz = r(p.xz,t*.15);\\n gl_Position = vec4(p.x,p.y*w,p.z,p.z+5.);\\n v_color = vec4(hsv2rgb(vec3((time * 0.01 + p0.z * 1.001), snd*10., 1./n)), 1);\\n gl_PointSize=2.;\\n}\"}", + "settings": { + "num": 55940, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define T radians(360.)\n#define N 100.\n#define f float\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\nfloat h(float p) { vec2 p2 = fract(vec2(p*5.3983, p*5.4427)); p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x*p2.y*95.4337);\n}\nvec3 h3(f s) { return vec3(h(s),h(s*.731),h(s*1.319))*2.-1.; }\nvec2 r(vec2 p,f a) { return vec2(p.x*cos(a)-p.y*sin(a), p.x*sin(a)+p.y*cos(a)); }\nvec3 c(f s, f b) {\n f a = h(s*0.911)*3.;\n vec3 p = h3(s), A = vec3(1.-step(.5,a));\n A.y = 1.-step(1.5,a)-A.x;\n A.z = 1.-step(2.5,a)-A.x-A.y;\n p = mix(step(0.,p)*2.-1.,p,mix(1.-A,A,b));\n return p;\n}\nvoid main() {\n f v = vertexId, t = time*3., w = resolution.x / resolution.y;\n float cc = floor(vertexId / 8.);\n vec3 p0 = c(v+t*0.132,sin(t*.2));\n f n = length(p0);\n float snd = texture2D(sound, vec2(n/2.,0)).a;\n vec3 p = mix(p0/n*(1.0+snd),vec3(r(p0.xy,snd),p0.z),cos(t*.54));\n p.xy = r(p.xy,t*5.*snd*0.00001);\n p.xz = r(p.xz,t*.15);\n gl_Position = vec4(p.x,p.y*w,p.z,p.z+5.);\n v_color = vec4(hsv2rgb(vec3((time * 0.01 + p0.z * 1.001), snd*10., 1./n)), 1);\n gl_PointSize=2.;\n}" + }, "screenshotURL": "data/images/images-uas34w59hxp0hp90v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YoyxivmzQMzpahR8j/art.json b/art/YoyxivmzQMzpahR8j/art.json index 017e6469..ed0dd307 100644 --- a/art/YoyxivmzQMzpahR8j/art.json +++ b/art/YoyxivmzQMzpahR8j/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .1//KParameter .1>>2.\\n#define PointSizeValue 1.13//KParameter 1.>>4.\\n#define deltaFactor0 0.//KParameter 0.>>1.\\n#define deltaFactor1 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n\\n//KDrawmode=GL_POINTS\\n\\n\\nvec3 osc3(float t, float i)\\n{\\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 osc3Comb(float t, float i) {\\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\\n}\\n\\nvec3 incr(float _t, float _i, vec3 _add, float _l)\\n{\\n vec3 pos = osc3Comb(_t,_i)+_add;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\\n \\n\\n float t = time*timeFactor;\\n float i = localVertexId;\\n\\n vec3 pos = osc3Comb(t,i);\\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\\n \\n \\n for (float f = 0.; f < 10.; f++) \\n {\\n\\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\\n }\\n \\n posDelta += incr(t,i,posDelta,0.2);\\n \\n pos -= osc3(t,-1.)*posComp0;\\n \\n pos += posDelta;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n \\n if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\\n\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .1//KParameter .1>>2.\n#define PointSizeValue 1.13//KParameter 1.>>4.\n#define deltaFactor0 0.//KParameter 0.>>1.\n#define deltaFactor1 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n\n//KDrawmode=GL_POINTS\n\n\nvec3 osc3(float t, float i)\n{\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 osc3Comb(float t, float i) {\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\n}\n\nvec3 incr(float _t, float _i, vec3 _add, float _l)\n{\n vec3 pos = osc3Comb(_t,_i)+_add;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\n \n\n float t = time*timeFactor;\n float i = localVertexId;\n\n vec3 pos = osc3Comb(t,i);\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\n \n \n for (float f = 0.; f < 10.; f++) \n {\n\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\n }\n \n posDelta += incr(t,i,posDelta,0.2);\n \n pos -= osc3(t,-1.)*posComp0;\n \n pos += posDelta;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n \n if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\n\n}\n" + }, "screenshotURL": "data/images/images-n6a19w5liwxn91pib-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YqNb2nTxxZRYWkJzz/art.json b/art/YqNb2nTxxZRYWkJzz/art.json index 5db11c9e..a3145c2f 100644 --- a/art/YqNb2nTxxZRYWkJzz/art.json +++ b/art/YqNb2nTxxZRYWkJzz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":91816,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wbgldn/track-01\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.xy, clamp(c.yz, 0.50, 5.- parameter7));\\n vec4 K = vec4(5.0, 0.5 / 4.0, parameter3 / 3.0, (parameter5 - 2.0 * parameter1));\\n vec3 p = abs(fract(c.xxx + K.xyz) * 3.0 / K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.9, (c.x * 3.)), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians -parameter2);\\n \\t\\n return mat4( \\n 1, -2, 0, parameter2,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n c-2.0 *s , -1, 0, -1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians + parameter4);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, s,\\n s, parameter6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians- parameter3);\\n float c = cos(angleInRadians /2.0 - parameter7);\\n \\t\\n return mat4( \\n c,-s, parameter2, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n parameter6, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, (2. - parameter4));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 2. - parameter3,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p + 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy * vec2(1.5351, 4.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1 + parameter3 / 2.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 91816, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wbgldn/track-01", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.xy, clamp(c.yz, 0.50, 5.- parameter7));\n vec4 K = vec4(5.0, 0.5 / 4.0, parameter3 / 3.0, (parameter5 - 2.0 * parameter1));\n vec3 p = abs(fract(c.xxx + K.xyz) * 3.0 / K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.9, (c.x * 3.)), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians -parameter2);\n \t\n return mat4( \n 1, -2, 0, parameter2,\n 0, c, s, 0,\n 0, -s, c, 0,\n c-2.0 *s , -1, 0, -1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians + parameter4);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, s,\n s, parameter6, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians- parameter3);\n float c = cos(angleInRadians /2.0 - parameter7);\n \t\n return mat4( \n c,-s, parameter2, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n parameter6, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, (2. - parameter4));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 2. - parameter3,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p + 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy * vec2(1.5351, 4.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1 + parameter3 / 2.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-k39cwwn8q1i4wu4p1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Yudd65BQfx92kHBcH/art.json b/art/Yudd65BQfx92kHBcH/art.json index 1e57d6ff..eef486b5 100644 --- a/art/Yudd65BQfx92kHBcH/art.json +++ b/art/Yudd65BQfx92kHBcH/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":99996,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/truecast-on-proton-music-guestmix-apsara\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 🌳🌲🎄🎋🌴\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\n// meh: would prefer a forumla\\nvoid branchInfo(float branchId, out float used, out float branch) {\\n if (branchId < 0.5) { used = 1.; branch = 0.; return; }\\n if (branchId < 1.5) { used = 2.; branch = 0.; return; }\\n if (branchId < 2.5) { used = 3.; branch = 0.; return; }\\n if (branchId < 3.5) { used = 4.; branch = 0.; return; }\\n if (branchId < 4.5) { used = 4.; branch = 8.; return; }\\n if (branchId < 5.5) { used = 3.; branch = 4.; return; }\\n if (branchId < 6.5) { used = 4.; branch = 4.; return; }\\n if (branchId < 7.5) { used = 4.; branch = 12.; return; }\\n if (branchId < 8.5) { used = 2.; branch = 2.; return; }\\n if (branchId < 9.5) { used = 3.; branch = 2.; return; }\\n if (branchId < 10.5) { used = 4.; branch = 2.; return; }\\n if (branchId < 11.5) { used = 4.; branch = 10.; return; }\\n if (branchId < 12.5) { used = 3.; branch = 6.; return; }\\n if (branchId < 13.5) { used = 4.; branch = 6.; return; }\\n used = 4.; branch = 14.; return;\\n}\\n\\nvoid main() {\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(vertexId, pos, normal);\\n float numCubes = floor(vertexCount / POINTS_PER_CUBE);\\n float cubeId = floor(vertexId / POINTS_PER_CUBE);\\n float cubeV = cubeId / numCubes;\\n \\n \\n float cubesPerTree = 15.0;\\n float cubesPerTreePair = cubesPerTree * 2.0;\\n float treeId = floor(cubeId / cubesPerTreePair);\\n float numTrees = floor(numCubes / cubesPerTreePair);\\n float treeV = treeId / numTrees;\\n \\n float branchId = floor(mod(cubeId + 0.1, cubesPerTree));\\n float branchV = branchId / cubesPerTree;\\n \\n /*\\n a 0 1 0-7\\n a a 1 3 0-3-2-1\\n a a a 2 7 0-1\\n a a a a 3 15 0\\n\\n a a a b 4 15 1\\n a a b 5 7 2-3\\n a a b a 6 15 2\\n a a b b 7 15 3\\n\\n a b 8 3 4-5-6-7\\n a b a 9 7 4-5\\n a b a a 10 15 4\\n a b a b 11 15 5\\n a b b 12 7 6-7\\n a b b a 13 15 6\\n a b b b 14 15 7\\n\\n */\\n \\n float used;\\n float branch;\\n branchInfo(branchId, used, branch);\\n\\n float s = texture2D(sound, vec2(mix(0.01, 0.25, hash(cubeV)), 0)).a;\\n \\n // position each cube that makes the tree\\n mat4 tree = ident();\\n const int depth = 4;\\n for (int d = 0; d < depth; ++d) {\\n float df = float(d);\\n if (df <= used - 1.0) {\\n float b = mod(branch / pow(2.0, df), 2.0) * 2.0 - 1.0;\\n float cd = (df / float(depth)) + b * 0.15 + treeV;\\n float root = step(0.5, df);\\n tree *= trans(vec3(0, 1, 0));\\n tree *= rotX((hash(cd * 0.741) * 0.5 + 0.2) * b * 0.8 * mix(0.3, 1., root) + root * sin(time + treeV * PI * 1.1) * 0.11);\\n tree *= rotY((hash(cd * 0.357) * 0.5 + 0.2) * b * 0.6 + root * sin(time + treeV * PI) * 0.1);\\n if (df > 2.5) {\\n float scx = mix(15., 8., hash(cd * 0.277));\\n float scy = mix(.8, 1.5, hash(cd * 0.727));\\n tree *= scale(vec3(scx + pow(s, 5.) * 20., scy + pow(s, 5.) * .5, 0.1));\\n }\\n }\\n }\\n \\n float leaf = step(3.5, used);\\n float shadow = mod(floor(cubeId / cubesPerTree), 2.0);\\n\\n // move camera in circle looking in direction of movement\\n float tm = time * 0.1;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n float r = 10.;\\n vec3 eye = vec3(\\n cos(tm) * r,\\n mix(0.5, 2.0, t5p5(sin(tm * 0.77))),\\n sin(tm) * r);\\n //vec3 target = vec3(0, 0, 0);\\n tm += 0.5;\\n vec3 target = vec3(\\n cos(tm) * r,\\n mix(1.0, 3.0, t5p5(sin(tm * 0.77))),\\n sin(tm) * r);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n // choose a random place\\n mat4 mat = trans((vec3(\\n hash(treeV * 0.219),\\n mix(0.5, 0.496 - treeV * 0.000, shadow),\\n hash(treeV * 0.691)) * 2.0 - 1.0) * 20.0);\\n \\n // rotate around the trunk randomly\\n mat *= rotY(hash(treeV * 0.597) * PI * 2.0);\\n \\n // scale the shadow\\n mat *= scale(mix(vec3(1), vec3(2, 0.02, 1), shadow));\\n \\n // scale the whole tree to some random size\\n mat *= uniformScale(mix(0.6, 1.5, hash(treeV * 0.371)));\\n \\n // offset because of the tree math above\\n mat *= trans(vec3(0, -1, 0));\\n \\n // posiiton each cube that makes the tree\\n mat *= tree;\\n \\n // adjust the size of the cube\\n mat *= scale(vec3(0.1, 0.8, 0.1));\\n \\n // offset the cube so it's origin is near the bottom of the cube\\n mat *= trans(vec3(0, 0.56, 0));\\n\\n // if it's the last 96 vertices make a ground plane\\n // need to make it a grid for fog (vs a single quad if no fog)\\n // because vertex colors\\n float ground = step(vertexCount - 96.5, vertexId);\\n if (ground > 0.5) {\\n float id = floor((vertexId - (vertexCount - 96.0)) / 6.0);\\n mat = uniformScale(10.);\\n mat *= trans(vec3(mod(id, 4.0) - 2.0, 0, floor(id / 4.0) - 2.0) * 2.0);\\n float ux = mod(vertexId, 2.);\\n \\tfloat vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n pos = (vec3(ux, 0.49, vy) * 2.0 - 1.0) * 1.0;\\n normal = vec3(0, 1, 0);\\n }\\n\\n // compute a view position (so 0,0,0 is the camera and all points are relative to that)\\n vec4 vpos = vmat * mat * vec4(pos, 1);\\n \\n // mutliply in the perspective\\n gl_Position = pmat * vpos;\\n \\n // orient the normal\\n vec3 n = normalize((vmat * mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n // color leaves differently\\n float hue = mix(0.1, 0.3 + pow(s + 0.2, 5.) * 0.5, leaf);\\n float sat = mix(0.0, 0., shadow); // set first argument to 1 to make trees in color\\n float val = mix(1.0, 0., shadow);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n \\n // if leaf and not shadow and sound is strong cuse diffeent color\\n color = mix(color, hsv2rgb(vec3(time * 0.05,1,1)), leaf * step(0.6, s) * (1.0 - shadow));\\n \\n // if ground use different color\\n color = mix(color, vec3(0.6), ground);\\n \\n // apply lighting (leaves have more contrast)\\n float light = dot(n, lightDir) * 0.5 + 0.5;\\n v_color = vec4(color * mix(light + leaf * 0.5, 1., shadow), 1);\\n\\n // apply fog\\n v_color.rgb = mix(v_color.rgb, vec3(background), clamp((length(vpos) - 10.) / 10., 0.0, 1.0));\\n \\n // try transparent shadows\\n //v_color.a = mix(1.0, 0.5, shadow);\\n \\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 99996, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/truecast-on-proton-music-guestmix-apsara", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 🌳🌲🎄🎋🌴\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\n// meh: would prefer a forumla\nvoid branchInfo(float branchId, out float used, out float branch) {\n if (branchId < 0.5) { used = 1.; branch = 0.; return; }\n if (branchId < 1.5) { used = 2.; branch = 0.; return; }\n if (branchId < 2.5) { used = 3.; branch = 0.; return; }\n if (branchId < 3.5) { used = 4.; branch = 0.; return; }\n if (branchId < 4.5) { used = 4.; branch = 8.; return; }\n if (branchId < 5.5) { used = 3.; branch = 4.; return; }\n if (branchId < 6.5) { used = 4.; branch = 4.; return; }\n if (branchId < 7.5) { used = 4.; branch = 12.; return; }\n if (branchId < 8.5) { used = 2.; branch = 2.; return; }\n if (branchId < 9.5) { used = 3.; branch = 2.; return; }\n if (branchId < 10.5) { used = 4.; branch = 2.; return; }\n if (branchId < 11.5) { used = 4.; branch = 10.; return; }\n if (branchId < 12.5) { used = 3.; branch = 6.; return; }\n if (branchId < 13.5) { used = 4.; branch = 6.; return; }\n used = 4.; branch = 14.; return;\n}\n\nvoid main() {\n vec3 pos;\n vec3 normal;\n getCubePoint(vertexId, pos, normal);\n float numCubes = floor(vertexCount / POINTS_PER_CUBE);\n float cubeId = floor(vertexId / POINTS_PER_CUBE);\n float cubeV = cubeId / numCubes;\n \n \n float cubesPerTree = 15.0;\n float cubesPerTreePair = cubesPerTree * 2.0;\n float treeId = floor(cubeId / cubesPerTreePair);\n float numTrees = floor(numCubes / cubesPerTreePair);\n float treeV = treeId / numTrees;\n \n float branchId = floor(mod(cubeId + 0.1, cubesPerTree));\n float branchV = branchId / cubesPerTree;\n \n /*\n a 0 1 0-7\n a a 1 3 0-3-2-1\n a a a 2 7 0-1\n a a a a 3 15 0\n\n a a a b 4 15 1\n a a b 5 7 2-3\n a a b a 6 15 2\n a a b b 7 15 3\n\n a b 8 3 4-5-6-7\n a b a 9 7 4-5\n a b a a 10 15 4\n a b a b 11 15 5\n a b b 12 7 6-7\n a b b a 13 15 6\n a b b b 14 15 7\n\n */\n \n float used;\n float branch;\n branchInfo(branchId, used, branch);\n\n float s = texture2D(sound, vec2(mix(0.01, 0.25, hash(cubeV)), 0)).a;\n \n // position each cube that makes the tree\n mat4 tree = ident();\n const int depth = 4;\n for (int d = 0; d < depth; ++d) {\n float df = float(d);\n if (df <= used - 1.0) {\n float b = mod(branch / pow(2.0, df), 2.0) * 2.0 - 1.0;\n float cd = (df / float(depth)) + b * 0.15 + treeV;\n float root = step(0.5, df);\n tree *= trans(vec3(0, 1, 0));\n tree *= rotX((hash(cd * 0.741) * 0.5 + 0.2) * b * 0.8 * mix(0.3, 1., root) + root * sin(time + treeV * PI * 1.1) * 0.11);\n tree *= rotY((hash(cd * 0.357) * 0.5 + 0.2) * b * 0.6 + root * sin(time + treeV * PI) * 0.1);\n if (df > 2.5) {\n float scx = mix(15., 8., hash(cd * 0.277));\n float scy = mix(.8, 1.5, hash(cd * 0.727));\n tree *= scale(vec3(scx + pow(s, 5.) * 20., scy + pow(s, 5.) * .5, 0.1));\n }\n }\n }\n \n float leaf = step(3.5, used);\n float shadow = mod(floor(cubeId / cubesPerTree), 2.0);\n\n // move camera in circle looking in direction of movement\n float tm = time * 0.1;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n float r = 10.;\n vec3 eye = vec3(\n cos(tm) * r,\n mix(0.5, 2.0, t5p5(sin(tm * 0.77))),\n sin(tm) * r);\n //vec3 target = vec3(0, 0, 0);\n tm += 0.5;\n vec3 target = vec3(\n cos(tm) * r,\n mix(1.0, 3.0, t5p5(sin(tm * 0.77))),\n sin(tm) * r);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up);\n \n // choose a random place\n mat4 mat = trans((vec3(\n hash(treeV * 0.219),\n mix(0.5, 0.496 - treeV * 0.000, shadow),\n hash(treeV * 0.691)) * 2.0 - 1.0) * 20.0);\n \n // rotate around the trunk randomly\n mat *= rotY(hash(treeV * 0.597) * PI * 2.0);\n \n // scale the shadow\n mat *= scale(mix(vec3(1), vec3(2, 0.02, 1), shadow));\n \n // scale the whole tree to some random size\n mat *= uniformScale(mix(0.6, 1.5, hash(treeV * 0.371)));\n \n // offset because of the tree math above\n mat *= trans(vec3(0, -1, 0));\n \n // posiiton each cube that makes the tree\n mat *= tree;\n \n // adjust the size of the cube\n mat *= scale(vec3(0.1, 0.8, 0.1));\n \n // offset the cube so it's origin is near the bottom of the cube\n mat *= trans(vec3(0, 0.56, 0));\n\n // if it's the last 96 vertices make a ground plane\n // need to make it a grid for fog (vs a single quad if no fog)\n // because vertex colors\n float ground = step(vertexCount - 96.5, vertexId);\n if (ground > 0.5) {\n float id = floor((vertexId - (vertexCount - 96.0)) / 6.0);\n mat = uniformScale(10.);\n mat *= trans(vec3(mod(id, 4.0) - 2.0, 0, floor(id / 4.0) - 2.0) * 2.0);\n float ux = mod(vertexId, 2.);\n \tfloat vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n pos = (vec3(ux, 0.49, vy) * 2.0 - 1.0) * 1.0;\n normal = vec3(0, 1, 0);\n }\n\n // compute a view position (so 0,0,0 is the camera and all points are relative to that)\n vec4 vpos = vmat * mat * vec4(pos, 1);\n \n // mutliply in the perspective\n gl_Position = pmat * vpos;\n \n // orient the normal\n vec3 n = normalize((vmat * mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n // color leaves differently\n float hue = mix(0.1, 0.3 + pow(s + 0.2, 5.) * 0.5, leaf);\n float sat = mix(0.0, 0., shadow); // set first argument to 1 to make trees in color\n float val = mix(1.0, 0., shadow);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n \n // if leaf and not shadow and sound is strong cuse diffeent color\n color = mix(color, hsv2rgb(vec3(time * 0.05,1,1)), leaf * step(0.6, s) * (1.0 - shadow));\n \n // if ground use different color\n color = mix(color, vec3(0.6), ground);\n \n // apply lighting (leaves have more contrast)\n float light = dot(n, lightDir) * 0.5 + 0.5;\n v_color = vec4(color * mix(light + leaf * 0.5, 1., shadow), 1);\n\n // apply fog\n v_color.rgb = mix(v_color.rgb, vec3(background), clamp((length(vpos) - 10.) / 10., 0.0, 1.0));\n \n // try transparent shadows\n //v_color.a = mix(1.0, 0.5, shadow);\n \n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-3af3gds7ce4xxejhi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YviLasT7Z62qurfRD/art.json b/art/YviLasT7Z62qurfRD/art.json index e6404797..7c6a7984 100644 --- a/art/YviLasT7Z62qurfRD/art.json +++ b/art/YviLasT7Z62qurfRD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":17762,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) + mouse.y * r;\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 17762, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) + mouse.y * r;\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-96nrt61aq6orp9hfg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/Yx83njpAunvLW4dyE/art.json b/art/Yx83njpAunvLW4dyE/art.json index 680c8b8a..57f1bbc6 100644 --- a/art/Yx83njpAunvLW4dyE/art.json +++ b/art/Yx83njpAunvLW4dyE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gregoireciles", "avatarUrl": "https://avatars.githubusercontent.com/GregoireCiles?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.011764705882352941,0,0.16862745098039217,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time + v * 20.0) * 0.01;\\n float sat = 1.0;\\n float val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.011764705882352941, + 0, + 0.16862745098039217, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time + v * 20.0) * 0.01;\n float sat = 1.0;\n float val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-g0e3bvvmadrgskrat-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/YyvPGrqSH2HjWTQi9/art.json b/art/YyvPGrqSH2HjWTQi9/art.json index 8468ef6f..19387980 100644 --- a/art/YyvPGrqSH2HjWTQi9/art.json +++ b/art/YyvPGrqSH2HjWTQi9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/arjunajungle/arjuna-chemical-jungle-parvati-rec\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 512.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float point = mod((floor(vertexId / 2.0)*(1.0+((time+1.0)*(mod(vertexId, 2.0))))),NUM_SEGMENTS)/NUM_SEGMENTS;\\n vec2 points = 0.5*vec2(cos(point*2.0*PI), sin(point*2.0*PI));\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4((points)*aspect, 0.0, 1.0);\\n float hue = mod((floor(vertexId / 2.0)*(1.0+floor(time*1.0*(mod(vertexId, 2.0))))),NUM_SEGMENTS)/NUM_SEGMENTS;\\n v_color = vec4(hsv2rgb(vec3(hue, 1.0, 1.0)), 1.0);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINES", + "sound": "https://soundcloud.com/arjunajungle/arjuna-chemical-jungle-parvati-rec", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 512.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float point = mod((floor(vertexId / 2.0)*(1.0+((time+1.0)*(mod(vertexId, 2.0))))),NUM_SEGMENTS)/NUM_SEGMENTS;\n vec2 points = 0.5*vec2(cos(point*2.0*PI), sin(point*2.0*PI));\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4((points)*aspect, 0.0, 1.0);\n float hue = mod((floor(vertexId / 2.0)*(1.0+floor(time*1.0*(mod(vertexId, 2.0))))),NUM_SEGMENTS)/NUM_SEGMENTS;\n v_color = vec4(hsv2rgb(vec3(hue, 1.0, 1.0)), 1.0);\n}" + }, "screenshotURL": "data/images/images-x2sdy14m6sxv8jsok-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/YzsRADN9oob3PHivP/art.json b/art/YzsRADN9oob3PHivP/art.json index db62ae0b..b58967c1 100644 --- a/art/YzsRADN9oob3PHivP/art.json +++ b/art/YzsRADN9oob3PHivP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "w.chae", "avatarUrl": "https://secure.gravatar.com/avatar/e33886e1d2ddd9c8199ae2b5bbb15df9?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-932548637/imase-night-dancer\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Wonhyeong Chae\\n// Exercise AudioReactive\\n// CS250 Spring 2022\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float centerX = (across - 1.) / 2.0;\\n float centerY = (down - 1.) / 2.0;\\n\\n float xOffset = x - centerX;\\n float yOffset = y - centerY;\\n\\n float normalizedX = xOffset / centerX;\\n float normalizedY = yOffset / centerY;\\n\\n float spread = 0.5;\\n float spreadX = normalizedX * spread;\\n float spreadY = normalizedY * spread;\\n\\n float u = (normalizedX + 1. + spreadX) / 2.;\\n float v = (normalizedY + 1. + spreadY) / 2.;\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n\\n float angle = time * 0.5;\\n float cosAngle = cos(angle);\\n float sinAngle = sin(angle);\\n float rotatedX = ux * cosAngle - vy * sinAngle;\\n float rotatedY = ux * sinAngle + vy * cosAngle;\\n\\n gl_Position = vec4(rotatedX, rotatedY, 0., 1.);\\n\\n float soff = sin(time + x * y * 0.02) * 5.;\\n\\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float colorModRed = u * .1 + snd * 0.2 + time * .1;\\n float colorModGreen = mix(0., 1., pump);\\n float colorModBlue = mix(.1, pow(snd + 0.2, 5.), pump);\\n\\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-932548637/imase-night-dancer", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Wonhyeong Chae\n// Exercise AudioReactive\n// CS250 Spring 2022\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float centerX = (across - 1.) / 2.0;\n float centerY = (down - 1.) / 2.0;\n\n float xOffset = x - centerX;\n float yOffset = y - centerY;\n\n float normalizedX = xOffset / centerX;\n float normalizedY = yOffset / centerY;\n\n float spread = 0.5;\n float spreadX = normalizedX * spread;\n float spreadY = normalizedY * spread;\n\n float u = (normalizedX + 1. + spreadX) / 2.;\n float v = (normalizedY + 1. + spreadY) / 2.;\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n\n float angle = time * 0.5;\n float cosAngle = cos(angle);\n float sinAngle = sin(angle);\n float rotatedX = ux * cosAngle - vy * sinAngle;\n float rotatedY = ux * sinAngle + vy * cosAngle;\n\n gl_Position = vec4(rotatedX, rotatedY, 0., 1.);\n\n float soff = sin(time + x * y * 0.02) * 5.;\n\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float colorModRed = u * .1 + snd * 0.2 + time * .1;\n float colorModGreen = mix(0., 1., pump);\n float colorModBlue = mix(.1, pow(snd + 0.2, 5.), pump);\n\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-o7lxu55kyhi30lxek-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Z25sf3c5qKzxzLrXF/art.json b/art/Z25sf3c5qKzxzLrXF/art.json index 457d6b46..7e70555f 100644 --- a/art/Z25sf3c5qKzxzLrXF/art.json +++ b/art/Z25sf3c5qKzxzLrXF/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "epoch", "avatarUrl": "https://secure.gravatar.com/avatar/3e53f54468906b25ff02d4860fa32a28?default=retro&size=200", - "settings": "{\"num\":2544,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/argofox/doctor-vox-death\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n# \\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = abs(atan(loc.x, loc.z) / PI);\\n float sv = abs(loc.y);\\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(cos(tm),-sin(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, pow(s, 2.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(0.9, 1.1, s) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n #if 0\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n#endif\\n}\\n\\n\"}", + "settings": { + "num": 2544, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/argofox/doctor-vox-death", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n# \n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = abs(atan(loc.x, loc.z) / PI);\n float sv = abs(loc.y);\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(cos(tm),-sin(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, pow(s, 2.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(0.9, 1.1, s) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n #if 0\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n#endif\n}\n\n" + }, "screenshotURL": "data/images/images-ib02rm3csmxf19u9w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Z26iq8hKBPX2svsmR/art.json b/art/Z26iq8hKBPX2svsmR/art.json index b0c9efb5..4e2f457b 100644 --- a/art/Z26iq8hKBPX2svsmR/art.json +++ b/art/Z26iq8hKBPX2svsmR/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":69172,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aqueous/spl-back-at-it-aqueous-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 3.//KParameter0 0.>>10.\\n#define parameter1 1.//KParameter1 0.>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>1.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.03 * c.y) , 8.0 /(c.x * 4.0, 8.0, .01 * parameter7), .9 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www * 20.);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 7.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 0, 2, 0, 0,\\n 0, c, s, 0,\\n parameter3, -s, c, 2,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1,-0.5, parameter5,\\n 0, 1, 0, 0,\\n s, 0, c, 1,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target + eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 +100.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 5.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 16.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 0.1);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.10, 0.1, pow(s + .12 *parameter2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 1)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 69172, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aqueous/spl-back-at-it-aqueous-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 3.//KParameter0 0.>>10.\n#define parameter1 1.//KParameter1 0.>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>1.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.03 * c.y) , 8.0 /(c.x * 4.0, 8.0, .01 * parameter7), .9 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www * 20.);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 7.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 0, 2, 0, 0,\n 0, c, s, 0,\n parameter3, -s, c, 2,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1,-0.5, parameter5,\n 0, 1, 0, 0,\n s, 0, c, 1,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target + eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 +100.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 5.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 16.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 0.1);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.10, 0.1, pow(s + .12 *parameter2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 1)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-vmj56oc7xaovbsqo1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Z3SAeG8oMryJKuF8z/art.json b/art/Z3SAeG8oMryJKuF8z/art.json index aa6b075a..647ff3de 100644 --- a/art/Z3SAeG8oMryJKuF8z/art.json +++ b/art/Z3SAeG8oMryJKuF8z/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":26331,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\nfloat vc = vertexCount * (1. + sin(time / 2.)) / 4.;\\n float density = floor(vc / 100.) + 1.;\\n \\n //float xoff = -0.5* (density / 20.);\\n //float yoff = -0.5 * (density / 20.);\\n \\n float xoff = -1. * (1. / density * density);\\n float yoff = -1. * (1. / density * density);\\n float ux = 0.1 * (20. / density);\\n float uy = 0.1 * (20. / density);\\n float x = mod(vertexId , density);\\n float y = mod(floor(vertexId / density), density);\\n float sndF = texture2D(sound, vec2(x * 5. / density, y / (density * 2.))).a;\\n //gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n gl_Position = vec4(y * uy + yoff, x * ux + xoff, 0, 1);\\n //gl_PointSize = mod(vertexId, density * density) / 5.;\\n gl_PointSize = (200. / density) * sndF * 5.;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 26331, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\nfloat vc = vertexCount * (1. + sin(time / 2.)) / 4.;\n float density = floor(vc / 100.) + 1.;\n \n //float xoff = -0.5* (density / 20.);\n //float yoff = -0.5 * (density / 20.);\n \n float xoff = -1. * (1. / density * density);\n float yoff = -1. * (1. / density * density);\n float ux = 0.1 * (20. / density);\n float uy = 0.1 * (20. / density);\n float x = mod(vertexId , density);\n float y = mod(floor(vertexId / density), density);\n float sndF = texture2D(sound, vec2(x * 5. / density, y / (density * 2.))).a;\n //gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n gl_Position = vec4(y * uy + yoff, x * ux + xoff, 0, 1);\n //gl_PointSize = mod(vertexId, density * density) / 5.;\n gl_PointSize = (200. / density) * sndF * 5.;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-2jo9v28lwe6q7nxsk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Z43GXJiragwBynoD3/art.json b/art/Z43GXJiragwBynoD3/art.json index 7b8afe63..8645ba24 100644 --- a/art/Z43GXJiragwBynoD3/art.json +++ b/art/Z43GXJiragwBynoD3/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":23011,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/**\\n * LED Music Visualizer\\n * A tribute to La La Land\\n * Try these sound:\\n * https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\\n * https://soundcloud.com/thave-lex/another-day-of-sun-la-la-land-thave-lex-remix\\n */\\nfloat hash(float n) { return fract(sin(n) * 777.1397);}\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\\n float gridWidth = resolution.x / xCount;\\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 100. / xCount; // if xCount > 100 then make pointSize smaller\\n \\n vec2 p = vec2(\\n mod(vertexId, xCount) * gridWidth,\\n floor(vertexId / xCount) * gridHeight\\n );\\n \\n gl_Position = vec4(\\n (p / resolution * 2. - vec2(1.)),\\n 0., 1.\\n ); \\n //v_color = vec4(vec3(1., 1., 1.0), 1.); // for debugging grid\\n \\n float tvGlitch = 400.;\\n float i = hash(vertexId) / tvGlitch;\\n vec4 snd = texture2D(sound, vec2(0., i)); \\n //vec4 snd = texture2D(sound, vec2(0., 0.));\\n vec3 s = vec3(snd.a * snd.a, pow(snd.b, 14.), pow(snd.z, 8.));\\n float glowFactor = s.x * floor(time / 50.) + 1.;\\n \\n // tweak variables below to see what happens\\n const float n = 3.0; // flower number\\n float petalNum = 3.0 + floor((time + s.x * 140.) / 50.); // petal number of each flower\\n float glowing = 0.03 * glowFactor;\\n float rotateSpeed = 0.07 + 0.015 * smoothstep(-0.1, 1.0, s.x);\\n float scale = 0.9 * (1. + s.y * 1.);\\n float variationX = 0.0 - 0.5 * sin(s.x);//0.25;\\n float variationY = 0.0 - 0.45 * sin(s.x) - 37. * sin(s.z);//0.25;\\n \\n vec2 pos = gl_Position.xy * vec2(max(resolution.x, resolution.y)) / vec2(resolution.yx); // make grid spacing equal in x and y, and fit window size\\n float radius = length(pos.xy) + 0.2;\\n float t = atan(\\n pos.y + variationY,\\n pos.x + variationX\\n );\\n\\n float color = 0.0;\\n for (float i = 1.; i <= n; i++) {\\n color += glowing / abs(\\n color + i / n * scale * sin(\\n petalNum * (t + i * time * rotateSpeed)\\n )\\n - radius\\n );\\n }\\n\\n vec3 debugColor = vec3(smoothstep(-0.1, 1.0, s.x));\\n v_color = vec4(\\n hsv2rgb(vec3(\\n 0.6 + sin(s.x * 2.6),// + cos(s.z * 73.),\\n 0.7 + 0.3 * (time / 120.),\\n 0.6 + 0.4 * (time / 120.)\\n )) * color\\n + step(1., length(pos * vec2(resolution.xy) / resolution)) * debugColor,\\n 1.\\n );\\n \\n}\"}", + "settings": { + "num": 23011, + "mode": "LINES", + "sound": "https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/**\n * LED Music Visualizer\n * A tribute to La La Land\n * Try these sound:\n * https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\n * https://soundcloud.com/thave-lex/another-day-of-sun-la-la-land-thave-lex-remix\n */\nfloat hash(float n) { return fract(sin(n) * 777.1397);}\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\n float gridWidth = resolution.x / xCount;\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\n \n gl_PointSize = 10.;\n gl_PointSize *= 100. / xCount; // if xCount > 100 then make pointSize smaller\n \n vec2 p = vec2(\n mod(vertexId, xCount) * gridWidth,\n floor(vertexId / xCount) * gridHeight\n );\n \n gl_Position = vec4(\n (p / resolution * 2. - vec2(1.)),\n 0., 1.\n ); \n //v_color = vec4(vec3(1., 1., 1.0), 1.); // for debugging grid\n \n float tvGlitch = 400.;\n float i = hash(vertexId) / tvGlitch;\n vec4 snd = texture2D(sound, vec2(0., i)); \n //vec4 snd = texture2D(sound, vec2(0., 0.));\n vec3 s = vec3(snd.a * snd.a, pow(snd.b, 14.), pow(snd.z, 8.));\n float glowFactor = s.x * floor(time / 50.) + 1.;\n \n // tweak variables below to see what happens\n const float n = 3.0; // flower number\n float petalNum = 3.0 + floor((time + s.x * 140.) / 50.); // petal number of each flower\n float glowing = 0.03 * glowFactor;\n float rotateSpeed = 0.07 + 0.015 * smoothstep(-0.1, 1.0, s.x);\n float scale = 0.9 * (1. + s.y * 1.);\n float variationX = 0.0 - 0.5 * sin(s.x);//0.25;\n float variationY = 0.0 - 0.45 * sin(s.x) - 37. * sin(s.z);//0.25;\n \n vec2 pos = gl_Position.xy * vec2(max(resolution.x, resolution.y)) / vec2(resolution.yx); // make grid spacing equal in x and y, and fit window size\n float radius = length(pos.xy) + 0.2;\n float t = atan(\n pos.y + variationY,\n pos.x + variationX\n );\n\n float color = 0.0;\n for (float i = 1.; i <= n; i++) {\n color += glowing / abs(\n color + i / n * scale * sin(\n petalNum * (t + i * time * rotateSpeed)\n )\n - radius\n );\n }\n\n vec3 debugColor = vec3(smoothstep(-0.1, 1.0, s.x));\n v_color = vec4(\n hsv2rgb(vec3(\n 0.6 + sin(s.x * 2.6),// + cos(s.z * 73.),\n 0.7 + 0.3 * (time / 120.),\n 0.6 + 0.4 * (time / 120.)\n )) * color\n + step(1., length(pos * vec2(resolution.xy) / resolution)) * debugColor,\n 1.\n );\n \n}" + }, "screenshotURL": "data/images/images-fs4znso8neoao271e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Z4HpJPY5d2PNYRHZA/art.json b/art/Z4HpJPY5d2PNYRHZA/art.json index 5f6bd593..3ce12659 100644 --- a/art/Z4HpJPY5d2PNYRHZA/art.json +++ b/art/Z4HpJPY5d2PNYRHZA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 12;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.5 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 12;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.5 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\n}\n" + }, "screenshotURL": "data/images/images-edpsawbdaqexusatd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/Z7vAdzozZiayT9xtx/art.json b/art/Z7vAdzozZiayT9xtx/art.json index 8c4632c0..74329503 100644 --- a/art/Z7vAdzozZiayT9xtx/art.json +++ b/art/Z7vAdzozZiayT9xtx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":93814,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Circles from Triangles\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4 (\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 36.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc += 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.02 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.; //mix(0.5, 1., pump); //mix(1., -10.,av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * 20.) * .05;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 93814, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Circles from Triangles\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4 (\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numCircleSegments = 36.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc += 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.02 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.; //mix(0.5, 1., pump); //mix(1., -10.,av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * 20.) * .05;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-4qiamzzv3mwtl6qg4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZADtvSryHzDYzCtp9/art.json b/art/ZADtvSryHzDYzCtp9/art.json index accbbf72..c0a27abe 100644 --- a/art/ZADtvSryHzDYzCtp9/art.json +++ b/art/ZADtvSryHzDYzCtp9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n //float width = 10.0;\\n \\n float x = floor(vertexId / 3.0);\\n float y = floor(vertexId / 3.0) + 1.0;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n \\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 10, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n //float width = 10.0;\n \n float x = floor(vertexId / 3.0);\n float y = floor(vertexId / 3.0) + 1.0;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n \n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-o8x37nolkczvzjlul-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZAHaRXC8kiQBzSkbb/art.json b/art/ZAHaRXC8kiQBzSkbb/art.json index 2d1f88ee..4bc57711 100644 --- a/art/ZAHaRXC8kiQBzSkbb/art.json +++ b/art/ZAHaRXC8kiQBzSkbb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":70000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define kNumVertX 15.0\\n#define kNumVertY 15.0\\n//#define kNumVertZ\\n#define kScale 0.2\\n#define kTranslate vec3(-1.5)\\n\\nvec3 hash3(vec3 v) {\\n return fract(sin(v) * vec3(43758.5453123, 12345.6789012,76543.2109876));\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x;\\n rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nmat4 lookat(vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\\n}\\n\\nvec3 voxelPosToWorld(vec3 vxlp) {\\n return vxlp * kScale + kTranslate;\\n}\\n\\nfloat blobSphere(vec3 p, float r) {\\n return 1.0 / (1.0 + pow(length(p / r), 2.0));\\n}\\n\\nfloat scene(vec3 p) {\\n const float kThreshould = 0.5;\\n float d = 0.0;\\n d += blobSphere(p + sin(time * vec3(1.5, 2.1, 0.5)) * vec3(0.5, 0.6, 0.3), 0.4);\\n d += blobSphere(p + sin(time * vec3(2.3, 1.2, 1.7)) * vec3(0.6, 0.5, 0.8), 0.2);\\n d += blobSphere(p + sin(time * vec3(0.3, 1.2, 2.7)) * vec3(0.5, 0.4, 0.5), 0.3);\\n //d += 1.0 / (1.0 + pow(length(p * 2.0), 2.0));\\n return kThreshould - d;\\n}\\n\\nvec3 sceneNormal(vec3 p) {\\n vec3 EPS = vec3(0.01, 0.0, 0.0);\\n vec3 n;\\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\\n return normalize(n);\\n}\\n\\nvec3 smoothVertex(vec3 ip) {\\n vec3 p = ip;\\n vec3 n = sceneNormal(p);\\n for(int i = 0; i < 8; i++) {\\n float d = scene(p);\\n p -= n * d;\\n if(abs(d) < 0.01) { break; }\\n }\\n return p;\\n}\\n\\nvec4 shading(vec3 p, vec3 n) {\\n vec3 kDc = vec3(0.6, 0.05, 0.15);\\n vec3 kSp = vec3(1.0, 1.0, 1.0) * 0.2;\\n vec3 kFc = vec3(0.3,0.1,0.15);\\n vec3 L = normalize(vec3(1.0, 1.0, 1.0));\\n float d = dot(L, n);\\n float s = 0.0;\\n if(d > 0.0) {\\n vec3 h = (normalize(-p) + L) * 0.5;\\n s = pow(max(0.0, dot(h, n)), 4.0);\\n }\\n float kR0 = 0.02;\\n float F = kR0 + (1.0 - kR0) * pow(1.0 - max(0.0, dot(normalize(-p), n)), 5.0);\\n \\n return vec4((max(0.0, d) * 0.6 + 0.2) * kDc + s * kSp + F * kFc, 1.0);\\n}\\n\\nvoid main() {\\n // vertex index in quad face (2 triangles: 0-5)\\n float faceVertId = mod(vertexId, 6.0);\\n // face index\\n float faceId = floor(vertexId / 6.0);\\n // fece index in corner\\n float cornerFaceId = mod(faceId, 3.0);\\n // edge index in corner\\n float cornerEdgeId = mod(faceId, 3.0);\\n // corner index (1 corner = 3 faces = 3 * 6 verts)\\n float cornerId = floor(vertexId / 18.0);\\n // corner position\\n vec3 cornerPos;\\n cornerPos.x = mod(cornerId, kNumVertX);\\n cornerPos.y = mod(floor(cornerId / kNumVertX), kNumVertY);\\n cornerPos.z = mod(floor(cornerId / (kNumVertX * kNumVertY)), kNumVertY);\\n \\n vec3 faceNormal;\\n vec3 faceTangent;\\n vec3 faceCotangent;\\n vec3 faceColor;\\n if(cornerEdgeId == 0.0) {\\n faceNormal = vec3(1.0, 0.0, 0.0);\\n faceTangent = vec3(0.0, 0.0, -1.0);\\n faceCotangent = vec3(0.0, 1.0, 0.0);\\n } else if(cornerEdgeId == 1.0) {\\n faceNormal = vec3(0.0, 1.0, 0.0);\\n faceTangent = vec3(1.0, 0.0, 0.0);\\n faceCotangent = vec3(0.0, 0.0, -1.0);\\n } else {\\n faceNormal = vec3(0.0, 0.0, 1.0);\\n faceTangent = vec3(1.0, 0.0, 0.0);\\n faceCotangent = vec3(0.0, 1.0, 0.0);\\n }\\n vec3 anotherPos = cornerPos + faceNormal;\\n \\n // sampling points\\n vec3 p0 = voxelPosToWorld(cornerPos);\\n vec3 p1 = voxelPosToWorld(anotherPos);\\n \\n // field value\\n float d0 = scene(p0);\\n float d1 = scene(p1);\\n \\n vec3 p;\\n vec3 vertNorm;\\n \\n if(d0 * d1 > 0.0) {\\n // no face\\n p = p0;\\n vertNorm = vec3(1.0, 1.0, 1.0);\\n } else {\\n // have a face\\n if(d1 < d0) {\\n // 0->1 is standard normal.\\n // otherwise flip triangle\\n if(faceVertId == 0.0) {\\n faceVertId = 2.0;\\n } else if(faceVertId == 2.0) {\\n faceVertId = 0.0;\\n } else if(faceVertId == 3.0) {\\n faceVertId = 5.0;\\n } else if(faceVertId == 5.0) {\\n faceVertId = 3.0;\\n }\\n faceNormal *= -1.0;\\n }\\n \\n /*\\n face\\n 2 4-5\\n |\\\\ \\\\|\\n 0-1 3\\n */\\n float kFaceSize = mix(0.45, 0.5, clamp(cos(time * 1.5) * 4.0 + 0.5, 0.0, 1.0));\\n vec3 edgeMidPos = (cornerPos + anotherPos) * 0.5;\\n vec3 faceVertPos;\\n if(faceVertId == 0.0) {\\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * -kFaceSize;\\n } else if(faceVertId == 1.0) {\\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\\n } else if(faceVertId == 2.0) {\\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\\n } else if(faceVertId == 3.0) {\\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\\n } else if(faceVertId == 4.0) {\\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\\n } else if(faceVertId == 5.0) {\\n faceVertPos = edgeMidPos + faceTangent * 0.5 + faceCotangent * 0.5;\\n }\\n p = voxelPosToWorld(faceVertPos);\\n \\n // smoothing\\n vec3 sp = smoothVertex(p);\\n vertNorm = sceneNormal(p);\\n \\n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\\n p = mix(p, sp, vmix);\\n vertNorm = mix(faceNormal, vertNorm, vmix);\\n }\\n \\n vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.5), -mouse.x * 2.0), mouse.y);\\n //vec3 eye = vec3(0.0, 0.0, 3.0);\\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n vec3 viewPos = (viewMat * vec4(p, 1.0)).xyz;\\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\\n \\n gl_Position = perspective(viewPos, 60.0, 0.1, 10.0);\\n gl_PointSize = 2.0;\\n //v_color = vec4(abs(faceNormal), 1.0);\\n //v_color = vec4(vertNorm * 0.5 + 0.5, 1.0);\\n //v_color = vec4(viewNorm * 0.5 + 0.5, 1.0);\\n v_color = shading(viewPos, viewNorm);\\n}\\n\"}", + "settings": { + "num": 70000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n\n#define kNumVertX 15.0\n#define kNumVertY 15.0\n//#define kNumVertZ\n#define kScale 0.2\n#define kTranslate vec3(-1.5)\n\nvec3 hash3(vec3 v) {\n return fract(sin(v) * vec3(43758.5453123, 12345.6789012,76543.2109876));\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x;\n rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 1.0) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nmat4 lookat(vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\n}\n\nvec3 voxelPosToWorld(vec3 vxlp) {\n return vxlp * kScale + kTranslate;\n}\n\nfloat blobSphere(vec3 p, float r) {\n return 1.0 / (1.0 + pow(length(p / r), 2.0));\n}\n\nfloat scene(vec3 p) {\n const float kThreshould = 0.5;\n float d = 0.0;\n d += blobSphere(p + sin(time * vec3(1.5, 2.1, 0.5)) * vec3(0.5, 0.6, 0.3), 0.4);\n d += blobSphere(p + sin(time * vec3(2.3, 1.2, 1.7)) * vec3(0.6, 0.5, 0.8), 0.2);\n d += blobSphere(p + sin(time * vec3(0.3, 1.2, 2.7)) * vec3(0.5, 0.4, 0.5), 0.3);\n //d += 1.0 / (1.0 + pow(length(p * 2.0), 2.0));\n return kThreshould - d;\n}\n\nvec3 sceneNormal(vec3 p) {\n vec3 EPS = vec3(0.01, 0.0, 0.0);\n vec3 n;\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\n return normalize(n);\n}\n\nvec3 smoothVertex(vec3 ip) {\n vec3 p = ip;\n vec3 n = sceneNormal(p);\n for(int i = 0; i < 8; i++) {\n float d = scene(p);\n p -= n * d;\n if(abs(d) < 0.01) { break; }\n }\n return p;\n}\n\nvec4 shading(vec3 p, vec3 n) {\n vec3 kDc = vec3(0.6, 0.05, 0.15);\n vec3 kSp = vec3(1.0, 1.0, 1.0) * 0.2;\n vec3 kFc = vec3(0.3,0.1,0.15);\n vec3 L = normalize(vec3(1.0, 1.0, 1.0));\n float d = dot(L, n);\n float s = 0.0;\n if(d > 0.0) {\n vec3 h = (normalize(-p) + L) * 0.5;\n s = pow(max(0.0, dot(h, n)), 4.0);\n }\n float kR0 = 0.02;\n float F = kR0 + (1.0 - kR0) * pow(1.0 - max(0.0, dot(normalize(-p), n)), 5.0);\n \n return vec4((max(0.0, d) * 0.6 + 0.2) * kDc + s * kSp + F * kFc, 1.0);\n}\n\nvoid main() {\n // vertex index in quad face (2 triangles: 0-5)\n float faceVertId = mod(vertexId, 6.0);\n // face index\n float faceId = floor(vertexId / 6.0);\n // fece index in corner\n float cornerFaceId = mod(faceId, 3.0);\n // edge index in corner\n float cornerEdgeId = mod(faceId, 3.0);\n // corner index (1 corner = 3 faces = 3 * 6 verts)\n float cornerId = floor(vertexId / 18.0);\n // corner position\n vec3 cornerPos;\n cornerPos.x = mod(cornerId, kNumVertX);\n cornerPos.y = mod(floor(cornerId / kNumVertX), kNumVertY);\n cornerPos.z = mod(floor(cornerId / (kNumVertX * kNumVertY)), kNumVertY);\n \n vec3 faceNormal;\n vec3 faceTangent;\n vec3 faceCotangent;\n vec3 faceColor;\n if(cornerEdgeId == 0.0) {\n faceNormal = vec3(1.0, 0.0, 0.0);\n faceTangent = vec3(0.0, 0.0, -1.0);\n faceCotangent = vec3(0.0, 1.0, 0.0);\n } else if(cornerEdgeId == 1.0) {\n faceNormal = vec3(0.0, 1.0, 0.0);\n faceTangent = vec3(1.0, 0.0, 0.0);\n faceCotangent = vec3(0.0, 0.0, -1.0);\n } else {\n faceNormal = vec3(0.0, 0.0, 1.0);\n faceTangent = vec3(1.0, 0.0, 0.0);\n faceCotangent = vec3(0.0, 1.0, 0.0);\n }\n vec3 anotherPos = cornerPos + faceNormal;\n \n // sampling points\n vec3 p0 = voxelPosToWorld(cornerPos);\n vec3 p1 = voxelPosToWorld(anotherPos);\n \n // field value\n float d0 = scene(p0);\n float d1 = scene(p1);\n \n vec3 p;\n vec3 vertNorm;\n \n if(d0 * d1 > 0.0) {\n // no face\n p = p0;\n vertNorm = vec3(1.0, 1.0, 1.0);\n } else {\n // have a face\n if(d1 < d0) {\n // 0->1 is standard normal.\n // otherwise flip triangle\n if(faceVertId == 0.0) {\n faceVertId = 2.0;\n } else if(faceVertId == 2.0) {\n faceVertId = 0.0;\n } else if(faceVertId == 3.0) {\n faceVertId = 5.0;\n } else if(faceVertId == 5.0) {\n faceVertId = 3.0;\n }\n faceNormal *= -1.0;\n }\n \n /*\n face\n 2 4-5\n |\\ \\|\n 0-1 3\n */\n float kFaceSize = mix(0.45, 0.5, clamp(cos(time * 1.5) * 4.0 + 0.5, 0.0, 1.0));\n vec3 edgeMidPos = (cornerPos + anotherPos) * 0.5;\n vec3 faceVertPos;\n if(faceVertId == 0.0) {\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * -kFaceSize;\n } else if(faceVertId == 1.0) {\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\n } else if(faceVertId == 2.0) {\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\n } else if(faceVertId == 3.0) {\n faceVertPos = edgeMidPos + faceTangent * kFaceSize + faceCotangent * -kFaceSize;\n } else if(faceVertId == 4.0) {\n faceVertPos = edgeMidPos + faceTangent * -kFaceSize + faceCotangent * kFaceSize;\n } else if(faceVertId == 5.0) {\n faceVertPos = edgeMidPos + faceTangent * 0.5 + faceCotangent * 0.5;\n }\n p = voxelPosToWorld(faceVertPos);\n \n // smoothing\n vec3 sp = smoothVertex(p);\n vertNorm = sceneNormal(p);\n \n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\n p = mix(p, sp, vmix);\n vertNorm = mix(faceNormal, vertNorm, vmix);\n }\n \n vec3 eye = rotX(rotY(vec3(0.0, 0.0, 3.5), -mouse.x * 2.0), mouse.y);\n //vec3 eye = vec3(0.0, 0.0, 3.0);\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n vec3 viewPos = (viewMat * vec4(p, 1.0)).xyz;\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\n \n gl_Position = perspective(viewPos, 60.0, 0.1, 10.0);\n gl_PointSize = 2.0;\n //v_color = vec4(abs(faceNormal), 1.0);\n //v_color = vec4(vertNorm * 0.5 + 0.5, 1.0);\n //v_color = vec4(viewNorm * 0.5 + 0.5, 1.0);\n v_color = shading(viewPos, viewNorm);\n}\n" + }, "screenshotURL": "data/images/images-290zfqwqwzy8ecig6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZENPygQSbgzTTXEP8/art.json b/art/ZENPygQSbgzTTXEP8/art.json index 19d95e7f..8fe55d9a 100644 --- a/art/ZENPygQSbgzTTXEP8/art.json +++ b/art/ZENPygQSbgzTTXEP8/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "faris", "avatarUrl": "https://lh3.googleusercontent.com/-Sse3yiTeppo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnNB__LHEi9elvRiBk8MogZtuVS_Q/s96-c/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float areaRad = 1.5;\\n \\n float gridDim = floor(sqrt(vertexCount));\\n \\n float scaleFactor = areaRad / gridDim;\\n\\n float x = mod(vertexId, gridDim);\\n \\n float y = floor(vertexId / gridDim);\\n \\n \\n gl_Position = vec4((x - (gridDim/2.)) * scaleFactor, (y - (gridDim/2.)) * scaleFactor, 0, 1);\\n \\n gl_PointSize = 100.0 * areaRad / gridDim;\\n \\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float areaRad = 1.5;\n \n float gridDim = floor(sqrt(vertexCount));\n \n float scaleFactor = areaRad / gridDim;\n\n float x = mod(vertexId, gridDim);\n \n float y = floor(vertexId / gridDim);\n \n \n gl_Position = vec4((x - (gridDim/2.)) * scaleFactor, (y - (gridDim/2.)) * scaleFactor, 0, 1);\n \n gl_PointSize = 100.0 * areaRad / gridDim;\n \n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n \n}" + }, "screenshotURL": "data/images/images-ros0orucl3pe1tt1p-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZFSiQpx33DLDg9hmd/art.json b/art/ZFSiQpx33DLDg9hmd/art.json index ab7faa3c..800ba8c1 100644 --- a/art/ZFSiQpx33DLDg9hmd/art.json +++ b/art/ZFSiQpx33DLDg9hmd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/greggman/testing-1-2-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.5, sin(tm) * 1.);\\n vec3 target = vec3(-eye.x, -1, -eye.z) * 5.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.5, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .5).a;\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = pow(snd, 5.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/greggman/testing-1-2-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.5, sin(tm) * 1.);\n vec3 target = vec3(-eye.x, -1, -eye.z) * 5.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.5, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .5).a;\n\n float hue = abs(ca * cd) * 2.;\n float sat = pow(snd, 5.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-q1rb2c7c3wpm66suj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZFd2APbTjP4sginbR/art.json b/art/ZFd2APbTjP4sginbR/art.json index 2af53788..84697c6f 100644 --- a/art/ZFd2APbTjP4sginbR/art.json +++ b/art/ZFd2APbTjP4sginbR/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "ale", "avatarUrl": "https://lh6.googleusercontent.com/-A2JcKOXWDHc/AAAAAAAAAAI/AAAAAAAAAcE/deS0m5oEnec/photo.jpg", - "settings": "{\"num\":10240,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float sqrTotal = floor(sqrt(vertexCount));\\n float width = sqrTotal;\\n \\n float x = mod(vertexId, width); // [0, width - 1]\\n float y = floor(vertexId / width); // [0, inf]\\n\\n // vertexId: 0 1 2 3 ... 10 11 12 13 ... 20 21 22 23 ... 100\\n // mod X: 0 1 2 3 ... 0 1 2 3 ... 0 1 2 3 ... 0\\n // floor Y: 0 0 0 0 ... 1 1 1 1 ... 2 2 2 2 ... 10\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time + y * x * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + sizeOffset;\\n gl_PointSize *= 32.0 / width;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 10240, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float sqrTotal = floor(sqrt(vertexCount));\n float width = sqrTotal;\n \n float x = mod(vertexId, width); // [0, width - 1]\n float y = floor(vertexId / width); // [0, inf]\n\n // vertexId: 0 1 2 3 ... 10 11 12 13 ... 20 21 22 23 ... 100\n // mod X: 0 1 2 3 ... 0 1 2 3 ... 0 1 2 3 ... 0\n // floor Y: 0 0 0 0 ... 1 1 1 1 ... 2 2 2 2 ... 10\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float sizeOffset = sin(time + y * x * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + sizeOffset;\n gl_PointSize *= 32.0 / width;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-yk1ihdjwjb1yps1xb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZFhCyFCR3GKn8HkgG/art.json b/art/ZFhCyFCR3GKn8HkgG/art.json index 80aded72..d9e6f999 100644 --- a/art/ZFhCyFCR3GKn8HkgG/art.json +++ b/art/ZFhCyFCR3GKn8HkgG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":87723,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0, \\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId + next) / (numSections - 1.);\\n float v = sv * 4. + base;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n #if 0\\n s = .5;\\n s2 = 0.5;\\n #endif\\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n //float width = mix(1., 2., pow(s2, .5));\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre * .4, 1)).xyz;\\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \\n \\n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n float pump = step(0.5, s2);\\n sat = mix(sat, 1., vert * pump);\\n val = mix(val, 1., vert * pump);\\n hue = mix(hue, hue + .15, vert * pump);\\n \\n //hue += sign(pre.x) * .25;\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\\n \\n //color.rgb = zaxis * .5 + .5; \\n color.a = 1. - pow(sv, 20.0);\\n color.rgb *= color.a;\\n}\\n\\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 30.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float sideV = sideSectionId / halfSectionsAcross;\\n \\n float lr = mod(vertexId, 2.);\\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n \\n float sv = (sectionId + next * .4) / (numSections - 1.);\\n float v = sv * .2 + base + .1;\\n \\n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 tzaxis = normalize(s1 - s0);\\n vec3 txaxis = normalize(cross(s0, s1));\\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\\n \\n const float height = .05;\\n const float period = 2.;\\n const float speed = 2.;\\n const float lPeriod = 0.5;\\n \\n float sx = (sideV + lr / halfSectionsAcross);\\n float bt = sx * period + time * speed + sv * lPeriod;\\n float bh = sin(bt) * height;\\n \\n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\\n float unit = 1. / halfSectionsAcross;\\n \\n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\\n \\n r0 += tzaxis * -.01;\\n \\n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\\n \\n vec3 sb0 = normalize(rb1 - rb0);\\n vec3 sb1 = normalize(rb2 - rb1);\\n \\n vec3 zaxis = normalize(sb1 - sb0);\\n vec3 xaxis = normalize(cross(sb0, sb1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(rb0 * expand, 1)); \\n\\n #if 0\\n s = 1.;\\n s2 = 1.;\\n #endif\\n \\n float su = (sideSectionId + lr) / halfSectionsAcross;\\n\\n float width = 1.; \\n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\\n vec3 nrm = vec3(0, 1, 0);\\n \\n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = 0.3;\\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n if (id < numTrackPoints) {\\n track(id, numTrackPoints, base, pos, color);\\n } else {\\n id -= numTrackPoints;\\n if (id < numFunkPoints) {\\n funk(id, numFunkPoints, base, pos, color);\\n } else {\\n id -= numFunkPoints;\\n sky(id, base, cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 87723, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0, \n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId + next) / (numSections - 1.);\n float v = sv * 4. + base;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n #if 0\n s = .5;\n s2 = 0.5;\n #endif\n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n //float width = mix(1., 2., pow(s2, .5));\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre * .4, 1)).xyz;\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \n \n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n float pump = step(0.5, s2);\n sat = mix(sat, 1., vert * pump);\n val = mix(val, 1., vert * pump);\n hue = mix(hue, hue + .15, vert * pump);\n \n //hue += sign(pre.x) * .25;\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\n \n //color.rgb = zaxis * .5 + .5; \n color.a = 1. - pow(sv, 20.0);\n color.rgb *= color.a;\n}\n\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 30.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float sideV = sideSectionId / halfSectionsAcross;\n \n float lr = mod(vertexId, 2.);\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n \n float sv = (sectionId + next * .4) / (numSections - 1.);\n float v = sv * .2 + base + .1;\n \n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 tzaxis = normalize(s1 - s0);\n vec3 txaxis = normalize(cross(s0, s1));\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\n \n const float height = .05;\n const float period = 2.;\n const float speed = 2.;\n const float lPeriod = 0.5;\n \n float sx = (sideV + lr / halfSectionsAcross);\n float bt = sx * period + time * speed + sv * lPeriod;\n float bh = sin(bt) * height;\n \n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\n float unit = 1. / halfSectionsAcross;\n \n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\n \n r0 += tzaxis * -.01;\n \n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\n \n vec3 sb0 = normalize(rb1 - rb0);\n vec3 sb1 = normalize(rb2 - rb1);\n \n vec3 zaxis = normalize(sb1 - sb0);\n vec3 xaxis = normalize(cross(sb0, sb1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(rb0 * expand, 1)); \n\n #if 0\n s = 1.;\n s2 = 1.;\n #endif\n \n float su = (sideSectionId + lr) / halfSectionsAcross;\n\n float width = 1.; \n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\n vec3 nrm = vec3(0, 1, 0);\n \n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\n float sat = 0.3;\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n if (id < numTrackPoints) {\n track(id, numTrackPoints, base, pos, color);\n } else {\n id -= numTrackPoints;\n if (id < numFunkPoints) {\n funk(id, numFunkPoints, base, pos, color);\n } else {\n id -= numFunkPoints;\n sky(id, base, cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-gxszja6uxjn787m35-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZHKbJh9f2vE6whpYF/art.json b/art/ZHKbJh9f2vE6whpYF/art.json index 81179c8e..233d06c0 100644 --- a/art/ZHKbJh9f2vE6whpYF/art.json +++ b/art/ZHKbJh9f2vE6whpYF/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n //float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n vec2 p = vec2(ux , vy);\\n //float z = fract(0.86);\\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( (u /*resolution.y/resolution.x*/) * 2.0 - 1.0) *resolution.y/resolution.x;\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n //float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n vec2 p = vec2(ux , vy);\n //float z = fract(0.86);\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\n int a = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / numAcrossDown) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-cyciqd7gdq6uq42pr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZKyW6sGCeKnuju3A2/art.json b/art/ZKyW6sGCeKnuju3A2/art.json index 117dd4ff..afd84466 100644 --- a/art/ZKyW6sGCeKnuju3A2/art.json +++ b/art/ZKyW6sGCeKnuju3A2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":74996,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ambient_space/4-ali-khan-sol\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, (c.x - 3.0) / 2.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 1, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,s, 0,\\n s, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n -1, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, -1, 2, 1,\\n 1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 10, 0,\\n 0, s[1], 2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 1, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 1.5 - 0.75 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 3.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.2 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 3. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * (v * x);\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.2);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * .7;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .13, 1000.0);\\n float rad = 2.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 1.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n float st = time; //-0.5 * PI * 10.;\\n float minRez = min(resolution.x, resolution.y);\\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 1000., sin(st * .2) * .5 + .5);\\n \\n float z = gl_Position.w / gl_Position.z * .5 + .5;\\n float hue = 1.1;// + mix(.4, .9, sin(st * .1) * .5 + .5);\\n float sat = 1.;\\n float val = 1. ;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 74996, + "mode": "POINTS", + "sound": "https://soundcloud.com/ambient_space/4-ali-khan-sol", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, (c.x - 3.0) / 2.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 1, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,s, 0,\n s, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n -1, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, -1, 2, 1,\n 1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 10, 0,\n 0, s[1], 2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 1, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 1.5 - 0.75 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 3.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.2 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 3. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * (v * x);\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.2);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * .7;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .13, 1000.0);\n float rad = 2.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 1.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n float st = time; //-0.5 * PI * 10.;\n float minRez = min(resolution.x, resolution.y);\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 1000., sin(st * .2) * .5 + .5);\n \n float z = gl_Position.w / gl_Position.z * .5 + .5;\n float hue = 1.1;// + mix(.4, .9, sin(st * .1) * .5 + .5);\n float sat = 1.;\n float val = 1. ;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-qasftp3wic0abijd1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZMzvpXNMZY9564WHh/art.json b/art/ZMzvpXNMZY9564WHh/art.json index b1490e1b..48e448b9 100644 --- a/art/ZMzvpXNMZY9564WHh/art.json +++ b/art/ZMzvpXNMZY9564WHh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_POINTS\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>1.\\n#define kpx 3.0//KParameter 0.>>4.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\n\\n#define elementPerTriangleShape 3.\\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\\n result = rotZ(result,_angle);\\n result.xy+=_center.xy;\\n return result;\\n}\\n\\n\\nvoid main() {\\n \\n //fix a maximum vertexId\\n float localVertexId = vertexId;\\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\\n \\n float relVertexId = vertexId/vertexCount-kpx;\\n \\n maxShapeCount = floor(maxShapeCount/2.);\\n \\n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\\n \\n if(localVertexId>=maxVerticesNumber)\\n localVertexId = maxVerticesNumber-1.5;\\n \\n float shapeId = floor(localVertexId / elementPerTriangleShape);\\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\\n float relShapeId = shapeId/maxShapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n \\n vec2 center=vec2(0., 0.);\\n \\n if(localVertexId>=(maxVerticesNumber/2.))\\n {\\n localVertexId = localVertexId - (maxVerticesNumber/2.);\\n }\\n \\n float localShapeId = floor(localVertexId/elementPerTriangleShape);\\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\\n \\n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\\n float snd = texture2D(sound, vec2(localRelShapeId,0.4) ).a* sndFactor;\\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\\n \\n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\\n ;\\n \\n \\n shapep.x/=aspect;\\n vec4 m = texture2D(touch, vec2(0., localShapeId /(maxShapeCount/2.)));\\n \\n shapep += vec3( m.xy, shapep.z+2.);\\n \\n if(shapeId>maxShapeCount/2.)\\n {\\n shapep.x = -shapep.x;\\n }\\n\\n \\n \\n \\n gl_Position = vec4(shapep,1.);\\n gl_PointSize = 3.*PointSizeFactor;\\n \\n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_POINTS\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>1.\n#define kpx 3.0//KParameter 0.>>4.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\n\n#define elementPerTriangleShape 3.\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\n result = rotZ(result,_angle);\n result.xy+=_center.xy;\n return result;\n}\n\n\nvoid main() {\n \n //fix a maximum vertexId\n float localVertexId = vertexId;\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\n \n float relVertexId = vertexId/vertexCount-kpx;\n \n maxShapeCount = floor(maxShapeCount/2.);\n \n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\n \n if(localVertexId>=maxVerticesNumber)\n localVertexId = maxVerticesNumber-1.5;\n \n float shapeId = floor(localVertexId / elementPerTriangleShape);\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\n float relShapeId = shapeId/maxShapeCount;\n \n float aspect = resolution.x / resolution.y;\n \n vec2 center=vec2(0., 0.);\n \n if(localVertexId>=(maxVerticesNumber/2.))\n {\n localVertexId = localVertexId - (maxVerticesNumber/2.);\n }\n \n float localShapeId = floor(localVertexId/elementPerTriangleShape);\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\n \n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\n float snd = texture2D(sound, vec2(localRelShapeId,0.4) ).a* sndFactor;\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\n \n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\n ;\n \n \n shapep.x/=aspect;\n vec4 m = texture2D(touch, vec2(0., localShapeId /(maxShapeCount/2.)));\n \n shapep += vec3( m.xy, shapep.z+2.);\n \n if(shapeId>maxShapeCount/2.)\n {\n shapep.x = -shapep.x;\n }\n\n \n \n \n gl_Position = vec4(shapep,1.);\n gl_PointSize = 3.*PointSizeFactor;\n \n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-m7g23vjzoy73jmpw1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZNi2inr6Jmirh6Hgy/art.json b/art/ZNi2inr6Jmirh6Hgy/art.json index c9cdf195..4c15503b 100644 --- a/art/ZNi2inr6Jmirh6Hgy/art.json +++ b/art/ZNi2inr6Jmirh6Hgy/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "eddietree", - "settings": "{\"num\":2000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sp00kyfish/icarus\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7686274509803922,0.3176470588235294,0.396078431372549,1],\"shader\":\"#define PI 3.14159\\n\\n//#define FIT_VERTICAL\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat modf( float x, float y )\\n{\\n return x - y * floor(x/y);\\n}\\n\\nfloat wrapf(float val, float minVal, float maxVal)\\n{\\n val -= minVal;\\n\\n float delta = maxVal - minVal;\\n if ( delta < 0.0001 ) return val;\\n\\n return val - (delta* floor(val/delta)) + minVal;\\n}\\n\\nvec3 mod289(vec3 x) {\\n return x - floor(x * (1.0 / 289.0)) * 289.0;\\n}\\n\\nvec4 mod289(vec4 x) {\\n return x - floor(x * (1.0 / 289.0)) * 289.0;\\n}\\n\\nvec4 permute(vec4 x) {\\n return mod289(((x*34.0)+1.0)*x);\\n}\\n\\nvec4 taylorInvSqrt(vec4 r)\\n{\\n return 1.79284291400159 - 0.85373472095314 * r;\\n}\\n\\nfloat snoise(vec3 v)\\n { \\n const vec2 C = vec2(1.0/6.0, 1.0/3.0) ;\\n const vec4 D = vec4(0.0, 0.5, 1.0, 2.0);\\n\\n// First corner\\n vec3 i = floor(v + dot(v, C.yyy) );\\n vec3 x0 = v - i + dot(i, C.xxx) ;\\n\\n// Other corners\\n vec3 g = step(x0.yzx, x0.xyz);\\n vec3 l = 1.0 - g;\\n vec3 i1 = min( g.xyz, l.zxy );\\n vec3 i2 = max( g.xyz, l.zxy );\\n\\n // x0 = x0 - 0.0 + 0.0 * C.xxx;\\n // x1 = x0 - i1 + 1.0 * C.xxx;\\n // x2 = x0 - i2 + 2.0 * C.xxx;\\n // x3 = x0 - 1.0 + 3.0 * C.xxx;\\n vec3 x1 = x0 - i1 + C.xxx;\\n vec3 x2 = x0 - i2 + C.yyy; // 2.0*C.x = 1/3 = C.y\\n vec3 x3 = x0 - D.yyy; // -1.0+3.0*C.x = -0.5 = -D.y\\n\\n// Permutations\\n i = mod289(i); \\n vec4 p = permute( permute( permute( \\n i.z + vec4(0.0, i1.z, i2.z, 1.0 ))\\n + i.y + vec4(0.0, i1.y, i2.y, 1.0 )) \\n + i.x + vec4(0.0, i1.x, i2.x, 1.0 ));\\n\\n// Gradients: 7x7 points over a square, mapped onto an octahedron.\\n// The ring size 17*17 = 289 is close to a multiple of 49 (49*6 = 294)\\n float n_ = 0.142857142857; // 1.0/7.0\\n vec3 ns = n_ * D.wyz - D.xzx;\\n\\n vec4 j = p - 49.0 * floor(p * ns.z * ns.z); // mod(p,7*7)\\n\\n vec4 x_ = floor(j * ns.z);\\n vec4 y_ = floor(j - 7.0 * x_ ); // mod(j,N)\\n\\n vec4 x = x_ *ns.x + ns.yyyy;\\n vec4 y = y_ *ns.x + ns.yyyy;\\n vec4 h = 1.0 - abs(x) - abs(y);\\n\\n vec4 b0 = vec4( x.xy, y.xy );\\n vec4 b1 = vec4( x.zw, y.zw );\\n\\n //vec4 s0 = vec4(lessThan(b0,0.0))*2.0 - 1.0;\\n //vec4 s1 = vec4(lessThan(b1,0.0))*2.0 - 1.0;\\n vec4 s0 = floor(b0)*2.0 + 1.0;\\n vec4 s1 = floor(b1)*2.0 + 1.0;\\n vec4 sh = -step(h, vec4(0.0));\\n\\n vec4 a0 = b0.xzyw + s0.xzyw*sh.xxyy ;\\n vec4 a1 = b1.xzyw + s1.xzyw*sh.zzww ;\\n\\n vec3 p0 = vec3(a0.xy,h.x);\\n vec3 p1 = vec3(a0.zw,h.y);\\n vec3 p2 = vec3(a1.xy,h.z);\\n vec3 p3 = vec3(a1.zw,h.w);\\n\\n//Normalise gradients\\n vec4 norm = taylorInvSqrt(vec4(dot(p0,p0), dot(p1,p1), dot(p2, p2), dot(p3,p3)));\\n p0 *= norm.x;\\n p1 *= norm.y;\\n p2 *= norm.z;\\n p3 *= norm.w;\\n\\n// Mix final noise value\\n vec4 m = max(0.6 - vec4(dot(x0,x0), dot(x1,x1), dot(x2,x2), dot(x3,x3)), 0.0);\\n m = m * m;\\n return 42.0 * dot( m*m, vec4( dot(p0,x0), dot(p1,x1), \\n dot(p2,x2), dot(p3,x3) ) );\\n }\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n //float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n\\n //gl_PointSize = 5.0; \\n \\n float NUM_SEGS_X = 32.0;\\n float NUM_SEGS_Y = 64.0;\\n \\n float xIndex = modf( vertexId, NUM_SEGS_X );\\n float yIndex = floor( vertexId / NUM_SEGS_X );\\n float xNormalized = (xIndex / NUM_SEGS_X) * 2.0 - 1.0;\\n float yNormalized = (yIndex / NUM_SEGS_Y) * 2.0 - 1.0;\\n \\n vec2 xy = vec2( xNormalized, yNormalized );\\n //xy.x = xNormalized;\\n //xy.y = yNormalized;\\n \\n float sndPiano = texture2D(sound, vec2(0.25, 0.0) ).a;\\n \\n xy.x += wrapf( localTime*0.15 + xy.y*8.0, -2.0, 2.0 );\\n xy.y += snoise( vec3( xy * 3.0, localTime*0.4) ) * 0.025;\\n xy.x += snoise( vec3( xy * 2.0 + sin(xNormalized), localTime*0.05) ) * 0.3;\\n \\n //float sndGuitar = texture2D(sound, vec2(0.3, 0.0) ).a;\\n //xy.y += sndGuitar*0.2;\\n \\n \\n vec4 color = vec4(1.0);\\n \\n if ( modf(xIndex, 2.0 ) < 0.1)\\n { \\n color.z -= sndPiano * 3.5;\\n }\\n \\n color.xyz += -vec3( length( xy ) + sin(vertexId*0.5) )*2.0 + vec3(sndPiano*3.0);\\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n\\n //gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float hue = (localTime * 0.01 + count * 1.001);\\n v_color = color;\\n}\"}", + "settings": { + "num": 2000, + "mode": "LINES", + "sound": "https://soundcloud.com/sp00kyfish/icarus", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7686274509803922, + 0.3176470588235294, + 0.396078431372549, + 1 + ], + "shader": "#define PI 3.14159\n\n//#define FIT_VERTICAL\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat modf( float x, float y )\n{\n return x - y * floor(x/y);\n}\n\nfloat wrapf(float val, float minVal, float maxVal)\n{\n val -= minVal;\n\n float delta = maxVal - minVal;\n if ( delta < 0.0001 ) return val;\n\n return val - (delta* floor(val/delta)) + minVal;\n}\n\nvec3 mod289(vec3 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n}\n\nvec4 mod289(vec4 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n}\n\nvec4 permute(vec4 x) {\n return mod289(((x*34.0)+1.0)*x);\n}\n\nvec4 taylorInvSqrt(vec4 r)\n{\n return 1.79284291400159 - 0.85373472095314 * r;\n}\n\nfloat snoise(vec3 v)\n { \n const vec2 C = vec2(1.0/6.0, 1.0/3.0) ;\n const vec4 D = vec4(0.0, 0.5, 1.0, 2.0);\n\n// First corner\n vec3 i = floor(v + dot(v, C.yyy) );\n vec3 x0 = v - i + dot(i, C.xxx) ;\n\n// Other corners\n vec3 g = step(x0.yzx, x0.xyz);\n vec3 l = 1.0 - g;\n vec3 i1 = min( g.xyz, l.zxy );\n vec3 i2 = max( g.xyz, l.zxy );\n\n // x0 = x0 - 0.0 + 0.0 * C.xxx;\n // x1 = x0 - i1 + 1.0 * C.xxx;\n // x2 = x0 - i2 + 2.0 * C.xxx;\n // x3 = x0 - 1.0 + 3.0 * C.xxx;\n vec3 x1 = x0 - i1 + C.xxx;\n vec3 x2 = x0 - i2 + C.yyy; // 2.0*C.x = 1/3 = C.y\n vec3 x3 = x0 - D.yyy; // -1.0+3.0*C.x = -0.5 = -D.y\n\n// Permutations\n i = mod289(i); \n vec4 p = permute( permute( permute( \n i.z + vec4(0.0, i1.z, i2.z, 1.0 ))\n + i.y + vec4(0.0, i1.y, i2.y, 1.0 )) \n + i.x + vec4(0.0, i1.x, i2.x, 1.0 ));\n\n// Gradients: 7x7 points over a square, mapped onto an octahedron.\n// The ring size 17*17 = 289 is close to a multiple of 49 (49*6 = 294)\n float n_ = 0.142857142857; // 1.0/7.0\n vec3 ns = n_ * D.wyz - D.xzx;\n\n vec4 j = p - 49.0 * floor(p * ns.z * ns.z); // mod(p,7*7)\n\n vec4 x_ = floor(j * ns.z);\n vec4 y_ = floor(j - 7.0 * x_ ); // mod(j,N)\n\n vec4 x = x_ *ns.x + ns.yyyy;\n vec4 y = y_ *ns.x + ns.yyyy;\n vec4 h = 1.0 - abs(x) - abs(y);\n\n vec4 b0 = vec4( x.xy, y.xy );\n vec4 b1 = vec4( x.zw, y.zw );\n\n //vec4 s0 = vec4(lessThan(b0,0.0))*2.0 - 1.0;\n //vec4 s1 = vec4(lessThan(b1,0.0))*2.0 - 1.0;\n vec4 s0 = floor(b0)*2.0 + 1.0;\n vec4 s1 = floor(b1)*2.0 + 1.0;\n vec4 sh = -step(h, vec4(0.0));\n\n vec4 a0 = b0.xzyw + s0.xzyw*sh.xxyy ;\n vec4 a1 = b1.xzyw + s1.xzyw*sh.zzww ;\n\n vec3 p0 = vec3(a0.xy,h.x);\n vec3 p1 = vec3(a0.zw,h.y);\n vec3 p2 = vec3(a1.xy,h.z);\n vec3 p3 = vec3(a1.zw,h.w);\n\n//Normalise gradients\n vec4 norm = taylorInvSqrt(vec4(dot(p0,p0), dot(p1,p1), dot(p2, p2), dot(p3,p3)));\n p0 *= norm.x;\n p1 *= norm.y;\n p2 *= norm.z;\n p3 *= norm.w;\n\n// Mix final noise value\n vec4 m = max(0.6 - vec4(dot(x0,x0), dot(x1,x1), dot(x2,x2), dot(x3,x3)), 0.0);\n m = m * m;\n return 42.0 * dot( m*m, vec4( dot(p0,x0), dot(p1,x1), \n dot(p2,x2), dot(p3,x3) ) );\n }\n\nvoid main() {\n float localTime = time + 20.0;\n //float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n\n //gl_PointSize = 5.0; \n \n float NUM_SEGS_X = 32.0;\n float NUM_SEGS_Y = 64.0;\n \n float xIndex = modf( vertexId, NUM_SEGS_X );\n float yIndex = floor( vertexId / NUM_SEGS_X );\n float xNormalized = (xIndex / NUM_SEGS_X) * 2.0 - 1.0;\n float yNormalized = (yIndex / NUM_SEGS_Y) * 2.0 - 1.0;\n \n vec2 xy = vec2( xNormalized, yNormalized );\n //xy.x = xNormalized;\n //xy.y = yNormalized;\n \n float sndPiano = texture2D(sound, vec2(0.25, 0.0) ).a;\n \n xy.x += wrapf( localTime*0.15 + xy.y*8.0, -2.0, 2.0 );\n xy.y += snoise( vec3( xy * 3.0, localTime*0.4) ) * 0.025;\n xy.x += snoise( vec3( xy * 2.0 + sin(xNormalized), localTime*0.05) ) * 0.3;\n \n //float sndGuitar = texture2D(sound, vec2(0.3, 0.0) ).a;\n //xy.y += sndGuitar*0.2;\n \n \n vec4 color = vec4(1.0);\n \n if ( modf(xIndex, 2.0 ) < 0.1)\n { \n color.z -= sndPiano * 3.5;\n }\n \n color.xyz += -vec3( length( xy ) + sin(vertexId*0.5) )*2.0 + vec3(sndPiano*3.0);\n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n\n //gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float hue = (localTime * 0.01 + count * 1.001);\n v_color = color;\n}" + }, "screenshotURL": "data/images/images-mno1wzlv6yd9hudz3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZNnRK7kpHZXGz5gT5/art.json b/art/ZNnRK7kpHZXGz5gT5/art.json index 2b8e2669..c9e38943 100644 --- a/art/ZNnRK7kpHZXGz5gT5/art.json +++ b/art/ZNnRK7kpHZXGz5gT5/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "MagnetTV", "username": "freefull", - "settings": "{\"num\":19272,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n gl_Position = vec4(x, y, 0, 1);\\n\\n gl_PointSize = cos(60.0*(length(vec2(x*sin(y*3.0+time),y))- time/20.0))*4.0 + 4.0;\\n \\n float hue = x*y;\\n float sat = 0.8;\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 19272, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n \n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n gl_Position = vec4(x, y, 0, 1);\n\n gl_PointSize = cos(60.0*(length(vec2(x*sin(y*3.0+time),y))- time/20.0))*4.0 + 4.0;\n \n float hue = x*y;\n float sat = 0.8;\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "BnFhPf79SsMQsqBaZ", "views": { "$numberInt": "1423" diff --git a/art/ZNyqShZSnzXJMjTPX/art.json b/art/ZNyqShZSnzXJMjTPX/art.json index 11f42302..1a1f1388 100644 --- a/art/ZNyqShZSnzXJMjTPX/art.json +++ b/art/ZNyqShZSnzXJMjTPX/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// -----[ shader missing! ] -----\\n\\n#define NUM 15.0\\nvoid main() {\\n gl_PointSize = 16.0;\\n float col = mod(vertexId, NUM + 1.0);\\n float row = mod(floor(vertexId / NUM), NUM + 1.0); \\n float x = col / NUM * 2.0 - 1.0;\\n float y = row / NUM * 2.0 - 1.0;\\n gl_Position = vec4(x, y, 0, 1);\\n v_color = vec4(fract(time + col / NUM + row / NUM), 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// -----[ shader missing! ] -----\n\n#define NUM 15.0\nvoid main() {\n gl_PointSize = 16.0;\n float col = mod(vertexId, NUM + 1.0);\n float row = mod(floor(vertexId / NUM), NUM + 1.0); \n float x = col / NUM * 2.0 - 1.0;\n float y = row / NUM * 2.0 - 1.0;\n gl_Position = vec4(x, y, 0, 1);\n v_color = vec4(fract(time + col / NUM + row / NUM), 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-jigj5pinfmwwm6phg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZPpq2oK4fqmPHJnQn/art.json b/art/ZPpq2oK4fqmPHJnQn/art.json index 2132ff24..b4d7d1df 100644 --- a/art/ZPpq2oK4fqmPHJnQn/art.json +++ b/art/ZPpq2oK4fqmPHJnQn/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "daff", "avatarUrl": "https://lh6.googleusercontent.com/-q6F2s0HNLkg/AAAAAAAAAAI/AAAAAAAAABQ/1TC-kZyFYM0/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/re_gain/alert\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Based on @greggman's contributions => https://goo.gl/jyVxLc\\n// @Re_gain aka Daff: https://soundcloud.com/re_gain\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x,clamp(c.yz, 0.0, 1.0));\\n vec4 k= vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p= abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y); \\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float munCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / munCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n// Based on @greggman's contributions => https://goo.gl/jyVxLc \\n// @Re_gain aka Daff: https://soundcloud.com/re_gain\\nvoid main() {\\n \\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * .02;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod (sliceId, .2);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId*PI, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n\\n \\n float su = abs(u - 0.5) * 2.2;\\n float sv = abs(v - 0.5) * 2.2;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2 (au * 0.05 , av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd, 5.) * mix (1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1, aspect,1)); \\n mat *= rotZ(time * 0.9);\\n mat *= rotY(time*0.0000009);\\n mat *= rotX(sin(snd)* sin(sc));\\n mat *= trans(vec3(ux, vy, 0)*snd); \\n mat *= rotZ(snd * ux);\\n mat *= uniformScale(0.000003*snd);\\n\\n \\n float soff = 1.; \\n \\n gl_Position = mat*pos;\\n //gl_Position +=vec4(su/snd,sv/snd,0,0); \\n gl_Position *=aspect;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd *0.2+ snd*time *.0001;\\n float sat = mix(time, snd, pump);\\n float val = mix(1., pow(snd + 0.5, 5.), pump);\\n \\n hue = hue + pump * oddSlice *0.5 + pump*.33;\\n val += oddSlice * pump;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat , val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/re_gain/alert", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Based on @greggman's contributions => https://goo.gl/jyVxLc\n// @Re_gain aka Daff: https://soundcloud.com/re_gain\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x,clamp(c.yz, 0.0, 1.0));\n vec4 k= vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p= abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y); \n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float munCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / munCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n// Based on @greggman's contributions => https://goo.gl/jyVxLc \n// @Re_gain aka Daff: https://soundcloud.com/re_gain\nvoid main() {\n \n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * .02;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod (sliceId, .2);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId*PI, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n\n \n float su = abs(u - 0.5) * 2.2;\n float sv = abs(v - 0.5) * 2.2;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2 (au * 0.05 , av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd, 5.) * mix (1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1, aspect,1)); \n mat *= rotZ(time * 0.9);\n mat *= rotY(time*0.0000009);\n mat *= rotX(sin(snd)* sin(sc));\n mat *= trans(vec3(ux, vy, 0)*snd); \n mat *= rotZ(snd * ux);\n mat *= uniformScale(0.000003*snd);\n\n \n float soff = 1.; \n \n gl_Position = mat*pos;\n //gl_Position +=vec4(su/snd,sv/snd,0,0); \n gl_Position *=aspect;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd *0.2+ snd*time *.0001;\n float sat = mix(time, snd, pump);\n float val = mix(1., pow(snd + 0.5, 5.), pump);\n \n hue = hue + pump * oddSlice *0.5 + pump*.33;\n val += oddSlice * pump;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat , val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-10ghgje8atqyukd46-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZRtD3xwsPjHk8vwmS/art.json b/art/ZRtD3xwsPjHk8vwmS/art.json index 60960b27..66eb8e9f 100644 --- a/art/ZRtD3xwsPjHk8vwmS/art.json +++ b/art/ZRtD3xwsPjHk8vwmS/art.json @@ -31,7 +31,19 @@ "private": true, "unlisted": false, "username": "gman", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// worms\\n\\n#define PI radians(180.)\\n\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0,0,0,1);\\n v_color = vec4(0,1,0,1);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// worms\n\n#define PI radians(180.)\n\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0,0,0,1);\n v_color = vec4(0,1,0,1);\n}" + }, "screenshotURL": "data/images/images-l0ru8wsge98jxxvo8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZSksx2deRsDocFDKT/art.json b/art/ZSksx2deRsDocFDKT/art.json index d9633d1f..a906119e 100644 --- a/art/ZSksx2deRsDocFDKT/art.json +++ b/art/ZSksx2deRsDocFDKT/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jefflee", "avatarUrl": "https://secure.gravatar.com/avatar/de0abc675a9bb11fedc01a78bd4ddf84?default=retro&size=200", - "settings": "{\"num\":9623,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, .0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = sin(orbitAngle + time * 0.3 + count * 0.1) * innerRadius;\\n float oS = tan(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 9623, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, .0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = sin(orbitAngle + time * 0.3 + count * 0.1) * innerRadius;\n float oS = tan(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-x8tzxjmbzwbjhhtlr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZTAvJzo5HJdr2FsZK/art.json b/art/ZTAvJzo5HJdr2FsZK/art.json index ec408f3e..f68db1ab 100644 --- a/art/ZTAvJzo5HJdr2FsZK/art.json +++ b/art/ZTAvJzo5HJdr2FsZK/art.json @@ -27,7 +27,19 @@ "name": "residuallines", "private": false, "username": "spotline", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.51)).a,10.0);\\n float x = (u*10.0)-0.8;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 800.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *20.0 + 0.7)/10.0;\\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.51)).a,10.0);\n float x = (u*10.0)-0.8;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 800.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *20.0 + 0.7)/10.0;\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\n}" + }, "screenshotURL": "data/images/images-5kfqvydni4i5h9bhh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZTEp3znDaGd9mFj4J/art.json b/art/ZTEp3znDaGd9mFj4J/art.json index 05d346c4..6daf5db7 100644 --- a/art/ZTEp3znDaGd9mFj4J/art.json +++ b/art/ZTEp3znDaGd9mFj4J/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":1320,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.043137254901960784,0.07058823529411765,0.09019607843137255,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 getCirclePoint(float id, float numSegments) { \\n // Each square is made of 2 triangles, 6 points\\n float ux = mod(id, 2.0) + floor(id / 6.0); \\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n\\n // \\n float angle = ux / numSegments * 2.0 * PI;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numSegments = 20.0;\\n float numPointsPerCircle = numSegments * 6.0;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n \\n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1;\\n \\n gl_Position = vec4(xy.x + circleId * 0.1 - 0.5, xy.y + sin(time + circleId)*0.1, 0, 1);\\n \\n // Circle color\\n float hue = sin(circleId * 0.1 + time * .1) * 0.8;\\n float sat = 0.4;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\\n}\"}", + "settings": { + "num": 1320, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.043137254901960784, + 0.07058823529411765, + 0.09019607843137255, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 getCirclePoint(float id, float numSegments) { \n // Each square is made of 2 triangles, 6 points\n float ux = mod(id, 2.0) + floor(id / 6.0); \n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n\n // \n float angle = ux / numSegments * 2.0 * PI;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numSegments = 20.0;\n float numPointsPerCircle = numSegments * 6.0;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n \n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1;\n \n gl_Position = vec4(xy.x + circleId * 0.1 - 0.5, xy.y + sin(time + circleId)*0.1, 0, 1);\n \n // Circle color\n float hue = sin(circleId * 0.1 + time * .1) * 0.8;\n float sat = 0.4;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\n}" + }, "screenshotURL": "data/images/images-bnyxagaak7tyeoq56-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZWM6nHwzqNcfrMCbQ/art.json b/art/ZWM6nHwzqNcfrMCbQ/art.json index d3b0782c..8e1c2e53 100644 --- a/art/ZWM6nHwzqNcfrMCbQ/art.json +++ b/art/ZWM6nHwzqNcfrMCbQ/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jc", "avatarUrl": "https://lh6.googleusercontent.com/-wxkmpL8A-s0/AAAAAAAAAAI/AAAAAAAAAFg/cZuqYtkpOCI/photo.jpg", - "settings": "{\"num\":3923,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float width = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n // vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4 (xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time + x * y * 0.2) * 5.0;\\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 32.0 / width;\\n \\n v_color= vec4(0.0, 1.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3923, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float width = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n // vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4 (xy, 0.0, 1.0);\n \n float sizeOffset = sin(time + x * y * 0.2) * 5.0;\n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 32.0 / width;\n \n v_color= vec4(0.0, 1.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-fewh20hnqgtenzrlm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZXDZSs2JN4hbwdSqr/art.json b/art/ZXDZSs2JN4hbwdSqr/art.json index e5ec4d39..f2fb6604 100644 --- a/art/ZXDZSs2JN4hbwdSqr/art.json +++ b/art/ZXDZSs2JN4hbwdSqr/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "taejukwon-digipen", "avatarUrl": "https://avatars.githubusercontent.com/taejuKwon-digipen?s=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float down = floor (sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n \\n float x = mod (vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0,1);\\n \\n float soff = sin(time + x) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float down = floor (sqrt(vertexCount));\n float across = floor(vertexCount /down);\n \n float x = mod (vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0,1);\n \n float soff = sin(time + x) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-h3hkvenzthm0qlzex-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZXEkPoPaDoTjDqbL7/art.json b/art/ZXEkPoPaDoTjDqbL7/art.json index 0f067305..18f7a71f 100644 --- a/art/ZXEkPoPaDoTjDqbL7/art.json +++ b/art/ZXEkPoPaDoTjDqbL7/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "epoch", "avatarUrl": "https://secure.gravatar.com/avatar/3e53f54468906b25ff02d4860fa32a28?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/marikarossa/ken-ishii-alberto-ruiz-transmission-marika-rossa-remix-stick-recordings-cut-version\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 3.;\\n float maxEdge = 16.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 6.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 loc = fibonacciSphere(numGroups, groupId);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(time * .17);\\n wmat *= rotX(time * .13);\\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\\n wmat *= uniformScale(mix(0.6, 1., mv));\\n wmat *= rotZ(groupId * PI / 3.);\\n \\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\\n float sat = .5;//step(pow(s, 3.), gt);\\n float val = pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = dot(litDir, nrm) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb *= v_color.a;\\n \\n float super = step(0.99, s);\\n v_color = mix(v_color, vec4(1,0,0,1), super);\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/marikarossa/ken-ishii-alberto-ruiz-transmission-marika-rossa-remix-stick-recordings-cut-version", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 3.;\n float maxEdge = 16.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 6.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 loc = fibonacciSphere(numGroups, groupId);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(time * .17);\n wmat *= rotX(time * .13);\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\n wmat *= uniformScale(mix(0.6, 1., mv));\n wmat *= rotZ(groupId * PI / 3.);\n \n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\n float sat = .5;//step(pow(s, 3.), gt);\n float val = pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = dot(litDir, nrm) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb *= v_color.a;\n \n float super = step(0.99, s);\n v_color = mix(v_color, vec4(1,0,0,1), super);\n \n}\n" + }, "screenshotURL": "data/images/images-rays4gw5mcznm4xev-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZXPZby6en2K8C7Fyg/art.json b/art/ZXPZby6en2K8C7Fyg/art.json index 3e444fc7..bfeaaf4f 100644 --- a/art/ZXPZby6en2K8C7Fyg/art.json +++ b/art/ZXPZby6en2K8C7Fyg/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mikipom", "avatarUrl": "https://secure.gravatar.com/avatar/fb938bdfd01f14cf89f8e00712fde243?default=retro&size=200", - "settings": "{\"num\":1333,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\tfloat x = mod(vertexId , across)/across;\\n \\tfloat y =floor(vertexId / across )/across;\\n \\tfloat ux = x*2.-1.;\\n \\tfloat uy = y*2.-1.;\\n\\tgl_Position = vec4(ux,uy,0,1);\\n \\t\\n \\tgl_PointSize = 10.0;\\n \\tgl_PointSize *= 20. / across;\\n \\tgl_PointSize *= resolution.x /600.; \\n \\tv_color = vec4(1,0,0,1);\\n \\n}\\n\"}", + "settings": { + "num": 1333, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \tfloat x = mod(vertexId , across)/across;\n \tfloat y =floor(vertexId / across )/across;\n \tfloat ux = x*2.-1.;\n \tfloat uy = y*2.-1.;\n\tgl_Position = vec4(ux,uy,0,1);\n \t\n \tgl_PointSize = 10.0;\n \tgl_PointSize *= 20. / across;\n \tgl_PointSize *= resolution.x /600.; \n \tv_color = vec4(1,0,0,1);\n \n}\n" + }, "screenshotURL": "data/images/images-em37eooyb4ckp5qry-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZZ2MBTXKXSRzbure5/art.json b/art/ZZ2MBTXKXSRzbure5/art.json index 4b2bcd76..d35f6103 100644 --- a/art/ZZ2MBTXKXSRzbure5/art.json +++ b/art/ZZ2MBTXKXSRzbure5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 0.04 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 8;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.5 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 0.04 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 8;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.5 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\n}\n" + }, "screenshotURL": "data/images/images-xvwa4daqb76klb1bk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZZPtHWkxTWXKxGiJB/art.json b/art/ZZPtHWkxTWXKxGiJB/art.json index 0d3dd528..48fb7469 100644 --- a/art/ZZPtHWkxTWXKxGiJB/art.json +++ b/art/ZZPtHWkxTWXKxGiJB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-e3i3deyf3k201t93b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZZj9dLPDqjWny5kJW/art.json b/art/ZZj9dLPDqjWny5kJW/art.json index e0a7a0d5..7ebcf33b 100644 --- a/art/ZZj9dLPDqjWny5kJW/art.json +++ b/art/ZZj9dLPDqjWny5kJW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":13879,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.26666666666666666,0.4117647058823529,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.0625 + (time * 20.));\\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.125, sy)).a, 2.) * 2.) * (1. - sy);\\n \\n float x = sin(deg) * radius;\\n float y = cos(deg) * radius;\\n float z = vertexId * 0.125;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0.1, 0.1,\\n 0, 0, 0, 1);\\n \\n gl_Position = camera * vec4(pos.xyz, 1);\\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 13879, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.26666666666666666, + 0.4117647058823529, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nvoid main()\n{\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.0625 + (time * 20.));\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.125, sy)).a, 2.) * 2.) * (1. - sy);\n \n float x = sin(deg) * radius;\n float y = cos(deg) * radius;\n float z = vertexId * 0.125;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0.1, 0.1,\n 0, 0, 0, 1);\n \n gl_Position = camera * vec4(pos.xyz, 1);\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-z4sw7mn5v2p75flvq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZZwMR9KfGEza6h9qC/art.json b/art/ZZwMR9KfGEza6h9qC/art.json index 9764055c..84b1e468 100644 --- a/art/ZZwMR9KfGEza6h9qC/art.json +++ b/art/ZZwMR9KfGEza6h9qC/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "dron", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocKD9cgmpithB46qFdf31lpdyttGLSjrFXGekm792_6ckvM=s96-c", - "settings": "{\"num\":922,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/dron007/suliko\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// vertexId\\n// vertexCount\\n// \\nvoid main() {\\n float PI = 3.14159265;\\n float down = floor(sqrt(vertexCount));\\n float grid = floor(vertexCount/down);\\n float x = mod(vertexId, grid)/(grid-1.); // 0..1\\n float y = floor(vertexId/grid)/(grid-1.); // 0..1\\n //float snd = 0.8;//texture2D(sound, vec2(-x,y)).a;\\n //float snd = texture2D(sound, vec2(x,y)).a;\\n float snd = texture2D(sound, vec2(-x,y)).a;\\n \\n gl_Position = vec4(cos(2.*PI*x)*snd, sin(2.*PI*y)*snd, 0, 1);\\n// gl_Position = vec4(x, y, 0, 1);\\n// gl_Position = vec4(snd, 0, 0, 1);\\n gl_PointSize = 20.*snd+3.;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 922, + "mode": "POINTS", + "sound": "https://soundcloud.com/dron007/suliko", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// vertexId\n// vertexCount\n// \nvoid main() {\n float PI = 3.14159265;\n float down = floor(sqrt(vertexCount));\n float grid = floor(vertexCount/down);\n float x = mod(vertexId, grid)/(grid-1.); // 0..1\n float y = floor(vertexId/grid)/(grid-1.); // 0..1\n //float snd = 0.8;//texture2D(sound, vec2(-x,y)).a;\n //float snd = texture2D(sound, vec2(x,y)).a;\n float snd = texture2D(sound, vec2(-x,y)).a;\n \n gl_Position = vec4(cos(2.*PI*x)*snd, sin(2.*PI*y)*snd, 0, 1);\n// gl_Position = vec4(x, y, 0, 1);\n// gl_Position = vec4(snd, 0, 0, 1);\n gl_PointSize = 20.*snd+3.;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ozlmsuubqinnu6um4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZaEqKDmErTwBskDSt/art.json b/art/ZaEqKDmErTwBskDSt/art.json index e517a673..9f2cc86e 100644 --- a/art/ZaEqKDmErTwBskDSt/art.json +++ b/art/ZaEqKDmErTwBskDSt/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "r21nomi", "avatarUrl": "https://avatars.githubusercontent.com/r21nomi?s=200", - "settings": "{\"num\":5000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n // 0 ~ POINTS_PER_CUBE - 1\\n float pointsPerCubeFromId = mod(id, POINTS_PER_CUBE);\\n // 0 ~ CUBE_POINTS_PER_FACE - 1\\n float quadId = floor(pointsPerCubeFromId / CUBE_POINTS_PER_FACE);\\n // 0 ~ 2\\n float sideId = mod(quadId, 3.);\\n // 2.5 means half value of max value for quadId (range of quadId is 0 ~ 5).\\n float flip = mix(1., -1., step(2.5, quadId)); // This become 1 or -1.\\n \\n // 0 ~ CUBE_POINTS_PER_FACE - 1\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n \\n // 0 1 2 1 2 3\\n //\\n // 0 -------- 2\\n // | |\\n // | |\\n // 1 -------- 3\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.7, sin(a)) * flip;\\n // 0 ~ 1\\n float lr = mod(sideId, 2.);\\n // 0 ~ 1\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n \\n vec3 n = vec3(0, 1, 0) * flip; // This affect color of cube.\\n normal = (mat * vec4(n, 1)).xyz;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n \\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n //mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\\n //mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 5000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n // 0 ~ POINTS_PER_CUBE - 1\n float pointsPerCubeFromId = mod(id, POINTS_PER_CUBE);\n // 0 ~ CUBE_POINTS_PER_FACE - 1\n float quadId = floor(pointsPerCubeFromId / CUBE_POINTS_PER_FACE);\n // 0 ~ 2\n float sideId = mod(quadId, 3.);\n // 2.5 means half value of max value for quadId (range of quadId is 0 ~ 5).\n float flip = mix(1., -1., step(2.5, quadId)); // This become 1 or -1.\n \n // 0 ~ CUBE_POINTS_PER_FACE - 1\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n \n // 0 1 2 1 2 3\n //\n // 0 -------- 2\n // | |\n // | |\n // 1 -------- 3\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.7, sin(a)) * flip;\n // 0 ~ 1\n float lr = mod(sideId, 2.);\n // 0 ~ 1\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n \n vec3 n = vec3(0, 1, 0) * flip; // This affect color of cube.\n normal = (mat * vec4(n, 1)).xyz;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n \n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n //mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\n //mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-tv5ly96dpv69983l5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZaHRJagSTkbt5ERMW/art.json b/art/ZaHRJagSTkbt5ERMW/art.json index ae3f84f0..868dc674 100644 --- a/art/ZaHRJagSTkbt5ERMW/art.json +++ b/art/ZaHRJagSTkbt5ERMW/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":51484,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 5;\\t\\n \\n \\n \\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\\n }\\n \\n else if(num == 5) {\\n gl_Position = normalize(vec4(cos(vertexId/5.0),sin(vertexId/5.0),\\n tan(vertexId/5.0),1.0))/0.01;\\n }\\n\\n gl_PointSize = -gl_Position.z*sin(1.0)+sin(time*vertexId/500.0); \\n \\n \\n v_color = vec4(sin(vertexId/122.0),\\n sin(vertexId/122.0),\\n sin(vertexId/122.0),1);\\n}\"}", + "settings": { + "num": 51484, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 5;\t\n \n \n \n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\n }\n \n else if(num == 5) {\n gl_Position = normalize(vec4(cos(vertexId/5.0),sin(vertexId/5.0),\n tan(vertexId/5.0),1.0))/0.01;\n }\n\n gl_PointSize = -gl_Position.z*sin(1.0)+sin(time*vertexId/500.0); \n \n \n v_color = vec4(sin(vertexId/122.0),\n sin(vertexId/122.0),\n sin(vertexId/122.0),1);\n}" + }, "screenshotURL": "data/images/images-mlzw97pjp1sntjgz5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZbFWyvpmE9fXFTeD6/art.json b/art/ZbFWyvpmE9fXFTeD6/art.json index 156a8551..469f4604 100644 --- a/art/ZbFWyvpmE9fXFTeD6/art.json +++ b/art/ZbFWyvpmE9fXFTeD6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "vincent23", "avatarUrl": "https://avatars.githubusercontent.com/vincent23?s=200", - "settings": "{\"num\":33162,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bensley/tiptoe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.4196078431372549,0.3411764705882353,0.49411764705882355,1],\"shader\":\"float vdc(int n, float base)\\n{\\n\\tfloat vdc = 0.;\\n\\tfloat denom = 1.;\\n // valid for n < 131072 (base 2)\\n\\tfor (int i = 0; i < 17; i++)\\n\\t{\\n\\t\\tdenom *= base;\\n\\t\\tvdc += mod(float(n), base) / denom;\\n\\t\\tn /= int(base);\\n\\t}\\n\\treturn vdc;\\n}\\n\\nvec2 hammersley2d(int i, int N) {\\n\\treturn vec2(float(i)/float(N), vdc(i, 2.));\\n}\\n\\nvec3 hammersley3d(int i, int N) {\\n\\treturn vec3(float(i)/float(N), vdc(i, 2.), vdc(i, 3.));\\n}\\n\\nfloat cheapHash(ivec2 c) {\\n\\tint x = int(0x3504f333)*c.x*c.x + c.y;\\n\\tint y = int(0xf1bbcdcb)*c.y*c.y + c.x;\\n\\treturn float(x*y)*(2.0/8589934592.0)+0.5;\\n}\\n\\nfloat waterNoise(vec2 p) {\\n\\tivec2 index = ivec2(floor(p));\\n\\tvec2 d = smoothstep(0., 1., fract(p));\\n\\tfloat result = 0.;\\n\\tfloat v00 = cheapHash(index);\\n\\tfloat v01 = cheapHash(index + ivec2(0, 1));\\n\\tfloat v10 = cheapHash(index + ivec2(1, 0));\\n\\tfloat v11 = cheapHash(index + ivec2(1, 1));\\n\\treturn mix(mix(v00, v10, d.x), mix(v01, v11, d.x), d.y) * 2. - 1.;\\n}\\n\\nfloat f2Sphere(vec2 p, float r) {\\n\\treturn length(p) - r;\\n}\\n\\nfloat fSphere(vec3 p, float r) {\\n\\treturn length(p) - r;\\n}\\n\\nvoid pTrans(inout float p, float d) {\\n p -= d;\\n}\\n\\nvoid pTrans(inout vec2 p, vec2 d) {\\n\\tp -= d;\\n}\\n\\nvoid pTrans(inout vec3 p, vec3 d) {\\n\\tp -= d;\\n}\\n\\nvoid pRot(inout vec2 p, float a) {\\n\\tp = cos(a)*p + sin(a)*vec2(p.y, -p.x);\\n}\\n\\nfloat fTorus(vec3 p, float smallRadius, float largeRadius) {\\n\\treturn length(vec2(length(p.xz) - largeRadius, p.y)) - smallRadius;\\n}\\n\\n\\nfloat vmax(vec3 v) {\\n\\treturn max(max(v.x, v.y), v.z);\\n}\\n\\nfloat fBox(vec3 p, vec3 b) {\\n\\tvec3 d = abs(p) - b;\\n\\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\\n}\\n\\nfloat sgn(float x) {\\n\\treturn (x<0.)?-1.:1.;\\n}\\n\\nvec2 sgn(vec2 v) {\\n\\treturn vec2(sgn(v.x), sgn(v.y));\\n}\\n\\nfloat pMirror (inout float p, float dist) {\\n\\tfloat s = sgn(p);\\n\\tp = abs(p)-dist;\\n\\treturn s;\\n}\\n\\n// Repeat in two dimensions\\nvec2 pMod2(inout vec2 p, vec2 size) {\\n\\tvec2 c = floor((p + size*0.5)/size);\\n\\tp = mod(p + size*0.5,size) - size*0.5;\\n\\treturn c;\\n}\\n\\nfloat PI = acos(-1.);\\n\\n// Repeat around the origin by a fixed angle.\\n// For easier use, num of repetitions is use to specify the angle.\\nfloat pModPolar(inout vec2 p, float repetitions) {\\n\\tfloat angle = 2.*PI/repetitions;\\n\\tfloat a = atan(p.y, p.x) + angle/2.;\\n\\tfloat r = length(p);\\n\\tfloat c = floor(a/angle);\\n\\ta = mod(a,angle) - angle/2.;\\n\\tp = vec2(cos(a), sin(a))*r;\\n\\t// For an odd number of repetitions, fix cell index of the cell in -x direction\\n\\t// (cell index would be e.g. -5 and 5 in the two halves of the cell):\\n\\tif (abs(c) >= (repetitions/2.)) c = abs(c);\\n\\treturn c;\\n}\\n\\n\\nfloat bps = 178. / 60.;\\n\\nfloat Tau = 2. * PI;\\n\\n\\nfloat f2Plane(vec2 p, vec2 n) {\\n\\t// n must be normalized\\n\\treturn dot(p, n);\\n}\\n\\nvec2 unitVector(float phi) {\\n\\treturn vec2(cos(phi), sin(phi));\\n}\\n\\nfloat f2PlaneAngle(vec2 p, float phi) {\\n\\treturn f2Plane(p, unitVector(phi));\\n}\\n\\nfloat max3(float a, float b, float c) {\\n\\treturn max(max(a, b), c);\\n}\\n\\n// r is the radius from the origin to the vertices\\nfloat f2Pentaprism(vec2 p, float r) {\\n\\tfloat phi1 = radians(108. / 2.);\\n\\tfloat phi2 = radians(-18.);\\n\\tfloat offset = r * cos(Tau / 5. / 2.);\\n\\n\\tvec2 q = vec2(abs(p.x), p.y);\\n\\tfloat side1 = f2PlaneAngle(q, phi1);\\n\\tfloat side2 = -p.y;\\n\\tfloat side3 = f2PlaneAngle(q, phi2);\\n\\n\\tfloat pentagon = max3(side1, side2, side3) - offset;\\n\\n\\treturn pentagon;\\n}\\n\\nfloat f2Supershape(vec2 p, float a, float b, float m, float n1, float n2, float n3) {\\n\\tfloat phi = atan(p.y, p.x);\\n\\tfloat d = length(p);\\n\\n\\tfloat m4 = m / 4.;\\n\\n\\tfloat c = cos(m4 * phi);\\n\\tfloat s = sin(m4 * phi);\\n\\n\\tfloat ca = c / a;\\n\\tfloat sb = s / b;\\n\\n\\tfloat gc = ca < 0. ? -1. : 1.;\\n\\tfloat gs = sb < 0. ? -1. : 1.;\\n\\n\\tfloat absc = ca * gc;\\n\\tfloat abss = sb * gs;\\n\\n\\tfloat ab2 = pow(absc, n2);\\n\\tfloat ab3 = pow(abss, n3);\\n\\n\\t//float ab21 = pow(absc, n2 - 1.);\\n\\t//float ab31 = pow(abss, n3 - 1.);\\n\\tfloat ab21 = ab2 / absc;\\n\\tfloat ab31 = ab3 / abss;\\n\\n\\tfloat rw = ab2 + ab3;\\n\\tfloat r = pow(rw, -1./n1);\\n\\n\\tfloat k = -n2 * ab21 * gc / a * s;\\n\\tfloat l = n3 * ab31 * gs / b * c;\\n\\n\\t//float drpre = m4 / n1 * pow(rw, -1./n1 - 1.);\\n\\tfloat drpre = m4 / n1 * r / rw;\\n\\tfloat dr2 = drpre * drpre * (k * k + 2. * k * l + l * l);\\n\\n\\tfloat f = (d - r) / sqrt(1. + dr2);\\n\\treturn f;\\n}\\n\\nfloat fTorusWeird(vec3 p, float scale) {\\n float rBig = scale;\\n float n1 = 1.;\\n float n2 = (sin(time * Tau * bps / 16.) * .5 + .5) * .7 + .3;\\n float n3 = (cos(time * Tau * bps / 32.) * .5 + .5) * .8 + .2;\\n vec2 q = vec2(f2Supershape(p.xz, rBig, rBig, 7., n1, n2, n3), p.y);\\n return f2Sphere(q, scale * .4);\\n}\\n\\nfloat f(vec3 p, out int material) {\\n vec3 p_box = p;\\n pRot(p_box.xy, time * 0.91);\\n pRot(p_box.yz, time * 0.93);\\n pRot(p_box.xz, time * 0.95);\\n float f_box = fTorusWeird(p_box, .2);\\n \\n pRot(p.xy, .7);\\n pRot(p.xz, time * 2. * PI * bps / 8.);\\n pModPolar(p.xz, 8.);\\n pTrans(p.x, .7);\\n pRot(p.xz, PI* 2. * 3. * p.y);\\n pTrans(p.x, .01);\\n float f_cylinders = f2Sphere(p.xz, .1);\\n \\n if (f_box < f_cylinders) {\\n material = 0;\\n \\treturn f_box;\\n } else {\\n material = 1;\\n return f_cylinders;\\n }\\n}\\n\\nvec3 sdfNormal(vec3 p, float e) {\\n\\tvec3 s[6];\\n\\ts[0] = vec3(e,0,0);\\n\\ts[1] = vec3(0,e,0);\\n\\ts[2] = vec3(0,0,e);\\n\\ts[3] = vec3(-e,0,0);\\n\\ts[4] = vec3(0,-e,0);\\n\\ts[5] = vec3(0,0,-e);\\n\\tfloat d[6];\\n int m;\\n\\tfor(int i = 0; i < 6; i++) {\\n\\t\\td[i] = f(p + s[i], m);\\n\\t}\\n\\treturn normalize(vec3(d[0] - d[3], d[1] - d[4], d[2] - d[5]));\\n}\\n\\nvoid main() {\\n float phi = vertexId * 6.28 * time;\\n vec3 p = hammersley3d(int(vertexId), int(vertexCount));\\n p.xy = p.xy * 2. - 1.;\\n \\n float freq = .08;\\n float foo = texture2D(sound, vec2(freq, .0)).r;\\n foo *= texture2D(sound, vec2(freq, .1)).r;\\n foo *= texture2D(sound, vec2(freq, .2)).r;\\n int material;\\n for (int i = 0; i < 3; i++) {\\n\\tvec3 direction = -sdfNormal(p, .01);\\n float d = f(p, material);\\n p += d * direction * (1. - foo);\\n }\\n \\n p.xy *= .9;\\n p.y *= resolution.x / resolution.y;\\n gl_PointSize = 10. + 3. * sin(vertexId + time * bps * 2. * PI * .25);\\n gl_PointSize *= .4;\\n gl_Position = vec4(p, 1);\\n \\n vec3 normal = sdfNormal(p, .01);\\n vec3 lightDir = vec3(0., 0., 1.);\\n \\n float x = smoothstep(.0, .3, abs(f(p, material)));\\n x = (1. - (1. - smoothstep(-.5, 1., x)));\\n \\n\\n vec3 color = mix(vec3(186, 186, 232) / 255., vec3(231, 231, 184) / 255. ,x);\\n if (material == 0) {\\n gl_PointSize *= 3.;\\n color = vec3(1, 0, 0);\\n }\\n color *= .4;\\n v_color = vec4(color, .05);\\n}\"}", + "settings": { + "num": 33162, + "mode": "POINTS", + "sound": "https://soundcloud.com/bensley/tiptoe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.4196078431372549, + 0.3411764705882353, + 0.49411764705882355, + 1 + ], + "shader": "float vdc(int n, float base)\n{\n\tfloat vdc = 0.;\n\tfloat denom = 1.;\n // valid for n < 131072 (base 2)\n\tfor (int i = 0; i < 17; i++)\n\t{\n\t\tdenom *= base;\n\t\tvdc += mod(float(n), base) / denom;\n\t\tn /= int(base);\n\t}\n\treturn vdc;\n}\n\nvec2 hammersley2d(int i, int N) {\n\treturn vec2(float(i)/float(N), vdc(i, 2.));\n}\n\nvec3 hammersley3d(int i, int N) {\n\treturn vec3(float(i)/float(N), vdc(i, 2.), vdc(i, 3.));\n}\n\nfloat cheapHash(ivec2 c) {\n\tint x = int(0x3504f333)*c.x*c.x + c.y;\n\tint y = int(0xf1bbcdcb)*c.y*c.y + c.x;\n\treturn float(x*y)*(2.0/8589934592.0)+0.5;\n}\n\nfloat waterNoise(vec2 p) {\n\tivec2 index = ivec2(floor(p));\n\tvec2 d = smoothstep(0., 1., fract(p));\n\tfloat result = 0.;\n\tfloat v00 = cheapHash(index);\n\tfloat v01 = cheapHash(index + ivec2(0, 1));\n\tfloat v10 = cheapHash(index + ivec2(1, 0));\n\tfloat v11 = cheapHash(index + ivec2(1, 1));\n\treturn mix(mix(v00, v10, d.x), mix(v01, v11, d.x), d.y) * 2. - 1.;\n}\n\nfloat f2Sphere(vec2 p, float r) {\n\treturn length(p) - r;\n}\n\nfloat fSphere(vec3 p, float r) {\n\treturn length(p) - r;\n}\n\nvoid pTrans(inout float p, float d) {\n p -= d;\n}\n\nvoid pTrans(inout vec2 p, vec2 d) {\n\tp -= d;\n}\n\nvoid pTrans(inout vec3 p, vec3 d) {\n\tp -= d;\n}\n\nvoid pRot(inout vec2 p, float a) {\n\tp = cos(a)*p + sin(a)*vec2(p.y, -p.x);\n}\n\nfloat fTorus(vec3 p, float smallRadius, float largeRadius) {\n\treturn length(vec2(length(p.xz) - largeRadius, p.y)) - smallRadius;\n}\n\n\nfloat vmax(vec3 v) {\n\treturn max(max(v.x, v.y), v.z);\n}\n\nfloat fBox(vec3 p, vec3 b) {\n\tvec3 d = abs(p) - b;\n\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\n}\n\nfloat sgn(float x) {\n\treturn (x<0.)?-1.:1.;\n}\n\nvec2 sgn(vec2 v) {\n\treturn vec2(sgn(v.x), sgn(v.y));\n}\n\nfloat pMirror (inout float p, float dist) {\n\tfloat s = sgn(p);\n\tp = abs(p)-dist;\n\treturn s;\n}\n\n// Repeat in two dimensions\nvec2 pMod2(inout vec2 p, vec2 size) {\n\tvec2 c = floor((p + size*0.5)/size);\n\tp = mod(p + size*0.5,size) - size*0.5;\n\treturn c;\n}\n\nfloat PI = acos(-1.);\n\n// Repeat around the origin by a fixed angle.\n// For easier use, num of repetitions is use to specify the angle.\nfloat pModPolar(inout vec2 p, float repetitions) {\n\tfloat angle = 2.*PI/repetitions;\n\tfloat a = atan(p.y, p.x) + angle/2.;\n\tfloat r = length(p);\n\tfloat c = floor(a/angle);\n\ta = mod(a,angle) - angle/2.;\n\tp = vec2(cos(a), sin(a))*r;\n\t// For an odd number of repetitions, fix cell index of the cell in -x direction\n\t// (cell index would be e.g. -5 and 5 in the two halves of the cell):\n\tif (abs(c) >= (repetitions/2.)) c = abs(c);\n\treturn c;\n}\n\n\nfloat bps = 178. / 60.;\n\nfloat Tau = 2. * PI;\n\n\nfloat f2Plane(vec2 p, vec2 n) {\n\t// n must be normalized\n\treturn dot(p, n);\n}\n\nvec2 unitVector(float phi) {\n\treturn vec2(cos(phi), sin(phi));\n}\n\nfloat f2PlaneAngle(vec2 p, float phi) {\n\treturn f2Plane(p, unitVector(phi));\n}\n\nfloat max3(float a, float b, float c) {\n\treturn max(max(a, b), c);\n}\n\n// r is the radius from the origin to the vertices\nfloat f2Pentaprism(vec2 p, float r) {\n\tfloat phi1 = radians(108. / 2.);\n\tfloat phi2 = radians(-18.);\n\tfloat offset = r * cos(Tau / 5. / 2.);\n\n\tvec2 q = vec2(abs(p.x), p.y);\n\tfloat side1 = f2PlaneAngle(q, phi1);\n\tfloat side2 = -p.y;\n\tfloat side3 = f2PlaneAngle(q, phi2);\n\n\tfloat pentagon = max3(side1, side2, side3) - offset;\n\n\treturn pentagon;\n}\n\nfloat f2Supershape(vec2 p, float a, float b, float m, float n1, float n2, float n3) {\n\tfloat phi = atan(p.y, p.x);\n\tfloat d = length(p);\n\n\tfloat m4 = m / 4.;\n\n\tfloat c = cos(m4 * phi);\n\tfloat s = sin(m4 * phi);\n\n\tfloat ca = c / a;\n\tfloat sb = s / b;\n\n\tfloat gc = ca < 0. ? -1. : 1.;\n\tfloat gs = sb < 0. ? -1. : 1.;\n\n\tfloat absc = ca * gc;\n\tfloat abss = sb * gs;\n\n\tfloat ab2 = pow(absc, n2);\n\tfloat ab3 = pow(abss, n3);\n\n\t//float ab21 = pow(absc, n2 - 1.);\n\t//float ab31 = pow(abss, n3 - 1.);\n\tfloat ab21 = ab2 / absc;\n\tfloat ab31 = ab3 / abss;\n\n\tfloat rw = ab2 + ab3;\n\tfloat r = pow(rw, -1./n1);\n\n\tfloat k = -n2 * ab21 * gc / a * s;\n\tfloat l = n3 * ab31 * gs / b * c;\n\n\t//float drpre = m4 / n1 * pow(rw, -1./n1 - 1.);\n\tfloat drpre = m4 / n1 * r / rw;\n\tfloat dr2 = drpre * drpre * (k * k + 2. * k * l + l * l);\n\n\tfloat f = (d - r) / sqrt(1. + dr2);\n\treturn f;\n}\n\nfloat fTorusWeird(vec3 p, float scale) {\n float rBig = scale;\n float n1 = 1.;\n float n2 = (sin(time * Tau * bps / 16.) * .5 + .5) * .7 + .3;\n float n3 = (cos(time * Tau * bps / 32.) * .5 + .5) * .8 + .2;\n vec2 q = vec2(f2Supershape(p.xz, rBig, rBig, 7., n1, n2, n3), p.y);\n return f2Sphere(q, scale * .4);\n}\n\nfloat f(vec3 p, out int material) {\n vec3 p_box = p;\n pRot(p_box.xy, time * 0.91);\n pRot(p_box.yz, time * 0.93);\n pRot(p_box.xz, time * 0.95);\n float f_box = fTorusWeird(p_box, .2);\n \n pRot(p.xy, .7);\n pRot(p.xz, time * 2. * PI * bps / 8.);\n pModPolar(p.xz, 8.);\n pTrans(p.x, .7);\n pRot(p.xz, PI* 2. * 3. * p.y);\n pTrans(p.x, .01);\n float f_cylinders = f2Sphere(p.xz, .1);\n \n if (f_box < f_cylinders) {\n material = 0;\n \treturn f_box;\n } else {\n material = 1;\n return f_cylinders;\n }\n}\n\nvec3 sdfNormal(vec3 p, float e) {\n\tvec3 s[6];\n\ts[0] = vec3(e,0,0);\n\ts[1] = vec3(0,e,0);\n\ts[2] = vec3(0,0,e);\n\ts[3] = vec3(-e,0,0);\n\ts[4] = vec3(0,-e,0);\n\ts[5] = vec3(0,0,-e);\n\tfloat d[6];\n int m;\n\tfor(int i = 0; i < 6; i++) {\n\t\td[i] = f(p + s[i], m);\n\t}\n\treturn normalize(vec3(d[0] - d[3], d[1] - d[4], d[2] - d[5]));\n}\n\nvoid main() {\n float phi = vertexId * 6.28 * time;\n vec3 p = hammersley3d(int(vertexId), int(vertexCount));\n p.xy = p.xy * 2. - 1.;\n \n float freq = .08;\n float foo = texture2D(sound, vec2(freq, .0)).r;\n foo *= texture2D(sound, vec2(freq, .1)).r;\n foo *= texture2D(sound, vec2(freq, .2)).r;\n int material;\n for (int i = 0; i < 3; i++) {\n\tvec3 direction = -sdfNormal(p, .01);\n float d = f(p, material);\n p += d * direction * (1. - foo);\n }\n \n p.xy *= .9;\n p.y *= resolution.x / resolution.y;\n gl_PointSize = 10. + 3. * sin(vertexId + time * bps * 2. * PI * .25);\n gl_PointSize *= .4;\n gl_Position = vec4(p, 1);\n \n vec3 normal = sdfNormal(p, .01);\n vec3 lightDir = vec3(0., 0., 1.);\n \n float x = smoothstep(.0, .3, abs(f(p, material)));\n x = (1. - (1. - smoothstep(-.5, 1., x)));\n \n\n vec3 color = mix(vec3(186, 186, 232) / 255., vec3(231, 231, 184) / 255. ,x);\n if (material == 0) {\n gl_PointSize *= 3.;\n color = vec3(1, 0, 0);\n }\n color *= .4;\n v_color = vec4(color, .05);\n}" + }, "screenshotURL": "data/images/images-bxhtcgyra7ayb6eg5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZbRaEcwQdQBWXwaX9/art.json b/art/ZbRaEcwQdQBWXwaX9/art.json index ed80cff5..f0d6872d 100644 --- a/art/ZbRaEcwQdQBWXwaX9/art.json +++ b/art/ZbRaEcwQdQBWXwaX9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8196078431372549,0.8196078431372549,0.8196078431372549,1],\"shader\":\"void main(){\\n v_color = vec4(0.0,0.0,0.0,1);\\n gl_PointSize = 20.0;\\n \\n float width = 10.0;\\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n x = x / (width - 1.0);\\n y = y / (width - 1.0);\\n \\n x = x * 2.0 - 1.0;\\n y = y * 2.0 - 1.0;\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n x = x + xOffset;\\n \\n float yOffset = cos(time + x) * 0.2;\\n y = y + yOffset;\\n \\n vec2 xy = vec2(x ,y) * 0.5;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8196078431372549, + 0.8196078431372549, + 0.8196078431372549, + 1 + ], + "shader": "void main(){\n v_color = vec4(0.0,0.0,0.0,1);\n gl_PointSize = 20.0;\n \n float width = 10.0;\n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n x = x / (width - 1.0);\n y = y / (width - 1.0);\n \n x = x * 2.0 - 1.0;\n y = y * 2.0 - 1.0;\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n x = x + xOffset;\n \n float yOffset = cos(time + x) * 0.2;\n y = y + yOffset;\n \n vec2 xy = vec2(x ,y) * 0.5;\n \n gl_Position = vec4(xy,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-8zjguu4aub63zn5ai-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZdjbNTWSNwcCQRwPT/art.json b/art/ZdjbNTWSNwcCQRwPT/art.json index 3234af33..ce64c43e 100644 --- a/art/ZdjbNTWSNwcCQRwPT/art.json +++ b/art/ZdjbNTWSNwcCQRwPT/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,3.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,2,0,-1,2,1,0,0,0,0,-1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 3.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.0;\\n \\tvec2 height = vec2(10.,0.6);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,3.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,2,0,-1,2,1,0,0,0,0,-1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 3.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.0;\n \tvec2 height = vec2(10.,0.6);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-9r689snvffufx67by-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZfE8NGNHiwufD7MPr/art.json b/art/ZfE8NGNHiwufD7MPr/art.json index 676b2c71..4243f6ee 100644 --- a/art/ZfE8NGNHiwufD7MPr/art.json +++ b/art/ZfE8NGNHiwufD7MPr/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":22731,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0784313725490196,0.06274509803921569,0.0784313725490196,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 4.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n//KVerticesNumber=50000\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.2, 1.5)/cos(time*1.6)*parameter3);\\n vec4 K = vec4(2.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle/cos(time* 0.16 ));\\n float c =cos( angle *32.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2*2.),\\n 1.-s, 0, 2, 0.4,\\n 0, 0, 0, 12); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle * 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0.1, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 0.33, -1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0.5, 0,\\n 0, 1, 0, 0,\\n 1, -1, 0, -0.9,\\n 0, 0, 0, 2.4);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 1,\\n 0, -0.1, 0.5, 2.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n 0, 0, 1.5, 1,\\n 0, 0.7+s, mouse.x, s-1.31,\\n s-0.5, 1.3, 0, 1.+s,\\n 2, 0.5, 0.2, 1.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p - 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 11.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 5.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (12.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 1.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t1.7) + tan((t * 0.013) + parameter6 -t) * sin(t -0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 12.0);\\n float side = mix(1., 5.3, step(2., mod(circleId, 311.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * 2.1)));\\n float start = fract(hash(circleId * 23.33) + cos(time * .03 + circleId) *0.1 /mouse.x);\\n float end = start * 1.3/vertexCount;\\n start + hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 1.8 *1.3)) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - parameter2 + 0.103) * 0.4;\\n offset.y += goop(circleId * time * 0.13)-pos.x;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset-parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x-circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11.1 - uv.y) * pow(snd * 66.51, snd-6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 22731, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.06274509803921569, + 0.0784313725490196, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 4.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n//KVerticesNumber=50000\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.2, 1.5)/cos(time*1.6)*parameter3);\n vec4 K = vec4(2.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle/cos(time* 0.16 ));\n float c =cos( angle *32.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2*2.),\n 1.-s, 0, 2, 0.4,\n 0, 0, 0, 12); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle * 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0.1, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 0.33, -1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0.5, 0,\n 0, 1, 0, 0,\n 1, -1, 0, -0.9,\n 0, 0, 0, 2.4);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 1,\n 0, -0.1, 0.5, 2.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n 0, 0, 1.5, 1,\n 0, 0.7+s, mouse.x, s-1.31,\n s-0.5, 1.3, 0, 1.+s,\n 2, 0.5, 0.2, 1.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p - 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 11.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 5.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (12.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 1.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t1.7) + tan((t * 0.013) + parameter6 -t) * sin(t -0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 12.0);\n float side = mix(1., 5.3, step(2., mod(circleId, 311.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * 2.1)));\n float start = fract(hash(circleId * 23.33) + cos(time * .03 + circleId) *0.1 /mouse.x);\n float end = start * 1.3/vertexCount;\n start + hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 1.8 *1.3)) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - parameter2 + 0.103) * 0.4;\n offset.y += goop(circleId * time * 0.13)-pos.x;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset-parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x-circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11.1 - uv.y) * pow(snd * 66.51, snd-6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-oiqcciwboto9vgl2b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZfXn2xm6JJh3o5b7T/art.json b/art/ZfXn2xm6JJh3o5b7T/art.json index f7483a97..ae1732a6 100644 --- a/art/ZfXn2xm6JJh3o5b7T/art.json +++ b/art/ZfXn2xm6JJh3o5b7T/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":22021,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n// Tuned via XShade (http://www.funparadigm.com/xshad\\n#define kp0 2.6//KParameter -22.>>22.\\n#define kp1 -1.//KParameter -3.>>3.\\n//KVerticesNumber=41000.\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(90.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),1.3-mouse.x,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0.5,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 2.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 8.;\\n\\n \\tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.20* kp1;\\n \\tvec2 height = vec2(22.*kp1,0.6);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\\n \\n \\tif (indexCircle > snd2 * 100.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 5.+kp1);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(1,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(-41,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis,0,\\n eye,0.8);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n 22.-dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 22021, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n//KDrawmode=GL_TRIANGLE_STRIP\n// Tuned via XShade (http://www.funparadigm.com/xshad\n#define kp0 2.6//KParameter -22.>>22.\n#define kp1 -1.//KParameter -3.>>3.\n//KVerticesNumber=41000.\n\n////////////////////////////////////////////////////////////\n#define PI radians(90.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),1.3-mouse.x,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0.5,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 2.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 8.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.20* kp1;\n \tvec2 height = vec2(22.*kp1,0.6);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\n \n \tif (indexCircle > snd2 * 100.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 5.+kp1);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(1,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(-41,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 3., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis,0,\n eye,0.8);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n 22.-dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-3vk5ria549kvtwiwm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZjCyyWmnuKxxTAkvt/art.json b/art/ZjCyyWmnuKxxTAkvt/art.json index 9daab77d..018285a0 100644 --- a/art/ZjCyyWmnuKxxTAkvt/art.json +++ b/art/ZjCyyWmnuKxxTAkvt/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jluethi", "avatarUrl": "https://secure.gravatar.com/avatar/21e93db3614e6e91a28d7f82b4e44433?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/jaems_lu/cowbop-201019-1158\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.14901960784313725,0.12941176470588237,0.27058823529411763,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\nc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0/ 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n \\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across) ;\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.3;\\n \\n \\n float sv = abs(v - .5) * 2.;\\n float su = abs(u - .5) * 2.;\\n \\n \\n float ux = u * 2. -1. +xoff;\\n float vy = v * 2. -1. +yoff;\\n \\n vec2 xy =vec2(ux, vy)* 1.3;\\n \\n float snd = texture2D(sound, vec2(su* .5,sv)).a;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 25.;\\n \\n \\ngl_Position = vec4(xy,0,1);\\n \\n gl_PointSize = snd * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\nfloat hue = u * .1 + sin(time + v *20.) *0.05;\\nfloat sat = 1.;\\nfloat val = pow(snd,.9 - 10.);//;sin(time + v * u * 20.0) * 0.5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(snd,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/jaems_lu/cowbop-201019-1158", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.14901960784313725, + 0.12941176470588237, + 0.27058823529411763, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\nc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0/ 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n \n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across) ;\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.3;\n \n \n float sv = abs(v - .5) * 2.;\n float su = abs(u - .5) * 2.;\n \n \n float ux = u * 2. -1. +xoff;\n float vy = v * 2. -1. +yoff;\n \n vec2 xy =vec2(ux, vy)* 1.3;\n \n float snd = texture2D(sound, vec2(su* .5,sv)).a;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 25.;\n \n \ngl_Position = vec4(xy,0,1);\n \n gl_PointSize = snd * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \nfloat hue = u * .1 + sin(time + v *20.) *0.05;\nfloat sat = 1.;\nfloat val = pow(snd,.9 - 10.);//;sin(time + v * u * 20.0) * 0.5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(snd,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-j05xfwnj8al0gnmuo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZkzFFuHEAaQzd2eGC/art.json b/art/ZkzFFuHEAaQzd2eGC/art.json index 61a28148..4579105c 100644 --- a/art/ZkzFFuHEAaQzd2eGC/art.json +++ b/art/ZkzFFuHEAaQzd2eGC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "julien", "avatarUrl": "https://avatars.githubusercontent.com/julien?s=200", - "settings": "{\"num\":533,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.0196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.09) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3; // x,y pos and scale;\\n\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n \\n float soff = sin(time + x * y * 0.02) * 8.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 533, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.0196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.09) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3; // x,y pos and scale;\n\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n \n float soff = sin(time + x * y * 0.02) * 8.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-ok1qjn23zednusf1u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZoyrdxZiwDYNfzT53/art.json b/art/ZoyrdxZiwDYNfzT53/art.json index eede2616..58fac05f 100644 --- a/art/ZoyrdxZiwDYNfzT53/art.json +++ b/art/ZoyrdxZiwDYNfzT53/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "shtrompel", "avatarUrl": "https://lh4.googleusercontent.com/-zzOobLO0ab8/AAAAAAAAAAI/AAAAAAAAANE/T3yiwRxnSlA/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lefaguette/extreme-meme-mashup\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\n\\nvoid main() {\\n float across = 50.;\\n float x, y, dist;\\n vec2 pos, a, b;\\n \\n //Calculate Position\\n x = mod(vertexId, across);\\n y = floor(vertexId / across);\\n \\n pos.x = x / across;\\n pos.y = y / across;\\n \\n pos.x = pos.x * 2. - 1.;\\n pos.y = pos.y * 2. - 1.;\\n \\n \\n //Calculate distance from mouse\\n dist = sqrt(pow(pos.x - mouse.x, 2.) + pow(pos.y - mouse.y, 2.));\\n dist /= 1.25;\\n dist = max(dist, 0.2);\\n \\n //Dividing position by distance\\n pos /= dist;\\n \\n \\n //Apply position\\n gl_Position = vec4(pos.x, pos.y, 0, 1);\\n \\n \\n \\n gl_PointSize = 7.0;\\n \\n //float r, g, b;\\n float r = (sin(time * 2.0 + PI / 2.75) + 1.) / 2.;\\n float g = (cos(time * 1.5 + PI / 1.5) + 1.) / 2.;\\n //b = (sin(time * 1.8 + PI / 2.0) + 1.) / 2.;\\n \\n v_color = vec4(r, g, 0, 1);\\n}\\n//\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lefaguette/extreme-meme-mashup", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\n\nvoid main() {\n float across = 50.;\n float x, y, dist;\n vec2 pos, a, b;\n \n //Calculate Position\n x = mod(vertexId, across);\n y = floor(vertexId / across);\n \n pos.x = x / across;\n pos.y = y / across;\n \n pos.x = pos.x * 2. - 1.;\n pos.y = pos.y * 2. - 1.;\n \n \n //Calculate distance from mouse\n dist = sqrt(pow(pos.x - mouse.x, 2.) + pow(pos.y - mouse.y, 2.));\n dist /= 1.25;\n dist = max(dist, 0.2);\n \n //Dividing position by distance\n pos /= dist;\n \n \n //Apply position\n gl_Position = vec4(pos.x, pos.y, 0, 1);\n \n \n \n gl_PointSize = 7.0;\n \n //float r, g, b;\n float r = (sin(time * 2.0 + PI / 2.75) + 1.) / 2.;\n float g = (cos(time * 1.5 + PI / 1.5) + 1.) / 2.;\n //b = (sin(time * 1.8 + PI / 2.0) + 1.) / 2.;\n \n v_color = vec4(r, g, 0, 1);\n}\n//" + }, "screenshotURL": "data/images/images-hmkp2nfr8bly8vwei-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZpTRRCPeXztEN8eLo/art.json b/art/ZpTRRCPeXztEN8eLo/art.json index c9f44bc4..cde37099 100644 --- a/art/ZpTRRCPeXztEN8eLo/art.json +++ b/art/ZpTRRCPeXztEN8eLo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float density = 50.;\\n \\n float xoff = -0.5 * sin(vertexId);\\n \\n float yoff = -0.5 * sin(time*vertexId);\\n \\n float ux = 0.01;\\n \\n float uy = 0.01;\\n \\n float x = mod(vertexId , density);\\n \\n float y = mod(floor(vertexId / density), density);\\n \\n \\n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n\\n \\n gl_PointSize = 10.; //*(sin(time*vertexId/10.)+ 1.); //mod(vertexId, density * density) / 5.;\\n\\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 10, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float density = 50.;\n \n float xoff = -0.5 * sin(vertexId);\n \n float yoff = -0.5 * sin(time*vertexId);\n \n float ux = 0.01;\n \n float uy = 0.01;\n \n float x = mod(vertexId , density);\n \n float y = mod(floor(vertexId / density), density);\n \n \n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n\n \n gl_PointSize = 10.; //*(sin(time*vertexId/10.)+ 1.); //mod(vertexId, density * density) / 5.;\n\n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-c9finxr5o8ub7ysq1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZqGJTgEXDTHA5rBjL/art.json b/art/ZqGJTgEXDTHA5rBjL/art.json index e8813f81..85abe798 100644 --- a/art/ZqGJTgEXDTHA5rBjL/art.json +++ b/art/ZqGJTgEXDTHA5rBjL/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":43701,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_LINES_LOOP\\n\\n\\n#define parameter0 3.//KParameter0 1.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n parameter3, c, s, 0,\\n 0, -s, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 1,\\n s, 0, c, 0,\\n 0, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians/parameter5);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0.2,\\n trans, 2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 43701, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_LINES_LOOP\n\n\n#define parameter0 3.//KParameter0 1.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 5.0, 1.0 / parameter2, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, .1, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n parameter3, c, s, 0,\n 0, -s, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 1,\n s, 0, c, 0,\n 0, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians/parameter5);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0.2,\n trans, 2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-nntysj1mb2vtnljdo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZqvxtvqSYZ8ThiJ3J/art.json b/art/ZqvxtvqSYZ8ThiJ3J/art.json index 75d53570..0476f672 100644 --- a/art/ZqvxtvqSYZ8ThiJ3J/art.json +++ b/art/ZqvxtvqSYZ8ThiJ3J/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Vertexshaderart : Motion\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Vertexshaderart : Motion\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-kirxfxyoftiz00usr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZtNG5CW8eJaJncLrk/art.json b/art/ZtNG5CW8eJaJncLrk/art.json index b28e0aaa..5e46743b 100644 --- a/art/ZtNG5CW8eJaJncLrk/art.json +++ b/art/ZtNG5CW8eJaJncLrk/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "sendi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GiA4oVEHO7tNcUpxHud7p60dl8Gb-TqVLeqG_Q1=s96-c", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/rudy-normale/incubificio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 2.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 1.4 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/rudy-normale/incubificio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 2.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 1.4 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-6vl4l3pjpgm0b8u43-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZvcLBFp3AkteTsGku/art.json b/art/ZvcLBFp3AkteTsGku/art.json index fc58f158..9d5e5b72 100644 --- a/art/ZvcLBFp3AkteTsGku/art.json +++ b/art/ZvcLBFp3AkteTsGku/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"void main() {\\n \\n float density = 10.;\\n \\n float xoff = -0.5;\\n \\n float yoff = -0.5;\\n \\n float ux = 0.1;\\n \\n float uy = 0.1;\\n \\n float x = mod(vertexId , density);\\n \\n float y = mod(floor(vertexId / density), density);\\n \\n \\n gl_Position = vec4(x * ux, y * uy, 0, 1);\\n\\n \\n gl_PointSize = mod(vertexId, density * density) / 5.;\\n\\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "void main() {\n \n float density = 10.;\n \n float xoff = -0.5;\n \n float yoff = -0.5;\n \n float ux = 0.1;\n \n float uy = 0.1;\n \n float x = mod(vertexId , density);\n \n float y = mod(floor(vertexId / density), density);\n \n \n gl_Position = vec4(x * ux, y * uy, 0, 1);\n\n \n gl_PointSize = mod(vertexId, density * density) / 5.;\n\n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-4wx1m3jvte423zxdn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ZwJTJhgwALcNCeGWC/art.json b/art/ZwJTJhgwALcNCeGWC/art.json index e483d8d8..fbeb766a 100644 --- a/art/ZwJTJhgwALcNCeGWC/art.json +++ b/art/ZwJTJhgwALcNCeGWC/art.json @@ -11,7 +11,19 @@ "origId": "fFEpFHbdC4ecFLuaB", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 5.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 7.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 5.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 7.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-axmkjt14yq7xcov3d-thumbnail.jpg", "views": { "$numberInt": "73" diff --git a/art/ZyWp3YSber6wbuY8a/art.json b/art/ZyWp3YSber6wbuY8a/art.json index 32750972..741a3d11 100644 --- a/art/ZyWp3YSber6wbuY8a/art.json +++ b/art/ZyWp3YSber6wbuY8a/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mrsynackster", "avatarUrl": "https://secure.gravatar.com/avatar/b289b3c15836cb88791f192c99d4b122?default=retro&size=200", - "settings": "{\"num\":26237,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount)); \\n float accross = floor(vertexCount / down); \\n \\n float x=mod(vertexId,accross);\\n float y=floor(vertexId/accross); \\n float u = x /(accross-1.); \\n float v = y / (accross-1.);\\n \\n float xoff = sin(time + y*0.2)*.1; \\n float yoff = sin(time + x*0.3)*.2; \\n \\n \\n float ux = u * 2. - 1. + xoff; \\n float vy = v * 2. - 1. + yoff; \\n \\n vec2 xy = vec2(ux,vy) *0.8; \\n \\n gl_Position = vec4(xy,0,1); \\n \\n float soff = sin(time + x * y * .1) * 5.; \\n \\n gl_PointSize = 10. + soff; \\n \\n gl_PointSize *= 20. / accross; \\n \\n gl_PointSize *= resolution.x / 600.; \\n \\n v_color = vec4(0.0,1.0,0.0,1.0);\\n \\n \\n}\"}", + "settings": { + "num": 26237, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount)); \n float accross = floor(vertexCount / down); \n \n float x=mod(vertexId,accross);\n float y=floor(vertexId/accross); \n float u = x /(accross-1.); \n float v = y / (accross-1.);\n \n float xoff = sin(time + y*0.2)*.1; \n float yoff = sin(time + x*0.3)*.2; \n \n \n float ux = u * 2. - 1. + xoff; \n float vy = v * 2. - 1. + yoff; \n \n vec2 xy = vec2(ux,vy) *0.8; \n \n gl_Position = vec4(xy,0,1); \n \n float soff = sin(time + x * y * .1) * 5.; \n \n gl_PointSize = 10. + soff; \n \n gl_PointSize *= 20. / accross; \n \n gl_PointSize *= resolution.x / 600.; \n \n v_color = vec4(0.0,1.0,0.0,1.0);\n \n \n}" + }, "screenshotURL": "data/images/images-lj9dnlq4s6grtgerk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ZzCgG7HuSE6BLGSKR/art.json b/art/ZzCgG7HuSE6BLGSKR/art.json index 0a8b3ef6..1874aff8 100644 --- a/art/ZzCgG7HuSE6BLGSKR/art.json +++ b/art/ZzCgG7HuSE6BLGSKR/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-96hk18ubib81ns45t-thumbnail.jpg", "views": { "$numberInt": "70" diff --git a/art/a2qkLCbs8jJyqJ4sJ/art.json b/art/a2qkLCbs8jJyqJ4sJ/art.json index 720b823c..a9076b98 100644 --- a/art/a2qkLCbs8jJyqJ4sJ/art.json +++ b/art/a2qkLCbs8jJyqJ4sJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":95182,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/uheplugins/bora\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.592156862745098,0.8980392156862745,0.7372549019607844,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 100.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float pointV = point / NUM_SEGMENTS;\\n float circleId = floor(vertexId / NUM_POINTS);\\n float numCircles = floor(vertexCount / NUM_POINTS);\\n float circleV = circleId / numCircles;\\n \\n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\\n \\n float angle = pointV * PI * 2.0 +5.;\\n float c = cos(angle) * mix(0.1, 1., circleV);\\n float s = sin(angle) * mix(0.25, 0.5, circleV);\\n \\n float r = mix(0., PI, circleV) + pow(snd, 5.0);\\n float rc = cos(r + sin(time * 4. + circleV * 4.));\\n float rs = sin(r + sin(time * 4. + circleV * 4.));\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\\n vec2 xy = vec2(\\n rc * c + rs * s,\\n -rs * c + rc * s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n float b = 1.0;\\n v_color.a = 1.;\\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\\n \\n gl_PointSize = 4.0;\\n gl_PointSize *= resolution.x / 1600.0;\\n}\"}", + "settings": { + "num": 95182, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/uheplugins/bora", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.592156862745098, + 0.8980392156862745, + 0.7372549019607844, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 100.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float pointV = point / NUM_SEGMENTS;\n float circleId = floor(vertexId / NUM_POINTS);\n float numCircles = floor(vertexCount / NUM_POINTS);\n float circleV = circleId / numCircles;\n \n float snd = texture2D(sound, vec2(pointV * 0.0125, (1. - circleV) * 0.1)).a;\n \n float angle = pointV * PI * 2.0 +5.;\n float c = cos(angle) * mix(0.1, 1., circleV);\n float s = sin(angle) * mix(0.25, 0.5, circleV);\n \n float r = mix(0., PI, circleV) + pow(snd, 5.0);\n float rc = cos(r + sin(time * 4. + circleV * 4.));\n float rs = sin(r + sin(time * 4. + circleV * 4.));\n \n vec2 aspect = vec2(1, resolution.x / resolution.y) * 0.8;\n vec2 xy = vec2(\n rc * c + rs * s,\n -rs * c + rc * s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n float b = 1.0;\n v_color.a = 1.;\n v_color.rgb = vec3(1. - circleV, circleV, 1) * (1. - pow(snd, 20.0));\n \n gl_PointSize = 4.0;\n gl_PointSize *= resolution.x / 1600.0;\n}" + }, "screenshotURL": "data/images/images-244ad5snqc1ucelg8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/a3JBo24QkPxvKYpja/art.json b/art/a3JBo24QkPxvKYpja/art.json index 44649911..eaaa1f07 100644 --- a/art/a3JBo24QkPxvKYpja/art.json +++ b/art/a3JBo24QkPxvKYpja/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":61995,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float vc = vertexCount / 11.;\\n \\n float x = mod(vertexId, vc);\\n float y = floor(vertexId / vc);\\n \\n float u = x / vc;\\n float v = y / vc;\\n \\n float ux = u * 2. - 1.;\\n float vy = y * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(ux, vy)).a;\\n \\n gl_PointSize = 50.0;\\n gl_Position = vec4(ux,vy-snd,0.5,1);\\n v_color = vec4(10,5,0,1);\\n}\"}", + "settings": { + "num": 61995, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float vc = vertexCount / 11.;\n \n float x = mod(vertexId, vc);\n float y = floor(vertexId / vc);\n \n float u = x / vc;\n float v = y / vc;\n \n float ux = u * 2. - 1.;\n float vy = y * 2. - 1.;\n \n float snd = texture2D(sound, vec2(ux, vy)).a;\n \n gl_PointSize = 50.0;\n gl_Position = vec4(ux,vy-snd,0.5,1);\n v_color = vec4(10,5,0,1);\n}" + }, "screenshotURL": "data/images/images-43d7yf6za24synjei-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/a3KvcpoEdK4k9gNxr/art.json b/art/a3KvcpoEdK4k9gNxr/art.json index a0548b85..a1d5b787 100644 --- a/art/a3KvcpoEdK4k9gNxr/art.json +++ b/art/a3KvcpoEdK4k9gNxr/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\\n vec4 K = vec4(1.0, 2.5 / 1.0, 1.0 / 3.0, (parameter5 - 3.0 * parameter1));\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians -parameter2);\\n \\t\\n return mat4( \\n 1, 0, 0, parameter2,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, parameter6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians- parameter3);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n parameter6, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, (2. - parameter4));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1. / parameter3,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1 + parameter3 / 2.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\n vec4 K = vec4(1.0, 2.5 / 1.0, 1.0 / 3.0, (parameter5 - 3.0 * parameter1));\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians -parameter2);\n \t\n return mat4( \n 1, 0, 0, parameter2,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, parameter6, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians- parameter3);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n parameter6, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, (2. - parameter4));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1. / parameter3,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1 + parameter3 / 2.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-4beqm4402figbyncc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/a3o5rh2HCzLMPnSbn/art.json b/art/a3o5rh2HCzLMPnSbn/art.json index 40a10aba..323f9615 100644 --- a/art/a3o5rh2HCzLMPnSbn/art.json +++ b/art/a3o5rh2HCzLMPnSbn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "leithba", "avatarUrl": "https://avatars.githubusercontent.com/LeithBA?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/manon-ariza/tortuga-deities\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nfloat radius = 0.15;\\nfloat amount = 100.;\\nfloat len = vertexCount / amount;\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (3.0 - 2.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + 1.0);\\n\\n vec4 o1 = fract(k3 * (1.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (1.0 - d.y);\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float seg = floor(vertexId/len);\\n float segId = mod(vertexId,len);\\n float v = texture2D(volume, vec2(1., (1.+seg)/amount*240.)).a;\\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\\n float n = noise(p);\\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\\n \\n x += cos(n * PI*4.) * segId * 0.000002 * s;\\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\\n \\n gl_Position = vec4(x, y, 0, 1);\\n\\n float b = 0.3 / mod(vertexId/len,1.);\\n v_color = vec4(vec3(b), 0.5);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/manon-ariza/tortuga-deities", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nfloat radius = 0.15;\nfloat amount = 100.;\nfloat len = vertexCount / amount;\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (3.0 - 2.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + 1.0);\n\n vec4 o1 = fract(k3 * (1.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (1.0 - d.y);\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float seg = floor(vertexId/len);\n float segId = mod(vertexId,len);\n float v = texture2D(volume, vec2(1., (1.+seg)/amount*240.)).a;\n float s = texture2D(floatSound, vec2(1., (1.+segId)/len*240.)).a;\n vec3 p = vec3(vertexId * 0.005, seg, time*0.1 - segId*0.001);\n float n = noise(p);\n float x = cos(vertexId/vertexCount * PI * 2.)*(v*radius+segId*0.001);\n float y = sin(vertexId/vertexCount * PI * 2.)*ratio*(v*radius+segId*0.0001);\n \n x += cos(n * PI*4.) * segId * 0.000002 * s;\n y += sin(n * PI*4.) * segId * 0.0000015 * s * ratio;\n \n gl_Position = vec4(x, y, 0, 1);\n\n float b = 0.3 / mod(vertexId/len,1.);\n v_color = vec4(vec3(b), 0.5);\n}" + }, "screenshotURL": "data/images/images-1oyzc51wdo5jdwgow-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/a4eb9XeRsqT78RngR/art.json b/art/a4eb9XeRsqT78RngR/art.json index c8d7059a..dbc84981 100644 --- a/art/a4eb9XeRsqT78RngR/art.json +++ b/art/a4eb9XeRsqT78RngR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/brianne-becker/charlie-brown-o-tannenbaum\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9764705882352941,1,0.984313725490196,1],\"shader\":\"/*\\n\\n _____, ____, ___, ___, __ _, \\n(-| | | (-|_, (-|_) (-|_) (-\\\\ | \\n _| | |_, _|__, _| \\\\_, _| \\\\_, \\\\| \\n( ( ( ( (__/ \\n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \\n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\\\_,(-(__`\\n \\\\___, _| |_, _| \\\\_, _|__, ____) _| _| | |_, _| ) ____)\\n ( ( ( ( ( ( ( ( \\n*/\\n//\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat t5p5(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\n#define PER_TREE 200.\\n#define PER_SIDE (PER_TREE / 2.)\\nvoid main() {\\n float vId = mod(vertexId, PER_TREE);\\n float treeId = floor(vertexId / PER_TREE);\\n float numTrees = floor(vertexCount / PER_TREE);\\n float treeV = treeId / numTrees;\\n float sideId = mod(vId, 2.);\\n float stemId = floor(vId / 2.);\\n float stemV = stemId / (PER_SIDE - 1.);\\n \\n \\n float r = 50.0;\\n float ct = time * .05;\\n vec3 camera = vec3(sin(ct) * r, mix(5., 15., t5p5(sin(time * .13))), cos(ct) * r);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 200.);\\n m *= cameraLookAt(camera, target, up);\\n m *= trans(vec3(m1p1(hash(treeV)), 0, m1p1(hash(treeV * 1.237))) * 100.);\\n m *= scale(vec3(1, mix(1., 3., hash(treeV * 0.541)), 1));\\n mat4 tm = rotY(stemV * PI * 6. + sideId * PI);\\n tm *= trans(vec3(0, (1. - stemV) * 5., -stemV * 2.));\\n gl_Position = m * tm * vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0 * stemV;\\n \\n vec3 p = vec3(tm[0]);\\n float light = dot(normalize(vec3(10,-20,5)), normalize(p)) * .5 + .5;\\n v_color = mix(vec4(1,0,0,1), vec4(0,.8,0,1), sideId);\\n v_color = vec4(v_color.rgb * v_color.a * light, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/brianne-becker/charlie-brown-o-tannenbaum", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9764705882352941, + 1, + 0.984313725490196, + 1 + ], + "shader": "/*\n\n _____, ____, ___, ___, __ _, \n(-| | | (-|_, (-|_) (-|_) (-\\ | \n _| | |_, _|__, _| \\_, _| \\_, \\| \n( ( ( ( (__/ \n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\_,(-(__`\n \\___, _| |_, _| \\_, _|__, ____) _| _| | |_, _| ) ____)\n ( ( ( ( ( ( ( ( \n*/\n//\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat t5p5(float v) {\n return v * .5 + .5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\n#define PER_TREE 200.\n#define PER_SIDE (PER_TREE / 2.)\nvoid main() {\n float vId = mod(vertexId, PER_TREE);\n float treeId = floor(vertexId / PER_TREE);\n float numTrees = floor(vertexCount / PER_TREE);\n float treeV = treeId / numTrees;\n float sideId = mod(vId, 2.);\n float stemId = floor(vId / 2.);\n float stemV = stemId / (PER_SIDE - 1.);\n \n \n float r = 50.0;\n float ct = time * .05;\n vec3 camera = vec3(sin(ct) * r, mix(5., 15., t5p5(sin(time * .13))), cos(ct) * r);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 200.);\n m *= cameraLookAt(camera, target, up);\n m *= trans(vec3(m1p1(hash(treeV)), 0, m1p1(hash(treeV * 1.237))) * 100.);\n m *= scale(vec3(1, mix(1., 3., hash(treeV * 0.541)), 1));\n mat4 tm = rotY(stemV * PI * 6. + sideId * PI);\n tm *= trans(vec3(0, (1. - stemV) * 5., -stemV * 2.));\n gl_Position = m * tm * vec4(0, 0, 0, 1);\n gl_PointSize = 10.0 * stemV;\n \n vec3 p = vec3(tm[0]);\n float light = dot(normalize(vec3(10,-20,5)), normalize(p)) * .5 + .5;\n v_color = mix(vec4(1,0,0,1), vec4(0,.8,0,1), sideId);\n v_color = vec4(v_color.rgb * v_color.a * light, v_color.a);\n}" + }, "screenshotURL": "data/images/images-sqxjto7jtlmpq1zoh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/a4rkLdCiX5RnyGq6x/art.json b/art/a4rkLdCiX5RnyGq6x/art.json index dd3c69ae..fe62ec2b 100644 --- a/art/a4rkLdCiX5RnyGq6x/art.json +++ b/art/a4rkLdCiX5RnyGq6x/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// hash functions\\n\\n\\n\\nvoid main() {\\n float x = vertexId * 0.1;\\n \\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// hash functions\n\n\n\nvoid main() {\n float x = vertexId * 0.1;\n \n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}\n" + }, "screenshotURL": "data/images/images-pjc745bll0s3r1avc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/a5fepCCbY5AhGFXTT/art.json b/art/a5fepCCbY5AhGFXTT/art.json index 0d2730de..8351b452 100644 --- a/art/a5fepCCbY5AhGFXTT/art.json +++ b/art/a5fepCCbY5AhGFXTT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "nezihesozen", "avatarUrl": "https://avatars.githubusercontent.com/NeziheSozen?s=200", - "settings": "{\"num\":4419,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5019607843137255,0.5019607843137255,0.5019607843137255,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\n\\n\\nvoid main() {\\n gl_PointSize=15.0;\\n gl_Position=vec4(0.0,0.0,0.0,1.0);\\n v_color=vec4(1.0,1.0,1.0,1.0);\\n}\"}", + "settings": { + "num": 4419, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5019607843137255, + 0.5019607843137255, + 0.5019607843137255, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\n\n\nvoid main() {\n gl_PointSize=15.0;\n gl_Position=vec4(0.0,0.0,0.0,1.0);\n v_color=vec4(1.0,1.0,1.0,1.0);\n}" + }, "screenshotURL": "data/images/images-l2d0dtrxveq3rn0aj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/a75Aou3fJGMJjXG5r/art.json b/art/a75Aou3fJGMJjXG5r/art.json index c18d873d..4a0a7dab 100644 --- a/art/a75Aou3fJGMJjXG5r/art.json +++ b/art/a75Aou3fJGMJjXG5r/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-ravekeeper-original-mix-plus-records-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.30196078431372547,0.7647058823529411,1,1],\"shader\":\"/*\\n\\n-=O=-\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.5, fract(abs(atan(ca, cd)) / PI + time * .1)), length(vec2(ca,cd))) * .5).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotY(ca * PI * 0.5);\\n mat *= trans(vec3(0, 0, cd) * 1.2);\\n //mat *= rotX(time + abs(ca) * 5.);\\n //mat *= rotZ(time + abs(cd) * 6.);\\n mat *= scale(vec3(0.1 * cd, mix(0.02, 0.2, pow(snd + .3, 4.)), 0.01));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = 1.;//abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.3, 5.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-4., 4., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-ravekeeper-original-mix-plus-records-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.30196078431372547, + 0.7647058823529411, + 1, + 1 + ], + "shader": "/*\n\n-=O=-\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.5, fract(abs(atan(ca, cd)) / PI + time * .1)), length(vec2(ca,cd))) * .5).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotY(ca * PI * 0.5);\n mat *= trans(vec3(0, 0, cd) * 1.2);\n //mat *= rotX(time + abs(ca) * 5.);\n //mat *= rotZ(time + abs(cd) * 6.);\n mat *= scale(vec3(0.1 * cd, mix(0.02, 0.2, pow(snd + .3, 4.)), 0.01));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = 1.;//abs(ca * cd) * 2.;\n float sat = pow(snd + 0.3, 5.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-4., 4., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-8j4khplgk7fip14s1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/a9PxcWZgDCKCjv5qK/art.json b/art/a9PxcWZgDCKCjv5qK/art.json index e6ffe8ff..4881fe78 100644 --- a/art/a9PxcWZgDCKCjv5qK/art.json +++ b/art/a9PxcWZgDCKCjv5qK/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Making a Grid\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Making a Grid\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-13mmf9wpnk8x7jrqp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aBnPmDNxFrFDiFvvL/art.json b/art/aBnPmDNxFrFDiFvvL/art.json index 174e9eb6..bca482da 100644 --- a/art/aBnPmDNxFrFDiFvvL/art.json +++ b/art/aBnPmDNxFrFDiFvvL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mohamed-asss-190506039/eminem-godzilla-venom-the-real?si=69025ec7f42140debb0b0fce4d54597c&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.); \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 4.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\nvoid main() \\n{\\n float numCircleSegments = 5.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments); \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.2);\\n mat *= trans(vec3(ux, vy, 0) * 1.5);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n\\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.01; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mohamed-asss-190506039/eminem-godzilla-venom-the-real?si=69025ec7f42140debb0b0fce4d54597c&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.); \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 4.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\nvoid main() \n{\n float numCircleSegments = 5.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments); \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.2);\n mat *= trans(vec3(ux, vy, 0) * 1.5);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n\n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * .02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.01; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-adhmaed4pn9dcrhl5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aD8f8mi353xWbSHQk/art.json b/art/aD8f8mi353xWbSHQk/art.json index 19b0edb7..de933cfe 100644 --- a/art/aD8f8mi353xWbSHQk/art.json +++ b/art/aD8f8mi353xWbSHQk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":73728,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/orbital-4/sets/orbital-tiny-foldable-cities\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 192.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.));\\nfloat snd2 = texture2D(sound, vec2(0.02 + su * 0.02, ringV * 0.5)).a;\\n snd = 1.0 + 0.05 * sin(time + u * PI * 24.) + pow(snd2, 5.) * (1. - ringV * 0.5);\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(s - snd2 * 0.4, 2.5, level);\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, -ringV); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.0;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n float sec = floor(uvfl.x * 6. + 1.0) / 6.;\\n float oa = sec * PI * 2. + -0.5;\\n float oc = cos(oa);\\n float os = sin(oa);\\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1)); \\n mat *= rotZ(uvfl.w * sin(time * 1.2) * 0.5 + time * 0.0);\\n //mat *= trans(vec3(oc, os, 0) * 0.2);\\n mat *= trans(vec3(0,-0.8,0));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = uvfl.y; //pow(abs(goop(uvfl.w)), 5.);\\n float cs = step(0.17, fract(cc * 10.));\\n float hue = ho + abs(m1p1(uvfl.x)) * 0.3 + cs * 0.05;\\n float sat = 1. - cs * 0.2;\\n float val = 1. - cs * 0.2;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n v_color.a = 0.5; //uvfl.y;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 73728, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/orbital-4/sets/orbital-tiny-foldable-cities", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 192.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.));\nfloat snd2 = texture2D(sound, vec2(0.02 + su * 0.02, ringV * 0.5)).a;\n snd = 1.0 + 0.05 * sin(time + u * PI * 24.) + pow(snd2, 5.) * (1. - ringV * 0.5);\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(s - snd2 * 0.4, 2.5, level);\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, -ringV); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.0;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n float sec = floor(uvfl.x * 6. + 1.0) / 6.;\n float oa = sec * PI * 2. + -0.5;\n float oc = cos(oa);\n float os = sin(oa);\n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1)); \n mat *= rotZ(uvfl.w * sin(time * 1.2) * 0.5 + time * 0.0);\n //mat *= trans(vec3(oc, os, 0) * 0.2);\n mat *= trans(vec3(0,-0.8,0));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = uvfl.y; //pow(abs(goop(uvfl.w)), 5.);\n float cs = step(0.17, fract(cc * 10.));\n float hue = ho + abs(m1p1(uvfl.x)) * 0.3 + cs * 0.05;\n float sat = 1. - cs * 0.2;\n float val = 1. - cs * 0.2;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n v_color.a = 0.5; //uvfl.y;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-kt6m0bz9dxa4a006z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aDTiAi7SZ3joeKxKs/art.json b/art/aDTiAi7SZ3joeKxKs/art.json index 267592f7..5c201123 100644 --- a/art/aDTiAi7SZ3joeKxKs/art.json +++ b/art/aDTiAi7SZ3joeKxKs/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n\\n#define seedFactor 0.75//KParameter 0.2>>2.\\n#define timeFactor 0.1//KParameter 0.1>>10.\\n\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by simFragCoord \\n //replace gl_FragColor by v_color\\n \\n\\tvec2 U = 5.*simFragCoord.xy/resolution.y, V; U.x -= time; V = floor(U);\\n\\tU.y = dot( cos( (8.*(time+V.x)+-3.-V.y) * max(0.,.5-length(U = fract(U)-.5)) - vec2(33,0) ), U);\\n\\t//v_color += smoothstep(-1.,1.,U/fwidth(U)).y;\\n // smoothstep(-1.,1.,U/fwidth(U)).y;\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n\n#define seedFactor 0.75//KParameter 0.2>>2.\n#define timeFactor 0.1//KParameter 0.1>>10.\n\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by simFragCoord \n //replace gl_FragColor by v_color\n \n\tvec2 U = 5.*simFragCoord.xy/resolution.y, V; U.x -= time; V = floor(U);\n\tU.y = dot( cos( (8.*(time+V.x)+-3.-V.y) * max(0.,.5-length(U = fract(U)-.5)) - vec2(33,0) ), U);\n\t//v_color += smoothstep(-1.,1.,U/fwidth(U)).y;\n // smoothstep(-1.,1.,U/fwidth(U)).y;\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-4hwvd0v8c2r3x4vc1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aDjRo3j6NPWb6isz6/art.json b/art/aDjRo3j6NPWb6isz6/art.json index 78165c2d..17371eff 100644 --- a/art/aDjRo3j6NPWb6isz6/art.json +++ b/art/aDjRo3j6NPWb6isz6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Exercise Making A Grid\\n// CS250 Spring 2022\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount /down);\\n float x = mod(vertexId ,across);\\n float y = floor(vertexId/across);\\n \\n float u= x /(across-1.);\\n float v= y/(across-1.);\\n \\n float ux = u* 2. -1.;\\n float vy = v* 2.-1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Exercise Making A Grid\n// CS250 Spring 2022\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount /down);\n float x = mod(vertexId ,across);\n float y = floor(vertexId/across);\n \n float u= x /(across-1.);\n float v= y/(across-1.);\n \n float ux = u* 2. -1.;\n float vy = v* 2.-1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.0;\n \n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-um3y19xdyza2v2n5q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aFBig76hWcPDu5Kf5/art.json b/art/aFBig76hWcPDu5Kf5/art.json index 08fc1132..eb3c2eec 100644 --- a/art/aFBig76hWcPDu5Kf5/art.json +++ b/art/aFBig76hWcPDu5Kf5/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "yonatan", "avatarUrl": "https://secure.gravatar.com/avatar/c7fabc219ab011fe8a1bd0590bcbcbd5?default=retro&size=200", - "settings": "{\"num\":46656,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* https://www.dwitter.net/d/10041\\nc.width|=f=(u,v,a,s,i)=>{for(i=6;s>29?i--:x.fillRect(u,v,9,9);f(u+S(b=i+i/21-a)*(q=s+s*S(b*6)**99),v+C(b)*q,b*2,s/2));}\\nf(960,540,t/200,600)\\n*/\\n\\n#define PI radians(180.)\\n#define TAU radians(360.)\\n// vertexCount is not a constant?\\n#define VCNT pow(6.0,3.0)\\n\\nvec3 hsv2rgb(vec3 c) { // This one came with the default shader...\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n const int levels = 6; // 6**6 = 46656 (points)\\n vec2 aspect = vec2(resolution.y / resolution.x, 1.0);\\n vec2 p = vec2(0);\\n float a = 0.0;\\n float angle = time / 400.0, mag, idMod, i = vertexId;\\n float h = 0.0;\\n float scale = 1.0;\\n for(int level = 0; level < levels; level++) {\\n a = angle * 2.0;\\n idMod = mod(i, 6.0);\\n // f(u+S(b=i+i/21-a)*(q=s+s*S(b*6)**99),v+C(b)*q,b*2,s/2));}\\n angle = idMod * TAU / 6.0 + float(levels - level) + a;\\n mag = 1.0 + pow(abs(sin(angle * 6.0)), 99.0);\\n p = p / 2.0 + vec2(sin(angle), cos(angle)) * mag;\\n h = h / 6.0 + idMod;\\n i = (i - idMod) / 6.0;\\n }\\n gl_Position = vec4(aspect * p / 2.0, 0, 1);\\n v_color = vec4(hsv2rgb(vec3(mod(h, PI), .75, .5)), 1.0);\\n gl_PointSize = 2.0;\\n}\"}", + "settings": { + "num": 46656, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* https://www.dwitter.net/d/10041\nc.width|=f=(u,v,a,s,i)=>{for(i=6;s>29?i--:x.fillRect(u,v,9,9);f(u+S(b=i+i/21-a)*(q=s+s*S(b*6)**99),v+C(b)*q,b*2,s/2));}\nf(960,540,t/200,600)\n*/\n\n#define PI radians(180.)\n#define TAU radians(360.)\n// vertexCount is not a constant?\n#define VCNT pow(6.0,3.0)\n\nvec3 hsv2rgb(vec3 c) { // This one came with the default shader...\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n const int levels = 6; // 6**6 = 46656 (points)\n vec2 aspect = vec2(resolution.y / resolution.x, 1.0);\n vec2 p = vec2(0);\n float a = 0.0;\n float angle = time / 400.0, mag, idMod, i = vertexId;\n float h = 0.0;\n float scale = 1.0;\n for(int level = 0; level < levels; level++) {\n a = angle * 2.0;\n idMod = mod(i, 6.0);\n // f(u+S(b=i+i/21-a)*(q=s+s*S(b*6)**99),v+C(b)*q,b*2,s/2));}\n angle = idMod * TAU / 6.0 + float(levels - level) + a;\n mag = 1.0 + pow(abs(sin(angle * 6.0)), 99.0);\n p = p / 2.0 + vec2(sin(angle), cos(angle)) * mag;\n h = h / 6.0 + idMod;\n i = (i - idMod) / 6.0;\n }\n gl_Position = vec4(aspect * p / 2.0, 0, 1);\n v_color = vec4(hsv2rgb(vec3(mod(h, PI), .75, .5)), 1.0);\n gl_PointSize = 2.0;\n}" + }, "screenshotURL": "data/images/images-zchd1rzdfm8xv4221-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aGMT3RwjTa9BswBkK/art.json b/art/aGMT3RwjTa9BswBkK/art.json index 324ad5bc..639bc873 100644 --- a/art/aGMT3RwjTa9BswBkK/art.json +++ b/art/aGMT3RwjTa9BswBkK/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":5963,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0,0, 10, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) { \\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 0 0 0 0 1 1 1 1 1 1 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n // x = 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\\n // y = 0 0 1 0 1 1 1 1 0 1 0 0 0\\n \\n float angle = ux /numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n \\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.05 * sc);\\n \\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.;//mix(0., 1., pump); // mix(1., -10.,av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5963, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0,0, 10, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) { \n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 0 0 0 0 1 1 1 1 1 1 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12\n // 0 0 1 1 2 2 3 3 4 4 5 5 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n // x = 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3\n // y = 0 0 1 0 1 1 1 1 0 1 0 0 0\n \n float angle = ux /numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n \n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.05 * sc);\n \n \n gl_Position = mat * pos;\n \n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.;//mix(0., 1., pump); // mix(1., -10.,av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-yekhk5ibllyvwcdez-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aHPn3XMX6j7TP3D8i/art.json b/art/aHPn3XMX6j7TP3D8i/art.json index 7577a2ee..42b54e09 100644 --- a/art/aHPn3XMX6j7TP3D8i/art.json +++ b/art/aHPn3XMX6j7TP3D8i/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":15989,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Circles from Triangles\\n//cs250\\n//spring 2023\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n \\n \\tfloat ux = floor(id /6.) + mod(id,2.);\\n \\tfloat vy = mod( floor(id/2.) + floor(id /3.),2.);\\n \\n \\n \\tfloat angle = ux / numCircleSegments * PI * 2.;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n \\n \\tfloat radius = vy + 1.;\\n \\n \\tfloat x = c * radius;\\n \\tfloat y = s * radius;\\n \\n \\n \\treturn vec2(x,y);\\n\\n\\n \\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float sliceId = floor(vertexId /6.0);\\n float oddSlice =- mod(sliceId, 2.);\\n \\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd+ 0.2 ,5.) * mix(1. , 1.1 , oddSlice );\\n \\n sc*= 20. / across;\\n \\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time *0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03*sc);\\n \\n \\n\\n \\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1 ; //sin(time + v * 20.) * .05;\\n float sat = 1. ;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n \\n hue = hue +pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 15989, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Circles from Triangles\n//cs250\n//spring 2023\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n \n \tfloat ux = floor(id /6.) + mod(id,2.);\n \tfloat vy = mod( floor(id/2.) + floor(id /3.),2.);\n \n \n \tfloat angle = ux / numCircleSegments * PI * 2.;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n \n \tfloat radius = vy + 1.;\n \n \tfloat x = c * radius;\n \tfloat y = s * radius;\n \n \n \treturn vec2(x,y);\n\n\n \n}\n\n\nvoid main() {\n \n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float sliceId = floor(vertexId /6.0);\n float oddSlice =- mod(sliceId, 2.);\n \n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd+ 0.2 ,5.) * mix(1. , 1.1 , oddSlice );\n \n sc*= 20. / across;\n \n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time *0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03*sc);\n \n \n\n \n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1 ; //sin(time + v * 20.) * .05;\n float sat = 1. ;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n \n hue = hue +pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-9pxyfx6erpwokuthp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aKTdaStpa8ugaemPs/art.json b/art/aKTdaStpa8ugaemPs/art.json index 83afe71b..454e2000 100644 --- a/art/aKTdaStpa8ugaemPs/art.json +++ b/art/aKTdaStpa8ugaemPs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0, 0, 0, 1);\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0, 0, 0, 1);\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-n9t2z0wfs6yojrtp6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aKaMTCwCLH9Wy2wfG/art.json b/art/aKaMTCwCLH9Wy2wfG/art.json index 8d14a49e..f75e6a80 100644 --- a/art/aKaMTCwCLH9Wy2wfG/art.json +++ b/art/aKaMTCwCLH9Wy2wfG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":33094,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 3.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x / c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y - axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n id = mod(id, 16.0);\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\nvec4 getPart0(float id) {\\n if (id == 00.) return hypercube(0.);\\n if (id == 01.) return hypercube(3.);\\n if (id == 02.) return hypercube(3.);\\n if (id == 03.) return hypercube(8.);\\n if (id == 04.) return hypercube(8.);\\n if (id == 05.) return hypercube(2.);\\n if (id == 06.) return hypercube(2.);\\n if (id == 07.) return hypercube(0.);\\n}\\nvec4 getPart1(float id) {\\n if (id == 08.) return hypercube(0.);\\n if (id == 09.) return hypercube(4.);\\n if (id == 10.) return hypercube(4.);\\n if (id == 11.) return hypercube(10.);\\n if (id == 12.) return hypercube(10.);\\n if (id == 13.) return hypercube(3.);\\n if (id == 14.) return hypercube(8.);\\n if (id == 15.) return hypercube(13.);\\n}\\nvec4 getPart2(float id) {\\n if (id == 16.) return hypercube(2.);\\n if (id == 17.) return hypercube(9.);\\n if (id == 18.) return hypercube(4.);\\n if (id == 19.) return hypercube(9.);\\n if (id == 20.) return hypercube(10.);\\n if (id == 21.) return hypercube(13.);\\n if (id == 22.) return hypercube(13.);\\n if (id == 23.) return hypercube(9.);\\n}\\nvec4 getPart3(float id) {\\n if (id == 24.) return hypercube(1.);\\n if (id == 25.) return hypercube(6.);\\n if (id == 26.) return hypercube(6.);\\n if (id == 27.) return hypercube(11.);\\n if (id == 28.) return hypercube(11.);\\n if (id == 29.) return hypercube(5.);\\n if (id == 30.) return hypercube(5.);\\n if (id == 31.) return hypercube(1.);\\n}\\nvec4 getPart4(float id) {\\n if (id == 32.) return hypercube(7.);\\n if (id == 33.) return hypercube(14.);\\n if (id == 34.) return hypercube(14.);\\n if (id == 35.) return hypercube(15.);\\n if (id == 36.) return hypercube(15.);\\n if (id == 37.) return hypercube(12.);\\n if (id == 38.) return hypercube(12.);\\n if (id == 39.) return hypercube(7.);\\n}\\nvec4 getPart5(float id) {\\n if (id == 40.) return hypercube(1.);\\n if (id == 41.) return hypercube(7.);\\n if (id == 42.) return hypercube(6.);\\n if (id == 43.) return hypercube(14.);\\n if (id == 44.) return hypercube(11.);\\n if (id == 45.) return hypercube(15.);\\n if (id == 46.) return hypercube(5.);\\n if (id == 47.) return hypercube(12.);\\n}\\nvec4 getPart6(float id) {\\n if (id == 48.) return hypercube(2.);\\n if (id == 49.) return hypercube(5.);\\n if (id == 50.) return hypercube(8.);\\n if (id == 51.) return hypercube(11.);\\n if (id == 52.) return hypercube(13.);\\n if (id == 53.) return hypercube(15.);\\n if (id == 54.) return hypercube(9.);\\n if (id == 55.) return hypercube(12.);\\n}\\nvec4 getPart7(float id) {\\n if (id == 56.) return hypercube(0.);\\n if (id == 57.) return hypercube(1.);\\n if (id == 58.) return hypercube(3.);\\n if (id == 59.) return hypercube(6.);\\n if (id == 60.) return hypercube(10.);\\n if (id == 61.) return hypercube(14.);\\n if (id == 62.) return hypercube(4.);\\n if (id == 63.) return hypercube(7.);\\n}\\nvec4 hypercube_lines(float id)\\n{\\n id = mod(vertexId, 64.0);\\n \\n if (id >= 0. && id < 8.)\\n return getPart0(id);\\n if (id >= 8. && id < 16.)\\n return getPart1(id);\\n if (id >= 16. && id < 24.)\\n return getPart2(id);\\n if (id >= 24. && id < 32.)\\n return getPart3(id);\\n if (id >= 32. && id < 40.)\\n return getPart4(id);\\n if (id >= 40. && id < 48.)\\n return getPart5(id);\\n if (id >= 48. && id < 56.)\\n return getPart6(id);\\n if (id >= 56. && id < 64.)\\n return getPart7(id);\\n \\n return vec4(0);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 3);\\n vec4 to4 = vec4(0, 0, 1, 0);\\n vec4 up4 = vec4(0, 1, -2, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(3.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, -1);\\n vec3 up3 = vec3(0, 1, -1);\\n float theta3 = 45.0 * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.3 * TAU*sin(mouse.x));\\n t4 *= rot4xy(time * 0.125 * TAU);\\n vec4 v4 = hypercube_lines(vertexId);\\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3*mouse.y, 1.0, theta3, t3);\\n vec2 aspect = vec2(1., resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect*sin(mouse), 0., 1.);\\n v_color = vec4(1.,1.,1., 1.);\\n}\"}", + "settings": { + "num": 33094, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 3.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x / c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y - axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n id = mod(id, 16.0);\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\nvec4 getPart0(float id) {\n if (id == 00.) return hypercube(0.);\n if (id == 01.) return hypercube(3.);\n if (id == 02.) return hypercube(3.);\n if (id == 03.) return hypercube(8.);\n if (id == 04.) return hypercube(8.);\n if (id == 05.) return hypercube(2.);\n if (id == 06.) return hypercube(2.);\n if (id == 07.) return hypercube(0.);\n}\nvec4 getPart1(float id) {\n if (id == 08.) return hypercube(0.);\n if (id == 09.) return hypercube(4.);\n if (id == 10.) return hypercube(4.);\n if (id == 11.) return hypercube(10.);\n if (id == 12.) return hypercube(10.);\n if (id == 13.) return hypercube(3.);\n if (id == 14.) return hypercube(8.);\n if (id == 15.) return hypercube(13.);\n}\nvec4 getPart2(float id) {\n if (id == 16.) return hypercube(2.);\n if (id == 17.) return hypercube(9.);\n if (id == 18.) return hypercube(4.);\n if (id == 19.) return hypercube(9.);\n if (id == 20.) return hypercube(10.);\n if (id == 21.) return hypercube(13.);\n if (id == 22.) return hypercube(13.);\n if (id == 23.) return hypercube(9.);\n}\nvec4 getPart3(float id) {\n if (id == 24.) return hypercube(1.);\n if (id == 25.) return hypercube(6.);\n if (id == 26.) return hypercube(6.);\n if (id == 27.) return hypercube(11.);\n if (id == 28.) return hypercube(11.);\n if (id == 29.) return hypercube(5.);\n if (id == 30.) return hypercube(5.);\n if (id == 31.) return hypercube(1.);\n}\nvec4 getPart4(float id) {\n if (id == 32.) return hypercube(7.);\n if (id == 33.) return hypercube(14.);\n if (id == 34.) return hypercube(14.);\n if (id == 35.) return hypercube(15.);\n if (id == 36.) return hypercube(15.);\n if (id == 37.) return hypercube(12.);\n if (id == 38.) return hypercube(12.);\n if (id == 39.) return hypercube(7.);\n}\nvec4 getPart5(float id) {\n if (id == 40.) return hypercube(1.);\n if (id == 41.) return hypercube(7.);\n if (id == 42.) return hypercube(6.);\n if (id == 43.) return hypercube(14.);\n if (id == 44.) return hypercube(11.);\n if (id == 45.) return hypercube(15.);\n if (id == 46.) return hypercube(5.);\n if (id == 47.) return hypercube(12.);\n}\nvec4 getPart6(float id) {\n if (id == 48.) return hypercube(2.);\n if (id == 49.) return hypercube(5.);\n if (id == 50.) return hypercube(8.);\n if (id == 51.) return hypercube(11.);\n if (id == 52.) return hypercube(13.);\n if (id == 53.) return hypercube(15.);\n if (id == 54.) return hypercube(9.);\n if (id == 55.) return hypercube(12.);\n}\nvec4 getPart7(float id) {\n if (id == 56.) return hypercube(0.);\n if (id == 57.) return hypercube(1.);\n if (id == 58.) return hypercube(3.);\n if (id == 59.) return hypercube(6.);\n if (id == 60.) return hypercube(10.);\n if (id == 61.) return hypercube(14.);\n if (id == 62.) return hypercube(4.);\n if (id == 63.) return hypercube(7.);\n}\nvec4 hypercube_lines(float id)\n{\n id = mod(vertexId, 64.0);\n \n if (id >= 0. && id < 8.)\n return getPart0(id);\n if (id >= 8. && id < 16.)\n return getPart1(id);\n if (id >= 16. && id < 24.)\n return getPart2(id);\n if (id >= 24. && id < 32.)\n return getPart3(id);\n if (id >= 32. && id < 40.)\n return getPart4(id);\n if (id >= 40. && id < 48.)\n return getPart5(id);\n if (id >= 48. && id < 56.)\n return getPart6(id);\n if (id >= 56. && id < 64.)\n return getPart7(id);\n \n return vec4(0);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 3);\n vec4 to4 = vec4(0, 0, 1, 0);\n vec4 up4 = vec4(0, 1, -2, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(3.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, -1);\n vec3 up3 = vec3(0, 1, -1);\n float theta3 = 45.0 * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.3 * TAU*sin(mouse.x));\n t4 *= rot4xy(time * 0.125 * TAU);\n vec4 v4 = hypercube_lines(vertexId);\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3*mouse.y, 1.0, theta3, t3);\n vec2 aspect = vec2(1., resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect*sin(mouse), 0., 1.);\n v_color = vec4(1.,1.,1., 1.);\n}" + }, "screenshotURL": "data/images/images-sc04zeskppxhbujy9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aKsCsvNiRHackMEsj/art.json b/art/aKsCsvNiRHackMEsj/art.json index 1ef22dfe..bbe4f739 100644 --- a/art/aKsCsvNiRHackMEsj/art.json +++ b/art/aKsCsvNiRHackMEsj/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":274,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n\\t\\n if(vertexId > 200.0){\\n\\tgl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n \\n gl_PointSize = 10.0; \\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n \\n v_color = vec4(1,vertexId/255.0,0.5,1);\\n}\"}", + "settings": { + "num": 274, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n\t\n if(vertexId > 200.0){\n\tgl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n \n gl_PointSize = 10.0; \n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n \n v_color = vec4(1,vertexId/255.0,0.5,1);\n}" + }, "screenshotURL": "data/images/images-948s2yb8q69xwo8n2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aM9NFXxMSiNnsvi4u/art.json b/art/aM9NFXxMSiNnsvi4u/art.json index 0c234336..6b3988d7 100644 --- a/art/aM9NFXxMSiNnsvi4u/art.json +++ b/art/aM9NFXxMSiNnsvi4u/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Colors - Geumbi Yeo\\n// Course : CS250\\n// Term & Year : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = mouse.x / u * .1 + cos(time * 1.3 + v * 20.) * 0.05;\\n float sat = 5.;\\n float val = mouse.x * sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat * mouse.y, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Colors - Geumbi Yeo\n// Course : CS250\n// Term & Year : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = mouse.x / u * .1 + cos(time * 1.3 + v * 20.) * 0.05;\n float sat = 5.;\n float val = mouse.x * sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat * mouse.y, val)), 1);\n}" + }, "screenshotURL": "data/images/images-pktdrv2l64t92si9y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aMJHfrjJHMKKy4iNi/art.json b/art/aMJHfrjJHMKKy4iNi/art.json index 2db96887..18094959 100644 --- a/art/aMJHfrjJHMKKy4iNi/art.json +++ b/art/aMJHfrjJHMKKy4iNi/art.json @@ -29,7 +29,19 @@ }, "private": false, "username": "fizzer", - "settings": "{\"num\":12849,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//\\nvoid main()\\n{\\n int vx=int(vertexId/4.),vy=int(mod(vertexId,4.));\\n\\n vec3 rp=vec3(0.,1.,0.),rd=rp.xzy;\\n \\n for(int j=0;j<100000;j++)\\n {\\n if(j>vx)\\n continue;\\n vec3 n=normalize(rp);\\n rp=n;\\n rd=normalize(rd-dot(n,rd)*n);\\n rd=normalize(rd+cross(n,rd)*(sin(float(j)*.007)*10.+cos(float(j)*.009+float(vy)*0.1)+sin(float(j)*.001+float(vy)))*.05);\\n rp+=rd*0.02;\\n }\\n\\n float xx=mod((time-float(vx)/400.0+floor(time/17.)*17.)*.6,1.);\\n float ss=mod(vertexId/5.,2.);\\n\\n vec3 n=normalize(rp);\\n vec3 pos=rp-n*ss*.002+vec3(0.,-pow(xx,2.+cos(float(vx))*.8),0.)*ss;\\n float a=time/10.;\\n pos.xz*=mat2(cos(a),sin(a),-sin(a),cos(a));\\n pos.z+=3.;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n \\n v_color.a=1.;\\n v_color.rgb=mix(vec3(.2,.5,.6),vec3(.5,.6,1.)*.1,(.5+.5*dot(n,normalize(vec3(1.,1.,0.)))))/xx;\\n\\n gl_PointSize=4./(1.+xx*4.);\\n gl_Position=vec4(pos.xy/pos.z*aspect,0,1);\\n}\\n\"}", + "settings": { + "num": 12849, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//\nvoid main()\n{\n int vx=int(vertexId/4.),vy=int(mod(vertexId,4.));\n\n vec3 rp=vec3(0.,1.,0.),rd=rp.xzy;\n \n for(int j=0;j<100000;j++)\n {\n if(j>vx)\n continue;\n vec3 n=normalize(rp);\n rp=n;\n rd=normalize(rd-dot(n,rd)*n);\n rd=normalize(rd+cross(n,rd)*(sin(float(j)*.007)*10.+cos(float(j)*.009+float(vy)*0.1)+sin(float(j)*.001+float(vy)))*.05);\n rp+=rd*0.02;\n }\n\n float xx=mod((time-float(vx)/400.0+floor(time/17.)*17.)*.6,1.);\n float ss=mod(vertexId/5.,2.);\n\n vec3 n=normalize(rp);\n vec3 pos=rp-n*ss*.002+vec3(0.,-pow(xx,2.+cos(float(vx))*.8),0.)*ss;\n float a=time/10.;\n pos.xz*=mat2(cos(a),sin(a),-sin(a),cos(a));\n pos.z+=3.;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n \n v_color.a=1.;\n v_color.rgb=mix(vec3(.2,.5,.6),vec3(.5,.6,1.)*.1,(.5+.5*dot(n,normalize(vec3(1.,1.,0.)))))/xx;\n\n gl_PointSize=4./(1.+xx*4.);\n gl_Position=vec4(pos.xy/pos.z*aspect,0,1);\n}\n" + }, "screenshotURL": "data/images/images-31qctr6ro2lmh4g2x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aNcrtoxiwyPFj9n9k/art.json b/art/aNcrtoxiwyPFj9n9k/art.json index bd25fbaa..0316ca4f 100644 --- a/art/aNcrtoxiwyPFj9n9k/art.json +++ b/art/aNcrtoxiwyPFj9n9k/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6902,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/saposcloud/sausebrause\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n \\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 6902, + "mode": "LINES", + "sound": "https://soundcloud.com/saposcloud/sausebrause", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n \n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-vj3uzeova1cz7jy7q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aRahetpEjCSsaLHkX/art.json b/art/aRahetpEjCSsaLHkX/art.json index 2907ffdc..3ebdd889 100644 --- a/art/aRahetpEjCSsaLHkX/art.json +++ b/art/aRahetpEjCSsaLHkX/art.json @@ -27,7 +27,19 @@ "name": "pointsprite plasma", "private": false, "username": "myownclone", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n \\n c = (sin(pos.x) * cos(pos.y))*(sin(pos.y) * cos(pos.x)*cos(pos.x+pos.y)*sin(pos.x));\\n c += sin(time)*cos(time);\\n \\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 10.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 4.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n \n c = (sin(pos.x) * cos(pos.y))*(sin(pos.y) * cos(pos.x)*cos(pos.x+pos.y)*sin(pos.x));\n c += sin(time)*cos(time);\n \n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 10.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 4.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-oxtgeg340znm4dsam-thumbnail.jpg", "views": { "$numberInt": "105" diff --git a/art/aW3a59fZi6sxhTYBj/art.json b/art/aW3a59fZi6sxhTYBj/art.json index bfbc968e..776195fc 100644 --- a/art/aW3a59fZi6sxhTYBj/art.json +++ b/art/aW3a59fZi6sxhTYBj/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.0, 2.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nvec3 triangle(float idx) // vec2:p / float triangleIndex\\n{\\n\\tfloat triangleIndex = floor(idx / 6.);\\n\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 p = vec2(0);\\n\\t\\n\\tif (index == 0.) p = vec2(0,0);\\n\\tif (index == 1.) p = vec2(1,0);\\n\\tif (index == 2.) p = vec2(1,1);\\n\\t\\n\\tif (index == 3.) p = vec2(0,0);\\n\\tif (index == 4.) p = vec2(1,1);\\n\\tif (index == 5.) p = vec2(0,1);\\n\\t\\n\\treturn vec3(p, triangleIndex);\\n}\\n\\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\\n{\\n\\tvec4 res;\\n\\tvec3 pi = triangle(idx);\\n\\t\\n\\tpi.y += floor(pi.z / countQuadsX);\\n pi.x += mod(pi.z, countQuadsX);\\n \\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadsX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\t\\n\\tif (centered == true)\\n\\t{\\n\\t\\tpi.x -= nx * 0.5;\\n\\t\\tpi.y -= ny * 0.5;\\n\\t}\\n\\t\\n\\treturn vec4(pi.xy, nx, ny);\\n}\\n\\n//https://www.shadertoy.com/view/ltK3WD\\nvec4 voronoi(vec2 g )\\n{\\n\\tvec4 f = vec4(9);\\n\\tvec2 p = g /= 200. ; f.x=9.;\\n \\n\\tg += time;\\n\\t\\n float t = time * 0.1;\\n \\n for(int x=-2;x<=2;x++)\\n for(int y=-2;y<=2;y++)\\n {\\t\\n p = vec2(x,y);\\n\\t\\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\\n\\t\\t//f.y = max(abs(p.x), abs(p.y));\\n\\t\\t//f.y = dot(p,p);\\n\\t\\tif (f.y < f.x)\\n {\\n f.x = f.y;\\n f.zw = p;\\n }\\n }\\n\\t\\n vec3 n = vec3(0);\\n \\n if ( f.x == -f.z*.866 - f.w*.5) \\tn = vec3(1,0,0);\\n\\tif ( f.x == f.z*.866 - f.w*.5) \\t\\tn = vec3(0,1,0);\\n\\tif ( f.x == f.w) \\t\\t\\t\\t\\tn = vec3(0,0,1);\\n\\t\\n return vec4(f.x, n);\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 2.;\\n\\t\\n \\tvec3 uSlider = vec3(50, 5, 1.2);\\n \\n\\tfloat thickNess = uSlider.x;\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat sizeEdge = floor(sqrt(countMax));\\n\\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\\n\\t\\n\\tvec4 voro = voronoi(p.xy * uSlider.y);\\n\\t\\n\\tfloat d = voro.x;\\n\\tvec3 n = voro.yzw;\\n\\t\\n\\tv_color = vec4(n*d,1);\\n\\t\\n\\tmat4 camera = ident();\\n\\t\\n\\tfloat ca = time * 0.1;\\n\\tfloat cd = 160.;\\n\\tfloat ce = PI * mouse.y;\\n\\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(1, 1, 0);\\n \\n\\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.0, 2.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nvec3 triangle(float idx) // vec2:p / float triangleIndex\n{\n\tfloat triangleIndex = floor(idx / 6.);\n\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 p = vec2(0);\n\t\n\tif (index == 0.) p = vec2(0,0);\n\tif (index == 1.) p = vec2(1,0);\n\tif (index == 2.) p = vec2(1,1);\n\t\n\tif (index == 3.) p = vec2(0,0);\n\tif (index == 4.) p = vec2(1,1);\n\tif (index == 5.) p = vec2(0,1);\n\t\n\treturn vec3(p, triangleIndex);\n}\n\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\n{\n\tvec4 res;\n\tvec3 pi = triangle(idx);\n\t\n\tpi.y += floor(pi.z / countQuadsX);\n pi.x += mod(pi.z, countQuadsX);\n \n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadsX;\n\tfloat ny = floor(countQuads / nx);\n\t\t\n\tif (centered == true)\n\t{\n\t\tpi.x -= nx * 0.5;\n\t\tpi.y -= ny * 0.5;\n\t}\n\t\n\treturn vec4(pi.xy, nx, ny);\n}\n\n//https://www.shadertoy.com/view/ltK3WD\nvec4 voronoi(vec2 g )\n{\n\tvec4 f = vec4(9);\n\tvec2 p = g /= 200. ; f.x=9.;\n \n\tg += time;\n\t\n float t = time * 0.1;\n \n for(int x=-2;x<=2;x++)\n for(int y=-2;y<=2;y++)\n {\t\n p = vec2(x,y);\n\t\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\n\t\t//f.y = max(abs(p.x), abs(p.y));\n\t\t//f.y = dot(p,p);\n\t\tif (f.y < f.x)\n {\n f.x = f.y;\n f.zw = p;\n }\n }\n\t\n vec3 n = vec3(0);\n \n if ( f.x == -f.z*.866 - f.w*.5) \tn = vec3(1,0,0);\n\tif ( f.x == f.z*.866 - f.w*.5) \t\tn = vec3(0,1,0);\n\tif ( f.x == f.w) \t\t\t\t\tn = vec3(0,0,1);\n\t\n return vec4(f.x, n);\n}\n\nvoid main()\n{\n\tgl_PointSize = 2.;\n\t\n \tvec3 uSlider = vec3(50, 5, 1.2);\n \n\tfloat thickNess = uSlider.x;\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat sizeEdge = floor(sqrt(countMax));\n\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\n\t\n\tvec4 voro = voronoi(p.xy * uSlider.y);\n\t\n\tfloat d = voro.x;\n\tvec3 n = voro.yzw;\n\t\n\tv_color = vec4(n*d,1);\n\t\n\tmat4 camera = ident();\n\t\n\tfloat ca = time * 0.1;\n\tfloat cd = 160.;\n\tfloat ce = PI * mouse.y;\n\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(1, 1, 0);\n \n\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\n}" + }, "screenshotURL": "data/images/images-lre10u2xzqvyrglfe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aW7ux7BBYH5aNYM6h/art.json b/art/aW7ux7BBYH5aNYM6h/art.json index 9c93b5ed..193caae7 100644 --- a/art/aW7ux7BBYH5aNYM6h/art.json +++ b/art/aW7ux7BBYH5aNYM6h/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n \\n vec2 p = vec2(0,0);\\n \\n if(vertexId < 0.5){\\n p = vec2 (0., 0.5);\\n }else if (vertexId < 1.5)\\n {\\n p = vec2 (0.5, -0.5);\\n }else if (vertexId < 2.5)\\n {\\n p = vec2 (-0.5, -0.5);\\n }\\n \\n gl_Position = vec4(p, 0., 1.);\\n\\n v_color = vec4(1,1,1, 1);\\n}\\n\\n\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n \n vec2 p = vec2(0,0);\n \n if(vertexId < 0.5){\n p = vec2 (0., 0.5);\n }else if (vertexId < 1.5)\n {\n p = vec2 (0.5, -0.5);\n }else if (vertexId < 2.5)\n {\n p = vec2 (-0.5, -0.5);\n }\n \n gl_Position = vec4(p, 0., 1.);\n\n v_color = vec4(1,1,1, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-u6crmgza45c3fkpmr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aXiR2fCcooYzoea9L/art.json b/art/aXiR2fCcooYzoea9L/art.json index 45ade758..bf758837 100644 --- a/art/aXiR2fCcooYzoea9L/art.json +++ b/art/aXiR2fCcooYzoea9L/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"plasma grid\\\" by johanberonius\\n\\nvoid main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"plasma grid\" by johanberonius\n\nvoid main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-ltwaxsxbyifp8cjg8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aY78NwrqSDZrC8tRW/art.json b/art/aY78NwrqSDZrC8tRW/art.json index a627aaac..361c5ddb 100644 --- a/art/aY78NwrqSDZrC8tRW/art.json +++ b/art/aY78NwrqSDZrC8tRW/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "kcha", "avatarUrl": "https://secure.gravatar.com/avatar/393683f94ba2c18293b67ab3d3eb6f10?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.14901960784313725,0.3764705882352941,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\\n // 0 0 0 0 0 0 1 1 1 1 1 1 2 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0 1\\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4 4\\n // 0 0 1 0 1 1 1 1 0 1 0 0 0 0\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main(){\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n // 0.0 - 1.0\\n float u = x / (across - 1.); // .0, .1, ... , .9, .0, .1, ...\\n float v = y / (across - 1.); // .0, .0, ... , .1, .1, ... \\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n // 0.0-1.0 => -0.5-0.5 => 0.5-0.0-0.5 => 1.0-0.0-1.0\\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n\\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1.0, 1.2, oddSlice);\\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.2);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 15. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .2 + sliceId * 0.01;//sin(time + v * 20.) * .05;\\n float sat = mix(0.8, 1.0, pump);//mix(1., 0., av);\\n float val = mix(.4, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.14901960784313725, + 0.3764705882352941, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments){\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\n // 0 0 0 0 0 0 1 1 1 1 1 1 2 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0 1\n // 0 1 0 1 0 1 1 2 1 2 1 2 2 3\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\n // 0 0 1 1 2 2 3 3 4 4 5 5 6 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4 4\n // 0 0 1 0 1 1 1 1 0 1 0 0 0 0\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main(){\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n // 0.0 - 1.0\n float u = x / (across - 1.); // .0, .1, ... , .9, .0, .1, ...\n float v = y / (across - 1.); // .0, .0, ... , .1, .1, ... \n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n // 0.0-1.0 => -0.5-0.5 => 0.5-0.0-0.5 => 1.0-0.0-1.0\n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n\n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1.0, 1.2, oddSlice);\n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.2);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 15. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .2 + sliceId * 0.01;//sin(time + v * 20.) * .05;\n float sat = mix(0.8, 1.0, pump);//mix(1., 0., av);\n float val = mix(.4, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-u2hg2lpfskrmwt5yi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aZd7ykAPBAnQ9mKSb/art.json b/art/aZd7ykAPBAnQ9mKSb/art.json index 8088b4d9..15cbb7a5 100644 --- a/art/aZd7ykAPBAnQ9mKSb/art.json +++ b/art/aZd7ykAPBAnQ9mKSb/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "duhochoi", "avatarUrl": "https://secure.gravatar.com/avatar/3a2a5d4b2ecd66c69241bc6b3e1e34e6?default=retro&size=200", - "settings": "{\"num\":1647,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Duho Choi\\n// Assignment : Exercise - Vertexshaderart : Motion\\n// Course : CS250\\n// Term : Spring 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n \\n \\tgl_PointSize = 15. + soff;\\n \\tgl_PointSize *= 20. / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tv_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 1647, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Duho Choi\n// Assignment : Exercise - Vertexshaderart : Motion\n// Course : CS250\n// Term : Spring 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 5.;\n \n \tgl_PointSize = 15. + soff;\n \tgl_PointSize *= 20. / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n \tv_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-kpqjsvrj2ee62sqba-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/adr4oWENvpWNLwHJR/art.json b/art/adr4oWENvpWNLwHJR/art.json index 8a76a723..8d208e37 100644 --- a/art/adr4oWENvpWNLwHJR/art.json +++ b/art/adr4oWENvpWNLwHJR/art.json @@ -20,7 +20,19 @@ "origId": null, "name": "geosphere", "username": "johan", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI 3.14159\\n#define DIVISIONS 0.\\n//#DEFINE INDICES {1,4,0,4,9,0,4,5,9,8,5,4,1,8,4,1,10,8,10,3,8,8,3,5,3,2,5,3,7,2,3,10,7,10,6,7,6,11,7,6,0,11,6,1,0,10,1,6,11,0,9,2,11,9,5,2,9,11,2,7};\\n\\nconst float DIM_X = 128.;\\nconst float DIM_Y = 64.;\\n\\nconst float BG_DIM_X = 8.;\\nconst float BG_DIM_Y = 6.;\\n//#define FIT_VERTICAL\\n/*\\n//const int INDICES[60] = int[](\\nconst int INDICES[60] = {\\n 1,4,0,\\n 4,9,0,\\n 4,5,9,\\n 8,5,4,\\n 1,8,4,\\n 1,10,8,\\n 10,3,8,\\n 8,3,5,\\n 3,2,5,\\n 3,7,2,\\n 3,10,7,\\n 10,6,7,\\n 6,11,7,\\n 6,0,11,\\n 6,1,0,\\n 10,1,6,\\n 11,0,9,\\n 2,11,9,\\n 5,2,9,\\n 11,2,7\\n//);\\n}\\n*/\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadTriIndex = floor(twoTriVertexIndex*0.334);\\n float quadVertexIndex = triVertexIndex + quadTriIndex;\\n\\n x = mod(quadVertexIndex, 2.);\\n y = floor(quadVertexIndex * 0.5);\\n \\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n//todo: DEFINE PROJECTION\\nmat4 GetProjection(){\\n float near = 0.01;\\n float far = 10.;\\n float aspectRatio = resolution.x / resolution.y;\\n float fov = 2.;\\n float h = cos(0.5*fov)/sin(0.5*fov);\\n float w = h * aspectRatio;\\n float a = - (near+far)/(near - far);\\n float b = - ((2.*far*near)/(far-near));\\n\\n mat4 m = mat4( \\n w, 0, 0, 0,\\n 0, h, 0, 0,\\n 0, 0, a, 1,\\n 0, 0, b, 0\\n );\\n return m;\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n\\n \\n /*\\n vec3 corners2[12] = vec3[](\\n vec3(-X, 0, Z),\\n vec3(X, 0, Z),\\n vec3(-X, 0, -Z),\\n \\n vec3(X, 0, -Z),\\n vec3(0, Z, X),\\n vec3(0, Z, -X),\\n \\n vec3(0, -Z, X),\\n vec3(0, -Z, -X),\\n vec3(Z, X, 0),\\n \\n vec3( -Z, X, 0),\\n vec3(Z, -X, 0),\\n vec3(-Z, -X, 0)\\n );\\n */\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexIndex, quadX, quadY, quadId );\\n\\n //vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, BG_DIM_X);\\n quadTile.y = floor(quadId / BG_DIM_X);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV /= vec2(BG_DIM_X, BG_DIM_Y);\\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.99, 1.0 );\\n\\n v_color = vec4( vUV.xy, 0., 1.0 );\\n}\\n\\nvec3 VolcanoVertexPos(vec2 uv){\\n float phase = uv.x * PI * 2.;\\n vec3 pos;\\n float r = smoothstep(1.,0.,uv.y);\\n r += 0.5;\\n r *= 0.25;\\n\\n \\n pos.x = sin(phase);\\n pos.y = uv.y - 0.5;\\n pos.z = cos(phase);\\n pos.xz *= r;\\n \\n pos.z += 1.;\\n \\n //pos += fractalNoise(pos*10.)* 0.05;\\n \\n return pos;\\n}\\n\\n/*\\nint[] getVertexIndices(float triangleIndex)\\n{\\n int indices[3] = int[](0,0,0);\\n return indices;\\n}\\n*/\\n\\nvoid ProcessGeoSphere(float vertexIndex )\\n{\\n float X = 0.525731112119133606;\\n float Z = 0.850650808352039932;\\n \\n vec3 corners[12];\\n corners[0] = vec3(-X, 0, Z);\\n corners[1] = vec3(X, 0, Z);\\n corners[2] = vec3(-X, 0, -Z);\\n \\n corners[3] = vec3(X, 0, -Z);\\n corners[4] = vec3(0, Z, X);\\n corners[5] = vec3(0, Z, -X);\\n \\n corners[6] = vec3(0, -Z, X);\\n corners[7] = vec3(0, -Z, -X);\\n corners[8] = vec3(Z, X, 0);\\n \\n corners[9] = vec3( -Z, X, 0);\\n corners[10] = vec3(Z, -X, 0);\\n corners[11] = vec3(-Z, -X, 0);\\n \\n vec3 triangles[20];\\n triangles[0] = vec3(1,4,0);\\n triangles[1] = vec3(4,9,0);\\n triangles[2] = vec3(4,5,9);\\n // \\n\\n //int indices[60] = int[](1,4,0,4,9,0,4,5,9,8,5,4,1,8,4,1,10,8,10,3,8,8,3,5,3,2,5,3,7,2,3,10,7,10,6,7,6,11,7,6,0,11,6,1,0,10,1,6,11,0,9,2,11,9,5,2,9,11,2,7);\\n //float array[2] = float[2](1., 1.);\\n \\n float vi = mod(vertexIndex, 3.);\\n float triIndex = floor(vertexIndex/3.);\\n\\n vec3 pos;\\n \\n gl_Position = GetProjection() * vec4(pos, 1.0 );\\n\\n //vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n //vPos.y *= resolution.x / resolution.y;\\n\\n //v_color = vec4( vUV.xy, 0., 1.0 );\\n v_color = vec4(pos * 0.5 + 0.5, 1.0 );\\n}\\n \\n\\nvoid main() {\\n float vid = vertexId;\\n float bgCount = BG_DIM_X * BG_DIM_Y * 6.;\\n \\n \\n \\tif( vid < bgCount )\\n {\\n\\t\\tProcessBackdrop(vid); \\n }\\n else \\n {\\n \\tvid -= bgCount;\\n \\tfloat geoSphereCount = 20. * pow(4., DIVISIONS) * 3.;\\n \\tif(vid < geoSphereCount) ProcessGeoSphere(vid); \\n }\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI 3.14159\n#define DIVISIONS 0.\n//#DEFINE INDICES {1,4,0,4,9,0,4,5,9,8,5,4,1,8,4,1,10,8,10,3,8,8,3,5,3,2,5,3,7,2,3,10,7,10,6,7,6,11,7,6,0,11,6,1,0,10,1,6,11,0,9,2,11,9,5,2,9,11,2,7};\n\nconst float DIM_X = 128.;\nconst float DIM_Y = 64.;\n\nconst float BG_DIM_X = 8.;\nconst float BG_DIM_Y = 6.;\n//#define FIT_VERTICAL\n/*\n//const int INDICES[60] = int[](\nconst int INDICES[60] = {\n 1,4,0,\n 4,9,0,\n 4,5,9,\n 8,5,4,\n 1,8,4,\n 1,10,8,\n 10,3,8,\n 8,3,5,\n 3,2,5,\n 3,7,2,\n 3,10,7,\n 10,6,7,\n 6,11,7,\n 6,0,11,\n 6,1,0,\n 10,1,6,\n 11,0,9,\n 2,11,9,\n 5,2,9,\n 11,2,7\n//);\n}\n*/\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadTriIndex = floor(twoTriVertexIndex*0.334);\n float quadVertexIndex = triVertexIndex + quadTriIndex;\n\n x = mod(quadVertexIndex, 2.);\n y = floor(quadVertexIndex * 0.5);\n \n quadId = floor( vertexIndex / 6.0 );\n}\n\n//todo: DEFINE PROJECTION\nmat4 GetProjection(){\n float near = 0.01;\n float far = 10.;\n float aspectRatio = resolution.x / resolution.y;\n float fov = 2.;\n float h = cos(0.5*fov)/sin(0.5*fov);\n float w = h * aspectRatio;\n float a = - (near+far)/(near - far);\n float b = - ((2.*far*near)/(far-near));\n\n mat4 m = mat4( \n w, 0, 0, 0,\n 0, h, 0, 0,\n 0, 0, a, 1,\n 0, 0, b, 0\n );\n return m;\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n\n \n /*\n vec3 corners2[12] = vec3[](\n vec3(-X, 0, Z),\n vec3(X, 0, Z),\n vec3(-X, 0, -Z),\n \n vec3(X, 0, -Z),\n vec3(0, Z, X),\n vec3(0, Z, -X),\n \n vec3(0, -Z, X),\n vec3(0, -Z, -X),\n vec3(Z, X, 0),\n \n vec3( -Z, X, 0),\n vec3(Z, -X, 0),\n vec3(-Z, -X, 0)\n );\n */\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexIndex, quadX, quadY, quadId );\n\n //vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, BG_DIM_X);\n quadTile.y = floor(quadId / BG_DIM_X);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV /= vec2(BG_DIM_X, BG_DIM_Y);\n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.99, 1.0 );\n\n v_color = vec4( vUV.xy, 0., 1.0 );\n}\n\nvec3 VolcanoVertexPos(vec2 uv){\n float phase = uv.x * PI * 2.;\n vec3 pos;\n float r = smoothstep(1.,0.,uv.y);\n r += 0.5;\n r *= 0.25;\n\n \n pos.x = sin(phase);\n pos.y = uv.y - 0.5;\n pos.z = cos(phase);\n pos.xz *= r;\n \n pos.z += 1.;\n \n //pos += fractalNoise(pos*10.)* 0.05;\n \n return pos;\n}\n\n/*\nint[] getVertexIndices(float triangleIndex)\n{\n int indices[3] = int[](0,0,0);\n return indices;\n}\n*/\n\nvoid ProcessGeoSphere(float vertexIndex )\n{\n float X = 0.525731112119133606;\n float Z = 0.850650808352039932;\n \n vec3 corners[12];\n corners[0] = vec3(-X, 0, Z);\n corners[1] = vec3(X, 0, Z);\n corners[2] = vec3(-X, 0, -Z);\n \n corners[3] = vec3(X, 0, -Z);\n corners[4] = vec3(0, Z, X);\n corners[5] = vec3(0, Z, -X);\n \n corners[6] = vec3(0, -Z, X);\n corners[7] = vec3(0, -Z, -X);\n corners[8] = vec3(Z, X, 0);\n \n corners[9] = vec3( -Z, X, 0);\n corners[10] = vec3(Z, -X, 0);\n corners[11] = vec3(-Z, -X, 0);\n \n vec3 triangles[20];\n triangles[0] = vec3(1,4,0);\n triangles[1] = vec3(4,9,0);\n triangles[2] = vec3(4,5,9);\n // \n\n //int indices[60] = int[](1,4,0,4,9,0,4,5,9,8,5,4,1,8,4,1,10,8,10,3,8,8,3,5,3,2,5,3,7,2,3,10,7,10,6,7,6,11,7,6,0,11,6,1,0,10,1,6,11,0,9,2,11,9,5,2,9,11,2,7);\n //float array[2] = float[2](1., 1.);\n \n float vi = mod(vertexIndex, 3.);\n float triIndex = floor(vertexIndex/3.);\n\n vec3 pos;\n \n gl_Position = GetProjection() * vec4(pos, 1.0 );\n\n //vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n //vPos.y *= resolution.x / resolution.y;\n\n //v_color = vec4( vUV.xy, 0., 1.0 );\n v_color = vec4(pos * 0.5 + 0.5, 1.0 );\n}\n \n\nvoid main() {\n float vid = vertexId;\n float bgCount = BG_DIM_X * BG_DIM_Y * 6.;\n \n \n \tif( vid < bgCount )\n {\n\t\tProcessBackdrop(vid); \n }\n else \n {\n \tvid -= bgCount;\n \tfloat geoSphereCount = 20. * pow(4., DIVISIONS) * 3.;\n \tif(vid < geoSphereCount) ProcessGeoSphere(vid); \n }\n}" + }, "screenshotURL": "data/images/images-0q00bdlrbeo1t0bkr-thumbnail.jpg", "views": { "$numberInt": "115" diff --git a/art/aeJaBveTxKQ9E6dTm/art.json b/art/aeJaBveTxKQ9E6dTm/art.json index 3c96ca1f..296b37e5 100644 --- a/art/aeJaBveTxKQ9E6dTm/art.json +++ b/art/aeJaBveTxKQ9E6dTm/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "daniel", "avatarUrl": "https://lh3.googleusercontent.com/-qXZbQEgaXn0/AAAAAAAAAAI/AAAAAAAAA6k/Q8oMgqryECw/photo.jpg", - "settings": "{\"num\":21,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"#define PI arctan(180)\\n\\nvoid main()\\n{\\n float across = 10.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across); \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 21, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "#define PI arctan(180)\n\nvoid main()\n{\n float across = 10.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across); \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-c36j131vemi5m2lgb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ahsgh32ELS6fLxWcK/art.json b/art/ahsgh32ELS6fLxWcK/art.json index a51c61dd..4bf4f119 100644 --- a/art/ahsgh32ELS6fLxWcK/art.json +++ b/art/ahsgh32ELS6fLxWcK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":108,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rot(vec3 axis, float angle) {\\n \\n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n \\n mat4 mr = rot(vec3(0.1, 0.2, 0.3), time);\\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 30.0; \\n\\n v_color = vec4(1,1,0.5,1);\\n}\"}", + "settings": { + "num": 108, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rot(vec3 axis, float angle) {\n \n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n \n mat4 mr = rot(vec3(0.1, 0.2, 0.3), time);\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 30.0; \n\n v_color = vec4(1,1,0.5,1);\n}" + }, "screenshotURL": "data/images/images-cimnc9o070j4ku174-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aigbErpiobPHWcME4/art.json b/art/aigbErpiobPHWcME4/art.json index ad99a51d..b60ab42c 100644 --- a/art/aigbErpiobPHWcME4/art.json +++ b/art/aigbErpiobPHWcME4/art.json @@ -27,7 +27,19 @@ "name": "landscape", "private": true, "username": "spotline", - "settings": "{\"num\":10095,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"void main() \\n{\\n float quadId = floor(vertexId/6.0);\\n float quadRole = floor(mod(vertexId,6.0));\\n float unit = 1.0/vertexCount/6.0;\\n \\n float quadIdRoleBonus = 0.0;\\n \\n if(quadRole == 0.0)\\n {\\n }\\n else if (quadRole == 1.0)\\n {\\n }\\n else if (quadRole == 2.0)\\n {\\n quadIdRoleBonus = 1.0;\\n }\\n else if (quadRole == 3.0)\\n {\\n }\\n else if (quadRole == 4.0)\\n {\\n quadIdRoleBonus = 1.0;\\n }\\n else if (quadRole == 5.0)\\n {\\n quadIdRoleBonus = 1.0;\\n }\\n \\n float u = (quadId+quadIdRoleBonus)/(vertexCount/6.0);\\n float v = 2.0*pow(texture2D(sound,vec2(u*0.05,0.0)).a,6.0);\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 1.0 - 0.5;\\n gl_PointSize = 5.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 10095, + "mode": "LINES", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "void main() \n{\n float quadId = floor(vertexId/6.0);\n float quadRole = floor(mod(vertexId,6.0));\n float unit = 1.0/vertexCount/6.0;\n \n float quadIdRoleBonus = 0.0;\n \n if(quadRole == 0.0)\n {\n }\n else if (quadRole == 1.0)\n {\n }\n else if (quadRole == 2.0)\n {\n quadIdRoleBonus = 1.0;\n }\n else if (quadRole == 3.0)\n {\n }\n else if (quadRole == 4.0)\n {\n quadIdRoleBonus = 1.0;\n }\n else if (quadRole == 5.0)\n {\n quadIdRoleBonus = 1.0;\n }\n \n float u = (quadId+quadIdRoleBonus)/(vertexCount/6.0);\n float v = 2.0*pow(texture2D(sound,vec2(u*0.05,0.0)).a,6.0);\n \n float x = u * 2.0 - 1.0;\n float y = v * 1.0 - 0.5;\n gl_PointSize = 5.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-vzvxu577fslk62tms-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aimt699JRJfpBQPGx/art.json b/art/aimt699JRJfpBQPGx/art.json index ce4db8f0..8a4b3fe5 100644 --- a/art/aimt699JRJfpBQPGx/art.json +++ b/art/aimt699JRJfpBQPGx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/nocopyrightsounds/alan-walker-dreamer-ncs-release\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 3.0, 0.5 / 10.0, 6.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n#define PI radians(180.0)\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.9;\\n float yoff = sin(time + x * 0.1) * 0.7;\\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\n \\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .05)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 10. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0. , 1. , pump);//1.;\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/nocopyrightsounds/alan-walker-dreamer-ncs-release", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 3.0, 0.5 / 10.0, 6.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n#define PI radians(180.0)\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.9;\n float yoff = sin(time + x * 0.1) * 0.7;\n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n \n \n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .05)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 10. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0. , 1. , pump);//1.;\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-bfwf1alo7cb9emzds-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/akox4yJZBcHiLrbKy/art.json b/art/akox4yJZBcHiLrbKy/art.json index d255fe6a..43b5c3c1 100644 --- a/art/akox4yJZBcHiLrbKy/art.json +++ b/art/akox4yJZBcHiLrbKy/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 3.0, 0.5 / 10.0, 6.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.9;\\n float yoff = sin(time + x * 0.1) * 0.7;\\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 3.0, 0.5 / 10.0, 6.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.9;\n float yoff = sin(time + x * 0.1) * 0.7;\n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-dapat16nmyupp9tty-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/aqJ9RgEQBu63bvw2o/art.json b/art/aqJ9RgEQBu63bvw2o/art.json index 974c61db..f6db4b38 100644 --- a/art/aqJ9RgEQBu63bvw2o/art.json +++ b/art/aqJ9RgEQBu63bvw2o/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/synthwave80s/04-valkyrie\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19607843137254902,0.4588235294117647,0.4627450980392157,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float id = vertexId;\\n float ux = mod(id, 2.) - 0.5;\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float bladeId = floor(id / 6.);\\n float numBlades = floor(vertexCount / 6.);\\n float down = floor(sqrt(numBlades)) * 1.;\\n float across = floor(numBlades / down);\\n \\n float v = bladeId / numBlades;\\n \\n float cx = mod(bladeId, across);\\n float cy = floor(bladeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(ca, 0, cd);\\n vec3 pos = vec3(ux, vy, 0);\\n vec3 normal = vec3(0, 0, 1);\\n \\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(v * 0.0713)), length(cpos) * .7)).a;\\n \\n\\n \\n float tm = time * 0.0125;\\n float etm = tm + PI;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n float er = 8.;\\n float tr = 8.;\\n vec3 eye = vec3(cos(tm) * er, 2.2 /*sin(tm * 0.9) * 1.5*/, sin(tm) * er);\\n vec3 target = vec3(cos(etm) * tr, -1., sin(etm) * tr); //vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(0, 1, 0);\\n float sh = mix(0.0, 0.1, hash(v * 0.327)) + \\n mix(0.0, 0.5, sin(cu * 15.) * 0.5 + 0.5) +\\n mix(0.0, 0.5, sin(cv * 15.) * 0.5 + 0.5);\\n vec3 h = vec3(\\n hash(v) + sin(time * 0.2 + cv * 205. + hash(cv) * 0.1) * vy * 0.2,\\n 0,\\n hash(v * 0.123));\\n normal = normalize(vec3(sin(cu * 15.), 1, cos(cv * 15.)));\\n \\n mat4 cmat = cameraLookAt(eye, target, up);\\n mat *= cmat;\\n mat *= trans(cpos * 8. + h);\\n mat *= inverse(mat4(\\n vec4(cmat[0].xyz, 0),\\n vec4(cmat[1].xyz, 0),\\n vec4(cmat[2].xyz, 0),\\n vec4(0, 0, 0, 1)));\\n mat *= rotZ(sin(time + v * 4.) * 0.3);\\n mat *= scale(vec3(mix(0.1, 0.01, vy), 1.+ sh + pow(snd + 0.3, 10.0) * 0.1, 1));\\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = time * 0.1 + mix(0.25, 0.35, hash(bladeId * 0.0001 + vertexId * 0.0001));// * 0.25 + 0.1;//sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\\n float sat = mix(0.5, 0.8, hash(bladeId * 0.0003));//step(0.6, snd);//pow(snd + 0.3, 5.);\\n float val = mix(0.7, 1.0, hash(bladeId * 0.0005));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n color = mix(color, vec3(1,1,0), pow(snd + 0.3, 10.0));\\n v_color = vec4(color * mix(0., 1., lit), 1.);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/synthwave80s/04-valkyrie", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19607843137254902, + 0.4588235294117647, + 0.4627450980392157, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float id = vertexId;\n float ux = mod(id, 2.) - 0.5;\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float bladeId = floor(id / 6.);\n float numBlades = floor(vertexCount / 6.);\n float down = floor(sqrt(numBlades)) * 1.;\n float across = floor(numBlades / down);\n \n float v = bladeId / numBlades;\n \n float cx = mod(bladeId, across);\n float cy = floor(bladeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(ca, 0, cd);\n vec3 pos = vec3(ux, vy, 0);\n vec3 normal = vec3(0, 0, 1);\n \n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(v * 0.0713)), length(cpos) * .7)).a;\n \n\n \n float tm = time * 0.0125;\n float etm = tm + PI;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n float er = 8.;\n float tr = 8.;\n vec3 eye = vec3(cos(tm) * er, 2.2 /*sin(tm * 0.9) * 1.5*/, sin(tm) * er);\n vec3 target = vec3(cos(etm) * tr, -1., sin(etm) * tr); //vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(0, 1, 0);\n float sh = mix(0.0, 0.1, hash(v * 0.327)) + \n mix(0.0, 0.5, sin(cu * 15.) * 0.5 + 0.5) +\n mix(0.0, 0.5, sin(cv * 15.) * 0.5 + 0.5);\n vec3 h = vec3(\n hash(v) + sin(time * 0.2 + cv * 205. + hash(cv) * 0.1) * vy * 0.2,\n 0,\n hash(v * 0.123));\n normal = normalize(vec3(sin(cu * 15.), 1, cos(cv * 15.)));\n \n mat4 cmat = cameraLookAt(eye, target, up);\n mat *= cmat;\n mat *= trans(cpos * 8. + h);\n mat *= inverse(mat4(\n vec4(cmat[0].xyz, 0),\n vec4(cmat[1].xyz, 0),\n vec4(cmat[2].xyz, 0),\n vec4(0, 0, 0, 1)));\n mat *= rotZ(sin(time + v * 4.) * 0.3);\n mat *= scale(vec3(mix(0.1, 0.01, vy), 1.+ sh + pow(snd + 0.3, 10.0) * 0.1, 1));\n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = time * 0.1 + mix(0.25, 0.35, hash(bladeId * 0.0001 + vertexId * 0.0001));// * 0.25 + 0.1;//sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\n float sat = mix(0.5, 0.8, hash(bladeId * 0.0003));//step(0.6, snd);//pow(snd + 0.3, 5.);\n float val = mix(0.7, 1.0, hash(bladeId * 0.0005));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n color = mix(color, vec3(1,1,0), pow(snd + 0.3, 10.0));\n v_color = vec4(color * mix(0., 1., lit), 1.);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-0s97jm0zph1gew89f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aqgyqr6ASpcsZTeEu/art.json b/art/aqgyqr6ASpcsZTeEu/art.json index 43c071cd..f43cb242 100644 --- a/art/aqgyqr6ASpcsZTeEu/art.json +++ b/art/aqgyqr6ASpcsZTeEu/art.json @@ -31,7 +31,19 @@ }, "private": false, "username": "mark", - "settings": "{\"num\":24000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fionabechmann/debussy-clair-de-lune\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9058823529411765,0.9058823529411765,0.9058823529411765,1],\"shader\":\"#define PI 3.14159\\n#define N_SAMPLES 500.\\n\\nvec3 lla2xyz(vec2 latlon, float rad) {\\n float rxz = rad * cos(latlon.y);\\n \\n return vec3(\\n rxz * cos(latlon.x),\\n rad * sin(latlon.y),\\n rxz * sin(latlon.x)\\n );\\n}\\n\\nvec3 aspect(vec3 p) {\\n float ratio = resolution.y / resolution.x;\\n if (ratio < 1.)\\n return vec3(p.x * ratio, p.yz);\\n else if (ratio > 1.)\\n return vec3(p.x, p.y / ratio, p.z);\\n return p;\\n}\\nvec3 project(vec3 p) { return aspect(vec3(p.xy/p.z, -p.z)); }\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvec2 sphere_point(float i) {\\n // golden ratio\\n float phi = (sqrt(5.) + 1.) / 2. - 1.;\\n // golden angle\\n float ga = phi * 2. * PI;\\n \\n \\n vec2 p = vec2(0.);\\n if (i > N_SAMPLES)\\n return p;\\n \\n p.x = ga * i;\\n p.x /= 2. * PI;\\n p.x = fract(p.x);\\n p.x *= 2. * PI;\\n \\n p.y = asin(-1. + 2. * i / N_SAMPLES);\\n return p;\\n}\\n\\nvoid main () {\\n vec3 centre = vec3(0., 0., -.5);\\n \\n float group = floor(vertexId / N_SAMPLES);\\n float index = mod(vertexId, N_SAMPLES);\\n float f = group / floor(vertexCount / N_SAMPLES);//rand(vec2(group, 7845.63541));\\n \\n float snd = pow(texture2D(sound, vec2(.05 + .25 * f, 0.)).a, 2.);\\n for (int t = 0; t < 20; t++) {\\n vec2 spos = vec2(\\n .05 + .25 * f,\\n float(t) / 10.\\n );\\n snd += pow(texture2D(sound, spos).a, 2.) / 20.;\\n }\\n \\n vec2 group_ll = vec2(\\n 2. * rand(vec2(group, 27.68)) * PI,\\n 2. * rand(vec2(534.5, group)) * PI\\n );\\n group_ll.x -= time * .1;\\n vec3 group_centre = lla2xyz(group_ll, .2 + .2 * rand(vec2(745.12, group)));\\n vec2 ll = sphere_point(index);\\n ll.x += time * f;\\n vec3 pos = lla2xyz(ll, .05 + .1 * snd) + group_centre;\\n pos += centre;\\n \\n \\n gl_PointSize = 8. - abs(pos.z) * 10.;\\n gl_Position = vec4(project(pos), 1.);\\n \\n \\n v_color = vec4(\\n .5 - .5 * cos(f * PI), .2,\\n .5 + .5 * sin(f * PI), 1.);\\n}\"}", + "settings": { + "num": 24000, + "mode": "POINTS", + "sound": "https://soundcloud.com/fionabechmann/debussy-clair-de-lune", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9058823529411765, + 0.9058823529411765, + 0.9058823529411765, + 1 + ], + "shader": "#define PI 3.14159\n#define N_SAMPLES 500.\n\nvec3 lla2xyz(vec2 latlon, float rad) {\n float rxz = rad * cos(latlon.y);\n \n return vec3(\n rxz * cos(latlon.x),\n rad * sin(latlon.y),\n rxz * sin(latlon.x)\n );\n}\n\nvec3 aspect(vec3 p) {\n float ratio = resolution.y / resolution.x;\n if (ratio < 1.)\n return vec3(p.x * ratio, p.yz);\n else if (ratio > 1.)\n return vec3(p.x, p.y / ratio, p.z);\n return p;\n}\nvec3 project(vec3 p) { return aspect(vec3(p.xy/p.z, -p.z)); }\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvec2 sphere_point(float i) {\n // golden ratio\n float phi = (sqrt(5.) + 1.) / 2. - 1.;\n // golden angle\n float ga = phi * 2. * PI;\n \n \n vec2 p = vec2(0.);\n if (i > N_SAMPLES)\n return p;\n \n p.x = ga * i;\n p.x /= 2. * PI;\n p.x = fract(p.x);\n p.x *= 2. * PI;\n \n p.y = asin(-1. + 2. * i / N_SAMPLES);\n return p;\n}\n\nvoid main () {\n vec3 centre = vec3(0., 0., -.5);\n \n float group = floor(vertexId / N_SAMPLES);\n float index = mod(vertexId, N_SAMPLES);\n float f = group / floor(vertexCount / N_SAMPLES);//rand(vec2(group, 7845.63541));\n \n float snd = pow(texture2D(sound, vec2(.05 + .25 * f, 0.)).a, 2.);\n for (int t = 0; t < 20; t++) {\n vec2 spos = vec2(\n .05 + .25 * f,\n float(t) / 10.\n );\n snd += pow(texture2D(sound, spos).a, 2.) / 20.;\n }\n \n vec2 group_ll = vec2(\n 2. * rand(vec2(group, 27.68)) * PI,\n 2. * rand(vec2(534.5, group)) * PI\n );\n group_ll.x -= time * .1;\n vec3 group_centre = lla2xyz(group_ll, .2 + .2 * rand(vec2(745.12, group)));\n vec2 ll = sphere_point(index);\n ll.x += time * f;\n vec3 pos = lla2xyz(ll, .05 + .1 * snd) + group_centre;\n pos += centre;\n \n \n gl_PointSize = 8. - abs(pos.z) * 10.;\n gl_Position = vec4(project(pos), 1.);\n \n \n v_color = vec4(\n .5 - .5 * cos(f * PI), .2,\n .5 + .5 * sin(f * PI), 1.);\n}" + }, "screenshotURL": "data/images/images-3w3gf1cd32tgjbgr4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aqszowTp3EkLRtdea/art.json b/art/aqszowTp3EkLRtdea/art.json index fe718f73..e76114c7 100644 --- a/art/aqszowTp3EkLRtdea/art.json +++ b/art/aqszowTp3EkLRtdea/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":6405,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Motion\\n// Course : CS250\\n// Spring 2023\\n\\n// Make sure the layout is \\\"LINES\\\"!\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.5;\\n float yoff = sin(time + x * 0.1) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n v_color = vec4(xoff * 3., y, x, 1);\\n}\"}", + "settings": { + "num": 6405, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Motion\n// Course : CS250\n// Spring 2023\n\n// Make sure the layout is \"LINES\"!\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.5;\n float yoff = sin(time + x * 0.1) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n v_color = vec4(xoff * 3., y, x, 1);\n}" + }, "screenshotURL": "data/images/images-1beqpgds4lbdxxcnd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/as29BXy9qihbCbPqA/art.json b/art/as29BXy9qihbCbPqA/art.json index f52ab182..9ccb5bd6 100644 --- a/art/as29BXy9qihbCbPqA/art.json +++ b/art/as29BXy9qihbCbPqA/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chemlo", "avatarUrl": "https://secure.gravatar.com/avatar/bd1fc3e2f0d77392e06266faedc63267?default=retro&size=200", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/gamechops/dj-jo-lonely-rolling-star\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nfloat soundIntensity(float frq){\\n\\treturn texture2D(sound, vec2(frq, 0)).a;\\n}\\n\\nfloat soundIntensityDelta(float frq, float timeOffset){\\n\\tfloat currentIntensity = soundIntensity(frq); \\n \\treturn currentIntensity - texture2D(sound, vec2(frq, timeOffset)).a;\\n}\\n\\nfloat meanIntensity(){\\n \\tconst float samples = 25.;\\n \\tfloat intensity;\\n \\n for(float i = 0.; i < samples; i+=1./samples){\\n\\t\\tintensity += soundIntensity(i);\\n \\t}\\n \\n\\treturn intensity/samples;\\n}\\n\\nfloat meanIntensityDelta(float frq, float range){\\n \\tconst float samples = 25.;\\n \\tfloat intensity = 1.;\\n \\t\\n \\tfor(float i = 0.; i < samples; i+=1./samples){\\n \\tintensity += abs(soundIntensityDelta(frq, i*range));\\n \\t}\\n \\n\\treturn intensity/samples;\\n}\\n\\nvec3 getVertexColor(){\\n\\tfloat ratio = (vertexId/vertexCount);\\n \\tfloat intensity = soundIntensity(ratio);\\n \\n \\treturn vec3(\\n clamp(soundIntensity(ratio)/1.5, 0.0, 0.5),\\n clamp(0.4 + soundIntensity(ratio)*0.5 - meanIntensityDelta(ratio, 0.015)/4., 0.0, 0.4),\\n 0.5\\n );\\n}\\n\\nvoid main(){\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat timeMultiplier = 0.33;\\n \\tfloat perspective = 0.66;\\n \\n\\tfloat vertexRatio = (vertexId+1.)/vertexCount;\\n float vertexRadians = vertexRatio * 2.;\\n \\n float x = cos(vertexRadians*PI-time*timeMultiplier);\\n float y = sin(vertexRadians*PI-time*timeMultiplier) * perspective;\\n float z = soundIntensity((vertexId/vertexCount)) * perspective;\\n \\n gl_Position = vec4(\\n x,\\n y*aspect,\\n 1. - z,\\n 2.5 - z - meanIntensity()\\n );\\n \\n \\tv_color = vec4(getVertexColor(), 0.5);\\n \\n \\tgl_PointSize = pow(soundIntensity((vertexId/vertexCount))+1.5, 5.);\\n \\n\\n}\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "https://soundcloud.com/gamechops/dj-jo-lonely-rolling-star", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nfloat soundIntensity(float frq){\n\treturn texture2D(sound, vec2(frq, 0)).a;\n}\n\nfloat soundIntensityDelta(float frq, float timeOffset){\n\tfloat currentIntensity = soundIntensity(frq); \n \treturn currentIntensity - texture2D(sound, vec2(frq, timeOffset)).a;\n}\n\nfloat meanIntensity(){\n \tconst float samples = 25.;\n \tfloat intensity;\n \n for(float i = 0.; i < samples; i+=1./samples){\n\t\tintensity += soundIntensity(i);\n \t}\n \n\treturn intensity/samples;\n}\n\nfloat meanIntensityDelta(float frq, float range){\n \tconst float samples = 25.;\n \tfloat intensity = 1.;\n \t\n \tfor(float i = 0.; i < samples; i+=1./samples){\n \tintensity += abs(soundIntensityDelta(frq, i*range));\n \t}\n \n\treturn intensity/samples;\n}\n\nvec3 getVertexColor(){\n\tfloat ratio = (vertexId/vertexCount);\n \tfloat intensity = soundIntensity(ratio);\n \n \treturn vec3(\n clamp(soundIntensity(ratio)/1.5, 0.0, 0.5),\n clamp(0.4 + soundIntensity(ratio)*0.5 - meanIntensityDelta(ratio, 0.015)/4., 0.0, 0.4),\n 0.5\n );\n}\n\nvoid main(){\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat timeMultiplier = 0.33;\n \tfloat perspective = 0.66;\n \n\tfloat vertexRatio = (vertexId+1.)/vertexCount;\n float vertexRadians = vertexRatio * 2.;\n \n float x = cos(vertexRadians*PI-time*timeMultiplier);\n float y = sin(vertexRadians*PI-time*timeMultiplier) * perspective;\n float z = soundIntensity((vertexId/vertexCount)) * perspective;\n \n gl_Position = vec4(\n x,\n y*aspect,\n 1. - z,\n 2.5 - z - meanIntensity()\n );\n \n \tv_color = vec4(getVertexColor(), 0.5);\n \n \tgl_PointSize = pow(soundIntensity((vertexId/vertexCount))+1.5, 5.);\n \n\n}" + }, "screenshotURL": "data/images/images-v2qlmxxm74lsgizsz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/asSnAehpD5b5tuJ27/art.json b/art/asSnAehpD5b5tuJ27/art.json index 65c73797..5fefc020 100644 --- a/art/asSnAehpD5b5tuJ27/art.json +++ b/art/asSnAehpD5b5tuJ27/art.json @@ -11,7 +11,19 @@ "origId": "JsEv9AaC54NF6cY8Q", "name": "round", "username": "-anon-", - "settings": "{\"num\":88796,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jamie-berry/jamie-berry-sweet-rascal-original-mix-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.12941176470588237,0.01568627450980392,0.07058823529411765,1],\"shader\":\"#define NUM_SEGMENTS 64.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 32.0\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 16.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 122.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.2 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.32125;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n \\n gl_PointSize = min(32.0, 3.0 + pow((snd + 0.2) * 1.5, 10.0) * mix(13.0, 0.3, v));\\n\\n float x = u * PI * 12432329.0 + snd - 0.5 + sin(count + time * 0.00000) * 0.1450;\\n float y = v - pow(snd, 1.5) * 0.4 + 0.5;\\n float c = cos(x);\\n float s = sin(x);\\n vec2 xy = vec2(c * y, s * y);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 88796, + "mode": "POINTS", + "sound": "https://soundcloud.com/jamie-berry/jamie-berry-sweet-rascal-original-mix-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0.12941176470588237, + 0.01568627450980392, + 0.07058823529411765, + 1 + ], + "shader": "#define NUM_SEGMENTS 64.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 32.0\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 16.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 122.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.2 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.32125;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n \n gl_PointSize = min(32.0, 3.0 + pow((snd + 0.2) * 1.5, 10.0) * mix(13.0, 0.3, v));\n\n float x = u * PI * 12432329.0 + snd - 0.5 + sin(count + time * 0.00000) * 0.1450;\n float y = v - pow(snd, 1.5) * 0.4 + 0.5;\n float c = cos(x);\n float s = sin(x);\n vec2 xy = vec2(c * y, s * y);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "55igKnZWEY89oN9en", "views": { "$numberInt": "340" diff --git a/art/auetPcBpAZ2WyysTb/art.json b/art/auetPcBpAZ2WyysTb/art.json index 0bd4a1cb..62b9ef14 100644 --- a/art/auetPcBpAZ2WyysTb/art.json +++ b/art/auetPcBpAZ2WyysTb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":99999,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 2.9\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n fract(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n tan(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*fract(0.1492)*fract(0.999992);\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5));\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float t = time*.010;\\n float i = fract(240000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *=1.*atan(-.6);\\n pos.z += 0.7;\\n pos.xy *= 0.6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 13.0/pos.z* 0.09;\\n\\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\\n}\"}", + "settings": { + "num": 99999, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 2.9\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n fract(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n tan(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*fract(0.1492)*fract(0.999992);\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5));\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float t = time*.010;\n float i = fract(240000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *=1.*atan(-.6);\n pos.z += 0.7;\n pos.xy *= 0.6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 13.0/pos.z* 0.09;\n\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\n}" + }, "screenshotURL": "data/images/images-gcypxrg8ppp2ylt9b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/auo92EWvwwyBRak2c/art.json b/art/auo92EWvwwyBRak2c/art.json index 0ac6717a..88c8cd5d 100644 --- a/art/auo92EWvwwyBRak2c/art.json +++ b/art/auo92EWvwwyBRak2c/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":95256,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n // mat *= uniformScale(1.);\\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0.2, 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 95256, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n // mat *= uniformScale(1.);\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0.2, 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-s71rid2d21wxp86yw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/awe7tBGAsEHzRYs2D/art.json b/art/awe7tBGAsEHzRYs2D/art.json index 478ab6a1..6dad32a6 100644 --- a/art/awe7tBGAsEHzRYs2D/art.json +++ b/art/awe7tBGAsEHzRYs2D/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n \\n\\n if(v>0.5)\\n position.y = (1. -position.y);\\n \\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\t//j *= 1.;\\n\\tj = mod(j + time, 1.0);\\n\\t\\n\\tfloat i = mod( position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\\n\\t\\n i = mod( sin(position.y * 7.)*sin(position.x * 7.) * j, i / j);\\n \\n\\ti *= 5.;\\n\\t\\n\\t//i = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n \n\n if(v>0.5)\n position.y = (1. -position.y);\n \n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\t//j *= 1.;\n\tj = mod(j + time, 1.0);\n\t\n\tfloat i = mod( position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\n\t\n i = mod( sin(position.y * 7.)*sin(position.x * 7.) * j, i / j);\n \n\ti *= 5.;\n\t\n\t//i = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-nv6ou9xo1brgeywvg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/axgq9WTTCr84iSYkv/art.json b/art/axgq9WTTCr84iSYkv/art.json index baa98e4d..1df0b081 100644 --- a/art/axgq9WTTCr84iSYkv/art.json +++ b/art/axgq9WTTCr84iSYkv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2714,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dirtybirdrecords/claudevonstroke-dood\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n🔴\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=8000\\n\\n#define KP0 1.//KParameter 0.>>10.\\n#define KP1 1.//KParameter 0.1>>5.\\n#define KP2 0.//KParameter 0.0>>8.\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 / b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 - b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1.44,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), KP0.1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983 +KP0, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137* KP0));\\n\\treturn fract(p2.x * p2.y * 55.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / KP0 -3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.0 + KP1);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 1.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertsPerBlob = 6. * 45.;\\n float blobId = floor(vertexId / vertsPerBlob);\\n float numBlobs = floor(vertexCount / vertsPerBlob);\\n float bv = blobId / numBlobs;\\n float id = mod(vertexId, vertsPerBlob);\\n float numQuads = floor(vertsPerBlob / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(id / 7.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(id, 6.);\\n float ux = floor(id / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n vec3 nrm = pos;\\n \\n float tm = time * 0.1 * 1.;\\n float rd = 3.;\\n mat4 pmat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float groupId = floor(blobId / 2.);\\n float numGroups = floor(numBlobs / 2.);\\n float gv = groupId / numGroups;\\n float odd = mod(blobId, 2.);\\n \\n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, gv), 0.)).a;\\n float s1 = texture2D(sound, vec2(mix(0.5, 0.2 + KP2, gv), qv)).a;\\n \\n mat4 cmat = lookAt(eye, target, up); \\n mat4 vmat = inverse(cmat);\\n \\n float t0 = floor(time);\\n float t1 = floor(time + 1.);\\n vec3 p0 = vec3(\\n t2m1(hash(t0 * 0.123/KP0)), \\n t2m1(hash(t0 * 0.617)), \\n t2m1(hash(t0 * 0.371)/(t0+KP1)));\\n vec3 p1 = vec3(\\n t2m1(hash(t1 * 0.123)), \\n t2m1(hash(t1 * 0.617)-mouse.x), \\n t2m1(hash(t1 * 0.371)+KP1));\\n \\n #if 1\\n mat4 wmat = ident();\\n wmat *= trans(t2m1(s0) * .0 + \\n mix(p0, p1, fract(time)) +\\n cmat[2].xyz * -odd * 0.1);\\n #endif\\n wmat *= rotX(time + qv);\\n wmat *= rotY(time * .77);\\n wmat *= rotZ(gv);\\n wmat *= uniformScale(mix(0., 1.7, pow(s0 + .2, 5.)) + odd * 0.02);\\n //wmat *= scale(vec3(1, 1, 1. - odd));\\n //wmat *= uniformScale(0.4);\\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = -quadId + KP2 + 1.0 + id * 2.0;\\n float sat = 3.;\\n float val = 1. - odd;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n vec3 n = (cmat * wmat * vec4(nrm, 0)).xyz;\\n float l = dot(normalize(vec3(.5,1,-3)), n) * .1 + .9;\\n //mix(l, 1., pow(s0, .1));\\n \\n v_color.rgb *= v_color.a;\\n \\n #if 0\\n gl_Position.xy /= gl_Position.w;\\n gl_Position.z = bv;\\n gl_Position.w = 0.1\\n #endif\\n}\"}", + "settings": { + "num": 2714, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dirtybirdrecords/claudevonstroke-dood", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n🔴\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=8000\n\n#define KP0 1.//KParameter 0.>>10.\n#define KP1 1.//KParameter 0.1>>5.\n#define KP2 0.//KParameter 0.0>>8.\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 / b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 - b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1.44,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), KP0.1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983 +KP0, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137* KP0));\n\treturn fract(p2.x * p2.y * 55.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / KP0 -3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.0 + KP1);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 1.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertsPerBlob = 6. * 45.;\n float blobId = floor(vertexId / vertsPerBlob);\n float numBlobs = floor(vertexCount / vertsPerBlob);\n float bv = blobId / numBlobs;\n float id = mod(vertexId, vertsPerBlob);\n float numQuads = floor(vertsPerBlob / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(id / 7.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(id, 6.);\n float ux = floor(id / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n vec3 nrm = pos;\n \n float tm = time * 0.1 * 1.;\n float rd = 3.;\n mat4 pmat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float groupId = floor(blobId / 2.);\n float numGroups = floor(numBlobs / 2.);\n float gv = groupId / numGroups;\n float odd = mod(blobId, 2.);\n \n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, gv), 0.)).a;\n float s1 = texture2D(sound, vec2(mix(0.5, 0.2 + KP2, gv), qv)).a;\n \n mat4 cmat = lookAt(eye, target, up); \n mat4 vmat = inverse(cmat);\n \n float t0 = floor(time);\n float t1 = floor(time + 1.);\n vec3 p0 = vec3(\n t2m1(hash(t0 * 0.123/KP0)), \n t2m1(hash(t0 * 0.617)), \n t2m1(hash(t0 * 0.371)/(t0+KP1)));\n vec3 p1 = vec3(\n t2m1(hash(t1 * 0.123)), \n t2m1(hash(t1 * 0.617)-mouse.x), \n t2m1(hash(t1 * 0.371)+KP1));\n \n #if 1\n mat4 wmat = ident();\n wmat *= trans(t2m1(s0) * .0 + \n mix(p0, p1, fract(time)) +\n cmat[2].xyz * -odd * 0.1);\n #endif\n wmat *= rotX(time + qv);\n wmat *= rotY(time * .77);\n wmat *= rotZ(gv);\n wmat *= uniformScale(mix(0., 1.7, pow(s0 + .2, 5.)) + odd * 0.02);\n //wmat *= scale(vec3(1, 1, 1. - odd));\n //wmat *= uniformScale(0.4);\n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = -quadId + KP2 + 1.0 + id * 2.0;\n float sat = 3.;\n float val = 1. - odd;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n vec3 n = (cmat * wmat * vec4(nrm, 0)).xyz;\n float l = dot(normalize(vec3(.5,1,-3)), n) * .1 + .9;\n //mix(l, 1., pow(s0, .1));\n \n v_color.rgb *= v_color.a;\n \n #if 0\n gl_Position.xy /= gl_Position.w;\n gl_Position.z = bv;\n gl_Position.w = 0.1\n #endif\n}" + }, "screenshotURL": "data/images/images-g62klv9uyy23pkrb9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/aynW9zWZRGxronmcP/art.json b/art/aynW9zWZRGxronmcP/art.json index 17dea53f..10d04699 100644 --- a/art/aynW9zWZRGxronmcP/art.json +++ b/art/aynW9zWZRGxronmcP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":70514,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(10.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /72. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x / p2.y * 165.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v+ 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 65.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 211.2 / PI) + (12.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c +v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 4.0);\\n float side = mix(-11., 5.3, step(1., mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 *mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd ,11.9 *mouse.x- circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 10.3 *+ snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\\n}\"}", + "settings": { + "num": 70514, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(10.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /72. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\n\treturn fract(p2.x / p2.y * 165.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v+ 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 65.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 211.2 / PI) + (12.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c +v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 4.0);\n float side = mix(-11., 5.3, step(1., mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 *mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd ,11.9 *mouse.x- circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 10.3 *+ snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\n}" + }, "screenshotURL": "data/images/images-zccb967zu9r7scfa8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/b2AspWSvDsXib8Kkc/art.json b/art/b2AspWSvDsXib8Kkc/art.json index c9ce9b55..1135f60b 100644 --- a/art/b2AspWSvDsXib8Kkc/art.json +++ b/art/b2AspWSvDsXib8Kkc/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":2400,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 3.0;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\t\\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat countSection = floor(6.);\\n\\t\\n\\tfloat indexCircle = floor(indexQuad / countSection);\\n\\t\\n\\tfloat astep = 3.14159 * 2.0 / countSection;\\n\\t\\n\\tfloat angle0 = indexQuad * astep;\\n\\tfloat angle1 = (indexQuad + 1.) * astep;\\n\\t\\n\\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\\n\\tfloat angleTorus = indexCircle * astepTorus;\\n\\t\\n\\tfloat radius = 4. * cos(angleTorus * 1.5 + time) * 2.;\\n\\t\\n\\t// triangle 1\\n\\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\\n\\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\\n\\t\\n \\tfloat atten = p.x;\\n \\n\\tp *= RotX(-angleTorus);\\n\\t\\n\\tp.z += 11. * cos(angleTorus);\\n\\tp.y += 11. * sin(angleTorus);\\n\\t\\n\\t// cam\\n\\tfloat ca = 3.14159 * 0.6;\\n\\tfloat cd = 50.;\\n\\tvec3 eye = vec3(sin(ca), 0.5, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n \\t// pos\\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\t// color\\n \\tp /= atten;\\n \\n\\tv_color = vec4(normalize(p) * 0.5 + 0.5, 1);\\n}\"}", + "settings": { + "num": 2400, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvoid main()\n{\n\tgl_PointSize = 3.0;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tvec3 p = vec3(0);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\t\n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat countSection = floor(6.);\n\t\n\tfloat indexCircle = floor(indexQuad / countSection);\n\t\n\tfloat astep = 3.14159 * 2.0 / countSection;\n\t\n\tfloat angle0 = indexQuad * astep;\n\tfloat angle1 = (indexQuad + 1.) * astep;\n\t\n\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\n\tfloat angleTorus = indexCircle * astepTorus;\n\t\n\tfloat radius = 4. * cos(angleTorus * 1.5 + time) * 2.;\n\t\n\t// triangle 1\n\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\n\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\t\n\t// triangle 2\n\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\n\t\n \tfloat atten = p.x;\n \n\tp *= RotX(-angleTorus);\n\t\n\tp.z += 11. * cos(angleTorus);\n\tp.y += 11. * sin(angleTorus);\n\t\n\t// cam\n\tfloat ca = 3.14159 * 0.6;\n\tfloat cd = 50.;\n\tvec3 eye = vec3(sin(ca), 0.5, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n \t// pos\n\tgl_Position = camera * vec4(p, 1);\n\t\n \t// color\n \tp /= atten;\n \n\tv_color = vec4(normalize(p) * 0.5 + 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-2ek98fepqfdnydxkm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/b32w7foxrhZkD9GeR/art.json b/art/b32w7foxrhZkD9GeR/art.json index 09b98b7f..defca3b7 100644 --- a/art/b32w7foxrhZkD9GeR/art.json +++ b/art/b32w7foxrhZkD9GeR/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "tom", "avatarUrl": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/photo.jpg", - "settings": "{\"num\":32768,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\nvec4 project(vec3 p) {\\n p.x *= resolution.y/resolution.x;\\n const float near = .9, far = 3.;\\n const float a = -(near+far)/(near-far);\\n const float b = 2.*near*far/(near-far); \\n return vec4(p.xy, a*p.z + b, p.z);\\n}\\n\\nvoid main () {\\n float u = vertexId * (1./256.);\\n float v = floor(u);\\n u = (u - v) * 2. * PI;\\n v *= PI / 128.;\\n \\n u += time * .1;\\n \\n // 3D polar sphere coords:\\n float sin_v = sin(v);\\n vec3 n = vec3(cos(u) * sin_v, cos(v), sin(u) * sin_v);\\n v_color = vec4(vec3(-n.z*.8), 1.);\\n \\n vec4 p = project(n + vec3(0.,0.,2.));\\n \\n // Deform in 2d:\\n float scale = .1*p.w*mouse.x;\\n p.x += cos(n.y*4.)*scale;\\n p.y += cos(n.x*8.)*scale;\\n \\n gl_Position = p;\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 32768, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\nvec4 project(vec3 p) {\n p.x *= resolution.y/resolution.x;\n const float near = .9, far = 3.;\n const float a = -(near+far)/(near-far);\n const float b = 2.*near*far/(near-far); \n return vec4(p.xy, a*p.z + b, p.z);\n}\n\nvoid main () {\n float u = vertexId * (1./256.);\n float v = floor(u);\n u = (u - v) * 2. * PI;\n v *= PI / 128.;\n \n u += time * .1;\n \n // 3D polar sphere coords:\n float sin_v = sin(v);\n vec3 n = vec3(cos(u) * sin_v, cos(v), sin(u) * sin_v);\n v_color = vec4(vec3(-n.z*.8), 1.);\n \n vec4 p = project(n + vec3(0.,0.,2.));\n \n // Deform in 2d:\n float scale = .1*p.w*mouse.x;\n p.x += cos(n.y*4.)*scale;\n p.y += cos(n.x*8.)*scale;\n \n gl_Position = p;\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-fl0hp7ii28jm0o1wn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/b3HJWpHiePeAo4JrM/art.json b/art/b3HJWpHiePeAo4JrM/art.json index 2d94a20f..c748a926 100644 --- a/art/b3HJWpHiePeAo4JrM/art.json +++ b/art/b3HJWpHiePeAo4JrM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat xoff = sin(time + y * 2.0 ) * 0.5;\\n \\tfloat yoff = cos(time + x * 3.0) * 0.5;\\n \\n \\tfloat ux = u * 2.0 - 1.0 * xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux , vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n\\n \\n \\tgl_PointSize = 15.0 ;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n\\n \\t\\n \\tv_color = vec4(1, 0.5, 0.5, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat xoff = sin(time + y * 2.0 ) * 0.5;\n \tfloat yoff = cos(time + x * 3.0) * 0.5;\n \n \tfloat ux = u * 2.0 - 1.0 * xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux , vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n\n \n \tgl_PointSize = 15.0 ;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.;\n\n \t\n \tv_color = vec4(1, 0.5, 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-c35b35ngfjae182ra-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/b3WFbQ4SDWLwXbcSp/art.json b/art/b3WFbQ4SDWLwXbcSp/art.json index 6eeeb6c4..a37aae39 100644 --- a/art/b3WFbQ4SDWLwXbcSp/art.json +++ b/art/b3WFbQ4SDWLwXbcSp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define WIDTH 20.\\n#define SPACING 20.\\n#define LINE_LENGTH 10.\\n\\n/*\\n\\nNote that every line is perpendicular to (\\\"facing\\\") the mouse\\n\\n*/\\n\\nvec2 field(vec2 pos) {\\n // just for easier readability\\n float x = pos.x;\\n float y = pos.y;\\n \\n // vector field mapping\\n return vec2(\\n -y,\\n x\\n );\\n}\\n\\nvoid main() {\\n // droplet grid positioning\\n float x = floor(floor(vertexId/2.) / WIDTH) / SPACING;\\n float y = mod(floor(vertexId/2.), WIDTH) / SPACING;\\n vec2 line_pos = vec2(2.*x - 1.,2.*y - 1.);\\n \\n // droplet position in this example\\n gl_Position = vec4(line_pos.x, line_pos.y, 0,1);\\n \\n // apply vector field to the next connecting point\\n // to demonstrate effect of vector field\\n if (mod(vertexId, 2.) == 1.) {\\n \\n // uses the field to calculate the displacement relative to the mouse's xy\\n vec2 d = field(line_pos.xy - mouse.xy);\\n \\n // apply field calculation to vertex\\n d = normalize(d) / LINE_LENGTH;\\n gl_Position += vec4(d.x, d.y, 0,0);\\n }\\n \\n gl_PointSize = 4.;\\n v_color = vec4(mod(vertexId, 2.),1,1,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define WIDTH 20.\n#define SPACING 20.\n#define LINE_LENGTH 10.\n\n/*\n\nNote that every line is perpendicular to (\"facing\") the mouse\n\n*/\n\nvec2 field(vec2 pos) {\n // just for easier readability\n float x = pos.x;\n float y = pos.y;\n \n // vector field mapping\n return vec2(\n -y,\n x\n );\n}\n\nvoid main() {\n // droplet grid positioning\n float x = floor(floor(vertexId/2.) / WIDTH) / SPACING;\n float y = mod(floor(vertexId/2.), WIDTH) / SPACING;\n vec2 line_pos = vec2(2.*x - 1.,2.*y - 1.);\n \n // droplet position in this example\n gl_Position = vec4(line_pos.x, line_pos.y, 0,1);\n \n // apply vector field to the next connecting point\n // to demonstrate effect of vector field\n if (mod(vertexId, 2.) == 1.) {\n \n // uses the field to calculate the displacement relative to the mouse's xy\n vec2 d = field(line_pos.xy - mouse.xy);\n \n // apply field calculation to vertex\n d = normalize(d) / LINE_LENGTH;\n gl_Position += vec4(d.x, d.y, 0,0);\n }\n \n gl_PointSize = 4.;\n v_color = vec4(mod(vertexId, 2.),1,1,1);\n}" + }, "screenshotURL": "data/images/images-fwmwqwqtzlc2aq39a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/b5fN5z5ZFYzsQukHD/art.json b/art/b5fN5z5ZFYzsQukHD/art.json index fa4ac01c..e2781dc5 100644 --- a/art/b5fN5z5ZFYzsQukHD/art.json +++ b/art/b5fN5z5ZFYzsQukHD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 9.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 9.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-x95nqjo5vt1wfrrtr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/b6di9dPczq6ZikLtM/art.json b/art/b6di9dPczq6ZikLtM/art.json index b74fa841..9b74d1c7 100644 --- a/art/b6di9dPczq6ZikLtM/art.json +++ b/art/b6di9dPczq6ZikLtM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2400,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 3.0;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\t\\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat countSection = floor(6.);\\n\\t\\n\\tfloat indexCircle = floor(indexQuad / countSection);\\n\\t\\n\\tfloat astep = 3.14159 * 2.0 / countSection;\\n\\t\\n\\tfloat angle0 = indexQuad * astep;\\n\\tfloat angle1 = (indexQuad + 1.) * astep;\\n\\t\\n\\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\\n\\tfloat angleTorus = indexCircle * astepTorus;\\n\\t\\n\\tfloat radius = 4. * cos(angleTorus * 0.5 + time) * 2.;\\n\\t\\n\\t// triangle 1\\n\\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\\n\\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\\n\\t\\n \\tfloat atten = p.x;\\n \\n\\tp *= RotX(-angleTorus);\\n\\t\\n\\tp.z += 11. * cos(angleTorus);\\n\\tp.y += 11. * sin(angleTorus);\\n\\t\\n\\t// cam\\n\\tfloat ca = 3.14159 * 0.6;\\n\\tfloat cd = 50.;\\n\\tvec3 eye = vec3(sin(ca), 0.5, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n \\t// pos\\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\t// color\\n \\tp /= atten;\\n \\n\\tv_color = vec4(normalize(p) * 0.5 + 0.5, 1);\\n}\"}", + "settings": { + "num": 2400, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvoid main()\n{\n\tgl_PointSize = 3.0;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tvec3 p = vec3(0);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\t\n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat countSection = floor(6.);\n\t\n\tfloat indexCircle = floor(indexQuad / countSection);\n\t\n\tfloat astep = 3.14159 * 2.0 / countSection;\n\t\n\tfloat angle0 = indexQuad * astep;\n\tfloat angle1 = (indexQuad + 1.) * astep;\n\t\n\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\n\tfloat angleTorus = indexCircle * astepTorus;\n\t\n\tfloat radius = 4. * cos(angleTorus * 0.5 + time) * 2.;\n\t\n\t// triangle 1\n\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\n\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\t\n\t// triangle 2\n\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\n\t\n \tfloat atten = p.x;\n \n\tp *= RotX(-angleTorus);\n\t\n\tp.z += 11. * cos(angleTorus);\n\tp.y += 11. * sin(angleTorus);\n\t\n\t// cam\n\tfloat ca = 3.14159 * 0.6;\n\tfloat cd = 50.;\n\tvec3 eye = vec3(sin(ca), 0.5, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n \t// pos\n\tgl_Position = camera * vec4(p, 1);\n\t\n \t// color\n \tp /= atten;\n \n\tv_color = vec4(normalize(p) * 0.5 + 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-cg2i9848v9l6ikhdm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/b9J4bEZw9Z2qRJm5f/art.json b/art/b9J4bEZw9Z2qRJm5f/art.json index 93ff81be..5a120e37 100644 --- a/art/b9J4bEZw9Z2qRJm5f/art.json +++ b/art/b9J4bEZw9Z2qRJm5f/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/feuerhaus/donauwalzer-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Planet Polygon - @P_Malin\\n\\n// Switch the primitive type to LINES to see how the background sun flare is rendered!\\n\\nfloat g_cameraFar = 8000.0;\\n\\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\n\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\nfloat GetCosSunRadius( vec3 vCameraPos )\\n{\\n \\tfloat d = length( vCameraPos - GetSunPosition() );\\n \\treturn 100.0 / d;\\n}\\n\\nfloat GetSunIntensity( vec3 vCameraPos )\\n{\\n \\tfloat d = length( vCameraPos - GetSunPosition() );\\n \\treturn 1000.0 / (d * d);\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n\\tfloat fGloss;\\n};\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = surfaceInfo.fGloss;\\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\\n}\\n\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n AddDirectionalLight( GetSunDir(vCameraPos), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor, float fExposure )\\n{\\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n\\tfloat fAlpha;\\n};\\n\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir(vCameraPos) );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity( vCameraPos ) / pow(fShade, 1.5);\\n \\n return vec3( fShade * g_sunColor ); \\n}\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t32.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n \\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0.0) && (fMinDist < 100.0 ) )\\n {\\n \\tfShadowAttn = (fClosestDist2 - fSphereRadius2) + 10.0;\\n \\tfShadowAttn *= 0.025;\\n \\tfShadowAttn = clamp( fShadowAttn, 0.0, 1.0);\\n }\\n\\t} \\n \\n \\treturn fShadowAttn;\\n}\\n\\n#define g_ringSegments \\t\\t\\t128.0\\n#define g_ringQuads \\t\\t\\t( g_ringSegments * 3.0 )\\n#define g_ringVertexCount \\t\\t( g_ringQuads * 6.0 )\\n\\nvoid GenerateRingVertex( const float vertexIndex, const vec3 vCameraPos, PlanetInfo planetInfo, out SceneVertex outSceneVertex, float fInnerRadius, float fOuterRadius, float fRandom )\\n{\\n vec2 vDim = vec2( g_ringSegments, 3 );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vUV );\\n\\n \\tvec3 vRingPos;\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\n \\tfloat fRadiusPos = vUV.y;\\n \\n \\tif( vUV.y < 0.5 ) fRadiusPos = 0.0; else fRadiusPos = 1.0;\\n\\n \\n \\tfloat fRadius = fInnerRadius + fRadiusPos * (fOuterRadius - fInnerRadius);\\n\\n \\tif ( vUV.y < 0.01 ) fRadius-= 0.02;\\n \\tif ( vUV.y > 0.99 ) fRadius+= 0.02;\\n \\n \\tvRingPos.y = 0.0;\\n \\tvRingPos.x = sin( fHeading ) * fRadius;\\n \\tvRingPos.z = cos( fHeading ) * fRadius;\\n \\n outSceneVertex.vWorldPos = PlanetPosToWorld( planetInfo, vRingPos );\\n \\n \\tfloat fShadow = GetPlanetShadow( outSceneVertex.vWorldPos, vCameraPos, planetInfo );\\n \\n \\tfloat fAlpha = ( fRandom * 0.5 + 0.5);\\n\\tfAlpha = fAlpha * fAlpha;\\n \\n \\tvec3 vAlbedo = mix( planetInfo.vRingColor0, planetInfo.vRingColor1, fRandom );\\n \\n \\tSurfaceInfo surfaceInfo;\\n \\tsurfaceInfo.vPos = outSceneVertex.vWorldPos;\\n \\tsurfaceInfo.vNormal = PlanetNormalToWorld( planetInfo, vec3(0.0, 1.0, 0.0) );\\n \\tsurfaceInfo.fGloss = 20.0;\\n\\n outSceneVertex.vColor = LightSurface( surfaceInfo, vCameraPos, vAlbedo, fShadow );\\n\\n \\t// Hack lighting from other side\\n \\tvec3 vCameraDir = vCameraPos - surfaceInfo.vPos;\\n \\tvCameraDir = reflect( vCameraDir, surfaceInfo.vNormal );\\n \\tvec3 otherSideCameraPos = vCameraDir + surfaceInfo.vPos;\\n outSceneVertex.vColor += LightSurface( surfaceInfo, otherSideCameraPos, vAlbedo, fShadow ) * 0.1;\\n\\n \\tfAlpha *= 1.0 - abs( vUV.y * 2.0 - 1.0 );\\n \\n \\tfloat NdotV = normalize(vCameraPos).y;\\n \\tfAlpha = mix( fAlpha, 1.0, exp2( abs(NdotV) * -5.0 ) );\\n \\n \\toutSceneVertex.fAlpha = fAlpha;\\n} \\n\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\tfloat orbitAngle = time * 0.4 + 2.5;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tPlanetInfo planetInfo;\\n \\n#if 1\\n //\\tplanetInfo.vSurfaceColor0 = vec3(0.36, 0.16, 0.0001);\\n //\\tplanetInfo.vSurfaceColor1 = vec3(1.0, 0.36, 0.000001);\\n \\n \\n \\n \\tplanetInfo.vOrigin = vec3(0.0);\\n \\tplanetInfo.fRadius = 5.0;\\n \\n \\tplanetInfo.fSegments = 64.0;\\n \\tplanetInfo.fSlices = 48.0;\\n \\n#else \\n#endif \\n \\n \\tfloat fOrbitDistance = (planetInfo.fRadius * 2.0) ;\\n \\n \\tvec3 vCameraPos = vec3( sin(orbitAngle), 2. , cos(orbitAngle) ) * fOrbitDistance;\\n \\tvec3 vCameraTarget = vec3( 0.0, planetInfo.fRadius * 0.2, 0.0 );\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n /* \\n \\t// Backdrop\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n*/\\n \\tvertexIndex -= g_backdropVertexCount;\\n/*\\n \\t// Stars\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_starVertexCount )\\n {\\n \\tGenerateStarVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n*/\\n \\tvertexIndex -= g_starVertexCount;\\n \\n \\t// Planet\\n \\tfloat fPlanetVertexCount = GetPlanetVertexCount(planetInfo);\\n //\\tfPlanetVertexCount = 1. ; \\n if ( vertexIndex >= 0.0 && vertexIndex < fPlanetVertexCount )\\n {\\n \\tGeneratePlanetVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex );\\n }\\n \\tvertexIndex -= fPlanetVertexCount;\\n/*\\n \\t// Moon \\n \\tconst int kMaxMoonCount = 5;\\n \\tfloat fMoonDist = planetInfo.fRadius * 6.0;\\n \\tfor( int moonIndex=0; moonIndex < kMaxMoonCount; moonIndex++ )\\n {\\n \\tif(moonIndex < planetInfo.iMoonCount)\\n {\\n PlanetInfo moonInfo;\\n\\n moonInfo.vSurfaceColor0 = vec3(0.7);\\n moonInfo.vSurfaceColor1 = vec3(0.5);\\n\\n moonInfo.textureScale = 100.0;\\n moonInfo.texturePersistence = 0.5;\\n moonInfo.surfaceType = 0.9;\\n\\n\\n moonInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\\n moonInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\\n\\n moonInfo.hasRings = false;\\n\\n float fAngle = hash11(fMoonDist) * 12.345 ;\\n moonInfo.vOrigin = vec3(sin(fAngle), 0.0, cos(fAngle)) * fMoonDist;\\n moonInfo.fRadius = planetInfo.fRadius * 0.025;\\n fMoonDist = fMoonDist * 1.8;\\n\\n moonInfo.fSegments = 16.0;\\n moonInfo.fSlices = 16.0;\\n\\n moonInfo.iMoonCount = 0;\\n \\n float fMoonVertexCount = GetPlanetVertexCount(moonInfo);\\n if ( vertexIndex >= 0.0 && vertexIndex < fMoonVertexCount )\\n {\\n GeneratePlanetVertex( vertexIndex, vCameraPos, moonInfo, sceneVertex );\\n }\\n vertexIndex -= fMoonVertexCount;\\n \\n } \\n }\\n */\\n \\n \\t// Ring\\n \\tif ( planetInfo.hasRings )\\n {\\n float fRingInner = 8.0;\\n float fRingSize = 2.0;\\n float fRingSeed = 0.0; \\t\\n for ( int ringIndex = 0; ringIndex < 6; ringIndex++ )\\n {\\n if ( vertexIndex >= 0.0 && vertexIndex < g_ringVertexCount )\\n {\\n GenerateRingVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex, fRingInner, fRingInner + fRingSize, hash11(fRingInner) );\\n }\\n vertexIndex -= g_ringVertexCount;\\n\\n fRingInner += fRingSize;\\n fRingInner += 0.02 + (sin( fRingSeed * 123.432 ) * 0.5 + 0.5) * 0.25;\\n float fSizeRandom = sin( fRingSeed * 423.432 ) * 0.5 + 0.5;\\n fRingSize = 0.1 + fSizeRandom * fSizeRandom * 2.0;\\n fRingSeed += 1.0;\\n }\\n }\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n sceneVertex.vWorldPos = vec3(0.0);\\n sceneVertex.vColor = vec3(0.0);\\n sceneVertex.fAlpha = 0.0;\\n }\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tvec3 vFinalColor = sceneVertex.vColor;\\n \\n \\tvFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \\n \\n \\tfloat VdotL = dot( vCameraForwards, -GetSunDir(vCameraPos) );\\n \\n \\t// Adjust exposure if we are looking towards the sun\\n \\tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\\n \\n \\tfExposure /= GetSunIntensity( vCameraPos ) * 100000.0;\\n \\n \\tfExposure += 0.5;\\n \\n \\tfExposure *= min( 1.0, time / 5.0 );\\n \\n \\tvFinalColor = PostProcess( vFinalColor, fExposure );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/feuerhaus/donauwalzer-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Planet Polygon - @P_Malin\n\n// Switch the primitive type to LINES to see how the background sun flare is rendered!\n\nfloat g_cameraFar = 8000.0;\n\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\n\n\n#define PI radians( 180.0 )\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\n\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\nfloat GetCosSunRadius( vec3 vCameraPos )\n{\n \tfloat d = length( vCameraPos - GetSunPosition() );\n \treturn 100.0 / d;\n}\n\nfloat GetSunIntensity( vec3 vCameraPos )\n{\n \tfloat d = length( vCameraPos - GetSunPosition() );\n \treturn 1000.0 / (d * d);\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n\tfloat fGloss;\n};\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = surfaceInfo.fGloss;\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\n}\n\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n AddDirectionalLight( GetSunDir(vCameraPos), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor, float fExposure )\n{\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n\tfloat fAlpha;\n};\n\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir(vCameraPos) );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius(vCameraPos);\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity( vCameraPos ) / pow(fShade, 1.5);\n \n return vec3( fShade * g_sunColor ); \n}\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t32.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n \n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0.0) && (fMinDist < 100.0 ) )\n {\n \tfShadowAttn = (fClosestDist2 - fSphereRadius2) + 10.0;\n \tfShadowAttn *= 0.025;\n \tfShadowAttn = clamp( fShadowAttn, 0.0, 1.0);\n }\n\t} \n \n \treturn fShadowAttn;\n}\n\n#define g_ringSegments \t\t\t128.0\n#define g_ringQuads \t\t\t( g_ringSegments * 3.0 )\n#define g_ringVertexCount \t\t( g_ringQuads * 6.0 )\n\nvoid GenerateRingVertex( const float vertexIndex, const vec3 vCameraPos, PlanetInfo planetInfo, out SceneVertex outSceneVertex, float fInnerRadius, float fOuterRadius, float fRandom )\n{\n vec2 vDim = vec2( g_ringSegments, 3 );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vUV );\n\n \tvec3 vRingPos;\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \n \tfloat fRadiusPos = vUV.y;\n \n \tif( vUV.y < 0.5 ) fRadiusPos = 0.0; else fRadiusPos = 1.0;\n\n \n \tfloat fRadius = fInnerRadius + fRadiusPos * (fOuterRadius - fInnerRadius);\n\n \tif ( vUV.y < 0.01 ) fRadius-= 0.02;\n \tif ( vUV.y > 0.99 ) fRadius+= 0.02;\n \n \tvRingPos.y = 0.0;\n \tvRingPos.x = sin( fHeading ) * fRadius;\n \tvRingPos.z = cos( fHeading ) * fRadius;\n \n outSceneVertex.vWorldPos = PlanetPosToWorld( planetInfo, vRingPos );\n \n \tfloat fShadow = GetPlanetShadow( outSceneVertex.vWorldPos, vCameraPos, planetInfo );\n \n \tfloat fAlpha = ( fRandom * 0.5 + 0.5);\n\tfAlpha = fAlpha * fAlpha;\n \n \tvec3 vAlbedo = mix( planetInfo.vRingColor0, planetInfo.vRingColor1, fRandom );\n \n \tSurfaceInfo surfaceInfo;\n \tsurfaceInfo.vPos = outSceneVertex.vWorldPos;\n \tsurfaceInfo.vNormal = PlanetNormalToWorld( planetInfo, vec3(0.0, 1.0, 0.0) );\n \tsurfaceInfo.fGloss = 20.0;\n\n outSceneVertex.vColor = LightSurface( surfaceInfo, vCameraPos, vAlbedo, fShadow );\n\n \t// Hack lighting from other side\n \tvec3 vCameraDir = vCameraPos - surfaceInfo.vPos;\n \tvCameraDir = reflect( vCameraDir, surfaceInfo.vNormal );\n \tvec3 otherSideCameraPos = vCameraDir + surfaceInfo.vPos;\n outSceneVertex.vColor += LightSurface( surfaceInfo, otherSideCameraPos, vAlbedo, fShadow ) * 0.1;\n\n \tfAlpha *= 1.0 - abs( vUV.y * 2.0 - 1.0 );\n \n \tfloat NdotV = normalize(vCameraPos).y;\n \tfAlpha = mix( fAlpha, 1.0, exp2( abs(NdotV) * -5.0 ) );\n \n \toutSceneVertex.fAlpha = fAlpha;\n} \n\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \tfloat orbitAngle = time * 0.4 + 2.5;\n \n \tfloat fov = 1.5;\n \n \tPlanetInfo planetInfo;\n \n#if 1\n //\tplanetInfo.vSurfaceColor0 = vec3(0.36, 0.16, 0.0001);\n //\tplanetInfo.vSurfaceColor1 = vec3(1.0, 0.36, 0.000001);\n \n \n \n \tplanetInfo.vOrigin = vec3(0.0);\n \tplanetInfo.fRadius = 5.0;\n \n \tplanetInfo.fSegments = 64.0;\n \tplanetInfo.fSlices = 48.0;\n \n#else \n#endif \n \n \tfloat fOrbitDistance = (planetInfo.fRadius * 2.0) ;\n \n \tvec3 vCameraPos = vec3( sin(orbitAngle), 2. , cos(orbitAngle) ) * fOrbitDistance;\n \tvec3 vCameraTarget = vec3( 0.0, planetInfo.fRadius * 0.2, 0.0 );\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n /* \n \t// Backdrop\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n*/\n \tvertexIndex -= g_backdropVertexCount;\n/*\n \t// Stars\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_starVertexCount )\n {\n \tGenerateStarVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n*/\n \tvertexIndex -= g_starVertexCount;\n \n \t// Planet\n \tfloat fPlanetVertexCount = GetPlanetVertexCount(planetInfo);\n //\tfPlanetVertexCount = 1. ; \n if ( vertexIndex >= 0.0 && vertexIndex < fPlanetVertexCount )\n {\n \tGeneratePlanetVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex );\n }\n \tvertexIndex -= fPlanetVertexCount;\n/*\n \t// Moon \n \tconst int kMaxMoonCount = 5;\n \tfloat fMoonDist = planetInfo.fRadius * 6.0;\n \tfor( int moonIndex=0; moonIndex < kMaxMoonCount; moonIndex++ )\n {\n \tif(moonIndex < planetInfo.iMoonCount)\n {\n PlanetInfo moonInfo;\n\n moonInfo.vSurfaceColor0 = vec3(0.7);\n moonInfo.vSurfaceColor1 = vec3(0.5);\n\n moonInfo.textureScale = 100.0;\n moonInfo.texturePersistence = 0.5;\n moonInfo.surfaceType = 0.9;\n\n\n moonInfo.vRingColor0 = vec3(1.0, 0.64, 0.09);\n moonInfo.vRingColor1 = vec3(0.36, 0.16, 0.0001);\n\n moonInfo.hasRings = false;\n\n float fAngle = hash11(fMoonDist) * 12.345 ;\n moonInfo.vOrigin = vec3(sin(fAngle), 0.0, cos(fAngle)) * fMoonDist;\n moonInfo.fRadius = planetInfo.fRadius * 0.025;\n fMoonDist = fMoonDist * 1.8;\n\n moonInfo.fSegments = 16.0;\n moonInfo.fSlices = 16.0;\n\n moonInfo.iMoonCount = 0;\n \n float fMoonVertexCount = GetPlanetVertexCount(moonInfo);\n if ( vertexIndex >= 0.0 && vertexIndex < fMoonVertexCount )\n {\n GeneratePlanetVertex( vertexIndex, vCameraPos, moonInfo, sceneVertex );\n }\n vertexIndex -= fMoonVertexCount;\n \n } \n }\n */\n \n \t// Ring\n \tif ( planetInfo.hasRings )\n {\n float fRingInner = 8.0;\n float fRingSize = 2.0;\n float fRingSeed = 0.0; \t\n for ( int ringIndex = 0; ringIndex < 6; ringIndex++ )\n {\n if ( vertexIndex >= 0.0 && vertexIndex < g_ringVertexCount )\n {\n GenerateRingVertex( vertexIndex, vCameraPos, planetInfo, sceneVertex, fRingInner, fRingInner + fRingSize, hash11(fRingInner) );\n }\n vertexIndex -= g_ringVertexCount;\n\n fRingInner += fRingSize;\n fRingInner += 0.02 + (sin( fRingSeed * 123.432 ) * 0.5 + 0.5) * 0.25;\n float fSizeRandom = sin( fRingSeed * 423.432 ) * 0.5 + 0.5;\n fRingSize = 0.1 + fSizeRandom * fSizeRandom * 2.0;\n fRingSeed += 1.0;\n }\n }\n \n \tif ( vertexIndex >= 0.0 )\n {\n sceneVertex.vWorldPos = vec3(0.0);\n sceneVertex.vColor = vec3(0.0);\n sceneVertex.fAlpha = 0.0;\n }\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tvec3 vFinalColor = sceneVertex.vColor;\n \n \tvFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \n \n \tfloat VdotL = dot( vCameraForwards, -GetSunDir(vCameraPos) );\n \n \t// Adjust exposure if we are looking towards the sun\n \tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\n \n \tfExposure /= GetSunIntensity( vCameraPos ) * 100000.0;\n \n \tfExposure += 0.5;\n \n \tfExposure *= min( 1.0, time / 5.0 );\n \n \tvFinalColor = PostProcess( vFinalColor, fExposure );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}\n\n" + }, "screenshotURL": "data/images/images-nidt3qols9exy4aqf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bBkRA4ZZ72cHNA7Xz/art.json b/art/bBkRA4ZZ72cHNA7Xz/art.json index 7ef27996..c4e6c447 100644 --- a/art/bBkRA4ZZ72cHNA7Xz/art.json +++ b/art/bBkRA4ZZ72cHNA7Xz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .05; p = mod(p/7., 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 fragcoord = vec2(x,y);\\n \\n\\tvec3 p = vec3((fragcoord.xy-resolution/2.0)/(resolution.y),mouse.x);\\n\\tvec2 p2 = vec2(fragcoord.xy/resolution);\\n\\t\\n\\tfor (int i = 0; i < 4; i++){\\n\\t p = abs(tan(atan(abs(atan(p)))/dot(p,sin( .5*p))));\\n\\t if(length(p) > 0.9 && length(p) < 1.04)break;\\n\\t}\\n \\n\\t//gl_FragColor.rgb = p;\\n\\t//gl_FragColor.a = 1.0;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(p,1.);\\n \\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .05; p = mod(p/7., 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 fragcoord = vec2(x,y);\n \n\tvec3 p = vec3((fragcoord.xy-resolution/2.0)/(resolution.y),mouse.x);\n\tvec2 p2 = vec2(fragcoord.xy/resolution);\n\t\n\tfor (int i = 0; i < 4; i++){\n\t p = abs(tan(atan(abs(atan(p)))/dot(p,sin( .5*p))));\n\t if(length(p) > 0.9 && length(p) < 1.04)break;\n\t}\n \n\t//gl_FragColor.rgb = p;\n\t//gl_FragColor.a = 1.0;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(p,1.);\n \n\n}" + }, "screenshotURL": "data/images/images-myt8ouaqffi6o7mv5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bD2aNq4oSF5v8z3Q9/art.json b/art/bD2aNq4oSF5v8z3Q9/art.json index 47107438..6568ccb7 100644 --- a/art/bD2aNq4oSF5v8z3Q9/art.json +++ b/art/bD2aNq4oSF5v8z3Q9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 0, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, c,-s, 1,\\n c+s, 1, 1, 1,\\n s, s, c, 1,\\n 1, 1, 1, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, c*s, 0,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, c, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n s, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 2,\\n 3, 1, 0, 1,\\n 0, 0, 1, 0,\\n trans, 3);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 3,\\n 0, 0, 1, 2,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 3, 3, s,\\n 0, s, s, 2,\\n 0, s, s, 2,\\n s, 1, 1, s);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 1, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 0, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, c,-s, 1,\n c+s, 1, 1, 1,\n s, s, c, 1,\n 1, 1, 1, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, c*s, 0,\n 0, 0, 0, 0); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, c, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n s, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 2,\n 3, 1, 0, 1,\n 0, 0, 1, 0,\n trans, 3);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 3,\n 0, 0, 1, 2,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 3, 3, s,\n 0, s, s, 2,\n 0, s, s, 2,\n s, 1, 1, s);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 1, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-9s908tofi0f53w1pk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bFK899aZjrEfnbQAi/art.json b/art/bFK899aZjrEfnbQAi/art.json index ebf402e1..2330e8f3 100644 --- a/art/bFK899aZjrEfnbQAi/art.json +++ b/art/bFK899aZjrEfnbQAi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nmat4 persp (float fov, float aspect, float zNear, float zFar)\\n{\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n \\n return mat4(\\n \\tf / aspect, 0, 0, 0,\\n \\t0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n \\t0, 0, zNear * zFar * rangeInv * 2.0, 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n zAxis, 0,\\n xAxis, 0,\\n yAxis, 0,\\n eye , 2\\n );\\n}\\n\\nvec3 pos_point[10];\\nvec3 colors[10];\\nvoid drow_point()\\n{\\n pos_point[0] = vec3(-.5, -.5, .0);\\n pos_point[1] = vec3(-.5 , .5, .0);\\n pos_point[2] = vec3(.5 , -.5, .0);\\n pos_point[3] = vec3(.5 , .5, .0);\\n pos_point[4] = vec3(.5 , -.5, .5);\\n pos_point[5] = vec3(.5 , .5, .5);\\n pos_point[6] = vec3(-.5, -.5, .5);\\n pos_point[7] = vec3(-.5 , .5, .5);\\n pos_point[8] = vec3(-.5, -.5, .0);\\n pos_point[9] = vec3(-.5 , .5, .0);\\n \\n colors[0] = vec3(1, 0, 0);\\n colors[1] = vec3(1, 0, 0);\\n colors[2] = vec3(0, 0, 1);\\n colors[3] = vec3(0, 0, 1);\\n colors[4] = vec3(1, 1, 1);\\n colors[5] = vec3(1, 1, 1);\\n colors[6] = vec3(0.2, 1, 0);\\n colors[7] = vec3(0.2, 1, 0);\\n colors[8] = vec3(0.5, 0, 0.5);\\n colors[9] = vec3(0.5, 0, 0.5);\\n}\\n\\nvoid main() {\\n drow_point();\\n int VD = int(vertexId);\\n vec2 m = mouse;\\n \\n float ct = time *0.3;\\n vec3 p = vec3(0 , -0.5, -2.5);\\n vec3 t = vec3(25.*cos(ct), 0., 25.*sin(ct));\\n vec3 u = vec3(0, 1, 0);\\n\\n for( int i=0; i<10; i++)\\n {\\n if(VD == i)\\n {\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= lookAt(p, t, u);\\n gl_Position = m * vec4(pos_point[i], 1);\\n gl_PointSize = 20.;\\n v_color = vec4(colors[i], 1.0);\\n }\\n }\\n\\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nmat4 persp (float fov, float aspect, float zNear, float zFar)\n{\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n \n return mat4(\n \tf / aspect, 0, 0, 0,\n \t0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n \t0, 0, zNear * zFar * rangeInv * 2.0, 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\n{\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n \n return mat4(\n zAxis, 0,\n xAxis, 0,\n yAxis, 0,\n eye , 2\n );\n}\n\nvec3 pos_point[10];\nvec3 colors[10];\nvoid drow_point()\n{\n pos_point[0] = vec3(-.5, -.5, .0);\n pos_point[1] = vec3(-.5 , .5, .0);\n pos_point[2] = vec3(.5 , -.5, .0);\n pos_point[3] = vec3(.5 , .5, .0);\n pos_point[4] = vec3(.5 , -.5, .5);\n pos_point[5] = vec3(.5 , .5, .5);\n pos_point[6] = vec3(-.5, -.5, .5);\n pos_point[7] = vec3(-.5 , .5, .5);\n pos_point[8] = vec3(-.5, -.5, .0);\n pos_point[9] = vec3(-.5 , .5, .0);\n \n colors[0] = vec3(1, 0, 0);\n colors[1] = vec3(1, 0, 0);\n colors[2] = vec3(0, 0, 1);\n colors[3] = vec3(0, 0, 1);\n colors[4] = vec3(1, 1, 1);\n colors[5] = vec3(1, 1, 1);\n colors[6] = vec3(0.2, 1, 0);\n colors[7] = vec3(0.2, 1, 0);\n colors[8] = vec3(0.5, 0, 0.5);\n colors[9] = vec3(0.5, 0, 0.5);\n}\n\nvoid main() {\n drow_point();\n int VD = int(vertexId);\n vec2 m = mouse;\n \n float ct = time *0.3;\n vec3 p = vec3(0 , -0.5, -2.5);\n vec3 t = vec3(25.*cos(ct), 0., 25.*sin(ct));\n vec3 u = vec3(0, 1, 0);\n\n for( int i=0; i<10; i++)\n {\n if(VD == i)\n {\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= lookAt(p, t, u);\n gl_Position = m * vec4(pos_point[i], 1);\n gl_PointSize = 20.;\n v_color = vec4(colors[i], 1.0);\n }\n }\n\n\n}" + }, "screenshotURL": "data/images/images-u19g9fi188hk6lpsu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bG8faYzBsvfvBSwDH/art.json b/art/bG8faYzBsvfvBSwDH/art.json index b02bd445..c9653046 100644 --- a/art/bG8faYzBsvfvBSwDH/art.json +++ b/art/bG8faYzBsvfvBSwDH/art.json @@ -21,7 +21,19 @@ "origId": "HSGSvjGwQyB6cFQMP", "name": "voices", "username": "gman", - "settings": "{\"num\":25600,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/totopicciotto/claude-von-stroke-vocal-chords\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 64.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.)\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvec2 mouthLine(float vertexId) {\\n vertexId = mod(vertexId, NUM_SEGMENTS);\\n float rt = floor(vertexId / (NUM_SEGMENTS * .5));\\n float bot = mod(floor(vertexId / (NUM_SEGMENTS * .25)), 2.);\\n float u = mod(vertexId, NUM_SEGMENTS * .25) / (NUM_SEGMENTS * .25);\\n bot = mix(bot, 1. - bot, rt);\\n // 0, 1, 2, 3\\n // 3, 2, 1, 0, 0, -1, -2, -3, \\n // -3, -2, -1, 0\\n float uh = mix(mix(u, 1. - u, bot), mix(-u, -1. + u,1. - bot), rt);\\n float v = mix(sin((0.2 + abs(uh) * 0.7) * PI) - 0.3, sin((0.4 + abs(uh) * 0.6) * PI), bot);\\n return vec2(uh, mix(v, -v, bot));\\n}\\n\\nvec2 mouth(float vertexId) {\\n float inOut = mod(floor(vertexId / NUM_POINTS), 2.);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n return mouthLine(point) * mix(vec2(1., 1.), vec2(1., .5), inOut);\\n}\\n\\nvoid main() {\\n float inOut = mod(floor(vertexId / NUM_POINTS), 2.);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = mod(floor(vertexId / (NUM_POINTS * 2.)), 10.);\\n float mEcho = floor(vertexId / (NUM_POINTS * 2. * 10.));\\n float snd = texture2D(sound, vec2(count / 10. * 0.1, 0.)).a;\\n \\n //vec2 rp = vec2(count / 10.0, 0.5);\\n float posId = count + floor(time * 0.1 + count * 0.1) * 10.;\\n float scale = rand(vec2(posId * .3, posId * 1.3));\\n vec2 rp = vec2(rand(vec2(posId, posId)), rand(vec2(posId*7.,posId*9.)));\\n float mLerp = mEcho / 10.;\\n float sndScale = mix(0.7, 2.3, pow(snd + 0.3, 5.0));\\n vec2 xy = mouth(vertexId) * vec2(1. + sndScale * 0.05, sndScale) * mix(0.3, 1.2, scale) * mix(1., .6, mLerp) + (rp * 2. - 1.) * 4.;\\n\\n gl_Position = vec4(xy * 0.20, 0, 1);\\n gl_PointSize = 4.;\\n\\n float hue = -0.08 + count * 0.01;\\n float sat = 1.0;\\n float val = pow(1. - mLerp, 3.) * mix(0.3, 1.0, snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 25600, + "mode": "LINES", + "sound": "https://soundcloud.com/totopicciotto/claude-von-stroke-vocal-chords", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 64.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.)\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvec2 mouthLine(float vertexId) {\n vertexId = mod(vertexId, NUM_SEGMENTS);\n float rt = floor(vertexId / (NUM_SEGMENTS * .5));\n float bot = mod(floor(vertexId / (NUM_SEGMENTS * .25)), 2.);\n float u = mod(vertexId, NUM_SEGMENTS * .25) / (NUM_SEGMENTS * .25);\n bot = mix(bot, 1. - bot, rt);\n // 0, 1, 2, 3\n // 3, 2, 1, 0, 0, -1, -2, -3, \n // -3, -2, -1, 0\n float uh = mix(mix(u, 1. - u, bot), mix(-u, -1. + u,1. - bot), rt);\n float v = mix(sin((0.2 + abs(uh) * 0.7) * PI) - 0.3, sin((0.4 + abs(uh) * 0.6) * PI), bot);\n return vec2(uh, mix(v, -v, bot));\n}\n\nvec2 mouth(float vertexId) {\n float inOut = mod(floor(vertexId / NUM_POINTS), 2.);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n return mouthLine(point) * mix(vec2(1., 1.), vec2(1., .5), inOut);\n}\n\nvoid main() {\n float inOut = mod(floor(vertexId / NUM_POINTS), 2.);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = mod(floor(vertexId / (NUM_POINTS * 2.)), 10.);\n float mEcho = floor(vertexId / (NUM_POINTS * 2. * 10.));\n float snd = texture2D(sound, vec2(count / 10. * 0.1, 0.)).a;\n \n //vec2 rp = vec2(count / 10.0, 0.5);\n float posId = count + floor(time * 0.1 + count * 0.1) * 10.;\n float scale = rand(vec2(posId * .3, posId * 1.3));\n vec2 rp = vec2(rand(vec2(posId, posId)), rand(vec2(posId*7.,posId*9.)));\n float mLerp = mEcho / 10.;\n float sndScale = mix(0.7, 2.3, pow(snd + 0.3, 5.0));\n vec2 xy = mouth(vertexId) * vec2(1. + sndScale * 0.05, sndScale) * mix(0.3, 1.2, scale) * mix(1., .6, mLerp) + (rp * 2. - 1.) * 4.;\n\n gl_Position = vec4(xy * 0.20, 0, 1);\n gl_PointSize = 4.;\n\n float hue = -0.08 + count * 0.01;\n float sat = 1.0;\n float val = pow(1. - mLerp, 3.) * mix(0.3, 1.0, snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-p3nkljbixrhwxoe0l-thumbnail.jpg", "views": { "$numberInt": "144" diff --git a/art/bJc832Huv2tEcL58Y/art.json b/art/bJc832Huv2tEcL58Y/art.json index 74b881ea..40c7d163 100644 --- a/art/bJc832Huv2tEcL58Y/art.json +++ b/art/bJc832Huv2tEcL58Y/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u + .1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u + .1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-3qsi5ghs04dv721fe-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bM77A2kSw6eM7YMHh/art.json b/art/bM77A2kSw6eM7YMHh/art.json index e0d5a13c..7c607a3e 100644 --- a/art/bM77A2kSw6eM7YMHh/art.json +++ b/art/bM77A2kSw6eM7YMHh/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tomoya2", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocJ-dZACqAyu8rLRCgKxMZ8OE3fcu9HT9ZVK9dQc3d9xSQRP=s96-c", - "settings": "{\"num\":43920,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos((angle + time)) * radius;\\n float s = sin((angle + time)) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 43920, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos((angle + time)) * radius;\n float s = sin((angle + time)) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-sjcchspbqjxgkjl6z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bN3QdqY39pxGw8csG/art.json b/art/bN3QdqY39pxGw8csG/art.json index e45c8584..ebce4dca 100644 --- a/art/bN3QdqY39pxGw8csG/art.json +++ b/art/bN3QdqY39pxGw8csG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":32665,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.592156862745098,0.5764705882352941,0.49019607843137253,1],\"shader\":\"vec3 hsv(in float h, in float s, in float v) {\\n return mix(vec3(1.0), clamp((abs(fract(\\n h + vec3(3.0, 2.0, 1.0) / 3.0) * 6.0 - 3.0) - 1.0), 0.0, 1.0), s) * v;\\n}\\n\\nmat4 perspective(in float fovy, in float aspect, in float near, in float far) {\\n float top = near * tan(radians(fovy * 0.5));\\n float right = top * aspect;\\n float u = right * 2.0;\\n float v = top * 2.0;\\n float w = far - near;\\n return mat4(\\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \\n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \\n -(far + near) / w, -1.0, 0.0, 0.0,\\n -(far * near * 2.0) / w, 0.0\\n ); \\n}\\n\\nfloat hash(in float n) {\\n return fract(sin(n)*753.5453123);\\n}\\n \\nvec3 hash31(in float n) {\\n return vec3(hash(n * 0.123), hash(n * 0.456), hash(n * 0.789)); \\n}\\n\\nmat2 rotate(float a) {\\n float s=sin(a),c=cos(a);\\n return mat2(c,s,-s,c);\\n}\\n\\nvec2 meshUV(in float id, in vec2 dim){\\n \\tfloat quadId = floor(id / 10.0);\\n \\tfloat pointId = mod(id,10.0);\\n \\n \\tvec2 pos = vec2(mod(quadId,dim.x),(floor(quadId / dim.x)));\\n \\tvec2 p1 = vec2(0,0);\\n \\tvec2 p2 = vec2(1,0);\\n \\tvec2 p3 = vec2(0,1);\\n \\tvec2 p4 = vec2(1,1);\\n \\tvec2 uv;\\n \\n \\tif (pointId==0.0) uv = p1;\\n \\tif (pointId==1.0) uv = p2;\\n \\tif (pointId==2.0) uv = p1;\\n \\tif (pointId==3.0) uv = p3;\\n \\tif (mod(pos.x+pos.y,2.0)<0.5){\\n \\t\\tif (pointId==4.0) uv = p2;\\n \\t\\tif (pointId==5.0) uv = p3;\\n \\t} else { \\n \\t\\tif (pointId==4.0) uv = p1;\\n \\t\\tif (pointId==5.0) uv = p4;\\n \\t}\\n \\tif (pointId==6.0) uv = p4;\\n \\tif (pointId==7.0) uv = p2;\\n \\tif (pointId==8.0) uv = p4;\\n \\tif (pointId==9.0) uv = p3;\\n uv += pos;\\n uv /= dim;\\n return uv;\\n}\\n\\nvoid main() {\\n\\tmat4 pMatrix = perspective(45.0, resolution.x/resolution.y, 0.1, 100.0);\\n \\tmat4 vMatrix = mat4(1.0);\\n \\tvMatrix[3].z = -3.5; \\n \\t\\n vec2 dim = vec2(10);\\n float num = 10.0*dim.x*dim.y;\\n float polyId = floor(vertexId/num);\\n float pointId = mod(vertexId, num);\\n vec3 p = vec3(0);\\n vec2 uv = meshUV(pointId, dim);\\n p.xy = uv*2.0-1.0;\\n vec3 p1 = p;\\n p.z = 0.85*(1.0- pow(max(abs(p.x),abs(p.y)),2.0));\\n p = normalize(p);\\n \\tp = mix(p1,p, 0.7*(smoothstep(0.0,1.0,abs(fract(time*0.2+hash(polyId + 46.12))*2.0-1.0)))+0.3);\\n\\tp *= 0.35;\\n p.xy *= rotate(time*0.3*hash(polyId + 46.12)+hash(polyId + 78.12));\\n p.yz *= rotate(time*0.5*hash(polyId + 37.12)+hash(polyId + 56.12)); \\n vec3 offset = hash31(polyId * 12.12 + 34.34) * 2.0 - 1.0;\\n vec3 v = hash31(polyId * 56.56 + 78.78) * 2.0 - 1.0; \\n \\toffset = abs(fract(offset + v * time * 0.03) * 2.0 - 1.0) * 2.0 - 1.0;\\n p += offset*2.5;\\n \\tgl_Position = pMatrix *vMatrix * vec4(p, 1.0);\\n \\tvec3 col = hsv(hash(polyId * 567.123), 0.5, 0.3);\\n \\tv_color = vec4(col, 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 32665, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.592156862745098, + 0.5764705882352941, + 0.49019607843137253, + 1 + ], + "shader": "vec3 hsv(in float h, in float s, in float v) {\n return mix(vec3(1.0), clamp((abs(fract(\n h + vec3(3.0, 2.0, 1.0) / 3.0) * 6.0 - 3.0) - 1.0), 0.0, 1.0), s) * v;\n}\n\nmat4 perspective(in float fovy, in float aspect, in float near, in float far) {\n float top = near * tan(radians(fovy * 0.5));\n float right = top * aspect;\n float u = right * 2.0;\n float v = top * 2.0;\n float w = far - near;\n return mat4(\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \n -(far + near) / w, -1.0, 0.0, 0.0,\n -(far * near * 2.0) / w, 0.0\n ); \n}\n\nfloat hash(in float n) {\n return fract(sin(n)*753.5453123);\n}\n \nvec3 hash31(in float n) {\n return vec3(hash(n * 0.123), hash(n * 0.456), hash(n * 0.789)); \n}\n\nmat2 rotate(float a) {\n float s=sin(a),c=cos(a);\n return mat2(c,s,-s,c);\n}\n\nvec2 meshUV(in float id, in vec2 dim){\n \tfloat quadId = floor(id / 10.0);\n \tfloat pointId = mod(id,10.0);\n \n \tvec2 pos = vec2(mod(quadId,dim.x),(floor(quadId / dim.x)));\n \tvec2 p1 = vec2(0,0);\n \tvec2 p2 = vec2(1,0);\n \tvec2 p3 = vec2(0,1);\n \tvec2 p4 = vec2(1,1);\n \tvec2 uv;\n \n \tif (pointId==0.0) uv = p1;\n \tif (pointId==1.0) uv = p2;\n \tif (pointId==2.0) uv = p1;\n \tif (pointId==3.0) uv = p3;\n \tif (mod(pos.x+pos.y,2.0)<0.5){\n \t\tif (pointId==4.0) uv = p2;\n \t\tif (pointId==5.0) uv = p3;\n \t} else { \n \t\tif (pointId==4.0) uv = p1;\n \t\tif (pointId==5.0) uv = p4;\n \t}\n \tif (pointId==6.0) uv = p4;\n \tif (pointId==7.0) uv = p2;\n \tif (pointId==8.0) uv = p4;\n \tif (pointId==9.0) uv = p3;\n uv += pos;\n uv /= dim;\n return uv;\n}\n\nvoid main() {\n\tmat4 pMatrix = perspective(45.0, resolution.x/resolution.y, 0.1, 100.0);\n \tmat4 vMatrix = mat4(1.0);\n \tvMatrix[3].z = -3.5; \n \t\n vec2 dim = vec2(10);\n float num = 10.0*dim.x*dim.y;\n float polyId = floor(vertexId/num);\n float pointId = mod(vertexId, num);\n vec3 p = vec3(0);\n vec2 uv = meshUV(pointId, dim);\n p.xy = uv*2.0-1.0;\n vec3 p1 = p;\n p.z = 0.85*(1.0- pow(max(abs(p.x),abs(p.y)),2.0));\n p = normalize(p);\n \tp = mix(p1,p, 0.7*(smoothstep(0.0,1.0,abs(fract(time*0.2+hash(polyId + 46.12))*2.0-1.0)))+0.3);\n\tp *= 0.35;\n p.xy *= rotate(time*0.3*hash(polyId + 46.12)+hash(polyId + 78.12));\n p.yz *= rotate(time*0.5*hash(polyId + 37.12)+hash(polyId + 56.12)); \n vec3 offset = hash31(polyId * 12.12 + 34.34) * 2.0 - 1.0;\n vec3 v = hash31(polyId * 56.56 + 78.78) * 2.0 - 1.0; \n \toffset = abs(fract(offset + v * time * 0.03) * 2.0 - 1.0) * 2.0 - 1.0;\n p += offset*2.5;\n \tgl_Position = pMatrix *vMatrix * vec4(p, 1.0);\n \tvec3 col = hsv(hash(polyId * 567.123), 0.5, 0.3);\n \tv_color = vec4(col, 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-yrushczem24ny5sni-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bN6NWErydKPLz62i5/art.json b/art/bN6NWErydKPLz62i5/art.json index e5f2343c..d46ee71a 100644 --- a/art/bN6NWErydKPLz62i5/art.json +++ b/art/bN6NWErydKPLz62i5/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "michell", "avatarUrl": "https://graph.facebook.com/10214849161372343/picture?type=large", - "settings": "{\"num\":20,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = ux / 20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n // x = radius * cos(angle);\\n // y = radius * sin(anlge);\\n \\n vec2 xy = vec2(x,y);\\n \\n gl_Position = vec4(xy *0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 20, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = ux / 20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n // x = radius * cos(angle);\n // y = radius * sin(anlge);\n \n vec2 xy = vec2(x,y);\n \n gl_Position = vec4(xy *0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-782dw6cws8x64ahwt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bNYRsM3GYemaiam5G/art.json b/art/bNYRsM3GYemaiam5G/art.json index bd09b98d..5409aec5 100644 --- a/art/bNYRsM3GYemaiam5G/art.json +++ b/art/bNYRsM3GYemaiam5G/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/necmusic/stravinsky-firebird-suite-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n \\n float su = fract(p.x * 0.0125);\\n float sv = (p.y + 0.5) / soundRes.y;\\n float st = sin(time * 0.01) * 10. * 0.;\\n float su2 = fract(mix(sv * 13.8 + st, (sv + 1.) * 140.8 + st, su * 0.00349));\\n float su3 = mix(0.05, 0.74, hash(su2)) ;\\n float s = 0.;\\n const int count = 3;\\n for (int i = 0; i < count; ++i) {\\n s += texture2D(sound, vec2(su3, (float(i * 1) + 0.5) / soundRes.y)).a * float(count - i);\\n }\\n return pow(s / (float((count * (count + 1)) / 2)), 2.) ;\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off, out vec3 preScale) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n preScale = vec3(ux, 0, vy) + off;\\n vec3 pos = preScale * scale + vec3(0, fbm(preScale.xz), 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float down = soundRes.y;\\n float across = floor(numQuads / down);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n vec3 preScale;\\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q, preScale);\\n vec3 n1 = getQuadPoint(nId + 1., s, q, preScale);\\n vec3 n2 = getQuadPoint(nId + 2., s, q, preScale);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q, preScale);\\n float pump = step(0.55, p.y);\\n p.y *= mix(1., 1. + hash(nId), pump);\\n\\n float ct = time * 0.6;\\n float ct2 = ct + 2.0;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct) * 3., mix(1., 5., p1m1(sin(time * 0.257))), cos(ct * -.612) * 10. + 10.);\\n vec3 cameraTarget = vec3(sin(ct2) * 2., 0, cos(ct2) * 10. + 10.);\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.; //0.5 + sin(time * 0.01) * 1.1 + qu * 0. + pow(p.y, 5.) * 0.5;//1.;m1p1(n.z);\\n float sat = mix(0., 1., pump);//, 2.);//.3;abs(n.z);\\n float val = mix(0., 1., l);\\n \\n float punch = step(0.8, p.y);\\n l = mix(l, 1., punch);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs(((preScale.x / across) * 2. - 1.)), 10.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/necmusic/stravinsky-firebird-suite-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n \n float su = fract(p.x * 0.0125);\n float sv = (p.y + 0.5) / soundRes.y;\n float st = sin(time * 0.01) * 10. * 0.;\n float su2 = fract(mix(sv * 13.8 + st, (sv + 1.) * 140.8 + st, su * 0.00349));\n float su3 = mix(0.05, 0.74, hash(su2)) ;\n float s = 0.;\n const int count = 3;\n for (int i = 0; i < count; ++i) {\n s += texture2D(sound, vec2(su3, (float(i * 1) + 0.5) / soundRes.y)).a * float(count - i);\n }\n return pow(s / (float((count * (count + 1)) / 2)), 2.) ;\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off, out vec3 preScale) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n preScale = vec3(ux, 0, vy) + off;\n vec3 pos = preScale * scale + vec3(0, fbm(preScale.xz), 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float down = soundRes.y;\n float across = floor(numQuads / down);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n vec3 preScale;\n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q, preScale);\n vec3 n1 = getQuadPoint(nId + 1., s, q, preScale);\n vec3 n2 = getQuadPoint(nId + 2., s, q, preScale);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q, preScale);\n float pump = step(0.55, p.y);\n p.y *= mix(1., 1. + hash(nId), pump);\n\n float ct = time * 0.6;\n float ct2 = ct + 2.0;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct) * 3., mix(1., 5., p1m1(sin(time * 0.257))), cos(ct * -.612) * 10. + 10.);\n vec3 cameraTarget = vec3(sin(ct2) * 2., 0, cos(ct2) * 10. + 10.);\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.; //0.5 + sin(time * 0.01) * 1.1 + qu * 0. + pow(p.y, 5.) * 0.5;//1.;m1p1(n.z);\n float sat = mix(0., 1., pump);//, 2.);//.3;abs(n.z);\n float val = mix(0., 1., l);\n \n float punch = step(0.8, p.y);\n l = mix(l, 1., punch);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs(((preScale.x / across) * 2. - 1.)), 10.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-kgig6x7ocjqne128f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bREFug9pGbyBNwXgE/art.json b/art/bREFug9pGbyBNwXgE/art.json index 476dafce..560dbb45 100644 --- a/art/bREFug9pGbyBNwXgE/art.json +++ b/art/bREFug9pGbyBNwXgE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":68609,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 11\\\\\\\\ 13\\\\\\\\ 15,(16,17) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n gl_PointSize=3.0;\\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\n v_color =vec4(texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a);\\n \\n \\n}\"}", + "settings": { + "num": 68609, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n gl_PointSize=3.0;\n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\n v_color =vec4(texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a);\n \n \n}" + }, "screenshotURL": "data/images/images-whfg7yukhc9t46ua6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bSD87iQ9LnqxJC3cb/art.json b/art/bSD87iQ9LnqxJC3cb/art.json index 4fc45acb..9b791a27 100644 --- a/art/bSD87iQ9LnqxJC3cb/art.json +++ b/art/bSD87iQ9LnqxJC3cb/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jko", "avatarUrl": "https://lh4.googleusercontent.com/-sTisLKPorfI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdngWBCd0QW-0Ip7SSZ0m-Ahnxndg/mo/photo.jpg", - "settings": "{\"num\":18580,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePt (float id, float numCircleSegments) {\\n\\tfloat ux = floor(id / 6.) + mod(id, 2.); \\t\\t\\t// 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3 2 3 3 4 3 4 3 4\\n \\n \\tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\t// 0 0 2 1 2 4 3 3 7 4\\t// 0 0 1 0 1 1 0 0 0 1\\n \\n \\n \\tfloat angle = ux / numCircleSegments * 2. * PI;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n \\n \\tfloat r = vy + 1.;\\n \\t\\n \\n\\tfloat x = c * r;\\n\\tfloat y = s * r;\\n \\n \\tvec2 xy = vec2(x, y) ;\\n \\n \\treturn vec2(x, y);\\n}\\n\\n\\n\\nvoid main() {\\n \\n \\tfloat numCircleSegments = 20.;\\n \\n \\tvec2 circleXY = getCirclePt(vertexId, numCircleSegments);\\n \\n \\tfloat numPointsPerCricle = numCircleSegments * 6.;\\n \\n \\tfloat circleId = floor(vertexId / numPointsPerCricle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCricle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = circleXY * vec2(ux, vy) * 1.3;\\n\\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n float pump = step(0.8, snd);\\n\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 18580, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePt (float id, float numCircleSegments) {\n\tfloat ux = floor(id / 6.) + mod(id, 2.); \t\t\t// 0 1 0 1 0 1 1 2 1 2 1 2 2 3 2 3 2 3 3 4 3 4 3 4\n \n \tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\t// 0 0 2 1 2 4 3 3 7 4\t// 0 0 1 0 1 1 0 0 0 1\n \n \n \tfloat angle = ux / numCircleSegments * 2. * PI;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n \n \tfloat r = vy + 1.;\n \t\n \n\tfloat x = c * r;\n\tfloat y = s * r;\n \n \tvec2 xy = vec2(x, y) ;\n \n \treturn vec2(x, y);\n}\n\n\n\nvoid main() {\n \n \tfloat numCircleSegments = 20.;\n \n \tvec2 circleXY = getCirclePt(vertexId, numCircleSegments);\n \n \tfloat numPointsPerCricle = numCircleSegments * 6.;\n \n \tfloat circleId = floor(vertexId / numPointsPerCricle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCricle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = circleXY * vec2(ux, vy) * 1.3;\n\n gl_Position = vec4(xy, 0, 1);\n\n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n float pump = step(0.8, snd);\n\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-kcertui6txa4zmjy0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bSWJchGnG97o3HQfE/art.json b/art/bSWJchGnG97o3HQfE/art.json index fd236584..d9c879a8 100644 --- a/art/bSWJchGnG97o3HQfE/art.json +++ b/art/bSWJchGnG97o3HQfE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":40000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/graham-panter/lotus\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvoid main() {\\n float pointsAroundCircle = 240.;\\n float pointsPerCircle = pointsAroundCircle * 2.;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float vId = mod(vertexId, pointsPerCircle);\\n float pointId = floor(vId / 2.) + mod(vId, 2.);\\n float pointV = pointId / (pointsAroundCircle - 1.);\\n \\n float circleV = circleId / (numCircles - 1.);\\n float odd = mod(circleId, 2.);\\n float quad = mod(floor(circleId / 2.), 2.);\\n \\n float tm = time * 4. - circleV;\\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .05;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float off = mix(.0, 0.953, circleV);\\n\\n float su = hash(pointV * 13.7);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.5)).a;\\n \\n float q = (odd + quad * 2.) / 3.;\\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\\n \\n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 5.));\\n float scale = mix(\\n mix(\\n mix(.4, .5, circleV),\\n mix(-.4, -.3, circleV),\\n odd),\\n mix(\\n mix(.1, .15, circleV),\\n mix(-.1, -.05, circleV),\\n odd),\\n quad) + pow(sq, 10.) * .1;\\n \\n gl_Position = vec4(xy * aspect * scale, circleV, 1);\\n\\n float hue = 0.5 + odd * .5 + quad * .125;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 40000, + "mode": "LINES", + "sound": "https://soundcloud.com/graham-panter/lotus", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvoid main() {\n float pointsAroundCircle = 240.;\n float pointsPerCircle = pointsAroundCircle * 2.;\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float vId = mod(vertexId, pointsPerCircle);\n float pointId = floor(vId / 2.) + mod(vId, 2.);\n float pointV = pointId / (pointsAroundCircle - 1.);\n \n float circleV = circleId / (numCircles - 1.);\n float odd = mod(circleId, 2.);\n float quad = mod(floor(circleId / 2.), 2.);\n \n float tm = time * 4. - circleV;\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .05;\n float c = cos(angle);\n float s = sin(angle);\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float off = mix(.0, 0.953, circleV);\n\n float su = hash(pointV * 13.7);\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.5)).a;\n \n float q = (odd + quad * 2.) / 3.;\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\n \n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 5.));\n float scale = mix(\n mix(\n mix(.4, .5, circleV),\n mix(-.4, -.3, circleV),\n odd),\n mix(\n mix(.1, .15, circleV),\n mix(-.1, -.05, circleV),\n odd),\n quad) + pow(sq, 10.) * .1;\n \n gl_Position = vec4(xy * aspect * scale, circleV, 1);\n\n float hue = 0.5 + odd * .5 + quad * .125;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-8tjij9c7bq0xl923x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bWGzwX6udGM4uM7ra/art.json b/art/bWGzwX6udGM4uM7ra/art.json index 676eeb6a..9b84c18f 100644 --- a/art/bWGzwX6udGM4uM7ra/art.json +++ b/art/bWGzwX6udGM4uM7ra/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-ps0o4xp5rdoy1fp2n-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bWQMzQA9jpeRKo7dL/art.json b/art/bWQMzQA9jpeRKo7dL/art.json index 8e7bf99b..b5d59bb1 100644 --- a/art/bWQMzQA9jpeRKo7dL/art.json +++ b/art/bWQMzQA9jpeRKo7dL/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/marawan-alsyed/suzume-no-tojimari-ost-kanata?si=61c8fd6002924a74930a32a91109f08f&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor( sqrt(vertexCount) );\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, sin(time) * .5 + .5);\\n \\n float soff = 0.; //sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(.8, snd);\\n float hue = u * 1. + snd * 0.2 + time * .2; //sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump); //mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/marawan-alsyed/suzume-no-tojimari-ost-kanata?si=61c8fd6002924a74930a32a91109f08f&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor( sqrt(vertexCount) );\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, sin(time) * .5 + .5);\n \n float soff = 0.; //sin(time + x * y * .02) * 5.; \n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(.8, snd);\n float hue = u * 1. + snd * 0.2 + time * .2; //sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump); //mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\n}" + }, "screenshotURL": "data/images/images-dj57dyr1jy6uv73hs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bbpMGgfF9vceKwYEH/art.json b/art/bbpMGgfF9vceKwYEH/art.json index 70dc0f39..bd1633c9 100644 --- a/art/bbpMGgfF9vceKwYEH/art.json +++ b/art/bbpMGgfF9vceKwYEH/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":21237,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.0196078431372549,0.23137254901960785,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define KP0 2.//KParameter -2.>>2.\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.//KParameter 0.3>>7.\\n\\n#define KP2 .3//KParameter 0.2>>2.\\n//KVerticesNumber=9000\\n\\n\\n#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n#define Fs sampler2D floatSound;\\n\\n//( Fs, vec2(0.));\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 0.90 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 21., 42.0, 13256.0, 3.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.0015,-0.198,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,1.0,0.));\\n }\\n \\n mat4 tr=rotX(KP0*1.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.08,0.-.92,0.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 5.0,3.0*KP2,.10,0.4));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=0.70;\\n gl_Position.z-=5./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 21237, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.0196078431372549, + 0.23137254901960785, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n\n#define KP0 2.//KParameter -2.>>2.\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.//KParameter 0.3>>7.\n\n#define KP2 .3//KParameter 0.2>>2.\n//KVerticesNumber=9000\n\n\n#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n#define Fs sampler2D floatSound;\n\n//( Fs, vec2(0.));\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 0.90 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 21., 42.0, 13256.0, 3.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.0015,-0.198,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,1.0,0.));\n }\n \n mat4 tr=rotX(KP0*1.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.08,0.-.92,0.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 5.0,3.0*KP2,.10,0.4));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=0.70;\n gl_Position.z-=5./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-boxqh59px59rpwtoi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bbsF39W6bJo3j4R3j/art.json b/art/bbsF39W6bJo3j4R3j/art.json index 2c666dc4..9e881bee 100644 --- a/art/bbsF39W6bJo3j4R3j/art.json +++ b/art/bbsF39W6bJo3j4R3j/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/stuart-king/kraftwerk-the-model-stuart\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(u) * across * 1.05 + bxId;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\\n vCubeOrigin.y += height;;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,1), step(0.75,s2));\\n //vCubeCol.rgb = vec3(1. - pow(s2, 3.));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 10, 5.6, 1.0 );\\n \\tvec3 vCameraPos = vec3(10.1, 6., -0.);\\n float ca = 0.;\\n \\n // get sick!\\n // ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/stuart-king/kraftwerk-the-model-stuart", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(u) * across * 1.05 + bxId;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\n vCubeOrigin.y += height;;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,1), step(0.75,s2));\n //vCubeCol.rgb = vec3(1. - pow(s2, 3.));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 10, 5.6, 1.0 );\n \tvec3 vCameraPos = vec3(10.1, 6., -0.);\n float ca = 0.;\n \n // get sick!\n // ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-4a3wvsmv4bb39rh29-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bbx93AtnjNRLNs4hC/art.json b/art/bbx93AtnjNRLNs4hC/art.json index 9614a732..85bc2997 100644 --- a/art/bbx93AtnjNRLNs4hC/art.json +++ b/art/bbx93AtnjNRLNs4hC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 1000.//KParameter0 10.>>10000.\\n#define parameter1 1.//KParameter1 1.>>5.\\n#define parameter2 0.8//KParameter2 0.8>>10.\\n#define parameter3 10.//KParameter3 1.>>40.\\n#define parameter4 0.85//KParameter4 0.>>1.\\n#define parameter5 0.95//KParameter5 0.>>1.\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 1800.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float quadCount = POINTS_PER_LINE / 6.;\\n \\n float fVertexId = mod(vertexId,vertexCount/2.);\\n \\n float v = fVertexId / vertexCount;\\n float invV = 1. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = mod(fVertexId, 100.) / 100.;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\\n \\n pos = getCenterPoint(time * parameter3 + fVertexId * 1./parameter0, vec2(0,0));\\n pos += vec3(pow(snd1, parameter1) * parameter2 * v * vec2(goop(time * 10.3 + fVertexId * 0.01), goop(time * 5.11 + fVertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(v);\\n \\n if(vertexId>vertexCount/2.)\\n {\\n gl_Position.x = 0.5 - gl_Position.x;\\n //gl_Position.y = 0.5;\\n \\n }\\n \\n gl_Position.x -= 0.25;\\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(parameter4, parameter5, pow(snd0, 5.));\\n float sat = 0.2 + pow(snd0 + 0.2, 10.);\\n float val = 1.;\\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n //v_color = vec4(1.,1.,1., v_color.a);\\n v_color = vec4(1.,1.,1., 1.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 1000.//KParameter0 10.>>10000.\n#define parameter1 1.//KParameter1 1.>>5.\n#define parameter2 0.8//KParameter2 0.8>>10.\n#define parameter3 10.//KParameter3 1.>>40.\n#define parameter4 0.85//KParameter4 0.>>1.\n#define parameter5 0.95//KParameter5 0.>>1.\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + sin(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 0.37) * 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 1800.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float quadCount = POINTS_PER_LINE / 6.;\n \n float fVertexId = mod(vertexId,vertexCount/2.);\n \n float v = fVertexId / vertexCount;\n float invV = 1. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = mod(fVertexId, 100.) / 100.;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.051, spread), mix(0.25, 0., v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.06, 0.061, spread), mix(0.25, 0., v))).a;\n \n pos = getCenterPoint(time * parameter3 + fVertexId * 1./parameter0, vec2(0,0));\n pos += vec3(pow(snd1, parameter1) * parameter2 * v * vec2(goop(time * 10.3 + fVertexId * 0.01), goop(time * 5.11 + fVertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(v);\n \n if(vertexId>vertexCount/2.)\n {\n gl_Position.x = 0.5 - gl_Position.x;\n //gl_Position.y = 0.5;\n \n }\n \n gl_Position.x -= 0.25;\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(parameter4, parameter5, pow(snd0, 5.));\n float sat = 0.2 + pow(snd0 + 0.2, 10.);\n float val = 1.;\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n //v_color = vec4(1.,1.,1., v_color.a);\n v_color = vec4(1.,1.,1., 1.);\n}" + }, "screenshotURL": "data/images/images-xaqakd9wc18czqugw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bcenao9Loe5Xc2Y7T/art.json b/art/bcenao9Loe5Xc2Y7T/art.json index 16258c3f..45edbd55 100644 --- a/art/bcenao9Loe5Xc2Y7T/art.json +++ b/art/bcenao9Loe5Xc2Y7T/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/florandfaun/alone\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return (sin(t) * 8. + sin(t * 0.27) * 4. + sin(t * 0.13) * 2. + sin(t * 0.73)) / 15.0;\\n}\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (3.0 - 2.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + 1.0);\\n\\n vec4 o1 = fract(k3 * (1.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (1.0 - d.y);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\n#define POINTS_PER_LINE 50.\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float pointId = mod(vertexId, POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n vec2 uv = vec2(\\n pointId / POINTS_PER_LINE, \\n lineId / numLines);\\n\\n float ang = uv.x * PI * 2. + uv.y * mix(10., 100., sin(time * 0.1));\\n vec3 pos = vec3(\\n cos(ang),\\n sin(ang),\\n uv.y * 10.\\n );\\n \\n vec3 eye = vec3(0, 0, 0.0);\\n vec3 target = vec3(0, 0, 1);\\n vec3 up = vec3(0, 1, 0);\\n \\n float sa = abs(atan(uv.x, uv.y) / PI);\\n float snd = texture2D(sound, vec2(0.02, mix(1.0, 0.0, uv.y))).a;\\n \\n pos.xy *= mix(1., 2.2, pow(snd, 5.));\\n float tm = time - uv.y * 15.;\\n pos.xy += vec2(sin(tm), cos(tm * 1.11)) * -0.2;\\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = persp(radians(140.), 1., 0.1, 200.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= scale(vec3(0.5, 0.4, 1));\\n gl_Position = mat * vec4(pos, 1);\\n float clipZ = gl_Position.z / gl_Position.w;\\n gl_PointSize = mix(0.7, 50., pow(1. - uv.y, 50.));\\n gl_PointSize *= resolution.x / 1400.;\\n\\n float hue = pos.z* 0.02 + time * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n float alp = noise(pos * 3. + time * vec3(.7,0.3,5.));//clamp(goop(uv.x * 20. + time) + goop(uv.y * 20.123 + time), 0., 1.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alp);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/florandfaun/alone", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return (sin(t) * 8. + sin(t * 0.27) * 4. + sin(t * 0.13) * 2. + sin(t * 0.73)) / 15.0;\n}\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (3.0 - 2.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + 1.0);\n\n vec4 o1 = fract(k3 * (1.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (1.0 - d.y);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\n#define POINTS_PER_LINE 50.\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float pointId = mod(vertexId, POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n vec2 uv = vec2(\n pointId / POINTS_PER_LINE, \n lineId / numLines);\n\n float ang = uv.x * PI * 2. + uv.y * mix(10., 100., sin(time * 0.1));\n vec3 pos = vec3(\n cos(ang),\n sin(ang),\n uv.y * 10.\n );\n \n vec3 eye = vec3(0, 0, 0.0);\n vec3 target = vec3(0, 0, 1);\n vec3 up = vec3(0, 1, 0);\n \n float sa = abs(atan(uv.x, uv.y) / PI);\n float snd = texture2D(sound, vec2(0.02, mix(1.0, 0.0, uv.y))).a;\n \n pos.xy *= mix(1., 2.2, pow(snd, 5.));\n float tm = time - uv.y * 15.;\n pos.xy += vec2(sin(tm), cos(tm * 1.11)) * -0.2;\n float aspect = resolution.x / resolution.y;\n \n mat4 mat = persp(radians(140.), 1., 0.1, 200.); \n mat *= cameraLookAt(eye, target, up);\n mat *= scale(vec3(0.5, 0.4, 1));\n gl_Position = mat * vec4(pos, 1);\n float clipZ = gl_Position.z / gl_Position.w;\n gl_PointSize = mix(0.7, 50., pow(1. - uv.y, 50.));\n gl_PointSize *= resolution.x / 1400.;\n\n float hue = pos.z* 0.02 + time * 0.1;\n float sat = 1.;\n float val = 1.;\n float alp = noise(pos * 3. + time * vec3(.7,0.3,5.));//clamp(goop(uv.x * 20. + time) + goop(uv.y * 20.123 + time), 0., 1.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alp);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-u5bonv21959qo7duf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bgNBk3TJvBHtbJ9jB/art.json b/art/bgNBk3TJvBHtbJ9jB/art.json index 92607f98..5b43f338 100644 --- a/art/bgNBk3TJvBHtbJ9jB/art.json +++ b/art/bgNBk3TJvBHtbJ9jB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, (3. , .2), 3.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-0.5, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0.3, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .3 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.6;\\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 0.21, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 * s + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(-1,-1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, (3. , .2), 3.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-0.5, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0.3, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .3 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.6;\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 0.21, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 * s + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(-1,-1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-gmupkbuf81sfkk5zs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bgatWdfJ85SuY4Fn3/art.json b/art/bgatWdfJ85SuY4Fn3/art.json index 0e7ea9f7..dbaf7431 100644 --- a/art/bgatWdfJ85SuY4Fn3/art.json +++ b/art/bgatWdfJ85SuY4Fn3/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":30000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/a-boogie-wit-da-hoodie/drowning-feat-kodak-black-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*a ) + exp( -k*b );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.00470;\\n \\tfloat transitionStrength = 0.75;\\n \\tvec3 colKernel0 = vec3(1,0,0);\\n \\tvec3 colKernel1 = vec3(0,0,1);\\n \\tvec3 colTransition = vec3(1,1,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,0,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.) \\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - 1.));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*0.5;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).x*0.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 0.5 - mouse.x * 0.5;\\n\\tfloat ce = -1.5+mouse.y * 3.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(76.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = 1.0 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv, -1,\\n\\t\\t0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 30000, + "mode": "LINES", + "sound": "https://soundcloud.com/a-boogie-wit-da-hoodie/drowning-feat-kodak-black-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*a ) + exp( -k*b );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.00470;\n \tfloat transitionStrength = 0.75;\n \tvec3 colKernel0 = vec3(1,0,0);\n \tvec3 colKernel1 = vec3(0,0,1);\n \tvec3 colTransition = vec3(1,1,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,0,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.) \n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - 1.));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*0.5;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).x*0.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 0.5 - mouse.x * 0.5;\n\tfloat ce = -1.5+mouse.y * 3.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(76.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = 1.0 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv, -1,\n\t\t0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-u17mun28yzgn6n4u3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bhTaMtEz4j9zuSn7g/art.json b/art/bhTaMtEz4j9zuSn7g/art.json index 35dae8b4..2c22cab3 100644 --- a/art/bhTaMtEz4j9zuSn7g/art.json +++ b/art/bhTaMtEz4j9zuSn7g/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-74c311r34oj3vo8q6-thumbnail.jpg", "views": { "$numberInt": "200" diff --git a/art/bi5qETD9A4okpa4oi/art.json b/art/bi5qETD9A4okpa4oi/art.json index 761a2738..1db59361 100644 --- a/art/bi5qETD9A4okpa4oi/art.json +++ b/art/bi5qETD9A4okpa4oi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mklcp", "avatarUrl": "https://secure.gravatar.com/avatar/df8745915c9604d77a0eb454dc371e90?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(void)\\n{\\n float sca = floor(sqrt(vertexCount));\\n float x = mod(vertexId, sca)/(sca-1.);\\n float y = floor(vertexId/sca)/(sca-1.);\\n float af = 12.; // 20.\\n float xf = sin(time + y*af)*0.2;\\n float yf = sin(time + x*af)*0.2;\\n vec2 xy = vec2(x+xf, y+yf)*2.-1.;\\n\\n gl_Position = vec4(xy*0.8,0,1);\\n\\n gl_PointSize = 1.;\\n gl_PointSize += ((resolution.x)/sca)/5.;\\n\\n v_color = vec4(sin(x),sin(y),sin(time),0.);\\n}\\n// form: all\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(void)\n{\n float sca = floor(sqrt(vertexCount));\n float x = mod(vertexId, sca)/(sca-1.);\n float y = floor(vertexId/sca)/(sca-1.);\n float af = 12.; // 20.\n float xf = sin(time + y*af)*0.2;\n float yf = sin(time + x*af)*0.2;\n vec2 xy = vec2(x+xf, y+yf)*2.-1.;\n\n gl_Position = vec4(xy*0.8,0,1);\n\n gl_PointSize = 1.;\n gl_PointSize += ((resolution.x)/sca)/5.;\n\n v_color = vec4(sin(x),sin(y),sin(time),0.);\n}\n// form: all" + }, "screenshotURL": "data/images/images-5l037lr5zvf3ic8hm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/biFYsrY6uepWwyQN8/art.json b/art/biFYsrY6uepWwyQN8/art.json index 2c9e8d98..0c038dda 100644 --- a/art/biFYsrY6uepWwyQN8/art.json +++ b/art/biFYsrY6uepWwyQN8/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":13959,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.123 * cgv + snd * .125);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n\\n \\n float pump = step(.45, snd);\\n float hue = 1.- cgId * 1.05 + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 7.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\\n v_color.rgb *= v_color.a;\\n \\n gl_Position = mat * vec4(pos, .25);\\n gl_PointSize = 2. + hue * 2.;\\n}\\n\\n\"}", + "settings": { + "num": 13959, + "mode": "POINTS", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.123 * cgv + snd * .125);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n\n \n float pump = step(.45, snd);\n float hue = 1.- cgId * 1.05 + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 7.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\n v_color.rgb *= v_color.a;\n \n gl_Position = mat * vec4(pos, .25);\n gl_PointSize = 2. + hue * 2.;\n}\n\n" + }, "screenshotURL": "data/images/images-8dn2j8yhrlzs9o3ph-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bjkZzQ6XfJ5Ypu4AX/art.json b/art/bjkZzQ6XfJ5Ypu4AX/art.json index 6aae5014..fca3cef4 100644 --- a/art/bjkZzQ6XfJ5Ypu4AX/art.json +++ b/art/bjkZzQ6XfJ5Ypu4AX/art.json @@ -11,7 +11,19 @@ "origId": "iQAtnkJRC8XtvT4tW", "name": "synapsicorporation2", "username": "-anon-", - "settings": "{\"num\":61324,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chiptune/05-boss-v2-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\n// music by rez! here we goooooooo-oo-oo-oooooooo.....\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float localTime = time + 20.0;\\n \\n float NUM_SEGMENTS = localTime*cos(texture2D(floatSound,vec2(localTime*0.0000001,cos(localTime*0.0000001))).a*0.00001);\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2+cos(texture2D(floatSound,vec2(count*0.01,angle*0.01)).a*0.0001*localTime);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01*texture2D(floatSound,vec2(localTime,s+vertexId*0.01)).a*0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n \\n \\n float aa = (localTime*0.001)*cos(localTime*0.1000*vertexId);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle-aa);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 61324, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chiptune/05-boss-v2-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\n// music by rez! here we goooooooo-oo-oo-oooooooo.....\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float localTime = time + 20.0;\n \n float NUM_SEGMENTS = localTime*cos(texture2D(floatSound,vec2(localTime*0.0000001,cos(localTime*0.0000001))).a*0.00001);\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2+cos(texture2D(floatSound,vec2(count*0.01,angle*0.01)).a*0.0001*localTime);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01*texture2D(floatSound,vec2(localTime,s+vertexId*0.01)).a*0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n \n \n float aa = (localTime*0.001)*cos(localTime*0.1000*vertexId);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle-aa);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-b32zrgvrma06ugm88-thumbnail.jpg", "views": { "$numberInt": "137" diff --git a/art/bmeg6H2QQu9rgbn4o/art.json b/art/bmeg6H2QQu9rgbn4o/art.json index 92b9a8cd..e22722f8 100644 --- a/art/bmeg6H2QQu9rgbn4o/art.json +++ b/art/bmeg6H2QQu9rgbn4o/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float vy = mod(time, 2.); // the distance to travel is 2 units, let time increment the velocity and reset when the unit traveled is 2\\n \\n gl_Position = vec4(0.0, 1.0 - vy, 0.0, 1.0); // minus velocity because coords inverted\\n gl_PointSize = 10.0;\\n v_color = vec4(1., 1., 1., 1.);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float vy = mod(time, 2.); // the distance to travel is 2 units, let time increment the velocity and reset when the unit traveled is 2\n \n gl_Position = vec4(0.0, 1.0 - vy, 0.0, 1.0); // minus velocity because coords inverted\n gl_PointSize = 10.0;\n v_color = vec4(1., 1., 1., 1.);\n}" + }, "screenshotURL": "data/images/images-jicqb7ibzo8l6tsdw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bnRnHzDJKpa425887/art.json b/art/bnRnHzDJKpa425887/art.json index 5b9384c0..63933fa3 100644 --- a/art/bnRnHzDJKpa425887/art.json +++ b/art/bnRnHzDJKpa425887/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":6,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(-vertexId * 0.2, vertexId * 0.2, 0.0, 1.0);\\n gl_PointSize = 50.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 6, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(-vertexId * 0.2, vertexId * 0.2, 0.0, 1.0);\n gl_PointSize = 50.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-e3849r1roga0i5myw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bpN3ufoDGdkJjxFsQ/art.json b/art/bpN3ufoDGdkJjxFsQ/art.json index f413c8d0..9f034bbe 100644 --- a/art/bpN3ufoDGdkJjxFsQ/art.json +++ b/art/bpN3ufoDGdkJjxFsQ/art.json @@ -21,7 +21,19 @@ "origId": "LTuqGKGJGc3bHxGij", "name": "starts", "username": "gman", - "settings": "{\"num\":3000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/judahofficial/london-grammar-strong-judah-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n// triangles per thing we want to draw\\n#define NUM_TRIANGLES 2.0 \\n// points pre thing\\n#define NUM_POINTS (NUM_TRIANGLES * 3.0)\\n#define STEP 2.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n gl_PointSize = 30.0;\\n float localTime = time;\\n // pointId: 0, 1, 2, for each point in thing\\n float pointId = mod(vertexId, NUM_POINTS);\\n // each triangle 0,1,2,0,1,2 ...\\n float triPointId = mod(vertexId, 3.0);\\n // thingId: counts things\\n float thingId = floor(vertexId / NUM_POINTS);\\n // triId: 0, 1, .. for each triangle in thing\\n float triId = mod(floor(pointId / 3.0), NUM_TRIANGLES);\\n float angle = (triId * 0.5 + triPointId) * PI * 2.0 / 3.0;\\n \\n float baseAngle = pow(thingId * 0.9, 0.8) + thingId * 0.01;\\n\\n float u = fract(thingId * 0.001) * 0.2 + 0.01;\\n float v = mod(thingId * 0.01, 0.25) * 0.05;\\n float snd = texture2D(sound, vec2(u, v)).a;\\n\\n float radius = pow(thingId * 0.002, 1.00) * 0.1 + pow(snd, 4.0) * 0.2;\\n float c = cos(angle) * radius;\\n float s = sin(angle) * radius; \\n \\n\\n float orbitAngle = baseAngle + snd * 0.0;\\n float innerRadius = pow(thingId * 0.0025, 1.2) + pow(snd, 4.0);\\n float oC = cos(orbitAngle + thingId * 0.01) * innerRadius;\\n float oS = sin(orbitAngle + thingId * 0.01) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n \\n float hue = (1.0 - fract(0.0 + thingId * 0.001 + sin(time) * 0.5)) * 0.2;\\n float sat = 1.0;\\n float val = 0.2 + pow(snd, 4.0);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/judahofficial/london-grammar-strong-judah-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n// triangles per thing we want to draw\n#define NUM_TRIANGLES 2.0 \n// points pre thing\n#define NUM_POINTS (NUM_TRIANGLES * 3.0)\n#define STEP 2.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n gl_PointSize = 30.0;\n float localTime = time;\n // pointId: 0, 1, 2, for each point in thing\n float pointId = mod(vertexId, NUM_POINTS);\n // each triangle 0,1,2,0,1,2 ...\n float triPointId = mod(vertexId, 3.0);\n // thingId: counts things\n float thingId = floor(vertexId / NUM_POINTS);\n // triId: 0, 1, .. for each triangle in thing\n float triId = mod(floor(pointId / 3.0), NUM_TRIANGLES);\n float angle = (triId * 0.5 + triPointId) * PI * 2.0 / 3.0;\n \n float baseAngle = pow(thingId * 0.9, 0.8) + thingId * 0.01;\n\n float u = fract(thingId * 0.001) * 0.2 + 0.01;\n float v = mod(thingId * 0.01, 0.25) * 0.05;\n float snd = texture2D(sound, vec2(u, v)).a;\n\n float radius = pow(thingId * 0.002, 1.00) * 0.1 + pow(snd, 4.0) * 0.2;\n float c = cos(angle) * radius;\n float s = sin(angle) * radius; \n \n\n float orbitAngle = baseAngle + snd * 0.0;\n float innerRadius = pow(thingId * 0.0025, 1.2) + pow(snd, 4.0);\n float oC = cos(orbitAngle + thingId * 0.01) * innerRadius;\n float oS = sin(orbitAngle + thingId * 0.01) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n \n float hue = (1.0 - fract(0.0 + thingId * 0.001 + sin(time) * 0.5)) * 0.2;\n float sat = 1.0;\n float val = 0.2 + pow(snd, 4.0);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "r2Kppkg2XMnp7Lr43", "views": { "$numberInt": "1601" diff --git a/art/bpX9tBkNhHiF6nHk8/art.json b/art/bpX9tBkNhHiF6nHk8/art.json index 52279893..36894b36 100644 --- a/art/bpX9tBkNhHiF6nHk8/art.json +++ b/art/bpX9tBkNhHiF6nHk8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mv10", "avatarUrl": "https://secure.gravatar.com/avatar/ae371690b3859dd1515ccf3e9ddc2ec8?default=retro&size=200", - "settings": "{\"num\":15000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// use about 15000 points\\n\\n// white = sound texture\\n// green = volume texture\\n\\n// very long playlist:\\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\\n\\nvoid main () {\\n \\n // normalize the ID; 0.0 to 1.0 across the range of input IDs\\n float norm = (vertexId / vertexCount);\\n \\n // expand x position to cover entire display area\\n // we're shifting norm 0.0 to 1.0 to cover display -1.0 to +1.0\\n // mathematically identical: norm * 2.0 - 1.0\\n float x = (norm - 0.5) * 2.0;\\n \\n // sample the texture history data (0.0 to 1.0 via norm)\\n // this will be the point's y-pos with offsets to separate them\\n // note the first array index is frequency; x=0.0 is all bass-driven\\n float ySnd = (texture2D(sound, vec2(0.0, norm)).a - 0.3);\\n float yVol = (texture2D(volume, vec2(0.0, norm)).a - 0.7);\\n\\n // even/odd IDs alternate between textures and colors\\n // it would be more readable and flexible to do this with arrays\\n // but WebGL can't handle variable array indexing (yeah WTF?)\\n // https://stackoverflow.com/a/30648046/152997\\n float a = mod(vertexId, 2.0);\\n float b = step(a, 0.0);\\n\\n // one y is multiplied by 1, the other is multiplied by 0\\n float y = (ySnd * a) + (yVol * b);\\n \\n // same for colors, while = sound tex, green = volume tex\\n vec3 color = (vec3(1.0) * a) + (vec3(0.0, 1.0, 0.0) * b);\\n\\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(color, 1.0);\\n\\n // fat points easier to see at hi-res full-screen\\n gl_PointSize = 5.0;\\n\\n}\"}", + "settings": { + "num": 15000, + "mode": "POINTS", + "sound": "https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// use about 15000 points\n\n// white = sound texture\n// green = volume texture\n\n// very long playlist:\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\n\nvoid main () {\n \n // normalize the ID; 0.0 to 1.0 across the range of input IDs\n float norm = (vertexId / vertexCount);\n \n // expand x position to cover entire display area\n // we're shifting norm 0.0 to 1.0 to cover display -1.0 to +1.0\n // mathematically identical: norm * 2.0 - 1.0\n float x = (norm - 0.5) * 2.0;\n \n // sample the texture history data (0.0 to 1.0 via norm)\n // this will be the point's y-pos with offsets to separate them\n // note the first array index is frequency; x=0.0 is all bass-driven\n float ySnd = (texture2D(sound, vec2(0.0, norm)).a - 0.3);\n float yVol = (texture2D(volume, vec2(0.0, norm)).a - 0.7);\n\n // even/odd IDs alternate between textures and colors\n // it would be more readable and flexible to do this with arrays\n // but WebGL can't handle variable array indexing (yeah WTF?)\n // https://stackoverflow.com/a/30648046/152997\n float a = mod(vertexId, 2.0);\n float b = step(a, 0.0);\n\n // one y is multiplied by 1, the other is multiplied by 0\n float y = (ySnd * a) + (yVol * b);\n \n // same for colors, while = sound tex, green = volume tex\n vec3 color = (vec3(1.0) * a) + (vec3(0.0, 1.0, 0.0) * b);\n\n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(color, 1.0);\n\n // fat points easier to see at hi-res full-screen\n gl_PointSize = 5.0;\n\n}" + }, "screenshotURL": "data/images/images-ef7ogza1aqocla6p6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bsfzCu524wjbdK79y/art.json b/art/bsfzCu524wjbdK79y/art.json index 1db00926..5883d81c 100644 --- a/art/bsfzCu524wjbdK79y/art.json +++ b/art/bsfzCu524wjbdK79y/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n \\n\\n if(v>0.5)\\n position.y = (1. -position.y);\\n \\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\t//j *= 1.;\\n\\tj = mod(j + time, 1.0);\\n\\t\\n\\tfloat i = mod(position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\\n\\t\\n i = mod(position.y * 7. * j, i / j);\\n \\n\\ti *= 5.;\\n\\t\\n\\t//i = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n \n\n if(v>0.5)\n position.y = (1. -position.y);\n \n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\t//j *= 1.;\n\tj = mod(j + time, 1.0);\n\t\n\tfloat i = mod(position.x * 1. + 1.*cos(time/12.), sin(time/12.0) + 2.0);\n\t\n i = mod(position.y * 7. * j, i / j);\n \n\ti *= 5.;\n\t\n\t//i = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-82vce86gi0um1mqlm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/btdHcA68nwnRPi6G5/art.json b/art/btdHcA68nwnRPi6G5/art.json index 7650c747..ef6a521d 100644 --- a/art/btdHcA68nwnRPi6G5/art.json +++ b/art/btdHcA68nwnRPi6G5/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lilhomiedowntown", "avatarUrl": "https://secure.gravatar.com/avatar/ac67592da38859acf3c943600143c436?default=retro&size=200", - "settings": "{\"num\":1669,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.20392156862745098,0.396078431372549,0.6431372549019608,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\t\\nvoid main() {\\n \\n float pointSize=mix(10.,0.,sin(time)*0.5+0.5);\\n float pointSeparation=20.;\\n float countX=40.;\\n float countY=40.;\\n float id=floor(vertexId/countY);\\n float mox=mod(vertexId,countX);\\n float inPosX=((mox/(countX-1.))-0.5)*2.;\\n float inPosY=((id/(countY-1.))-0.5)*2.;\\n \\n pointSize*=pow(abs(inPosY+inPosX),.4)*1.3;\\n \\n \\n vec2 pos=vec2(inPosX,inPosY);\\n\\n \\n \\n \\n \\n \\n \\n \\n \\n \\n gl_Position=vec4(pos.x,pos.y,-1,1);\\n gl_PointSize=pointSize;\\n vec3 col=hsv2rgb(vec3(gl_Position.xy,1));\\n v_color = vec4(col,1);\\n}\"}", + "settings": { + "num": 1669, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.20392156862745098, + 0.396078431372549, + 0.6431372549019608, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\t\nvoid main() {\n \n float pointSize=mix(10.,0.,sin(time)*0.5+0.5);\n float pointSeparation=20.;\n float countX=40.;\n float countY=40.;\n float id=floor(vertexId/countY);\n float mox=mod(vertexId,countX);\n float inPosX=((mox/(countX-1.))-0.5)*2.;\n float inPosY=((id/(countY-1.))-0.5)*2.;\n \n pointSize*=pow(abs(inPosY+inPosX),.4)*1.3;\n \n \n vec2 pos=vec2(inPosX,inPosY);\n\n \n \n \n \n \n \n \n \n \n gl_Position=vec4(pos.x,pos.y,-1,1);\n gl_PointSize=pointSize;\n vec3 col=hsv2rgb(vec3(gl_Position.xy,1));\n v_color = vec4(col,1);\n}" + }, "screenshotURL": "data/images/images-egu2oxhvkc6d9kasl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/btkDAJMxJHZR3rK2M/art.json b/art/btkDAJMxJHZR3rK2M/art.json index 0e186625..954c7144 100644 --- a/art/btkDAJMxJHZR3rK2M/art.json +++ b/art/btkDAJMxJHZR3rK2M/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":421,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 5;\\t\\n \\n \\n \\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\\n }\\n \\n else if(num == 5) {\\n gl_Position = vec4(cos(vertexId),sin(vertexId),0.0,1.0);\\n }\\n\\n gl_PointSize = cos(time)+sin(time*vertexId/50.0); \\n \\n \\n v_color = vec4(sin(vertexId/122.0),\\n sin(vertexId/122.0),\\n sin(vertexId/122.0),1);\\n}\"}", + "settings": { + "num": 421, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 5;\t\n \n \n \n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\n }\n \n else if(num == 5) {\n gl_Position = vec4(cos(vertexId),sin(vertexId),0.0,1.0);\n }\n\n gl_PointSize = cos(time)+sin(time*vertexId/50.0); \n \n \n v_color = vec4(sin(vertexId/122.0),\n sin(vertexId/122.0),\n sin(vertexId/122.0),1);\n}" + }, "screenshotURL": "data/images/images-1yqo0khicrv2c2x8x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bwr53KzdWw7hBTnsA/art.json b/art/bwr53KzdWw7hBTnsA/art.json index 629dde04..8ab9f614 100644 --- a/art/bwr53KzdWw7hBTnsA/art.json +++ b/art/bwr53KzdWw7hBTnsA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/upscale-recordings/forestfires\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Derivative of \\\"the tangled webs we weave\\\" by jshrake\\n// Make sure to also switch to \\\"points\\\"!\\n\\n// hash functions\\n#define HASHSCALE1 .1031\\n#define HASHSCALE3 vec3(.1031, .1030, .0973)\\n#define HASHSCALE4 vec4(.1031, .1030, .0973, .1099)\\n\\nfloat hash11(float p) {\\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n // calculate the position\\n float vertex_id = vertexId;\\n // This basically makes each vertex ID even so that the lines don't cross the screen edge, and are straight\\n float quad_id = floor(vertex_id*0.5);\\n float quad_count = vertexCount;\\n float quad_pct = quad_id / quad_count;\\n float quads_per_trail = 1000.0;\\n float trail_id = floor(quad_id / quads_per_trail);\\n float trail_count = floor(quad_count / quads_per_trail);\\n float trail_pct = trail_id / trail_count;\\n float quad_trail_pct = quad_id / quads_per_trail - trail_id;\\n float quad_size = 1.0;\\n float trail_length = 1.0;//2.0*hash11(trail_id + 0.9872);\\n \\n\\n\\n float x = -1.0 + 2.0*quad_trail_pct*trail_length + 0.05*hash11(trail_id + 0.5123)*time;\\n x = mod(x + 1.0, 2.0) - 1.0;\\n float quad_x_pct = (x + 1.0) / 2.0;\\n \\n float toggle = texture2D(sound, vec2(0.0,0.5-x*0.5)).a*0.5;\\n float spread = 0.2;\\n float how_much_quad = 0.3*(hash11(trail_id + 0.734)) * toggle;\\n \\n \\n \\n float y = mix(\\n spread*hash11(trail_id + 0.1353)*sin(10.0*(time*0.05+x - trail_id)),\\n how_much_quad*(2.0 * hash11(vertex_id) - 1.0) + (1.0 - how_much_quad)*(2.0 * hash11(trail_id) - 1.0),\\n smoothstep(0.1, 0.5, quad_x_pct) - smoothstep(0.2, 0.9 - 0.1*hash11(trail_id + 0.223), quad_x_pct));\\n \\n float z = 0.0;\\n\\n gl_Position = vec4(x,y,z,1.0);\\n gl_PointSize = quad_size;\\n\\n // write the color\\n vec3 hsv = vec3(mix(0.6 + 0.3*trail_pct, 0.5 + 0.1*trail_pct, quad_x_pct), 1.0, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/upscale-recordings/forestfires", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Derivative of \"the tangled webs we weave\" by jshrake\n// Make sure to also switch to \"points\"!\n\n// hash functions\n#define HASHSCALE1 .1031\n#define HASHSCALE3 vec3(.1031, .1030, .0973)\n#define HASHSCALE4 vec4(.1031, .1030, .0973, .1099)\n\nfloat hash11(float p) {\n vec3 p3 = fract(vec3(p) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n // calculate the position\n float vertex_id = vertexId;\n // This basically makes each vertex ID even so that the lines don't cross the screen edge, and are straight\n float quad_id = floor(vertex_id*0.5);\n float quad_count = vertexCount;\n float quad_pct = quad_id / quad_count;\n float quads_per_trail = 1000.0;\n float trail_id = floor(quad_id / quads_per_trail);\n float trail_count = floor(quad_count / quads_per_trail);\n float trail_pct = trail_id / trail_count;\n float quad_trail_pct = quad_id / quads_per_trail - trail_id;\n float quad_size = 1.0;\n float trail_length = 1.0;//2.0*hash11(trail_id + 0.9872);\n \n\n\n float x = -1.0 + 2.0*quad_trail_pct*trail_length + 0.05*hash11(trail_id + 0.5123)*time;\n x = mod(x + 1.0, 2.0) - 1.0;\n float quad_x_pct = (x + 1.0) / 2.0;\n \n float toggle = texture2D(sound, vec2(0.0,0.5-x*0.5)).a*0.5;\n float spread = 0.2;\n float how_much_quad = 0.3*(hash11(trail_id + 0.734)) * toggle;\n \n \n \n float y = mix(\n spread*hash11(trail_id + 0.1353)*sin(10.0*(time*0.05+x - trail_id)),\n how_much_quad*(2.0 * hash11(vertex_id) - 1.0) + (1.0 - how_much_quad)*(2.0 * hash11(trail_id) - 1.0),\n smoothstep(0.1, 0.5, quad_x_pct) - smoothstep(0.2, 0.9 - 0.1*hash11(trail_id + 0.223), quad_x_pct));\n \n float z = 0.0;\n\n gl_Position = vec4(x,y,z,1.0);\n gl_PointSize = quad_size;\n\n // write the color\n vec3 hsv = vec3(mix(0.6 + 0.3*trail_pct, 0.5 + 0.1*trail_pct, quad_x_pct), 1.0, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-sgreoau9jthpzdty2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/bwv3qCqRiC5rfavvx/art.json b/art/bwv3qCqRiC5rfavvx/art.json index 3f38e4ed..d037c1ae 100644 --- a/art/bwv3qCqRiC5rfavvx/art.json +++ b/art/bwv3qCqRiC5rfavvx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Motion\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Motion\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-kdmt87gz6x2y4mevw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/bySCJHkqxfotHbAzv/art.json b/art/bySCJHkqxfotHbAzv/art.json index af3069ed..7c91a093 100644 --- a/art/bySCJHkqxfotHbAzv/art.json +++ b/art/bySCJHkqxfotHbAzv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hug-life/coppe-666ganstaz-guttertek-666\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 1.+time*0.001 - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 10.*time;\\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;\\n \\n mat = ident();\\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(3, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 1.;//0.5 + over * 0.7;\\n float sat = step(0.25,s2)*3.;\\n float val = pow(s2*0.01,0.3);\\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 00.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -2.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hug-life/coppe-666ganstaz-guttertek-666", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 10.0 ) * NdotL * f * 0.1;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( cos(time*100.)*1., fAOAmount, clamp( h, 0.0, -0.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 1.+time*0.001 - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx,0.3, 1.0), c.y*2.+c.x);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(1.0, 0.2, u/16.), v * 4.2)).a*10.;\n float s2 = texture2D(sound, vec2(mix(0.001, 0.002, u), v * 00.05)).a*0.1-sin(time*3.);\n \n vCubeOrigin.x += m1p1(bu) * perBlock * time*0.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 10.*time;\n vCubeOrigin.z += fract(-time * 0.0201+ z / vSpace) * vSpace;\n float height = mix(0.1, 1., hash(fCubeId)) + smoothstep(0., 2., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;\n \n mat = ident();\n mat *= rotZ(time + v * 2. + bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(3, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 1.;//0.5 + over * 0.7;\n float sat = step(0.25,s2)*3.;\n float val = pow(s2*0.01,0.3);\n vCubeCol.rgb = hsv2rgb(vec3(hue*sat, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace-val;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 00.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -2.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(115.), resolution.x / resolution.y, 10.1*abs(cos(time)), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.6) - exp2( sceneVertex.vColor * -fExposure ) );\n \tvFinalColor -= vec3(0.0-sin(time*0.0)*sceneVertex.vColor.r,0.0,0.0-cos(time*0.2));\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-hm2uamqbbejg5nw01-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/byf5BfNoi72wvAFDi/art.json b/art/byf5BfNoi72wvAFDi/art.json index f350dfe8..c2f5fc69 100644 --- a/art/byf5BfNoi72wvAFDi/art.json +++ b/art/byf5BfNoi72wvAFDi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tExercise - Vertexshaderart : Circles from Triangles\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n \\tc, -s, 0, 0,\\n \\ts, c, 0, 0,\\n \\t0, 0, 1, 0,\\n \\t0, 0, 0, 1\\n );\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n\\t1, 0, 0, 0,\\n\\t0, 1, 0, 0,\\n\\t0, 0, 1, 0,\\n\\ttrans, 1\\n );\\n}\\n\\nmat4 ident()\\n{\\n\\treturn mat4(\\n\\t\\t1, 0, 0, 0,\\n\\t\\t0, 1, 0, 0,\\n\\t\\t0, 0, 1, 0,\\n\\t\\t0, 0, 0, 1\\n );\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n\\treturn mat4(\\n\\t\\ts.x, 0, 0, 0,\\n\\t\\t0, s.y, 0, 0,\\n\\t\\t0, 0, s.z, 0,\\n\\t\\t0, 0, 0, 1\\n );\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n\\treturn mat4(\\n\\t\\ts, 0, 0, 0,\\n\\t\\t0, s, 0, 0,\\n\\t\\t0, 0, s, 0,\\n\\t\\t0, 0, 0, 1\\n );\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / numCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main()\\n{\\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0);\\n \\n \\tfloat numCircleSegments = oddSlice * 6.0;\\n \\tvec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\tfloat numPointsPerCircle = numCircleSegments * 6.0;\\n \\tfloat circleId = floor(vertexId / numPointsPerCircle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n\\tfloat down = floor(sqrt(numCircles));\\n \\tfloat across = floor(numCircles / down);\\n \\n \\tfloat x = mod(circleId, across);\\n \\tfloat y = floor(circleId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat sc = pow(snd + 0.2, 5.0) * mix(1., 1.1, oddSlice);\\n \\n \\tsc *= 20. / across;\\n \\n \\tvec4 pos = vec4(circleXY, 0, 1);\\n \\tmat4 mat = ident();\\n \\tmat *= scale(vec3(1, aspect, 1));\\n \\tmat *= rotZ(sin(time));\\n \\tmat *= uniformScale((sin(time) + 3.));\\n \\tmat *= trans(vec3(ux, vy, 0));\\n \\tmat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n \\tgl_Position = mat * pos;\\n \\n \\tfloat soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\t\\n \\tfloat pump = step(0.8, snd);\\n \\tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\\n \\tfloat sat = 1.;//mix(0.5, 1.0, pump);\\n \\tfloat val = mix(0.4, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\thue = hue + pump * 0.5 + pump * 0.33;\\n \\tval += pump;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\tseongryul.park\n//\tCS250 spring 2023\n//\tExercise - Vertexshaderart : Circles from Triangles\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n \tc, -s, 0, 0,\n \ts, c, 0, 0,\n \t0, 0, 1, 0,\n \t0, 0, 0, 1\n );\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n\t1, 0, 0, 0,\n\t0, 1, 0, 0,\n\t0, 0, 1, 0,\n\ttrans, 1\n );\n}\n\nmat4 ident()\n{\n\treturn mat4(\n\t\t1, 0, 0, 0,\n\t\t0, 1, 0, 0,\n\t\t0, 0, 1, 0,\n\t\t0, 0, 0, 1\n );\n}\n\nmat4 scale(vec3 s)\n{\n\treturn mat4(\n\t\ts.x, 0, 0, 0,\n\t\t0, s.y, 0, 0,\n\t\t0, 0, s.z, 0,\n\t\t0, 0, 0, 1\n );\n}\n\nmat4 uniformScale(float s)\n{\n\treturn mat4(\n\t\ts, 0, 0, 0,\n\t\t0, s, 0, 0,\n\t\t0, 0, s, 0,\n\t\t0, 0, 0, 1\n );\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.0);\n float vy = mod(floor(id / 2.) + floor(id / 3.0), 2.0);\n \n float angle = ux / numCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main()\n{\n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0);\n \n \tfloat numCircleSegments = oddSlice * 6.0;\n \tvec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \tfloat numPointsPerCircle = numCircleSegments * 6.0;\n \tfloat circleId = floor(vertexId / numPointsPerCircle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCircle);\n \n\tfloat down = floor(sqrt(numCircles));\n \tfloat across = floor(numCircles / down);\n \n \tfloat x = mod(circleId, across);\n \tfloat y = floor(circleId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tfloat su = abs(u - 0.5) * 2.0;\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tfloat aspect = resolution.x / resolution.y;\n \tfloat sc = pow(snd + 0.2, 5.0) * mix(1., 1.1, oddSlice);\n \n \tsc *= 20. / across;\n \n \tvec4 pos = vec4(circleXY, 0, 1);\n \tmat4 mat = ident();\n \tmat *= scale(vec3(1, aspect, 1));\n \tmat *= rotZ(sin(time));\n \tmat *= uniformScale((sin(time) + 3.));\n \tmat *= trans(vec3(ux, vy, 0));\n \tmat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n \tgl_Position = mat * pos;\n \n \tfloat soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \t\n \tfloat pump = step(0.8, snd);\n \tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\n \tfloat sat = 1.;//mix(0.5, 1.0, pump);\n \tfloat val = mix(0.4, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \thue = hue + pump * 0.5 + pump * 0.33;\n \tval += pump;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-0cfi9ju2j111mwnyl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/c2G37xF7rQv9E6DnK/art.json b/art/c2G37xF7rQv9E6DnK/art.json index 2b7d097f..21bdd864 100644 --- a/art/c2G37xF7rQv9E6DnK/art.json +++ b/art/c2G37xF7rQv9E6DnK/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n/*\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n sin(id * 0.5+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}\\n*/\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 1.),\\n sin(id * 0.5),\\n sin(id * 0.25));\\n}\\n\\n\\nconst float expand = 120.;\\nconst float off = 0.1;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \\n{\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 eye = r0 * expand + zaxis * 1.;\\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n /*_emat = mat4(\\n 1.,0.,0.,0.,\\n 0.,1.,0.,0.,\\n 0.,0.,1.,0.,\\n 0.,0.,0.,1.); \\n */\\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./200.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n mat4 scaleMat = scale(vec3(sizeFactor,100.*sizeFactor,sizeFactor));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n //cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n \\n //LOGISTIC\\n /*\\n vec2 vp = vec2(0.,0.);\\n float z = fract(0.02+snd*snd);//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n \\n\\n cubep.y+= z;\\n cubep.x+= shapeRelId;\\n //END LOGISTIC\\n */\\n \\n //cubep+= getCurvePoint(shapeId, 0.);\\n \\n \\n mat4 wmat;\\n mat4 emat;\\n \\n float base = 14.5; \\n //base = time * 10.0;\\n vec4 color2 = vec4(1.,1.,1.,1.);\\n vec3 pos;\\n //void track(shapeId, shapeCount, base, pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \\n track(shapeId, shapeCount/100., base, pos, color2, wmat, emat);\\n \\n // track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi/expand;\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n/*\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n sin(id * 0.5+_time*10.),\n sin(id * 0.25+_time*10.));\n}\n*/\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 1.),\n sin(id * 0.5),\n sin(id * 0.25));\n}\n\n\nconst float expand = 120.;\nconst float off = 0.1;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \n{\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 eye = r0 * expand + zaxis * 1.;\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n /*_emat = mat4(\n 1.,0.,0.,0.,\n 0.,1.,0.,0.,\n 0.,0.,1.,0.,\n 0.,0.,0.,1.); \n */\n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./200.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n mat4 scaleMat = scale(vec3(sizeFactor,100.*sizeFactor,sizeFactor));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n //cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n \n //LOGISTIC\n /*\n vec2 vp = vec2(0.,0.);\n float z = fract(0.02+snd*snd);//sin(shapeRelId+fract(time/100.));//fract(0.02);\n\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n \n\n cubep.y+= z;\n cubep.x+= shapeRelId;\n //END LOGISTIC\n */\n \n //cubep+= getCurvePoint(shapeId, 0.);\n \n \n mat4 wmat;\n mat4 emat;\n \n float base = 14.5; \n //base = time * 10.0;\n vec4 color2 = vec4(1.,1.,1.,1.);\n vec3 pos;\n //void track(shapeId, shapeCount, base, pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \n track(shapeId, shapeCount/100., base, pos, color2, wmat, emat);\n \n // track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi/expand;\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-j4sp4rvrgkh1cqx6l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/c3DBxMMrtv3DhErvP/art.json b/art/c3DBxMMrtv3DhErvP/art.json index 24fedb21..0d94b885 100644 --- a/art/c3DBxMMrtv3DhErvP/art.json +++ b/art/c3DBxMMrtv3DhErvP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":570,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n}\"}", + "settings": { + "num": 570, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n}" + }, "screenshotURL": "data/images/images-ybfh9kbwmzja90t0b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/c53eL6yrZ2W47TK9r/art.json b/art/c53eL6yrZ2W47TK9r/art.json index e931f804..36a11aeb 100644 --- a/art/c53eL6yrZ2W47TK9r/art.json +++ b/art/c53eL6yrZ2W47TK9r/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":700,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define VERTEX_SPEED 0.5\\n\\nvoid main () {\\n vec3 pos = vec3(cos(VERTEX_SPEED*time+(vertexId))*1.3, ((vertexId/(vertexCount-1.0))-0.5)*2.0, 0.0);\\n vec3 clr = vec3(pos.x, pos.y, -pos.y)+0.2;\\n \\n gl_PointSize = 15.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(clr, 1.0);\\n}\"}", + "settings": { + "num": 700, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define VERTEX_SPEED 0.5\n\nvoid main () {\n vec3 pos = vec3(cos(VERTEX_SPEED*time+(vertexId))*1.3, ((vertexId/(vertexCount-1.0))-0.5)*2.0, 0.0);\n vec3 clr = vec3(pos.x, pos.y, -pos.y)+0.2;\n \n gl_PointSize = 15.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(clr, 1.0);\n}" + }, "screenshotURL": "data/images/images-y7dt8bhwiqgbpdcvr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/c5eMNzQN3L9wo8Bp5/art.json b/art/c5eMNzQN3L9wo8Bp5/art.json index 21b9ed90..cf11e9ce 100644 --- a/art/c5eMNzQN3L9wo8Bp5/art.json +++ b/art/c5eMNzQN3L9wo8Bp5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\n float x = vertexId;\\n float y = vertexId;\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 10.;\\n\\n v_color = vec4(1., 0., 0., 1.);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\n float x = vertexId;\n float y = vertexId;\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 10.;\n\n v_color = vec4(1., 0., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-xdcrroj3kebozh27d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/c65csouQ75h2ArqRF/art.json b/art/c65csouQ75h2ArqRF/art.json index d6e13bb5..ff013675 100644 --- a/art/c65csouQ75h2ArqRF/art.json +++ b/art/c65csouQ75h2ArqRF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":60,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n\\n#define AND(a,x) int(floor(x - (a * 16.0)))\\n#define MASK 1024.0\\n#define SCALE 112.0\\n#define MAX_TRIS 32\\n#define TOTAL_TRI 21\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec3 triangles[MAX_TRIS];\\nmat4 indices[4];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid populate(){ \\n\\n#define V1 18451.0\\n#define V2 7169.0\\n#define V3 46.0\\n#define V4 22588.0\\n#define V5 75.0\\n#define V6 18534.0\\n#define V7 7288.0\\n#define V8 54525998.0\\n#define V9 54526027.0\\n#define V10 19930228.0\\n#define V11 19930116.0\\n#define V12 31473724.0\\n\\ntriangles[0]=vec3(V1,V2,V3);\\ntriangles[1]=vec3(V3,V1,V4);\\ntriangles[2]=vec3(V4,V3,V5);\\ntriangles[3]=vec3(V5,V4,V6);\\ntriangles[4]=vec3(V6,V5,V7);\\ntriangles[5]=vec3(V3,V8,V5);\\ntriangles[6]=vec3(V8,V9,V5);\\ntriangles[7]=vec3(V10,V5,V9);\\ntriangles[8]=vec3(V7,V10,V5);\\ntriangles[9]=vec3(V11,V3,V8);\\ntriangles[10]=vec3(V2,V11,V3);\\ntriangles[11]=vec3(V12,V9,V8);\\ntriangles[12]=vec3(V12,V4,V6);\\ntriangles[13]=vec3(V12,V1,V4);\\ntriangles[14]=vec3(V12,V6,V9);\\ntriangles[15]=vec3(V12,V8,V1);\\ntriangles[16]=vec3(V9,V6,V10);\\ntriangles[17]=vec3(V8,V1,V11);\\ntriangles[18]=vec3(V7,V6,V10);\\ntriangles[19]=vec3(V2,V1,V11);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTICES_PER_TRI));\\n for(int i=0;i < \\\\___ \\\\| Y \\\\/ __ \\\\_/ /_/ \\\\ ___/| | \\\\// __ \\\\| | \\\\/| | \\n \\\\_/ \\\\___ >__| |__| \\\\___ >__/\\\\_ \\\\/____ >___| (____ /\\\\____ |\\\\___ >__| (____ /__| |__| \\n \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 3.) \\nvoid getCirclePoint(const float id, out vec3 pos, out float center) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n center = step(0.5, mod(id, 3.));\\n float u = outId / (NUM_EDGE_POINTS_PER_CIRCLE - 1.);\\n float a = u * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = s;\\n float y = c;\\n float z = 0.;\\n pos = vec3(x, y, z) * center; \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float center;\\n getCirclePoint(vertexId, pos, center); \\n \\n float sideId = floor(circleId / 2.);// + floor(time * 10.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n vec3 offset = vec3(hash(sideId), m1p1(hash(sideId * 0.37)), 0);\\n offset.x += goop(sideId + time) * 0.1;\\n offset.y += goop(sideId + time * 1.13) * 0.1;\\n offset.x *= side;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n float snd = 0.;\\n\\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.2, hash(sideId)) + pow(snd, 5.0) * 0.1);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0., 0.2, fract(sideId * 0.79));\\n float sat = 0.5;\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.6039215686274509, + 0.5137254901960784, + 1 + ], + "shader": "/*\n __ .__ .___ __ \n___ __ ____________/ |_ ____ ___ ___ _____| |__ _____ __| _/________________ ________/ |_ \n\\ \\/ // __ \\_ __ \\ __\\/ __ \\\\ \\/ / / ___/ | \\\\__ \\ / __ |/ __ \\_ __ \\__ \\\\_ __ \\ __\\\n \\ /\\ ___/| | \\/| | \\ ___/ > < \\___ \\| Y \\/ __ \\_/ /_/ \\ ___/| | \\// __ \\| | \\/| | \n \\_/ \\___ >__| |__| \\___ >__/\\_ \\/____ >___| (____ /\\____ |\\___ >__| (____ /__| |__| \n \\/ \\/ \\/ \\/ \\/ \\/ \\/ \\/ \\/ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 3.) \nvoid getCirclePoint(const float id, out vec3 pos, out float center) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n center = step(0.5, mod(id, 3.));\n float u = outId / (NUM_EDGE_POINTS_PER_CIRCLE - 1.);\n float a = u * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = s;\n float y = c;\n float z = 0.;\n pos = vec3(x, y, z) * center; \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float center;\n getCirclePoint(vertexId, pos, center); \n \n float sideId = floor(circleId / 2.);// + floor(time * 10.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n vec3 offset = vec3(hash(sideId), m1p1(hash(sideId * 0.37)), 0);\n offset.x += goop(sideId + time) * 0.1;\n offset.y += goop(sideId + time * 1.13) * 0.1;\n offset.x *= side;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n float snd = 0.;\n\n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.2, hash(sideId)) + pow(snd, 5.0) * 0.1);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0., 0.2, fract(sideId * 0.79));\n float sat = 0.5;\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-y5ecssgjqyl96efme-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cHuvNCmJmuzYDZwhL/art.json b/art/cHuvNCmJmuzYDZwhL/art.json index 8f8603d7..b529feff 100644 --- a/art/cHuvNCmJmuzYDZwhL/art.json +++ b/art/cHuvNCmJmuzYDZwhL/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "epoch", "avatarUrl": "https://secure.gravatar.com/avatar/3e53f54468906b25ff02d4860fa32a28?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n if (gl_Position.x < 0.) {\\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n if (gl_Position.x < 0.) {\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n}\n\n" + }, "screenshotURL": "data/images/images-i0qzd4rvqn1xor9fi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cMSxxdiL7gecfonqz/art.json b/art/cMSxxdiL7gecfonqz/art.json index f7af1782..33b45c1c 100644 --- a/art/cMSxxdiL7gecfonqz/art.json +++ b/art/cMSxxdiL7gecfonqz/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":24579,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.403921568627451,0.403921568627451,0.403921568627451,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n01/01/2019\\n@BestRegard \\n*/ \\n\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region Scene_Vertex_Collection \\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n\\n struct SurfaceInfo \\n {\\n vec3 vPos;\\n vec3 vNormal;\\n float fGloss;\\n };\\n struct SphereInfo\\n {\\t \\n vec3 vOrigin;\\n float fRadius ; \\n \\n float fSlices ; \\n float fSegments ; \\n }; \\n \\n struct Material \\n {\\n vec4 diffuseAlebdo;\\n vec3 FresenlR0 ;\\n float Roughness ;\\n mat4 MatTransform ; \\n }; \\n struct Light\\n {\\n\\n vec3 vStrength ; \\n float FalloffStart ; \\n vec3 vDirection ; \\n float FalloffEnd ; \\n vec3 vPosition ; \\n float SpotPower ; \\n };\\n#pragma endregion \\n \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, DirLight,\\n sv) ; \\n vertexIndex -= floorVertexCount ; \\n #pragma endregion \\n \\n #pragma region Sphere\\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo,\\n DirLight, \\n camPos,\\n sv);\\n m *= uniformScale(1.5);\\n m *= trans(vec3(0. , 4. , 0. )) ; \\n }\\n vertexIndex -= fSphereVertexCount ; \\n #pragma endregion \\n#pragma endregion \\n \\n \\n#pragma region PostEffect\\n // PE_Vignette(sv) ;\\n#pragma endregion \\n \\n#pragma region ApplySetting\\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n#pragma endregion \\n}\"}", + "settings": { + "num": 24579, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n01/01/2019\n@BestRegard \n*/ \n\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t \n vec3 vOrigin;\n float fRadius ; \n \n float fSlices ; \n float fSegments ; \n }; \n \n struct Material \n {\n vec4 diffuseAlebdo;\n vec3 FresenlR0 ;\n float Roughness ;\n mat4 MatTransform ; \n }; \n struct Light\n {\n\n vec3 vStrength ; \n float FalloffStart ; \n vec3 vDirection ; \n float FalloffEnd ; \n vec3 vPosition ; \n float SpotPower ; \n };\n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, DirLight,\n sv) ; \n vertexIndex -= floorVertexCount ; \n #pragma endregion \n \n #pragma region Sphere\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo,\n DirLight, \n camPos,\n sv);\n m *= uniformScale(1.5);\n m *= trans(vec3(0. , 4. , 0. )) ; \n }\n vertexIndex -= fSphereVertexCount ; \n #pragma endregion \n#pragma endregion \n \n \n#pragma region PostEffect\n // PE_Vignette(sv) ;\n#pragma endregion \n \n#pragma region ApplySetting\n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n#pragma endregion \n}" + }, "screenshotURL": "data/images/images-gc17abjxqx6i76z55-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cMqY3Hixco2WwFZo6/art.json b/art/cMqY3Hixco2WwFZo6/art.json index 3e07ba8e..1594bee1 100644 --- a/art/cMqY3Hixco2WwFZo6/art.json +++ b/art/cMqY3Hixco2WwFZo6/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "kcha", "avatarUrl": "https://secure.gravatar.com/avatar/393683f94ba2c18293b67ab3d3eb6f10?default=retro&size=200", - "settings": "{\"num\":150,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 10.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\"}", + "settings": { + "num": 150, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 10.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}" + }, "screenshotURL": "data/images/images-dopf3pk1pczd3avl5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cMzGhMJLeg2FmmwWM/art.json b/art/cMzGhMJLeg2FmmwWM/art.json index d79df9da..a4fa5f68 100644 --- a/art/cMzGhMJLeg2FmmwWM/art.json +++ b/art/cMzGhMJLeg2FmmwWM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvec3 getColor(int index)\\n{\\n\\tif (index == 0)\\n\\t\\treturn vec3(0.2, 0.2, 0.2);\\n\\tif (index == 1)\\n\\t\\treturn vec3(0.2, 0.4, 0.6);\\n\\tif (index == 2)\\n\\t\\treturn vec3(0.2, 0.6, 0.4);\\n\\tif (index == 3)\\n\\t\\treturn vec3(0.4, 0.2, 0.6);\\n\\tif (index == 4)\\n\\t\\treturn vec3(0.4, 0.6, 0.2);\\n\\tif (index == 5)\\n\\t\\treturn vec3(0.6, 0.2, 0.4);\\n\\tif (index == 6)\\n\\t\\treturn vec3(0.6, 0.4, 0.2);\\n\\tif (index == 7)\\n\\t\\treturn vec3(0.6, 0.6, 0.6);\\n\\t\\n}\\n\\n\\nvoid main ()\\n{\\n float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n\\t\\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\tj *= 1.;\\n\\tj = mod(j - time/2., 1.0);\\n\\t\\n\\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\\n\\ti = mod(position.y * colorCount * j, i / j);\\n\\ti *= 8.;\\n\\t\\n\\ti = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( getColor(int(i)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvec3 getColor(int index)\n{\n\tif (index == 0)\n\t\treturn vec3(0.2, 0.2, 0.2);\n\tif (index == 1)\n\t\treturn vec3(0.2, 0.4, 0.6);\n\tif (index == 2)\n\t\treturn vec3(0.2, 0.6, 0.4);\n\tif (index == 3)\n\t\treturn vec3(0.4, 0.2, 0.6);\n\tif (index == 4)\n\t\treturn vec3(0.4, 0.6, 0.2);\n\tif (index == 5)\n\t\treturn vec3(0.6, 0.2, 0.4);\n\tif (index == 6)\n\t\treturn vec3(0.6, 0.4, 0.2);\n\tif (index == 7)\n\t\treturn vec3(0.6, 0.6, 0.6);\n\t\n}\n\n\nvoid main ()\n{\n float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n\t\n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\tj *= 1.;\n\tj = mod(j - time/2., 1.0);\n\t\n\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\n\ti = mod(position.y * colorCount * j, i / j);\n\ti *= 8.;\n\t\n\ti = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( getColor(int(i)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-o0ypnvj6jvnnz9qlf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cNaBhCSeeqFwhZQw4/art.json b/art/cNaBhCSeeqFwhZQw4/art.json index 99d10ce7..edfb6179 100644 --- a/art/cNaBhCSeeqFwhZQw4/art.json +++ b/art/cNaBhCSeeqFwhZQw4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .1//KParameter 0.>>5.\\n#define PointSizeValue 2.//KParameter 1.>>4.\\n#define colorFactorR 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79553//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n#define symCount 3.//KParameter 0.>>20.\\n\\n#define PI radians(180.0)\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n\\nmat4 rotZ( float _angle ) {\\n float s = sin( _angle );\\n float c = cos( _angle );\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 osc3(float t, float i)\\n{\\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 osc3Comb(float t, float i) {\\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\\n}\\n\\nvec3 incr(float t, float i, vec3 ofs, float lerpEnd)\\n{\\n vec3 pos = osc3Comb(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n \\n float rotationCout = floor(symCount);\\n \\n float localVertexId = mod(vertexId,vertexCount/rotationCout);\\n \\n float shapeId = floor(vertexId/rotationCout);\\n\\n float t = time*timeFactor;\\n float i = localVertexId;//+sin(localVertexId)*100.;\\n\\n vec3 pos = osc3Comb(t,i);\\n vec3 posDelta = vec3(colorFactorR,0.,0.);\\n \\n \\n for (float f = 0.; f < 10.; f++) \\n {\\n\\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\\n }\\n \\n posDelta += incr(t,i,posDelta,0.2);\\n \\n pos -= osc3(t,-1.)*posComp0;\\n \\n pos += posDelta;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n \\n mat4 rot = rotZ(shapeId*2.*PI/rotationCout);\\n vec4 fpos = vec4((vec4(pos, 1)).xyz, 1);\\n fpos *= rot;\\n \\n gl_Position = vec4(fpos.x, fpos.y*resolution.x/resolution.y, fpos.z*.1, 1);\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .1//KParameter 0.>>5.\n#define PointSizeValue 2.//KParameter 1.>>4.\n#define colorFactorR 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79553//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n#define symCount 3.//KParameter 0.>>20.\n\n#define PI radians(180.0)\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n\nmat4 rotZ( float _angle ) {\n float s = sin( _angle );\n float c = cos( _angle );\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nvec3 osc3(float t, float i)\n{\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 osc3Comb(float t, float i) {\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\n}\n\nvec3 incr(float t, float i, vec3 ofs, float lerpEnd)\n{\n vec3 pos = osc3Comb(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n \n float rotationCout = floor(symCount);\n \n float localVertexId = mod(vertexId,vertexCount/rotationCout);\n \n float shapeId = floor(vertexId/rotationCout);\n\n float t = time*timeFactor;\n float i = localVertexId;//+sin(localVertexId)*100.;\n\n vec3 pos = osc3Comb(t,i);\n vec3 posDelta = vec3(colorFactorR,0.,0.);\n \n \n for (float f = 0.; f < 10.; f++) \n {\n\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\n }\n \n posDelta += incr(t,i,posDelta,0.2);\n \n pos -= osc3(t,-1.)*posComp0;\n \n pos += posDelta;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n \n mat4 rot = rotZ(shapeId*2.*PI/rotationCout);\n vec4 fpos = vec4((vec4(pos, 1)).xyz, 1);\n fpos *= rot;\n \n gl_Position = vec4(fpos.x, fpos.y*resolution.x/resolution.y, fpos.z*.1, 1);\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\n\n}" + }, "screenshotURL": "data/images/images-wlp3cendqexr8sa4a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cQ2oBbxfbCYZLRFtr/art.json b/art/cQ2oBbxfbCYZLRFtr/art.json index 50be0625..d7f736d9 100644 --- a/art/cQ2oBbxfbCYZLRFtr/art.json +++ b/art/cQ2oBbxfbCYZLRFtr/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":99192,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.50, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 0.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.20), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0.2,\\n 1.9-s, 0.2, 0, 0,\\n s, -0.6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, s, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, s/2.0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0, 0,\\n trans, 0.5);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0.1, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 2, 0.1, 0);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, mouse.x, 0, 0,\\n 0, s-2., 0, -0.1,\\n 0.5, 0, s, -mouse.y,\\n 0, 0, 0, -1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(11.5351, 34.3137));\\n\\treturn fract(p2.x * p2.y / 61.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 3.2 - 2.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.81 - (0.5*v);\\n}\\n\\nfloat inv(float v) {\\n return 2. * (v - mouse.x);\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.9);\\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 3.5 ); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI - tan(sin((11.6, 110.2) / PI * 1.10));\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v -s*2.;\\n float y = s * v-c;\\n float z = 0.05 * v;\\n pos = vec3(x, y, z -s *- u/36.); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) - mouse.y -t) + sin(t * 2.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 1.5)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\\n float end = start - 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x/ 11.8 - 1.3)-7.) * 0.5, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 2.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3((0.9, resolution.y / resolution.x , mouse.y)* 1.91);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 0. + snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, snd*6.));\\n v_color = vec4(2.1 *v_color.rgb * v_color.a, v_color.a /9.0);\\n}\"}", + "settings": { + "num": 99192, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.50, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 0.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.20), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0.2,\n 1.9-s, 0.2, 0, 0,\n s, -0.6, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, s, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, s/2.0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0, 0,\n trans, 0.5);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1,\n 0, -1, 1, -0.9,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0.1, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 2, 0.1, 0);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, mouse.x, 0, 0,\n 0, s-2., 0, -0.1,\n 0.5, 0, s, -mouse.y,\n 0, 0, 0, -1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(11.5351, 34.3137));\n\treturn fract(p2.x * p2.y / 61.4337);\n}\n\nfloat m1p1(float v) {\n return v * 3.2 - 2.;\n}\n\nfloat p1m1(float v) {\n return v * 1.81 - (0.5*v);\n}\n\nfloat inv(float v) {\n return 2. * (v - mouse.x);\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.9);\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 3.5 ); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI - tan(sin((11.6, 110.2) / PI * 1.10));\n float s = sin(a);\n float c = cos(a);\n float x = c * v -s*2.;\n float y = s * v-c;\n float z = 0.05 * v;\n pos = vec3(x, y, z -s *- u/36.); \n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) - mouse.y -t) + sin(t * 2.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 1.5)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\n float end = start - 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x/ 11.8 - 1.3)-7.) * 0.5, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 2.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3((0.9, resolution.y / resolution.x , mouse.y)* 1.91);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 0. + snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, snd*6.));\n v_color = vec4(2.1 *v_color.rgb * v_color.a, v_color.a /9.0);\n}" + }, "screenshotURL": "data/images/images-qqti112vp0s0bzvtz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cRFKCFDgC87Q4M4di/art.json b/art/cRFKCFDgC87Q4M4di/art.json index 49d00837..c6c9bdb0 100644 --- a/art/cRFKCFDgC87Q4M4di/art.json +++ b/art/cRFKCFDgC87Q4M4di/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":2000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Audio Reactive\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(av * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.75, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 2000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Audio Reactive\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(av * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.75, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-4wkru1gstsm4lrchk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cTBcy7LTxJubbEYXF/art.json b/art/cTBcy7LTxJubbEYXF/art.json index 192cb488..66161173 100644 --- a/art/cTBcy7LTxJubbEYXF/art.json +++ b/art/cTBcy7LTxJubbEYXF/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chemlo", "avatarUrl": "https://secure.gravatar.com/avatar/bd1fc3e2f0d77392e06266faedc63267?default=retro&size=200", - "settings": "{\"num\":128,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/sanglorians/heartstrong\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nfloat soundIntensity(float frq){\\n\\treturn texture2D(sound, vec2(frq, 0)).a;\\n}\\n\\nfloat soundIntensityDelta(float frq, float timeOffset){\\n\\tfloat currentIntensity = soundIntensity(frq); \\n \\treturn currentIntensity - texture2D(sound, vec2(frq, timeOffset)).a;\\n}\\n\\nfloat meanIntensity(){\\n \\tconst float samples = 25.;\\n \\tfloat intensity;\\n \\n for(float i = 0.; i < samples; i+=1./samples){\\n\\t\\tintensity += soundIntensity(i);\\n \\t}\\n \\n\\treturn intensity/samples;\\n}\\n\\nfloat meanIntensityDelta(float frq, float range){\\n \\tconst float samples = 25.;\\n \\tfloat intensity = 1.;\\n \\t\\n \\tfor(float i = 0.; i < samples; i+=1./samples){\\n \\tintensity += abs(soundIntensityDelta(frq, i*range));\\n \\t}\\n \\n\\treturn intensity/samples;\\n}\\n\\nvec3 getVertexColor(){\\n\\tfloat ratio = (vertexId/vertexCount);\\n \\tfloat intensity = soundIntensity(ratio);\\n \\n \\treturn vec3(\\n clamp(soundIntensity(ratio)/1.5, 0.0, 0.5),\\n clamp(0.4 + soundIntensity(ratio)*0.5 - meanIntensityDelta(ratio, 0.015)/4., 0.0, 0.4),\\n 0.5\\n );\\n}\\n\\nvoid main(){\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat timeMultiplier = 0.33;\\n \\tfloat perspective = 0.66;\\n \\n\\tfloat vertexRatio = (vertexId+1.)/vertexCount;\\n float vertexRadians = vertexRatio * 2.;\\n \\n vec3 pos = vec3(\\n\\t\\tcos(vertexRadians*PI-time*timeMultiplier),\\n \\t\\tsin(vertexRadians*PI-time*timeMultiplier) * perspective,\\n \\tsoundIntensity((vertexId/vertexCount)) * perspective\\n \\t);\\n \\n gl_Position = vec4(\\n pos.x,\\n pos.y*aspect,\\n 1. - pos.z,\\n 2.0 - pos.z - meanIntensity()\\n );\\n \\n \\tv_color = vec4(getVertexColor(), 0.5);\\n \\n \\tgl_PointSize = pow(soundIntensity((vertexId/vertexCount))+1.5, 5.)*resolution.y*resolution.x*0.0000003;\\n\\n1.;\\n}\"}", + "settings": { + "num": 128, + "mode": "POINTS", + "sound": "https://soundcloud.com/sanglorians/heartstrong", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nfloat soundIntensity(float frq){\n\treturn texture2D(sound, vec2(frq, 0)).a;\n}\n\nfloat soundIntensityDelta(float frq, float timeOffset){\n\tfloat currentIntensity = soundIntensity(frq); \n \treturn currentIntensity - texture2D(sound, vec2(frq, timeOffset)).a;\n}\n\nfloat meanIntensity(){\n \tconst float samples = 25.;\n \tfloat intensity;\n \n for(float i = 0.; i < samples; i+=1./samples){\n\t\tintensity += soundIntensity(i);\n \t}\n \n\treturn intensity/samples;\n}\n\nfloat meanIntensityDelta(float frq, float range){\n \tconst float samples = 25.;\n \tfloat intensity = 1.;\n \t\n \tfor(float i = 0.; i < samples; i+=1./samples){\n \tintensity += abs(soundIntensityDelta(frq, i*range));\n \t}\n \n\treturn intensity/samples;\n}\n\nvec3 getVertexColor(){\n\tfloat ratio = (vertexId/vertexCount);\n \tfloat intensity = soundIntensity(ratio);\n \n \treturn vec3(\n clamp(soundIntensity(ratio)/1.5, 0.0, 0.5),\n clamp(0.4 + soundIntensity(ratio)*0.5 - meanIntensityDelta(ratio, 0.015)/4., 0.0, 0.4),\n 0.5\n );\n}\n\nvoid main(){\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat timeMultiplier = 0.33;\n \tfloat perspective = 0.66;\n \n\tfloat vertexRatio = (vertexId+1.)/vertexCount;\n float vertexRadians = vertexRatio * 2.;\n \n vec3 pos = vec3(\n\t\tcos(vertexRadians*PI-time*timeMultiplier),\n \t\tsin(vertexRadians*PI-time*timeMultiplier) * perspective,\n \tsoundIntensity((vertexId/vertexCount)) * perspective\n \t);\n \n gl_Position = vec4(\n pos.x,\n pos.y*aspect,\n 1. - pos.z,\n 2.0 - pos.z - meanIntensity()\n );\n \n \tv_color = vec4(getVertexColor(), 0.5);\n \n \tgl_PointSize = pow(soundIntensity((vertexId/vertexCount))+1.5, 5.)*resolution.y*resolution.x*0.0000003;\n\n1.;\n}" + }, "screenshotURL": "data/images/images-2c6c0vy0gu1vbtj5x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cTjJFwZcBSSW8d9gw/art.json b/art/cTjJFwZcBSSW8d9gw/art.json index 3f28312b..ec43c877 100644 --- a/art/cTjJFwZcBSSW8d9gw/art.json +++ b/art/cTjJFwZcBSSW8d9gw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":277,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/yoasobimusic/jqiurhdzp3dy?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float r = sin(time);\\n float g = sin(time) + cos(time);\\n float b = cos(time);\\n \\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 277, + "mode": "POINTS", + "sound": "https://soundcloud.com/yoasobimusic/jqiurhdzp3dy?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float r = sin(time);\n float g = sin(time) + cos(time);\n float b = cos(time);\n \n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-3nsin53boylhavckc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cWYEWZbQ3HcWiKgyG/art.json b/art/cWYEWZbQ3HcWiKgyG/art.json index dfffe00e..db7f0c17 100644 --- a/art/cWYEWZbQ3HcWiKgyG/art.json +++ b/art/cWYEWZbQ3HcWiKgyG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":21798,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, (c.x - 3.0) / 2.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 1, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,s, 0,\\n s, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n -1, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, -1, 2, 1,\\n 1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 10, 0,\\n 0, s[1], 2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 1, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 1.5 - 0.75 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 3.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 1.2 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 2.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.1), 1.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v +s;\\n float y = s * (v * x);\\n float z = -0.4;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.2);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * .7;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n float rad = 2.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.2) * rad * 2.1, sin(tm) * rad);\\n vec3 target = vec3(0.1);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n gl_Position = mat * vec4(pos, 2.);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n float st = time *0.5 * PI * 10.;\\n float minRez = min(resolution.x, resolution.y);\\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 1000., sin(st * .2) * .5 + .5);\\n \\n float z = gl_Position.w / gl_Position.z * .5 + .5;\\n float hue = 1.1 + mix(.4, .9, sin(st * .1) * .5 + .5);\\n float sat = 1.;\\n float val = 1. ;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 21798, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, (c.x - 3.0) / 2.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 1, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,s, 0,\n s, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n -1, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, -1, 2, 1,\n 1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 10, 0,\n 0, s[1], 2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 1, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 1.5 - 0.75 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 3.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 1.2 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 2.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.1), 1.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a);\n float x = c * v +s;\n float y = s * (v * x);\n float z = -0.4;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.2);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * .7;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n float rad = 2.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.2) * rad * 2.1, sin(tm) * rad);\n vec3 target = vec3(0.1);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n gl_Position = mat * vec4(pos, 2.);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n float st = time *0.5 * PI * 10.;\n float minRez = min(resolution.x, resolution.y);\n gl_PointSize = mix(minRez / 8000., pow(sz, 1.) * 120. * minRez / 1000., sin(st * .2) * .5 + .5);\n \n float z = gl_Position.w / gl_Position.z * .5 + .5;\n float hue = 1.1 + mix(.4, .9, sin(st * .1) * .5 + .5);\n float sat = 1.;\n float val = 1. ;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-afysjn6y1r2mnygdy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cYSbbDEEERcyLekzE/art.json b/art/cYSbbDEEERcyLekzE/art.json index 0736c7d9..3f031ecd 100644 --- a/art/cYSbbDEEERcyLekzE/art.json +++ b/art/cYSbbDEEERcyLekzE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":50742,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user-698140890/limbus-company-chapter-3?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\\n//Course : CS250\\n//Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n \\treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / 20.0 * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\nvoid main()\\n{\\n \\tfloat numCircleSegments = 5.0;\\n \\tvec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\tfloat numPointsPerCircle = numCircleSegments * 6.0;\\n \\tfloat circleId = floor(vertexId / numPointsPerCircle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCircle);\\n \\t\\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0);\\n \\n\\tfloat down = floor(sqrt(numCircles));\\n \\tfloat across = floor(numCircles / down);\\n \\n \\tfloat x = mod(circleId, across);\\n \\tfloat y = floor(circleId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat xoff = 0.0; //sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2.0 - 1.0 + xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat sc = pow(snd + 0.2, 5.0) * mix(1.0, -0.5, oddSlice);\\n \\n \\tsc *= 20.0 / across;\\n \\n \\tvec4 pos = vec4(circleXY, 0.0, 1.0);\\n \\tmat4 mat = ident();\\n \\tmat *= scale(vec3(1.0, aspect, 1.0));\\n \\tmat *= rotZ(time * 0.3);\\n \\tmat *= rotX(time * 2.0);\\n \\tmat *= rotY(-time * 0.1);\\n \\tmat *= trans(vec3(ux * 0.5, vy * 0.5, 0.0) * 1.3);\\n \\tmat *= rotZ(snd * sign(ux));\\n \\tmat *= uniformScale(0.03 * sc);\\n \\n \\t//vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\\n \\t\\n \\tgl_Position = mat * pos;\\n \\n \\tfloat soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\\n \\n \\tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tfloat pump = step(0.8, snd);\\n \\tfloat hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\\n \\tfloat sat = mix(0.5, 1.0, pump) * 0.3;\\n \\tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);\\n \\n \\thue = hue + pump * oddSlice * 0.5;\\n \\tval += oddSlice * pump * 0.8;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 50742, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user-698140890/limbus-company-chapter-3?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Circles from Triangles\n//Course : CS250\n//Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n \treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = ux / 20.0 * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\nvoid main()\n{\n \tfloat numCircleSegments = 5.0;\n \tvec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \tfloat numPointsPerCircle = numCircleSegments * 6.0;\n \tfloat circleId = floor(vertexId / numPointsPerCircle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCircle);\n \t\n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0);\n \n\tfloat down = floor(sqrt(numCircles));\n \tfloat across = floor(numCircles / down);\n \n \tfloat x = mod(circleId, across);\n \tfloat y = floor(circleId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat xoff = 0.0; //sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2.0 - 1.0 + xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tfloat su = abs(u - 0.5) * 2.0;\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tfloat aspect = resolution.x / resolution.y;\n \tfloat sc = pow(snd + 0.2, 5.0) * mix(1.0, -0.5, oddSlice);\n \n \tsc *= 20.0 / across;\n \n \tvec4 pos = vec4(circleXY, 0.0, 1.0);\n \tmat4 mat = ident();\n \tmat *= scale(vec3(1.0, aspect, 1.0));\n \tmat *= rotZ(time * 0.3);\n \tmat *= rotX(time * 2.0);\n \tmat *= rotY(-time * 0.1);\n \tmat *= trans(vec3(ux * 0.5, vy * 0.5, 0.0) * 1.3);\n \tmat *= rotZ(snd * sign(ux));\n \tmat *= uniformScale(0.03 * sc);\n \n \t//vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3;\n \t\n \tgl_Position = mat * pos;\n \n \tfloat soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\n \n \tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tfloat pump = step(0.8, snd);\n \tfloat hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\n \tfloat sat = mix(0.5, 1.0, pump) * 0.3;\n \tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);\n \n \thue = hue + pump * oddSlice * 0.5;\n \tval += oddSlice * pump * 0.8;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-l8jnsq2iq43go4fa7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cYx2ofpAnLZMY6Xqr/art.json b/art/cYx2ofpAnLZMY6Xqr/art.json index 72542490..350fdb14 100644 --- a/art/cYx2ofpAnLZMY6Xqr/art.json +++ b/art/cYx2ofpAnLZMY6Xqr/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "julio", "avatarUrl": "https://lh4.googleusercontent.com/-_qIuSe0i5BM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3re8EYbgzIrdnuAsoVZKmC72bCiiKQ/mo/photo.jpg", - "settings": "{\"num\":72,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,0.9921568627450981,1],\"shader\":\"void main()\\n{\\n \\tfloat x = floor(vertexId / 2.0);\\n \\tfloat y = mod(vertexId + 1.0, 2.0);\\n \\n \\tfloat angle = x / 20.0 * radians(360.0);\\n \\tfloat radius = 2.0 - y;\\n \\n float ux = radius * cos(angle);\\n float uy = radius * sin(angle);\\n \\n vec2 xy = vec2(ux, uy) * 0.1;\\n \\n\\tgl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(sin(angle), cos(radius), sin(time), 1.0);\\n gl_PointSize = 10.0; \\n}\\n\\n\\n\\n/*void main()\\n{\\n \\tfloat pi = 3.141592;\\n \\tfloat x = vertexId / 20.0 * 2.0 * pi;\\n \\tfloat y = vertexId / 20.0 * 2.0 * pi;\\n \\tfloat r = mod(vertexId, 2.0) + (y * 0.1);\\n \\n \\tfloat ux = r * cos(x) * 0.1;\\n \\tfloat uy = r * sin(y) * 0.1;\\n \\n\\tgl_Position = vec4(ux, uy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0; \\n} */\\n\\n\\n/*void main()\\n{\\n \\tfloat x = floor(vertexId / 2.0) * 0.1;\\n \\tfloat y = (vertexId + 1.0 - floor(vertexId / 2.0)) * 0.1;\\n\\tgl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0; \\n}*/\\n\\n\\n/*void main()\\n{\\n \\tfloat x = floor(vertexId / 2.0) * 0.1;\\n \\tfloat y = mod(vertexId + 1.0, 2.0) * 0.1;\\n\\tgl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0; \\n} */\\n\\n/* void main()\\n {\\n float width = 20.0;\\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n\\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n\\n float xOffset = sin(time + y * 0.1) * 0.5;\\n float yOffset = cos(time + x * 0.4) * 0.3;\\n\\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n\\n vec2 xy = vec2(ux, vy) * 0.5;\\n\\n gl_Position = vec4(ux, vy, sin(time), 1.0);\\n v_color = vec4(sin(time / vertexId), sin(time), cos(vertexId), 1.0);\\n gl_PointSize = 40.0;\\n }*/\"}", + "settings": { + "num": 72, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 0.9921568627450981, + 1 + ], + "shader": "void main()\n{\n \tfloat x = floor(vertexId / 2.0);\n \tfloat y = mod(vertexId + 1.0, 2.0);\n \n \tfloat angle = x / 20.0 * radians(360.0);\n \tfloat radius = 2.0 - y;\n \n float ux = radius * cos(angle);\n float uy = radius * sin(angle);\n \n vec2 xy = vec2(ux, uy) * 0.1;\n \n\tgl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(sin(angle), cos(radius), sin(time), 1.0);\n gl_PointSize = 10.0; \n}\n\n\n\n/*void main()\n{\n \tfloat pi = 3.141592;\n \tfloat x = vertexId / 20.0 * 2.0 * pi;\n \tfloat y = vertexId / 20.0 * 2.0 * pi;\n \tfloat r = mod(vertexId, 2.0) + (y * 0.1);\n \n \tfloat ux = r * cos(x) * 0.1;\n \tfloat uy = r * sin(y) * 0.1;\n \n\tgl_Position = vec4(ux, uy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0; \n} */\n\n\n/*void main()\n{\n \tfloat x = floor(vertexId / 2.0) * 0.1;\n \tfloat y = (vertexId + 1.0 - floor(vertexId / 2.0)) * 0.1;\n\tgl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0; \n}*/\n\n\n/*void main()\n{\n \tfloat x = floor(vertexId / 2.0) * 0.1;\n \tfloat y = mod(vertexId + 1.0, 2.0) * 0.1;\n\tgl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0; \n} */\n\n/* void main()\n {\n float width = 20.0;\n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n\n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n\n float xOffset = sin(time + y * 0.1) * 0.5;\n float yOffset = cos(time + x * 0.4) * 0.3;\n\n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n\n vec2 xy = vec2(ux, vy) * 0.5;\n\n gl_Position = vec4(ux, vy, sin(time), 1.0);\n v_color = vec4(sin(time / vertexId), sin(time), cos(vertexId), 1.0);\n gl_PointSize = 40.0;\n }*/" + }, "screenshotURL": "data/images/images-e02qh3tkicqy8pyia-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cZLahmf6sZpctWKsR/art.json b/art/cZLahmf6sZpctWKsR/art.json index 1c47d5f8..9cb293cd 100644 --- a/art/cZLahmf6sZpctWKsR/art.json +++ b/art/cZLahmf6sZpctWKsR/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "eugene", "avatarUrl": "https://lh4.googleusercontent.com/-1W0Zx2V2YBo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuck7HOEHYTKOuOYfO3JNASLLHC1T0A/s96-c/photo.jpg", - "settings": "{\"num\":4031,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.06666666666666667,0.25882352941176473,1],\"shader\":\"void main() {\\n\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 4031, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.06666666666666667, + 0.25882352941176473, + 1 + ], + "shader": "void main() {\n\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-k79umvkc3s6yw6xvi-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cZZ3eyhcr5QzLGrqT/art.json b/art/cZZ3eyhcr5QzLGrqT/art.json index d44c61ee..a4405307 100644 --- a/art/cZZ3eyhcr5QzLGrqT/art.json +++ b/art/cZZ3eyhcr5QzLGrqT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":99999,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE .5\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n fract(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n tan(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*fract(0.1492)*fract(0.999992);\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5));\\n return (- posf + posf/l)*(0.002-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float t = time*.010;\\n float i = fract(20000000000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*sqrt(.0094/fract(900.57)*atan(60.60))));\\n }\\n ofs += push(t,i,ofs,.999);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.0,-.6,.8);\\n pos.xz *= mat2(.8,1,-.5,.1);\\n pos *=1.*atan(-.99996);\\n pos.z += 0.5;\\n pos.xy *= 0.6/pos.z;\\n \\n gl_Position = vec4(pos.x-0.2, pos.y*resolution.x/resolution.y, pos.z*.000006, 1);\\n gl_PointSize = 3.0/pos.z* 0.09;\\n\\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\\n}\"}", + "settings": { + "num": 99999, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE .5\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n fract(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n tan(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*fract(0.1492)*fract(0.999992);\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5));\n return (- posf + posf/l)*(0.002-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float t = time*.010;\n float i = fract(20000000000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*sqrt(.0094/fract(900.57)*atan(60.60))));\n }\n ofs += push(t,i,ofs,.999);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.0,-.6,.8);\n pos.xz *= mat2(.8,1,-.5,.1);\n pos *=1.*atan(-.99996);\n pos.z += 0.5;\n pos.xy *= 0.6/pos.z;\n \n gl_Position = vec4(pos.x-0.2, pos.y*resolution.x/resolution.y, pos.z*.000006, 1);\n gl_PointSize = 3.0/pos.z* 0.09;\n\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\n}" + }, "screenshotURL": "data/images/images-eyo5kcj1k5c27dhmv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cZoyrQ8kQECXDtSTn/art.json b/art/cZoyrQ8kQECXDtSTn/art.json index dcf459d3..31a60fd5 100644 --- a/art/cZoyrQ8kQECXDtSTn/art.json +++ b/art/cZoyrQ8kQECXDtSTn/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/randi-mealer/sunday-morning-bossa-nova\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.9176470588235294,1,1],\"shader\":\"/*\\n\\n\\n \\n /) /) \\n_ _ _ __ _/_ _ __/ _ (/ _ _(/ _ __ _ __ _/_ \\n(/___(/_/ (_(___(/_ /(__/_)_/ )_(_(_(_(__(/_/ (_(_(_/ (_(__ \\n / \\n \\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.2, 0.8, p1m1(sin(goop(sideId) + time)));\\n float start = fract(hash(sideId * 0.33) + 0. * fract(time + sideId) * 1.1);\\n float end = start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n \\n vec3 offset = vec3(hash(sideId) * 0.8, m1p1(hash(sideId * 0.37)), 0);\\n offset.x += goop(sideId + time) * 0.1;\\n offset.y += goop(sideId + time * 1.13) * 0.1;\\n offset.z = m1p1(cu);\\n vec3 aspect = vec3(side, resolution.x / resolution.y, 1.);\\n \\n #define AVERAGE 5\\n float snd = 0.;\\n for (int i = 0; i < AVERAGE; ++i) {\\n snd += texture2D(sound, vec2(0.02 + cu * 0.2, (pointId + float(i)) / NUM_POINTS_PER_CIRCLE * 0.5)).a * float(AVERAGE - i);\\n }\\n snd /= float(AVERAGE * (AVERAGE + 1)) * 0.5;\\n\\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.0, 0.1, hash(sideId)) * 0.0 + pow(snd, 1.0) * 0.3);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.5, 0.55, fract(sideId * 0.79));\\n float sat = mix(0.3 + snd, 0., step(0.9, snd));\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/randi-mealer/sunday-morning-bossa-nova", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.9176470588235294, + 1, + 1 + ], + "shader": "/*\n\n\n \n /) /) \n_ _ _ __ _/_ _ __/ _ (/ _ _(/ _ __ _ __ _/_ \n(/___(/_/ (_(___(/_ /(__/_)_/ )_(_(_(_(__(/_/ (_(_(_/ (_(__ \n / \n \n\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.2, 0.8, p1m1(sin(goop(sideId) + time)));\n float start = fract(hash(sideId * 0.33) + 0. * fract(time + sideId) * 1.1);\n float end = start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n \n vec3 offset = vec3(hash(sideId) * 0.8, m1p1(hash(sideId * 0.37)), 0);\n offset.x += goop(sideId + time) * 0.1;\n offset.y += goop(sideId + time * 1.13) * 0.1;\n offset.z = m1p1(cu);\n vec3 aspect = vec3(side, resolution.x / resolution.y, 1.);\n \n #define AVERAGE 5\n float snd = 0.;\n for (int i = 0; i < AVERAGE; ++i) {\n snd += texture2D(sound, vec2(0.02 + cu * 0.2, (pointId + float(i)) / NUM_POINTS_PER_CIRCLE * 0.5)).a * float(AVERAGE - i);\n }\n snd /= float(AVERAGE * (AVERAGE + 1)) * 0.5;\n\n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.0, 0.1, hash(sideId)) * 0.0 + pow(snd, 1.0) * 0.3);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.5, 0.55, fract(sideId * 0.79));\n float sat = mix(0.3 + snd, 0., step(0.9, snd));\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-dgdib8thfbbw1lzrd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ccQWyo6KBLufEhq89/art.json b/art/ccQWyo6KBLufEhq89/art.json index 6ee8b6ac..5294dbb9 100644 --- a/art/ccQWyo6KBLufEhq89/art.json +++ b/art/ccQWyo6KBLufEhq89/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7962,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/didrec/ken-ishii-malfunction-10\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .17);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s +.1, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\\n float sat =1.0;step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb *= v_color.a;\\n \\n float super = .0;step(0.9, s);\\n v_color = mix(v_color, vec4(1,0,0,1), super);\\n \\n}\\n\"}", + "settings": { + "num": 7962, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/didrec/ken-ishii-malfunction-10", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .17);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s +.1, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\n float sat =1.0;step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb *= v_color.a;\n \n float super = .0;step(0.9, s);\n v_color = mix(v_color, vec4(1,0,0,1), super);\n \n}\n" + }, "screenshotURL": "data/images/images-tvgoxbp3ecqk83ml4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cdqm4FpNvFdtD7We7/art.json b/art/cdqm4FpNvFdtD7We7/art.json index ad75e4cf..97786a16 100644 --- a/art/cdqm4FpNvFdtD7We7/art.json +++ b/art/cdqm4FpNvFdtD7We7/art.json @@ -27,7 +27,19 @@ "name": "residual", "private": true, "username": "spotline", - "settings": "{\"num\":5009,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.0594630943592952645618252949463\\n//#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n float u = (float(vertexId)/NUM_POINTS) * 2.0 - 1.0;\\n float v = 0.0;\\n float ucoor = log((abs(u)*0.3 + 1.0));\\n v+= floor(texture2D(sound,vec2(ucoor,0.0)).a * 15.0)/15.0;\\n float x = u * 2.0;\\n float y = v -0.5;\\n gl_PointSize = v*15.0 + 1.0;\\n gl_Position = vec4(x,y,0,1);\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 5009, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.0594630943592952645618252949463\n//#define FIT_VERTICAL\n\n\nvoid main() \n{\n float u = (float(vertexId)/NUM_POINTS) * 2.0 - 1.0;\n float v = 0.0;\n float ucoor = log((abs(u)*0.3 + 1.0));\n v+= floor(texture2D(sound,vec2(ucoor,0.0)).a * 15.0)/15.0;\n float x = u * 2.0;\n float y = v -0.5;\n gl_PointSize = v*15.0 + 1.0;\n gl_Position = vec4(x,y,0,1);\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-r9h6ca862r0izzgc3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cds3yEbDHT2sbnKxa/art.json b/art/cds3yEbDHT2sbnKxa/art.json index 73038251..e409d753 100644 --- a/art/cds3yEbDHT2sbnKxa/art.json +++ b/art/cds3yEbDHT2sbnKxa/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":19450,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ihsanozturk/kruder-dorfmeister-liquid-acid\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + .3, 3.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 1000.0;\\n \\n float pump = step(0.1, snd);\\n float hue = u * 0. + snd + sin(0.); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.3, .8, pump);\\n float val = mix(0.6, pow(snd + 0.2, 10.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, 0.0, val)), 1.0);\\n}\"}", + "settings": { + "num": 19450, + "mode": "POINTS", + "sound": "https://soundcloud.com/ihsanozturk/kruder-dorfmeister-liquid-acid", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + .3, 3.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 1000.0;\n \n float pump = step(0.1, snd);\n float hue = u * 0. + snd + sin(0.); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.3, .8, pump);\n float val = mix(0.6, pow(snd + 0.2, 10.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, 0.0, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ycxpztn0rh8lt5glb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cgHCLAi7mKznjvENd/art.json b/art/cgHCLAi7mKznjvENd/art.json index d2c9704a..78dd144a 100644 --- a/art/cgHCLAi7mKznjvENd/art.json +++ b/art/cgHCLAi7mKznjvENd/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "8bitrick", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/queroxmusic/querox-phaxe-tripical-moon\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI 3.14159\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) { return v * 2. - 1.; }\\n\\nvoid main()\\n{\\n float ROWS = 5.;\\n float cur_time = mod(time, 4.);\\n float verts_per_row = vertexCount / ROWS;\\n float vert_per = vertexId / (vertexCount - 1.);\\n float row = floor(vertexId / verts_per_row);\\n float row_per = row / (ROWS-1.);\\n float freq = vert_per * 0.8 + 0.1;\\n vec2 center = vec2(m1p1(hash(row_per)), m1p1(hash(hash(row_per))))* 0.5;\\n \\n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\\n float x = vertex_per;\\n //float y = texture2D(sound,vec2(vertex_per*0.90+0.1,0.)).a;// + (row_per) - 1. + hash(row_per);\\n float amp = texture2D(sound,vec2(freq, cur_time)).a;// + (row_per) - 1. + hash(row_per);\\n \\n float angle = x * 2. * PI;\\n vec2 vel = vec2(m1p1(hash(vert_per))*0.25 * amp, amp);\\n vec2 xy = (center + vel * cur_time) ;\\n \\n gl_PointSize = 10.0;\\n gl_Position = vec4(xy,0,1);\\n v_color = vec4(1.0);\\n// v_color = mix(vec4(hsv2rgb(vec3(y*0.21, 1.-y, 1.)), 1.-row_per), background, row_per - 0.2);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/queroxmusic/querox-phaxe-tripical-moon", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI 3.14159\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) { return v * 2. - 1.; }\n\nvoid main()\n{\n float ROWS = 5.;\n float cur_time = mod(time, 4.);\n float verts_per_row = vertexCount / ROWS;\n float vert_per = vertexId / (vertexCount - 1.);\n float row = floor(vertexId / verts_per_row);\n float row_per = row / (ROWS-1.);\n float freq = vert_per * 0.8 + 0.1;\n vec2 center = vec2(m1p1(hash(row_per)), m1p1(hash(hash(row_per))))* 0.5;\n \n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\n float x = vertex_per;\n //float y = texture2D(sound,vec2(vertex_per*0.90+0.1,0.)).a;// + (row_per) - 1. + hash(row_per);\n float amp = texture2D(sound,vec2(freq, cur_time)).a;// + (row_per) - 1. + hash(row_per);\n \n float angle = x * 2. * PI;\n vec2 vel = vec2(m1p1(hash(vert_per))*0.25 * amp, amp);\n vec2 xy = (center + vel * cur_time) ;\n \n gl_PointSize = 10.0;\n gl_Position = vec4(xy,0,1);\n v_color = vec4(1.0);\n// v_color = mix(vec4(hsv2rgb(vec3(y*0.21, 1.-y, 1.)), 1.-row_per), background, row_per - 0.2);\n}\n" + }, "screenshotURL": "data/images/images-j97pqeyxnn1cmlf5u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cgibgS9oD8o5yDmqZ/art.json b/art/cgibgS9oD8o5yDmqZ/art.json index 102bacd8..fcbb56a4 100644 --- a/art/cgibgS9oD8o5yDmqZ/art.json +++ b/art/cgibgS9oD8o5yDmqZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Based on patriciogv\\n// http://patriciogonzalezvivo.com\\n\\n//#ifdef GL_ES\\n//precision mediump float;\\n//#endif \\n\\n#define PI 3.14159265359\\n#define TWO_PI 6.28318530718\\n\\n//uniform float time;\\n//uniform vec2 vertexResolution;\\n\\n// Based on Asalga shader\\n// https://www.shadertoy.com/view/4ss3WX\\nvoid main () {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n float u_time = time*0.25;\\n float koeff = vertexResolution.y/vertexResolution.x;\\n\\n vec2 st = ( simFragCoord.xy / vertexResolution.xy)-0.5;\\n st.y *= koeff;\\n\\n // cartesian to polar coordinates\\n float r = length(st);\\n float a = atan(st.y, st.x);\\n\\n // Repeat side acoriding to angle\\n float sides = 8.;\\n float ma = mod(a, TWO_PI/sides);\\n ma = abs(ma - PI/sides);\\n\\n // polar to cartesian coordinates\\n st = r * vec2(cos(ma), sin(ma));\\n\\n //st -= cos(r-ma*koeff);\\n st -= cos(r*koeff-ma*PI);\\n //st -= cos(r*PI-ma*koeff);\\n //st -= cos(r+ma*koeff);\\n //st += cos(r-ma*koeff);\\n //st += cos(r+ma-koeff);\\n //st += sin(r-ma*koeff);\\n //st += sin(r+ma*PI-koeff);\\n\\n st = fract(st+u_time);\\n st.x = smoothstep(0.0,1.0, st.x);\\n st.y = smoothstep(1.0,0.0, st.y);\\n vec4 color = vec4(st.x,st.y, sin(u_time/(r+ma)), 1.0);\\n v_color = color.rgba;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Based on patriciogv\n// http://patriciogonzalezvivo.com\n\n//#ifdef GL_ES\n//precision mediump float;\n//#endif \n\n#define PI 3.14159265359\n#define TWO_PI 6.28318530718\n\n//uniform float time;\n//uniform vec2 vertexResolution;\n\n// Based on Asalga shader\n// https://www.shadertoy.com/view/4ss3WX\nvoid main () {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n float u_time = time*0.25;\n float koeff = vertexResolution.y/vertexResolution.x;\n\n vec2 st = ( simFragCoord.xy / vertexResolution.xy)-0.5;\n st.y *= koeff;\n\n // cartesian to polar coordinates\n float r = length(st);\n float a = atan(st.y, st.x);\n\n // Repeat side acoriding to angle\n float sides = 8.;\n float ma = mod(a, TWO_PI/sides);\n ma = abs(ma - PI/sides);\n\n // polar to cartesian coordinates\n st = r * vec2(cos(ma), sin(ma));\n\n //st -= cos(r-ma*koeff);\n st -= cos(r*koeff-ma*PI);\n //st -= cos(r*PI-ma*koeff);\n //st -= cos(r+ma*koeff);\n //st += cos(r-ma*koeff);\n //st += cos(r+ma-koeff);\n //st += sin(r-ma*koeff);\n //st += sin(r+ma*PI-koeff);\n\n st = fract(st+u_time);\n st.x = smoothstep(0.0,1.0, st.x);\n st.y = smoothstep(1.0,0.0, st.y);\n vec4 color = vec4(st.x,st.y, sin(u_time/(r+ma)), 1.0);\n v_color = color.rgba;\n}" + }, "screenshotURL": "data/images/images-hn4mudj125ok7xy8k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/chpxsLEkqhZkhLxDD/art.json b/art/chpxsLEkqhZkhLxDD/art.json index da425273..1f5b8f14 100644 --- a/art/chpxsLEkqhZkhLxDD/art.json +++ b/art/chpxsLEkqhZkhLxDD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":36,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][3], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 0\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 1\\n#define ASPECT (resolution.y/resolution.x)\\nvoid main() {\\n mat4 mat = rotY(time);\\n vec3 point = vec3(0.0);\\n vec3 normal = vec3(0.0);\\n getCubePoint(vertexId, point, normal);\\n mat4 camera = mat4(\\n 0.5*ASPECT, 0.0, 0.0, 0.0,\\n 0.0, 0.5, 0.0, 0.0,\\n 0.0, 0.0, 1.0, 0.2,\\n 0.0, 0.0, 0.5, 1.0\\n )*rotX(-0.4);\\n gl_Position = camera * mat * vec4(point, 1);\\n //gl_Position /= gl_Position.w;\\n vec3 correctedNormal = (mat*vec4(normal, 1.0)).xyz;\\n float brightness = dot(correctedNormal, normalize(vec3(0,1,-1)));\\n v_color = vec4(1.0*brightness, 0.0, 0.0, 1.0);\\n}\\n\\n#endif\"}", + "settings": { + "num": 36, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][3], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 0\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 1\n#define ASPECT (resolution.y/resolution.x)\nvoid main() {\n mat4 mat = rotY(time);\n vec3 point = vec3(0.0);\n vec3 normal = vec3(0.0);\n getCubePoint(vertexId, point, normal);\n mat4 camera = mat4(\n 0.5*ASPECT, 0.0, 0.0, 0.0,\n 0.0, 0.5, 0.0, 0.0,\n 0.0, 0.0, 1.0, 0.2,\n 0.0, 0.0, 0.5, 1.0\n )*rotX(-0.4);\n gl_Position = camera * mat * vec4(point, 1);\n //gl_Position /= gl_Position.w;\n vec3 correctedNormal = (mat*vec4(normal, 1.0)).xyz;\n float brightness = dot(correctedNormal, normalize(vec3(0,1,-1)));\n v_color = vec4(1.0*brightness, 0.0, 0.0, 1.0);\n}\n\n#endif" + }, "screenshotURL": "data/images/images-907ihbkmpi5rmhxa3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cifFKxGSudzB8CEt6/art.json b/art/cifFKxGSudzB8CEt6/art.json index 8b403740..50e3d5ad 100644 --- a/art/cifFKxGSudzB8CEt6/art.json +++ b/art/cifFKxGSudzB8CEt6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLE_STRIP\\n#define parameter0 30.//KParameter0 10.>>70.\\n#define parameter1 10.//KParameter1 0.>>100.\\n#define parameter2 10.//KParameter2 0.>>100.\\n#define parameter3 0.//KParameter3 0.>>100.\\n#define parameter4 2.//KParameter4 2.>>30.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 ROTZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n // front\\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n // back\\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n // top\\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n // bottom\\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n // right\\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n // left\\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.0, pow(dot(_n, h), _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\nvec3 formation(vec2 _touchPos, vec3 _a, float _t) {\\n \\n return vec3( _touchPos.x, _touchPos.y, _a.z-1.5);\\n}\\n\\nvoid main() {\\n \\n float symCount = parameter4;\\n \\n float fVertexId = mod(vertexId,vertexCount/symCount);\\n \\n float vertexCountToUse = vertexCount;\\n float vertexIdToUse = mod(fVertexId, vertexCountToUse);\\n \\n float shapeCount = floor(vertexCountToUse / kShapeVertexCount);\\n float shapeId = floor(fVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(fVertexId, kShapeVertexCount);\\n \\n vec3 color;\\n \\n float t = shapeId / (shapeCount);\\n \\n float aspect = resolution.x / resolution.y;\\n \\n vec4 cbNi;\\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * parameter0/100.;\\n \\n vec3 cubeRot = vec3(parameter1,parameter2,parameter3) * time/10.;\\n \\n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.x);\\n \\n cubep.x += 0.3;\\n /*\\n if(vertexId>vertexCount/2.)\\n {\\n cubep.x = -cubep.x;\\n }\\n */\\n /*\\n float shapeId = floor(vertexId/ (vertexCount/symCount));\\n mat4 rot = ROTZ(shapeId*2.*PI/rotationCout);\\n vec4 fpos = vec4((vec4(pos, 1)).xyz, 1);\\n */\\n cbNi.xyz = rotX(rotY(rotZ(cbNi.xyz, cubeRot.z), cubeRot.y), cubeRot.x);\\n \\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, cubep, cbNi.xyz, vec3(1.,1.,1.), 0.1, vec2(64.0, 0.8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLE_STRIP\n#define parameter0 30.//KParameter0 10.>>70.\n#define parameter1 10.//KParameter1 0.>>100.\n#define parameter2 10.//KParameter2 0.>>100.\n#define parameter3 0.//KParameter3 0.>>100.\n#define parameter4 2.//KParameter4 2.>>30.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 ROTZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n // front\n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n // back\n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n // top\n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n // bottom\n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n // right\n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n // left\n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.0, pow(dot(_n, h), _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\nvec3 formation(vec2 _touchPos, vec3 _a, float _t) {\n \n return vec3( _touchPos.x, _touchPos.y, _a.z-1.5);\n}\n\nvoid main() {\n \n float symCount = parameter4;\n \n float fVertexId = mod(vertexId,vertexCount/symCount);\n \n float vertexCountToUse = vertexCount;\n float vertexIdToUse = mod(fVertexId, vertexCountToUse);\n \n float shapeCount = floor(vertexCountToUse / kShapeVertexCount);\n float shapeId = floor(fVertexId / kShapeVertexCount);\n float shapeVertexId = mod(fVertexId, kShapeVertexCount);\n \n vec3 color;\n \n float t = shapeId / (shapeCount);\n \n float aspect = resolution.x / resolution.y;\n \n vec4 cbNi;\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * parameter0/100.;\n \n vec3 cubeRot = vec3(parameter1,parameter2,parameter3) * time/10.;\n \n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.x);\n \n cubep.x += 0.3;\n /*\n if(vertexId>vertexCount/2.)\n {\n cubep.x = -cubep.x;\n }\n */\n /*\n float shapeId = floor(vertexId/ (vertexCount/symCount));\n mat4 rot = ROTZ(shapeId*2.*PI/rotationCout);\n vec4 fpos = vec4((vec4(pos, 1)).xyz, 1);\n */\n cbNi.xyz = rotX(rotY(rotZ(cbNi.xyz, cubeRot.z), cubeRot.y), cubeRot.x);\n \n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, cubep, cbNi.xyz, vec3(1.,1.,1.), 0.1, vec2(64.0, 0.8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-h1l72659gnan00eyg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cj62wdtr684imMKtg/art.json b/art/cj62wdtr684imMKtg/art.json index 0c325448..2dee4c04 100644 --- a/art/cj62wdtr684imMKtg/art.json +++ b/art/cj62wdtr684imMKtg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6170,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n cos(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.5;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 6170, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n cos(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.5;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-8rxmfu15tfld7cprc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cjTYyd8z2yEWqYFeg/art.json b/art/cjTYyd8z2yEWqYFeg/art.json index 48249651..871f7081 100644 --- a/art/cjTYyd8z2yEWqYFeg/art.json +++ b/art/cjTYyd8z2yEWqYFeg/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/allaboutthebeat/distant-friends-gen-neo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n \\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n \\n float x = (u*200.0)-10.0;\\n float y = 0.0;\\n gl_PointSize = 100.0;\\n gl_Position = vec4(x,y,0,1);\\n \\n float lum = floor(v *10.0 + 1.9)/10.0;\\n //float lum = 1.0;\\n v_color = vec4(v*lum*0.4,lum*0.2,lum*1.0,1);\\n\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/allaboutthebeat/distant-friends-gen-neo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n \n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n \n float x = (u*200.0)-10.0;\n float y = 0.0;\n gl_PointSize = 100.0;\n gl_Position = vec4(x,y,0,1);\n \n float lum = floor(v *10.0 + 1.9)/10.0;\n //float lum = 1.0;\n v_color = vec4(v*lum*0.4,lum*0.2,lum*1.0,1);\n\n}" + }, "screenshotURL": "data/images/images-os8wh9rdkcz2f37ol-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cjw2sg8cHvsk78JBF/art.json b/art/cjw2sg8cHvsk78JBF/art.json index 0d10a07e..7c091dea 100644 --- a/art/cjw2sg8cHvsk78JBF/art.json +++ b/art/cjw2sg8cHvsk78JBF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Colors\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.3 + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Colors\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.3 + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ixqutkhr581jaqbmq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ckAitsgFTQ4DbFHAC/art.json b/art/ckAitsgFTQ4DbFHAC/art.json index f6de3e43..f1f742e0 100644 --- a/art/ckAitsgFTQ4DbFHAC/art.json +++ b/art/ckAitsgFTQ4DbFHAC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":85150,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 9\\\\\\\\ 11\\\\\\\\ 13,(14) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(7)8 \\\\\\\\10 12\\n 1\\\\\\\\ 3\\\\\\\\ 5(6) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\nvoid main(){\\n gl_PointSize=2.0;\\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\n v_color =vec4(1.0);\\n}\"}", + "settings": { + "num": 85150, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 9\\\\ 11\\\\ 13,(14) <---degen\n | \\\\ | \\\\|\ndegen-->(7)8 \\\\10 12\n 1\\\\ 3\\\\ 5(6) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \nvoid main(){\n gl_PointSize=2.0;\n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\n v_color =vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-e6v19213q992xt2gf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cm7ZiKYPzjYBqPSyQ/art.json b/art/cm7ZiKYPzjYBqPSyQ/art.json index 19acf7e6..f9dd8460 100644 --- a/art/cm7ZiKYPzjYBqPSyQ/art.json +++ b/art/cm7ZiKYPzjYBqPSyQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":19097,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n#define KP0 mouse.y\\n#define KP1 mouse.x\\n#define zoom 1.0-(mouse.x+mouse.y)\\n#define KP2 0.4\\t\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \\ntriangles[ 2]=vec4( mouse.x*91.0, 2112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( mouse.y*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 11., 42.0, 1326.0, 4.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 19097, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n#define KP0 mouse.y\n#define KP1 mouse.x\n#define zoom 1.0-(mouse.x+mouse.y)\n#define KP2 0.4\t\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \ntriangles[ 2]=vec4( mouse.x*91.0, 2112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \ntriangles[ 4]=vec4( mouse.y*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 11., 42.0, 1326.0, 4.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-iklkbopsxvoxx2z8o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cmajQzzGy7RWLuWqC/art.json b/art/cmajQzzGy7RWLuWqC/art.json index 12c41cb9..10cf0908 100644 --- a/art/cmajQzzGy7RWLuWqC/art.json +++ b/art/cmajQzzGy7RWLuWqC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "bleedinqtiqer", "avatarUrl": "https://lh6.googleusercontent.com/-A8vXonWuy1Q/AAAAAAAAAAI/AAAAAAAAAAc/YnjEb9fs2_g/photo.jpg", - "settings": "{\"num\":40000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/umbleby/sets/ummmm\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9803921568627451,0.9411764705882353,0.9803921568627451,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), .9);\\n}\"}", + "settings": { + "num": 40000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/umbleby/sets/ummmm", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9803921568627451, + 0.9411764705882353, + 0.9803921568627451, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), .9);\n}" + }, "screenshotURL": "data/images/images-enxppwqc3mgd3moqa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cnpLD2E8bCJ8MjaXX/art.json b/art/cnpLD2E8bCJ8MjaXX/art.json index a10465dc..9e6b21fc 100644 --- a/art/cnpLD2E8bCJ8MjaXX/art.json +++ b/art/cnpLD2E8bCJ8MjaXX/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.7)/20.0;\\n //float lum = floor(v *30.0 + 0.9)/5.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\\n /*vec2 soundTexCoords = vec2(0, 0);\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n*/\\n v_color = vec4(v*lum*1.0,v*lum*1.0,v*lum*1.0,1);\\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\\n\\n\\n \\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,10.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.7)/20.0;\n //float lum = floor(v *30.0 + 0.9)/5.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\n /*vec2 soundTexCoords = vec2(0, 0);\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n*/\n v_color = vec4(v*lum*1.0,v*lum*1.0,v*lum*1.0,1);\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\n\n\n \n}" + }, "screenshotURL": "data/images/images-s8a03p2l2llzgdosf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/coje67XoytKsXMYqF/art.json b/art/coje67XoytKsXMYqF/art.json index d7f8e720..447e79b1 100644 --- a/art/coje67XoytKsXMYqF/art.json +++ b/art/coje67XoytKsXMYqF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3333,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00392156862745098,0.11372549019607843,0.3411764705882353,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 1.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.93\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\\nfloat snd = texture2D(sound,vec2(0.,1.)).a;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * .6- mouse.y) + 11.0;\\n float angle = point * PI * 3.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.0014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.0000025, .9);\\n float innerRadius = pow(count * 0.0003, .2);\\n float oC = cos(orbitAngle + count * 0.005) * innerRadius*mouse.y*sin(time);\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius-mouse.x+sin(time);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC -1.+ c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\\n\\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 1.3 + 0.17, 1.8);\\n b = 0.20;mix(-.3, mouse.x/0.9, b)/-T;\\n v_color = vec4(c,- snd/c, cos(T*snd-snd*b)+b/c-b, .489);\\n}\\n\"}", + "settings": { + "num": 3333, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00392156862745098, + 0.11372549019607843, + 0.3411764705882353, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 1.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.93\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\nfloat snd = texture2D(sound,vec2(0.,1.)).a;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * .6- mouse.y) + 11.0;\n float angle = point * PI * 3.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.0014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.0000025, .9);\n float innerRadius = pow(count * 0.0003, .2);\n float oC = cos(orbitAngle + count * 0.005) * innerRadius*mouse.y*sin(time);\n float oS = sin(orbitAngle + count * 0.01) * innerRadius-mouse.x+sin(time);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC -1.+ c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\n\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 1.3 + 0.17, 1.8);\n b = 0.20;mix(-.3, mouse.x/0.9, b)/-T;\n v_color = vec4(c,- snd/c, cos(T*snd-snd*b)+b/c-b, .489);\n}\n" + }, "screenshotURL": "data/images/images-4gp5a7fswz9v16fiz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cpo4C8yfRudYYakav/art.json b/art/cpo4C8yfRudYYakav/art.json index cb1508a8..9db4131d 100644 --- a/art/cpo4C8yfRudYYakav/art.json +++ b/art/cpo4C8yfRudYYakav/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "erick2", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocJJUVfbufTAj0kqeFOfAGZpqUwrny828uOVrPxBNx2R1e5Tmn0=s96-c", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 2);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 2);\n}" + }, "screenshotURL": "data/images/images-83g4qewooqvx46lz7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cprWonx4tN8nMgQHt/art.json b/art/cprWonx4tN8nMgQHt/art.json index a97f5dde..95b8fbd8 100644 --- a/art/cprWonx4tN8nMgQHt/art.json +++ b/art/cprWonx4tN8nMgQHt/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "anuar", "avatarUrl": "https://graph.facebook.com/1812741555404077/picture?type=large", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\nfloat width = floor(sqrt(vertexCount));\\nfloat x = mod(vertexId,width);\\nfloat y = floor(vertexId/width);\\n\\nfloat u = x/(width - 1.0);\\nfloat v = y/(width - 1.0);\\n\\nfloat xOffset = cos(time + y * .2) *.1;\\nfloat yOffset = cos(time + x * .2) *.1;\\n\\nfloat ux = u*2.0 - 1.0 + xOffset;\\nfloat vy = v*2.0 - 1.0 + yOffset;\\n\\n//vertex id 0 1 2 3 4 ... 10 11 12 ... 20 21 22\\n//mod X 0 1 2 3 4 ... 0 1 2 ... 0 1 2\\n//floor Y 0 0 0 0 0 ... 1 1 1 ... 2 2 2\\n\\nvec2 xy = vec2(ux,vy)*1.2;\\n\\nfloat sizeOffSet = sin(time + x * y * .2)*5.;\\n\\ngl_Position = vec4(xy, 0.0, 1.0);\\ngl_PointSize = 15.0 + sizeOffSet;\\ngl_PointSize*= 32.0 / width;\\nv_color = vec4(47.0, 211.0, 0.0, 1.0);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\nfloat width = floor(sqrt(vertexCount));\nfloat x = mod(vertexId,width);\nfloat y = floor(vertexId/width);\n\nfloat u = x/(width - 1.0);\nfloat v = y/(width - 1.0);\n\nfloat xOffset = cos(time + y * .2) *.1;\nfloat yOffset = cos(time + x * .2) *.1;\n\nfloat ux = u*2.0 - 1.0 + xOffset;\nfloat vy = v*2.0 - 1.0 + yOffset;\n\n//vertex id 0 1 2 3 4 ... 10 11 12 ... 20 21 22\n//mod X 0 1 2 3 4 ... 0 1 2 ... 0 1 2\n//floor Y 0 0 0 0 0 ... 1 1 1 ... 2 2 2\n\nvec2 xy = vec2(ux,vy)*1.2;\n\nfloat sizeOffSet = sin(time + x * y * .2)*5.;\n\ngl_Position = vec4(xy, 0.0, 1.0);\ngl_PointSize = 15.0 + sizeOffSet;\ngl_PointSize*= 32.0 / width;\nv_color = vec4(47.0, 211.0, 0.0, 1.0);\n\n}" + }, "screenshotURL": "data/images/images-6xf6be9n2fduyi78u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cqLtuWkpoZFuj7Aq2/art.json b/art/cqLtuWkpoZFuj7Aq2/art.json index 4e1b5402..791b9400 100644 --- a/art/cqLtuWkpoZFuj7Aq2/art.json +++ b/art/cqLtuWkpoZFuj7Aq2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":24855,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caravan-palace-official/lone-digger?in=caravan-palace-official%2Fsets%2Freleases\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0196078431372549,0.19607843137254902,0.9921568627450981,1],\"shader\":\"/*\\n \\n . \\n .-. ...;....;. _ \\n_.; : .-. .;.::..'.-. `.,' ' \\n ; ;.;.-' .; .;.;.-' ,'`. \\n `._.' `:::'.;' .; `:::' -' `._. \\n .; .' \\n . ;;-. .-. .-..' .-. .;.::. \\n .'; ;; ;; : : ; .;.-' .; \\n .' .'.;` ``:::'-'`:::'`.`:::'.;' \\n' . \\n ...;... \\n .-. .;.::..' \\n ; : .; .; \\n `:::'-'.;' .; \\n \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float r = pow(cos((u - 0.5) * 2.), 2.);\\n float s = sin(a) * abs(cos(a * 0.5));\\n float c = cos(a);\\n float x = c * v * r;\\n float y = s * v * r;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nconst float numTrails = 1.;\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n// float trailId = mod(circleId, numTrails);\\n// float trailV = trailId / numTrails;\\n// circleId = floor(circleId / trailId);\\nfloat trailV = 1.;\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float pointV = pointId / NUM_POINTS_PER_CIRCLE;\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;//mix(0.0, 1.0, p1m1(sin(goop(circleId) + time * 0.0)));\\n float start = 0.0;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n \\n float across = floor(sqrt(numCircles));\\n float down = floor(numCircles / across);\\n float uId = mod(circleId, across);\\n float u = uId / (across - 1.);\\n float vId = floor(circleId / across);\\n float v = vId / (down - 1.);\\n \\n float ur = m1p1(u);// * cos(time);\\n float vr = m1p1(v);// * sin(time);\\n float rr = length(vec2(ur, vr));\\n float aa = (atan(ur, vr) + PI) / (2. * PI);\\n float snd = texture2D(sound, vec2(mix(0.01, 0.1, abs(m1p1(aa))), rr * .025)).a;\\n \\n \\n vec3 offset = vec3(0);vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\\n offset.x += 0.;m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\\n offset.y += 0.;goop(circleId + time * 0.) * 0.1;\\n float timeOff = m1p1(mod(time * 0.01 + (cu * 3.), 1.));\\n offset.x += m1p1(u) + mod(vId, 2.) / across; //sin(timeOff * PI * 2.) * cu * 2.;\\n offset.y += m1p1(v); //cos(timeOff * PI * 2.) * cu * 2.;\\n offset.z = -m1p1(cu);//m1p1(hash(circleId * 0.641)) - trailV * 0.01;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1.);\\n \\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n // mat *= rotZ(hash(circleId * 0.543) * PI * 2.);\\n mat *= trans(offset);\\n // mat *= rotZ(hash(circleId * 0.234) * PI * 2. + time);\\n // mat *= rotZ(PI * -1.5 + snd * 6.);\\n mat *= rotZ(m1p1(aa) * PI - PI * 0.5 );\\n mat *= scale(vec3(mix(-0.2, 0.4, pow(snd, 3.0)), 0.1, 0.1));\\n mat *= trans(vec3(1.5, 0, 0));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(1.1, 1.2, fract(circleId * 0.1));\\n float sat = 1.;trailV; //mix(1., 0., step(0.99, pow(snd, 5.0)));\\n float val = 1.;mix(0.8, 1.0, fract(circleId * 0.79));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.a = 1.;//p1m1(offset.z);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 24855, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caravan-palace-official/lone-digger?in=caravan-palace-official%2Fsets%2Freleases", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0196078431372549, + 0.19607843137254902, + 0.9921568627450981, + 1 + ], + "shader": "/*\n \n . \n .-. ...;....;. _ \n_.; : .-. .;.::..'.-. `.,' ' \n ; ;.;.-' .; .;.;.-' ,'`. \n `._.' `:::'.;' .; `:::' -' `._. \n .; .' \n . ;;-. .-. .-..' .-. .;.::. \n .'; ;; ;; : : ; .;.-' .; \n .' .'.;` ``:::'-'`:::'`.`:::'.;' \n' . \n ...;... \n .-. .;.::..' \n ; : .; .; \n `:::'-'.;' .; \n \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float r = pow(cos((u - 0.5) * 2.), 2.);\n float s = sin(a) * abs(cos(a * 0.5));\n float c = cos(a);\n float x = c * v * r;\n float y = s * v * r;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nconst float numTrails = 1.;\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n// float trailId = mod(circleId, numTrails);\n// float trailV = trailId / numTrails;\n// circleId = floor(circleId / trailId);\nfloat trailV = 1.;\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float pointV = pointId / NUM_POINTS_PER_CIRCLE;\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;//mix(0.0, 1.0, p1m1(sin(goop(circleId) + time * 0.0)));\n float start = 0.0;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n \n float across = floor(sqrt(numCircles));\n float down = floor(numCircles / across);\n float uId = mod(circleId, across);\n float u = uId / (across - 1.);\n float vId = floor(circleId / across);\n float v = vId / (down - 1.);\n \n float ur = m1p1(u);// * cos(time);\n float vr = m1p1(v);// * sin(time);\n float rr = length(vec2(ur, vr));\n float aa = (atan(ur, vr) + PI) / (2. * PI);\n float snd = texture2D(sound, vec2(mix(0.01, 0.1, abs(m1p1(aa))), rr * .025)).a;\n \n \n vec3 offset = vec3(0);vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\n offset.x += 0.;m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\n offset.y += 0.;goop(circleId + time * 0.) * 0.1;\n float timeOff = m1p1(mod(time * 0.01 + (cu * 3.), 1.));\n offset.x += m1p1(u) + mod(vId, 2.) / across; //sin(timeOff * PI * 2.) * cu * 2.;\n offset.y += m1p1(v); //cos(timeOff * PI * 2.) * cu * 2.;\n offset.z = -m1p1(cu);//m1p1(hash(circleId * 0.641)) - trailV * 0.01;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1.);\n \n \n mat4 mat = ident(); \n mat *= scale(aspect);\n // mat *= rotZ(hash(circleId * 0.543) * PI * 2.);\n mat *= trans(offset);\n // mat *= rotZ(hash(circleId * 0.234) * PI * 2. + time);\n // mat *= rotZ(PI * -1.5 + snd * 6.);\n mat *= rotZ(m1p1(aa) * PI - PI * 0.5 );\n mat *= scale(vec3(mix(-0.2, 0.4, pow(snd, 3.0)), 0.1, 0.1));\n mat *= trans(vec3(1.5, 0, 0));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(1.1, 1.2, fract(circleId * 0.1));\n float sat = 1.;trailV; //mix(1., 0., step(0.99, pow(snd, 5.0)));\n float val = 1.;mix(0.8, 1.0, fract(circleId * 0.79));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.a = 1.;//p1m1(offset.z);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-bld6ud541ckdye2h1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cqrpE8sDb6Md6djDh/art.json b/art/cqrpE8sDb6Md6djDh/art.json index a3d66350..6b93bd34 100644 --- a/art/cqrpE8sDb6Md6djDh/art.json +++ b/art/cqrpE8sDb6Md6djDh/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\nMaking a grid\\n2022 spring\\n*/\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x* y* 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\nMaking a grid\n2022 spring\n*/\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x* y* 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-4rskjlaycflwj17a8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ct6NykQPhqWr3A7aC/art.json b/art/ct6NykQPhqWr3A7aC/art.json index 7b2e49cb..812b2397 100644 --- a/art/ct6NykQPhqWr3A7aC/art.json +++ b/art/ct6NykQPhqWr3A7aC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/guigoo-official/acido\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//Simple study for glslsandbox fragment shader to vertexshaderart vertex shader conversion - WORK IN PROGRESS\\n//inspired from http://glslsandbox.com/e#49260.0\\n//2 KParameters added for import and control in K Machine (https://itunes.apple.com/app/k-machine/id1095617380?mt=8)\\n\\n#define ITERS 8.\\n\\n#define speedFactor 25.//KParameter 1>>100.0\\n#define soundFactor 5.0//KParameter 5.0>>30.\\n#define sizeFactor 1.0//KParameter 0.2>>2.\\n\\nvoid main () \\n{\\n \\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //vertexResolution.x = number of elements in a line as x value for local resolution\\n //vertexResolution.y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //Calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n //simfragCoord <=> gl_FragCoord of the fragment shader\\n \\n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\\n \\n //relative coordinate of the vertex (cordinates range 0. to 1.)\\n float u = (simfragCoord.x /vertexResolution.x);\\n float v = (simfragCoord.y /vertexResolution.y);\\n \\n //calculate coordinates range -1. to 1.\\n \\n float fact = 2.*sizeFactor;\\n float ux = fact*(u - 0.5);\\n float vy = fact*(v - 0.5);\\n \\n //Finally set the position of each vertex of the grid\\n gl_Position = vec4(ux, vy, 0., 1.);\\n\\n //Calculate the best possible pointSize to fill the screen\\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\\n \\n //create the surfacePosition (glslsandbox parameter ...not used here)\\n //vec2 surfacePosition = vec2(ux,vy);\\n \\n float snd = soundFactor*texture2D(sound, vec2(0., 0.2)).a;\\n //snd+= +0.001*time;//add a little something to avoid total flatnes;\\n \\n //////////////////////////////////////////////////////////////////////////////////////////\\n ///Below we import fragment shader logic/code almost unmodify from glslsandbox\\n //gl_FragCoord is replaced with the new simfragCoord \\n //////////////////////////////////////////////////////////////////////////////////////////\\n\\n vec2 position = vec2(simfragCoord.x, simfragCoord.y);\\n vec2 res = vec2(vertexResolution.x, vertexResolution.y);\\n vec2 fragCoord = vec2(u,v);\\n \\n vec3 d = normalize( vec3( (position.xy - res.xy * .5) / vertexResolution.y, .15));\\n \\n\\tvec3 p, c, f, g=d, o, y1=vec3(1.0,1.5,0.0);\\n \\n \\to.y = 4. + 4.8*cos((o.x=0.1)*(o.z=time * speedFactor));\\n\\to.x -= sin(time) + 3.0;\\n\\n for( float i=.0; i ++p.y/snd ) {\\n\\t \\tg = (f.y-.04*cos((c.x+c.z)*10.)>.7?y1:f.x*y1.yxz) / i;\\n break;\\n }\\n }\\n \\n \\n v_color = vec4(g,1.0);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/guigoo-official/acido", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//Simple study for glslsandbox fragment shader to vertexshaderart vertex shader conversion - WORK IN PROGRESS\n//inspired from http://glslsandbox.com/e#49260.0\n//2 KParameters added for import and control in K Machine (https://itunes.apple.com/app/k-machine/id1095617380?mt=8)\n\n#define ITERS 8.\n\n#define speedFactor 25.//KParameter 1>>100.0\n#define soundFactor 5.0//KParameter 5.0>>30.\n#define sizeFactor 1.0//KParameter 0.2>>2.\n\nvoid main () \n{\n \n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //vertexResolution.x = number of elements in a line as x value for local resolution\n //vertexResolution.y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //Calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n //simfragCoord <=> gl_FragCoord of the fragment shader\n \n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\n \n //relative coordinate of the vertex (cordinates range 0. to 1.)\n float u = (simfragCoord.x /vertexResolution.x);\n float v = (simfragCoord.y /vertexResolution.y);\n \n //calculate coordinates range -1. to 1.\n \n float fact = 2.*sizeFactor;\n float ux = fact*(u - 0.5);\n float vy = fact*(v - 0.5);\n \n //Finally set the position of each vertex of the grid\n gl_Position = vec4(ux, vy, 0., 1.);\n\n //Calculate the best possible pointSize to fill the screen\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\n \n //create the surfacePosition (glslsandbox parameter ...not used here)\n //vec2 surfacePosition = vec2(ux,vy);\n \n float snd = soundFactor*texture2D(sound, vec2(0., 0.2)).a;\n //snd+= +0.001*time;//add a little something to avoid total flatnes;\n \n //////////////////////////////////////////////////////////////////////////////////////////\n ///Below we import fragment shader logic/code almost unmodify from glslsandbox\n //gl_FragCoord is replaced with the new simfragCoord \n //////////////////////////////////////////////////////////////////////////////////////////\n\n vec2 position = vec2(simfragCoord.x, simfragCoord.y);\n vec2 res = vec2(vertexResolution.x, vertexResolution.y);\n vec2 fragCoord = vec2(u,v);\n \n vec3 d = normalize( vec3( (position.xy - res.xy * .5) / vertexResolution.y, .15));\n \n\tvec3 p, c, f, g=d, o, y1=vec3(1.0,1.5,0.0);\n \n \to.y = 4. + 4.8*cos((o.x=0.1)*(o.z=time * speedFactor));\n\to.x -= sin(time) + 3.0;\n\n for( float i=.0; i ++p.y/snd ) {\n\t \tg = (f.y-.04*cos((c.x+c.z)*10.)>.7?y1:f.x*y1.yxz) / i;\n break;\n }\n }\n \n \n v_color = vec4(g,1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-9nv796me9ziong1hu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ctdaXFjXNjTiss8Kh/art.json b/art/ctdaXFjXNjTiss8Kh/art.json index fb6a5e45..58b2dc90 100644 --- a/art/ctdaXFjXNjTiss8Kh/art.json +++ b/art/ctdaXFjXNjTiss8Kh/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":40000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/graham-panter/lotus\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvoid main() {\\n float pointsAroundCircle = 240.;\\n float pointsPerCircle = pointsAroundCircle * 2.;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float vId = mod(vertexId, pointsPerCircle);\\n float pointId = floor(vId / 2.) + mod(vId, 2.);\\n float pointV = pointId / (pointsAroundCircle - 1.);\\n \\n float circleV = circleId / (numCircles - 1.);\\n float odd = mod(circleId, 2.);\\n float quad = mod(floor(circleId / 2.), 2.);\\n \\n float tm = time * 4. - circleV;\\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .05;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float off = mix(.0, 0.953, circleV);\\n\\n float su = hash(pointV * 13.7);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.2)).a;\\n \\n float q = (odd + quad * 2.) / 3.;\\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\\n \\n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 5.));\\n float scale = mix(\\n mix(\\n mix(.4, .5, circleV),\\n mix(-.4, -.3, circleV),\\n odd),\\n mix(\\n mix(.1, .15, circleV),\\n mix(-.1, -.05, circleV),\\n odd),\\n quad) + pow(sq, 10.) * .1;\\n \\n gl_Position = vec4(xy * aspect * scale, circleV, 1);\\n\\n float hue = 0.5 + odd * .5 + quad * .125;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 40000, + "mode": "LINES", + "sound": "https://soundcloud.com/graham-panter/lotus", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvoid main() {\n float pointsAroundCircle = 240.;\n float pointsPerCircle = pointsAroundCircle * 2.;\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float vId = mod(vertexId, pointsPerCircle);\n float pointId = floor(vId / 2.) + mod(vId, 2.);\n float pointV = pointId / (pointsAroundCircle - 1.);\n \n float circleV = circleId / (numCircles - 1.);\n float odd = mod(circleId, 2.);\n float quad = mod(floor(circleId / 2.), 2.);\n \n float tm = time * 4. - circleV;\n float angle = mix(-PI, PI, pointV) + sin(tm + pointV * PI * 8.) * .05;\n float c = cos(angle);\n float s = sin(angle);\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float off = mix(.0, 0.953, circleV);\n\n float su = hash(pointV * 13.7);\n float snd = texture2D(sound, vec2(mix(0.001, 0.115, su), circleV * 0.2)).a;\n \n float q = (odd + quad * 2.) / 3.;\n float sq = texture2D(sound, vec2(mix(0.001, 0.115, 0.), 0)).a;\n \n vec2 xy = vec2(c, s) * mix(1. , 1. + off, pow(snd, 5.));\n float scale = mix(\n mix(\n mix(.4, .5, circleV),\n mix(-.4, -.3, circleV),\n odd),\n mix(\n mix(.1, .15, circleV),\n mix(-.1, -.05, circleV),\n odd),\n quad) + pow(sq, 10.) * .1;\n \n gl_Position = vec4(xy * aspect * scale, circleV, 1);\n\n float hue = 0.5 + odd * .5 + quad * .125;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1. - circleV);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-48z002kn4oniobgni-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cvLGj6QKvo7uebnbK/art.json b/art/cvLGj6QKvo7uebnbK/art.json index 059f7789..a54ffb39 100644 --- a/art/cvLGj6QKvo7uebnbK/art.json +++ b/art/cvLGj6QKvo7uebnbK/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres", "private": false, "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.953) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.953) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-h8oc2dy04u0dwdefp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cvcz6reqzpuyvdjvY/art.json b/art/cvcz6reqzpuyvdjvY/art.json index 6d3bc15f..91539a67 100644 --- a/art/cvcz6reqzpuyvdjvY/art.json +++ b/art/cvcz6reqzpuyvdjvY/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mipmap", "avatarUrl": "https://secure.gravatar.com/avatar/2840df8e29cba840a5b7f90f66bc66cd?default=retro&size=200", - "settings": "{\"num\":28831,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n\\n#define PI radians(180.0)\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, s, 0, 0, \\n s, 0, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n 1 -dot(xAxis, eye), dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.3, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\n\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 1.25);\\n float sv = 1. - (p.y + 0.5); // soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * 1.2;\\n s *= 0.15;\\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time*.25;\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(55.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\\n float val = mix(.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 28831, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n\n#define PI radians(180.0)\n//KDrawmode=GL_TRIANGLES\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, s, 0, 0, \n s, 0, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n 1 -dot(xAxis, eye), dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.3, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\n\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 1.25);\n float sv = 1. - (p.y + 0.5); // soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * 1.2;\n s *= 0.15;\n texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time*.25;\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(55.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.71 + qu * p.y * 2.1;//1.;m1p1(n.z);\n float sat = pow(0.5 - p.y, 2.);.3;//abs(n.z);\n float val = mix(.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-ld2t51bqtupcrtyrv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cxEbTRudczrikaEBX/art.json b/art/cxEbTRudczrikaEBX/art.json index 2cc8bd66..76d93e75 100644 --- a/art/cxEbTRudczrikaEBX/art.json +++ b/art/cxEbTRudczrikaEBX/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":59737,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Circles from Triangles\\n// CS250 Spring 2022\\n\\n\\n\\n/// These helper functions are from https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n///\\n\\n\\nvec2 getCirclePoint(float id, float circleSegmentCount)\\n{\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / circleSegmentCount * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n return vec2(c, s) * radius;\\n}\\n\\n\\nvoid main()\\n{\\n float circleSegmentCount = 12.0;\\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentCount);\\n \\n float pointCountPerCircle = circleSegmentCount * 6.0;\\n float circleId = floor(vertexId / pointCountPerCircle);\\n float circleCount = floor(vertexCount / pointCountPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0);\\n \\n float down = floor(sqrt(circleCount));\\n float across = floor(circleCount / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = 0.0;\\n float yOffset = 0.0;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.1, 7.0) * mix(1.0, 1.1, oddSlice);\\n sc *= 20.0 / across;\\n \\n vec4 pos = vec4(circleXY, 0.0, 1.0);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(texture2D(sound, vec2(au * 0.0001, av * 0.1)).a * -2.5);\\n mat *= trans(vec3(ux,vy, 0) * 1.4);\\n mat *= rotZ(snd * 20.0 * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n gl_Position = mat * pos;\\n \\n const float range = 120.0;\\n const float block = 120.0 / 240.0;\\n float sum = 0.0;\\n for (float b = 0.0; b < range / 240.0; b += block)\\n {\\n sum += texture2D(sound, vec2(b, av * 0.25)).a;\\n }\\n \\n float pump = step(0.8, snd);\\n float hue = sum / block;\\n float saturation = 1.0;\\n float value = mix(0.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue += pump * oddSlice * 0.1;\\n value += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 59737, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Circles from Triangles\n// CS250 Spring 2022\n\n\n\n/// These helper functions are from https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n///\n\n\nvec2 getCirclePoint(float id, float circleSegmentCount)\n{\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = ux / circleSegmentCount * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n return vec2(c, s) * radius;\n}\n\n\nvoid main()\n{\n float circleSegmentCount = 12.0;\n vec2 circleXY = getCirclePoint(vertexId, circleSegmentCount);\n \n float pointCountPerCircle = circleSegmentCount * 6.0;\n float circleId = floor(vertexId / pointCountPerCircle);\n float circleCount = floor(vertexCount / pointCountPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0);\n \n float down = floor(sqrt(circleCount));\n float across = floor(circleCount / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = 0.0;\n float yOffset = 0.0;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.1, 7.0) * mix(1.0, 1.1, oddSlice);\n sc *= 20.0 / across;\n \n vec4 pos = vec4(circleXY, 0.0, 1.0);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(texture2D(sound, vec2(au * 0.0001, av * 0.1)).a * -2.5);\n mat *= trans(vec3(ux,vy, 0) * 1.4);\n mat *= rotZ(snd * 20.0 * sign(ux));\n mat *= uniformScale(0.03 * sc);\n gl_Position = mat * pos;\n \n const float range = 120.0;\n const float block = 120.0 / 240.0;\n float sum = 0.0;\n for (float b = 0.0; b < range / 240.0; b += block)\n {\n sum += texture2D(sound, vec2(b, av * 0.25)).a;\n }\n \n float pump = step(0.8, snd);\n float hue = sum / block;\n float saturation = 1.0;\n float value = mix(0.4, pow(snd + 0.2, 5.0), pump);\n \n hue += pump * oddSlice * 0.1;\n value += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-uyzuozlwfsjhs9h4p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cxdd3QwD34CZzTpFj/art.json b/art/cxdd3QwD34CZzTpFj/art.json index c9e3725e..496566f2 100644 --- a/art/cxdd3QwD34CZzTpFj/art.json +++ b/art/cxdd3QwD34CZzTpFj/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "aphim44", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocIbUrfKa-_sasPTCzc5YyCidETMwcm-KjFqfbic41trqgs=s96-c", - "settings": "{\"num\":40,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7803921568627451,0.5568627450980392,0.5568627450980392,1],\"shader\":\"void main(){\\n float act = resolution[1]/resolution[0];\\n\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 5.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId +1., 2.0);\\n \\n float elements = x / 100.0;\\n float angle = elements * radians(360.0);\\n float radius = 4. - y;\\n \\n x = radius * cos(angle);\\n y = radius * sin(angle);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n xy[0]*=act;\\n// xy[0]*=cos(10.);\\n //xy[1]*=sin(10.);\\n\\n\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n}\\n\"}", + "settings": { + "num": 40, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7803921568627451, + 0.5568627450980392, + 0.5568627450980392, + 1 + ], + "shader": "void main(){\n float act = resolution[1]/resolution[0];\n\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n gl_PointSize = 5.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId +1., 2.0);\n \n float elements = x / 100.0;\n float angle = elements * radians(360.0);\n float radius = 4. - y;\n \n x = radius * cos(angle);\n y = radius * sin(angle);\n \n vec2 xy = vec2(x, y) * 0.1;\n xy[0]*=act;\n// xy[0]*=cos(10.);\n //xy[1]*=sin(10.);\n\n\n \n gl_Position = vec4(xy, 0.0, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-bec1z4kmli7l82s7q-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/cynWXyqSFnWDriqfR/art.json b/art/cynWXyqSFnWDriqfR/art.json index 7c78ebb6..433f0934 100644 --- a/art/cynWXyqSFnWDriqfR/art.json +++ b/art/cynWXyqSFnWDriqfR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":3739,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/shuffle/chris-schwarzwalder-garbicz-2018\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00392156862745098,0.023529411764705882,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; // sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float snd = texture2D(sound, vec2(u, 0.0)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.0; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 8.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float val = snd; //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 3739, + "mode": "POINTS", + "sound": "https://soundcloud.com/shuffle/chris-schwarzwalder-garbicz-2018", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00392156862745098, + 0.023529411764705882, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; // sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float snd = texture2D(sound, vec2(u, 0.0)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.0; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 8.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.0;\n float val = snd; //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-7vxgaxq2q9l94cdxq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cz2CWm8MobiaqYc46/art.json b/art/cz2CWm8MobiaqYc46/art.json index 1c8b56aa..49363866 100644 --- a/art/cz2CWm8MobiaqYc46/art.json +++ b/art/cz2CWm8MobiaqYc46/art.json @@ -17,7 +17,19 @@ "name": "residualfillattack", "private": false, "username": "-anon-", - "settings": "{\"num\":3000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(4.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\\n float x = (u*60.0)-1.0;\\n float y = ((v+vold)*0.5);//*osc;\\n gl_PointSize = 1.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\\n v_color = vec4((lum-lumOld*1.5)*0.6,(lum-lumOld)*0.6,(lum-lumOld*0.2)*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(4.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\n float x = (u*60.0)-1.0;\n float y = ((v+vold)*0.5);//*osc;\n gl_PointSize = 1.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\n v_color = vec4((lum-lumOld*1.5)*0.6,(lum-lumOld)*0.6,(lum-lumOld*0.2)*1.0,v);\n}" + }, "screenshotURL": "data/images/images-2kvbe7w6rl8k2xfla-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/cznhWtArrLFqxJgAf/art.json b/art/cznhWtArrLFqxJgAf/art.json index 21631e38..74e3d3bb 100644 --- a/art/cznhWtArrLFqxJgAf/art.json +++ b/art/cznhWtArrLFqxJgAf/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nfloat cbrt(float n) {\\n float x = 1.0;\\n for (int i = 0; i < 10; ++i) {\\n x = (2.0 * x + n / (x * x)) / 3.0;\\n }\\n return x;\\n}\\n\\nvec3 rgb2oklab(vec3 c) \\n{\\n float l = dot(c, vec3(0.4121656120, 0.5362752080, 0.0514575653));\\n float m = dot(c, vec3(0.2118591070, 0.6807189584, 0.1074065790));\\n float s = dot(c, vec3(0.0883097947, 0.2818474174, 0.6302613616));\\n\\n float l_ = cbrt(l);\\n float m_ = cbrt(m);\\n float s_ = cbrt(s);\\n\\n return vec3(\\n 0.2104542553*l_ + 0.7936177850*m_ - 0.0040720468*s_,\\n 1.9779984951*l_ - 2.4285922050*m_ + 0.4505937099*s_,\\n 0.0259040371*l_ + 0.7827717662*m_ - 0.8086757660*s_);\\n}\\n\\nvec3 oklab2rgb(vec3 c) \\n{\\n float l_ = c.x + 0.3963377774 * c.y + 0.2158037573 * c.z;\\n float m_ = c.x - 0.1055613458 * c.y - 0.0638541728 * c.z;\\n float s_ = c.x - 0.0894841775 * c.y - 1.2914855480 * c.z;\\n\\n float l = l_*l_*l_;\\n float m = m_*m_*m_;\\n float s = s_*s_*s_;\\n\\n return vec3(\\n + 4.0767245293*l - 3.3072168827*m + 0.2307590544*s,\\n - 1.2681437731*l + 2.6093323231*m - 0.3411344290*s,\\n - 0.0041119885*l - 0.7034763098*m + 1.7068625689*s);\\n}\\n\\nvec3 hsl2rgb(vec3 c) {\\n float C = c.y;\\n float h = c.x;\\n float a = C * cos(h * PI * 2.0);\\n float b = C * sin(h * PI * 2.0);\\n float L = c.z;\\n return oklab2rgb(vec3(L,a,b));\\n}\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount));\\n float down = floor(vertexCount / across);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (down - 1.0);\\n \\n float xu = u * 2.0 - 1.0;\\n float yv = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(xu, yv, 0, 1);\\n gl_PointSize = 10.0;\\n\\n v_color= vec4(hsl2rgb(vec3(u, 0.2, 1.)), 1);\\n \\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nfloat cbrt(float n) {\n float x = 1.0;\n for (int i = 0; i < 10; ++i) {\n x = (2.0 * x + n / (x * x)) / 3.0;\n }\n return x;\n}\n\nvec3 rgb2oklab(vec3 c) \n{\n float l = dot(c, vec3(0.4121656120, 0.5362752080, 0.0514575653));\n float m = dot(c, vec3(0.2118591070, 0.6807189584, 0.1074065790));\n float s = dot(c, vec3(0.0883097947, 0.2818474174, 0.6302613616));\n\n float l_ = cbrt(l);\n float m_ = cbrt(m);\n float s_ = cbrt(s);\n\n return vec3(\n 0.2104542553*l_ + 0.7936177850*m_ - 0.0040720468*s_,\n 1.9779984951*l_ - 2.4285922050*m_ + 0.4505937099*s_,\n 0.0259040371*l_ + 0.7827717662*m_ - 0.8086757660*s_);\n}\n\nvec3 oklab2rgb(vec3 c) \n{\n float l_ = c.x + 0.3963377774 * c.y + 0.2158037573 * c.z;\n float m_ = c.x - 0.1055613458 * c.y - 0.0638541728 * c.z;\n float s_ = c.x - 0.0894841775 * c.y - 1.2914855480 * c.z;\n\n float l = l_*l_*l_;\n float m = m_*m_*m_;\n float s = s_*s_*s_;\n\n return vec3(\n + 4.0767245293*l - 3.3072168827*m + 0.2307590544*s,\n - 1.2681437731*l + 2.6093323231*m - 0.3411344290*s,\n - 0.0041119885*l - 0.7034763098*m + 1.7068625689*s);\n}\n\nvec3 hsl2rgb(vec3 c) {\n float C = c.y;\n float h = c.x;\n float a = C * cos(h * PI * 2.0);\n float b = C * sin(h * PI * 2.0);\n float L = c.z;\n return oklab2rgb(vec3(L,a,b));\n}\n\nvoid main() {\n float across = floor(sqrt(vertexCount));\n float down = floor(vertexCount / across);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (down - 1.0);\n \n float xu = u * 2.0 - 1.0;\n float yv = v * 2.0 - 1.0;\n \n gl_Position = vec4(xu, yv, 0, 1);\n gl_PointSize = 10.0;\n\n v_color= vec4(hsl2rgb(vec3(u, 0.2, 1.)), 1);\n \n}" + }, "screenshotURL": "data/images/images-ur30c1be3rakpj5fh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/d5232ap5Whxh5xE5w/art.json b/art/d5232ap5Whxh5xE5w/art.json index a86e1fe8..97dca76f 100644 --- a/art/d5232ap5Whxh5xE5w/art.json +++ b/art/d5232ap5Whxh5xE5w/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":36036,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jaschahagen/simple-brain-dance\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 100.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 36036, + "mode": "POINTS", + "sound": "https://soundcloud.com/jaschahagen/simple-brain-dance", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 100.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-nzvtjnvgw8x4v3jyn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/d5MYkeFzBcFMQzpQf/art.json b/art/d5MYkeFzBcFMQzpQf/art.json index bc29b63d..ea95a10b 100644 --- a/art/d5MYkeFzBcFMQzpQf/art.json +++ b/art/d5MYkeFzBcFMQzpQf/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "gitanely", "avatarUrl": "https://secure.gravatar.com/avatar/d5fdfe8b65ebd7057053c353e059209a?default=retro&size=200", - "settings": "{\"num\":300,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float ID = vertexId;\\n vec4 OutColor = vec4(1,1,1,1);\\n gl_Position=vec4(\\n cos(ID + time + mouse.x) * (ID * ID * 0.01), \\n sin(ID + time + mouse.y) * (40.0),\\n 1.,\\n 60.0 + ID );\\n gl_PointSize= 5.0;\\n float st = step(time,1.0);\\n OutColor.x = time * 0.01 - (ID / 300.0);\\n OutColor = vec4(hsv2rgb(OutColor.xyz),1.0);\\n \\n v_color= OutColor;\\n \\n}\"}", + "settings": { + "num": 300, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float ID = vertexId;\n vec4 OutColor = vec4(1,1,1,1);\n gl_Position=vec4(\n cos(ID + time + mouse.x) * (ID * ID * 0.01), \n sin(ID + time + mouse.y) * (40.0),\n 1.,\n 60.0 + ID );\n gl_PointSize= 5.0;\n float st = step(time,1.0);\n OutColor.x = time * 0.01 - (ID / 300.0);\n OutColor = vec4(hsv2rgb(OutColor.xyz),1.0);\n \n v_color= OutColor;\n \n}" + }, "screenshotURL": "data/images/images-1wy40xa7vq4uwtov1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/d5q4WZfHWEwTikN2o/art.json b/art/d5q4WZfHWEwTikN2o/art.json index fe9912dc..4cb2a14c 100644 --- a/art/d5q4WZfHWEwTikN2o/art.json +++ b/art/d5q4WZfHWEwTikN2o/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "kcha", "avatarUrl": "https://secure.gravatar.com/avatar/393683f94ba2c18293b67ab3d3eb6f10?default=retro&size=200", - "settings": "{\"num\":1533,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.14901960784313725,0.3764705882352941,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across); // 0, 1, 2, ..., 9, 0, 1, ...\\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\\n \\n // 0.0 - 1.0\\n float u = x / (across - 1.); // .0, .1, ... , .9, .0, .1, ...\\n float v = y / (across - 1.); // .0, .0, ... , .1, .1, ... \\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n // 0.0-1.0 => -0.5-0.5 => 0.5-0.0-0.5 => 1.0-0.0-1.0\\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + .2, 5.) * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .2;//sin(time + v * 20.) * .05;\\n float sat = mix(0.0, 1.0, pump);//mix(1., 0., av);\\n float val = mix(.1, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n 2 + 3;\\n}\\n\"}", + "settings": { + "num": 1533, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.14901960784313725, + 0.3764705882352941, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across); // 0, 1, 2, ..., 9, 0, 1, ...\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\n \n // 0.0 - 1.0\n float u = x / (across - 1.); // .0, .1, ... , .9, .0, .1, ...\n float v = y / (across - 1.); // .0, .0, ... , .1, .1, ... \n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n // 0.0-1.0 => -0.5-0.5 => 0.5-0.0-0.5 => 1.0-0.0-1.0\n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + .2, 5.) * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .2;//sin(time + v * 20.) * .05;\n float sat = mix(0.0, 1.0, pump);//mix(1., 0., av);\n float val = mix(.1, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n 2 + 3;\n}\n" + }, "screenshotURL": "data/images/images-uxamxew6if8gngqbu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/d6HHmyLaBsmttvb5b/art.json b/art/d6HHmyLaBsmttvb5b/art.json index 3b0699ea..9994425e 100644 --- a/art/d6HHmyLaBsmttvb5b/art.json +++ b/art/d6HHmyLaBsmttvb5b/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":48023,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DIST 2.0\\n\\nvoid main() {\\n float pointId = (vertexId/vertexCount);\\n float faceId = floor(vertexId / 100.0);\\n\\n /*\\n Face ID:\\n Right - 0\\n Left - 1\\n Top - 2\\n Bottom - 3\\n Front - 4\\n Back - 5\\n */\\n// VertexCount\\n /* vec3 pos = vec3(0.0, mod(pointId, 10.0), 0.5);\\n pos.x = (pointId - pos.y) / 10.0;\\n pos.xy = pos.xy / 10.0 - 0.5;\\n\\n if (mod(faceId, 2.0) == 1.0) pos.z *= -1.0;\\n if (faceId == 0.0 || faceId == 1.0) pos = pos.zyx;\\n if (faceId == 2.0 || faceId == 3.0) pos = pos.xzy;\\n\\n // Set color before transforms so the colors don't slip\\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\\n\\n float c = cos(time), s = sin(time);\\n pos.xz *= mat2(c, s, -s, c);\\n pos.yz *= mat2(c, s, -s, c);\\n pos *= 1.5;\\n\\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\\n gl_Position.x *= resolution.y / resolution.x;\\n gl_PointSize = 5.0 / (EYE_DIST - pos.z);*/\\n \\n float c = cos(time), s = sin(time);\\n vec3 pos = vec3( cos(vertexId), sin(vertexId), 0.5);\\n pos.xy *=pointId;\\n \\tpos.z*=cos(pointId)*sin(time*4.+pointId)*2.;\\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\\n pos.xz *= mat2(c, s, -s, c);\\n pos.yz *= mat2(c, s, -s, c);\\npos *=1.5;\\n\\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\\n gl_PointSize =2.;\\n}\"}", + "settings": { + "num": 48023, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DIST 2.0\n\nvoid main() {\n float pointId = (vertexId/vertexCount);\n float faceId = floor(vertexId / 100.0);\n\n /*\n Face ID:\n Right - 0\n Left - 1\n Top - 2\n Bottom - 3\n Front - 4\n Back - 5\n */\n// VertexCount\n /* vec3 pos = vec3(0.0, mod(pointId, 10.0), 0.5);\n pos.x = (pointId - pos.y) / 10.0;\n pos.xy = pos.xy / 10.0 - 0.5;\n\n if (mod(faceId, 2.0) == 1.0) pos.z *= -1.0;\n if (faceId == 0.0 || faceId == 1.0) pos = pos.zyx;\n if (faceId == 2.0 || faceId == 3.0) pos = pos.xzy;\n\n // Set color before transforms so the colors don't slip\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\n\n float c = cos(time), s = sin(time);\n pos.xz *= mat2(c, s, -s, c);\n pos.yz *= mat2(c, s, -s, c);\n pos *= 1.5;\n\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\n gl_Position.x *= resolution.y / resolution.x;\n gl_PointSize = 5.0 / (EYE_DIST - pos.z);*/\n \n float c = cos(time), s = sin(time);\n vec3 pos = vec3( cos(vertexId), sin(vertexId), 0.5);\n pos.xy *=pointId;\n \tpos.z*=cos(pointId)*sin(time*4.+pointId)*2.;\n v_color = vec4(pos * 2.0 + 1.0, 1.0);\n pos.xz *= mat2(c, s, -s, c);\n pos.yz *= mat2(c, s, -s, c);\npos *=1.5;\n\n gl_Position = vec4(pos.xy / (EYE_DIST - pos.z), 0.0, 1.0);\n gl_PointSize =2.;\n}" + }, "screenshotURL": "data/images/images-wawjubb6axcnjmh5t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/d6J9M7EJyoAgw5NcA/art.json b/art/d6J9M7EJyoAgw5NcA/art.json index 1797ed17..81830413 100644 --- a/art/d6J9M7EJyoAgw5NcA/art.json +++ b/art/d6J9M7EJyoAgw5NcA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/charliebeale/charlie-beale-planet-funk\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float numStars = floor(vertexCount / 3.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n float s = texture2D(sound, vec2(\\n mix(0.02, 0.5, h),\\n mix(0.0, 0.05, starV))).a;\\n \\n \\n float pId = mod(vertexId, 3.);\\n float sz = pow(s + 0.25, 5.) * 10.;\\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n \\n float hue = time * .1 + h * .2;\\n float sat = 1.;\\n float val = pow(s + 0.4, 5.);\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n float pump = step(.8, s);\\n color = mix(color, vec4(1, 0, 0, 1), pump);\\n color.a = mix(1., 0.2, pow(s, 5.));\\n color.rgb *= color.a;\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.125;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/charliebeale/charlie-beale-planet-funk", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float numStars = floor(vertexCount / 3.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n float s = texture2D(sound, vec2(\n mix(0.02, 0.5, h),\n mix(0.0, 0.05, starV))).a;\n \n \n float pId = mod(vertexId, 3.);\n float sz = pow(s + 0.25, 5.) * 10.;\n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n \n float hue = time * .1 + h * .2;\n float sat = 1.;\n float val = pow(s + 0.4, 5.);\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n float pump = step(.8, s);\n color = mix(color, vec4(1, 0, 0, 1), pump);\n color.a = mix(1., 0.2, pow(s, 5.));\n color.rgb *= color.a;\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.125;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n sky(vertexId + 1., vertexCount - 1., base, cmat, pos, color);\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-i912cmxjgisq3em06-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/d7anES7ef6WrrDwsy/art.json b/art/d7anES7ef6WrrDwsy/art.json index f188eb0e..83c3ac21 100644 --- a/art/d7anES7ef6WrrDwsy/art.json +++ b/art/d7anES7ef6WrrDwsy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.14901960784313725,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\\n // \\tvec3 vCameraUp = vec3( 0, 0, 1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.14901960784313725, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\n // \tvec3 vCameraUp = vec3( 0, 0, 1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-m5f2e7xd2dh99sj9r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/d7bnfzEFFTWGyQNaT/art.json b/art/d7bnfzEFFTWGyQNaT/art.json index f256db7a..60aa20d8 100644 --- a/art/d7bnfzEFFTWGyQNaT/art.json +++ b/art/d7bnfzEFFTWGyQNaT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 10.0\\n#define NUM_POINTS (NUM_SEGMENTS * 12.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.21 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 10.0\n#define NUM_POINTS (NUM_SEGMENTS * 12.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.21 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-m6e570ff6wrwxm5qa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/d8J6rAnjiWz4HntZH/art.json b/art/d8J6rAnjiWz4HntZH/art.json index 6c11fa68..e6d103de 100644 --- a/art/d8J6rAnjiWz4HntZH/art.json +++ b/art/d8J6rAnjiWz4HntZH/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "renya", "avatarUrl": "https://graph.facebook.com/825779784232264/picture?type=large", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/edm/deorro-ft-dycy-five-hours-dont-hold-me-back-edmcom-premiere\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//test test test\\n\\n\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nfloat slerping( float n ) { \\n return fract(sin(n)*100000.0);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float i = slerping(vertexId);\\n float f = i;\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 0.5);\\n vec2 uv;\\n \\n float count = floor(vertexId / NUM_POINTS);\\n \\n \\n float radius = pow(count * 0.00014, sin(time)); \\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005,.0);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oS*innerRadius*cos(snd)+0.7,\\n snd*.9)-0.05*snd*oC*2.0*innerRadius-0.7;\\n gl_Position = vec4(xy * aspect, 0, 1.5);\\n\\n \\n v_color = vec4(hsv2rgb(vec3(snd,snd, snd)), snd);\\n\\n \\n \\n\\n\\n\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/edm/deorro-ft-dycy-five-hours-dont-hold-me-back-edmcom-premiere", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//test test test\n\n\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nfloat slerping( float n ) { \n return fract(sin(n)*100000.0);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float i = slerping(vertexId);\n float f = i;\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 0.5);\n vec2 uv;\n \n float count = floor(vertexId / NUM_POINTS);\n \n \n float radius = pow(count * 0.00014, sin(time)); \n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005,.0);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oS*innerRadius*cos(snd)+0.7,\n snd*.9)-0.05*snd*oC*2.0*innerRadius-0.7;\n gl_Position = vec4(xy * aspect, 0, 1.5);\n\n \n v_color = vec4(hsv2rgb(vec3(snd,snd, snd)), snd);\n\n \n \n\n\n\n}\n\n" + }, "screenshotURL": "data/images/images-1nwtq8kn51dfqqkuc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/d8rzf4Hgtp69tQvrz/art.json b/art/d8rzf4Hgtp69tQvrz/art.json index 5f5c4cbf..e857a627 100644 --- a/art/d8rzf4Hgtp69tQvrz/art.json +++ b/art/d8rzf4Hgtp69tQvrz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.7333333333333333,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Making a Grid\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvoid main() {\\n \\n float across = 10.;\\n \\n float x = mod(vertexId , across);\\n float y = floor(vertexId / across);\\n \\n float u = x / across;\\n float v = y / across;\\n \\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.7333333333333333, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Making a Grid\ncourse name : CS250\nterm : 2022 Spring\n*/\nvoid main() {\n \n float across = 10.;\n \n float x = mod(vertexId , across);\n float y = floor(vertexId / across);\n \n float u = x / across;\n float v = y / across;\n \n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-sg86jhm1bdhbqgxl5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dAF9Jm3ZxebA7j6wX/art.json b/art/dAF9Jm3ZxebA7j6wX/art.json index fa699210..6206c2db 100644 --- a/art/dAF9Jm3ZxebA7j6wX/art.json +++ b/art/dAF9Jm3ZxebA7j6wX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=LINES_LOOP\\n//KVerticesNumber=1000000\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b05) *—det*det*b06/a00;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 66.4427));\\n p2 /= dot(p2.yx, p2.xy + vec2(1.5351, 444.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 3.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n mat *= uniformScale(1.);\\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, 1));\\n\\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 2. - sv), 2.));\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0.2, 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 1.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 12.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=LINES_LOOP\n//KVerticesNumber=1000000\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b05) *—det*det*b06/a00;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 66.4427));\n p2 /= dot(p2.yx, p2.xy + vec2(1.5351, 444.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 3.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n mat *= uniformScale(1.);\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, 1));\n\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 2. - sv), 2.));\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0.2, 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 1.5 + 0.5);\n v_color = vec4(color * pinch(lt, 12.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-i9geqj908wsd9weld-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dAL8F3TW5GN54MCBB/art.json b/art/dAL8F3TW5GN54MCBB/art.json index 5d39bcf0..760ed275 100644 --- a/art/dAL8F3TW5GN54MCBB/art.json +++ b/art/dAL8F3TW5GN54MCBB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tAudio Reactive Art\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\n \\tfloat pump = step(0.8, snd);\\n \\n \\tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5. * pump;\\n \\n \\tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n \\tgl_PointSize *= 10.0 / across * pump;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\\n \\tfloat sat = mix(0.0, 1.0, pump);\\n \\tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\tseongryul.park\n//\tCS250 spring 2023\n//\tAudio Reactive Art\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tfloat su = abs(u - 0.5) * 2.0;\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \n \tfloat pump = step(0.8, snd);\n \n \tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5. * pump;\n \n \tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n \tgl_PointSize *= 10.0 / across * pump;\n \tgl_PointSize *= resolution.x / 600.;\n \n \tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\n \tfloat sat = mix(0.0, 1.0, pump);\n \tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-myict7mjsb35a6i9c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dBc4DnM9H4zxHwGcH/art.json b/art/dBc4DnM9H4zxHwGcH/art.json index ea638929..9d1a3c3b 100644 --- a/art/dBc4DnM9H4zxHwGcH/art.json +++ b/art/dBc4DnM9H4zxHwGcH/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// hash functions\\n\\n\\n\\nvoid main() {\\n \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// hash functions\n\n\n\nvoid main() {\n \n \n}\n" + }, "screenshotURL": "data/images/images-4hh9pvko2o0w647b6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dCjgtsZXnjdzATJ8P/art.json b/art/dCjgtsZXnjdzATJ8P/art.json index 9029c194..c29a0271 100644 --- a/art/dCjgtsZXnjdzATJ8P/art.json +++ b/art/dCjgtsZXnjdzATJ8P/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.01;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.01;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1); // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ba41e3fs8gy8h9o73-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dCwDkmvtYAHzDGrKm/art.json b/art/dCwDkmvtYAHzDGrKm/art.json index 7c6dd098..cbe5c9ca 100644 --- a/art/dCwDkmvtYAHzDGrKm/art.json +++ b/art/dCwDkmvtYAHzDGrKm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\n\\n\\nvoid main ()\\n{\\n //float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n float snd = texture2D(sound, vec2(0., 0.)).a;\\n //apply fragment logic\\n\\n\\t//vec2 position = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);\\n\\tvec2 position = vec2(u, v);\\n\\t\\n \\n vec3 destColor = vec3(1.2, 5.0 * mouse.y, 0.6 * mouse.y);\\n\\tfloat f = 0.0;\\n\\t\\n\\tfor(float i = 0.0; i < 20.0; i++)\\n\\t{\\n\\t\\tfloat s = 0.2 * sin(0.11*(10.*snd+mouse.x*10.0) + i);\\n\\t\\tfloat c = 1.2 * cos(0.02*(10.*snd+mouse.x*10.0) + i);\\n\\t\\tf += 0.0015 / abs(length(11.0 * position * f - vec2(c, s)) - 0.8);\\n\\t}\\n\\n\\t//gl_FragColor = vec4(vec3(destColor * f), 2);\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4(vec3(destColor * f), 2);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\n\n\nvoid main ()\n{\n //float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n float snd = texture2D(sound, vec2(0., 0.)).a;\n //apply fragment logic\n\n\t//vec2 position = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);\n\tvec2 position = vec2(u, v);\n\t\n \n vec3 destColor = vec3(1.2, 5.0 * mouse.y, 0.6 * mouse.y);\n\tfloat f = 0.0;\n\t\n\tfor(float i = 0.0; i < 20.0; i++)\n\t{\n\t\tfloat s = 0.2 * sin(0.11*(10.*snd+mouse.x*10.0) + i);\n\t\tfloat c = 1.2 * cos(0.02*(10.*snd+mouse.x*10.0) + i);\n\t\tf += 0.0015 / abs(length(11.0 * position * f - vec2(c, s)) - 0.8);\n\t}\n\n\t//gl_FragColor = vec4(vec3(destColor * f), 2);\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4(vec3(destColor * f), 2);\n \n\n}" + }, "screenshotURL": "data/images/images-l5o04wgze9ohee1s6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dCyrwwNxWC4gmj7zN/art.json b/art/dCyrwwNxWC4gmj7zN/art.json index 904c02b0..870f654b 100644 --- a/art/dCyrwwNxWC4gmj7zN/art.json +++ b/art/dCyrwwNxWC4gmj7zN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":65536,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Simple Fractal - @P_Malin\\n \\nvoid main() \\n{ \\n \\tfloat fRotation = time * 0.25;\\n \\tvec2 vTranslation = vec2( 0.32, 0.2 );\\n \\tfloat fScale = 0.6;\\n\\n \\tfloat fSinRot = sin(fRotation);\\n \\tfloat fCosRot = cos(fRotation);\\n\\n \\tmat3 m = mat3( fCosRot * fScale, fSinRot * fScale, vTranslation.x, -fSinRot * fScale, fCosRot * fScale, vTranslation.y, 0.0, 0.0, 1.0 );\\n \\n \\tvec2 vPos = vec2( 0.0 );\\n \\tvec2 vMin = vec2( 100.0 ); \\t\\n \\tfloat fPassId = vertexId;\\n \\n \\tfor ( int i=0; i<8; i++ )\\n { \\n \\tvPos = (vec3(vPos, 1.0) * m).xy;\\n\\n \\tfPassId = fPassId / 4.0;\\n \\n \\tif ( fract( fPassId * 2.0 ) < 0.5 ) vPos.x = -vPos.x;\\n \\tif ( fract( fPassId ) < 0.5 ) vPos.y = -vPos.y;\\n \\tfPassId = floor( fPassId );\\n \\n \\tvMin = min( vMin, abs( vPos ) );\\n }\\n \\n \\tgl_PointSize = 6.0;\\n \\tgl_Position = vec4(vPos * vec2( 1.0, resolution.x / resolution.y) , 1.0/vertexId, 1);\\n\\n \\tvec3 vColor;\\n \\tvColor.x = sin( vMin.x * 11.0 + time * 1.234 ) * 0.5 + 0.5;\\n \\tvColor.y = sin( vMin.y * 10.0 + time * 2.345 ) * 0.5 + 0.5;\\n \\tvColor.z = sin( (vMin.x + vMin.y) * 5.0 + time * 3.456 ) * 0.5 + 0.5;\\n \\n \\tvColor = normalize(vColor);\\n \\n \\tvColor = 1.0 - exp2( vColor * -length( vMin ) * 3.0 );\\n \\tv_color = vec4( vColor, 0.0 );\\n}\"}", + "settings": { + "num": 65536, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Simple Fractal - @P_Malin\n \nvoid main() \n{ \n \tfloat fRotation = time * 0.25;\n \tvec2 vTranslation = vec2( 0.32, 0.2 );\n \tfloat fScale = 0.6;\n\n \tfloat fSinRot = sin(fRotation);\n \tfloat fCosRot = cos(fRotation);\n\n \tmat3 m = mat3( fCosRot * fScale, fSinRot * fScale, vTranslation.x, -fSinRot * fScale, fCosRot * fScale, vTranslation.y, 0.0, 0.0, 1.0 );\n \n \tvec2 vPos = vec2( 0.0 );\n \tvec2 vMin = vec2( 100.0 ); \t\n \tfloat fPassId = vertexId;\n \n \tfor ( int i=0; i<8; i++ )\n { \n \tvPos = (vec3(vPos, 1.0) * m).xy;\n\n \tfPassId = fPassId / 4.0;\n \n \tif ( fract( fPassId * 2.0 ) < 0.5 ) vPos.x = -vPos.x;\n \tif ( fract( fPassId ) < 0.5 ) vPos.y = -vPos.y;\n \tfPassId = floor( fPassId );\n \n \tvMin = min( vMin, abs( vPos ) );\n }\n \n \tgl_PointSize = 6.0;\n \tgl_Position = vec4(vPos * vec2( 1.0, resolution.x / resolution.y) , 1.0/vertexId, 1);\n\n \tvec3 vColor;\n \tvColor.x = sin( vMin.x * 11.0 + time * 1.234 ) * 0.5 + 0.5;\n \tvColor.y = sin( vMin.y * 10.0 + time * 2.345 ) * 0.5 + 0.5;\n \tvColor.z = sin( (vMin.x + vMin.y) * 5.0 + time * 3.456 ) * 0.5 + 0.5;\n \n \tvColor = normalize(vColor);\n \n \tvColor = 1.0 - exp2( vColor * -length( vMin ) * 3.0 );\n \tv_color = vec4( vColor, 0.0 );\n}" + }, "screenshotURL": "data/images/images-lzcz7tctn124vvv6o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dDWeHcCfjXZ2qxCji/art.json b/art/dDWeHcCfjXZ2qxCji/art.json index 700d8b40..9052e4e3 100644 --- a/art/dDWeHcCfjXZ2qxCji/art.json +++ b/art/dDWeHcCfjXZ2qxCji/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1947,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.0196078431372549,0.23137254901960785,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define KP0 2.//KParameter -2.>>2.\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.//KParameter 0.3>>7.\\n\\n#define KP2 .3//KParameter 0.2>>2.\\n//KVerticesNumber=9000\\n\\n\\n#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n#define Fs sampler2D floatSound;\\n\\n//( Fs, vec2(0.));\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.0001, zfar=100.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 0.90 / aspect, 0, 0, 0,\\n 0,3.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -3.0,\\n 0, 0, znear * zfar * rangeInv *.2, 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 332.0); \\ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 21., 42.0, 13256.0, 3.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.0015,-0.198,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(3.,-1.0,0.));\\n }\\n \\n mat4 tr=rotX(KP0*1.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.08,0.-.92,0.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 5.0,3.0*KP2,.10,0.4));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=0.70;\\n gl_Position.z-=2./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 1947, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.0196078431372549, + 0.23137254901960785, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n\n#define KP0 2.//KParameter -2.>>2.\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.//KParameter 0.3>>7.\n\n#define KP2 .3//KParameter 0.2>>2.\n//KVerticesNumber=9000\n\n\n#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n#define Fs sampler2D floatSound;\n\n//( Fs, vec2(0.));\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.0001, zfar=100.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 0.90 / aspect, 0, 0, 0,\n 0,3.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -3.0,\n 0, 0, znear * zfar * rangeInv *.2, 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 332.0); \ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 21., 42.0, 13256.0, 3.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.0015,-0.198,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(3.,-1.0,0.));\n }\n \n mat4 tr=rotX(KP0*1.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.08,0.-.92,0.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 5.0,3.0*KP2,.10,0.4));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=0.70;\n gl_Position.z-=2./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-b22yd31wklvw8foma-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dGD7KhAgWY4qfsmbJ/art.json b/art/dGD7KhAgWY4qfsmbJ/art.json index 231a74a4..cf25cb8b 100644 --- a/art/dGD7KhAgWY4qfsmbJ/art.json +++ b/art/dGD7KhAgWY4qfsmbJ/art.json @@ -31,7 +31,19 @@ "private": true, "unlisted": false, "username": "gman", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// plants\\n\\n#define PI radians(180.)\\n\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0,0,0,1);\\n v_color = vec4(0.5,1,0,1);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// plants\n\n#define PI radians(180.)\n\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0,0,0,1);\n v_color = vec4(0.5,1,0,1);\n}" + }, "screenshotURL": "data/images/images-s1p6byvwnmgx2y5c5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dGs6fdtenLWLjmBEE/art.json b/art/dGs6fdtenLWLjmBEE/art.json index ef2e7662..331aff04 100644 --- a/art/dGs6fdtenLWLjmBEE/art.json +++ b/art/dGs6fdtenLWLjmBEE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvec3 getColor(int index)\\n{\\n\\tif (index == 0)\\n\\t\\treturn vec3(0.0, 0.0, 0.0);\\n\\tif (index == 1)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\tif (index == 2)\\n\\t\\treturn vec3(0.0, 0.0, 0.0);\\n\\tif (index == 3)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\tif (index == 4)\\n\\t\\treturn vec3(0.0, 0.0, 0.0);\\n\\tif (index == 5)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\tif (index == 6)\\n\\t\\treturn vec3(0.0, 0.0, 0.);\\n\\tif (index == 7)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\t\\n}\\n\\n\\nvoid main ()\\n{\\n //float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n if(position.y>1.)\\n position.y = 2.-position.y;\\n\\t\\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\tj *= 1.;\\n\\tj = mod(j + time/2., 1.0);\\n\\t\\n\\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\\n\\ti = mod(position.y * colorCount * j, i / j);\\n\\ti *= 4.00;\\n\\t\\n\\ti = mod(i - 40.*time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( getColor(int(i)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvec3 getColor(int index)\n{\n\tif (index == 0)\n\t\treturn vec3(0.0, 0.0, 0.0);\n\tif (index == 1)\n\t\treturn vec3(1., 1., 1.);\n\tif (index == 2)\n\t\treturn vec3(0.0, 0.0, 0.0);\n\tif (index == 3)\n\t\treturn vec3(1., 1., 1.);\n\tif (index == 4)\n\t\treturn vec3(0.0, 0.0, 0.0);\n\tif (index == 5)\n\t\treturn vec3(1., 1., 1.);\n\tif (index == 6)\n\t\treturn vec3(0.0, 0.0, 0.);\n\tif (index == 7)\n\t\treturn vec3(1., 1., 1.);\n\t\n}\n\n\nvoid main ()\n{\n //float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n if(position.y>1.)\n position.y = 2.-position.y;\n\t\n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\tj *= 1.;\n\tj = mod(j + time/2., 1.0);\n\t\n\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\n\ti = mod(position.y * colorCount * j, i / j);\n\ti *= 4.00;\n\t\n\ti = mod(i - 40.*time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( getColor(int(i)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-unwvz4hdgep53g419-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dJ7LxrXfRuAz7PLaC/art.json b/art/dJ7LxrXfRuAz7PLaC/art.json index 18ef5e50..a7da452e 100644 --- a/art/dJ7LxrXfRuAz7PLaC/art.json +++ b/art/dJ7LxrXfRuAz7PLaC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":13790,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define P1 3.//KParameter0 0.>>6.\\n\\n\\n\\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 1, 0,\\n 0, 0, 0.1, 0,\\n 0, 0, 2, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1.2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], -.1, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0.1, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 6.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.01;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5,1.30 * P1, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 8.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 2.);\\n float oddSlice = mod(sliceId, 12.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 1.5) * 4.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 40;\\n float snd = 0.01;\\n float totalSnd = 0.14;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 2);\\n float spx = hash(spf *- 0.123);\\n float spy = hash(spf / .317);\\n float sps = hash(spf - 3.411);\\n \\n float sds = distance(vec2(u*step(11.9,snd*2.), -v+snd), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.111, sps), sds * .09)).a *\\n mix(2.95, 1.7*2., sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 0.4, 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n float sc = pow(snd, 4.) * 0.1 +snd *\\n oddSlice * 0.03;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 0.61));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0.10));\\n mat *= uniformScale(0.2 * sc * 5. / across);\\n mat *= rotZ(snd * 2. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.17, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 1.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 13790, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define P1 3.//KParameter0 0.>>6.\n\n\n\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 1, 0,\n 0, 0, 0.1, 0,\n 0, 0, 2, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1.2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], -.1, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0.1, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 6.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.01;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5,1.30 * P1, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 8.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 2.);\n float oddSlice = mod(sliceId, 12.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 1.5) * 4.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 40;\n float snd = 0.01;\n float totalSnd = 0.14;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 2);\n float spx = hash(spf *- 0.123);\n float spy = hash(spf / .317);\n float sps = hash(spf - 3.411);\n \n float sds = distance(vec2(u*step(11.9,snd*2.), -v+snd), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.111, sps), sds * .09)).a *\n mix(2.95, 1.7*2., sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 0.4, 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n float sc = pow(snd, 4.) * 0.1 +snd *\n oddSlice * 0.03;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 0.61));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0.10));\n mat *= uniformScale(0.2 * sc * 5. / across);\n mat *= rotZ(snd * 2. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = sin(time + x * y * .02) * 5.; \n \n float pump = step(0.17, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 1.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-0ngnjysucizv9vrn3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dJQHunZMaGr5ssiey/art.json b/art/dJQHunZMaGr5ssiey/art.json index c2c8e523..77a75476 100644 --- a/art/dJQHunZMaGr5ssiey/art.json +++ b/art/dJQHunZMaGr5ssiey/art.json @@ -11,7 +11,19 @@ "origId": "WgAGyf4sc6LfsH2bd", "name": "squiro", "username": "-anon-", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n// float offset = 0.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.21 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.9;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n// float oS = .1 + innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n// float offset = 0.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.21 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.9;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n// float oS = .1 + innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ab40lwjcoxyq4yixl-thumbnail.jpg", "views": { "$numberInt": "108" diff --git a/art/dJTCRw4XXeXH2rYMd/art.json b/art/dJTCRw4XXeXH2rYMd/art.json index c5f236b5..555fdbd5 100644 --- a/art/dJTCRw4XXeXH2rYMd/art.json +++ b/art/dJTCRw4XXeXH2rYMd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":10531,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n#define KP0 mouse.y\\n#define KP1 mouse.x\\n#define zoom 1.0-(mouse.x+mouse.y)\\n#define KP2 0.4\\t\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\n\\nconst vec3 masker = vec3(MASK,2.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 2., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \\ntriangles[ 2]=vec4( mouse.x*91.0, 2112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( mouse.y*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 10., 42.0, 1326.0, 4.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 10531, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n#define KP0 mouse.y\n#define KP1 mouse.x\n#define zoom 1.0-(mouse.x+mouse.y)\n#define KP2 0.4\t\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\n\nconst vec3 masker = vec3(MASK,2.0,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 2., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \ntriangles[ 2]=vec4( mouse.x*91.0, 2112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \ntriangles[ 4]=vec4( mouse.y*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 10., 42.0, 1326.0, 4.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-aa1i172l5fq3griyt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dJZ8nxPG2JKPBwHut/art.json b/art/dJZ8nxPG2JKPBwHut/art.json index d71edb5f..d9285ea7 100644 --- a/art/dJZ8nxPG2JKPBwHut/art.json +++ b/art/dJZ8nxPG2JKPBwHut/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":8781,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/re_gain/alert\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Based on @greggman's contributions => https://goo.gl/jyVxLc\\n// @Re_gain aka Daff: https://soundcloud.com/re_gain\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x,clamp(c.yz, 0.0, 1.0));\\n vec4 k= vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p= abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y); \\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float munCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / munCircleSegments * PI * 2.;\\n float c = sin(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n// Based on @greggman's contributions => https://goo.gl/jyVxLc \\n// @Re_gain aka Daff: https://soundcloud.com/re_gain\\nvoid main() {\\n time*33.;\\n \\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * .02;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod (sliceId, .2);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId*PI, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across -2.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;\\n \\n float ux = u * 3.-.1+ xoff;\\n float vy = v * 2.- 1. + yoff;\\n \\n\\n \\n float su = abs(u - 0.15) * 2.2;\\n float sv = abs(v - 0.15) * 2.2;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2 (au * 0.05 , av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd, 5.) * mix (1.,11.2*snd, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1, aspect,.1)); \\n mat *= rotZ(time * 0.1+snd);\\n mat *= rotY(time*0.0000009);\\n mat *= rotX(sin(snd)* sin(sc));\\n mat *= trans(vec3(ux, vy, 0)*snd); \\n mat *= rotZ(snd * ux);\\n mat *= uniformScale(0.003*snd);\\n\\n \\n float soff = 1.; \\n \\n gl_Position = mat*pos;\\n gl_Position +=vec4(su/snd,sv-snd,0.,1); \\n gl_Position *=aspect;\\n \\n float pump = step(1.8, snd);\\n float hue = u *1.1 * snd *0.666/ snd*time *.0001;\\n float sat = mix(time, snd, pump);\\n float val = mix(1., pow(snd + 0.5, 5.), pump);\\n \\n hue = hue + pump * oddSlice *0.5 + pump*.33;\\n val += oddSlice - pump;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat , val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 8781, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/re_gain/alert", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Based on @greggman's contributions => https://goo.gl/jyVxLc\n// @Re_gain aka Daff: https://soundcloud.com/re_gain\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x,clamp(c.yz, 0.0, 1.0));\n vec4 k= vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p= abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y); \n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float munCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / munCircleSegments * PI * 2.;\n float c = sin(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n// Based on @greggman's contributions => https://goo.gl/jyVxLc \n// @Re_gain aka Daff: https://soundcloud.com/re_gain\nvoid main() {\n time*33.;\n \n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * .02;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod (sliceId, .2);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId*PI, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across -2.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = 0.;\n \n float ux = u * 3.-.1+ xoff;\n float vy = v * 2.- 1. + yoff;\n \n\n \n float su = abs(u - 0.15) * 2.2;\n float sv = abs(v - 0.15) * 2.2;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2 (au * 0.05 , av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd, 5.) * mix (1.,11.2*snd, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1, aspect,.1)); \n mat *= rotZ(time * 0.1+snd);\n mat *= rotY(time*0.0000009);\n mat *= rotX(sin(snd)* sin(sc));\n mat *= trans(vec3(ux, vy, 0)*snd); \n mat *= rotZ(snd * ux);\n mat *= uniformScale(0.003*snd);\n\n \n float soff = 1.; \n \n gl_Position = mat*pos;\n gl_Position +=vec4(su/snd,sv-snd,0.,1); \n gl_Position *=aspect;\n \n float pump = step(1.8, snd);\n float hue = u *1.1 * snd *0.666/ snd*time *.0001;\n float sat = mix(time, snd, pump);\n float val = mix(1., pow(snd + 0.5, 5.), pump);\n \n hue = hue + pump * oddSlice *0.5 + pump*.33;\n val += oddSlice - pump;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat , val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-gz9xmdxpsjg6ulyfm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dKGqajerwQQwap65w/art.json b/art/dKGqajerwQQwap65w/art.json index 403f719a..37f0ab55 100644 --- a/art/dKGqajerwQQwap65w/art.json +++ b/art/dKGqajerwQQwap65w/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "toneoperator", "avatarUrl": "https://secure.gravatar.com/avatar/007f8d76b1bcea19c9a1475bbe1b165f?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(500.)\\n#define NUM_SEGMENTS 31.0\\n#define NUM_POINTS (NUM_SEGMENTS * 65.0)\\n#define STEP 1.30\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 30.0, 1.0));\\n vec4 K = vec4( 1.6, 2.70 / 3.0, 17.0 / 65.0, 73.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 68.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 17.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = sin(time * angle) * radius;\\n float s = cos(angle - time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.007) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.00901) * cos(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(500.)\n#define NUM_SEGMENTS 31.0\n#define NUM_POINTS (NUM_SEGMENTS * 65.0)\n#define STEP 1.30\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 30.0, 1.0));\n vec4 K = vec4( 1.6, 2.70 / 3.0, 17.0 / 65.0, 73.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 68.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 17.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = sin(time * angle) * radius;\n float s = cos(angle - time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.007) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.00901) * cos(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ap3mfj975nq5w1b8f-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dLkqdiAkHgpKZWw9c/art.json b/art/dLkqdiAkHgpKZWw9c/art.json index fd5bfad1..d7b5d1fe 100644 --- a/art/dLkqdiAkHgpKZWw9c/art.json +++ b/art/dLkqdiAkHgpKZWw9c/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":78100,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0.2,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, -1,\\n 0.3, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 - b08 * a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 / a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 / a32 * b00,\\n a20 / b03 - a21 * b01 + a22 * b01) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -0.2,\\n yAxis, 0.03,\\n zAxis, 0.002,\\n -dot(xAxis, eye /84.), -dot(yAxis, eye -2.), -dot(zAxis * mouse.x, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.2 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 0.2, vy);\\n float a = mix(start, end, u) * PI * 13. - PI * 1.20;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = -0.2;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-2., 1., step(0.5, mod(circleId, 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.5) / 2.6,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.4) / 2.1,\\n cgv) * 0.7;\\n\\n float tm = time - cgv * 1.2;\\n float su = hash(groupId);\\n float snd2 = 0.1; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.25)).a;\\n \\n\\n vec3 pos;\\n float inner = .95;\\n float start = 1.2;\\n float end = 5.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 0.9, 0.01) * .3*snd);\\n mat *= rotZ(time * 0.1 * mix(1., 0.3, mod(groupId, 3.)));\\n mat *= trans(vec3(offset));\\n float gt = time - gv * PI * 9.;\\n mat *= trans(vec3(sin(gt), cos(gt), 1.31) * .095 * (2.3 - cgv * 1.25));\\n mat *= uniformScale(0.13 * cgv + snd * 1.1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 0.83 + snd);\\n gl_PointSize = 4.;\\n \\n float pump = step(1.5, snd);\\n float hue = 1. + cgId * 1.6 + pump * 10.7;\\n float sat = mod(cgId, 1.) + pump;\\n float val = 1. - mod(cgId + .5, 3.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\\n v_color.rgb = mix(v_color.rgb, vec3(0.84)+pump, 5.*pump);\\n v_color.rgb *= v_color.a /1./snd;\\n}\\n\\n\"}", + "settings": { + "num": 78100, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0.2,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, -1,\n 0.3, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 - b08 * a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 / a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 / a32 * b00,\n a20 / b03 - a21 * b01 + a22 * b01) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -0.2,\n yAxis, 0.03,\n zAxis, 0.002,\n -dot(xAxis, eye /84.), -dot(yAxis, eye -2.), -dot(zAxis * mouse.x, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.2 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 0.2, vy);\n float a = mix(start, end, u) * PI * 13. - PI * 1.20;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = -0.2;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-2., 1., step(0.5, mod(circleId, 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.5) / 2.6,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.4) / 2.1,\n cgv) * 0.7;\n\n float tm = time - cgv * 1.2;\n float su = hash(groupId);\n float snd2 = 0.1; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.25)).a;\n \n\n vec3 pos;\n float inner = .95;\n float start = 1.2;\n float end = 5.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 0.9, 0.01) * .3*snd);\n mat *= rotZ(time * 0.1 * mix(1., 0.3, mod(groupId, 3.)));\n mat *= trans(vec3(offset));\n float gt = time - gv * PI * 9.;\n mat *= trans(vec3(sin(gt), cos(gt), 1.31) * .095 * (2.3 - cgv * 1.25));\n mat *= uniformScale(0.13 * cgv + snd * 1.1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 0.83 + snd);\n gl_PointSize = 4.;\n \n float pump = step(1.5, snd);\n float hue = 1. + cgId * 1.6 + pump * 10.7;\n float sat = mod(cgId, 1.) + pump;\n float val = 1. - mod(cgId + .5, 3.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\n v_color.rgb = mix(v_color.rgb, vec3(0.84)+pump, 5.*pump);\n v_color.rgb *= v_color.a /1./snd;\n}\n\n" + }, "screenshotURL": "data/images/images-dtw6vhxh668yact8l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dLyBG6jnNceKnhqbB/art.json b/art/dLyBG6jnNceKnhqbB/art.json index d21e5b4c..08d1319d 100644 --- a/art/dLyBG6jnNceKnhqbB/art.json +++ b/art/dLyBG6jnNceKnhqbB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.4980392156862745,0.4980392156862745,0.4980392156862745,1],\"shader\":\"#define PI radians(180.)\\n#define TAU (2. * PI)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nmat4 rotZ() {\\n float s = sin(time);\\n float c = cos(time);\\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY() {\\n float val = time * 20.;\\n float s = sin(radians(val));\\n float c = cos(radians(val));\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 cameraFrustum = mat4(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, -1,\\n 0, 0, 0, 1);\\n\\nvoid main() {\\n mat4 cameraTransform = mat4(\\n 1, 0, 0, 0,\\n \\t0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n cameraTransform = rotY() * cameraTransform;\\n \\n float triId = floor(vertexId / 3.);\\n float triIdx = mod(vertexId, 3.);\\n \\n vec4 triCenter = vec4(triId * 2., 0, 0, 1);\\n vec4 triPos = rotZ() * vec4(sin(triIdx * radians(120.)), cos(triIdx * radians(120.)), 0, 1);\\n vec4 vPos = triCenter + triPos;\\n \\n gl_Position = (cameraFrustum * cameraTransform * vPos);\\n v_color = vec4(mod(vertexId, 3.), mod(vertexId + 1., 3.), mod(vertexId + 2., 3.), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.4980392156862745, + 0.4980392156862745, + 0.4980392156862745, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU (2. * PI)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nmat4 rotZ() {\n float s = sin(time);\n float c = cos(time);\n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY() {\n float val = time * 20.;\n float s = sin(radians(val));\n float c = cos(radians(val));\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 cameraFrustum = mat4(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, -1,\n 0, 0, 0, 1);\n\nvoid main() {\n mat4 cameraTransform = mat4(\n 1, 0, 0, 0,\n \t0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n cameraTransform = rotY() * cameraTransform;\n \n float triId = floor(vertexId / 3.);\n float triIdx = mod(vertexId, 3.);\n \n vec4 triCenter = vec4(triId * 2., 0, 0, 1);\n vec4 triPos = rotZ() * vec4(sin(triIdx * radians(120.)), cos(triIdx * radians(120.)), 0, 1);\n vec4 vPos = triCenter + triPos;\n \n gl_Position = (cameraFrustum * cameraTransform * vPos);\n v_color = vec4(mod(vertexId, 3.), mod(vertexId + 1., 3.), mod(vertexId + 2., 3.), 1);\n}" + }, "screenshotURL": "data/images/images-p72wbrg8qs8znhvzt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dMRx2bNxuYsRKSHKt/art.json b/art/dMRx2bNxuYsRKSHKt/art.json index fd17657d..4c395aa3 100644 --- a/art/dMRx2bNxuYsRKSHKt/art.json +++ b/art/dMRx2bNxuYsRKSHKt/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20001,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 20000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n // Good values for f:\\n // 0.0 in bass is always around 1\\n // 0.5 is in the mids, goes with music\\n // 1.0 is in the highs always 0\\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float phi = TWO_PI * t * 13.0;\\n float theta = TWO_PI * t * 17.0;\\n float r0 = 0.5;\\n float r1 = 0.4;\\n \\n phi += cos(theta * 3.0) * 0.3;\\n theta += sin(phi * 5.0) * 0.3;\\n r0 += cos(phi) * 0.03;\\n r1 += sin(theta * 3.0 + phi) * 0.05;\\n \\n phi += sin(theta * 3.0) * r0 * 1.0;\\n theta += cos(phi * 2.0) * r1 * 1.0;\\n r0 += sin(theta * 5.0 + phi * 1.0) * 0.03;\\n r1 += cos(phi * 2.0) * 0.07;\\n r0 += -cos(theta) * 0.1 * (1.0 + 0.3 * cos(phi * 13.0));\\n \\n phi += cos(theta * 3.0) * 0.2;\\n theta += sin(phi * 7.0) * 0.3;\\n r1 = r1 * (1.0 + 0.3 * sin(t * TWO_PI * 19.0) * (1.0 + 0.3 * cos(theta)));\\n \\n float x0 = cos(phi);\\n float y0 = sin(phi);\\n \\n float x1 = cos(theta);\\n float y1 = sin(theta);\\n \\n float x = x0 * (r0 + x1 * r1);\\n float y = y0 * (r0 + x1 * r1);\\n float z = y1 * r1;\\n \\n float rr = 1.0 / sqrt(x * x + y * y + z * z);\\n float rt = sin(t * TWO_PI * 19.0);\\n float f = 0.7 + 0.3 * (rr + rt * 0.2);\\n x *= f;\\n y *= f;\\n z *= f;\\n \\n return vec3(x, y, z);\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\\n \\n float power = 0.0;\\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\\n power = sqrt(power);\\n \\n\\n float mix1 = getSound(r, 0.0) - r;\\n float mix2 = power - r + 0.3;\\n float mixt = mix1 * 3.0 + mix2 * 10.0;\\n \\n float rwave = sin(mixt * 0.8);\\n float tpulse = sin((time * 0.05 + t * 100.0) * TWO_PI + mixt * 0.05);\\n float trpulse = sin(r * 0.75 * TWO_PI - time);\\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\\n \\n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\\n \\n \\n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\\n float s = 1.0 - ((1.0 - rpulse) * pulse);\\n\\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\\n}\"}", + "settings": { + "num": 20001, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 20000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n // Good values for f:\n // 0.0 in bass is always around 1\n // 0.5 is in the mids, goes with music\n // 1.0 is in the highs always 0\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\n}\n\nvec3 curvePos(float t) {\n float phi = TWO_PI * t * 13.0;\n float theta = TWO_PI * t * 17.0;\n float r0 = 0.5;\n float r1 = 0.4;\n \n phi += cos(theta * 3.0) * 0.3;\n theta += sin(phi * 5.0) * 0.3;\n r0 += cos(phi) * 0.03;\n r1 += sin(theta * 3.0 + phi) * 0.05;\n \n phi += sin(theta * 3.0) * r0 * 1.0;\n theta += cos(phi * 2.0) * r1 * 1.0;\n r0 += sin(theta * 5.0 + phi * 1.0) * 0.03;\n r1 += cos(phi * 2.0) * 0.07;\n r0 += -cos(theta) * 0.1 * (1.0 + 0.3 * cos(phi * 13.0));\n \n phi += cos(theta * 3.0) * 0.2;\n theta += sin(phi * 7.0) * 0.3;\n r1 = r1 * (1.0 + 0.3 * sin(t * TWO_PI * 19.0) * (1.0 + 0.3 * cos(theta)));\n \n float x0 = cos(phi);\n float y0 = sin(phi);\n \n float x1 = cos(theta);\n float y1 = sin(theta);\n \n float x = x0 * (r0 + x1 * r1);\n float y = y0 * (r0 + x1 * r1);\n float z = y1 * r1;\n \n float rr = 1.0 / sqrt(x * x + y * y + z * z);\n float rt = sin(t * TWO_PI * 19.0);\n float f = 0.7 + 0.3 * (rr + rt * 0.2);\n x *= f;\n y *= f;\n z *= f;\n \n return vec3(x, y, z);\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\n \n float power = 0.0;\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\n power = sqrt(power);\n \n\n float mix1 = getSound(r, 0.0) - r;\n float mix2 = power - r + 0.3;\n float mixt = mix1 * 3.0 + mix2 * 10.0;\n \n float rwave = sin(mixt * 0.8);\n float tpulse = sin((time * 0.05 + t * 100.0) * TWO_PI + mixt * 0.05);\n float trpulse = sin(r * 0.75 * TWO_PI - time);\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\n \n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\n \n \n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\n float s = 1.0 - ((1.0 - rpulse) * pulse);\n\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\n}" + }, "screenshotURL": "data/images/images-2igcj3m8r2wfr6io0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dMZsJyyPW2EgjrH4P/art.json b/art/dMZsJyyPW2EgjrH4P/art.json index 11c164b1..6a3529e4 100644 --- a/art/dMZsJyyPW2EgjrH4P/art.json +++ b/art/dMZsJyyPW2EgjrH4P/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "철짜", "avatarUrl": "https://lh5.googleusercontent.com/-Ms9fjf33Cc0/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reZGVnMGsJP55FG1NwfwQX9im-L6Q/mo/photo.jpg", - "settings": "{\"num\":950,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.48627450980392156,0.48627450980392156,0.48627450980392156,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t = chulseung.lee\\nAssignment Name/Number = Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t= CS230\\nTerm\\t\\t\\t\\t\\t= Spring 2019\\n------------------------------------------------------------------------*/\\n#define PI 3.1415926\\n\\nvoid main()\\n{\\n float radian = vertexId / (vertexCount) * 3.0 * PI;\\n radian *= 3.0;\\n \\n gl_Position = vec4( cos(radian * mouse.x), sin(radian * mouse.y), 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= abs(mouse.x)+abs(mouse.y);\\n \\n v_color = vec4(sin(time*100.0), tan(time*5.0), cos(time*5.0), 1);\\n}\"}", + "settings": { + "num": 950, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.48627450980392156, + 0.48627450980392156, + 0.48627450980392156, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t = chulseung.lee\nAssignment Name/Number = Shader/3 (Extra Credit)\nCourse Name\t\t\t\t= CS230\nTerm\t\t\t\t\t= Spring 2019\n------------------------------------------------------------------------*/\n#define PI 3.1415926\n\nvoid main()\n{\n float radian = vertexId / (vertexCount) * 3.0 * PI;\n radian *= 3.0;\n \n gl_Position = vec4( cos(radian * mouse.x), sin(radian * mouse.y), 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= abs(mouse.x)+abs(mouse.y);\n \n v_color = vec4(sin(time*100.0), tan(time*5.0), cos(time*5.0), 1);\n}" + }, "screenshotURL": "data/images/images-h7lwkokzpmjeb0e9c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dMsa7ScyoyExY3Cxk/art.json b/art/dMsa7ScyoyExY3Cxk/art.json index 1934dac3..42b3b854 100644 --- a/art/dMsa7ScyoyExY3Cxk/art.json +++ b/art/dMsa7ScyoyExY3Cxk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":21600,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/lazerhawk/skull-and-shark\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// _ _ _ _ \\n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \\n// \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__/ _` | '__| __|\\n// \\\\ V / __/ | | || __/> <\\\\__ \\\\ | | | (_| | (_| | __/ | | (_| | | | |_ \\n// \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\\\__,_|_| \\\\__|\\n//\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\\n \\n float across = 32.;\\n float down = 20.;\\n float u = mod(fCubeId, across) / across;\\n float v = floor(fCubeId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), abs(v - 0.5) * 0.5)).a;\\n \\n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.32;\\n \\n mat = ident();\\n \\tmat *= rotZ(lng);\\n \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= uniformScale(fScale);\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n \\n float s3 = pow(snd + 0.1, 50.);\\n vCubeCol = mix(hsv2rgb(vec3(1,s3,s3)), vec3(0,0,0), pow(s2, 40.0)); \\n vCubeCol = mix(vCubeCol, vec3(1,1,1), step(0.95,s2));\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n mat4 mCube;\\n vec3 vCubeCol;\\n\\n GetCubePosition( fCubeId, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 21600, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/lazerhawk/skull-and-shark", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// _ _ _ _ \n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \n// \\ \\ / / _ \\ '__| __/ _ \\ \\/ / __| '_ \\ / _` |/ _` |/ _ \\ '__/ _` | '__| __|\n// \\ V / __/ | | || __/> <\\__ \\ | | | (_| | (_| | __/ | | (_| | | | |_ \n// \\_/ \\___|_| \\__\\___/_/\\_\\___/_| |_|\\__,_|\\__,_|\\___|_| \\__,_|_| \\__|\n//\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\n \n float across = 32.;\n float down = 20.;\n float u = mod(fCubeId, across) / across;\n float v = floor(fCubeId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), abs(v - 0.5) * 0.5)).a;\n \n vCubeOrigin.z += pow(snd, 10.0) * 10.0;\n float fScale = mix(0.1, 0.6, sin(lat)) * snd * 1.32;\n \n mat = ident();\n \tmat *= rotZ(lng);\n \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= uniformScale(fScale);\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n \n float s3 = pow(snd + 0.1, 50.);\n vCubeCol = mix(hsv2rgb(vec3(1,s3,s3)), vec3(0,0,0), pow(s2, 40.0)); \n vCubeCol = mix(vCubeCol, vec3(1,1,1), step(0.95,s2));\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n mat4 mCube;\n vec3 vCubeCol;\n\n GetCubePosition( fCubeId, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-ijxhhjcynuh1lm0wm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dN7ijsBkvACZ3Nv8B/art.json b/art/dN7ijsBkvACZ3Nv8B/art.json index 3d06b14f..4a4e2124 100644 --- a/art/dN7ijsBkvACZ3Nv8B/art.json +++ b/art/dN7ijsBkvACZ3Nv8B/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// hash functions\\n\\n\\n\\nvoid main() {\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// hash functions\n\n\n\nvoid main() {\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-q0m9p48f9qc8h4cx6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dPFqiAgc3g3evvDtS/art.json b/art/dPFqiAgc3g3evvDtS/art.json index caee765d..5a3c9171 100644 --- a/art/dPFqiAgc3g3evvDtS/art.json +++ b/art/dPFqiAgc3g3evvDtS/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "floppafilms google emails", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocIuaBwUR9c6Zno3BImNS0s8sMlZcGj0gBrDxanr22L0IECUEO0=s96-c", - "settings": "{\"num\":28423,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user-458550313/whats-up\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nV V SSSSSS A\\n V V S A A\\n V V S A A\\n V V S AAAAAAA\\n V SSSSS A A\\n\\nvsa is awesome\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\nvoid main() {\\n\\tvec3 cameraEyeVec = vec3(0,0,0);\\n \\tfloat snd = texture2D(sound,vec2(mix(0.1,0.25,time),(vertexId/vertexCount)*.2)).a;\\n \\tv_color = vec4(1,snd,0,1);\\n}\"}", + "settings": { + "num": 28423, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user-458550313/whats-up", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nV V SSSSSS A\n V V S A A\n V V S A A\n V V S AAAAAAA\n V SSSSS A A\n\nvsa is awesome\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\nvoid main() {\n\tvec3 cameraEyeVec = vec3(0,0,0);\n \tfloat snd = texture2D(sound,vec2(mix(0.1,0.25,time),(vertexId/vertexCount)*.2)).a;\n \tv_color = vec4(1,snd,0,1);\n}" + }, "screenshotURL": "data/images/images-mxu8nfobf8yoatw3z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dPkbvz9nuwNJRn9oB/art.json b/art/dPkbvz9nuwNJRn9oB/art.json index 0fb7e2e8..26c34657 100644 --- a/art/dPkbvz9nuwNJRn9oB/art.json +++ b/art/dPkbvz9nuwNJRn9oB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46121.0\\nvec2 vertexResolution = resolution;\\n// Author: @amagitakayosi\\n// Alternate version by Laura and dennis family\\n//#ifdef GL_ES\\n//precision mediump float;\\n//#endif \\n\\n//#extension GL_OES_standard_derivatives : enable\\n\\n//uniform float time;\\n//uniform vec2 vertexResolution;\\n\\nvec2 rot(in vec2 uv, in float t) {\\n float c = sin(t), s = cos(t);\\n\\tuv.x=uv.x+.1*sin(t);\\n\\tuv.y=uv.y+.1*cos(t);\\n return mat2(c, -s, s, c) * uv;\\n}\\n\\nvoid main() {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n vec2 p = (simFragCoord.xy * 2. - vertexResolution) / min(vertexResolution.x, vertexResolution.y);\\n\\n p = p * (length(p) + sin(time * 1.4) - .2);\\n p = rot(p + .1, time + sin(time + (length(p) + 3.) * 4.) * .4);\\n\\n v_color = vec4(\\n sin(p.x * 5. + sin(p.x * 9. + time + 9.)) + cos(p.y * 6. + sin(p.y * 5. + time)),\\n sin(p.x * 5. + sin(p.y * 9. + time + 9.)) + cos(p.y * 5. + sin(p.x * 3. + time)),\\n sin(p.x * 5. + sin(p.x * 9. + time + 9.)) + cos(p.y * 1. + sin(p.y * 1. + time)),\\n 1\\n );\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46121.0\nvec2 vertexResolution = resolution;\n// Author: @amagitakayosi\n// Alternate version by Laura and dennis family\n//#ifdef GL_ES\n//precision mediump float;\n//#endif \n\n//#extension GL_OES_standard_derivatives : enable\n\n//uniform float time;\n//uniform vec2 vertexResolution;\n\nvec2 rot(in vec2 uv, in float t) {\n float c = sin(t), s = cos(t);\n\tuv.x=uv.x+.1*sin(t);\n\tuv.y=uv.y+.1*cos(t);\n return mat2(c, -s, s, c) * uv;\n}\n\nvoid main() {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n vec2 p = (simFragCoord.xy * 2. - vertexResolution) / min(vertexResolution.x, vertexResolution.y);\n\n p = p * (length(p) + sin(time * 1.4) - .2);\n p = rot(p + .1, time + sin(time + (length(p) + 3.) * 4.) * .4);\n\n v_color = vec4(\n sin(p.x * 5. + sin(p.x * 9. + time + 9.)) + cos(p.y * 6. + sin(p.y * 5. + time)),\n sin(p.x * 5. + sin(p.y * 9. + time + 9.)) + cos(p.y * 5. + sin(p.x * 3. + time)),\n sin(p.x * 5. + sin(p.x * 9. + time + 9.)) + cos(p.y * 1. + sin(p.y * 1. + time)),\n 1\n );\n}" + }, "screenshotURL": "data/images/images-gg7rgjef057qczmyz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dPsnyuwF6HxdEJMAd/art.json b/art/dPsnyuwF6HxdEJMAd/art.json index d11ddd59..5851062f 100644 --- a/art/dPsnyuwF6HxdEJMAd/art.json +++ b/art/dPsnyuwF6HxdEJMAd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n#define factor0 9.//KParameter 1.>>20.\\n#define factor1 0.1//KParameter .1>>1.\\n#define timeFactor 1.//KParameter 1.>>10.\\n//#define ANGLE_DELTA 0.02\\n//#define XOFF .7\\n\\nfloat b = time*timeFactor, g, v, q;\\nvec4 s(vec2 v) {\\n g = length(v);\\n q = abs(sin((atan(v.g, v.r) - g + b) * factor0) * factor1) + .1;\\n return min(vec4(1.), vec4(.05 / abs(q - g / 3.), .04 / abs(q - g / 2.), .03 / abs(q - g * .7), 1.));\\n}\\nfloat n(vec3 v) {\\n return 1. - dot(abs(v), vec3(0., 1., 0.)) - length(s(v.rb).rgb) / 2. * sin(b * 2.) +\\n (sin(5. * (v.b + b)) + sin(5. * (v.r + b))) * .1;\\n}\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by simFragCoord \\n //replace gl_FragColor by v_color\\n //replace iResolution by resolution\\n //replace resolution by vertexResolution\\n \\n vec3 m = vec3(-1. + 2. * (simFragCoord.rg /\\n vertexResolution), 1.), a = vec3(0., 0., -2.);\\n for (int r = 0; r < 55; r += 1) g = n(a + m * v), v += g * .125;\\n v_color = vec4(v / 2.) * s((v * m + a).rb) + v * .1 * vec4(1., 2., 3., 4.) / 2. * n(v * m + a);\\n\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n#define factor0 9.//KParameter 1.>>20.\n#define factor1 0.1//KParameter .1>>1.\n#define timeFactor 1.//KParameter 1.>>10.\n//#define ANGLE_DELTA 0.02\n//#define XOFF .7\n\nfloat b = time*timeFactor, g, v, q;\nvec4 s(vec2 v) {\n g = length(v);\n q = abs(sin((atan(v.g, v.r) - g + b) * factor0) * factor1) + .1;\n return min(vec4(1.), vec4(.05 / abs(q - g / 3.), .04 / abs(q - g / 2.), .03 / abs(q - g * .7), 1.));\n}\nfloat n(vec3 v) {\n return 1. - dot(abs(v), vec3(0., 1., 0.)) - length(s(v.rb).rgb) / 2. * sin(b * 2.) +\n (sin(5. * (v.b + b)) + sin(5. * (v.r + b))) * .1;\n}\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by simFragCoord \n //replace gl_FragColor by v_color\n //replace iResolution by resolution\n //replace resolution by vertexResolution\n \n vec3 m = vec3(-1. + 2. * (simFragCoord.rg /\n vertexResolution), 1.), a = vec3(0., 0., -2.);\n for (int r = 0; r < 55; r += 1) g = n(a + m * v), v += g * .125;\n v_color = vec4(v / 2.) * s((v * m + a).rb) + v * .1 * vec4(1., 2., 3., 4.) / 2. * n(v * m + a);\n\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-qmohckdrz77nxdgmg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dQM2bdFTuo6XKyJ9B/art.json b/art/dQM2bdFTuo6XKyJ9B/art.json index 5ee9a6b3..4fc18456 100644 --- a/art/dQM2bdFTuo6XKyJ9B/art.json +++ b/art/dQM2bdFTuo6XKyJ9B/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n id = mod(id, 16.0);\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\nvec4 getPart0(float id) {\\n if (id == 00.) return hypercube(0.);\\n if (id == 01.) return hypercube(3.);\\n if (id == 02.) return hypercube(3.);\\n if (id == 03.) return hypercube(8.);\\n if (id == 04.) return hypercube(8.);\\n if (id == 05.) return hypercube(2.);\\n if (id == 06.) return hypercube(2.);\\n if (id == 07.) return hypercube(0.);\\n}\\nvec4 getPart1(float id) {\\n if (id == 08.) return hypercube(0.);\\n if (id == 09.) return hypercube(4.);\\n if (id == 10.) return hypercube(4.);\\n if (id == 11.) return hypercube(10.);\\n if (id == 12.) return hypercube(10.);\\n if (id == 13.) return hypercube(3.);\\n if (id == 14.) return hypercube(8.);\\n if (id == 15.) return hypercube(13.);\\n}\\nvec4 getPart2(float id) {\\n if (id == 16.) return hypercube(2.);\\n if (id == 17.) return hypercube(9.);\\n if (id == 18.) return hypercube(4.);\\n if (id == 19.) return hypercube(9.);\\n if (id == 20.) return hypercube(10.);\\n if (id == 21.) return hypercube(13.);\\n if (id == 22.) return hypercube(13.);\\n if (id == 23.) return hypercube(9.);\\n}\\nvec4 getPart3(float id) {\\n if (id == 24.) return hypercube(1.);\\n if (id == 25.) return hypercube(6.);\\n if (id == 26.) return hypercube(6.);\\n if (id == 27.) return hypercube(11.);\\n if (id == 28.) return hypercube(11.);\\n if (id == 29.) return hypercube(5.);\\n if (id == 30.) return hypercube(5.);\\n if (id == 31.) return hypercube(1.);\\n}\\nvec4 getPart4(float id) {\\n if (id == 32.) return hypercube(7.);\\n if (id == 33.) return hypercube(14.);\\n if (id == 34.) return hypercube(14.);\\n if (id == 35.) return hypercube(15.);\\n if (id == 36.) return hypercube(15.);\\n if (id == 37.) return hypercube(12.);\\n if (id == 38.) return hypercube(12.);\\n if (id == 39.) return hypercube(7.);\\n}\\nvec4 getPart5(float id) {\\n if (id == 40.) return hypercube(1.);\\n if (id == 41.) return hypercube(7.);\\n if (id == 42.) return hypercube(6.);\\n if (id == 43.) return hypercube(14.);\\n if (id == 44.) return hypercube(11.);\\n if (id == 45.) return hypercube(15.);\\n if (id == 46.) return hypercube(5.);\\n if (id == 47.) return hypercube(12.);\\n}\\nvec4 getPart6(float id) {\\n if (id == 48.) return hypercube(2.);\\n if (id == 49.) return hypercube(5.);\\n if (id == 50.) return hypercube(8.);\\n if (id == 51.) return hypercube(11.);\\n if (id == 52.) return hypercube(13.);\\n if (id == 53.) return hypercube(15.);\\n if (id == 54.) return hypercube(9.);\\n if (id == 55.) return hypercube(12.);\\n}\\nvec4 getPart7(float id) {\\n if (id == 56.) return hypercube(0.);\\n if (id == 57.) return hypercube(1.);\\n if (id == 58.) return hypercube(3.);\\n if (id == 59.) return hypercube(6.);\\n if (id == 60.) return hypercube(10.);\\n if (id == 61.) return hypercube(14.);\\n if (id == 62.) return hypercube(4.);\\n if (id == 63.) return hypercube(7.);\\n}\\nvec4 hypercube_lines(float id)\\n{\\n id = mod(vertexId, 64.0);\\n \\n if (id >= 0. && id < 8.)\\n return getPart0(id);\\n if (id >= 8. && id < 16.)\\n return getPart1(id);\\n if (id >= 16. && id < 24.)\\n return getPart2(id);\\n if (id >= 24. && id < 32.)\\n return getPart3(id);\\n if (id >= 32. && id < 40.)\\n return getPart4(id);\\n if (id >= 40. && id < 48.)\\n return getPart5(id);\\n if (id >= 48. && id < 56.)\\n return getPart6(id);\\n if (id >= 56. && id < 64.)\\n return getPart7(id);\\n \\n return vec4(0);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 0, 0, 0);\\n vec4 up4 = vec4(0, 1, 0, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(3.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n float theta3 = 45.0 * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.1 * TAU*mouse.x);\\n t4 *= rot4xy(time * 0.05 * TAU);\\n vec4 v4 = hypercube_lines(vertexId);\\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3*mouse.y, 1.0, theta3, t3);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect*sin(mouse), 0, 1);\\n v_color = vec4(1,1,1, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n id = mod(id, 16.0);\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\nvec4 getPart0(float id) {\n if (id == 00.) return hypercube(0.);\n if (id == 01.) return hypercube(3.);\n if (id == 02.) return hypercube(3.);\n if (id == 03.) return hypercube(8.);\n if (id == 04.) return hypercube(8.);\n if (id == 05.) return hypercube(2.);\n if (id == 06.) return hypercube(2.);\n if (id == 07.) return hypercube(0.);\n}\nvec4 getPart1(float id) {\n if (id == 08.) return hypercube(0.);\n if (id == 09.) return hypercube(4.);\n if (id == 10.) return hypercube(4.);\n if (id == 11.) return hypercube(10.);\n if (id == 12.) return hypercube(10.);\n if (id == 13.) return hypercube(3.);\n if (id == 14.) return hypercube(8.);\n if (id == 15.) return hypercube(13.);\n}\nvec4 getPart2(float id) {\n if (id == 16.) return hypercube(2.);\n if (id == 17.) return hypercube(9.);\n if (id == 18.) return hypercube(4.);\n if (id == 19.) return hypercube(9.);\n if (id == 20.) return hypercube(10.);\n if (id == 21.) return hypercube(13.);\n if (id == 22.) return hypercube(13.);\n if (id == 23.) return hypercube(9.);\n}\nvec4 getPart3(float id) {\n if (id == 24.) return hypercube(1.);\n if (id == 25.) return hypercube(6.);\n if (id == 26.) return hypercube(6.);\n if (id == 27.) return hypercube(11.);\n if (id == 28.) return hypercube(11.);\n if (id == 29.) return hypercube(5.);\n if (id == 30.) return hypercube(5.);\n if (id == 31.) return hypercube(1.);\n}\nvec4 getPart4(float id) {\n if (id == 32.) return hypercube(7.);\n if (id == 33.) return hypercube(14.);\n if (id == 34.) return hypercube(14.);\n if (id == 35.) return hypercube(15.);\n if (id == 36.) return hypercube(15.);\n if (id == 37.) return hypercube(12.);\n if (id == 38.) return hypercube(12.);\n if (id == 39.) return hypercube(7.);\n}\nvec4 getPart5(float id) {\n if (id == 40.) return hypercube(1.);\n if (id == 41.) return hypercube(7.);\n if (id == 42.) return hypercube(6.);\n if (id == 43.) return hypercube(14.);\n if (id == 44.) return hypercube(11.);\n if (id == 45.) return hypercube(15.);\n if (id == 46.) return hypercube(5.);\n if (id == 47.) return hypercube(12.);\n}\nvec4 getPart6(float id) {\n if (id == 48.) return hypercube(2.);\n if (id == 49.) return hypercube(5.);\n if (id == 50.) return hypercube(8.);\n if (id == 51.) return hypercube(11.);\n if (id == 52.) return hypercube(13.);\n if (id == 53.) return hypercube(15.);\n if (id == 54.) return hypercube(9.);\n if (id == 55.) return hypercube(12.);\n}\nvec4 getPart7(float id) {\n if (id == 56.) return hypercube(0.);\n if (id == 57.) return hypercube(1.);\n if (id == 58.) return hypercube(3.);\n if (id == 59.) return hypercube(6.);\n if (id == 60.) return hypercube(10.);\n if (id == 61.) return hypercube(14.);\n if (id == 62.) return hypercube(4.);\n if (id == 63.) return hypercube(7.);\n}\nvec4 hypercube_lines(float id)\n{\n id = mod(vertexId, 64.0);\n \n if (id >= 0. && id < 8.)\n return getPart0(id);\n if (id >= 8. && id < 16.)\n return getPart1(id);\n if (id >= 16. && id < 24.)\n return getPart2(id);\n if (id >= 24. && id < 32.)\n return getPart3(id);\n if (id >= 32. && id < 40.)\n return getPart4(id);\n if (id >= 40. && id < 48.)\n return getPart5(id);\n if (id >= 48. && id < 56.)\n return getPart6(id);\n if (id >= 56. && id < 64.)\n return getPart7(id);\n \n return vec4(0);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 0, 0, 0);\n vec4 up4 = vec4(0, 1, 0, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(3.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n float theta3 = 45.0 * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.1 * TAU*mouse.x);\n t4 *= rot4xy(time * 0.05 * TAU);\n vec4 v4 = hypercube_lines(vertexId);\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3*mouse.y, 1.0, theta3, t3);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect*sin(mouse), 0, 1);\n v_color = vec4(1,1,1, 1);\n}" + }, "screenshotURL": "data/images/images-3v58l2e254bjseaxp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dT5B8hrDztDwvmxaK/art.json b/art/dT5B8hrDztDwvmxaK/art.json index 76b96b00..130c2f69 100644 --- a/art/dT5B8hrDztDwvmxaK/art.json +++ b/art/dT5B8hrDztDwvmxaK/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor( sqrt(vertexCount) );\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, sin(time) * .5 + .5);\\n \\n float soff = 0.; //sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(.8, snd);\\n float hue = u * 1. + snd * 0.2 + time * .2; //sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump); //mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor( sqrt(vertexCount) );\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, sin(time) * .5 + .5);\n \n float soff = 0.; //sin(time + x * y * .02) * 5.; \n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(.8, snd);\n float hue = u * 1. + snd * 0.2 + time * .2; //sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump); //mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\n}" + }, "screenshotURL": "data/images/images-7u87lh8397g69103s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dTLifasffbDKw6x9Q/art.json b/art/dTLifasffbDKw6x9Q/art.json index 43673e0e..e9206d12 100644 --- a/art/dTLifasffbDKw6x9Q/art.json +++ b/art/dTLifasffbDKw6x9Q/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":15328,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>5.\\n#define KP3 0.000//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>2.0\\n#define KP5 4000.0//KParameter5 30.000>>100000.0\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 15328, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>5.\n#define KP3 0.000//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>2.0\n#define KP5 4000.0//KParameter5 30.000>>100000.0\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-o4u4rn8qh1zv06q0t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dWK8BJdJy3MCus377/art.json b/art/dWK8BJdJy3MCus377/art.json index 131fced7..cccce540 100644 --- a/art/dWK8BJdJy3MCus377/art.json +++ b/art/dWK8BJdJy3MCus377/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "gitanely", "avatarUrl": "https://secure.gravatar.com/avatar/d5fdfe8b65ebd7057053c353e059209a?default=retro&size=200", - "settings": "{\"num\":10151,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main() {\\n vec2 scr = vec2(\\n \\t\\t vertexId / vertexCount * 2.0,\\n \\t\\t\\t vertexId / vertexCount * 2.0);\\n vec4 pos = gl_Position;\\n \\n \\n pos.x = -1. + scr.x;\\n pos.y = sin(vertexId + time) * pos.x;\\n pos.y = pow(pos.x,pos.y) - 1.;\\n pos.z = 0.;\\n \\n \\n pos.x += -.5;\\n gl_Position = pos;\\n gl_Position.w = 1.; \\n gl_PointSize =2.5;\\n\\n v_color.xyz = hsv2rgb(vec3(time + scr.x * 0.1,1,1));\\n\\n\\n}\"}", + "settings": { + "num": 10151, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main() {\n vec2 scr = vec2(\n \t\t vertexId / vertexCount * 2.0,\n \t\t\t vertexId / vertexCount * 2.0);\n vec4 pos = gl_Position;\n \n \n pos.x = -1. + scr.x;\n pos.y = sin(vertexId + time) * pos.x;\n pos.y = pow(pos.x,pos.y) - 1.;\n pos.z = 0.;\n \n \n pos.x += -.5;\n gl_Position = pos;\n gl_Position.w = 1.; \n gl_PointSize =2.5;\n\n v_color.xyz = hsv2rgb(vec3(time + scr.x * 0.1,1,1));\n\n\n}" + }, "screenshotURL": "data/images/images-1t5886xeark8nwcry-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dWoGmbWvzsuG5YKwG/art.json b/art/dWoGmbWvzsuG5YKwG/art.json index 0c3c2f61..2f93ddff 100644 --- a/art/dWoGmbWvzsuG5YKwG/art.json +++ b/art/dWoGmbWvzsuG5YKwG/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "test", "username": "karlll", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.02) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 0.6);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.7);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0002) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.02) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 0.6);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.7);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0002) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-5epvsj1kxk21vjt2c-thumbnail.jpg", "views": { "$numberInt": "175" diff --git a/art/dXKhFciQLSL49zDPB/art.json b/art/dXKhFciQLSL49zDPB/art.json index 659910d0..1a446893 100644 --- a/art/dXKhFciQLSL49zDPB/art.json +++ b/art/dXKhFciQLSL49zDPB/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "john2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GgOm4If5lPzmRZoOk5yb2TN0twuiwzp0zeJiUZ3qw=s96-c", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/awen-recordings/lily-pitaapsara-filtering-history-original-mix-release-data-18052020\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 4.0);\\n float across = floor(sqrt(numQuads));\\n float down = floor(numQuads / across);\\n \\n float qId = floor(vertexId / 4.0);\\n float qx = mod(qId, across);\\n float qy = floor(qId / across);\\n\\n float vId = mod(vertexId, 4.0);\\n\\n vec2 p = vec2(\\n qx + step(vId, 0.5),\\n qy + step(2.5, vId)) / vec2(across, down);\\n vec2 pn = p * 2. - 1.;\\n \\n float distFromCenter = length(pn);\\n\\n float s = texture2D(sound, vec2(\\n hash(p.x) * 0.004 + \\n mix(0.02, 0.15, (abs(atan(pn.x, pn.y)) / PI)),\\n length(pn) * 0.5)).r;\\n \\n \\n vec3 pos = vec3(pn * 1., (pow(1. - distFromCenter, 0.3)) * .4 * s );\\n \\n \\n \\n vec3 eye = vec3(0, 0, -.01);\\n vec3 target = vec3(0, sin(time * 0.005) * 0.0005, 0);\\n vec3 up = vec3(sin(time * 0.001), 1, 0);\\n \\n mat4 mat = persp(160. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \\n mat *= cameraLookAt(eye, target, up);\\n gl_Position = mat * vec4(pos, 1);\\n\\n\\n float boost = step(0.7, s);\\n \\n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\\n float val = mix(0.25, 2.0, pow(s, 2.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/awen-recordings/lily-pitaapsara-filtering-history-original-mix-release-data-18052020", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid main() {\n float numQuads = floor(vertexCount / 4.0);\n float across = floor(sqrt(numQuads));\n float down = floor(numQuads / across);\n \n float qId = floor(vertexId / 4.0);\n float qx = mod(qId, across);\n float qy = floor(qId / across);\n\n float vId = mod(vertexId, 4.0);\n\n vec2 p = vec2(\n qx + step(vId, 0.5),\n qy + step(2.5, vId)) / vec2(across, down);\n vec2 pn = p * 2. - 1.;\n \n float distFromCenter = length(pn);\n\n float s = texture2D(sound, vec2(\n hash(p.x) * 0.004 + \n mix(0.02, 0.15, (abs(atan(pn.x, pn.y)) / PI)),\n length(pn) * 0.5)).r;\n \n \n vec3 pos = vec3(pn * 1., (pow(1. - distFromCenter, 0.3)) * .4 * s );\n \n \n \n vec3 eye = vec3(0, 0, -.01);\n vec3 target = vec3(0, sin(time * 0.005) * 0.0005, 0);\n vec3 up = vec3(sin(time * 0.001), 1, 0);\n \n mat4 mat = persp(160. * PI / 180., resolution.x / resolution.y, 0.001, 10.); \n mat *= cameraLookAt(eye, target, up);\n gl_Position = mat * vec4(pos, 1);\n\n\n float boost = step(0.7, s);\n \n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\n float sat = 1.0 - pow(pos.z, 1.) - pow(s, 4.);\n float val = mix(0.25, 2.0, pow(s, 2.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-9u6xa6dhii16fzomd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dY6antnsT68htYfWz/art.json b/art/dY6antnsT68htYfWz/art.json index 9658f2b6..0bdb6bcc 100644 --- a/art/dY6antnsT68htYfWz/art.json +++ b/art/dY6antnsT68htYfWz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kaleidocollective/9duskus-bear\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float s = texture2D(sound, vec2(fract(p.x * 0.01), fract(p.y * .1))).a;\\n return pow(s, 5.) * 0.3;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = (vec3(ux, 0, vy) + off) * scale; \\n pos.y += fbm(pos.xz) * 2.;\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float down = floor(sqrt(numQuads));\\n float across = floor(numQuads / down);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraTarget = vec3(0, 0, 3);\\n vec3 cameraUp = vec3(0, 1, 0);\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = time * 0.01 + qu * 0.2;//1.;m1p1(n.z);\\n float sat = .3;abs(n.z);\\n float val = mix(0.5, 1., l);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n //v_color = vec4(n * 0.5 + 0.5, 1);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kaleidocollective/9duskus-bear", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float s = texture2D(sound, vec2(fract(p.x * 0.01), fract(p.y * .1))).a;\n return pow(s, 5.) * 0.3;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = (vec3(ux, 0, vy) + off) * scale; \n pos.y += fbm(pos.xz) * 2.;\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float down = floor(sqrt(numQuads));\n float across = floor(numQuads / down);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraTarget = vec3(0, 0, 3);\n vec3 cameraUp = vec3(0, 1, 0);\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = time * 0.01 + qu * 0.2;//1.;m1p1(n.z);\n float sat = .3;abs(n.z);\n float val = mix(0.5, 1., l);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n //v_color = vec4(n * 0.5 + 0.5, 1);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-3dv4clpyerc9kexo2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dYaXs9CwnzQhAT8Kt/art.json b/art/dYaXs9CwnzQhAT8Kt/art.json index fdc3c84e..5adff433 100644 --- a/art/dYaXs9CwnzQhAT8Kt/art.json +++ b/art/dYaXs9CwnzQhAT8Kt/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "mouse-wip", "username": "gman", - "settings": "{\"num\":57600,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.01568627450980392,0.023529411764705882,0.058823529411764705,1],\"shader\":\"// ==========================================\\n// ^\\n// |\\n// +-- click \\\"hide\\\" then MOVE YOUR MOUSE!!!!\\n// ==========================================\\n\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float u = 0.0;\\n float v = fract(vertexId / 240.0);\\n float age = floor(vertexId / 240.0) / 240.0;\\n float invAge = 1.0 - age;\\n vec4 touch = texture2D(touch, vec2(u, v));\\n float snd = texture2D(sound, vec2(v, age) * vec2(0.25, 0.25)).a;\\n float t = time - touch.w;\\n \\n float a = mod(vertexId, 6.0) / 6.0 * PI * 2.0 + t * 100.0;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = vec2(touch.xy) + (cs * age * snd * 0.2 - 0.1) * 0.1;\\n gl_Position = vec4(xy * (1.0 + (age + t) * 1.0) , age, 1);\\n\\n float hue = mix(age + 0.6 + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\\n vec3 color = hsv2rgb(vec3(hue, invAge, snd + touch.z));\\n v_color = vec4(mix(color, background.rgb, age) * invAge, invAge);\\n gl_PointSize = mix(20.0, 1.0, age);\\n\\n}\\n\\n\"}", + "settings": { + "num": 57600, + "mode": "LINES", + "sound": "https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy", + "lineSize": "CSS", + "backgroundColor": [ + 0.01568627450980392, + 0.023529411764705882, + 0.058823529411764705, + 1 + ], + "shader": "// ==========================================\n// ^\n// |\n// +-- click \"hide\" then MOVE YOUR MOUSE!!!!\n// ==========================================\n\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float u = 0.0;\n float v = fract(vertexId / 240.0);\n float age = floor(vertexId / 240.0) / 240.0;\n float invAge = 1.0 - age;\n vec4 touch = texture2D(touch, vec2(u, v));\n float snd = texture2D(sound, vec2(v, age) * vec2(0.25, 0.25)).a;\n float t = time - touch.w;\n \n float a = mod(vertexId, 6.0) / 6.0 * PI * 2.0 + t * 100.0;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = vec2(touch.xy) + (cs * age * snd * 0.2 - 0.1) * 0.1;\n gl_Position = vec4(xy * (1.0 + (age + t) * 1.0) , age, 1);\n\n float hue = mix(age + 0.6 + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\n vec3 color = hsv2rgb(vec3(hue, invAge, snd + touch.z));\n v_color = vec4(mix(color, background.rgb, age) * invAge, invAge);\n gl_PointSize = mix(20.0, 1.0, age);\n\n}\n\n" + }, "screenshotDataId": "t99zGXjFrYfgwXEQR", "views": { "$numberInt": "427" diff --git a/art/dZFJfYQQ8kmuoFFpi/art.json b/art/dZFJfYQQ8kmuoFFpi/art.json index 45c4a9e1..ce994140 100644 --- a/art/dZFJfYQQ8kmuoFFpi/art.json +++ b/art/dZFJfYQQ8kmuoFFpi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//vertex shader:\\nvoid main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.75;\\n float rightBottom = 0.0125;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n //v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n //v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 0, 0, 1);\\n }\\n else {\\n v_color = vec4(0, 0, 1, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//vertex shader:\nvoid main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.75;\n float rightBottom = 0.0125;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n //v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n //v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 0, 0, 1);\n }\n else {\n v_color = vec4(0, 0, 1, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-w040z10xyhncokxn3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/daPtAnEfTEnXXXpuZ/art.json b/art/daPtAnEfTEnXXXpuZ/art.json index 17415a70..31717093 100644 --- a/art/daPtAnEfTEnXXXpuZ/art.json +++ b/art/daPtAnEfTEnXXXpuZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/marikarossa/ken-ishii-alberto-ruiz-transmission-marika-rossa-remix-stick-recordings-cut-version\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 1, 1, 0,\\n 1, c, s, 0,\\n 1, -s, c, 0,\\n 1, 0, 0, 0); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 1, 1, 1, 1,\\n s, 0, c, 0,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 1, \\n s, c, 1, 0,\\n 0, 1, 0, 0,\\n 1, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 1, 1, 0,\\n 0, 1, 0, 1,\\n 1\\n , 0, 1, 1,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 2, 0,\\n 1, 0, s[2], 0,\\n 0, 2, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 2,\\n 0, s, 1, 0,\\n 0, 0, s, 0,\\n 4, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 2, 0, 1,\\n 1, f, 0, 0,\\n 2, 1, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[0][0], m[0][0], \\n m[1][1], m[1][1], m[1][1], \\n m[2][2], m[2][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[2], t[0], \\n i[1], t[1],\\n i[0], t[2],\\n 3, 3, 3, 3);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][1], m[2][2], m[3][3], \\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 3.;\\n float maxEdge = 16.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 loc = fibonacciSphere(numGroups, groupId);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(time * .17);\\n wmat *= rotX(time * .13);\\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\\n wmat *= uniformScale(mix(0.6, 1., mv));\\n wmat *= rotZ(groupId * PI / 3.);\\n \\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\\n float sat = .5;//step(pow(s, 3.), gt);\\n float val = pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = dot(litDir, nrm) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb *= v_color.a;\\n \\n float super = step(0.99, s);\\n v_color = mix(v_color, vec4(1,0,0,1), super);\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/marikarossa/ken-ishii-alberto-ruiz-transmission-marika-rossa-remix-stick-recordings-cut-version", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 1, 1, 0,\n 1, c, s, 0,\n 1, -s, c, 0,\n 1, 0, 0, 0); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 1, 1, 1, 1,\n s, 0, c, 0,\n 0, 0, 0, 0); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 1, \n s, c, 1, 0,\n 0, 1, 0, 0,\n 1, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 1, 1, 0,\n 0, 1, 0, 1,\n 1\n , 0, 1, 1,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 2, 0,\n 1, 0, s[2], 0,\n 0, 2, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 2,\n 0, s, 1, 0,\n 0, 0, s, 0,\n 4, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 2, 0, 1,\n 1, f, 0, 0,\n 2, 1, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[0][0], m[0][0], \n m[1][1], m[1][1], m[1][1], \n m[2][2], m[2][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[2], t[0], \n i[1], t[1],\n i[0], t[2],\n 3, 3, 3, 3);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][1], m[2][2], m[3][3], \n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 3.;\n float maxEdge = 16.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 loc = fibonacciSphere(numGroups, groupId);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(time * .17);\n wmat *= rotX(time * .13);\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\n wmat *= uniformScale(mix(0.6, 1., mv));\n wmat *= rotZ(groupId * PI / 3.);\n \n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\n float sat = .5;//step(pow(s, 3.), gt);\n float val = pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = dot(litDir, nrm) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb *= v_color.a;\n \n float super = step(0.99, s);\n v_color = mix(v_color, vec4(1,0,0,1), super);\n \n}\n" + }, "screenshotURL": "data/images/images-xq7ksl4r2ety6rf40-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/df3RvcwJQkovKdovf/art.json b/art/df3RvcwJQkovKdovf/art.json index ad5c1679..80a72efd 100644 --- a/art/df3RvcwJQkovKdovf/art.json +++ b/art/df3RvcwJQkovKdovf/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":82331,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 11\\\\\\\\ 13\\\\\\\\ 15,(16,17) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n \\n \\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\n float sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\\n gl_PointSize=sample*3.0;\\n gl_Position.z=(sample);\\n v_color =vec4(sample);\\n \\n \\n}\"}", + "settings": { + "num": 82331, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n \n \n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\n float sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\n gl_PointSize=sample*3.0;\n gl_Position.z=(sample);\n v_color =vec4(sample);\n \n \n}" + }, "screenshotURL": "data/images/images-x22ij1sbnauep2wke-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/df7Ra8dPPtCwcsrwL/art.json b/art/df7Ra8dPPtCwcsrwL/art.json index fbac9c76..c0154c93 100644 --- a/art/df7Ra8dPPtCwcsrwL/art.json +++ b/art/df7Ra8dPPtCwcsrwL/art.json @@ -20,7 +20,19 @@ }, "private": false, "username": "-anon-", - "settings": "{\"num\":89839,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/carloruetz/minus-promo-rec-sep16\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 2.0, 8.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 40.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.04 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 89839, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/carloruetz/minus-promo-rec-sep16", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 2.0, 8.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 40.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.04 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-m3w3s848st53eqsxu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dfb54ssJPtsdTbqaj/art.json b/art/dfb54ssJPtsdTbqaj/art.json index d9525149..68ed0f56 100644 --- a/art/dfb54ssJPtsdTbqaj/art.json +++ b/art/dfb54ssJPtsdTbqaj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":96313,\"mode\":\"POINTS\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#40190.0\\n//Another experiment of 'vertexification' of a fragment shader \\n\\n#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.25 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\tif(v>0.5)\\n v = 1.- v;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u*cos(time),v-1.4);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = normalize(vec2(u,v));//\\n \\t\\n float s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*.1 - floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 1.3;\\n float tm = .5 *time;\\n float tm2 = 0.25*time;\\n mat4 mat = persp(radians(60.0), resolution.x /resolution.y *-1., .3-sin(tm),2.0);\\n vec3 eye\\n = vec3(cos(tm) * r/10., 0.3, r);\\n //3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0.,-0.001,0.1);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, -snd*depth , .79);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 1./abs(gl_Position.z);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\\n\\n\"}", + "settings": { + "num": 96313, + "mode": "POINTS", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#40190.0\n//Another experiment of 'vertexification' of a fragment shader \n\n#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.25 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\tif(v>0.5)\n v = 1.- v;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u*cos(time),v-1.4);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = normalize(vec2(u,v));//\n \t\n float s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*.1 - floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 1.3;\n float tm = .5 *time;\n float tm2 = 0.25*time;\n mat4 mat = persp(radians(60.0), resolution.x /resolution.y *-1., .3-sin(tm),2.0);\n vec3 eye\n = vec3(cos(tm) * r/10., 0.3, r);\n //3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0.,-0.001,0.1);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, -snd*depth , .79);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 1./abs(gl_Position.z);\n \n //v_color = vec4(1.,1.,1.,1.);\n}\n\n" + }, "screenshotURL": "data/images/images-vd4en3frpc32r0x4o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dfek5Y7Cg65RmZeWJ/art.json b/art/dfek5Y7Cg65RmZeWJ/art.json index 11c498b3..10769b95 100644 --- a/art/dfek5Y7Cg65RmZeWJ/art.json +++ b/art/dfek5Y7Cg65RmZeWJ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":28720,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 12.;\\n\\n \\tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\\n\\tfloat hexSpace = 1.0;\\n \\tvec2 height = vec2(1.,0.4);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 33.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 2.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\\n float rangeInv = 0.2 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -0.043,\\n yAxis, 1.01,\\n zAxis, .10,\\n eye, sin(-0.1*time));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 * a10 * b09 - a12 * b06,\\n a00 * b09 - a01 / b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) * det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye-3., target*3., -up));\\n #else\\n vec3 zAxis = normalize(target * eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 2.,\\n yAxis, -1.20\\n zAxis, 2.2,\\n -dot(xAxis, -eye), *dot(yAxis, -eye), -dot(zAxis, eye), 0.6); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 28720, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 12.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\n\tfloat hexSpace = 1.0;\n \tvec2 height = vec2(1.,0.4);\n \t\n\tfloat indexQuad = floor(vertexId / 33.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 2.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\n float rangeInv = 0.2 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -0.043,\n yAxis, 1.01,\n zAxis, .10,\n eye, sin(-0.1*time));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 * a10 * b09 - a12 * b06,\n a00 * b09 - a01 / b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) * det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye-3., target*3., -up));\n #else\n vec3 zAxis = normalize(target * eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 2.,\n yAxis, -1.20\n zAxis, 2.2,\n -dot(xAxis, -eye), *dot(yAxis, -eye), -dot(zAxis, eye), 0.6); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-ek5i2j3hos1vfq0a3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dh3DHrafWfekY5Q5d/art.json b/art/dh3DHrafWfekY5Q5d/art.json index aeae74e3..7692eaaa 100644 --- a/art/dh3DHrafWfekY5Q5d/art.json +++ b/art/dh3DHrafWfekY5Q5d/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jonaced", "avatarUrl": "https://secure.gravatar.com/avatar/4afc7bbaa73d3ae5795519659259854b?default=retro&size=200", - "settings": "{\"num\":362,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n float tamCirculo = 360.0;\\n if (vertexId == 0.0) {\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n } else {\\n float angle = vertexId / tamCirculo * radians(360.0);\\n float radius = 1.0;\\n float u = radius * cos(angle) ;\\n float v = radius * sin(angle) ;\\n gl_Position = vec4(u, v, 0.0, 1.0);\\n float absU = abs(u);\\n float absV = abs(v);\\n vec3 colVec = vec3((absU + absV) * cos(angle/2.0) * cos(angle/2.0), (absU + absV) * sin(angle/3.0) * cos(angle/3.0), (absU + absV) * sin(angle));\\n v_color = vec4(colVec, 1.0);\\n }\\n}\\n\\n/*\\nvoid main() {\\n float tamCirculo = 360.0;\\n if (vertexId == 0.0) {\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n } else {\\n float angle = vertexId / tamCirculo * radians(360.0);\\n float radius = 1.0;\\n float u = radius * cos(angle) ;\\n float v = radius * sin(angle) ;\\n gl_Position = vec4(u, v, 0.0, 1.0);\\n float absU = abs(u);\\n float absV = abs(v);\\n v_color = vec4((u + absV)/1.6, (absU + v)/1.6, (absU + absV)/3.0, 1.0);\\n }\\n}\\n\\n\\n\\n\\n\\n\\n\\nvec3 colVec = vec3(absU / abs(1.0 - u), (absU + v) / 2.0, (absU + absV) * cos(angle));\\nvec3 colVec = vec3(absU * abs(0.5 - u), absV * abs(0.5 - v), ((absU * 0.9) + (absV * 0.5)) * cos(angle));\\nvec3 colVec = vec3(absU * abs(0.5 - u), absV * abs(0.5 - v), (absU + absV) * cos(angle));\\n*/\"}", + "settings": { + "num": 362, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n float tamCirculo = 360.0;\n if (vertexId == 0.0) {\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n } else {\n float angle = vertexId / tamCirculo * radians(360.0);\n float radius = 1.0;\n float u = radius * cos(angle) ;\n float v = radius * sin(angle) ;\n gl_Position = vec4(u, v, 0.0, 1.0);\n float absU = abs(u);\n float absV = abs(v);\n vec3 colVec = vec3((absU + absV) * cos(angle/2.0) * cos(angle/2.0), (absU + absV) * sin(angle/3.0) * cos(angle/3.0), (absU + absV) * sin(angle));\n v_color = vec4(colVec, 1.0);\n }\n}\n\n/*\nvoid main() {\n float tamCirculo = 360.0;\n if (vertexId == 0.0) {\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n } else {\n float angle = vertexId / tamCirculo * radians(360.0);\n float radius = 1.0;\n float u = radius * cos(angle) ;\n float v = radius * sin(angle) ;\n gl_Position = vec4(u, v, 0.0, 1.0);\n float absU = abs(u);\n float absV = abs(v);\n v_color = vec4((u + absV)/1.6, (absU + v)/1.6, (absU + absV)/3.0, 1.0);\n }\n}\n\n\n\n\n\n\n\nvec3 colVec = vec3(absU / abs(1.0 - u), (absU + v) / 2.0, (absU + absV) * cos(angle));\nvec3 colVec = vec3(absU * abs(0.5 - u), absV * abs(0.5 - v), ((absU * 0.9) + (absV * 0.5)) * cos(angle));\nvec3 colVec = vec3(absU * abs(0.5 - u), absV * abs(0.5 - v), (absU + absV) * cos(angle));\n*/" + }, "screenshotURL": "data/images/images-35s40dxdeio8y8598-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dhbsE39FZ6S2kKtfm/art.json b/art/dhbsE39FZ6S2kKtfm/art.json index 86edc0ec..99597423 100644 --- a/art/dhbsE39FZ6S2kKtfm/art.json +++ b/art/dhbsE39FZ6S2kKtfm/art.json @@ -23,7 +23,19 @@ "unlisted": true, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4030,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);;\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n float u = x / across;\\n float v = y / across;\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n gl_Position = vec4(ux, vy, 0, 1);\\n\\n gl_PointSize = (20. / across) * (resolution.x / across);\\n \\n v_color = vec4(0, .5, .8, 1); // mod(time, .9)\\n}\"}", + "settings": { + "num": 4030, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);;\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n float u = x / across;\n float v = y / across;\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n gl_Position = vec4(ux, vy, 0, 1);\n\n gl_PointSize = (20. / across) * (resolution.x / across);\n \n v_color = vec4(0, .5, .8, 1); // mod(time, .9)\n}" + }, "screenshotURL": "data/images/images-mdr2boxphzmzjeg87-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dhnTE8qmLte8dvycB/art.json b/art/dhnTE8qmLte8dvycB/art.json index ad96a526..4ba6a959 100644 --- a/art/dhnTE8qmLte8dvycB/art.json +++ b/art/dhnTE8qmLte8dvycB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n//\\n\\n#define PI 3.14159\\n#define NUM_SEGMENTS 101.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n float snd = 0.0;//texture2D(sound, vec2(abs(m1p1(a1 / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n float t = time * 0.1;\\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.3,.6))\\n \\t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.9 + t,.5,.8))\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.6 + t,.7,.4))\\n \\t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.7 + t,.4,.7));\\n\\n light *= mix(0.5, 2.0, snd);\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n v_color = vec4(vec3(light), 1);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n//\n\n#define PI 3.14159\n#define NUM_SEGMENTS 101.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n float snd = 0.0;//texture2D(sound, vec2(abs(m1p1(a1 / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n float t = time * 0.1;\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.3,.6))\n \t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.9 + t,.5,.8))\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.6 + t,.7,.4))\n \t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.7 + t,.4,.7));\n\n light *= mix(0.5, 2.0, snd);\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n v_color = vec4(vec3(light), 1);\n}" + }, "screenshotURL": "data/images/images-veuy0owcqvjz311vf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/di9ZgJzgbKZDyCan3/art.json b/art/di9ZgJzgbKZDyCan3/art.json index 24cedac8..23e15d27 100644 --- a/art/di9ZgJzgbKZDyCan3/art.json +++ b/art/di9ZgJzgbKZDyCan3/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":29236,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 1.0;\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\nfloat HSCALE = 1.0;\\n\\n// sea\\nconst int ITER_GEOMETRY = 3;\\nconst int ITER_FRAGMENT = 5;\\nconst float SEA_HEIGHT = 1.6;\\nconst float SEA_CHOPPY = 4.0;\\nconst float SEA_SPEED = 0.8;\\nconst float SEA_FREQ = 0.16;\\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\\n#define SEA_TIME (1.0 + time * SEA_SPEED)\\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n\\nfloat hash( vec2 p ) {\\n\\tfloat h = dot(p,vec2(127.1,311.7));\\t\\n return fract(sin(h)*43758.5453123);\\n}\\nfloat noise( in vec2 p ) {\\n vec2 i = floor( p );\\n vec2 f = fract( p );\\t\\n\\tvec2 u = f*f*(3.0-2.0*f);\\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \\n hash( i + vec2(1.0,0.0) ), u.x),\\n mix( hash( i + vec2(0.0,1.0) ), \\n hash( i + vec2(1.0,1.0) ), u.x), u.y);\\n}\\nfloat fbm( vec2 uv, float choppy )\\n{\\n uv += noise(uv); \\n vec2 wv = 1.0-abs(sin(uv));\\n vec2 swv = abs(cos(uv)); \\n wv = mix(wv,swv,wv);\\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\\n}\\n\\n\\n\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n\\n \\n float freq = SEA_FREQ;\\n float amp = SEA_HEIGHT;\\n float choppy = SEA_CHOPPY;\\n vec2 uv = vec2((-SIZE/2.0 + x) * SPACING,(-SIZE/2.0 + y) * SPACING);\\n \\n uv.x *= 0.75;\\n\\n float d, h = 0.0; \\n for(int i = 0; i < ITER_GEOMETRY; i++) { \\n d = fbm((uv+SEA_TIME)*freq,SEA_CHOPPY);\\n d += fbm((uv-+SEA_TIME)*freq,SEA_CHOPPY);\\n h += d * amp; \\n uv *= octave_m; freq *= 1.9; amp *= 0.22;\\n choppy = mix(choppy,1.0,0.2);\\n }\\n \\n return vec3((-SIZE/2.0 + x) * SPACING,HSCALE*h,(-SIZE/2.0 + y) * SPACING);\\n\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n //v_color = vec4(abs(p.y/100.0));\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n \\n}\"}", + "settings": { + "num": 29236, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 1.0;\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\nfloat HSCALE = 1.0;\n\n// sea\nconst int ITER_GEOMETRY = 3;\nconst int ITER_FRAGMENT = 5;\nconst float SEA_HEIGHT = 1.6;\nconst float SEA_CHOPPY = 4.0;\nconst float SEA_SPEED = 0.8;\nconst float SEA_FREQ = 0.16;\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\n#define SEA_TIME (1.0 + time * SEA_SPEED)\nconst mat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n\nfloat hash( vec2 p ) {\n\tfloat h = dot(p,vec2(127.1,311.7));\t\n return fract(sin(h)*43758.5453123);\n}\nfloat noise( in vec2 p ) {\n vec2 i = floor( p );\n vec2 f = fract( p );\t\n\tvec2 u = f*f*(3.0-2.0*f);\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \n hash( i + vec2(1.0,0.0) ), u.x),\n mix( hash( i + vec2(0.0,1.0) ), \n hash( i + vec2(1.0,1.0) ), u.x), u.y);\n}\nfloat fbm( vec2 uv, float choppy )\n{\n uv += noise(uv); \n vec2 wv = 1.0-abs(sin(uv));\n vec2 swv = abs(cos(uv)); \n wv = mix(wv,swv,wv);\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\n}\n\n\n\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n\n \n float freq = SEA_FREQ;\n float amp = SEA_HEIGHT;\n float choppy = SEA_CHOPPY;\n vec2 uv = vec2((-SIZE/2.0 + x) * SPACING,(-SIZE/2.0 + y) * SPACING);\n \n uv.x *= 0.75;\n\n float d, h = 0.0; \n for(int i = 0; i < ITER_GEOMETRY; i++) { \n d = fbm((uv+SEA_TIME)*freq,SEA_CHOPPY);\n d += fbm((uv-+SEA_TIME)*freq,SEA_CHOPPY);\n h += d * amp; \n uv *= octave_m; freq *= 1.9; amp *= 0.22;\n choppy = mix(choppy,1.0,0.2);\n }\n \n return vec3((-SIZE/2.0 + x) * SPACING,HSCALE*h,(-SIZE/2.0 + y) * SPACING);\n\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n //v_color = vec4(abs(p.y/100.0));\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n \n}" + }, "screenshotURL": "data/images/images-4lh2u5zkdjybt8ari-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dk6ee6LN5fC4Dkybg/art.json b/art/dk6ee6LN5fC4Dkybg/art.json index 4ac15de0..dc80163b 100644 --- a/art/dk6ee6LN5fC4Dkybg/art.json +++ b/art/dk6ee6LN5fC4Dkybg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hug-life/freek-it-remaster\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 2);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 10.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 2.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) -1.4;\\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 6.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .02)).xyz, 1.2);\\n gl_PointSize = tan(5. *snd);\\n float hue = mix(1.3*snd, 12.6/snd, fract(circleId -21.79)*3.);\\n float sat = 45.2 * circleId/snd;\\n float val = .29;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-2.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/hug-life/freek-it-remaster", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 2);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 10.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 2.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) -1.4;\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 6.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .02)).xyz, 1.2);\n gl_PointSize = tan(5. *snd);\n float hue = mix(1.3*snd, 12.6/snd, fract(circleId -21.79)*3.);\n float sat = 45.2 * circleId/snd;\n float val = .29;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-2.0);\n}" + }, "screenshotURL": "data/images/images-a9p3q50c1fizc35vj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dmBnGPyH5KjJbneie/art.json b/art/dmBnGPyH5KjJbneie/art.json index 0acf1369..62e20b35 100644 --- a/art/dmBnGPyH5KjJbneie/art.json +++ b/art/dmBnGPyH5KjJbneie/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://on.soundcloud.com/BCLB1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Audio Reactive\\n//Course: CS250\\n//Term: Spring 2023\\n//YEA LETS GOOOOOOOO\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 30. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 100. + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = pow(snd + 0.2, 5.);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://on.soundcloud.com/BCLB1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Audio Reactive\n//Course: CS250\n//Term: Spring 2023\n//YEA LETS GOOOOOOOO\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 30. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * 100. + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = pow(snd + 0.2, 5.);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-dfh6gc59eguxybrxq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/do5csPmmsrqctxz3p/art.json b/art/do5csPmmsrqctxz3p/art.json index d54b6311..7d081191 100644 --- a/art/do5csPmmsrqctxz3p/art.json +++ b/art/do5csPmmsrqctxz3p/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.141594\\n//#define FIT_VERTICAL\\n\\nvec3 computeVert(float angle, float H) {\\n float STEP = time*0.7;\\n float R = (cos(H * 2.6 + STEP * 2.5 + sin(STEP * 4.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\\n R *= sin((H + 4.0) * 0.375);\\n \\n float Q = cos(STEP * 0.54 + H * 0.7);\\n float dX = cos(H * 1.4) * Q * 1.5;\\n float dY = sin(H * 0.75) * Q * 0.4;\\n float dZ = sin(H * 0.5) * Q * 0.15;\\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\\n}\\n\\nvec3 computeNorm(float angle, float H) {\\n float dA = 0.01;\\n float dH = 0.01;\\n vec3 A = computeVert(angle, H);\\n vec3 B = computeVert(angle + dA, H);\\n vec3 C = computeVert(angle, H + dH);\\n return normalize(-cross((B-A)/dA,(C-A)/dH));\\n}\\n\\nvoid main() {\\n int NUM_ROT =76;\\n float dH = 0.05;\\n \\n float STEP = time*0.7;\\n \\n int base = int(vertexId) /5;\\n int level = int(base) / NUM_ROT;\\n int idx = int(mod(vertexId,8.0*sin(time*min(mouse.x+1.5,3.))));\\n vec3 xyz = vec3(0,0,0);\\n vec3 N = normalize(vec3(1,0,0));\\n \\n float dA = 2.0 * PI / float(NUM_ROT);\\n\\n float H = float(level) * dH - 4.0;\\n float angle = float(base) * dA;\\n \\n if (idx == 0) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n if (idx == 1) {\\n \\txyz = computeVert(angle + dA, H);\\n \\tN = computeNorm(angle + dA, H);\\n }\\n if (idx == 2) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n \\n if (idx == 3) {\\n \\txyz = computeVert(angle + dA, H + dH);\\n \\tN = computeNorm(angle + dA, H + dH);\\n }\\n if (idx == 4) {\\n \\txyz = computeVert(angle, H + dH);\\n \\tN = computeNorm(angle, H + dH);\\n }\\n if (idx == 5) {\\n \\txyz = computeVert(angle, H);\\n \\tN = computeNorm(angle, H);\\n }\\n \\n \\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n \\n float Cs = cos(STEP);\\n float Si = sin(STEP);\\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\\n xyz *= 0.3;\\n //xyz *= rot;\\n //N *= rot;\\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\\n \\n vec3 light = normalize(vec3(1,1,-1));\\n vec3 V = vec3(0,0,1);\\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\\n vec3 A_col = vec3(1,1,1) * N * rot2;\\n vec3 D_col = vec3(1,1,1) * N;\\n vec3 S_col = vec3(1,1,1);\\n vec3 LUM = A * A_col + D * D_col +S * S_col;\\n v_color = vec4(LUM, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.141594\n//#define FIT_VERTICAL\n\nvec3 computeVert(float angle, float H) {\n float STEP = time*0.7;\n float R = (cos(H * 2.6 + STEP * 2.5 + sin(STEP * 4.3 + H * 3.0) * (cos(STEP * 0.6) + 0.6)) * 0.2 + 0.9) * (cos(STEP * 0.5 + H * 1.4) * 0.3 + 0.9);\n R *= sin((H + 4.0) * 0.375);\n \n float Q = cos(STEP * 0.54 + H * 0.7);\n float dX = cos(H * 1.4) * Q * 1.5;\n float dY = sin(H * 0.75) * Q * 0.4;\n float dZ = sin(H * 0.5) * Q * 0.15;\n return vec3(cos(angle) * R, H, sin(angle) * R) + vec3(dX, dY, dZ);\n}\n\nvec3 computeNorm(float angle, float H) {\n float dA = 0.01;\n float dH = 0.01;\n vec3 A = computeVert(angle, H);\n vec3 B = computeVert(angle + dA, H);\n vec3 C = computeVert(angle, H + dH);\n return normalize(-cross((B-A)/dA,(C-A)/dH));\n}\n\nvoid main() {\n int NUM_ROT =76;\n float dH = 0.05;\n \n float STEP = time*0.7;\n \n int base = int(vertexId) /5;\n int level = int(base) / NUM_ROT;\n int idx = int(mod(vertexId,8.0*sin(time*min(mouse.x+1.5,3.))));\n vec3 xyz = vec3(0,0,0);\n vec3 N = normalize(vec3(1,0,0));\n \n float dA = 2.0 * PI / float(NUM_ROT);\n\n float H = float(level) * dH - 4.0;\n float angle = float(base) * dA;\n \n if (idx == 0) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n if (idx == 1) {\n \txyz = computeVert(angle + dA, H);\n \tN = computeNorm(angle + dA, H);\n }\n if (idx == 2) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n \n if (idx == 3) {\n \txyz = computeVert(angle + dA, H + dH);\n \tN = computeNorm(angle + dA, H + dH);\n }\n if (idx == 4) {\n \txyz = computeVert(angle, H + dH);\n \tN = computeNorm(angle, H + dH);\n }\n if (idx == 5) {\n \txyz = computeVert(angle, H);\n \tN = computeNorm(angle, H);\n }\n \n \n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n \n float Cs = cos(STEP);\n float Si = sin(STEP);\n mat3 rot = mat3(vec3(Cs,0,Si), vec3(0,1,0), vec3(-Si,0,Cs));\n mat3 rot2 = mat3(vec3(0,1,0), vec3(Cs,0,Si), vec3(-Si,0,Cs));\n xyz *= 0.3;\n //xyz *= rot;\n //N *= rot;\n gl_Position = vec4(xyz.xy * aspect / (3.0 + xyz.z), xyz.z, 1);\n \n vec3 light = normalize(vec3(1,1,-1));\n vec3 V = vec3(0,0,1);\n float A = 0.8 + cos(xyz.y * 0.6 + STEP);\n float D = 0.6 * clamp(dot(N, light), 0.0, 1.0);\n float S = 1.6 * pow(clamp(dot(light, reflect(V,N)),0.0,1.0), 5.0);\n vec3 A_col = vec3(1,1,1) * N * rot2;\n vec3 D_col = vec3(1,1,1) * N;\n vec3 S_col = vec3(1,1,1);\n vec3 LUM = A * A_col + D * D_col +S * S_col;\n v_color = vec4(LUM, 1);\n}" + }, "screenshotURL": "data/images/images-rci5cr266wrrzgu70-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dpsBkE3nfEEmeSaC8/art.json b/art/dpsBkE3nfEEmeSaC8/art.json index 0aa3cfbe..1c06b866 100644 --- a/art/dpsBkE3nfEEmeSaC8/art.json +++ b/art/dpsBkE3nfEEmeSaC8/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "dumpster", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJySGGmgPbDAoycXt3iXyhYrzMSM8CvuNCRqg0ay=s96-c", - "settings": "{\"num\":4958,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/auvicmusic/tell-the-world-feat-samantha-montenero\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n // float id = vertexId;\\n \\n // float ux = floor(id / 6.) + mod(id, 2.);\\n // float vy = mod(floor(id + 2.) + floor(id + 3.), 2.);\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n \\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n\\n}\\n\\n// #if 0 \\n\\n void main() {\\n \\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = 0.; // sin(time + y * 0.2) * .1;\\n float yoff = 0.; // sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u-0.5) * 2.; \\n float sv = abs(v-0.5) * 2.; \\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y; \\n \\n float sc = pow(snd + .2, 5.) * mix(1., 1.1, oddSlice);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * .1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.05 * sc);\\n \\n // vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3; \\n // gl_Position = vec4(xy,0,1) * vec4(1,aspect,1,1);\\n \\n gl_Position = mat * pos;\\n\\n float soff = .0; // sin(time + x * y * 0.02) * 5.;\\n \\n // gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\\n // gl_PointSize *= 20. / across;\\n // gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd *.2 + time * 0.1;\\n float sat = 1.; mix(0.3, 1., pump); // mix(28., -8., av);\\n float val = .1; // mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\\n\\n hue = hue + pump * oddSlice * .5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\\n\\n// #endif\"}", + "settings": { + "num": 4958, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/auvicmusic/tell-the-world-feat-samantha-montenero", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n // float id = vertexId;\n \n // float ux = floor(id / 6.) + mod(id, 2.);\n // float vy = mod(floor(id + 2.) + floor(id + 3.), 2.);\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n \n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n\n}\n\n// #if 0 \n\n void main() {\n \n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n // float pointSize = 5.;\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = 0.; // sin(time + y * 0.2) * .1;\n float yoff = 0.; // sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u-0.5) * 2.; \n float sv = abs(v-0.5) * 2.; \n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y; \n \n float sc = pow(snd + .2, 5.) * mix(1., 1.1, oddSlice);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * .1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.05 * sc);\n \n // vec2 xy = circleXY * 0.1 * sc + vec2(ux, vy) * 1.3; \n // gl_Position = vec4(xy,0,1) * vec4(1,aspect,1,1);\n \n gl_Position = mat * pos;\n\n float soff = .0; // sin(time + x * y * 0.02) * 5.;\n \n // gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\n // gl_PointSize *= 20. / across;\n // gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd *.2 + time * 0.1;\n float sat = 1.; mix(0.3, 1., pump); // mix(28., -8., av);\n float val = .1; // mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\n\n hue = hue + pump * oddSlice * .5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}\n\n// #endif" + }, "screenshotURL": "data/images/images-dc9hcsvj9ngotx6f7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dtZMYXvfSW4gKJ7Mr/art.json b/art/dtZMYXvfSW4gKJ7Mr/art.json index ddc28f98..45b82d38 100644 --- a/art/dtZMYXvfSW4gKJ7Mr/art.json +++ b/art/dtZMYXvfSW4gKJ7Mr/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jpaquim", "avatarUrl": "https://secure.gravatar.com/avatar/374b09dacab582ca17818a391b59a214?default=retro&size=200", - "settings": "{\"num\":7825,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/jpaquim/synth-jam-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) { \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n // float numCircleSegments = 20.;\\n // float numCircleSegments = 6.;\\n // float numCircleSegments = 36.;\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n // float xoff = sin(time + y * .2) * .1;\\n float yoff = 0.;\\n // float yoff = sin(time + x * .3) * .2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + .2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * .1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float pump = step(.8, snd);\\n // float hue = 1.;\\n // float hue = u * .1 + sin(time + v * 20.) * .05;\\n float hue = u * .1 + snd * .2 + time * .1;\\n float sat = 1.;\\n // float sat = 1. - av;\\n // float sat = mix(1., -10., av);\\n // float sat = mix(0., 1., pump);\\n // float sat = mix(.5, 1., pump);\\n // float val = 1.;\\n // float val = sin(time + u * v * 20.) * .5 + .5;\\n // float val = pow(snd + .2, 5.);\\n float val = mix(.4, pow(snd + .2, 5.), pump);\\n \\n hue = hue + pump * oddSlice * .5 + pump * .33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 7825, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/jpaquim/synth-jam-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) { \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n // float numCircleSegments = 20.;\n // float numCircleSegments = 6.;\n // float numCircleSegments = 36.;\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n // float xoff = sin(time + y * .2) * .1;\n float yoff = 0.;\n // float yoff = sin(time + x * .3) * .2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + .2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * .1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(.03 * sc);\n \n gl_Position = mat * pos;\n \n float pump = step(.8, snd);\n // float hue = 1.;\n // float hue = u * .1 + sin(time + v * 20.) * .05;\n float hue = u * .1 + snd * .2 + time * .1;\n float sat = 1.;\n // float sat = 1. - av;\n // float sat = mix(1., -10., av);\n // float sat = mix(0., 1., pump);\n // float sat = mix(.5, 1., pump);\n // float val = 1.;\n // float val = sin(time + u * v * 20.) * .5 + .5;\n // float val = pow(snd + .2, 5.);\n float val = mix(.4, pow(snd + .2, 5.), pump);\n \n hue = hue + pump * oddSlice * .5 + pump * .33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-pleifqnnrf1pl2seh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/duHXW2G4Ct7oCwFdN/art.json b/art/duHXW2G4Ct7oCwFdN/art.json index 13ae32d4..535b1942 100644 --- a/art/duHXW2G4Ct7oCwFdN/art.json +++ b/art/duHXW2G4Ct7oCwFdN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":42724,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>1.\\n#define kpx 6.0//KParameter 0.>>8.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n//KverticesNumber=233333\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\n\\n#define elementPerTriangleShape 3.\\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\\n result = rotZ(result,_angle);\\n result.xy+=_center.xy;\\n return result;\\n}\\n\\n\\nvoid main() {\\n \\n //fix a maximum vertexId\\n float localVertexId = vertexId;\\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\\n \\n float relVertexId = vertexId/vertexCount*kpx;\\n \\n maxShapeCount = floor(maxShapeCount/2.);\\n \\n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\\n \\n if(localVertexId>=maxVerticesNumber)\\n localVertexId = maxVerticesNumber-1.5;\\n \\n float shapeId = floor(localVertexId / elementPerTriangleShape);\\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\\n float relShapeId = shapeId/maxShapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n \\n vec2 center=vec2(0., 0.);\\n \\n if(localVertexId>=(maxVerticesNumber/2.))\\n {\\n localVertexId = localVertexId - (maxVerticesNumber/2.);\\n }\\n \\n float localShapeId = floor(localVertexId/elementPerTriangleShape);\\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\\n \\n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\\n float snd = texture2D(floatSound, vec2(localRelShapeId,0.4) ).a* sndFactor;\\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\\n \\n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\\n ;\\n \\n \\n shapep.x/=aspect;\\n vec4 m = texture2D(touch, vec2(0.009-snd, localShapeId /(maxShapeCount/2.)));\\n \\n shapep += vec3( m.xy, shapep.z+1.);\\n \\n if(shapeId>maxShapeCount/2.)\\n {\\n shapep.x = -shapep.x;\\n }\\n\\n \\n \\n \\n gl_Position = vec4(shapep,1.);\\n gl_PointSize = 3.*PointSizeFactor;\\n \\n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 42724, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>1.\n#define kpx 6.0//KParameter 0.>>8.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n//KverticesNumber=233333\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\n\n#define elementPerTriangleShape 3.\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\n result = rotZ(result,_angle);\n result.xy+=_center.xy;\n return result;\n}\n\n\nvoid main() {\n \n //fix a maximum vertexId\n float localVertexId = vertexId;\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\n \n float relVertexId = vertexId/vertexCount*kpx;\n \n maxShapeCount = floor(maxShapeCount/2.);\n \n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\n \n if(localVertexId>=maxVerticesNumber)\n localVertexId = maxVerticesNumber-1.5;\n \n float shapeId = floor(localVertexId / elementPerTriangleShape);\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\n float relShapeId = shapeId/maxShapeCount;\n \n float aspect = resolution.x / resolution.y;\n \n vec2 center=vec2(0., 0.);\n \n if(localVertexId>=(maxVerticesNumber/2.))\n {\n localVertexId = localVertexId - (maxVerticesNumber/2.);\n }\n \n float localShapeId = floor(localVertexId/elementPerTriangleShape);\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\n \n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\n float snd = texture2D(floatSound, vec2(localRelShapeId,0.4) ).a* sndFactor;\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\n \n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\n ;\n \n \n shapep.x/=aspect;\n vec4 m = texture2D(touch, vec2(0.009-snd, localShapeId /(maxShapeCount/2.)));\n \n shapep += vec3( m.xy, shapep.z+1.);\n \n if(shapeId>maxShapeCount/2.)\n {\n shapep.x = -shapep.x;\n }\n\n \n \n \n gl_Position = vec4(shapep,1.);\n gl_PointSize = 3.*PointSizeFactor;\n \n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-adl94rdj0yhl7a6ct-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dufQqpoG5ZrSfdkjf/art.json b/art/dufQqpoG5ZrSfdkjf/art.json index 69783f6c..ed9d6c7c 100644 --- a/art/dufQqpoG5ZrSfdkjf/art.json +++ b/art/dufQqpoG5ZrSfdkjf/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nfloat random(vec2 co){\\n return fract(sin(dot(co, vec2(12.9898, 78.233))) * 43758.5453);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx,0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n \\tv_color.rgb = vec3(min(v_color.bg*v_color.br, 1.0) , v_color.r);\\n \\tv_color.a = random(v_color.bg)*10.0;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nfloat random(vec2 co){\n return fract(sin(dot(co, vec2(12.9898, 78.233))) * 43758.5453);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx,0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n \tv_color.rgb = vec3(min(v_color.bg*v_color.br, 1.0) , v_color.r);\n \tv_color.a = random(v_color.bg)*10.0;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-c8hmo4y2h3f07cs3u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dvzt2TN84y8LGgnsn/art.json b/art/dvzt2TN84y8LGgnsn/art.json index ec9f54c6..275f048e 100644 --- a/art/dvzt2TN84y8LGgnsn/art.json +++ b/art/dvzt2TN84y8LGgnsn/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chemlo", "avatarUrl": "https://secure.gravatar.com/avatar/bd1fc3e2f0d77392e06266faedc63267?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvoid main() {\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n \\n vec3 pos = posf2(t, i);\\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n gl_PointSize = 1.+pos.z*5.;\\n gl_Position = vec4(pos.x, pos.y, pos.z, 1);\\n v_color = vec4(pos.z*10., 0. , -pos.z*10., 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvoid main() {\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n \n vec3 pos = posf2(t, i);\n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n gl_PointSize = 1.+pos.z*5.;\n gl_Position = vec4(pos.x, pos.y, pos.z, 1);\n v_color = vec4(pos.z*10., 0. , -pos.z*10., 1);\n}" + }, "screenshotURL": "data/images/images-4rlgpo9b58z2994kn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dw7XrmJjH3mBbHx8u/art.json b/art/dw7XrmJjH3mBbHx8u/art.json index f9be0ce9..fe725cc3 100644 --- a/art/dw7XrmJjH3mBbHx8u/art.json +++ b/art/dw7XrmJjH3mBbHx8u/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":16384,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/gargaj/fractured-impulse-monolithic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// nice little fun toy, i like integration with soundcloud\\n// [commercial] \\n// also check out http://polycu.be\\n// [/commercial]\\n\\n#define W 128\\n#define H 64\\n#define PI 3.1415926535\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float fv = floor(vertexId / float(W));\\n float fu = vertexId - fv*float(W);\\n fu /= float(W);\\n fv /= float(H);\\n float u = fu*2.*PI;\\n float v = fv*1.*PI;\\n u += time;\\n \\n float sin_u = sin(u), cos_u = cos(u);\\n float sin_v = sin(v), cos_v = cos(v);\\n float f = texture2D(sound, vec2(abs(fu-.5)+.1,fv*.1)).x+.05;\\n vec3 p = vec3(cos_u*(cos_v*f+1.), sin_u*(cos_v*f+1.), sin_v*f);\\n float sin_t = sin(time), cos_t = cos(time);\\n p *= mat3(sin_t,0,cos_t, 0,1,0, -sin_t,0,cos_t);\\n sin_t = sin(time*.7), cos_t = cos(time*.7);\\n p *= mat3(cos_t,sin_t,0, -sin_t,cos_t,0, 0,0,1);\\n p.x *= resolution.y/resolution.x;\\n p.z += 3.;\\n p.xy *= 3./p.z;\\n gl_Position = vec4(p.x, p.y, 2., p.z);\\n\\n v_color = vec4(hsv2rgb(vec3(fu*3., 1., 1.)), 1);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/gargaj/fractured-impulse-monolithic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// nice little fun toy, i like integration with soundcloud\n// [commercial] \n// also check out http://polycu.be\n// [/commercial]\n\n#define W 128\n#define H 64\n#define PI 3.1415926535\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float fv = floor(vertexId / float(W));\n float fu = vertexId - fv*float(W);\n fu /= float(W);\n fv /= float(H);\n float u = fu*2.*PI;\n float v = fv*1.*PI;\n u += time;\n \n float sin_u = sin(u), cos_u = cos(u);\n float sin_v = sin(v), cos_v = cos(v);\n float f = texture2D(sound, vec2(abs(fu-.5)+.1,fv*.1)).x+.05;\n vec3 p = vec3(cos_u*(cos_v*f+1.), sin_u*(cos_v*f+1.), sin_v*f);\n float sin_t = sin(time), cos_t = cos(time);\n p *= mat3(sin_t,0,cos_t, 0,1,0, -sin_t,0,cos_t);\n sin_t = sin(time*.7), cos_t = cos(time*.7);\n p *= mat3(cos_t,sin_t,0, -sin_t,cos_t,0, 0,0,1);\n p.x *= resolution.y/resolution.x;\n p.z += 3.;\n p.xy *= 3./p.z;\n gl_Position = vec4(p.x, p.y, 2., p.z);\n\n v_color = vec4(hsv2rgb(vec3(fu*3., 1., 1.)), 1);\n}\n" + }, "screenshotURL": "data/images/images-8tqol0os4vx1zx0pl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dwJrBDGXGSGAQkzf3/art.json b/art/dwJrBDGXGSGAQkzf3/art.json index d7389580..8ea4f4ce 100644 --- a/art/dwJrBDGXGSGAQkzf3/art.json +++ b/art/dwJrBDGXGSGAQkzf3/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Bound Mod\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.3);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Bound Mod\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.3);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}" + }, "screenshotURL": "data/images/images-tdtgzzyh0kf3v9t55-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dxaRX4ZTW7m76nQzS/art.json b/art/dxaRX4ZTW7m76nQzS/art.json index 5dd4229d..572cc4e5 100644 --- a/art/dxaRX4ZTW7m76nQzS/art.json +++ b/art/dxaRX4ZTW7m76nQzS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 50\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float sizeFactor = 1./50.;\\n float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n \\n //LOGISTIC\\n \\n //vec2 p = vec2(fragCoord.x / iResolution.x, fragCoord.y / iResolution.y);\\n \\n \\n vec2 vp = vec2(0.,0.);\\n float z = fract(0.02+time+shapeRelId);//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n int acc = 0;\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + vp.x * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n //acc += (z > p.y && z <= p.y + 1. / iResolution.y) ? 1 : 0;\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n float g = 25. * float(acc) / iters;\\n\\n cubep.x+= z*10.;\\n cubep.z+= shapeRelId*10.;\\n cubep.z+= snd*10.;\\n //fragColor = vec4(g, g /3., g / 8.,1.);\\n\\n\\n //END LOGISTIC\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n vec3 eye = vec3(2., 2., -1.2);\\n \\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(3.0, 0., 2.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 50\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float sizeFactor = 1./50.;\n float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n \n //LOGISTIC\n \n //vec2 p = vec2(fragCoord.x / iResolution.x, fragCoord.y / iResolution.y);\n \n \n vec2 vp = vec2(0.,0.);\n float z = fract(0.02+time+shapeRelId);//sin(shapeRelId+fract(time/100.));//fract(0.02);\n int acc = 0;\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + vp.x * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n //acc += (z > p.y && z <= p.y + 1. / iResolution.y) ? 1 : 0;\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n float g = 25. * float(acc) / iters;\n\n cubep.x+= z*10.;\n cubep.z+= shapeRelId*10.;\n cubep.z+= snd*10.;\n //fragColor = vec4(g, g /3., g / 8.,1.);\n\n\n //END LOGISTIC\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n vec3 eye = vec3(2., 2., -1.2);\n \n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(3.0, 0., 2.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-gigotnf0l8dqjvi72-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dxmjSBXBuwTbPjkQZ/art.json b/art/dxmjSBXBuwTbPjkQZ/art.json index 39a6eee3..9b92ea11 100644 --- a/art/dxmjSBXBuwTbPjkQZ/art.json +++ b/art/dxmjSBXBuwTbPjkQZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":73,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.06666666666666667,0.06666666666666667,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 4\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\n \\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\nconst vec4 model_offset = vec4(0.0,2.0,7.5,0.0);\\nconst vec4 light = vec4(-.8,.8,-.2,1.0);\\n\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 2., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \\ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \\ntriangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( 1326.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \\ntriangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \\ntriangles[ 8]=vec4( 4.0, 47.0, 1326.0, 4.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI) ) {\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,-normals[0].zxy);\\n }\\n \\n n2=vec4(dot(n2,light));\\n gl_Position=tr*gl_Position;\\n v_color = n2/6.0+0.05*(vec4(.0,.0,.70,0.0));\\n v_color.w=1.0;\\n gl_Position.z-=10.0;\\n gl_Position = persp * gl_Position;\\n\\n}\"}", + "settings": { + "num": 73, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.06666666666666667, + 0.06666666666666667, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 4\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\n \nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\nconst vec4 model_offset = vec4(0.0,2.0,7.5,0.0);\nconst vec4 light = vec4(-.8,.8,-.2,1.0);\n\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 2., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \ntriangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \ntriangles[ 4]=vec4( 1326.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \ntriangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \ntriangles[ 8]=vec4( 4.0, 47.0, 1326.0, 4.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI) ) {\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,-normals[0].zxy);\n }\n \n n2=vec4(dot(n2,light));\n gl_Position=tr*gl_Position;\n v_color = n2/6.0+0.05*(vec4(.0,.0,.70,0.0));\n v_color.w=1.0;\n gl_Position.z-=10.0;\n gl_Position = persp * gl_Position;\n\n}" + }, "screenshotURL": "data/images/images-cfk53e015vkune1kt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dxtwYFtYDMAdGgpJm/art.json b/art/dxtwYFtYDMAdGgpJm/art.json index d7b9f2b6..13fd7ac6 100644 --- a/art/dxtwYFtYDMAdGgpJm/art.json +++ b/art/dxtwYFtYDMAdGgpJm/art.json @@ -27,7 +27,19 @@ "name": "pulseaudio", "private": false, "username": "gman", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/v-e-r-t-e/track1\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 51.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS - offset;\\n// float rPulse = pow(sin(time * 3. + -count * 0.05), 4.0);\\n float spread = 0.01;\\n float off = 0.1;\\n float speed = count * 0.004;\\n float snd = (\\n texture2D(sound, vec2(off + spread * 0., speed)).a +\\n texture2D(sound, vec2(off + spread * 1., speed)).a + \\n texture2D(sound, vec2(off + spread * 2., speed)).a) / 2.;\\n// radius = radius + pow(snd, 5.0) * 0.1;\\n// float radius = count * 0.02 + rPlus * 0.2 + 0.0;\\n float rPulse = pow(snd, 5.0);\\n float radius = count * 0.02 + rPulse * 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(c, s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n gl_PointSize = 2.0 + length(xy) * 20. * resolution.x / 1600.0;\\n\\n float hue = (time * 0.03 + count * 1.001);\\n float cPulse = pow(rPulse, 2.0);\\n float invCPulse = 1. - cPulse;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, invCPulse, 1.)), 1), background, radius - cPulse);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/v-e-r-t-e/track1", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 51.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS - offset;\n// float rPulse = pow(sin(time * 3. + -count * 0.05), 4.0);\n float spread = 0.01;\n float off = 0.1;\n float speed = count * 0.004;\n float snd = (\n texture2D(sound, vec2(off + spread * 0., speed)).a +\n texture2D(sound, vec2(off + spread * 1., speed)).a + \n texture2D(sound, vec2(off + spread * 2., speed)).a) / 2.;\n// radius = radius + pow(snd, 5.0) * 0.1;\n// float radius = count * 0.02 + rPlus * 0.2 + 0.0;\n float rPulse = pow(snd, 5.0);\n float radius = count * 0.02 + rPulse * 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(c, s);\n gl_Position = vec4(xy * aspect, 0, 1);\n gl_PointSize = 2.0 + length(xy) * 20. * resolution.x / 1600.0;\n\n float hue = (time * 0.03 + count * 1.001);\n float cPulse = pow(rPulse, 2.0);\n float invCPulse = 1. - cPulse;\n v_color = mix(vec4(hsv2rgb(vec3(hue, invCPulse, 1.)), 1), background, radius - cPulse);\n}" + }, "screenshotURL": "data/images/images-fhuydt3s73bz1udky-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dyCMb2QsTKKjPQptu/art.json b/art/dyCMb2QsTKKjPQptu/art.json index d4728cc2..85678fdc 100644 --- a/art/dyCMb2QsTKKjPQptu/art.json +++ b/art/dyCMb2QsTKKjPQptu/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":210,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main() {\\n float t2 = floor(time*10.);\\n float tr = rand(vec2(t2,t2));\\n float x = vertexId - 20.0*floor(vertexId / 20.);\\n float y = floor(vertexId / 20.)*1.0;\\n \\n \\n float cx = 1. * cos(vertexId*0.03) + rand(vec2(x+tr, y))*0.03;\\n float cy = 1. * sin(vertexId*0.03) + rand(vec2(y+tr, x))*0.07;\\n //gl_Position = vec4(0.01*x, 0.01*y, 0, 0.5);\\n gl_Position = vec4(cx, cy*0.3, 0, 2);\\n \\n v_color = vec4(1, 0, 0, 0);\\n}\"}", + "settings": { + "num": 210, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main() {\n float t2 = floor(time*10.);\n float tr = rand(vec2(t2,t2));\n float x = vertexId - 20.0*floor(vertexId / 20.);\n float y = floor(vertexId / 20.)*1.0;\n \n \n float cx = 1. * cos(vertexId*0.03) + rand(vec2(x+tr, y))*0.03;\n float cy = 1. * sin(vertexId*0.03) + rand(vec2(y+tr, x))*0.07;\n //gl_Position = vec4(0.01*x, 0.01*y, 0, 0.5);\n gl_Position = vec4(cx, cy*0.3, 0, 2);\n \n v_color = vec4(1, 0, 0, 0);\n}" + }, "screenshotURL": "data/images/images-egsf5elfbcskg8bvh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/dzCu7QoEjYiNTWqFD/art.json b/art/dzCu7QoEjYiNTWqFD/art.json index f26570fe..991eaa85 100644 --- a/art/dzCu7QoEjYiNTWqFD/art.json +++ b/art/dzCu7QoEjYiNTWqFD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "antoine", "avatarUrl": "https://lh4.googleusercontent.com/-9Jawf2P8ZPU/AAAAAAAAAAI/AAAAAAAAAHA/GxUGacmbvXo/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 ToPolar(vec3 uv, float K, float percent) {\\n float R = sqrt(dot(uv,uv)) + K;\\n R = mix(1.0, R, percent);\\n return vec3(uv / R);\\n}\\n\\nvec2 ToCartesian(vec2 uv, float K) {\\n return vec2(uv.x / sqrt(uv.x*uv.x + K*K), uv.y / sqrt(uv.y*uv.y + K*K));\\n}\\n\\nvoid main() {\\n float planecount = floor(vertexId / 10000.0);\\n float restplane = mod(vertexId, 10000.0);\\n vec3 point = (vec3(floor(restplane / 100.0) , mod(restplane, 100.0), planecount*5.0) - 50.0) * 0.035;\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\n \\n float K = 0.5;\\n float percent = sin(time * 1.0) * 0.5 + 0.5;\\n \\n vec3 xyz = ToPolar(point, K, percent);\\n vec2 xy = xyz.xy;// / xyz.z;\\n //gl_Position = vec4(xy * aspect + mouse * 0.5, 0, 1);\\n gl_Position = vec4(xy * aspect + mouse * 0.5, xyz.z, 1.0);\\n gl_PointSize = 4.0;\\n\\n v_color = vec4(abs(sin(xy*10.0)),abs(point.z*0.5), 1.0);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 ToPolar(vec3 uv, float K, float percent) {\n float R = sqrt(dot(uv,uv)) + K;\n R = mix(1.0, R, percent);\n return vec3(uv / R);\n}\n\nvec2 ToCartesian(vec2 uv, float K) {\n return vec2(uv.x / sqrt(uv.x*uv.x + K*K), uv.y / sqrt(uv.y*uv.y + K*K));\n}\n\nvoid main() {\n float planecount = floor(vertexId / 10000.0);\n float restplane = mod(vertexId, 10000.0);\n vec3 point = (vec3(floor(restplane / 100.0) , mod(restplane, 100.0), planecount*5.0) - 50.0) * 0.035;\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \n \n float K = 0.5;\n float percent = sin(time * 1.0) * 0.5 + 0.5;\n \n vec3 xyz = ToPolar(point, K, percent);\n vec2 xy = xyz.xy;// / xyz.z;\n //gl_Position = vec4(xy * aspect + mouse * 0.5, 0, 1);\n gl_Position = vec4(xy * aspect + mouse * 0.5, xyz.z, 1.0);\n gl_PointSize = 4.0;\n\n v_color = vec4(abs(sin(xy*10.0)),abs(point.z*0.5), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-13nb2u24chetl8cd1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/dzGkjTSDwbutqCp57/art.json b/art/dzGkjTSDwbutqCp57/art.json index 4ec21a1d..81c8b35b 100644 --- a/art/dzGkjTSDwbutqCp57/art.json +++ b/art/dzGkjTSDwbutqCp57/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":15989,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Circles from Triangles\\n//cs250\\n//spring 2023\\n\\n\\n\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n \\n \\tfloat ux = floor(id /6.) + mod(id,2.);\\n \\tfloat vy = mod( floor(id/2.) + floor(id /3.),2.);\\n \\n \\n \\tfloat angle = ux / numCircleSegments * PI * 2.;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n \\n \\tfloat radius = vy + 1.;\\n \\n \\tfloat x = c * radius;\\n \\tfloat y = s * radius;\\n \\n \\n \\treturn vec2(x,y);\\n\\n\\n \\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float sliceId = floor(vertexId /6.0);\\n float oddSlice =- mod(sliceId, 2.);\\n \\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd+ 0.2 ,5.) * mix(1. , 1.1 , oddSlice );\\n \\n sc*= 25. / across;\\n \\n \\n vec4 pos = vec4(circleXY+ sliceId/60. *0.05,0,1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time *0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03*sc);\\n \\n \\n\\n \\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\\n float sat = mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n \\n hue = hue +pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 15989, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Circles from Triangles\n//cs250\n//spring 2023\n\n\n\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n \n \tfloat ux = floor(id /6.) + mod(id,2.);\n \tfloat vy = mod( floor(id/2.) + floor(id /3.),2.);\n \n \n \tfloat angle = ux / numCircleSegments * PI * 2.;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n \n \tfloat radius = vy + 1.;\n \n \tfloat x = c * radius;\n \tfloat y = s * radius;\n \n \n \treturn vec2(x,y);\n\n\n \n}\n\n\nvoid main() {\n \n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float sliceId = floor(vertexId /6.0);\n float oddSlice =- mod(sliceId, 2.);\n \n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd+ 0.2 ,5.) * mix(1. , 1.1 , oddSlice );\n \n sc*= 25. / across;\n \n \n vec4 pos = vec4(circleXY+ sliceId/60. *0.05,0,1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time *0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03*sc);\n \n \n\n \n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\n float sat = mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n \n hue = hue +pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-4iqv8z2kkavbf68yl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/e6LP3FE5P3qePgJk6/art.json b/art/e6LP3FE5P3qePgJk6/art.json index 01a7f42a..7da4f0f9 100644 --- a/art/e6LP3FE5P3qePgJk6/art.json +++ b/art/e6LP3FE5P3qePgJk6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/sunrizer-mantra\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n float v = vertexId;\\n //float sndFactor = texture2D(sound, vec2(;\\n float off = .1;\\n float scale = 0.0001 * vertexCount / vertexId;\\n float grid = floor(vertexCount / 1000.);\\n\\n \\n float x = sin(v + scale + time);\\n float y = cos(v + time / 1.3 );\\n \\n float ux = x * scale - off;\\n float uy = y * scale - off;\\n \\n gl_Position =vec4(ux, uy, 0, 1);\\n gl_PointSize = 10. * scale ;// grid;\\n v_color = vec4(sin(scale), sin(vertexId), sin(time), 1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/sunrizer-mantra", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n float v = vertexId;\n //float sndFactor = texture2D(sound, vec2(;\n float off = .1;\n float scale = 0.0001 * vertexCount / vertexId;\n float grid = floor(vertexCount / 1000.);\n\n \n float x = sin(v + scale + time);\n float y = cos(v + time / 1.3 );\n \n float ux = x * scale - off;\n float uy = y * scale - off;\n \n gl_Position =vec4(ux, uy, 0, 1);\n gl_PointSize = 10. * scale ;// grid;\n v_color = vec4(sin(scale), sin(vertexId), sin(time), 1);\n \n}" + }, "screenshotURL": "data/images/images-afsezdz6s5r4li5zg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/e96He2kRbxRk7o6N8/art.json b/art/e96He2kRbxRk7o6N8/art.json index 4a0aa40d..2d8d4edc 100644 --- a/art/e96He2kRbxRk7o6N8/art.json +++ b/art/e96He2kRbxRk7o6N8/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"///GLSL\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\\n /*RGB */\\n v_color = vec4(1.0, .0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "///GLSL\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\n /*RGB */\n v_color = vec4(1.0, .0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-ccfb5gedaofu8r9v3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/e9b2X5LXefT2W9oh4/art.json b/art/e9b2X5LXefT2W9oh4/art.json index 8519c5e2..0b72f39a 100644 --- a/art/e9b2X5LXefT2W9oh4/art.json +++ b/art/e9b2X5LXefT2W9oh4/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.13725490196078433,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0/3.0, 1.0/3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\\n vertexId;\\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\\n float x = mod(vertexId, across);\\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n gl_Position = vec4(xy, 0., 1.);\\n \\n float szoff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n\\n gl_PointSize = 15.0 + szoff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u*.1 + sin(time * 1.3 + v * 20.) * 0.10;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * 0.5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), val);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.13725490196078433, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0/3.0, 1.0/3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\n vertexId;\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\n float x = mod(vertexId, across);\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n gl_Position = vec4(xy, 0., 1.);\n \n float szoff = sin(time * 1.2 + x * y * 0.02) * 5.;\n\n gl_PointSize = 15.0 + szoff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u*.1 + sin(time * 1.3 + v * 20.) * 0.10;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * 0.5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), val);\n}" + }, "screenshotURL": "data/images/images-srru68via052ri2kt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eBpxuAodpyWjT6Asr/art.json b/art/eBpxuAodpyWjT6Asr/art.json index a0c317c8..52a2efbb 100644 --- a/art/eBpxuAodpyWjT6Asr/art.json +++ b/art/eBpxuAodpyWjT6Asr/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":19746,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 -3.//KParameter0 -4.>>5.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>2.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n\\n#define PI radians(90.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 2.00);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 11.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 2. +parameter2 );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -31.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n c, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * parameter0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 1./parameter2,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0.3, 1, 0, 0,\\n 0, 0, (1./ parameter3), 0.3,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 3. / 2.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 32.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = tan(0.7 - parameter4);\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t - 2.27) + tan(t * 0.13+mouse.x) + cos(t- .73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(.2, mod(circleId, .076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - 3.3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 10.18 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId + 10.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) /.4;\\n offset.y += goop(circleId + time * 0.13) * .31- mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.002)).xyz, 0.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = 3.*(1.3*snd, 2.6/snd, sin(circleId +1.79));\\n float sat = 1.2 * (circleId*snd);\\n float val = .69;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. / uv.y) * tan(pos / 83.1* snd));\\n v_color = vec4(v_color.rgb - v_color.a*5., v_color.a);\\n}\"}", + "settings": { + "num": 19746, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 -3.//KParameter0 -4.>>5.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>2.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n\n#define PI radians(90.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 2.00);\n vec3 p = abs(fract(c.xxx + K.xyz) * 11.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 2. +parameter2 );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -31.);\n \t\n return mat4( \n c,-s, 0, 0, \n c, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * parameter0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 1./parameter2,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0.3, 1, 0, 0,\n 0, 0, (1./ parameter3), 0.3,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 3. / 2.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 32.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = tan(0.7 - parameter4);\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t - 2.27) + tan(t * 0.13+mouse.x) + cos(t- .73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(.2, mod(circleId, .076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - 3.3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 10.18 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId + 10.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) /.4;\n offset.y += goop(circleId + time * 0.13) * .31- mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.002)).xyz, 0.2);\n gl_PointSize = sin(5. *snd);\n float hue = 3.*(1.3*snd, 2.6/snd, sin(circleId +1.79));\n float sat = 1.2 * (circleId*snd);\n float val = .69;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. / uv.y) * tan(pos / 83.1* snd));\n v_color = vec4(v_color.rgb - v_color.a*5., v_color.a);\n}" + }, "screenshotURL": "data/images/images-2ibox6kclp7osyvv5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eCTzFjq4bRAxBAC7h/art.json b/art/eCTzFjq4bRAxBAC7h/art.json index e7cf00c5..6d010ae1 100644 --- a/art/eCTzFjq4bRAxBAC7h/art.json +++ b/art/eCTzFjq4bRAxBAC7h/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 2.0 * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.530,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 2.0 * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.530,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-2ogmchyi1l2biqky3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eCgwSmrFuafedggBy/art.json b/art/eCgwSmrFuafedggBy/art.json index e68c84a0..840e4207 100644 --- a/art/eCgwSmrFuafedggBy/art.json +++ b/art/eCgwSmrFuafedggBy/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\n\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = abs(sin(time * 0.6 + y * 0.1)) * 1.;\\n float yoff = sin(time + x * 0.3) * 1.;\\n \\n float ux = cos(u * 2.) - 1. + xoff;\\n float vy = sin(v * 2.) - 1. + yoff;\\n\\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x* y* 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.5;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v*u*20.0)*.5+.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\n\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = abs(sin(time * 0.6 + y * 0.1)) * 1.;\n float yoff = sin(time + x * 0.3) * 1.;\n \n float ux = cos(u * 2.) - 1. + xoff;\n float vy = sin(v * 2.) - 1. + yoff;\n\n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x* y* 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.5;\n float sat = 1.;\n float val = sin(time * 1.4 + v*u*20.0)*.5+.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}" + }, "screenshotURL": "data/images/images-bl6osed6ycyuabwum-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eCtymAejxmi75Fg78/art.json b/art/eCtymAejxmi75Fg78/art.json index 39e7ed58..d453a7fa 100644 --- a/art/eCtymAejxmi75Fg78/art.json +++ b/art/eCtymAejxmi75Fg78/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time + v * 20.);\\n float sat = 1.;\\n float val = 1.;\\n\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time + v * 20.);\n float sat = 1.;\n float val = 1.;\n\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-w4lm489ltdpqzowwm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eDqQBCKFjn2a35csa/art.json b/art/eDqQBCKFjn2a35csa/art.json index 2043f170..1b2c9830 100644 --- a/art/eDqQBCKFjn2a35csa/art.json +++ b/art/eDqQBCKFjn2a35csa/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "ilyadorosh", "avatarUrl": "https://avatars.githubusercontent.com/ilyadorosh?s=200", - "settings": "{\"num\":28595,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\nvec3 inv(vec3 a){return 1.-a;}\\n\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n \\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n for (int i = 0; i < 60; i++) {\\n float f=float(i);\\n \\n }\\n \\n float a = pos.x;//fract(sin(dot(floor(pos.xy*8.0+time*2.0),vec2(5.364,6.357)))*357.536);\\n //a=2.*a-1.;\\n vec3 color = vec3(a, -a, abs(a));\\n color = inv(color); \\n \\n light = dot(vec3(.9,.9,.1),norm)*\\n color;\\n /*\\n \\n pow(dot(normalize(vec3(.3,.4,-.5)),norm)*.5+.5,50.)*vec3(.8,.3,.2)\\n \\t+ pow(dot(normalize(vec3(.1,-.2,-.5)),norm)*.5+.5,50.)*vec3(.2,.3,.8)\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,50.)*vec3(.2,.7,.4)\\n \\t+ pow(dot(normalize(vec3(.7,-.2,-.5)),norm)*.5+.5,50.)*vec3(.7,.6,.1);\\n */\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n\\n v_color = vec4(light, 1);\\n}\\n\\n// Unmodified fork from \\\"disco ball\\\" by -anon-\\n// Added music\\n\\n\\n\"}", + "settings": { + "num": 28595, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\nvec3 inv(vec3 a){return 1.-a;}\n\n\nvoid main() {\n float localTime = time + 20.0;\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n \n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n for (int i = 0; i < 60; i++) {\n float f=float(i);\n \n }\n \n float a = pos.x;//fract(sin(dot(floor(pos.xy*8.0+time*2.0),vec2(5.364,6.357)))*357.536);\n //a=2.*a-1.;\n vec3 color = vec3(a, -a, abs(a));\n color = inv(color); \n \n light = dot(vec3(.9,.9,.1),norm)*\n color;\n /*\n \n pow(dot(normalize(vec3(.3,.4,-.5)),norm)*.5+.5,50.)*vec3(.8,.3,.2)\n \t+ pow(dot(normalize(vec3(.1,-.2,-.5)),norm)*.5+.5,50.)*vec3(.2,.3,.8)\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,50.)*vec3(.2,.7,.4)\n \t+ pow(dot(normalize(vec3(.7,-.2,-.5)),norm)*.5+.5,50.)*vec3(.7,.6,.1);\n */\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n\n v_color = vec4(light, 1);\n}\n\n// Unmodified fork from \"disco ball\" by -anon-\n// Added music\n\n\n" + }, "screenshotURL": "data/images/images-y4nabnsgbde7qw1v5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eE6QrFjkFRdezQsuW/art.json b/art/eE6QrFjkFRdezQsuW/art.json index d686efbc..25775a83 100644 --- a/art/eE6QrFjkFRdezQsuW/art.json +++ b/art/eE6QrFjkFRdezQsuW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.13333333333333333,0.4,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 3.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 2.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, mouse.xy);\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.06;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background-.13, vCubeCol.a* 1.36);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.13333333333333333, + 0.4, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 3.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 2.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, mouse.xy);\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.06;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background-.13, vCubeCol.a* 1.36);\n \n}" + }, "screenshotURL": "data/images/images-wskcldpcdj1waig9s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eGvHvcKj3nHkhw9C6/art.json b/art/eGvHvcKj3nHkhw9C6/art.json index c275eef4..065da452 100644 --- a/art/eGvHvcKj3nHkhw9C6/art.json +++ b/art/eGvHvcKj3nHkhw9C6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":18619,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/abc-trance-king-arturia-ms2k\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Spiral Circle thingy\\n\\n\\nvoid main () {\\n float v = vertexId;\\n float vc = vertexCount * (1. + sin(time/2000.));\\n //float sndFactor = texture2D(sound, vec2(;\\n \\n float spiral = 1. - 1.9 * v / (vc * vc);\\n \\n float grid = floor(vc / 1000.);\\n float step100 = floor (100. * v / vc); \\n float sndFactor = texture2D(sound, vec2(mod(step100, 4.), step100/400.)).a;\\n float scale = 0.1 * (7. * sndFactor);\\n \\n float xoff = sndFactor * (sin(time/1.)/2.) * 0.5;\\n float yoff = sndFactor * (sin(time/1.1)/2.) * 0.5;\\n \\n float y = sin(v / (50. * (2. + sin(time * 2000.)))) * spiral;\\n float x = cos(v / (50. * (2. + sin(time * 2010.)))) * spiral;\\n \\n float ux = x * scale - xoff;\\n float uy = y * scale - yoff;\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = sndFactor * 5.;//v / (sndFactor *100000.) ;// grid;\\n \\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\\n //v_color = vec4(sin(spiral * 5. +time + sndFactor), 0.1, 0.5, 1);\\n v_color = vec4(sndFactor * 2., sin(1./spiral), 1./spiral, 1);\\n}\"}", + "settings": { + "num": 18619, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/abc-trance-king-arturia-ms2k", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Spiral Circle thingy\n\n\nvoid main () {\n float v = vertexId;\n float vc = vertexCount * (1. + sin(time/2000.));\n //float sndFactor = texture2D(sound, vec2(;\n \n float spiral = 1. - 1.9 * v / (vc * vc);\n \n float grid = floor(vc / 1000.);\n float step100 = floor (100. * v / vc); \n float sndFactor = texture2D(sound, vec2(mod(step100, 4.), step100/400.)).a;\n float scale = 0.1 * (7. * sndFactor);\n \n float xoff = sndFactor * (sin(time/1.)/2.) * 0.5;\n float yoff = sndFactor * (sin(time/1.1)/2.) * 0.5;\n \n float y = sin(v / (50. * (2. + sin(time * 2000.)))) * spiral;\n float x = cos(v / (50. * (2. + sin(time * 2010.)))) * spiral;\n \n float ux = x * scale - xoff;\n float uy = y * scale - yoff;\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = sndFactor * 5.;//v / (sndFactor *100000.) ;// grid;\n \n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\n //v_color = vec4(sin(spiral * 5. +time + sndFactor), 0.1, 0.5, 1);\n v_color = vec4(sndFactor * 2., sin(1./spiral), 1./spiral, 1);\n}" + }, "screenshotURL": "data/images/images-esgcw10v878wlcldk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eH67ZJMsPmJWmEdoK/art.json b/art/eH67ZJMsPmJWmEdoK/art.json index c5f8c186..dc707344 100644 --- a/art/eH67ZJMsPmJWmEdoK/art.json +++ b/art/eH67ZJMsPmJWmEdoK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":840,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n//Vector 4\\n float width = 20.0;\\n float row = 42.0 * 15.0;\\n float circleID = mod(vertexId, row);\\n \\n float y = mod(vertexId + 1.0, 2.0);\\n float x = floor(vertexId / 2.0);\\n float movx = floor(circleID/42.0) * 1.1;\\n float movy = floor(vertexId/ row) * 1.1;\\n float ang = (x/20.0)*radians(360.0);\\n float r = 2.0 - y;\\n float rx = r * cos(ang);\\n float ry = r *sin (ang);\\n \\n float u = rx / (width - 1.0);\\n float v = ry / (width - 1.0);\\n \\n float xOffset = cos(time + movy * 0.2) * 0.1;\\n float yOffset = sin(time + movx * 0.2) * 0.1;\\n \\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2 (ux + movx, uy + movy) * 0.2;\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n}\\n\"}", + "settings": { + "num": 840, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n//Vector 4\n float width = 20.0;\n float row = 42.0 * 15.0;\n float circleID = mod(vertexId, row);\n \n float y = mod(vertexId + 1.0, 2.0);\n float x = floor(vertexId / 2.0);\n float movx = floor(circleID/42.0) * 1.1;\n float movy = floor(vertexId/ row) * 1.1;\n float ang = (x/20.0)*radians(360.0);\n float r = 2.0 - y;\n float rx = r * cos(ang);\n float ry = r *sin (ang);\n \n float u = rx / (width - 1.0);\n float v = ry / (width - 1.0);\n \n float xOffset = cos(time + movy * 0.2) * 0.1;\n float yOffset = sin(time + movx * 0.2) * 0.1;\n \n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2 (ux + movx, uy + movy) * 0.2;\n \n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n}\n" + }, "screenshotURL": "data/images/images-yeqq5rwl4o9saxhr2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eJGcWNyj42atTeXsz/art.json b/art/eJGcWNyj42atTeXsz/art.json index 7fdb639f..fcb8c3a9 100644 --- a/art/eJGcWNyj42atTeXsz/art.json +++ b/art/eJGcWNyj42atTeXsz/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "richel", "avatarUrl": "https://graph.facebook.com/1269313776429568/picture?type=large", - "settings": "{\"num\":600,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/industrialpope/pferdloss\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() \\n{\\n vec2 coords;\\n coords.x = mod(vertexId, 30.0);\\n coords.y = floor(vertexId / 30.0);\\n \\n float u = 1.0 / 30.0 * coords.x;\\n float v = 1.0 / 20.0 * coords.y;\\n\\n float posX = -0.7 + ((1.4 / 30.0) * coords.x);\\n posX += sin(time) * 0.1;\\n \\n float posY = -0.7 + (1.4 / 20.0) * coords.y;\\n posY += sin(time + coords.x * 0.1) * 0.1;\\n \\n float posZ = -1.0;//sin(coords.x + time);\\n \\n gl_Position = vec4(posX, posY, posZ, 1);\\n\\n if(coords.x > 13.0 && coords.x < 16.0 ||\\n coords.y > 8.5 && coords.y < 12. )\\n {\\n v_color = vec4(1.0, 1.0, 1.0, 1);\\n }\\n else\\n {\\n v_color = vec4(1.0, 0.0, 0.0, 1);\\n }\\n \\n //gl_PointSize = snd;\\n \\n \\n gl_PointSize = 10.0 + (0.5 + sin(posX * posY * 10.0 + time * 2.0) * 0.5) * 20.0;\\n}\"}", + "settings": { + "num": 600, + "mode": "POINTS", + "sound": "https://soundcloud.com/industrialpope/pferdloss", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() \n{\n vec2 coords;\n coords.x = mod(vertexId, 30.0);\n coords.y = floor(vertexId / 30.0);\n \n float u = 1.0 / 30.0 * coords.x;\n float v = 1.0 / 20.0 * coords.y;\n\n float posX = -0.7 + ((1.4 / 30.0) * coords.x);\n posX += sin(time) * 0.1;\n \n float posY = -0.7 + (1.4 / 20.0) * coords.y;\n posY += sin(time + coords.x * 0.1) * 0.1;\n \n float posZ = -1.0;//sin(coords.x + time);\n \n gl_Position = vec4(posX, posY, posZ, 1);\n\n if(coords.x > 13.0 && coords.x < 16.0 ||\n coords.y > 8.5 && coords.y < 12. )\n {\n v_color = vec4(1.0, 1.0, 1.0, 1);\n }\n else\n {\n v_color = vec4(1.0, 0.0, 0.0, 1);\n }\n \n //gl_PointSize = snd;\n \n \n gl_PointSize = 10.0 + (0.5 + sin(posX * posY * 10.0 + time * 2.0) * 0.5) * 20.0;\n}" + }, "screenshotURL": "data/images/images-roo7qc84qtx33ghvq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eKqemqRBragaEs55Y/art.json b/art/eKqemqRBragaEs55Y/art.json index 8039a1b1..eaa4c63a 100644 --- a/art/eKqemqRBragaEs55Y/art.json +++ b/art/eKqemqRBragaEs55Y/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 5.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.25, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * 1.319)) * 2. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 5.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.25, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * 1.319)) * 2. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-eztlitzffj21uloyh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eLAMSS8iwH7ip3sS6/art.json b/art/eLAMSS8iwH7ip3sS6/art.json index f9da4fac..50437b9d 100644 --- a/art/eLAMSS8iwH7ip3sS6/art.json +++ b/art/eLAMSS8iwH7ip3sS6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":61555,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = u * fract(time / PI * 0.25) - 1.0 * snd;\\n float y = v * fract(time / PI * 0.25) - 1.0 * snd * s;\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 6.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 20. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown *snd; \\n gl_PointSize *= resolution.x / 30. * xOff; \\n xy -= vec2(0.5);\\n xy *= rotate2D(snd * PI * 2.0);\\n xy += vec2(0.5);\\n //xy.normalize();\\n gl_Position = vec4(xy, xOff , yOff);\\n xy -= vec2(0.5);\\n //xy *= rotate2D(-snd * -PI * -2.0);\\n xy += vec2(0.5);\\n float hue = snd;\\n float sat = invV;\\n float val = invV;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n //color *= rotY(PI * snd * 2.);\\n v_color = mix(color, background, v * v);\\n}\"}", + "settings": { + "num": 61555, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = u * fract(time / PI * 0.25) - 1.0 * snd;\n float y = v * fract(time / PI * 0.25) - 1.0 * snd * s;\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 6.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 20. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown *snd; \n gl_PointSize *= resolution.x / 30. * xOff; \n xy -= vec2(0.5);\n xy *= rotate2D(snd * PI * 2.0);\n xy += vec2(0.5);\n //xy.normalize();\n gl_Position = vec4(xy, xOff , yOff);\n xy -= vec2(0.5);\n //xy *= rotate2D(-snd * -PI * -2.0);\n xy += vec2(0.5);\n float hue = snd;\n float sat = invV;\n float val = invV;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n //color *= rotY(PI * snd * 2.);\n v_color = mix(color, background, v * v);\n}" + }, "screenshotURL": "data/images/images-eftxxh3r2qrv46yb1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eMAJ5HydzdzbnzduF/art.json b/art/eMAJ5HydzdzbnzduF/art.json index c5bf4938..b91ccfe5 100644 --- a/art/eMAJ5HydzdzbnzduF/art.json +++ b/art/eMAJ5HydzdzbnzduF/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "demoniak", "avatarUrl": "https://avatars.githubusercontent.com/johanberonius?s=200", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.5) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-1138c3q08ikgv8ltn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eN9F6DmmRZpCrr3v4/art.json b/art/eN9F6DmmRZpCrr3v4/art.json index f72398d0..0109cfea 100644 --- a/art/eN9F6DmmRZpCrr3v4/art.json +++ b/art/eN9F6DmmRZpCrr3v4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":834,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.01568627450980392,0.047058823529411764,1],\"shader\":\"void main(){\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId , across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\n \\tfloat ux = u * 2. - 1.;\\n \\tfloat vy = v * 2. - 1.;\\n \\n\\tgl_Position = vec4(1.0, 1.0, 0.0, 1.0);\\n \\n \\n \\tgl_PointSize = 10.0;\\n \\tgl_PointSize *= 20./across;\\n\\t \\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 834, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.01568627450980392, + 0.047058823529411764, + 1 + ], + "shader": "void main(){\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId , across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \n \tfloat ux = u * 2. - 1.;\n \tfloat vy = v * 2. - 1.;\n \n\tgl_Position = vec4(1.0, 1.0, 0.0, 1.0);\n \n \n \tgl_PointSize = 10.0;\n \tgl_PointSize *= 20./across;\n\t \n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-un9u5t0lu637ljqdb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ePRvbCFXEeYiRFk7c/art.json b/art/ePRvbCFXEeYiRFk7c/art.json index 643cde68..e3ede2a6 100644 --- a/art/ePRvbCFXEeYiRFk7c/art.json +++ b/art/ePRvbCFXEeYiRFk7c/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "ricardomatias", "avatarUrl": "https://avatars.githubusercontent.com/ricardomatias?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\t\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.8;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * .5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \t\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.8;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * .5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-cwi67s73rmygd8hpb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ePt2CZtNzQzvEYWAy/art.json b/art/ePt2CZtNzQzvEYWAy/art.json index e23d801a..d03bf3fc 100644 --- a/art/ePt2CZtNzQzvEYWAy/art.json +++ b/art/ePt2CZtNzQzvEYWAy/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":2262,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/adhesivewombat/adhesivewombat-8-bit-adventure\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06274509803921569,0.13333333333333333,0.27450980392156865,1],\"shader\":\"//Daehyeon Kim\\n//Motion\\n//CS250\\n//Spring, 2022\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n float snd = texture2D(sound, vec2(sin(time) - 1. , cos(time) - 1.)).b;\\n \\n gl_Position = vec4(xy.x,xy.y , 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff + (snd * 200.) / 20.;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, snd, 0, 1);\\n}\"}", + "settings": { + "num": 2262, + "mode": "POINTS", + "sound": "https://soundcloud.com/adhesivewombat/adhesivewombat-8-bit-adventure", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06274509803921569, + 0.13333333333333333, + 0.27450980392156865, + 1 + ], + "shader": "//Daehyeon Kim\n//Motion\n//CS250\n//Spring, 2022\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n float snd = texture2D(sound, vec2(sin(time) - 1. , cos(time) - 1.)).b;\n \n gl_Position = vec4(xy.x,xy.y , 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff + (snd * 200.) / 20.;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, snd, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ddcvng4qrduru4txl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eQWS62YSydqjQaeSx/art.json b/art/eQWS62YSydqjQaeSx/art.json index 02734ca3..0a4d4025 100644 --- a/art/eQWS62YSydqjQaeSx/art.json +++ b/art/eQWS62YSydqjQaeSx/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = vertexId * 0.1;\\n float y = vertexId * 0.1;\\n gl_Position = vec4(x, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 7, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = vertexId * 0.1;\n float y = vertexId * 0.1;\n gl_Position = vec4(x, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-etbgzksbg23pzb57f-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eQxQuMzXiCEc7rMYz/art.json b/art/eQxQuMzXiCEc7rMYz/art.json index f588cef4..16801642 100644 --- a/art/eQxQuMzXiCEc7rMYz/art.json +++ b/art/eQxQuMzXiCEc7rMYz/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mtoutside", "avatarUrl": "https://avatars.githubusercontent.com/mtoutside?s=200", - "settings": "{\"num\":120,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/hypercube\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.1607843137254902,0.3254901960784314,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n // id = 0 1 2 3 \\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 20.;\\n vec2 circleXY = getCirclePoint(vertexId,\\n numCircleSegments);\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * .1;\\n float yoff = 0.; //sin(time + x * 0.2) * .2;\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n float soff = 0.; // sin(time + x * y * .002) * 5.;\\n \\n gl_PointSize = snd * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(.8, snd); \\n float hue = u * .1 + snd * .2 + time + .1;\\n float sat = mix(0., 1., pump);\\n float val = 1.; //mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\\n\"}", + "settings": { + "num": 120, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/hypercube", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.1607843137254902, + 0.3254901960784314, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n // id = 0 1 2 3 \n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 20.;\n vec2 circleXY = getCirclePoint(vertexId,\n numCircleSegments);\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float xoff = 0.; //sin(time + y * 0.2) * .1;\n float yoff = 0.; //sin(time + x * 0.2) * .2;\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - .5) * 2.;\n float sv = abs(v - .5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0., 1.);\n \n float soff = 0.; // sin(time + x * y * .002) * 5.;\n \n gl_PointSize = snd * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(.8, snd); \n float hue = u * .1 + snd * .2 + time + .1;\n float sat = mix(0., 1., pump);\n float val = 1.; //mix(1., pow(snd + .2, 5.), pump); //sin(time + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-nwst684nt8u2olosw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eXXeb2MwbgjMFutev/art.json b/art/eXXeb2MwbgjMFutev/art.json index a4bc7536..e9d23e29 100644 --- a/art/eXXeb2MwbgjMFutev/art.json +++ b/art/eXXeb2MwbgjMFutev/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-qbyk2benxn3ynsvcp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/eXepJNmr5e5q3DjWv/art.json b/art/eXepJNmr5e5q3DjWv/art.json index ce2d720b..a55f6759 100644 --- a/art/eXepJNmr5e5q3DjWv/art.json +++ b/art/eXepJNmr5e5q3DjWv/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/bydaruma/duskus-lord-is\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n \\n / / \\n---------__---)__--_/_----__---|/---__---/__----__----__-/----__---)__----__---)__--_/_-\\n | / /___) / ) / /___) | (_ ` / ) / ) / / /___) / ) / ) / ) / \\n__|/__(___ _/_____(_ __(___ __/|__(__)_/___/_(___(_(___/___(___ _/_____(___(_/_____(_ __\\n / \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians( 180. )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotX( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nvoid getShapePoint(const float numPointsPerFace, const float id, const mat4 wvp, out vec4 pos) {\\n float numPointsPerShape = pow(numPointsPerFace, 3.);\\n float numPointsPerWhat = numPointsPerFace * numPointsPerFace;\\n float aId = mod(id, numPointsPerFace);\\n float a = aId / numPointsPerFace;\\n float bId = mod(floor(id / numPointsPerFace), numPointsPerFace);\\n float b = bId / numPointsPerFace;\\n float cId = floor(id / numPointsPerWhat);\\n float c = cId / numPointsPerFace;\\n float a0 = a * PI * 2.;\\n float b0 = b * PI * 2.;\\n float c0 = c * PI * 2.;\\n \\n mat4 m = wvp;\\n m *= rotZ(c0);\\n m *= rotY(b0);\\n m *= rotY(a0);\\n pos = m * vec4(1,1,1,1);\\n}\\n\\n\\nvoid main() { \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.03456;\\n \\tfloat elevation = sin(animTime * 0.223);\\n \\tfloat fOrbitDistance = 30.;\\n \\n vec3 target = vec3(0, 0, 0);\\n vec3 eye = vec3(0, 0, 10);\\n \\t eye = vec3( sin(orbitAngle) * fOrbitDistance , sin(elevation * 1.11) * 10. , cos(orbitAngle)* fOrbitDistance ) ;\\n vec3 up = vec3(0,1,0);\\n \\n float numPointsPerFace = 4.;\\n float numPointsPerShape = pow(numPointsPerFace, 3.);\\n float shapeId = floor(vertexId / numPointsPerShape); \\n float shapeCount = floor(vertexCount / numPointsPerShape);\\n \\n float size = floor(pow(shapeCount, 1./3.));\\n vec3 p = vec3(\\n mod(shapeId, size),\\n mod(floor(shapeId / size), size),\\n floor(floor(shapeId / size) / size));\\n vec3 pv = p / size;\\n \\n float snd = texture2D(sound, vec2(0.05 + pv.x * 0.25, pv.z * 0.2)).a; \\n \\n vec4 pos;\\n mat4 m = ident();\\n m *= persp(45., resolution.x / resolution.y, 0.1, 60.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans((pv * 2. - 1.) * 16.);\\n m *= uniformScale(pow(snd,3.));\\n getShapePoint(numPointsPerFace, vertexId, m, pos);\\n\\n gl_Position = pos;\\n gl_PointSize = 4.;\\n float z = p1m1(pos.z / pos.w);\\n \\n \\t// Final output color\\n v_color = vec4(1,snd,0,z);\\n \\tv_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/bydaruma/duskus-lord-is", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n \n / / \n---------__---)__--_/_----__---|/---__---/__----__----__-/----__---)__----__---)__--_/_-\n | / /___) / ) / /___) | (_ ` / ) / ) / / /___) / ) / ) / ) / \n__|/__(___ _/_____(_ __(___ __/|__(__)_/___/_(___(_(___/___(___ _/_____(___(_/_____(_ __\n / \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians( 180. )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotX( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nvoid getShapePoint(const float numPointsPerFace, const float id, const mat4 wvp, out vec4 pos) {\n float numPointsPerShape = pow(numPointsPerFace, 3.);\n float numPointsPerWhat = numPointsPerFace * numPointsPerFace;\n float aId = mod(id, numPointsPerFace);\n float a = aId / numPointsPerFace;\n float bId = mod(floor(id / numPointsPerFace), numPointsPerFace);\n float b = bId / numPointsPerFace;\n float cId = floor(id / numPointsPerWhat);\n float c = cId / numPointsPerFace;\n float a0 = a * PI * 2.;\n float b0 = b * PI * 2.;\n float c0 = c * PI * 2.;\n \n mat4 m = wvp;\n m *= rotZ(c0);\n m *= rotY(b0);\n m *= rotY(a0);\n pos = m * vec4(1,1,1,1);\n}\n\n\nvoid main() { \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.03456;\n \tfloat elevation = sin(animTime * 0.223);\n \tfloat fOrbitDistance = 30.;\n \n vec3 target = vec3(0, 0, 0);\n vec3 eye = vec3(0, 0, 10);\n \t eye = vec3( sin(orbitAngle) * fOrbitDistance , sin(elevation * 1.11) * 10. , cos(orbitAngle)* fOrbitDistance ) ;\n vec3 up = vec3(0,1,0);\n \n float numPointsPerFace = 4.;\n float numPointsPerShape = pow(numPointsPerFace, 3.);\n float shapeId = floor(vertexId / numPointsPerShape); \n float shapeCount = floor(vertexCount / numPointsPerShape);\n \n float size = floor(pow(shapeCount, 1./3.));\n vec3 p = vec3(\n mod(shapeId, size),\n mod(floor(shapeId / size), size),\n floor(floor(shapeId / size) / size));\n vec3 pv = p / size;\n \n float snd = texture2D(sound, vec2(0.05 + pv.x * 0.25, pv.z * 0.2)).a; \n \n vec4 pos;\n mat4 m = ident();\n m *= persp(45., resolution.x / resolution.y, 0.1, 60.);\n m *= cameraLookAt(eye, target, up);\n m *= trans((pv * 2. - 1.) * 16.);\n m *= uniformScale(pow(snd,3.));\n getShapePoint(numPointsPerFace, vertexId, m, pos);\n\n gl_Position = pos;\n gl_PointSize = 4.;\n float z = p1m1(pos.z / pos.w);\n \n \t// Final output color\n v_color = vec4(1,snd,0,z);\n \tv_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-a9lcjlyadhcmlj9x3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eY9pGfw52QeELpY2y/art.json b/art/eY9pGfw52QeELpY2y/art.json index b5a04dc5..1ec0631d 100644 --- a/art/eY9pGfw52QeELpY2y/art.json +++ b/art/eY9pGfw52QeELpY2y/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":81411,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wbgldn/track-01\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 0.5>>2.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>2.\\n#define parameter3 1.//KParameter3 0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 2.>>1.\\n#define parameter7 1.//KParameter7 -1.>>1.\\n\\n\\n#define PI radians(90. * parameter2)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.8, parameter7));\\n vec4 K = vec4(0.10, 2.5 / 0.7, 1.0 / 3.0/parameter4, (parameter5 - 3.0 * parameter6));\\n vec3 p = abs(fract(c.xxx + K.xyz) - (3.0 / parameter6) + K.www+ parameter3);\\n return c.z * mix(K.xxx, clamp(p / K.xxx, 1.0, parameter0), (c.y *parameter2));\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians -parameter2);\\n \\t\\n return mat4( \\n 1, 0, 0, parameter2,\\n 1, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, parameter6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians- parameter3);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, s,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, (2. - parameter4));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1. * parameter3,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2. / parameter5), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * parameter3;\\n float s = sin(a);\\n float c = cos(a);\\n float x = (c * v -a);\\n float y = s * v;\\n float z = 0.1;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, parameter4 -3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1 + parameter3 / 2.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 81411, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wbgldn/track-01", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 0.5>>2.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>2.\n#define parameter3 1.//KParameter3 0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 2.>>1.\n#define parameter7 1.//KParameter7 -1.>>1.\n\n\n#define PI radians(90. * parameter2)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.8, parameter7));\n vec4 K = vec4(0.10, 2.5 / 0.7, 1.0 / 3.0/parameter4, (parameter5 - 3.0 * parameter6));\n vec3 p = abs(fract(c.xxx + K.xyz) - (3.0 / parameter6) + K.www+ parameter3);\n return c.z * mix(K.xxx, clamp(p / K.xxx, 1.0, parameter0), (c.y *parameter2));\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians -parameter2);\n \t\n return mat4( \n 1, 0, 0, parameter2,\n 1, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, parameter6, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians- parameter3);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, s,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, (2. - parameter4));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1. * parameter3,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2. / parameter5), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * parameter3;\n float s = sin(a);\n float c = cos(a);\n float x = (c * v -a);\n float y = s * v;\n float z = 0.1;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, parameter4 -3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1 + parameter3 / 2.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-uhupqqfvrw1qe0quo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eYuBQN69mTZCKaGdB/art.json b/art/eYuBQN69mTZCKaGdB/art.json index 05a1a41e..21ebd81b 100644 --- a/art/eYuBQN69mTZCKaGdB/art.json +++ b/art/eYuBQN69mTZCKaGdB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14245,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 2.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 37.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\\n \\n vCubeCol.xyz = vec3(0,0,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.1;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0.0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId*snd*22., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, .07770),-10,1,1), color, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 14245, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 2.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 37.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\n \n vCubeCol.xyz = vec3(0,0,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.1;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0.0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId*snd*22., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, .07770),-10,1,1), color, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-qwgw5b71zv43vvguz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/easEJ6iaXWeeR99Gj/art.json b/art/easEJ6iaXWeeR99Gj/art.json index 52728237..473fe89e 100644 --- a/art/easEJ6iaXWeeR99Gj/art.json +++ b/art/easEJ6iaXWeeR99Gj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n // float yoff = sin(time + x * 0.1);\\n float xoff = sin(time + y * 0.1);\\n\\n float ux = u * 2. - 1. + xoff;\\n // float vy = v * 2. - 1. + yoff;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n // float yoff = sin(time + x * 0.1);\n float xoff = sin(time + y * 0.1);\n\n float ux = u * 2. - 1. + xoff;\n // float vy = v * 2. - 1. + yoff;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-xrfr6bz31jn1bvc4m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/edJC7G3Sd2mixhfmg/art.json b/art/edJC7G3Sd2mixhfmg/art.json index 88e86bc2..2651a4ac 100644 --- a/art/edJC7G3Sd2mixhfmg/art.json +++ b/art/edJC7G3Sd2mixhfmg/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":5403,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/u7shannwflvs/mangophalt-feat-official-lyric-video?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.023529411764705882,0.06666666666666667,0.11764705882352941,1],\"shader\":\"// Seulbin Seo\\n// Exercise Circles from Triangles 2\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) \\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n\\n float radius = vy + 1.;\\n \\n float x = c * radius * cos(time) / 2.;\\n float y = s * radius * sin(time);\\n \\n return vec2(x,y);\\n}\\n\\n\\nvoid main ()\\n{\\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\n float numPointPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointPerCircle);\\n float numCircles = floor(vertexCount / numPointPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(sv, su));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n\\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) *mix(1., 1.1, oddSlice);\\n \\n sc *= 37. * cos(time) / across ;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * sin(0.7));\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 10. * sign(vy));\\n mat *= uniformScale(0.04 * sc);\\n\\n gl_Position = mat * pos;\\n \\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n float pump = step(0.4, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; // + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5403, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/u7shannwflvs/mangophalt-feat-official-lyric-video?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.023529411764705882, + 0.06666666666666667, + 0.11764705882352941, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Circles from Triangles 2\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) \n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n\n float radius = vy + 1.;\n \n float x = c * radius * cos(time) / 2.;\n float y = s * radius * sin(time);\n \n return vec2(x,y);\n}\n\n\nvoid main ()\n{\n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \n float numPointPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointPerCircle);\n float numCircles = floor(vertexCount / numPointPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(sv, su));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n\n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) *mix(1., 1.1, oddSlice);\n \n sc *= 37. * cos(time) / across ;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * sin(0.7));\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 10. * sign(vy));\n mat *= uniformScale(0.04 * sc);\n\n gl_Position = mat * pos;\n \n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n float pump = step(0.4, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; // + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-3hzld4pb4feio9tnp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ef4RfHy9WFPvn43T6/art.json b/art/ef4RfHy9WFPvn43T6/art.json index ece8a628..fb49a80f 100644 --- a/art/ef4RfHy9WFPvn43T6/art.json +++ b/art/ef4RfHy9WFPvn43T6/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mol", "avatarUrl": "https://secure.gravatar.com/avatar/fe5b47f4d74c95c9b38908469761a86d?default=retro&size=200", - "settings": "{\"num\":64,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n gl_PointSize = 5.0;\\n \\n v_color = vec4(\\n\\n abs(sin(vertexId * 0.1 - time * 8.0)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\\n 1.0);\\n \\n gl_Position.x = sin(time * 2.0 - vertexId / 8.0) * vertexId / 64.0;\\n gl_Position.y = cos(time * 2.0 - vertexId / 16.0) * vertexId / 64.0;\\n gl_Position.z = 0.0;\\n gl_Position[3] = 1.0;\\n}\"}", + "settings": { + "num": 64, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n gl_PointSize = 5.0;\n \n v_color = vec4(\n\n abs(sin(vertexId * 0.1 - time * 8.0)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\n 1.0);\n \n gl_Position.x = sin(time * 2.0 - vertexId / 8.0) * vertexId / 64.0;\n gl_Position.y = cos(time * 2.0 - vertexId / 16.0) * vertexId / 64.0;\n gl_Position.z = 0.0;\n gl_Position[3] = 1.0;\n}" + }, "screenshotURL": "data/images/images-oq0jlttn48s8u0bkz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/efitgBPvLvfEFCPvW/art.json b/art/efitgBPvLvfEFCPvW/art.json index 91f0e1ab..8c2ed1a7 100644 --- a/art/efitgBPvLvfEFCPvW/art.json +++ b/art/efitgBPvLvfEFCPvW/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hzktqr", "avatarUrl": "https://secure.gravatar.com/avatar/c5ca7d7d4b527ab960b78f57cfbe61c2?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-y9ggr0o4c6irztil9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eh4QC67q3gssnkYYv/art.json b/art/eh4QC67q3gssnkYYv/art.json index b9873ea8..11f81493 100644 --- a/art/eh4QC67q3gssnkYYv/art.json +++ b/art/eh4QC67q3gssnkYYv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/merzbow/pulse-vegan-part-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#42523.0\\n\\n#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\n//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n\\n#define soundFactor 1.0//KParameter 1.0>>5.\\n#define screenSizeRation 1.0//KParameter 0.5>>1.\\n\\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n //float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n //float ratio = resolution.y/numAcrossDown;\\n \\n //float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n float x = mod(finalVertexId, finalResolution.x);\\n float y = floor(finalVertexId / finalResolution.y);\\n \\n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\\n float v = (y / finalResolution.y);\\n \\n float snd = texture2D(sound, vec2(0.2, u)).a;\\n snd = soundFactor*pow(0.1+snd,2.);\\n \\n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\\n \\n float sndOffset = snd;\\n if(v>0.5)\\n sndOffset = -snd;\\n float vy = sndOffset+( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\\n \\n \\n \\n \\n //apply fragment logic\\n\\n vec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n \\n \\n\\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n \\n \\n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n gl_Position = vec4(ux-distance(v_color.x,v_color.y )/2., vy, 0, 1);\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/merzbow/pulse-vegan-part-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#42523.0\n\n#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\n//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n\n#define soundFactor 1.0//KParameter 1.0>>5.\n#define screenSizeRation 1.0//KParameter 0.5>>1.\n\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n //float numAcrossDown = floor(sqrt(finalVertexCount));\n \n //float ratio = resolution.y/numAcrossDown;\n \n //float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n float x = mod(finalVertexId, finalResolution.x);\n float y = floor(finalVertexId / finalResolution.y);\n \n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\n float v = (y / finalResolution.y);\n \n float snd = texture2D(sound, vec2(0.2, u)).a;\n snd = soundFactor*pow(0.1+snd,2.);\n \n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x);\n \n float sndOffset = snd;\n if(v>0.5)\n sndOffset = -snd;\n float vy = sndOffset+( v * 2.0 - 1.0)* (finalResolution.y/resolution.y);\n \n \n \n \n //apply fragment logic\n\n vec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n \n \n\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n \n \n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n gl_Position = vec4(ux-distance(v_color.x,v_color.y )/2., vy, 0, 1);\n \n\n}" + }, "screenshotURL": "data/images/images-8t8i8w63y4p16c9b6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ehS7PTfScc8NxvEpP/art.json b/art/ehS7PTfScc8NxvEpP/art.json index 36d8be4f..75d88b22 100644 --- a/art/ehS7PTfScc8NxvEpP/art.json +++ b/art/ehS7PTfScc8NxvEpP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":61534,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\nmat4 rotZ(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n return mat4(\\n c,-s,0,0,\\n s,c,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\n\\nmat4 trans(vec3 trans){\\n return mat4(\\n \\t1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n trans,1);\\n}\\nmat4 ident(){\\n return mat4(\\n \\t1,0,0,0,\\n 0,1,0,0,\\n 0,0,1,0,\\n 0,0,0,1);\\n}\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n \\ts[0],0,0,0,\\n 0,s[1],0,0,\\n 0,0,s[2],0,\\n 0,0,0,1);\\n}\\nmat4 uniformScale(float s){\\n return mat4(\\n \\ts,0,0,0,\\n 0,s,0,0,\\n 0,0,s,0,\\n 0,0,0,1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n float ux = floor(id / 6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id / 3.),2.);\\n\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy +1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\n return vec2(x,y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId/ numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/ 6.0);\\n float oddSlice = mod(sliceId,2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au* .05, av * .25)).a;\\n\\n \\n float sc = pow(snd+0.2,5.) * mix(1., 1.1, oddSlice);\\n float aspect = resolution.x / resolution.y;\\n \\n sc *= 20. / across;\\n \\n \\n vec4 pos = vec4(circleXY , 0 ,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.05 * sc );\\n \\n \\n gl_Position = mat * pos;\\n \\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n\\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice *0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 61534, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\nmat4 rotZ(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n return mat4(\n c,-s,0,0,\n s,c,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\n\nmat4 trans(vec3 trans){\n return mat4(\n \t1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n trans,1);\n}\nmat4 ident(){\n return mat4(\n \t1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1);\n}\nmat4 scale(vec3 s)\n{\n return mat4(\n \ts[0],0,0,0,\n 0,s[1],0,0,\n 0,0,s[2],0,\n 0,0,0,1);\n}\nmat4 uniformScale(float s){\n return mat4(\n \ts,0,0,0,\n 0,s,0,0,\n 0,0,s,0,\n 0,0,0,1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n float ux = floor(id / 6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id / 3.),2.);\n\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy +1.;\n \n float x = c * radius;\n float y = s * radius;\n\n return vec2(x,y);\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId/ numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId/ 6.0);\n float oddSlice = mod(sliceId,2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au* .05, av * .25)).a;\n\n \n float sc = pow(snd+0.2,5.) * mix(1., 1.1, oddSlice);\n float aspect = resolution.x / resolution.y;\n \n sc *= 20. / across;\n \n \n vec4 pos = vec4(circleXY , 0 ,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.05 * sc );\n \n \n gl_Position = mat * pos;\n \n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n\n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice *0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-9zl9dei1gpudqn7p4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ehyZCh7WmuNeadkky/art.json b/art/ehyZCh7WmuNeadkky/art.json index b1ff18e5..d899d9f7 100644 --- a/art/ehyZCh7WmuNeadkky/art.json +++ b/art/ehyZCh7WmuNeadkky/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "luis", "avatarUrl": "https://graph.facebook.com/10208687216256743/picture?type=large", - "settings": "{\"num\":23758,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n/*\\n\\nvoid main()\\n{\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = ux /20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n vec2 xy = vec2(x, y);\\n \\n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n}*/\\n\\nvec2 func(float vertexId){\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float angle = ux /20.0 * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n vec2 xy = vec2(x, y);\\n return xy;\\n}\\n\\n\\n\\nvoid main()\\n{\\n float circleID = floor(vertexId/120.0);\\n float circleCount = floor(vertexCount/120.0);\\n \\n float sqrTotal = floor(sqrt(circleCount));\\n float width = sqrTotal;\\n \\n float x = mod(circleID, width); // [0, width - 1]\\n float y = floor(circleID / width); // [0, inf]\\n\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float ux = u * 2.0 - 1.0 ;\\n float vy = v * 2.0 - 1.0 ;\\n \\n vec2 xy = vec2(ux, vy)* 1.1;\\n \\n \\n gl_Position = vec4(xy + (func(vertexId)* 0.02), 0.0, 1.0);\\n \\n \\n gl_PointSize = 15.0 ;\\n gl_PointSize *= 32.0 / width;\\n \\n \\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 23758, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n/*\n\nvoid main()\n{\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = ux /20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n vec2 xy = vec2(x, y);\n \n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n}*/\n\nvec2 func(float vertexId){\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float angle = ux /20.0 * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n vec2 xy = vec2(x, y);\n return xy;\n}\n\n\n\nvoid main()\n{\n float circleID = floor(vertexId/120.0);\n float circleCount = floor(vertexCount/120.0);\n \n float sqrTotal = floor(sqrt(circleCount));\n float width = sqrTotal;\n \n float x = mod(circleID, width); // [0, width - 1]\n float y = floor(circleID / width); // [0, inf]\n\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float ux = u * 2.0 - 1.0 ;\n float vy = v * 2.0 - 1.0 ;\n \n vec2 xy = vec2(ux, vy)* 1.1;\n \n \n gl_Position = vec4(xy + (func(vertexId)* 0.02), 0.0, 1.0);\n \n \n gl_PointSize = 15.0 ;\n gl_PointSize *= 32.0 / width;\n \n \n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-hspb9cvc50rfktt9d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eiJ4hxesSBMicxFyJ/art.json b/art/eiJ4hxesSBMicxFyJ/art.json index 60c8e9c9..bf4328da 100644 --- a/art/eiJ4hxesSBMicxFyJ/art.json +++ b/art/eiJ4hxesSBMicxFyJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-hid924udtyfkk4yxk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eiQJGkMsgvxpx6Ejq/art.json b/art/eiQJGkMsgvxpx6Ejq/art.json index a6703c4e..80811bea 100644 --- a/art/eiQJGkMsgvxpx6Ejq/art.json +++ b/art/eiQJGkMsgvxpx6Ejq/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"\\n\\nvoid main(){\\n float across = 10.;\\n \\n float x = mod(vertexId, across );\\n float y = floor(vertexId / across);\\n \\n float u = x / (across -1.);\\n float v = y / (across -1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "\n\nvoid main(){\n float across = 10.;\n \n float x = mod(vertexId, across );\n float y = floor(vertexId / across);\n \n float u = x / (across -1.);\n float v = y / (across -1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n \n \n}" + }, "screenshotURL": "data/images/images-hs7t83xud833j0s4a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ek2r2jAkKe4kBeGaN/art.json b/art/ek2r2jAkKe4kBeGaN/art.json index 9542c02d..bc198b26 100644 --- a/art/ek2r2jAkKe4kBeGaN/art.json +++ b/art/ek2r2jAkKe4kBeGaN/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "shinyisshiny", "avatarUrl": "https://secure.gravatar.com/avatar/382822a2fd34cc1eedf9317c4c63083d?default=retro&size=200", - "settings": "{\"num\":966,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.050980392156862744,0.32941176470588235,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\\n \\n \"}", + "settings": { + "num": 966, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.050980392156862744, + 0.32941176470588235, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}\n \n " + }, "screenshotURL": "data/images/images-2mc0h8r53k4na3n1l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/em6g5TXFWMofu5RHa/art.json b/art/em6g5TXFWMofu5RHa/art.json index a0dc0ecd..29653b10 100644 --- a/art/em6g5TXFWMofu5RHa/art.json +++ b/art/em6g5TXFWMofu5RHa/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 10.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 10.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-q2k3cgnvzvhbz9bys-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/emCzESvMqeynBHRzP/art.json b/art/emCzESvMqeynBHRzP/art.json index ad28fbb8..f4a79bed 100644 --- a/art/emCzESvMqeynBHRzP/art.json +++ b/art/emCzESvMqeynBHRzP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "pgan", "avatarUrl": "https://secure.gravatar.com/avatar/b786c3cea88eff238ced38e7ee896997?default=retro&size=200", - "settings": "{\"num\":43209,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n //background = vec4(0.0, 0.1, 0.0, 1.0);\\n float magic = 10.0;\\n float x = mod(vertexId, magic);\\n float y = floor(vertexId / magic);\\n \\n gl_Position = vec4(x/magic-magic/2.0, y/magic-magic/2.0, 0.0, 1.0);\\n vec4 v_color = vec4(0.0, 1.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\\n\"}", + "settings": { + "num": 43209, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n //background = vec4(0.0, 0.1, 0.0, 1.0);\n float magic = 10.0;\n float x = mod(vertexId, magic);\n float y = floor(vertexId / magic);\n \n gl_Position = vec4(x/magic-magic/2.0, y/magic-magic/2.0, 0.0, 1.0);\n vec4 v_color = vec4(0.0, 1.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}\n" + }, "screenshotURL": "data/images/images-m8suth7l6pxh6oj7b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/emui4ppu4ZWu8iLwB/art.json b/art/emui4ppu4ZWu8iLwB/art.json index d5794311..8771b5c5 100644 --- a/art/emui4ppu4ZWu8iLwB/art.json +++ b/art/emui4ppu4ZWu8iLwB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS * sin(time));\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS * sin(time));\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-qxe4loax4pibydqtz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/enNTxR7RgQNk53fmx/art.json b/art/enNTxR7RgQNk53fmx/art.json index f142b9c1..d0b8def5 100644 --- a/art/enNTxR7RgQNk53fmx/art.json +++ b/art/enNTxR7RgQNk53fmx/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main(){\\n float across = 10.;\\n \\n float x = mod(vertexId, across );\\n float y = floor(vertexId / across);\\n \\n float u = x / across;\\n float v = y / across;\\n \\n gl_Position = vec4(u,v,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main(){\n float across = 10.;\n \n float x = mod(vertexId, across );\n float y = floor(vertexId / across);\n \n float u = x / across;\n float v = y / across;\n \n gl_Position = vec4(u,v,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n \n \n}" + }, "screenshotURL": "data/images/images-qioua6g3dk76y3fho-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/epH8co5uSwMkCYZGo/art.json b/art/epH8co5uSwMkCYZGo/art.json index 3960fd64..d19cdb26 100644 --- a/art/epH8co5uSwMkCYZGo/art.json +++ b/art/epH8co5uSwMkCYZGo/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cjensen93", "avatarUrl": "https://secure.gravatar.com/avatar/0df4239ac208a0c9696c1edd2e895cee?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.058823529411764705,0.4117647058823529,1],\"shader\":\"void main(){\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOff = sin(time + y * 0.2) * 0.1;\\n float yOff = sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2.0 - 1.0 + xOff;\\n float uy = v * 2.0 - 1.0 + yOff;\\n \\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n \\n float sOff = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sOff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.058823529411764705, + 0.4117647058823529, + 1 + ], + "shader": "void main(){\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOff = sin(time + y * 0.2) * 0.1;\n float yOff = sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2.0 - 1.0 + xOff;\n float uy = v * 2.0 - 1.0 + yOff;\n \n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n gl_Position = vec4(xy,0.0,1.0);\n \n float sOff = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sOff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-0q1guwvb8985nmcjl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/epNhofNCAKkjo88eT/art.json b/art/epNhofNCAKkjo88eT/art.json index 2f1ee583..04fe9ae0 100644 --- a/art/epNhofNCAKkjo88eT/art.json +++ b/art/epNhofNCAKkjo88eT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\nconst int max_v = 12;\\nvec3 poi_v[max_v];\\nvec3 point[max_v+2];\\nvec3 color[max_v+2];\\n\\nfloat z[2];\\n\\n\\nmat4 persp (float fov, float aspect, float zNear, float zFar)\\n{\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n \\n return mat4(\\n \\tf / aspect, 0, 0, 0,\\n \\t0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n \\t0, 0, zNear * zFar * rangeInv * 2.0, 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n zAxis, 0,\\n xAxis, 0,\\n yAxis, 0,\\n eye , 2\\n );\\n}\\n\\nvoid drow_point()\\n{\\n z[0] = 0.;\\n z[1] = 1.;\\n \\n for(int i=0; i>5.\\n#define kp1 1.//KParameter 0.>>5.\\n#define kp2 .3//KParameter 0.>>5.\\n#define kp3 2.//KParameter 1.>>5.\\n#define kp4 3.//KParameter 0.>>5.\\n#define kp5 1.1//KParameter 0.>>5.\\n//#define kp0 -5.//KParameter -5.>>5.\\n//#define kp1 1.//KParameter -6.>>5.\\n//KVerticesNumber=16622\\n\\n\\n\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.0030;\\n \\tfloat transitionStrength = 1.3*kp5;\\n \\tvec3 colKernel0 = vec3(1,0,1.-kp3);\\n \\tvec3 colKernel1 = vec3(0,kp2,0);\\n \\tvec3 colTransition = vec3(kp0,kp4,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = .5 - kp1* 0.5;\\n\\tfloat ce = -1.5+ kp0* 3.+1.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 1, 0);\\n\\tvec3 up = vec3(0, 0.6,1.);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(33.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = .2 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * .23, 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis,0,\\n\\t\\tzAxis, -sin(mouse*0.021).y,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) /dot(det*det,\\n \\n 2.-b01);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),.45); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 19328, + "mode": "LINES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define kp0 2.//KParameter -5.>>5.\n#define kp1 1.//KParameter 0.>>5.\n#define kp2 .3//KParameter 0.>>5.\n#define kp3 2.//KParameter 1.>>5.\n#define kp4 3.//KParameter 0.>>5.\n#define kp5 1.1//KParameter 0.>>5.\n//#define kp0 -5.//KParameter -5.>>5.\n//#define kp1 1.//KParameter -6.>>5.\n//KVerticesNumber=16622\n\n\n\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.0030;\n \tfloat transitionStrength = 1.3*kp5;\n \tvec3 colKernel0 = vec3(1,0,1.-kp3);\n \tvec3 colKernel1 = vec3(0,kp2,0);\n \tvec3 colTransition = vec3(kp0,kp4,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = .5 - kp1* 0.5;\n\tfloat ce = -1.5+ kp0* 3.+1.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 1, 0);\n\tvec3 up = vec3(0, 0.6,1.);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(33.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = .2 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * .23, 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis,0,\n\t\tzAxis, -sin(mouse*0.021).y,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) /dot(det*det,\n \n 2.-b01);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),.45); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-lpbqu4k8xj0sutgcp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eq35fsTk4w4ZA3LQF/art.json b/art/eq35fsTk4w4ZA3LQF/art.json index 02678ae7..4250f3f4 100644 --- a/art/eq35fsTk4w4ZA3LQF/art.json +++ b/art/eq35fsTk4w4ZA3LQF/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tAudio Reactive Art\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\t\\n \\tfloat pump = step(0.8, snd);\\n \\tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\\n \\tfloat sat = mix(0.0, 1.0, pump);\\n \\tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\tseongryul.park\n//\tCS250 spring 2023\n//\tAudio Reactive Art\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tfloat su = abs(u - 0.5) * 2.0;\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n \t\n \tfloat pump = step(0.8, snd);\n \tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\n \tfloat sat = mix(0.0, 1.0, pump);\n \tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-st0wpbd02rttv49t1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eqcXviN95rTrGxwyW/art.json b/art/eqcXviN95rTrGxwyW/art.json index b18c000d..8aece08b 100644 --- a/art/eqcXviN95rTrGxwyW/art.json +++ b/art/eqcXviN95rTrGxwyW/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":81932,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.00784313725490196,0.00784313725490196,1],\"shader\":\"#define PI radians(180.)\\n#define SIZE 90.0\\n#define NUM_CUBES (SIZE*SIZE*SIZE)\\n#define NUM_TRIANGLES (NUM_CUBES*6)\\n#define NUM_VERTICES (NUM_TRIANGLES*6)\\n#define STEP 80.0\\n\\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nvec3 camPath(float t){\\n \\n //return vec3(0, 0, t); // Straight path.\\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\\n \\n //float s = sin(t/24.)*cos(t/12.);\\n //return vec3(s*12., 0., t);\\n \\n float a = -sin(t * 0.011);\\n float b = cos(t * 0.014);\\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\\n \\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nfloat map(vec3 p){\\n \\n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\\n \\n p *= 0.4;\\n \\n\\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\\n \\n \\n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\\n\\n // It's an easy field to create, but not so great to hone in one. The \\\"1.4\\\" fudge factor\\n // is there to get a little extra distance... Obtained by trial and error.\\n return (n - 1.025)*1.33;\\n \\n}\\n\\n\\nvoid main() {\\n \\n float speed = 10.0;\\n \\n vec3 wpos = vec3(0);\\n \\n vec3 pos = camPath(time*speed)*sin(-1.5*mouse.x);\\n \\n vec3 lookat = camPath(time*speed+2.0);\\n vec3 forward = normalize(lookat-pos);\\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\\n vec3 up = cross(forward,left);\\n \\n float id = vertexId;\\n \\n float numcube = floor(id/18.0);\\n float numquad = floor(id/6.0);\\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\\n float nori = mod(numquad,3.0);\\n //quadid = quadid ^ diri;\\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\\n \\n \\n vec3 mask;\\n if (nori < 0.5) {\\n mask = vec3(1,0,0);\\n } else if (nori < 1.5) {\\n mask = vec3(0,1,0);\\n } else {\\n mask = vec3(0,0,1);\\n }\\n \\n float size = floor(pow(vertexCount/23.0,1.0/3.0)*mouse.y)*2.;\\n \\n vec3 blockpos = vec3(\\n mod(floor(numcube),size),\\n mod(floor(numcube/size),size),\\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\\n \\n bool a = map(blockpos) > 0.0;\\n bool b = map(blockpos+mask) > 0.0;\\n \\n float diri;\\n \\n if (a == b) {\\n gl_Position = vec4(0,0,0,1);\\n return;\\n } else {\\n \\n float diri = 1.0;\\n if (b) {\\n diri = -diri;\\n quad.xy = quad.yx;\\n }\\n \\n vec3 nor = mask*(diri*2.0-1.0);\\n\\n wpos += mask.zxy*quad.x;\\n wpos += mask.yzx*quad.y;\\n\\twpos += mask;\\n wpos += blockpos;\\n\\n wpos -= 0.5;\\n\\n //wpos += vec3(data.xyz);\\n //wpos += float(gl_VertexID/6);\\n //wpos += u_centerPosition;\\n\\n\\n\\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\\n \\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\\n \\n p.x *= resolution.y/resolution.x;\\n\\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\\n\\n\\n float hue = (id * 1.001);\\n v_color = vec4(nor*0.5+0.5, 1);\\n }\\n}\"}", + "settings": { + "num": 81932, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.00784313725490196, + 0.00784313725490196, + 1 + ], + "shader": "#define PI radians(180.)\n#define SIZE 90.0\n#define NUM_CUBES (SIZE*SIZE*SIZE)\n#define NUM_TRIANGLES (NUM_CUBES*6)\n#define NUM_VERTICES (NUM_TRIANGLES*6)\n#define STEP 80.0\n\n#define rot(A) mat2(cos(A),-sin(A),sin(A),cos(A))\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(12.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n//https://www.shadertoy.com/view/4ttGDH\nvec3 camPath(float t){\n \n //return vec3(0, 0, t); // Straight path.\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\n \n //float s = sin(t/24.)*cos(t/12.);\n //return vec3(s*12., 0., t);\n \n float a = -sin(t * 0.011);\n float b = cos(t * 0.014);\n return vec3(a*4. -b*1.5, b*1.7 + a*2.5, t);\n \n}\n\n//https://www.shadertoy.com/view/4ttGDH\nfloat map(vec3 p){\n \n p.xy /= camPath(p.z).xy; // Perturb the object around the camera path.\n \n p *= 0.4;\n \n\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\n \n \n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\n\n // It's an easy field to create, but not so great to hone in one. The \"1.4\" fudge factor\n // is there to get a little extra distance... Obtained by trial and error.\n return (n - 1.025)*1.33;\n \n}\n\n\nvoid main() {\n \n float speed = 10.0;\n \n vec3 wpos = vec3(0);\n \n vec3 pos = camPath(time*speed)*sin(-1.5*mouse.x);\n \n vec3 lookat = camPath(time*speed+2.0);\n vec3 forward = normalize(lookat-pos);\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\n vec3 up = cross(forward,left);\n \n float id = vertexId;\n \n float numcube = floor(id/18.0);\n float numquad = floor(id/6.0);\n float quadid = 3.0-abs(id-numquad*6.0-3.0);\n float nori = mod(numquad,3.0);\n //quadid = quadid ^ diri;\n vec2 quad = vec2(mod(quadid,2.0),mod(floor(quadid*0.5),2.0));\n \n \n vec3 mask;\n if (nori < 0.5) {\n mask = vec3(1,0,0);\n } else if (nori < 1.5) {\n mask = vec3(0,1,0);\n } else {\n mask = vec3(0,0,1);\n }\n \n float size = floor(pow(vertexCount/23.0,1.0/3.0)*mouse.y)*2.;\n \n vec3 blockpos = vec3(\n mod(floor(numcube),size),\n mod(floor(numcube/size),size),\n floor(numcube/size/size))-vec2(floor(size*0.5),0).xxy+floor(pos);\n \n bool a = map(blockpos) > 0.0;\n bool b = map(blockpos+mask) > 0.0;\n \n float diri;\n \n if (a == b) {\n gl_Position = vec4(0,0,0,1);\n return;\n } else {\n \n float diri = 1.0;\n if (b) {\n diri = -diri;\n quad.xy = quad.yx;\n }\n \n vec3 nor = mask*(diri*2.0-1.0);\n\n wpos += mask.zxy*quad.x;\n wpos += mask.yzx*quad.y;\n\twpos += mask;\n wpos += blockpos;\n\n wpos -= 0.5;\n\n //wpos += vec3(data.xyz);\n //wpos += float(gl_VertexID/6);\n //wpos += u_centerPosition;\n\n\n\n vec3 p = wpos-pos;//vec3(sin(id+time),cos(id+time),id);\n \n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\n \n p.x *= resolution.y/resolution.x;\n\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\n\n\n float hue = (id * 1.001);\n v_color = vec4(nor*0.5+0.5, 1);\n }\n}" + }, "screenshotURL": "data/images/images-xaqu6fg4bn96hfdkq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ercnsAaqXuGhCCCAe/art.json b/art/ercnsAaqXuGhCCCAe/art.json index 2bb1d833..30ce8e9d 100644 --- a/art/ercnsAaqXuGhCCCAe/art.json +++ b/art/ercnsAaqXuGhCCCAe/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "nworblegin", "avatarUrl": "https://secure.gravatar.com/avatar/9869f0d67f3bae85633a7fde13480565?default=retro&size=200", - "settings": "{\"num\":2590,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8784313725490196,0.9333333333333333,0.8313725490196079,1],\"shader\":\"\\nconst float line = 3. ; \\nvec2 drawTriangle(in float vertexId ,out vec3 color )\\n{\\n vec2 res = vec2(1.);\\n // res.x = floor(mod(vertexId , line))/line;\\n // res.y = floor(vertexId/ line) ; \\n if(vertexId < (vertexCount / 3. ))\\n {\\n res.x = -0.5 ; \\n res.y = -0.5 ; \\n color.r = 1.;\\n color.g = 0. ; \\n color.b = 0. ; \\n res.x += (sin(-time * 3.0) * 0.1);\\n res.y += (cos(-time * 10.0) * 0.1);\\n } \\n else if (vertexId > (vertexCount * 2. /3. )) \\n {\\n res.x = 0.5 ; \\n res.y = -0.5 ; \\n color.r = 0.;\\n color.g = 1. ; \\n color.b = 0. ; \\n res.x += (sin(-time * 10.0) * 0.1);\\n res.y += (cos(time * 7.0) * 0.1);\\n }\\n else\\n {\\n res.x = 0. ; \\n res.y = 0.5 ;\\n color.r = 0.;\\n color.g = 0. ; \\n color.b = 1. ; \\n res.x += (sin(time * 5.0) * 0.1);\\n res.y += (cos(time * 11.0) * 0.1);\\n }\\n return res; \\n \\n}\\n\\nvoid main()\\n{\\n vec3 color = vec3(0.);\\n \\n \\n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\\n \\n gl_PointSize = 10. ; \\n \\n v_color = vec4(color , 1.0);\\n}\"}", + "settings": { + "num": 2590, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8784313725490196, + 0.9333333333333333, + 0.8313725490196079, + 1 + ], + "shader": "\nconst float line = 3. ; \nvec2 drawTriangle(in float vertexId ,out vec3 color )\n{\n vec2 res = vec2(1.);\n // res.x = floor(mod(vertexId , line))/line;\n // res.y = floor(vertexId/ line) ; \n if(vertexId < (vertexCount / 3. ))\n {\n res.x = -0.5 ; \n res.y = -0.5 ; \n color.r = 1.;\n color.g = 0. ; \n color.b = 0. ; \n res.x += (sin(-time * 3.0) * 0.1);\n res.y += (cos(-time * 10.0) * 0.1);\n } \n else if (vertexId > (vertexCount * 2. /3. )) \n {\n res.x = 0.5 ; \n res.y = -0.5 ; \n color.r = 0.;\n color.g = 1. ; \n color.b = 0. ; \n res.x += (sin(-time * 10.0) * 0.1);\n res.y += (cos(time * 7.0) * 0.1);\n }\n else\n {\n res.x = 0. ; \n res.y = 0.5 ;\n color.r = 0.;\n color.g = 0. ; \n color.b = 1. ; \n res.x += (sin(time * 5.0) * 0.1);\n res.y += (cos(time * 11.0) * 0.1);\n }\n return res; \n \n}\n\nvoid main()\n{\n vec3 color = vec3(0.);\n \n \n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\n \n gl_PointSize = 10. ; \n \n v_color = vec4(color , 1.0);\n}" + }, "screenshotURL": "data/images/images-cyq3acn20wzdo62mo-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ercvafg86xKeMKPY4/art.json b/art/ercvafg86xKeMKPY4/art.json index a4ad8ab3..b6757398 100644 --- a/art/ercvafg86xKeMKPY4/art.json +++ b/art/ercvafg86xKeMKPY4/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chrisc", "avatarUrl": "https://secure.gravatar.com/avatar/28c173c669316a6cf7fe577bf30531ba?default=retro&size=200", - "settings": "{\"num\":20074,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"uniform mat4 transform;\\nuniform mat3 normalMatrix;\\nuniform vec3 lightNormal;\\n\\nattribute vec4 position;\\nattribute vec4 color;\\nattribute vec3 normal;\\n\\nvarying vec4 vertColor;\\nvarying vec3 vertNormal;\\nvarying vec3 vertLightDir;\\n\\nvoid main() {\\n gl_Position = transform * position;\\n vertColor = color;\\n vertNormal = normalize(normalMatrix * normal);\\n vertLightDir = -lightNormal;\\n}\"}", + "settings": { + "num": 20074, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "uniform mat4 transform;\nuniform mat3 normalMatrix;\nuniform vec3 lightNormal;\n\nattribute vec4 position;\nattribute vec4 color;\nattribute vec3 normal;\n\nvarying vec4 vertColor;\nvarying vec3 vertNormal;\nvarying vec3 vertLightDir;\n\nvoid main() {\n gl_Position = transform * position;\n vertColor = color;\n vertNormal = normalize(normalMatrix * normal);\n vertLightDir = -lightNormal;\n}" + }, "screenshotURL": "data/images/images-do7vedcz6djobcqbk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/esptz5bbgn8NtZkbN/art.json b/art/esptz5bbgn8NtZkbN/art.json index 9ee22319..9a605004 100644 --- a/art/esptz5bbgn8NtZkbN/art.json +++ b/art/esptz5bbgn8NtZkbN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.01;\\n float phase = -time+mod(vertexId,2.0);\\n float a = 0.5;\\n float b = 0.3063489;\\n float x = a * exp(b*t)*cos(t+phase)*0.015;\\n float y = a * exp(b*t)*sin(t+phase)*0.015;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n \\n float hue = floor(time*0.0) / 0.23;\\n float sat = 10000000000.;\\n float val = 0.5+mod(vertexId,2.0)*0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.01;\n float phase = -time+mod(vertexId,2.0);\n float a = 0.5;\n float b = 0.3063489;\n float x = a * exp(b*t)*cos(t+phase)*0.015;\n float y = a * exp(b*t)*sin(t+phase)*0.015;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n \n float hue = floor(time*0.0) / 0.23;\n float sat = 10000000000.;\n float val = 0.5+mod(vertexId,2.0)*0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ygagq3ffhvrolnb8a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/esyFcPb5cskLWGgGE/art.json b/art/esyFcPb5cskLWGgGE/art.json index c61b92c1..3b146d23 100644 --- a/art/esyFcPb5cskLWGgGE/art.json +++ b/art/esyFcPb5cskLWGgGE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.10196078431372549,0.10196078431372549,1],\"shader\":\"/* ---------------------------- SURFACE --------------------------//\\nSpecial gifts for everyone who loves 2d games and sprite creation.*/\\n\\nvec3 surface(){\\n float x, y, w, h;//x,y coordinates and w,h width and height of a surface.\\n float width = 0.2;\\n float height = 0.4;\\n x = mouse.x-(width/2.);//move the surface from the center of widith.\\n y = mouse.y-(height/2.);//move the surface from the center of height.\\n w = width+x;\\n h = height+y;\\n \\n vec3 v[4];\\n v[0] = vec3(x, y, 0.);\\n v[1] = vec3(x, h, 0.);\\n v[2] = vec3(w, y, 0.);\\n v[3] = vec3(w, h, 0.);\\n \\n int vid = int(vertexId);\\n for(int i=0; i<3; i++){\\n if(vid == i){\\n return v[i];\\n }\\n }\\n return v[3];\\n}\\n\\nvoid main(){\\n gl_Position = vec4(surface(), 1);\\n gl_PointSize = 10.;\\n v_color = vec4(0, 1, 1, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.10196078431372549, + 0.10196078431372549, + 1 + ], + "shader": "/* ---------------------------- SURFACE --------------------------//\nSpecial gifts for everyone who loves 2d games and sprite creation.*/\n\nvec3 surface(){\n float x, y, w, h;//x,y coordinates and w,h width and height of a surface.\n float width = 0.2;\n float height = 0.4;\n x = mouse.x-(width/2.);//move the surface from the center of widith.\n y = mouse.y-(height/2.);//move the surface from the center of height.\n w = width+x;\n h = height+y;\n \n vec3 v[4];\n v[0] = vec3(x, y, 0.);\n v[1] = vec3(x, h, 0.);\n v[2] = vec3(w, y, 0.);\n v[3] = vec3(w, h, 0.);\n \n int vid = int(vertexId);\n for(int i=0; i<3; i++){\n if(vid == i){\n return v[i];\n }\n }\n return v[3];\n}\n\nvoid main(){\n gl_Position = vec4(surface(), 1);\n gl_PointSize = 10.;\n v_color = vec4(0, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-oawtgfc01fg4ilkxp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/etLPNmJ9oBq9QDcz6/art.json b/art/etLPNmJ9oBq9QDcz6/art.json index b8f64e0c..9275804c 100644 --- a/art/etLPNmJ9oBq9QDcz6/art.json +++ b/art/etLPNmJ9oBq9QDcz6/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "codework10101", "avatarUrl": "https://lh6.googleusercontent.com/-PQyKHxpBwIo/AAAAAAAAAAI/AAAAAAAAARk/HWB3OGMyzZE/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/yeonkkot/sets/s08\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0.5019607843137255,0.5019607843137255,1],\"shader\":\"void main() \\n{\\n \\n float down = floor( sqrt( vertexCount ) );\\n float across = floor( vertexCount / down );\\n \\n float index = vertexId;\\n float x = mod(index, across);\\n float y = floor(index/across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0.0, 1.0);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n \\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/yeonkkot/sets/s08", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0.5019607843137255, + 0.5019607843137255, + 1 + ], + "shader": "void main() \n{\n \n float down = floor( sqrt( vertexCount ) );\n float across = floor( vertexCount / down );\n \n float index = vertexId;\n float x = mod(index, across);\n float y = floor(index/across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0.0, 1.0);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n \n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-h6cvlmd77fk9nygf7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/euQ9yLGh4rWre3oqK/art.json b/art/euQ9yLGh4rWre3oqK/art.json index 794606e6..d76f709b 100644 --- a/art/euQ9yLGh4rWre3oqK/art.json +++ b/art/euQ9yLGh4rWre3oqK/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "good", "avatarUrl": "https://lh3.googleusercontent.com/a/AAcHTtdi7RB9cxYb8eQrW013DjbHjwp_BpDQVOUEQr28Bg=s96-c", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(su* 0.05, sv * 0.25 )).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.9, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);//mix(2., -10.,av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n//name : Juseung Yang\\n//assignment name/number : Exercise - Vertexshaderart : Audio Reactive\\n//course name ; CS250\\n//term : 2023/05/24\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(su* 0.05, sv * 0.25 )).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.9, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);//mix(2., -10.,av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n\n//name : Juseung Yang\n//assignment name/number : Exercise - Vertexshaderart : Audio Reactive\n//course name ; CS250\n//term : 2023/05/24" + }, "screenshotURL": "data/images/images-61u0me3y90srjguux-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ev52maygjcBnfCzwC/art.json b/art/ev52maygjcBnfCzwC/art.json index 2fdff154..e5565b00 100644 --- a/art/ev52maygjcBnfCzwC/art.json +++ b/art/ev52maygjcBnfCzwC/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "aleon", "avatarUrl": "https://secure.gravatar.com/avatar/ed3bcd978a61b62a2de04577302ee1f8?default=retro&size=200", - "settings": "{\"num\":70105,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/yumerec/sango-agorinha-yume-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = abs(atan(loc.x, loc.z) / PI);\\n float sv = abs(loc.y);\\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(cos(tm),-sin(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, pow(s, 2.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(0.9, 1.1, s) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 1000.;\\n }\\n #if 0\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n#endif\\n}\\n\\n\"}", + "settings": { + "num": 70105, + "mode": "LINES", + "sound": "https://soundcloud.com/yumerec/sango-agorinha-yume-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux * 2. - 1., mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = abs(atan(loc.x, loc.z) / PI);\n float sv = abs(loc.y);\n float s = texture2D(sound, vec2(mix(0.1, 0.2, su), mix(0.0, 0.2, sv))).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 10.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(cos(tm),-sin(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(2.8, 2.8, mix(1., 1.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, pow(s, 2.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(0.9, 1.1, s) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 3.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 1000.;\n }\n #if 0\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n#endif\n}\n\n" + }, "screenshotURL": "data/images/images-77ym3exa356wz2w52-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/evAAwbGtYJLZKPkMq/art.json b/art/evAAwbGtYJLZKPkMq/art.json index 28ea7052..4d42b8be 100644 --- a/art/evAAwbGtYJLZKPkMq/art.json +++ b/art/evAAwbGtYJLZKPkMq/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/victorruiz/robots\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n //rad += spike * 0.35;\\n //rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n \\tp1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/victorruiz/robots", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n //rad += spike * 0.35;\n //rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n \tp1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-gtgcq67hgk5ykmzm2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ewJGvmyLg4AN7sTJA/art.json b/art/ewJGvmyLg4AN7sTJA/art.json index a8ef2ca4..ec8db4f6 100644 --- a/art/ewJGvmyLg4AN7sTJA/art.json +++ b/art/ewJGvmyLg4AN7sTJA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":1024,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/yuriy-ershov/mix-2023-06-12\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//test\\n\\n#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 4.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat select(float v, float t) {\\n return step(t * 0.9, v) * step(v, t * 1.1);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (0. * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float historyV2 = (1. * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float snd2 = texture2D(sound, vec2(historyX, historyV2)).a;\\n \\n float s_norm = select(count, 0.);\\n float s_low = select(count, 1.);\\n float s_high = select(count, 2.);\\n float s_powd = select(count, 3.);\\n \\n float ds = abs(snd - snd2);\\n float norm = snd;\\n float low = step(ds, 0.1) * snd;\\n float high = step(0.1, ds) * snd;\\n float powd = pow(snd, 5.0);\\n \\n float s = \\n norm * s_norm + \\n low * s_low +\\n high * s_high + \\n powd * s_powd +\\n 0.;\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x,\\n s * 0.2 + v - 0.3);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = count * 0.25;\\n float sat = 1.0;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINES", + "sound": "https://soundcloud.com/yuriy-ershov/mix-2023-06-12", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//test\n\n#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 4.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat select(float v, float t) {\n return step(t * 0.9, v) * step(v, t * 1.1);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (0. * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float historyV2 = (1. * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float snd2 = texture2D(sound, vec2(historyX, historyV2)).a;\n \n float s_norm = select(count, 0.);\n float s_low = select(count, 1.);\n float s_high = select(count, 2.);\n float s_powd = select(count, 3.);\n \n float ds = abs(snd - snd2);\n float norm = snd;\n float low = step(ds, 0.1) * snd;\n float high = step(0.1, ds) * snd;\n float powd = pow(snd, 5.0);\n \n float s = \n norm * s_norm + \n low * s_low +\n high * s_high + \n powd * s_powd +\n 0.;\n \n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x,\n s * 0.2 + v - 0.3);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = count * 0.25;\n float sat = 1.0;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-3gci3fvyqvi64wcw7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/exWL4hKkpkDAwMwS5/art.json b/art/exWL4hKkpkDAwMwS5/art.json index 32e8f33c..4189e7aa 100644 --- a/art/exWL4hKkpkDAwMwS5/art.json +++ b/art/exWL4hKkpkDAwMwS5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\n/*\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id *1.55),\\n cos(id *0.43),\\n sin(id*0.22));\\n}\\n*/\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 120.;\\nconst float off = 0.1;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 eye = r0 * expand + zaxis * 1.;\\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n /*_emat = mat4(\\n 1.,0.,0.,0.,\\n 0.,1.,0.,0.,\\n 0.,0.,1.,0.,\\n 0.,0.,0.,1.); \\n */\\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n\\n float base = 14.5; // good place to adjust\\n base = time * 1.0;\\n\\n\\n vec3 b0 = getCurvePoint(base + off * 0.);\\n vec3 b1 = getCurvePoint(base + off * 1.);\\n vec3 b2 = getCurvePoint(base + off * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n \\n vec3 eye = b0 * expand + czaxis * 1.;\\n //eye = vec3(-60.,0.,40.);\\n vec3 target = b1 * expand + czaxis;\\n vec3 up = cyaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n \\n \\n //\\n float sizeFactor = 1./10.;\\n \\n float shapeCount = floor(vertexCount / 36.);\\n float shapeId = floor(vertexId / 36.);\\n float shapeVertexId = mod(vertexId, 36.);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElementPerGroup = 20.;\\n float groupId = floor(shapeId/numberOfElementPerGroup);\\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\\n float relGroupId = shapeIdInGroup/numberOfElementPerGroup;\\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\\n \\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n //cubep*= sizeFactor;\\n mat4 scaleMat = scale(vec3(sizeFactor,(3.+snd*snd)*sizeFactor,sizeFactor));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n mat4 zrot = rotZ(relGroupId*2.*PI);\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n //cbNi*=scaleMat;\\n \\n //create the circle group\\n \\n \\n \\n float radius = 30.*sizeFactor;\\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n \\n vec3 pos;\\n vec4 color;\\n \\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n //base+= mod(time,2.);\\n mat4 wmat;\\n mat4 emat;\\n \\n track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi;\\n //float rotx = atan( wmat.y, wmat.z );\\n //float roty = Math.atan2( x * Math.cos(rotx), z )\\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \\n \\n \\n //cbNi.xyz+= posi;\\n \\n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\n/*\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id *1.55),\n cos(id *0.43),\n sin(id*0.22));\n}\n*/\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 120.;\nconst float off = 0.1;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 eye = r0 * expand + zaxis * 1.;\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n /*_emat = mat4(\n 1.,0.,0.,0.,\n 0.,1.,0.,0.,\n 0.,0.,1.,0.,\n 0.,0.,0.,1.); \n */\n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n\n float base = 14.5; // good place to adjust\n base = time * 1.0;\n\n\n vec3 b0 = getCurvePoint(base + off * 0.);\n vec3 b1 = getCurvePoint(base + off * 1.);\n vec3 b2 = getCurvePoint(base + off * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n \n vec3 eye = b0 * expand + czaxis * 1.;\n //eye = vec3(-60.,0.,40.);\n vec3 target = b1 * expand + czaxis;\n vec3 up = cyaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n \n \n //\n float sizeFactor = 1./10.;\n \n float shapeCount = floor(vertexCount / 36.);\n float shapeId = floor(vertexId / 36.);\n float shapeVertexId = mod(vertexId, 36.);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElementPerGroup = 20.;\n float groupId = floor(shapeId/numberOfElementPerGroup);\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\n float relGroupId = shapeIdInGroup/numberOfElementPerGroup;\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\n \n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n //cubep*= sizeFactor;\n mat4 scaleMat = scale(vec3(sizeFactor,(3.+snd*snd)*sizeFactor,sizeFactor));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n mat4 zrot = rotZ(relGroupId*2.*PI);\n cubep = (zrot*vec4(cubep,1.)).xyz;\n //cbNi*=scaleMat;\n \n //create the circle group\n \n \n \n float radius = 30.*sizeFactor;\n cubep.x+= radius*sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n cubep.y+= radius*cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n \n vec3 pos;\n vec4 color;\n \n \n //shapeId = mod(shapeId+time, shapeCount);\n //base+= mod(time,2.);\n mat4 wmat;\n mat4 emat;\n \n track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi;\n //float rotx = atan( wmat.y, wmat.z );\n //float roty = Math.atan2( x * Math.cos(rotx), z )\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \n \n \n //cbNi.xyz+= posi;\n \n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-8xw4ziz6zhh0zwscw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/eyJnMiGS99BJjeDGt/art.json b/art/eyJnMiGS99BJjeDGt/art.json index 75674fb1..cabb27bd 100644 --- a/art/eyJnMiGS99BJjeDGt/art.json +++ b/art/eyJnMiGS99BJjeDGt/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":5272,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//[commercial] \\n\\n//Another K Machine exposed shader\\n//See it in action in the K Machine v2 on https://vimeo.com/217012333\\n//the 'K beginning' comments allows the K Machine to recognize \\n//and build adapted events controllers\\n//This shader can be copied in a text file with .glsl extension and\\n//uploaded to the K Machine. \\n//For more instructions for K Machine compliance see the doc on\\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\\n//More about the K Machine v2\\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\\n//as the K Machine has it's own relLoopProgress float parameter\\n//corresponding to the progression in the selected loop\\n\\n//[/commercial]\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n#define parameter0 2.5//KParameter0 1.>>8.\\n#define parameter1 -0.782//KParameter1 -1.>>1.\\n#define parameter2 -0.2//KParameter2 -3.>>3.\\n#define parameter3 0.6//KParameter3 0.>>12.\\n#define parameter4 6.1//KP0arameter4 0.>>2.\\n#define parameter5 0.2//KParameter5 0.1>>4.5\\n#define parameter6 1.2//KParameter6 0.>>3.\\n#define parameter7 .1//KParameter7 0.0>>10.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define SYMMETRY_H 0\\n#define SYMMETRY_V 1\\n#define COLOR_MODE 2\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\\n{\\n \\n \\n \\n \\n vec4 result = vec4(0., 0.,-1., 1.);\\n \\n \\n float localVertexId = _vertexId - _startVertexId;\\n \\n if(localVertexId<1.)\\n {\\n result.xy = _letter[11,2,0].xy;\\n }\\n else\\n \\n if(localVertexId<2.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n \\n else\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[6,16].xy;\\n }\\n else //2nd triangle\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<5.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<6.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n else\\n if(localVertexId<7.) \\n {\\n result.xy = _letter[2].xy;\\n }\\n else\\n if(localVertexId<8.)\\n {\\n result.xy = _letter[2].xy;\\n }\\n else\\n if(localVertexId<9.)\\n {\\n result.xy = _letter[8].xy;\\n \\n }\\n \\n else\\n if(localVertexId<10.)//4eme triangle\\n {\\n result.xy = _letter[4].xy;\\n \\n }\\n else\\n if(localVertexId<11.)\\n {\\n result.xy = _letter[10].xy;\\n \\n }\\n \\n else\\n if(localVertexId<12.)\\n {\\n result.xy = _letter[1,13].xy;\\n \\n }\\n else\\n if(localVertexId>=(3.,4.+parameter1))\\n {\\n result.xy = _letter[15,2].xy;\\n \\n }\\n else\\n if(localVertexId<14.)\\n {\\n result.xy = _letter[13].xy;\\n \\n }\\n else\\n if(localVertexId<15.)\\n {\\n result.xy = _letter[14,3,13].xy;\\n \\n }\\n else\\n if(localVertexId>6.)\\n {\\n result.xy = _letter[5,11].xy;\\n \\n }\\n else\\n if(localVertexId<17.)\\n {\\n result.xy = _letter[16].xy;\\n \\n }\\n else\\n if(localVertexId<18.)\\n {\\n result.xy = _letter[1,3].xy;\\n \\n }\\n result.xy+=_pos;\\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\\n result.xyz =rotZ(result.xyz, _rotation);\\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\\n result *= uniformScale(_scale);\\n \\n \\n return result.xyz;\\n}\\n\\n\\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\\n{\\n vec2 finalPos = _pos;\\n \\n \\n vec2 additionalPos = vec2(0.,0.);\\n \\n float transfoMode = floor(parameter3);\\n \\n \\n //additionalPos.x = _relLetterTimeProgress*0.5;\\n if(transfoMode<1.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n else\\n if(transfoMode<2.)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<3.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<4.)\\n {\\n additionalPos = -finalPos;\\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\\n \\n additionalPos.x+= m.x;\\n additionalPos.y+= m.y;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<5.)\\n {\\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<6.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<7.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n finalPos+= additionalPos;\\n }\\n \\n }\\n else\\n if(transfoMode<8.)\\n {\\n additionalPos = -finalPos;\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*2.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<9.)\\n {\\n additionalPos = -finalPos;\\n \\n if(mod(_shapeId,2.)<1.)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*3.-(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n \\n if(transfoMode<10.)\\n {\\n //if(_selectedShape == _shapeId)\\n {\\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\\n additionalPos.y = m.x*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n \\n else\\n \\n if(transfoMode<11.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\\n finalPos+= additionalPos;\\n }\\n \\n return finalPos;\\n}\\n\\n\\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\\n{\\n float finalRot = _rotation;\\n \\n float additionalRotation = 0.;\\n \\n float transfoMode = floor(parameter3);\\n \\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n else\\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n \\n \\n finalRot+= additionalRotation;\\n \\n /*\\n float additionalRotation = 0.;\\n \\n if(selectedLetterIndex == shapeId)\\n {\\n additionalRotation = 2.*PI*relLetterTimeProgress;\\n }\\n \\n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\\n */\\n \\n return finalRot;\\n}\\n\\n\\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\\n{\\n vec2 finalCenter = _center;\\n \\n \\n /*\\n vec2 additionalCenter = vec2(0.,0.);\\n \\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalCenter.x = _relLetterTimeProgress*0.5;\\n additionalCenter.y = _relLetterTimeProgress*0.5;\\n }\\n \\n finalCenter+= additionalCenter;\\n */\\n \\n return finalCenter;\\n}\\n\\n#define elementPerShapeLetterK 18.\\n\\n#define defaultRotationForShapeLetterK 0.13\\n#define defaultRotationForShapeLetterM - 0.09\\n#define defaultRotationForShapeLetterN 0.04\\n#define defaultRotationForShapeLetterA 0.1\\n#define defaultRotationForShapeLetterC - 0.05\\n#define defaultRotationForShapeLetterE - 0.03\\n#define defaultRotationForShapeLetterH 0.04\\n#define defaultRotationForShapeLetterI - 0.2\\n\\n\\n#define shapeNumber 8.\\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\\n\\nvoid main() {\\n \\n \\n vec3 color = vec3(1.);\\n \\n float sndFactor = texture2D(sound, vec2(1., .02)).r;\\n float _junctionY = 0.5 +parameter4*sndFactor/14.;\\n \\n float _barWidth = 0.2 + parameter4*sndFactor/100.;\\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\\n \\n float shapeId = 0.;\\n \\n vec2 letterK[18];\\n letterK[0] = vec2(0.,2.);\\n letterK[1] = vec2(0.,1.);\\n letterK[2] = vec2(_barWidth,1.);\\n letterK[3] = vec2(0.,0.0);\\n letterK[4] = vec2(_barWidth,1.);\\n letterK[5] = vec2(_barWidth,0.);\\n letterK[6] = vec2(_barWidth,_junctionY);\\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\\n letterK[8] = vec2(_secondVertY,1.);\\n letterK[9] = vec2(_barWidth,_junctionY);\\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\\n letterK[11] = vec2(_secondVertY,0.);\\n letterK[12] = vec2(_secondVertY,0.);\\n letterK[13] = vec2(_secondVertY,1.);\\n letterK[14] = vec2(_secondVertY,0.);\\n letterK[15] = vec2(_secondVertY,0.);\\n letterK[16] = vec2(_secondVertY,0.);\\n letterK[17] = vec2(_secondVertY,0.);\\n \\n vec2 letterM[18];\\n letterM[0] = vec2(0.,0.);\\n letterM[1] = vec2(0.,1.);\\n letterM[2] = vec2(_barWidth,1.);\\n letterM[3] = vec2(0.,0.0);\\n letterM[4] = vec2(_barWidth,1.);\\n letterM[5] = vec2(_barWidth,1.);//PROBLEM !!\\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterM[7] = vec2(_barWidth,1.);\\n letterM[8] = vec2(_barWidth*2.,_junctionY);\\n letterM[9] = vec2(_barWidth*2.,_junctionY);\\n letterM[10] = vec2((_barWidth*3.),1.);\\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\\n letterM[12] = vec2(_barWidth*3.,1.);\\n letterM[13] = vec2(_barWidth*4.,1.);\\n letterM[14] = vec2(_barWidth*3.,0.);\\n letterM[15] = vec2(_barWidth*3.,0.);\\n letterM[16] = vec2(_barWidth*4.,1.);\\n letterM[17] = vec2(_barWidth*4.,0.);\\n \\n \\n vec2 letterN[18];\\n letterN[0] = vec2(0.,0.);\\n letterN[1] = vec2(0.,1.);\\n letterN[2] = vec2(_barWidth,1.);\\n letterN[3] = vec2(0.,0.0);\\n letterN[4] = vec2(_barWidth,1.);\\n letterN[5] = vec2(_barWidth,0.);\\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterN[7] = vec2(_barWidth,1.);\\n letterN[8] = vec2(_barWidth*2.,_junctionY);\\n letterN[9] = vec2(_barWidth*2.,1.);\\n letterN[10] = vec2(_barWidth*3.,1.);\\n letterN[11] = vec2(_barWidth*2.,0.);\\n \\n letterN[12] = vec2(_barWidth*2.,0.);\\n letterN[13] = vec2(_barWidth*3.,1.);\\n letterN[14] = vec2(_barWidth*3.,0.);\\n letterN[15] = vec2(_barWidth*3.,0.);\\n \\n letterN[16] = vec2(_barWidth*3.,0.);\\n letterN[17] = vec2(_barWidth*3.,0.);\\n \\n \\n vec2 letterA[18];\\n letterA[0] = vec2(0.,0.);\\n letterA[1] = vec2(_barWidth,0.);\\n letterA[2] = vec2(_barWidth*2.,1.);\\n letterA[3] = vec2(_barWidth*4.,0.0);\\n letterA[4] = vec2(_barWidth*2.,1.);\\n letterA[5] = vec2(_barWidth*3.,0.);\\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\\n letterA[8] = vec2(_barWidth*3.,_junctionY);\\n letterA[9] = vec2(_barWidth*3.,_junctionY);\\n letterA[10] = vec2(_barWidth*3.,_junctionY);\\n letterA[11] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[12] = vec2(_barWidth*3.,_junctionY);\\n letterA[13] = vec2(_barWidth*3.,_junctionY);\\n letterA[14] = vec2(_barWidth*3.,_junctionY);\\n letterA[15] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[16] = vec2(_barWidth*3.,_junctionY);\\n letterA[17] = vec2(_barWidth*3.,_junctionY);\\n \\n \\n vec2 letterE[18];\\n letterE[0] = vec2(0.,0.);\\n letterE[1] = vec2(0.,1.);\\n letterE[2] = vec2(_barWidth,1.);\\n letterE[3] = vec2(0.,0.0);\\n letterE[4] = vec2(_barWidth,1.);\\n letterE[5] = vec2(_barWidth,0.);\\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\\n letterE[7] = vec2(_barWidth,1.);\\n letterE[8] = vec2(_barWidth*3.,1.);\\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\\n letterE[10] = vec2(_barWidth,0.);\\n letterE[11] = vec2(_barWidth*3.,0.);\\n letterE[12] = vec2(_barWidth,_junctionY);\\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n \\n \\n vec2 letterC[18];\\n letterC[0] = vec2(0.,0.);\\n letterC[1] = vec2(0.,1.);\\n letterC[2] = vec2(_barWidth,1.);\\n letterC[3] = vec2(0.,0.0);\\n letterC[4] = vec2(_barWidth,1.);\\n letterC[5] = vec2(_barWidth,0.);\\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\\n letterC[7] = vec2(_barWidth,1.);\\n letterC[8] = vec2(_barWidth*3.,1.);\\n letterC[9] = vec2(_barWidth,0.);\\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\\n letterC[11] = vec2(_barWidth*3.,0.);\\n letterC[12] = vec2(_barWidth*3.,0.);\\n letterC[13] = vec2(_barWidth*3.,0.);\\n letterC[14] = vec2(_barWidth*3.,0.);\\n letterC[15] = vec2(_barWidth*3.,0.);\\n letterC[16] = vec2(_barWidth*3.,0.);\\n letterC[17] = vec2(_barWidth*3.,0.);\\n \\n vec2 letterH[18];\\n letterH[0] = vec2(0.,0.);\\n letterH[1] = vec2(0.,1.);\\n letterH[2] = vec2(_barWidth,1.);\\n letterH[3] = vec2(0.,0.0);\\n letterH[4] = vec2(_barWidth,1.);\\n letterH[5] = vec2(_barWidth,0.);\\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\\n letterH[8] = vec2(_barWidth*2.,_junctionY);\\n letterH[9] = vec2(_barWidth*2.,_junctionY);\\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\\n letterH[12] = vec2(_barWidth*3.,1.);\\n letterH[13] = vec2(_barWidth*4.,1.);\\n letterH[14] = vec2(_barWidth*3.,0.);\\n letterH[15] = vec2(_barWidth*3.,0.);\\n letterH[16] = vec2(_barWidth*4.,1.);\\n letterH[17] = vec2(_barWidth*4.,0.);\\n \\n vec2 letterI[18];\\n letterI[0] = vec2(0.,0.);\\n letterI[1] = vec2(0.,_junctionY+_barWidth);\\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[3] = vec2(0.,0.0);\\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterI[6] = vec2(0.,1.-_barWidth);\\n letterI[7] = vec2(0.,1.);\\n letterI[8] = vec2(_barWidth,1.-_barWidth);\\n letterI[9] = vec2(_barWidth,1.-_barWidth);\\n letterI[10] = vec2(0.,1.);\\n letterI[11] = vec2(_barWidth,1.);\\n letterI[12] = vec2(_barWidth,1.);\\n letterI[13] = vec2(_barWidth,1.);\\n letterI[14] = vec2(_barWidth,1.);\\n letterI[15] = vec2(_barWidth,1.);\\n letterI[16] = vec2(_barWidth,1.);\\n letterI[17] = vec2(_barWidth,1.);\\n \\n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\\n \\n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\\n \\n finalVertexId = min(maxNumberOfVertices,vertexId);\\n \\n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\\n \\n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\\n //float relMetaShapeId = metaShapeId/256.;\\n \\n float masterScale = parameter5;//parameter6;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n \\n vec2 letterPos = vec2(0.,0.);\\n \\n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\\n \\n float scaleK = 0.1*masterScale;\\n float scale = 0.2*masterScale;\\n float startPosK = parameter2;\\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\\n \\n vec2 shapeCenter = vec2(0.1,0.15);\\n \\n //for vsa\\n \\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n \\n //end for vsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n \\n float numberOfSubLoops = floor(parameter0);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n \\n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\\n \\n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\\n \\n /////////////////////////\\n \\n float rotation = PI/2.*time*shapeId;\\n \\n if(finalVertexId0\\n else\\n if(vertexId0\\n else\\n if(vertexId1 && SYMMETRY_H >0\\n else\\n if(vertexId>8.\n#define parameter1 -0.782//KParameter1 -1.>>1.\n#define parameter2 -0.2//KParameter2 -3.>>3.\n#define parameter3 0.6//KParameter3 0.>>12.\n#define parameter4 6.1//KP0arameter4 0.>>2.\n#define parameter5 0.2//KParameter5 0.1>>4.5\n#define parameter6 1.2//KParameter6 0.>>3.\n#define parameter7 .1//KParameter7 0.0>>10.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n#define SYMMETRY_H 0\n#define SYMMETRY_V 1\n#define COLOR_MODE 2\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\n{\n \n \n \n \n vec4 result = vec4(0., 0.,-1., 1.);\n \n \n float localVertexId = _vertexId - _startVertexId;\n \n if(localVertexId<1.)\n {\n result.xy = _letter[11,2,0].xy;\n }\n else\n \n if(localVertexId<2.)\n {\n result.xy = _letter[1].xy;\n }\n \n else\n if(localVertexId<4.)\n {\n result.xy = _letter[6,16].xy;\n }\n else //2nd triangle\n if(localVertexId<4.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<5.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<6.)\n {\n result.xy = _letter[1].xy;\n }\n else\n if(localVertexId<7.) \n {\n result.xy = _letter[2].xy;\n }\n else\n if(localVertexId<8.)\n {\n result.xy = _letter[2].xy;\n }\n else\n if(localVertexId<9.)\n {\n result.xy = _letter[8].xy;\n \n }\n \n else\n if(localVertexId<10.)//4eme triangle\n {\n result.xy = _letter[4].xy;\n \n }\n else\n if(localVertexId<11.)\n {\n result.xy = _letter[10].xy;\n \n }\n \n else\n if(localVertexId<12.)\n {\n result.xy = _letter[1,13].xy;\n \n }\n else\n if(localVertexId>=(3.,4.+parameter1))\n {\n result.xy = _letter[15,2].xy;\n \n }\n else\n if(localVertexId<14.)\n {\n result.xy = _letter[13].xy;\n \n }\n else\n if(localVertexId<15.)\n {\n result.xy = _letter[14,3,13].xy;\n \n }\n else\n if(localVertexId>6.)\n {\n result.xy = _letter[5,11].xy;\n \n }\n else\n if(localVertexId<17.)\n {\n result.xy = _letter[16].xy;\n \n }\n else\n if(localVertexId<18.)\n {\n result.xy = _letter[1,3].xy;\n \n }\n result.xy+=_pos;\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\n result.xyz =rotZ(result.xyz, _rotation);\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\n result *= uniformScale(_scale);\n \n \n return result.xyz;\n}\n\n\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\n{\n vec2 finalPos = _pos;\n \n \n vec2 additionalPos = vec2(0.,0.);\n \n float transfoMode = floor(parameter3);\n \n \n //additionalPos.x = _relLetterTimeProgress*0.5;\n if(transfoMode<1.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n else\n if(transfoMode<2.)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<3.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<4.)\n {\n additionalPos = -finalPos;\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\n \n additionalPos.x+= m.x;\n additionalPos.y+= m.y;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<5.)\n {\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<6.)\n {\n additionalPos = -finalPos;\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<7.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n finalPos+= additionalPos;\n }\n \n }\n else\n if(transfoMode<8.)\n {\n additionalPos = -finalPos;\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*2.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<9.)\n {\n additionalPos = -finalPos;\n \n if(mod(_shapeId,2.)<1.)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*3.-(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n \n if(transfoMode<10.)\n {\n //if(_selectedShape == _shapeId)\n {\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\n additionalPos.y = m.x*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n \n else\n \n if(transfoMode<11.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\n finalPos+= additionalPos;\n }\n \n return finalPos;\n}\n\n\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\n{\n float finalRot = _rotation;\n \n float additionalRotation = 0.;\n \n float transfoMode = floor(parameter3);\n \n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\n \n }\n }\n else\n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\n \n }\n }\n \n \n finalRot+= additionalRotation;\n \n /*\n float additionalRotation = 0.;\n \n if(selectedLetterIndex == shapeId)\n {\n additionalRotation = 2.*PI*relLetterTimeProgress;\n }\n \n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\n */\n \n return finalRot;\n}\n\n\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\n{\n vec2 finalCenter = _center;\n \n \n /*\n vec2 additionalCenter = vec2(0.,0.);\n \n \n if(_selectedShape == _shapeId)\n {\n additionalCenter.x = _relLetterTimeProgress*0.5;\n additionalCenter.y = _relLetterTimeProgress*0.5;\n }\n \n finalCenter+= additionalCenter;\n */\n \n return finalCenter;\n}\n\n#define elementPerShapeLetterK 18.\n\n#define defaultRotationForShapeLetterK 0.13\n#define defaultRotationForShapeLetterM - 0.09\n#define defaultRotationForShapeLetterN 0.04\n#define defaultRotationForShapeLetterA 0.1\n#define defaultRotationForShapeLetterC - 0.05\n#define defaultRotationForShapeLetterE - 0.03\n#define defaultRotationForShapeLetterH 0.04\n#define defaultRotationForShapeLetterI - 0.2\n\n\n#define shapeNumber 8.\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\n\nvoid main() {\n \n \n vec3 color = vec3(1.);\n \n float sndFactor = texture2D(sound, vec2(1., .02)).r;\n float _junctionY = 0.5 +parameter4*sndFactor/14.;\n \n float _barWidth = 0.2 + parameter4*sndFactor/100.;\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\n \n float shapeId = 0.;\n \n vec2 letterK[18];\n letterK[0] = vec2(0.,2.);\n letterK[1] = vec2(0.,1.);\n letterK[2] = vec2(_barWidth,1.);\n letterK[3] = vec2(0.,0.0);\n letterK[4] = vec2(_barWidth,1.);\n letterK[5] = vec2(_barWidth,0.);\n letterK[6] = vec2(_barWidth,_junctionY);\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\n letterK[8] = vec2(_secondVertY,1.);\n letterK[9] = vec2(_barWidth,_junctionY);\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\n letterK[11] = vec2(_secondVertY,0.);\n letterK[12] = vec2(_secondVertY,0.);\n letterK[13] = vec2(_secondVertY,1.);\n letterK[14] = vec2(_secondVertY,0.);\n letterK[15] = vec2(_secondVertY,0.);\n letterK[16] = vec2(_secondVertY,0.);\n letterK[17] = vec2(_secondVertY,0.);\n \n vec2 letterM[18];\n letterM[0] = vec2(0.,0.);\n letterM[1] = vec2(0.,1.);\n letterM[2] = vec2(_barWidth,1.);\n letterM[3] = vec2(0.,0.0);\n letterM[4] = vec2(_barWidth,1.);\n letterM[5] = vec2(_barWidth,1.);//PROBLEM !!\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterM[7] = vec2(_barWidth,1.);\n letterM[8] = vec2(_barWidth*2.,_junctionY);\n letterM[9] = vec2(_barWidth*2.,_junctionY);\n letterM[10] = vec2((_barWidth*3.),1.);\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\n letterM[12] = vec2(_barWidth*3.,1.);\n letterM[13] = vec2(_barWidth*4.,1.);\n letterM[14] = vec2(_barWidth*3.,0.);\n letterM[15] = vec2(_barWidth*3.,0.);\n letterM[16] = vec2(_barWidth*4.,1.);\n letterM[17] = vec2(_barWidth*4.,0.);\n \n \n vec2 letterN[18];\n letterN[0] = vec2(0.,0.);\n letterN[1] = vec2(0.,1.);\n letterN[2] = vec2(_barWidth,1.);\n letterN[3] = vec2(0.,0.0);\n letterN[4] = vec2(_barWidth,1.);\n letterN[5] = vec2(_barWidth,0.);\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterN[7] = vec2(_barWidth,1.);\n letterN[8] = vec2(_barWidth*2.,_junctionY);\n letterN[9] = vec2(_barWidth*2.,1.);\n letterN[10] = vec2(_barWidth*3.,1.);\n letterN[11] = vec2(_barWidth*2.,0.);\n \n letterN[12] = vec2(_barWidth*2.,0.);\n letterN[13] = vec2(_barWidth*3.,1.);\n letterN[14] = vec2(_barWidth*3.,0.);\n letterN[15] = vec2(_barWidth*3.,0.);\n \n letterN[16] = vec2(_barWidth*3.,0.);\n letterN[17] = vec2(_barWidth*3.,0.);\n \n \n vec2 letterA[18];\n letterA[0] = vec2(0.,0.);\n letterA[1] = vec2(_barWidth,0.);\n letterA[2] = vec2(_barWidth*2.,1.);\n letterA[3] = vec2(_barWidth*4.,0.0);\n letterA[4] = vec2(_barWidth*2.,1.);\n letterA[5] = vec2(_barWidth*3.,0.);\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\n letterA[8] = vec2(_barWidth*3.,_junctionY);\n letterA[9] = vec2(_barWidth*3.,_junctionY);\n letterA[10] = vec2(_barWidth*3.,_junctionY);\n letterA[11] = vec2(_barWidth*3.,_junctionY);\n \n letterA[12] = vec2(_barWidth*3.,_junctionY);\n letterA[13] = vec2(_barWidth*3.,_junctionY);\n letterA[14] = vec2(_barWidth*3.,_junctionY);\n letterA[15] = vec2(_barWidth*3.,_junctionY);\n \n letterA[16] = vec2(_barWidth*3.,_junctionY);\n letterA[17] = vec2(_barWidth*3.,_junctionY);\n \n \n vec2 letterE[18];\n letterE[0] = vec2(0.,0.);\n letterE[1] = vec2(0.,1.);\n letterE[2] = vec2(_barWidth,1.);\n letterE[3] = vec2(0.,0.0);\n letterE[4] = vec2(_barWidth,1.);\n letterE[5] = vec2(_barWidth,0.);\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\n letterE[7] = vec2(_barWidth,1.);\n letterE[8] = vec2(_barWidth*3.,1.);\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\n letterE[10] = vec2(_barWidth,0.);\n letterE[11] = vec2(_barWidth*3.,0.);\n letterE[12] = vec2(_barWidth,_junctionY);\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n \n \n vec2 letterC[18];\n letterC[0] = vec2(0.,0.);\n letterC[1] = vec2(0.,1.);\n letterC[2] = vec2(_barWidth,1.);\n letterC[3] = vec2(0.,0.0);\n letterC[4] = vec2(_barWidth,1.);\n letterC[5] = vec2(_barWidth,0.);\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\n letterC[7] = vec2(_barWidth,1.);\n letterC[8] = vec2(_barWidth*3.,1.);\n letterC[9] = vec2(_barWidth,0.);\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\n letterC[11] = vec2(_barWidth*3.,0.);\n letterC[12] = vec2(_barWidth*3.,0.);\n letterC[13] = vec2(_barWidth*3.,0.);\n letterC[14] = vec2(_barWidth*3.,0.);\n letterC[15] = vec2(_barWidth*3.,0.);\n letterC[16] = vec2(_barWidth*3.,0.);\n letterC[17] = vec2(_barWidth*3.,0.);\n \n vec2 letterH[18];\n letterH[0] = vec2(0.,0.);\n letterH[1] = vec2(0.,1.);\n letterH[2] = vec2(_barWidth,1.);\n letterH[3] = vec2(0.,0.0);\n letterH[4] = vec2(_barWidth,1.);\n letterH[5] = vec2(_barWidth,0.);\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\n letterH[8] = vec2(_barWidth*2.,_junctionY);\n letterH[9] = vec2(_barWidth*2.,_junctionY);\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\n letterH[12] = vec2(_barWidth*3.,1.);\n letterH[13] = vec2(_barWidth*4.,1.);\n letterH[14] = vec2(_barWidth*3.,0.);\n letterH[15] = vec2(_barWidth*3.,0.);\n letterH[16] = vec2(_barWidth*4.,1.);\n letterH[17] = vec2(_barWidth*4.,0.);\n \n vec2 letterI[18];\n letterI[0] = vec2(0.,0.);\n letterI[1] = vec2(0.,_junctionY+_barWidth);\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[3] = vec2(0.,0.0);\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterI[6] = vec2(0.,1.-_barWidth);\n letterI[7] = vec2(0.,1.);\n letterI[8] = vec2(_barWidth,1.-_barWidth);\n letterI[9] = vec2(_barWidth,1.-_barWidth);\n letterI[10] = vec2(0.,1.);\n letterI[11] = vec2(_barWidth,1.);\n letterI[12] = vec2(_barWidth,1.);\n letterI[13] = vec2(_barWidth,1.);\n letterI[14] = vec2(_barWidth,1.);\n letterI[15] = vec2(_barWidth,1.);\n letterI[16] = vec2(_barWidth,1.);\n letterI[17] = vec2(_barWidth,1.);\n \n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\n \n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\n \n finalVertexId = min(maxNumberOfVertices,vertexId);\n \n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\n \n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\n //float relMetaShapeId = metaShapeId/256.;\n \n float masterScale = parameter5;//parameter6;\n \n vec3 _v = vec3(0.,0.,0.);\n \n vec2 letterPos = vec2(0.,0.);\n \n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\n \n float scaleK = 0.1*masterScale;\n float scale = 0.2*masterScale;\n float startPosK = parameter2;\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\n \n vec2 shapeCenter = vec2(0.1,0.15);\n \n //for vsa\n \n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n \n //end for vsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n \n float numberOfSubLoops = floor(parameter0);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n \n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\n \n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\n \n /////////////////////////\n \n float rotation = PI/2.*time*shapeId;\n \n if(finalVertexId0\n else\n if(vertexId0\n else\n if(vertexId1 && SYMMETRY_H >0\n else\n if(vertexId>8.\\n#define parameter1 3.//KParameter1 1.>>8.\\n#define parameter2 3.//KParameter2 0.>>40.\\n#define parameter3 15.//KParameter3 5>>100.\\n#define parameter4 0.1//KParameter4 0.01>>0.05\\n#define parameter5 30.//KParameter5 5.>>50.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 1.>>5.\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\\n{\\n vec3 u = _triangleVertices0 - _triangleVertices1;\\n vec3 v = _triangleVertices1 - _triangleVertices2;\\n return cross(v, u);\\n}\\n\\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\\n{\\n float localVid = mod(_vId,_vtn);\\n \\n if(localVid< 1.)\\n {\\n \\n _v = _vt[0];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n \\n }\\n else\\n if(localVid< 2.)\\n {\\n _v = _vt[1];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 3.)\\n {\\n _v = _vt[2];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 4.)\\n {\\n _v = _vt[3];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 5.)\\n {\\n _v = _vt[4];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 6.)\\n {\\n _v = _vt[5];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 7.)\\n {\\n _v = _vt[6];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 8.)\\n {\\n _v = _vt[7];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 9.)\\n {\\n _v = _vt[8];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 10.)\\n {\\n _v = _vt[9];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 11.)\\n {\\n _v = _vt[10];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 12.)\\n {\\n _v = _vt[11];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n \\n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\\n \\n _v = rotY(_v,_rot.y);\\n _n = rotY(_n,_rot.y);\\n \\n\\n _v = rotX(_v,_rot.x);\\n _n = rotX(_n,_rot.x);\\n \\n _v = rotZ(_v,_rot.z);\\n _n = rotZ(_n,_rot.z);\\n \\n _v += _pos;\\n //_n += _pos;\\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\\n specular = max(0.0, pow(NDoth, _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n \\n //KVsa\\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n //KVsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops = floor(parameter1);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n\\n \\n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops2 = floor(1.);\\n float subLoopLength2 = 1./numberOfSubLoops2;\\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n vec3 _n = vec3(0.,0.,0.);\\n \\n vec3 shapeVertices[12];\\n float shapeSize = 12.;\\n \\n \\n \\n \\n float maxShapeCount = floor(vertexCount/shapeSize);\\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\\n float shapeId = floor(finalVertexId/shapeSize);\\n float relShapeId = shapeId/maxShapeCount;\\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\\n \\n //create the big circle\\n float masterCircleRadius = 0.8;\\n float numberOfCirclesInMasterCircle = floor(parameter5);\\n float vertexPerSmallCircle = numberOfShape*shapeSize;\\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\\n \\n float scale = parameter4;\\n \\n \\n \\n float localShapeId = mod(shapeId,numberOfShape);\\n float localRelShapeId = localShapeId/numberOfShape;\\n \\n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\\n \\n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\\n float sndFactor = texture2D(sound, vec2(relMasterCircleId, 0.)).a ;\\n float factor1 = 1.;//+sndFactor*20.;\\n \\n float radius = sndFactor;//0.3+sndFactor/5.;//+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\\n \\n \\n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\\n \\n \\n \\n //[commercial] \\n\\n//Another K Machine exposed shader\\n//the 'K beginning' comments allows the K Machine to recognize \\n//and build adapted events controllers\\n//This shader can be copied in a text file with .glsl extension and\\n//uploaded to the K Machine. \\n//For more instructions for K Machine compliance see the doc on\\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\\n//More about the K Machine v2\\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\\n//as the K Machine has it's own relLoopProgress float parameter\\n//corresponding to the progression in the selected loop\\n\\n//[/commercial]\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=1000000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n \\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\\n shapeVertices[1] = vec3(0.5,0.,-0.5);\\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\\n shapeVertices[3] = vec3(0.5,0.,-0.5);\\n shapeVertices[4] = vec3(0.5,0.,0.5);\\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\\n shapeVertices[6] =vec3(0.5,0.,0.5);\\n shapeVertices[7] =vec3(-0.5,0.,0.5);\\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\\n shapeVertices[9] =vec3(-0.5,0.,0.5);\\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\\n \\n vec3 shapeColors[4];\\n \\n shapeColors[0] = vec3(1.,1.,0.);\\n shapeColors[1] = vec3(0.,0.,1.);\\n shapeColors[2] = vec3(0.,1.,1.);\\n shapeColors[3] = vec3(1.,0.,1.);\\n \\n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\\n \\n \\n //vec3 eye = vec3(cos(time), 0., sin(time));\\n vec3 eye = vec3(0., 0., -1.);\\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\\n\\n vec3 p = lookAt(_v, eye, vec3(0.,0.,0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n \\n _v.x*=resolution.y/resolution.x;\\n\\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 94167, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mr-one-way/kmachine-drum-endeavor1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//[commercial] \n\n//Another K Machine exposed shader\n//See vertex shaders in action in the K Machine v2 on https://vimeo.com/217012333\n//the 'K beginning' comments allows the K Machine to recognize \n//and build adapted events controllers\n//This shader can be copied in a text file with .glsl extension and\n//uploaded to the K Machine. \n//For more instructions for K Machine compliance see the doc on\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\n//More about the K Machine v2\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\n//as the K Machine has it's own relLoopProgress float parameter\n//corresponding to the progression in the selected loop\n\n//[/commercial]\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=1000000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>8.\n#define parameter1 3.//KParameter1 1.>>8.\n#define parameter2 3.//KParameter2 0.>>40.\n#define parameter3 15.//KParameter3 5>>100.\n#define parameter4 0.1//KParameter4 0.01>>0.05\n#define parameter5 30.//KParameter5 5.>>50.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 1.>>5.\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\n{\n vec3 u = _triangleVertices0 - _triangleVertices1;\n vec3 v = _triangleVertices1 - _triangleVertices2;\n return cross(v, u);\n}\n\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\n{\n float localVid = mod(_vId,_vtn);\n \n if(localVid< 1.)\n {\n \n _v = _vt[0];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n \n }\n else\n if(localVid< 2.)\n {\n _v = _vt[1];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 3.)\n {\n _v = _vt[2];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 4.)\n {\n _v = _vt[3];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 5.)\n {\n _v = _vt[4];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 6.)\n {\n _v = _vt[5];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 7.)\n {\n _v = _vt[6];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 8.)\n {\n _v = _vt[7];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 9.)\n {\n _v = _vt[8];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 10.)\n {\n _v = _vt[9];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 11.)\n {\n _v = _vt[10];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 12.)\n {\n _v = _vt[11];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n \n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\n \n _v = rotY(_v,_rot.y);\n _n = rotY(_n,_rot.y);\n \n\n _v = rotX(_v,_rot.x);\n _n = rotX(_n,_rot.x);\n \n _v = rotZ(_v,_rot.z);\n _n = rotZ(_n,_rot.z);\n \n _v += _pos;\n //_n += _pos;\n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\n specular = max(0.0, pow(NDoth, _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n \n vec3 color = vec3(1.);\n \n //KVsa\n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n //KVsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops = floor(parameter1);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n\n \n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops2 = floor(1.);\n float subLoopLength2 = 1./numberOfSubLoops2;\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\n \n vec3 _v = vec3(0.,0.,0.);\n vec3 _n = vec3(0.,0.,0.);\n \n vec3 shapeVertices[12];\n float shapeSize = 12.;\n \n \n \n \n float maxShapeCount = floor(vertexCount/shapeSize);\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\n float shapeId = floor(finalVertexId/shapeSize);\n float relShapeId = shapeId/maxShapeCount;\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\n \n //create the big circle\n float masterCircleRadius = 0.8;\n float numberOfCirclesInMasterCircle = floor(parameter5);\n float vertexPerSmallCircle = numberOfShape*shapeSize;\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\n \n float scale = parameter4;\n \n \n \n float localShapeId = mod(shapeId,numberOfShape);\n float localRelShapeId = localShapeId/numberOfShape;\n \n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\n \n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\n float sndFactor = texture2D(sound, vec2(relMasterCircleId, 0.)).a ;\n float factor1 = 1.;//+sndFactor*20.;\n \n float radius = sndFactor;//0.3+sndFactor/5.;//+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\n \n \n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\n \n \n \n //[commercial] \n\n//Another K Machine exposed shader\n//the 'K beginning' comments allows the K Machine to recognize \n//and build adapted events controllers\n//This shader can be copied in a text file with .glsl extension and\n//uploaded to the K Machine. \n//For more instructions for K Machine compliance see the doc on\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\n//More about the K Machine v2\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\n//as the K Machine has it's own relLoopProgress float parameter\n//corresponding to the progression in the selected loop\n\n//[/commercial]\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=1000000\n//KBackGroundColor=vec3(0.,0.,0.);\n \n shapeVertices[0] = vec3(-0.5,0.,-0.5);\n shapeVertices[1] = vec3(0.5,0.,-0.5);\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\n shapeVertices[3] = vec3(0.5,0.,-0.5);\n shapeVertices[4] = vec3(0.5,0.,0.5);\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\n shapeVertices[6] =vec3(0.5,0.,0.5);\n shapeVertices[7] =vec3(-0.5,0.,0.5);\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\n shapeVertices[9] =vec3(-0.5,0.,0.5);\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\n \n vec3 shapeColors[4];\n \n shapeColors[0] = vec3(1.,1.,0.);\n shapeColors[1] = vec3(0.,0.,1.);\n shapeColors[2] = vec3(0.,1.,1.);\n shapeColors[3] = vec3(1.,0.,1.);\n \n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\n \n \n //vec3 eye = vec3(cos(time), 0., sin(time));\n vec3 eye = vec3(0., 0., -1.);\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\n\n vec3 p = lookAt(_v, eye, vec3(0.,0.,0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n \n _v.x*=resolution.y/resolution.x;\n\n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-o8j6foul9djzvabgh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/f2btT6XFeFnaFopph/art.json b/art/f2btT6XFeFnaFopph/art.json index 354725f4..7185f0bd 100644 --- a/art/f2btT6XFeFnaFopph/art.json +++ b/art/f2btT6XFeFnaFopph/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Exercise a moving Grid\\n// CS250 Spring 2022\\n\\n//\\nvoid main() \\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.1;\\n float yoff = sin(time + y * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + xoff;\\n \\n vec2 xy = vec2(ux,vy)*1.3;\\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n}\\n \\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Exercise a moving Grid\n// CS250 Spring 2022\n\n//\nvoid main() \n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.1;\n float yoff = sin(time + y * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + xoff;\n \n vec2 xy = vec2(ux,vy)*1.3;\n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n}\n \n" + }, "screenshotURL": "data/images/images-bys4wm1juvncbwgvz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/f2eQBt4FaMKf9efrz/art.json b/art/f2eQBt4FaMKf9efrz/art.json index ea51127b..39ed4394 100644 --- a/art/f2eQBt4FaMKf9efrz/art.json +++ b/art/f2eQBt4FaMKf9efrz/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":51393,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id - 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI - 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod(c+ s, v);\\n float y = s = v + 11.* s *.04;\\n float z = c/ 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 1.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 12.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin((time * .03)+ circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) /.4;\\n offset.y += goop(circleId + time * 0.13) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -1.79));\\n float sat = 0.2 * circleId/snd;\\n float val = .9;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) * tan(pos / 83.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\\n}\"}", + "settings": { + "num": 51393, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id - 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI - 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod(c+ s, v);\n float y = s = v + 11.* s *.04;\n float z = c/ 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 1.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 12.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin((time * .03)+ circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) /.4;\n offset.y += goop(circleId + time * 0.13) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -1.79));\n float sat = 0.2 * circleId/snd;\n float val = .9;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) * tan(pos / 83.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\n}" + }, "screenshotURL": "data/images/images-udowci5p0xp1bgfzj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/f2knCxK4pMLFDEZWB/art.json b/art/f2knCxK4pMLFDEZWB/art.json index 69bc97fd..82314a60 100644 --- a/art/f2knCxK4pMLFDEZWB/art.json +++ b/art/f2knCxK4pMLFDEZWB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * .7;\\n \\n gl_Position = vec4(xy,0,1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * .7;\n \n gl_Position = vec4(xy,0,1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-f4kmyyz6quocwsyks-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/f5etc59cCAN5qsa9G/art.json b/art/f5etc59cCAN5qsa9G/art.json index 849acf94..6518631f 100644 --- a/art/f5etc59cCAN5qsa9G/art.json +++ b/art/f5etc59cCAN5qsa9G/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"#define PI radians(180.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 st = uv;\\n\\tst.x *= resolution.x / resolution.y;\\n\\n\\tvec2 pos = st.yx* vec2(10.0, 3.0);\\n\\t\\n\\tfloat pattern = pos.x;\\n\\t\\n\\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\\n\\t\\n\\tpattern = lines(pos, 0.5);\\n\\t\\n\\t//gl_FragColor = vec4(vec3(pattern), 1.0);\\n \\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n //camera\\n float r = 0.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 5.;//finalDesiredPointSize;\\n\\n v_color = vec4(vec3(pattern), 1.0);\\n float depth = (v_color.x*v_color.y*v_color.z)/20.;\\n \\n vec4 finalPos = vec4(ux, vy, 0.+depth*snd*2., 1.);\\n \\n gl_Position = mat*finalPos;\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 st = uv;\n\tst.x *= resolution.x / resolution.y;\n\n\tvec2 pos = st.yx* vec2(10.0, 3.0);\n\t\n\tfloat pattern = pos.x;\n\t\n\tpos += rotate2d((noise(pos + time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(time) * 0.2) * 2.0 - 1.0);\n\t\n\tpattern = lines(pos, 0.5);\n\t\n\t//gl_FragColor = vec4(vec3(pattern), 1.0);\n \n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n //camera\n float r = 0.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 5.;//finalDesiredPointSize;\n\n v_color = vec4(vec3(pattern), 1.0);\n float depth = (v_color.x*v_color.y*v_color.z)/20.;\n \n vec4 finalPos = vec4(ux, vy, 0.+depth*snd*2., 1.);\n \n gl_Position = mat*finalPos;\n}" + }, "screenshotURL": "data/images/images-uin9qftlmbdymf5ws-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/f6Qou7QNuj5onaJeQ/art.json b/art/f6Qou7QNuj5onaJeQ/art.json index 6ce62919..0973b09f 100644 --- a/art/f6Qou7QNuj5onaJeQ/art.json +++ b/art/f6Qou7QNuj5onaJeQ/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "aaron", "avatarUrl": "https://graph.facebook.com/10104810304767532/picture?type=large", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 500.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() {\\n float quadId = floor(vertexId / 6.);\\n float quadVert = mod(vertexId, 6.);\\n float trisize = 2.;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\n vec4 camera_scale = vec4(1. / resolution.xy /2., 1., 1.); // converts 1 unit to 1 pixel\\n //vec4 camera_scale = vec4(1, 1, 1, 1);\\n vec4 camera_translation = vec4(0, resolution.y, 0, 0);\\n \\n float realId = quadVert - floor(quadVert / 3.);\\n float rad = PI / 2. * realId + PI / 4.;\\n vec2 pos = vec2(cos(rad), sin(rad));\\n pos *= vec2(trisize * 20., trisize);\\n pos.y += quadId * sqrt(trisize * trisize * 2.);\\n gl_Position = (vec4(pos, 0, 1) - camera_translation) * camera_scale;\\n \\n vec4 color = vec4(0.33, 0.25, 0.5, 1);\\n vec4 highlight_max = vec4(1, 1, 1, 1);\\n vec4 highlight_min = vec4(0, 0, 0, 0);\\n float time_speed = 500.; // arbitrary\\n v_color = color + mix(highlight_min, highlight_max, mod(pos.y - time * 500., resolution.y) / resolution.y) * 0.75;\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 500.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() {\n float quadId = floor(vertexId / 6.);\n float quadVert = mod(vertexId, 6.);\n float trisize = 2.;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \n vec4 camera_scale = vec4(1. / resolution.xy /2., 1., 1.); // converts 1 unit to 1 pixel\n //vec4 camera_scale = vec4(1, 1, 1, 1);\n vec4 camera_translation = vec4(0, resolution.y, 0, 0);\n \n float realId = quadVert - floor(quadVert / 3.);\n float rad = PI / 2. * realId + PI / 4.;\n vec2 pos = vec2(cos(rad), sin(rad));\n pos *= vec2(trisize * 20., trisize);\n pos.y += quadId * sqrt(trisize * trisize * 2.);\n gl_Position = (vec4(pos, 0, 1) - camera_translation) * camera_scale;\n \n vec4 color = vec4(0.33, 0.25, 0.5, 1);\n vec4 highlight_max = vec4(1, 1, 1, 1);\n vec4 highlight_min = vec4(0, 0, 0, 0);\n float time_speed = 500.; // arbitrary\n v_color = color + mix(highlight_min, highlight_max, mod(pos.y - time * 500., resolution.y) / resolution.y) * 0.75;\n}" + }, "screenshotURL": "data/images/images-2cgppphin4hp8buux-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/f7oq7MsfTgoAMeXX2/art.json b/art/f7oq7MsfTgoAMeXX2/art.json index fc2ab43a..1121913d 100644 --- a/art/f7oq7MsfTgoAMeXX2/art.json +++ b/art/f7oq7MsfTgoAMeXX2/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "다은", "avatarUrl": "https://lh3.googleusercontent.com/--VGFNmU3UuQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rekfGpN6byv9fIvs3pAjQAlrfA__A/mo/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// your name (daeun Jeong)\\n// the assignment number (03)\\n// the course name (CS230)\\n// the term (Spring 2019)\\n\\nvoid main() \\n{ \\n float xOff = sin(time) * 0.2;\\n \\n float yOff = cos(time) * 0.2;\\n \\n float blueOff = abs(cos(time));\\n \\n float alphaOff = abs(sin(time)) + 0.5;\\n \\n float sizeOff = abs(sin(time)) * 10.0 + 10.0;\\n \\n vec4 pos = vec4(mouse.x + xOff, mouse.y + yOff, 0.0, 1.0);\\n \\n gl_Position = pos;\\n \\n gl_PointSize = sizeOff;\\n \\n v_color = vec4(0.1, 0.1, blueOff, alphaOff);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// your name (daeun Jeong)\n// the assignment number (03)\n// the course name (CS230)\n// the term (Spring 2019)\n\nvoid main() \n{ \n float xOff = sin(time) * 0.2;\n \n float yOff = cos(time) * 0.2;\n \n float blueOff = abs(cos(time));\n \n float alphaOff = abs(sin(time)) + 0.5;\n \n float sizeOff = abs(sin(time)) * 10.0 + 10.0;\n \n vec4 pos = vec4(mouse.x + xOff, mouse.y + yOff, 0.0, 1.0);\n \n gl_Position = pos;\n \n gl_PointSize = sizeOff;\n \n v_color = vec4(0.1, 0.1, blueOff, alphaOff);\n}" + }, "screenshotURL": "data/images/images-txxf77ib6jx1fq4il-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/f9MztjgyzxAHdqsxy/art.json b/art/f9MztjgyzxAHdqsxy/art.json index c3957d0d..dfb0142a 100644 --- a/art/f9MztjgyzxAHdqsxy/art.json +++ b/art/f9MztjgyzxAHdqsxy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = 0.; // sin(time + y * 0.2) * .1;\\n float yoff = 0.; // sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float snd = texture2D(sound, vec2(u * 0.125, v * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = .0; // sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = snd * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = 1.; // u * .1 + sin(time + v * 20.) * .5;\\n float sat = 1.;\\n float val = snd; //sin(time + v * u * 20.0) * .5 + .5;\\n\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = 0.; // sin(time + y * 0.2) * .1;\n float yoff = 0.; // sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float snd = texture2D(sound, vec2(u * 0.125, v * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = .0; // sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = snd * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = 1.; // u * .1 + sin(time + v * 20.) * .5;\n float sat = 1.;\n float val = snd; //sin(time + v * u * 20.0) * .5 + .5;\n\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}\n" + }, "screenshotURL": "data/images/images-6crny2r0gk0rlosg5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fAnatQu5aZpC5Dmby/art.json b/art/fAnatQu5aZpC5Dmby/art.json index 18b3eea4..4ee684ab 100644 --- a/art/fAnatQu5aZpC5Dmby/art.json +++ b/art/fAnatQu5aZpC5Dmby/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "bene2002", "avatarUrl": "https://secure.gravatar.com/avatar/08b4d8a2c513dbbd32686b69f0d14fc6?default=retro&size=200", - "settings": "{\"num\":2995,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0.6823529411764706,0.788235294117647,1],\"shader\":\"void main() {\\n float numY = floor(sqrt(vertexCount));\\n float numX = floor(vertexCount/numY);\\n \\n float x = mod(vertexId, numX);\\n float y = floor(vertexId / numX);\\n \\n float u = x / (numX - 1.);\\n float v = y / (numY - 1.);\\n \\n gl_Position = vec4(-1.+u*2.,1.-v*2.,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize = gl_PointSize * 20. / numX;\\n gl_PointSize = gl_PointSize * resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 2995, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0.6823529411764706, + 0.788235294117647, + 1 + ], + "shader": "void main() {\n float numY = floor(sqrt(vertexCount));\n float numX = floor(vertexCount/numY);\n \n float x = mod(vertexId, numX);\n float y = floor(vertexId / numX);\n \n float u = x / (numX - 1.);\n float v = y / (numY - 1.);\n \n gl_Position = vec4(-1.+u*2.,1.-v*2.,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize = gl_PointSize * 20. / numX;\n gl_PointSize = gl_PointSize * resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-w5kd0wb3zku61wqpr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fDJEaZrfDnKxNGck3/art.json b/art/fDJEaZrfDnKxNGck3/art.json index e7e5277e..30020d11 100644 --- a/art/fDJEaZrfDnKxNGck3/art.json +++ b/art/fDJEaZrfDnKxNGck3/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Motion\\n// CS250 \\n// Spring/2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time+y*0.2)*0.1;\\n float yoff = sin(time+x*0.3)*0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\t\\n vec2 xy = vec2(ux,vy)*1.3;\\n gl_Position = vec4(xy, 0., 1.);\\n \\n float soff = sin(time+x*y*0.02)*5.;\\n\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Motion\n// CS250 \n// Spring/2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time+y*0.2)*0.1;\n float yoff = sin(time+x*0.3)*0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \t\n vec2 xy = vec2(ux,vy)*1.3;\n gl_Position = vec4(xy, 0., 1.);\n \n float soff = sin(time+x*y*0.02)*5.;\n\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-o9ybjrawelrdgatry-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fDPvNsyqX8zmv9hxa/art.json b/art/fDPvNsyqX8zmv9hxa/art.json index e71c218d..8c7a619e 100644 --- a/art/fDPvNsyqX8zmv9hxa/art.json +++ b/art/fDPvNsyqX8zmv9hxa/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/sunrizer-mantra\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n float v = vertexId;\\n //float sndFactor = texture2D(sound, vec2(;\\n float off = .1;\\n \\n float spiral = 1. - 1.7 * vertexId / (vertexCount+vertexCount);\\n float scale = 1.;\\n float grid = floor(vertexCount / 1000.);\\n float sndFactor = texture2D(sound, vec2(mod(v, 1.), mod(v, 240.))).a;\\n\\n \\n float y = sin(v / 100.) * spiral ;//*sndFactor;\\n float x = cos(v / 100. + sndFactor / 25.) * spiral;\\n \\n float ux = x * scale - off;\\n float uy = y * scale - off;\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = 5.;//v / (sndFactor *100000.) ;// grid;\\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\\n //v_color = vec4(sin(spiral * 5. +time + sndFactor), 0.1, 0.5, 1);\\n v_color = vec4(sin(spiral * 10. +time + sndFactor), 0.1, 0.5, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/sunrizer-mantra", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n float v = vertexId;\n //float sndFactor = texture2D(sound, vec2(;\n float off = .1;\n \n float spiral = 1. - 1.7 * vertexId / (vertexCount+vertexCount);\n float scale = 1.;\n float grid = floor(vertexCount / 1000.);\n float sndFactor = texture2D(sound, vec2(mod(v, 1.), mod(v, 240.))).a;\n\n \n float y = sin(v / 100.) * spiral ;//*sndFactor;\n float x = cos(v / 100. + sndFactor / 25.) * spiral;\n \n float ux = x * scale - off;\n float uy = y * scale - off;\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = 5.;//v / (sndFactor *100000.) ;// grid;\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\n //v_color = vec4(sin(spiral * 5. +time + sndFactor), 0.1, 0.5, 1);\n v_color = vec4(sin(spiral * 10. +time + sndFactor), 0.1, 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-enlcwaqznapc9xhb8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fFEpFHbdC4ecFLuaB/art.json b/art/fFEpFHbdC4ecFLuaB/art.json index fcd0b35d..7c3a560e 100644 --- a/art/fFEpFHbdC4ecFLuaB/art.json +++ b/art/fFEpFHbdC4ecFLuaB/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 7.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 7.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-odg44osl63lgnpnca-thumbnail.jpg", "views": { "$numberInt": "161" diff --git a/art/fGCtwoQy8Mc8RK2pY/art.json b/art/fGCtwoQy8Mc8RK2pY/art.json index fd69861f..fdd00ed0 100644 --- a/art/fGCtwoQy8Mc8RK2pY/art.json +++ b/art/fGCtwoQy8Mc8RK2pY/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "aaron1924", "avatarUrl": "https://secure.gravatar.com/avatar/401c5d5fc2a9202f44ee18595001dbac?default=retro&size=200", - "settings": "{\"num\":25000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n\\nfloat box(vec3 p)\\n{\\n p = abs(p);\\n return max(p.x, max(p.y, p.z));\\n}\\n\\nmat2 rot(float a)\\n{\\n float s=sin(a), c=cos(a);\\n return mat2(c,s,-s,c);\\n}\\n\\n\\n\\nvec3 cube(float id, float count)\\n{ \\n id += time;\\n vec3 m = vec3(0.73287, 0.91706, 0.29328);\\n vec3 p = fract(m * id) - 0.5;\\n p /= box(p);\\n \\n p.xz *= rot(time);\\n p.yz *= rot(0.5 * time);\\n \\n return 0.3 * p;\\n}\\n\\nvec3 scanline(float id, float count)\\n{\\n float segs = 8.;\\n float a = 0.5 * TAU * fract(floor(segs * id/count) / segs + 0.1 * time);\\n float b = TAU * id/count * segs - time;\\n \\n vec3 p = vec3(sin(a) * cos(b), cos(a), sin(a) * sin(b));\\n \\n float off = fract(time+1.2345*vertexId);\\n p.xy *= 1.0 + sin(a) * off;\\n \\n return p;\\n}\\n\\nvec3 ambient(float id, float count)\\n{\\n float w = sqrt(count);\\n vec2 u = vec2(mod(id, w), floor(id / w)) / w;\\n \\n u.y = fract(u.y - 0.1 * time);\\n u = 12. * (u - 0.5);\\n \\n vec3 p = vec3(u, 0.1 * cos(8. * u.x) + 0.1 * cos(3. * u.y));\\n \\n /*vec3 p = fract(8. * fract(vec3(67.502, 36.565, 66.536) * id) + id/count);\\n p.y -= 0.1 * time;\\n p = 8. * (fract(p) - 0.5);*/\\n \\n return p;\\n}\\n\\n\\n\\nvoid main() {\\n vec3 p = vec3(0);\\n \\n float count = vertexCount / 3.;\\n \\n if(3.*vertexId < vertexCount)p = scanline(vertexId, count);\\n else if(3.*vertexId < 2. * vertexCount) p = cube(vertexId - count, count);\\n else p = ambient(vertexId - 2. * count, count);\\n \\n p.z += 2.;\\n \\n vec2 uv = p.xy / p.z;\\n uv.x *= resolution.y / resolution.x;\\n \\n gl_PointSize = 4. / p.z;\\n gl_Position = vec4(uv, 0, 1);\\n \\n v_color = vec4(1);\\n}\"}", + "settings": { + "num": 25000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n\nfloat box(vec3 p)\n{\n p = abs(p);\n return max(p.x, max(p.y, p.z));\n}\n\nmat2 rot(float a)\n{\n float s=sin(a), c=cos(a);\n return mat2(c,s,-s,c);\n}\n\n\n\nvec3 cube(float id, float count)\n{ \n id += time;\n vec3 m = vec3(0.73287, 0.91706, 0.29328);\n vec3 p = fract(m * id) - 0.5;\n p /= box(p);\n \n p.xz *= rot(time);\n p.yz *= rot(0.5 * time);\n \n return 0.3 * p;\n}\n\nvec3 scanline(float id, float count)\n{\n float segs = 8.;\n float a = 0.5 * TAU * fract(floor(segs * id/count) / segs + 0.1 * time);\n float b = TAU * id/count * segs - time;\n \n vec3 p = vec3(sin(a) * cos(b), cos(a), sin(a) * sin(b));\n \n float off = fract(time+1.2345*vertexId);\n p.xy *= 1.0 + sin(a) * off;\n \n return p;\n}\n\nvec3 ambient(float id, float count)\n{\n float w = sqrt(count);\n vec2 u = vec2(mod(id, w), floor(id / w)) / w;\n \n u.y = fract(u.y - 0.1 * time);\n u = 12. * (u - 0.5);\n \n vec3 p = vec3(u, 0.1 * cos(8. * u.x) + 0.1 * cos(3. * u.y));\n \n /*vec3 p = fract(8. * fract(vec3(67.502, 36.565, 66.536) * id) + id/count);\n p.y -= 0.1 * time;\n p = 8. * (fract(p) - 0.5);*/\n \n return p;\n}\n\n\n\nvoid main() {\n vec3 p = vec3(0);\n \n float count = vertexCount / 3.;\n \n if(3.*vertexId < vertexCount)p = scanline(vertexId, count);\n else if(3.*vertexId < 2. * vertexCount) p = cube(vertexId - count, count);\n else p = ambient(vertexId - 2. * count, count);\n \n p.z += 2.;\n \n vec2 uv = p.xy / p.z;\n uv.x *= resolution.y / resolution.x;\n \n gl_PointSize = 4. / p.z;\n gl_Position = vec4(uv, 0, 1);\n \n v_color = vec4(1);\n}" + }, "screenshotURL": "data/images/images-3zpmb6d2a6g198ctx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fHqs32thqJc7j2QR3/art.json b/art/fHqs32thqJc7j2QR3/art.json index 113d1160..e6e1f855 100644 --- a/art/fHqs32thqJc7j2QR3/art.json +++ b/art/fHqs32thqJc7j2QR3/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":15000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mouthwateringrecords/dubokaj-trimoto-calim\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5568627450980392,0.611764705882353,0.5725490196078431,1],\"shader\":\"void main() {\\n float aspect = resolution.x / resolution.y;\\n float phi = vertexId * .120;\\n float radius = fract(vertexId / (10. + sin(time * .01 + phi * .1))) * .6;\\n phi += radius * 5.;\\n radius += (sin(phi * 5.) * .5 + .5) * .1;\\n float tau = acos(-1.) * 2.;\\n phi += clamp(fract(time * 80. / 60.) * 3., 0., 1.) * tau / 5.;\\n radius += .5 * radius * texture2D(sound, vec2(abs(fract(phi / tau - .25) - .5) * .25, 0.)).r;\\n gl_PointSize = mix(1., 3., fract(phi * .1));\\n vec3 pos = vec3(radius * cos(phi), radius * sin(phi), 0.);\\n pos.x /= aspect;\\n gl_Position = vec4(pos, 1);\\n vec3 color = vec3(0);\\n v_color = vec4(color, 1.);\\n\\n}\"}", + "settings": { + "num": 15000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mouthwateringrecords/dubokaj-trimoto-calim", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5568627450980392, + 0.611764705882353, + 0.5725490196078431, + 1 + ], + "shader": "void main() {\n float aspect = resolution.x / resolution.y;\n float phi = vertexId * .120;\n float radius = fract(vertexId / (10. + sin(time * .01 + phi * .1))) * .6;\n phi += radius * 5.;\n radius += (sin(phi * 5.) * .5 + .5) * .1;\n float tau = acos(-1.) * 2.;\n phi += clamp(fract(time * 80. / 60.) * 3., 0., 1.) * tau / 5.;\n radius += .5 * radius * texture2D(sound, vec2(abs(fract(phi / tau - .25) - .5) * .25, 0.)).r;\n gl_PointSize = mix(1., 3., fract(phi * .1));\n vec3 pos = vec3(radius * cos(phi), radius * sin(phi), 0.);\n pos.x /= aspect;\n gl_Position = vec4(pos, 1);\n vec3 color = vec3(0);\n v_color = vec4(color, 1.);\n\n}" + }, "screenshotURL": "data/images/images-t3ye1v22de0ypn7qu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fHwLHN2yrXWfnAnbn/art.json b/art/fHwLHN2yrXWfnAnbn/art.json index 4a51e12c..4068a74b 100644 --- a/art/fHwLHN2yrXWfnAnbn/art.json +++ b/art/fHwLHN2yrXWfnAnbn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(0.5, 0.5);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-0.5, 0.5);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(0.5, -0.5);\\n }\\n else {\\n fp = vec2(-0.5, -0.5);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 0.5);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -0.5);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 0.5, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -0.5, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-0.5, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(0.5, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 1.;\\n //float lineId = mod(shapeId, numberOfElement);\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float relXid = xPos/2.;\\n xPos =xPos*2.-1.;\\n \\n //float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n //float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\\n \\n float scaleFactor = 0.2;\\n \\n //lineId+=mod(time*1.,2.);\\n \\n cubep*= scaleFactor;\\n //cubep.y+= soundFactor;\\n \\n float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n\\n float speed = 1.;\\n //float simpZ = cubep.z + lineId;\\n float elementSize = 1.*scaleFactor;\\n float basePatternLength = 2.*elementSize;\\n float colorPatternLength = 2.*basePatternLength;\\n cubep.z += lineId*basePatternLength+ mod(time*speed,colorPatternLength);//mod(time/1000.+simpZ,1.2*shapeCount);\\n //float relZPos = cubep.z/(shapeCount*basePatternLength);\\n //float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n //cubep.y+=snd;\\n //float eyeZ = sin(time/10.)*topZPos;\\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(2., 2., 0.5);//29./2.*abs(cos(time/5.))\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n float redCOmp = mod(lineId,2.);\\n color.x = redCOmp;\\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(0.5, 0.5);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-0.5, 0.5);\n }\n else if(vtxId == 3.0) {\n fp = vec2(0.5, -0.5);\n }\n else {\n fp = vec2(-0.5, -0.5);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 0.5);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -0.5);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 0.5, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -0.5, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-0.5, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(0.5, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 1.;\n //float lineId = mod(shapeId, numberOfElement);\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float relXid = xPos/2.;\n xPos =xPos*2.-1.;\n \n //float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n //float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);\n \n float scaleFactor = 0.2;\n \n //lineId+=mod(time*1.,2.);\n \n cubep*= scaleFactor;\n //cubep.y+= soundFactor;\n \n float snd = texture2D(sound, vec2(0., shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+3.*snd, cubep.z);//position\n \n vec3 color = vec3(1., 1., 1.);\n \n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n\n float speed = 1.;\n //float simpZ = cubep.z + lineId;\n float elementSize = 1.*scaleFactor;\n float basePatternLength = 2.*elementSize;\n float colorPatternLength = 2.*basePatternLength;\n cubep.z += lineId*basePatternLength+ mod(time*speed,colorPatternLength);//mod(time/1000.+simpZ,1.2*shapeCount);\n //float relZPos = cubep.z/(shapeCount*basePatternLength);\n //float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n //cubep.y+=snd;\n //float eyeZ = sin(time/10.)*topZPos;\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(2., 2., 0.5);//29./2.*abs(cos(time/5.))\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n float redCOmp = mod(lineId,2.);\n color.x = redCOmp;\n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-4ksvew0bjm38em3bc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fKArPmJPF5sgaDbNK/art.json b/art/fKArPmJPF5sgaDbNK/art.json index 0014fb4e..1c0591d1 100644 --- a/art/fKArPmJPF5sgaDbNK/art.json +++ b/art/fKArPmJPF5sgaDbNK/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":150,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.11764705882352941,0.11764705882352941,0.11764705882352941,1],\"shader\":\"mat2 Rotate2D (float x) {\\n float a=sin(x), b=cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main() {\\n vec2 pos = vec2((vertexId/vertexCount), 0.0)*Rotate2D(vertexId+time*2.0);\\n gl_PointSize = 15.0;\\n gl_Position = vec4(pos, 0.0, 1.0);\\n v_color = vec4(pos.x, pos.y, abs(-pos.x), 1.0)+0.5;\\n}\"}", + "settings": { + "num": 150, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.11764705882352941, + 0.11764705882352941, + 0.11764705882352941, + 1 + ], + "shader": "mat2 Rotate2D (float x) {\n float a=sin(x), b=cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main() {\n vec2 pos = vec2((vertexId/vertexCount), 0.0)*Rotate2D(vertexId+time*2.0);\n gl_PointSize = 15.0;\n gl_Position = vec4(pos, 0.0, 1.0);\n v_color = vec4(pos.x, pos.y, abs(-pos.x), 1.0)+0.5;\n}" + }, "screenshotURL": "data/images/images-3v2tartd20707roac-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fKPK987qvE5gGHcWS/art.json b/art/fKPK987qvE5gGHcWS/art.json index 2d8f50ee..3127666e 100644 --- a/art/fKPK987qvE5gGHcWS/art.json +++ b/art/fKPK987qvE5gGHcWS/art.json @@ -28,7 +28,19 @@ "name": "sines", "private": false, "username": "jason2", - "settings": "{\"num\":46119,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() { \\n float traces = 6.0;\\n float trace = mod(vertexId, traces);\\n float x = -1.0 + 2.0 * vertexId / vertexCount;\\n \\n float speed = 1.0 * time;\\n float amp = x * 0.7 * (sin(time) + (1.0 + trace) / traces);\\n float y = amp * sin(speed + PI * x);\\n \\n gl_Position = vec4(x, y, 0, 1);\\n float c = trace / traces;\\n v_color = vec4(hsv2rgb(vec3(x, 0.5, 1)), 1);\\n}\"}", + "settings": { + "num": 46119, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() { \n float traces = 6.0;\n float trace = mod(vertexId, traces);\n float x = -1.0 + 2.0 * vertexId / vertexCount;\n \n float speed = 1.0 * time;\n float amp = x * 0.7 * (sin(time) + (1.0 + trace) / traces);\n float y = amp * sin(speed + PI * x);\n \n gl_Position = vec4(x, y, 0, 1);\n float c = trace / traces;\n v_color = vec4(hsv2rgb(vec3(x, 0.5, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-oq24k4gtm5vocgxag-thumbnail.jpg", "views": { "$numberInt": "312" diff --git a/art/fKYmuHmgGeNTPniPK/art.json b/art/fKYmuHmgGeNTPniPK/art.json index 7c8014fa..d572da9b 100644 --- a/art/fKYmuHmgGeNTPniPK/art.json +++ b/art/fKYmuHmgGeNTPniPK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07450980392156863,0.07450980392156863,0.08627450980392157,1],\"shader\":\"#define PI 3.141592653589793238462643383\\n\\nvec3 hueShift(vec3 color,float hueAdjust){\\n\\tconst vec3 kRGBToYPrime=vec3(0.299,0.587,0.114);\\n\\tconst vec3 kRGBToI=vec3(0.596,-0.275,-0.321);\\n\\tconst vec3 kRGBToQ=vec3(0.212,-0.523,0.311);\\n\\tconst vec3 kYIQToR=vec3(1.0,0.956,0.621);\\n\\tconst vec3 kYIQToG=vec3(1.0,-0.272,-0.647);\\n\\tconst vec3 kYIQToB=vec3(1.0,-1.107,1.704);\\n\\tfloat YPrime=dot(color,kRGBToYPrime);\\n\\tfloat I=dot(color,kRGBToI);\\n\\tfloat Q=dot(color,kRGBToQ);\\n\\tfloat hue=atan(Q,I);\\n\\tfloat chroma=sqrt(I*I+Q*Q);\\n\\thue+=hueAdjust;\\n\\tQ=chroma*sin(hue);\\n\\tI=chroma*cos(hue);\\n\\tvec3 yIQ=vec3(YPrime,I,Q);\\n\\treturn vec3(dot(yIQ,kYIQToR),dot(yIQ,kYIQToG),dot(yIQ,kYIQToB));\\n}\\n\\n//I don't understand how to achieve 3D scenes.\\nvoid main(){\\n float t=vertexId/vertexCount;\\n float aspect=resolution.x/resolution.y;\\n float x=cos(((t-(time/9.))+2.4)*25.3),\\n y=sin(((t+(time/6.))*5.62)+x);\\n x+=sin(t*y*2.);\\n vec2 shift=vec2(fract(sin(x*y*522.41)*25.2)-.5,fract(sin(x*y*564.1)*35.2)-.5);\\n x+=pow(length(shift),2.5)*shift.x;\\n y+=pow(length(shift),2.5)*shift.y;\\n gl_Position=vec4(x/aspect,y,0.,1.+(length(shift)*+.1));\\n gl_PointSize=1.2+((pow(sin(t*PI),5.)*3.)/((length(shift)*5.)+1.));\\n vec3 a=vec3(1.,1.,1.);\\n vec3 b=hueShift(vec3(1.,0.,0.),(t*8.)+time);\\n v_color=vec4(mix(a,b,clamp(pow(length(shift),2.)*4.,0.,1.)),1.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07450980392156863, + 0.07450980392156863, + 0.08627450980392157, + 1 + ], + "shader": "#define PI 3.141592653589793238462643383\n\nvec3 hueShift(vec3 color,float hueAdjust){\n\tconst vec3 kRGBToYPrime=vec3(0.299,0.587,0.114);\n\tconst vec3 kRGBToI=vec3(0.596,-0.275,-0.321);\n\tconst vec3 kRGBToQ=vec3(0.212,-0.523,0.311);\n\tconst vec3 kYIQToR=vec3(1.0,0.956,0.621);\n\tconst vec3 kYIQToG=vec3(1.0,-0.272,-0.647);\n\tconst vec3 kYIQToB=vec3(1.0,-1.107,1.704);\n\tfloat YPrime=dot(color,kRGBToYPrime);\n\tfloat I=dot(color,kRGBToI);\n\tfloat Q=dot(color,kRGBToQ);\n\tfloat hue=atan(Q,I);\n\tfloat chroma=sqrt(I*I+Q*Q);\n\thue+=hueAdjust;\n\tQ=chroma*sin(hue);\n\tI=chroma*cos(hue);\n\tvec3 yIQ=vec3(YPrime,I,Q);\n\treturn vec3(dot(yIQ,kYIQToR),dot(yIQ,kYIQToG),dot(yIQ,kYIQToB));\n}\n\n//I don't understand how to achieve 3D scenes.\nvoid main(){\n float t=vertexId/vertexCount;\n float aspect=resolution.x/resolution.y;\n float x=cos(((t-(time/9.))+2.4)*25.3),\n y=sin(((t+(time/6.))*5.62)+x);\n x+=sin(t*y*2.);\n vec2 shift=vec2(fract(sin(x*y*522.41)*25.2)-.5,fract(sin(x*y*564.1)*35.2)-.5);\n x+=pow(length(shift),2.5)*shift.x;\n y+=pow(length(shift),2.5)*shift.y;\n gl_Position=vec4(x/aspect,y,0.,1.+(length(shift)*+.1));\n gl_PointSize=1.2+((pow(sin(t*PI),5.)*3.)/((length(shift)*5.)+1.));\n vec3 a=vec3(1.,1.,1.);\n vec3 b=hueShift(vec3(1.,0.,0.),(t*8.)+time);\n v_color=vec4(mix(a,b,clamp(pow(length(shift),2.)*4.,0.,1.)),1.);\n}" + }, "screenshotURL": "data/images/images-bxd8b6b6r9ie6abhy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fLedbHFSXD9E4aMSv/art.json b/art/fLedbHFSXD9E4aMSv/art.json index 5b79d439..538769d0 100644 --- a/art/fLedbHFSXD9E4aMSv/art.json +++ b/art/fLedbHFSXD9E4aMSv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.3\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, .9);\\n float innerRadius = pow(count * 0.0005, .2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * 0.5, 0, 1);\\n\\n float b = 1.2 - pow(sin(count * 0.4) * 0.0 + 0.7, 1.8);\\n b = 0.0;mix(0.3, 0.7, b);\\n v_color = vec4(c, b, c, 0.6);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.3\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, .9);\n float innerRadius = pow(count * 0.0005, .2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * 0.5, 0, 1);\n\n float b = 1.2 - pow(sin(count * 0.4) * 0.0 + 0.7, 1.8);\n b = 0.0;mix(0.3, 0.7, b);\n v_color = vec4(c, b, c, 0.6);\n}" + }, "screenshotURL": "data/images/images-gu78a1hdbkc8e989z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fM43AivGvoEWBm7G7/art.json b/art/fM43AivGvoEWBm7G7/art.json index e9cee50e..862deaeb 100644 --- a/art/fM43AivGvoEWBm7G7/art.json +++ b/art/fM43AivGvoEWBm7G7/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "moon-jong", "avatarUrl": "https://avatars.githubusercontent.com/moon-jong?s=200", - "settings": "{\"num\":2426,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/moe-p0/newjeans-omg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.047058823529411764,0.047058823529411764,1],\"shader\":\"void main() {\\n \\n \\tfloat down = floor(sqrt(vertexCount));\\n\\tfloat across = floor(vertexCount / down); \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\t\\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = cos(time + x * 0.3) * 0.2;\\n \\tfloat soff = sin(time + x) * 5.;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\tgl_Position = vec4(xy, 0, 1);\\n \\tgl_PointSize = 15.0 + soff;\\n\\tgl_PointSize *= 20.0 / across;\\n \\n \\tfloat snd = texture2D(sound, vec2(ux, ux)).a;\\n \\tgl_PointSize *= resolution.x / 600. + snd;\\n \\n\\tv_color = vec4(0.5 + snd, 0.2 + snd, 1. + snd , 1);\\n \\n\\n}\"}", + "settings": { + "num": 2426, + "mode": "POINTS", + "sound": "https://soundcloud.com/moe-p0/newjeans-omg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.047058823529411764, + 0.047058823529411764, + 1 + ], + "shader": "void main() {\n \n \tfloat down = floor(sqrt(vertexCount));\n\tfloat across = floor(vertexCount / down); \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \t\n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = cos(time + x * 0.3) * 0.2;\n \tfloat soff = sin(time + x) * 5.;\n \n \tfloat ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n\tgl_Position = vec4(xy, 0, 1);\n \tgl_PointSize = 15.0 + soff;\n\tgl_PointSize *= 20.0 / across;\n \n \tfloat snd = texture2D(sound, vec2(ux, ux)).a;\n \tgl_PointSize *= resolution.x / 600. + snd;\n \n\tv_color = vec4(0.5 + snd, 0.2 + snd, 1. + snd , 1);\n \n\n}" + }, "screenshotURL": "data/images/images-jd6enm4gjd4tg8jp4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fMPBsNwkev8DSYD72/art.json b/art/fMPBsNwkev8DSYD72/art.json index cb74b9c9..e5e79b67 100644 --- a/art/fMPBsNwkev8DSYD72/art.json +++ b/art/fMPBsNwkev8DSYD72/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":31263,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/truecast-on-proton-music-guestmix-apsara\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8901960784313725,0.8901960784313725,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.10)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 5.5, 1.55));\\n vec4 K = vec4(5.0, 2.0 / 3.0, 1.0 / 3.0, 3.5);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 2.10, 1.155), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS + NUM_SEGMENTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS + NUM_SEGMENTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS - 1.0);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.5;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float hxv = mod(historyX * historyV, NUM_POINTS);\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0 + hxv;\\n float y = v * 2.0 - 1.0 - hxv;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v + hxv);\\n}\"}", + "settings": { + "num": 31263, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/djapsara/truecast-on-proton-music-guestmix-apsara", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8901960784313725, + 0.8901960784313725, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.10)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 5.5, 1.55));\n vec4 K = vec4(5.0, 2.0 / 3.0, 1.0 / 3.0, 3.5);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 2.10, 1.155), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS + NUM_SEGMENTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS + NUM_SEGMENTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS - 1.0);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.5;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float hxv = mod(historyX * historyV, NUM_POINTS);\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0 + hxv;\n float y = v * 2.0 - 1.0 - hxv;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v + hxv);\n}" + }, "screenshotURL": "data/images/images-z6hyf2iuknjtljetj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fNYWAGT9SkHb3bQrk/art.json b/art/fNYWAGT9SkHb3bQrk/art.json index caa5e515..203fd0be 100644 --- a/art/fNYWAGT9SkHb3bQrk/art.json +++ b/art/fNYWAGT9SkHb3bQrk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":63411,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\n\\n\\nfloat norm(float n)\\n{\\n if (n >= 0.49)\\n return 1.;\\n else\\n return 0.;\\n}\\n\\nfloat getb(float n, float pos)\\n{\\n return norm(mod(n / (pos * 2.), 1.0));\\n}\\n\\nfloat round(float n)\\n{\\n return floor(n + .5);\\n}\\n\\nfloat not(float n)\\n{\\n return floor(n * -1. + 1.);\\n}\\n\\nvec4 hypercube_lines(float id)\\n{\\n float F = getb(id, 1.);\\n float E = getb(id, 2.);\\n float D = getb(id, 4.);\\n float C = getb(id, 8.);\\n float B = getb(id, 16.);\\n float A = getb(id, 32.);\\n\\n float FA = B*not(C)*not(D)*F+A*not(B)*C*not(E)+not(A)*C*D*F+B*not(C)*not(E)*F+not(A)*B*E*F+not(A)*B*D*E+A*not(B)*not(E)*not(F)+A*B*not(D)*not(E)*F+not(A)*B*C*not(E)*not(F)+B*C*D*E*F+A*not(B)*not(C)*E*F+A*B*not(C)*D*not(F)+not(A)*not(C)*not(D)*not(E)*F+A*not(B)*C*D*not(F)+not(A)*not(B)*not(C)*not(D)*E*not(F)+A*B*C*not(D)*E*not(F);\\n float FB = C*not(D)*E*F+not(B)*C*D*not(E)+C*D*not(E)*not(F)+B*C*not(D)*E+A*not(B)*not(D)*F+A*not(B)*not(D)*E+A*not(D)*E*F+not(A)*not(B)*not(C)*not(E)*F+not(A)*not(B)*not(C)*E*not(F)+not(A)*B*not(C)*not(E)*not(F)+B*not(C)*not(D)*not(E)*not(F)+not(A)*B*C*not(D)*F+A*not(B)*not(C)*not(E)*not(F)+A*not(B)*not(C)*E*F+A*B*D*not(E)*F+A*B*C*E*F;\\n float FC = A*D*F+A*not(B)*not(C)+A*not(B)*F+A*not(C)*D*not(E)+A*not(C)*not(E)*F+B*D*not(E)*F+not(A)*B*E*not(F)+A*C*D*E+A*C*E*F+not(B)*C*not(D)*E*not(F)+not(B)*C*D*E*F+not(A)*C*not(D)*not(E)*F;\\n float FD = D*not(E)*not(F)+B*not(C)*D+A*D*not(E)+not(A)*not(D)*E*F+not(C)*not(D)*E*F+not(B)*C*E*F+not(A)*B*not(C)*F+A*not(C)*E*not(F)+not(A)*not(B)*C*D*not(F)+A*not(B)*not(C)*not(D)*F;\\n\\n FA = norm(FA);\\n FB = norm(FB);\\n FC = norm(FC);\\n FD = norm(FD);\\n \\n float FF = mod(FA + FB * 2. + FC * 4. + FD * 8., 16.);\\n \\n return hypercube(FF);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 0, 0, 0);\\n vec4 up4 = vec4(0, 1, 0, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(3.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n float theta3 = 45.0 * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.1 * TAU);\\n vec4 v4 = hypercube_lines(mod(vertexId, 64.0));\\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect, 0, 1);\\n v_color = vec4(1,1,1, 1);\\n}\"}", + "settings": { + "num": 63411, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\n\n\nfloat norm(float n)\n{\n if (n >= 0.49)\n return 1.;\n else\n return 0.;\n}\n\nfloat getb(float n, float pos)\n{\n return norm(mod(n / (pos * 2.), 1.0));\n}\n\nfloat round(float n)\n{\n return floor(n + .5);\n}\n\nfloat not(float n)\n{\n return floor(n * -1. + 1.);\n}\n\nvec4 hypercube_lines(float id)\n{\n float F = getb(id, 1.);\n float E = getb(id, 2.);\n float D = getb(id, 4.);\n float C = getb(id, 8.);\n float B = getb(id, 16.);\n float A = getb(id, 32.);\n\n float FA = B*not(C)*not(D)*F+A*not(B)*C*not(E)+not(A)*C*D*F+B*not(C)*not(E)*F+not(A)*B*E*F+not(A)*B*D*E+A*not(B)*not(E)*not(F)+A*B*not(D)*not(E)*F+not(A)*B*C*not(E)*not(F)+B*C*D*E*F+A*not(B)*not(C)*E*F+A*B*not(C)*D*not(F)+not(A)*not(C)*not(D)*not(E)*F+A*not(B)*C*D*not(F)+not(A)*not(B)*not(C)*not(D)*E*not(F)+A*B*C*not(D)*E*not(F);\n float FB = C*not(D)*E*F+not(B)*C*D*not(E)+C*D*not(E)*not(F)+B*C*not(D)*E+A*not(B)*not(D)*F+A*not(B)*not(D)*E+A*not(D)*E*F+not(A)*not(B)*not(C)*not(E)*F+not(A)*not(B)*not(C)*E*not(F)+not(A)*B*not(C)*not(E)*not(F)+B*not(C)*not(D)*not(E)*not(F)+not(A)*B*C*not(D)*F+A*not(B)*not(C)*not(E)*not(F)+A*not(B)*not(C)*E*F+A*B*D*not(E)*F+A*B*C*E*F;\n float FC = A*D*F+A*not(B)*not(C)+A*not(B)*F+A*not(C)*D*not(E)+A*not(C)*not(E)*F+B*D*not(E)*F+not(A)*B*E*not(F)+A*C*D*E+A*C*E*F+not(B)*C*not(D)*E*not(F)+not(B)*C*D*E*F+not(A)*C*not(D)*not(E)*F;\n float FD = D*not(E)*not(F)+B*not(C)*D+A*D*not(E)+not(A)*not(D)*E*F+not(C)*not(D)*E*F+not(B)*C*E*F+not(A)*B*not(C)*F+A*not(C)*E*not(F)+not(A)*not(B)*C*D*not(F)+A*not(B)*not(C)*not(D)*F;\n\n FA = norm(FA);\n FB = norm(FB);\n FC = norm(FC);\n FD = norm(FD);\n \n float FF = mod(FA + FB * 2. + FC * 4. + FD * 8., 16.);\n \n return hypercube(FF);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 0, 0, 0);\n vec4 up4 = vec4(0, 1, 0, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(3.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n float theta3 = 45.0 * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.1 * TAU);\n vec4 v4 = hypercube_lines(mod(vertexId, 64.0));\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect, 0, 1);\n v_color = vec4(1,1,1, 1);\n}" + }, "screenshotURL": "data/images/images-xyxzilawzfc16xh2w-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fNyYuzQ69eREkJCMq/art.json b/art/fNyYuzQ69eREkJCMq/art.json index 1215bad0..381cbb3d 100644 --- a/art/fNyYuzQ69eREkJCMq/art.json +++ b/art/fNyYuzQ69eREkJCMq/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":6000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jiangxueer/dj\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.8901960784313725,0.8431372549019608,1],\"shader\":\"#pragma once\\n/* \\n\\n\\n\\n \\n \\n\\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nFinal View: \\n\\nhttps://www.bilibili.com/video/av84117427/\\n\\n这就是你分手的借口,\\n🕺🕺🕺如果让你重新来过,\\n🕺🕺🕺你会不会爱我,\\n🕺🕺🕺爱情让人拥有快乐,\\n🕺🕺🕺也会带来折磨,\\n🕺🕺🕺曾经和你一起走过传说中的爱河,\\n🕺🕺🕺已经被我泪水淹没,\\n🕺🕺🕺变成痛苦的爱河这就是你分手的借口,🕺🕺🕺 \\n\\n@31/12/2019 \\n*/ \\n#define PI radians(180.)\\n\\n\\nmat4 mAspect = mat4\\n(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n); \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash2( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\n#pragma region FlowerComponent \\n\\n#define limbVC 1000. \\n#define MajorVC 1000. \\nvoid GenFlower(float offsetX, float offsetX2 , \\n float offsetY, \\n \\t\\t\\t inout float In_vertexIndex , \\n out vec3 Pos , \\n out mat4 model) \\n{\\n /*Time&Music Setting*/\\n float ux = mod(In_vertexIndex, 1.) ; \\n float vy = floor(In_vertexIndex /1. ) ; \\n vec4 soundUV = texture2D(sound, vec2(ux,vy)); \\n \\tfloat pPoint= soundUV.r * 0.25; \\n \\n \\tfloat radius = 0. ; \\n if(In_vertexIndex > 0. && In_vertexIndex < limbVC )\\n { \\n float fy = floor(In_vertexIndex / (limbVC ) );\\n float xOffset = fract( (In_vertexIndex) / (limbVC * 2.)) * 0.2 ; \\n\\tfloat yOffset = sqrt(xOffset ) ; \\n if(soundUV != vec4(0.))\\n {\\n if(sin( 3.5 * time)> 0.)\\n xOffset = sin(yOffset * 100. * pPoint) * 0.025 * pPoint * time * 0.0003; \\n else \\n xOffset = -sin(yOffset * 100. * pPoint) * 0.025 * pPoint * time * 0.0003; \\n }\\n Pos = vec3(xOffset + offsetX+ offsetX2,- yOffset + offsetY , 0. );\\n }\\n In_vertexIndex -= limbVC; \\n if(In_vertexIndex > 0. && In_vertexIndex < MajorVC) \\n { \\n radius = sin(In_vertexIndex * (1.)) * .2 ; \\n if(mouse.y > -0.6 && mouse.y < 0.1)\\n { \\n if(mouse.y > -0.6 && mouse.y < -0.4)\\n \\tradius = sin(In_vertexIndex * floor(4. * mouse.y)) * .2 ; \\n if(mouse.y > -0.4 && mouse.y < -0.2)\\n radius = sin(In_vertexIndex * floor(5.)) * .2 ; \\n if(mouse.y > -0.2 && mouse.y < -0.1)\\n \\t\\tradius = sin(In_vertexIndex * floor(3. * mouse.y)) * .2 ; \\n }\\n if(mouse.y > 0.0)\\n radius = sin(In_vertexIndex * (5. * pPoint * log(mouse.y))) * .2 ; \\n float xPos = radius * sin(In_vertexIndex) ; \\n float yPos = radius * cos(In_vertexIndex) ; \\n float zPos = 0.1 ; \\n Pos = vec3( xPos + offsetX, yPos + offsetY, zPos);\\n \\n \\t\\n } \\n In_vertexIndex -= MajorVC;\\n // model *= trans(vec3(0. , 0. , 0.)) ;\\n \\n}\\n\\n#pragma endregion \\n\\n\\n/* -------------------------------- Display ------------------------------- */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/* -------------------------------- Display ------------------------------- */\\n#define OffsetX1 -1.\\n#define OffsetX2 +1.\\n#define OffsetX3 0.\\n#define OffsetXX1 -0.04 \\n#define OffsetXX2 +0.04 \\n#define OffsetXX3 0. \\n#define OffsetY1 0.0 \\n#define OffsetY2 0.0 \\nvoid main() \\n{\\n /*UniformSetting*/\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1 , 20. ); \\n vec3 camera = vec3(0. , 0. , 1. ) ;\\n vec3 target = vec3(0.);\\n vec3 up = vec3(0., 1., 0.); \\n m*= cameraLookAt(camera , target , up);\\n m*= uniformScale(0.4); \\n \\n float vertexIndex = vertexId ; \\n vec3 Pos = vec3(0.) ; \\n float u = mod(vertexId , 10.); \\n float v = floor(vertexId/ 10.) ; \\n \\n /*影流の花*/\\n GenFlower(OffsetX1, OffsetXX1, \\n OffsetY1, vertexIndex , Pos, m); \\n \\n GenFlower(OffsetX2, OffsetXX2, \\n OffsetY1, vertexIndex , Pos, m); \\n \\n GenFlower(OffsetX3, OffsetXX3, \\n OffsetY1, vertexIndex , Pos, m); \\n /*Apply*/ \\n gl_Position = m*vec4(Pos, 1); \\n gl_PointSize = 2.; \\n v_color = vec4(vec3(0.), 1.); \\n \\n}\\n\\n\\n\\n\\n\"}", + "settings": { + "num": 6000, + "mode": "POINTS", + "sound": "https://soundcloud.com/jiangxueer/dj", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.8901960784313725, + 0.8431372549019608, + 1 + ], + "shader": "#pragma once\n/* \n\n\n\n \n \n\n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nFinal View: \n\nhttps://www.bilibili.com/video/av84117427/\n\n这就是你分手的借口,\n🕺🕺🕺如果让你重新来过,\n🕺🕺🕺你会不会爱我,\n🕺🕺🕺爱情让人拥有快乐,\n🕺🕺🕺也会带来折磨,\n🕺🕺🕺曾经和你一起走过传说中的爱河,\n🕺🕺🕺已经被我泪水淹没,\n🕺🕺🕺变成痛苦的爱河这就是你分手的借口,🕺🕺🕺 \n\n@31/12/2019 \n*/ \n#define PI radians(180.)\n\n\nmat4 mAspect = mat4\n(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n); \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash2( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\n#pragma region FlowerComponent \n\n#define limbVC 1000. \n#define MajorVC 1000. \nvoid GenFlower(float offsetX, float offsetX2 , \n float offsetY, \n \t\t\t inout float In_vertexIndex , \n out vec3 Pos , \n out mat4 model) \n{\n /*Time&Music Setting*/\n float ux = mod(In_vertexIndex, 1.) ; \n float vy = floor(In_vertexIndex /1. ) ; \n vec4 soundUV = texture2D(sound, vec2(ux,vy)); \n \tfloat pPoint= soundUV.r * 0.25; \n \n \tfloat radius = 0. ; \n if(In_vertexIndex > 0. && In_vertexIndex < limbVC )\n { \n float fy = floor(In_vertexIndex / (limbVC ) );\n float xOffset = fract( (In_vertexIndex) / (limbVC * 2.)) * 0.2 ; \n\tfloat yOffset = sqrt(xOffset ) ; \n if(soundUV != vec4(0.))\n {\n if(sin( 3.5 * time)> 0.)\n xOffset = sin(yOffset * 100. * pPoint) * 0.025 * pPoint * time * 0.0003; \n else \n xOffset = -sin(yOffset * 100. * pPoint) * 0.025 * pPoint * time * 0.0003; \n }\n Pos = vec3(xOffset + offsetX+ offsetX2,- yOffset + offsetY , 0. );\n }\n In_vertexIndex -= limbVC; \n if(In_vertexIndex > 0. && In_vertexIndex < MajorVC) \n { \n radius = sin(In_vertexIndex * (1.)) * .2 ; \n if(mouse.y > -0.6 && mouse.y < 0.1)\n { \n if(mouse.y > -0.6 && mouse.y < -0.4)\n \tradius = sin(In_vertexIndex * floor(4. * mouse.y)) * .2 ; \n if(mouse.y > -0.4 && mouse.y < -0.2)\n radius = sin(In_vertexIndex * floor(5.)) * .2 ; \n if(mouse.y > -0.2 && mouse.y < -0.1)\n \t\tradius = sin(In_vertexIndex * floor(3. * mouse.y)) * .2 ; \n }\n if(mouse.y > 0.0)\n radius = sin(In_vertexIndex * (5. * pPoint * log(mouse.y))) * .2 ; \n float xPos = radius * sin(In_vertexIndex) ; \n float yPos = radius * cos(In_vertexIndex) ; \n float zPos = 0.1 ; \n Pos = vec3( xPos + offsetX, yPos + offsetY, zPos);\n \n \t\n } \n In_vertexIndex -= MajorVC;\n // model *= trans(vec3(0. , 0. , 0.)) ;\n \n}\n\n#pragma endregion \n\n\n/* -------------------------------- Display ------------------------------- */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* -------------------------------- Display ------------------------------- */\n#define OffsetX1 -1.\n#define OffsetX2 +1.\n#define OffsetX3 0.\n#define OffsetXX1 -0.04 \n#define OffsetXX2 +0.04 \n#define OffsetXX3 0. \n#define OffsetY1 0.0 \n#define OffsetY2 0.0 \nvoid main() \n{\n /*UniformSetting*/\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1 , 20. ); \n vec3 camera = vec3(0. , 0. , 1. ) ;\n vec3 target = vec3(0.);\n vec3 up = vec3(0., 1., 0.); \n m*= cameraLookAt(camera , target , up);\n m*= uniformScale(0.4); \n \n float vertexIndex = vertexId ; \n vec3 Pos = vec3(0.) ; \n float u = mod(vertexId , 10.); \n float v = floor(vertexId/ 10.) ; \n \n /*影流の花*/\n GenFlower(OffsetX1, OffsetXX1, \n OffsetY1, vertexIndex , Pos, m); \n \n GenFlower(OffsetX2, OffsetXX2, \n OffsetY1, vertexIndex , Pos, m); \n \n GenFlower(OffsetX3, OffsetXX3, \n OffsetY1, vertexIndex , Pos, m); \n /*Apply*/ \n gl_Position = m*vec4(Pos, 1); \n gl_PointSize = 2.; \n v_color = vec4(vec3(0.), 1.); \n \n}\n\n\n\n\n" + }, "screenshotURL": "data/images/images-7l9gc1si4ebpqd981-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fRJj6RxaarH7Lp4HG/art.json b/art/fRJj6RxaarH7Lp4HG/art.json index 7191c009..a942e4a6 100644 --- a/art/fRJj6RxaarH7Lp4HG/art.json +++ b/art/fRJj6RxaarH7Lp4HG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":42866,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle + 3. );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 2.); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], -0.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n\\n -0.1 -s, 0, 0, 0.1,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 2) /2.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. + 0.1;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.07;\\n pos = vec3(x, y +1., z +2. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(.1, mod(circleId*2., 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles -parameter4;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n\\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.0203) * 1.4;\\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 * 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\\n float sat = 0.9 - circleId;\\n float val = .75;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9 /parameter6, 0.2));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 42866, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle + 3. );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 2.); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], -0.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n\n -0.1 -s, 0, 0, 0.1,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 2) /2.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. + 0.1;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.07;\n pos = vec3(x, y +1., z +2. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(.1, mod(circleId*2., 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles -parameter4;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.0203) * 1.4;\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 * 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\n float sat = 0.9 - circleId;\n float val = .75;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9 /parameter6, 0.2));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-n3zu0njdlpxx9259z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fRcccsZ7jqFGGPAdJ/art.json b/art/fRcccsZ7jqFGGPAdJ/art.json index dad25ccc..0bdcdbd6 100644 --- a/art/fRcccsZ7jqFGGPAdJ/art.json +++ b/art/fRcccsZ7jqFGGPAdJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.5019607843137255,1,1],\"shader\":\"//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tMotion\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = cos(sin(time + y * 0.2)) * 0.1;\\n \\tfloat yoff = cos(sin(time + x * 0.3)) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across * (2. - sin(time * 10.));\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tv_color = vec4(xy.x, xy.y, 0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.5019607843137255, + 1, + 1 + ], + "shader": "//\tseongryul.park\n//\tCS250 spring 2023\n//\tMotion\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = cos(sin(time + y * 0.2)) * 0.1;\n \tfloat yoff = cos(sin(time + x * 0.3)) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across * (2. - sin(time * 10.));\n \tgl_PointSize *= resolution.x / 600.;\n \n \tv_color = vec4(xy.x, xy.y, 0, 1);\n}" + }, "screenshotURL": "data/images/images-p0wlp0izngehkv3y2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fRmvmXuk82tiLXCRX/art.json b/art/fRmvmXuk82tiLXCRX/art.json index c8100fdb..36e309a7 100644 --- a/art/fRmvmXuk82tiLXCRX/art.json +++ b/art/fRmvmXuk82tiLXCRX/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//\\t\\t\\\"description\\\"\\t: \\\"3D assets and textures for ROME - 3 Dreams of Black - at http://ro.me are licensed under a Creative CommonsAttribution-NonCommercial-ShareAlike 3.0 Unported License ( http://creativecommons.org/licenses/by-nc-sa/3.0/ ).\\\"\\n\\n\\n#define NUM_VERTS_0 1626.\\nvoid getVert0(in float id, out vec3 pos, out vec3 norm) {\\n if (id < 813.) {\\n if (id < 406.) {\\n if (id < 203.) {\\n if (id < 101.) {\\n if (id < 50.) {\\n if (id < 25.) {\\n if (id < 12.) {\\n if (id < 6.) {\\n if (id < 3.) {\\n if (id < 1.) {\\n pos = vec3(0., 99., 84.); norm = vec3(-0.159, 0.803, 0.379); return;\\n } else {\\n if (id < 2.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(-0.159, 0.803, 0.379); return;\\n } else {\\n pos = vec3(0., 48., 192.); norm = vec3(-0.159, 0.803, 0.379); return;\\n }\\n }\\n } else {\\n if (id < 4.) {\\n pos = vec3(0., 48., 192.); norm = vec3(-0.095, 0.178, 0.183); return;\\n } else {\\n if (id < 5.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(-0.095, 0.178, 0.183); return;\\n } else {\\n pos = vec3(-28., 31., 194.); norm = vec3(-0.095, 0.178, 0.183); return;\\n }\\n }\\n }\\n } else {\\n if (id < 9.) {\\n if (id < 7.) {\\n pos = vec3(-30., -54., -256.); norm = vec3(-0.269, -0.018, -0.097); return;\\n } else {\\n if (id < 8.) {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.269, -0.018, -0.097); return;\\n } else {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.269, -0.018, -0.097); return;\\n }\\n }\\n } else {\\n if (id < 10.) {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.837, -0.109, -0.313); return;\\n } else {\\n if (id < 11.) {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.837, -0.109, -0.313); return;\\n } else {\\n pos = vec3(-68., 46., -184.); norm = vec3(-0.837, -0.109, -0.313); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 18.) {\\n if (id < 15.) {\\n if (id < 13.) {\\n pos = vec3(0., -11., -266.); norm = vec3(-0.378, 0.646, -0.567); return;\\n } else {\\n if (id < 14.) {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.378, 0.646, -0.567); return;\\n } else {\\n pos = vec3(0., 67., -177.); norm = vec3(-0.378, 0.646, -0.567); return;\\n }\\n }\\n } else {\\n if (id < 16.) {\\n pos = vec3(0., 67., -177.); norm = vec3(-0.110, 0.229, -0.209); return;\\n } else {\\n if (id < 17.) {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.110, 0.229, -0.209); return;\\n } else {\\n pos = vec3(-40., 66., -157.); norm = vec3(-0.110, 0.229, -0.209); return;\\n }\\n }\\n }\\n } else {\\n if (id < 21.) {\\n if (id < 19.) {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.236, -0.013, 0.125); return;\\n } else {\\n if (id < 20.) {\\n pos = vec3(-115., 15., 87.); norm = vec3(-0.236, -0.013, 0.125); return;\\n } else {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.236, -0.013, 0.125); return;\\n }\\n }\\n } else {\\n if (id < 23.) {\\n if (id < 22.) {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.872, -0.318, 0.363); return;\\n } else {\\n pos = vec3(-115., 15., 87.); norm = vec3(-0.872, -0.318, 0.363); return;\\n }\\n } else {\\n if (id < 24.) {\\n pos = vec3(-95., -81., 51.); norm = vec3(-0.872, -0.318, 0.363); return;\\n } else {\\n pos = vec3(-63., 88., -94.); norm = vec3(-0.012, 0.726, -0.258); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 37.) {\\n if (id < 31.) {\\n if (id < 28.) {\\n if (id < 26.) {\\n pos = vec3(0., 94., -80.); norm = vec3(-0.012, 0.726, -0.258); return;\\n } else {\\n if (id < 27.) {\\n pos = vec3(-40., 66., -157.); norm = vec3(-0.012, 0.726, -0.258); return;\\n } else {\\n pos = vec3(-40., 66., -157.); norm = vec3(-0.069, 0.423, -0.118); return;\\n }\\n }\\n } else {\\n if (id < 29.) {\\n pos = vec3(0., 94., -80.); norm = vec3(-0.069, 0.423, -0.118); return;\\n } else {\\n if (id < 30.) {\\n pos = vec3(0., 67., -177.); norm = vec3(-0.069, 0.423, -0.118); return;\\n } else {\\n pos = vec3(-68., 46., -184.); norm = vec3(-0.707, -0.202, -0.646); return;\\n }\\n }\\n }\\n } else {\\n if (id < 34.) {\\n if (id < 32.) {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.707, -0.202, -0.646); return;\\n } else {\\n if (id < 33.) {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.707, -0.202, -0.646); return;\\n } else {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.712, -0.153, -0.681); return;\\n }\\n }\\n } else {\\n if (id < 35.) {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.712, -0.153, -0.681); return;\\n } else {\\n if (id < 36.) {\\n pos = vec3(-70., -61., -150.); norm = vec3(-0.712, -0.153, -0.681); return;\\n } else {\\n pos = vec3(-63., 88., -94.); norm = vec3(-0.034, 0.610, -0.109); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 43.) {\\n if (id < 40.) {\\n if (id < 38.) {\\n pos = vec3(-85., 100., -20.); norm = vec3(-0.034, 0.610, -0.109); return;\\n } else {\\n if (id < 39.) {\\n pos = vec3(0., 94., -80.); norm = vec3(-0.034, 0.610, -0.109); return;\\n } else {\\n pos = vec3(0., 94., -80.); norm = vec3(-0.055, 0.646, -0.143); return;\\n }\\n }\\n } else {\\n if (id < 41.) {\\n pos = vec3(-85., 100., -20.); norm = vec3(-0.055, 0.646, -0.143); return;\\n } else {\\n if (id < 42.) {\\n pos = vec3(0., 109., -12.); norm = vec3(-0.055, 0.646, -0.143); return;\\n } else {\\n pos = vec3(0., -132., 23.); norm = vec3(-0.067, -0.269, 0.062); return;\\n }\\n }\\n }\\n } else {\\n if (id < 46.) {\\n if (id < 44.) {\\n pos = vec3(0., -81., 243.); norm = vec3(-0.067, -0.269, 0.062); return;\\n } else {\\n if (id < 45.) {\\n pos = vec3(-64., -116., 23.); norm = vec3(-0.067, -0.269, 0.062); return;\\n } else {\\n pos = vec3(-63., 88., -94.); norm = vec3(-0.216, 0.773, -0.349); return;\\n }\\n }\\n } else {\\n if (id < 48.) {\\n if (id < 47.) {\\n pos = vec3(-40., 66., -157.); norm = vec3(-0.216, 0.773, -0.349); return;\\n } else {\\n pos = vec3(-68., 46., -184.); norm = vec3(-0.216, 0.773, -0.349); return;\\n }\\n } else {\\n if (id < 49.) {\\n pos = vec3(-68., 46., -184.); norm = vec3(0.061, 0.522, -0.450); return;\\n } else {\\n pos = vec3(-40., 66., -157.); norm = vec3(0.061, 0.522, -0.450); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 75.) {\\n if (id < 62.) {\\n if (id < 56.) {\\n if (id < 53.) {\\n if (id < 51.) {\\n pos = vec3(-31., -23., -259.); norm = vec3(0.061, 0.522, -0.450); return;\\n } else {\\n if (id < 52.) {\\n pos = vec3(-115., 15., 87.); norm = vec3(-0.456, -0.043, 0.240); return;\\n } else {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.456, -0.043, 0.240); return;\\n }\\n }\\n } else {\\n if (id < 54.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(-0.456, -0.043, 0.240); return;\\n } else {\\n if (id < 55.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(-0.389, 0.603, 0.696); return;\\n } else {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.389, 0.603, 0.696); return;\\n }\\n }\\n }\\n } else {\\n if (id < 59.) {\\n if (id < 57.) {\\n pos = vec3(-28., 31., 194.); norm = vec3(-0.389, 0.603, 0.696); return;\\n } else {\\n if (id < 58.) {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.344, -0.114, 0.066); return;\\n } else {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.344, -0.114, 0.066); return;\\n }\\n }\\n } else {\\n if (id < 60.) {\\n pos = vec3(-27., -56., 288.); norm = vec3(-0.344, -0.114, 0.066); return;\\n } else {\\n if (id < 61.) {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.570, 0.342, 0.208); return;\\n } else {\\n pos = vec3(-32., -3., 286.); norm = vec3(-0.570, 0.342, 0.208); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 68.) {\\n if (id < 65.) {\\n if (id < 63.) {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.570, 0.342, 0.208); return;\\n } else {\\n if (id < 64.) {\\n pos = vec3(0., 11., 276.); norm = vec3(-0.167, 0.469, 0.123); return;\\n } else {\\n pos = vec3(0., 22., 234.); norm = vec3(-0.167, 0.469, 0.123); return;\\n }\\n }\\n } else {\\n if (id < 66.) {\\n pos = vec3(-32., -3., 286.); norm = vec3(-0.167, 0.469, 0.123); return;\\n } else {\\n if (id < 67.) {\\n pos = vec3(-32., -3., 286.); norm = vec3(-0.343, 0.911, 0.227); return;\\n } else {\\n pos = vec3(0., 22., 234.); norm = vec3(-0.343, 0.911, 0.227); return;\\n }\\n }\\n }\\n } else {\\n if (id < 71.) {\\n if (id < 69.) {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.343, 0.911, 0.227); return;\\n } else {\\n if (id < 70.) {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.357, 0.925, 0.123); return;\\n } else {\\n pos = vec3(1., -8., 420.); norm = vec3(-0.357, 0.925, 0.123); return;\\n }\\n }\\n } else {\\n if (id < 73.) {\\n if (id < 72.) {\\n pos = vec3(-32., -3., 286.); norm = vec3(-0.357, 0.925, 0.123); return;\\n } else {\\n pos = vec3(-32., -3., 286.); norm = vec3(-0.091, 0.230, 0.031); return;\\n }\\n } else {\\n if (id < 74.) {\\n pos = vec3(1., -8., 420.); norm = vec3(-0.091, 0.230, 0.031); return;\\n } else {\\n pos = vec3(0., 11., 276.); norm = vec3(-0.091, 0.230, 0.031); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 88.) {\\n if (id < 81.) {\\n if (id < 78.) {\\n if (id < 76.) {\\n pos = vec3(1., -58., 357.); norm = vec3(-0.373, -0.577, 0.119); return;\\n } else {\\n if (id < 77.) {\\n pos = vec3(-30., -39., 352.); norm = vec3(-0.373, -0.577, 0.119); return;\\n } else {\\n pos = vec3(1., -65., 323.); norm = vec3(-0.373, -0.577, 0.119); return;\\n }\\n }\\n } else {\\n if (id < 79.) {\\n pos = vec3(1., -65., 323.); norm = vec3(-0.693, -0.643, -0.164); return;\\n } else {\\n if (id < 80.) {\\n pos = vec3(-30., -39., 352.); norm = vec3(-0.693, -0.643, -0.164); return;\\n } else {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.693, -0.643, -0.164); return;\\n }\\n }\\n }\\n } else {\\n if (id < 84.) {\\n if (id < 82.) {\\n pos = vec3(5., 13., 811.); norm = vec3(-0.249, -0.343, 0.114); return;\\n } else {\\n if (id < 83.) {\\n pos = vec3(-20., -1., 714.); norm = vec3(-0.249, -0.343, 0.114); return;\\n } else {\\n pos = vec3(2., -71., 551.); norm = vec3(-0.249, -0.343, 0.114); return;\\n }\\n }\\n } else {\\n if (id < 86.) {\\n if (id < 85.) {\\n pos = vec3(2., -71., 551.); norm = vec3(-0.078, -0.143, 0.051); return;\\n } else {\\n pos = vec3(-20., -1., 714.); norm = vec3(-0.078, -0.143, 0.051); return;\\n }\\n } else {\\n if (id < 87.) {\\n pos = vec3(-25., -56., 552.); norm = vec3(-0.078, -0.143, 0.051); return;\\n } else {\\n pos = vec3(-69., -74., -154.); norm = vec3(-0.145, -0.935, -0.311); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 94.) {\\n if (id < 91.) {\\n if (id < 89.) {\\n pos = vec3(-41., -72., -173.); norm = vec3(-0.145, -0.935, -0.311); return;\\n } else {\\n if (id < 90.) {\\n pos = vec3(0., -94., -126.); norm = vec3(-0.145, -0.935, -0.311); return;\\n } else {\\n pos = vec3(0., -70., -189.); norm = vec3(-0.058, -0.579, -0.221); return;\\n }\\n }\\n } else {\\n if (id < 92.) {\\n pos = vec3(0., -94., -126.); norm = vec3(-0.058, -0.579, -0.221); return;\\n } else {\\n if (id < 93.) {\\n pos = vec3(-41., -72., -173.); norm = vec3(-0.058, -0.579, -0.221); return;\\n } else {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.706, -0.276, -0.195); return;\\n }\\n }\\n }\\n } else {\\n if (id < 97.) {\\n if (id < 95.) {\\n pos = vec3(-82., -108., -138.); norm = vec3(-0.706, -0.276, -0.195); return;\\n } else {\\n if (id < 96.) {\\n pos = vec3(-137., -28., -52.); norm = vec3(-0.706, -0.276, -0.195); return;\\n } else {\\n pos = vec3(-137., -28., -52.); norm = vec3(-0.516, -0.374, 0.018); return;\\n }\\n }\\n } else {\\n if (id < 99.) {\\n if (id < 98.) {\\n pos = vec3(-82., -108., -138.); norm = vec3(-0.516, -0.374, 0.018); return;\\n } else {\\n pos = vec3(-95., -81., 51.); norm = vec3(-0.516, -0.374, 0.018); return;\\n }\\n } else {\\n if (id < 100.) {\\n pos = vec3(-82., -108., -138.); norm = vec3(-0.663, -0.622, 0.043); return;\\n } else {\\n pos = vec3(-64., -116., 23.); norm = vec3(-0.663, -0.622, 0.043); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 152.) {\\n if (id < 126.) {\\n if (id < 113.) {\\n if (id < 107.) {\\n if (id < 104.) {\\n if (id < 102.) {\\n pos = vec3(-95., -81., 51.); norm = vec3(-0.663, -0.622, 0.043); return;\\n } else {\\n if (id < 103.) {\\n pos = vec3(-95., -81., 51.); norm = vec3(-0.329, -0.527, 0.294); return;\\n } else {\\n pos = vec3(-64., -116., 23.); norm = vec3(-0.329, -0.527, 0.294); return;\\n }\\n }\\n } else {\\n if (id < 105.) {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.329, -0.527, 0.294); return;\\n } else {\\n if (id < 106.) {\\n pos = vec3(-64., -116., 23.); norm = vec3(-0.084, -0.335, -0.019); return;\\n } else {\\n pos = vec3(-64., -106., -155.); norm = vec3(-0.084, -0.335, -0.019); return;\\n }\\n }\\n }\\n } else {\\n if (id < 110.) {\\n if (id < 108.) {\\n pos = vec3(0., -132., 23.); norm = vec3(-0.084, -0.335, -0.019); return;\\n } else {\\n if (id < 109.) {\\n pos = vec3(-24., -34., 549.); norm = vec3(-0.096, 0.144, -0.050); return;\\n } else {\\n pos = vec3(-25., 20., 706.); norm = vec3(-0.096, 0.144, -0.050); return;\\n }\\n }\\n } else {\\n if (id < 111.) {\\n pos = vec3(2., -19., 542.); norm = vec3(-0.096, 0.144, -0.050); return;\\n } else {\\n if (id < 112.) {\\n pos = vec3(2., -19., 542.); norm = vec3(-0.455, 0.832, -0.273); return;\\n } else {\\n pos = vec3(-25., 20., 706.); norm = vec3(-0.455, 0.832, -0.273); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 119.) {\\n if (id < 116.) {\\n if (id < 114.) {\\n pos = vec3(3., 34., 702.); norm = vec3(-0.455, 0.832, -0.273); return;\\n } else {\\n if (id < 115.) {\\n pos = vec3(-70., -61., -150.); norm = vec3(-0.294, 0.014, -0.118); return;\\n } else {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.294, 0.014, -0.118); return;\\n }\\n }\\n } else {\\n if (id < 117.) {\\n pos = vec3(-69., -74., -154.); norm = vec3(-0.294, 0.014, -0.118); return;\\n } else {\\n if (id < 118.) {\\n pos = vec3(-69., -74., -154.); norm = vec3(-0.457, -0.045, -0.678); return;\\n } else {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.457, -0.045, -0.678); return;\\n }\\n }\\n }\\n } else {\\n if (id < 122.) {\\n if (id < 120.) {\\n pos = vec3(-41., -72., -173.); norm = vec3(-0.457, -0.045, -0.678); return;\\n } else {\\n if (id < 121.) {\\n pos = vec3(-64., -116., 23.); norm = vec3(-0.659, -0.429, 0.260); return;\\n } else {\\n pos = vec3(0., -81., 243.); norm = vec3(-0.659, -0.429, 0.260); return;\\n }\\n }\\n } else {\\n if (id < 124.) {\\n if (id < 123.) {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.659, -0.429, 0.260); return;\\n } else {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.695, -0.704, -0.026); return;\\n }\\n } else {\\n if (id < 125.) {\\n pos = vec3(0., -81., 243.); norm = vec3(-0.695, -0.704, -0.026); return;\\n } else {\\n pos = vec3(-27., -56., 288.); norm = vec3(-0.695, -0.704, -0.026); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 139.) {\\n if (id < 132.) {\\n if (id < 129.) {\\n if (id < 127.) {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.762, -0.402, 0.507); return;\\n } else {\\n if (id < 128.) {\\n pos = vec3(-27., -56., 288.); norm = vec3(-0.762, -0.402, 0.507); return;\\n } else {\\n pos = vec3(1., -65., 323.); norm = vec3(-0.762, -0.402, 0.507); return;\\n }\\n }\\n } else {\\n if (id < 130.) {\\n pos = vec3(1., -65., 323.); norm = vec3(-0.482, -0.830, 0.172); return;\\n } else {\\n if (id < 131.) {\\n pos = vec3(-27., -56., 288.); norm = vec3(-0.482, -0.830, 0.172); return;\\n } else {\\n pos = vec3(0., -81., 243.); norm = vec3(-0.482, -0.830, 0.172); return;\\n }\\n }\\n }\\n } else {\\n if (id < 135.) {\\n if (id < 133.) {\\n pos = vec3(-56., -92., -163.); norm = vec3(0.370, 0.533, -0.532); return;\\n } else {\\n if (id < 134.) {\\n pos = vec3(-69., -74., -154.); norm = vec3(0.370, 0.533, -0.532); return;\\n } else {\\n pos = vec3(0., -94., -126.); norm = vec3(0.370, 0.533, -0.532); return;\\n }\\n }\\n } else {\\n if (id < 137.) {\\n if (id < 136.) {\\n pos = vec3(-23., 87., 818.); norm = vec3(-0.351, 0.797, -0.475); return;\\n } else {\\n pos = vec3(6., 98., 815.); norm = vec3(-0.351, 0.797, -0.475); return;\\n }\\n } else {\\n if (id < 138.) {\\n pos = vec3(4., 59., 751.); norm = vec3(-0.351, 0.797, -0.475); return;\\n } else {\\n pos = vec3(1., -66., 421.); norm = vec3(-0.572, -0.665, -0.083); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 145.) {\\n if (id < 142.) {\\n if (id < 140.) {\\n pos = vec3(-25., -44., 424.); norm = vec3(-0.572, -0.665, -0.083); return;\\n } else {\\n if (id < 141.) {\\n pos = vec3(1., -58., 357.); norm = vec3(-0.572, -0.665, -0.083); return;\\n } else {\\n pos = vec3(1., -58., 357.); norm = vec3(-0.254, -0.417, -0.011); return;\\n }\\n }\\n } else {\\n if (id < 143.) {\\n pos = vec3(-25., -44., 424.); norm = vec3(-0.254, -0.417, -0.011); return;\\n } else {\\n if (id < 144.) {\\n pos = vec3(-30., -39., 352.); norm = vec3(-0.254, -0.417, -0.011); return;\\n } else {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.554, 0.755, 0.070); return;\\n }\\n }\\n }\\n } else {\\n if (id < 148.) {\\n if (id < 146.) {\\n pos = vec3(6., 91., 890.); norm = vec3(-0.554, 0.755, 0.070); return;\\n } else {\\n if (id < 147.) {\\n pos = vec3(6., 98., 815.); norm = vec3(-0.554, 0.755, 0.070); return;\\n } else {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.152, 0.288, 0.182); return;\\n }\\n }\\n } else {\\n if (id < 150.) {\\n if (id < 149.) {\\n pos = vec3(6., 43., 966.); norm = vec3(-0.152, 0.288, 0.182); return;\\n } else {\\n pos = vec3(6., 91., 890.); norm = vec3(-0.152, 0.288, 0.182); return;\\n }\\n } else {\\n if (id < 151.) {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.798, -0.001, -0.489); return;\\n } else {\\n pos = vec3(-34., 59., 836.); norm = vec3(-0.798, -0.001, -0.489); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 177.) {\\n if (id < 164.) {\\n if (id < 158.) {\\n if (id < 155.) {\\n if (id < 153.) {\\n pos = vec3(-23., 87., 818.); norm = vec3(-0.798, -0.001, -0.489); return;\\n } else {\\n if (id < 154.) {\\n pos = vec3(-23., 87., 818.); norm = vec3(-0.844, 0.134, -0.308); return;\\n } else {\\n pos = vec3(-34., 59., 836.); norm = vec3(-0.844, 0.134, -0.308); return;\\n }\\n }\\n } else {\\n if (id < 156.) {\\n pos = vec3(-35., 78., 847.); norm = vec3(-0.844, 0.134, -0.308); return;\\n } else {\\n if (id < 157.) {\\n pos = vec3(-31., 49., 861.); norm = vec3(-0.370, 0.036, 0.040); return;\\n } else {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.370, 0.036, 0.040); return;\\n }\\n }\\n }\\n } else {\\n if (id < 161.) {\\n if (id < 159.) {\\n pos = vec3(-29., 55., 874.); norm = vec3(-0.370, 0.036, 0.040); return;\\n } else {\\n if (id < 160.) {\\n pos = vec3(-29., 55., 874.); norm = vec3(-0.360, 0.031, 0.043); return;\\n } else {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.360, 0.031, 0.043); return;\\n }\\n }\\n } else {\\n if (id < 162.) {\\n pos = vec3(-27., 53., 892.); norm = vec3(-0.360, 0.031, 0.043); return;\\n } else {\\n if (id < 163.) {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.934, 0.251, 0.253); return;\\n } else {\\n pos = vec3(-27., 53., 892.); norm = vec3(-0.934, 0.251, 0.253); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 170.) {\\n if (id < 167.) {\\n if (id < 165.) {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.934, 0.251, 0.253); return;\\n } else {\\n if (id < 166.) {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.353, -0.003, 0.036); return;\\n } else {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.353, -0.003, 0.036); return;\\n }\\n }\\n } else {\\n if (id < 168.) {\\n pos = vec3(-17., -21., 966.); norm = vec3(-0.353, -0.003, 0.036); return;\\n } else {\\n if (id < 169.) {\\n pos = vec3(0., 48., 192.); norm = vec3(-0.406, 0.722, 0.447); return;\\n } else {\\n pos = vec3(-28., 31., 194.); norm = vec3(-0.406, 0.722, 0.447); return;\\n }\\n }\\n }\\n } else {\\n if (id < 173.) {\\n if (id < 171.) {\\n pos = vec3(0., 22., 234.); norm = vec3(-0.406, 0.722, 0.447); return;\\n } else {\\n if (id < 172.) {\\n pos = vec3(0., 22., 234.); norm = vec3(-0.462, 0.683, 0.477); return;\\n } else {\\n pos = vec3(-28., 31., 194.); norm = vec3(-0.462, 0.683, 0.477); return;\\n }\\n }\\n } else {\\n if (id < 175.) {\\n if (id < 174.) {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.462, 0.683, 0.477); return;\\n } else {\\n pos = vec3(-137., -28., -52.); norm = vec3(-0.284, -0.006, -0.050); return;\\n }\\n } else {\\n if (id < 176.) {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.284, -0.006, -0.050); return;\\n } else {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.284, -0.006, -0.050); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 190.) {\\n if (id < 183.) {\\n if (id < 180.) {\\n if (id < 178.) {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.407, 0.176, -0.122); return;\\n } else {\\n if (id < 179.) {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.407, 0.176, -0.122); return;\\n } else {\\n pos = vec3(-128., 42., -30.); norm = vec3(-0.407, 0.176, -0.122); return;\\n }\\n }\\n } else {\\n if (id < 181.) {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.719, 0.636, -0.088); return;\\n } else {\\n if (id < 182.) {\\n pos = vec3(4., 59., 751.); norm = vec3(-0.719, 0.636, -0.088); return;\\n } else {\\n pos = vec3(-25., 20., 706.); norm = vec3(-0.719, 0.636, -0.088); return;\\n }\\n }\\n }\\n } else {\\n if (id < 186.) {\\n if (id < 184.) {\\n pos = vec3(-25., 20., 706.); norm = vec3(-0.216, 0.378, -0.188); return;\\n } else {\\n if (id < 185.) {\\n pos = vec3(4., 59., 751.); norm = vec3(-0.216, 0.378, -0.188); return;\\n } else {\\n pos = vec3(3., 34., 702.); norm = vec3(-0.216, 0.378, -0.188); return;\\n }\\n }\\n } else {\\n if (id < 188.) {\\n if (id < 187.) {\\n pos = vec3(-25., 20., 706.); norm = vec3(-0.974, -0.224, 0.020); return;\\n } else {\\n pos = vec3(-20., -1., 714.); norm = vec3(-0.974, -0.224, 0.020); return;\\n }\\n } else {\\n if (id < 189.) {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.974, -0.224, 0.020); return;\\n } else {\\n pos = vec3(-17., -21., 966.); norm = vec3(-0.134, -0.032, 0.085); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 196.) {\\n if (id < 193.) {\\n if (id < 191.) {\\n pos = vec3(5., -95., 973.); norm = vec3(-0.134, -0.032, 0.085); return;\\n } else {\\n if (id < 192.) {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.134, -0.032, 0.085); return;\\n } else {\\n pos = vec3(6., -3., 907.); norm = vec3(-0.463, -0.362, -0.148); return;\\n }\\n }\\n } else {\\n if (id < 194.) {\\n pos = vec3(6., -19., 946.); norm = vec3(-0.463, -0.362, -0.148); return;\\n } else {\\n if (id < 195.) {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.463, -0.362, -0.148); return;\\n } else {\\n pos = vec3(6., -19., 946.); norm = vec3(-0.234, -0.096, -0.279); return;\\n }\\n }\\n }\\n } else {\\n if (id < 199.) {\\n if (id < 197.) {\\n pos = vec3(5., -95., 973.); norm = vec3(-0.234, -0.096, -0.279); return;\\n } else {\\n if (id < 198.) {\\n pos = vec3(-17., -21., 966.); norm = vec3(-0.234, -0.096, -0.279); return;\\n } else {\\n pos = vec3(-24., -34., 549.); norm = vec3(-0.474, 0.869, 0.103); return;\\n }\\n }\\n } else {\\n if (id < 201.) {\\n if (id < 200.) {\\n pos = vec3(2., -19., 542.); norm = vec3(-0.474, 0.869, 0.103); return;\\n } else {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.474, 0.869, 0.103); return;\\n }\\n } else {\\n if (id < 202.) {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.063, 0.160, 0.015); return;\\n } else {\\n pos = vec3(2., -19., 542.); norm = vec3(-0.063, 0.160, 0.015); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 304.) {\\n if (id < 253.) {\\n if (id < 228.) {\\n if (id < 215.) {\\n if (id < 209.) {\\n if (id < 206.) {\\n if (id < 204.) {\\n pos = vec3(1., -8., 420.); norm = vec3(-0.063, 0.160, 0.015); return;\\n } else {\\n if (id < 205.) {\\n pos = vec3(-32., -3., 286.); norm = vec3(-0.712, 0.264, 0.096); return;\\n } else {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.712, 0.264, 0.096); return;\\n }\\n }\\n } else {\\n if (id < 207.) {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.712, 0.264, 0.096); return;\\n } else {\\n if (id < 208.) {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.613, 0.037, 0.089); return;\\n } else {\\n pos = vec3(-30., -39., 352.); norm = vec3(-0.613, 0.037, 0.089); return;\\n }\\n }\\n }\\n } else {\\n if (id < 212.) {\\n if (id < 210.) {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.613, 0.037, 0.089); return;\\n } else {\\n if (id < 211.) {\\n pos = vec3(-30., -39., 352.); norm = vec3(-0.967, 0.239, 0.084); return;\\n } else {\\n pos = vec3(-25., -44., 424.); norm = vec3(-0.967, 0.239, 0.084); return;\\n }\\n }\\n } else {\\n if (id < 213.) {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.967, 0.239, 0.084); return;\\n } else {\\n if (id < 214.) {\\n pos = vec3(0., 99., 84.); norm = vec3(-0.092, 0.816, 0.510); return;\\n } else {\\n pos = vec3(-110., 91., 77.); norm = vec3(-0.092, 0.816, 0.510); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 221.) {\\n if (id < 218.) {\\n if (id < 216.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(-0.092, 0.816, 0.510); return;\\n } else {\\n if (id < 217.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(0.122, 0.593, 0.317); return;\\n } else {\\n pos = vec3(-110., 91., 77.); norm = vec3(0.122, 0.593, 0.317); return;\\n }\\n }\\n } else {\\n if (id < 219.) {\\n pos = vec3(-127., 79., 106.); norm = vec3(0.122, 0.593, 0.317); return;\\n } else {\\n if (id < 220.) {\\n pos = vec3(-25., -56., 552.); norm = vec3(-0.997, 0.046, 0.004); return;\\n } else {\\n pos = vec3(-24., -34., 549.); norm = vec3(-0.997, 0.046, 0.004); return;\\n }\\n }\\n }\\n } else {\\n if (id < 224.) {\\n if (id < 222.) {\\n pos = vec3(-25., -44., 424.); norm = vec3(-0.997, 0.046, 0.004); return;\\n } else {\\n if (id < 223.) {\\n pos = vec3(-25., -44., 424.); norm = vec3(-0.222, 0.056, -0.003); return;\\n } else {\\n pos = vec3(-24., -34., 549.); norm = vec3(-0.222, 0.056, -0.003); return;\\n }\\n }\\n } else {\\n if (id < 226.) {\\n if (id < 225.) {\\n pos = vec3(-18., -16., 425.); norm = vec3(-0.222, 0.056, -0.003); return;\\n } else {\\n pos = vec3(1., -66., 421.); norm = vec3(-0.166, -0.193, -0.018); return;\\n }\\n } else {\\n if (id < 227.) {\\n pos = vec3(-25., -56., 552.); norm = vec3(-0.166, -0.193, -0.018); return;\\n } else {\\n pos = vec3(-25., -44., 424.); norm = vec3(-0.166, -0.193, -0.018); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 240.) {\\n if (id < 234.) {\\n if (id < 231.) {\\n if (id < 229.) {\\n pos = vec3(6., -19., 946.); norm = vec3(-0.394, -0.605, -0.514); return;\\n } else {\\n if (id < 230.) {\\n pos = vec3(-17., -21., 966.); norm = vec3(-0.394, -0.605, -0.514); return;\\n } else {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.394, -0.605, -0.514); return;\\n }\\n }\\n } else {\\n if (id < 232.) {\\n pos = vec3(-23., 87., 818.); norm = vec3(-0.573, 0.010, -0.235); return;\\n } else {\\n if (id < 233.) {\\n pos = vec3(4., 59., 751.); norm = vec3(-0.573, 0.010, -0.235); return;\\n } else {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.573, 0.010, -0.235); return;\\n }\\n }\\n }\\n } else {\\n if (id < 237.) {\\n if (id < 235.) {\\n pos = vec3(-25., 20., 706.); norm = vec3(-0.133, -0.028, 0.009); return;\\n } else {\\n if (id < 236.) {\\n pos = vec3(-24., -34., 549.); norm = vec3(-0.133, -0.028, 0.009); return;\\n } else {\\n pos = vec3(-20., -1., 714.); norm = vec3(-0.133, -0.028, 0.009); return;\\n }\\n }\\n } else {\\n if (id < 238.) {\\n pos = vec3(-20., -1., 714.); norm = vec3(-0.997, 0.047, 0.015); return;\\n } else {\\n if (id < 239.) {\\n pos = vec3(-24., -34., 549.); norm = vec3(-0.997, 0.047, 0.015); return;\\n } else {\\n pos = vec3(-25., -56., 552.); norm = vec3(-0.997, 0.047, 0.015); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 246.) {\\n if (id < 243.) {\\n if (id < 241.) {\\n pos = vec3(-82., -108., -138.); norm = vec3(0.042, -0.724, -0.041); return;\\n } else {\\n if (id < 242.) {\\n pos = vec3(-64., -106., -155.); norm = vec3(0.042, -0.724, -0.041); return;\\n } else {\\n pos = vec3(-64., -116., 23.); norm = vec3(0.042, -0.724, -0.041); return;\\n }\\n }\\n } else {\\n if (id < 244.) {\\n pos = vec3(2., -71., 551.); norm = vec3(-0.472, -0.848, -0.029); return;\\n } else {\\n if (id < 245.) {\\n pos = vec3(-25., -56., 552.); norm = vec3(-0.472, -0.848, -0.029); return;\\n } else {\\n pos = vec3(1., -66., 421.); norm = vec3(-0.472, -0.848, -0.029); return;\\n }\\n }\\n }\\n } else {\\n if (id < 249.) {\\n if (id < 247.) {\\n pos = vec3(-115., 15., 87.); norm = vec3(-0.647, -0.296, 0.430); return;\\n } else {\\n if (id < 248.) {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.647, -0.296, 0.430); return;\\n } else {\\n pos = vec3(-95., -81., 51.); norm = vec3(-0.647, -0.296, 0.430); return;\\n }\\n }\\n } else {\\n if (id < 251.) {\\n if (id < 250.) {\\n pos = vec3(-95., -81., 51.); norm = vec3(-0.786, -0.409, 0.110); return;\\n } else {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.786, -0.409, 0.110); return;\\n }\\n } else {\\n if (id < 252.) {\\n pos = vec3(-137., -28., -52.); norm = vec3(-0.786, -0.409, 0.110); return;\\n } else {\\n pos = vec3(6., 5., 996.); norm = vec3(-0.294, 0.311, 0.394); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 278.) {\\n if (id < 265.) {\\n if (id < 259.) {\\n if (id < 256.) {\\n if (id < 254.) {\\n pos = vec3(6., 43., 966.); norm = vec3(-0.294, 0.311, 0.394); return;\\n } else {\\n if (id < 255.) {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.294, 0.311, 0.394); return;\\n } else {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.610, 0.527, 0.464); return;\\n }\\n }\\n } else {\\n if (id < 257.) {\\n pos = vec3(6., 43., 966.); norm = vec3(-0.610, 0.527, 0.464); return;\\n } else {\\n if (id < 258.) {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.610, 0.527, 0.464); return;\\n } else {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.173, -0.046, 0.206); return;\\n }\\n }\\n }\\n } else {\\n if (id < 262.) {\\n if (id < 260.) {\\n pos = vec3(5., -95., 973.); norm = vec3(-0.173, -0.046, 0.206); return;\\n } else {\\n if (id < 261.) {\\n pos = vec3(6., 5., 996.); norm = vec3(-0.173, -0.046, 0.206); return;\\n } else {\\n pos = vec3(-40., -49., -294.); norm = vec3(-0.942, -0.006, 0.247); return;\\n }\\n }\\n } else {\\n if (id < 263.) {\\n pos = vec3(-30., -54., -256.); norm = vec3(-0.942, -0.006, 0.247); return;\\n } else {\\n if (id < 264.) {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.942, -0.006, 0.247); return;\\n } else {\\n pos = vec3(-41., -72., -173.); norm = vec3(-0.019, -0.502, -0.111); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 271.) {\\n if (id < 268.) {\\n if (id < 266.) {\\n pos = vec3(-30., -54., -256.); norm = vec3(-0.019, -0.502, -0.111); return;\\n } else {\\n if (id < 267.) {\\n pos = vec3(0., -70., -189.); norm = vec3(-0.019, -0.502, -0.111); return;\\n } else {\\n pos = vec3(0., -70., -189.); norm = vec3(-0.066, -0.909, -0.187); return;\\n }\\n }\\n } else {\\n if (id < 269.) {\\n pos = vec3(-30., -54., -256.); norm = vec3(-0.066, -0.909, -0.187); return;\\n } else {\\n if (id < 270.) {\\n pos = vec3(0., -50., -286.); norm = vec3(-0.066, -0.909, -0.187); return;\\n } else {\\n pos = vec3(5., -10., 875.); norm = vec3(-0.560, -0.660, -0.237); return;\\n }\\n }\\n }\\n } else {\\n if (id < 274.) {\\n if (id < 272.) {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.560, -0.660, -0.237); return;\\n } else {\\n if (id < 273.) {\\n pos = vec3(5., 13., 811.); norm = vec3(-0.560, -0.660, -0.237); return;\\n } else {\\n pos = vec3(5., 13., 811.); norm = vec3(-0.429, -0.722, 0.215); return;\\n }\\n }\\n } else {\\n if (id < 276.) {\\n if (id < 275.) {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.429, -0.722, 0.215); return;\\n } else {\\n pos = vec3(-20., -1., 714.); norm = vec3(-0.429, -0.722, 0.215); return;\\n }\\n } else {\\n if (id < 277.) {\\n pos = vec3(0., -26., -365.); norm = vec3(-0.345, 0.818, -0.124); return;\\n } else {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.345, 0.818, -0.124); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 291.) {\\n if (id < 284.) {\\n if (id < 281.) {\\n if (id < 279.) {\\n pos = vec3(0., -11., -266.); norm = vec3(-0.345, 0.818, -0.124); return;\\n } else {\\n if (id < 280.) {\\n pos = vec3(0., -50., -286.); norm = vec3(0.001, -0.853, -0.113); return;\\n } else {\\n pos = vec3(-30., -54., -256.); norm = vec3(0.001, -0.853, -0.113); return;\\n }\\n }\\n } else {\\n if (id < 282.) {\\n pos = vec3(-40., -49., -294.); norm = vec3(0.001, -0.853, -0.113); return;\\n } else {\\n if (id < 283.) {\\n pos = vec3(-82., -108., -138.); norm = vec3(0.022, -0.086, 0.013); return;\\n } else {\\n pos = vec3(-80., -140., -357.); norm = vec3(0.022, -0.086, 0.013); return;\\n }\\n }\\n }\\n } else {\\n if (id < 287.) {\\n if (id < 285.) {\\n pos = vec3(-64., -106., -155.); norm = vec3(0.022, -0.086, 0.013); return;\\n } else {\\n if (id < 286.) {\\n pos = vec3(-64., -106., -155.); norm = vec3(0.000, -0.983, 0.165); return;\\n } else {\\n pos = vec3(-80., -140., -357.); norm = vec3(0.000, -0.983, 0.165); return;\\n }\\n }\\n } else {\\n if (id < 289.) {\\n if (id < 288.) {\\n pos = vec3(-69., -140., -357.); norm = vec3(0.000, -0.983, 0.165); return;\\n } else {\\n pos = vec3(-63., -129., -360.); norm = vec3(0.057, -0.030, 0.004); return;\\n }\\n } else {\\n if (id < 290.) {\\n pos = vec3(-56., -92., -163.); norm = vec3(0.057, -0.030, 0.004); return;\\n } else {\\n pos = vec3(-69., -140., -357.); norm = vec3(0.057, -0.030, 0.004); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 297.) {\\n if (id < 294.) {\\n if (id < 292.) {\\n pos = vec3(-69., -140., -357.); norm = vec3(0.860, -0.459, 0.056); return;\\n } else {\\n if (id < 293.) {\\n pos = vec3(-56., -92., -163.); norm = vec3(0.860, -0.459, 0.056); return;\\n } else {\\n pos = vec3(-64., -106., -155.); norm = vec3(0.860, -0.459, 0.056); return;\\n }\\n }\\n } else {\\n if (id < 295.) {\\n pos = vec3(-63., -129., -360.); norm = vec3(0.482, 0.854, -0.178); return;\\n } else {\\n if (id < 296.) {\\n pos = vec3(-74., -123., -361.); norm = vec3(0.482, 0.854, -0.178); return;\\n } else {\\n pos = vec3(-56., -92., -163.); norm = vec3(0.482, 0.854, -0.178); return;\\n }\\n }\\n }\\n } else {\\n if (id < 300.) {\\n if (id < 298.) {\\n pos = vec3(-56., -92., -163.); norm = vec3(0.077, 0.064, -0.017); return;\\n } else {\\n if (id < 299.) {\\n pos = vec3(-74., -123., -361.); norm = vec3(0.077, 0.064, -0.017); return;\\n } else {\\n pos = vec3(-69., -74., -154.); norm = vec3(0.077, 0.064, -0.017); return;\\n }\\n }\\n } else {\\n if (id < 302.) {\\n if (id < 301.) {\\n pos = vec3(-74., -123., -361.); norm = vec3(-0.550, 0.814, -0.179); return;\\n } else {\\n pos = vec3(-85., -130., -359.); norm = vec3(-0.550, 0.814, -0.179); return;\\n }\\n } else {\\n if (id < 303.) {\\n pos = vec3(-69., -74., -154.); norm = vec3(-0.550, 0.814, -0.179); return;\\n } else {\\n pos = vec3(-69., -74., -154.); norm = vec3(-0.076, 0.091, -0.019); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 355.) {\\n if (id < 329.) {\\n if (id < 316.) {\\n if (id < 310.) {\\n if (id < 307.) {\\n if (id < 305.) {\\n pos = vec3(-85., -130., -359.); norm = vec3(-0.076, 0.091, -0.019); return;\\n } else {\\n if (id < 306.) {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.076, 0.091, -0.019); return;\\n } else {\\n pos = vec3(-85., -130., -359.); norm = vec3(-0.896, -0.435, 0.067); return;\\n }\\n }\\n } else {\\n if (id < 308.) {\\n pos = vec3(-80., -140., -357.); norm = vec3(-0.896, -0.435, 0.067); return;\\n } else {\\n if (id < 309.) {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.896, -0.435, 0.067); return;\\n } else {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.091, -0.031, 0.004); return;\\n }\\n }\\n }\\n } else {\\n if (id < 313.) {\\n if (id < 311.) {\\n pos = vec3(-80., -140., -357.); norm = vec3(-0.091, -0.031, 0.004); return;\\n } else {\\n if (id < 312.) {\\n pos = vec3(-82., -108., -138.); norm = vec3(-0.091, -0.031, 0.004); return;\\n } else {\\n pos = vec3(-65., -148., -474.); norm = vec3(0.488, 0.759, -0.162); return;\\n }\\n }\\n } else {\\n if (id < 314.) {\\n pos = vec3(-75., -142., -476.); norm = vec3(0.488, 0.759, -0.162); return;\\n } else {\\n if (id < 315.) {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.488, 0.759, -0.162); return;\\n } else {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.340, 0.255, -0.108); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 322.) {\\n if (id < 319.) {\\n if (id < 317.) {\\n pos = vec3(-75., -142., -476.); norm = vec3(0.340, 0.255, -0.108); return;\\n } else {\\n if (id < 318.) {\\n pos = vec3(-74., -120., -421.); norm = vec3(0.340, 0.255, -0.108); return;\\n } else {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.231, 0.149, -0.103); return;\\n }\\n }\\n } else {\\n if (id < 320.) {\\n pos = vec3(-100., -140., -417.); norm = vec3(-0.231, 0.149, -0.103); return;\\n } else {\\n if (id < 321.) {\\n pos = vec3(-75., -142., -476.); norm = vec3(-0.231, 0.149, -0.103); return;\\n } else {\\n pos = vec3(-75., -142., -476.); norm = vec3(-0.561, 0.677, -0.261); return;\\n }\\n }\\n }\\n } else {\\n if (id < 325.) {\\n if (id < 323.) {\\n pos = vec3(-100., -140., -417.); norm = vec3(-0.561, 0.677, -0.261); return;\\n } else {\\n if (id < 324.) {\\n pos = vec3(-74., -120., -421.); norm = vec3(-0.561, 0.677, -0.261); return;\\n } else {\\n pos = vec3(-81., -163., -472.); norm = vec3(-0.097, -0.084, -0.019); return;\\n }\\n }\\n } else {\\n if (id < 327.) {\\n if (id < 326.) {\\n pos = vec3(-92., -164., -413.); norm = vec3(-0.097, -0.084, -0.019); return;\\n } else {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.097, -0.084, -0.019); return;\\n }\\n } else {\\n if (id < 328.) {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.908, -0.324, -0.129); return;\\n } else {\\n pos = vec3(-92., -164., -413.); norm = vec3(-0.908, -0.324, -0.129); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 342.) {\\n if (id < 335.) {\\n if (id < 332.) {\\n if (id < 330.) {\\n pos = vec3(-100., -140., -417.); norm = vec3(-0.908, -0.324, -0.129); return;\\n } else {\\n if (id < 331.) {\\n pos = vec3(-70., -163., -472.); norm = vec3(0.000, -0.180, 0.000); return;\\n } else {\\n pos = vec3(-66., -163., -413.); norm = vec3(0.000, -0.180, 0.000); return;\\n }\\n }\\n } else {\\n if (id < 333.) {\\n pos = vec3(-81., -163., -472.); norm = vec3(0.000, -0.180, 0.000); return;\\n } else {\\n if (id < 334.) {\\n pos = vec3(-81., -163., -472.); norm = vec3(0.037, -0.968, -0.009); return;\\n } else {\\n pos = vec3(-66., -163., -413.); norm = vec3(0.037, -0.968, -0.009); return;\\n }\\n }\\n }\\n } else {\\n if (id < 338.) {\\n if (id < 336.) {\\n pos = vec3(-92., -164., -413.); norm = vec3(0.037, -0.968, -0.009); return;\\n } else {\\n if (id < 337.) {\\n pos = vec3(-65., -148., -474.); norm = vec3(0.247, -0.086, -0.024); return;\\n } else {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.247, -0.086, -0.024); return;\\n }\\n }\\n } else {\\n if (id < 340.) {\\n if (id < 339.) {\\n pos = vec3(-70., -163., -472.); norm = vec3(0.247, -0.086, -0.024); return;\\n } else {\\n pos = vec3(-70., -163., -472.); norm = vec3(0.888, -0.374, -0.060); return;\\n }\\n } else {\\n if (id < 341.) {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.888, -0.374, -0.060); return;\\n } else {\\n pos = vec3(-66., -163., -413.); norm = vec3(0.888, -0.374, -0.060); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 348.) {\\n if (id < 345.) {\\n if (id < 343.) {\\n pos = vec3(-85., -130., -359.); norm = vec3(-0.156, -0.068, 0.052); return;\\n } else {\\n if (id < 344.) {\\n pos = vec3(-100., -140., -417.); norm = vec3(-0.156, -0.068, 0.052); return;\\n } else {\\n pos = vec3(-80., -140., -357.); norm = vec3(-0.156, -0.068, 0.052); return;\\n }\\n }\\n } else {\\n if (id < 346.) {\\n pos = vec3(-80., -140., -357.); norm = vec3(-0.889, -0.247, 0.296); return;\\n } else {\\n if (id < 347.) {\\n pos = vec3(-100., -140., -417.); norm = vec3(-0.889, -0.247, 0.296); return;\\n } else {\\n pos = vec3(-92., -164., -413.); norm = vec3(-0.889, -0.247, 0.296); return;\\n }\\n }\\n }\\n } else {\\n if (id < 351.) {\\n if (id < 349.) {\\n pos = vec3(-92., -164., -413.); norm = vec3(0.035, -0.901, 0.379); return;\\n } else {\\n if (id < 350.) {\\n pos = vec3(-66., -163., -413.); norm = vec3(0.035, -0.901, 0.379); return;\\n } else {\\n pos = vec3(-80., -140., -357.); norm = vec3(0.035, -0.901, 0.379); return;\\n }\\n }\\n } else {\\n if (id < 353.) {\\n if (id < 352.) {\\n pos = vec3(-80., -140., -357.); norm = vec3(0.000, -0.164, 0.067); return;\\n } else {\\n pos = vec3(-66., -163., -413.); norm = vec3(0.000, -0.164, 0.067); return;\\n }\\n } else {\\n if (id < 354.) {\\n pos = vec3(-69., -140., -357.); norm = vec3(0.000, -0.164, 0.067); return;\\n } else {\\n pos = vec3(-66., -163., -413.); norm = vec3(0.898, -0.334, 0.185); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 380.) {\\n if (id < 367.) {\\n if (id < 361.) {\\n if (id < 358.) {\\n if (id < 356.) {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.898, -0.334, 0.185); return;\\n } else {\\n if (id < 357.) {\\n pos = vec3(-69., -140., -357.); norm = vec3(0.898, -0.334, 0.185); return;\\n } else {\\n pos = vec3(-69., -140., -357.); norm = vec3(0.185, -0.090, 0.039); return;\\n }\\n }\\n } else {\\n if (id < 359.) {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.185, -0.090, 0.039); return;\\n } else {\\n if (id < 360.) {\\n pos = vec3(-63., -129., -360.); norm = vec3(0.185, -0.090, 0.039); return;\\n } else {\\n pos = vec3(-74., -120., -421.); norm = vec3(0.339, 0.277, 0.014); return;\\n }\\n }\\n }\\n } else {\\n if (id < 364.) {\\n if (id < 362.) {\\n pos = vec3(-74., -123., -361.); norm = vec3(0.339, 0.277, 0.014); return;\\n } else {\\n if (id < 363.) {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.339, 0.277, 0.014); return;\\n } else {\\n pos = vec3(-57., -141., -417.); norm = vec3(0.460, 0.822, -0.125); return;\\n }\\n }\\n } else {\\n if (id < 365.) {\\n pos = vec3(-74., -123., -361.); norm = vec3(0.460, 0.822, -0.125); return;\\n } else {\\n if (id < 366.) {\\n pos = vec3(-63., -129., -360.); norm = vec3(0.460, 0.822, -0.125); return;\\n } else {\\n pos = vec3(-100., -140., -417.); norm = vec3(-0.310, 0.405, 0.010); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 373.) {\\n if (id < 370.) {\\n if (id < 368.) {\\n pos = vec3(-85., -130., -359.); norm = vec3(-0.310, 0.405, 0.010); return;\\n } else {\\n if (id < 369.) {\\n pos = vec3(-74., -120., -421.); norm = vec3(-0.310, 0.405, 0.010); return;\\n } else {\\n pos = vec3(-74., -120., -421.); norm = vec3(-0.492, 0.785, 0.039); return;\\n }\\n }\\n } else {\\n if (id < 371.) {\\n pos = vec3(-85., -130., -359.); norm = vec3(-0.492, 0.785, 0.039); return;\\n } else {\\n if (id < 372.) {\\n pos = vec3(-74., -123., -361.); norm = vec3(-0.492, 0.785, 0.039); return;\\n } else {\\n pos = vec3(-67., -193., -692.); norm = vec3(0.605, 0.778, -0.166); return;\\n }\\n }\\n }\\n } else {\\n if (id < 376.) {\\n if (id < 374.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(0.605, 0.778, -0.166); return;\\n } else {\\n if (id < 375.) {\\n pos = vec3(-65., -148., -474.); norm = vec3(0.605, 0.778, -0.166); return;\\n } else {\\n pos = vec3(-65., -148., -474.); norm = vec3(0.028, 0.044, -0.009); return;\\n }\\n }\\n } else {\\n if (id < 378.) {\\n if (id < 377.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(0.028, 0.044, -0.009); return;\\n } else {\\n pos = vec3(-75., -142., -476.); norm = vec3(0.028, 0.044, -0.009); return;\\n }\\n } else {\\n if (id < 379.) {\\n pos = vec3(-83., -194., -692.); norm = vec3(-0.032, 0.035, -0.006); return;\\n } else {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.032, 0.035, -0.006); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 393.) {\\n if (id < 386.) {\\n if (id < 383.) {\\n if (id < 381.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(-0.032, 0.035, -0.006); return;\\n } else {\\n if (id < 382.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(-0.809, 0.570, -0.118); return;\\n } else {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.809, 0.570, -0.118); return;\\n }\\n }\\n } else {\\n if (id < 384.) {\\n pos = vec3(-75., -142., -476.); norm = vec3(-0.809, 0.570, -0.118); return;\\n } else {\\n if (id < 385.) {\\n pos = vec3(-83., -194., -692.); norm = vec3(-0.961, -0.266, 0.032); return;\\n } else {\\n pos = vec3(-81., -201., -690.); norm = vec3(-0.961, -0.266, 0.032); return;\\n }\\n }\\n }\\n } else {\\n if (id < 389.) {\\n if (id < 387.) {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.961, -0.266, 0.032); return;\\n } else {\\n if (id < 388.) {\\n pos = vec3(-86., -157., -473.); norm = vec3(-0.027, -0.022, 0.004); return;\\n } else {\\n pos = vec3(-81., -201., -690.); norm = vec3(-0.027, -0.022, 0.004); return;\\n }\\n }\\n } else {\\n if (id < 391.) {\\n if (id < 390.) {\\n pos = vec3(-81., -163., -472.); norm = vec3(-0.027, -0.022, 0.004); return;\\n } else {\\n pos = vec3(-81., -201., -690.); norm = vec3(0.000, -0.984, 0.172); return;\\n }\\n } else {\\n if (id < 392.) {\\n pos = vec3(-71., -201., -690.); norm = vec3(0.000, -0.984, 0.172); return;\\n } else {\\n pos = vec3(-81., -163., -472.); norm = vec3(0.000, -0.984, 0.172); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 399.) {\\n if (id < 396.) {\\n if (id < 394.) {\\n pos = vec3(-81., -163., -472.); norm = vec3(-0.000, -0.049, 0.009); return;\\n } else {\\n if (id < 395.) {\\n pos = vec3(-71., -201., -690.); norm = vec3(-0.000, -0.049, 0.009); return;\\n } else {\\n pos = vec3(-70., -163., -472.); norm = vec3(-0.000, -0.049, 0.009); return;\\n }\\n }\\n } else {\\n if (id < 397.) {\\n pos = vec3(-71., -201., -690.); norm = vec3(0.894, -0.429, 0.071); return;\\n } else {\\n if (id < 398.) {\\n pos = vec3(-67., -193., -692.); norm = vec3(0.894, -0.429, 0.071); return;\\n } else {\\n pos = vec3(-70., -163., -472.); norm = vec3(0.894, -0.429, 0.071); return;\\n }\\n }\\n }\\n } else {\\n if (id < 402.) {\\n if (id < 400.) {\\n pos = vec3(-70., -163., -472.); norm = vec3(0.068, -0.022, 0.004); return;\\n } else {\\n if (id < 401.) {\\n pos = vec3(-67., -193., -692.); norm = vec3(0.068, -0.022, 0.004); return;\\n } else {\\n pos = vec3(-65., -148., -474.); norm = vec3(0.068, -0.022, 0.004); return;\\n }\\n }\\n } else {\\n if (id < 404.) {\\n if (id < 403.) {\\n pos = vec3(-95., -179., -713.); norm = vec3(-0.651, -0.000, 0.372); return;\\n } else {\\n pos = vec3(-91., -216., -706.); norm = vec3(-0.651, -0.000, 0.372); return;\\n }\\n } else {\\n if (id < 405.) {\\n pos = vec3(-83., -194., -692.); norm = vec3(-0.651, -0.000, 0.372); return;\\n } else {\\n pos = vec3(-83., -194., -692.); norm = vec3(-0.216, -0.018, 0.152); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 609.) {\\n if (id < 507.) {\\n if (id < 456.) {\\n if (id < 431.) {\\n if (id < 418.) {\\n if (id < 412.) {\\n if (id < 409.) {\\n if (id < 407.) {\\n pos = vec3(-91., -216., -706.); norm = vec3(-0.216, -0.018, 0.152); return;\\n } else {\\n if (id < 408.) {\\n pos = vec3(-81., -201., -690.); norm = vec3(-0.216, -0.018, 0.152); return;\\n } else {\\n pos = vec3(-63., -216., -706.); norm = vec3(0.000, -0.647, 0.606); return;\\n }\\n }\\n } else {\\n if (id < 410.) {\\n pos = vec3(-71., -201., -690.); norm = vec3(0.000, -0.647, 0.606); return;\\n } else {\\n if (id < 411.) {\\n pos = vec3(-91., -216., -706.); norm = vec3(0.000, -0.647, 0.606); return;\\n } else {\\n pos = vec3(-91., -216., -706.); norm = vec3(0.000, -0.539, 0.505); return;\\n }\\n }\\n }\\n } else {\\n if (id < 415.) {\\n if (id < 413.) {\\n pos = vec3(-71., -201., -690.); norm = vec3(0.000, -0.539, 0.505); return;\\n } else {\\n if (id < 414.) {\\n pos = vec3(-81., -201., -690.); norm = vec3(0.000, -0.539, 0.505); return;\\n } else {\\n pos = vec3(-58., -180., -715.); norm = vec3(0.936, -0.045, 0.341); return;\\n }\\n }\\n } else {\\n if (id < 416.) {\\n pos = vec3(-67., -193., -692.); norm = vec3(0.936, -0.045, 0.341); return;\\n } else {\\n if (id < 417.) {\\n pos = vec3(-63., -216., -706.); norm = vec3(0.936, -0.045, 0.341); return;\\n } else {\\n pos = vec3(-63., -216., -706.); norm = vec3(0.633, -0.192, 0.497); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 424.) {\\n if (id < 421.) {\\n if (id < 419.) {\\n pos = vec3(-67., -193., -692.); norm = vec3(0.633, -0.192, 0.497); return;\\n } else {\\n if (id < 420.) {\\n pos = vec3(-71., -201., -690.); norm = vec3(0.633, -0.192, 0.497); return;\\n } else {\\n pos = vec3(-58., -180., -715.); norm = vec3(0.033, 0.716, 0.253); return;\\n }\\n }\\n } else {\\n if (id < 422.) {\\n pos = vec3(-95., -179., -713.); norm = vec3(0.033, 0.716, 0.253); return;\\n } else {\\n if (id < 423.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(0.033, 0.716, 0.253); return;\\n } else {\\n pos = vec3(-95., -179., -713.); norm = vec3(-0.434, 0.592, 0.671); return;\\n }\\n }\\n }\\n } else {\\n if (id < 427.) {\\n if (id < 425.) {\\n pos = vec3(-83., -194., -692.); norm = vec3(-0.434, 0.592, 0.671); return;\\n } else {\\n if (id < 426.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(-0.434, 0.592, 0.671); return;\\n } else {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.311, -0.301, -0.075); return;\\n }\\n }\\n } else {\\n if (id < 429.) {\\n if (id < 428.) {\\n pos = vec3(5., -10., 875.); norm = vec3(-0.311, -0.301, -0.075); return;\\n } else {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.311, -0.301, -0.075); return;\\n }\\n } else {\\n if (id < 430.) {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.561, -0.426, 0.135); return;\\n } else {\\n pos = vec3(5., -10., 875.); norm = vec3(-0.561, -0.426, 0.135); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 443.) {\\n if (id < 437.) {\\n if (id < 434.) {\\n if (id < 432.) {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.561, -0.426, 0.135); return;\\n } else {\\n if (id < 433.) {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.645, -0.471, 0.123); return;\\n } else {\\n pos = vec3(5., -10., 875.); norm = vec3(-0.645, -0.471, 0.123); return;\\n }\\n }\\n } else {\\n if (id < 435.) {\\n pos = vec3(6., -3., 907.); norm = vec3(-0.645, -0.471, 0.123); return;\\n } else {\\n if (id < 436.) {\\n pos = vec3(-137., -28., -52.); norm = vec3(-0.897, -0.312, -0.273); return;\\n } else {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.897, -0.312, -0.273); return;\\n }\\n }\\n }\\n } else {\\n if (id < 440.) {\\n if (id < 438.) {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.897, -0.312, -0.273); return;\\n } else {\\n if (id < 439.) {\\n pos = vec3(-69., -74., -154.); norm = vec3(-0.238, 0.071, -0.289); return;\\n } else {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.238, 0.071, -0.289); return;\\n }\\n }\\n } else {\\n if (id < 441.) {\\n pos = vec3(-70., -61., -150.); norm = vec3(-0.238, 0.071, -0.289); return;\\n } else {\\n if (id < 442.) {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.570, 0.131, -0.809); return;\\n } else {\\n pos = vec3(-70., -61., -150.); norm = vec3(-0.570, 0.131, -0.809); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 449.) {\\n if (id < 446.) {\\n if (id < 444.) {\\n pos = vec3(-89., -88., -141.); norm = vec3(-0.570, 0.131, -0.809); return;\\n } else {\\n if (id < 445.) {\\n pos = vec3(-68., 46., -184.); norm = vec3(-0.799, 0.428, -0.300); return;\\n } else {\\n pos = vec3(-129., -9., -100.); norm = vec3(-0.799, 0.428, -0.300); return;\\n }\\n }\\n } else {\\n if (id < 447.) {\\n pos = vec3(-128., 42., -30.); norm = vec3(-0.799, 0.428, -0.300); return;\\n } else {\\n if (id < 448.) {\\n pos = vec3(0., 109., -12.); norm = vec3(-0.082, 0.708, 0.074); return;\\n } else {\\n pos = vec3(-85., 100., -20.); norm = vec3(-0.082, 0.708, 0.074); return;\\n }\\n }\\n }\\n } else {\\n if (id < 452.) {\\n if (id < 450.) {\\n pos = vec3(0., 99., 84.); norm = vec3(-0.082, 0.708, 0.074); return;\\n } else {\\n if (id < 451.) {\\n pos = vec3(0., 99., 84.); norm = vec3(-0.062, 0.803, 0.058); return;\\n } else {\\n pos = vec3(-85., 100., -20.); norm = vec3(-0.062, 0.803, 0.058); return;\\n }\\n }\\n } else {\\n if (id < 454.) {\\n if (id < 453.) {\\n pos = vec3(-110., 91., 77.); norm = vec3(-0.062, 0.803, 0.058); return;\\n } else {\\n pos = vec3(-58., -180., -715.); norm = vec3(0.434, 0.670, 0.548); return;\\n }\\n } else {\\n if (id < 455.) {\\n pos = vec3(-75., -187., -693.); norm = vec3(0.434, 0.670, 0.548); return;\\n } else {\\n pos = vec3(-67., -193., -692.); norm = vec3(0.434, 0.670, 0.548); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 481.) {\\n if (id < 468.) {\\n if (id < 462.) {\\n if (id < 459.) {\\n if (id < 457.) {\\n pos = vec3(-56., -92., -163.); norm = vec3(0.105, -0.155, -0.167); return;\\n } else {\\n if (id < 458.) {\\n pos = vec3(0., -94., -126.); norm = vec3(0.105, -0.155, -0.167); return;\\n } else {\\n pos = vec3(-64., -106., -155.); norm = vec3(0.105, -0.155, -0.167); return;\\n }\\n }\\n } else {\\n if (id < 460.) {\\n pos = vec3(0., -132., 23.); norm = vec3(0.212, -0.701, -0.179); return;\\n } else {\\n if (id < 461.) {\\n pos = vec3(-64., -106., -155.); norm = vec3(0.212, -0.701, -0.179); return;\\n } else {\\n pos = vec3(0., -94., -126.); norm = vec3(0.212, -0.701, -0.179); return;\\n }\\n }\\n }\\n } else {\\n if (id < 465.) {\\n if (id < 463.) {\\n pos = vec3(-38., -46., -295.); norm = vec3(-0.314, 0.667, 0.020); return;\\n } else {\\n if (id < 464.) {\\n pos = vec3(0., -26., -365.); norm = vec3(-0.314, 0.667, 0.020); return;\\n } else {\\n pos = vec3(-65., -57., -351.); norm = vec3(-0.314, 0.667, 0.020); return;\\n }\\n }\\n } else {\\n if (id < 466.) {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.809, 0.488, -0.154); return;\\n } else {\\n if (id < 467.) {\\n pos = vec3(-38., -46., -295.); norm = vec3(-0.809, 0.488, -0.154); return;\\n } else {\\n pos = vec3(-40., -49., -294.); norm = vec3(-0.809, 0.488, -0.154); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 474.) {\\n if (id < 471.) {\\n if (id < 469.) {\\n pos = vec3(0., -26., -365.); norm = vec3(-0.655, 0.523, -0.206); return;\\n } else {\\n if (id < 470.) {\\n pos = vec3(-38., -46., -295.); norm = vec3(-0.655, 0.523, -0.206); return;\\n } else {\\n pos = vec3(-31., -23., -259.); norm = vec3(-0.655, 0.523, -0.206); return;\\n }\\n }\\n } else {\\n if (id < 472.) {\\n pos = vec3(-40., -49., -294.); norm = vec3(-0.758, 0.588, 0.250); return;\\n } else {\\n if (id < 473.) {\\n pos = vec3(-38., -46., -295.); norm = vec3(-0.758, 0.588, 0.250); return;\\n } else {\\n pos = vec3(-65., -57., -351.); norm = vec3(-0.758, 0.588, 0.250); return;\\n }\\n }\\n }\\n } else {\\n if (id < 477.) {\\n if (id < 475.) {\\n pos = vec3(-65., -57., -351.); norm = vec3(0.302, -0.653, -0.041); return;\\n } else {\\n if (id < 476.) {\\n pos = vec3(0., -26., -365.); norm = vec3(0.302, -0.653, -0.041); return;\\n } else {\\n pos = vec3(-40., -49., -294.); norm = vec3(0.302, -0.653, -0.041); return;\\n }\\n }\\n } else {\\n if (id < 479.) {\\n if (id < 478.) {\\n pos = vec3(-40., -49., -294.); norm = vec3(0.016, -0.452, -0.137); return;\\n } else {\\n pos = vec3(0., -26., -365.); norm = vec3(0.016, -0.452, -0.137); return;\\n }\\n } else {\\n if (id < 480.) {\\n pos = vec3(0., -50., -286.); norm = vec3(0.016, -0.452, -0.137); return;\\n } else {\\n pos = vec3(-115., 15., 87.); norm = vec3(0.041, -0.658, 0.532); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 494.) {\\n if (id < 487.) {\\n if (id < 484.) {\\n if (id < 482.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(0.041, -0.658, 0.532); return;\\n } else {\\n if (id < 483.) {\\n pos = vec3(-153., 45., 127.); norm = vec3(0.041, -0.658, 0.532); return;\\n } else {\\n pos = vec3(-153., 45., 127.); norm = vec3(-0.171, 0.477, 0.559); return;\\n }\\n }\\n } else {\\n if (id < 485.) {\\n pos = vec3(-93., 56., 136.); norm = vec3(-0.171, 0.477, 0.559); return;\\n } else {\\n if (id < 486.) {\\n pos = vec3(-127., 79., 106.); norm = vec3(-0.171, 0.477, 0.559); return;\\n } else {\\n pos = vec3(-325., 157., -8.); norm = vec3(0.111, 0.684, 0.098); return;\\n }\\n }\\n }\\n } else {\\n if (id < 490.) {\\n if (id < 488.) {\\n pos = vec3(-497., 175., 61.); norm = vec3(0.111, 0.684, 0.098); return;\\n } else {\\n if (id < 489.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(0.111, 0.684, 0.098); return;\\n } else {\\n pos = vec3(-308., 116., 139.); norm = vec3(-0.038, -0.339, -0.008); return;\\n }\\n }\\n } else {\\n if (id < 492.) {\\n if (id < 491.) {\\n pos = vec3(-557., 142., 207.); norm = vec3(-0.038, -0.339, -0.008); return;\\n } else {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.038, -0.339, -0.008); return;\\n }\\n } else {\\n if (id < 493.) {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.076, -0.488, -0.043); return;\\n } else {\\n pos = vec3(-557., 142., 207.); norm = vec3(-0.076, -0.488, -0.043); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 500.) {\\n if (id < 497.) {\\n if (id < 495.) {\\n pos = vec3(-491., 144., 68.); norm = vec3(-0.076, -0.488, -0.043); return;\\n } else {\\n if (id < 496.) {\\n pos = vec3(-306., 158., 141.); norm = vec3(0.283, 0.828, -0.002); return;\\n } else {\\n pos = vec3(-110., 91., 77.); norm = vec3(0.283, 0.828, -0.002); return;\\n }\\n }\\n } else {\\n if (id < 498.) {\\n pos = vec3(-172., 112., 14.); norm = vec3(0.283, 0.828, -0.002); return;\\n } else {\\n if (id < 499.) {\\n pos = vec3(-172., 112., 14.); norm = vec3(0.161, 0.831, 0.119); return;\\n } else {\\n pos = vec3(-110., 91., 77.); norm = vec3(0.161, 0.831, 0.119); return;\\n }\\n }\\n }\\n } else {\\n if (id < 503.) {\\n if (id < 501.) {\\n pos = vec3(-85., 100., -20.); norm = vec3(0.161, 0.831, 0.119); return;\\n } else {\\n if (id < 502.) {\\n pos = vec3(-110., 91., 77.); norm = vec3(0.063, 0.107, 0.081); return;\\n } else {\\n pos = vec3(-306., 158., 141.); norm = vec3(0.063, 0.107, 0.081); return;\\n }\\n }\\n } else {\\n if (id < 505.) {\\n if (id < 504.) {\\n pos = vec3(-127., 79., 106.); norm = vec3(0.063, 0.107, 0.081); return;\\n } else {\\n pos = vec3(-127., 79., 106.); norm = vec3(0.380, 0.522, 0.764); return;\\n }\\n } else {\\n if (id < 506.) {\\n pos = vec3(-306., 158., 141.); norm = vec3(0.380, 0.522, 0.764); return;\\n } else {\\n pos = vec3(-312., 136., 159.); norm = vec3(0.380, 0.522, 0.764); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 558.) {\\n if (id < 532.) {\\n if (id < 519.) {\\n if (id < 513.) {\\n if (id < 510.) {\\n if (id < 508.) {\\n pos = vec3(-308., 116., 139.); norm = vec3(-0.037, -0.096, 0.089); return;\\n } else {\\n if (id < 509.) {\\n pos = vec3(-153., 45., 127.); norm = vec3(-0.037, -0.096, 0.089); return;\\n } else {\\n pos = vec3(-312., 136., 159.); norm = vec3(-0.037, -0.096, 0.089); return;\\n }\\n }\\n } else {\\n if (id < 511.) {\\n pos = vec3(-312., 136., 159.); norm = vec3(0.338, 0.283, 0.877); return;\\n } else {\\n if (id < 512.) {\\n pos = vec3(-153., 45., 127.); norm = vec3(0.338, 0.283, 0.877); return;\\n } else {\\n pos = vec3(-127., 79., 106.); norm = vec3(0.338, 0.283, 0.877); return;\\n }\\n }\\n }\\n } else {\\n if (id < 516.) {\\n if (id < 514.) {\\n pos = vec3(-153., 45., 127.); norm = vec3(-0.176, -0.397, 0.073); return;\\n } else {\\n if (id < 515.) {\\n pos = vec3(-308., 116., 139.); norm = vec3(-0.176, -0.397, 0.073); return;\\n } else {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.176, -0.397, 0.073); return;\\n }\\n }\\n } else {\\n if (id < 517.) {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.417, -0.633, -0.091); return;\\n } else {\\n if (id < 518.) {\\n pos = vec3(-308., 116., 139.); norm = vec3(-0.417, -0.633, -0.091); return;\\n } else {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.417, -0.633, -0.091); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 525.) {\\n if (id < 522.) {\\n if (id < 520.) {\\n pos = vec3(-68., 46., -184.); norm = vec3(0.413, 0.867, -0.072); return;\\n } else {\\n if (id < 521.) {\\n pos = vec3(-236., 127., -173.); norm = vec3(0.413, 0.867, -0.072); return;\\n } else {\\n pos = vec3(-172., 112., 14.); norm = vec3(0.413, 0.867, -0.072); return;\\n }\\n }\\n } else {\\n if (id < 523.) {\\n pos = vec3(-172., 112., 14.); norm = vec3(0.215, 0.723, -0.016); return;\\n } else {\\n if (id < 524.) {\\n pos = vec3(-236., 127., -173.); norm = vec3(0.215, 0.723, -0.016); return;\\n } else {\\n pos = vec3(-325., 157., -8.); norm = vec3(0.215, 0.723, -0.016); return;\\n }\\n }\\n }\\n } else {\\n if (id < 528.) {\\n if (id < 526.) {\\n pos = vec3(-236., 127., -173.); norm = vec3(0.299, 0.879, 0.002); return;\\n } else {\\n if (id < 527.) {\\n pos = vec3(-401., 183., -70.); norm = vec3(0.299, 0.879, 0.002); return;\\n } else {\\n pos = vec3(-325., 157., -8.); norm = vec3(0.299, 0.879, 0.002); return;\\n }\\n }\\n } else {\\n if (id < 530.) {\\n if (id < 529.) {\\n pos = vec3(-325., 157., -8.); norm = vec3(0.176, 0.964, 0.188); return;\\n } else {\\n pos = vec3(-401., 183., -70.); norm = vec3(0.176, 0.964, 0.188); return;\\n }\\n } else {\\n if (id < 531.) {\\n pos = vec3(-497., 175., 61.); norm = vec3(0.176, 0.964, 0.188); return;\\n } else {\\n pos = vec3(-401., 183., -70.); norm = vec3(0.024, 0.077, -0.004); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 545.) {\\n if (id < 538.) {\\n if (id < 535.) {\\n if (id < 533.) {\\n pos = vec3(-236., 127., -173.); norm = vec3(0.024, 0.077, -0.004); return;\\n } else {\\n if (id < 534.) {\\n pos = vec3(-386., 177., -96.); norm = vec3(0.024, 0.077, -0.004); return;\\n } else {\\n pos = vec3(-386., 177., -96.); norm = vec3(-0.156, 0.275, -0.483); return;\\n }\\n }\\n } else {\\n if (id < 536.) {\\n pos = vec3(-236., 127., -173.); norm = vec3(-0.156, 0.275, -0.483); return;\\n } else {\\n if (id < 537.) {\\n pos = vec3(-220., 101., -193.); norm = vec3(-0.156, 0.275, -0.483); return;\\n } else {\\n pos = vec3(-85., 100., -20.); norm = vec3(0.040, 0.469, -0.064); return;\\n }\\n }\\n }\\n } else {\\n if (id < 541.) {\\n if (id < 539.) {\\n pos = vec3(-63., 88., -94.); norm = vec3(0.040, 0.469, -0.064); return;\\n } else {\\n if (id < 540.) {\\n pos = vec3(-172., 112., 14.); norm = vec3(0.040, 0.469, -0.064); return;\\n } else {\\n pos = vec3(-172., 112., 14.); norm = vec3(-0.154, 0.670, -0.304); return;\\n }\\n }\\n } else {\\n if (id < 543.) {\\n if (id < 542.) {\\n pos = vec3(-63., 88., -94.); norm = vec3(-0.154, 0.670, -0.304); return;\\n } else {\\n pos = vec3(-68., 46., -184.); norm = vec3(-0.154, 0.670, -0.304); return;\\n }\\n } else {\\n if (id < 544.) {\\n pos = vec3(-564., 150., 216.); norm = vec3(0.019, 0.088, 0.064); return;\\n } else {\\n pos = vec3(-312., 136., 159.); norm = vec3(0.019, 0.088, 0.064); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 551.) {\\n if (id < 548.) {\\n if (id < 546.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(0.019, 0.088, 0.064); return;\\n } else {\\n if (id < 547.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(0.175, 0.582, 0.770); return;\\n } else {\\n pos = vec3(-312., 136., 159.); norm = vec3(0.175, 0.582, 0.770); return;\\n }\\n }\\n } else {\\n if (id < 549.) {\\n pos = vec3(-306., 158., 141.); norm = vec3(0.175, 0.582, 0.770); return;\\n } else {\\n if (id < 550.) {\\n pos = vec3(-564., 150., 216.); norm = vec3(0.095, -0.537, 0.551); return;\\n } else {\\n pos = vec3(-557., 142., 207.); norm = vec3(0.095, -0.537, 0.551); return;\\n }\\n }\\n }\\n } else {\\n if (id < 554.) {\\n if (id < 552.) {\\n pos = vec3(-312., 136., 159.); norm = vec3(0.095, -0.537, 0.551); return;\\n } else {\\n if (id < 553.) {\\n pos = vec3(-312., 136., 159.); norm = vec3(0.013, -0.073, 0.075); return;\\n } else {\\n pos = vec3(-557., 142., 207.); norm = vec3(0.013, -0.073, 0.075); return;\\n }\\n }\\n } else {\\n if (id < 556.) {\\n if (id < 555.) {\\n pos = vec3(-308., 116., 139.); norm = vec3(0.013, -0.073, 0.075); return;\\n } else {\\n pos = vec3(-68., 46., -184.); norm = vec3(-0.260, -0.738, -0.120); return;\\n }\\n } else {\\n if (id < 557.) {\\n pos = vec3(-128., 42., -30.); norm = vec3(-0.260, -0.738, -0.120); return;\\n } else {\\n pos = vec3(-220., 101., -193.); norm = vec3(-0.260, -0.738, -0.120); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 583.) {\\n if (id < 570.) {\\n if (id < 564.) {\\n if (id < 561.) {\\n if (id < 559.) {\\n pos = vec3(-220., 101., -193.); norm = vec3(-0.087, -0.182, -0.017); return;\\n } else {\\n if (id < 560.) {\\n pos = vec3(-128., 42., -30.); norm = vec3(-0.087, -0.182, -0.017); return;\\n } else {\\n pos = vec3(-248., 112., -167.); norm = vec3(-0.087, -0.182, -0.017); return;\\n }\\n }\\n } else {\\n if (id < 562.) {\\n pos = vec3(-172., 112., 14.); norm = vec3(0.278, 0.925, -0.042); return;\\n } else {\\n if (id < 563.) {\\n pos = vec3(-325., 157., -8.); norm = vec3(0.278, 0.925, -0.042); return;\\n } else {\\n pos = vec3(-306., 158., 141.); norm = vec3(0.278, 0.925, -0.042); return;\\n }\\n }\\n }\\n } else {\\n if (id < 567.) {\\n if (id < 565.) {\\n pos = vec3(-306., 158., 141.); norm = vec3(0.025, 0.834, -0.009); return;\\n } else {\\n if (id < 566.) {\\n pos = vec3(-325., 157., -8.); norm = vec3(0.025, 0.834, -0.009); return;\\n } else {\\n pos = vec3(-557., 166., 192.); norm = vec3(0.025, 0.834, -0.009); return;\\n }\\n }\\n } else {\\n if (id < 568.) {\\n pos = vec3(-408., 152., -38.); norm = vec3(-0.493, -0.572, -0.434); return;\\n } else {\\n if (id < 569.) {\\n pos = vec3(-386., 177., -96.); norm = vec3(-0.493, -0.572, -0.434); return;\\n } else {\\n pos = vec3(-248., 112., -167.); norm = vec3(-0.493, -0.572, -0.434); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 576.) {\\n if (id < 573.) {\\n if (id < 571.) {\\n pos = vec3(-248., 112., -167.); norm = vec3(-0.026, -0.046, -0.009); return;\\n } else {\\n if (id < 572.) {\\n pos = vec3(-386., 177., -96.); norm = vec3(-0.026, -0.046, -0.009); return;\\n } else {\\n pos = vec3(-220., 101., -193.); norm = vec3(-0.026, -0.046, -0.009); return;\\n }\\n }\\n } else {\\n if (id < 574.) {\\n pos = vec3(-386., 177., -96.); norm = vec3(-0.054, 0.217, -0.081); return;\\n } else {\\n if (id < 575.) {\\n pos = vec3(-509., 144., -103.); norm = vec3(-0.054, 0.217, -0.081); return;\\n } else {\\n pos = vec3(-401., 183., -70.); norm = vec3(-0.054, 0.217, -0.081); return;\\n }\\n }\\n }\\n } else {\\n if (id < 579.) {\\n if (id < 577.) {\\n pos = vec3(-401., 183., -70.); norm = vec3(-0.099, 0.773, -0.590); return;\\n } else {\\n if (id < 578.) {\\n pos = vec3(-509., 144., -103.); norm = vec3(-0.099, 0.773, -0.590); return;\\n } else {\\n pos = vec3(-512., 152., -92.); norm = vec3(-0.099, 0.773, -0.590); return;\\n }\\n }\\n } else {\\n if (id < 581.) {\\n if (id < 580.) {\\n pos = vec3(-795., 100., 140.); norm = vec3(-0.021, 0.080, -0.006); return;\\n } else {\\n pos = vec3(-557., 166., 192.); norm = vec3(-0.021, 0.080, -0.006); return;\\n }\\n } else {\\n if (id < 582.) {\\n pos = vec3(-786., 101., 121.); norm = vec3(-0.021, 0.080, -0.006); return;\\n } else {\\n pos = vec3(-733., 113., 89.); norm = vec3(-0.187, 0.708, -0.044); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 596.) {\\n if (id < 589.) {\\n if (id < 586.) {\\n if (id < 584.) {\\n pos = vec3(-786., 101., 121.); norm = vec3(-0.187, 0.708, -0.044); return;\\n } else {\\n if (id < 585.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(-0.187, 0.708, -0.044); return;\\n } else {\\n pos = vec3(-401., 183., -70.); norm = vec3(-0.232, 0.913, -0.114); return;\\n }\\n }\\n } else {\\n if (id < 587.) {\\n pos = vec3(-512., 152., -92.); norm = vec3(-0.232, 0.913, -0.114); return;\\n } else {\\n if (id < 588.) {\\n pos = vec3(-497., 175., 61.); norm = vec3(-0.232, 0.913, -0.114); return;\\n } else {\\n pos = vec3(-497., 175., 61.); norm = vec3(-0.166, 0.972, -0.130); return;\\n }\\n }\\n }\\n } else {\\n if (id < 592.) {\\n if (id < 590.) {\\n pos = vec3(-512., 152., -92.); norm = vec3(-0.166, 0.972, -0.130); return;\\n } else {\\n if (id < 591.) {\\n pos = vec3(-598., 140., -72.); norm = vec3(-0.166, 0.972, -0.130); return;\\n } else {\\n pos = vec3(-802., 83., 164.); norm = vec3(0.054, -0.718, 0.680); return;\\n }\\n }\\n } else {\\n if (id < 594.) {\\n if (id < 593.) {\\n pos = vec3(-795., 75., 155.); norm = vec3(0.054, -0.718, 0.680); return;\\n } else {\\n pos = vec3(-564., 150., 216.); norm = vec3(0.054, -0.718, 0.680); return;\\n }\\n } else {\\n if (id < 595.) {\\n pos = vec3(-564., 150., 216.); norm = vec3(0.003, -0.040, 0.038); return;\\n } else {\\n pos = vec3(-795., 75., 155.); norm = vec3(0.003, -0.040, 0.038); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 602.) {\\n if (id < 599.) {\\n if (id < 597.) {\\n pos = vec3(-557., 142., 207.); norm = vec3(0.003, -0.040, 0.038); return;\\n } else {\\n if (id < 598.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(-0.039, 0.097, 0.053); return;\\n } else {\\n pos = vec3(-795., 100., 140.); norm = vec3(-0.039, 0.097, 0.053); return;\\n }\\n }\\n } else {\\n if (id < 600.) {\\n pos = vec3(-564., 150., 216.); norm = vec3(-0.039, 0.097, 0.053); return;\\n } else {\\n if (id < 601.) {\\n pos = vec3(-564., 150., 216.); norm = vec3(-0.332, 0.810, 0.477); return;\\n } else {\\n pos = vec3(-795., 100., 140.); norm = vec3(-0.332, 0.810, 0.477); return;\\n }\\n }\\n }\\n } else {\\n if (id < 605.) {\\n if (id < 603.) {\\n pos = vec3(-802., 83., 164.); norm = vec3(-0.332, 0.810, 0.477); return;\\n } else {\\n if (id < 604.) {\\n pos = vec3(-665., 93., -1.); norm = vec3(0.242, -0.933, 0.079); return;\\n } else {\\n pos = vec3(-653., 93., -38.); norm = vec3(0.242, -0.933, 0.079); return;\\n }\\n }\\n } else {\\n if (id < 607.) {\\n if (id < 606.) {\\n pos = vec3(-491., 144., 68.); norm = vec3(0.242, -0.933, 0.079); return;\\n } else {\\n pos = vec3(-653., 93., -38.); norm = vec3(0.244, -0.938, 0.078); return;\\n }\\n } else {\\n if (id < 608.) {\\n pos = vec3(-590., 107., -67.); norm = vec3(0.244, -0.938, 0.078); return;\\n } else {\\n pos = vec3(-491., 144., 68.); norm = vec3(0.244, -0.938, 0.078); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 711.) {\\n if (id < 660.) {\\n if (id < 634.) {\\n if (id < 621.) {\\n if (id < 615.) {\\n if (id < 612.) {\\n if (id < 610.) {\\n pos = vec3(-408., 152., -38.); norm = vec3(0.216, -0.938, 0.099); return;\\n } else {\\n if (id < 611.) {\\n pos = vec3(-491., 144., 68.); norm = vec3(0.216, -0.938, 0.099); return;\\n } else {\\n pos = vec3(-590., 107., -67.); norm = vec3(0.216, -0.938, 0.099); return;\\n }\\n }\\n } else {\\n if (id < 613.) {\\n pos = vec3(-509., 144., -103.); norm = vec3(-0.077, 0.087, -0.085); return;\\n } else {\\n if (id < 614.) {\\n pos = vec3(-590., 107., -67.); norm = vec3(-0.077, 0.087, -0.085); return;\\n } else {\\n pos = vec3(-512., 152., -92.); norm = vec3(-0.077, 0.087, -0.085); return;\\n }\\n }\\n }\\n } else {\\n if (id < 618.) {\\n if (id < 616.) {\\n pos = vec3(-512., 152., -92.); norm = vec3(-0.187, -0.184, -0.915); return;\\n } else {\\n if (id < 617.) {\\n pos = vec3(-590., 107., -67.); norm = vec3(-0.187, -0.184, -0.915); return;\\n } else {\\n pos = vec3(-598., 140., -72.); norm = vec3(-0.187, -0.184, -0.915); return;\\n }\\n }\\n } else {\\n if (id < 619.) {\\n pos = vec3(-725., 81., 25.); norm = vec3(0.016, 0.005, -0.191); return;\\n } else {\\n if (id < 620.) {\\n pos = vec3(-874., 56., 12.); norm = vec3(0.016, 0.005, -0.191); return;\\n } else {\\n pos = vec3(-733., 109., 25.); norm = vec3(0.016, 0.005, -0.191); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 627.) {\\n if (id < 624.) {\\n if (id < 622.) {\\n pos = vec3(-733., 109., 25.); norm = vec3(-0.130, 0.350, -0.022); return;\\n } else {\\n if (id < 623.) {\\n pos = vec3(-874., 56., 12.); norm = vec3(-0.130, 0.350, -0.022); return;\\n } else {\\n pos = vec3(-733., 113., 89.); norm = vec3(-0.130, 0.350, -0.022); return;\\n }\\n }\\n } else {\\n if (id < 625.) {\\n pos = vec3(-733., 113., 89.); norm = vec3(-0.075, -0.009, 0.145); return;\\n } else {\\n if (id < 626.) {\\n pos = vec3(-874., 56., 12.); norm = vec3(-0.075, -0.009, 0.145); return;\\n } else {\\n pos = vec3(-726., 86., 91.); norm = vec3(-0.075, -0.009, 0.145); return;\\n }\\n }\\n }\\n } else {\\n if (id < 630.) {\\n if (id < 628.) {\\n pos = vec3(-726., 86., 91.); norm = vec3(0.061, -0.381, 0.030); return;\\n } else {\\n if (id < 629.) {\\n pos = vec3(-874., 56., 12.); norm = vec3(0.061, -0.381, 0.030); return;\\n } else {\\n pos = vec3(-725., 81., 25.); norm = vec3(0.061, -0.381, 0.030); return;\\n }\\n }\\n } else {\\n if (id < 632.) {\\n if (id < 631.) {\\n pos = vec3(-665., 93., -1.); norm = vec3(0.067, 0.028, -0.213); return;\\n } else {\\n pos = vec3(-800., 71., -46.); norm = vec3(0.067, 0.028, -0.213); return;\\n }\\n } else {\\n if (id < 633.) {\\n pos = vec3(-675., 124., 0.); norm = vec3(0.067, 0.028, -0.213); return;\\n } else {\\n pos = vec3(-675., 124., 0.); norm = vec3(-0.134, 0.386, -0.080); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 647.) {\\n if (id < 640.) {\\n if (id < 637.) {\\n if (id < 635.) {\\n pos = vec3(-800., 71., -46.); norm = vec3(-0.134, 0.386, -0.080); return;\\n } else {\\n if (id < 636.) {\\n pos = vec3(-733., 109., 25.); norm = vec3(-0.134, 0.386, -0.080); return;\\n } else {\\n pos = vec3(-733., 109., 25.); norm = vec3(-0.183, -0.052, 0.201); return;\\n }\\n }\\n } else {\\n if (id < 638.) {\\n pos = vec3(-800., 71., -46.); norm = vec3(-0.183, -0.052, 0.201); return;\\n } else {\\n if (id < 639.) {\\n pos = vec3(-725., 81., 25.); norm = vec3(-0.183, -0.052, 0.201); return;\\n } else {\\n pos = vec3(-725., 81., 25.); norm = vec3(0.074, -0.416, -0.020); return;\\n }\\n }\\n }\\n } else {\\n if (id < 643.) {\\n if (id < 641.) {\\n pos = vec3(-800., 71., -46.); norm = vec3(0.074, -0.416, -0.020); return;\\n } else {\\n if (id < 642.) {\\n pos = vec3(-665., 93., -1.); norm = vec3(0.074, -0.416, -0.020); return;\\n } else {\\n pos = vec3(-653., 93., -38.); norm = vec3(0.179, 0.025, -0.317); return;\\n }\\n }\\n } else {\\n if (id < 645.) {\\n if (id < 644.) {\\n pos = vec3(-730., 87., -82.); norm = vec3(0.179, 0.025, -0.317); return;\\n } else {\\n pos = vec3(-661., 125., -40.); norm = vec3(0.179, 0.025, -0.317); return;\\n }\\n } else {\\n if (id < 646.) {\\n pos = vec3(-661., 125., -40.); norm = vec3(-0.166, 0.356, -0.049); return;\\n } else {\\n pos = vec3(-730., 87., -82.); norm = vec3(-0.166, 0.356, -0.049); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 653.) {\\n if (id < 650.) {\\n if (id < 648.) {\\n pos = vec3(-675., 124., 0.); norm = vec3(-0.166, 0.356, -0.049); return;\\n } else {\\n if (id < 649.) {\\n pos = vec3(-675., 124., 0.); norm = vec3(-0.228, -0.080, 0.189); return;\\n } else {\\n pos = vec3(-730., 87., -82.); norm = vec3(-0.228, -0.080, 0.189); return;\\n }\\n }\\n } else {\\n if (id < 651.) {\\n pos = vec3(-665., 93., -1.); norm = vec3(-0.228, -0.080, 0.189); return;\\n } else {\\n if (id < 652.) {\\n pos = vec3(-665., 93., -1.); norm = vec3(0.024, -0.365, 0.008); return;\\n } else {\\n pos = vec3(-730., 87., -82.); norm = vec3(0.024, -0.365, 0.008); return;\\n }\\n }\\n }\\n } else {\\n if (id < 656.) {\\n if (id < 654.) {\\n pos = vec3(-653., 93., -38.); norm = vec3(0.024, -0.365, 0.008); return;\\n } else {\\n if (id < 655.) {\\n pos = vec3(-590., 107., -67.); norm = vec3(0.183, -0.012, -0.370); return;\\n } else {\\n pos = vec3(-663., 103., -103.); norm = vec3(0.183, -0.012, -0.370); return;\\n }\\n }\\n } else {\\n if (id < 658.) {\\n if (id < 657.) {\\n pos = vec3(-598., 140., -72.); norm = vec3(0.183, -0.012, -0.370); return;\\n } else {\\n pos = vec3(-598., 140., -72.); norm = vec3(-0.305, 0.746, -0.251); return;\\n }\\n } else {\\n if (id < 659.) {\\n pos = vec3(-663., 103., -103.); norm = vec3(-0.305, 0.746, -0.251); return;\\n } else {\\n pos = vec3(-661., 125., -40.); norm = vec3(-0.305, 0.746, -0.251); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 685.) {\\n if (id < 672.) {\\n if (id < 666.) {\\n if (id < 663.) {\\n if (id < 661.) {\\n pos = vec3(-661., 125., -40.); norm = vec3(-0.464, -0.113, 0.054); return;\\n } else {\\n if (id < 662.) {\\n pos = vec3(-663., 103., -103.); norm = vec3(-0.464, -0.113, 0.054); return;\\n } else {\\n pos = vec3(-653., 93., -38.); norm = vec3(-0.464, -0.113, 0.054); return;\\n }\\n }\\n } else {\\n if (id < 664.) {\\n pos = vec3(-653., 93., -38.); norm = vec3(0.114, -0.809, -0.142); return;\\n } else {\\n if (id < 665.) {\\n pos = vec3(-663., 103., -103.); norm = vec3(0.114, -0.809, -0.142); return;\\n } else {\\n pos = vec3(-590., 107., -67.); norm = vec3(0.114, -0.809, -0.142); return;\\n }\\n }\\n }\\n } else {\\n if (id < 669.) {\\n if (id < 667.) {\\n pos = vec3(-780., 75., 123.); norm = vec3(-0.019, -0.024, -0.254); return;\\n } else {\\n if (id < 668.) {\\n pos = vec3(-882., 62., 132.); norm = vec3(-0.019, -0.024, -0.254); return;\\n } else {\\n pos = vec3(-786., 101., 121.); norm = vec3(-0.019, -0.024, -0.254); return;\\n }\\n }\\n } else {\\n if (id < 670.) {\\n pos = vec3(-786., 101., 121.); norm = vec3(-0.074, 0.174, -0.026); return;\\n } else {\\n if (id < 671.) {\\n pos = vec3(-882., 62., 132.); norm = vec3(-0.074, 0.174, -0.026); return;\\n } else {\\n pos = vec3(-795., 100., 140.); norm = vec3(-0.074, 0.174, -0.026); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 678.) {\\n if (id < 675.) {\\n if (id < 673.) {\\n pos = vec3(-795., 100., 140.); norm = vec3(-0.124, 0.254, 0.144); return;\\n } else {\\n if (id < 674.) {\\n pos = vec3(-882., 62., 132.); norm = vec3(-0.124, 0.254, 0.144); return;\\n } else {\\n pos = vec3(-802., 83., 164.); norm = vec3(-0.124, 0.254, 0.144); return;\\n }\\n }\\n } else {\\n if (id < 676.) {\\n pos = vec3(-802., 83., 164.); norm = vec3(-0.008, -0.117, 0.098); return;\\n } else {\\n if (id < 677.) {\\n pos = vec3(-882., 62., 132.); norm = vec3(-0.008, -0.117, 0.098); return;\\n } else {\\n pos = vec3(-795., 75., 155.); norm = vec3(-0.008, -0.117, 0.098); return;\\n }\\n }\\n }\\n } else {\\n if (id < 681.) {\\n if (id < 679.) {\\n pos = vec3(-795., 75., 155.); norm = vec3(0.044, -0.333, 0.021); return;\\n } else {\\n if (id < 680.) {\\n pos = vec3(-882., 62., 132.); norm = vec3(0.044, -0.333, 0.021); return;\\n } else {\\n pos = vec3(-780., 75., 123.); norm = vec3(0.044, -0.333, 0.021); return;\\n }\\n }\\n } else {\\n if (id < 683.) {\\n if (id < 682.) {\\n pos = vec3(-726., 86., 91.); norm = vec3(0.010, -0.008, -0.139); return;\\n } else {\\n pos = vec3(-922., 48., 79.); norm = vec3(0.010, -0.008, -0.139); return;\\n }\\n } else {\\n if (id < 684.) {\\n pos = vec3(-733., 113., 89.); norm = vec3(0.010, -0.008, -0.139); return;\\n } else {\\n pos = vec3(-733., 113., 89.); norm = vec3(-0.072, 0.216, -0.039); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 698.) {\\n if (id < 691.) {\\n if (id < 688.) {\\n if (id < 686.) {\\n pos = vec3(-922., 48., 79.); norm = vec3(-0.072, 0.216, -0.039); return;\\n } else {\\n if (id < 687.) {\\n pos = vec3(-786., 101., 121.); norm = vec3(-0.072, 0.216, -0.039); return;\\n } else {\\n pos = vec3(-786., 101., 121.); norm = vec3(-0.052, 0.001, 0.168); return;\\n }\\n }\\n } else {\\n if (id < 689.) {\\n pos = vec3(-922., 48., 79.); norm = vec3(-0.052, 0.001, 0.168); return;\\n } else {\\n if (id < 690.) {\\n pos = vec3(-780., 75., 123.); norm = vec3(-0.052, 0.001, 0.168); return;\\n } else {\\n pos = vec3(-780., 75., 123.); norm = vec3(0.045, -0.229, -0.003); return;\\n }\\n }\\n }\\n } else {\\n if (id < 694.) {\\n if (id < 692.) {\\n pos = vec3(-922., 48., 79.); norm = vec3(0.045, -0.229, -0.003); return;\\n } else {\\n if (id < 693.) {\\n pos = vec3(-726., 86., 91.); norm = vec3(0.045, -0.229, -0.003); return;\\n } else {\\n pos = vec3(-386., 177., -96.); norm = vec3(0.259, -0.905, -0.292); return;\\n }\\n }\\n } else {\\n if (id < 696.) {\\n if (id < 695.) {\\n pos = vec3(-408., 152., -38.); norm = vec3(0.259, -0.905, -0.292); return;\\n } else {\\n pos = vec3(-509., 144., -103.); norm = vec3(0.259, -0.905, -0.292); return;\\n }\\n } else {\\n if (id < 697.) {\\n pos = vec3(-509., 144., -103.); norm = vec3(0.118, -0.390, -0.135); return;\\n } else {\\n pos = vec3(-408., 152., -38.); norm = vec3(0.118, -0.390, -0.135); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 704.) {\\n if (id < 701.) {\\n if (id < 699.) {\\n pos = vec3(-590., 107., -67.); norm = vec3(0.118, -0.390, -0.135); return;\\n } else {\\n if (id < 700.) {\\n pos = vec3(-733., 113., 89.); norm = vec3(-0.057, 0.215, -0.013); return;\\n } else {\\n pos = vec3(-557., 166., 192.); norm = vec3(-0.057, 0.215, -0.013); return;\\n }\\n }\\n } else {\\n if (id < 702.) {\\n pos = vec3(-733., 109., 25.); norm = vec3(-0.057, 0.215, -0.013); return;\\n } else {\\n if (id < 703.) {\\n pos = vec3(-675., 124., 0.); norm = vec3(-0.243, 0.871, -0.041); return;\\n } else {\\n pos = vec3(-733., 109., 25.); norm = vec3(-0.243, 0.871, -0.041); return;\\n }\\n }\\n }\\n } else {\\n if (id < 707.) {\\n if (id < 705.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(-0.243, 0.871, -0.041); return;\\n } else {\\n if (id < 706.) {\\n pos = vec3(-557., 166., 192.); norm = vec3(-0.257, 0.959, -0.052); return;\\n } else {\\n pos = vec3(-497., 175., 61.); norm = vec3(-0.257, 0.959, -0.052); return;\\n }\\n }\\n } else {\\n if (id < 709.) {\\n if (id < 708.) {\\n pos = vec3(-675., 124., 0.); norm = vec3(-0.257, 0.959, -0.052); return;\\n } else {\\n pos = vec3(-675., 124., 0.); norm = vec3(-0.054, 0.206, -0.014); return;\\n }\\n } else {\\n if (id < 710.) {\\n pos = vec3(-497., 175., 61.); norm = vec3(-0.054, 0.206, -0.014); return;\\n } else {\\n pos = vec3(-661., 125., -40.); norm = vec3(-0.054, 0.206, -0.014); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 762.) {\\n if (id < 736.) {\\n if (id < 723.) {\\n if (id < 717.) {\\n if (id < 714.) {\\n if (id < 712.) {\\n pos = vec3(-497., 175., 61.); norm = vec3(-0.253, 0.942, -0.056); return;\\n } else {\\n if (id < 713.) {\\n pos = vec3(-598., 140., -72.); norm = vec3(-0.253, 0.942, -0.056); return;\\n } else {\\n pos = vec3(-661., 125., -40.); norm = vec3(-0.253, 0.942, -0.056); return;\\n }\\n }\\n } else {\\n if (id < 715.) {\\n pos = vec3(-68., 46., -184.); norm = vec3(0.226, 0.539, -0.520); return;\\n } else {\\n if (id < 716.) {\\n pos = vec3(-220., 101., -193.); norm = vec3(0.226, 0.539, -0.520); return;\\n } else {\\n pos = vec3(-236., 127., -173.); norm = vec3(0.226, 0.539, -0.520); return;\\n }\\n }\\n }\\n } else {\\n if (id < 720.) {\\n if (id < 718.) {\\n pos = vec3(-557., 142., 207.); norm = vec3(0.155, -0.603, 0.065); return;\\n } else {\\n if (id < 719.) {\\n pos = vec3(-726., 86., 91.); norm = vec3(0.155, -0.603, 0.065); return;\\n } else {\\n pos = vec3(-491., 144., 68.); norm = vec3(0.155, -0.603, 0.065); return;\\n }\\n }\\n } else {\\n if (id < 721.) {\\n pos = vec3(-726., 86., 91.); norm = vec3(0.242, -0.951, 0.076); return;\\n } else {\\n if (id < 722.) {\\n pos = vec3(-725., 81., 25.); norm = vec3(0.242, -0.951, 0.076); return;\\n } else {\\n pos = vec3(-491., 144., 68.); norm = vec3(0.242, -0.951, 0.076); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 729.) {\\n if (id < 726.) {\\n if (id < 724.) {\\n pos = vec3(-725., 81., 25.); norm = vec3(0.167, -0.672, 0.075); return;\\n } else {\\n if (id < 725.) {\\n pos = vec3(-665., 93., -1.); norm = vec3(0.167, -0.672, 0.075); return;\\n } else {\\n pos = vec3(-491., 144., 68.); norm = vec3(0.167, -0.672, 0.075); return;\\n }\\n }\\n } else {\\n if (id < 727.) {\\n pos = vec3(-795., 75., 155.); norm = vec3(0.245, -0.960, 0.115); return;\\n } else {\\n if (id < 728.) {\\n pos = vec3(-780., 75., 123.); norm = vec3(0.245, -0.960, 0.115); return;\\n } else {\\n pos = vec3(-557., 142., 207.); norm = vec3(0.245, -0.960, 0.115); return;\\n }\\n }\\n }\\n } else {\\n if (id < 732.) {\\n if (id < 730.) {\\n pos = vec3(-557., 142., 207.); norm = vec3(0.194, -0.740, 0.074); return;\\n } else {\\n if (id < 731.) {\\n pos = vec3(-780., 75., 123.); norm = vec3(0.194, -0.740, 0.074); return;\\n } else {\\n pos = vec3(-726., 86., 91.); norm = vec3(0.194, -0.740, 0.074); return;\\n }\\n }\\n } else {\\n if (id < 734.) {\\n if (id < 733.) {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.504, -0.849, 0.158); return;\\n } else {\\n pos = vec3(-115., 15., 87.); norm = vec3(-0.504, -0.849, 0.158); return;\\n }\\n } else {\\n if (id < 735.) {\\n pos = vec3(-153., 45., 127.); norm = vec3(-0.504, -0.849, 0.158); return;\\n } else {\\n pos = vec3(-248., 112., -167.); norm = vec3(-0.383, -0.758, -0.052); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 749.) {\\n if (id < 742.) {\\n if (id < 739.) {\\n if (id < 737.) {\\n pos = vec3(-128., 42., -30.); norm = vec3(-0.383, -0.758, -0.052); return;\\n } else {\\n if (id < 738.) {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.383, -0.758, -0.052); return;\\n } else {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.433, -0.721, -0.303); return;\\n }\\n }\\n } else {\\n if (id < 740.) {\\n pos = vec3(-128., 42., -30.); norm = vec3(-0.433, -0.721, -0.303); return;\\n } else {\\n if (id < 741.) {\\n pos = vec3(-154., 29., 38.); norm = vec3(-0.433, -0.721, -0.303); return;\\n } else {\\n pos = vec3(-248., 112., -167.); norm = vec3(-0.258, -0.950, -0.025); return;\\n }\\n }\\n }\\n } else {\\n if (id < 745.) {\\n if (id < 743.) {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.258, -0.950, -0.025); return;\\n } else {\\n if (id < 744.) {\\n pos = vec3(-408., 152., -38.); norm = vec3(-0.258, -0.950, -0.025); return;\\n } else {\\n pos = vec3(-408., 152., -38.); norm = vec3(-0.110, -0.565, -0.128); return;\\n }\\n }\\n } else {\\n if (id < 747.) {\\n if (id < 746.) {\\n pos = vec3(-280., 116., 11.); norm = vec3(-0.110, -0.565, -0.128); return;\\n } else {\\n pos = vec3(-491., 144., 68.); norm = vec3(-0.110, -0.565, -0.128); return;\\n }\\n } else {\\n if (id < 748.) {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.295, 0.825, 0.172); return;\\n } else {\\n pos = vec3(6., 98., 815.); norm = vec3(-0.295, 0.825, 0.172); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 755.) {\\n if (id < 752.) {\\n if (id < 750.) {\\n pos = vec3(-23., 87., 818.); norm = vec3(-0.295, 0.825, 0.172); return;\\n } else {\\n if (id < 751.) {\\n pos = vec3(0., 99., 84.); norm = vec3(0.153, 0.773, 0.365); return;\\n } else {\\n pos = vec3(0., 48., 192.); norm = vec3(0.153, 0.773, 0.365); return;\\n }\\n }\\n } else {\\n if (id < 753.) {\\n pos = vec3(93., 56., 136.); norm = vec3(0.153, 0.773, 0.365); return;\\n } else {\\n if (id < 754.) {\\n pos = vec3(93., 56., 136.); norm = vec3(0.262, 0.491, 0.505); return;\\n } else {\\n pos = vec3(0., 48., 192.); norm = vec3(0.262, 0.491, 0.505); return;\\n }\\n }\\n }\\n } else {\\n if (id < 758.) {\\n if (id < 756.) {\\n pos = vec3(28., 31., 194.); norm = vec3(0.262, 0.491, 0.505); return;\\n } else {\\n if (id < 757.) {\\n pos = vec3(67., 45., -184.); norm = vec3(0.836, -0.100, -0.310); return;\\n } else {\\n pos = vec3(66., -44., -158.); norm = vec3(0.836, -0.100, -0.310); return;\\n }\\n }\\n } else {\\n if (id < 760.) {\\n if (id < 759.) {\\n pos = vec3(31., -23., -259.); norm = vec3(0.836, -0.100, -0.310); return;\\n } else {\\n pos = vec3(31., -23., -259.); norm = vec3(0.269, -0.018, -0.097); return;\\n }\\n } else {\\n if (id < 761.) {\\n pos = vec3(66., -44., -158.); norm = vec3(0.269, -0.018, -0.097); return;\\n } else {\\n pos = vec3(30., -54., -256.); norm = vec3(0.269, -0.018, -0.097); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 787.) {\\n if (id < 774.) {\\n if (id < 768.) {\\n if (id < 765.) {\\n if (id < 763.) {\\n pos = vec3(0., -11., -266.); norm = vec3(0.109, 0.186, -0.163); return;\\n } else {\\n if (id < 764.) {\\n pos = vec3(0., 67., -177.); norm = vec3(0.109, 0.186, -0.163); return;\\n } else {\\n pos = vec3(31., -23., -259.); norm = vec3(0.109, 0.186, -0.163); return;\\n }\\n }\\n } else {\\n if (id < 766.) {\\n pos = vec3(31., -23., -259.); norm = vec3(0.335, 0.694, -0.635); return;\\n } else {\\n if (id < 767.) {\\n pos = vec3(0., 67., -177.); norm = vec3(0.335, 0.694, -0.635); return;\\n } else {\\n pos = vec3(40., 66., -157.); norm = vec3(0.335, 0.694, -0.635); return;\\n }\\n }\\n }\\n } else {\\n if (id < 771.) {\\n if (id < 769.) {\\n pos = vec3(57., 10., 196.); norm = vec3(0.833, -0.048, 0.441); return;\\n } else {\\n if (id < 770.) {\\n pos = vec3(55., -25., 196.); norm = vec3(0.833, -0.048, 0.441); return;\\n } else {\\n pos = vec3(115., 15., 87.); norm = vec3(0.833, -0.048, 0.441); return;\\n }\\n }\\n } else {\\n if (id < 772.) {\\n pos = vec3(115., 15., 87.); norm = vec3(0.484, -0.171, 0.204); return;\\n } else {\\n if (id < 773.) {\\n pos = vec3(55., -25., 196.); norm = vec3(0.484, -0.171, 0.204); return;\\n } else {\\n pos = vec3(95., -57., 74.); norm = vec3(0.484, -0.171, 0.204); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 780.) {\\n if (id < 777.) {\\n if (id < 775.) {\\n pos = vec3(63., 88., -94.); norm = vec3(0.011, 0.667, -0.237); return;\\n } else {\\n if (id < 776.) {\\n pos = vec3(40., 66., -157.); norm = vec3(0.011, 0.667, -0.237); return;\\n } else {\\n pos = vec3(0., 94., -80.); norm = vec3(0.011, 0.667, -0.237); return;\\n }\\n }\\n } else {\\n if (id < 778.) {\\n pos = vec3(0., 94., -80.); norm = vec3(0.156, 0.951, -0.265); return;\\n } else {\\n if (id < 779.) {\\n pos = vec3(40., 66., -157.); norm = vec3(0.156, 0.951, -0.265); return;\\n } else {\\n pos = vec3(0., 67., -177.); norm = vec3(0.156, 0.951, -0.265); return;\\n }\\n }\\n }\\n } else {\\n if (id < 783.) {\\n if (id < 781.) {\\n pos = vec3(70., -61., -150.); norm = vec3(0.712, -0.153, -0.681); return;\\n } else {\\n if (id < 782.) {\\n pos = vec3(66., -44., -158.); norm = vec3(0.712, -0.153, -0.681); return;\\n } else {\\n pos = vec3(129., -9., -100.); norm = vec3(0.712, -0.153, -0.681); return;\\n }\\n }\\n } else {\\n if (id < 785.) {\\n if (id < 784.) {\\n pos = vec3(129., -9., -100.); norm = vec3(0.708, -0.198, -0.650); return;\\n } else {\\n pos = vec3(66., -44., -158.); norm = vec3(0.708, -0.198, -0.650); return;\\n }\\n } else {\\n if (id < 786.) {\\n pos = vec3(67., 45., -184.); norm = vec3(0.708, -0.198, -0.650); return;\\n } else {\\n pos = vec3(0., 109., -12.); norm = vec3(0.055, 0.646, -0.143); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 800.) {\\n if (id < 793.) {\\n if (id < 790.) {\\n if (id < 788.) {\\n pos = vec3(85., 100., -20.); norm = vec3(0.055, 0.646, -0.143); return;\\n } else {\\n if (id < 789.) {\\n pos = vec3(0., 94., -80.); norm = vec3(0.055, 0.646, -0.143); return;\\n } else {\\n pos = vec3(0., 94., -80.); norm = vec3(0.034, 0.610, -0.109); return;\\n }\\n }\\n } else {\\n if (id < 791.) {\\n pos = vec3(85., 100., -20.); norm = vec3(0.034, 0.610, -0.109); return;\\n } else {\\n if (id < 792.) {\\n pos = vec3(63., 88., -94.); norm = vec3(0.034, 0.610, -0.109); return;\\n } else {\\n pos = vec3(41., -73., -173.); norm = vec3(0.299, -0.212, -0.088); return;\\n }\\n }\\n }\\n } else {\\n if (id < 796.) {\\n if (id < 794.) {\\n pos = vec3(30., -54., -256.); norm = vec3(0.299, -0.212, -0.088); return;\\n } else {\\n if (id < 795.) {\\n pos = vec3(66., -44., -158.); norm = vec3(0.299, -0.212, -0.088); return;\\n } else {\\n pos = vec3(0., -132., 23.); norm = vec3(0.230, -0.921, 0.213); return;\\n }\\n }\\n } else {\\n if (id < 798.) {\\n if (id < 797.) {\\n pos = vec3(64., -116., 23.); norm = vec3(0.230, -0.921, 0.213); return;\\n } else {\\n pos = vec3(0., -81., 243.); norm = vec3(0.230, -0.921, 0.213); return;\\n }\\n } else {\\n if (id < 799.) {\\n pos = vec3(31., -23., -259.); norm = vec3(-0.044, 0.507, -0.438); return;\\n } else {\\n pos = vec3(40., 66., -157.); norm = vec3(-0.044, 0.507, -0.438); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 806.) {\\n if (id < 803.) {\\n if (id < 801.) {\\n pos = vec3(67., 45., -184.); norm = vec3(-0.044, 0.507, -0.438); return;\\n } else {\\n if (id < 802.) {\\n pos = vec3(67., 45., -184.); norm = vec3(0.237, 0.755, -0.350); return;\\n } else {\\n pos = vec3(40., 66., -157.); norm = vec3(0.237, 0.755, -0.350); return;\\n }\\n }\\n } else {\\n if (id < 804.) {\\n pos = vec3(63., 88., -94.); norm = vec3(0.237, 0.755, -0.350); return;\\n } else {\\n if (id < 805.) {\\n pos = vec3(28., 31., 194.); norm = vec3(0.389, 0.603, 0.696); return;\\n } else {\\n pos = vec3(57., 10., 196.); norm = vec3(0.389, 0.603, 0.696); return;\\n }\\n }\\n }\\n } else {\\n if (id < 809.) {\\n if (id < 807.) {\\n pos = vec3(93., 56., 136.); norm = vec3(0.389, 0.603, 0.696); return;\\n } else {\\n if (id < 808.) {\\n pos = vec3(93., 56., 136.); norm = vec3(0.456, -0.043, 0.240); return;\\n } else {\\n pos = vec3(57., 10., 196.); norm = vec3(0.456, -0.043, 0.240); return;\\n }\\n }\\n } else {\\n if (id < 811.) {\\n if (id < 810.) {\\n pos = vec3(115., 15., 87.); norm = vec3(0.456, -0.043, 0.240); return;\\n } else {\\n pos = vec3(28., -56., 288.); norm = vec3(0.345, -0.113, 0.063); return;\\n }\\n } else {\\n if (id < 812.) {\\n pos = vec3(55., -25., 196.); norm = vec3(0.345, -0.113, 0.063); return;\\n } else {\\n pos = vec3(37., -20., 303.); norm = vec3(0.345, -0.113, 0.063); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1219.) {\\n if (id < 1016.) {\\n if (id < 914.) {\\n if (id < 863.) {\\n if (id < 838.) {\\n if (id < 825.) {\\n if (id < 819.) {\\n if (id < 816.) {\\n if (id < 814.) {\\n pos = vec3(57., 10., 196.); norm = vec3(0.576, 0.291, 0.189); return;\\n } else {\\n if (id < 815.) {\\n pos = vec3(34., -3., 286.); norm = vec3(0.576, 0.291, 0.189); return;\\n } else {\\n pos = vec3(37., -20., 303.); norm = vec3(0.576, 0.291, 0.189); return;\\n }\\n }\\n } else {\\n if (id < 817.) {\\n pos = vec3(57., 10., 196.); norm = vec3(0.338, 0.914, 0.218); return;\\n } else {\\n if (id < 818.) {\\n pos = vec3(0., 22., 234.); norm = vec3(0.338, 0.914, 0.218); return;\\n } else {\\n pos = vec3(34., -3., 286.); norm = vec3(0.338, 0.914, 0.218); return;\\n }\\n }\\n }\\n } else {\\n if (id < 822.) {\\n if (id < 820.) {\\n pos = vec3(34., -3., 286.); norm = vec3(0.164, 0.491, 0.129); return;\\n } else {\\n if (id < 821.) {\\n pos = vec3(0., 22., 234.); norm = vec3(0.164, 0.491, 0.129); return;\\n } else {\\n pos = vec3(0., 11., 276.); norm = vec3(0.164, 0.491, 0.129); return;\\n }\\n }\\n } else {\\n if (id < 823.) {\\n pos = vec3(0., 11., 276.); norm = vec3(0.091, 0.244, 0.032); return;\\n } else {\\n if (id < 824.) {\\n pos = vec3(1., -8., 420.); norm = vec3(0.091, 0.244, 0.032); return;\\n } else {\\n pos = vec3(34., -3., 286.); norm = vec3(0.091, 0.244, 0.032); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 831.) {\\n if (id < 828.) {\\n if (id < 826.) {\\n pos = vec3(34., -3., 286.); norm = vec3(0.329, 0.937, 0.116); return;\\n } else {\\n if (id < 827.) {\\n pos = vec3(1., -8., 420.); norm = vec3(0.329, 0.937, 0.116); return;\\n } else {\\n pos = vec3(22., -16., 425.); norm = vec3(0.329, 0.937, 0.116); return;\\n }\\n }\\n } else {\\n if (id < 829.) {\\n pos = vec3(37., -20., 303.); norm = vec3(0.687, -0.634, -0.190); return;\\n } else {\\n if (id < 830.) {\\n pos = vec3(33., -39., 352.); norm = vec3(0.687, -0.634, -0.190); return;\\n } else {\\n pos = vec3(1., -65., 323.); norm = vec3(0.687, -0.634, -0.190); return;\\n }\\n }\\n }\\n } else {\\n if (id < 834.) {\\n if (id < 832.) {\\n pos = vec3(1., -65., 323.); norm = vec3(0.360, -0.575, 0.118); return;\\n } else {\\n if (id < 833.) {\\n pos = vec3(33., -39., 352.); norm = vec3(0.360, -0.575, 0.118); return;\\n } else {\\n pos = vec3(1., -58., 357.); norm = vec3(0.360, -0.575, 0.118); return;\\n }\\n }\\n } else {\\n if (id < 836.) {\\n if (id < 835.) {\\n pos = vec3(29., -56., 552.); norm = vec3(0.077, -0.143, 0.049); return;\\n } else {\\n pos = vec3(28., -1., 714.); norm = vec3(0.077, -0.143, 0.049); return;\\n }\\n } else {\\n if (id < 837.) {\\n pos = vec3(2., -71., 551.); norm = vec3(0.077, -0.143, 0.049); return;\\n } else {\\n pos = vec3(2., -71., 551.); norm = vec3(0.250, -0.347, 0.109); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 850.) {\\n if (id < 844.) {\\n if (id < 841.) {\\n if (id < 839.) {\\n pos = vec3(28., -1., 714.); norm = vec3(0.250, -0.347, 0.109); return;\\n } else {\\n if (id < 840.) {\\n pos = vec3(5., 13., 811.); norm = vec3(0.250, -0.347, 0.109); return;\\n } else {\\n pos = vec3(67., -74., -154.); norm = vec3(0.071, -0.404, -0.118); return;\\n }\\n }\\n } else {\\n if (id < 842.) {\\n pos = vec3(0., -94., -126.); norm = vec3(0.071, -0.404, -0.118); return;\\n } else {\\n if (id < 843.) {\\n pos = vec3(41., -73., -173.); norm = vec3(0.071, -0.404, -0.118); return;\\n } else {\\n pos = vec3(0., -70., -189.); norm = vec3(0.067, -0.890, -0.339); return;\\n }\\n }\\n }\\n } else {\\n if (id < 847.) {\\n if (id < 845.) {\\n pos = vec3(41., -73., -173.); norm = vec3(0.067, -0.890, -0.339); return;\\n } else {\\n if (id < 846.) {\\n pos = vec3(0., -94., -126.); norm = vec3(0.067, -0.890, -0.339); return;\\n } else {\\n pos = vec3(87., -88., -141.); norm = vec3(0.126, -0.056, -0.034); return;\\n }\\n }\\n } else {\\n if (id < 848.) {\\n pos = vec3(137., -28., -52.); norm = vec3(0.126, -0.056, -0.034); return;\\n } else {\\n if (id < 849.) {\\n pos = vec3(79., -108., -138.); norm = vec3(0.126, -0.056, -0.034); return;\\n } else {\\n pos = vec3(79., -108., -138.); norm = vec3(0.706, -0.613, 0.094); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 856.) {\\n if (id < 853.) {\\n if (id < 851.) {\\n pos = vec3(137., -28., -52.); norm = vec3(0.706, -0.613, 0.094); return;\\n } else {\\n if (id < 852.) {\\n pos = vec3(95., -57., 74.); norm = vec3(0.706, -0.613, 0.094); return;\\n } else {\\n pos = vec3(55., -25., 196.); norm = vec3(0.339, -0.355, 0.204); return;\\n }\\n }\\n } else {\\n if (id < 854.) {\\n pos = vec3(64., -116., 23.); norm = vec3(0.339, -0.355, 0.204); return;\\n } else {\\n if (id < 855.) {\\n pos = vec3(95., -57., 74.); norm = vec3(0.339, -0.355, 0.204); return;\\n } else {\\n pos = vec3(95., -57., 74.); norm = vec3(0.729, -0.424, 0.047); return;\\n }\\n }\\n }\\n } else {\\n if (id < 859.) {\\n if (id < 857.) {\\n pos = vec3(64., -116., 23.); norm = vec3(0.729, -0.424, 0.047); return;\\n } else {\\n if (id < 858.) {\\n pos = vec3(79., -108., -138.); norm = vec3(0.729, -0.424, 0.047); return;\\n } else {\\n pos = vec3(64., -116., 23.); norm = vec3(0.227, -0.908, -0.054); return;\\n }\\n }\\n } else {\\n if (id < 861.) {\\n if (id < 860.) {\\n pos = vec3(0., -132., 23.); norm = vec3(0.227, -0.908, -0.054); return;\\n } else {\\n pos = vec3(62., -106., -155.); norm = vec3(0.227, -0.908, -0.054); return;\\n }\\n } else {\\n if (id < 862.) {\\n pos = vec3(28., -34., 549.); norm = vec3(0.517, 0.766, -0.280); return;\\n } else {\\n pos = vec3(2., -19., 542.); norm = vec3(0.517, 0.766, -0.280); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 888.) {\\n if (id < 875.) {\\n if (id < 869.) {\\n if (id < 866.) {\\n if (id < 864.) {\\n pos = vec3(33., 20., 706.); norm = vec3(0.517, 0.766, -0.280); return;\\n } else {\\n if (id < 865.) {\\n pos = vec3(33., 20., 706.); norm = vec3(0.085, 0.166, -0.056); return;\\n } else {\\n pos = vec3(2., -19., 542.); norm = vec3(0.085, 0.166, -0.056); return;\\n }\\n }\\n } else {\\n if (id < 867.) {\\n pos = vec3(3., 34., 702.); norm = vec3(0.085, 0.166, -0.056); return;\\n } else {\\n if (id < 868.) {\\n pos = vec3(70., -61., -150.); norm = vec3(0.408, -0.019, -0.244); return;\\n } else {\\n pos = vec3(67., -74., -154.); norm = vec3(0.408, -0.019, -0.244); return;\\n }\\n }\\n }\\n } else {\\n if (id < 872.) {\\n if (id < 870.) {\\n pos = vec3(66., -44., -158.); norm = vec3(0.408, -0.019, -0.244); return;\\n } else {\\n if (id < 871.) {\\n pos = vec3(66., -44., -158.); norm = vec3(0.580, -0.087, -0.798); return;\\n } else {\\n pos = vec3(67., -74., -154.); norm = vec3(0.580, -0.087, -0.798); return;\\n }\\n }\\n } else {\\n if (id < 873.) {\\n pos = vec3(41., -73., -173.); norm = vec3(0.580, -0.087, -0.798); return;\\n } else {\\n if (id < 874.) {\\n pos = vec3(28., -56., 288.); norm = vec3(0.689, -0.707, -0.036); return;\\n } else {\\n pos = vec3(0., -81., 243.); norm = vec3(0.689, -0.707, -0.036); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 881.) {\\n if (id < 878.) {\\n if (id < 876.) {\\n pos = vec3(55., -25., 196.); norm = vec3(0.689, -0.707, -0.036); return;\\n } else {\\n if (id < 877.) {\\n pos = vec3(55., -25., 196.); norm = vec3(0.659, -0.429, 0.260); return;\\n } else {\\n pos = vec3(0., -81., 243.); norm = vec3(0.659, -0.429, 0.260); return;\\n }\\n }\\n } else {\\n if (id < 879.) {\\n pos = vec3(64., -116., 23.); norm = vec3(0.659, -0.429, 0.260); return;\\n } else {\\n if (id < 880.) {\\n pos = vec3(0., -81., 243.); norm = vec3(0.484, -0.830, 0.160); return;\\n } else {\\n pos = vec3(28., -56., 288.); norm = vec3(0.484, -0.830, 0.160); return;\\n }\\n }\\n }\\n } else {\\n if (id < 884.) {\\n if (id < 882.) {\\n pos = vec3(1., -65., 323.); norm = vec3(0.484, -0.830, 0.160); return;\\n } else {\\n if (id < 883.) {\\n pos = vec3(1., -65., 323.); norm = vec3(0.773, -0.399, 0.493); return;\\n } else {\\n pos = vec3(28., -56., 288.); norm = vec3(0.773, -0.399, 0.493); return;\\n }\\n }\\n } else {\\n if (id < 886.) {\\n if (id < 885.) {\\n pos = vec3(37., -20., 303.); norm = vec3(0.773, -0.399, 0.493); return;\\n } else {\\n pos = vec3(53., -92., -163.); norm = vec3(-0.140, 0.204, -0.190); return;\\n }\\n } else {\\n if (id < 887.) {\\n pos = vec3(0., -94., -126.); norm = vec3(-0.140, 0.204, -0.190); return;\\n } else {\\n pos = vec3(67., -74., -154.); norm = vec3(-0.140, 0.204, -0.190); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 901.) {\\n if (id < 894.) {\\n if (id < 891.) {\\n if (id < 889.) {\\n pos = vec3(34., 86., 818.); norm = vec3(0.151, 0.305, -0.190); return;\\n } else {\\n if (id < 890.) {\\n pos = vec3(4., 59., 751.); norm = vec3(0.151, 0.305, -0.190); return;\\n } else {\\n pos = vec3(6., 98., 815.); norm = vec3(0.151, 0.305, -0.190); return;\\n }\\n }\\n } else {\\n if (id < 892.) {\\n pos = vec3(1., -66., 421.); norm = vec3(0.302, -0.364, -0.046); return;\\n } else {\\n if (id < 893.) {\\n pos = vec3(1., -58., 357.); norm = vec3(0.302, -0.364, -0.046); return;\\n } else {\\n pos = vec3(28., -44., 424.); norm = vec3(0.302, -0.364, -0.046); return;\\n }\\n }\\n }\\n } else {\\n if (id < 897.) {\\n if (id < 895.) {\\n pos = vec3(28., -44., 424.); norm = vec3(0.486, -0.825, -0.024); return;\\n } else {\\n if (id < 896.) {\\n pos = vec3(1., -58., 357.); norm = vec3(0.486, -0.825, -0.024); return;\\n } else {\\n pos = vec3(33., -39., 352.); norm = vec3(0.486, -0.825, -0.024); return;\\n }\\n }\\n } else {\\n if (id < 899.) {\\n if (id < 898.) {\\n pos = vec3(33., 70., 900.); norm = vec3(0.214, 0.288, 0.027); return;\\n } else {\\n pos = vec3(6., 98., 815.); norm = vec3(0.214, 0.288, 0.027); return;\\n }\\n } else {\\n if (id < 900.) {\\n pos = vec3(6., 91., 890.); norm = vec3(0.214, 0.288, 0.027); return;\\n } else {\\n pos = vec3(33., 70., 900.); norm = vec3(0.348, 0.641, 0.405); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 907.) {\\n if (id < 904.) {\\n if (id < 902.) {\\n pos = vec3(6., 91., 890.); norm = vec3(0.348, 0.641, 0.405); return;\\n } else {\\n if (id < 903.) {\\n pos = vec3(6., 43., 966.); norm = vec3(0.348, 0.641, 0.405); return;\\n } else {\\n pos = vec3(40., 52., 892.); norm = vec3(0.749, -0.172, 0.022); return;\\n }\\n }\\n } else {\\n if (id < 905.) {\\n pos = vec3(41., 54., 874.); norm = vec3(0.749, -0.172, 0.022); return;\\n } else {\\n if (id < 906.) {\\n pos = vec3(44., 66., 866.); norm = vec3(0.749, -0.172, 0.022); return;\\n } else {\\n pos = vec3(33., 70., 900.); norm = vec3(0.158, 0.639, 0.127); return;\\n }\\n }\\n }\\n } else {\\n if (id < 910.) {\\n if (id < 908.) {\\n pos = vec3(48., 77., 846.); norm = vec3(0.158, 0.639, 0.127); return;\\n } else {\\n if (id < 909.) {\\n pos = vec3(34., 86., 818.); norm = vec3(0.158, 0.639, 0.127); return;\\n } else {\\n pos = vec3(40., 52., 892.); norm = vec3(0.116, -0.029, -0.001); return;\\n }\\n }\\n } else {\\n if (id < 912.) {\\n if (id < 911.) {\\n pos = vec3(29., 7., 978.); norm = vec3(0.116, -0.029, -0.001); return;\\n } else {\\n pos = vec3(36., 36., 902.); norm = vec3(0.116, -0.029, -0.001); return;\\n }\\n } else {\\n if (id < 913.) {\\n pos = vec3(36., 36., 902.); norm = vec3(0.995, -0.003, 0.090); return;\\n } else {\\n pos = vec3(29., 7., 978.); norm = vec3(0.995, -0.003, 0.090); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 965.) {\\n if (id < 939.) {\\n if (id < 926.) {\\n if (id < 920.) {\\n if (id < 917.) {\\n if (id < 915.) {\\n pos = vec3(30., -22., 966.); norm = vec3(0.995, -0.003, 0.090); return;\\n } else {\\n if (id < 916.) {\\n pos = vec3(0., 48., 192.); norm = vec3(0.270, 0.480, 0.297); return;\\n } else {\\n pos = vec3(0., 22., 234.); norm = vec3(0.270, 0.480, 0.297); return;\\n }\\n }\\n } else {\\n if (id < 918.) {\\n pos = vec3(28., 31., 194.); norm = vec3(0.270, 0.480, 0.297); return;\\n } else {\\n if (id < 919.) {\\n pos = vec3(28., 31., 194.); norm = vec3(0.238, 0.352, 0.246); return;\\n } else {\\n pos = vec3(0., 22., 234.); norm = vec3(0.238, 0.352, 0.246); return;\\n }\\n }\\n }\\n } else {\\n if (id < 923.) {\\n if (id < 921.) {\\n pos = vec3(57., 10., 196.); norm = vec3(0.238, 0.352, 0.246); return;\\n } else {\\n if (id < 922.) {\\n pos = vec3(137., -28., -52.); norm = vec3(0.581, -0.006, -0.099); return;\\n } else {\\n pos = vec3(129., -9., -100.); norm = vec3(0.581, -0.006, -0.099); return;\\n }\\n }\\n } else {\\n if (id < 924.) {\\n pos = vec3(153., 28., 38.); norm = vec3(0.581, -0.006, -0.099); return;\\n } else {\\n if (id < 925.) {\\n pos = vec3(153., 28., 38.); norm = vec3(0.292, 0.162, -0.094); return;\\n } else {\\n pos = vec3(129., -9., -100.); norm = vec3(0.292, 0.162, -0.094); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 932.) {\\n if (id < 929.) {\\n if (id < 927.) {\\n pos = vec3(127., 37., -27.); norm = vec3(0.292, 0.162, -0.094); return;\\n } else {\\n if (id < 928.) {\\n pos = vec3(37., 35., 822.); norm = vec3(0.497, 0.457, -0.076); return;\\n } else {\\n pos = vec3(33., 20., 706.); norm = vec3(0.497, 0.457, -0.076); return;\\n }\\n }\\n } else {\\n if (id < 930.) {\\n pos = vec3(4., 59., 751.); norm = vec3(0.497, 0.457, -0.076); return;\\n } else {\\n if (id < 931.) {\\n pos = vec3(4., 59., 751.); norm = vec3(0.356, 0.664, -0.346); return;\\n } else {\\n pos = vec3(33., 20., 706.); norm = vec3(0.356, 0.664, -0.346); return;\\n }\\n }\\n }\\n } else {\\n if (id < 935.) {\\n if (id < 933.) {\\n pos = vec3(3., 34., 702.); norm = vec3(0.356, 0.664, -0.346); return;\\n } else {\\n if (id < 934.) {\\n pos = vec3(33., 20., 706.); norm = vec3(0.191, -0.046, -0.001); return;\\n } else {\\n pos = vec3(37., 35., 822.); norm = vec3(0.191, -0.046, -0.001); return;\\n }\\n }\\n } else {\\n if (id < 937.) {\\n if (id < 936.) {\\n pos = vec3(28., -1., 714.); norm = vec3(0.191, -0.046, -0.001); return;\\n } else {\\n pos = vec3(30., -22., 966.); norm = vec3(0.328, -0.089, 0.242); return;\\n }\\n } else {\\n if (id < 938.) {\\n pos = vec3(29., 7., 978.); norm = vec3(0.328, -0.089, 0.242); return;\\n } else {\\n pos = vec3(5., -95., 973.); norm = vec3(0.328, -0.089, 0.242); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 952.) {\\n if (id < 945.) {\\n if (id < 942.) {\\n if (id < 940.) {\\n pos = vec3(6., -3., 907.); norm = vec3(0.381, -0.309, -0.127); return;\\n } else {\\n if (id < 941.) {\\n pos = vec3(36., 36., 902.); norm = vec3(0.381, -0.309, -0.127); return;\\n } else {\\n pos = vec3(6., -19., 946.); norm = vec3(0.381, -0.309, -0.127); return;\\n }\\n }\\n } else {\\n if (id < 943.) {\\n pos = vec3(6., -19., 946.); norm = vec3(0.592, -0.275, -0.751); return;\\n } else {\\n if (id < 944.) {\\n pos = vec3(30., -22., 966.); norm = vec3(0.592, -0.275, -0.751); return;\\n } else {\\n pos = vec3(5., -95., 973.); norm = vec3(0.592, -0.275, -0.751); return;\\n }\\n }\\n }\\n } else {\\n if (id < 948.) {\\n if (id < 946.) {\\n pos = vec3(28., -34., 549.); norm = vec3(0.116, 0.214, 0.025); return;\\n } else {\\n if (id < 947.) {\\n pos = vec3(22., -16., 425.); norm = vec3(0.116, 0.214, 0.025); return;\\n } else {\\n pos = vec3(2., -19., 542.); norm = vec3(0.116, 0.214, 0.025); return;\\n }\\n }\\n } else {\\n if (id < 950.) {\\n if (id < 949.) {\\n pos = vec3(2., -19., 542.); norm = vec3(0.337, 0.935, 0.082); return;\\n } else {\\n pos = vec3(22., -16., 425.); norm = vec3(0.337, 0.935, 0.082); return;\\n }\\n } else {\\n if (id < 951.) {\\n pos = vec3(1., -8., 420.); norm = vec3(0.337, 0.935, 0.082); return;\\n } else {\\n pos = vec3(34., -3., 286.); norm = vec3(0.124, 0.036, 0.014); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 958.) {\\n if (id < 955.) {\\n if (id < 953.) {\\n pos = vec3(22., -16., 425.); norm = vec3(0.124, 0.036, 0.014); return;\\n } else {\\n if (id < 954.) {\\n pos = vec3(37., -20., 303.); norm = vec3(0.124, 0.036, 0.014); return;\\n } else {\\n pos = vec3(37., -20., 303.); norm = vec3(0.264, 0.026, 0.032); return;\\n }\\n }\\n } else {\\n if (id < 956.) {\\n pos = vec3(22., -16., 425.); norm = vec3(0.264, 0.026, 0.032); return;\\n } else {\\n if (id < 957.) {\\n pos = vec3(33., -39., 352.); norm = vec3(0.264, 0.026, 0.032); return;\\n } else {\\n pos = vec3(22., -16., 425.); norm = vec3(0.975, 0.206, 0.082); return;\\n }\\n }\\n }\\n } else {\\n if (id < 961.) {\\n if (id < 959.) {\\n pos = vec3(28., -44., 424.); norm = vec3(0.975, 0.206, 0.082); return;\\n } else {\\n if (id < 960.) {\\n pos = vec3(33., -39., 352.); norm = vec3(0.975, 0.206, 0.082); return;\\n } else {\\n pos = vec3(0., 99., 84.); norm = vec3(0.096, 0.786, 0.479); return;\\n }\\n }\\n } else {\\n if (id < 963.) {\\n if (id < 962.) {\\n pos = vec3(93., 56., 136.); norm = vec3(0.096, 0.786, 0.479); return;\\n } else {\\n pos = vec3(109., 90., 77.); norm = vec3(0.096, 0.786, 0.479); return;\\n }\\n } else {\\n if (id < 964.) {\\n pos = vec3(109., 90., 77.); norm = vec3(-0.079, 0.433, 0.228); return;\\n } else {\\n pos = vec3(93., 56., 136.); norm = vec3(-0.079, 0.433, 0.228); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 990.) {\\n if (id < 977.) {\\n if (id < 971.) {\\n if (id < 968.) {\\n if (id < 966.) {\\n pos = vec3(127., 78., 106.); norm = vec3(-0.079, 0.433, 0.228); return;\\n } else {\\n if (id < 967.) {\\n pos = vec3(29., -56., 552.); norm = vec3(0.172, 0.008, -0.001); return;\\n } else {\\n pos = vec3(28., -44., 424.); norm = vec3(0.172, 0.008, -0.001); return;\\n }\\n }\\n } else {\\n if (id < 969.) {\\n pos = vec3(28., -34., 549.); norm = vec3(0.172, 0.008, -0.001); return;\\n } else {\\n if (id < 970.) {\\n pos = vec3(28., -44., 424.); norm = vec3(0.971, 0.209, -0.017); return;\\n } else {\\n pos = vec3(22., -16., 425.); norm = vec3(0.971, 0.209, -0.017); return;\\n }\\n }\\n }\\n } else {\\n if (id < 974.) {\\n if (id < 972.) {\\n pos = vec3(28., -34., 549.); norm = vec3(0.971, 0.209, -0.017); return;\\n } else {\\n if (id < 973.) {\\n pos = vec3(1., -66., 421.); norm = vec3(0.635, -0.768, -0.077); return;\\n } else {\\n pos = vec3(28., -44., 424.); norm = vec3(0.635, -0.768, -0.077); return;\\n }\\n }\\n } else {\\n if (id < 975.) {\\n pos = vec3(29., -56., 552.); norm = vec3(0.635, -0.768, -0.077); return;\\n } else {\\n if (id < 976.) {\\n pos = vec3(6., -19., 946.); norm = vec3(0.146, -0.250, -0.213); return;\\n } else {\\n pos = vec3(36., 36., 902.); norm = vec3(0.146, -0.250, -0.213); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 983.) {\\n if (id < 980.) {\\n if (id < 978.) {\\n pos = vec3(30., -22., 966.); norm = vec3(0.146, -0.250, -0.213); return;\\n } else {\\n if (id < 979.) {\\n pos = vec3(0., -26., -365.); norm = vec3(0.380, 0.902, -0.137); return;\\n } else {\\n pos = vec3(0., -11., -266.); norm = vec3(0.380, 0.902, -0.137); return;\\n }\\n }\\n } else {\\n if (id < 981.) {\\n pos = vec3(31., -23., -259.); norm = vec3(0.380, 0.902, -0.137); return;\\n } else {\\n if (id < 982.) {\\n pos = vec3(34., 86., 818.); norm = vec3(0.840, 0.019, -0.384); return;\\n } else {\\n pos = vec3(37., 35., 822.); norm = vec3(0.840, 0.019, -0.384); return;\\n }\\n }\\n }\\n } else {\\n if (id < 986.) {\\n if (id < 984.) {\\n pos = vec3(4., 59., 751.); norm = vec3(0.840, 0.019, -0.384); return;\\n } else {\\n if (id < 985.) {\\n pos = vec3(29., -56., 552.); norm = vec3(0.997, 0.044, -0.009); return;\\n } else {\\n pos = vec3(28., -34., 549.); norm = vec3(0.997, 0.044, -0.009); return;\\n }\\n }\\n } else {\\n if (id < 988.) {\\n if (id < 987.) {\\n pos = vec3(28., -1., 714.); norm = vec3(0.997, 0.044, -0.009); return;\\n } else {\\n pos = vec3(28., -1., 714.); norm = vec3(0.133, -0.030, 0.006); return;\\n }\\n } else {\\n if (id < 989.) {\\n pos = vec3(28., -34., 549.); norm = vec3(0.133, -0.030, 0.006); return;\\n } else {\\n pos = vec3(33., 20., 706.); norm = vec3(0.133, -0.030, 0.006); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1003.) {\\n if (id < 996.) {\\n if (id < 993.) {\\n if (id < 991.) {\\n pos = vec3(79., -108., -138.); norm = vec3(-0.006, -0.104, -0.006); return;\\n } else {\\n if (id < 992.) {\\n pos = vec3(64., -116., 23.); norm = vec3(-0.006, -0.104, -0.006); return;\\n } else {\\n pos = vec3(62., -106., -155.); norm = vec3(-0.006, -0.104, -0.006); return;\\n }\\n }\\n } else {\\n if (id < 994.) {\\n pos = vec3(2., -71., 551.); norm = vec3(0.112, -0.201, -0.009); return;\\n } else {\\n if (id < 995.) {\\n pos = vec3(1., -66., 421.); norm = vec3(0.112, -0.201, -0.009); return;\\n } else {\\n pos = vec3(29., -56., 552.); norm = vec3(0.112, -0.201, -0.009); return;\\n }\\n }\\n }\\n } else {\\n if (id < 999.) {\\n if (id < 997.) {\\n pos = vec3(137., -28., -52.); norm = vec3(0.827, -0.496, 0.162); return;\\n } else {\\n if (id < 998.) {\\n pos = vec3(153., 28., 38.); norm = vec3(0.827, -0.496, 0.162); return;\\n } else {\\n pos = vec3(95., -57., 74.); norm = vec3(0.827, -0.496, 0.162); return;\\n }\\n }\\n } else {\\n if (id < 1001.) {\\n if (id < 1000.) {\\n pos = vec3(95., -57., 74.); norm = vec3(0.535, -0.213, 0.358); return;\\n } else {\\n pos = vec3(153., 28., 38.); norm = vec3(0.535, -0.213, 0.358); return;\\n }\\n } else {\\n if (id < 1002.) {\\n pos = vec3(115., 15., 87.); norm = vec3(0.535, -0.213, 0.358); return;\\n } else {\\n pos = vec3(33., 70., 900.); norm = vec3(0.606, 0.544, 0.471); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1009.) {\\n if (id < 1006.) {\\n if (id < 1004.) {\\n pos = vec3(6., 43., 966.); norm = vec3(0.606, 0.544, 0.471); return;\\n } else {\\n if (id < 1005.) {\\n pos = vec3(29., 7., 978.); norm = vec3(0.606, 0.544, 0.471); return;\\n } else {\\n pos = vec3(29., 7., 978.); norm = vec3(0.290, 0.321, 0.407); return;\\n }\\n }\\n } else {\\n if (id < 1007.) {\\n pos = vec3(6., 43., 966.); norm = vec3(0.290, 0.321, 0.407); return;\\n } else {\\n if (id < 1008.) {\\n pos = vec3(6., 5., 996.); norm = vec3(0.290, 0.321, 0.407); return;\\n } else {\\n pos = vec3(29., 7., 978.); norm = vec3(0.615, -0.182, 0.765); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1012.) {\\n if (id < 1010.) {\\n pos = vec3(6., 5., 996.); norm = vec3(0.615, -0.182, 0.765); return;\\n } else {\\n if (id < 1011.) {\\n pos = vec3(5., -95., 973.); norm = vec3(0.615, -0.182, 0.765); return;\\n } else {\\n pos = vec3(41., -73., -173.); norm = vec3(0.017, -0.974, -0.225); return;\\n }\\n }\\n } else {\\n if (id < 1014.) {\\n if (id < 1013.) {\\n pos = vec3(0., -70., -189.); norm = vec3(0.017, -0.974, -0.225); return;\\n } else {\\n pos = vec3(30., -54., -256.); norm = vec3(0.017, -0.974, -0.225); return;\\n }\\n } else {\\n if (id < 1015.) {\\n pos = vec3(30., -54., -256.); norm = vec3(0.028, -0.391, -0.081); return;\\n } else {\\n pos = vec3(0., -70., -189.); norm = vec3(0.028, -0.391, -0.081); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1117.) {\\n if (id < 1066.) {\\n if (id < 1041.) {\\n if (id < 1028.) {\\n if (id < 1022.) {\\n if (id < 1019.) {\\n if (id < 1017.) {\\n pos = vec3(0., -50., -286.); norm = vec3(0.028, -0.391, -0.081); return;\\n } else {\\n if (id < 1018.) {\\n pos = vec3(40., -49., -294.); norm = vec3(0.838, -0.006, 0.220); return;\\n } else {\\n pos = vec3(31., -23., -259.); norm = vec3(0.838, -0.006, 0.220); return;\\n }\\n }\\n } else {\\n if (id < 1020.) {\\n pos = vec3(30., -54., -256.); norm = vec3(0.838, -0.006, 0.220); return;\\n } else {\\n if (id < 1021.) {\\n pos = vec3(28., -1., 714.); norm = vec3(0.430, -0.728, 0.207); return;\\n } else {\\n pos = vec3(37., 35., 822.); norm = vec3(0.430, -0.728, 0.207); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1025.) {\\n if (id < 1023.) {\\n pos = vec3(5., 13., 811.); norm = vec3(0.430, -0.728, 0.207); return;\\n } else {\\n if (id < 1024.) {\\n pos = vec3(5., 13., 811.); norm = vec3(0.538, -0.663, -0.238); return;\\n } else {\\n pos = vec3(37., 35., 822.); norm = vec3(0.538, -0.663, -0.238); return;\\n }\\n }\\n } else {\\n if (id < 1026.) {\\n pos = vec3(5., -10., 875.); norm = vec3(0.538, -0.663, -0.238); return;\\n } else {\\n if (id < 1027.) {\\n pos = vec3(0., -50., -286.); norm = vec3(-0.001, -0.891, -0.118); return;\\n } else {\\n pos = vec3(40., -49., -294.); norm = vec3(-0.001, -0.891, -0.118); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1034.) {\\n if (id < 1031.) {\\n if (id < 1029.) {\\n pos = vec3(30., -54., -256.); norm = vec3(-0.001, -0.891, -0.118); return;\\n } else {\\n if (id < 1030.) {\\n pos = vec3(79., -108., -138.); norm = vec3(-0.198, -0.748, 0.110); return;\\n } else {\\n pos = vec3(62., -106., -155.); norm = vec3(-0.198, -0.748, 0.110); return;\\n }\\n }\\n } else {\\n if (id < 1032.) {\\n pos = vec3(78., -140., -357.); norm = vec3(-0.198, -0.748, 0.110); return;\\n } else {\\n if (id < 1033.) {\\n pos = vec3(78., -140., -357.); norm = vec3(0.000, -0.053, 0.009); return;\\n } else {\\n pos = vec3(62., -106., -155.); norm = vec3(0.000, -0.053, 0.009); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1037.) {\\n if (id < 1035.) {\\n pos = vec3(67., -140., -357.); norm = vec3(0.000, -0.053, 0.009); return;\\n } else {\\n if (id < 1036.) {\\n pos = vec3(62., -106., -155.); norm = vec3(-0.838, -0.502, 0.064); return;\\n } else {\\n pos = vec3(53., -92., -163.); norm = vec3(-0.838, -0.502, 0.064); return;\\n }\\n }\\n } else {\\n if (id < 1039.) {\\n if (id < 1038.) {\\n pos = vec3(67., -140., -357.); norm = vec3(-0.838, -0.502, 0.064); return;\\n } else {\\n pos = vec3(67., -140., -357.); norm = vec3(-0.057, -0.030, 0.003); return;\\n }\\n } else {\\n if (id < 1040.) {\\n pos = vec3(53., -92., -163.); norm = vec3(-0.057, -0.030, 0.003); return;\\n } else {\\n pos = vec3(61., -129., -360.); norm = vec3(-0.057, -0.030, 0.003); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1053.) {\\n if (id < 1047.) {\\n if (id < 1044.) {\\n if (id < 1042.) {\\n pos = vec3(61., -129., -360.); norm = vec3(-0.030, 0.053, -0.011); return;\\n } else {\\n if (id < 1043.) {\\n pos = vec3(53., -92., -163.); norm = vec3(-0.030, 0.053, -0.011); return;\\n } else {\\n pos = vec3(72., -123., -361.); norm = vec3(-0.030, 0.053, -0.011); return;\\n }\\n }\\n } else {\\n if (id < 1045.) {\\n pos = vec3(72., -123., -361.); norm = vec3(-0.666, 0.596, -0.157); return;\\n } else {\\n if (id < 1046.) {\\n pos = vec3(53., -92., -163.); norm = vec3(-0.666, 0.596, -0.157); return;\\n } else {\\n pos = vec3(67., -74., -154.); norm = vec3(-0.666, 0.596, -0.157); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1050.) {\\n if (id < 1048.) {\\n pos = vec3(72., -123., -361.); norm = vec3(0.034, 0.050, -0.011); return;\\n } else {\\n if (id < 1049.) {\\n pos = vec3(67., -74., -154.); norm = vec3(0.034, 0.050, -0.011); return;\\n } else {\\n pos = vec3(83., -130., -359.); norm = vec3(0.034, 0.050, -0.011); return;\\n }\\n }\\n } else {\\n if (id < 1051.) {\\n pos = vec3(83., -130., -359.); norm = vec3(0.610, 0.731, -0.152); return;\\n } else {\\n if (id < 1052.) {\\n pos = vec3(67., -74., -154.); norm = vec3(0.610, 0.731, -0.152); return;\\n } else {\\n pos = vec3(87., -88., -141.); norm = vec3(0.610, 0.731, -0.152); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1059.) {\\n if (id < 1056.) {\\n if (id < 1054.) {\\n pos = vec3(83., -130., -359.); norm = vec3(0.046, -0.022, 0.003); return;\\n } else {\\n if (id < 1055.) {\\n pos = vec3(87., -88., -141.); norm = vec3(0.046, -0.022, 0.003); return;\\n } else {\\n pos = vec3(78., -140., -357.); norm = vec3(0.046, -0.022, 0.003); return;\\n }\\n }\\n } else {\\n if (id < 1057.) {\\n pos = vec3(78., -140., -357.); norm = vec3(0.926, -0.363, 0.049); return;\\n } else {\\n if (id < 1058.) {\\n pos = vec3(87., -88., -141.); norm = vec3(0.926, -0.363, 0.049); return;\\n } else {\\n pos = vec3(79., -108., -138.); norm = vec3(0.926, -0.363, 0.049); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1062.) {\\n if (id < 1060.) {\\n pos = vec3(71., -120., -421.); norm = vec3(-0.343, 0.243, -0.097); return;\\n } else {\\n if (id < 1061.) {\\n pos = vec3(71., -142., -476.); norm = vec3(-0.343, 0.243, -0.097); return;\\n } else {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.343, 0.243, -0.097); return;\\n }\\n }\\n } else {\\n if (id < 1064.) {\\n if (id < 1063.) {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.492, 0.771, -0.147); return;\\n } else {\\n pos = vec3(71., -142., -476.); norm = vec3(-0.492, 0.771, -0.147); return;\\n }\\n } else {\\n if (id < 1065.) {\\n pos = vec3(61., -148., -474.); norm = vec3(-0.492, 0.771, -0.147); return;\\n } else {\\n pos = vec3(71., -120., -421.); norm = vec3(0.557, 0.671, -0.268); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1091.) {\\n if (id < 1078.) {\\n if (id < 1072.) {\\n if (id < 1069.) {\\n if (id < 1067.) {\\n pos = vec3(97., -140., -417.); norm = vec3(0.557, 0.671, -0.268); return;\\n } else {\\n if (id < 1068.) {\\n pos = vec3(71., -142., -476.); norm = vec3(0.557, 0.671, -0.268); return;\\n } else {\\n pos = vec3(71., -142., -476.); norm = vec3(0.229, 0.147, -0.106); return;\\n }\\n }\\n } else {\\n if (id < 1070.) {\\n pos = vec3(97., -140., -417.); norm = vec3(0.229, 0.147, -0.106); return;\\n } else {\\n if (id < 1071.) {\\n pos = vec3(82., -157., -473.); norm = vec3(0.229, 0.147, -0.106); return;\\n } else {\\n pos = vec3(97., -140., -417.); norm = vec3(0.907, -0.326, -0.144); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1075.) {\\n if (id < 1073.) {\\n pos = vec3(89., -164., -413.); norm = vec3(0.907, -0.326, -0.144); return;\\n } else {\\n if (id < 1074.) {\\n pos = vec3(82., -157., -473.); norm = vec3(0.907, -0.326, -0.144); return;\\n } else {\\n pos = vec3(82., -157., -473.); norm = vec3(0.096, -0.084, -0.021); return;\\n }\\n }\\n } else {\\n if (id < 1076.) {\\n pos = vec3(89., -164., -413.); norm = vec3(0.096, -0.084, -0.021); return;\\n } else {\\n if (id < 1077.) {\\n pos = vec3(77., -163., -472.); norm = vec3(0.096, -0.084, -0.021); return;\\n } else {\\n pos = vec3(89., -164., -413.); norm = vec3(-0.037, -0.972, -0.009); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1084.) {\\n if (id < 1081.) {\\n if (id < 1079.) {\\n pos = vec3(63., -163., -413.); norm = vec3(-0.037, -0.972, -0.009); return;\\n } else {\\n if (id < 1080.) {\\n pos = vec3(77., -163., -472.); norm = vec3(-0.037, -0.972, -0.009); return;\\n } else {\\n pos = vec3(77., -163., -472.); norm = vec3(0.000, -0.181, 0.000); return;\\n }\\n }\\n } else {\\n if (id < 1082.) {\\n pos = vec3(63., -163., -413.); norm = vec3(0.000, -0.181, 0.000); return;\\n } else {\\n if (id < 1083.) {\\n pos = vec3(66., -163., -472.); norm = vec3(0.000, -0.181, 0.000); return;\\n } else {\\n pos = vec3(63., -163., -413.); norm = vec3(-0.907, -0.338, -0.046); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1087.) {\\n if (id < 1085.) {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.907, -0.338, -0.046); return;\\n } else {\\n if (id < 1086.) {\\n pos = vec3(66., -163., -472.); norm = vec3(-0.907, -0.338, -0.046); return;\\n } else {\\n pos = vec3(66., -163., -472.); norm = vec3(-0.250, -0.085, -0.016); return;\\n }\\n }\\n } else {\\n if (id < 1089.) {\\n if (id < 1088.) {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.250, -0.085, -0.016); return;\\n } else {\\n pos = vec3(61., -148., -474.); norm = vec3(-0.250, -0.085, -0.016); return;\\n }\\n } else {\\n if (id < 1090.) {\\n pos = vec3(83., -130., -359.); norm = vec3(0.839, -0.367, 0.266); return;\\n } else {\\n pos = vec3(78., -140., -357.); norm = vec3(0.839, -0.367, 0.266); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1104.) {\\n if (id < 1097.) {\\n if (id < 1094.) {\\n if (id < 1092.) {\\n pos = vec3(97., -140., -417.); norm = vec3(0.839, -0.367, 0.266); return;\\n } else {\\n if (id < 1093.) {\\n pos = vec3(97., -140., -417.); norm = vec3(0.370, -0.104, 0.117); return;\\n } else {\\n pos = vec3(78., -140., -357.); norm = vec3(0.370, -0.104, 0.117); return;\\n }\\n }\\n } else {\\n if (id < 1095.) {\\n pos = vec3(89., -164., -413.); norm = vec3(0.370, -0.104, 0.117); return;\\n } else {\\n if (id < 1096.) {\\n pos = vec3(89., -164., -413.); norm = vec3(-0.015, -0.377, 0.159); return;\\n } else {\\n pos = vec3(78., -140., -357.); norm = vec3(-0.015, -0.377, 0.159); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1100.) {\\n if (id < 1098.) {\\n pos = vec3(63., -163., -413.); norm = vec3(-0.015, -0.377, 0.159); return;\\n } else {\\n if (id < 1099.) {\\n pos = vec3(63., -163., -413.); norm = vec3(0.000, -0.898, 0.369); return;\\n } else {\\n pos = vec3(78., -140., -357.); norm = vec3(0.000, -0.898, 0.369); return;\\n }\\n }\\n } else {\\n if (id < 1102.) {\\n if (id < 1101.) {\\n pos = vec3(67., -140., -357.); norm = vec3(0.000, -0.898, 0.369); return;\\n } else {\\n pos = vec3(63., -163., -413.); norm = vec3(-0.357, -0.116, 0.073); return;\\n }\\n } else {\\n if (id < 1103.) {\\n pos = vec3(67., -140., -357.); norm = vec3(-0.357, -0.116, 0.073); return;\\n } else {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.357, -0.116, 0.073); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1110.) {\\n if (id < 1107.) {\\n if (id < 1105.) {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.841, -0.411, 0.175); return;\\n } else {\\n if (id < 1106.) {\\n pos = vec3(67., -140., -357.); norm = vec3(-0.841, -0.411, 0.175); return;\\n } else {\\n pos = vec3(61., -129., -360.); norm = vec3(-0.841, -0.411, 0.175); return;\\n }\\n }\\n } else {\\n if (id < 1108.) {\\n pos = vec3(61., -129., -360.); norm = vec3(-0.460, 0.822, -0.125); return;\\n } else {\\n if (id < 1109.) {\\n pos = vec3(72., -123., -361.); norm = vec3(-0.460, 0.822, -0.125); return;\\n } else {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.460, 0.822, -0.125); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1113.) {\\n if (id < 1111.) {\\n pos = vec3(55., -141., -417.); norm = vec3(-0.339, 0.262, 0.019); return;\\n } else {\\n if (id < 1112.) {\\n pos = vec3(72., -123., -361.); norm = vec3(-0.339, 0.262, 0.019); return;\\n } else {\\n pos = vec3(71., -120., -421.); norm = vec3(-0.339, 0.262, 0.019); return;\\n }\\n }\\n } else {\\n if (id < 1115.) {\\n if (id < 1114.) {\\n pos = vec3(72., -123., -361.); norm = vec3(0.491, 0.780, 0.031); return;\\n } else {\\n pos = vec3(83., -130., -359.); norm = vec3(0.491, 0.780, 0.031); return;\\n }\\n } else {\\n if (id < 1116.) {\\n pos = vec3(71., -120., -421.); norm = vec3(0.491, 0.780, 0.031); return;\\n } else {\\n pos = vec3(71., -120., -421.); norm = vec3(0.310, 0.404, 0.005); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1168.) {\\n if (id < 1142.) {\\n if (id < 1129.) {\\n if (id < 1123.) {\\n if (id < 1120.) {\\n if (id < 1118.) {\\n pos = vec3(83., -130., -359.); norm = vec3(0.310, 0.404, 0.005); return;\\n } else {\\n if (id < 1119.) {\\n pos = vec3(97., -140., -417.); norm = vec3(0.310, 0.404, 0.005); return;\\n } else {\\n pos = vec3(71., -142., -476.); norm = vec3(-0.028, 0.044, -0.009); return;\\n }\\n }\\n } else {\\n if (id < 1121.) {\\n pos = vec3(73., -187., -693.); norm = vec3(-0.028, 0.044, -0.009); return;\\n } else {\\n if (id < 1122.) {\\n pos = vec3(61., -148., -474.); norm = vec3(-0.028, 0.044, -0.009); return;\\n } else {\\n pos = vec3(61., -148., -474.); norm = vec3(-0.559, 0.810, -0.175); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1126.) {\\n if (id < 1124.) {\\n pos = vec3(73., -187., -693.); norm = vec3(-0.559, 0.810, -0.175); return;\\n } else {\\n if (id < 1125.) {\\n pos = vec3(64., -193., -692.); norm = vec3(-0.559, 0.810, -0.175); return;\\n } else {\\n pos = vec3(71., -142., -476.); norm = vec3(0.810, 0.572, -0.111); return;\\n }\\n }\\n } else {\\n if (id < 1127.) {\\n pos = vec3(82., -157., -473.); norm = vec3(0.810, 0.572, -0.111); return;\\n } else {\\n if (id < 1128.) {\\n pos = vec3(73., -187., -693.); norm = vec3(0.810, 0.572, -0.111); return;\\n } else {\\n pos = vec3(73., -187., -693.); norm = vec3(0.032, 0.031, -0.006); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1135.) {\\n if (id < 1132.) {\\n if (id < 1130.) {\\n pos = vec3(82., -157., -473.); norm = vec3(0.032, 0.031, -0.006); return;\\n } else {\\n if (id < 1131.) {\\n pos = vec3(80., -194., -692.); norm = vec3(0.032, 0.031, -0.006); return;\\n } else {\\n pos = vec3(80., -194., -692.); norm = vec3(0.037, -0.009, 0.001); return;\\n }\\n }\\n } else {\\n if (id < 1133.) {\\n pos = vec3(82., -157., -473.); norm = vec3(0.037, -0.009, 0.001); return;\\n } else {\\n if (id < 1134.) {\\n pos = vec3(78., -202., -690.); norm = vec3(0.037, -0.009, 0.001); return;\\n } else {\\n pos = vec3(78., -202., -690.); norm = vec3(0.772, -0.624, 0.115); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1138.) {\\n if (id < 1136.) {\\n pos = vec3(82., -157., -473.); norm = vec3(0.772, -0.624, 0.115); return;\\n } else {\\n if (id < 1137.) {\\n pos = vec3(77., -163., -472.); norm = vec3(0.772, -0.624, 0.115); return;\\n } else {\\n pos = vec3(78., -202., -690.); norm = vec3(-0.004, -0.040, 0.007); return;\\n }\\n }\\n } else {\\n if (id < 1140.) {\\n if (id < 1139.) {\\n pos = vec3(77., -163., -472.); norm = vec3(-0.004, -0.040, 0.007); return;\\n } else {\\n pos = vec3(69., -201., -690.); norm = vec3(-0.004, -0.040, 0.007); return;\\n }\\n } else {\\n if (id < 1141.) {\\n pos = vec3(69., -201., -690.); norm = vec3(0.000, -0.985, 0.172); return;\\n } else {\\n pos = vec3(77., -163., -472.); norm = vec3(0.000, -0.985, 0.172); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1155.) {\\n if (id < 1148.) {\\n if (id < 1145.) {\\n if (id < 1143.) {\\n pos = vec3(66., -163., -472.); norm = vec3(0.000, -0.985, 0.172); return;\\n } else {\\n if (id < 1144.) {\\n pos = vec3(69., -201., -690.); norm = vec3(-0.037, -0.022, 0.003); return;\\n } else {\\n pos = vec3(66., -163., -472.); norm = vec3(-0.037, -0.022, 0.003); return;\\n }\\n }\\n } else {\\n if (id < 1146.) {\\n pos = vec3(64., -193., -692.); norm = vec3(-0.037, -0.022, 0.003); return;\\n } else {\\n if (id < 1147.) {\\n pos = vec3(64., -193., -692.); norm = vec3(-0.949, -0.310, 0.051); return;\\n } else {\\n pos = vec3(66., -163., -472.); norm = vec3(-0.949, -0.310, 0.051); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1151.) {\\n if (id < 1149.) {\\n pos = vec3(61., -148., -474.); norm = vec3(-0.949, -0.310, 0.051); return;\\n } else {\\n if (id < 1150.) {\\n pos = vec3(78., -202., -690.); norm = vec3(0.292, -0.040, 0.131); return;\\n } else {\\n pos = vec3(84., -214., -707.); norm = vec3(0.292, -0.040, 0.131); return;\\n }\\n }\\n } else {\\n if (id < 1153.) {\\n if (id < 1152.) {\\n pos = vec3(80., -194., -692.); norm = vec3(0.292, -0.040, 0.131); return;\\n } else {\\n pos = vec3(80., -194., -692.); norm = vec3(0.699, -0.047, 0.249); return;\\n }\\n } else {\\n if (id < 1154.) {\\n pos = vec3(84., -214., -707.); norm = vec3(0.699, -0.047, 0.249); return;\\n } else {\\n pos = vec3(88., -181., -712.); norm = vec3(0.699, -0.047, 0.249); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1161.) {\\n if (id < 1158.) {\\n if (id < 1156.) {\\n pos = vec3(78., -202., -690.); norm = vec3(-0.072, -0.647, 0.431); return;\\n } else {\\n if (id < 1157.) {\\n pos = vec3(69., -201., -690.); norm = vec3(-0.072, -0.647, 0.431); return;\\n } else {\\n pos = vec3(84., -214., -707.); norm = vec3(-0.072, -0.647, 0.431); return;\\n }\\n }\\n } else {\\n if (id < 1159.) {\\n pos = vec3(84., -214., -707.); norm = vec3(0.000, -0.672, 0.514); return;\\n } else {\\n if (id < 1160.) {\\n pos = vec3(69., -201., -690.); norm = vec3(0.000, -0.672, 0.514); return;\\n } else {\\n pos = vec3(60., -214., -707.); norm = vec3(0.000, -0.672, 0.514); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1164.) {\\n if (id < 1162.) {\\n pos = vec3(56., -182., -715.); norm = vec3(-0.747, -0.032, 0.244); return;\\n } else {\\n if (id < 1163.) {\\n pos = vec3(60., -214., -707.); norm = vec3(-0.747, -0.032, 0.244); return;\\n } else {\\n pos = vec3(64., -193., -692.); norm = vec3(-0.747, -0.032, 0.244); return;\\n }\\n }\\n } else {\\n if (id < 1166.) {\\n if (id < 1165.) {\\n pos = vec3(64., -193., -692.); norm = vec3(-0.267, -0.111, 0.226); return;\\n } else {\\n pos = vec3(60., -214., -707.); norm = vec3(-0.267, -0.111, 0.226); return;\\n }\\n } else {\\n if (id < 1167.) {\\n pos = vec3(69., -201., -690.); norm = vec3(-0.267, -0.111, 0.226); return;\\n } else {\\n pos = vec3(56., -182., -715.); norm = vec3(-0.053, 0.927, 0.251); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1193.) {\\n if (id < 1180.) {\\n if (id < 1174.) {\\n if (id < 1171.) {\\n if (id < 1169.) {\\n pos = vec3(73., -187., -693.); norm = vec3(-0.053, 0.927, 0.251); return;\\n } else {\\n if (id < 1170.) {\\n pos = vec3(88., -181., -712.); norm = vec3(-0.053, 0.927, 0.251); return;\\n } else {\\n pos = vec3(88., -181., -712.); norm = vec3(0.512, 0.596, 0.592); return;\\n }\\n }\\n } else {\\n if (id < 1172.) {\\n pos = vec3(73., -187., -693.); norm = vec3(0.512, 0.596, 0.592); return;\\n } else {\\n if (id < 1173.) {\\n pos = vec3(80., -194., -692.); norm = vec3(0.512, 0.596, 0.592); return;\\n } else {\\n pos = vec3(37., 35., 822.); norm = vec3(0.659, -0.700, -0.196); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1177.) {\\n if (id < 1175.) {\\n pos = vec3(45., 33., 856.); norm = vec3(0.659, -0.700, -0.196); return;\\n } else {\\n if (id < 1176.) {\\n pos = vec3(5., -10., 875.); norm = vec3(0.659, -0.700, -0.196); return;\\n } else {\\n pos = vec3(5., -10., 875.); norm = vec3(0.702, -0.576, 0.175); return;\\n }\\n }\\n } else {\\n if (id < 1178.) {\\n pos = vec3(45., 33., 856.); norm = vec3(0.702, -0.576, 0.175); return;\\n } else {\\n if (id < 1179.) {\\n pos = vec3(36., 36., 902.); norm = vec3(0.702, -0.576, 0.175); return;\\n } else {\\n pos = vec3(5., -10., 875.); norm = vec3(0.420, -0.316, 0.056); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1186.) {\\n if (id < 1183.) {\\n if (id < 1181.) {\\n pos = vec3(36., 36., 902.); norm = vec3(0.420, -0.316, 0.056); return;\\n } else {\\n if (id < 1182.) {\\n pos = vec3(6., -3., 907.); norm = vec3(0.420, -0.316, 0.056); return;\\n } else {\\n pos = vec3(137., -28., -52.); norm = vec3(0.392, -0.145, -0.123); return;\\n }\\n }\\n } else {\\n if (id < 1184.) {\\n pos = vec3(87., -88., -141.); norm = vec3(0.392, -0.145, -0.123); return;\\n } else {\\n if (id < 1185.) {\\n pos = vec3(129., -9., -100.); norm = vec3(0.392, -0.145, -0.123); return;\\n } else {\\n pos = vec3(67., -74., -154.); norm = vec3(0.487, 0.089, -0.654); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1189.) {\\n if (id < 1187.) {\\n pos = vec3(70., -61., -150.); norm = vec3(0.487, 0.089, -0.654); return;\\n } else {\\n if (id < 1188.) {\\n pos = vec3(87., -88., -141.); norm = vec3(0.487, 0.089, -0.654); return;\\n } else {\\n pos = vec3(87., -88., -141.); norm = vec3(0.588, 0.103, -0.802); return;\\n }\\n }\\n } else {\\n if (id < 1191.) {\\n if (id < 1190.) {\\n pos = vec3(70., -61., -150.); norm = vec3(0.588, 0.103, -0.802); return;\\n } else {\\n pos = vec3(129., -9., -100.); norm = vec3(0.588, 0.103, -0.802); return;\\n }\\n } else {\\n if (id < 1192.) {\\n pos = vec3(67., 45., -184.); norm = vec3(0.538, 0.323, -0.189); return;\\n } else {\\n pos = vec3(127., 37., -27.); norm = vec3(0.538, 0.323, -0.189); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1206.) {\\n if (id < 1199.) {\\n if (id < 1196.) {\\n if (id < 1194.) {\\n pos = vec3(129., -9., -100.); norm = vec3(0.538, 0.323, -0.189); return;\\n } else {\\n if (id < 1195.) {\\n pos = vec3(0., 109., -12.); norm = vec3(0.073, 0.629, 0.066); return;\\n } else {\\n pos = vec3(0., 99., 84.); norm = vec3(0.073, 0.629, 0.066); return;\\n }\\n }\\n } else {\\n if (id < 1197.) {\\n pos = vec3(85., 100., -20.); norm = vec3(0.073, 0.629, 0.066); return;\\n } else {\\n if (id < 1198.) {\\n pos = vec3(85., 100., -20.); norm = vec3(0.064, 0.730, 0.059); return;\\n } else {\\n pos = vec3(0., 99., 84.); norm = vec3(0.064, 0.730, 0.059); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1202.) {\\n if (id < 1200.) {\\n pos = vec3(109., 90., 77.); norm = vec3(0.064, 0.730, 0.059); return;\\n } else {\\n if (id < 1201.) {\\n pos = vec3(56., -182., -715.); norm = vec3(-0.438, 0.741, 0.506); return;\\n } else {\\n pos = vec3(64., -193., -692.); norm = vec3(-0.438, 0.741, 0.506); return;\\n }\\n }\\n } else {\\n if (id < 1204.) {\\n if (id < 1203.) {\\n pos = vec3(73., -187., -693.); norm = vec3(-0.438, 0.741, 0.506); return;\\n } else {\\n pos = vec3(53., -92., -163.); norm = vec3(-0.391, -0.590, -0.592); return;\\n }\\n } else {\\n if (id < 1205.) {\\n pos = vec3(62., -106., -155.); norm = vec3(-0.391, -0.590, -0.592); return;\\n } else {\\n pos = vec3(0., -94., -126.); norm = vec3(-0.391, -0.590, -0.592); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1212.) {\\n if (id < 1209.) {\\n if (id < 1207.) {\\n pos = vec3(0., -132., 23.); norm = vec3(-0.270, -0.865, -0.220); return;\\n } else {\\n if (id < 1208.) {\\n pos = vec3(0., -94., -126.); norm = vec3(-0.270, -0.865, -0.220); return;\\n } else {\\n pos = vec3(62., -106., -155.); norm = vec3(-0.270, -0.865, -0.220); return;\\n }\\n }\\n } else {\\n if (id < 1210.) {\\n pos = vec3(38., -46., -295.); norm = vec3(0.408, 0.867, 0.026); return;\\n } else {\\n if (id < 1211.) {\\n pos = vec3(65., -57., -351.); norm = vec3(0.408, 0.867, 0.026); return;\\n } else {\\n pos = vec3(0., -26., -365.); norm = vec3(0.408, 0.867, 0.026); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1215.) {\\n if (id < 1213.) {\\n pos = vec3(31., -23., -259.); norm = vec3(0.786, 0.474, -0.150); return;\\n } else {\\n if (id < 1214.) {\\n pos = vec3(40., -49., -294.); norm = vec3(0.786, 0.474, -0.150); return;\\n } else {\\n pos = vec3(38., -46., -295.); norm = vec3(0.786, 0.474, -0.150); return;\\n }\\n }\\n } else {\\n if (id < 1217.) {\\n if (id < 1216.) {\\n pos = vec3(0., -26., -365.); norm = vec3(0.487, 0.388, -0.153); return;\\n } else {\\n pos = vec3(31., -23., -259.); norm = vec3(0.487, 0.388, -0.153); return;\\n }\\n } else {\\n if (id < 1218.) {\\n pos = vec3(38., -46., -295.); norm = vec3(0.487, 0.388, -0.153); return;\\n } else {\\n pos = vec3(40., -49., -294.); norm = vec3(0.045, 0.035, 0.015); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1422.) {\\n if (id < 1320.) {\\n if (id < 1269.) {\\n if (id < 1244.) {\\n if (id < 1231.) {\\n if (id < 1225.) {\\n if (id < 1222.) {\\n if (id < 1220.) {\\n pos = vec3(65., -57., -351.); norm = vec3(0.045, 0.035, 0.015); return;\\n } else {\\n if (id < 1221.) {\\n pos = vec3(38., -46., -295.); norm = vec3(0.045, 0.035, 0.015); return;\\n } else {\\n pos = vec3(0., -50., -286.); norm = vec3(-0.016, -0.452, -0.137); return;\\n }\\n }\\n } else {\\n if (id < 1223.) {\\n pos = vec3(0., -26., -365.); norm = vec3(-0.016, -0.452, -0.137); return;\\n } else {\\n if (id < 1224.) {\\n pos = vec3(40., -49., -294.); norm = vec3(-0.016, -0.452, -0.137); return;\\n } else {\\n pos = vec3(40., -49., -294.); norm = vec3(-0.302, -0.653, -0.041); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1228.) {\\n if (id < 1226.) {\\n pos = vec3(0., -26., -365.); norm = vec3(-0.302, -0.653, -0.041); return;\\n } else {\\n if (id < 1227.) {\\n pos = vec3(65., -57., -351.); norm = vec3(-0.302, -0.653, -0.041); return;\\n } else {\\n pos = vec3(115., 15., 87.); norm = vec3(-0.105, -0.722, 0.556); return;\\n }\\n }\\n } else {\\n if (id < 1229.) {\\n pos = vec3(152., 42., 129.); norm = vec3(-0.105, -0.722, 0.556); return;\\n } else {\\n if (id < 1230.) {\\n pos = vec3(93., 56., 136.); norm = vec3(-0.105, -0.722, 0.556); return;\\n } else {\\n pos = vec3(93., 56., 136.); norm = vec3(0.190, 0.507, 0.587); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1237.) {\\n if (id < 1234.) {\\n if (id < 1232.) {\\n pos = vec3(152., 42., 129.); norm = vec3(0.190, 0.507, 0.587); return;\\n } else {\\n if (id < 1233.) {\\n pos = vec3(127., 78., 106.); norm = vec3(0.190, 0.507, 0.587); return;\\n } else {\\n pos = vec3(321., 157., -5.); norm = vec3(-0.144, 0.393, 0.075); return;\\n }\\n }\\n } else {\\n if (id < 1235.) {\\n pos = vec3(546., 202., 191.); norm = vec3(-0.144, 0.393, 0.075); return;\\n } else {\\n if (id < 1236.) {\\n pos = vec3(484., 204., 61.); norm = vec3(-0.144, 0.393, 0.075); return;\\n } else {\\n pos = vec3(484., 172., 66.); norm = vec3(0.165, -0.466, -0.064); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1240.) {\\n if (id < 1238.) {\\n pos = vec3(552., 177., 205.); norm = vec3(0.165, -0.466, -0.064); return;\\n } else {\\n if (id < 1239.) {\\n pos = vec3(283., 108., 13.); norm = vec3(0.165, -0.466, -0.064); return;\\n } else {\\n pos = vec3(283., 108., 13.); norm = vec3(0.098, -0.330, -0.019); return;\\n }\\n }\\n } else {\\n if (id < 1242.) {\\n if (id < 1241.) {\\n pos = vec3(552., 177., 205.); norm = vec3(0.098, -0.330, -0.019); return;\\n } else {\\n pos = vec3(311., 109., 140.); norm = vec3(0.098, -0.330, -0.019); return;\\n }\\n } else {\\n if (id < 1243.) {\\n pos = vec3(304., 150., 144.); norm = vec3(-0.282, 0.956, -0.036); return;\\n } else {\\n pos = vec3(171., 106., 16.); norm = vec3(-0.282, 0.956, -0.036); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1256.) {\\n if (id < 1250.) {\\n if (id < 1247.) {\\n if (id < 1245.) {\\n pos = vec3(109., 90., 77.); norm = vec3(-0.282, 0.956, -0.036); return;\\n } else {\\n if (id < 1246.) {\\n pos = vec3(109., 90., 77.); norm = vec3(-0.114, 0.905, 0.122); return;\\n } else {\\n pos = vec3(171., 106., 16.); norm = vec3(-0.114, 0.905, 0.122); return;\\n }\\n }\\n } else {\\n if (id < 1248.) {\\n pos = vec3(85., 100., -20.); norm = vec3(-0.114, 0.905, 0.122); return;\\n } else {\\n if (id < 1249.) {\\n pos = vec3(312., 128., 162.); norm = vec3(-0.371, 0.501, 0.777); return;\\n } else {\\n pos = vec3(304., 150., 144.); norm = vec3(-0.371, 0.501, 0.777); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1253.) {\\n if (id < 1251.) {\\n pos = vec3(127., 78., 106.); norm = vec3(-0.371, 0.501, 0.777); return;\\n } else {\\n if (id < 1252.) {\\n pos = vec3(127., 78., 106.); norm = vec3(-0.061, 0.106, 0.082); return;\\n } else {\\n pos = vec3(304., 150., 144.); norm = vec3(-0.061, 0.106, 0.082); return;\\n }\\n }\\n } else {\\n if (id < 1254.) {\\n pos = vec3(109., 90., 77.); norm = vec3(-0.061, 0.106, 0.082); return;\\n } else {\\n if (id < 1255.) {\\n pos = vec3(127., 78., 106.); norm = vec3(-0.346, 0.312, 0.866); return;\\n } else {\\n pos = vec3(152., 42., 129.); norm = vec3(-0.346, 0.312, 0.866); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1262.) {\\n if (id < 1259.) {\\n if (id < 1257.) {\\n pos = vec3(312., 128., 162.); norm = vec3(-0.346, 0.312, 0.866); return;\\n } else {\\n if (id < 1258.) {\\n pos = vec3(312., 128., 162.); norm = vec3(0.040, -0.109, 0.093); return;\\n } else {\\n pos = vec3(152., 42., 129.); norm = vec3(0.040, -0.109, 0.093); return;\\n }\\n }\\n } else {\\n if (id < 1260.) {\\n pos = vec3(311., 109., 140.); norm = vec3(0.040, -0.109, 0.093); return;\\n } else {\\n if (id < 1261.) {\\n pos = vec3(152., 42., 129.); norm = vec3(0.315, -0.768, 0.122); return;\\n } else {\\n pos = vec3(153., 28., 38.); norm = vec3(0.315, -0.768, 0.122); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1265.) {\\n if (id < 1263.) {\\n pos = vec3(311., 109., 140.); norm = vec3(0.315, -0.768, 0.122); return;\\n } else {\\n if (id < 1264.) {\\n pos = vec3(311., 109., 140.); norm = vec3(0.322, -0.543, -0.067); return;\\n } else {\\n pos = vec3(153., 28., 38.); norm = vec3(0.322, -0.543, -0.067); return;\\n }\\n }\\n } else {\\n if (id < 1267.) {\\n if (id < 1266.) {\\n pos = vec3(283., 108., 13.); norm = vec3(0.322, -0.543, -0.067); return;\\n } else {\\n pos = vec3(321., 157., -5.); norm = vec3(-0.245, 0.710, -0.026); return;\\n }\\n } else {\\n if (id < 1268.) {\\n pos = vec3(234., 121., -170.); norm = vec3(-0.245, 0.710, -0.026); return;\\n } else {\\n pos = vec3(171., 106., 16.); norm = vec3(-0.245, 0.710, -0.026); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1294.) {\\n if (id < 1281.) {\\n if (id < 1275.) {\\n if (id < 1272.) {\\n if (id < 1270.) {\\n pos = vec3(171., 106., 16.); norm = vec3(-0.396, 0.881, -0.063); return;\\n } else {\\n if (id < 1271.) {\\n pos = vec3(234., 121., -170.); norm = vec3(-0.396, 0.881, -0.063); return;\\n } else {\\n pos = vec3(67., 45., -184.); norm = vec3(-0.396, 0.881, -0.063); return;\\n }\\n }\\n } else {\\n if (id < 1273.) {\\n pos = vec3(234., 121., -170.); norm = vec3(-0.484, 0.854, 0.069); return;\\n } else {\\n if (id < 1274.) {\\n pos = vec3(321., 157., -5.); norm = vec3(-0.484, 0.854, 0.069); return;\\n } else {\\n pos = vec3(386., 199., -69.); norm = vec3(-0.484, 0.854, 0.069); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1278.) {\\n if (id < 1276.) {\\n pos = vec3(386., 199., -69.); norm = vec3(-0.316, 0.805, 0.207); return;\\n } else {\\n if (id < 1277.) {\\n pos = vec3(321., 157., -5.); norm = vec3(-0.316, 0.805, 0.207); return;\\n } else {\\n pos = vec3(484., 204., 61.); norm = vec3(-0.316, 0.805, 0.207); return;\\n }\\n }\\n } else {\\n if (id < 1279.) {\\n pos = vec3(219., 95., -190.); norm = vec3(0.084, 0.269, -0.412); return;\\n } else {\\n if (id < 1280.) {\\n pos = vec3(234., 121., -170.); norm = vec3(0.084, 0.269, -0.412); return;\\n } else {\\n pos = vec3(373., 191., -96.); norm = vec3(0.084, 0.269, -0.412); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1287.) {\\n if (id < 1284.) {\\n if (id < 1282.) {\\n pos = vec3(373., 191., -96.); norm = vec3(-0.038, 0.082, -0.006); return;\\n } else {\\n if (id < 1283.) {\\n pos = vec3(234., 121., -170.); norm = vec3(-0.038, 0.082, -0.006); return;\\n } else {\\n pos = vec3(386., 199., -69.); norm = vec3(-0.038, 0.082, -0.006); return;\\n }\\n }\\n } else {\\n if (id < 1285.) {\\n pos = vec3(85., 100., -20.); norm = vec3(-0.001, 0.384, -0.062); return;\\n } else {\\n if (id < 1286.) {\\n pos = vec3(171., 106., 16.); norm = vec3(-0.001, 0.384, -0.062); return;\\n } else {\\n pos = vec3(63., 88., -94.); norm = vec3(-0.001, 0.384, -0.062); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1290.) {\\n if (id < 1288.) {\\n pos = vec3(63., 88., -94.); norm = vec3(0.086, 0.280, -0.130); return;\\n } else {\\n if (id < 1289.) {\\n pos = vec3(171., 106., 16.); norm = vec3(0.086, 0.280, -0.130); return;\\n } else {\\n pos = vec3(67., 45., -184.); norm = vec3(0.086, 0.280, -0.130); return;\\n }\\n }\\n } else {\\n if (id < 1292.) {\\n if (id < 1291.) {\\n pos = vec3(304., 150., 144.); norm = vec3(-0.270, 0.545, 0.787); return;\\n } else {\\n pos = vec3(312., 128., 162.); norm = vec3(-0.270, 0.545, 0.787); return;\\n }\\n } else {\\n if (id < 1293.) {\\n pos = vec3(546., 202., 191.); norm = vec3(-0.270, 0.545, 0.787); return;\\n } else {\\n pos = vec3(546., 202., 191.); norm = vec3(-0.035, 0.083, 0.072); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1307.) {\\n if (id < 1300.) {\\n if (id < 1297.) {\\n if (id < 1295.) {\\n pos = vec3(312., 128., 162.); norm = vec3(-0.035, 0.083, 0.072); return;\\n } else {\\n if (id < 1296.) {\\n pos = vec3(557., 186., 215.); norm = vec3(-0.035, 0.083, 0.072); return;\\n } else {\\n pos = vec3(311., 109., 140.); norm = vec3(0.004, -0.081, 0.070); return;\\n }\\n }\\n } else {\\n if (id < 1298.) {\\n pos = vec3(552., 177., 205.); norm = vec3(0.004, -0.081, 0.070); return;\\n } else {\\n if (id < 1299.) {\\n pos = vec3(312., 128., 162.); norm = vec3(0.004, -0.081, 0.070); return;\\n } else {\\n pos = vec3(312., 128., 162.); norm = vec3(0.029, -0.612, 0.536); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1303.) {\\n if (id < 1301.) {\\n pos = vec3(552., 177., 205.); norm = vec3(0.029, -0.612, 0.536); return;\\n } else {\\n if (id < 1302.) {\\n pos = vec3(557., 186., 215.); norm = vec3(0.029, -0.612, 0.536); return;\\n } else {\\n pos = vec3(248., 106., -165.); norm = vec3(0.084, -0.183, -0.017); return;\\n }\\n }\\n } else {\\n if (id < 1305.) {\\n if (id < 1304.) {\\n pos = vec3(127., 37., -27.); norm = vec3(0.084, -0.183, -0.017); return;\\n } else {\\n pos = vec3(219., 95., -190.); norm = vec3(0.084, -0.183, -0.017); return;\\n }\\n } else {\\n if (id < 1306.) {\\n pos = vec3(219., 95., -190.); norm = vec3(0.237, -0.735, -0.128); return;\\n } else {\\n pos = vec3(127., 37., -27.); norm = vec3(0.237, -0.735, -0.128); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1313.) {\\n if (id < 1310.) {\\n if (id < 1308.) {\\n pos = vec3(67., 45., -184.); norm = vec3(0.237, -0.735, -0.128); return;\\n } else {\\n if (id < 1309.) {\\n pos = vec3(546., 202., 191.); norm = vec3(-0.178, 0.814, 0.018); return;\\n } else {\\n pos = vec3(321., 157., -5.); norm = vec3(-0.178, 0.814, 0.018); return;\\n }\\n }\\n } else {\\n if (id < 1311.) {\\n pos = vec3(304., 150., 144.); norm = vec3(-0.178, 0.814, 0.018); return;\\n } else {\\n if (id < 1312.) {\\n pos = vec3(304., 150., 144.); norm = vec3(-0.311, 0.917, 0.008); return;\\n } else {\\n pos = vec3(321., 157., -5.); norm = vec3(-0.311, 0.917, 0.008); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1316.) {\\n if (id < 1314.) {\\n pos = vec3(171., 106., 16.); norm = vec3(-0.311, 0.917, 0.008); return;\\n } else {\\n if (id < 1315.) {\\n pos = vec3(400., 168., -38.); norm = vec3(0.189, -0.156, -0.150); return;\\n } else {\\n pos = vec3(248., 106., -165.); norm = vec3(0.189, -0.156, -0.150); return;\\n }\\n }\\n } else {\\n if (id < 1318.) {\\n if (id < 1317.) {\\n pos = vec3(373., 191., -96.); norm = vec3(0.189, -0.156, -0.150); return;\\n } else {\\n pos = vec3(373., 191., -96.); norm = vec3(0.206, -0.170, -0.165); return;\\n }\\n } else {\\n if (id < 1319.) {\\n pos = vec3(248., 106., -165.); norm = vec3(0.206, -0.170, -0.165); return;\\n } else {\\n pos = vec3(219., 95., -190.); norm = vec3(0.206, -0.170, -0.165); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1371.) {\\n if (id < 1345.) {\\n if (id < 1332.) {\\n if (id < 1326.) {\\n if (id < 1323.) {\\n if (id < 1321.) {\\n pos = vec3(373., 191., -96.); norm = vec3(0.041, 0.947, -0.300); return;\\n } else {\\n if (id < 1322.) {\\n pos = vec3(386., 199., -69.); norm = vec3(0.041, 0.947, -0.300); return;\\n } else {\\n pos = vec3(500., 183., -104.); norm = vec3(0.041, 0.947, -0.300); return;\\n }\\n }\\n } else {\\n if (id < 1324.) {\\n pos = vec3(500., 183., -104.); norm = vec3(-0.010, 0.091, -0.074); return;\\n } else {\\n if (id < 1325.) {\\n pos = vec3(386., 199., -69.); norm = vec3(-0.010, 0.091, -0.074); return;\\n } else {\\n pos = vec3(501., 192., -93.); norm = vec3(-0.010, 0.091, -0.074); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1329.) {\\n if (id < 1327.) {\\n pos = vec3(792., 186., 135.); norm = vec3(0.069, 0.988, 0.019); return;\\n } else {\\n if (id < 1328.) {\\n pos = vec3(783., 187., 116.); norm = vec3(0.069, 0.988, 0.019); return;\\n } else {\\n pos = vec3(546., 202., 191.); norm = vec3(0.069, 0.988, 0.019); return;\\n }\\n }\\n } else {\\n if (id < 1330.) {\\n pos = vec3(728., 189., 85.); norm = vec3(0.012, 0.218, -0.007); return;\\n } else {\\n if (id < 1331.) {\\n pos = vec3(546., 202., 191.); norm = vec3(0.012, 0.218, -0.007); return;\\n } else {\\n pos = vec3(783., 187., 116.); norm = vec3(0.012, 0.218, -0.007); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1338.) {\\n if (id < 1335.) {\\n if (id < 1333.) {\\n pos = vec3(588., 196., -74.); norm = vec3(-0.028, 0.991, -0.080); return;\\n } else {\\n if (id < 1334.) {\\n pos = vec3(501., 192., -93.); norm = vec3(-0.028, 0.991, -0.080); return;\\n } else {\\n pos = vec3(484., 204., 61.); norm = vec3(-0.028, 0.991, -0.080); return;\\n }\\n }\\n } else {\\n if (id < 1336.) {\\n pos = vec3(386., 199., -69.); norm = vec3(0.031, 0.684, -0.050); return;\\n } else {\\n if (id < 1337.) {\\n pos = vec3(484., 204., 61.); norm = vec3(0.031, 0.684, -0.050); return;\\n } else {\\n pos = vec3(501., 192., -93.); norm = vec3(0.031, 0.684, -0.050); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1341.) {\\n if (id < 1339.) {\\n pos = vec3(552., 177., 205.); norm = vec3(0.005, -0.043, 0.036); return;\\n } else {\\n if (id < 1340.) {\\n pos = vec3(797., 161., 149.); norm = vec3(0.005, -0.043, 0.036); return;\\n } else {\\n pos = vec3(557., 186., 215.); norm = vec3(0.005, -0.043, 0.036); return;\\n }\\n }\\n } else {\\n if (id < 1343.) {\\n if (id < 1342.) {\\n pos = vec3(557., 186., 215.); norm = vec3(0.108, -0.728, 0.668); return;\\n } else {\\n pos = vec3(797., 161., 149.); norm = vec3(0.108, -0.728, 0.668); return;\\n }\\n } else {\\n if (id < 1344.) {\\n pos = vec3(802., 170., 158.); norm = vec3(0.108, -0.728, 0.668); return;\\n } else {\\n pos = vec3(546., 202., 191.); norm = vec3(0.167, 0.851, 0.491); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1358.) {\\n if (id < 1351.) {\\n if (id < 1348.) {\\n if (id < 1346.) {\\n pos = vec3(557., 186., 215.); norm = vec3(0.167, 0.851, 0.491); return;\\n } else {\\n if (id < 1347.) {\\n pos = vec3(792., 186., 135.); norm = vec3(0.167, 0.851, 0.491); return;\\n } else {\\n pos = vec3(792., 186., 135.); norm = vec3(0.020, 0.099, 0.060); return;\\n }\\n }\\n } else {\\n if (id < 1349.) {\\n pos = vec3(557., 186., 215.); norm = vec3(0.020, 0.099, 0.060); return;\\n } else {\\n if (id < 1350.) {\\n pos = vec3(802., 170., 158.); norm = vec3(0.020, 0.099, 0.060); return;\\n } else {\\n pos = vec3(664., 160., -5.); norm = vec3(-0.010, -0.196, 0.009); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1354.) {\\n if (id < 1352.) {\\n pos = vec3(484., 172., 66.); norm = vec3(-0.010, -0.196, 0.009); return;\\n } else {\\n if (id < 1353.) {\\n pos = vec3(651., 159., -42.); norm = vec3(-0.010, -0.196, 0.009); return;\\n } else {\\n pos = vec3(484., 172., 66.); norm = vec3(-0.058, -0.974, 0.027); return;\\n }\\n }\\n } else {\\n if (id < 1356.) {\\n if (id < 1355.) {\\n pos = vec3(587., 162., -71.); norm = vec3(-0.058, -0.974, 0.027); return;\\n } else {\\n pos = vec3(651., 159., -42.); norm = vec3(-0.058, -0.974, 0.027); return;\\n }\\n } else {\\n if (id < 1357.) {\\n pos = vec3(400., 168., -38.); norm = vec3(-0.015, -0.681, 0.038); return;\\n } else {\\n pos = vec3(587., 162., -71.); norm = vec3(-0.015, -0.681, 0.038); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1364.) {\\n if (id < 1361.) {\\n if (id < 1359.) {\\n pos = vec3(484., 172., 66.); norm = vec3(-0.015, -0.681, 0.038); return;\\n } else {\\n if (id < 1360.) {\\n pos = vec3(501., 192., -93.); norm = vec3(0.015, 0.112, -0.093); return;\\n } else {\\n pos = vec3(588., 196., -74.); norm = vec3(0.015, 0.112, -0.093); return;\\n }\\n }\\n } else {\\n if (id < 1362.) {\\n pos = vec3(500., 183., -104.); norm = vec3(0.015, 0.112, -0.093); return;\\n } else {\\n if (id < 1363.) {\\n pos = vec3(500., 183., -104.); norm = vec3(0.330, -0.092, -0.929); return;\\n } else {\\n pos = vec3(588., 196., -74.); norm = vec3(0.330, -0.092, -0.929); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1367.) {\\n if (id < 1365.) {\\n pos = vec3(587., 162., -71.); norm = vec3(0.330, -0.092, -0.929); return;\\n } else {\\n if (id < 1366.) {\\n pos = vec3(725., 159., 20.); norm = vec3(-0.094, 0.042, -0.993); return;\\n } else {\\n pos = vec3(728., 189., 21.); norm = vec3(-0.094, 0.042, -0.993); return;\\n }\\n }\\n } else {\\n if (id < 1369.) {\\n if (id < 1368.) {\\n pos = vec3(876., 165., 6.); norm = vec3(-0.094, 0.042, -0.993); return;\\n } else {\\n pos = vec3(728., 189., 21.); norm = vec3(0.142, 0.873, 0.000); return;\\n }\\n } else {\\n if (id < 1370.) {\\n pos = vec3(728., 189., 85.); norm = vec3(0.142, 0.873, 0.000); return;\\n } else {\\n pos = vec3(876., 165., 6.); norm = vec3(0.142, 0.873, 0.000); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1396.) {\\n if (id < 1383.) {\\n if (id < 1377.) {\\n if (id < 1374.) {\\n if (id < 1372.) {\\n pos = vec3(728., 189., 85.); norm = vec3(0.468, -0.002, 0.878); return;\\n } else {\\n if (id < 1373.) {\\n pos = vec3(726., 161., 86.); norm = vec3(0.468, -0.002, 0.878); return;\\n } else {\\n pos = vec3(876., 165., 6.); norm = vec3(0.468, -0.002, 0.878); return;\\n }\\n }\\n } else {\\n if (id < 1375.) {\\n pos = vec3(726., 161., 86.); norm = vec3(0.042, -0.996, 0.030); return;\\n } else {\\n if (id < 1376.) {\\n pos = vec3(725., 159., 20.); norm = vec3(0.042, -0.996, 0.030); return;\\n } else {\\n pos = vec3(876., 165., 6.); norm = vec3(0.042, -0.996, 0.030); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1380.) {\\n if (id < 1378.) {\\n pos = vec3(664., 160., -5.); norm = vec3(-0.327, 0.118, -0.930); return;\\n } else {\\n if (id < 1379.) {\\n pos = vec3(667., 192., -2.); norm = vec3(-0.327, 0.118, -0.930); return;\\n } else {\\n pos = vec3(800., 167., -52.); norm = vec3(-0.327, 0.118, -0.930); return;\\n }\\n }\\n } else {\\n if (id < 1381.) {\\n pos = vec3(667., 192., -2.); norm = vec3(0.106, 0.893, -0.165); return;\\n } else {\\n if (id < 1382.) {\\n pos = vec3(728., 189., 21.); norm = vec3(0.106, 0.893, -0.165); return;\\n } else {\\n pos = vec3(800., 167., -52.); norm = vec3(0.106, 0.893, -0.165); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1389.) {\\n if (id < 1386.) {\\n if (id < 1384.) {\\n pos = vec3(728., 189., 21.); norm = vec3(0.689, -0.093, 0.708); return;\\n } else {\\n if (id < 1385.) {\\n pos = vec3(725., 159., 20.); norm = vec3(0.689, -0.093, 0.708); return;\\n } else {\\n pos = vec3(800., 167., -52.); norm = vec3(0.689, -0.093, 0.708); return;\\n }\\n }\\n } else {\\n if (id < 1387.) {\\n pos = vec3(725., 159., 20.); norm = vec3(0.013, -0.660, -0.059); return;\\n } else {\\n if (id < 1388.) {\\n pos = vec3(664., 160., -5.); norm = vec3(0.013, -0.660, -0.059); return;\\n } else {\\n pos = vec3(800., 167., -52.); norm = vec3(0.013, -0.660, -0.059); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1392.) {\\n if (id < 1390.) {\\n pos = vec3(651., 159., -42.); norm = vec3(-0.493, 0.004, -0.851); return;\\n } else {\\n if (id < 1391.) {\\n pos = vec3(653., 192., -43.); norm = vec3(-0.493, 0.004, -0.851); return;\\n } else {\\n pos = vec3(727., 170., -86.); norm = vec3(-0.493, 0.004, -0.851); return;\\n }\\n }\\n } else {\\n if (id < 1394.) {\\n if (id < 1393.) {\\n pos = vec3(653., 192., -43.); norm = vec3(0.197, 0.795, -0.067); return;\\n } else {\\n pos = vec3(667., 192., -2.); norm = vec3(0.197, 0.795, -0.067); return;\\n }\\n } else {\\n if (id < 1395.) {\\n pos = vec3(727., 170., -86.); norm = vec3(0.197, 0.795, -0.067); return;\\n } else {\\n pos = vec3(667., 192., -2.); norm = vec3(0.788, -0.130, 0.597); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1409.) {\\n if (id < 1402.) {\\n if (id < 1399.) {\\n if (id < 1397.) {\\n pos = vec3(664., 160., -5.); norm = vec3(0.788, -0.130, 0.597); return;\\n } else {\\n if (id < 1398.) {\\n pos = vec3(727., 170., -86.); norm = vec3(0.788, -0.130, 0.597); return;\\n } else {\\n pos = vec3(664., 160., -5.); norm = vec3(0.130, -0.975, -0.019); return;\\n }\\n }\\n } else {\\n if (id < 1400.) {\\n pos = vec3(651., 159., -42.); norm = vec3(0.130, -0.975, -0.019); return;\\n } else {\\n if (id < 1401.) {\\n pos = vec3(727., 170., -86.); norm = vec3(0.130, -0.975, -0.019); return;\\n } else {\\n pos = vec3(587., 162., -71.); norm = vec3(-0.428, -0.065, -0.877); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1405.) {\\n if (id < 1403.) {\\n pos = vec3(588., 196., -74.); norm = vec3(-0.428, -0.065, -0.877); return;\\n } else {\\n if (id < 1404.) {\\n pos = vec3(659., 174., -107.); norm = vec3(-0.428, -0.065, -0.877); return;\\n } else {\\n pos = vec3(588., 196., -74.); norm = vec3(0.169, 0.903, -0.238); return;\\n }\\n }\\n } else {\\n if (id < 1407.) {\\n if (id < 1406.) {\\n pos = vec3(653., 192., -43.); norm = vec3(0.169, 0.903, -0.238); return;\\n } else {\\n pos = vec3(659., 174., -107.); norm = vec3(0.169, 0.903, -0.238); return;\\n }\\n } else {\\n if (id < 1408.) {\\n pos = vec3(653., 192., -43.); norm = vec3(0.958, -0.055, 0.105); return;\\n } else {\\n pos = vec3(651., 159., -42.); norm = vec3(0.958, -0.055, 0.105); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1415.) {\\n if (id < 1412.) {\\n if (id < 1410.) {\\n pos = vec3(659., 174., -107.); norm = vec3(0.958, -0.055, 0.105); return;\\n } else {\\n if (id < 1411.) {\\n pos = vec3(651., 159., -42.); norm = vec3(0.042, -0.767, -0.172); return;\\n } else {\\n pos = vec3(587., 162., -71.); norm = vec3(0.042, -0.767, -0.172); return;\\n }\\n }\\n } else {\\n if (id < 1413.) {\\n pos = vec3(659., 174., -107.); norm = vec3(0.042, -0.767, -0.172); return;\\n } else {\\n if (id < 1414.) {\\n pos = vec3(782., 160., 118.); norm = vec3(0.072, -0.075, -0.981); return;\\n } else {\\n pos = vec3(783., 187., 116.); norm = vec3(0.072, -0.075, -0.981); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1418.) {\\n if (id < 1416.) {\\n pos = vec3(885., 167., 125.); norm = vec3(0.072, -0.075, -0.981); return;\\n } else {\\n if (id < 1417.) {\\n pos = vec3(783., 187., 116.); norm = vec3(0.185, 0.924, -0.039); return;\\n } else {\\n pos = vec3(792., 186., 135.); norm = vec3(0.185, 0.924, -0.039); return;\\n }\\n }\\n } else {\\n if (id < 1420.) {\\n if (id < 1419.) {\\n pos = vec3(885., 167., 125.); norm = vec3(0.185, 0.924, -0.039); return;\\n } else {\\n pos = vec3(792., 186., 135.); norm = vec3(0.225, 0.842, 0.488); return;\\n }\\n } else {\\n if (id < 1421.) {\\n pos = vec3(802., 170., 158.); norm = vec3(0.225, 0.842, 0.488); return;\\n } else {\\n pos = vec3(885., 167., 125.); norm = vec3(0.225, 0.842, 0.488); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1524.) {\\n if (id < 1473.) {\\n if (id < 1447.) {\\n if (id < 1434.) {\\n if (id < 1428.) {\\n if (id < 1425.) {\\n if (id < 1423.) {\\n pos = vec3(802., 170., 158.); norm = vec3(0.216, -0.730, 0.610); return;\\n } else {\\n if (id < 1424.) {\\n pos = vec3(797., 161., 149.); norm = vec3(0.216, -0.730, 0.610); return;\\n } else {\\n pos = vec3(885., 167., 125.); norm = vec3(0.216, -0.730, 0.610); return;\\n }\\n }\\n } else {\\n if (id < 1426.) {\\n pos = vec3(797., 161., 149.); norm = vec3(0.059, -0.866, -0.001); return;\\n } else {\\n if (id < 1427.) {\\n pos = vec3(782., 160., 118.); norm = vec3(0.059, -0.866, -0.001); return;\\n } else {\\n pos = vec3(885., 167., 125.); norm = vec3(0.059, -0.866, -0.001); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1431.) {\\n if (id < 1429.) {\\n pos = vec3(726., 161., 86.); norm = vec3(-0.074, -0.030, -0.995); return;\\n } else {\\n if (id < 1430.) {\\n pos = vec3(728., 189., 85.); norm = vec3(-0.074, -0.030, -0.995); return;\\n } else {\\n pos = vec3(926., 163., 71.); norm = vec3(-0.074, -0.030, -0.995); return;\\n }\\n }\\n } else {\\n if (id < 1432.) {\\n pos = vec3(728., 189., 85.); norm = vec3(0.087, 0.720, -0.108); return;\\n } else {\\n if (id < 1433.) {\\n pos = vec3(783., 187., 116.); norm = vec3(0.087, 0.720, -0.108); return;\\n } else {\\n pos = vec3(926., 163., 71.); norm = vec3(0.087, 0.720, -0.108); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1440.) {\\n if (id < 1437.) {\\n if (id < 1435.) {\\n pos = vec3(783., 187., 116.); norm = vec3(0.308, 0.059, 0.946); return;\\n } else {\\n if (id < 1436.) {\\n pos = vec3(782., 160., 118.); norm = vec3(0.308, 0.059, 0.946); return;\\n } else {\\n pos = vec3(926., 163., 71.); norm = vec3(0.308, 0.059, 0.946); return;\\n }\\n }\\n } else {\\n if (id < 1438.) {\\n pos = vec3(782., 160., 118.); norm = vec3(0.004, -0.560, -0.024); return;\\n } else {\\n if (id < 1439.) {\\n pos = vec3(726., 161., 86.); norm = vec3(0.004, -0.560, -0.024); return;\\n } else {\\n pos = vec3(926., 163., 71.); norm = vec3(0.004, -0.560, -0.024); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1443.) {\\n if (id < 1441.) {\\n pos = vec3(587., 162., -71.); norm = vec3(-0.039, -0.394, -0.148); return;\\n } else {\\n if (id < 1442.) {\\n pos = vec3(400., 168., -38.); norm = vec3(-0.039, -0.394, -0.148); return;\\n } else {\\n pos = vec3(500., 183., -104.); norm = vec3(-0.039, -0.394, -0.148); return;\\n }\\n }\\n } else {\\n if (id < 1445.) {\\n if (id < 1444.) {\\n pos = vec3(500., 183., -104.); norm = vec3(-0.079, -0.924, -0.330); return;\\n } else {\\n pos = vec3(400., 168., -38.); norm = vec3(-0.079, -0.924, -0.330); return;\\n }\\n } else {\\n if (id < 1446.) {\\n pos = vec3(373., 191., -96.); norm = vec3(-0.079, -0.924, -0.330); return;\\n } else {\\n pos = vec3(667., 192., -2.); norm = vec3(0.060, 0.992, -0.014); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1460.) {\\n if (id < 1453.) {\\n if (id < 1450.) {\\n if (id < 1448.) {\\n pos = vec3(484., 204., 61.); norm = vec3(0.060, 0.992, -0.014); return;\\n } else {\\n if (id < 1449.) {\\n pos = vec3(546., 202., 191.); norm = vec3(0.060, 0.992, -0.014); return;\\n } else {\\n pos = vec3(546., 202., 191.); norm = vec3(0.062, 0.862, 0.000); return;\\n }\\n }\\n } else {\\n if (id < 1451.) {\\n pos = vec3(728., 189., 85.); norm = vec3(0.062, 0.862, 0.000); return;\\n } else {\\n if (id < 1452.) {\\n pos = vec3(728., 189., 21.); norm = vec3(0.062, 0.862, 0.000); return;\\n } else {\\n pos = vec3(667., 192., -2.); norm = vec3(0.014, 0.256, -0.004); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1456.) {\\n if (id < 1454.) {\\n pos = vec3(546., 202., 191.); norm = vec3(0.014, 0.256, -0.004); return;\\n } else {\\n if (id < 1455.) {\\n pos = vec3(728., 189., 21.); norm = vec3(0.014, 0.256, -0.004); return;\\n } else {\\n pos = vec3(667., 192., -2.); norm = vec3(0.057, 0.974, -0.020); return;\\n }\\n }\\n } else {\\n if (id < 1458.) {\\n if (id < 1457.) {\\n pos = vec3(653., 192., -43.); norm = vec3(0.057, 0.974, -0.020); return;\\n } else {\\n pos = vec3(484., 204., 61.); norm = vec3(0.057, 0.974, -0.020); return;\\n }\\n } else {\\n if (id < 1459.) {\\n pos = vec3(484., 204., 61.); norm = vec3(0.055, 0.837, -0.007); return;\\n } else {\\n pos = vec3(653., 192., -43.); norm = vec3(0.055, 0.837, -0.007); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1466.) {\\n if (id < 1463.) {\\n if (id < 1461.) {\\n pos = vec3(588., 196., -74.); norm = vec3(0.055, 0.837, -0.007); return;\\n } else {\\n if (id < 1462.) {\\n pos = vec3(67., 45., -184.); norm = vec3(-0.174, 0.472, -0.482); return;\\n } else {\\n pos = vec3(234., 121., -170.); norm = vec3(-0.174, 0.472, -0.482); return;\\n }\\n }\\n } else {\\n if (id < 1464.) {\\n pos = vec3(219., 95., -190.); norm = vec3(-0.174, 0.472, -0.482); return;\\n } else {\\n if (id < 1465.) {\\n pos = vec3(552., 177., 205.); norm = vec3(-0.043, -0.858, 0.052); return;\\n } else {\\n pos = vec3(484., 172., 66.); norm = vec3(-0.043, -0.858, 0.052); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1469.) {\\n if (id < 1467.) {\\n pos = vec3(726., 161., 86.); norm = vec3(-0.043, -0.858, 0.052); return;\\n } else {\\n if (id < 1468.) {\\n pos = vec3(726., 161., 86.); norm = vec3(-0.013, -0.267, 0.008); return;\\n } else {\\n pos = vec3(484., 172., 66.); norm = vec3(-0.013, -0.267, 0.008); return;\\n }\\n }\\n } else {\\n if (id < 1471.) {\\n if (id < 1470.) {\\n pos = vec3(725., 159., 20.); norm = vec3(-0.013, -0.267, 0.008); return;\\n } else {\\n pos = vec3(484., 172., 66.); norm = vec3(-0.029, -0.691, 0.043); return;\\n }\\n } else {\\n if (id < 1472.) {\\n pos = vec3(664., 160., -5.); norm = vec3(-0.029, -0.691, 0.043); return;\\n } else {\\n pos = vec3(725., 159., 20.); norm = vec3(-0.029, -0.691, 0.043); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1498.) {\\n if (id < 1485.) {\\n if (id < 1479.) {\\n if (id < 1476.) {\\n if (id < 1474.) {\\n pos = vec3(797., 161., 149.); norm = vec3(-0.007, -0.136, 0.008); return;\\n } else {\\n if (id < 1475.) {\\n pos = vec3(552., 177., 205.); norm = vec3(-0.007, -0.136, 0.008); return;\\n } else {\\n pos = vec3(782., 160., 118.); norm = vec3(-0.007, -0.136, 0.008); return;\\n }\\n }\\n } else {\\n if (id < 1477.) {\\n pos = vec3(552., 177., 205.); norm = vec3(-0.046, -0.897, 0.053); return;\\n } else {\\n if (id < 1478.) {\\n pos = vec3(726., 161., 86.); norm = vec3(-0.046, -0.897, 0.053); return;\\n } else {\\n pos = vec3(782., 160., 118.); norm = vec3(-0.046, -0.897, 0.053); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1482.) {\\n if (id < 1480.) {\\n pos = vec3(153., 28., 38.); norm = vec3(0.327, -0.596, 0.095); return;\\n } else {\\n if (id < 1481.) {\\n pos = vec3(152., 42., 129.); norm = vec3(0.327, -0.596, 0.095); return;\\n } else {\\n pos = vec3(115., 15., 87.); norm = vec3(0.327, -0.596, 0.095); return;\\n }\\n }\\n } else {\\n if (id < 1483.) {\\n pos = vec3(153., 28., 38.); norm = vec3(0.400, -0.733, -0.262); return;\\n } else {\\n if (id < 1484.) {\\n pos = vec3(127., 37., -27.); norm = vec3(0.400, -0.733, -0.262); return;\\n } else {\\n pos = vec3(283., 108., 13.); norm = vec3(0.400, -0.733, -0.262); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1491.) {\\n if (id < 1488.) {\\n if (id < 1486.) {\\n pos = vec3(283., 108., 13.); norm = vec3(0.364, -0.764, -0.063); return;\\n } else {\\n if (id < 1487.) {\\n pos = vec3(127., 37., -27.); norm = vec3(0.364, -0.764, -0.063); return;\\n } else {\\n pos = vec3(248., 106., -165.); norm = vec3(0.364, -0.764, -0.063); return;\\n }\\n }\\n } else {\\n if (id < 1489.) {\\n pos = vec3(484., 172., 66.); norm = vec3(0.210, -0.536, -0.149); return;\\n } else {\\n if (id < 1490.) {\\n pos = vec3(283., 108., 13.); norm = vec3(0.210, -0.536, -0.149); return;\\n } else {\\n pos = vec3(400., 168., -38.); norm = vec3(0.210, -0.536, -0.149); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1494.) {\\n if (id < 1492.) {\\n pos = vec3(400., 168., -38.); norm = vec3(0.421, -0.884, -0.073); return;\\n } else {\\n if (id < 1493.) {\\n pos = vec3(283., 108., 13.); norm = vec3(0.421, -0.884, -0.073); return;\\n } else {\\n pos = vec3(248., 106., -165.); norm = vec3(0.421, -0.884, -0.073); return;\\n }\\n }\\n } else {\\n if (id < 1496.) {\\n if (id < 1495.) {\\n pos = vec3(33., 70., 900.); norm = vec3(0.366, 0.899, 0.180); return;\\n } else {\\n pos = vec3(34., 86., 818.); norm = vec3(0.366, 0.899, 0.180); return;\\n }\\n } else {\\n if (id < 1497.) {\\n pos = vec3(6., 98., 815.); norm = vec3(0.366, 0.899, 0.180); return;\\n } else {\\n pos = vec3(84., -214., -707.); norm = vec3(0.435, -0.065, -0.081); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1511.) {\\n if (id < 1504.) {\\n if (id < 1501.) {\\n if (id < 1499.) {\\n pos = vec3(72., -204., -779.); norm = vec3(0.435, -0.065, -0.081); return;\\n } else {\\n if (id < 1500.) {\\n pos = vec3(88., -181., -712.); norm = vec3(0.435, -0.065, -0.081); return;\\n } else {\\n pos = vec3(60., -214., -707.); norm = vec3(-0.963, -0.166, -0.184); return;\\n }\\n }\\n } else {\\n if (id < 1502.) {\\n pos = vec3(56., -182., -715.); norm = vec3(-0.963, -0.166, -0.184); return;\\n } else {\\n if (id < 1503.) {\\n pos = vec3(72., -204., -779.); norm = vec3(-0.963, -0.166, -0.184); return;\\n } else {\\n pos = vec3(72., -204., -779.); norm = vec3(0.001, 0.937, -0.322); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1507.) {\\n if (id < 1505.) {\\n pos = vec3(56., -182., -715.); norm = vec3(0.001, 0.937, -0.322); return;\\n } else {\\n if (id < 1506.) {\\n pos = vec3(88., -181., -712.); norm = vec3(0.001, 0.937, -0.322); return;\\n } else {\\n pos = vec3(60., -214., -707.); norm = vec3(0.000, -0.318, -0.044); return;\\n }\\n }\\n } else {\\n if (id < 1509.) {\\n if (id < 1508.) {\\n pos = vec3(72., -204., -779.); norm = vec3(0.000, -0.318, -0.044); return;\\n } else {\\n pos = vec3(84., -214., -707.); norm = vec3(0.000, -0.318, -0.044); return;\\n }\\n } else {\\n if (id < 1510.) {\\n pos = vec3(-58., -180., -715.); norm = vec3(0.003, 0.480, -0.190); return;\\n } else {\\n pos = vec3(-77., -204., -776.); norm = vec3(0.003, 0.480, -0.190); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1517.) {\\n if (id < 1514.) {\\n if (id < 1512.) {\\n pos = vec3(-95., -179., -713.); norm = vec3(0.003, 0.480, -0.190); return;\\n } else {\\n if (id < 1513.) {\\n pos = vec3(-63., -216., -706.); norm = vec3(0.000, -0.967, -0.166); return;\\n } else {\\n pos = vec3(-91., -216., -706.); norm = vec3(0.000, -0.967, -0.166); return;\\n }\\n }\\n } else {\\n if (id < 1515.) {\\n pos = vec3(-77., -204., -776.); norm = vec3(0.000, -0.967, -0.166); return;\\n } else {\\n if (id < 1516.) {\\n pos = vec3(-77., -204., -776.); norm = vec3(-0.914, -0.138, -0.206); return;\\n } else {\\n pos = vec3(-91., -216., -706.); norm = vec3(-0.914, -0.138, -0.206); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1520.) {\\n if (id < 1518.) {\\n pos = vec3(-95., -179., -713.); norm = vec3(-0.914, -0.138, -0.206); return;\\n } else {\\n if (id < 1519.) {\\n pos = vec3(-63., -216., -706.); norm = vec3(0.488, -0.096, -0.114); return;\\n } else {\\n pos = vec3(-77., -204., -776.); norm = vec3(0.488, -0.096, -0.114); return;\\n }\\n }\\n } else {\\n if (id < 1522.) {\\n if (id < 1521.) {\\n pos = vec3(-58., -180., -715.); norm = vec3(0.488, -0.096, -0.114); return;\\n } else {\\n pos = vec3(-30., -54., -256.); norm = vec3(-0.749, -0.552, -0.219); return;\\n }\\n } else {\\n if (id < 1523.) {\\n pos = vec3(-41., -72., -173.); norm = vec3(-0.749, -0.552, -0.219); return;\\n } else {\\n pos = vec3(-66., -44., -158.); norm = vec3(-0.749, -0.552, -0.219); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1575.) {\\n if (id < 1549.) {\\n if (id < 1536.) {\\n if (id < 1530.) {\\n if (id < 1527.) {\\n if (id < 1525.) {\\n pos = vec3(37., -20., 303.); norm = vec3(0.983, -0.056, 0.168); return;\\n } else {\\n if (id < 1526.) {\\n pos = vec3(55., -25., 196.); norm = vec3(0.983, -0.056, 0.168); return;\\n } else {\\n pos = vec3(57., 10., 196.); norm = vec3(0.983, -0.056, 0.168); return;\\n }\\n }\\n } else {\\n if (id < 1528.) {\\n pos = vec3(-57., 10., 196.); norm = vec3(-0.982, -0.056, 0.177); return;\\n } else {\\n if (id < 1529.) {\\n pos = vec3(-55., -25., 196.); norm = vec3(-0.982, -0.056, 0.177); return;\\n } else {\\n pos = vec3(-36., -20., 303.); norm = vec3(-0.982, -0.056, 0.177); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1533.) {\\n if (id < 1531.) {\\n pos = vec3(44., 66., 866.); norm = vec3(0.347, 0.064, 0.105); return;\\n } else {\\n if (id < 1532.) {\\n pos = vec3(48., 77., 846.); norm = vec3(0.347, 0.064, 0.105); return;\\n } else {\\n pos = vec3(33., 70., 900.); norm = vec3(0.347, 0.064, 0.105); return;\\n }\\n }\\n } else {\\n if (id < 1534.) {\\n pos = vec3(36., 36., 902.); norm = vec3(0.398, -0.049, 0.081); return;\\n } else {\\n if (id < 1535.) {\\n pos = vec3(45., 33., 856.); norm = vec3(0.398, -0.049, 0.081); return;\\n } else {\\n pos = vec3(40., 52., 892.); norm = vec3(0.398, -0.049, 0.081); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1542.) {\\n if (id < 1539.) {\\n if (id < 1537.) {\\n pos = vec3(45., 33., 856.); norm = vec3(0.837, -0.201, -0.209); return;\\n } else {\\n if (id < 1538.) {\\n pos = vec3(37., 35., 822.); norm = vec3(0.837, -0.201, -0.209); return;\\n } else {\\n pos = vec3(46., 59., 835.); norm = vec3(0.837, -0.201, -0.209); return;\\n }\\n }\\n } else {\\n if (id < 1540.) {\\n pos = vec3(43., 48., 861.); norm = vec3(0.457, 0.269, 0.166); return;\\n } else {\\n if (id < 1541.) {\\n pos = vec3(46., 59., 835.); norm = vec3(0.457, 0.269, 0.166); return;\\n } else {\\n pos = vec3(39., 61., 851.); norm = vec3(0.457, 0.269, 0.166); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1545.) {\\n if (id < 1543.) {\\n pos = vec3(41., 54., 874.); norm = vec3(0.528, -0.471, -0.509); return;\\n } else {\\n if (id < 1544.) {\\n pos = vec3(33., 58., 862.); norm = vec3(0.528, -0.471, -0.509); return;\\n } else {\\n pos = vec3(44., 66., 866.); norm = vec3(0.528, -0.471, -0.509); return;\\n }\\n }\\n } else {\\n if (id < 1547.) {\\n if (id < 1546.) {\\n pos = vec3(43., 48., 861.); norm = vec3(0.408, 0.040, 0.045); return;\\n } else {\\n pos = vec3(41., 54., 874.); norm = vec3(0.408, 0.040, 0.045); return;\\n }\\n } else {\\n if (id < 1548.) {\\n pos = vec3(45., 33., 856.); norm = vec3(0.408, 0.040, 0.045); return;\\n } else {\\n pos = vec3(45., 33., 856.); norm = vec3(0.817, 0.107, 0.057); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1562.) {\\n if (id < 1555.) {\\n if (id < 1552.) {\\n if (id < 1550.) {\\n pos = vec3(41., 54., 874.); norm = vec3(0.817, 0.107, 0.057); return;\\n } else {\\n if (id < 1551.) {\\n pos = vec3(40., 52., 892.); norm = vec3(0.817, 0.107, 0.057); return;\\n } else {\\n pos = vec3(33., 58., 862.); norm = vec3(0.468, -0.679, 0.070); return;\\n }\\n }\\n } else {\\n if (id < 1553.) {\\n pos = vec3(39., 61., 851.); norm = vec3(0.468, -0.679, 0.070); return;\\n } else {\\n if (id < 1554.) {\\n pos = vec3(44., 66., 866.); norm = vec3(0.468, -0.679, 0.070); return;\\n } else {\\n pos = vec3(48., 77., 846.); norm = vec3(0.835, 0.136, -0.374); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1558.) {\\n if (id < 1556.) {\\n pos = vec3(46., 59., 835.); norm = vec3(0.835, 0.136, -0.374); return;\\n } else {\\n if (id < 1557.) {\\n pos = vec3(34., 86., 818.); norm = vec3(0.835, 0.136, -0.374); return;\\n } else {\\n pos = vec3(34., 86., 818.); norm = vec3(0.775, 0.003, -0.542); return;\\n }\\n }\\n } else {\\n if (id < 1560.) {\\n if (id < 1559.) {\\n pos = vec3(46., 59., 835.); norm = vec3(0.775, 0.003, -0.542); return;\\n } else {\\n pos = vec3(37., 35., 822.); norm = vec3(0.775, 0.003, -0.542); return;\\n }\\n } else {\\n if (id < 1561.) {\\n pos = vec3(41., 54., 874.); norm = vec3(0.605, 0.625, -0.195); return;\\n } else {\\n pos = vec3(43., 48., 861.); norm = vec3(0.605, 0.625, -0.195); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1568.) {\\n if (id < 1565.) {\\n if (id < 1563.) {\\n pos = vec3(33., 58., 862.); norm = vec3(0.605, 0.625, -0.195); return;\\n } else {\\n if (id < 1564.) {\\n pos = vec3(43., 48., 861.); norm = vec3(0.520, 0.478, 0.414); return;\\n } else {\\n pos = vec3(39., 61., 851.); norm = vec3(0.520, 0.478, 0.414); return;\\n }\\n }\\n } else {\\n if (id < 1566.) {\\n pos = vec3(33., 58., 862.); norm = vec3(0.520, 0.478, 0.414); return;\\n } else {\\n if (id < 1567.) {\\n pos = vec3(44., 66., 866.); norm = vec3(0.840, -0.507, -0.111); return;\\n } else {\\n pos = vec3(39., 61., 851.); norm = vec3(0.840, -0.507, -0.111); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1571.) {\\n if (id < 1569.) {\\n pos = vec3(48., 77., 846.); norm = vec3(0.840, -0.507, -0.111); return;\\n } else {\\n if (id < 1570.) {\\n pos = vec3(48., 77., 846.); norm = vec3(0.795, -0.326, 0.389); return;\\n } else {\\n pos = vec3(39., 61., 851.); norm = vec3(0.795, -0.326, 0.389); return;\\n }\\n }\\n } else {\\n if (id < 1573.) {\\n if (id < 1572.) {\\n pos = vec3(46., 59., 835.); norm = vec3(0.795, -0.326, 0.389); return;\\n } else {\\n pos = vec3(45., 33., 856.); norm = vec3(0.469, 0.039, 0.071); return;\\n }\\n } else {\\n if (id < 1574.) {\\n pos = vec3(46., 59., 835.); norm = vec3(0.469, 0.039, 0.071); return;\\n } else {\\n pos = vec3(43., 48., 861.); norm = vec3(0.469, 0.039, 0.071); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1600.) {\\n if (id < 1587.) {\\n if (id < 1581.) {\\n if (id < 1578.) {\\n if (id < 1576.) {\\n pos = vec3(40., 52., 892.); norm = vec3(0.541, 0.140, 0.159); return;\\n } else {\\n if (id < 1577.) {\\n pos = vec3(44., 66., 866.); norm = vec3(0.541, 0.140, 0.159); return;\\n } else {\\n pos = vec3(33., 70., 900.); norm = vec3(0.541, 0.140, 0.159); return;\\n }\\n }\\n } else {\\n if (id < 1579.) {\\n pos = vec3(-27., 53., 892.); norm = vec3(-0.481, -0.104, 0.042); return;\\n } else {\\n if (id < 1580.) {\\n pos = vec3(-32., 66., 867.); norm = vec3(-0.481, -0.104, 0.042); return;\\n } else {\\n pos = vec3(-29., 55., 874.); norm = vec3(-0.481, -0.104, 0.042); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1584.) {\\n if (id < 1582.) {\\n pos = vec3(-23., 87., 818.); norm = vec3(-0.151, 0.591, 0.121); return;\\n } else {\\n if (id < 1583.) {\\n pos = vec3(-35., 78., 847.); norm = vec3(-0.151, 0.591, 0.121); return;\\n } else {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.151, 0.591, 0.121); return;\\n }\\n }\\n } else {\\n if (id < 1585.) {\\n pos = vec3(-32., 66., 867.); norm = vec3(-0.616, -0.380, -0.136); return;\\n } else {\\n if (id < 1586.) {\\n pos = vec3(-35., 78., 847.); norm = vec3(-0.616, -0.380, -0.136); return;\\n } else {\\n pos = vec3(-26., 62., 851.); norm = vec3(-0.616, -0.380, -0.136); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1593.) {\\n if (id < 1590.) {\\n if (id < 1588.) {\\n pos = vec3(-26., 62., 851.); norm = vec3(-0.610, -0.249, 0.375); return;\\n } else {\\n if (id < 1589.) {\\n pos = vec3(-35., 78., 847.); norm = vec3(-0.610, -0.249, 0.375); return;\\n } else {\\n pos = vec3(-34., 59., 836.); norm = vec3(-0.610, -0.249, 0.375); return;\\n }\\n }\\n } else {\\n if (id < 1591.) {\\n pos = vec3(-34., 59., 836.); norm = vec3(-0.833, 0.069, 0.127); return;\\n } else {\\n if (id < 1592.) {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.833, 0.069, 0.127); return;\\n } else {\\n pos = vec3(-31., 49., 861.); norm = vec3(-0.833, 0.069, 0.127); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1596.) {\\n if (id < 1594.) {\\n pos = vec3(-21., 58., 862.); norm = vec3(-0.569, 0.656, -0.215); return;\\n } else {\\n if (id < 1595.) {\\n pos = vec3(-31., 49., 861.); norm = vec3(-0.569, 0.656, -0.215); return;\\n } else {\\n pos = vec3(-29., 55., 874.); norm = vec3(-0.569, 0.656, -0.215); return;\\n }\\n }\\n } else {\\n if (id < 1598.) {\\n if (id < 1597.) {\\n pos = vec3(-26., 62., 851.); norm = vec3(-0.445, 0.454, 0.367); return;\\n } else {\\n pos = vec3(-31., 49., 861.); norm = vec3(-0.445, 0.454, 0.367); return;\\n }\\n } else {\\n if (id < 1599.) {\\n pos = vec3(-21., 58., 862.); norm = vec3(-0.445, 0.454, 0.367); return;\\n } else {\\n pos = vec3(-32., 66., 867.); norm = vec3(-0.483, -0.654, -0.018); return;\\n }\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1613.) {\\n if (id < 1606.) {\\n if (id < 1603.) {\\n if (id < 1601.) {\\n pos = vec3(-26., 62., 851.); norm = vec3(-0.483, -0.654, -0.018); return;\\n } else {\\n if (id < 1602.) {\\n pos = vec3(-21., 58., 862.); norm = vec3(-0.483, -0.654, -0.018); return;\\n } else {\\n pos = vec3(-29., 55., 874.); norm = vec3(-0.573, -0.475, -0.500); return;\\n }\\n }\\n } else {\\n if (id < 1604.) {\\n pos = vec3(-32., 66., 867.); norm = vec3(-0.573, -0.475, -0.500); return;\\n } else {\\n if (id < 1605.) {\\n pos = vec3(-21., 58., 862.); norm = vec3(-0.573, -0.475, -0.500); return;\\n } else {\\n pos = vec3(-34., 59., 836.); norm = vec3(-0.484, 0.334, 0.192); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1609.) {\\n if (id < 1607.) {\\n pos = vec3(-31., 49., 861.); norm = vec3(-0.484, 0.334, 0.192); return;\\n } else {\\n if (id < 1608.) {\\n pos = vec3(-26., 62., 851.); norm = vec3(-0.484, 0.334, 0.192); return;\\n } else {\\n pos = vec3(-34., 59., 836.); norm = vec3(-0.839, -0.180, -0.183); return;\\n }\\n }\\n } else {\\n if (id < 1611.) {\\n if (id < 1610.) {\\n pos = vec3(-26., 35., 823.); norm = vec3(-0.839, -0.180, -0.183); return;\\n } else {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.839, -0.180, -0.183); return;\\n }\\n } else {\\n if (id < 1612.) {\\n pos = vec3(-27., 53., 892.); norm = vec3(-0.398, -0.021, 0.078); return;\\n } else {\\n pos = vec3(-33., 34., 856.); norm = vec3(-0.398, -0.021, 0.078); return;\\n }\\n }\\n }\\n }\\n } else {\\n if (id < 1619.) {\\n if (id < 1616.) {\\n if (id < 1614.) {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.398, -0.021, 0.078); return;\\n } else {\\n if (id < 1615.) {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.546, 0.133, 0.178); return;\\n } else {\\n pos = vec3(-32., 66., 867.); norm = vec3(-0.546, 0.133, 0.178); return;\\n }\\n }\\n } else {\\n if (id < 1617.) {\\n pos = vec3(-27., 53., 892.); norm = vec3(-0.546, 0.133, 0.178); return;\\n } else {\\n if (id < 1618.) {\\n pos = vec3(-20., 71., 900.); norm = vec3(-0.380, 0.108, 0.122); return;\\n } else {\\n pos = vec3(-35., 78., 847.); norm = vec3(-0.380, 0.108, 0.122); return;\\n }\\n }\\n }\\n } else {\\n if (id < 1622.) {\\n if (id < 1620.) {\\n pos = vec3(-32., 66., 867.); norm = vec3(-0.380, 0.108, 0.122); return;\\n } else {\\n if (id < 1621.) {\\n pos = vec3(-16., 7., 978.); norm = vec3(-0.451, -0.071, 0.020); return;\\n } else {\\n pos = vec3(-27., 53., 892.); norm = vec3(-0.451, -0.071, 0.020); return;\\n }\\n }\\n } else {\\n if (id < 1624.) {\\n if (id < 1623.) {\\n pos = vec3(-24., 37., 903.); norm = vec3(-0.451, -0.071, 0.020); return;\\n } else {\\n pos = vec3(33., 70., 900.); norm = vec3(0.195, 0.052, 0.052); return;\\n }\\n } else {\\n if (id < 1625.) {\\n pos = vec3(29., 7., 978.); norm = vec3(0.195, 0.052, 0.052); return;\\n } else {\\n pos = vec3(40., 52., 892.); norm = vec3(0.195, 0.052, 0.052); return;\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n }\\n}\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n float pointId = mod(vertexId, NUM_VERTS_0);\\n float modelId = floor(vertexId / NUM_VERTS_0);\\n \\n vec3 pos;\\n vec3 normal;\\n getVert0(pointId, pos, normal);\\n \\n float tt = time * 4. * mix(0.8, 1.2, hash(modelId * 0.23));\\n pos.y += sin(abs(pos.x) * 0.001) * sin(-tt + abs(pos.x * -0.001)) * 300.;\\n\\n float tm = time * 0.5;\\n float r = 1500.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 1., 10000.0);\\n vec3 eye = vec3(cos(tm * 0.9) * r, sin(tm * 0.9) * r, 6000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(\\n vec3(\\n t2m1(hash(modelId * 0.121)), \\n t2m1(hash(modelId * 0.312)) + sin(-tt + PI + 0.75) * 0.01, \\n t2m1(hash(modelId * 0.717))) * 4000.);\\n// mat *= rotX(time + abs(ca) * 5.);\\n// mat *= rotZ(time + abs(cd) * 6.);\\n// mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = pos.z / 10000. + mix(0.9, 1.1, hash(modelId * 0.17));//abs(ca * cd) * 2.;\\n float sat = 0.5;//mix(1., 0., abs(ca));\\n float val = 1.0;//mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//\t\t\"description\"\t: \"3D assets and textures for ROME - 3 Dreams of Black - at http://ro.me are licensed under a Creative CommonsAttribution-NonCommercial-ShareAlike 3.0 Unported License ( http://creativecommons.org/licenses/by-nc-sa/3.0/ ).\"\n\n\n#define NUM_VERTS_0 1626.\nvoid getVert0(in float id, out vec3 pos, out vec3 norm) {\n if (id < 813.) {\n if (id < 406.) {\n if (id < 203.) {\n if (id < 101.) {\n if (id < 50.) {\n if (id < 25.) {\n if (id < 12.) {\n if (id < 6.) {\n if (id < 3.) {\n if (id < 1.) {\n pos = vec3(0., 99., 84.); norm = vec3(-0.159, 0.803, 0.379); return;\n } else {\n if (id < 2.) {\n pos = vec3(-93., 56., 136.); norm = vec3(-0.159, 0.803, 0.379); return;\n } else {\n pos = vec3(0., 48., 192.); norm = vec3(-0.159, 0.803, 0.379); return;\n }\n }\n } else {\n if (id < 4.) {\n pos = vec3(0., 48., 192.); norm = vec3(-0.095, 0.178, 0.183); return;\n } else {\n if (id < 5.) {\n pos = vec3(-93., 56., 136.); norm = vec3(-0.095, 0.178, 0.183); return;\n } else {\n pos = vec3(-28., 31., 194.); norm = vec3(-0.095, 0.178, 0.183); return;\n }\n }\n }\n } else {\n if (id < 9.) {\n if (id < 7.) {\n pos = vec3(-30., -54., -256.); norm = vec3(-0.269, -0.018, -0.097); return;\n } else {\n if (id < 8.) {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.269, -0.018, -0.097); return;\n } else {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.269, -0.018, -0.097); return;\n }\n }\n } else {\n if (id < 10.) {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.837, -0.109, -0.313); return;\n } else {\n if (id < 11.) {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.837, -0.109, -0.313); return;\n } else {\n pos = vec3(-68., 46., -184.); norm = vec3(-0.837, -0.109, -0.313); return;\n }\n }\n }\n }\n } else {\n if (id < 18.) {\n if (id < 15.) {\n if (id < 13.) {\n pos = vec3(0., -11., -266.); norm = vec3(-0.378, 0.646, -0.567); return;\n } else {\n if (id < 14.) {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.378, 0.646, -0.567); return;\n } else {\n pos = vec3(0., 67., -177.); norm = vec3(-0.378, 0.646, -0.567); return;\n }\n }\n } else {\n if (id < 16.) {\n pos = vec3(0., 67., -177.); norm = vec3(-0.110, 0.229, -0.209); return;\n } else {\n if (id < 17.) {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.110, 0.229, -0.209); return;\n } else {\n pos = vec3(-40., 66., -157.); norm = vec3(-0.110, 0.229, -0.209); return;\n }\n }\n }\n } else {\n if (id < 21.) {\n if (id < 19.) {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.236, -0.013, 0.125); return;\n } else {\n if (id < 20.) {\n pos = vec3(-115., 15., 87.); norm = vec3(-0.236, -0.013, 0.125); return;\n } else {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.236, -0.013, 0.125); return;\n }\n }\n } else {\n if (id < 23.) {\n if (id < 22.) {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.872, -0.318, 0.363); return;\n } else {\n pos = vec3(-115., 15., 87.); norm = vec3(-0.872, -0.318, 0.363); return;\n }\n } else {\n if (id < 24.) {\n pos = vec3(-95., -81., 51.); norm = vec3(-0.872, -0.318, 0.363); return;\n } else {\n pos = vec3(-63., 88., -94.); norm = vec3(-0.012, 0.726, -0.258); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 37.) {\n if (id < 31.) {\n if (id < 28.) {\n if (id < 26.) {\n pos = vec3(0., 94., -80.); norm = vec3(-0.012, 0.726, -0.258); return;\n } else {\n if (id < 27.) {\n pos = vec3(-40., 66., -157.); norm = vec3(-0.012, 0.726, -0.258); return;\n } else {\n pos = vec3(-40., 66., -157.); norm = vec3(-0.069, 0.423, -0.118); return;\n }\n }\n } else {\n if (id < 29.) {\n pos = vec3(0., 94., -80.); norm = vec3(-0.069, 0.423, -0.118); return;\n } else {\n if (id < 30.) {\n pos = vec3(0., 67., -177.); norm = vec3(-0.069, 0.423, -0.118); return;\n } else {\n pos = vec3(-68., 46., -184.); norm = vec3(-0.707, -0.202, -0.646); return;\n }\n }\n }\n } else {\n if (id < 34.) {\n if (id < 32.) {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.707, -0.202, -0.646); return;\n } else {\n if (id < 33.) {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.707, -0.202, -0.646); return;\n } else {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.712, -0.153, -0.681); return;\n }\n }\n } else {\n if (id < 35.) {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.712, -0.153, -0.681); return;\n } else {\n if (id < 36.) {\n pos = vec3(-70., -61., -150.); norm = vec3(-0.712, -0.153, -0.681); return;\n } else {\n pos = vec3(-63., 88., -94.); norm = vec3(-0.034, 0.610, -0.109); return;\n }\n }\n }\n }\n } else {\n if (id < 43.) {\n if (id < 40.) {\n if (id < 38.) {\n pos = vec3(-85., 100., -20.); norm = vec3(-0.034, 0.610, -0.109); return;\n } else {\n if (id < 39.) {\n pos = vec3(0., 94., -80.); norm = vec3(-0.034, 0.610, -0.109); return;\n } else {\n pos = vec3(0., 94., -80.); norm = vec3(-0.055, 0.646, -0.143); return;\n }\n }\n } else {\n if (id < 41.) {\n pos = vec3(-85., 100., -20.); norm = vec3(-0.055, 0.646, -0.143); return;\n } else {\n if (id < 42.) {\n pos = vec3(0., 109., -12.); norm = vec3(-0.055, 0.646, -0.143); return;\n } else {\n pos = vec3(0., -132., 23.); norm = vec3(-0.067, -0.269, 0.062); return;\n }\n }\n }\n } else {\n if (id < 46.) {\n if (id < 44.) {\n pos = vec3(0., -81., 243.); norm = vec3(-0.067, -0.269, 0.062); return;\n } else {\n if (id < 45.) {\n pos = vec3(-64., -116., 23.); norm = vec3(-0.067, -0.269, 0.062); return;\n } else {\n pos = vec3(-63., 88., -94.); norm = vec3(-0.216, 0.773, -0.349); return;\n }\n }\n } else {\n if (id < 48.) {\n if (id < 47.) {\n pos = vec3(-40., 66., -157.); norm = vec3(-0.216, 0.773, -0.349); return;\n } else {\n pos = vec3(-68., 46., -184.); norm = vec3(-0.216, 0.773, -0.349); return;\n }\n } else {\n if (id < 49.) {\n pos = vec3(-68., 46., -184.); norm = vec3(0.061, 0.522, -0.450); return;\n } else {\n pos = vec3(-40., 66., -157.); norm = vec3(0.061, 0.522, -0.450); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 75.) {\n if (id < 62.) {\n if (id < 56.) {\n if (id < 53.) {\n if (id < 51.) {\n pos = vec3(-31., -23., -259.); norm = vec3(0.061, 0.522, -0.450); return;\n } else {\n if (id < 52.) {\n pos = vec3(-115., 15., 87.); norm = vec3(-0.456, -0.043, 0.240); return;\n } else {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.456, -0.043, 0.240); return;\n }\n }\n } else {\n if (id < 54.) {\n pos = vec3(-93., 56., 136.); norm = vec3(-0.456, -0.043, 0.240); return;\n } else {\n if (id < 55.) {\n pos = vec3(-93., 56., 136.); norm = vec3(-0.389, 0.603, 0.696); return;\n } else {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.389, 0.603, 0.696); return;\n }\n }\n }\n } else {\n if (id < 59.) {\n if (id < 57.) {\n pos = vec3(-28., 31., 194.); norm = vec3(-0.389, 0.603, 0.696); return;\n } else {\n if (id < 58.) {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.344, -0.114, 0.066); return;\n } else {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.344, -0.114, 0.066); return;\n }\n }\n } else {\n if (id < 60.) {\n pos = vec3(-27., -56., 288.); norm = vec3(-0.344, -0.114, 0.066); return;\n } else {\n if (id < 61.) {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.570, 0.342, 0.208); return;\n } else {\n pos = vec3(-32., -3., 286.); norm = vec3(-0.570, 0.342, 0.208); return;\n }\n }\n }\n }\n } else {\n if (id < 68.) {\n if (id < 65.) {\n if (id < 63.) {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.570, 0.342, 0.208); return;\n } else {\n if (id < 64.) {\n pos = vec3(0., 11., 276.); norm = vec3(-0.167, 0.469, 0.123); return;\n } else {\n pos = vec3(0., 22., 234.); norm = vec3(-0.167, 0.469, 0.123); return;\n }\n }\n } else {\n if (id < 66.) {\n pos = vec3(-32., -3., 286.); norm = vec3(-0.167, 0.469, 0.123); return;\n } else {\n if (id < 67.) {\n pos = vec3(-32., -3., 286.); norm = vec3(-0.343, 0.911, 0.227); return;\n } else {\n pos = vec3(0., 22., 234.); norm = vec3(-0.343, 0.911, 0.227); return;\n }\n }\n }\n } else {\n if (id < 71.) {\n if (id < 69.) {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.343, 0.911, 0.227); return;\n } else {\n if (id < 70.) {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.357, 0.925, 0.123); return;\n } else {\n pos = vec3(1., -8., 420.); norm = vec3(-0.357, 0.925, 0.123); return;\n }\n }\n } else {\n if (id < 73.) {\n if (id < 72.) {\n pos = vec3(-32., -3., 286.); norm = vec3(-0.357, 0.925, 0.123); return;\n } else {\n pos = vec3(-32., -3., 286.); norm = vec3(-0.091, 0.230, 0.031); return;\n }\n } else {\n if (id < 74.) {\n pos = vec3(1., -8., 420.); norm = vec3(-0.091, 0.230, 0.031); return;\n } else {\n pos = vec3(0., 11., 276.); norm = vec3(-0.091, 0.230, 0.031); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 88.) {\n if (id < 81.) {\n if (id < 78.) {\n if (id < 76.) {\n pos = vec3(1., -58., 357.); norm = vec3(-0.373, -0.577, 0.119); return;\n } else {\n if (id < 77.) {\n pos = vec3(-30., -39., 352.); norm = vec3(-0.373, -0.577, 0.119); return;\n } else {\n pos = vec3(1., -65., 323.); norm = vec3(-0.373, -0.577, 0.119); return;\n }\n }\n } else {\n if (id < 79.) {\n pos = vec3(1., -65., 323.); norm = vec3(-0.693, -0.643, -0.164); return;\n } else {\n if (id < 80.) {\n pos = vec3(-30., -39., 352.); norm = vec3(-0.693, -0.643, -0.164); return;\n } else {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.693, -0.643, -0.164); return;\n }\n }\n }\n } else {\n if (id < 84.) {\n if (id < 82.) {\n pos = vec3(5., 13., 811.); norm = vec3(-0.249, -0.343, 0.114); return;\n } else {\n if (id < 83.) {\n pos = vec3(-20., -1., 714.); norm = vec3(-0.249, -0.343, 0.114); return;\n } else {\n pos = vec3(2., -71., 551.); norm = vec3(-0.249, -0.343, 0.114); return;\n }\n }\n } else {\n if (id < 86.) {\n if (id < 85.) {\n pos = vec3(2., -71., 551.); norm = vec3(-0.078, -0.143, 0.051); return;\n } else {\n pos = vec3(-20., -1., 714.); norm = vec3(-0.078, -0.143, 0.051); return;\n }\n } else {\n if (id < 87.) {\n pos = vec3(-25., -56., 552.); norm = vec3(-0.078, -0.143, 0.051); return;\n } else {\n pos = vec3(-69., -74., -154.); norm = vec3(-0.145, -0.935, -0.311); return;\n }\n }\n }\n }\n } else {\n if (id < 94.) {\n if (id < 91.) {\n if (id < 89.) {\n pos = vec3(-41., -72., -173.); norm = vec3(-0.145, -0.935, -0.311); return;\n } else {\n if (id < 90.) {\n pos = vec3(0., -94., -126.); norm = vec3(-0.145, -0.935, -0.311); return;\n } else {\n pos = vec3(0., -70., -189.); norm = vec3(-0.058, -0.579, -0.221); return;\n }\n }\n } else {\n if (id < 92.) {\n pos = vec3(0., -94., -126.); norm = vec3(-0.058, -0.579, -0.221); return;\n } else {\n if (id < 93.) {\n pos = vec3(-41., -72., -173.); norm = vec3(-0.058, -0.579, -0.221); return;\n } else {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.706, -0.276, -0.195); return;\n }\n }\n }\n } else {\n if (id < 97.) {\n if (id < 95.) {\n pos = vec3(-82., -108., -138.); norm = vec3(-0.706, -0.276, -0.195); return;\n } else {\n if (id < 96.) {\n pos = vec3(-137., -28., -52.); norm = vec3(-0.706, -0.276, -0.195); return;\n } else {\n pos = vec3(-137., -28., -52.); norm = vec3(-0.516, -0.374, 0.018); return;\n }\n }\n } else {\n if (id < 99.) {\n if (id < 98.) {\n pos = vec3(-82., -108., -138.); norm = vec3(-0.516, -0.374, 0.018); return;\n } else {\n pos = vec3(-95., -81., 51.); norm = vec3(-0.516, -0.374, 0.018); return;\n }\n } else {\n if (id < 100.) {\n pos = vec3(-82., -108., -138.); norm = vec3(-0.663, -0.622, 0.043); return;\n } else {\n pos = vec3(-64., -116., 23.); norm = vec3(-0.663, -0.622, 0.043); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 152.) {\n if (id < 126.) {\n if (id < 113.) {\n if (id < 107.) {\n if (id < 104.) {\n if (id < 102.) {\n pos = vec3(-95., -81., 51.); norm = vec3(-0.663, -0.622, 0.043); return;\n } else {\n if (id < 103.) {\n pos = vec3(-95., -81., 51.); norm = vec3(-0.329, -0.527, 0.294); return;\n } else {\n pos = vec3(-64., -116., 23.); norm = vec3(-0.329, -0.527, 0.294); return;\n }\n }\n } else {\n if (id < 105.) {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.329, -0.527, 0.294); return;\n } else {\n if (id < 106.) {\n pos = vec3(-64., -116., 23.); norm = vec3(-0.084, -0.335, -0.019); return;\n } else {\n pos = vec3(-64., -106., -155.); norm = vec3(-0.084, -0.335, -0.019); return;\n }\n }\n }\n } else {\n if (id < 110.) {\n if (id < 108.) {\n pos = vec3(0., -132., 23.); norm = vec3(-0.084, -0.335, -0.019); return;\n } else {\n if (id < 109.) {\n pos = vec3(-24., -34., 549.); norm = vec3(-0.096, 0.144, -0.050); return;\n } else {\n pos = vec3(-25., 20., 706.); norm = vec3(-0.096, 0.144, -0.050); return;\n }\n }\n } else {\n if (id < 111.) {\n pos = vec3(2., -19., 542.); norm = vec3(-0.096, 0.144, -0.050); return;\n } else {\n if (id < 112.) {\n pos = vec3(2., -19., 542.); norm = vec3(-0.455, 0.832, -0.273); return;\n } else {\n pos = vec3(-25., 20., 706.); norm = vec3(-0.455, 0.832, -0.273); return;\n }\n }\n }\n }\n } else {\n if (id < 119.) {\n if (id < 116.) {\n if (id < 114.) {\n pos = vec3(3., 34., 702.); norm = vec3(-0.455, 0.832, -0.273); return;\n } else {\n if (id < 115.) {\n pos = vec3(-70., -61., -150.); norm = vec3(-0.294, 0.014, -0.118); return;\n } else {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.294, 0.014, -0.118); return;\n }\n }\n } else {\n if (id < 117.) {\n pos = vec3(-69., -74., -154.); norm = vec3(-0.294, 0.014, -0.118); return;\n } else {\n if (id < 118.) {\n pos = vec3(-69., -74., -154.); norm = vec3(-0.457, -0.045, -0.678); return;\n } else {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.457, -0.045, -0.678); return;\n }\n }\n }\n } else {\n if (id < 122.) {\n if (id < 120.) {\n pos = vec3(-41., -72., -173.); norm = vec3(-0.457, -0.045, -0.678); return;\n } else {\n if (id < 121.) {\n pos = vec3(-64., -116., 23.); norm = vec3(-0.659, -0.429, 0.260); return;\n } else {\n pos = vec3(0., -81., 243.); norm = vec3(-0.659, -0.429, 0.260); return;\n }\n }\n } else {\n if (id < 124.) {\n if (id < 123.) {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.659, -0.429, 0.260); return;\n } else {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.695, -0.704, -0.026); return;\n }\n } else {\n if (id < 125.) {\n pos = vec3(0., -81., 243.); norm = vec3(-0.695, -0.704, -0.026); return;\n } else {\n pos = vec3(-27., -56., 288.); norm = vec3(-0.695, -0.704, -0.026); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 139.) {\n if (id < 132.) {\n if (id < 129.) {\n if (id < 127.) {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.762, -0.402, 0.507); return;\n } else {\n if (id < 128.) {\n pos = vec3(-27., -56., 288.); norm = vec3(-0.762, -0.402, 0.507); return;\n } else {\n pos = vec3(1., -65., 323.); norm = vec3(-0.762, -0.402, 0.507); return;\n }\n }\n } else {\n if (id < 130.) {\n pos = vec3(1., -65., 323.); norm = vec3(-0.482, -0.830, 0.172); return;\n } else {\n if (id < 131.) {\n pos = vec3(-27., -56., 288.); norm = vec3(-0.482, -0.830, 0.172); return;\n } else {\n pos = vec3(0., -81., 243.); norm = vec3(-0.482, -0.830, 0.172); return;\n }\n }\n }\n } else {\n if (id < 135.) {\n if (id < 133.) {\n pos = vec3(-56., -92., -163.); norm = vec3(0.370, 0.533, -0.532); return;\n } else {\n if (id < 134.) {\n pos = vec3(-69., -74., -154.); norm = vec3(0.370, 0.533, -0.532); return;\n } else {\n pos = vec3(0., -94., -126.); norm = vec3(0.370, 0.533, -0.532); return;\n }\n }\n } else {\n if (id < 137.) {\n if (id < 136.) {\n pos = vec3(-23., 87., 818.); norm = vec3(-0.351, 0.797, -0.475); return;\n } else {\n pos = vec3(6., 98., 815.); norm = vec3(-0.351, 0.797, -0.475); return;\n }\n } else {\n if (id < 138.) {\n pos = vec3(4., 59., 751.); norm = vec3(-0.351, 0.797, -0.475); return;\n } else {\n pos = vec3(1., -66., 421.); norm = vec3(-0.572, -0.665, -0.083); return;\n }\n }\n }\n }\n } else {\n if (id < 145.) {\n if (id < 142.) {\n if (id < 140.) {\n pos = vec3(-25., -44., 424.); norm = vec3(-0.572, -0.665, -0.083); return;\n } else {\n if (id < 141.) {\n pos = vec3(1., -58., 357.); norm = vec3(-0.572, -0.665, -0.083); return;\n } else {\n pos = vec3(1., -58., 357.); norm = vec3(-0.254, -0.417, -0.011); return;\n }\n }\n } else {\n if (id < 143.) {\n pos = vec3(-25., -44., 424.); norm = vec3(-0.254, -0.417, -0.011); return;\n } else {\n if (id < 144.) {\n pos = vec3(-30., -39., 352.); norm = vec3(-0.254, -0.417, -0.011); return;\n } else {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.554, 0.755, 0.070); return;\n }\n }\n }\n } else {\n if (id < 148.) {\n if (id < 146.) {\n pos = vec3(6., 91., 890.); norm = vec3(-0.554, 0.755, 0.070); return;\n } else {\n if (id < 147.) {\n pos = vec3(6., 98., 815.); norm = vec3(-0.554, 0.755, 0.070); return;\n } else {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.152, 0.288, 0.182); return;\n }\n }\n } else {\n if (id < 150.) {\n if (id < 149.) {\n pos = vec3(6., 43., 966.); norm = vec3(-0.152, 0.288, 0.182); return;\n } else {\n pos = vec3(6., 91., 890.); norm = vec3(-0.152, 0.288, 0.182); return;\n }\n } else {\n if (id < 151.) {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.798, -0.001, -0.489); return;\n } else {\n pos = vec3(-34., 59., 836.); norm = vec3(-0.798, -0.001, -0.489); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 177.) {\n if (id < 164.) {\n if (id < 158.) {\n if (id < 155.) {\n if (id < 153.) {\n pos = vec3(-23., 87., 818.); norm = vec3(-0.798, -0.001, -0.489); return;\n } else {\n if (id < 154.) {\n pos = vec3(-23., 87., 818.); norm = vec3(-0.844, 0.134, -0.308); return;\n } else {\n pos = vec3(-34., 59., 836.); norm = vec3(-0.844, 0.134, -0.308); return;\n }\n }\n } else {\n if (id < 156.) {\n pos = vec3(-35., 78., 847.); norm = vec3(-0.844, 0.134, -0.308); return;\n } else {\n if (id < 157.) {\n pos = vec3(-31., 49., 861.); norm = vec3(-0.370, 0.036, 0.040); return;\n } else {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.370, 0.036, 0.040); return;\n }\n }\n }\n } else {\n if (id < 161.) {\n if (id < 159.) {\n pos = vec3(-29., 55., 874.); norm = vec3(-0.370, 0.036, 0.040); return;\n } else {\n if (id < 160.) {\n pos = vec3(-29., 55., 874.); norm = vec3(-0.360, 0.031, 0.043); return;\n } else {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.360, 0.031, 0.043); return;\n }\n }\n } else {\n if (id < 162.) {\n pos = vec3(-27., 53., 892.); norm = vec3(-0.360, 0.031, 0.043); return;\n } else {\n if (id < 163.) {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.934, 0.251, 0.253); return;\n } else {\n pos = vec3(-27., 53., 892.); norm = vec3(-0.934, 0.251, 0.253); return;\n }\n }\n }\n }\n } else {\n if (id < 170.) {\n if (id < 167.) {\n if (id < 165.) {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.934, 0.251, 0.253); return;\n } else {\n if (id < 166.) {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.353, -0.003, 0.036); return;\n } else {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.353, -0.003, 0.036); return;\n }\n }\n } else {\n if (id < 168.) {\n pos = vec3(-17., -21., 966.); norm = vec3(-0.353, -0.003, 0.036); return;\n } else {\n if (id < 169.) {\n pos = vec3(0., 48., 192.); norm = vec3(-0.406, 0.722, 0.447); return;\n } else {\n pos = vec3(-28., 31., 194.); norm = vec3(-0.406, 0.722, 0.447); return;\n }\n }\n }\n } else {\n if (id < 173.) {\n if (id < 171.) {\n pos = vec3(0., 22., 234.); norm = vec3(-0.406, 0.722, 0.447); return;\n } else {\n if (id < 172.) {\n pos = vec3(0., 22., 234.); norm = vec3(-0.462, 0.683, 0.477); return;\n } else {\n pos = vec3(-28., 31., 194.); norm = vec3(-0.462, 0.683, 0.477); return;\n }\n }\n } else {\n if (id < 175.) {\n if (id < 174.) {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.462, 0.683, 0.477); return;\n } else {\n pos = vec3(-137., -28., -52.); norm = vec3(-0.284, -0.006, -0.050); return;\n }\n } else {\n if (id < 176.) {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.284, -0.006, -0.050); return;\n } else {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.284, -0.006, -0.050); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 190.) {\n if (id < 183.) {\n if (id < 180.) {\n if (id < 178.) {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.407, 0.176, -0.122); return;\n } else {\n if (id < 179.) {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.407, 0.176, -0.122); return;\n } else {\n pos = vec3(-128., 42., -30.); norm = vec3(-0.407, 0.176, -0.122); return;\n }\n }\n } else {\n if (id < 181.) {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.719, 0.636, -0.088); return;\n } else {\n if (id < 182.) {\n pos = vec3(4., 59., 751.); norm = vec3(-0.719, 0.636, -0.088); return;\n } else {\n pos = vec3(-25., 20., 706.); norm = vec3(-0.719, 0.636, -0.088); return;\n }\n }\n }\n } else {\n if (id < 186.) {\n if (id < 184.) {\n pos = vec3(-25., 20., 706.); norm = vec3(-0.216, 0.378, -0.188); return;\n } else {\n if (id < 185.) {\n pos = vec3(4., 59., 751.); norm = vec3(-0.216, 0.378, -0.188); return;\n } else {\n pos = vec3(3., 34., 702.); norm = vec3(-0.216, 0.378, -0.188); return;\n }\n }\n } else {\n if (id < 188.) {\n if (id < 187.) {\n pos = vec3(-25., 20., 706.); norm = vec3(-0.974, -0.224, 0.020); return;\n } else {\n pos = vec3(-20., -1., 714.); norm = vec3(-0.974, -0.224, 0.020); return;\n }\n } else {\n if (id < 189.) {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.974, -0.224, 0.020); return;\n } else {\n pos = vec3(-17., -21., 966.); norm = vec3(-0.134, -0.032, 0.085); return;\n }\n }\n }\n }\n } else {\n if (id < 196.) {\n if (id < 193.) {\n if (id < 191.) {\n pos = vec3(5., -95., 973.); norm = vec3(-0.134, -0.032, 0.085); return;\n } else {\n if (id < 192.) {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.134, -0.032, 0.085); return;\n } else {\n pos = vec3(6., -3., 907.); norm = vec3(-0.463, -0.362, -0.148); return;\n }\n }\n } else {\n if (id < 194.) {\n pos = vec3(6., -19., 946.); norm = vec3(-0.463, -0.362, -0.148); return;\n } else {\n if (id < 195.) {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.463, -0.362, -0.148); return;\n } else {\n pos = vec3(6., -19., 946.); norm = vec3(-0.234, -0.096, -0.279); return;\n }\n }\n }\n } else {\n if (id < 199.) {\n if (id < 197.) {\n pos = vec3(5., -95., 973.); norm = vec3(-0.234, -0.096, -0.279); return;\n } else {\n if (id < 198.) {\n pos = vec3(-17., -21., 966.); norm = vec3(-0.234, -0.096, -0.279); return;\n } else {\n pos = vec3(-24., -34., 549.); norm = vec3(-0.474, 0.869, 0.103); return;\n }\n }\n } else {\n if (id < 201.) {\n if (id < 200.) {\n pos = vec3(2., -19., 542.); norm = vec3(-0.474, 0.869, 0.103); return;\n } else {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.474, 0.869, 0.103); return;\n }\n } else {\n if (id < 202.) {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.063, 0.160, 0.015); return;\n } else {\n pos = vec3(2., -19., 542.); norm = vec3(-0.063, 0.160, 0.015); return;\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 304.) {\n if (id < 253.) {\n if (id < 228.) {\n if (id < 215.) {\n if (id < 209.) {\n if (id < 206.) {\n if (id < 204.) {\n pos = vec3(1., -8., 420.); norm = vec3(-0.063, 0.160, 0.015); return;\n } else {\n if (id < 205.) {\n pos = vec3(-32., -3., 286.); norm = vec3(-0.712, 0.264, 0.096); return;\n } else {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.712, 0.264, 0.096); return;\n }\n }\n } else {\n if (id < 207.) {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.712, 0.264, 0.096); return;\n } else {\n if (id < 208.) {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.613, 0.037, 0.089); return;\n } else {\n pos = vec3(-30., -39., 352.); norm = vec3(-0.613, 0.037, 0.089); return;\n }\n }\n }\n } else {\n if (id < 212.) {\n if (id < 210.) {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.613, 0.037, 0.089); return;\n } else {\n if (id < 211.) {\n pos = vec3(-30., -39., 352.); norm = vec3(-0.967, 0.239, 0.084); return;\n } else {\n pos = vec3(-25., -44., 424.); norm = vec3(-0.967, 0.239, 0.084); return;\n }\n }\n } else {\n if (id < 213.) {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.967, 0.239, 0.084); return;\n } else {\n if (id < 214.) {\n pos = vec3(0., 99., 84.); norm = vec3(-0.092, 0.816, 0.510); return;\n } else {\n pos = vec3(-110., 91., 77.); norm = vec3(-0.092, 0.816, 0.510); return;\n }\n }\n }\n }\n } else {\n if (id < 221.) {\n if (id < 218.) {\n if (id < 216.) {\n pos = vec3(-93., 56., 136.); norm = vec3(-0.092, 0.816, 0.510); return;\n } else {\n if (id < 217.) {\n pos = vec3(-93., 56., 136.); norm = vec3(0.122, 0.593, 0.317); return;\n } else {\n pos = vec3(-110., 91., 77.); norm = vec3(0.122, 0.593, 0.317); return;\n }\n }\n } else {\n if (id < 219.) {\n pos = vec3(-127., 79., 106.); norm = vec3(0.122, 0.593, 0.317); return;\n } else {\n if (id < 220.) {\n pos = vec3(-25., -56., 552.); norm = vec3(-0.997, 0.046, 0.004); return;\n } else {\n pos = vec3(-24., -34., 549.); norm = vec3(-0.997, 0.046, 0.004); return;\n }\n }\n }\n } else {\n if (id < 224.) {\n if (id < 222.) {\n pos = vec3(-25., -44., 424.); norm = vec3(-0.997, 0.046, 0.004); return;\n } else {\n if (id < 223.) {\n pos = vec3(-25., -44., 424.); norm = vec3(-0.222, 0.056, -0.003); return;\n } else {\n pos = vec3(-24., -34., 549.); norm = vec3(-0.222, 0.056, -0.003); return;\n }\n }\n } else {\n if (id < 226.) {\n if (id < 225.) {\n pos = vec3(-18., -16., 425.); norm = vec3(-0.222, 0.056, -0.003); return;\n } else {\n pos = vec3(1., -66., 421.); norm = vec3(-0.166, -0.193, -0.018); return;\n }\n } else {\n if (id < 227.) {\n pos = vec3(-25., -56., 552.); norm = vec3(-0.166, -0.193, -0.018); return;\n } else {\n pos = vec3(-25., -44., 424.); norm = vec3(-0.166, -0.193, -0.018); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 240.) {\n if (id < 234.) {\n if (id < 231.) {\n if (id < 229.) {\n pos = vec3(6., -19., 946.); norm = vec3(-0.394, -0.605, -0.514); return;\n } else {\n if (id < 230.) {\n pos = vec3(-17., -21., 966.); norm = vec3(-0.394, -0.605, -0.514); return;\n } else {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.394, -0.605, -0.514); return;\n }\n }\n } else {\n if (id < 232.) {\n pos = vec3(-23., 87., 818.); norm = vec3(-0.573, 0.010, -0.235); return;\n } else {\n if (id < 233.) {\n pos = vec3(4., 59., 751.); norm = vec3(-0.573, 0.010, -0.235); return;\n } else {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.573, 0.010, -0.235); return;\n }\n }\n }\n } else {\n if (id < 237.) {\n if (id < 235.) {\n pos = vec3(-25., 20., 706.); norm = vec3(-0.133, -0.028, 0.009); return;\n } else {\n if (id < 236.) {\n pos = vec3(-24., -34., 549.); norm = vec3(-0.133, -0.028, 0.009); return;\n } else {\n pos = vec3(-20., -1., 714.); norm = vec3(-0.133, -0.028, 0.009); return;\n }\n }\n } else {\n if (id < 238.) {\n pos = vec3(-20., -1., 714.); norm = vec3(-0.997, 0.047, 0.015); return;\n } else {\n if (id < 239.) {\n pos = vec3(-24., -34., 549.); norm = vec3(-0.997, 0.047, 0.015); return;\n } else {\n pos = vec3(-25., -56., 552.); norm = vec3(-0.997, 0.047, 0.015); return;\n }\n }\n }\n }\n } else {\n if (id < 246.) {\n if (id < 243.) {\n if (id < 241.) {\n pos = vec3(-82., -108., -138.); norm = vec3(0.042, -0.724, -0.041); return;\n } else {\n if (id < 242.) {\n pos = vec3(-64., -106., -155.); norm = vec3(0.042, -0.724, -0.041); return;\n } else {\n pos = vec3(-64., -116., 23.); norm = vec3(0.042, -0.724, -0.041); return;\n }\n }\n } else {\n if (id < 244.) {\n pos = vec3(2., -71., 551.); norm = vec3(-0.472, -0.848, -0.029); return;\n } else {\n if (id < 245.) {\n pos = vec3(-25., -56., 552.); norm = vec3(-0.472, -0.848, -0.029); return;\n } else {\n pos = vec3(1., -66., 421.); norm = vec3(-0.472, -0.848, -0.029); return;\n }\n }\n }\n } else {\n if (id < 249.) {\n if (id < 247.) {\n pos = vec3(-115., 15., 87.); norm = vec3(-0.647, -0.296, 0.430); return;\n } else {\n if (id < 248.) {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.647, -0.296, 0.430); return;\n } else {\n pos = vec3(-95., -81., 51.); norm = vec3(-0.647, -0.296, 0.430); return;\n }\n }\n } else {\n if (id < 251.) {\n if (id < 250.) {\n pos = vec3(-95., -81., 51.); norm = vec3(-0.786, -0.409, 0.110); return;\n } else {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.786, -0.409, 0.110); return;\n }\n } else {\n if (id < 252.) {\n pos = vec3(-137., -28., -52.); norm = vec3(-0.786, -0.409, 0.110); return;\n } else {\n pos = vec3(6., 5., 996.); norm = vec3(-0.294, 0.311, 0.394); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 278.) {\n if (id < 265.) {\n if (id < 259.) {\n if (id < 256.) {\n if (id < 254.) {\n pos = vec3(6., 43., 966.); norm = vec3(-0.294, 0.311, 0.394); return;\n } else {\n if (id < 255.) {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.294, 0.311, 0.394); return;\n } else {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.610, 0.527, 0.464); return;\n }\n }\n } else {\n if (id < 257.) {\n pos = vec3(6., 43., 966.); norm = vec3(-0.610, 0.527, 0.464); return;\n } else {\n if (id < 258.) {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.610, 0.527, 0.464); return;\n } else {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.173, -0.046, 0.206); return;\n }\n }\n }\n } else {\n if (id < 262.) {\n if (id < 260.) {\n pos = vec3(5., -95., 973.); norm = vec3(-0.173, -0.046, 0.206); return;\n } else {\n if (id < 261.) {\n pos = vec3(6., 5., 996.); norm = vec3(-0.173, -0.046, 0.206); return;\n } else {\n pos = vec3(-40., -49., -294.); norm = vec3(-0.942, -0.006, 0.247); return;\n }\n }\n } else {\n if (id < 263.) {\n pos = vec3(-30., -54., -256.); norm = vec3(-0.942, -0.006, 0.247); return;\n } else {\n if (id < 264.) {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.942, -0.006, 0.247); return;\n } else {\n pos = vec3(-41., -72., -173.); norm = vec3(-0.019, -0.502, -0.111); return;\n }\n }\n }\n }\n } else {\n if (id < 271.) {\n if (id < 268.) {\n if (id < 266.) {\n pos = vec3(-30., -54., -256.); norm = vec3(-0.019, -0.502, -0.111); return;\n } else {\n if (id < 267.) {\n pos = vec3(0., -70., -189.); norm = vec3(-0.019, -0.502, -0.111); return;\n } else {\n pos = vec3(0., -70., -189.); norm = vec3(-0.066, -0.909, -0.187); return;\n }\n }\n } else {\n if (id < 269.) {\n pos = vec3(-30., -54., -256.); norm = vec3(-0.066, -0.909, -0.187); return;\n } else {\n if (id < 270.) {\n pos = vec3(0., -50., -286.); norm = vec3(-0.066, -0.909, -0.187); return;\n } else {\n pos = vec3(5., -10., 875.); norm = vec3(-0.560, -0.660, -0.237); return;\n }\n }\n }\n } else {\n if (id < 274.) {\n if (id < 272.) {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.560, -0.660, -0.237); return;\n } else {\n if (id < 273.) {\n pos = vec3(5., 13., 811.); norm = vec3(-0.560, -0.660, -0.237); return;\n } else {\n pos = vec3(5., 13., 811.); norm = vec3(-0.429, -0.722, 0.215); return;\n }\n }\n } else {\n if (id < 276.) {\n if (id < 275.) {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.429, -0.722, 0.215); return;\n } else {\n pos = vec3(-20., -1., 714.); norm = vec3(-0.429, -0.722, 0.215); return;\n }\n } else {\n if (id < 277.) {\n pos = vec3(0., -26., -365.); norm = vec3(-0.345, 0.818, -0.124); return;\n } else {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.345, 0.818, -0.124); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 291.) {\n if (id < 284.) {\n if (id < 281.) {\n if (id < 279.) {\n pos = vec3(0., -11., -266.); norm = vec3(-0.345, 0.818, -0.124); return;\n } else {\n if (id < 280.) {\n pos = vec3(0., -50., -286.); norm = vec3(0.001, -0.853, -0.113); return;\n } else {\n pos = vec3(-30., -54., -256.); norm = vec3(0.001, -0.853, -0.113); return;\n }\n }\n } else {\n if (id < 282.) {\n pos = vec3(-40., -49., -294.); norm = vec3(0.001, -0.853, -0.113); return;\n } else {\n if (id < 283.) {\n pos = vec3(-82., -108., -138.); norm = vec3(0.022, -0.086, 0.013); return;\n } else {\n pos = vec3(-80., -140., -357.); norm = vec3(0.022, -0.086, 0.013); return;\n }\n }\n }\n } else {\n if (id < 287.) {\n if (id < 285.) {\n pos = vec3(-64., -106., -155.); norm = vec3(0.022, -0.086, 0.013); return;\n } else {\n if (id < 286.) {\n pos = vec3(-64., -106., -155.); norm = vec3(0.000, -0.983, 0.165); return;\n } else {\n pos = vec3(-80., -140., -357.); norm = vec3(0.000, -0.983, 0.165); return;\n }\n }\n } else {\n if (id < 289.) {\n if (id < 288.) {\n pos = vec3(-69., -140., -357.); norm = vec3(0.000, -0.983, 0.165); return;\n } else {\n pos = vec3(-63., -129., -360.); norm = vec3(0.057, -0.030, 0.004); return;\n }\n } else {\n if (id < 290.) {\n pos = vec3(-56., -92., -163.); norm = vec3(0.057, -0.030, 0.004); return;\n } else {\n pos = vec3(-69., -140., -357.); norm = vec3(0.057, -0.030, 0.004); return;\n }\n }\n }\n }\n } else {\n if (id < 297.) {\n if (id < 294.) {\n if (id < 292.) {\n pos = vec3(-69., -140., -357.); norm = vec3(0.860, -0.459, 0.056); return;\n } else {\n if (id < 293.) {\n pos = vec3(-56., -92., -163.); norm = vec3(0.860, -0.459, 0.056); return;\n } else {\n pos = vec3(-64., -106., -155.); norm = vec3(0.860, -0.459, 0.056); return;\n }\n }\n } else {\n if (id < 295.) {\n pos = vec3(-63., -129., -360.); norm = vec3(0.482, 0.854, -0.178); return;\n } else {\n if (id < 296.) {\n pos = vec3(-74., -123., -361.); norm = vec3(0.482, 0.854, -0.178); return;\n } else {\n pos = vec3(-56., -92., -163.); norm = vec3(0.482, 0.854, -0.178); return;\n }\n }\n }\n } else {\n if (id < 300.) {\n if (id < 298.) {\n pos = vec3(-56., -92., -163.); norm = vec3(0.077, 0.064, -0.017); return;\n } else {\n if (id < 299.) {\n pos = vec3(-74., -123., -361.); norm = vec3(0.077, 0.064, -0.017); return;\n } else {\n pos = vec3(-69., -74., -154.); norm = vec3(0.077, 0.064, -0.017); return;\n }\n }\n } else {\n if (id < 302.) {\n if (id < 301.) {\n pos = vec3(-74., -123., -361.); norm = vec3(-0.550, 0.814, -0.179); return;\n } else {\n pos = vec3(-85., -130., -359.); norm = vec3(-0.550, 0.814, -0.179); return;\n }\n } else {\n if (id < 303.) {\n pos = vec3(-69., -74., -154.); norm = vec3(-0.550, 0.814, -0.179); return;\n } else {\n pos = vec3(-69., -74., -154.); norm = vec3(-0.076, 0.091, -0.019); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 355.) {\n if (id < 329.) {\n if (id < 316.) {\n if (id < 310.) {\n if (id < 307.) {\n if (id < 305.) {\n pos = vec3(-85., -130., -359.); norm = vec3(-0.076, 0.091, -0.019); return;\n } else {\n if (id < 306.) {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.076, 0.091, -0.019); return;\n } else {\n pos = vec3(-85., -130., -359.); norm = vec3(-0.896, -0.435, 0.067); return;\n }\n }\n } else {\n if (id < 308.) {\n pos = vec3(-80., -140., -357.); norm = vec3(-0.896, -0.435, 0.067); return;\n } else {\n if (id < 309.) {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.896, -0.435, 0.067); return;\n } else {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.091, -0.031, 0.004); return;\n }\n }\n }\n } else {\n if (id < 313.) {\n if (id < 311.) {\n pos = vec3(-80., -140., -357.); norm = vec3(-0.091, -0.031, 0.004); return;\n } else {\n if (id < 312.) {\n pos = vec3(-82., -108., -138.); norm = vec3(-0.091, -0.031, 0.004); return;\n } else {\n pos = vec3(-65., -148., -474.); norm = vec3(0.488, 0.759, -0.162); return;\n }\n }\n } else {\n if (id < 314.) {\n pos = vec3(-75., -142., -476.); norm = vec3(0.488, 0.759, -0.162); return;\n } else {\n if (id < 315.) {\n pos = vec3(-57., -141., -417.); norm = vec3(0.488, 0.759, -0.162); return;\n } else {\n pos = vec3(-57., -141., -417.); norm = vec3(0.340, 0.255, -0.108); return;\n }\n }\n }\n }\n } else {\n if (id < 322.) {\n if (id < 319.) {\n if (id < 317.) {\n pos = vec3(-75., -142., -476.); norm = vec3(0.340, 0.255, -0.108); return;\n } else {\n if (id < 318.) {\n pos = vec3(-74., -120., -421.); norm = vec3(0.340, 0.255, -0.108); return;\n } else {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.231, 0.149, -0.103); return;\n }\n }\n } else {\n if (id < 320.) {\n pos = vec3(-100., -140., -417.); norm = vec3(-0.231, 0.149, -0.103); return;\n } else {\n if (id < 321.) {\n pos = vec3(-75., -142., -476.); norm = vec3(-0.231, 0.149, -0.103); return;\n } else {\n pos = vec3(-75., -142., -476.); norm = vec3(-0.561, 0.677, -0.261); return;\n }\n }\n }\n } else {\n if (id < 325.) {\n if (id < 323.) {\n pos = vec3(-100., -140., -417.); norm = vec3(-0.561, 0.677, -0.261); return;\n } else {\n if (id < 324.) {\n pos = vec3(-74., -120., -421.); norm = vec3(-0.561, 0.677, -0.261); return;\n } else {\n pos = vec3(-81., -163., -472.); norm = vec3(-0.097, -0.084, -0.019); return;\n }\n }\n } else {\n if (id < 327.) {\n if (id < 326.) {\n pos = vec3(-92., -164., -413.); norm = vec3(-0.097, -0.084, -0.019); return;\n } else {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.097, -0.084, -0.019); return;\n }\n } else {\n if (id < 328.) {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.908, -0.324, -0.129); return;\n } else {\n pos = vec3(-92., -164., -413.); norm = vec3(-0.908, -0.324, -0.129); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 342.) {\n if (id < 335.) {\n if (id < 332.) {\n if (id < 330.) {\n pos = vec3(-100., -140., -417.); norm = vec3(-0.908, -0.324, -0.129); return;\n } else {\n if (id < 331.) {\n pos = vec3(-70., -163., -472.); norm = vec3(0.000, -0.180, 0.000); return;\n } else {\n pos = vec3(-66., -163., -413.); norm = vec3(0.000, -0.180, 0.000); return;\n }\n }\n } else {\n if (id < 333.) {\n pos = vec3(-81., -163., -472.); norm = vec3(0.000, -0.180, 0.000); return;\n } else {\n if (id < 334.) {\n pos = vec3(-81., -163., -472.); norm = vec3(0.037, -0.968, -0.009); return;\n } else {\n pos = vec3(-66., -163., -413.); norm = vec3(0.037, -0.968, -0.009); return;\n }\n }\n }\n } else {\n if (id < 338.) {\n if (id < 336.) {\n pos = vec3(-92., -164., -413.); norm = vec3(0.037, -0.968, -0.009); return;\n } else {\n if (id < 337.) {\n pos = vec3(-65., -148., -474.); norm = vec3(0.247, -0.086, -0.024); return;\n } else {\n pos = vec3(-57., -141., -417.); norm = vec3(0.247, -0.086, -0.024); return;\n }\n }\n } else {\n if (id < 340.) {\n if (id < 339.) {\n pos = vec3(-70., -163., -472.); norm = vec3(0.247, -0.086, -0.024); return;\n } else {\n pos = vec3(-70., -163., -472.); norm = vec3(0.888, -0.374, -0.060); return;\n }\n } else {\n if (id < 341.) {\n pos = vec3(-57., -141., -417.); norm = vec3(0.888, -0.374, -0.060); return;\n } else {\n pos = vec3(-66., -163., -413.); norm = vec3(0.888, -0.374, -0.060); return;\n }\n }\n }\n }\n } else {\n if (id < 348.) {\n if (id < 345.) {\n if (id < 343.) {\n pos = vec3(-85., -130., -359.); norm = vec3(-0.156, -0.068, 0.052); return;\n } else {\n if (id < 344.) {\n pos = vec3(-100., -140., -417.); norm = vec3(-0.156, -0.068, 0.052); return;\n } else {\n pos = vec3(-80., -140., -357.); norm = vec3(-0.156, -0.068, 0.052); return;\n }\n }\n } else {\n if (id < 346.) {\n pos = vec3(-80., -140., -357.); norm = vec3(-0.889, -0.247, 0.296); return;\n } else {\n if (id < 347.) {\n pos = vec3(-100., -140., -417.); norm = vec3(-0.889, -0.247, 0.296); return;\n } else {\n pos = vec3(-92., -164., -413.); norm = vec3(-0.889, -0.247, 0.296); return;\n }\n }\n }\n } else {\n if (id < 351.) {\n if (id < 349.) {\n pos = vec3(-92., -164., -413.); norm = vec3(0.035, -0.901, 0.379); return;\n } else {\n if (id < 350.) {\n pos = vec3(-66., -163., -413.); norm = vec3(0.035, -0.901, 0.379); return;\n } else {\n pos = vec3(-80., -140., -357.); norm = vec3(0.035, -0.901, 0.379); return;\n }\n }\n } else {\n if (id < 353.) {\n if (id < 352.) {\n pos = vec3(-80., -140., -357.); norm = vec3(0.000, -0.164, 0.067); return;\n } else {\n pos = vec3(-66., -163., -413.); norm = vec3(0.000, -0.164, 0.067); return;\n }\n } else {\n if (id < 354.) {\n pos = vec3(-69., -140., -357.); norm = vec3(0.000, -0.164, 0.067); return;\n } else {\n pos = vec3(-66., -163., -413.); norm = vec3(0.898, -0.334, 0.185); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 380.) {\n if (id < 367.) {\n if (id < 361.) {\n if (id < 358.) {\n if (id < 356.) {\n pos = vec3(-57., -141., -417.); norm = vec3(0.898, -0.334, 0.185); return;\n } else {\n if (id < 357.) {\n pos = vec3(-69., -140., -357.); norm = vec3(0.898, -0.334, 0.185); return;\n } else {\n pos = vec3(-69., -140., -357.); norm = vec3(0.185, -0.090, 0.039); return;\n }\n }\n } else {\n if (id < 359.) {\n pos = vec3(-57., -141., -417.); norm = vec3(0.185, -0.090, 0.039); return;\n } else {\n if (id < 360.) {\n pos = vec3(-63., -129., -360.); norm = vec3(0.185, -0.090, 0.039); return;\n } else {\n pos = vec3(-74., -120., -421.); norm = vec3(0.339, 0.277, 0.014); return;\n }\n }\n }\n } else {\n if (id < 364.) {\n if (id < 362.) {\n pos = vec3(-74., -123., -361.); norm = vec3(0.339, 0.277, 0.014); return;\n } else {\n if (id < 363.) {\n pos = vec3(-57., -141., -417.); norm = vec3(0.339, 0.277, 0.014); return;\n } else {\n pos = vec3(-57., -141., -417.); norm = vec3(0.460, 0.822, -0.125); return;\n }\n }\n } else {\n if (id < 365.) {\n pos = vec3(-74., -123., -361.); norm = vec3(0.460, 0.822, -0.125); return;\n } else {\n if (id < 366.) {\n pos = vec3(-63., -129., -360.); norm = vec3(0.460, 0.822, -0.125); return;\n } else {\n pos = vec3(-100., -140., -417.); norm = vec3(-0.310, 0.405, 0.010); return;\n }\n }\n }\n }\n } else {\n if (id < 373.) {\n if (id < 370.) {\n if (id < 368.) {\n pos = vec3(-85., -130., -359.); norm = vec3(-0.310, 0.405, 0.010); return;\n } else {\n if (id < 369.) {\n pos = vec3(-74., -120., -421.); norm = vec3(-0.310, 0.405, 0.010); return;\n } else {\n pos = vec3(-74., -120., -421.); norm = vec3(-0.492, 0.785, 0.039); return;\n }\n }\n } else {\n if (id < 371.) {\n pos = vec3(-85., -130., -359.); norm = vec3(-0.492, 0.785, 0.039); return;\n } else {\n if (id < 372.) {\n pos = vec3(-74., -123., -361.); norm = vec3(-0.492, 0.785, 0.039); return;\n } else {\n pos = vec3(-67., -193., -692.); norm = vec3(0.605, 0.778, -0.166); return;\n }\n }\n }\n } else {\n if (id < 376.) {\n if (id < 374.) {\n pos = vec3(-75., -187., -693.); norm = vec3(0.605, 0.778, -0.166); return;\n } else {\n if (id < 375.) {\n pos = vec3(-65., -148., -474.); norm = vec3(0.605, 0.778, -0.166); return;\n } else {\n pos = vec3(-65., -148., -474.); norm = vec3(0.028, 0.044, -0.009); return;\n }\n }\n } else {\n if (id < 378.) {\n if (id < 377.) {\n pos = vec3(-75., -187., -693.); norm = vec3(0.028, 0.044, -0.009); return;\n } else {\n pos = vec3(-75., -142., -476.); norm = vec3(0.028, 0.044, -0.009); return;\n }\n } else {\n if (id < 379.) {\n pos = vec3(-83., -194., -692.); norm = vec3(-0.032, 0.035, -0.006); return;\n } else {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.032, 0.035, -0.006); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 393.) {\n if (id < 386.) {\n if (id < 383.) {\n if (id < 381.) {\n pos = vec3(-75., -187., -693.); norm = vec3(-0.032, 0.035, -0.006); return;\n } else {\n if (id < 382.) {\n pos = vec3(-75., -187., -693.); norm = vec3(-0.809, 0.570, -0.118); return;\n } else {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.809, 0.570, -0.118); return;\n }\n }\n } else {\n if (id < 384.) {\n pos = vec3(-75., -142., -476.); norm = vec3(-0.809, 0.570, -0.118); return;\n } else {\n if (id < 385.) {\n pos = vec3(-83., -194., -692.); norm = vec3(-0.961, -0.266, 0.032); return;\n } else {\n pos = vec3(-81., -201., -690.); norm = vec3(-0.961, -0.266, 0.032); return;\n }\n }\n }\n } else {\n if (id < 389.) {\n if (id < 387.) {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.961, -0.266, 0.032); return;\n } else {\n if (id < 388.) {\n pos = vec3(-86., -157., -473.); norm = vec3(-0.027, -0.022, 0.004); return;\n } else {\n pos = vec3(-81., -201., -690.); norm = vec3(-0.027, -0.022, 0.004); return;\n }\n }\n } else {\n if (id < 391.) {\n if (id < 390.) {\n pos = vec3(-81., -163., -472.); norm = vec3(-0.027, -0.022, 0.004); return;\n } else {\n pos = vec3(-81., -201., -690.); norm = vec3(0.000, -0.984, 0.172); return;\n }\n } else {\n if (id < 392.) {\n pos = vec3(-71., -201., -690.); norm = vec3(0.000, -0.984, 0.172); return;\n } else {\n pos = vec3(-81., -163., -472.); norm = vec3(0.000, -0.984, 0.172); return;\n }\n }\n }\n }\n } else {\n if (id < 399.) {\n if (id < 396.) {\n if (id < 394.) {\n pos = vec3(-81., -163., -472.); norm = vec3(-0.000, -0.049, 0.009); return;\n } else {\n if (id < 395.) {\n pos = vec3(-71., -201., -690.); norm = vec3(-0.000, -0.049, 0.009); return;\n } else {\n pos = vec3(-70., -163., -472.); norm = vec3(-0.000, -0.049, 0.009); return;\n }\n }\n } else {\n if (id < 397.) {\n pos = vec3(-71., -201., -690.); norm = vec3(0.894, -0.429, 0.071); return;\n } else {\n if (id < 398.) {\n pos = vec3(-67., -193., -692.); norm = vec3(0.894, -0.429, 0.071); return;\n } else {\n pos = vec3(-70., -163., -472.); norm = vec3(0.894, -0.429, 0.071); return;\n }\n }\n }\n } else {\n if (id < 402.) {\n if (id < 400.) {\n pos = vec3(-70., -163., -472.); norm = vec3(0.068, -0.022, 0.004); return;\n } else {\n if (id < 401.) {\n pos = vec3(-67., -193., -692.); norm = vec3(0.068, -0.022, 0.004); return;\n } else {\n pos = vec3(-65., -148., -474.); norm = vec3(0.068, -0.022, 0.004); return;\n }\n }\n } else {\n if (id < 404.) {\n if (id < 403.) {\n pos = vec3(-95., -179., -713.); norm = vec3(-0.651, -0.000, 0.372); return;\n } else {\n pos = vec3(-91., -216., -706.); norm = vec3(-0.651, -0.000, 0.372); return;\n }\n } else {\n if (id < 405.) {\n pos = vec3(-83., -194., -692.); norm = vec3(-0.651, -0.000, 0.372); return;\n } else {\n pos = vec3(-83., -194., -692.); norm = vec3(-0.216, -0.018, 0.152); return;\n }\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 609.) {\n if (id < 507.) {\n if (id < 456.) {\n if (id < 431.) {\n if (id < 418.) {\n if (id < 412.) {\n if (id < 409.) {\n if (id < 407.) {\n pos = vec3(-91., -216., -706.); norm = vec3(-0.216, -0.018, 0.152); return;\n } else {\n if (id < 408.) {\n pos = vec3(-81., -201., -690.); norm = vec3(-0.216, -0.018, 0.152); return;\n } else {\n pos = vec3(-63., -216., -706.); norm = vec3(0.000, -0.647, 0.606); return;\n }\n }\n } else {\n if (id < 410.) {\n pos = vec3(-71., -201., -690.); norm = vec3(0.000, -0.647, 0.606); return;\n } else {\n if (id < 411.) {\n pos = vec3(-91., -216., -706.); norm = vec3(0.000, -0.647, 0.606); return;\n } else {\n pos = vec3(-91., -216., -706.); norm = vec3(0.000, -0.539, 0.505); return;\n }\n }\n }\n } else {\n if (id < 415.) {\n if (id < 413.) {\n pos = vec3(-71., -201., -690.); norm = vec3(0.000, -0.539, 0.505); return;\n } else {\n if (id < 414.) {\n pos = vec3(-81., -201., -690.); norm = vec3(0.000, -0.539, 0.505); return;\n } else {\n pos = vec3(-58., -180., -715.); norm = vec3(0.936, -0.045, 0.341); return;\n }\n }\n } else {\n if (id < 416.) {\n pos = vec3(-67., -193., -692.); norm = vec3(0.936, -0.045, 0.341); return;\n } else {\n if (id < 417.) {\n pos = vec3(-63., -216., -706.); norm = vec3(0.936, -0.045, 0.341); return;\n } else {\n pos = vec3(-63., -216., -706.); norm = vec3(0.633, -0.192, 0.497); return;\n }\n }\n }\n }\n } else {\n if (id < 424.) {\n if (id < 421.) {\n if (id < 419.) {\n pos = vec3(-67., -193., -692.); norm = vec3(0.633, -0.192, 0.497); return;\n } else {\n if (id < 420.) {\n pos = vec3(-71., -201., -690.); norm = vec3(0.633, -0.192, 0.497); return;\n } else {\n pos = vec3(-58., -180., -715.); norm = vec3(0.033, 0.716, 0.253); return;\n }\n }\n } else {\n if (id < 422.) {\n pos = vec3(-95., -179., -713.); norm = vec3(0.033, 0.716, 0.253); return;\n } else {\n if (id < 423.) {\n pos = vec3(-75., -187., -693.); norm = vec3(0.033, 0.716, 0.253); return;\n } else {\n pos = vec3(-95., -179., -713.); norm = vec3(-0.434, 0.592, 0.671); return;\n }\n }\n }\n } else {\n if (id < 427.) {\n if (id < 425.) {\n pos = vec3(-83., -194., -692.); norm = vec3(-0.434, 0.592, 0.671); return;\n } else {\n if (id < 426.) {\n pos = vec3(-75., -187., -693.); norm = vec3(-0.434, 0.592, 0.671); return;\n } else {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.311, -0.301, -0.075); return;\n }\n }\n } else {\n if (id < 429.) {\n if (id < 428.) {\n pos = vec3(5., -10., 875.); norm = vec3(-0.311, -0.301, -0.075); return;\n } else {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.311, -0.301, -0.075); return;\n }\n } else {\n if (id < 430.) {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.561, -0.426, 0.135); return;\n } else {\n pos = vec3(5., -10., 875.); norm = vec3(-0.561, -0.426, 0.135); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 443.) {\n if (id < 437.) {\n if (id < 434.) {\n if (id < 432.) {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.561, -0.426, 0.135); return;\n } else {\n if (id < 433.) {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.645, -0.471, 0.123); return;\n } else {\n pos = vec3(5., -10., 875.); norm = vec3(-0.645, -0.471, 0.123); return;\n }\n }\n } else {\n if (id < 435.) {\n pos = vec3(6., -3., 907.); norm = vec3(-0.645, -0.471, 0.123); return;\n } else {\n if (id < 436.) {\n pos = vec3(-137., -28., -52.); norm = vec3(-0.897, -0.312, -0.273); return;\n } else {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.897, -0.312, -0.273); return;\n }\n }\n }\n } else {\n if (id < 440.) {\n if (id < 438.) {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.897, -0.312, -0.273); return;\n } else {\n if (id < 439.) {\n pos = vec3(-69., -74., -154.); norm = vec3(-0.238, 0.071, -0.289); return;\n } else {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.238, 0.071, -0.289); return;\n }\n }\n } else {\n if (id < 441.) {\n pos = vec3(-70., -61., -150.); norm = vec3(-0.238, 0.071, -0.289); return;\n } else {\n if (id < 442.) {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.570, 0.131, -0.809); return;\n } else {\n pos = vec3(-70., -61., -150.); norm = vec3(-0.570, 0.131, -0.809); return;\n }\n }\n }\n }\n } else {\n if (id < 449.) {\n if (id < 446.) {\n if (id < 444.) {\n pos = vec3(-89., -88., -141.); norm = vec3(-0.570, 0.131, -0.809); return;\n } else {\n if (id < 445.) {\n pos = vec3(-68., 46., -184.); norm = vec3(-0.799, 0.428, -0.300); return;\n } else {\n pos = vec3(-129., -9., -100.); norm = vec3(-0.799, 0.428, -0.300); return;\n }\n }\n } else {\n if (id < 447.) {\n pos = vec3(-128., 42., -30.); norm = vec3(-0.799, 0.428, -0.300); return;\n } else {\n if (id < 448.) {\n pos = vec3(0., 109., -12.); norm = vec3(-0.082, 0.708, 0.074); return;\n } else {\n pos = vec3(-85., 100., -20.); norm = vec3(-0.082, 0.708, 0.074); return;\n }\n }\n }\n } else {\n if (id < 452.) {\n if (id < 450.) {\n pos = vec3(0., 99., 84.); norm = vec3(-0.082, 0.708, 0.074); return;\n } else {\n if (id < 451.) {\n pos = vec3(0., 99., 84.); norm = vec3(-0.062, 0.803, 0.058); return;\n } else {\n pos = vec3(-85., 100., -20.); norm = vec3(-0.062, 0.803, 0.058); return;\n }\n }\n } else {\n if (id < 454.) {\n if (id < 453.) {\n pos = vec3(-110., 91., 77.); norm = vec3(-0.062, 0.803, 0.058); return;\n } else {\n pos = vec3(-58., -180., -715.); norm = vec3(0.434, 0.670, 0.548); return;\n }\n } else {\n if (id < 455.) {\n pos = vec3(-75., -187., -693.); norm = vec3(0.434, 0.670, 0.548); return;\n } else {\n pos = vec3(-67., -193., -692.); norm = vec3(0.434, 0.670, 0.548); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 481.) {\n if (id < 468.) {\n if (id < 462.) {\n if (id < 459.) {\n if (id < 457.) {\n pos = vec3(-56., -92., -163.); norm = vec3(0.105, -0.155, -0.167); return;\n } else {\n if (id < 458.) {\n pos = vec3(0., -94., -126.); norm = vec3(0.105, -0.155, -0.167); return;\n } else {\n pos = vec3(-64., -106., -155.); norm = vec3(0.105, -0.155, -0.167); return;\n }\n }\n } else {\n if (id < 460.) {\n pos = vec3(0., -132., 23.); norm = vec3(0.212, -0.701, -0.179); return;\n } else {\n if (id < 461.) {\n pos = vec3(-64., -106., -155.); norm = vec3(0.212, -0.701, -0.179); return;\n } else {\n pos = vec3(0., -94., -126.); norm = vec3(0.212, -0.701, -0.179); return;\n }\n }\n }\n } else {\n if (id < 465.) {\n if (id < 463.) {\n pos = vec3(-38., -46., -295.); norm = vec3(-0.314, 0.667, 0.020); return;\n } else {\n if (id < 464.) {\n pos = vec3(0., -26., -365.); norm = vec3(-0.314, 0.667, 0.020); return;\n } else {\n pos = vec3(-65., -57., -351.); norm = vec3(-0.314, 0.667, 0.020); return;\n }\n }\n } else {\n if (id < 466.) {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.809, 0.488, -0.154); return;\n } else {\n if (id < 467.) {\n pos = vec3(-38., -46., -295.); norm = vec3(-0.809, 0.488, -0.154); return;\n } else {\n pos = vec3(-40., -49., -294.); norm = vec3(-0.809, 0.488, -0.154); return;\n }\n }\n }\n }\n } else {\n if (id < 474.) {\n if (id < 471.) {\n if (id < 469.) {\n pos = vec3(0., -26., -365.); norm = vec3(-0.655, 0.523, -0.206); return;\n } else {\n if (id < 470.) {\n pos = vec3(-38., -46., -295.); norm = vec3(-0.655, 0.523, -0.206); return;\n } else {\n pos = vec3(-31., -23., -259.); norm = vec3(-0.655, 0.523, -0.206); return;\n }\n }\n } else {\n if (id < 472.) {\n pos = vec3(-40., -49., -294.); norm = vec3(-0.758, 0.588, 0.250); return;\n } else {\n if (id < 473.) {\n pos = vec3(-38., -46., -295.); norm = vec3(-0.758, 0.588, 0.250); return;\n } else {\n pos = vec3(-65., -57., -351.); norm = vec3(-0.758, 0.588, 0.250); return;\n }\n }\n }\n } else {\n if (id < 477.) {\n if (id < 475.) {\n pos = vec3(-65., -57., -351.); norm = vec3(0.302, -0.653, -0.041); return;\n } else {\n if (id < 476.) {\n pos = vec3(0., -26., -365.); norm = vec3(0.302, -0.653, -0.041); return;\n } else {\n pos = vec3(-40., -49., -294.); norm = vec3(0.302, -0.653, -0.041); return;\n }\n }\n } else {\n if (id < 479.) {\n if (id < 478.) {\n pos = vec3(-40., -49., -294.); norm = vec3(0.016, -0.452, -0.137); return;\n } else {\n pos = vec3(0., -26., -365.); norm = vec3(0.016, -0.452, -0.137); return;\n }\n } else {\n if (id < 480.) {\n pos = vec3(0., -50., -286.); norm = vec3(0.016, -0.452, -0.137); return;\n } else {\n pos = vec3(-115., 15., 87.); norm = vec3(0.041, -0.658, 0.532); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 494.) {\n if (id < 487.) {\n if (id < 484.) {\n if (id < 482.) {\n pos = vec3(-93., 56., 136.); norm = vec3(0.041, -0.658, 0.532); return;\n } else {\n if (id < 483.) {\n pos = vec3(-153., 45., 127.); norm = vec3(0.041, -0.658, 0.532); return;\n } else {\n pos = vec3(-153., 45., 127.); norm = vec3(-0.171, 0.477, 0.559); return;\n }\n }\n } else {\n if (id < 485.) {\n pos = vec3(-93., 56., 136.); norm = vec3(-0.171, 0.477, 0.559); return;\n } else {\n if (id < 486.) {\n pos = vec3(-127., 79., 106.); norm = vec3(-0.171, 0.477, 0.559); return;\n } else {\n pos = vec3(-325., 157., -8.); norm = vec3(0.111, 0.684, 0.098); return;\n }\n }\n }\n } else {\n if (id < 490.) {\n if (id < 488.) {\n pos = vec3(-497., 175., 61.); norm = vec3(0.111, 0.684, 0.098); return;\n } else {\n if (id < 489.) {\n pos = vec3(-557., 166., 192.); norm = vec3(0.111, 0.684, 0.098); return;\n } else {\n pos = vec3(-308., 116., 139.); norm = vec3(-0.038, -0.339, -0.008); return;\n }\n }\n } else {\n if (id < 492.) {\n if (id < 491.) {\n pos = vec3(-557., 142., 207.); norm = vec3(-0.038, -0.339, -0.008); return;\n } else {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.038, -0.339, -0.008); return;\n }\n } else {\n if (id < 493.) {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.076, -0.488, -0.043); return;\n } else {\n pos = vec3(-557., 142., 207.); norm = vec3(-0.076, -0.488, -0.043); return;\n }\n }\n }\n }\n } else {\n if (id < 500.) {\n if (id < 497.) {\n if (id < 495.) {\n pos = vec3(-491., 144., 68.); norm = vec3(-0.076, -0.488, -0.043); return;\n } else {\n if (id < 496.) {\n pos = vec3(-306., 158., 141.); norm = vec3(0.283, 0.828, -0.002); return;\n } else {\n pos = vec3(-110., 91., 77.); norm = vec3(0.283, 0.828, -0.002); return;\n }\n }\n } else {\n if (id < 498.) {\n pos = vec3(-172., 112., 14.); norm = vec3(0.283, 0.828, -0.002); return;\n } else {\n if (id < 499.) {\n pos = vec3(-172., 112., 14.); norm = vec3(0.161, 0.831, 0.119); return;\n } else {\n pos = vec3(-110., 91., 77.); norm = vec3(0.161, 0.831, 0.119); return;\n }\n }\n }\n } else {\n if (id < 503.) {\n if (id < 501.) {\n pos = vec3(-85., 100., -20.); norm = vec3(0.161, 0.831, 0.119); return;\n } else {\n if (id < 502.) {\n pos = vec3(-110., 91., 77.); norm = vec3(0.063, 0.107, 0.081); return;\n } else {\n pos = vec3(-306., 158., 141.); norm = vec3(0.063, 0.107, 0.081); return;\n }\n }\n } else {\n if (id < 505.) {\n if (id < 504.) {\n pos = vec3(-127., 79., 106.); norm = vec3(0.063, 0.107, 0.081); return;\n } else {\n pos = vec3(-127., 79., 106.); norm = vec3(0.380, 0.522, 0.764); return;\n }\n } else {\n if (id < 506.) {\n pos = vec3(-306., 158., 141.); norm = vec3(0.380, 0.522, 0.764); return;\n } else {\n pos = vec3(-312., 136., 159.); norm = vec3(0.380, 0.522, 0.764); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 558.) {\n if (id < 532.) {\n if (id < 519.) {\n if (id < 513.) {\n if (id < 510.) {\n if (id < 508.) {\n pos = vec3(-308., 116., 139.); norm = vec3(-0.037, -0.096, 0.089); return;\n } else {\n if (id < 509.) {\n pos = vec3(-153., 45., 127.); norm = vec3(-0.037, -0.096, 0.089); return;\n } else {\n pos = vec3(-312., 136., 159.); norm = vec3(-0.037, -0.096, 0.089); return;\n }\n }\n } else {\n if (id < 511.) {\n pos = vec3(-312., 136., 159.); norm = vec3(0.338, 0.283, 0.877); return;\n } else {\n if (id < 512.) {\n pos = vec3(-153., 45., 127.); norm = vec3(0.338, 0.283, 0.877); return;\n } else {\n pos = vec3(-127., 79., 106.); norm = vec3(0.338, 0.283, 0.877); return;\n }\n }\n }\n } else {\n if (id < 516.) {\n if (id < 514.) {\n pos = vec3(-153., 45., 127.); norm = vec3(-0.176, -0.397, 0.073); return;\n } else {\n if (id < 515.) {\n pos = vec3(-308., 116., 139.); norm = vec3(-0.176, -0.397, 0.073); return;\n } else {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.176, -0.397, 0.073); return;\n }\n }\n } else {\n if (id < 517.) {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.417, -0.633, -0.091); return;\n } else {\n if (id < 518.) {\n pos = vec3(-308., 116., 139.); norm = vec3(-0.417, -0.633, -0.091); return;\n } else {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.417, -0.633, -0.091); return;\n }\n }\n }\n }\n } else {\n if (id < 525.) {\n if (id < 522.) {\n if (id < 520.) {\n pos = vec3(-68., 46., -184.); norm = vec3(0.413, 0.867, -0.072); return;\n } else {\n if (id < 521.) {\n pos = vec3(-236., 127., -173.); norm = vec3(0.413, 0.867, -0.072); return;\n } else {\n pos = vec3(-172., 112., 14.); norm = vec3(0.413, 0.867, -0.072); return;\n }\n }\n } else {\n if (id < 523.) {\n pos = vec3(-172., 112., 14.); norm = vec3(0.215, 0.723, -0.016); return;\n } else {\n if (id < 524.) {\n pos = vec3(-236., 127., -173.); norm = vec3(0.215, 0.723, -0.016); return;\n } else {\n pos = vec3(-325., 157., -8.); norm = vec3(0.215, 0.723, -0.016); return;\n }\n }\n }\n } else {\n if (id < 528.) {\n if (id < 526.) {\n pos = vec3(-236., 127., -173.); norm = vec3(0.299, 0.879, 0.002); return;\n } else {\n if (id < 527.) {\n pos = vec3(-401., 183., -70.); norm = vec3(0.299, 0.879, 0.002); return;\n } else {\n pos = vec3(-325., 157., -8.); norm = vec3(0.299, 0.879, 0.002); return;\n }\n }\n } else {\n if (id < 530.) {\n if (id < 529.) {\n pos = vec3(-325., 157., -8.); norm = vec3(0.176, 0.964, 0.188); return;\n } else {\n pos = vec3(-401., 183., -70.); norm = vec3(0.176, 0.964, 0.188); return;\n }\n } else {\n if (id < 531.) {\n pos = vec3(-497., 175., 61.); norm = vec3(0.176, 0.964, 0.188); return;\n } else {\n pos = vec3(-401., 183., -70.); norm = vec3(0.024, 0.077, -0.004); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 545.) {\n if (id < 538.) {\n if (id < 535.) {\n if (id < 533.) {\n pos = vec3(-236., 127., -173.); norm = vec3(0.024, 0.077, -0.004); return;\n } else {\n if (id < 534.) {\n pos = vec3(-386., 177., -96.); norm = vec3(0.024, 0.077, -0.004); return;\n } else {\n pos = vec3(-386., 177., -96.); norm = vec3(-0.156, 0.275, -0.483); return;\n }\n }\n } else {\n if (id < 536.) {\n pos = vec3(-236., 127., -173.); norm = vec3(-0.156, 0.275, -0.483); return;\n } else {\n if (id < 537.) {\n pos = vec3(-220., 101., -193.); norm = vec3(-0.156, 0.275, -0.483); return;\n } else {\n pos = vec3(-85., 100., -20.); norm = vec3(0.040, 0.469, -0.064); return;\n }\n }\n }\n } else {\n if (id < 541.) {\n if (id < 539.) {\n pos = vec3(-63., 88., -94.); norm = vec3(0.040, 0.469, -0.064); return;\n } else {\n if (id < 540.) {\n pos = vec3(-172., 112., 14.); norm = vec3(0.040, 0.469, -0.064); return;\n } else {\n pos = vec3(-172., 112., 14.); norm = vec3(-0.154, 0.670, -0.304); return;\n }\n }\n } else {\n if (id < 543.) {\n if (id < 542.) {\n pos = vec3(-63., 88., -94.); norm = vec3(-0.154, 0.670, -0.304); return;\n } else {\n pos = vec3(-68., 46., -184.); norm = vec3(-0.154, 0.670, -0.304); return;\n }\n } else {\n if (id < 544.) {\n pos = vec3(-564., 150., 216.); norm = vec3(0.019, 0.088, 0.064); return;\n } else {\n pos = vec3(-312., 136., 159.); norm = vec3(0.019, 0.088, 0.064); return;\n }\n }\n }\n }\n } else {\n if (id < 551.) {\n if (id < 548.) {\n if (id < 546.) {\n pos = vec3(-557., 166., 192.); norm = vec3(0.019, 0.088, 0.064); return;\n } else {\n if (id < 547.) {\n pos = vec3(-557., 166., 192.); norm = vec3(0.175, 0.582, 0.770); return;\n } else {\n pos = vec3(-312., 136., 159.); norm = vec3(0.175, 0.582, 0.770); return;\n }\n }\n } else {\n if (id < 549.) {\n pos = vec3(-306., 158., 141.); norm = vec3(0.175, 0.582, 0.770); return;\n } else {\n if (id < 550.) {\n pos = vec3(-564., 150., 216.); norm = vec3(0.095, -0.537, 0.551); return;\n } else {\n pos = vec3(-557., 142., 207.); norm = vec3(0.095, -0.537, 0.551); return;\n }\n }\n }\n } else {\n if (id < 554.) {\n if (id < 552.) {\n pos = vec3(-312., 136., 159.); norm = vec3(0.095, -0.537, 0.551); return;\n } else {\n if (id < 553.) {\n pos = vec3(-312., 136., 159.); norm = vec3(0.013, -0.073, 0.075); return;\n } else {\n pos = vec3(-557., 142., 207.); norm = vec3(0.013, -0.073, 0.075); return;\n }\n }\n } else {\n if (id < 556.) {\n if (id < 555.) {\n pos = vec3(-308., 116., 139.); norm = vec3(0.013, -0.073, 0.075); return;\n } else {\n pos = vec3(-68., 46., -184.); norm = vec3(-0.260, -0.738, -0.120); return;\n }\n } else {\n if (id < 557.) {\n pos = vec3(-128., 42., -30.); norm = vec3(-0.260, -0.738, -0.120); return;\n } else {\n pos = vec3(-220., 101., -193.); norm = vec3(-0.260, -0.738, -0.120); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 583.) {\n if (id < 570.) {\n if (id < 564.) {\n if (id < 561.) {\n if (id < 559.) {\n pos = vec3(-220., 101., -193.); norm = vec3(-0.087, -0.182, -0.017); return;\n } else {\n if (id < 560.) {\n pos = vec3(-128., 42., -30.); norm = vec3(-0.087, -0.182, -0.017); return;\n } else {\n pos = vec3(-248., 112., -167.); norm = vec3(-0.087, -0.182, -0.017); return;\n }\n }\n } else {\n if (id < 562.) {\n pos = vec3(-172., 112., 14.); norm = vec3(0.278, 0.925, -0.042); return;\n } else {\n if (id < 563.) {\n pos = vec3(-325., 157., -8.); norm = vec3(0.278, 0.925, -0.042); return;\n } else {\n pos = vec3(-306., 158., 141.); norm = vec3(0.278, 0.925, -0.042); return;\n }\n }\n }\n } else {\n if (id < 567.) {\n if (id < 565.) {\n pos = vec3(-306., 158., 141.); norm = vec3(0.025, 0.834, -0.009); return;\n } else {\n if (id < 566.) {\n pos = vec3(-325., 157., -8.); norm = vec3(0.025, 0.834, -0.009); return;\n } else {\n pos = vec3(-557., 166., 192.); norm = vec3(0.025, 0.834, -0.009); return;\n }\n }\n } else {\n if (id < 568.) {\n pos = vec3(-408., 152., -38.); norm = vec3(-0.493, -0.572, -0.434); return;\n } else {\n if (id < 569.) {\n pos = vec3(-386., 177., -96.); norm = vec3(-0.493, -0.572, -0.434); return;\n } else {\n pos = vec3(-248., 112., -167.); norm = vec3(-0.493, -0.572, -0.434); return;\n }\n }\n }\n }\n } else {\n if (id < 576.) {\n if (id < 573.) {\n if (id < 571.) {\n pos = vec3(-248., 112., -167.); norm = vec3(-0.026, -0.046, -0.009); return;\n } else {\n if (id < 572.) {\n pos = vec3(-386., 177., -96.); norm = vec3(-0.026, -0.046, -0.009); return;\n } else {\n pos = vec3(-220., 101., -193.); norm = vec3(-0.026, -0.046, -0.009); return;\n }\n }\n } else {\n if (id < 574.) {\n pos = vec3(-386., 177., -96.); norm = vec3(-0.054, 0.217, -0.081); return;\n } else {\n if (id < 575.) {\n pos = vec3(-509., 144., -103.); norm = vec3(-0.054, 0.217, -0.081); return;\n } else {\n pos = vec3(-401., 183., -70.); norm = vec3(-0.054, 0.217, -0.081); return;\n }\n }\n }\n } else {\n if (id < 579.) {\n if (id < 577.) {\n pos = vec3(-401., 183., -70.); norm = vec3(-0.099, 0.773, -0.590); return;\n } else {\n if (id < 578.) {\n pos = vec3(-509., 144., -103.); norm = vec3(-0.099, 0.773, -0.590); return;\n } else {\n pos = vec3(-512., 152., -92.); norm = vec3(-0.099, 0.773, -0.590); return;\n }\n }\n } else {\n if (id < 581.) {\n if (id < 580.) {\n pos = vec3(-795., 100., 140.); norm = vec3(-0.021, 0.080, -0.006); return;\n } else {\n pos = vec3(-557., 166., 192.); norm = vec3(-0.021, 0.080, -0.006); return;\n }\n } else {\n if (id < 582.) {\n pos = vec3(-786., 101., 121.); norm = vec3(-0.021, 0.080, -0.006); return;\n } else {\n pos = vec3(-733., 113., 89.); norm = vec3(-0.187, 0.708, -0.044); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 596.) {\n if (id < 589.) {\n if (id < 586.) {\n if (id < 584.) {\n pos = vec3(-786., 101., 121.); norm = vec3(-0.187, 0.708, -0.044); return;\n } else {\n if (id < 585.) {\n pos = vec3(-557., 166., 192.); norm = vec3(-0.187, 0.708, -0.044); return;\n } else {\n pos = vec3(-401., 183., -70.); norm = vec3(-0.232, 0.913, -0.114); return;\n }\n }\n } else {\n if (id < 587.) {\n pos = vec3(-512., 152., -92.); norm = vec3(-0.232, 0.913, -0.114); return;\n } else {\n if (id < 588.) {\n pos = vec3(-497., 175., 61.); norm = vec3(-0.232, 0.913, -0.114); return;\n } else {\n pos = vec3(-497., 175., 61.); norm = vec3(-0.166, 0.972, -0.130); return;\n }\n }\n }\n } else {\n if (id < 592.) {\n if (id < 590.) {\n pos = vec3(-512., 152., -92.); norm = vec3(-0.166, 0.972, -0.130); return;\n } else {\n if (id < 591.) {\n pos = vec3(-598., 140., -72.); norm = vec3(-0.166, 0.972, -0.130); return;\n } else {\n pos = vec3(-802., 83., 164.); norm = vec3(0.054, -0.718, 0.680); return;\n }\n }\n } else {\n if (id < 594.) {\n if (id < 593.) {\n pos = vec3(-795., 75., 155.); norm = vec3(0.054, -0.718, 0.680); return;\n } else {\n pos = vec3(-564., 150., 216.); norm = vec3(0.054, -0.718, 0.680); return;\n }\n } else {\n if (id < 595.) {\n pos = vec3(-564., 150., 216.); norm = vec3(0.003, -0.040, 0.038); return;\n } else {\n pos = vec3(-795., 75., 155.); norm = vec3(0.003, -0.040, 0.038); return;\n }\n }\n }\n }\n } else {\n if (id < 602.) {\n if (id < 599.) {\n if (id < 597.) {\n pos = vec3(-557., 142., 207.); norm = vec3(0.003, -0.040, 0.038); return;\n } else {\n if (id < 598.) {\n pos = vec3(-557., 166., 192.); norm = vec3(-0.039, 0.097, 0.053); return;\n } else {\n pos = vec3(-795., 100., 140.); norm = vec3(-0.039, 0.097, 0.053); return;\n }\n }\n } else {\n if (id < 600.) {\n pos = vec3(-564., 150., 216.); norm = vec3(-0.039, 0.097, 0.053); return;\n } else {\n if (id < 601.) {\n pos = vec3(-564., 150., 216.); norm = vec3(-0.332, 0.810, 0.477); return;\n } else {\n pos = vec3(-795., 100., 140.); norm = vec3(-0.332, 0.810, 0.477); return;\n }\n }\n }\n } else {\n if (id < 605.) {\n if (id < 603.) {\n pos = vec3(-802., 83., 164.); norm = vec3(-0.332, 0.810, 0.477); return;\n } else {\n if (id < 604.) {\n pos = vec3(-665., 93., -1.); norm = vec3(0.242, -0.933, 0.079); return;\n } else {\n pos = vec3(-653., 93., -38.); norm = vec3(0.242, -0.933, 0.079); return;\n }\n }\n } else {\n if (id < 607.) {\n if (id < 606.) {\n pos = vec3(-491., 144., 68.); norm = vec3(0.242, -0.933, 0.079); return;\n } else {\n pos = vec3(-653., 93., -38.); norm = vec3(0.244, -0.938, 0.078); return;\n }\n } else {\n if (id < 608.) {\n pos = vec3(-590., 107., -67.); norm = vec3(0.244, -0.938, 0.078); return;\n } else {\n pos = vec3(-491., 144., 68.); norm = vec3(0.244, -0.938, 0.078); return;\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 711.) {\n if (id < 660.) {\n if (id < 634.) {\n if (id < 621.) {\n if (id < 615.) {\n if (id < 612.) {\n if (id < 610.) {\n pos = vec3(-408., 152., -38.); norm = vec3(0.216, -0.938, 0.099); return;\n } else {\n if (id < 611.) {\n pos = vec3(-491., 144., 68.); norm = vec3(0.216, -0.938, 0.099); return;\n } else {\n pos = vec3(-590., 107., -67.); norm = vec3(0.216, -0.938, 0.099); return;\n }\n }\n } else {\n if (id < 613.) {\n pos = vec3(-509., 144., -103.); norm = vec3(-0.077, 0.087, -0.085); return;\n } else {\n if (id < 614.) {\n pos = vec3(-590., 107., -67.); norm = vec3(-0.077, 0.087, -0.085); return;\n } else {\n pos = vec3(-512., 152., -92.); norm = vec3(-0.077, 0.087, -0.085); return;\n }\n }\n }\n } else {\n if (id < 618.) {\n if (id < 616.) {\n pos = vec3(-512., 152., -92.); norm = vec3(-0.187, -0.184, -0.915); return;\n } else {\n if (id < 617.) {\n pos = vec3(-590., 107., -67.); norm = vec3(-0.187, -0.184, -0.915); return;\n } else {\n pos = vec3(-598., 140., -72.); norm = vec3(-0.187, -0.184, -0.915); return;\n }\n }\n } else {\n if (id < 619.) {\n pos = vec3(-725., 81., 25.); norm = vec3(0.016, 0.005, -0.191); return;\n } else {\n if (id < 620.) {\n pos = vec3(-874., 56., 12.); norm = vec3(0.016, 0.005, -0.191); return;\n } else {\n pos = vec3(-733., 109., 25.); norm = vec3(0.016, 0.005, -0.191); return;\n }\n }\n }\n }\n } else {\n if (id < 627.) {\n if (id < 624.) {\n if (id < 622.) {\n pos = vec3(-733., 109., 25.); norm = vec3(-0.130, 0.350, -0.022); return;\n } else {\n if (id < 623.) {\n pos = vec3(-874., 56., 12.); norm = vec3(-0.130, 0.350, -0.022); return;\n } else {\n pos = vec3(-733., 113., 89.); norm = vec3(-0.130, 0.350, -0.022); return;\n }\n }\n } else {\n if (id < 625.) {\n pos = vec3(-733., 113., 89.); norm = vec3(-0.075, -0.009, 0.145); return;\n } else {\n if (id < 626.) {\n pos = vec3(-874., 56., 12.); norm = vec3(-0.075, -0.009, 0.145); return;\n } else {\n pos = vec3(-726., 86., 91.); norm = vec3(-0.075, -0.009, 0.145); return;\n }\n }\n }\n } else {\n if (id < 630.) {\n if (id < 628.) {\n pos = vec3(-726., 86., 91.); norm = vec3(0.061, -0.381, 0.030); return;\n } else {\n if (id < 629.) {\n pos = vec3(-874., 56., 12.); norm = vec3(0.061, -0.381, 0.030); return;\n } else {\n pos = vec3(-725., 81., 25.); norm = vec3(0.061, -0.381, 0.030); return;\n }\n }\n } else {\n if (id < 632.) {\n if (id < 631.) {\n pos = vec3(-665., 93., -1.); norm = vec3(0.067, 0.028, -0.213); return;\n } else {\n pos = vec3(-800., 71., -46.); norm = vec3(0.067, 0.028, -0.213); return;\n }\n } else {\n if (id < 633.) {\n pos = vec3(-675., 124., 0.); norm = vec3(0.067, 0.028, -0.213); return;\n } else {\n pos = vec3(-675., 124., 0.); norm = vec3(-0.134, 0.386, -0.080); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 647.) {\n if (id < 640.) {\n if (id < 637.) {\n if (id < 635.) {\n pos = vec3(-800., 71., -46.); norm = vec3(-0.134, 0.386, -0.080); return;\n } else {\n if (id < 636.) {\n pos = vec3(-733., 109., 25.); norm = vec3(-0.134, 0.386, -0.080); return;\n } else {\n pos = vec3(-733., 109., 25.); norm = vec3(-0.183, -0.052, 0.201); return;\n }\n }\n } else {\n if (id < 638.) {\n pos = vec3(-800., 71., -46.); norm = vec3(-0.183, -0.052, 0.201); return;\n } else {\n if (id < 639.) {\n pos = vec3(-725., 81., 25.); norm = vec3(-0.183, -0.052, 0.201); return;\n } else {\n pos = vec3(-725., 81., 25.); norm = vec3(0.074, -0.416, -0.020); return;\n }\n }\n }\n } else {\n if (id < 643.) {\n if (id < 641.) {\n pos = vec3(-800., 71., -46.); norm = vec3(0.074, -0.416, -0.020); return;\n } else {\n if (id < 642.) {\n pos = vec3(-665., 93., -1.); norm = vec3(0.074, -0.416, -0.020); return;\n } else {\n pos = vec3(-653., 93., -38.); norm = vec3(0.179, 0.025, -0.317); return;\n }\n }\n } else {\n if (id < 645.) {\n if (id < 644.) {\n pos = vec3(-730., 87., -82.); norm = vec3(0.179, 0.025, -0.317); return;\n } else {\n pos = vec3(-661., 125., -40.); norm = vec3(0.179, 0.025, -0.317); return;\n }\n } else {\n if (id < 646.) {\n pos = vec3(-661., 125., -40.); norm = vec3(-0.166, 0.356, -0.049); return;\n } else {\n pos = vec3(-730., 87., -82.); norm = vec3(-0.166, 0.356, -0.049); return;\n }\n }\n }\n }\n } else {\n if (id < 653.) {\n if (id < 650.) {\n if (id < 648.) {\n pos = vec3(-675., 124., 0.); norm = vec3(-0.166, 0.356, -0.049); return;\n } else {\n if (id < 649.) {\n pos = vec3(-675., 124., 0.); norm = vec3(-0.228, -0.080, 0.189); return;\n } else {\n pos = vec3(-730., 87., -82.); norm = vec3(-0.228, -0.080, 0.189); return;\n }\n }\n } else {\n if (id < 651.) {\n pos = vec3(-665., 93., -1.); norm = vec3(-0.228, -0.080, 0.189); return;\n } else {\n if (id < 652.) {\n pos = vec3(-665., 93., -1.); norm = vec3(0.024, -0.365, 0.008); return;\n } else {\n pos = vec3(-730., 87., -82.); norm = vec3(0.024, -0.365, 0.008); return;\n }\n }\n }\n } else {\n if (id < 656.) {\n if (id < 654.) {\n pos = vec3(-653., 93., -38.); norm = vec3(0.024, -0.365, 0.008); return;\n } else {\n if (id < 655.) {\n pos = vec3(-590., 107., -67.); norm = vec3(0.183, -0.012, -0.370); return;\n } else {\n pos = vec3(-663., 103., -103.); norm = vec3(0.183, -0.012, -0.370); return;\n }\n }\n } else {\n if (id < 658.) {\n if (id < 657.) {\n pos = vec3(-598., 140., -72.); norm = vec3(0.183, -0.012, -0.370); return;\n } else {\n pos = vec3(-598., 140., -72.); norm = vec3(-0.305, 0.746, -0.251); return;\n }\n } else {\n if (id < 659.) {\n pos = vec3(-663., 103., -103.); norm = vec3(-0.305, 0.746, -0.251); return;\n } else {\n pos = vec3(-661., 125., -40.); norm = vec3(-0.305, 0.746, -0.251); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 685.) {\n if (id < 672.) {\n if (id < 666.) {\n if (id < 663.) {\n if (id < 661.) {\n pos = vec3(-661., 125., -40.); norm = vec3(-0.464, -0.113, 0.054); return;\n } else {\n if (id < 662.) {\n pos = vec3(-663., 103., -103.); norm = vec3(-0.464, -0.113, 0.054); return;\n } else {\n pos = vec3(-653., 93., -38.); norm = vec3(-0.464, -0.113, 0.054); return;\n }\n }\n } else {\n if (id < 664.) {\n pos = vec3(-653., 93., -38.); norm = vec3(0.114, -0.809, -0.142); return;\n } else {\n if (id < 665.) {\n pos = vec3(-663., 103., -103.); norm = vec3(0.114, -0.809, -0.142); return;\n } else {\n pos = vec3(-590., 107., -67.); norm = vec3(0.114, -0.809, -0.142); return;\n }\n }\n }\n } else {\n if (id < 669.) {\n if (id < 667.) {\n pos = vec3(-780., 75., 123.); norm = vec3(-0.019, -0.024, -0.254); return;\n } else {\n if (id < 668.) {\n pos = vec3(-882., 62., 132.); norm = vec3(-0.019, -0.024, -0.254); return;\n } else {\n pos = vec3(-786., 101., 121.); norm = vec3(-0.019, -0.024, -0.254); return;\n }\n }\n } else {\n if (id < 670.) {\n pos = vec3(-786., 101., 121.); norm = vec3(-0.074, 0.174, -0.026); return;\n } else {\n if (id < 671.) {\n pos = vec3(-882., 62., 132.); norm = vec3(-0.074, 0.174, -0.026); return;\n } else {\n pos = vec3(-795., 100., 140.); norm = vec3(-0.074, 0.174, -0.026); return;\n }\n }\n }\n }\n } else {\n if (id < 678.) {\n if (id < 675.) {\n if (id < 673.) {\n pos = vec3(-795., 100., 140.); norm = vec3(-0.124, 0.254, 0.144); return;\n } else {\n if (id < 674.) {\n pos = vec3(-882., 62., 132.); norm = vec3(-0.124, 0.254, 0.144); return;\n } else {\n pos = vec3(-802., 83., 164.); norm = vec3(-0.124, 0.254, 0.144); return;\n }\n }\n } else {\n if (id < 676.) {\n pos = vec3(-802., 83., 164.); norm = vec3(-0.008, -0.117, 0.098); return;\n } else {\n if (id < 677.) {\n pos = vec3(-882., 62., 132.); norm = vec3(-0.008, -0.117, 0.098); return;\n } else {\n pos = vec3(-795., 75., 155.); norm = vec3(-0.008, -0.117, 0.098); return;\n }\n }\n }\n } else {\n if (id < 681.) {\n if (id < 679.) {\n pos = vec3(-795., 75., 155.); norm = vec3(0.044, -0.333, 0.021); return;\n } else {\n if (id < 680.) {\n pos = vec3(-882., 62., 132.); norm = vec3(0.044, -0.333, 0.021); return;\n } else {\n pos = vec3(-780., 75., 123.); norm = vec3(0.044, -0.333, 0.021); return;\n }\n }\n } else {\n if (id < 683.) {\n if (id < 682.) {\n pos = vec3(-726., 86., 91.); norm = vec3(0.010, -0.008, -0.139); return;\n } else {\n pos = vec3(-922., 48., 79.); norm = vec3(0.010, -0.008, -0.139); return;\n }\n } else {\n if (id < 684.) {\n pos = vec3(-733., 113., 89.); norm = vec3(0.010, -0.008, -0.139); return;\n } else {\n pos = vec3(-733., 113., 89.); norm = vec3(-0.072, 0.216, -0.039); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 698.) {\n if (id < 691.) {\n if (id < 688.) {\n if (id < 686.) {\n pos = vec3(-922., 48., 79.); norm = vec3(-0.072, 0.216, -0.039); return;\n } else {\n if (id < 687.) {\n pos = vec3(-786., 101., 121.); norm = vec3(-0.072, 0.216, -0.039); return;\n } else {\n pos = vec3(-786., 101., 121.); norm = vec3(-0.052, 0.001, 0.168); return;\n }\n }\n } else {\n if (id < 689.) {\n pos = vec3(-922., 48., 79.); norm = vec3(-0.052, 0.001, 0.168); return;\n } else {\n if (id < 690.) {\n pos = vec3(-780., 75., 123.); norm = vec3(-0.052, 0.001, 0.168); return;\n } else {\n pos = vec3(-780., 75., 123.); norm = vec3(0.045, -0.229, -0.003); return;\n }\n }\n }\n } else {\n if (id < 694.) {\n if (id < 692.) {\n pos = vec3(-922., 48., 79.); norm = vec3(0.045, -0.229, -0.003); return;\n } else {\n if (id < 693.) {\n pos = vec3(-726., 86., 91.); norm = vec3(0.045, -0.229, -0.003); return;\n } else {\n pos = vec3(-386., 177., -96.); norm = vec3(0.259, -0.905, -0.292); return;\n }\n }\n } else {\n if (id < 696.) {\n if (id < 695.) {\n pos = vec3(-408., 152., -38.); norm = vec3(0.259, -0.905, -0.292); return;\n } else {\n pos = vec3(-509., 144., -103.); norm = vec3(0.259, -0.905, -0.292); return;\n }\n } else {\n if (id < 697.) {\n pos = vec3(-509., 144., -103.); norm = vec3(0.118, -0.390, -0.135); return;\n } else {\n pos = vec3(-408., 152., -38.); norm = vec3(0.118, -0.390, -0.135); return;\n }\n }\n }\n }\n } else {\n if (id < 704.) {\n if (id < 701.) {\n if (id < 699.) {\n pos = vec3(-590., 107., -67.); norm = vec3(0.118, -0.390, -0.135); return;\n } else {\n if (id < 700.) {\n pos = vec3(-733., 113., 89.); norm = vec3(-0.057, 0.215, -0.013); return;\n } else {\n pos = vec3(-557., 166., 192.); norm = vec3(-0.057, 0.215, -0.013); return;\n }\n }\n } else {\n if (id < 702.) {\n pos = vec3(-733., 109., 25.); norm = vec3(-0.057, 0.215, -0.013); return;\n } else {\n if (id < 703.) {\n pos = vec3(-675., 124., 0.); norm = vec3(-0.243, 0.871, -0.041); return;\n } else {\n pos = vec3(-733., 109., 25.); norm = vec3(-0.243, 0.871, -0.041); return;\n }\n }\n }\n } else {\n if (id < 707.) {\n if (id < 705.) {\n pos = vec3(-557., 166., 192.); norm = vec3(-0.243, 0.871, -0.041); return;\n } else {\n if (id < 706.) {\n pos = vec3(-557., 166., 192.); norm = vec3(-0.257, 0.959, -0.052); return;\n } else {\n pos = vec3(-497., 175., 61.); norm = vec3(-0.257, 0.959, -0.052); return;\n }\n }\n } else {\n if (id < 709.) {\n if (id < 708.) {\n pos = vec3(-675., 124., 0.); norm = vec3(-0.257, 0.959, -0.052); return;\n } else {\n pos = vec3(-675., 124., 0.); norm = vec3(-0.054, 0.206, -0.014); return;\n }\n } else {\n if (id < 710.) {\n pos = vec3(-497., 175., 61.); norm = vec3(-0.054, 0.206, -0.014); return;\n } else {\n pos = vec3(-661., 125., -40.); norm = vec3(-0.054, 0.206, -0.014); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 762.) {\n if (id < 736.) {\n if (id < 723.) {\n if (id < 717.) {\n if (id < 714.) {\n if (id < 712.) {\n pos = vec3(-497., 175., 61.); norm = vec3(-0.253, 0.942, -0.056); return;\n } else {\n if (id < 713.) {\n pos = vec3(-598., 140., -72.); norm = vec3(-0.253, 0.942, -0.056); return;\n } else {\n pos = vec3(-661., 125., -40.); norm = vec3(-0.253, 0.942, -0.056); return;\n }\n }\n } else {\n if (id < 715.) {\n pos = vec3(-68., 46., -184.); norm = vec3(0.226, 0.539, -0.520); return;\n } else {\n if (id < 716.) {\n pos = vec3(-220., 101., -193.); norm = vec3(0.226, 0.539, -0.520); return;\n } else {\n pos = vec3(-236., 127., -173.); norm = vec3(0.226, 0.539, -0.520); return;\n }\n }\n }\n } else {\n if (id < 720.) {\n if (id < 718.) {\n pos = vec3(-557., 142., 207.); norm = vec3(0.155, -0.603, 0.065); return;\n } else {\n if (id < 719.) {\n pos = vec3(-726., 86., 91.); norm = vec3(0.155, -0.603, 0.065); return;\n } else {\n pos = vec3(-491., 144., 68.); norm = vec3(0.155, -0.603, 0.065); return;\n }\n }\n } else {\n if (id < 721.) {\n pos = vec3(-726., 86., 91.); norm = vec3(0.242, -0.951, 0.076); return;\n } else {\n if (id < 722.) {\n pos = vec3(-725., 81., 25.); norm = vec3(0.242, -0.951, 0.076); return;\n } else {\n pos = vec3(-491., 144., 68.); norm = vec3(0.242, -0.951, 0.076); return;\n }\n }\n }\n }\n } else {\n if (id < 729.) {\n if (id < 726.) {\n if (id < 724.) {\n pos = vec3(-725., 81., 25.); norm = vec3(0.167, -0.672, 0.075); return;\n } else {\n if (id < 725.) {\n pos = vec3(-665., 93., -1.); norm = vec3(0.167, -0.672, 0.075); return;\n } else {\n pos = vec3(-491., 144., 68.); norm = vec3(0.167, -0.672, 0.075); return;\n }\n }\n } else {\n if (id < 727.) {\n pos = vec3(-795., 75., 155.); norm = vec3(0.245, -0.960, 0.115); return;\n } else {\n if (id < 728.) {\n pos = vec3(-780., 75., 123.); norm = vec3(0.245, -0.960, 0.115); return;\n } else {\n pos = vec3(-557., 142., 207.); norm = vec3(0.245, -0.960, 0.115); return;\n }\n }\n }\n } else {\n if (id < 732.) {\n if (id < 730.) {\n pos = vec3(-557., 142., 207.); norm = vec3(0.194, -0.740, 0.074); return;\n } else {\n if (id < 731.) {\n pos = vec3(-780., 75., 123.); norm = vec3(0.194, -0.740, 0.074); return;\n } else {\n pos = vec3(-726., 86., 91.); norm = vec3(0.194, -0.740, 0.074); return;\n }\n }\n } else {\n if (id < 734.) {\n if (id < 733.) {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.504, -0.849, 0.158); return;\n } else {\n pos = vec3(-115., 15., 87.); norm = vec3(-0.504, -0.849, 0.158); return;\n }\n } else {\n if (id < 735.) {\n pos = vec3(-153., 45., 127.); norm = vec3(-0.504, -0.849, 0.158); return;\n } else {\n pos = vec3(-248., 112., -167.); norm = vec3(-0.383, -0.758, -0.052); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 749.) {\n if (id < 742.) {\n if (id < 739.) {\n if (id < 737.) {\n pos = vec3(-128., 42., -30.); norm = vec3(-0.383, -0.758, -0.052); return;\n } else {\n if (id < 738.) {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.383, -0.758, -0.052); return;\n } else {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.433, -0.721, -0.303); return;\n }\n }\n } else {\n if (id < 740.) {\n pos = vec3(-128., 42., -30.); norm = vec3(-0.433, -0.721, -0.303); return;\n } else {\n if (id < 741.) {\n pos = vec3(-154., 29., 38.); norm = vec3(-0.433, -0.721, -0.303); return;\n } else {\n pos = vec3(-248., 112., -167.); norm = vec3(-0.258, -0.950, -0.025); return;\n }\n }\n }\n } else {\n if (id < 745.) {\n if (id < 743.) {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.258, -0.950, -0.025); return;\n } else {\n if (id < 744.) {\n pos = vec3(-408., 152., -38.); norm = vec3(-0.258, -0.950, -0.025); return;\n } else {\n pos = vec3(-408., 152., -38.); norm = vec3(-0.110, -0.565, -0.128); return;\n }\n }\n } else {\n if (id < 747.) {\n if (id < 746.) {\n pos = vec3(-280., 116., 11.); norm = vec3(-0.110, -0.565, -0.128); return;\n } else {\n pos = vec3(-491., 144., 68.); norm = vec3(-0.110, -0.565, -0.128); return;\n }\n } else {\n if (id < 748.) {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.295, 0.825, 0.172); return;\n } else {\n pos = vec3(6., 98., 815.); norm = vec3(-0.295, 0.825, 0.172); return;\n }\n }\n }\n }\n } else {\n if (id < 755.) {\n if (id < 752.) {\n if (id < 750.) {\n pos = vec3(-23., 87., 818.); norm = vec3(-0.295, 0.825, 0.172); return;\n } else {\n if (id < 751.) {\n pos = vec3(0., 99., 84.); norm = vec3(0.153, 0.773, 0.365); return;\n } else {\n pos = vec3(0., 48., 192.); norm = vec3(0.153, 0.773, 0.365); return;\n }\n }\n } else {\n if (id < 753.) {\n pos = vec3(93., 56., 136.); norm = vec3(0.153, 0.773, 0.365); return;\n } else {\n if (id < 754.) {\n pos = vec3(93., 56., 136.); norm = vec3(0.262, 0.491, 0.505); return;\n } else {\n pos = vec3(0., 48., 192.); norm = vec3(0.262, 0.491, 0.505); return;\n }\n }\n }\n } else {\n if (id < 758.) {\n if (id < 756.) {\n pos = vec3(28., 31., 194.); norm = vec3(0.262, 0.491, 0.505); return;\n } else {\n if (id < 757.) {\n pos = vec3(67., 45., -184.); norm = vec3(0.836, -0.100, -0.310); return;\n } else {\n pos = vec3(66., -44., -158.); norm = vec3(0.836, -0.100, -0.310); return;\n }\n }\n } else {\n if (id < 760.) {\n if (id < 759.) {\n pos = vec3(31., -23., -259.); norm = vec3(0.836, -0.100, -0.310); return;\n } else {\n pos = vec3(31., -23., -259.); norm = vec3(0.269, -0.018, -0.097); return;\n }\n } else {\n if (id < 761.) {\n pos = vec3(66., -44., -158.); norm = vec3(0.269, -0.018, -0.097); return;\n } else {\n pos = vec3(30., -54., -256.); norm = vec3(0.269, -0.018, -0.097); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 787.) {\n if (id < 774.) {\n if (id < 768.) {\n if (id < 765.) {\n if (id < 763.) {\n pos = vec3(0., -11., -266.); norm = vec3(0.109, 0.186, -0.163); return;\n } else {\n if (id < 764.) {\n pos = vec3(0., 67., -177.); norm = vec3(0.109, 0.186, -0.163); return;\n } else {\n pos = vec3(31., -23., -259.); norm = vec3(0.109, 0.186, -0.163); return;\n }\n }\n } else {\n if (id < 766.) {\n pos = vec3(31., -23., -259.); norm = vec3(0.335, 0.694, -0.635); return;\n } else {\n if (id < 767.) {\n pos = vec3(0., 67., -177.); norm = vec3(0.335, 0.694, -0.635); return;\n } else {\n pos = vec3(40., 66., -157.); norm = vec3(0.335, 0.694, -0.635); return;\n }\n }\n }\n } else {\n if (id < 771.) {\n if (id < 769.) {\n pos = vec3(57., 10., 196.); norm = vec3(0.833, -0.048, 0.441); return;\n } else {\n if (id < 770.) {\n pos = vec3(55., -25., 196.); norm = vec3(0.833, -0.048, 0.441); return;\n } else {\n pos = vec3(115., 15., 87.); norm = vec3(0.833, -0.048, 0.441); return;\n }\n }\n } else {\n if (id < 772.) {\n pos = vec3(115., 15., 87.); norm = vec3(0.484, -0.171, 0.204); return;\n } else {\n if (id < 773.) {\n pos = vec3(55., -25., 196.); norm = vec3(0.484, -0.171, 0.204); return;\n } else {\n pos = vec3(95., -57., 74.); norm = vec3(0.484, -0.171, 0.204); return;\n }\n }\n }\n }\n } else {\n if (id < 780.) {\n if (id < 777.) {\n if (id < 775.) {\n pos = vec3(63., 88., -94.); norm = vec3(0.011, 0.667, -0.237); return;\n } else {\n if (id < 776.) {\n pos = vec3(40., 66., -157.); norm = vec3(0.011, 0.667, -0.237); return;\n } else {\n pos = vec3(0., 94., -80.); norm = vec3(0.011, 0.667, -0.237); return;\n }\n }\n } else {\n if (id < 778.) {\n pos = vec3(0., 94., -80.); norm = vec3(0.156, 0.951, -0.265); return;\n } else {\n if (id < 779.) {\n pos = vec3(40., 66., -157.); norm = vec3(0.156, 0.951, -0.265); return;\n } else {\n pos = vec3(0., 67., -177.); norm = vec3(0.156, 0.951, -0.265); return;\n }\n }\n }\n } else {\n if (id < 783.) {\n if (id < 781.) {\n pos = vec3(70., -61., -150.); norm = vec3(0.712, -0.153, -0.681); return;\n } else {\n if (id < 782.) {\n pos = vec3(66., -44., -158.); norm = vec3(0.712, -0.153, -0.681); return;\n } else {\n pos = vec3(129., -9., -100.); norm = vec3(0.712, -0.153, -0.681); return;\n }\n }\n } else {\n if (id < 785.) {\n if (id < 784.) {\n pos = vec3(129., -9., -100.); norm = vec3(0.708, -0.198, -0.650); return;\n } else {\n pos = vec3(66., -44., -158.); norm = vec3(0.708, -0.198, -0.650); return;\n }\n } else {\n if (id < 786.) {\n pos = vec3(67., 45., -184.); norm = vec3(0.708, -0.198, -0.650); return;\n } else {\n pos = vec3(0., 109., -12.); norm = vec3(0.055, 0.646, -0.143); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 800.) {\n if (id < 793.) {\n if (id < 790.) {\n if (id < 788.) {\n pos = vec3(85., 100., -20.); norm = vec3(0.055, 0.646, -0.143); return;\n } else {\n if (id < 789.) {\n pos = vec3(0., 94., -80.); norm = vec3(0.055, 0.646, -0.143); return;\n } else {\n pos = vec3(0., 94., -80.); norm = vec3(0.034, 0.610, -0.109); return;\n }\n }\n } else {\n if (id < 791.) {\n pos = vec3(85., 100., -20.); norm = vec3(0.034, 0.610, -0.109); return;\n } else {\n if (id < 792.) {\n pos = vec3(63., 88., -94.); norm = vec3(0.034, 0.610, -0.109); return;\n } else {\n pos = vec3(41., -73., -173.); norm = vec3(0.299, -0.212, -0.088); return;\n }\n }\n }\n } else {\n if (id < 796.) {\n if (id < 794.) {\n pos = vec3(30., -54., -256.); norm = vec3(0.299, -0.212, -0.088); return;\n } else {\n if (id < 795.) {\n pos = vec3(66., -44., -158.); norm = vec3(0.299, -0.212, -0.088); return;\n } else {\n pos = vec3(0., -132., 23.); norm = vec3(0.230, -0.921, 0.213); return;\n }\n }\n } else {\n if (id < 798.) {\n if (id < 797.) {\n pos = vec3(64., -116., 23.); norm = vec3(0.230, -0.921, 0.213); return;\n } else {\n pos = vec3(0., -81., 243.); norm = vec3(0.230, -0.921, 0.213); return;\n }\n } else {\n if (id < 799.) {\n pos = vec3(31., -23., -259.); norm = vec3(-0.044, 0.507, -0.438); return;\n } else {\n pos = vec3(40., 66., -157.); norm = vec3(-0.044, 0.507, -0.438); return;\n }\n }\n }\n }\n } else {\n if (id < 806.) {\n if (id < 803.) {\n if (id < 801.) {\n pos = vec3(67., 45., -184.); norm = vec3(-0.044, 0.507, -0.438); return;\n } else {\n if (id < 802.) {\n pos = vec3(67., 45., -184.); norm = vec3(0.237, 0.755, -0.350); return;\n } else {\n pos = vec3(40., 66., -157.); norm = vec3(0.237, 0.755, -0.350); return;\n }\n }\n } else {\n if (id < 804.) {\n pos = vec3(63., 88., -94.); norm = vec3(0.237, 0.755, -0.350); return;\n } else {\n if (id < 805.) {\n pos = vec3(28., 31., 194.); norm = vec3(0.389, 0.603, 0.696); return;\n } else {\n pos = vec3(57., 10., 196.); norm = vec3(0.389, 0.603, 0.696); return;\n }\n }\n }\n } else {\n if (id < 809.) {\n if (id < 807.) {\n pos = vec3(93., 56., 136.); norm = vec3(0.389, 0.603, 0.696); return;\n } else {\n if (id < 808.) {\n pos = vec3(93., 56., 136.); norm = vec3(0.456, -0.043, 0.240); return;\n } else {\n pos = vec3(57., 10., 196.); norm = vec3(0.456, -0.043, 0.240); return;\n }\n }\n } else {\n if (id < 811.) {\n if (id < 810.) {\n pos = vec3(115., 15., 87.); norm = vec3(0.456, -0.043, 0.240); return;\n } else {\n pos = vec3(28., -56., 288.); norm = vec3(0.345, -0.113, 0.063); return;\n }\n } else {\n if (id < 812.) {\n pos = vec3(55., -25., 196.); norm = vec3(0.345, -0.113, 0.063); return;\n } else {\n pos = vec3(37., -20., 303.); norm = vec3(0.345, -0.113, 0.063); return;\n }\n }\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1219.) {\n if (id < 1016.) {\n if (id < 914.) {\n if (id < 863.) {\n if (id < 838.) {\n if (id < 825.) {\n if (id < 819.) {\n if (id < 816.) {\n if (id < 814.) {\n pos = vec3(57., 10., 196.); norm = vec3(0.576, 0.291, 0.189); return;\n } else {\n if (id < 815.) {\n pos = vec3(34., -3., 286.); norm = vec3(0.576, 0.291, 0.189); return;\n } else {\n pos = vec3(37., -20., 303.); norm = vec3(0.576, 0.291, 0.189); return;\n }\n }\n } else {\n if (id < 817.) {\n pos = vec3(57., 10., 196.); norm = vec3(0.338, 0.914, 0.218); return;\n } else {\n if (id < 818.) {\n pos = vec3(0., 22., 234.); norm = vec3(0.338, 0.914, 0.218); return;\n } else {\n pos = vec3(34., -3., 286.); norm = vec3(0.338, 0.914, 0.218); return;\n }\n }\n }\n } else {\n if (id < 822.) {\n if (id < 820.) {\n pos = vec3(34., -3., 286.); norm = vec3(0.164, 0.491, 0.129); return;\n } else {\n if (id < 821.) {\n pos = vec3(0., 22., 234.); norm = vec3(0.164, 0.491, 0.129); return;\n } else {\n pos = vec3(0., 11., 276.); norm = vec3(0.164, 0.491, 0.129); return;\n }\n }\n } else {\n if (id < 823.) {\n pos = vec3(0., 11., 276.); norm = vec3(0.091, 0.244, 0.032); return;\n } else {\n if (id < 824.) {\n pos = vec3(1., -8., 420.); norm = vec3(0.091, 0.244, 0.032); return;\n } else {\n pos = vec3(34., -3., 286.); norm = vec3(0.091, 0.244, 0.032); return;\n }\n }\n }\n }\n } else {\n if (id < 831.) {\n if (id < 828.) {\n if (id < 826.) {\n pos = vec3(34., -3., 286.); norm = vec3(0.329, 0.937, 0.116); return;\n } else {\n if (id < 827.) {\n pos = vec3(1., -8., 420.); norm = vec3(0.329, 0.937, 0.116); return;\n } else {\n pos = vec3(22., -16., 425.); norm = vec3(0.329, 0.937, 0.116); return;\n }\n }\n } else {\n if (id < 829.) {\n pos = vec3(37., -20., 303.); norm = vec3(0.687, -0.634, -0.190); return;\n } else {\n if (id < 830.) {\n pos = vec3(33., -39., 352.); norm = vec3(0.687, -0.634, -0.190); return;\n } else {\n pos = vec3(1., -65., 323.); norm = vec3(0.687, -0.634, -0.190); return;\n }\n }\n }\n } else {\n if (id < 834.) {\n if (id < 832.) {\n pos = vec3(1., -65., 323.); norm = vec3(0.360, -0.575, 0.118); return;\n } else {\n if (id < 833.) {\n pos = vec3(33., -39., 352.); norm = vec3(0.360, -0.575, 0.118); return;\n } else {\n pos = vec3(1., -58., 357.); norm = vec3(0.360, -0.575, 0.118); return;\n }\n }\n } else {\n if (id < 836.) {\n if (id < 835.) {\n pos = vec3(29., -56., 552.); norm = vec3(0.077, -0.143, 0.049); return;\n } else {\n pos = vec3(28., -1., 714.); norm = vec3(0.077, -0.143, 0.049); return;\n }\n } else {\n if (id < 837.) {\n pos = vec3(2., -71., 551.); norm = vec3(0.077, -0.143, 0.049); return;\n } else {\n pos = vec3(2., -71., 551.); norm = vec3(0.250, -0.347, 0.109); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 850.) {\n if (id < 844.) {\n if (id < 841.) {\n if (id < 839.) {\n pos = vec3(28., -1., 714.); norm = vec3(0.250, -0.347, 0.109); return;\n } else {\n if (id < 840.) {\n pos = vec3(5., 13., 811.); norm = vec3(0.250, -0.347, 0.109); return;\n } else {\n pos = vec3(67., -74., -154.); norm = vec3(0.071, -0.404, -0.118); return;\n }\n }\n } else {\n if (id < 842.) {\n pos = vec3(0., -94., -126.); norm = vec3(0.071, -0.404, -0.118); return;\n } else {\n if (id < 843.) {\n pos = vec3(41., -73., -173.); norm = vec3(0.071, -0.404, -0.118); return;\n } else {\n pos = vec3(0., -70., -189.); norm = vec3(0.067, -0.890, -0.339); return;\n }\n }\n }\n } else {\n if (id < 847.) {\n if (id < 845.) {\n pos = vec3(41., -73., -173.); norm = vec3(0.067, -0.890, -0.339); return;\n } else {\n if (id < 846.) {\n pos = vec3(0., -94., -126.); norm = vec3(0.067, -0.890, -0.339); return;\n } else {\n pos = vec3(87., -88., -141.); norm = vec3(0.126, -0.056, -0.034); return;\n }\n }\n } else {\n if (id < 848.) {\n pos = vec3(137., -28., -52.); norm = vec3(0.126, -0.056, -0.034); return;\n } else {\n if (id < 849.) {\n pos = vec3(79., -108., -138.); norm = vec3(0.126, -0.056, -0.034); return;\n } else {\n pos = vec3(79., -108., -138.); norm = vec3(0.706, -0.613, 0.094); return;\n }\n }\n }\n }\n } else {\n if (id < 856.) {\n if (id < 853.) {\n if (id < 851.) {\n pos = vec3(137., -28., -52.); norm = vec3(0.706, -0.613, 0.094); return;\n } else {\n if (id < 852.) {\n pos = vec3(95., -57., 74.); norm = vec3(0.706, -0.613, 0.094); return;\n } else {\n pos = vec3(55., -25., 196.); norm = vec3(0.339, -0.355, 0.204); return;\n }\n }\n } else {\n if (id < 854.) {\n pos = vec3(64., -116., 23.); norm = vec3(0.339, -0.355, 0.204); return;\n } else {\n if (id < 855.) {\n pos = vec3(95., -57., 74.); norm = vec3(0.339, -0.355, 0.204); return;\n } else {\n pos = vec3(95., -57., 74.); norm = vec3(0.729, -0.424, 0.047); return;\n }\n }\n }\n } else {\n if (id < 859.) {\n if (id < 857.) {\n pos = vec3(64., -116., 23.); norm = vec3(0.729, -0.424, 0.047); return;\n } else {\n if (id < 858.) {\n pos = vec3(79., -108., -138.); norm = vec3(0.729, -0.424, 0.047); return;\n } else {\n pos = vec3(64., -116., 23.); norm = vec3(0.227, -0.908, -0.054); return;\n }\n }\n } else {\n if (id < 861.) {\n if (id < 860.) {\n pos = vec3(0., -132., 23.); norm = vec3(0.227, -0.908, -0.054); return;\n } else {\n pos = vec3(62., -106., -155.); norm = vec3(0.227, -0.908, -0.054); return;\n }\n } else {\n if (id < 862.) {\n pos = vec3(28., -34., 549.); norm = vec3(0.517, 0.766, -0.280); return;\n } else {\n pos = vec3(2., -19., 542.); norm = vec3(0.517, 0.766, -0.280); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 888.) {\n if (id < 875.) {\n if (id < 869.) {\n if (id < 866.) {\n if (id < 864.) {\n pos = vec3(33., 20., 706.); norm = vec3(0.517, 0.766, -0.280); return;\n } else {\n if (id < 865.) {\n pos = vec3(33., 20., 706.); norm = vec3(0.085, 0.166, -0.056); return;\n } else {\n pos = vec3(2., -19., 542.); norm = vec3(0.085, 0.166, -0.056); return;\n }\n }\n } else {\n if (id < 867.) {\n pos = vec3(3., 34., 702.); norm = vec3(0.085, 0.166, -0.056); return;\n } else {\n if (id < 868.) {\n pos = vec3(70., -61., -150.); norm = vec3(0.408, -0.019, -0.244); return;\n } else {\n pos = vec3(67., -74., -154.); norm = vec3(0.408, -0.019, -0.244); return;\n }\n }\n }\n } else {\n if (id < 872.) {\n if (id < 870.) {\n pos = vec3(66., -44., -158.); norm = vec3(0.408, -0.019, -0.244); return;\n } else {\n if (id < 871.) {\n pos = vec3(66., -44., -158.); norm = vec3(0.580, -0.087, -0.798); return;\n } else {\n pos = vec3(67., -74., -154.); norm = vec3(0.580, -0.087, -0.798); return;\n }\n }\n } else {\n if (id < 873.) {\n pos = vec3(41., -73., -173.); norm = vec3(0.580, -0.087, -0.798); return;\n } else {\n if (id < 874.) {\n pos = vec3(28., -56., 288.); norm = vec3(0.689, -0.707, -0.036); return;\n } else {\n pos = vec3(0., -81., 243.); norm = vec3(0.689, -0.707, -0.036); return;\n }\n }\n }\n }\n } else {\n if (id < 881.) {\n if (id < 878.) {\n if (id < 876.) {\n pos = vec3(55., -25., 196.); norm = vec3(0.689, -0.707, -0.036); return;\n } else {\n if (id < 877.) {\n pos = vec3(55., -25., 196.); norm = vec3(0.659, -0.429, 0.260); return;\n } else {\n pos = vec3(0., -81., 243.); norm = vec3(0.659, -0.429, 0.260); return;\n }\n }\n } else {\n if (id < 879.) {\n pos = vec3(64., -116., 23.); norm = vec3(0.659, -0.429, 0.260); return;\n } else {\n if (id < 880.) {\n pos = vec3(0., -81., 243.); norm = vec3(0.484, -0.830, 0.160); return;\n } else {\n pos = vec3(28., -56., 288.); norm = vec3(0.484, -0.830, 0.160); return;\n }\n }\n }\n } else {\n if (id < 884.) {\n if (id < 882.) {\n pos = vec3(1., -65., 323.); norm = vec3(0.484, -0.830, 0.160); return;\n } else {\n if (id < 883.) {\n pos = vec3(1., -65., 323.); norm = vec3(0.773, -0.399, 0.493); return;\n } else {\n pos = vec3(28., -56., 288.); norm = vec3(0.773, -0.399, 0.493); return;\n }\n }\n } else {\n if (id < 886.) {\n if (id < 885.) {\n pos = vec3(37., -20., 303.); norm = vec3(0.773, -0.399, 0.493); return;\n } else {\n pos = vec3(53., -92., -163.); norm = vec3(-0.140, 0.204, -0.190); return;\n }\n } else {\n if (id < 887.) {\n pos = vec3(0., -94., -126.); norm = vec3(-0.140, 0.204, -0.190); return;\n } else {\n pos = vec3(67., -74., -154.); norm = vec3(-0.140, 0.204, -0.190); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 901.) {\n if (id < 894.) {\n if (id < 891.) {\n if (id < 889.) {\n pos = vec3(34., 86., 818.); norm = vec3(0.151, 0.305, -0.190); return;\n } else {\n if (id < 890.) {\n pos = vec3(4., 59., 751.); norm = vec3(0.151, 0.305, -0.190); return;\n } else {\n pos = vec3(6., 98., 815.); norm = vec3(0.151, 0.305, -0.190); return;\n }\n }\n } else {\n if (id < 892.) {\n pos = vec3(1., -66., 421.); norm = vec3(0.302, -0.364, -0.046); return;\n } else {\n if (id < 893.) {\n pos = vec3(1., -58., 357.); norm = vec3(0.302, -0.364, -0.046); return;\n } else {\n pos = vec3(28., -44., 424.); norm = vec3(0.302, -0.364, -0.046); return;\n }\n }\n }\n } else {\n if (id < 897.) {\n if (id < 895.) {\n pos = vec3(28., -44., 424.); norm = vec3(0.486, -0.825, -0.024); return;\n } else {\n if (id < 896.) {\n pos = vec3(1., -58., 357.); norm = vec3(0.486, -0.825, -0.024); return;\n } else {\n pos = vec3(33., -39., 352.); norm = vec3(0.486, -0.825, -0.024); return;\n }\n }\n } else {\n if (id < 899.) {\n if (id < 898.) {\n pos = vec3(33., 70., 900.); norm = vec3(0.214, 0.288, 0.027); return;\n } else {\n pos = vec3(6., 98., 815.); norm = vec3(0.214, 0.288, 0.027); return;\n }\n } else {\n if (id < 900.) {\n pos = vec3(6., 91., 890.); norm = vec3(0.214, 0.288, 0.027); return;\n } else {\n pos = vec3(33., 70., 900.); norm = vec3(0.348, 0.641, 0.405); return;\n }\n }\n }\n }\n } else {\n if (id < 907.) {\n if (id < 904.) {\n if (id < 902.) {\n pos = vec3(6., 91., 890.); norm = vec3(0.348, 0.641, 0.405); return;\n } else {\n if (id < 903.) {\n pos = vec3(6., 43., 966.); norm = vec3(0.348, 0.641, 0.405); return;\n } else {\n pos = vec3(40., 52., 892.); norm = vec3(0.749, -0.172, 0.022); return;\n }\n }\n } else {\n if (id < 905.) {\n pos = vec3(41., 54., 874.); norm = vec3(0.749, -0.172, 0.022); return;\n } else {\n if (id < 906.) {\n pos = vec3(44., 66., 866.); norm = vec3(0.749, -0.172, 0.022); return;\n } else {\n pos = vec3(33., 70., 900.); norm = vec3(0.158, 0.639, 0.127); return;\n }\n }\n }\n } else {\n if (id < 910.) {\n if (id < 908.) {\n pos = vec3(48., 77., 846.); norm = vec3(0.158, 0.639, 0.127); return;\n } else {\n if (id < 909.) {\n pos = vec3(34., 86., 818.); norm = vec3(0.158, 0.639, 0.127); return;\n } else {\n pos = vec3(40., 52., 892.); norm = vec3(0.116, -0.029, -0.001); return;\n }\n }\n } else {\n if (id < 912.) {\n if (id < 911.) {\n pos = vec3(29., 7., 978.); norm = vec3(0.116, -0.029, -0.001); return;\n } else {\n pos = vec3(36., 36., 902.); norm = vec3(0.116, -0.029, -0.001); return;\n }\n } else {\n if (id < 913.) {\n pos = vec3(36., 36., 902.); norm = vec3(0.995, -0.003, 0.090); return;\n } else {\n pos = vec3(29., 7., 978.); norm = vec3(0.995, -0.003, 0.090); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 965.) {\n if (id < 939.) {\n if (id < 926.) {\n if (id < 920.) {\n if (id < 917.) {\n if (id < 915.) {\n pos = vec3(30., -22., 966.); norm = vec3(0.995, -0.003, 0.090); return;\n } else {\n if (id < 916.) {\n pos = vec3(0., 48., 192.); norm = vec3(0.270, 0.480, 0.297); return;\n } else {\n pos = vec3(0., 22., 234.); norm = vec3(0.270, 0.480, 0.297); return;\n }\n }\n } else {\n if (id < 918.) {\n pos = vec3(28., 31., 194.); norm = vec3(0.270, 0.480, 0.297); return;\n } else {\n if (id < 919.) {\n pos = vec3(28., 31., 194.); norm = vec3(0.238, 0.352, 0.246); return;\n } else {\n pos = vec3(0., 22., 234.); norm = vec3(0.238, 0.352, 0.246); return;\n }\n }\n }\n } else {\n if (id < 923.) {\n if (id < 921.) {\n pos = vec3(57., 10., 196.); norm = vec3(0.238, 0.352, 0.246); return;\n } else {\n if (id < 922.) {\n pos = vec3(137., -28., -52.); norm = vec3(0.581, -0.006, -0.099); return;\n } else {\n pos = vec3(129., -9., -100.); norm = vec3(0.581, -0.006, -0.099); return;\n }\n }\n } else {\n if (id < 924.) {\n pos = vec3(153., 28., 38.); norm = vec3(0.581, -0.006, -0.099); return;\n } else {\n if (id < 925.) {\n pos = vec3(153., 28., 38.); norm = vec3(0.292, 0.162, -0.094); return;\n } else {\n pos = vec3(129., -9., -100.); norm = vec3(0.292, 0.162, -0.094); return;\n }\n }\n }\n }\n } else {\n if (id < 932.) {\n if (id < 929.) {\n if (id < 927.) {\n pos = vec3(127., 37., -27.); norm = vec3(0.292, 0.162, -0.094); return;\n } else {\n if (id < 928.) {\n pos = vec3(37., 35., 822.); norm = vec3(0.497, 0.457, -0.076); return;\n } else {\n pos = vec3(33., 20., 706.); norm = vec3(0.497, 0.457, -0.076); return;\n }\n }\n } else {\n if (id < 930.) {\n pos = vec3(4., 59., 751.); norm = vec3(0.497, 0.457, -0.076); return;\n } else {\n if (id < 931.) {\n pos = vec3(4., 59., 751.); norm = vec3(0.356, 0.664, -0.346); return;\n } else {\n pos = vec3(33., 20., 706.); norm = vec3(0.356, 0.664, -0.346); return;\n }\n }\n }\n } else {\n if (id < 935.) {\n if (id < 933.) {\n pos = vec3(3., 34., 702.); norm = vec3(0.356, 0.664, -0.346); return;\n } else {\n if (id < 934.) {\n pos = vec3(33., 20., 706.); norm = vec3(0.191, -0.046, -0.001); return;\n } else {\n pos = vec3(37., 35., 822.); norm = vec3(0.191, -0.046, -0.001); return;\n }\n }\n } else {\n if (id < 937.) {\n if (id < 936.) {\n pos = vec3(28., -1., 714.); norm = vec3(0.191, -0.046, -0.001); return;\n } else {\n pos = vec3(30., -22., 966.); norm = vec3(0.328, -0.089, 0.242); return;\n }\n } else {\n if (id < 938.) {\n pos = vec3(29., 7., 978.); norm = vec3(0.328, -0.089, 0.242); return;\n } else {\n pos = vec3(5., -95., 973.); norm = vec3(0.328, -0.089, 0.242); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 952.) {\n if (id < 945.) {\n if (id < 942.) {\n if (id < 940.) {\n pos = vec3(6., -3., 907.); norm = vec3(0.381, -0.309, -0.127); return;\n } else {\n if (id < 941.) {\n pos = vec3(36., 36., 902.); norm = vec3(0.381, -0.309, -0.127); return;\n } else {\n pos = vec3(6., -19., 946.); norm = vec3(0.381, -0.309, -0.127); return;\n }\n }\n } else {\n if (id < 943.) {\n pos = vec3(6., -19., 946.); norm = vec3(0.592, -0.275, -0.751); return;\n } else {\n if (id < 944.) {\n pos = vec3(30., -22., 966.); norm = vec3(0.592, -0.275, -0.751); return;\n } else {\n pos = vec3(5., -95., 973.); norm = vec3(0.592, -0.275, -0.751); return;\n }\n }\n }\n } else {\n if (id < 948.) {\n if (id < 946.) {\n pos = vec3(28., -34., 549.); norm = vec3(0.116, 0.214, 0.025); return;\n } else {\n if (id < 947.) {\n pos = vec3(22., -16., 425.); norm = vec3(0.116, 0.214, 0.025); return;\n } else {\n pos = vec3(2., -19., 542.); norm = vec3(0.116, 0.214, 0.025); return;\n }\n }\n } else {\n if (id < 950.) {\n if (id < 949.) {\n pos = vec3(2., -19., 542.); norm = vec3(0.337, 0.935, 0.082); return;\n } else {\n pos = vec3(22., -16., 425.); norm = vec3(0.337, 0.935, 0.082); return;\n }\n } else {\n if (id < 951.) {\n pos = vec3(1., -8., 420.); norm = vec3(0.337, 0.935, 0.082); return;\n } else {\n pos = vec3(34., -3., 286.); norm = vec3(0.124, 0.036, 0.014); return;\n }\n }\n }\n }\n } else {\n if (id < 958.) {\n if (id < 955.) {\n if (id < 953.) {\n pos = vec3(22., -16., 425.); norm = vec3(0.124, 0.036, 0.014); return;\n } else {\n if (id < 954.) {\n pos = vec3(37., -20., 303.); norm = vec3(0.124, 0.036, 0.014); return;\n } else {\n pos = vec3(37., -20., 303.); norm = vec3(0.264, 0.026, 0.032); return;\n }\n }\n } else {\n if (id < 956.) {\n pos = vec3(22., -16., 425.); norm = vec3(0.264, 0.026, 0.032); return;\n } else {\n if (id < 957.) {\n pos = vec3(33., -39., 352.); norm = vec3(0.264, 0.026, 0.032); return;\n } else {\n pos = vec3(22., -16., 425.); norm = vec3(0.975, 0.206, 0.082); return;\n }\n }\n }\n } else {\n if (id < 961.) {\n if (id < 959.) {\n pos = vec3(28., -44., 424.); norm = vec3(0.975, 0.206, 0.082); return;\n } else {\n if (id < 960.) {\n pos = vec3(33., -39., 352.); norm = vec3(0.975, 0.206, 0.082); return;\n } else {\n pos = vec3(0., 99., 84.); norm = vec3(0.096, 0.786, 0.479); return;\n }\n }\n } else {\n if (id < 963.) {\n if (id < 962.) {\n pos = vec3(93., 56., 136.); norm = vec3(0.096, 0.786, 0.479); return;\n } else {\n pos = vec3(109., 90., 77.); norm = vec3(0.096, 0.786, 0.479); return;\n }\n } else {\n if (id < 964.) {\n pos = vec3(109., 90., 77.); norm = vec3(-0.079, 0.433, 0.228); return;\n } else {\n pos = vec3(93., 56., 136.); norm = vec3(-0.079, 0.433, 0.228); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 990.) {\n if (id < 977.) {\n if (id < 971.) {\n if (id < 968.) {\n if (id < 966.) {\n pos = vec3(127., 78., 106.); norm = vec3(-0.079, 0.433, 0.228); return;\n } else {\n if (id < 967.) {\n pos = vec3(29., -56., 552.); norm = vec3(0.172, 0.008, -0.001); return;\n } else {\n pos = vec3(28., -44., 424.); norm = vec3(0.172, 0.008, -0.001); return;\n }\n }\n } else {\n if (id < 969.) {\n pos = vec3(28., -34., 549.); norm = vec3(0.172, 0.008, -0.001); return;\n } else {\n if (id < 970.) {\n pos = vec3(28., -44., 424.); norm = vec3(0.971, 0.209, -0.017); return;\n } else {\n pos = vec3(22., -16., 425.); norm = vec3(0.971, 0.209, -0.017); return;\n }\n }\n }\n } else {\n if (id < 974.) {\n if (id < 972.) {\n pos = vec3(28., -34., 549.); norm = vec3(0.971, 0.209, -0.017); return;\n } else {\n if (id < 973.) {\n pos = vec3(1., -66., 421.); norm = vec3(0.635, -0.768, -0.077); return;\n } else {\n pos = vec3(28., -44., 424.); norm = vec3(0.635, -0.768, -0.077); return;\n }\n }\n } else {\n if (id < 975.) {\n pos = vec3(29., -56., 552.); norm = vec3(0.635, -0.768, -0.077); return;\n } else {\n if (id < 976.) {\n pos = vec3(6., -19., 946.); norm = vec3(0.146, -0.250, -0.213); return;\n } else {\n pos = vec3(36., 36., 902.); norm = vec3(0.146, -0.250, -0.213); return;\n }\n }\n }\n }\n } else {\n if (id < 983.) {\n if (id < 980.) {\n if (id < 978.) {\n pos = vec3(30., -22., 966.); norm = vec3(0.146, -0.250, -0.213); return;\n } else {\n if (id < 979.) {\n pos = vec3(0., -26., -365.); norm = vec3(0.380, 0.902, -0.137); return;\n } else {\n pos = vec3(0., -11., -266.); norm = vec3(0.380, 0.902, -0.137); return;\n }\n }\n } else {\n if (id < 981.) {\n pos = vec3(31., -23., -259.); norm = vec3(0.380, 0.902, -0.137); return;\n } else {\n if (id < 982.) {\n pos = vec3(34., 86., 818.); norm = vec3(0.840, 0.019, -0.384); return;\n } else {\n pos = vec3(37., 35., 822.); norm = vec3(0.840, 0.019, -0.384); return;\n }\n }\n }\n } else {\n if (id < 986.) {\n if (id < 984.) {\n pos = vec3(4., 59., 751.); norm = vec3(0.840, 0.019, -0.384); return;\n } else {\n if (id < 985.) {\n pos = vec3(29., -56., 552.); norm = vec3(0.997, 0.044, -0.009); return;\n } else {\n pos = vec3(28., -34., 549.); norm = vec3(0.997, 0.044, -0.009); return;\n }\n }\n } else {\n if (id < 988.) {\n if (id < 987.) {\n pos = vec3(28., -1., 714.); norm = vec3(0.997, 0.044, -0.009); return;\n } else {\n pos = vec3(28., -1., 714.); norm = vec3(0.133, -0.030, 0.006); return;\n }\n } else {\n if (id < 989.) {\n pos = vec3(28., -34., 549.); norm = vec3(0.133, -0.030, 0.006); return;\n } else {\n pos = vec3(33., 20., 706.); norm = vec3(0.133, -0.030, 0.006); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1003.) {\n if (id < 996.) {\n if (id < 993.) {\n if (id < 991.) {\n pos = vec3(79., -108., -138.); norm = vec3(-0.006, -0.104, -0.006); return;\n } else {\n if (id < 992.) {\n pos = vec3(64., -116., 23.); norm = vec3(-0.006, -0.104, -0.006); return;\n } else {\n pos = vec3(62., -106., -155.); norm = vec3(-0.006, -0.104, -0.006); return;\n }\n }\n } else {\n if (id < 994.) {\n pos = vec3(2., -71., 551.); norm = vec3(0.112, -0.201, -0.009); return;\n } else {\n if (id < 995.) {\n pos = vec3(1., -66., 421.); norm = vec3(0.112, -0.201, -0.009); return;\n } else {\n pos = vec3(29., -56., 552.); norm = vec3(0.112, -0.201, -0.009); return;\n }\n }\n }\n } else {\n if (id < 999.) {\n if (id < 997.) {\n pos = vec3(137., -28., -52.); norm = vec3(0.827, -0.496, 0.162); return;\n } else {\n if (id < 998.) {\n pos = vec3(153., 28., 38.); norm = vec3(0.827, -0.496, 0.162); return;\n } else {\n pos = vec3(95., -57., 74.); norm = vec3(0.827, -0.496, 0.162); return;\n }\n }\n } else {\n if (id < 1001.) {\n if (id < 1000.) {\n pos = vec3(95., -57., 74.); norm = vec3(0.535, -0.213, 0.358); return;\n } else {\n pos = vec3(153., 28., 38.); norm = vec3(0.535, -0.213, 0.358); return;\n }\n } else {\n if (id < 1002.) {\n pos = vec3(115., 15., 87.); norm = vec3(0.535, -0.213, 0.358); return;\n } else {\n pos = vec3(33., 70., 900.); norm = vec3(0.606, 0.544, 0.471); return;\n }\n }\n }\n }\n } else {\n if (id < 1009.) {\n if (id < 1006.) {\n if (id < 1004.) {\n pos = vec3(6., 43., 966.); norm = vec3(0.606, 0.544, 0.471); return;\n } else {\n if (id < 1005.) {\n pos = vec3(29., 7., 978.); norm = vec3(0.606, 0.544, 0.471); return;\n } else {\n pos = vec3(29., 7., 978.); norm = vec3(0.290, 0.321, 0.407); return;\n }\n }\n } else {\n if (id < 1007.) {\n pos = vec3(6., 43., 966.); norm = vec3(0.290, 0.321, 0.407); return;\n } else {\n if (id < 1008.) {\n pos = vec3(6., 5., 996.); norm = vec3(0.290, 0.321, 0.407); return;\n } else {\n pos = vec3(29., 7., 978.); norm = vec3(0.615, -0.182, 0.765); return;\n }\n }\n }\n } else {\n if (id < 1012.) {\n if (id < 1010.) {\n pos = vec3(6., 5., 996.); norm = vec3(0.615, -0.182, 0.765); return;\n } else {\n if (id < 1011.) {\n pos = vec3(5., -95., 973.); norm = vec3(0.615, -0.182, 0.765); return;\n } else {\n pos = vec3(41., -73., -173.); norm = vec3(0.017, -0.974, -0.225); return;\n }\n }\n } else {\n if (id < 1014.) {\n if (id < 1013.) {\n pos = vec3(0., -70., -189.); norm = vec3(0.017, -0.974, -0.225); return;\n } else {\n pos = vec3(30., -54., -256.); norm = vec3(0.017, -0.974, -0.225); return;\n }\n } else {\n if (id < 1015.) {\n pos = vec3(30., -54., -256.); norm = vec3(0.028, -0.391, -0.081); return;\n } else {\n pos = vec3(0., -70., -189.); norm = vec3(0.028, -0.391, -0.081); return;\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1117.) {\n if (id < 1066.) {\n if (id < 1041.) {\n if (id < 1028.) {\n if (id < 1022.) {\n if (id < 1019.) {\n if (id < 1017.) {\n pos = vec3(0., -50., -286.); norm = vec3(0.028, -0.391, -0.081); return;\n } else {\n if (id < 1018.) {\n pos = vec3(40., -49., -294.); norm = vec3(0.838, -0.006, 0.220); return;\n } else {\n pos = vec3(31., -23., -259.); norm = vec3(0.838, -0.006, 0.220); return;\n }\n }\n } else {\n if (id < 1020.) {\n pos = vec3(30., -54., -256.); norm = vec3(0.838, -0.006, 0.220); return;\n } else {\n if (id < 1021.) {\n pos = vec3(28., -1., 714.); norm = vec3(0.430, -0.728, 0.207); return;\n } else {\n pos = vec3(37., 35., 822.); norm = vec3(0.430, -0.728, 0.207); return;\n }\n }\n }\n } else {\n if (id < 1025.) {\n if (id < 1023.) {\n pos = vec3(5., 13., 811.); norm = vec3(0.430, -0.728, 0.207); return;\n } else {\n if (id < 1024.) {\n pos = vec3(5., 13., 811.); norm = vec3(0.538, -0.663, -0.238); return;\n } else {\n pos = vec3(37., 35., 822.); norm = vec3(0.538, -0.663, -0.238); return;\n }\n }\n } else {\n if (id < 1026.) {\n pos = vec3(5., -10., 875.); norm = vec3(0.538, -0.663, -0.238); return;\n } else {\n if (id < 1027.) {\n pos = vec3(0., -50., -286.); norm = vec3(-0.001, -0.891, -0.118); return;\n } else {\n pos = vec3(40., -49., -294.); norm = vec3(-0.001, -0.891, -0.118); return;\n }\n }\n }\n }\n } else {\n if (id < 1034.) {\n if (id < 1031.) {\n if (id < 1029.) {\n pos = vec3(30., -54., -256.); norm = vec3(-0.001, -0.891, -0.118); return;\n } else {\n if (id < 1030.) {\n pos = vec3(79., -108., -138.); norm = vec3(-0.198, -0.748, 0.110); return;\n } else {\n pos = vec3(62., -106., -155.); norm = vec3(-0.198, -0.748, 0.110); return;\n }\n }\n } else {\n if (id < 1032.) {\n pos = vec3(78., -140., -357.); norm = vec3(-0.198, -0.748, 0.110); return;\n } else {\n if (id < 1033.) {\n pos = vec3(78., -140., -357.); norm = vec3(0.000, -0.053, 0.009); return;\n } else {\n pos = vec3(62., -106., -155.); norm = vec3(0.000, -0.053, 0.009); return;\n }\n }\n }\n } else {\n if (id < 1037.) {\n if (id < 1035.) {\n pos = vec3(67., -140., -357.); norm = vec3(0.000, -0.053, 0.009); return;\n } else {\n if (id < 1036.) {\n pos = vec3(62., -106., -155.); norm = vec3(-0.838, -0.502, 0.064); return;\n } else {\n pos = vec3(53., -92., -163.); norm = vec3(-0.838, -0.502, 0.064); return;\n }\n }\n } else {\n if (id < 1039.) {\n if (id < 1038.) {\n pos = vec3(67., -140., -357.); norm = vec3(-0.838, -0.502, 0.064); return;\n } else {\n pos = vec3(67., -140., -357.); norm = vec3(-0.057, -0.030, 0.003); return;\n }\n } else {\n if (id < 1040.) {\n pos = vec3(53., -92., -163.); norm = vec3(-0.057, -0.030, 0.003); return;\n } else {\n pos = vec3(61., -129., -360.); norm = vec3(-0.057, -0.030, 0.003); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1053.) {\n if (id < 1047.) {\n if (id < 1044.) {\n if (id < 1042.) {\n pos = vec3(61., -129., -360.); norm = vec3(-0.030, 0.053, -0.011); return;\n } else {\n if (id < 1043.) {\n pos = vec3(53., -92., -163.); norm = vec3(-0.030, 0.053, -0.011); return;\n } else {\n pos = vec3(72., -123., -361.); norm = vec3(-0.030, 0.053, -0.011); return;\n }\n }\n } else {\n if (id < 1045.) {\n pos = vec3(72., -123., -361.); norm = vec3(-0.666, 0.596, -0.157); return;\n } else {\n if (id < 1046.) {\n pos = vec3(53., -92., -163.); norm = vec3(-0.666, 0.596, -0.157); return;\n } else {\n pos = vec3(67., -74., -154.); norm = vec3(-0.666, 0.596, -0.157); return;\n }\n }\n }\n } else {\n if (id < 1050.) {\n if (id < 1048.) {\n pos = vec3(72., -123., -361.); norm = vec3(0.034, 0.050, -0.011); return;\n } else {\n if (id < 1049.) {\n pos = vec3(67., -74., -154.); norm = vec3(0.034, 0.050, -0.011); return;\n } else {\n pos = vec3(83., -130., -359.); norm = vec3(0.034, 0.050, -0.011); return;\n }\n }\n } else {\n if (id < 1051.) {\n pos = vec3(83., -130., -359.); norm = vec3(0.610, 0.731, -0.152); return;\n } else {\n if (id < 1052.) {\n pos = vec3(67., -74., -154.); norm = vec3(0.610, 0.731, -0.152); return;\n } else {\n pos = vec3(87., -88., -141.); norm = vec3(0.610, 0.731, -0.152); return;\n }\n }\n }\n }\n } else {\n if (id < 1059.) {\n if (id < 1056.) {\n if (id < 1054.) {\n pos = vec3(83., -130., -359.); norm = vec3(0.046, -0.022, 0.003); return;\n } else {\n if (id < 1055.) {\n pos = vec3(87., -88., -141.); norm = vec3(0.046, -0.022, 0.003); return;\n } else {\n pos = vec3(78., -140., -357.); norm = vec3(0.046, -0.022, 0.003); return;\n }\n }\n } else {\n if (id < 1057.) {\n pos = vec3(78., -140., -357.); norm = vec3(0.926, -0.363, 0.049); return;\n } else {\n if (id < 1058.) {\n pos = vec3(87., -88., -141.); norm = vec3(0.926, -0.363, 0.049); return;\n } else {\n pos = vec3(79., -108., -138.); norm = vec3(0.926, -0.363, 0.049); return;\n }\n }\n }\n } else {\n if (id < 1062.) {\n if (id < 1060.) {\n pos = vec3(71., -120., -421.); norm = vec3(-0.343, 0.243, -0.097); return;\n } else {\n if (id < 1061.) {\n pos = vec3(71., -142., -476.); norm = vec3(-0.343, 0.243, -0.097); return;\n } else {\n pos = vec3(55., -141., -417.); norm = vec3(-0.343, 0.243, -0.097); return;\n }\n }\n } else {\n if (id < 1064.) {\n if (id < 1063.) {\n pos = vec3(55., -141., -417.); norm = vec3(-0.492, 0.771, -0.147); return;\n } else {\n pos = vec3(71., -142., -476.); norm = vec3(-0.492, 0.771, -0.147); return;\n }\n } else {\n if (id < 1065.) {\n pos = vec3(61., -148., -474.); norm = vec3(-0.492, 0.771, -0.147); return;\n } else {\n pos = vec3(71., -120., -421.); norm = vec3(0.557, 0.671, -0.268); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1091.) {\n if (id < 1078.) {\n if (id < 1072.) {\n if (id < 1069.) {\n if (id < 1067.) {\n pos = vec3(97., -140., -417.); norm = vec3(0.557, 0.671, -0.268); return;\n } else {\n if (id < 1068.) {\n pos = vec3(71., -142., -476.); norm = vec3(0.557, 0.671, -0.268); return;\n } else {\n pos = vec3(71., -142., -476.); norm = vec3(0.229, 0.147, -0.106); return;\n }\n }\n } else {\n if (id < 1070.) {\n pos = vec3(97., -140., -417.); norm = vec3(0.229, 0.147, -0.106); return;\n } else {\n if (id < 1071.) {\n pos = vec3(82., -157., -473.); norm = vec3(0.229, 0.147, -0.106); return;\n } else {\n pos = vec3(97., -140., -417.); norm = vec3(0.907, -0.326, -0.144); return;\n }\n }\n }\n } else {\n if (id < 1075.) {\n if (id < 1073.) {\n pos = vec3(89., -164., -413.); norm = vec3(0.907, -0.326, -0.144); return;\n } else {\n if (id < 1074.) {\n pos = vec3(82., -157., -473.); norm = vec3(0.907, -0.326, -0.144); return;\n } else {\n pos = vec3(82., -157., -473.); norm = vec3(0.096, -0.084, -0.021); return;\n }\n }\n } else {\n if (id < 1076.) {\n pos = vec3(89., -164., -413.); norm = vec3(0.096, -0.084, -0.021); return;\n } else {\n if (id < 1077.) {\n pos = vec3(77., -163., -472.); norm = vec3(0.096, -0.084, -0.021); return;\n } else {\n pos = vec3(89., -164., -413.); norm = vec3(-0.037, -0.972, -0.009); return;\n }\n }\n }\n }\n } else {\n if (id < 1084.) {\n if (id < 1081.) {\n if (id < 1079.) {\n pos = vec3(63., -163., -413.); norm = vec3(-0.037, -0.972, -0.009); return;\n } else {\n if (id < 1080.) {\n pos = vec3(77., -163., -472.); norm = vec3(-0.037, -0.972, -0.009); return;\n } else {\n pos = vec3(77., -163., -472.); norm = vec3(0.000, -0.181, 0.000); return;\n }\n }\n } else {\n if (id < 1082.) {\n pos = vec3(63., -163., -413.); norm = vec3(0.000, -0.181, 0.000); return;\n } else {\n if (id < 1083.) {\n pos = vec3(66., -163., -472.); norm = vec3(0.000, -0.181, 0.000); return;\n } else {\n pos = vec3(63., -163., -413.); norm = vec3(-0.907, -0.338, -0.046); return;\n }\n }\n }\n } else {\n if (id < 1087.) {\n if (id < 1085.) {\n pos = vec3(55., -141., -417.); norm = vec3(-0.907, -0.338, -0.046); return;\n } else {\n if (id < 1086.) {\n pos = vec3(66., -163., -472.); norm = vec3(-0.907, -0.338, -0.046); return;\n } else {\n pos = vec3(66., -163., -472.); norm = vec3(-0.250, -0.085, -0.016); return;\n }\n }\n } else {\n if (id < 1089.) {\n if (id < 1088.) {\n pos = vec3(55., -141., -417.); norm = vec3(-0.250, -0.085, -0.016); return;\n } else {\n pos = vec3(61., -148., -474.); norm = vec3(-0.250, -0.085, -0.016); return;\n }\n } else {\n if (id < 1090.) {\n pos = vec3(83., -130., -359.); norm = vec3(0.839, -0.367, 0.266); return;\n } else {\n pos = vec3(78., -140., -357.); norm = vec3(0.839, -0.367, 0.266); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1104.) {\n if (id < 1097.) {\n if (id < 1094.) {\n if (id < 1092.) {\n pos = vec3(97., -140., -417.); norm = vec3(0.839, -0.367, 0.266); return;\n } else {\n if (id < 1093.) {\n pos = vec3(97., -140., -417.); norm = vec3(0.370, -0.104, 0.117); return;\n } else {\n pos = vec3(78., -140., -357.); norm = vec3(0.370, -0.104, 0.117); return;\n }\n }\n } else {\n if (id < 1095.) {\n pos = vec3(89., -164., -413.); norm = vec3(0.370, -0.104, 0.117); return;\n } else {\n if (id < 1096.) {\n pos = vec3(89., -164., -413.); norm = vec3(-0.015, -0.377, 0.159); return;\n } else {\n pos = vec3(78., -140., -357.); norm = vec3(-0.015, -0.377, 0.159); return;\n }\n }\n }\n } else {\n if (id < 1100.) {\n if (id < 1098.) {\n pos = vec3(63., -163., -413.); norm = vec3(-0.015, -0.377, 0.159); return;\n } else {\n if (id < 1099.) {\n pos = vec3(63., -163., -413.); norm = vec3(0.000, -0.898, 0.369); return;\n } else {\n pos = vec3(78., -140., -357.); norm = vec3(0.000, -0.898, 0.369); return;\n }\n }\n } else {\n if (id < 1102.) {\n if (id < 1101.) {\n pos = vec3(67., -140., -357.); norm = vec3(0.000, -0.898, 0.369); return;\n } else {\n pos = vec3(63., -163., -413.); norm = vec3(-0.357, -0.116, 0.073); return;\n }\n } else {\n if (id < 1103.) {\n pos = vec3(67., -140., -357.); norm = vec3(-0.357, -0.116, 0.073); return;\n } else {\n pos = vec3(55., -141., -417.); norm = vec3(-0.357, -0.116, 0.073); return;\n }\n }\n }\n }\n } else {\n if (id < 1110.) {\n if (id < 1107.) {\n if (id < 1105.) {\n pos = vec3(55., -141., -417.); norm = vec3(-0.841, -0.411, 0.175); return;\n } else {\n if (id < 1106.) {\n pos = vec3(67., -140., -357.); norm = vec3(-0.841, -0.411, 0.175); return;\n } else {\n pos = vec3(61., -129., -360.); norm = vec3(-0.841, -0.411, 0.175); return;\n }\n }\n } else {\n if (id < 1108.) {\n pos = vec3(61., -129., -360.); norm = vec3(-0.460, 0.822, -0.125); return;\n } else {\n if (id < 1109.) {\n pos = vec3(72., -123., -361.); norm = vec3(-0.460, 0.822, -0.125); return;\n } else {\n pos = vec3(55., -141., -417.); norm = vec3(-0.460, 0.822, -0.125); return;\n }\n }\n }\n } else {\n if (id < 1113.) {\n if (id < 1111.) {\n pos = vec3(55., -141., -417.); norm = vec3(-0.339, 0.262, 0.019); return;\n } else {\n if (id < 1112.) {\n pos = vec3(72., -123., -361.); norm = vec3(-0.339, 0.262, 0.019); return;\n } else {\n pos = vec3(71., -120., -421.); norm = vec3(-0.339, 0.262, 0.019); return;\n }\n }\n } else {\n if (id < 1115.) {\n if (id < 1114.) {\n pos = vec3(72., -123., -361.); norm = vec3(0.491, 0.780, 0.031); return;\n } else {\n pos = vec3(83., -130., -359.); norm = vec3(0.491, 0.780, 0.031); return;\n }\n } else {\n if (id < 1116.) {\n pos = vec3(71., -120., -421.); norm = vec3(0.491, 0.780, 0.031); return;\n } else {\n pos = vec3(71., -120., -421.); norm = vec3(0.310, 0.404, 0.005); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1168.) {\n if (id < 1142.) {\n if (id < 1129.) {\n if (id < 1123.) {\n if (id < 1120.) {\n if (id < 1118.) {\n pos = vec3(83., -130., -359.); norm = vec3(0.310, 0.404, 0.005); return;\n } else {\n if (id < 1119.) {\n pos = vec3(97., -140., -417.); norm = vec3(0.310, 0.404, 0.005); return;\n } else {\n pos = vec3(71., -142., -476.); norm = vec3(-0.028, 0.044, -0.009); return;\n }\n }\n } else {\n if (id < 1121.) {\n pos = vec3(73., -187., -693.); norm = vec3(-0.028, 0.044, -0.009); return;\n } else {\n if (id < 1122.) {\n pos = vec3(61., -148., -474.); norm = vec3(-0.028, 0.044, -0.009); return;\n } else {\n pos = vec3(61., -148., -474.); norm = vec3(-0.559, 0.810, -0.175); return;\n }\n }\n }\n } else {\n if (id < 1126.) {\n if (id < 1124.) {\n pos = vec3(73., -187., -693.); norm = vec3(-0.559, 0.810, -0.175); return;\n } else {\n if (id < 1125.) {\n pos = vec3(64., -193., -692.); norm = vec3(-0.559, 0.810, -0.175); return;\n } else {\n pos = vec3(71., -142., -476.); norm = vec3(0.810, 0.572, -0.111); return;\n }\n }\n } else {\n if (id < 1127.) {\n pos = vec3(82., -157., -473.); norm = vec3(0.810, 0.572, -0.111); return;\n } else {\n if (id < 1128.) {\n pos = vec3(73., -187., -693.); norm = vec3(0.810, 0.572, -0.111); return;\n } else {\n pos = vec3(73., -187., -693.); norm = vec3(0.032, 0.031, -0.006); return;\n }\n }\n }\n }\n } else {\n if (id < 1135.) {\n if (id < 1132.) {\n if (id < 1130.) {\n pos = vec3(82., -157., -473.); norm = vec3(0.032, 0.031, -0.006); return;\n } else {\n if (id < 1131.) {\n pos = vec3(80., -194., -692.); norm = vec3(0.032, 0.031, -0.006); return;\n } else {\n pos = vec3(80., -194., -692.); norm = vec3(0.037, -0.009, 0.001); return;\n }\n }\n } else {\n if (id < 1133.) {\n pos = vec3(82., -157., -473.); norm = vec3(0.037, -0.009, 0.001); return;\n } else {\n if (id < 1134.) {\n pos = vec3(78., -202., -690.); norm = vec3(0.037, -0.009, 0.001); return;\n } else {\n pos = vec3(78., -202., -690.); norm = vec3(0.772, -0.624, 0.115); return;\n }\n }\n }\n } else {\n if (id < 1138.) {\n if (id < 1136.) {\n pos = vec3(82., -157., -473.); norm = vec3(0.772, -0.624, 0.115); return;\n } else {\n if (id < 1137.) {\n pos = vec3(77., -163., -472.); norm = vec3(0.772, -0.624, 0.115); return;\n } else {\n pos = vec3(78., -202., -690.); norm = vec3(-0.004, -0.040, 0.007); return;\n }\n }\n } else {\n if (id < 1140.) {\n if (id < 1139.) {\n pos = vec3(77., -163., -472.); norm = vec3(-0.004, -0.040, 0.007); return;\n } else {\n pos = vec3(69., -201., -690.); norm = vec3(-0.004, -0.040, 0.007); return;\n }\n } else {\n if (id < 1141.) {\n pos = vec3(69., -201., -690.); norm = vec3(0.000, -0.985, 0.172); return;\n } else {\n pos = vec3(77., -163., -472.); norm = vec3(0.000, -0.985, 0.172); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1155.) {\n if (id < 1148.) {\n if (id < 1145.) {\n if (id < 1143.) {\n pos = vec3(66., -163., -472.); norm = vec3(0.000, -0.985, 0.172); return;\n } else {\n if (id < 1144.) {\n pos = vec3(69., -201., -690.); norm = vec3(-0.037, -0.022, 0.003); return;\n } else {\n pos = vec3(66., -163., -472.); norm = vec3(-0.037, -0.022, 0.003); return;\n }\n }\n } else {\n if (id < 1146.) {\n pos = vec3(64., -193., -692.); norm = vec3(-0.037, -0.022, 0.003); return;\n } else {\n if (id < 1147.) {\n pos = vec3(64., -193., -692.); norm = vec3(-0.949, -0.310, 0.051); return;\n } else {\n pos = vec3(66., -163., -472.); norm = vec3(-0.949, -0.310, 0.051); return;\n }\n }\n }\n } else {\n if (id < 1151.) {\n if (id < 1149.) {\n pos = vec3(61., -148., -474.); norm = vec3(-0.949, -0.310, 0.051); return;\n } else {\n if (id < 1150.) {\n pos = vec3(78., -202., -690.); norm = vec3(0.292, -0.040, 0.131); return;\n } else {\n pos = vec3(84., -214., -707.); norm = vec3(0.292, -0.040, 0.131); return;\n }\n }\n } else {\n if (id < 1153.) {\n if (id < 1152.) {\n pos = vec3(80., -194., -692.); norm = vec3(0.292, -0.040, 0.131); return;\n } else {\n pos = vec3(80., -194., -692.); norm = vec3(0.699, -0.047, 0.249); return;\n }\n } else {\n if (id < 1154.) {\n pos = vec3(84., -214., -707.); norm = vec3(0.699, -0.047, 0.249); return;\n } else {\n pos = vec3(88., -181., -712.); norm = vec3(0.699, -0.047, 0.249); return;\n }\n }\n }\n }\n } else {\n if (id < 1161.) {\n if (id < 1158.) {\n if (id < 1156.) {\n pos = vec3(78., -202., -690.); norm = vec3(-0.072, -0.647, 0.431); return;\n } else {\n if (id < 1157.) {\n pos = vec3(69., -201., -690.); norm = vec3(-0.072, -0.647, 0.431); return;\n } else {\n pos = vec3(84., -214., -707.); norm = vec3(-0.072, -0.647, 0.431); return;\n }\n }\n } else {\n if (id < 1159.) {\n pos = vec3(84., -214., -707.); norm = vec3(0.000, -0.672, 0.514); return;\n } else {\n if (id < 1160.) {\n pos = vec3(69., -201., -690.); norm = vec3(0.000, -0.672, 0.514); return;\n } else {\n pos = vec3(60., -214., -707.); norm = vec3(0.000, -0.672, 0.514); return;\n }\n }\n }\n } else {\n if (id < 1164.) {\n if (id < 1162.) {\n pos = vec3(56., -182., -715.); norm = vec3(-0.747, -0.032, 0.244); return;\n } else {\n if (id < 1163.) {\n pos = vec3(60., -214., -707.); norm = vec3(-0.747, -0.032, 0.244); return;\n } else {\n pos = vec3(64., -193., -692.); norm = vec3(-0.747, -0.032, 0.244); return;\n }\n }\n } else {\n if (id < 1166.) {\n if (id < 1165.) {\n pos = vec3(64., -193., -692.); norm = vec3(-0.267, -0.111, 0.226); return;\n } else {\n pos = vec3(60., -214., -707.); norm = vec3(-0.267, -0.111, 0.226); return;\n }\n } else {\n if (id < 1167.) {\n pos = vec3(69., -201., -690.); norm = vec3(-0.267, -0.111, 0.226); return;\n } else {\n pos = vec3(56., -182., -715.); norm = vec3(-0.053, 0.927, 0.251); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1193.) {\n if (id < 1180.) {\n if (id < 1174.) {\n if (id < 1171.) {\n if (id < 1169.) {\n pos = vec3(73., -187., -693.); norm = vec3(-0.053, 0.927, 0.251); return;\n } else {\n if (id < 1170.) {\n pos = vec3(88., -181., -712.); norm = vec3(-0.053, 0.927, 0.251); return;\n } else {\n pos = vec3(88., -181., -712.); norm = vec3(0.512, 0.596, 0.592); return;\n }\n }\n } else {\n if (id < 1172.) {\n pos = vec3(73., -187., -693.); norm = vec3(0.512, 0.596, 0.592); return;\n } else {\n if (id < 1173.) {\n pos = vec3(80., -194., -692.); norm = vec3(0.512, 0.596, 0.592); return;\n } else {\n pos = vec3(37., 35., 822.); norm = vec3(0.659, -0.700, -0.196); return;\n }\n }\n }\n } else {\n if (id < 1177.) {\n if (id < 1175.) {\n pos = vec3(45., 33., 856.); norm = vec3(0.659, -0.700, -0.196); return;\n } else {\n if (id < 1176.) {\n pos = vec3(5., -10., 875.); norm = vec3(0.659, -0.700, -0.196); return;\n } else {\n pos = vec3(5., -10., 875.); norm = vec3(0.702, -0.576, 0.175); return;\n }\n }\n } else {\n if (id < 1178.) {\n pos = vec3(45., 33., 856.); norm = vec3(0.702, -0.576, 0.175); return;\n } else {\n if (id < 1179.) {\n pos = vec3(36., 36., 902.); norm = vec3(0.702, -0.576, 0.175); return;\n } else {\n pos = vec3(5., -10., 875.); norm = vec3(0.420, -0.316, 0.056); return;\n }\n }\n }\n }\n } else {\n if (id < 1186.) {\n if (id < 1183.) {\n if (id < 1181.) {\n pos = vec3(36., 36., 902.); norm = vec3(0.420, -0.316, 0.056); return;\n } else {\n if (id < 1182.) {\n pos = vec3(6., -3., 907.); norm = vec3(0.420, -0.316, 0.056); return;\n } else {\n pos = vec3(137., -28., -52.); norm = vec3(0.392, -0.145, -0.123); return;\n }\n }\n } else {\n if (id < 1184.) {\n pos = vec3(87., -88., -141.); norm = vec3(0.392, -0.145, -0.123); return;\n } else {\n if (id < 1185.) {\n pos = vec3(129., -9., -100.); norm = vec3(0.392, -0.145, -0.123); return;\n } else {\n pos = vec3(67., -74., -154.); norm = vec3(0.487, 0.089, -0.654); return;\n }\n }\n }\n } else {\n if (id < 1189.) {\n if (id < 1187.) {\n pos = vec3(70., -61., -150.); norm = vec3(0.487, 0.089, -0.654); return;\n } else {\n if (id < 1188.) {\n pos = vec3(87., -88., -141.); norm = vec3(0.487, 0.089, -0.654); return;\n } else {\n pos = vec3(87., -88., -141.); norm = vec3(0.588, 0.103, -0.802); return;\n }\n }\n } else {\n if (id < 1191.) {\n if (id < 1190.) {\n pos = vec3(70., -61., -150.); norm = vec3(0.588, 0.103, -0.802); return;\n } else {\n pos = vec3(129., -9., -100.); norm = vec3(0.588, 0.103, -0.802); return;\n }\n } else {\n if (id < 1192.) {\n pos = vec3(67., 45., -184.); norm = vec3(0.538, 0.323, -0.189); return;\n } else {\n pos = vec3(127., 37., -27.); norm = vec3(0.538, 0.323, -0.189); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1206.) {\n if (id < 1199.) {\n if (id < 1196.) {\n if (id < 1194.) {\n pos = vec3(129., -9., -100.); norm = vec3(0.538, 0.323, -0.189); return;\n } else {\n if (id < 1195.) {\n pos = vec3(0., 109., -12.); norm = vec3(0.073, 0.629, 0.066); return;\n } else {\n pos = vec3(0., 99., 84.); norm = vec3(0.073, 0.629, 0.066); return;\n }\n }\n } else {\n if (id < 1197.) {\n pos = vec3(85., 100., -20.); norm = vec3(0.073, 0.629, 0.066); return;\n } else {\n if (id < 1198.) {\n pos = vec3(85., 100., -20.); norm = vec3(0.064, 0.730, 0.059); return;\n } else {\n pos = vec3(0., 99., 84.); norm = vec3(0.064, 0.730, 0.059); return;\n }\n }\n }\n } else {\n if (id < 1202.) {\n if (id < 1200.) {\n pos = vec3(109., 90., 77.); norm = vec3(0.064, 0.730, 0.059); return;\n } else {\n if (id < 1201.) {\n pos = vec3(56., -182., -715.); norm = vec3(-0.438, 0.741, 0.506); return;\n } else {\n pos = vec3(64., -193., -692.); norm = vec3(-0.438, 0.741, 0.506); return;\n }\n }\n } else {\n if (id < 1204.) {\n if (id < 1203.) {\n pos = vec3(73., -187., -693.); norm = vec3(-0.438, 0.741, 0.506); return;\n } else {\n pos = vec3(53., -92., -163.); norm = vec3(-0.391, -0.590, -0.592); return;\n }\n } else {\n if (id < 1205.) {\n pos = vec3(62., -106., -155.); norm = vec3(-0.391, -0.590, -0.592); return;\n } else {\n pos = vec3(0., -94., -126.); norm = vec3(-0.391, -0.590, -0.592); return;\n }\n }\n }\n }\n } else {\n if (id < 1212.) {\n if (id < 1209.) {\n if (id < 1207.) {\n pos = vec3(0., -132., 23.); norm = vec3(-0.270, -0.865, -0.220); return;\n } else {\n if (id < 1208.) {\n pos = vec3(0., -94., -126.); norm = vec3(-0.270, -0.865, -0.220); return;\n } else {\n pos = vec3(62., -106., -155.); norm = vec3(-0.270, -0.865, -0.220); return;\n }\n }\n } else {\n if (id < 1210.) {\n pos = vec3(38., -46., -295.); norm = vec3(0.408, 0.867, 0.026); return;\n } else {\n if (id < 1211.) {\n pos = vec3(65., -57., -351.); norm = vec3(0.408, 0.867, 0.026); return;\n } else {\n pos = vec3(0., -26., -365.); norm = vec3(0.408, 0.867, 0.026); return;\n }\n }\n }\n } else {\n if (id < 1215.) {\n if (id < 1213.) {\n pos = vec3(31., -23., -259.); norm = vec3(0.786, 0.474, -0.150); return;\n } else {\n if (id < 1214.) {\n pos = vec3(40., -49., -294.); norm = vec3(0.786, 0.474, -0.150); return;\n } else {\n pos = vec3(38., -46., -295.); norm = vec3(0.786, 0.474, -0.150); return;\n }\n }\n } else {\n if (id < 1217.) {\n if (id < 1216.) {\n pos = vec3(0., -26., -365.); norm = vec3(0.487, 0.388, -0.153); return;\n } else {\n pos = vec3(31., -23., -259.); norm = vec3(0.487, 0.388, -0.153); return;\n }\n } else {\n if (id < 1218.) {\n pos = vec3(38., -46., -295.); norm = vec3(0.487, 0.388, -0.153); return;\n } else {\n pos = vec3(40., -49., -294.); norm = vec3(0.045, 0.035, 0.015); return;\n }\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1422.) {\n if (id < 1320.) {\n if (id < 1269.) {\n if (id < 1244.) {\n if (id < 1231.) {\n if (id < 1225.) {\n if (id < 1222.) {\n if (id < 1220.) {\n pos = vec3(65., -57., -351.); norm = vec3(0.045, 0.035, 0.015); return;\n } else {\n if (id < 1221.) {\n pos = vec3(38., -46., -295.); norm = vec3(0.045, 0.035, 0.015); return;\n } else {\n pos = vec3(0., -50., -286.); norm = vec3(-0.016, -0.452, -0.137); return;\n }\n }\n } else {\n if (id < 1223.) {\n pos = vec3(0., -26., -365.); norm = vec3(-0.016, -0.452, -0.137); return;\n } else {\n if (id < 1224.) {\n pos = vec3(40., -49., -294.); norm = vec3(-0.016, -0.452, -0.137); return;\n } else {\n pos = vec3(40., -49., -294.); norm = vec3(-0.302, -0.653, -0.041); return;\n }\n }\n }\n } else {\n if (id < 1228.) {\n if (id < 1226.) {\n pos = vec3(0., -26., -365.); norm = vec3(-0.302, -0.653, -0.041); return;\n } else {\n if (id < 1227.) {\n pos = vec3(65., -57., -351.); norm = vec3(-0.302, -0.653, -0.041); return;\n } else {\n pos = vec3(115., 15., 87.); norm = vec3(-0.105, -0.722, 0.556); return;\n }\n }\n } else {\n if (id < 1229.) {\n pos = vec3(152., 42., 129.); norm = vec3(-0.105, -0.722, 0.556); return;\n } else {\n if (id < 1230.) {\n pos = vec3(93., 56., 136.); norm = vec3(-0.105, -0.722, 0.556); return;\n } else {\n pos = vec3(93., 56., 136.); norm = vec3(0.190, 0.507, 0.587); return;\n }\n }\n }\n }\n } else {\n if (id < 1237.) {\n if (id < 1234.) {\n if (id < 1232.) {\n pos = vec3(152., 42., 129.); norm = vec3(0.190, 0.507, 0.587); return;\n } else {\n if (id < 1233.) {\n pos = vec3(127., 78., 106.); norm = vec3(0.190, 0.507, 0.587); return;\n } else {\n pos = vec3(321., 157., -5.); norm = vec3(-0.144, 0.393, 0.075); return;\n }\n }\n } else {\n if (id < 1235.) {\n pos = vec3(546., 202., 191.); norm = vec3(-0.144, 0.393, 0.075); return;\n } else {\n if (id < 1236.) {\n pos = vec3(484., 204., 61.); norm = vec3(-0.144, 0.393, 0.075); return;\n } else {\n pos = vec3(484., 172., 66.); norm = vec3(0.165, -0.466, -0.064); return;\n }\n }\n }\n } else {\n if (id < 1240.) {\n if (id < 1238.) {\n pos = vec3(552., 177., 205.); norm = vec3(0.165, -0.466, -0.064); return;\n } else {\n if (id < 1239.) {\n pos = vec3(283., 108., 13.); norm = vec3(0.165, -0.466, -0.064); return;\n } else {\n pos = vec3(283., 108., 13.); norm = vec3(0.098, -0.330, -0.019); return;\n }\n }\n } else {\n if (id < 1242.) {\n if (id < 1241.) {\n pos = vec3(552., 177., 205.); norm = vec3(0.098, -0.330, -0.019); return;\n } else {\n pos = vec3(311., 109., 140.); norm = vec3(0.098, -0.330, -0.019); return;\n }\n } else {\n if (id < 1243.) {\n pos = vec3(304., 150., 144.); norm = vec3(-0.282, 0.956, -0.036); return;\n } else {\n pos = vec3(171., 106., 16.); norm = vec3(-0.282, 0.956, -0.036); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1256.) {\n if (id < 1250.) {\n if (id < 1247.) {\n if (id < 1245.) {\n pos = vec3(109., 90., 77.); norm = vec3(-0.282, 0.956, -0.036); return;\n } else {\n if (id < 1246.) {\n pos = vec3(109., 90., 77.); norm = vec3(-0.114, 0.905, 0.122); return;\n } else {\n pos = vec3(171., 106., 16.); norm = vec3(-0.114, 0.905, 0.122); return;\n }\n }\n } else {\n if (id < 1248.) {\n pos = vec3(85., 100., -20.); norm = vec3(-0.114, 0.905, 0.122); return;\n } else {\n if (id < 1249.) {\n pos = vec3(312., 128., 162.); norm = vec3(-0.371, 0.501, 0.777); return;\n } else {\n pos = vec3(304., 150., 144.); norm = vec3(-0.371, 0.501, 0.777); return;\n }\n }\n }\n } else {\n if (id < 1253.) {\n if (id < 1251.) {\n pos = vec3(127., 78., 106.); norm = vec3(-0.371, 0.501, 0.777); return;\n } else {\n if (id < 1252.) {\n pos = vec3(127., 78., 106.); norm = vec3(-0.061, 0.106, 0.082); return;\n } else {\n pos = vec3(304., 150., 144.); norm = vec3(-0.061, 0.106, 0.082); return;\n }\n }\n } else {\n if (id < 1254.) {\n pos = vec3(109., 90., 77.); norm = vec3(-0.061, 0.106, 0.082); return;\n } else {\n if (id < 1255.) {\n pos = vec3(127., 78., 106.); norm = vec3(-0.346, 0.312, 0.866); return;\n } else {\n pos = vec3(152., 42., 129.); norm = vec3(-0.346, 0.312, 0.866); return;\n }\n }\n }\n }\n } else {\n if (id < 1262.) {\n if (id < 1259.) {\n if (id < 1257.) {\n pos = vec3(312., 128., 162.); norm = vec3(-0.346, 0.312, 0.866); return;\n } else {\n if (id < 1258.) {\n pos = vec3(312., 128., 162.); norm = vec3(0.040, -0.109, 0.093); return;\n } else {\n pos = vec3(152., 42., 129.); norm = vec3(0.040, -0.109, 0.093); return;\n }\n }\n } else {\n if (id < 1260.) {\n pos = vec3(311., 109., 140.); norm = vec3(0.040, -0.109, 0.093); return;\n } else {\n if (id < 1261.) {\n pos = vec3(152., 42., 129.); norm = vec3(0.315, -0.768, 0.122); return;\n } else {\n pos = vec3(153., 28., 38.); norm = vec3(0.315, -0.768, 0.122); return;\n }\n }\n }\n } else {\n if (id < 1265.) {\n if (id < 1263.) {\n pos = vec3(311., 109., 140.); norm = vec3(0.315, -0.768, 0.122); return;\n } else {\n if (id < 1264.) {\n pos = vec3(311., 109., 140.); norm = vec3(0.322, -0.543, -0.067); return;\n } else {\n pos = vec3(153., 28., 38.); norm = vec3(0.322, -0.543, -0.067); return;\n }\n }\n } else {\n if (id < 1267.) {\n if (id < 1266.) {\n pos = vec3(283., 108., 13.); norm = vec3(0.322, -0.543, -0.067); return;\n } else {\n pos = vec3(321., 157., -5.); norm = vec3(-0.245, 0.710, -0.026); return;\n }\n } else {\n if (id < 1268.) {\n pos = vec3(234., 121., -170.); norm = vec3(-0.245, 0.710, -0.026); return;\n } else {\n pos = vec3(171., 106., 16.); norm = vec3(-0.245, 0.710, -0.026); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1294.) {\n if (id < 1281.) {\n if (id < 1275.) {\n if (id < 1272.) {\n if (id < 1270.) {\n pos = vec3(171., 106., 16.); norm = vec3(-0.396, 0.881, -0.063); return;\n } else {\n if (id < 1271.) {\n pos = vec3(234., 121., -170.); norm = vec3(-0.396, 0.881, -0.063); return;\n } else {\n pos = vec3(67., 45., -184.); norm = vec3(-0.396, 0.881, -0.063); return;\n }\n }\n } else {\n if (id < 1273.) {\n pos = vec3(234., 121., -170.); norm = vec3(-0.484, 0.854, 0.069); return;\n } else {\n if (id < 1274.) {\n pos = vec3(321., 157., -5.); norm = vec3(-0.484, 0.854, 0.069); return;\n } else {\n pos = vec3(386., 199., -69.); norm = vec3(-0.484, 0.854, 0.069); return;\n }\n }\n }\n } else {\n if (id < 1278.) {\n if (id < 1276.) {\n pos = vec3(386., 199., -69.); norm = vec3(-0.316, 0.805, 0.207); return;\n } else {\n if (id < 1277.) {\n pos = vec3(321., 157., -5.); norm = vec3(-0.316, 0.805, 0.207); return;\n } else {\n pos = vec3(484., 204., 61.); norm = vec3(-0.316, 0.805, 0.207); return;\n }\n }\n } else {\n if (id < 1279.) {\n pos = vec3(219., 95., -190.); norm = vec3(0.084, 0.269, -0.412); return;\n } else {\n if (id < 1280.) {\n pos = vec3(234., 121., -170.); norm = vec3(0.084, 0.269, -0.412); return;\n } else {\n pos = vec3(373., 191., -96.); norm = vec3(0.084, 0.269, -0.412); return;\n }\n }\n }\n }\n } else {\n if (id < 1287.) {\n if (id < 1284.) {\n if (id < 1282.) {\n pos = vec3(373., 191., -96.); norm = vec3(-0.038, 0.082, -0.006); return;\n } else {\n if (id < 1283.) {\n pos = vec3(234., 121., -170.); norm = vec3(-0.038, 0.082, -0.006); return;\n } else {\n pos = vec3(386., 199., -69.); norm = vec3(-0.038, 0.082, -0.006); return;\n }\n }\n } else {\n if (id < 1285.) {\n pos = vec3(85., 100., -20.); norm = vec3(-0.001, 0.384, -0.062); return;\n } else {\n if (id < 1286.) {\n pos = vec3(171., 106., 16.); norm = vec3(-0.001, 0.384, -0.062); return;\n } else {\n pos = vec3(63., 88., -94.); norm = vec3(-0.001, 0.384, -0.062); return;\n }\n }\n }\n } else {\n if (id < 1290.) {\n if (id < 1288.) {\n pos = vec3(63., 88., -94.); norm = vec3(0.086, 0.280, -0.130); return;\n } else {\n if (id < 1289.) {\n pos = vec3(171., 106., 16.); norm = vec3(0.086, 0.280, -0.130); return;\n } else {\n pos = vec3(67., 45., -184.); norm = vec3(0.086, 0.280, -0.130); return;\n }\n }\n } else {\n if (id < 1292.) {\n if (id < 1291.) {\n pos = vec3(304., 150., 144.); norm = vec3(-0.270, 0.545, 0.787); return;\n } else {\n pos = vec3(312., 128., 162.); norm = vec3(-0.270, 0.545, 0.787); return;\n }\n } else {\n if (id < 1293.) {\n pos = vec3(546., 202., 191.); norm = vec3(-0.270, 0.545, 0.787); return;\n } else {\n pos = vec3(546., 202., 191.); norm = vec3(-0.035, 0.083, 0.072); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1307.) {\n if (id < 1300.) {\n if (id < 1297.) {\n if (id < 1295.) {\n pos = vec3(312., 128., 162.); norm = vec3(-0.035, 0.083, 0.072); return;\n } else {\n if (id < 1296.) {\n pos = vec3(557., 186., 215.); norm = vec3(-0.035, 0.083, 0.072); return;\n } else {\n pos = vec3(311., 109., 140.); norm = vec3(0.004, -0.081, 0.070); return;\n }\n }\n } else {\n if (id < 1298.) {\n pos = vec3(552., 177., 205.); norm = vec3(0.004, -0.081, 0.070); return;\n } else {\n if (id < 1299.) {\n pos = vec3(312., 128., 162.); norm = vec3(0.004, -0.081, 0.070); return;\n } else {\n pos = vec3(312., 128., 162.); norm = vec3(0.029, -0.612, 0.536); return;\n }\n }\n }\n } else {\n if (id < 1303.) {\n if (id < 1301.) {\n pos = vec3(552., 177., 205.); norm = vec3(0.029, -0.612, 0.536); return;\n } else {\n if (id < 1302.) {\n pos = vec3(557., 186., 215.); norm = vec3(0.029, -0.612, 0.536); return;\n } else {\n pos = vec3(248., 106., -165.); norm = vec3(0.084, -0.183, -0.017); return;\n }\n }\n } else {\n if (id < 1305.) {\n if (id < 1304.) {\n pos = vec3(127., 37., -27.); norm = vec3(0.084, -0.183, -0.017); return;\n } else {\n pos = vec3(219., 95., -190.); norm = vec3(0.084, -0.183, -0.017); return;\n }\n } else {\n if (id < 1306.) {\n pos = vec3(219., 95., -190.); norm = vec3(0.237, -0.735, -0.128); return;\n } else {\n pos = vec3(127., 37., -27.); norm = vec3(0.237, -0.735, -0.128); return;\n }\n }\n }\n }\n } else {\n if (id < 1313.) {\n if (id < 1310.) {\n if (id < 1308.) {\n pos = vec3(67., 45., -184.); norm = vec3(0.237, -0.735, -0.128); return;\n } else {\n if (id < 1309.) {\n pos = vec3(546., 202., 191.); norm = vec3(-0.178, 0.814, 0.018); return;\n } else {\n pos = vec3(321., 157., -5.); norm = vec3(-0.178, 0.814, 0.018); return;\n }\n }\n } else {\n if (id < 1311.) {\n pos = vec3(304., 150., 144.); norm = vec3(-0.178, 0.814, 0.018); return;\n } else {\n if (id < 1312.) {\n pos = vec3(304., 150., 144.); norm = vec3(-0.311, 0.917, 0.008); return;\n } else {\n pos = vec3(321., 157., -5.); norm = vec3(-0.311, 0.917, 0.008); return;\n }\n }\n }\n } else {\n if (id < 1316.) {\n if (id < 1314.) {\n pos = vec3(171., 106., 16.); norm = vec3(-0.311, 0.917, 0.008); return;\n } else {\n if (id < 1315.) {\n pos = vec3(400., 168., -38.); norm = vec3(0.189, -0.156, -0.150); return;\n } else {\n pos = vec3(248., 106., -165.); norm = vec3(0.189, -0.156, -0.150); return;\n }\n }\n } else {\n if (id < 1318.) {\n if (id < 1317.) {\n pos = vec3(373., 191., -96.); norm = vec3(0.189, -0.156, -0.150); return;\n } else {\n pos = vec3(373., 191., -96.); norm = vec3(0.206, -0.170, -0.165); return;\n }\n } else {\n if (id < 1319.) {\n pos = vec3(248., 106., -165.); norm = vec3(0.206, -0.170, -0.165); return;\n } else {\n pos = vec3(219., 95., -190.); norm = vec3(0.206, -0.170, -0.165); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1371.) {\n if (id < 1345.) {\n if (id < 1332.) {\n if (id < 1326.) {\n if (id < 1323.) {\n if (id < 1321.) {\n pos = vec3(373., 191., -96.); norm = vec3(0.041, 0.947, -0.300); return;\n } else {\n if (id < 1322.) {\n pos = vec3(386., 199., -69.); norm = vec3(0.041, 0.947, -0.300); return;\n } else {\n pos = vec3(500., 183., -104.); norm = vec3(0.041, 0.947, -0.300); return;\n }\n }\n } else {\n if (id < 1324.) {\n pos = vec3(500., 183., -104.); norm = vec3(-0.010, 0.091, -0.074); return;\n } else {\n if (id < 1325.) {\n pos = vec3(386., 199., -69.); norm = vec3(-0.010, 0.091, -0.074); return;\n } else {\n pos = vec3(501., 192., -93.); norm = vec3(-0.010, 0.091, -0.074); return;\n }\n }\n }\n } else {\n if (id < 1329.) {\n if (id < 1327.) {\n pos = vec3(792., 186., 135.); norm = vec3(0.069, 0.988, 0.019); return;\n } else {\n if (id < 1328.) {\n pos = vec3(783., 187., 116.); norm = vec3(0.069, 0.988, 0.019); return;\n } else {\n pos = vec3(546., 202., 191.); norm = vec3(0.069, 0.988, 0.019); return;\n }\n }\n } else {\n if (id < 1330.) {\n pos = vec3(728., 189., 85.); norm = vec3(0.012, 0.218, -0.007); return;\n } else {\n if (id < 1331.) {\n pos = vec3(546., 202., 191.); norm = vec3(0.012, 0.218, -0.007); return;\n } else {\n pos = vec3(783., 187., 116.); norm = vec3(0.012, 0.218, -0.007); return;\n }\n }\n }\n }\n } else {\n if (id < 1338.) {\n if (id < 1335.) {\n if (id < 1333.) {\n pos = vec3(588., 196., -74.); norm = vec3(-0.028, 0.991, -0.080); return;\n } else {\n if (id < 1334.) {\n pos = vec3(501., 192., -93.); norm = vec3(-0.028, 0.991, -0.080); return;\n } else {\n pos = vec3(484., 204., 61.); norm = vec3(-0.028, 0.991, -0.080); return;\n }\n }\n } else {\n if (id < 1336.) {\n pos = vec3(386., 199., -69.); norm = vec3(0.031, 0.684, -0.050); return;\n } else {\n if (id < 1337.) {\n pos = vec3(484., 204., 61.); norm = vec3(0.031, 0.684, -0.050); return;\n } else {\n pos = vec3(501., 192., -93.); norm = vec3(0.031, 0.684, -0.050); return;\n }\n }\n }\n } else {\n if (id < 1341.) {\n if (id < 1339.) {\n pos = vec3(552., 177., 205.); norm = vec3(0.005, -0.043, 0.036); return;\n } else {\n if (id < 1340.) {\n pos = vec3(797., 161., 149.); norm = vec3(0.005, -0.043, 0.036); return;\n } else {\n pos = vec3(557., 186., 215.); norm = vec3(0.005, -0.043, 0.036); return;\n }\n }\n } else {\n if (id < 1343.) {\n if (id < 1342.) {\n pos = vec3(557., 186., 215.); norm = vec3(0.108, -0.728, 0.668); return;\n } else {\n pos = vec3(797., 161., 149.); norm = vec3(0.108, -0.728, 0.668); return;\n }\n } else {\n if (id < 1344.) {\n pos = vec3(802., 170., 158.); norm = vec3(0.108, -0.728, 0.668); return;\n } else {\n pos = vec3(546., 202., 191.); norm = vec3(0.167, 0.851, 0.491); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1358.) {\n if (id < 1351.) {\n if (id < 1348.) {\n if (id < 1346.) {\n pos = vec3(557., 186., 215.); norm = vec3(0.167, 0.851, 0.491); return;\n } else {\n if (id < 1347.) {\n pos = vec3(792., 186., 135.); norm = vec3(0.167, 0.851, 0.491); return;\n } else {\n pos = vec3(792., 186., 135.); norm = vec3(0.020, 0.099, 0.060); return;\n }\n }\n } else {\n if (id < 1349.) {\n pos = vec3(557., 186., 215.); norm = vec3(0.020, 0.099, 0.060); return;\n } else {\n if (id < 1350.) {\n pos = vec3(802., 170., 158.); norm = vec3(0.020, 0.099, 0.060); return;\n } else {\n pos = vec3(664., 160., -5.); norm = vec3(-0.010, -0.196, 0.009); return;\n }\n }\n }\n } else {\n if (id < 1354.) {\n if (id < 1352.) {\n pos = vec3(484., 172., 66.); norm = vec3(-0.010, -0.196, 0.009); return;\n } else {\n if (id < 1353.) {\n pos = vec3(651., 159., -42.); norm = vec3(-0.010, -0.196, 0.009); return;\n } else {\n pos = vec3(484., 172., 66.); norm = vec3(-0.058, -0.974, 0.027); return;\n }\n }\n } else {\n if (id < 1356.) {\n if (id < 1355.) {\n pos = vec3(587., 162., -71.); norm = vec3(-0.058, -0.974, 0.027); return;\n } else {\n pos = vec3(651., 159., -42.); norm = vec3(-0.058, -0.974, 0.027); return;\n }\n } else {\n if (id < 1357.) {\n pos = vec3(400., 168., -38.); norm = vec3(-0.015, -0.681, 0.038); return;\n } else {\n pos = vec3(587., 162., -71.); norm = vec3(-0.015, -0.681, 0.038); return;\n }\n }\n }\n }\n } else {\n if (id < 1364.) {\n if (id < 1361.) {\n if (id < 1359.) {\n pos = vec3(484., 172., 66.); norm = vec3(-0.015, -0.681, 0.038); return;\n } else {\n if (id < 1360.) {\n pos = vec3(501., 192., -93.); norm = vec3(0.015, 0.112, -0.093); return;\n } else {\n pos = vec3(588., 196., -74.); norm = vec3(0.015, 0.112, -0.093); return;\n }\n }\n } else {\n if (id < 1362.) {\n pos = vec3(500., 183., -104.); norm = vec3(0.015, 0.112, -0.093); return;\n } else {\n if (id < 1363.) {\n pos = vec3(500., 183., -104.); norm = vec3(0.330, -0.092, -0.929); return;\n } else {\n pos = vec3(588., 196., -74.); norm = vec3(0.330, -0.092, -0.929); return;\n }\n }\n }\n } else {\n if (id < 1367.) {\n if (id < 1365.) {\n pos = vec3(587., 162., -71.); norm = vec3(0.330, -0.092, -0.929); return;\n } else {\n if (id < 1366.) {\n pos = vec3(725., 159., 20.); norm = vec3(-0.094, 0.042, -0.993); return;\n } else {\n pos = vec3(728., 189., 21.); norm = vec3(-0.094, 0.042, -0.993); return;\n }\n }\n } else {\n if (id < 1369.) {\n if (id < 1368.) {\n pos = vec3(876., 165., 6.); norm = vec3(-0.094, 0.042, -0.993); return;\n } else {\n pos = vec3(728., 189., 21.); norm = vec3(0.142, 0.873, 0.000); return;\n }\n } else {\n if (id < 1370.) {\n pos = vec3(728., 189., 85.); norm = vec3(0.142, 0.873, 0.000); return;\n } else {\n pos = vec3(876., 165., 6.); norm = vec3(0.142, 0.873, 0.000); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1396.) {\n if (id < 1383.) {\n if (id < 1377.) {\n if (id < 1374.) {\n if (id < 1372.) {\n pos = vec3(728., 189., 85.); norm = vec3(0.468, -0.002, 0.878); return;\n } else {\n if (id < 1373.) {\n pos = vec3(726., 161., 86.); norm = vec3(0.468, -0.002, 0.878); return;\n } else {\n pos = vec3(876., 165., 6.); norm = vec3(0.468, -0.002, 0.878); return;\n }\n }\n } else {\n if (id < 1375.) {\n pos = vec3(726., 161., 86.); norm = vec3(0.042, -0.996, 0.030); return;\n } else {\n if (id < 1376.) {\n pos = vec3(725., 159., 20.); norm = vec3(0.042, -0.996, 0.030); return;\n } else {\n pos = vec3(876., 165., 6.); norm = vec3(0.042, -0.996, 0.030); return;\n }\n }\n }\n } else {\n if (id < 1380.) {\n if (id < 1378.) {\n pos = vec3(664., 160., -5.); norm = vec3(-0.327, 0.118, -0.930); return;\n } else {\n if (id < 1379.) {\n pos = vec3(667., 192., -2.); norm = vec3(-0.327, 0.118, -0.930); return;\n } else {\n pos = vec3(800., 167., -52.); norm = vec3(-0.327, 0.118, -0.930); return;\n }\n }\n } else {\n if (id < 1381.) {\n pos = vec3(667., 192., -2.); norm = vec3(0.106, 0.893, -0.165); return;\n } else {\n if (id < 1382.) {\n pos = vec3(728., 189., 21.); norm = vec3(0.106, 0.893, -0.165); return;\n } else {\n pos = vec3(800., 167., -52.); norm = vec3(0.106, 0.893, -0.165); return;\n }\n }\n }\n }\n } else {\n if (id < 1389.) {\n if (id < 1386.) {\n if (id < 1384.) {\n pos = vec3(728., 189., 21.); norm = vec3(0.689, -0.093, 0.708); return;\n } else {\n if (id < 1385.) {\n pos = vec3(725., 159., 20.); norm = vec3(0.689, -0.093, 0.708); return;\n } else {\n pos = vec3(800., 167., -52.); norm = vec3(0.689, -0.093, 0.708); return;\n }\n }\n } else {\n if (id < 1387.) {\n pos = vec3(725., 159., 20.); norm = vec3(0.013, -0.660, -0.059); return;\n } else {\n if (id < 1388.) {\n pos = vec3(664., 160., -5.); norm = vec3(0.013, -0.660, -0.059); return;\n } else {\n pos = vec3(800., 167., -52.); norm = vec3(0.013, -0.660, -0.059); return;\n }\n }\n }\n } else {\n if (id < 1392.) {\n if (id < 1390.) {\n pos = vec3(651., 159., -42.); norm = vec3(-0.493, 0.004, -0.851); return;\n } else {\n if (id < 1391.) {\n pos = vec3(653., 192., -43.); norm = vec3(-0.493, 0.004, -0.851); return;\n } else {\n pos = vec3(727., 170., -86.); norm = vec3(-0.493, 0.004, -0.851); return;\n }\n }\n } else {\n if (id < 1394.) {\n if (id < 1393.) {\n pos = vec3(653., 192., -43.); norm = vec3(0.197, 0.795, -0.067); return;\n } else {\n pos = vec3(667., 192., -2.); norm = vec3(0.197, 0.795, -0.067); return;\n }\n } else {\n if (id < 1395.) {\n pos = vec3(727., 170., -86.); norm = vec3(0.197, 0.795, -0.067); return;\n } else {\n pos = vec3(667., 192., -2.); norm = vec3(0.788, -0.130, 0.597); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1409.) {\n if (id < 1402.) {\n if (id < 1399.) {\n if (id < 1397.) {\n pos = vec3(664., 160., -5.); norm = vec3(0.788, -0.130, 0.597); return;\n } else {\n if (id < 1398.) {\n pos = vec3(727., 170., -86.); norm = vec3(0.788, -0.130, 0.597); return;\n } else {\n pos = vec3(664., 160., -5.); norm = vec3(0.130, -0.975, -0.019); return;\n }\n }\n } else {\n if (id < 1400.) {\n pos = vec3(651., 159., -42.); norm = vec3(0.130, -0.975, -0.019); return;\n } else {\n if (id < 1401.) {\n pos = vec3(727., 170., -86.); norm = vec3(0.130, -0.975, -0.019); return;\n } else {\n pos = vec3(587., 162., -71.); norm = vec3(-0.428, -0.065, -0.877); return;\n }\n }\n }\n } else {\n if (id < 1405.) {\n if (id < 1403.) {\n pos = vec3(588., 196., -74.); norm = vec3(-0.428, -0.065, -0.877); return;\n } else {\n if (id < 1404.) {\n pos = vec3(659., 174., -107.); norm = vec3(-0.428, -0.065, -0.877); return;\n } else {\n pos = vec3(588., 196., -74.); norm = vec3(0.169, 0.903, -0.238); return;\n }\n }\n } else {\n if (id < 1407.) {\n if (id < 1406.) {\n pos = vec3(653., 192., -43.); norm = vec3(0.169, 0.903, -0.238); return;\n } else {\n pos = vec3(659., 174., -107.); norm = vec3(0.169, 0.903, -0.238); return;\n }\n } else {\n if (id < 1408.) {\n pos = vec3(653., 192., -43.); norm = vec3(0.958, -0.055, 0.105); return;\n } else {\n pos = vec3(651., 159., -42.); norm = vec3(0.958, -0.055, 0.105); return;\n }\n }\n }\n }\n } else {\n if (id < 1415.) {\n if (id < 1412.) {\n if (id < 1410.) {\n pos = vec3(659., 174., -107.); norm = vec3(0.958, -0.055, 0.105); return;\n } else {\n if (id < 1411.) {\n pos = vec3(651., 159., -42.); norm = vec3(0.042, -0.767, -0.172); return;\n } else {\n pos = vec3(587., 162., -71.); norm = vec3(0.042, -0.767, -0.172); return;\n }\n }\n } else {\n if (id < 1413.) {\n pos = vec3(659., 174., -107.); norm = vec3(0.042, -0.767, -0.172); return;\n } else {\n if (id < 1414.) {\n pos = vec3(782., 160., 118.); norm = vec3(0.072, -0.075, -0.981); return;\n } else {\n pos = vec3(783., 187., 116.); norm = vec3(0.072, -0.075, -0.981); return;\n }\n }\n }\n } else {\n if (id < 1418.) {\n if (id < 1416.) {\n pos = vec3(885., 167., 125.); norm = vec3(0.072, -0.075, -0.981); return;\n } else {\n if (id < 1417.) {\n pos = vec3(783., 187., 116.); norm = vec3(0.185, 0.924, -0.039); return;\n } else {\n pos = vec3(792., 186., 135.); norm = vec3(0.185, 0.924, -0.039); return;\n }\n }\n } else {\n if (id < 1420.) {\n if (id < 1419.) {\n pos = vec3(885., 167., 125.); norm = vec3(0.185, 0.924, -0.039); return;\n } else {\n pos = vec3(792., 186., 135.); norm = vec3(0.225, 0.842, 0.488); return;\n }\n } else {\n if (id < 1421.) {\n pos = vec3(802., 170., 158.); norm = vec3(0.225, 0.842, 0.488); return;\n } else {\n pos = vec3(885., 167., 125.); norm = vec3(0.225, 0.842, 0.488); return;\n }\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1524.) {\n if (id < 1473.) {\n if (id < 1447.) {\n if (id < 1434.) {\n if (id < 1428.) {\n if (id < 1425.) {\n if (id < 1423.) {\n pos = vec3(802., 170., 158.); norm = vec3(0.216, -0.730, 0.610); return;\n } else {\n if (id < 1424.) {\n pos = vec3(797., 161., 149.); norm = vec3(0.216, -0.730, 0.610); return;\n } else {\n pos = vec3(885., 167., 125.); norm = vec3(0.216, -0.730, 0.610); return;\n }\n }\n } else {\n if (id < 1426.) {\n pos = vec3(797., 161., 149.); norm = vec3(0.059, -0.866, -0.001); return;\n } else {\n if (id < 1427.) {\n pos = vec3(782., 160., 118.); norm = vec3(0.059, -0.866, -0.001); return;\n } else {\n pos = vec3(885., 167., 125.); norm = vec3(0.059, -0.866, -0.001); return;\n }\n }\n }\n } else {\n if (id < 1431.) {\n if (id < 1429.) {\n pos = vec3(726., 161., 86.); norm = vec3(-0.074, -0.030, -0.995); return;\n } else {\n if (id < 1430.) {\n pos = vec3(728., 189., 85.); norm = vec3(-0.074, -0.030, -0.995); return;\n } else {\n pos = vec3(926., 163., 71.); norm = vec3(-0.074, -0.030, -0.995); return;\n }\n }\n } else {\n if (id < 1432.) {\n pos = vec3(728., 189., 85.); norm = vec3(0.087, 0.720, -0.108); return;\n } else {\n if (id < 1433.) {\n pos = vec3(783., 187., 116.); norm = vec3(0.087, 0.720, -0.108); return;\n } else {\n pos = vec3(926., 163., 71.); norm = vec3(0.087, 0.720, -0.108); return;\n }\n }\n }\n }\n } else {\n if (id < 1440.) {\n if (id < 1437.) {\n if (id < 1435.) {\n pos = vec3(783., 187., 116.); norm = vec3(0.308, 0.059, 0.946); return;\n } else {\n if (id < 1436.) {\n pos = vec3(782., 160., 118.); norm = vec3(0.308, 0.059, 0.946); return;\n } else {\n pos = vec3(926., 163., 71.); norm = vec3(0.308, 0.059, 0.946); return;\n }\n }\n } else {\n if (id < 1438.) {\n pos = vec3(782., 160., 118.); norm = vec3(0.004, -0.560, -0.024); return;\n } else {\n if (id < 1439.) {\n pos = vec3(726., 161., 86.); norm = vec3(0.004, -0.560, -0.024); return;\n } else {\n pos = vec3(926., 163., 71.); norm = vec3(0.004, -0.560, -0.024); return;\n }\n }\n }\n } else {\n if (id < 1443.) {\n if (id < 1441.) {\n pos = vec3(587., 162., -71.); norm = vec3(-0.039, -0.394, -0.148); return;\n } else {\n if (id < 1442.) {\n pos = vec3(400., 168., -38.); norm = vec3(-0.039, -0.394, -0.148); return;\n } else {\n pos = vec3(500., 183., -104.); norm = vec3(-0.039, -0.394, -0.148); return;\n }\n }\n } else {\n if (id < 1445.) {\n if (id < 1444.) {\n pos = vec3(500., 183., -104.); norm = vec3(-0.079, -0.924, -0.330); return;\n } else {\n pos = vec3(400., 168., -38.); norm = vec3(-0.079, -0.924, -0.330); return;\n }\n } else {\n if (id < 1446.) {\n pos = vec3(373., 191., -96.); norm = vec3(-0.079, -0.924, -0.330); return;\n } else {\n pos = vec3(667., 192., -2.); norm = vec3(0.060, 0.992, -0.014); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1460.) {\n if (id < 1453.) {\n if (id < 1450.) {\n if (id < 1448.) {\n pos = vec3(484., 204., 61.); norm = vec3(0.060, 0.992, -0.014); return;\n } else {\n if (id < 1449.) {\n pos = vec3(546., 202., 191.); norm = vec3(0.060, 0.992, -0.014); return;\n } else {\n pos = vec3(546., 202., 191.); norm = vec3(0.062, 0.862, 0.000); return;\n }\n }\n } else {\n if (id < 1451.) {\n pos = vec3(728., 189., 85.); norm = vec3(0.062, 0.862, 0.000); return;\n } else {\n if (id < 1452.) {\n pos = vec3(728., 189., 21.); norm = vec3(0.062, 0.862, 0.000); return;\n } else {\n pos = vec3(667., 192., -2.); norm = vec3(0.014, 0.256, -0.004); return;\n }\n }\n }\n } else {\n if (id < 1456.) {\n if (id < 1454.) {\n pos = vec3(546., 202., 191.); norm = vec3(0.014, 0.256, -0.004); return;\n } else {\n if (id < 1455.) {\n pos = vec3(728., 189., 21.); norm = vec3(0.014, 0.256, -0.004); return;\n } else {\n pos = vec3(667., 192., -2.); norm = vec3(0.057, 0.974, -0.020); return;\n }\n }\n } else {\n if (id < 1458.) {\n if (id < 1457.) {\n pos = vec3(653., 192., -43.); norm = vec3(0.057, 0.974, -0.020); return;\n } else {\n pos = vec3(484., 204., 61.); norm = vec3(0.057, 0.974, -0.020); return;\n }\n } else {\n if (id < 1459.) {\n pos = vec3(484., 204., 61.); norm = vec3(0.055, 0.837, -0.007); return;\n } else {\n pos = vec3(653., 192., -43.); norm = vec3(0.055, 0.837, -0.007); return;\n }\n }\n }\n }\n } else {\n if (id < 1466.) {\n if (id < 1463.) {\n if (id < 1461.) {\n pos = vec3(588., 196., -74.); norm = vec3(0.055, 0.837, -0.007); return;\n } else {\n if (id < 1462.) {\n pos = vec3(67., 45., -184.); norm = vec3(-0.174, 0.472, -0.482); return;\n } else {\n pos = vec3(234., 121., -170.); norm = vec3(-0.174, 0.472, -0.482); return;\n }\n }\n } else {\n if (id < 1464.) {\n pos = vec3(219., 95., -190.); norm = vec3(-0.174, 0.472, -0.482); return;\n } else {\n if (id < 1465.) {\n pos = vec3(552., 177., 205.); norm = vec3(-0.043, -0.858, 0.052); return;\n } else {\n pos = vec3(484., 172., 66.); norm = vec3(-0.043, -0.858, 0.052); return;\n }\n }\n }\n } else {\n if (id < 1469.) {\n if (id < 1467.) {\n pos = vec3(726., 161., 86.); norm = vec3(-0.043, -0.858, 0.052); return;\n } else {\n if (id < 1468.) {\n pos = vec3(726., 161., 86.); norm = vec3(-0.013, -0.267, 0.008); return;\n } else {\n pos = vec3(484., 172., 66.); norm = vec3(-0.013, -0.267, 0.008); return;\n }\n }\n } else {\n if (id < 1471.) {\n if (id < 1470.) {\n pos = vec3(725., 159., 20.); norm = vec3(-0.013, -0.267, 0.008); return;\n } else {\n pos = vec3(484., 172., 66.); norm = vec3(-0.029, -0.691, 0.043); return;\n }\n } else {\n if (id < 1472.) {\n pos = vec3(664., 160., -5.); norm = vec3(-0.029, -0.691, 0.043); return;\n } else {\n pos = vec3(725., 159., 20.); norm = vec3(-0.029, -0.691, 0.043); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1498.) {\n if (id < 1485.) {\n if (id < 1479.) {\n if (id < 1476.) {\n if (id < 1474.) {\n pos = vec3(797., 161., 149.); norm = vec3(-0.007, -0.136, 0.008); return;\n } else {\n if (id < 1475.) {\n pos = vec3(552., 177., 205.); norm = vec3(-0.007, -0.136, 0.008); return;\n } else {\n pos = vec3(782., 160., 118.); norm = vec3(-0.007, -0.136, 0.008); return;\n }\n }\n } else {\n if (id < 1477.) {\n pos = vec3(552., 177., 205.); norm = vec3(-0.046, -0.897, 0.053); return;\n } else {\n if (id < 1478.) {\n pos = vec3(726., 161., 86.); norm = vec3(-0.046, -0.897, 0.053); return;\n } else {\n pos = vec3(782., 160., 118.); norm = vec3(-0.046, -0.897, 0.053); return;\n }\n }\n }\n } else {\n if (id < 1482.) {\n if (id < 1480.) {\n pos = vec3(153., 28., 38.); norm = vec3(0.327, -0.596, 0.095); return;\n } else {\n if (id < 1481.) {\n pos = vec3(152., 42., 129.); norm = vec3(0.327, -0.596, 0.095); return;\n } else {\n pos = vec3(115., 15., 87.); norm = vec3(0.327, -0.596, 0.095); return;\n }\n }\n } else {\n if (id < 1483.) {\n pos = vec3(153., 28., 38.); norm = vec3(0.400, -0.733, -0.262); return;\n } else {\n if (id < 1484.) {\n pos = vec3(127., 37., -27.); norm = vec3(0.400, -0.733, -0.262); return;\n } else {\n pos = vec3(283., 108., 13.); norm = vec3(0.400, -0.733, -0.262); return;\n }\n }\n }\n }\n } else {\n if (id < 1491.) {\n if (id < 1488.) {\n if (id < 1486.) {\n pos = vec3(283., 108., 13.); norm = vec3(0.364, -0.764, -0.063); return;\n } else {\n if (id < 1487.) {\n pos = vec3(127., 37., -27.); norm = vec3(0.364, -0.764, -0.063); return;\n } else {\n pos = vec3(248., 106., -165.); norm = vec3(0.364, -0.764, -0.063); return;\n }\n }\n } else {\n if (id < 1489.) {\n pos = vec3(484., 172., 66.); norm = vec3(0.210, -0.536, -0.149); return;\n } else {\n if (id < 1490.) {\n pos = vec3(283., 108., 13.); norm = vec3(0.210, -0.536, -0.149); return;\n } else {\n pos = vec3(400., 168., -38.); norm = vec3(0.210, -0.536, -0.149); return;\n }\n }\n }\n } else {\n if (id < 1494.) {\n if (id < 1492.) {\n pos = vec3(400., 168., -38.); norm = vec3(0.421, -0.884, -0.073); return;\n } else {\n if (id < 1493.) {\n pos = vec3(283., 108., 13.); norm = vec3(0.421, -0.884, -0.073); return;\n } else {\n pos = vec3(248., 106., -165.); norm = vec3(0.421, -0.884, -0.073); return;\n }\n }\n } else {\n if (id < 1496.) {\n if (id < 1495.) {\n pos = vec3(33., 70., 900.); norm = vec3(0.366, 0.899, 0.180); return;\n } else {\n pos = vec3(34., 86., 818.); norm = vec3(0.366, 0.899, 0.180); return;\n }\n } else {\n if (id < 1497.) {\n pos = vec3(6., 98., 815.); norm = vec3(0.366, 0.899, 0.180); return;\n } else {\n pos = vec3(84., -214., -707.); norm = vec3(0.435, -0.065, -0.081); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1511.) {\n if (id < 1504.) {\n if (id < 1501.) {\n if (id < 1499.) {\n pos = vec3(72., -204., -779.); norm = vec3(0.435, -0.065, -0.081); return;\n } else {\n if (id < 1500.) {\n pos = vec3(88., -181., -712.); norm = vec3(0.435, -0.065, -0.081); return;\n } else {\n pos = vec3(60., -214., -707.); norm = vec3(-0.963, -0.166, -0.184); return;\n }\n }\n } else {\n if (id < 1502.) {\n pos = vec3(56., -182., -715.); norm = vec3(-0.963, -0.166, -0.184); return;\n } else {\n if (id < 1503.) {\n pos = vec3(72., -204., -779.); norm = vec3(-0.963, -0.166, -0.184); return;\n } else {\n pos = vec3(72., -204., -779.); norm = vec3(0.001, 0.937, -0.322); return;\n }\n }\n }\n } else {\n if (id < 1507.) {\n if (id < 1505.) {\n pos = vec3(56., -182., -715.); norm = vec3(0.001, 0.937, -0.322); return;\n } else {\n if (id < 1506.) {\n pos = vec3(88., -181., -712.); norm = vec3(0.001, 0.937, -0.322); return;\n } else {\n pos = vec3(60., -214., -707.); norm = vec3(0.000, -0.318, -0.044); return;\n }\n }\n } else {\n if (id < 1509.) {\n if (id < 1508.) {\n pos = vec3(72., -204., -779.); norm = vec3(0.000, -0.318, -0.044); return;\n } else {\n pos = vec3(84., -214., -707.); norm = vec3(0.000, -0.318, -0.044); return;\n }\n } else {\n if (id < 1510.) {\n pos = vec3(-58., -180., -715.); norm = vec3(0.003, 0.480, -0.190); return;\n } else {\n pos = vec3(-77., -204., -776.); norm = vec3(0.003, 0.480, -0.190); return;\n }\n }\n }\n }\n } else {\n if (id < 1517.) {\n if (id < 1514.) {\n if (id < 1512.) {\n pos = vec3(-95., -179., -713.); norm = vec3(0.003, 0.480, -0.190); return;\n } else {\n if (id < 1513.) {\n pos = vec3(-63., -216., -706.); norm = vec3(0.000, -0.967, -0.166); return;\n } else {\n pos = vec3(-91., -216., -706.); norm = vec3(0.000, -0.967, -0.166); return;\n }\n }\n } else {\n if (id < 1515.) {\n pos = vec3(-77., -204., -776.); norm = vec3(0.000, -0.967, -0.166); return;\n } else {\n if (id < 1516.) {\n pos = vec3(-77., -204., -776.); norm = vec3(-0.914, -0.138, -0.206); return;\n } else {\n pos = vec3(-91., -216., -706.); norm = vec3(-0.914, -0.138, -0.206); return;\n }\n }\n }\n } else {\n if (id < 1520.) {\n if (id < 1518.) {\n pos = vec3(-95., -179., -713.); norm = vec3(-0.914, -0.138, -0.206); return;\n } else {\n if (id < 1519.) {\n pos = vec3(-63., -216., -706.); norm = vec3(0.488, -0.096, -0.114); return;\n } else {\n pos = vec3(-77., -204., -776.); norm = vec3(0.488, -0.096, -0.114); return;\n }\n }\n } else {\n if (id < 1522.) {\n if (id < 1521.) {\n pos = vec3(-58., -180., -715.); norm = vec3(0.488, -0.096, -0.114); return;\n } else {\n pos = vec3(-30., -54., -256.); norm = vec3(-0.749, -0.552, -0.219); return;\n }\n } else {\n if (id < 1523.) {\n pos = vec3(-41., -72., -173.); norm = vec3(-0.749, -0.552, -0.219); return;\n } else {\n pos = vec3(-66., -44., -158.); norm = vec3(-0.749, -0.552, -0.219); return;\n }\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1575.) {\n if (id < 1549.) {\n if (id < 1536.) {\n if (id < 1530.) {\n if (id < 1527.) {\n if (id < 1525.) {\n pos = vec3(37., -20., 303.); norm = vec3(0.983, -0.056, 0.168); return;\n } else {\n if (id < 1526.) {\n pos = vec3(55., -25., 196.); norm = vec3(0.983, -0.056, 0.168); return;\n } else {\n pos = vec3(57., 10., 196.); norm = vec3(0.983, -0.056, 0.168); return;\n }\n }\n } else {\n if (id < 1528.) {\n pos = vec3(-57., 10., 196.); norm = vec3(-0.982, -0.056, 0.177); return;\n } else {\n if (id < 1529.) {\n pos = vec3(-55., -25., 196.); norm = vec3(-0.982, -0.056, 0.177); return;\n } else {\n pos = vec3(-36., -20., 303.); norm = vec3(-0.982, -0.056, 0.177); return;\n }\n }\n }\n } else {\n if (id < 1533.) {\n if (id < 1531.) {\n pos = vec3(44., 66., 866.); norm = vec3(0.347, 0.064, 0.105); return;\n } else {\n if (id < 1532.) {\n pos = vec3(48., 77., 846.); norm = vec3(0.347, 0.064, 0.105); return;\n } else {\n pos = vec3(33., 70., 900.); norm = vec3(0.347, 0.064, 0.105); return;\n }\n }\n } else {\n if (id < 1534.) {\n pos = vec3(36., 36., 902.); norm = vec3(0.398, -0.049, 0.081); return;\n } else {\n if (id < 1535.) {\n pos = vec3(45., 33., 856.); norm = vec3(0.398, -0.049, 0.081); return;\n } else {\n pos = vec3(40., 52., 892.); norm = vec3(0.398, -0.049, 0.081); return;\n }\n }\n }\n }\n } else {\n if (id < 1542.) {\n if (id < 1539.) {\n if (id < 1537.) {\n pos = vec3(45., 33., 856.); norm = vec3(0.837, -0.201, -0.209); return;\n } else {\n if (id < 1538.) {\n pos = vec3(37., 35., 822.); norm = vec3(0.837, -0.201, -0.209); return;\n } else {\n pos = vec3(46., 59., 835.); norm = vec3(0.837, -0.201, -0.209); return;\n }\n }\n } else {\n if (id < 1540.) {\n pos = vec3(43., 48., 861.); norm = vec3(0.457, 0.269, 0.166); return;\n } else {\n if (id < 1541.) {\n pos = vec3(46., 59., 835.); norm = vec3(0.457, 0.269, 0.166); return;\n } else {\n pos = vec3(39., 61., 851.); norm = vec3(0.457, 0.269, 0.166); return;\n }\n }\n }\n } else {\n if (id < 1545.) {\n if (id < 1543.) {\n pos = vec3(41., 54., 874.); norm = vec3(0.528, -0.471, -0.509); return;\n } else {\n if (id < 1544.) {\n pos = vec3(33., 58., 862.); norm = vec3(0.528, -0.471, -0.509); return;\n } else {\n pos = vec3(44., 66., 866.); norm = vec3(0.528, -0.471, -0.509); return;\n }\n }\n } else {\n if (id < 1547.) {\n if (id < 1546.) {\n pos = vec3(43., 48., 861.); norm = vec3(0.408, 0.040, 0.045); return;\n } else {\n pos = vec3(41., 54., 874.); norm = vec3(0.408, 0.040, 0.045); return;\n }\n } else {\n if (id < 1548.) {\n pos = vec3(45., 33., 856.); norm = vec3(0.408, 0.040, 0.045); return;\n } else {\n pos = vec3(45., 33., 856.); norm = vec3(0.817, 0.107, 0.057); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1562.) {\n if (id < 1555.) {\n if (id < 1552.) {\n if (id < 1550.) {\n pos = vec3(41., 54., 874.); norm = vec3(0.817, 0.107, 0.057); return;\n } else {\n if (id < 1551.) {\n pos = vec3(40., 52., 892.); norm = vec3(0.817, 0.107, 0.057); return;\n } else {\n pos = vec3(33., 58., 862.); norm = vec3(0.468, -0.679, 0.070); return;\n }\n }\n } else {\n if (id < 1553.) {\n pos = vec3(39., 61., 851.); norm = vec3(0.468, -0.679, 0.070); return;\n } else {\n if (id < 1554.) {\n pos = vec3(44., 66., 866.); norm = vec3(0.468, -0.679, 0.070); return;\n } else {\n pos = vec3(48., 77., 846.); norm = vec3(0.835, 0.136, -0.374); return;\n }\n }\n }\n } else {\n if (id < 1558.) {\n if (id < 1556.) {\n pos = vec3(46., 59., 835.); norm = vec3(0.835, 0.136, -0.374); return;\n } else {\n if (id < 1557.) {\n pos = vec3(34., 86., 818.); norm = vec3(0.835, 0.136, -0.374); return;\n } else {\n pos = vec3(34., 86., 818.); norm = vec3(0.775, 0.003, -0.542); return;\n }\n }\n } else {\n if (id < 1560.) {\n if (id < 1559.) {\n pos = vec3(46., 59., 835.); norm = vec3(0.775, 0.003, -0.542); return;\n } else {\n pos = vec3(37., 35., 822.); norm = vec3(0.775, 0.003, -0.542); return;\n }\n } else {\n if (id < 1561.) {\n pos = vec3(41., 54., 874.); norm = vec3(0.605, 0.625, -0.195); return;\n } else {\n pos = vec3(43., 48., 861.); norm = vec3(0.605, 0.625, -0.195); return;\n }\n }\n }\n }\n } else {\n if (id < 1568.) {\n if (id < 1565.) {\n if (id < 1563.) {\n pos = vec3(33., 58., 862.); norm = vec3(0.605, 0.625, -0.195); return;\n } else {\n if (id < 1564.) {\n pos = vec3(43., 48., 861.); norm = vec3(0.520, 0.478, 0.414); return;\n } else {\n pos = vec3(39., 61., 851.); norm = vec3(0.520, 0.478, 0.414); return;\n }\n }\n } else {\n if (id < 1566.) {\n pos = vec3(33., 58., 862.); norm = vec3(0.520, 0.478, 0.414); return;\n } else {\n if (id < 1567.) {\n pos = vec3(44., 66., 866.); norm = vec3(0.840, -0.507, -0.111); return;\n } else {\n pos = vec3(39., 61., 851.); norm = vec3(0.840, -0.507, -0.111); return;\n }\n }\n }\n } else {\n if (id < 1571.) {\n if (id < 1569.) {\n pos = vec3(48., 77., 846.); norm = vec3(0.840, -0.507, -0.111); return;\n } else {\n if (id < 1570.) {\n pos = vec3(48., 77., 846.); norm = vec3(0.795, -0.326, 0.389); return;\n } else {\n pos = vec3(39., 61., 851.); norm = vec3(0.795, -0.326, 0.389); return;\n }\n }\n } else {\n if (id < 1573.) {\n if (id < 1572.) {\n pos = vec3(46., 59., 835.); norm = vec3(0.795, -0.326, 0.389); return;\n } else {\n pos = vec3(45., 33., 856.); norm = vec3(0.469, 0.039, 0.071); return;\n }\n } else {\n if (id < 1574.) {\n pos = vec3(46., 59., 835.); norm = vec3(0.469, 0.039, 0.071); return;\n } else {\n pos = vec3(43., 48., 861.); norm = vec3(0.469, 0.039, 0.071); return;\n }\n }\n }\n }\n }\n }\n } else {\n if (id < 1600.) {\n if (id < 1587.) {\n if (id < 1581.) {\n if (id < 1578.) {\n if (id < 1576.) {\n pos = vec3(40., 52., 892.); norm = vec3(0.541, 0.140, 0.159); return;\n } else {\n if (id < 1577.) {\n pos = vec3(44., 66., 866.); norm = vec3(0.541, 0.140, 0.159); return;\n } else {\n pos = vec3(33., 70., 900.); norm = vec3(0.541, 0.140, 0.159); return;\n }\n }\n } else {\n if (id < 1579.) {\n pos = vec3(-27., 53., 892.); norm = vec3(-0.481, -0.104, 0.042); return;\n } else {\n if (id < 1580.) {\n pos = vec3(-32., 66., 867.); norm = vec3(-0.481, -0.104, 0.042); return;\n } else {\n pos = vec3(-29., 55., 874.); norm = vec3(-0.481, -0.104, 0.042); return;\n }\n }\n }\n } else {\n if (id < 1584.) {\n if (id < 1582.) {\n pos = vec3(-23., 87., 818.); norm = vec3(-0.151, 0.591, 0.121); return;\n } else {\n if (id < 1583.) {\n pos = vec3(-35., 78., 847.); norm = vec3(-0.151, 0.591, 0.121); return;\n } else {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.151, 0.591, 0.121); return;\n }\n }\n } else {\n if (id < 1585.) {\n pos = vec3(-32., 66., 867.); norm = vec3(-0.616, -0.380, -0.136); return;\n } else {\n if (id < 1586.) {\n pos = vec3(-35., 78., 847.); norm = vec3(-0.616, -0.380, -0.136); return;\n } else {\n pos = vec3(-26., 62., 851.); norm = vec3(-0.616, -0.380, -0.136); return;\n }\n }\n }\n }\n } else {\n if (id < 1593.) {\n if (id < 1590.) {\n if (id < 1588.) {\n pos = vec3(-26., 62., 851.); norm = vec3(-0.610, -0.249, 0.375); return;\n } else {\n if (id < 1589.) {\n pos = vec3(-35., 78., 847.); norm = vec3(-0.610, -0.249, 0.375); return;\n } else {\n pos = vec3(-34., 59., 836.); norm = vec3(-0.610, -0.249, 0.375); return;\n }\n }\n } else {\n if (id < 1591.) {\n pos = vec3(-34., 59., 836.); norm = vec3(-0.833, 0.069, 0.127); return;\n } else {\n if (id < 1592.) {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.833, 0.069, 0.127); return;\n } else {\n pos = vec3(-31., 49., 861.); norm = vec3(-0.833, 0.069, 0.127); return;\n }\n }\n }\n } else {\n if (id < 1596.) {\n if (id < 1594.) {\n pos = vec3(-21., 58., 862.); norm = vec3(-0.569, 0.656, -0.215); return;\n } else {\n if (id < 1595.) {\n pos = vec3(-31., 49., 861.); norm = vec3(-0.569, 0.656, -0.215); return;\n } else {\n pos = vec3(-29., 55., 874.); norm = vec3(-0.569, 0.656, -0.215); return;\n }\n }\n } else {\n if (id < 1598.) {\n if (id < 1597.) {\n pos = vec3(-26., 62., 851.); norm = vec3(-0.445, 0.454, 0.367); return;\n } else {\n pos = vec3(-31., 49., 861.); norm = vec3(-0.445, 0.454, 0.367); return;\n }\n } else {\n if (id < 1599.) {\n pos = vec3(-21., 58., 862.); norm = vec3(-0.445, 0.454, 0.367); return;\n } else {\n pos = vec3(-32., 66., 867.); norm = vec3(-0.483, -0.654, -0.018); return;\n }\n }\n }\n }\n }\n } else {\n if (id < 1613.) {\n if (id < 1606.) {\n if (id < 1603.) {\n if (id < 1601.) {\n pos = vec3(-26., 62., 851.); norm = vec3(-0.483, -0.654, -0.018); return;\n } else {\n if (id < 1602.) {\n pos = vec3(-21., 58., 862.); norm = vec3(-0.483, -0.654, -0.018); return;\n } else {\n pos = vec3(-29., 55., 874.); norm = vec3(-0.573, -0.475, -0.500); return;\n }\n }\n } else {\n if (id < 1604.) {\n pos = vec3(-32., 66., 867.); norm = vec3(-0.573, -0.475, -0.500); return;\n } else {\n if (id < 1605.) {\n pos = vec3(-21., 58., 862.); norm = vec3(-0.573, -0.475, -0.500); return;\n } else {\n pos = vec3(-34., 59., 836.); norm = vec3(-0.484, 0.334, 0.192); return;\n }\n }\n }\n } else {\n if (id < 1609.) {\n if (id < 1607.) {\n pos = vec3(-31., 49., 861.); norm = vec3(-0.484, 0.334, 0.192); return;\n } else {\n if (id < 1608.) {\n pos = vec3(-26., 62., 851.); norm = vec3(-0.484, 0.334, 0.192); return;\n } else {\n pos = vec3(-34., 59., 836.); norm = vec3(-0.839, -0.180, -0.183); return;\n }\n }\n } else {\n if (id < 1611.) {\n if (id < 1610.) {\n pos = vec3(-26., 35., 823.); norm = vec3(-0.839, -0.180, -0.183); return;\n } else {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.839, -0.180, -0.183); return;\n }\n } else {\n if (id < 1612.) {\n pos = vec3(-27., 53., 892.); norm = vec3(-0.398, -0.021, 0.078); return;\n } else {\n pos = vec3(-33., 34., 856.); norm = vec3(-0.398, -0.021, 0.078); return;\n }\n }\n }\n }\n } else {\n if (id < 1619.) {\n if (id < 1616.) {\n if (id < 1614.) {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.398, -0.021, 0.078); return;\n } else {\n if (id < 1615.) {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.546, 0.133, 0.178); return;\n } else {\n pos = vec3(-32., 66., 867.); norm = vec3(-0.546, 0.133, 0.178); return;\n }\n }\n } else {\n if (id < 1617.) {\n pos = vec3(-27., 53., 892.); norm = vec3(-0.546, 0.133, 0.178); return;\n } else {\n if (id < 1618.) {\n pos = vec3(-20., 71., 900.); norm = vec3(-0.380, 0.108, 0.122); return;\n } else {\n pos = vec3(-35., 78., 847.); norm = vec3(-0.380, 0.108, 0.122); return;\n }\n }\n }\n } else {\n if (id < 1622.) {\n if (id < 1620.) {\n pos = vec3(-32., 66., 867.); norm = vec3(-0.380, 0.108, 0.122); return;\n } else {\n if (id < 1621.) {\n pos = vec3(-16., 7., 978.); norm = vec3(-0.451, -0.071, 0.020); return;\n } else {\n pos = vec3(-27., 53., 892.); norm = vec3(-0.451, -0.071, 0.020); return;\n }\n }\n } else {\n if (id < 1624.) {\n if (id < 1623.) {\n pos = vec3(-24., 37., 903.); norm = vec3(-0.451, -0.071, 0.020); return;\n } else {\n pos = vec3(33., 70., 900.); norm = vec3(0.195, 0.052, 0.052); return;\n }\n } else {\n if (id < 1625.) {\n pos = vec3(29., 7., 978.); norm = vec3(0.195, 0.052, 0.052); return;\n } else {\n pos = vec3(40., 52., 892.); norm = vec3(0.195, 0.052, 0.052); return;\n }\n }\n }\n }\n }\n }\n }\n }\n }\n }\n }\n}\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n float pointId = mod(vertexId, NUM_VERTS_0);\n float modelId = floor(vertexId / NUM_VERTS_0);\n \n vec3 pos;\n vec3 normal;\n getVert0(pointId, pos, normal);\n \n float tt = time * 4. * mix(0.8, 1.2, hash(modelId * 0.23));\n pos.y += sin(abs(pos.x) * 0.001) * sin(-tt + abs(pos.x * -0.001)) * 300.;\n\n float tm = time * 0.5;\n float r = 1500.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 1., 10000.0);\n vec3 eye = vec3(cos(tm * 0.9) * r, sin(tm * 0.9) * r, 6000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(\n vec3(\n t2m1(hash(modelId * 0.121)), \n t2m1(hash(modelId * 0.312)) + sin(-tt + PI + 0.75) * 0.01, \n t2m1(hash(modelId * 0.717))) * 4000.);\n// mat *= rotX(time + abs(ca) * 5.);\n// mat *= rotZ(time + abs(cd) * 6.);\n// mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = pos.z / 10000. + mix(0.9, 1.1, hash(modelId * 0.17));//abs(ca * cd) * 2.;\n float sat = 0.5;//mix(1., 0., abs(ca));\n float val = 1.0;//mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n \n}" + }, "screenshotURL": "data/images/images-lo7idkdlh8afbxgvk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fSdF3Y59NoqNegw7y/art.json b/art/fSdF3Y59NoqNegw7y/art.json index 40579ee5..05953e2a 100644 --- a/art/fSdF3Y59NoqNegw7y/art.json +++ b/art/fSdF3Y59NoqNegw7y/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat2 rotate2D(float x)\\n{\\n float a = sin(x), b = cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main()\\n{\\n float tmp \\t= 2.0 * abs(sin(time * 0.02)) * 10.0;\\n float posx \\t= (vertexId / vertexCount - 0.5) * 3.0;\\n float posy \\t= fract(posx * tmp);\\n \\n vec2 pos = vec2(posx, posy * sin(posx + time));\\n \\n gl_PointSize \\t= 2.0;\\n gl_Position \\t= vec4(pos, 0.0, 1.0);\\n v_color \\t\\t= vec4(1.0); \\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat2 rotate2D(float x)\n{\n float a = sin(x), b = cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main()\n{\n float tmp \t= 2.0 * abs(sin(time * 0.02)) * 10.0;\n float posx \t= (vertexId / vertexCount - 0.5) * 3.0;\n float posy \t= fract(posx * tmp);\n \n vec2 pos = vec2(posx, posy * sin(posx + time));\n \n gl_PointSize \t= 2.0;\n gl_Position \t= vec4(pos, 0.0, 1.0);\n v_color \t\t= vec4(1.0); \n}" + }, "screenshotURL": "data/images/images-mxnl0bmnx1xrs2fil-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fSom8rCSmFz3LJYiZ/art.json b/art/fSom8rCSmFz3LJYiZ/art.json index 106abefb..32d60629 100644 --- a/art/fSom8rCSmFz3LJYiZ/art.json +++ b/art/fSom8rCSmFz3LJYiZ/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":421,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 5;\\t\\n \\n \\n \\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\\n }\\n \\n else if(num == 5) {\\n gl_Position = vec4(cos(vertexId),sin(vertexId),0.0,1.0);\\n }\\n\\n gl_PointSize = sin(time)*vertexId/5.0; \\n \\n \\n v_color = vec4(vertexId/500.0,vertexId/255.0,0.5,1);\\n}\"}", + "settings": { + "num": 421, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 5;\t\n \n \n \n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\n }\n \n else if(num == 5) {\n gl_Position = vec4(cos(vertexId),sin(vertexId),0.0,1.0);\n }\n\n gl_PointSize = sin(time)*vertexId/5.0; \n \n \n v_color = vec4(vertexId/500.0,vertexId/255.0,0.5,1);\n}" + }, "screenshotURL": "data/images/images-b37b8fccowmjbzl3q-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fSz8brGjX9TATFZLC/art.json b/art/fSz8brGjX9TATFZLC/art.json index 4fecd06a..80b99e6f 100644 --- a/art/fSz8brGjX9TATFZLC/art.json +++ b/art/fSz8brGjX9TATFZLC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/oschzqgdxjxe/haon-pullik-prod-godic-korean?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. -1. * sin(time);\\n float vy = v * 2. -1. * cos(time);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 500. ;\\n \\n v_color = vec4(sin(time), cos(time), 0, 1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/oschzqgdxjxe/haon-pullik-prod-godic-korean?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Term : 2023 Fall\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. -1. * sin(time);\n float vy = v * 2. -1. * cos(time);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 500. ;\n \n v_color = vec4(sin(time), cos(time), 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-vlsx6bdgp6tsk2bnu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fTYSeXRBwwDXJEac4/art.json b/art/fTYSeXRBwwDXJEac4/art.json index 5eecf0b5..698bb8e8 100644 --- a/art/fTYSeXRBwwDXJEac4/art.json +++ b/art/fTYSeXRBwwDXJEac4/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/bt/ocean-waves\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.350;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= -rotateX;\\n p1.position.xz *= -rotateY;\\n p1.position.xy *= -rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/bt/ocean-waves", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.350;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= -rotateX;\n p1.position.xz *= -rotateY;\n p1.position.xy *= -rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-xnqwcu4ebdrswq7l2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fWTyJ5884wxLdY28e/art.json b/art/fWTyJ5884wxLdY28e/art.json index a1f94eac..5fb093bc 100644 --- a/art/fWTyJ5884wxLdY28e/art.json +++ b/art/fWTyJ5884wxLdY28e/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-u90l37q6fik224i53-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fXX9cns72XG97J3rk/art.json b/art/fXX9cns72XG97J3rk/art.json index 03942c69..7340e432 100644 --- a/art/fXX9cns72XG97J3rk/art.json +++ b/art/fXX9cns72XG97J3rk/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sergioerick", "avatarUrl": "https://lh6.googleusercontent.com/-6mWCYE7e8JE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcnyCK5B6N4hdhN62pAcPOwiFeA5g/mo/photo.jpg", - "settings": "{\"num\":164,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float squares = 80.0;\\n float PI = 3.14159;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId, 2.0); \\n \\n float angle = (x/squares)*(2.0*PI);\\n float r = y + 0.5; \\n \\n float x1 = r * cos(angle);\\n float y1 = r * sin(angle); \\n \\n vec2 xy = vec2(x1,y1)*0.4;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n v_color=vec4(0.0, 0.0,1.0,1.0);\\n gl_PointSize = 10.0;\\n \\n}\"}", + "settings": { + "num": 164, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float squares = 80.0;\n float PI = 3.14159;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId, 2.0); \n \n float angle = (x/squares)*(2.0*PI);\n float r = y + 0.5; \n \n float x1 = r * cos(angle);\n float y1 = r * sin(angle); \n \n vec2 xy = vec2(x1,y1)*0.4;\n \n gl_Position = vec4(xy,0.0,1.0);\n v_color=vec4(0.0, 0.0,1.0,1.0);\n gl_PointSize = 10.0;\n \n}" + }, "screenshotURL": "data/images/images-a9ulk6ew7ah541dl2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fXjL89sHjq7Pkzz5X/art.json b/art/fXjL89sHjq7Pkzz5X/art.json index f5618083..6927ec55 100644 --- a/art/fXjL89sHjq7Pkzz5X/art.json +++ b/art/fXjL89sHjq7Pkzz5X/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n#define kp1 3.//KParameter 0.>>10.\\n#define kp2 3.//KParameter 0.>>5.\\n//KVertices_Number=16666\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n float vertexCount = 1666. *kp1;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5*kp2) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n#define kp1 3.//KParameter 0.>>10.\n#define kp2 3.//KParameter 0.>>5.\n//KVertices_Number=16666\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n float vertexCount = 1666. *kp1;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5*kp2) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-ub777b6slvrbq9pkq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fcAdcLhQi59meuwEa/art.json b/art/fcAdcLhQi59meuwEa/art.json index e0e7e3b0..3bd31341 100644 --- a/art/fcAdcLhQi59meuwEa/art.json +++ b/art/fcAdcLhQi59meuwEa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":72000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/apollyonpsy/apollyon-particle-velocity-album-previews-out-on-freak-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 7.0\\n#define fakeVerticeNumber 100000.\\n\\nconst float dim = 120.;\\nconst float off = 0.1;\\nconst vec3 vAlb = vec3(0.5);\\n\\n\\n//////////////////////////////\\n//K Machine parameters\\n/////////////////////////////\\n\\n//KDrawmode=GL_LINE_STRIP \\n\\n\\n#define tubeSpeedFactor 2.3 //KParameter 0.>>4. \\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 100.1 //KParameter 1.>>10.\\n#define radiusSizeFactor 0.8 //KParameter 0.05>>0.2\\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\\n#define soundFactor 1. //KParameter 1.>>3.\\n\\n#define cubeScaleFactorZ 1.\\n\\nmat4 rotZ(float _radAngle) { \\n float s = sin(_radAngle);\\n float c = cos(_radAngle);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 _s) {\\n return mat4(\\n _s[0], 0, 0, 0,\\n 0, _s[1], 0, 0,\\n 0, 0, _s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\\n float f = tan(PI * 0.5 - 0.5 * _fov);\\n float rInv = 1.0 / (_zNear - _zFar);\\n\\n return mat4(\\n f / _aspect, 0., 0., 0.,\\n 0., f, 0., 0.,\\n 0., 0., (_zNear + _zFar) * rInv, -1.,\\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\\n}\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 _m) {\\n float\\n a00 = _m[0][0], a01 = _m[0][1], a02 = _m[0][2], a03 = _m[0][3],\\n a10 = _m[1][0], a11 = _m[1][1], a12 = _m[1][2], a13 = _m[1][3],\\n a20 = _m[2][0], a21 = _m[2][1], a22 = _m[2][2], a23 = _m[2][3],\\n a30 = _m[3][0], a31 = _m[3][1], a32 = _m[3][2], a33 = _m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nvec3 getTrajPoint(const float _id) {\\n return vec3(\\n sin(_id * 0.99+time/100.),\\n sin(_id * 2.43+time/100.),\\n sin(_id * 1.57+time/100.));\\n}\\n \\nfloat getFLoatLiss(const float _id, const float _time)\\n{\\n return sin(0.99+_time) +sin( 2.43+_time) +sin( 1.57)/30.;\\n}\\n\\nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\\n{\\n \\n float pg = _rel + _delta;\\n \\n vec3 r0 = getTrajPoint(pg + off * 0.);\\n vec3 r1 = getTrajPoint(pg + off * 1.);\\n vec3 r2 = getTrajPoint(pg + off * 2.);\\n \\n _pos = mat3(\\n getTrajPoint(pg + off * 0.),\\n getTrajPoint(pg + off * 1.),\\n getTrajPoint(pg + off * 2.));\\n \\n vec3 s0 = normalize(_pos[1] - _pos[0]);\\n vec3 s1 = normalize(_pos[2] - _pos[1]);\\n \\n vec4 zaxis = vec4(normalize(s1 - s0),1.);\\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\\n \\n _axis = mat3(\\n xaxis,\\n yaxis,\\n zaxis);\\n\\n\\n}\\n\\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\\n \\n \\n float prog = (_shapeId / _shapeCount)+_timeB;\\n \\n mat3 axis, mPos;\\n\\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\\n\\n //pos mtx\\n _wmat = mat4(\\n vec4(axis[0], 0),\\n vec4(axis[1], 0),\\n vec4(axis[2], 0),\\n vec4(mPos[0] * dim, 1)); \\n \\n //orient mtx\\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\\n vec3 target = mPos[1] * dim + axis[2];\\n vec3 up = axis[1];\\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\nmat4 rotMatx(vec3 _axis, float _angle)\\n{\\n _axis = normalize(_axis);\\n float s = sin(_angle);\\n float c = cos(_angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * _axis.x * _axis.x + c, oc * _axis.x * _axis.y - _axis.z * s, oc * _axis.z * _axis.x + _axis.y * s, 0.0,\\n oc * _axis.x * _axis.y + _axis.z * s, oc * _axis.y * _axis.y + c, oc * _axis.y * _axis.z - _axis.x * s, 0.0,\\n oc * _axis.z * _axis.x - _axis.y * s, oc * _axis.y * _axis.z + _axis.x * s, oc * _axis.z * _axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\n\\nvoid addPtLight( vec3 vLightPos, vec3 vLightColor, in vec3 _pos, in vec3 _norm, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - _pos);\\n vec3 vViewDir = normalize(-_pos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, _norm ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid addDirLight( vec3 _vLDir, vec3 _vLColor, in vec3 _pos, in vec3 _norm, inout vec3 _vDiff, inout vec3 _vSpec )\\n{\\n vec3 vViewDir = normalize(-_pos);\\n \\n float NdotL = max( 0.0, dot( _vLDir, _norm ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + _vLDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\\n \\n _vDiff += NdotL * _vLColor;\\n\\n float fPower = 80.0;\\n _vSpec += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * _vLColor;\\n}\\n\\nvec3 lightget(const vec3 vAlbedo, const vec3 _pos, const vec3 _eyePos, const vec3 _norm )\\n{ \\n vec3 vDiffuseLight = vec3(0.8,0.8, 0.8);\\n vec3 vSpecLight = vec3(0.8,0.8, 0.8);\\n\\n vec3 vAmbient = vec3(0.8,0.8, 0.8);\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n\\n //addPtLight( vec3(3.0, 2.0, 30.0), vec3( 0.2, 0.2,0.2),_pos, _norm, vDiffuseLight, vSpecLight );\\n \\n //addDirLight( normalize(vec3(0.0, -1.0, 0.0)*dim), vAmbient * 0.1, _pos, _norm, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(-_eyePos);\\n \\n float fNdotD = clamp(dot(_norm, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\n\\nvec3 lightPost( vec3 _vColor )\\n{\\n float exposure = 1.0;\\n _vColor = vec3(1.0) - exp2( _vColor * -exposure );\\n\\n _vColor = pow( _vColor, vec3(1.0 / 2.2) );\\n\\n return _vColor;\\n}\\n\\nvoid processSymX(inout vec3 _pos, inout vec3 _norm, float _xSym)\\n{\\n _pos.x = (_xSym - _pos.x);\\n _norm.x = -_norm.x;//(_xSym - _norm.x);;\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n \\n#define EYE_STATIC true\\n//#define STOP_TRAJ true\\n//#define DYN_GROUPID true\\n#define SOUND_REACT true\\n\\nvoid main() {\\n \\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\\n \\n bool bSym = false;\\n //Handle the sym\\n if(finalVertexId>=vertexCount/2.)\\n {\\n finalVertexId-= vertexCount/2.;\\n bSym = true;\\n }\\n \\n \\n //shape\\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\\n float shapeId = floor(finalVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n #ifdef SOUND_REACT\\n float snd = 1.+soundFactor*texture2D(sound, vec2(0., (1.-relGroupId))).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n \\n #ifdef STOP_TRAJ\\n float timeB = 14.;\\n #else\\n float timeB = time * tubeSpeedFactor;\\n #endif\\n \\n\\n \\n //Static eye\\n #ifdef EYE_STATIC\\n /*\\n vec3 eye = vec3(0.5, 0.5, 3.5)*dim;\\n vec3 target = vec3(0.5, 0.5, 1.)*dim;\\n vec3 up = vec3(0., 1., 0.);\\n*/\\n vec3 eye = vec3(sin(0.22*time), 1.5*cos(0.99*time), 6.*cos(0.13*time))*dim;\\n vec3 target = vec3(0.5*sin(0.22*time), 0.5, 1.)*dim;\\n vec3 up = vec3(0., 1., 0.);\\n #else\\n //Following eye\\n mat3 axis, sPos;// = getAxisMat(0., timeB);\\n getPosAndAxisMat(0., timeB, axis, sPos);\\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\\n vec3 target = sPos[2] * dim + axis[2];\\n vec3 up = axis[1];\\n #endif\\n \\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n\\n vec4 cNorm;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\\n \\n \\n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n \\n cNorm *= zrot;\\n //create the circle group\\n float radius =100.*radiusSizeFactor*getFLoatLiss(groupId, 0.)*snd;\\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n\\n mat4 posmat, rotmat;\\n\\n #ifdef DYN_GROUPID\\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\\n #else\\n getTrajMat(groupId, groupCount/10., timeB, posmat, rotmat);\\n #endif\\n \\n //shape orientation\\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\\n cNorm *= rotmat;\\n \\n //shape position\\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\\n \\n //Sym\\n if(bSym)\\n processSymX(cubep, cNorm.xyz, dim/2.);\\n\\n float colorIndex = mod(shapeIdInGroup,2.);\\n \\n vec3 alb = vec3(0.,0.,1.);\\n if(colorIndex == 0.)\\n {\\n alb = vec3(1.,1.,0.);\\n\\n }\\n \\n \\n vec3 finalColor = alb;\\n lightPost(finalColor);\\n \\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n \\n v_color = vec4(finalColor,1.);\\n}\\n\"}", + "settings": { + "num": 72000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/apollyonpsy/apollyon-particle-velocity-album-previews-out-on-freak-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 7.0\n#define fakeVerticeNumber 100000.\n\nconst float dim = 120.;\nconst float off = 0.1;\nconst vec3 vAlb = vec3(0.5);\n\n\n//////////////////////////////\n//K Machine parameters\n/////////////////////////////\n\n//KDrawmode=GL_LINE_STRIP \n\n\n#define tubeSpeedFactor 2.3 //KParameter 0.>>4. \n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 100.1 //KParameter 1.>>10.\n#define radiusSizeFactor 0.8 //KParameter 0.05>>0.2\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\n#define soundFactor 1. //KParameter 1.>>3.\n\n#define cubeScaleFactorZ 1.\n\nmat4 rotZ(float _radAngle) { \n float s = sin(_radAngle);\n float c = cos(_radAngle);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 _s) {\n return mat4(\n _s[0], 0, 0, 0,\n 0, _s[1], 0, 0,\n 0, 0, _s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\n float f = tan(PI * 0.5 - 0.5 * _fov);\n float rInv = 1.0 / (_zNear - _zFar);\n\n return mat4(\n f / _aspect, 0., 0., 0.,\n 0., f, 0., 0.,\n 0., 0., (_zNear + _zFar) * rInv, -1.,\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\n}\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 _m) {\n float\n a00 = _m[0][0], a01 = _m[0][1], a02 = _m[0][2], a03 = _m[0][3],\n a10 = _m[1][0], a11 = _m[1][1], a12 = _m[1][2], a13 = _m[1][3],\n a20 = _m[2][0], a21 = _m[2][1], a22 = _m[2][2], a23 = _m[2][3],\n a30 = _m[3][0], a31 = _m[3][1], a32 = _m[3][2], a33 = _m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nvec3 getTrajPoint(const float _id) {\n return vec3(\n sin(_id * 0.99+time/100.),\n sin(_id * 2.43+time/100.),\n sin(_id * 1.57+time/100.));\n}\n \nfloat getFLoatLiss(const float _id, const float _time)\n{\n return sin(0.99+_time) +sin( 2.43+_time) +sin( 1.57)/30.;\n}\n\nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\n{\n \n float pg = _rel + _delta;\n \n vec3 r0 = getTrajPoint(pg + off * 0.);\n vec3 r1 = getTrajPoint(pg + off * 1.);\n vec3 r2 = getTrajPoint(pg + off * 2.);\n \n _pos = mat3(\n getTrajPoint(pg + off * 0.),\n getTrajPoint(pg + off * 1.),\n getTrajPoint(pg + off * 2.));\n \n vec3 s0 = normalize(_pos[1] - _pos[0]);\n vec3 s1 = normalize(_pos[2] - _pos[1]);\n \n vec4 zaxis = vec4(normalize(s1 - s0),1.);\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\n \n _axis = mat3(\n xaxis,\n yaxis,\n zaxis);\n\n\n}\n\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\n \n \n float prog = (_shapeId / _shapeCount)+_timeB;\n \n mat3 axis, mPos;\n\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\n\n //pos mtx\n _wmat = mat4(\n vec4(axis[0], 0),\n vec4(axis[1], 0),\n vec4(axis[2], 0),\n vec4(mPos[0] * dim, 1)); \n \n //orient mtx\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\n vec3 target = mPos[1] * dim + axis[2];\n vec3 up = axis[1];\n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\nmat4 rotMatx(vec3 _axis, float _angle)\n{\n _axis = normalize(_axis);\n float s = sin(_angle);\n float c = cos(_angle);\n float oc = 1.0 - c;\n \n return mat4(oc * _axis.x * _axis.x + c, oc * _axis.x * _axis.y - _axis.z * s, oc * _axis.z * _axis.x + _axis.y * s, 0.0,\n oc * _axis.x * _axis.y + _axis.z * s, oc * _axis.y * _axis.y + c, oc * _axis.y * _axis.z - _axis.x * s, 0.0,\n oc * _axis.z * _axis.x - _axis.y * s, oc * _axis.y * _axis.z + _axis.x * s, oc * _axis.z * _axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\n\nvoid addPtLight( vec3 vLightPos, vec3 vLightColor, in vec3 _pos, in vec3 _norm, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - _pos);\n vec3 vViewDir = normalize(-_pos);\n \n float NdotL = max( 0.0, dot( vLightDir, _norm ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid addDirLight( vec3 _vLDir, vec3 _vLColor, in vec3 _pos, in vec3 _norm, inout vec3 _vDiff, inout vec3 _vSpec )\n{\n vec3 vViewDir = normalize(-_pos);\n \n float NdotL = max( 0.0, dot( _vLDir, _norm ) );\n \n vec3 vHalfAngle = normalize( vViewDir + _vLDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\n \n _vDiff += NdotL * _vLColor;\n\n float fPower = 80.0;\n _vSpec += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * _vLColor;\n}\n\nvec3 lightget(const vec3 vAlbedo, const vec3 _pos, const vec3 _eyePos, const vec3 _norm )\n{ \n vec3 vDiffuseLight = vec3(0.8,0.8, 0.8);\n vec3 vSpecLight = vec3(0.8,0.8, 0.8);\n\n vec3 vAmbient = vec3(0.8,0.8, 0.8);\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n\n //addPtLight( vec3(3.0, 2.0, 30.0), vec3( 0.2, 0.2,0.2),_pos, _norm, vDiffuseLight, vSpecLight );\n \n //addDirLight( normalize(vec3(0.0, -1.0, 0.0)*dim), vAmbient * 0.1, _pos, _norm, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(-_eyePos);\n \n float fNdotD = clamp(dot(_norm, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\n\nvec3 lightPost( vec3 _vColor )\n{\n float exposure = 1.0;\n _vColor = vec3(1.0) - exp2( _vColor * -exposure );\n\n _vColor = pow( _vColor, vec3(1.0 / 2.2) );\n\n return _vColor;\n}\n\nvoid processSymX(inout vec3 _pos, inout vec3 _norm, float _xSym)\n{\n _pos.x = (_xSym - _pos.x);\n _norm.x = -_norm.x;//(_xSym - _norm.x);;\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n \n#define EYE_STATIC true\n//#define STOP_TRAJ true\n//#define DYN_GROUPID true\n#define SOUND_REACT true\n\nvoid main() {\n \n float finalVertexId = mod(vertexId,fakeVerticeNumber);\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\n \n bool bSym = false;\n //Handle the sym\n if(finalVertexId>=vertexCount/2.)\n {\n finalVertexId-= vertexCount/2.;\n bSym = true;\n }\n \n \n //shape\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\n float shapeId = floor(finalVertexId / kShapeVertexCount);\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n #ifdef SOUND_REACT\n float snd = 1.+soundFactor*texture2D(sound, vec2(0., (1.-relGroupId))).a;\n #else\n float snd = 1.;\n #endif\n \n \n #ifdef STOP_TRAJ\n float timeB = 14.;\n #else\n float timeB = time * tubeSpeedFactor;\n #endif\n \n\n \n //Static eye\n #ifdef EYE_STATIC\n /*\n vec3 eye = vec3(0.5, 0.5, 3.5)*dim;\n vec3 target = vec3(0.5, 0.5, 1.)*dim;\n vec3 up = vec3(0., 1., 0.);\n*/\n vec3 eye = vec3(sin(0.22*time), 1.5*cos(0.99*time), 6.*cos(0.13*time))*dim;\n vec3 target = vec3(0.5*sin(0.22*time), 0.5, 1.)*dim;\n vec3 up = vec3(0., 1., 0.);\n #else\n //Following eye\n mat3 axis, sPos;// = getAxisMat(0., timeB);\n getPosAndAxisMat(0., timeB, axis, sPos);\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\n vec3 target = sPos[2] * dim + axis[2];\n vec3 up = axis[1];\n #endif\n \n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n\n vec4 cNorm;\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\n \n \n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\n cubep = (zrot*vec4(cubep,1.)).xyz;\n \n cNorm *= zrot;\n //create the circle group\n float radius =100.*radiusSizeFactor*getFLoatLiss(groupId, 0.)*snd;\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n \n //shapeId = mod(shapeId+time, shapeCount);\n\n mat4 posmat, rotmat;\n\n #ifdef DYN_GROUPID\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\n #else\n getTrajMat(groupId, groupCount/10., timeB, posmat, rotmat);\n #endif\n \n //shape orientation\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\n cNorm *= rotmat;\n \n //shape position\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\n \n //Sym\n if(bSym)\n processSymX(cubep, cNorm.xyz, dim/2.);\n\n float colorIndex = mod(shapeIdInGroup,2.);\n \n vec3 alb = vec3(0.,0.,1.);\n if(colorIndex == 0.)\n {\n alb = vec3(1.,1.,0.);\n\n }\n \n \n vec3 finalColor = alb;\n lightPost(finalColor);\n \n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n \n v_color = vec4(finalColor,1.);\n}\n" + }, "screenshotURL": "data/images/images-l9p0p51s8hnyxfrea-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fcxZGWMjswfrJWNLZ/art.json b/art/fcxZGWMjswfrJWNLZ/art.json index eac9b57c..d5454a9f 100644 --- a/art/fcxZGWMjswfrJWNLZ/art.json +++ b/art/fcxZGWMjswfrJWNLZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float move = vertexId*10.0;\\n \\n float x= mouse.x ;\\n float y=mouse.y;\\n \\n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\\n \\n gl_PointSize = 30.0;\\n \\n float red=tan(time);\\n float blue=cos(time);\\n float green=tan(time);\\n \\n v_color=vec4(red,green,blue,1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float move = vertexId*10.0;\n \n float x= mouse.x ;\n float y=mouse.y;\n \n gl_Position = vec4(sin(move)+x,cos(move)+y, 0, 1);\n \n gl_PointSize = 30.0;\n \n float red=tan(time);\n float blue=cos(time);\n float green=tan(time);\n \n v_color=vec4(red,green,blue,1.0);\n}" + }, "screenshotURL": "data/images/images-uvh7hp90hl3xiqtd4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fdRMRscY4Te3iZPBF/art.json b/art/fdRMRscY4Te3iZPBF/art.json index 94241475..a43854eb 100644 --- a/art/fdRMRscY4Te3iZPBF/art.json +++ b/art/fdRMRscY4Te3iZPBF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":58969,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.01568627450980392,0.023529411764705882,0.058823529411764705,1],\"shader\":\"\\n//KDrawmode=GL_LINES\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>2.\\n#define kpx 0.160//KParameter 1.>>8.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n//KverticesNumber=233333\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float u = 0.0;\\n float v = fract(vertexId / 240.0);\\n float age = floor(vertexId / 240.0) / 240.0;\\n float invAge = 1.0 - age;\\n vec4 touch = texture2D(touch, vec2(u, v));\\n float snd = texture2D(sound, vec2(v, age) * vec2(0.25, 0.25)).a;\\n float t = time - touch.w;\\n \\n float a = mod(vertexId, 6.0) / 6.0 * PI * 2.0 + t * 100.0;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = vec2(touch.xy) + (cs * age * snd * 0.2 *asin(kpx/3. )- 0.21) * 0.1;\\n gl_Position = vec4(xy * (1.0 + (age + t) * 1.0) , age/kpx*.4, 1);\\n\\n float hue = mix(age + 0.6*kpx + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\\n vec3 color = hsv2rgb(vec3(hue, invAge, snd + touch.z));\\n v_color = vec4(mix(color, background.rgb, age)-sin(color*.18) * invAge, invAge);\\n gl_PointSize = mix(20.0, 1.0, age);\\n\\n}\\n\\n\"}", + "settings": { + "num": 58969, + "mode": "LINES", + "sound": "https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy", + "lineSize": "CSS", + "backgroundColor": [ + 0.01568627450980392, + 0.023529411764705882, + 0.058823529411764705, + 1 + ], + "shader": "\n//KDrawmode=GL_LINES\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>2.\n#define kpx 0.160//KParameter 1.>>8.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n//KverticesNumber=233333\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float u = 0.0;\n float v = fract(vertexId / 240.0);\n float age = floor(vertexId / 240.0) / 240.0;\n float invAge = 1.0 - age;\n vec4 touch = texture2D(touch, vec2(u, v));\n float snd = texture2D(sound, vec2(v, age) * vec2(0.25, 0.25)).a;\n float t = time - touch.w;\n \n float a = mod(vertexId, 6.0) / 6.0 * PI * 2.0 + t * 100.0;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = vec2(touch.xy) + (cs * age * snd * 0.2 *asin(kpx/3. )- 0.21) * 0.1;\n gl_Position = vec4(xy * (1.0 + (age + t) * 1.0) , age/kpx*.4, 1);\n\n float hue = mix(age + 0.6*kpx + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\n vec3 color = hsv2rgb(vec3(hue, invAge, snd + touch.z));\n v_color = vec4(mix(color, background.rgb, age)-sin(color*.18) * invAge, invAge);\n gl_PointSize = mix(20.0, 1.0, age);\n\n}\n\n" + }, "screenshotURL": "data/images/images-bo7a7mz2kj4dqzopb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fe73gvqsKrgRYgqGX/art.json b/art/fe73gvqsKrgRYgqGX/art.json index 38bf3bfd..7b09bb03 100644 --- a/art/fe73gvqsKrgRYgqGX/art.json +++ b/art/fe73gvqsKrgRYgqGX/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "juan", "avatarUrl": "https://lh3.googleusercontent.com/a-/AFdZucoL0lP1434PdZotBF_QrR7BHy1cL8nZPDGU16LA=s96-c", - "settings": "{\"num\":1415,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define TAU (PI * 2.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 rotate(float freq, float phase, float radius, float index)\\n{\\n\\tfloat angle = (index * freq + phase) * TAU;\\n\\treturn vec2(radius * cos(angle), radius * sin(angle));\\n}\\n\\nfloat oscilate(float freq, float phase, float amp, float index)\\n{\\n return amp * sin((index * freq + phase) * TAU);\\n}\\n\\nvoid main() {\\n \\tfloat index = vertexId / vertexCount;\\n \\tfloat count = floor(index);\\n \\n \\n float r1_freq = 20.0;\\n float r1_phase = .30;\\n float r1_radius = .70;\\n float r1_osc_freq = 10.0;\\n float r1_osc_phase = 0.0;\\n float r1_osc_amp = 0.1;\\n \\n \\n float r2_freq = 556.0;\\n float r2_phase = .50;\\n float r2_radius = .90; \\n float r2_osc_freq = 20.0;\\n float r2_osc_phase = 0.0;\\n float r2_osc_amp = 0.3;\\n \\n vec2 xy = rotate( r1_freq, r1_phase + time*0.001, \\n r1_radius + oscilate(r1_osc_freq, \\n r1_osc_phase,\\n r1_osc_amp,\\n index), index) + \\n \\t\\trotate( r2_freq, r2_phase + time *0.01, \\n r2_radius + oscilate(r2_osc_freq, \\n r2_osc_phase, \\n r2_osc_amp,\\n index), index);\\n \\n //xy = vec2 (index,index);\\n\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n\\n gl_Position = vec4(xy * aspect, xy.y, 2);\\n\\n\\n float hue = 0.025;\\n float sat = 0.82;\\n float val = 0.925;\\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.001);\\n v_color = vec4(0.05,0.5,0.85,1);\\n}\"}", + "settings": { + "num": 1415, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define TAU (PI * 2.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 rotate(float freq, float phase, float radius, float index)\n{\n\tfloat angle = (index * freq + phase) * TAU;\n\treturn vec2(radius * cos(angle), radius * sin(angle));\n}\n\nfloat oscilate(float freq, float phase, float amp, float index)\n{\n return amp * sin((index * freq + phase) * TAU);\n}\n\nvoid main() {\n \tfloat index = vertexId / vertexCount;\n \tfloat count = floor(index);\n \n \n float r1_freq = 20.0;\n float r1_phase = .30;\n float r1_radius = .70;\n float r1_osc_freq = 10.0;\n float r1_osc_phase = 0.0;\n float r1_osc_amp = 0.1;\n \n \n float r2_freq = 556.0;\n float r2_phase = .50;\n float r2_radius = .90; \n float r2_osc_freq = 20.0;\n float r2_osc_phase = 0.0;\n float r2_osc_amp = 0.3;\n \n vec2 xy = rotate( r1_freq, r1_phase + time*0.001, \n r1_radius + oscilate(r1_osc_freq, \n r1_osc_phase,\n r1_osc_amp,\n index), index) + \n \t\trotate( r2_freq, r2_phase + time *0.01, \n r2_radius + oscilate(r2_osc_freq, \n r2_osc_phase, \n r2_osc_amp,\n index), index);\n \n //xy = vec2 (index,index);\n\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n\n gl_Position = vec4(xy * aspect, xy.y, 2);\n\n\n float hue = 0.025;\n float sat = 0.82;\n float val = 0.925;\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.001);\n v_color = vec4(0.05,0.5,0.85,1);\n}" + }, "screenshotURL": "data/images/images-o0y7dal6j44spkklr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fe8yM9E3pBta2SbNa/art.json b/art/fe8yM9E3pBta2SbNa/art.json index d0b83bde..fe4b0950 100644 --- a/art/fe8yM9E3pBta2SbNa/art.json +++ b/art/fe8yM9E3pBta2SbNa/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/christopher-camplin/qlabmilano\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 1\\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n\\n float ux = floor(id / 6.0) + mod(id, 2.);\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.0;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n \\t// \\n \\tfloat numSegments = 4.0;\\n \\tvec2 circleXY = getCirclePoint(vertexId, numSegments);\\n \\tfloat numPointsPerCircle = numSegments * 6.0;\\n \\tfloat circleId = floor(vertexId / numPointsPerCircle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\\n \\tfloat cols = floor(sqrt(numCircles));\\n \\tfloat rows = floor(numCircles / cols);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(circleId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat c = cos(PI * time + x * 0.25);\\n \\tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\\n \\tfloat yOff = cos(time + x * 0.25) * 0.2;\\n \\tfloat zOff = sin(time * x * y * 0.005) * 0.05;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\\\\\n\\n float ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. - zOff;\\n\\n \\t// concentrate on center\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\n // circular - atan returns values between PI & -PI\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n // sound\\n\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\\n \\tscl *= 20. / rows;\\t\\n \\tvec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\\n \\tfloat z = -pow(snd + c, 2.) - zOff + snd;\\n \\tvec4 pos = vec4(circleXY, z, 1);\\n \\tmat4 mat = ident();\\n \\tmat *= scale(vec3(1, aspect, 1));\\n mat *= rotX(radians(45.));\\n //mat *= rotY(radians(-45.));\\n \\tmat *= rotZ(time * 0.1);\\n\\tmat += transpose(mat * snd * mouse.x * mouse.y);\\n \\tmat *= trans(vec3(ux, vy, 0) * 1.3);\\n \\tmat *= uniformScale(0.02 * scl);\\n \\tmat *= rotY(PI * snd * 0.1 * sign(ux));\\n \\tmat *= rotZ(time * sign(ux));\\n \\n\\tgl_Position = mat * pos;\\n\\n \\n \\tfloat pump = step(0.6, snd);\\n float hue = 0.5 - pump * mouse.x * 0.1;\\n hue = hue + smoothstep(x, y, snd);\\n float sat = 0.8;\\n \\t// add more impact using pow\\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\\n \\t//val += oddSlice;\\n vec4 color = vec4(hsv2rgb(vec3(fract(hue), sat, val)), 1);\\n //color *= snd;\\n //background += 0.1;\\n \\tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\\n vec4 finalColor = mix(color, background, s);\\n\\tfinalColor = mix(color, newColor, c);\\n v_color = finalColor;\\n }\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/christopher-camplin/qlabmilano", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 1\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n\n float ux = floor(id / 6.0) + mod(id, 2.);\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 1 1 2 2 3 3 4 4 5 5 6\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.0;\n\n float x = c * radius;\n float y = s * radius;\n\n \n return vec2(x, y);\n}\n\nvoid main() {\n \t// \n \tfloat numSegments = 4.0;\n \tvec2 circleXY = getCirclePoint(vertexId, numSegments);\n \tfloat numPointsPerCircle = numSegments * 6.0;\n \tfloat circleId = floor(vertexId / numPointsPerCircle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCircle);\n \n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\n \tfloat cols = floor(sqrt(numCircles));\n \tfloat rows = floor(numCircles / cols);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(circleId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(circleId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat c = cos(PI * time + x * 0.25);\n \tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\n \tfloat yOff = cos(time + x * 0.25) * 0.2;\n \tfloat zOff = sin(time * x * y * 0.005) * 0.05;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\\\n\n float ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. - zOff;\n\n \t// concentrate on center\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat su = abs(u - 0.5) * 2.0;\n \n // circular - atan returns values between PI & -PI\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n // sound\n\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\n \tscl *= 20. / rows;\t\n \tvec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\n \tfloat z = -pow(snd + c, 2.) - zOff + snd;\n \tvec4 pos = vec4(circleXY, z, 1);\n \tmat4 mat = ident();\n \tmat *= scale(vec3(1, aspect, 1));\n mat *= rotX(radians(45.));\n //mat *= rotY(radians(-45.));\n \tmat *= rotZ(time * 0.1);\n\tmat += transpose(mat * snd * mouse.x * mouse.y);\n \tmat *= trans(vec3(ux, vy, 0) * 1.3);\n \tmat *= uniformScale(0.02 * scl);\n \tmat *= rotY(PI * snd * 0.1 * sign(ux));\n \tmat *= rotZ(time * sign(ux));\n \n\tgl_Position = mat * pos;\n\n \n \tfloat pump = step(0.6, snd);\n float hue = 0.5 - pump * mouse.x * 0.1;\n hue = hue + smoothstep(x, y, snd);\n float sat = 0.8;\n \t// add more impact using pow\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\n \t//val += oddSlice;\n vec4 color = vec4(hsv2rgb(vec3(fract(hue), sat, val)), 1);\n //color *= snd;\n //background += 0.1;\n \tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\n vec4 finalColor = mix(color, background, s);\n\tfinalColor = mix(color, newColor, c);\n v_color = finalColor;\n }\n\n" + }, "screenshotURL": "data/images/images-nzvwjs1cgrg1ldb07-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ffWaRfDRtqa8osv3y/art.json b/art/ffWaRfDRtqa8osv3y/art.json index fef80644..371f59d7 100644 --- a/art/ffWaRfDRtqa8osv3y/art.json +++ b/art/ffWaRfDRtqa8osv3y/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/t0kisaki/u-got-that-halogen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n#define Kp0 22.//KParameter 0.>>22.\\n#define Kp1 1.//KParameter 0.>>1.\\n#define Kp2 1.//KParameter 0.>>1.\\n#define Kp3 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>1.\\n#define rotationFactorY 1.//KParameter 0.>>1.\\n#define rotationFactorZ 1.//KParameter 0.>>1.\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427*Kp0));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .15)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(cpos*-0.8*snd);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-0.1, 0.5, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, .0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4-Kp1, -0.5*Kp2));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\\n float sat =pow(snd + 1.3,3.); step(0.4, snd);\\n float val = -0.5+snd;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/t0kisaki/u-got-that-halogen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n#define Kp0 22.//KParameter 0.>>22.\n#define Kp1 1.//KParameter 0.>>1.\n#define Kp2 1.//KParameter 0.>>1.\n#define Kp3 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>1.\n#define rotationFactorY 1.//KParameter 0.>>1.\n#define rotationFactorZ 1.//KParameter 0.>>1.\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427*Kp0));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.*Kp2*mouse.x) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.*Kp1) + floor(id / 3.-Kp3), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 1.13)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .15)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(cpos*-0.8*snd);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-0.1, 0.5, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, .0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 1.4-Kp1, -0.5*Kp2));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\n float sat =pow(snd + 1.3,3.); step(0.4, snd);\n float val = -0.5+snd;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-fj8u7vbyufjs0p4vk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fh74hqW59nbsQkT6N/art.json b/art/fh74hqW59nbsQkT6N/art.json index 03a452eb..ad9554fa 100644 --- a/art/fh74hqW59nbsQkT6N/art.json +++ b/art/fh74hqW59nbsQkT6N/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 428.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = u * fract(time / PI) - 1.0;\\n float y = v * 2.0 - 1.0;\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 6.0;\\n vec2 xy = vec2(\\n x * mix(yOff, 1.0, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 3. - xOff - yOff; \\n //gl_PointSize po*= 20.0 / cols; \\n gl_PointSize *= resolution.x / 1800.; \\n xy -= vec2(0.5);\\n xy *= rotate2D(snd * PI * 2.0);\\n xy += vec2(0.5);\\n gl_Position = vec4(xy, xOff , 1);\\n xy -= vec2(0.5);\\n xy *= rotate2D(-snd * -PI * -2.0);\\n xy += vec2(0.5);\\n float hue = snd * xOff;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 428.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = u * fract(time / PI) - 1.0;\n float y = v * 2.0 - 1.0;\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 6.0;\n vec2 xy = vec2(\n x * mix(yOff, 1.0, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 3. - xOff - yOff; \n //gl_PointSize po*= 20.0 / cols; \n gl_PointSize *= resolution.x / 1800.; \n xy -= vec2(0.5);\n xy *= rotate2D(snd * PI * 2.0);\n xy += vec2(0.5);\n gl_Position = vec4(xy, xOff , 1);\n xy -= vec2(0.5);\n xy *= rotate2D(-snd * -PI * -2.0);\n xy += vec2(0.5);\n float hue = snd * xOff;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-mbsypi50i68ym2i64-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fhgo4viQjn4Y4cfck/art.json b/art/fhgo4viQjn4Y4cfck/art.json index b3e04860..3d5e0bb6 100644 --- a/art/fhgo4viQjn4Y4cfck/art.json +++ b/art/fhgo4viQjn4Y4cfck/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "dzozef", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float SIDE = 16.; // how many cubes on one side\\nfloat CUBESIZE = 0.1; // one cube size\\nfloat NSCALE = 0.4;\\nfloat TSCALE = 1.2;\\n\\nvoid rotateX(inout vec3 p, float a) {\\n\\tfloat c,s;vec3 q=p;\\n\\tc = cos(a); s = sin(a);\\n\\tp.y = c * q.y - s * q.z;\\n\\tp.z = s * q.y + c * q.z;\\n}\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// noise from iq (https://www.shadertoy.com/view/4sfGzS)\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\nfloat noise( in vec3 x )\\n{\\n vec3 p = floor(x);\\n vec3 f = fract(x);\\n f = f*f*(3.0-2.0*f);\\n\\t\\n float n = p.x + p.y*157.0 + 113.0*p.z;\\n return mix(mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n mix( hash(n+157.0), hash(n+158.0),f.x),f.y),\\n mix(mix( hash(n+113.0), hash(n+114.0),f.x),\\n mix( hash(n+270.0), hash(n+271.0),f.x),f.y),f.z);\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n\\tfloat cube = floor( vertexid / 24. ); // 24 vertexes per cube\\n\\tif (cube > SIDE*SIDE*SIDE-1.) return vec3(0.0);\\n\\t// get the grid location\\n\\tfloat y = floor( cube / (SIDE*SIDE) );\\n\\tfloat z = floor( mod( cube, SIDE*SIDE ) / SIDE );\\n\\tfloat x = mod( mod( cube, SIDE*SIDE ), SIDE );\\n\\t// first check if empty\\n\\tfloat n = noise( vec3( x, y, z ) * NSCALE + vec3( time, time/2., time /3. ) * TSCALE );\\n\\tif (n < 0.7) return vec3(0.);\\n \\n\\tfloat vid = mod( vertexid, 24. );\\n\\tfloat sideid = floor( vid / 4. );\\n\\n \\n\\treturn (vec3( x, y, z ) + vec3( -SIDE/2. ))* CUBESIZE;\\n}\\n\\nvoid main()\\n{\\n\\tvec3 p = GetPoint( vertexId );\\n\\tfloat fov = 1.1;\\n\\tp = rotateY( p, -mouse.x*1.2-0.2 );\\n\\trotateX( p, mouse.y*1.2-0.2 );\\n\\tfloat origz = p.z;\\n\\tp += vec3( 0.0, 0, SIDE/7. );\\n\\tgl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n\\tgl_PointSize = 3.0;\\n\\tv_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float SIDE = 16.; // how many cubes on one side\nfloat CUBESIZE = 0.1; // one cube size\nfloat NSCALE = 0.4;\nfloat TSCALE = 1.2;\n\nvoid rotateX(inout vec3 p, float a) {\n\tfloat c,s;vec3 q=p;\n\tc = cos(a); s = sin(a);\n\tp.y = c * q.y - s * q.z;\n\tp.z = s * q.y + c * q.z;\n}\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// noise from iq (https://www.shadertoy.com/view/4sfGzS)\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\nfloat noise( in vec3 x )\n{\n vec3 p = floor(x);\n vec3 f = fract(x);\n f = f*f*(3.0-2.0*f);\n\t\n float n = p.x + p.y*157.0 + 113.0*p.z;\n return mix(mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n mix( hash(n+157.0), hash(n+158.0),f.x),f.y),\n mix(mix( hash(n+113.0), hash(n+114.0),f.x),\n mix( hash(n+270.0), hash(n+271.0),f.x),f.y),f.z);\n}\n\nvec3 GetPoint( float vertexid )\n{\n\tfloat cube = floor( vertexid / 24. ); // 24 vertexes per cube\n\tif (cube > SIDE*SIDE*SIDE-1.) return vec3(0.0);\n\t// get the grid location\n\tfloat y = floor( cube / (SIDE*SIDE) );\n\tfloat z = floor( mod( cube, SIDE*SIDE ) / SIDE );\n\tfloat x = mod( mod( cube, SIDE*SIDE ), SIDE );\n\t// first check if empty\n\tfloat n = noise( vec3( x, y, z ) * NSCALE + vec3( time, time/2., time /3. ) * TSCALE );\n\tif (n < 0.7) return vec3(0.);\n \n\tfloat vid = mod( vertexid, 24. );\n\tfloat sideid = floor( vid / 4. );\n\n \n\treturn (vec3( x, y, z ) + vec3( -SIDE/2. ))* CUBESIZE;\n}\n\nvoid main()\n{\n\tvec3 p = GetPoint( vertexId );\n\tfloat fov = 1.1;\n\tp = rotateY( p, -mouse.x*1.2-0.2 );\n\trotateX( p, mouse.y*1.2-0.2 );\n\tfloat origz = p.z;\n\tp += vec3( 0.0, 0, SIDE/7. );\n\tgl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n\tgl_PointSize = 3.0;\n\tv_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-bgz3bzrkem6dna8qp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fj8P6N2AkQHBBaTmZ/art.json b/art/fj8P6N2AkQHBBaTmZ/art.json index 8da3ff05..1fa099f1 100644 --- a/art/fj8P6N2AkQHBBaTmZ/art.json +++ b/art/fj8P6N2AkQHBBaTmZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "shortwavedave", "avatarUrl": "https://secure.gravatar.com/avatar/5999d47c7003bd60c3f1bfd965a79666?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.047058823529411764,0.06274509803921569,0.29411764705882354,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.2) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time+x*y*0.02) * 5.;\\n \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.047058823529411764, + 0.06274509803921569, + 0.29411764705882354, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.2) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time+x*y*0.02) * 5.;\n \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-0ddr6kmem61e78899-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fjN25zTwqLYMCNkJ4/art.json b/art/fjN25zTwqLYMCNkJ4/art.json index 550e1a05..e4b9ab20 100644 --- a/art/fjN25zTwqLYMCNkJ4/art.json +++ b/art/fjN25zTwqLYMCNkJ4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Motion\\n//Course : CS250\\n//Spring 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2.0 - 1.0 + xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x) * 5.0;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tv_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Motion\n//Course : CS250\n//Spring 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2.0 - 1.0 + xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x) * 5.0;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tv_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-adq4xfys08soo9ays-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fmmQsNyrdyjA3226x/art.json b/art/fmmQsNyrdyjA3226x/art.json index cf1df3ae..e13eb861 100644 --- a/art/fmmQsNyrdyjA3226x/art.json +++ b/art/fmmQsNyrdyjA3226x/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":18432,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/inplainsight/orbital-where-is-it-going-in\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 0.0;\\n const int count = 8;\\n for (int i = 0; i < count; ++i) {\\n snd += float(count - i) * texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1 + (0.5 + float(i)) / soundRes.y)).a;\\n }\\n snd /= float(2 * (count + 4));\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level);\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.5;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.5); \\n mat *= rotZ(-time + snd);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = mix(0.3, 1.0, abs(m1p1(uvfl.x)));\\n float val = cs;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 18432, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/inplainsight/orbital-where-is-it-going-in", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 0.0;\n const int count = 8;\n for (int i = 0; i < count; ++i) {\n snd += float(count - i) * texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1 + (0.5 + float(i)) / soundRes.y)).a;\n }\n snd /= float(2 * (count + 4));\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level);\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.5;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1, 1) * 0.5); \n mat *= rotZ(-time + snd);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = mix(0.3, 1.0, abs(m1p1(uvfl.x)));\n float val = cs;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-wtf4k2310970nl4zh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fnQrnopggmFfZmzMG/art.json b/art/fnQrnopggmFfZmzMG/art.json index 3f80d0a7..51f096ec 100644 --- a/art/fnQrnopggmFfZmzMG/art.json +++ b/art/fnQrnopggmFfZmzMG/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.11372549019607843,0.3843137254901961,1],\"shader\":\"//Lesson 3\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yx, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.4;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.11372549019607843, + 0.3843137254901961, + 1 + ], + "shader": "//Lesson 3\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yx, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.4;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-2wn0cg7einuom8gxq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/foJQ7C4rZnwuJSDxD/art.json b/art/foJQ7C4rZnwuJSDxD/art.json index b6d20abc..37f2a358 100644 --- a/art/foJQ7C4rZnwuJSDxD/art.json +++ b/art/foJQ7C4rZnwuJSDxD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 0.4, 1.0);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 0.4, 1.0);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-tb96zlmyq4dpn6m9e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fpcEBXb2uz75rjixv/art.json b/art/fpcEBXb2uz75rjixv/art.json index 8c2b070f..0f51eb4c 100644 --- a/art/fpcEBXb2uz75rjixv/art.json +++ b/art/fpcEBXb2uz75rjixv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":5145,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/loulourecords/pimpo-gama-zacchi-go-loulou-records-preview-llr082-release-date-06-august\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 1, 1, 1,\\n 1, c, s, 0,\\n 1, -s, c, 0,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 1,\\n 0, 0, 1, 1,\\n s, 0, c, 1,\\n 0, 0, 1, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 0\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\\n\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() {\\n float numCircles = 8.;\\n float numPointsPerCircle = floor(vertexCount / numCircles);\\n float id = mod(vertexId, numPointsPerCircle);\\n float u = id / numPointsPerCircle;\\n \\n float cId = floor(vertexId / numPointsPerCircle);\\n float cv = cId / numCircles;\\n\\n float a = u * PI * 2.;\\n vec3 pos = vec3(cos(a), 0, sin(a));\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 mat = persp(PI * 0.25, aspect, 1., 15.);\\n \\n float cs = time * 0.5;\\n float r = 8.;\\n vec3 eye = vec3(cos(cs) * r, sin(cs * .7) * r * .5, sin(cs) * r);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.25, fract(time + cv)),\\n 0.)).a;\\n float pump = step(0.70, s);\\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n mat *= rotZ(cv * PI * 2. + time * 0.05);\\n mat *= trans(vec3(0, mix(2.5, 2.5, pow(s, 5.)), 0));\\n \\n float sp = cv + time * 0.1;\\n mat *= rotZ(PI * 0.5); //sin(u * PI * 2.) * cos(sp) * 1.);\\n mat *= rotX(sin(u * PI * 1.) * PI * sin(sp * PI) * 80. * pow(s, 5.));\\n mat *= uniformScale(mix(0.7, 0.7, pump));\\n \\n\\n gl_Position = mat * vec4(pos, 1);\\n float z = gl_Position.z / gl_Position.w * .5 + .5;\\n z = pow(z, 8.);\\n z = 1. - z;\\n \\n float hue = mix(0.5, 8.5, s) + sin(u * PI * 2.) * .1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n// v_color = mix(v_color, vec4(1,0,0,1), pump);\\n \\n gl_PointSize = z * (5. * pow(s + .2, 5.) * 5.);\\n}\"}", + "settings": { + "num": 5145, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/loulourecords/pimpo-gama-zacchi-go-loulou-records-preview-llr082-release-date-06-august", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 1, 1, 1,\n 1, c, s, 0,\n 1, -s, c, 0,\n 0, 0, 0, 0); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 1,\n 0, 0, 1, 1,\n s, 0, c, 1,\n 0, 0, 1, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 0\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif\n\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() {\n float numCircles = 8.;\n float numPointsPerCircle = floor(vertexCount / numCircles);\n float id = mod(vertexId, numPointsPerCircle);\n float u = id / numPointsPerCircle;\n \n float cId = floor(vertexId / numPointsPerCircle);\n float cv = cId / numCircles;\n\n float a = u * PI * 2.;\n vec3 pos = vec3(cos(a), 0, sin(a));\n \n float aspect = resolution.x / resolution.y;\n mat4 mat = persp(PI * 0.25, aspect, 1., 15.);\n \n float cs = time * 0.5;\n float r = 8.;\n vec3 eye = vec3(cos(cs) * r, sin(cs * .7) * r * .5, sin(cs) * r);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n float s = texture2D(sound, vec2(\n mix(0.01, 0.25, fract(time + cv)),\n 0.)).a;\n float pump = step(0.70, s);\n \n mat *= cameraLookAt(eye, target, up);\n \n mat *= rotZ(cv * PI * 2. + time * 0.05);\n mat *= trans(vec3(0, mix(2.5, 2.5, pow(s, 5.)), 0));\n \n float sp = cv + time * 0.1;\n mat *= rotZ(PI * 0.5); //sin(u * PI * 2.) * cos(sp) * 1.);\n mat *= rotX(sin(u * PI * 1.) * PI * sin(sp * PI) * 80. * pow(s, 5.));\n mat *= uniformScale(mix(0.7, 0.7, pump));\n \n\n gl_Position = mat * vec4(pos, 1);\n float z = gl_Position.z / gl_Position.w * .5 + .5;\n z = pow(z, 8.);\n z = 1. - z;\n \n float hue = mix(0.5, 8.5, s) + sin(u * PI * 2.) * .1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n// v_color = mix(v_color, vec4(1,0,0,1), pump);\n \n gl_PointSize = z * (5. * pow(s + .2, 5.) * 5.);\n}" + }, "screenshotURL": "data/images/images-onqks47yh04yzmhcm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fs6GHW2crknZmzoWy/art.json b/art/fs6GHW2crknZmzoWy/art.json index cbba651c..d2ce71cc 100644 --- a/art/fs6GHW2crknZmzoWy/art.json +++ b/art/fs6GHW2crknZmzoWy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "martinpalko", "avatarUrl": "https://avatars.githubusercontent.com/MartinPalko?s=200", - "settings": "{\"num\":6362,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cosmomedia/thunderstorm-sounds-of-nature\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Defines to compile the HLSL code with GLSL\\n#define float4 vec4\\n#define float3 vec3\\n#define float2 vec2\\n#define float4x4 mat4\\n#define float3x3 mat3\\n#define mul(x, y) y * x\\n#define lerp mix\\n#define static\\n#define saturate(x) clamp(x, 0.0, 1.0)\\n\\nfloat Rand(float2 seed)\\n{\\n return fract(sin(dot(seed.xy ,float2(12.9898,78.233))) * 43758.5453); \\n}\\n\\nstruct RainParams\\n{\\n float minSpeed;\\n\\tfloat maxSpeed;\\n float groundHeight;\\n float fallDistance;\\n float2 minBounds;\\n float2 maxBounds;\\n float2 windDirectionAndStrength;\\n};\\n\\nstruct Raindrop\\n{\\n float size;\\n float3 position;\\n float3 velocity;\\n};\\n\\nfloat Wrap(float value, float minimum, float maximum, out float offset)\\n{\\n float maxMinusMin = maximum - minimum;\\n float valueMinusMin = value - minimum;\\n offset = floor(valueMinusMin / maxMinusMin);\\n return minimum + mod(valueMinusMin, maxMinusMin);\\n}\\n\\nfloat Wrap(float value, float minimum, float maximum)\\n{\\n float dummy;\\n return Wrap(value, minimum, maximum, dummy);\\n}\\n\\nRaindrop GenerateRaindrop(RainParams params, float time, float seed)\\n{\\n \\tfloat3 boundsSize;\\n \\tboundsSize.xy = params.maxBounds - params.minBounds;\\n \\tboundsSize.z = params.fallDistance;\\n \\n \\tfloat seed2 = 0.0;\\n \\n float3 initialOffset = boundsSize * float3(Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)));\\n \\n float3 velocity = float3(0.0, 0, -1.0) * lerp(params.minSpeed, params.maxSpeed, Rand(float2(seed, seed2++)));\\n \\n velocity.xy += params.windDirectionAndStrength;\\n \\n Raindrop drop;\\n drop.size = 0.003;\\n drop.position = initialOffset + (velocity * time);\\n \\n float wrapOffset;\\n drop.position.z = Wrap(drop.position.z, params.groundHeight, params.groundHeight + params.fallDistance, wrapOffset);\\n \\n\\tdrop.position.x += Rand(float2(wrapOffset, 0.0)) * (params.maxBounds.x - params.minBounds.x);\\n drop.position.x = Wrap(drop.position.x, params.minBounds.x, params.maxBounds.x);\\n drop.position.y += Rand(float2(wrapOffset, 1.0)) * (params.maxBounds.y - params.minBounds.y);\\n drop.position.y = Wrap(drop.position.y, params.minBounds.y, params.maxBounds.y);\\n \\n drop.velocity = velocity;\\n \\n return drop;\\n}\\n\\n#define TRIANGLES_PER_DROP 2.0\\nvoid RenderRaindrop(Raindrop drop, RainParams params, float triangle, float triVert, out float4 outPos, out float4 outColor)\\n{\\n // Super brute-force. Lets do something nicer later. \\n outPos.yz = float2(0.0, 0.0);\\n \\n float alpha = 0.4;\\n \\n if (triangle == 0.0)\\n {\\n if (triVert == 0.0)\\n {\\n outPos.xy = float2(-1.0, 0.0);\\n }\\n else if (triVert == 1.0)\\n {\\n outPos.xy = float2(1.0, 0.0);\\n }\\n else\\n {\\n outPos.xy = float2(0.0, -1.0);\\n }\\n }\\n else // triange == 1\\n {\\n if (triVert == 0.0)\\n {\\n outPos.xy = float2(-1.0, 0.0);\\n }\\n else if (triVert == 1.0)\\n {\\n outPos.xy = float2(1.0, 0.0);\\n }\\n else\\n {\\n alpha = 0.;\\n outPos.xy = float2(0.0, 150.0);\\n }\\n }\\n \\n outPos.xyz *= drop.size;\\n \\n outColor = float4(0.8, 0.9, 1.0, alpha);\\n outColor.rgb *= alpha;\\n \\n // Drop is currently in local space. Translate to world space\\n outPos.xyz *= drop.position.y;\\n \\n outPos.xyz += drop.position.xzy * drop.position.y; \\n}\\n\\nfloat GetLightningBrightness(float2 uv)\\n{\\n float2 lookupCoord = float2(0.0005, 0.0 + uv.x);\\n float sample = texture2D(sound, lookupCoord).a;\\n return pow(saturate((sample - 0.4) * 2.0), 6.0) * 5.0;\\n \\n}\\n\\n#define BACKGROUND_QUADS_X 20.0\\n#define BACKGROUND_QUADS_Y 20.0\\n#define TRIANGLES_FOR_BACKGROUND BACKGROUND_QUADS_X * BACKGROUND_QUADS_X * 2.0\\nvoid RenderBackground(float triangle, float triVert, out float4 outPos, out float4 outColor)\\n{\\n float quad = floor(triangle / 2.0);\\n float2 quadCoord = float2(\\n (mod(quad, BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_X,\\n (floor(quad / BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_Y\\n );\\n \\n float2 quadSize = float2(1.0 / BACKGROUND_QUADS_X, 1.0 / BACKGROUND_QUADS_Y);\\n \\n outPos.zw = float2(0.0, 1.0);\\n \\n \\n if (floor(mod(triangle, 2.0)) == 0.0)\\n {\\n if (triVert == 0.0)\\n outPos.xy = float2(0.0, 0.0);\\n else if (triVert == 1.0)\\n outPos.xy = float2(1.0, 0.0);\\n else\\n outPos.xy = float2(1.0, 1.0);\\n }\\n else\\n {\\n if (triVert == 0.0)\\n outPos.xy = float2(0.0, 0.0);\\n else if (triVert == 1.0)\\n outPos.xy = float2(0.0, 1.0);\\n else\\n outPos.xy = float2(1.0, 1.0);\\n }\\n \\n float2 uv = outPos.xy * quadSize - quadCoord;\\n outPos.xy = uv * 2.0 + 1.0;\\n \\n outColor.a = 0.0;\\n \\n float3 gradientTop = float3(130.0, 160.0, 220.0) / 255.0;\\n gradientTop *= gradientTop;\\n float3 gradientBottom = float3(15.0, 21.0, 53.0) / 255.0;\\n gradientBottom *= gradientBottom;\\n \\n float gradient = 1.0 - saturate(length(uv * float2(0.5, 1.0) + float2(0.25, 1.0)));\\n gradient *= gradient * gradient;\\n \\n float3 backgroundColor = lerp(gradientBottom, gradientTop, gradient);\\n \\n float thunder = GetLightningBrightness(uv);\\n outColor.rgb = backgroundColor + float3(thunder, thunder, thunder);\\n \\n}\\n\\n\\nvoid main()\\n{ \\n float triangleId = floor(vertexId / 3.0);\\n float vertIndex = floor(mod(vertexId, 3.0));\\n \\n float backgroundTriangleStart = vertexCount / 3.0 - TRIANGLES_FOR_BACKGROUND;\\n \\n if (triangleId >= backgroundTriangleStart)\\n {\\n RenderBackground(triangleId - backgroundTriangleStart, vertIndex, gl_Position, v_color);\\n }\\n else\\n {\\n float dropId = floor(triangleId / TRIANGLES_PER_DROP);\\n \\n RainParams params;\\n params.minSpeed = 8.1;\\n params.maxSpeed = 11.1;\\n params.groundHeight = -2.0;\\n params.fallDistance = 4.0;\\n params.minBounds = float2(-2.0, 0.3);\\n params.maxBounds = float2(2.0, 1.0);\\n params.windDirectionAndStrength = float2(0.0, 0.0);\\n \\n Raindrop drop = GenerateRaindrop(params, time, dropId);\\n \\n \\n gl_Position = float4(0.0, 0.0, 0.0, 1.0);\\n v_color = float4(1.0, 1.0, 1.0, 1.0);\\n \\n RenderRaindrop(drop, params, triangleId, vertIndex, gl_Position, v_color);\\n }\\n}\"}", + "settings": { + "num": 6362, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cosmomedia/thunderstorm-sounds-of-nature", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Defines to compile the HLSL code with GLSL\n#define float4 vec4\n#define float3 vec3\n#define float2 vec2\n#define float4x4 mat4\n#define float3x3 mat3\n#define mul(x, y) y * x\n#define lerp mix\n#define static\n#define saturate(x) clamp(x, 0.0, 1.0)\n\nfloat Rand(float2 seed)\n{\n return fract(sin(dot(seed.xy ,float2(12.9898,78.233))) * 43758.5453); \n}\n\nstruct RainParams\n{\n float minSpeed;\n\tfloat maxSpeed;\n float groundHeight;\n float fallDistance;\n float2 minBounds;\n float2 maxBounds;\n float2 windDirectionAndStrength;\n};\n\nstruct Raindrop\n{\n float size;\n float3 position;\n float3 velocity;\n};\n\nfloat Wrap(float value, float minimum, float maximum, out float offset)\n{\n float maxMinusMin = maximum - minimum;\n float valueMinusMin = value - minimum;\n offset = floor(valueMinusMin / maxMinusMin);\n return minimum + mod(valueMinusMin, maxMinusMin);\n}\n\nfloat Wrap(float value, float minimum, float maximum)\n{\n float dummy;\n return Wrap(value, minimum, maximum, dummy);\n}\n\nRaindrop GenerateRaindrop(RainParams params, float time, float seed)\n{\n \tfloat3 boundsSize;\n \tboundsSize.xy = params.maxBounds - params.minBounds;\n \tboundsSize.z = params.fallDistance;\n \n \tfloat seed2 = 0.0;\n \n float3 initialOffset = boundsSize * float3(Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)), Rand(float2(seed, seed2++)));\n \n float3 velocity = float3(0.0, 0, -1.0) * lerp(params.minSpeed, params.maxSpeed, Rand(float2(seed, seed2++)));\n \n velocity.xy += params.windDirectionAndStrength;\n \n Raindrop drop;\n drop.size = 0.003;\n drop.position = initialOffset + (velocity * time);\n \n float wrapOffset;\n drop.position.z = Wrap(drop.position.z, params.groundHeight, params.groundHeight + params.fallDistance, wrapOffset);\n \n\tdrop.position.x += Rand(float2(wrapOffset, 0.0)) * (params.maxBounds.x - params.minBounds.x);\n drop.position.x = Wrap(drop.position.x, params.minBounds.x, params.maxBounds.x);\n drop.position.y += Rand(float2(wrapOffset, 1.0)) * (params.maxBounds.y - params.minBounds.y);\n drop.position.y = Wrap(drop.position.y, params.minBounds.y, params.maxBounds.y);\n \n drop.velocity = velocity;\n \n return drop;\n}\n\n#define TRIANGLES_PER_DROP 2.0\nvoid RenderRaindrop(Raindrop drop, RainParams params, float triangle, float triVert, out float4 outPos, out float4 outColor)\n{\n // Super brute-force. Lets do something nicer later. \n outPos.yz = float2(0.0, 0.0);\n \n float alpha = 0.4;\n \n if (triangle == 0.0)\n {\n if (triVert == 0.0)\n {\n outPos.xy = float2(-1.0, 0.0);\n }\n else if (triVert == 1.0)\n {\n outPos.xy = float2(1.0, 0.0);\n }\n else\n {\n outPos.xy = float2(0.0, -1.0);\n }\n }\n else // triange == 1\n {\n if (triVert == 0.0)\n {\n outPos.xy = float2(-1.0, 0.0);\n }\n else if (triVert == 1.0)\n {\n outPos.xy = float2(1.0, 0.0);\n }\n else\n {\n alpha = 0.;\n outPos.xy = float2(0.0, 150.0);\n }\n }\n \n outPos.xyz *= drop.size;\n \n outColor = float4(0.8, 0.9, 1.0, alpha);\n outColor.rgb *= alpha;\n \n // Drop is currently in local space. Translate to world space\n outPos.xyz *= drop.position.y;\n \n outPos.xyz += drop.position.xzy * drop.position.y; \n}\n\nfloat GetLightningBrightness(float2 uv)\n{\n float2 lookupCoord = float2(0.0005, 0.0 + uv.x);\n float sample = texture2D(sound, lookupCoord).a;\n return pow(saturate((sample - 0.4) * 2.0), 6.0) * 5.0;\n \n}\n\n#define BACKGROUND_QUADS_X 20.0\n#define BACKGROUND_QUADS_Y 20.0\n#define TRIANGLES_FOR_BACKGROUND BACKGROUND_QUADS_X * BACKGROUND_QUADS_X * 2.0\nvoid RenderBackground(float triangle, float triVert, out float4 outPos, out float4 outColor)\n{\n float quad = floor(triangle / 2.0);\n float2 quadCoord = float2(\n (mod(quad, BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_X,\n (floor(quad / BACKGROUND_QUADS_X) + 1.0) / BACKGROUND_QUADS_Y\n );\n \n float2 quadSize = float2(1.0 / BACKGROUND_QUADS_X, 1.0 / BACKGROUND_QUADS_Y);\n \n outPos.zw = float2(0.0, 1.0);\n \n \n if (floor(mod(triangle, 2.0)) == 0.0)\n {\n if (triVert == 0.0)\n outPos.xy = float2(0.0, 0.0);\n else if (triVert == 1.0)\n outPos.xy = float2(1.0, 0.0);\n else\n outPos.xy = float2(1.0, 1.0);\n }\n else\n {\n if (triVert == 0.0)\n outPos.xy = float2(0.0, 0.0);\n else if (triVert == 1.0)\n outPos.xy = float2(0.0, 1.0);\n else\n outPos.xy = float2(1.0, 1.0);\n }\n \n float2 uv = outPos.xy * quadSize - quadCoord;\n outPos.xy = uv * 2.0 + 1.0;\n \n outColor.a = 0.0;\n \n float3 gradientTop = float3(130.0, 160.0, 220.0) / 255.0;\n gradientTop *= gradientTop;\n float3 gradientBottom = float3(15.0, 21.0, 53.0) / 255.0;\n gradientBottom *= gradientBottom;\n \n float gradient = 1.0 - saturate(length(uv * float2(0.5, 1.0) + float2(0.25, 1.0)));\n gradient *= gradient * gradient;\n \n float3 backgroundColor = lerp(gradientBottom, gradientTop, gradient);\n \n float thunder = GetLightningBrightness(uv);\n outColor.rgb = backgroundColor + float3(thunder, thunder, thunder);\n \n}\n\n\nvoid main()\n{ \n float triangleId = floor(vertexId / 3.0);\n float vertIndex = floor(mod(vertexId, 3.0));\n \n float backgroundTriangleStart = vertexCount / 3.0 - TRIANGLES_FOR_BACKGROUND;\n \n if (triangleId >= backgroundTriangleStart)\n {\n RenderBackground(triangleId - backgroundTriangleStart, vertIndex, gl_Position, v_color);\n }\n else\n {\n float dropId = floor(triangleId / TRIANGLES_PER_DROP);\n \n RainParams params;\n params.minSpeed = 8.1;\n params.maxSpeed = 11.1;\n params.groundHeight = -2.0;\n params.fallDistance = 4.0;\n params.minBounds = float2(-2.0, 0.3);\n params.maxBounds = float2(2.0, 1.0);\n params.windDirectionAndStrength = float2(0.0, 0.0);\n \n Raindrop drop = GenerateRaindrop(params, time, dropId);\n \n \n gl_Position = float4(0.0, 0.0, 0.0, 1.0);\n v_color = float4(1.0, 1.0, 1.0, 1.0);\n \n RenderRaindrop(drop, params, triangleId, vertIndex, gl_Position, v_color);\n }\n}" + }, "screenshotURL": "data/images/images-o4d8vpo616josegsr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fssfXPCEwPLZfQFqp/art.json b/art/fssfXPCEwPLZfQFqp/art.json index 3b51497e..c7bbdca6 100644 --- a/art/fssfXPCEwPLZfQFqp/art.json +++ b/art/fssfXPCEwPLZfQFqp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":36000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n 1., 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, 1., 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n sin(id * 0.5+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}\\n\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./50.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n cubep*= sizeFactor;\\n \\n \\n \\n \\n float off = 0.14;\\n float expand = 1.;\\n float curveFactor = time/20.;\\n vec3 r0 = getCurvePoint(shapeRelId + off * 0., curveFactor);\\n vec3 r1 = getCurvePoint(shapeRelId + off * 1., curveFactor);\\n vec3 r2 = getCurvePoint(shapeRelId + off * 2., curveFactor);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n cubep = (vec4(cubep,1.)*uniformScale(20.*snd)).xyz;\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n vec3 zax = vec3(0., 0., 1.);\\n \\n float dotz = dot(zax,zaxis);\\n float angle = acos(dot(zax,zaxis));\\n cubep = rotX(cubep.xyz, acos(dot(vec3(1., 0., 0.),xaxis)));\\n cubep = rotY(cubep.xyz, acos(dot(vec3(0., 1., 0.),yaxis)));\\n cubep = rotZ(cubep.xyz, acos(dot(vec3(0., 0., 1.),zaxis)));\\n \\n //cubep*= sizeFactor;//resize\\n //cubep.xyz*= (wmat*vec4(cubep,1.)).xyz;\\n \\n\\n //cubep+=r0;\\n cubep+= getCurvePoint(shapeId, curveFactor) ;\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n float aspect = resolution.y / resolution.x;\\n \\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n //gl_Position.x*=aspect;\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 36000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nmat4 uniformScale(float _s) {\n return mat4(\n 1., 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, 1., 0,\n 0, 0, 0, 1);\n}\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n sin(id * 0.5+_time*10.),\n sin(id * 0.25+_time*10.));\n}\n\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./50.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n cubep*= sizeFactor;\n \n \n \n \n float off = 0.14;\n float expand = 1.;\n float curveFactor = time/20.;\n vec3 r0 = getCurvePoint(shapeRelId + off * 0., curveFactor);\n vec3 r1 = getCurvePoint(shapeRelId + off * 1., curveFactor);\n vec3 r2 = getCurvePoint(shapeRelId + off * 2., curveFactor);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n cubep = (vec4(cubep,1.)*uniformScale(20.*snd)).xyz;\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n vec3 zax = vec3(0., 0., 1.);\n \n float dotz = dot(zax,zaxis);\n float angle = acos(dot(zax,zaxis));\n cubep = rotX(cubep.xyz, acos(dot(vec3(1., 0., 0.),xaxis)));\n cubep = rotY(cubep.xyz, acos(dot(vec3(0., 1., 0.),yaxis)));\n cubep = rotZ(cubep.xyz, acos(dot(vec3(0., 0., 1.),zaxis)));\n \n //cubep*= sizeFactor;//resize\n //cubep.xyz*= (wmat*vec4(cubep,1.)).xyz;\n \n\n //cubep+=r0;\n cubep+= getCurvePoint(shapeId, curveFactor) ;\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n float aspect = resolution.y / resolution.x;\n \n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n //gl_Position.x*=aspect;\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-yf49f1lbvr5pjbfsb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ftJv2CdwjJ5jJDa3k/art.json b/art/ftJv2CdwjJ5jJDa3k/art.json index dfdad1b1..9e782199 100644 --- a/art/ftJv2CdwjJ5jJDa3k/art.json +++ b/art/ftJv2CdwjJ5jJDa3k/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":33371,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/taeoxo/swimming-pool\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.06274509803921569,0.13725490196078433,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Circles from Triangles\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n \\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 33371, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/taeoxo/swimming-pool", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.06274509803921569, + 0.13725490196078433, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Circles from Triangles\n// Course Name: CS250\n// Term: Spring 2022\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n \n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-7j6w4fmd8ztzfvtpc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fvQTW8AHjW54ifFbh/art.json b/art/fvQTW8AHjW54ifFbh/art.json index 7a6ba3bf..a33a057c 100644 --- a/art/fvQTW8AHjW54ifFbh/art.json +++ b/art/fvQTW8AHjW54ifFbh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":23201,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/arkaodaberlin/benedikt-frey-b2b-philipp-otterbach-arkaoda-berlin-040120?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.18823529411764706,0.18823529411764706,0.18823529411764706,1],\"shader\":\"// _ _ _ _ \\n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \\n// \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__/ _` | '__| __|\\n// \\\\ V / __/ | | || __/> <\\\\__ \\\\ | | | (_| | (_| | __/ | | (_| | | | |_ \\n// \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\\\__,_|_| \\\\__|\\n//\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.75 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\\n \\n float across = 32.;\\n float down = 20.;\\n float u = mod(fCubeId, across) / across;\\n float v = floor(fCubeId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\\n \\n vCubeOrigin.z += pow(snd, 8.0) * 8.0;\\n float fScale = mix(0.1, 0.6, sin(lat)) * mix(0.7, 2.0, pow(snd, 8.0)) * snd;\\n \\n mat = ident();\\n \\tmat *= rotZ(lng);\\n \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= uniformScale(fScale);\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\\n \\n vCubeCol = mix(hsv2rgb(vec3(time + 0.5, 0., 0.2)) * pow(s2 + 0.25, 90.), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol = mix(vCubeCol, hsv2rgb(vec3(time * 1.,1,1)), step(0.8,s2));\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n mat4 mCube;\\n vec3 vCubeCol;\\n\\n GetCubePosition( fCubeId, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 23201, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/arkaodaberlin/benedikt-frey-b2b-philipp-otterbach-arkaoda-berlin-040120?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.18823529411764706, + 0.18823529411764706, + 0.18823529411764706, + 1 + ], + "shader": "// _ _ _ _ \n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \n// \\ \\ / / _ \\ '__| __/ _ \\ \\/ / __| '_ \\ / _` |/ _` |/ _ \\ '__/ _` | '__| __|\n// \\ V / __/ | | || __/> <\\__ \\ | | | (_| | (_| | __/ | | (_| | | | |_ \n// \\_/ \\___|_| \\__\\___/_/\\_\\___/_| |_|\\__,_|\\__,_|\\___|_| \\__,_|_| \\__|\n//\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.75 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\n \n float across = 32.;\n float down = 20.;\n float u = mod(fCubeId, across) / across;\n float v = floor(fCubeId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\n \n vCubeOrigin.z += pow(snd, 8.0) * 8.0;\n float fScale = mix(0.1, 0.6, sin(lat)) * mix(0.7, 2.0, pow(snd, 8.0)) * snd;\n \n mat = ident();\n \tmat *= rotZ(lng);\n \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= uniformScale(fScale);\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\n \n vCubeCol = mix(hsv2rgb(vec3(time + 0.5, 0., 0.2)) * pow(s2 + 0.25, 90.), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol = mix(vCubeCol, hsv2rgb(vec3(time * 1.,1,1)), step(0.8,s2));\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n mat4 mCube;\n vec3 vCubeCol;\n\n GetCubePosition( fCubeId, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-4vzyacke43e0hh5rn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fvQbw8FtZzmvQG4Wz/art.json b/art/fvQbw8FtZzmvQG4Wz/art.json index 6b07a8fc..f3c5ace7 100644 --- a/art/fvQbw8FtZzmvQG4Wz/art.json +++ b/art/fvQbw8FtZzmvQG4Wz/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n float aspect = resolution.x / resolution.y;\\n vec2 dim = floor(vec2(sqrt(vertexCount*aspect) ,sqrt(vertexCount/aspect)));\\n vec2 p = vec2(mod(vertexId, dim.x), mod(floor(vertexId/ dim.x),dim.y));\\n p /= dim;\\n p = p * 2.0 - 1.0;\\n gl_Position = vec4(p, 0.0, 1.0); \\n gl_PointSize=resolution.y / dim.y;\\n //p.x *= aspect;\\n vec3 col = texture2D(sound, p * 0.5 + 0.5).rgb;\\n v_color = vec4(col, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n float aspect = resolution.x / resolution.y;\n vec2 dim = floor(vec2(sqrt(vertexCount*aspect) ,sqrt(vertexCount/aspect)));\n vec2 p = vec2(mod(vertexId, dim.x), mod(floor(vertexId/ dim.x),dim.y));\n p /= dim;\n p = p * 2.0 - 1.0;\n gl_Position = vec4(p, 0.0, 1.0); \n gl_PointSize=resolution.y / dim.y;\n //p.x *= aspect;\n vec3 col = texture2D(sound, p * 0.5 + 0.5).rgb;\n v_color = vec4(col, 1.0);\n}" + }, "screenshotURL": "data/images/images-39o1j2yw3iwkq9h4i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fwuLjHMQenJtNXJxZ/art.json b/art/fwuLjHMQenJtNXJxZ/art.json index 4662296f..26fd3f08 100644 --- a/art/fwuLjHMQenJtNXJxZ/art.json +++ b/art/fwuLjHMQenJtNXJxZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n int vertID = int(vertexId);\\n \\n if (vertID == 0) {\\n \\tgl_Position = vec4(-0.025, -0.3, 0, 1); \\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(0.25, 0.3, 0, 1); \\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(0.0125, -0.3, 0, 1); \\n }\\n \\n \\n else if (vertID == 3) {\\n \\tgl_Position = vec4(-0.025, 0.3, 0, 1); \\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(0.25, 0.3, 0, 1); \\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(-0.025, -0.3, 0, 1); \\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 1, 1, 1);\\n }\\n else {\\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n int vertID = int(vertexId);\n \n if (vertID == 0) {\n \tgl_Position = vec4(-0.025, -0.3, 0, 1); \n }\n else if (vertID == 1) {\n \tgl_Position = vec4(0.25, 0.3, 0, 1); \n }\n else if (vertID == 2) {\n \tgl_Position = vec4(0.0125, -0.3, 0, 1); \n }\n \n \n else if (vertID == 3) {\n \tgl_Position = vec4(-0.025, 0.3, 0, 1); \n }\n else if (vertID == 4) {\n \tgl_Position = vec4(0.25, 0.3, 0, 1); \n }\n else if (vertID == 5) {\n \tgl_Position = vec4(-0.025, -0.3, 0, 1); \n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 1, 1, 1);\n }\n else {\n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-w1yxuppkkuajbilto-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/fxYFNf9d36E5GgBen/art.json b/art/fxYFNf9d36E5GgBen/art.json index 746e37d4..62d28957 100644 --- a/art/fxYFNf9d36E5GgBen/art.json +++ b/art/fxYFNf9d36E5GgBen/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":2000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\nconst float off = 0.1;\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, vec3 _cubep) {\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 19.; // good place to adjust\\n float base = time * 1.0;\\n\\n //const float off = 0.1;\\n \\n vec3 b0 = getCurvePoint(base + off * 0.);\\n vec3 b1 = getCurvePoint(base + off * 1.);\\n vec3 b2 = getCurvePoint(base + off * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 eye = b0 * expand + czaxis * 1.;\\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 target = b1 * expand + czaxis;\\n vec3 up = cyaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n \\n \\n //\\n float sizeFactor = 1./10.;\\n \\n float shapeCount = floor(vertexCount / 36.);\\n float shapeId = floor(vertexId / 36.);\\n float shapeVertexId = mod(vertexId, 36.);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n //cubep*= sizeFactor;\\n mat4 scaleMat = scale(vec3(sizeFactor,30.*sizeFactor,sizeFactor));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n vec3 pos;\\n vec4 color;\\n \\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n //base+= mod(time,2.);\\n mat4 wmat;\\n track(shapeId, shapeCount, base, pos, color, wmat, cubep);\\n //\\n //mat4 matCubeLookAt = lookAt(eye, target, up);\\n \\n /*\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n*/\\n mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n cubep = (vec4(cubep.xyz,1.)*wmat).xyz;\\n //float rotx = atan( wmat.y, wmat.z );\\n //float roty = Math.atan2( x * Math.cos(rotx), z )\\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \\n \\n cubep+= posi;\\n \\n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 2000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\nconst float off = 0.1;\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, vec3 _cubep) {\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 19.; // good place to adjust\n float base = time * 1.0;\n\n //const float off = 0.1;\n \n vec3 b0 = getCurvePoint(base + off * 0.);\n vec3 b1 = getCurvePoint(base + off * 1.);\n vec3 b2 = getCurvePoint(base + off * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 eye = b0 * expand + czaxis * 1.;\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 target = b1 * expand + czaxis;\n vec3 up = cyaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n \n \n //\n float sizeFactor = 1./10.;\n \n float shapeCount = floor(vertexCount / 36.);\n float shapeId = floor(vertexId / 36.);\n float shapeVertexId = mod(vertexId, 36.);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n //cubep*= sizeFactor;\n mat4 scaleMat = scale(vec3(sizeFactor,30.*sizeFactor,sizeFactor));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n vec3 pos;\n vec4 color;\n \n \n //shapeId = mod(shapeId+time, shapeCount);\n //base+= mod(time,2.);\n mat4 wmat;\n track(shapeId, shapeCount, base, pos, color, wmat, cubep);\n //\n //mat4 matCubeLookAt = lookAt(eye, target, up);\n \n /*\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n*/\n mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n cubep = (vec4(cubep.xyz,1.)*wmat).xyz;\n //float rotx = atan( wmat.y, wmat.z );\n //float roty = Math.atan2( x * Math.cos(rotx), z )\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \n \n cubep+= posi;\n \n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-xe5u6n0qq4bbdso1x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fxwcEhippPALwji4k/art.json b/art/fxwcEhippPALwji4k/art.json index dab93a8b..d5f83a47 100644 --- a/art/fxwcEhippPALwji4k/art.json +++ b/art/fxwcEhippPALwji4k/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "優斗", "avatarUrl": "https://lh6.googleusercontent.com/-7lDk3Xe1fns/AAAAAAAAAAI/AAAAAAAAxfY/U4fHGcEU_pQ/photo.jpg", - "settings": "{\"num\":200,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/blondish/should-be-higher-blondish-remix-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.15294117647058825,0.15294117647058825,0.15294117647058825,1],\"shader\":\"#define PI radians(90.0)\\n#define NUM_SEGMENTS 50.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 3.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n gl_PointSize = resolution.x / 40.0 ;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS) * time;\\n float count = floor(vertexId / NUM_POINTS) + sin(-time);\\n float offset = count * .0002;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float r2 = sin(orbitAngle);\\n float oC = cos(orbitAngle + time * count * 0.01) * r2;\\n float oS = sin(orbitAngle + time * count * 0.01) * r2;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n\\n float dd = length(xy);\\n float snd = pow(texture2D(sound, vec2(fract(count * 0.01) * 0.125, dd * 0.1)).a, .1);\\n \\n xy = xy + xy * snd ;\\n gl_Position = vec4(xy * aspect + mouse * 0.1, -fract(count * 10. * time), 1);\\n \\n float hue = (time * 0.01 + count);\\n v_color = vec4(mix(hsv2rgb(vec3(hue + snd, 1, 1)), vec3(1,1,1), snd), 0.1 + snd * 0.5);\\n v_color = vec4(v_color.rgb + abs(sin(time) * cos(time)) + abs(dot(cos(time), sin(time))) * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 200, + "mode": "LINES", + "sound": "https://soundcloud.com/blondish/should-be-higher-blondish-remix-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0.15294117647058825, + 0.15294117647058825, + 0.15294117647058825, + 1 + ], + "shader": "#define PI radians(90.0)\n#define NUM_SEGMENTS 50.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 3.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n gl_PointSize = resolution.x / 40.0 ;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS) * time;\n float count = floor(vertexId / NUM_POINTS) + sin(-time);\n float offset = count * .0002;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float r2 = sin(orbitAngle);\n float oC = cos(orbitAngle + time * count * 0.01) * r2;\n float oS = sin(orbitAngle + time * count * 0.01) * r2;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n\n float dd = length(xy);\n float snd = pow(texture2D(sound, vec2(fract(count * 0.01) * 0.125, dd * 0.1)).a, .1);\n \n xy = xy + xy * snd ;\n gl_Position = vec4(xy * aspect + mouse * 0.1, -fract(count * 10. * time), 1);\n \n float hue = (time * 0.01 + count);\n v_color = vec4(mix(hsv2rgb(vec3(hue + snd, 1, 1)), vec3(1,1,1), snd), 0.1 + snd * 0.5);\n v_color = vec4(v_color.rgb + abs(sin(time) * cos(time)) + abs(dot(cos(time), sin(time))) * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-s39mnpzvehrw0b53p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/fytzNu7M5YR27TpEP/art.json b/art/fytzNu7M5YR27TpEP/art.json index 7e0d62c3..6c1cf948 100644 --- a/art/fytzNu7M5YR27TpEP/art.json +++ b/art/fytzNu7M5YR27TpEP/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "gitanely", "avatarUrl": "https://secure.gravatar.com/avatar/d5fdfe8b65ebd7057053c353e059209a?default=retro&size=200", - "settings": "{\"num\":5283,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\n\\n\\n\\nvoid main() {\\n vec2 scr = vec2(\\n \\t\\t vertexId / vertexCount * 2.0,\\n \\t\\t\\t vertexId / vertexCount * 2.0);\\n \\n \\n gl_Position.x = cos(time * scr.x) * scr.x;\\n gl_Position.y = sin(time * scr.y) * scr.y * 0.5;\\n gl_Position.y = (gl_Position.y);\\n gl_Position.z = 0.;\\n \\n \\n \\n\\n gl_Position.w = 1.; \\n gl_PointSize =2.5;\\n\\n v_color.xyz = hsv2rgb(vec3(time + scr.x * 0.1,1,1));\\n\\n\\n}\"}", + "settings": { + "num": 5283, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\n\n\n\nvoid main() {\n vec2 scr = vec2(\n \t\t vertexId / vertexCount * 2.0,\n \t\t\t vertexId / vertexCount * 2.0);\n \n \n gl_Position.x = cos(time * scr.x) * scr.x;\n gl_Position.y = sin(time * scr.y) * scr.y * 0.5;\n gl_Position.y = (gl_Position.y);\n gl_Position.z = 0.;\n \n \n \n\n gl_Position.w = 1.; \n gl_PointSize =2.5;\n\n v_color.xyz = hsv2rgb(vec3(time + scr.x * 0.1,1,1));\n\n\n}" + }, "screenshotURL": "data/images/images-ygwt15bggedjyp6j9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/g2PZWgGp6YYe9CWwE/art.json b/art/g2PZWgGp6YYe9CWwE/art.json index e460eded..b33037ba 100644 --- a/art/g2PZWgGp6YYe9CWwE/art.json +++ b/art/g2PZWgGp6YYe9CWwE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/funkn-deep/dimi-mechero-mind-construction-john-norman-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6274509803921569,0.8901960784313725,0.9254901960784314,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.1)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 0.0 + pow(snd, 5.) * 30.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 4.);\\n mat *= rotY(p1m1(snd) * 4.);\\n mat *= uniformScale(mix(0.1,4., hash(fCubeId * 0.519)));\\n \\n \\tvec3 vRandCol;\\n\\n vCubeCol.rgb = vec3(pow(snd, 3.) * 4.5);//fract( snd + hash(vertexId * 0.917)));\\n float emf = step(0.99, snd) * floor(mod(time * 60., 2.));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-1001), emf);\\n vCubeCol.a = 0.;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 80., sin(time * 0.03) * 40., cos(time * 0.1) * 60.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/funkn-deep/dimi-mechero-mind-construction-john-norman-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6274509803921569, + 0.8901960784313725, + 0.9254901960784314, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.1)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 0.0 + pow(snd, 5.) * 30.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 4.);\n mat *= rotY(p1m1(snd) * 4.);\n mat *= uniformScale(mix(0.1,4., hash(fCubeId * 0.519)));\n \n \tvec3 vRandCol;\n\n vCubeCol.rgb = vec3(pow(snd, 3.) * 4.5);//fract( snd + hash(vertexId * 0.917)));\n float emf = step(0.99, snd) * floor(mod(time * 60., 2.));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-1001), emf);\n vCubeCol.a = 0.;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 80., sin(time * 0.03) * 40., cos(time * 0.1) * 60.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-3hvvuihdy67268s52-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/g4ZutuWewAGLeBJHx/art.json b/art/g4ZutuWewAGLeBJHx/art.json index 34cc1aed..f7303bbe 100644 --- a/art/g4ZutuWewAGLeBJHx/art.json +++ b/art/g4ZutuWewAGLeBJHx/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 30.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 30.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-qbp66cgorcutxe7ok-thumbnail.jpg", "views": { "$numberInt": "57" diff --git a/art/g5Ygw3eYNe7DzpA3a/art.json b/art/g5Ygw3eYNe7DzpA3a/art.json index 8af62a54..fded821b 100644 --- a/art/g5Ygw3eYNe7DzpA3a/art.json +++ b/art/g5Ygw3eYNe7DzpA3a/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.15294117647058825,0.12941176470588237,0.43529411764705883,1],\"shader\":\"void main() {\\n float down= floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n \\n \\n gl_Position = vec4(2.*u-1.,2.*v-1.,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize*=20./across;\\n gl_PointSize*=resolution.x/600.;\\n \\n v_color = vec4(1,0,0,1)\\n\\n} \"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.15294117647058825, + 0.12941176470588237, + 0.43529411764705883, + 1 + ], + "shader": "void main() {\n float down= floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n float u = x/(across-1.);\n float v = y/(across-1.);\n \n \n \n gl_Position = vec4(2.*u-1.,2.*v-1.,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize*=20./across;\n gl_PointSize*=resolution.x/600.;\n \n v_color = vec4(1,0,0,1)\n\n} " + }, "screenshotURL": "data/images/images-2tnc3kn4efn9m8b2d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/g79cZoGhWhgn9tKfr/art.json b/art/g79cZoGhWhgn9tKfr/art.json index 2d5b2b43..e6716df7 100644 --- a/art/g79cZoGhWhgn9tKfr/art.json +++ b/art/g79cZoGhWhgn9tKfr/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jshaw", "avatarUrl": "https://avatars.githubusercontent.com/jshaw?s=200", - "settings": "{\"num\":68199,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9529411764705882,0.7137254901960784,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(crv(a0), crv(a1), 0);\\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\\n// return vec3(\\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n// 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 3000.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float qn = quadId / quadCount;\\n float ln = lineId / numLines;\\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.0, 0.1, pn))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.02, 0.12, pn))).a;\\n \\n snd0 = 0.6;\\n snd1 = 0.7;\\n// snd1 = snd0;\\n \\n float mult = .002;\\n getQuadPoint(\\n //pn + time * 0.5 + ln * .2, \\n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\\n mult,\\n pointId, \\n pow(snd0, 5.0) * 0.25, \\n vec2(\\n pow(snd0, 2.), \\n pow(snd1, 2.)), \\n pos, \\n uv); \\n \\n float across = floor(sqrt(numLines));\\n float down = floor(numLines / across);\\n float xx = mod(lineId, across);\\n float yy = floor(lineId / across);\\n float ux = xx / (across - 1.);\\n float vy = yy / (down - 1.);\\n \\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .15);\\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\\n gl_Position.xyz /= gl_Position.w;\\n gl_Position.z = -pn;\\n gl_Position.w = 1.;\\n\\n float hue = mix(0.95, 1.5, ln * 0.3 + qn * 00.) + time * 0.01;\\n float sat = 1. + sin(time) * .5;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pn);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n // v_color.a = 1.;\\n}\"}", + "settings": { + "num": 68199, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9529411764705882, + 0.7137254901960784, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(crv(a0), crv(a1), 0);\n return vec3(crv(a0), crv(a1), crv(a0 + a1 * 0.134));\n// return vec3(\n// (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n// (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n// 0);\n}\n\nvoid getQuadPoint(const float quadId, const float mult, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + mult * 0., seed);\n vec3 p1 = getCenterPoint(quadId + mult * 1., seed);\n vec3 p2 = getCenterPoint(quadId + mult * 2., seed);\n vec3 p3 = getCenterPoint(quadId + mult * 3., seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 3000.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float qn = quadId / quadCount;\n float ln = lineId / numLines;\n float pn = (quadId + mod(pointId, 2.)) / quadCount;\n float snd0 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.0, 0.1, pn))).a;\n float snd1 = texture2D(sound, vec2(mix(0.1, 0.3, ln), mix(0.02, 0.12, pn))).a;\n \n snd0 = 0.6;\n snd1 = 0.7;\n// snd1 = snd0;\n \n float mult = .002;\n getQuadPoint(\n //pn + time * 0.5 + ln * .2, \n (quadId + mod(pointId, 2.)) * mult + time * 0.1 + ln * .42,\n mult,\n pointId, \n pow(snd0, 5.0) * 0.25, \n vec2(\n pow(snd0, 2.), \n pow(snd1, 2.)), \n pos, \n uv); \n \n float across = floor(sqrt(numLines));\n float down = floor(numLines / across);\n float xx = mod(lineId, across);\n float yy = floor(lineId / across);\n float ux = xx / (across - 1.);\n float vy = yy / (down - 1.);\n \n float aspect = resolution.x / resolution.y;\n \n mat4 mat = scale(vec3(1, aspect, 1) * .15);\n mat *= trans((vec3(ux, vy, 0) * 2. - 1.) * 2.);\n gl_Position = mat * vec4((pos * 2. - 1.) * mix(5., 15., sin(time * 0.1 + qn) * .5 + .5), 1);\n gl_Position.xyz /= gl_Position.w;\n gl_Position.z = -pn;\n gl_Position.w = 1.;\n\n float hue = mix(0.95, 1.5, ln * 0.3 + qn * 00.) + time * 0.01;\n float sat = 1. + sin(time) * .5;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pn);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n // v_color.a = 1.;\n}" + }, "screenshotURL": "data/images/images-vuyrrf64jx9es77e5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/g7wWJ4yKzThxqkmN5/art.json b/art/g7wWJ4yKzThxqkmN5/art.json index fb5cdcf9..a2869a84 100644 --- a/art/g7wWJ4yKzThxqkmN5/art.json +++ b/art/g7wWJ4yKzThxqkmN5/art.json @@ -11,7 +11,19 @@ "origId": "YSzcySDB7rcbwJmTP", "name": "mfx01", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.5019607843137255,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 7.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = PI * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.5019607843137255, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 7.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = PI * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ke4somqga045rjket-thumbnail.jpg", "views": { "$numberInt": "89" diff --git a/art/gAsFJCDiWiyemHoSX/art.json b/art/gAsFJCDiWiyemHoSX/art.json index 41b68be0..2d0c160f 100644 --- a/art/gAsFJCDiWiyemHoSX/art.json +++ b/art/gAsFJCDiWiyemHoSX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "タケシ", "avatarUrl": "https://lh3.googleusercontent.com/-DscYffOX92k/AAAAAAAAAAI/AAAAAAAAABA/PNB3e9i2cJM/photo.jpg", - "settings": "{\"num\":652,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/therhythmrights/dj-seven-dnb-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nvec3 rotate(vec3 p, float angle, vec3 axis){\\n vec3 a = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float r = 1.0 - c;\\n mat3 m = mat3(\\n a.x * a.x * r + c,\\n a.y * a.x * r + a.z * s,\\n a.z * a.x * r - a.y * s,\\n a.x * a.y * r - a.z * s,\\n a.y * a.y * r + c,\\n a.z * a.y * r + a.x * s,\\n a.x * a.z * r + a.y * s,\\n a.y * a.z * r - a.x * s,\\n a.z * a.z * r + c\\n );\\n \\n return m * p;\\n}\\n\\nvec3 Hue( float hue )\\n{\\n\\tvec3 rgb = fract(hue + vec3(0.0,2.0/3.0,1.0/3.0));\\n\\n\\trgb = abs(rgb*2.0-1.0);\\n\\t\\t\\n\\treturn clamp(rgb*3.0-1.0,0.0,1.0);\\n}\\n\\nvec3 HSVtoRGB( vec3 hsv )\\n{\\n\\treturn ((Hue(hsv.x)-1.0)*hsv.y+1.0) * hsv.z;\\n}\\n\\nvoid main() {\\n //float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n //float count = floor(vertexId / NUM_POINTS);\\n float id= vertexId;\\n float sound=texture2D(sound,vec2(1.*0.015,id/vertexCount*0.2)).a;\\nfloat r=cos(1.57*id/vertexCount)*sin(3.14*id/vertexCount)*1.5+0.0*pow(sound,5.);\\n float x=r*cos(id*0.1);\\n float y=r*sin(id*0.1);\\n float z=sin(1.57*id/vertexCount)*2.0;\\n vec2 xy=vec2(x,y);\\n vec3 rpos=rotate(vec3(x+0.1,y+0.1,z-0.5), 1.*time, vec3(1,1.,0.5));\\n\\n \\n rpos.z=0.;\\n// float sound=texture2D(sound,vec2(1.*0.015,id/vertexCount*0.9)).a; \\n gl_Position = vec4(rpos, 1);\\ngl_PointSize=70.*pow(sound,10.)-6.;\\n\\n v_color = vec4(1, sound, 0, 1);\\n v_color = vec4(HSVtoRGB(vec3(pow(sound-0.1,1.8),1.,4.-pow(z,2.))), 1);\\n \\n \\n}\"}", + "settings": { + "num": 652, + "mode": "POINTS", + "sound": "https://soundcloud.com/therhythmrights/dj-seven-dnb-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nvec3 rotate(vec3 p, float angle, vec3 axis){\n vec3 a = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float r = 1.0 - c;\n mat3 m = mat3(\n a.x * a.x * r + c,\n a.y * a.x * r + a.z * s,\n a.z * a.x * r - a.y * s,\n a.x * a.y * r - a.z * s,\n a.y * a.y * r + c,\n a.z * a.y * r + a.x * s,\n a.x * a.z * r + a.y * s,\n a.y * a.z * r - a.x * s,\n a.z * a.z * r + c\n );\n \n return m * p;\n}\n\nvec3 Hue( float hue )\n{\n\tvec3 rgb = fract(hue + vec3(0.0,2.0/3.0,1.0/3.0));\n\n\trgb = abs(rgb*2.0-1.0);\n\t\t\n\treturn clamp(rgb*3.0-1.0,0.0,1.0);\n}\n\nvec3 HSVtoRGB( vec3 hsv )\n{\n\treturn ((Hue(hsv.x)-1.0)*hsv.y+1.0) * hsv.z;\n}\n\nvoid main() {\n //float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n //float count = floor(vertexId / NUM_POINTS);\n float id= vertexId;\n float sound=texture2D(sound,vec2(1.*0.015,id/vertexCount*0.2)).a;\nfloat r=cos(1.57*id/vertexCount)*sin(3.14*id/vertexCount)*1.5+0.0*pow(sound,5.);\n float x=r*cos(id*0.1);\n float y=r*sin(id*0.1);\n float z=sin(1.57*id/vertexCount)*2.0;\n vec2 xy=vec2(x,y);\n vec3 rpos=rotate(vec3(x+0.1,y+0.1,z-0.5), 1.*time, vec3(1,1.,0.5));\n\n \n rpos.z=0.;\n// float sound=texture2D(sound,vec2(1.*0.015,id/vertexCount*0.9)).a; \n gl_Position = vec4(rpos, 1);\ngl_PointSize=70.*pow(sound,10.)-6.;\n\n v_color = vec4(1, sound, 0, 1);\n v_color = vec4(HSVtoRGB(vec3(pow(sound-0.1,1.8),1.,4.-pow(z,2.))), 1);\n \n \n}" + }, "screenshotURL": "data/images/images-1k01oje19eb4e2jzy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gAx4XYrQhtffjGR2v/art.json b/art/gAx4XYrQhtffjGR2v/art.json index ca0d769e..29e23a37 100644 --- a/art/gAx4XYrQhtffjGR2v/art.json +++ b/art/gAx4XYrQhtffjGR2v/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n\\tgl_Position = vec4(0, 0, 0 ,1);\\n\\tgl_PointSize = 10.0;\\n\\tv_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n\tgl_Position = vec4(0, 0, 0 ,1);\n\tgl_PointSize = 10.0;\n\tv_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-0com9xajg9jk73sje-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gBa8KAJTb6MqbNzBK/art.json b/art/gBa8KAJTb6MqbNzBK/art.json index 3fae5aa3..a7a37cdc 100644 --- a/art/gBa8KAJTb6MqbNzBK/art.json +++ b/art/gBa8KAJTb6MqbNzBK/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":807,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float w = sqrt(vertexCount);\\n float h = 10.;\\n float x = mod(vertexId, w);\\n float y = floor(vertexId/h);\\n float u = x/(w-1.);\\n float v = y/(h-1.);\\n float ux = u*2.-1.;\\n float vy = v*2.-1.;\\n gl_Position = vec4(ux,vy,0.,1.);\\n gl_PointSize = 10.;\\n v_color = vec4(1.);\\n}\\n\\n/*\\nvoid main(){\\n float w = sqrt(vertexCount);\\n float h = 10.;\\n float x = mod(vertexId, w);\\n float y = floor(vertexId/h);\\n float u = x/(w-1.);\\n float v = y/(h-1.);\\n float ux = u*2.-1.;\\n float vy = v*2.-1.;\\n gl_Position = vec4(ux,vy,0.,1.);\\n gl_PointSize = 10.;\\n v_color = vec4(1.);\\n}\\n*/\"}", + "settings": { + "num": 807, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float w = sqrt(vertexCount);\n float h = 10.;\n float x = mod(vertexId, w);\n float y = floor(vertexId/h);\n float u = x/(w-1.);\n float v = y/(h-1.);\n float ux = u*2.-1.;\n float vy = v*2.-1.;\n gl_Position = vec4(ux,vy,0.,1.);\n gl_PointSize = 10.;\n v_color = vec4(1.);\n}\n\n/*\nvoid main(){\n float w = sqrt(vertexCount);\n float h = 10.;\n float x = mod(vertexId, w);\n float y = floor(vertexId/h);\n float u = x/(w-1.);\n float v = y/(h-1.);\n float ux = u*2.-1.;\n float vy = v*2.-1.;\n gl_Position = vec4(ux,vy,0.,1.);\n gl_PointSize = 10.;\n v_color = vec4(1.);\n}\n*/" + }, "screenshotURL": "data/images/images-93ihkkp2cq0johsc9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gBqWsGGvjPsKNMGja/art.json b/art/gBqWsGGvjPsKNMGja/art.json index 94e94409..d9f15e27 100644 --- a/art/gBqWsGGvjPsKNMGja/art.json +++ b/art/gBqWsGGvjPsKNMGja/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "pgan", "avatarUrl": "https://secure.gravatar.com/avatar/b786c3cea88eff238ced38e7ee896997?default=retro&size=200", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//#define CUBES_PER_ROW 20.0\\n#define CUBES_PER_ROW 20.0\\n//#define CUBE_SPACING 0.05\\n#define CUBE_SPACING 0.075\\n\\nfloat rotr3(float x, float n) {\\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.0);\\n}\\n\\nvec3 cubePos(float x) {\\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n float near = -1.0;\\n float far = 0.99;\\n \\n float aspectRatio = resolution.y / resolution.x;\\n \\n float cubeIdx = floor(vertexId / 36.0);\\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\\n float faceDiv3 = floor(faceIdx / 3.0);\\n float faceMod3 = mod(faceIdx, 3.0);\\n float quadIdx = mod(vertexId, 6.0);\\n float baseIdx = faceIdx * 6.0;\\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\\n \\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\\n pos -= 0.5;\\n pos *= 0.02;\\n \\n float ct = time + mod(cubeIdx, CUBES_PER_ROW);\\n float ct1 = time + floor(cubeIdx / CUBES_PER_ROW);\\n \\n float s = sin(ct*0.37), c = cos(ct*0.37);\\n float s1 = sin(ct1), c1 = cos(ct1);\\n \\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), \\n vec4(-s, c, 0.0, 0.0), \\n vec4(0.0, 0.0, 1.0, 0.0), \\n vec4(0.0, 0.0, 0.0, 1.0));\\n \\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), \\n vec4(0.0, 1.0, 0.0, 0.0), \\n vec4(-s1, 0.0, c1, 0.0), \\n vec4(0.0, 0.0, 0.0, 1.0));\\n \\n gl_Position = vec4(pos, 1.0) * rot * rot2;\\n // gl_Position = vec4(pos, 1.0) * rot2;\\n\\n // gl_Position.x += (mod(cubeIdx, CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (1.0/CUBES_PER_ROW);\\n // gl_Position.y += (floor(cubeIdx / CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (1.0/CUBES_PER_ROW);\\n gl_Position.x += (mod(cubeIdx, CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (CUBE_SPACING);\\n gl_Position.y += (floor(cubeIdx / CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (CUBE_SPACING);\\n \\n gl_Position.y /= aspectRatio;\\n float zDist = gl_Position.z - near;\\n gl_Position.w = zDist;\\n\\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\\n}\\n\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//#define CUBES_PER_ROW 20.0\n#define CUBES_PER_ROW 20.0\n//#define CUBE_SPACING 0.05\n#define CUBE_SPACING 0.075\n\nfloat rotr3(float x, float n) {\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.0);\n}\n\nvec3 cubePos(float x) {\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n float near = -1.0;\n float far = 0.99;\n \n float aspectRatio = resolution.y / resolution.x;\n \n float cubeIdx = floor(vertexId / 36.0);\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\n float faceDiv3 = floor(faceIdx / 3.0);\n float faceMod3 = mod(faceIdx, 3.0);\n float quadIdx = mod(vertexId, 6.0);\n float baseIdx = faceIdx * 6.0;\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\n \n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\n pos -= 0.5;\n pos *= 0.02;\n \n float ct = time + mod(cubeIdx, CUBES_PER_ROW);\n float ct1 = time + floor(cubeIdx / CUBES_PER_ROW);\n \n float s = sin(ct*0.37), c = cos(ct*0.37);\n float s1 = sin(ct1), c1 = cos(ct1);\n \n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), \n vec4(-s, c, 0.0, 0.0), \n vec4(0.0, 0.0, 1.0, 0.0), \n vec4(0.0, 0.0, 0.0, 1.0));\n \n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), \n vec4(0.0, 1.0, 0.0, 0.0), \n vec4(-s1, 0.0, c1, 0.0), \n vec4(0.0, 0.0, 0.0, 1.0));\n \n gl_Position = vec4(pos, 1.0) * rot * rot2;\n // gl_Position = vec4(pos, 1.0) * rot2;\n\n // gl_Position.x += (mod(cubeIdx, CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (1.0/CUBES_PER_ROW);\n // gl_Position.y += (floor(cubeIdx / CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (1.0/CUBES_PER_ROW);\n gl_Position.x += (mod(cubeIdx, CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (CUBE_SPACING);\n gl_Position.y += (floor(cubeIdx / CUBES_PER_ROW) - CUBES_PER_ROW/2.0) * (CUBE_SPACING);\n \n gl_Position.y /= aspectRatio;\n float zDist = gl_Position.z - near;\n gl_Position.w = zDist;\n\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-o54j3rsd4jrr5e2wb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gCLHvWrWsPsbDjksh/art.json b/art/gCLHvWrWsPsbDjksh/art.json index b3ae603c..bf1b0848 100644 --- a/art/gCLHvWrWsPsbDjksh/art.json +++ b/art/gCLHvWrWsPsbDjksh/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sean", "avatarUrl": "https://lh4.googleusercontent.com/-2XVr7oP52uM/AAAAAAAAAAI/AAAAAAAAF8w/OxC5EHp2Xvk/photo.jpg", - "settings": "{\"num\":84926,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvec3 getUnitVector(vec3 a) {\\n\\treturn a / length(a);\\n}\\n\\nfloat round(float a) {\\n\\treturn floor(a + 0.5);\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 14.;\\n float across = 14.;\\n float back = 14.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float cz = floor(cubeId / across / back);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (back - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n float cc = cw * 2. - 1.;\\n \\n \\n float tm = time*0.1;\\n float tm1 = time;\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n \\n vec3 eye = vec3(30,40,4);\\n eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float s1 = abs(ca);\\n float s2 = abs(cb);\\n float s3 = abs(cc);\\n \\n float fac = s3+s1+s2;\\n vec3 dir = getUnitVector(vec3(ca,cc,cb));\\n vec3 card = vec3(round(dir.x), round(dir.y), round(dir.z));\\n vec3 sc = (abs(card)+1.0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= uniformScale(0.75);\\n \\n mat *= trans(dir*(sin(time)+.7)*fac);\\n mat *= trans(vec3(ca, cc, cb) * down * 0.65);\\n //mat *= scale(sc);\\n \\n\\n gl_Position = mat * vec4(pos, 1);\\n \\n \\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n float hue = 0.;\\n float sat = 1.;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 84926, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvec3 getUnitVector(vec3 a) {\n\treturn a / length(a);\n}\n\nfloat round(float a) {\n\treturn floor(a + 0.5);\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 14.;\n float across = 14.;\n float back = 14.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float cz = floor(cubeId / across / back);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (back - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n float cc = cw * 2. - 1.;\n \n \n float tm = time*0.1;\n float tm1 = time;\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n \n vec3 eye = vec3(30,40,4);\n eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float s1 = abs(ca);\n float s2 = abs(cb);\n float s3 = abs(cc);\n \n float fac = s3+s1+s2;\n vec3 dir = getUnitVector(vec3(ca,cc,cb));\n vec3 card = vec3(round(dir.x), round(dir.y), round(dir.z));\n vec3 sc = (abs(card)+1.0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= uniformScale(0.75);\n \n mat *= trans(dir*(sin(time)+.7)*fac);\n mat *= trans(vec3(ca, cc, cb) * down * 0.65);\n //mat *= scale(sc);\n \n\n gl_Position = mat * vec4(pos, 1);\n \n \n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n float hue = 0.;\n float sat = 1.;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-ma64oacrch02gmbod-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gDfmqnLHBbcKghmwL/art.json b/art/gDfmqnLHBbcKghmwL/art.json index e38b5213..ac808f68 100644 --- a/art/gDfmqnLHBbcKghmwL/art.json +++ b/art/gDfmqnLHBbcKghmwL/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\\n vec4 K = vec4(1.0, 2.5 / 1.0, 1.0 / 3.0, (parameter5 - 3.0 * parameter1));\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians -parameter2);\\n \\t\\n return mat4( \\n 1, 0, 0, parameter2,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, parameter6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians- parameter3);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n parameter6, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, (2. - parameter4));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1. / parameter3,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1 + parameter3 / 2.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/illusionize-shapeless-time-feature084", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\n vec4 K = vec4(1.0, 2.5 / 1.0, 1.0 / 3.0, (parameter5 - 3.0 * parameter1));\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians -parameter2);\n \t\n return mat4( \n 1, 0, 0, parameter2,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, parameter6, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians- parameter3);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n parameter6, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, (2. - parameter4));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1. / parameter3,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1 + parameter3 / 2.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-iw5rxllvfgxl9wdzh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gEkij9HTZTy6b4tRf/art.json b/art/gEkij9HTZTy6b4tRf/art.json index 7a8d30c1..75dbc138 100644 --- a/art/gEkij9HTZTy6b4tRf/art.json +++ b/art/gEkij9HTZTy6b4tRf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dan-hekate-1/too-much-nostalgia\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\n//KDrawmode=GL_TRIANGLES\\n\\n#define my 0.5//KParameter -1.0>>1.0\\n#define KP0 -0.12//KParameter -1.0>>3.0\\n#define KP1 0.5//KParameter -0.05>>0.7\\n#define KP2 0.72//KParameter 0.02>>1.0\\n#define KP3 2.//KParameter 0.0>>3.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 1.+KP3);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < -6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\nfloat vertexCount = 100000.*KP2;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float maxCubes = floor(vertexCount / 36./my);\\n float numCubes = maxCubes * mix(0.1, 1., t5p5(sin(time * .05+KP1)));\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = (cv);\\n //su = hash(cubeId / maxCubes);\\n float s1 = texture2D(sound, vec2(mix(.2, .0, su), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(.2, .0, su), 1. / soundRes.x)).a;\\n float s3 = texture2D(sound, vec2(mix(1.2, .0, su), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(.2,1.0, su), 3. / soundRes.y)).a;\\n \\n float s = mix(0.0, 0.25, s1 + s2 + s3 + s4);\\n \\n float tm = time * .1;\\n float r = 50.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(sc, sc, mix(0.5, s*3.61, pow(s,.0030))));\\n mat *= trans(vec3(0, 1, 1));\\n mat *= rotZ(s * PI * 2.);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = .4 + s * KP0;\\n float sat = .2 + s;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt, 1);\\n v_color.a = s;\\n v_color.rgb *= v_color.a; \\n if (s < .2) {\\n gl_Position.z = 10000.;\\n }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dan-hekate-1/too-much-nostalgia", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n \n\n//KDrawmode=GL_TRIANGLES\n\n#define my 0.5//KParameter -1.0>>1.0\n#define KP0 -0.12//KParameter -1.0>>3.0\n#define KP1 0.5//KParameter -0.05>>0.7\n#define KP2 0.72//KParameter 0.02>>1.0\n#define KP3 2.//KParameter 0.0>>3.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 1.+KP3);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < -6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \nfloat vertexCount = 100000.*KP2;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float maxCubes = floor(vertexCount / 36./my);\n float numCubes = maxCubes * mix(0.1, 1., t5p5(sin(time * .05+KP1)));\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = (cv);\n //su = hash(cubeId / maxCubes);\n float s1 = texture2D(sound, vec2(mix(.2, .0, su), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(.2, .0, su), 1. / soundRes.x)).a;\n float s3 = texture2D(sound, vec2(mix(1.2, .0, su), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(.2,1.0, su), 3. / soundRes.y)).a;\n \n float s = mix(0.0, 0.25, s1 + s2 + s3 + s4);\n \n float tm = time * .1;\n float r = 50.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(sc, sc, mix(0.5, s*3.61, pow(s,.0030))));\n mat *= trans(vec3(0, 1, 1));\n mat *= rotZ(s * PI * 2.);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = .4 + s * KP0;\n float sat = .2 + s;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt, 1);\n v_color.a = s;\n v_color.rgb *= v_color.a; \n if (s < .2) {\n gl_Position.z = 10000.;\n }\n}\n\n" + }, "screenshotURL": "data/images/images-qyxb7ch3s2yca52s9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gFjsSoxA5bwzxPwXc/art.json b/art/gFjsSoxA5bwzxPwXc/art.json index c6f36403..2dd453c4 100644 --- a/art/gFjsSoxA5bwzxPwXc/art.json +++ b/art/gFjsSoxA5bwzxPwXc/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP + 0.01, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n \\n \\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP + 0.01, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n \n \n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-r6jjcmih2ttwfu564-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gJPot9c9wsbfuT6Md/art.json b/art/gJPot9c9wsbfuT6Md/art.json index 99e6997e..f54fd6f3 100644 --- a/art/gJPot9c9wsbfuT6Md/art.json +++ b/art/gJPot9c9wsbfuT6Md/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * 9.319)) * 2. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * 9.319)) * 2. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-fq2bl5x6nmigdkelx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gKbNhtAK4AqZvFaQM/art.json b/art/gKbNhtAK4AqZvFaQM/art.json index 1736c05b..1cf8283d 100644 --- a/art/gKbNhtAK4AqZvFaQM/art.json +++ b/art/gKbNhtAK4AqZvFaQM/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chris-camplin/in-my-mind\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 1\\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n\\n float ux = floor(id / 6.0) + mod(id, 2.);\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.0;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n \\n return vec2(x, y);\\n}\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n \\t// \\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float cols = floor(sqrt(numCubes));\\n float rows = floor(numCubes / cols);\\n \\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(cubeId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(cubeId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat c = cos(PI * time + x * 0.25);\\n \\tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\\n \\tfloat yOff = cos(time + x * 0.25) * 0.2;\\n \\tfloat zOff = sin(time * x * y * 0.005) * 0.05;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\\\\\n\\n float ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. - zOff;\\n\\n \\t// concentrate on center\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\n // circular - atan returns values between PI & -PI\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n // sound\\n\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\\n \\tscl *= 20. / rows;\\t\\n \\t//vec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\\n \\tfloat z = -pow(snd + c, 2.* snd) - zOff + snd;\\n \\t//pos -= vec3(circleXY, z);\\n \\tmat4 mat = ident();\\n float tm = time * 0.1;\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.5) * .1 + 1., sin(tm) * 2.* snd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n //mat *= cameraLookAt(eye, target, up);\\n\\n \\tmat *= scale(vec3(1, aspect, 1));\\n mat *= rotX(radians(45. * mouse.x * mouse.y));\\n //mat *= rotY(radians(-45.));\\n \\tmat *= rotZ(time * 0.1);\\n\\tmat += transpose(mat * snd * mouse.x * mouse.y);\\n \\tmat *= trans(vec3(ux, vy, 0) * 1.3);\\n \\tmat *= uniformScale(0.02 * scl);\\n \\t//mat *= rotY(PI * snd * 0.1 * sign(ux));\\n \\t//mat *= rotZ(PI* snd* 0.1 *time * sign(ux));\\n \\n\\tgl_Position = mat * vec4(pos, 1.);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n \\n \\tfloat pump = step(0.2, 20. * snd);\\n float hue = 0.5 - pump * mouse.x * 0.1;\\n hue = hue + smoothstep(x, y, snd);\\n float sat = 0.8;\\n \\t// add more impact using pow\\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\\n \\t//val += oddSlice;\\n vec3 color = vec3(hsv2rgb(vec3(fract(hue), sat, val)));\\n //color *= snd;\\n //background += 0.1;\\n \\tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\\n //vec3 finalColor = mix(vec4(color, 1.), background, s);\\n\\t//finalColor = mix(color, newColor, c);\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n }\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chris-camplin/in-my-mind", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 1\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n\n float ux = floor(id / 6.0) + mod(id, 2.);\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 1 1 2 2 3 3 4 4 5 5 6\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.0;\n\n float x = c * radius;\n float y = s * radius;\n\n \n return vec2(x, y);\n}\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n \t// \n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float cols = floor(sqrt(numCubes));\n float rows = floor(numCubes / cols);\n \n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\n \t// vertex ID is number of the vertex\n \tfloat x = mod(cubeId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(cubeId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat c = cos(PI * time + x * 0.25);\n \tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\n \tfloat yOff = cos(time + x * 0.25) * 0.2;\n \tfloat zOff = sin(time * x * y * 0.005) * 0.05;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\\\n\n float ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. - zOff;\n\n \t// concentrate on center\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat su = abs(u - 0.5) * 2.0;\n \n // circular - atan returns values between PI & -PI\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n // sound\n\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\n \tscl *= 20. / rows;\t\n \t//vec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\n \tfloat z = -pow(snd + c, 2.* snd) - zOff + snd;\n \t//pos -= vec3(circleXY, z);\n \tmat4 mat = ident();\n float tm = time * 0.1;\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.5) * .1 + 1., sin(tm) * 2.* snd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n //mat *= cameraLookAt(eye, target, up);\n\n \tmat *= scale(vec3(1, aspect, 1));\n mat *= rotX(radians(45. * mouse.x * mouse.y));\n //mat *= rotY(radians(-45.));\n \tmat *= rotZ(time * 0.1);\n\tmat += transpose(mat * snd * mouse.x * mouse.y);\n \tmat *= trans(vec3(ux, vy, 0) * 1.3);\n \tmat *= uniformScale(0.02 * scl);\n \t//mat *= rotY(PI * snd * 0.1 * sign(ux));\n \t//mat *= rotZ(PI* snd* 0.1 *time * sign(ux));\n \n\tgl_Position = mat * vec4(pos, 1.);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n \n \tfloat pump = step(0.2, 20. * snd);\n float hue = 0.5 - pump * mouse.x * 0.1;\n hue = hue + smoothstep(x, y, snd);\n float sat = 0.8;\n \t// add more impact using pow\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\n \t//val += oddSlice;\n vec3 color = vec3(hsv2rgb(vec3(fract(hue), sat, val)));\n //color *= snd;\n //background += 0.1;\n \tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\n //vec3 finalColor = mix(vec4(color, 1.), background, s);\n\t//finalColor = mix(color, newColor, c);\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n }\n\n" + }, "screenshotURL": "data/images/images-jlvq4qrowcpvrqioz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gKzj7CPEr29FdEonW/art.json b/art/gKzj7CPEr29FdEonW/art.json index ec090002..fb2ad32b 100644 --- a/art/gKzj7CPEr29FdEonW/art.json +++ b/art/gKzj7CPEr29FdEonW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jonaced", "avatarUrl": "https://secure.gravatar.com/avatar/4afc7bbaa73d3ae5795519659259854b?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float vertexPerCircle = 42.0;\\n float circlePerRow = 22.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n\\n float xRow = floor(mod(vertexId , vertexPerCircle * circlePerRow) / vertexPerCircle);\\n float yColumn = floor(vertexId / (vertexPerCircle * circlePerRow));\\n\\n //float x = floor(vertexId / 2.0);\\n //float y = mod(vertexId + 1.0, 2.0);\\n \\n // Radianes de 360 da pi\\n float angle = x / 20.0 * radians(360.0);\\n float radius = 2.0 - y;\\n \\n // Movimiento\\n float xOffset = cos(time + yColumn * 0.2) * 0.4;\\n float yOffset = cos(time + xRow * 0.2 ) * 0.8;\\n \\n // Se asignan a 4 cuadrantes\\n float u = radius * cos(angle) * 0.2 + xOffset;\\n float v = radius * sin(angle) * 0.2 + yOffset;\\n \\n vec2 xy = vec2(u + xRow , v + yColumn) * 0.1 - 1.0;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n v_color = vec4(0.0, 0.7, 1.0, 1.0);\\n} \"}", + "settings": { + "num": 20000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float vertexPerCircle = 42.0;\n float circlePerRow = 22.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n\n float xRow = floor(mod(vertexId , vertexPerCircle * circlePerRow) / vertexPerCircle);\n float yColumn = floor(vertexId / (vertexPerCircle * circlePerRow));\n\n //float x = floor(vertexId / 2.0);\n //float y = mod(vertexId + 1.0, 2.0);\n \n // Radianes de 360 da pi\n float angle = x / 20.0 * radians(360.0);\n float radius = 2.0 - y;\n \n // Movimiento\n float xOffset = cos(time + yColumn * 0.2) * 0.4;\n float yOffset = cos(time + xRow * 0.2 ) * 0.8;\n \n // Se asignan a 4 cuadrantes\n float u = radius * cos(angle) * 0.2 + xOffset;\n float v = radius * sin(angle) * 0.2 + yOffset;\n \n vec2 xy = vec2(u + xRow , v + yColumn) * 0.1 - 1.0;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 1.0;\n v_color = vec4(0.0, 0.7, 1.0, 1.0);\n} " + }, "screenshotURL": "data/images/images-a8gjtdbwgbi5qtj73-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gMC34jEobWC2ofXfB/art.json b/art/gMC34jEobWC2ofXfB/art.json index a3c810fe..ec871508 100644 --- a/art/gMC34jEobWC2ofXfB/art.json +++ b/art/gMC34jEobWC2ofXfB/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Audio Reactive\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Audio Reactive\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;//sin(time + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-3hbf67t41wub9an6t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gQ93FbmuckckWhhix/art.json b/art/gQ93FbmuckckWhhix/art.json index bf54ba26..56c93e22 100644 --- a/art/gQ93FbmuckckWhhix/art.json +++ b/art/gQ93FbmuckckWhhix/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.15294117647058825,0.14901960784313725,0.34901960784313724,1],\"shader\":\"//Daehyeon Kim\\n//Make a grid\\n//CS250\\n//Spring, 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.15294117647058825, + 0.14901960784313725, + 0.34901960784313724, + 1 + ], + "shader": "//Daehyeon Kim\n//Make a grid\n//CS250\n//Spring, 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-l04mln0fydrvloicy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gQTuwGmLKEGMHfB3x/art.json b/art/gQTuwGmLKEGMHfB3x/art.json index 7cb55712..c5c73731 100644 --- a/art/gQTuwGmLKEGMHfB3x/art.json +++ b/art/gQTuwGmLKEGMHfB3x/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":14721,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/globalliquidity/ordinal-prime\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n \\n\\n \\n float spike = pow(cos(a * 4.), 4.);\\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * 4.), 4.);\\n }\\n \\n \\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * 5.0;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 1.0 - p1.rad);\\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\\n float rotationAmp = 1.5;\\n p1.position.yz *= rotateX * rotationAmp;\\n p1.position.xz *= rotateY * rotationAmp;\\n p1.position.xy *= rotateZ * rotationAmp; \\n// normal.xz *= rotateX;\\n// normal.yz *= rotateY;\\n \\n\\n \\n float screenZ = -1.;\\n float eyeZ = -1.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2.0 * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 14721, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/globalliquidity/ordinal-prime", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n \n\n \n float spike = pow(cos(a * 4.), 4.);\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * 4.), 4.);\n }\n \n \n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * 5.0;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 1.0 - p1.rad);\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\n float rotationAmp = 1.5;\n p1.position.yz *= rotateX * rotationAmp;\n p1.position.xz *= rotateY * rotationAmp;\n p1.position.xy *= rotateZ * rotationAmp; \n// normal.xz *= rotateX;\n// normal.yz *= rotateY;\n \n\n \n float screenZ = -1.;\n float eyeZ = -1.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2.0 * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-5aecaotsnr1shzgfx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gTDpcK8Kws8upyKKp/art.json b/art/gTDpcK8Kws8upyKKp/art.json index aeeae359..f43c00f4 100644 --- a/art/gTDpcK8Kws8upyKKp/art.json +++ b/art/gTDpcK8Kws8upyKKp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/guigoo-official/acido\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const int maxIter = 10;\\nfloat df(vec3 p, float power) {\\n vec3 z = p;\\n float r = 0.0;\\n float dr = 1.0;\\n for(int i = 0; i < maxIter; i++) {\\n r = length(z);\\n if(r > 100.0) break;\\n \\n float theta = acos(z.z/r);\\n float phi = atan(z.y, z.x);\\n \\n dr = power*pow(r, power-1.0)*dr + 1.0;\\n \\n r = pow(r, power);\\n theta *= power;\\n phi *= power;\\n \\n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\\n z += p;\\n }\\n return 0.5*log(r)*r/dr;\\n}\\n\\n\\nstruct Ray {\\n bool hit;\\n vec3 hitPos;\\n float t;\\n int steps;\\n};\\nconst int maxSteps = 50;\\n\\nRay trace(vec3 camPos, vec3 rayDir, float _factor) {\\n vec3 p = vec3(0);\\n float t = 0.0; \\n int steps = 0;\\n bool hit = false;\\n for(int i = 0; i < maxSteps; i++) {\\n p = camPos + t*rayDir;\\n float d = df(p, 8.0*abs(sin(0.5*_factor)) + 1.0);\\n if(d < 0.001) {\\n hit = true;\\n steps = i;\\n break;\\n }\\n t += d*0.9;\\n }\\n return Ray(hit, p, t, steps);\\n}\\n\\n\\nvec3 shading(Ray tr) {\\n if(tr.hit) {\\n \\treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\\n }\\n else {\\n return vec3(0);\\n }\\n}\\n\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n //we want to keep the resolution.xresolution.y ratio\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //deduce from finalMaxVertexCount the number of possible lines with the given across\\n float down = floor(finalMaxVertexCount / across);\\n \\n //Now we have the across and down number of elements, we can now calculate the final number of vertices\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n\\n \\n //vec2 fragCoord = vec2(ux,vy);\\n \\n //apply fragment logic\\n\\n\\tvec2 fragCoord = vec2(x,y);\\n \\n\\tvec2 iResolution = vec2(across, down);\\n float iTime = time;\\n \\n\\tvec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\\n \\n //vec2 uv = vec2(u,v);\\n \\n //vec3 camPos = vec3(-2, 0, 0);\\n //vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\\n vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\\n vec3 camFront = normalize(-camPos);\\n vec3 camUp = vec3(0, 1, 0);\\n vec3 camRight = cross(camFront, camUp);\\n float focus = 1.0;\\n \\n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float sndFactor = texture2D(sound, vec2(udnd, 0.2)).a;\\n Ray tr = trace(camPos, rayDir, 1.+sndFactor);\\n \\n\\t//fragColor = vec4(shading(tr), 1.0);\\n\\t\\n v_color = vec4(shading(tr), 1.0);\\n gl_Position = vec4(ux*v_color.x*5.*pow(2.*sndFactor,10.), vy*v_color.y *5., 0, 1);\\n //gl_Position = vec4(ux , vy , 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n \\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/guigoo-official/acido", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const int maxIter = 10;\nfloat df(vec3 p, float power) {\n vec3 z = p;\n float r = 0.0;\n float dr = 1.0;\n for(int i = 0; i < maxIter; i++) {\n r = length(z);\n if(r > 100.0) break;\n \n float theta = acos(z.z/r);\n float phi = atan(z.y, z.x);\n \n dr = power*pow(r, power-1.0)*dr + 1.0;\n \n r = pow(r, power);\n theta *= power;\n phi *= power;\n \n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\n z += p;\n }\n return 0.5*log(r)*r/dr;\n}\n\n\nstruct Ray {\n bool hit;\n vec3 hitPos;\n float t;\n int steps;\n};\nconst int maxSteps = 50;\n\nRay trace(vec3 camPos, vec3 rayDir, float _factor) {\n vec3 p = vec3(0);\n float t = 0.0; \n int steps = 0;\n bool hit = false;\n for(int i = 0; i < maxSteps; i++) {\n p = camPos + t*rayDir;\n float d = df(p, 8.0*abs(sin(0.5*_factor)) + 1.0);\n if(d < 0.001) {\n hit = true;\n steps = i;\n break;\n }\n t += d*0.9;\n }\n return Ray(hit, p, t, steps);\n}\n\n\nvec3 shading(Ray tr) {\n if(tr.hit) {\n \treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\n }\n else {\n return vec3(0);\n }\n}\n\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n //we want to keep the resolution.xresolution.y ratio\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //deduce from finalMaxVertexCount the number of possible lines with the given across\n float down = floor(finalMaxVertexCount / across);\n \n //Now we have the across and down number of elements, we can now calculate the final number of vertices\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n\n \n //vec2 fragCoord = vec2(ux,vy);\n \n //apply fragment logic\n\n\tvec2 fragCoord = vec2(x,y);\n \n\tvec2 iResolution = vec2(across, down);\n float iTime = time;\n \n\tvec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\n \n //vec2 uv = vec2(u,v);\n \n //vec3 camPos = vec3(-2, 0, 0);\n //vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\n vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\n vec3 camFront = normalize(-camPos);\n vec3 camUp = vec3(0, 1, 0);\n vec3 camRight = cross(camFront, camUp);\n float focus = 1.0;\n \n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float sndFactor = texture2D(sound, vec2(udnd, 0.2)).a;\n Ray tr = trace(camPos, rayDir, 1.+sndFactor);\n \n\t//fragColor = vec4(shading(tr), 1.0);\n\t\n v_color = vec4(shading(tr), 1.0);\n gl_Position = vec4(ux*v_color.x*5.*pow(2.*sndFactor,10.), vy*v_color.y *5., 0, 1);\n //gl_Position = vec4(ux , vy , 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n \n \n //v_color = vec4(1.,1.,1.,1.);\n}" + }, "screenshotURL": "data/images/images-b1mx6qnlwwr047y09-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gWF8YEaiS44osT2K7/art.json b/art/gWF8YEaiS44osT2K7/art.json index f0303d24..60a6f308 100644 --- a/art/gWF8YEaiS44osT2K7/art.json +++ b/art/gWF8YEaiS44osT2K7/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * .719)) * 1. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * .719)) * 1. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-x5sk8ux4v7jw5o0s4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gX32iAvezAbinbMJz/art.json b/art/gX32iAvezAbinbMJz/art.json index b95a4639..313b4bb7 100644 --- a/art/gX32iAvezAbinbMJz/art.json +++ b/art/gX32iAvezAbinbMJz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21176470588235294,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n float beat = texture2D(sound, vec2(0.007, 0)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0.65; + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(5,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n float beat = texture2D(sound, vec2(0.007, 0)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0.65; + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(5,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-ltsnd5j7fp9a8rh7d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gZNitbfDuN5pSwLf3/art.json b/art/gZNitbfDuN5pSwLf3/art.json index fa6c498d..01bc6825 100644 --- a/art/gZNitbfDuN5pSwLf3/art.json +++ b/art/gZNitbfDuN5pSwLf3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/clutchrecs/cr5\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n float ll = length(vec2(uP, vP * 2.));\\n float snd = texture2D(sound, vec2(mix(0.005, 0.025, u), ll * 0.3)).a;\\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 10.);\\n mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(1.2);\\n \\n \\tvec3 vRandCol;\\n\\n \\n float h = 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, step(0.9, snd)), \\n pow(snd, 2.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-100), step(0.95, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\\n // \\tvec3 vCameraUp = vec3( 0, 0, 1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/clutchrecs/cr5", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n float ll = length(vec2(uP, vP * 2.));\n float snd = texture2D(sound, vec2(mix(0.005, 0.025, u), ll * 0.3)).a;\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 10.);\n mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(1.2);\n \n \tvec3 vRandCol;\n\n \n float h = 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, step(0.9, snd)), \n pow(snd, 2.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(-100), step(0.95, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\n // \tvec3 vCameraUp = vec3( 0, 0, 1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-tubz2x6f92hn416mc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gZgDK3bN2z7xtma6A/art.json b/art/gZgDK3bN2z7xtma6A/art.json index db1d1453..2420c5af 100644 --- a/art/gZgDK3bN2z7xtma6A/art.json +++ b/art/gZgDK3bN2z7xtma6A/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"void main() {\\n \\n float density = 10.;\\n \\n float xoff = -0.5;\\n \\n float yoff = -0.5;\\n \\n float ux = 0.1;\\n \\n float uy = 0.1;\\n \\n float x = mod(vertexId , density);\\n \\n float y = mod(floor(vertexId / density), density);\\n \\n float step = mod(vertexId, density * density);\\n \\n float psize = mod(step, 3.) * 3. * (sin(time) + 1.);\\n \\n \\n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n \\n \\n gl_PointSize = psize;\\n\\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "void main() {\n \n float density = 10.;\n \n float xoff = -0.5;\n \n float yoff = -0.5;\n \n float ux = 0.1;\n \n float uy = 0.1;\n \n float x = mod(vertexId , density);\n \n float y = mod(floor(vertexId / density), density);\n \n float step = mod(vertexId, density * density);\n \n float psize = mod(step, 3.) * 3. * (sin(time) + 1.);\n \n \n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n \n \n gl_PointSize = psize;\n\n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-z3an9e0yhujk4l3cq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gZjPchBFJAGSk4ZTK/art.json b/art/gZjPchBFJAGSk4ZTK/art.json index d537bb72..bc0577db 100644 --- a/art/gZjPchBFJAGSk4ZTK/art.json +++ b/art/gZjPchBFJAGSk4ZTK/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "8bitrick", - "settings": "{\"num\":50,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/mortengranau/morten-granau-not-over-yet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Simple Line which responds to music\\n// This is intended to be super simple, to learn how to use VertexShaderArt\\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\\n\\nvoid main()\\n{\\n // vertex_percent is vertexId mapped to [0..1]\\n float vertex_percent = vertexId / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\\n float x = vertex_percent*2.0 - 1.0; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\\n \\n // sound texture has (amplitude, history) for (u,v). \\n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\\n // It is all in the alpha channel of the sound texture\\n \\n // Set y position to amplitude in [0..1] range.\\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\\n float y = texture2D(sound,vec2(vertex_percent,0.0)).a; \\n \\n gl_PointSize = 10.0; // Set point size in case want to render points instead of line, not used in line\\n gl_Position = vec4(x,y,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\\n v_color = vec4(1.0); // Just setting to the color white with opacity=1\\n}\\n\\n//===================================================================================\\n// ** Experiment **\\n// Try setting primitive to \\\"POINTS\\\" in the drop down\\n// Type a new number of verts in the text box at top. Try something small like \\\"10\\\".\\n// Keep adding zeros to 100, 1000, 10000 and watch sampling fidelity increase.\\n//===================================================================================\\n\\n\\n// Sometimes looking at code is easier without comments\\n// Here it is without my clutter.\\n// You can click \\\"+\\\" at the top of this window to create a new clean shader.\\n// Then cut at paste this code into that shader\\n// Don't forget to get a song from SoundCloud to paste into the URL in top right.\\n//\\n/*\\n\\nvoid main()\\n{\\n float vertex_per = vertexId / (vertexCount-1.0);\\n float x = vertex_per*2.0 - 1.0;\\n float y = texture2D(sound,vec2(vertex_per,0.0)).a;\\n gl_PointSize = 10.0;\\n gl_Position = vec4(x,y,0,1);\\n v_color = vec4(1.0);\\n}\\n\\n*/\\n\"}", + "settings": { + "num": 50, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/mortengranau/morten-granau-not-over-yet", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Simple Line which responds to music\n// This is intended to be super simple, to learn how to use VertexShaderArt\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\n\nvoid main()\n{\n // vertex_percent is vertexId mapped to [0..1]\n float vertex_percent = vertexId / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\n float x = vertex_percent*2.0 - 1.0; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\n \n // sound texture has (amplitude, history) for (u,v). \n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\n // It is all in the alpha channel of the sound texture\n \n // Set y position to amplitude in [0..1] range.\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\n float y = texture2D(sound,vec2(vertex_percent,0.0)).a; \n \n gl_PointSize = 10.0; // Set point size in case want to render points instead of line, not used in line\n gl_Position = vec4(x,y,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\n v_color = vec4(1.0); // Just setting to the color white with opacity=1\n}\n\n//===================================================================================\n// ** Experiment **\n// Try setting primitive to \"POINTS\" in the drop down\n// Type a new number of verts in the text box at top. Try something small like \"10\".\n// Keep adding zeros to 100, 1000, 10000 and watch sampling fidelity increase.\n//===================================================================================\n\n\n// Sometimes looking at code is easier without comments\n// Here it is without my clutter.\n// You can click \"+\" at the top of this window to create a new clean shader.\n// Then cut at paste this code into that shader\n// Don't forget to get a song from SoundCloud to paste into the URL in top right.\n//\n/*\n\nvoid main()\n{\n float vertex_per = vertexId / (vertexCount-1.0);\n float x = vertex_per*2.0 - 1.0;\n float y = texture2D(sound,vec2(vertex_per,0.0)).a;\n gl_PointSize = 10.0;\n gl_Position = vec4(x,y,0,1);\n v_color = vec4(1.0);\n}\n\n*/\n" + }, "screenshotURL": "data/images/images-tbc7952hrkj9bo5bp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gb48Jjp6zYH7bcWGN/art.json b/art/gb48Jjp6zYH7bcWGN/art.json index 7472013b..ef794804 100644 --- a/art/gb48Jjp6zYH7bcWGN/art.json +++ b/art/gb48Jjp6zYH7bcWGN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":6666,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 6.+mouse.x);\\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\\n mat *= scale(vec3(0.3 * sc, sc*mouse.y, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 6666, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 6.+mouse.x);\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\n mat *= scale(vec3(0.3 * sc, sc*mouse.y, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-bnga4x1sewsrwabbl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gb4JMDjdT2iyyCLdE/art.json b/art/gb4JMDjdT2iyyCLdE/art.json index 68b52a9a..7cc7a83b 100644 --- a/art/gb4JMDjdT2iyyCLdE/art.json +++ b/art/gb4JMDjdT2iyyCLdE/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/goblinsfrommars/pokemon-go-goblins-from-mars-trap-remixfree-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define maxN 7.0\\n#define zoom 0.8\\n#define sprite_min_scale 0.005\\n#define sprite_max_scale 0.05\\n#define PI 3.14159265359\\n\\nmat2 rot(float a) {\\n float s = sin(a);\\n float c = cos(a);\\n return mat2(c, s, -s, c);\\n}\\n\\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// From https://www.shadertoy.com/view/4dS3Wd\\nfloat hash(float n) { return fract(sin(n) * 1e4); }\\n\\n#define S(o) hash(shape_id + (o))\\n\\nvoid main () {\\n float points_per_shape = 200.0;\\n float point_id = float(vertexId);\\n float shape_id = floor(point_id / points_per_shape);\\n float shape_count = floor(vertexCount / points_per_shape);\\n float point_pct = point_id / points_per_shape - shape_id;\\n\\n // shape animaton params\\n float shape_rot = 2.0 * PI * S(2.1);\\n vec2 shape_offset = 2.0 * vec2(S(30.1), S(400.1)) - 1.0;\\n float shape_speed = 0.2 * S(5.222) + 0.001;\\n float shape_rot_speed = 1.0*(S(16.3133) - 0.5);\\n\\n // Parametric equation of a polygon courtesy of\\n // https://math.stackexchange.com/a/41954\\n // Generate random values of n for each shape_id between 3.0 and 7.0\\n float n = floor((maxN - 3.0)*S(7.22125) + 3.0);\\n float theta = mod(2.0 * PI * (point_pct), 2.0*PI);\\n float r = cos(PI / n)/cos(mod(theta, 2.0 * PI / n) - PI / n);\\n float x = r * cos(theta);\\n float y = r * sin(theta);\\n \\n float s = texture2D(sound, vec2(S(3042.33) * .1, 0)).a;\\n s = smoothstep(0.6, 1.0, s);\\n \\n // Apply animation params\\n vec2 xy = rot(0.5*PI + shape_rot_speed*time)*vec2(x,y);\\n xy *= ((s*sprite_max_scale - sprite_min_scale) * S(78.01) + sprite_min_scale);\\n xy.y *= resolution.x/resolution.y;\\n xy.x += 1.0*(2.0 * S(3.311222) - 1.0);\\n xy.y -= 1.0*S(439.11035) + shape_speed * time;\\n xy.y = mod(xy.y + 1.0, 2.0) - 1.0;\\n\\n\\n gl_Position = vec4(xy, 0.0, zoom);\\n gl_PointSize = 0.0035*resolution.y;\\n v_color.rgb = hsv2rgb(vec3(0.1 + 0.05*S(452.011), 1.0, 1.0));\\n v_color.a = 1.0;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/goblinsfrommars/pokemon-go-goblins-from-mars-trap-remixfree-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define maxN 7.0\n#define zoom 0.8\n#define sprite_min_scale 0.005\n#define sprite_max_scale 0.05\n#define PI 3.14159265359\n\nmat2 rot(float a) {\n float s = sin(a);\n float c = cos(a);\n return mat2(c, s, -s, c);\n}\n\n// from http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// From https://www.shadertoy.com/view/4dS3Wd\nfloat hash(float n) { return fract(sin(n) * 1e4); }\n\n#define S(o) hash(shape_id + (o))\n\nvoid main () {\n float points_per_shape = 200.0;\n float point_id = float(vertexId);\n float shape_id = floor(point_id / points_per_shape);\n float shape_count = floor(vertexCount / points_per_shape);\n float point_pct = point_id / points_per_shape - shape_id;\n\n // shape animaton params\n float shape_rot = 2.0 * PI * S(2.1);\n vec2 shape_offset = 2.0 * vec2(S(30.1), S(400.1)) - 1.0;\n float shape_speed = 0.2 * S(5.222) + 0.001;\n float shape_rot_speed = 1.0*(S(16.3133) - 0.5);\n\n // Parametric equation of a polygon courtesy of\n // https://math.stackexchange.com/a/41954\n // Generate random values of n for each shape_id between 3.0 and 7.0\n float n = floor((maxN - 3.0)*S(7.22125) + 3.0);\n float theta = mod(2.0 * PI * (point_pct), 2.0*PI);\n float r = cos(PI / n)/cos(mod(theta, 2.0 * PI / n) - PI / n);\n float x = r * cos(theta);\n float y = r * sin(theta);\n \n float s = texture2D(sound, vec2(S(3042.33) * .1, 0)).a;\n s = smoothstep(0.6, 1.0, s);\n \n // Apply animation params\n vec2 xy = rot(0.5*PI + shape_rot_speed*time)*vec2(x,y);\n xy *= ((s*sprite_max_scale - sprite_min_scale) * S(78.01) + sprite_min_scale);\n xy.y *= resolution.x/resolution.y;\n xy.x += 1.0*(2.0 * S(3.311222) - 1.0);\n xy.y -= 1.0*S(439.11035) + shape_speed * time;\n xy.y = mod(xy.y + 1.0, 2.0) - 1.0;\n\n\n gl_Position = vec4(xy, 0.0, zoom);\n gl_PointSize = 0.0035*resolution.y;\n v_color.rgb = hsv2rgb(vec3(0.1 + 0.05*S(452.011), 1.0, 1.0));\n v_color.a = 1.0;\n}\n" + }, "screenshotURL": "data/images/images-ek50l9z239w993xi3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gbv2z926cb7MWF3Gy/art.json b/art/gbv2z926cb7MWF3Gy/art.json index 930a02e9..db74e52c 100644 --- a/art/gbv2z926cb7MWF3Gy/art.json +++ b/art/gbv2z926cb7MWF3Gy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":54,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n vec3 pos = vec3(cos(time+vertexId)*0.7, sin(time+vertexId), 0.0);\\n float color = 1.0;\\n gl_PointSize = 20.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0)+0.5;\\n}\"}", + "settings": { + "num": 54, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n vec3 pos = vec3(cos(time+vertexId)*0.7, sin(time+vertexId), 0.0);\n float color = 1.0;\n gl_PointSize = 20.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0)+0.5;\n}" + }, "screenshotURL": "data/images/images-5fnnehcthnc49607f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gfBdkzchpT5DPGwqE/art.json b/art/gfBdkzchpT5DPGwqE/art.json index c9a437f6..7f25f3de 100644 --- a/art/gfBdkzchpT5DPGwqE/art.json +++ b/art/gfBdkzchpT5DPGwqE/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":1086,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Colors Assignment\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. -1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n\\n}\"}", + "settings": { + "num": 1086, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Colors Assignment\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. -1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n\n}" + }, "screenshotURL": "data/images/images-bkh9k5fibyuvjwc65-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ghFixTy38ux4F235T/art.json b/art/ghFixTy38ux4F235T/art.json index 6da3f14b..7b20d24a 100644 --- a/art/ghFixTy38ux4F235T/art.json +++ b/art/ghFixTy38ux4F235T/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//SpiralPrm lines vertices 5000\\n\\n//KDrawmode=GL_LINES\\n#define SegCntrl 2.//KParameter0 1.>>10.\\n#define StepCntrl 2.//KParameter1 1.>>10.\\n#define RadiusCntrl 0.001//KParameter2 0.001>>0.009\\n#define HueCntrl 1.001//KParameter3 1.001>>1.009\\n\\n//KVerticesNumber=5000\\n\\n#define PI radians(180.)\\n#define SegStepAsgn\\n\\n#ifdef SegStepAsgn\\n\\nfloat getSeg(float Sn){\\n\\tif (floor(SegCntrl) < 2.)\\n\\t{return 3.;}\\n\\telse if (floor(SegCntrl) < 3.)\\n\\t{return 5.;}\\n\\telse if (floor(SegCntrl) < 4.)\\n\\t{return 7.;}\\n\\telse if (floor(SegCntrl) < 5.)\\n\\t{return 9.;}\\n\\telse if (floor(SegCntrl) < 6.)\\n\\t{return 11.;}\\n\\telse if (floor(SegCntrl) < 7.)\\n\\t{return 13.;}\\n\\telse if (floor(SegCntrl) < 8.)\\n\\t{return 15.;}\\n\\telse if (floor(SegCntrl) < 9.)\\n\\t{return 17.;}\\n\\telse if (floor(SegCntrl) < 10.)\\n\\t{return 19.;}\\n\\telse\\n\\t{return 21.;}\\n}\\n\\nfloat getStep(float Sm){\\n\\tif (floor(StepCntrl) < 2.)\\n\\t{return 2.;}\\n\\telse if (floor(StepCntrl) < 3.)\\n\\t{return 4.;}\\n\\telse if (floor(StepCntrl) < 4.)\\n\\t{return 8.;}\\n\\telse if (floor(StepCntrl) < 5.)\\n\\t{return 16.;}\\n\\telse if (floor(StepCntrl) < 6.)\\n\\t{return 23.;}\\n\\telse if (floor(StepCntrl) < 7.)\\n\\t{return 29.;}\\n\\telse if (floor(StepCntrl) < 8.)\\n\\t{return 31.;}\\n\\telse if (floor(StepCntrl) < 9.)\\n\\t{return 37.;}\\n\\telse if (floor(StepCntrl) < 10.)\\n\\t{return 41.;}\\n\\telse\\n\\t{return 43.;}\\n}\\n\\nfloat temp;\\n#define NUM_SEGMENTS (getSeg(temp))\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP (getStep(temp))\\n\\n#endif\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n \\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * RadiusCntrl;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * HueCntrl);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//SpiralPrm lines vertices 5000\n\n//KDrawmode=GL_LINES\n#define SegCntrl 2.//KParameter0 1.>>10.\n#define StepCntrl 2.//KParameter1 1.>>10.\n#define RadiusCntrl 0.001//KParameter2 0.001>>0.009\n#define HueCntrl 1.001//KParameter3 1.001>>1.009\n\n//KVerticesNumber=5000\n\n#define PI radians(180.)\n#define SegStepAsgn\n\n#ifdef SegStepAsgn\n\nfloat getSeg(float Sn){\n\tif (floor(SegCntrl) < 2.)\n\t{return 3.;}\n\telse if (floor(SegCntrl) < 3.)\n\t{return 5.;}\n\telse if (floor(SegCntrl) < 4.)\n\t{return 7.;}\n\telse if (floor(SegCntrl) < 5.)\n\t{return 9.;}\n\telse if (floor(SegCntrl) < 6.)\n\t{return 11.;}\n\telse if (floor(SegCntrl) < 7.)\n\t{return 13.;}\n\telse if (floor(SegCntrl) < 8.)\n\t{return 15.;}\n\telse if (floor(SegCntrl) < 9.)\n\t{return 17.;}\n\telse if (floor(SegCntrl) < 10.)\n\t{return 19.;}\n\telse\n\t{return 21.;}\n}\n\nfloat getStep(float Sm){\n\tif (floor(StepCntrl) < 2.)\n\t{return 2.;}\n\telse if (floor(StepCntrl) < 3.)\n\t{return 4.;}\n\telse if (floor(StepCntrl) < 4.)\n\t{return 8.;}\n\telse if (floor(StepCntrl) < 5.)\n\t{return 16.;}\n\telse if (floor(StepCntrl) < 6.)\n\t{return 23.;}\n\telse if (floor(StepCntrl) < 7.)\n\t{return 29.;}\n\telse if (floor(StepCntrl) < 8.)\n\t{return 31.;}\n\telse if (floor(StepCntrl) < 9.)\n\t{return 37.;}\n\telse if (floor(StepCntrl) < 10.)\n\t{return 41.;}\n\telse\n\t{return 43.;}\n}\n\nfloat temp;\n#define NUM_SEGMENTS (getSeg(temp))\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP (getStep(temp))\n\n#endif\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n \n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * RadiusCntrl;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * HueCntrl);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-w3a32cyj0260lfz63-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ghH8XPT3kfdig8cXX/art.json b/art/ghH8XPT3kfdig8cXX/art.json index 73791603..416943af 100644 --- a/art/ghH8XPT3kfdig8cXX/art.json +++ b/art/ghH8XPT3kfdig8cXX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.18823529411764706,0.3137254901960784,0.26666666666666666,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 4.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time* 0.6 );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2/2.),\\n s, 0, 0-2, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, -2, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, -0.1, 0.5, 0.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, s, s-mouse.x, 1.31,\\n s-0.5, 0.3, s, 0,\\n 2, 0.5, 0, 0.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 13.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.18823529411764706, + 0.3137254901960784, + 0.26666666666666666, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 4.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.2, 0.5)/cos(time*0.6)*parameter3);\n vec4 K = vec4(1.0, 2.0 / -3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time* 0.6 );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2/2.),\n s, 0, 0-2, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, -2, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, -0.1, 0.5, 0.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, s, s-mouse.x, 1.31,\n s-0.5, 0.3, s, 0,\n 2, 0.5, 0, 0.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t10.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 13.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * .1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *0.1 /mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.04;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-s2f44s3t1x0j0o48f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gkNsynXB23Y8WhASo/art.json b/art/gkNsynXB23Y8WhASo/art.json index 4c509549..fc6e9136 100644 --- a/art/gkNsynXB23Y8WhASo/art.json +++ b/art/gkNsynXB23Y8WhASo/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "xurxo", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD0p44DV5qPWJz5scluCuMG3Emc9M_fA2dSRyXD", - "settings": "{\"num\":14429,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09411764705882353,0.08627450980392157,0.5294117647058824,1],\"shader\":\"\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across =floor (vertexCount/down);\\n float x= mod(vertexId,across);\\n float y= floor(vertexId /across);\\n\\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float ux = u * 2.-1.;\\n float vy = v * 2.-1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x/600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\\n\\n\\n\"}", + "settings": { + "num": 14429, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09411764705882353, + 0.08627450980392157, + 0.5294117647058824, + 1 + ], + "shader": "\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across =floor (vertexCount/down);\n float x= mod(vertexId,across);\n float y= floor(vertexId /across);\n\n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float ux = u * 2.-1.;\n float vy = v * 2.-1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x/600.;\n \n v_color = vec4(1,0,0,1);\n \n}\n\n\n" + }, "screenshotURL": "data/images/images-3heyj3k7mlv08w6hh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gkrLbb6TwrbveHw49/art.json b/art/gkrLbb6TwrbveHw49/art.json index eaf3a24f..0c55d4d1 100644 --- a/art/gkrLbb6TwrbveHw49/art.json +++ b/art/gkrLbb6TwrbveHw49/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":80000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.1);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 80000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.1);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-h2dnqkrvpzisr9lzq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gqGmyfsEh6zDQWsvA/art.json b/art/gqGmyfsEh6zDQWsvA/art.json index 84ef7fe5..545af843 100644 --- a/art/gqGmyfsEh6zDQWsvA/art.json +++ b/art/gqGmyfsEh6zDQWsvA/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n float starId = floor(vertexId / 3.0);\\n \\n float near = 0.01;\\n float far = 25.0;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, near, far);\\n mat4 cmat = ident();\\n cmat *= rotX(mouse.y * PI);\\n cmat *= rotY(mouse.x * -PI);\\n mat4 vmat = inverse(cmat);\\n \\n float starSize = 0.05;\\n vec3 pos = vec3(\\n hash(starId * 0.123), \\n hash(starId * 0.357), \\n // fract(hash(vertexId * 0.531) - time * .01)) * vec3(2, 2, -40) - vec3(1, 1, -20);\\n fract(hash(starId * 0.531) + time * .05)) * 2. - 1.;\\n pos *= 20.;\\n \\n pos += cmat[0].xyz * mod(vertexId, 2.) * starSize +\\n cmat[1].xyz * step(1.5, mod(vertexId, 3.)) * starSize;\\n \\n vec3 boxMin = (cmat * vec4(-1, -1, 0, 1)).xyz;\\n vec3 boxMax = (cmat * vec4(1, 1, -20, 1)).xyz;\\n \\n \\n \\n\\n /*\\n\\n +--------+--------+--------+--------+\\n | | | | |\\n | |\\\\ | | |\\n | | \\\\ | | |\\n | | \\\\ | | |\\n +--------+--------+--------+--------+\\n | | \\\\ | | |\\n | | \\\\ | | |\\n | | \\\\ | | |\\n | | \\\\| | |\\n +--------+--------c--------+--------+\\n | | /| | |\\n | | / | | |\\n | | / | | |\\n | | / | | |\\n +--------+--------+--------+--------+\\n | | / | | |\\n | | / | | |\\n | |/ | | |\\n | | | | |\\n +--------+--------+--------+--------+\\n\\n */\\n \\n \\n //mat[2][2] /= far;\\n //mat[2][3] /= far;\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n // gl_Position.z = gl_Position.z * gl_Position.w / far; \\n\\n \\n /*\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n rangeInv = 1.0 / (near - far)\\n rangnInv = 1.0 / (0.01 - 25.0)\\n rangeInv = 1.0 / -24.99\\n rangeInv = -0.040016006402561027\\n\\n -0.1 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = -0.000996\\n -20 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = 0.1988\\n\\n\\n */\\n \\n v_color = vec4(1);vec4(hsv2rgb(vec3(hash(vertexId * 0.237), 0.25, 1)), 1);\\n v_color.rgb *= v_color.a;\\n// v_color = vec4(hsv2rgb(vec3(depth, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n float starId = floor(vertexId / 3.0);\n \n float near = 0.01;\n float far = 25.0;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, near, far);\n mat4 cmat = ident();\n cmat *= rotX(mouse.y * PI);\n cmat *= rotY(mouse.x * -PI);\n mat4 vmat = inverse(cmat);\n \n float starSize = 0.05;\n vec3 pos = vec3(\n hash(starId * 0.123), \n hash(starId * 0.357), \n // fract(hash(vertexId * 0.531) - time * .01)) * vec3(2, 2, -40) - vec3(1, 1, -20);\n fract(hash(starId * 0.531) + time * .05)) * 2. - 1.;\n pos *= 20.;\n \n pos += cmat[0].xyz * mod(vertexId, 2.) * starSize +\n cmat[1].xyz * step(1.5, mod(vertexId, 3.)) * starSize;\n \n vec3 boxMin = (cmat * vec4(-1, -1, 0, 1)).xyz;\n vec3 boxMax = (cmat * vec4(1, 1, -20, 1)).xyz;\n \n \n \n\n /*\n\n +--------+--------+--------+--------+\n | | | | |\n | |\\ | | |\n | | \\ | | |\n | | \\ | | |\n +--------+--------+--------+--------+\n | | \\ | | |\n | | \\ | | |\n | | \\ | | |\n | | \\| | |\n +--------+--------c--------+--------+\n | | /| | |\n | | / | | |\n | | / | | |\n | | / | | |\n +--------+--------+--------+--------+\n | | / | | |\n | | / | | |\n | |/ | | |\n | | | | |\n +--------+--------+--------+--------+\n\n */\n \n \n //mat[2][2] /= far;\n //mat[2][3] /= far;\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n // gl_Position.z = gl_Position.z * gl_Position.w / far; \n\n \n /*\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n rangeInv = 1.0 / (near - far)\n rangnInv = 1.0 / (0.01 - 25.0)\n rangeInv = 1.0 / -24.99\n rangeInv = -0.040016006402561027\n\n -0.1 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = -0.000996\n -20 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = 0.1988\n\n\n */\n \n v_color = vec4(1);vec4(hsv2rgb(vec3(hash(vertexId * 0.237), 0.25, 1)), 1);\n v_color.rgb *= v_color.a;\n// v_color = vec4(hsv2rgb(vec3(depth, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-jb1nrxnndn2f2as2x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gqJ33JsAWdcuKjJHH/art.json b/art/gqJ33JsAWdcuKjJHH/art.json index 65746e56..bc2ce301 100644 --- a/art/gqJ33JsAWdcuKjJHH/art.json +++ b/art/gqJ33JsAWdcuKjJHH/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n//#define SHAPE_TWO_BRAIDS\\n#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n//#define SHAPE_TWO_BRAIDS\n#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-w7s8diqut6qc7yq9s-thumbnail.jpg", "views": { "$numberInt": "106" diff --git a/art/grkNAy4oE5JqXxyMr/art.json b/art/grkNAy4oE5JqXxyMr/art.json index f086d1c3..c44ca1bb 100644 --- a/art/grkNAy4oE5JqXxyMr/art.json +++ b/art/grkNAy4oE5JqXxyMr/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":94,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/albertryan/never-around\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7529411764705882,0.7529411764705882,0.7529411764705882,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.5)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.1, 1.3));\\n vec4 K = vec4(1.1, 2.2 / 3.3, 1.4 / 3.5, 3.6);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.7 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 2.8, 1.9), c.y);\\n}\\n\\nfloat rand(float p){\\n \\treturn fract(sin(p*256000./time));\\n}\\n\\nfloat noise(vec2 p)\\n{\\n return rand((p.x + p.y) * 1000.1000);\\n}\\n\\nvoid main() {\\n float samp = texture2D(sound,vec2(11.34,10.)).r + texture2D(sound,vec2(803.1,3.6)).r;\\n samp /=2.5;\\n vec2 uv = vec2(sin(time+ vertexId + time),tan(time + vertexId ));\\n uv *= samp + .50;\\n gl_Position = vec4(uv,0,1);\\n gl_PointSize = 250.;\\n \\n \\n v_color = vec4(1.3);\\n v_color.a*= noise(uv *time); \\n vec3 gdlw = vec3(texture2D(sound, vec2(2.5,0.5)).r * sin(time + vertexId) ,texture2D(sound,vec2(50.*8.5,0.07)).r *cos(time * vertexId) , (sin(vertexId - time)));\\n v_color.rgb *= gdlw;\\n }\"}", + "settings": { + "num": 94, + "mode": "POINTS", + "sound": "https://soundcloud.com/albertryan/never-around", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7529411764705882, + 0.7529411764705882, + 0.7529411764705882, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.5)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.1, 1.3));\n vec4 K = vec4(1.1, 2.2 / 3.3, 1.4 / 3.5, 3.6);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.7 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 2.8, 1.9), c.y);\n}\n\nfloat rand(float p){\n \treturn fract(sin(p*256000./time));\n}\n\nfloat noise(vec2 p)\n{\n return rand((p.x + p.y) * 1000.1000);\n}\n\nvoid main() {\n float samp = texture2D(sound,vec2(11.34,10.)).r + texture2D(sound,vec2(803.1,3.6)).r;\n samp /=2.5;\n vec2 uv = vec2(sin(time+ vertexId + time),tan(time + vertexId ));\n uv *= samp + .50;\n gl_Position = vec4(uv,0,1);\n gl_PointSize = 250.;\n \n \n v_color = vec4(1.3);\n v_color.a*= noise(uv *time); \n vec3 gdlw = vec3(texture2D(sound, vec2(2.5,0.5)).r * sin(time + vertexId) ,texture2D(sound,vec2(50.*8.5,0.07)).r *cos(time * vertexId) , (sin(vertexId - time)));\n v_color.rgb *= gdlw;\n }" + }, "screenshotURL": "data/images/images-d9ckseu4mmgxfnce0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gs5Ttw4zaPA7LZrNS/art.json b/art/gs5Ttw4zaPA7LZrNS/art.json index 2e8163b3..7ebebd7e 100644 --- a/art/gs5Ttw4zaPA7LZrNS/art.json +++ b/art/gs5Ttw4zaPA7LZrNS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "theflyingd", "avatarUrl": "https://avatars.githubusercontent.com/theflyingd?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float accross = floor(vertexCount/down);\\n \\n float x =mod(vertexId, accross);\\n float y =floor(vertexId /accross);\\n \\n float u = x/(accross- 1.);\\n float v = y/(accross- 1.);\\n \\n float ux = u * 2. -1.; \\n float vy = v * 2. -1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n \\n v_color = vec4(1, 0, 1, 1);\\n \\n \\n\\n}\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n float accross = floor(vertexCount/down);\n \n float x =mod(vertexId, accross);\n float y =floor(vertexId /accross);\n \n float u = x/(accross- 1.);\n float v = y/(accross- 1.);\n \n float ux = u * 2. -1.; \n float vy = v * 2. -1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n \n \n v_color = vec4(1, 0, 1, 1);\n \n \n\n}\n" + }, "screenshotURL": "data/images/images-vclafltm3cvm65b2v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gszWKmYHHf8HxkXiS/art.json b/art/gszWKmYHHf8HxkXiS/art.json index 4b7e05e0..d9559ec9 100644 --- a/art/gszWKmYHHf8HxkXiS/art.json +++ b/art/gszWKmYHHf8HxkXiS/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 1.33) + sin(time * 0.83 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n\\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 1.33) + sin(time * 0.83 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-j3coer4mz1tt8e39y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gue44sXxDW5AceuTX/art.json b/art/gue44sXxDW5AceuTX/art.json index c226919f..1ce81cd2 100644 --- a/art/gue44sXxDW5AceuTX/art.json +++ b/art/gue44sXxDW5AceuTX/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jonaced", "avatarUrl": "https://secure.gravatar.com/avatar/4afc7bbaa73d3ae5795519659259854b?default=retro&size=200", - "settings": "{\"num\":802,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9725490196078431,0.9725490196078431,0.9725490196078431,1],\"shader\":\"void main() \\n{\\n float tamCirculo = 400.0;\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n // Radianes de 360 da pi\\n // El 20 son los puntos necesarios para el círculo.\\n float angle = x / tamCirculo * radians(360.0);\\n float radius = y + 3.0;\\n \\n float ux = radius * cos(angle);\\n float vy = radius * sin(angle);\\n \\n vec2 xy = vec2(ux *abs(cos(time)), vy * abs(sin(time))) * 0.1;\\n //vec2 xy = vec2(ux, vy) * 0.1;\\n \\n \\n // Donde debería estar el vértice\\n gl_Position = vec4(xy, 0, 1.0);\\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\\n gl_PointSize = 3.0;\\n}\\n\\n/*\\nvoid main() \\n{\\n float width = 210.0;\\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n float line = vertexId/vertexCount;\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.1) * 0.2;\\n float yOffset = sin(time + x * 0.1) * 0.2 + 1.0;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n \\n // Donde debería estar el vértice\\n gl_Position = vec4(ux, vy, sin(time), 1.0);\\n // Para color, vector 4\\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\\n \\n // Cambiar el tamaño de los puntos\\n gl_PointSize = 3.0;\\n \\n}\\n*/\\n\\n\\n\\n/*\\nLo del profe\\nvoid main() \\n{\\n float width = 20.0;\\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n float line = vertexId/vertexCount;\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n \\n // Donde debería estar el vértice\\n gl_Position = vec4(ux, vy, 0, 1.0);\\n // Para color, vector 4\\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\\n \\n // Cambiar el tamaño de los puntos\\n gl_PointSize = 10.0;\\n \\n}\\n*/\\n\\n\\n/*\\nTriangulo strip 1\\nvoid main() \\n{\\n float width = 2.0;\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n //float y = floor(vertexId / width);\\n \\n float u = x / 1.0;\\n float v = y / 1.0;\\n \\n float tamano = 1.0 / vertexCount;\\n \\n float ux = u * 0.1;\\n float vy = v * 0.1;\\n \\n \\n // Donde debería estar el vértice\\n gl_Position = vec4(ux, vy, 0, 1.0);\\n // Para color, vector 4\\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\\n \\n // Cambiar el tamaño de los puntos\\n gl_PointSize = 1.0;\\n \\n}\\n\\n*/\"}", + "settings": { + "num": 802, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9725490196078431, + 0.9725490196078431, + 0.9725490196078431, + 1 + ], + "shader": "void main() \n{\n float tamCirculo = 400.0;\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n // Radianes de 360 da pi\n // El 20 son los puntos necesarios para el círculo.\n float angle = x / tamCirculo * radians(360.0);\n float radius = y + 3.0;\n \n float ux = radius * cos(angle);\n float vy = radius * sin(angle);\n \n vec2 xy = vec2(ux *abs(cos(time)), vy * abs(sin(time))) * 0.1;\n //vec2 xy = vec2(ux, vy) * 0.1;\n \n \n // Donde debería estar el vértice\n gl_Position = vec4(xy, 0, 1.0);\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\n gl_PointSize = 3.0;\n}\n\n/*\nvoid main() \n{\n float width = 210.0;\n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n float line = vertexId/vertexCount;\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.1) * 0.2;\n float yOffset = sin(time + x * 0.1) * 0.2 + 1.0;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n \n // Donde debería estar el vértice\n gl_Position = vec4(ux, vy, sin(time), 1.0);\n // Para color, vector 4\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\n \n // Cambiar el tamaño de los puntos\n gl_PointSize = 3.0;\n \n}\n*/\n\n\n\n/*\nLo del profe\nvoid main() \n{\n float width = 20.0;\n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n float line = vertexId/vertexCount;\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n \n // Donde debería estar el vértice\n gl_Position = vec4(ux, vy, 0, 1.0);\n // Para color, vector 4\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\n \n // Cambiar el tamaño de los puntos\n gl_PointSize = 10.0;\n \n}\n*/\n\n\n/*\nTriangulo strip 1\nvoid main() \n{\n float width = 2.0;\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n //float y = floor(vertexId / width);\n \n float u = x / 1.0;\n float v = y / 1.0;\n \n float tamano = 1.0 / vertexCount;\n \n float ux = u * 0.1;\n float vy = v * 0.1;\n \n \n // Donde debería estar el vértice\n gl_Position = vec4(ux, vy, 0, 1.0);\n // Para color, vector 4\n v_color= vec4(sin(time), cos(time), 1.0, 1.0);\n \n // Cambiar el tamaño de los puntos\n gl_PointSize = 1.0;\n \n}\n\n*/" + }, "screenshotURL": "data/images/images-48umvzhu16i3pnh1t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gunbdr7k6M6z5hL8B/art.json b/art/gunbdr7k6M6z5hL8B/art.json index 5e900b86..9b2f8298 100644 --- a/art/gunbdr7k6M6z5hL8B/art.json +++ b/art/gunbdr7k6M6z5hL8B/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "liaminjapan", "avatarUrl": "https://avatars.githubusercontent.com/LiamInJapan?s=200", - "settings": "{\"num\":68578,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12549019607843137,0,0.3411764705882353,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time * 1.1 + x * 0.3) * .2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across; \\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time*1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time*1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 68578, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12549019607843137, + 0, + 0.3411764705882353, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time * 1.1 + x * 0.3) * .2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across; \n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time*1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time*1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-2a9dumc0pkzd0nqua-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gxQFmkRMFP6oHs6Qb/art.json b/art/gxQFmkRMFP6oHs6Qb/art.json index 2b6ac537..d5f5b439 100644 --- a/art/gxQFmkRMFP6oHs6Qb/art.json +++ b/art/gxQFmkRMFP6oHs6Qb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":41002,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"mat2 rotate2D(float x)\\n{\\n float a = sin(x), b = cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main()\\n{\\n float tmp \\t= 2.0 * abs(sin(time * 0.02)) * 10.0;\\n if(1==1){\\n \\ttmp \\t= 4.0 * abs(sin(time * 0.02)) * 10.0;\\n }\\n \\n float posx \\t= (vertexId / vertexCount - 0.5) * 3.0;\\n float posy \\t= fract(posx * tmp);\\n \\n vec2 pos = vec2(posx, posy * sin(posx + time));\\n \\n gl_PointSize \\t= 2.0;\\n gl_Position \\t= vec4(pos, 0.0, 1.0);\\n v_color \\t\\t= vec4(1.0); \\n}\"}", + "settings": { + "num": 41002, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "mat2 rotate2D(float x)\n{\n float a = sin(x), b = cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main()\n{\n float tmp \t= 2.0 * abs(sin(time * 0.02)) * 10.0;\n if(1==1){\n \ttmp \t= 4.0 * abs(sin(time * 0.02)) * 10.0;\n }\n \n float posx \t= (vertexId / vertexCount - 0.5) * 3.0;\n float posy \t= fract(posx * tmp);\n \n vec2 pos = vec2(posx, posy * sin(posx + time));\n \n gl_PointSize \t= 2.0;\n gl_Position \t= vec4(pos, 0.0, 1.0);\n v_color \t\t= vec4(1.0); \n}" + }, "screenshotURL": "data/images/images-n2gix7iwgkccu74dk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gxSjsgjmXdmzAwFJY/art.json b/art/gxSjsgjmXdmzAwFJY/art.json index 04c35731..e07d439f 100644 --- a/art/gxSjsgjmXdmzAwFJY/art.json +++ b/art/gxSjsgjmXdmzAwFJY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const float speed = 0.2;\\n\\nvoid main() {\\n vec4 position = \\n vec4(1.25 * abs(cos(time * speed) * -sin(time * speed)) * cos(speed * time + vertexId), \\n vertexId/vertexCount*2.0-1.0, \\n 0.0, 1.0);\\n gl_PointSize = vertexId/vertexCount * 5.0;\\n gl_Position = position;\\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const float speed = 0.2;\n\nvoid main() {\n vec4 position = \n vec4(1.25 * abs(cos(time * speed) * -sin(time * speed)) * cos(speed * time + vertexId), \n vertexId/vertexCount*2.0-1.0, \n 0.0, 1.0);\n gl_PointSize = vertexId/vertexCount * 5.0;\n gl_Position = position;\n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-20zgeykxs42b09us7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gxfqzX2z6JLPodtww/art.json b/art/gxfqzX2z6JLPodtww/art.json index 4d825efd..e47b79b6 100644 --- a/art/gxfqzX2z6JLPodtww/art.json +++ b/art/gxfqzX2z6JLPodtww/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06274509803921569,0.13333333333333333,0.27450980392156865,1],\"shader\":\"//Daehyeon Kim\\n//Motion\\n//CS250\\n//Spring, 2022\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06274509803921569, + 0.13333333333333333, + 0.27450980392156865, + 1 + ], + "shader": "//Daehyeon Kim\n//Motion\n//CS250\n//Spring, 2022\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-e6jd2rjpeys8dumpz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gyyeCLrtNBFwdqzD3/art.json b/art/gyyeCLrtNBFwdqzD3/art.json index edf182b5..fc891edb 100644 --- a/art/gyyeCLrtNBFwdqzD3/art.json +++ b/art/gyyeCLrtNBFwdqzD3/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_PointSize = 10.0;\\n \\n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\\n \\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_PointSize = 10.0;\n \n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\n \n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-a1f9hgrzqp0sw34eq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/gyyfnx8KyXiz9QvWn/art.json b/art/gyyfnx8KyXiz9QvWn/art.json index ab771d4f..3d555996 100644 --- a/art/gyyfnx8KyXiz9QvWn/art.json +++ b/art/gyyfnx8KyXiz9QvWn/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "masoud", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocKduENtgZ5YgN-oFXWds5z6iD7S4GtlK8DMGCULeb3_jNsAvHg=s96-c", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/caleesi-sarah-kreis-mbr-sao\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 10000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 06.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 6.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1.5,\\n 0, 0, zNear * zFar * rangeInv * 3., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n return texture2D(sound, vec2(f, delay)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float r = (0.6 + sin(t * 31.0 * TWO_PI) * 0.4);\\n float phi = sin(t * 43.0 * TWO_PI) * PI;\\n float theta = PI * sin(t * 41.0 * PI);\\n float x = cos(phi) * cos(theta);\\n float y = sin(phi) * cos(theta);\\n float z = sin(theta);\\n return r * vec3(x, y, z);\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = sqrt(p.x * p.x + p.y * p.y + p.z * p.z);\\n float h = 0.5; //0.5 + 0.5 * sin(r * TWO_PI + time + p.x);\\n float s = 1.0; // 0.5 + 0.5 * cos(r * TWO_PI + time + p.x);\\n \\n float pulse = sin((time * 0.3 + t * 500.0) * TWO_PI);\\n float v = //max(0.5, sin(r * 3.0 * TWO_PI + time * 0.1 + t * 100.0)) - 0.5)\\n pow(max(0.0, pulse), 5.0)\\n + getSound(0.1, 0.0);\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/sarahkreis/sets/caleesi-sarah-kreis-mbr-sao", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 10000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 06.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 6.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1.5,\n 0, 0, zNear * zFar * rangeInv * 3., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n return texture2D(sound, vec2(f, delay)).a;\n}\n\nvec3 curvePos(float t) {\n float r = (0.6 + sin(t * 31.0 * TWO_PI) * 0.4);\n float phi = sin(t * 43.0 * TWO_PI) * PI;\n float theta = PI * sin(t * 41.0 * PI);\n float x = cos(phi) * cos(theta);\n float y = sin(phi) * cos(theta);\n float z = sin(theta);\n return r * vec3(x, y, z);\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = sqrt(p.x * p.x + p.y * p.y + p.z * p.z);\n float h = 0.5; //0.5 + 0.5 * sin(r * TWO_PI + time + p.x);\n float s = 1.0; // 0.5 + 0.5 * cos(r * TWO_PI + time + p.x);\n \n float pulse = sin((time * 0.3 + t * 500.0) * TWO_PI);\n float v = //max(0.5, sin(r * 3.0 * TWO_PI + time * 0.1 + t * 100.0)) - 0.5)\n pow(max(0.0, pulse), 5.0)\n + getSound(0.1, 0.0);\n \n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1.0);\n}" + }, "screenshotURL": "data/images/images-j1z04sh3qlgivmavm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/gztz5WvpLypyur8Ls/art.json b/art/gztz5WvpLypyur8Ls/art.json index 0d70c3a2..78f3517b 100644 --- a/art/gztz5WvpLypyur8Ls/art.json +++ b/art/gztz5WvpLypyur8Ls/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2985,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.33725490196078434,0.6745098039215687,0.788235294117647,1],\"shader\":\"void main() {\\n\\tgl_Position = vec4(0.0,0.0,0.0,1.0);\\n \\tgl_PointSize = 10.0;\\n \\tv_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 2985, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.33725490196078434, + 0.6745098039215687, + 0.788235294117647, + 1 + ], + "shader": "void main() {\n\tgl_Position = vec4(0.0,0.0,0.0,1.0);\n \tgl_PointSize = 10.0;\n \tv_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-98b83zxz670x08odp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/h2d7j2tEBmEKvpKGQ/art.json b/art/h2d7j2tEBmEKvpKGQ/art.json index 89aab062..81a40dc2 100644 --- a/art/h2d7j2tEBmEKvpKGQ/art.json +++ b/art/h2d7j2tEBmEKvpKGQ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":3985,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Making a Grid Assignment\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(u * u, v * v, 1. - u - v, 1.);\\n}\"}", + "settings": { + "num": 3985, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Making a Grid Assignment\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(u * u, v * v, 1. - u - v, 1.);\n}" + }, "screenshotURL": "data/images/images-c7apur1w6vbxjrc47-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/h3CiR79ZrnrLiiXjZ/art.json b/art/h3CiR79ZrnrLiiXjZ/art.json index 0b62ba4f..f1725d5d 100644 --- a/art/h3CiR79ZrnrLiiXjZ/art.json +++ b/art/h3CiR79ZrnrLiiXjZ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "playdo", "avatarUrl": "https://secure.gravatar.com/avatar/788432c7d38ee9e807aa931c021c8323?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F9e51ee797bb5adf71c7a6b3cdf72ce5d", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12941176470588237,0.1411764705882353,0.19215686274509805,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n \\nvoid main() {\\n \\n float c = vertexCount;\\n float down = floor(sqrt(c));\\n float across = floor(c/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y*0.2) * 0.1;\\n float yoff = sin(time*1.1 + x*0.3) * 0.2;\\n \\n float ux = u*2.-1. + xoff;\\n float vy = v*2.-1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.5;\\n\\n gl_Position = vec4(xy, 0.,1.);\\n \\n float soff = sin(time*1.2 + x*y*.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x/600.;\\n \\n float hue = u*.1 + sin(time*1.3 + v*20.)*.05;\\n float sat = 1.;\\n float val = sin(time*1.4 + v*u*20.)*.5+.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1.);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12941176470588237, + 0.1411764705882353, + 0.19215686274509805, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n \nvoid main() {\n \n float c = vertexCount;\n float down = floor(sqrt(c));\n float across = floor(c/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y*0.2) * 0.1;\n float yoff = sin(time*1.1 + x*0.3) * 0.2;\n \n float ux = u*2.-1. + xoff;\n float vy = v*2.-1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.5;\n\n gl_Position = vec4(xy, 0.,1.);\n \n float soff = sin(time*1.2 + x*y*.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x/600.;\n \n float hue = u*.1 + sin(time*1.3 + v*20.)*.05;\n float sat = 1.;\n float val = sin(time*1.4 + v*u*20.)*.5+.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1.);\n\n}" + }, "screenshotURL": "data/images/images-wdy76pizzte4e1pj7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/h3FP6QYiZoQbwACiy/art.json b/art/h3FP6QYiZoQbwACiy/art.json index a8235aec..a59d0086 100644 --- a/art/h3FP6QYiZoQbwACiy/art.json +++ b/art/h3FP6QYiZoQbwACiy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "leonzh2k", "avatarUrl": "https://avatars.githubusercontent.com/leonzh2k?s=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-imgr23eov7ch5ye84-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/h4dmaWw9awheH5EG6/art.json b/art/h4dmaWw9awheH5EG6/art.json index 599f8624..8fbedcd0 100644 --- a/art/h4dmaWw9awheH5EG6/art.json +++ b/art/h4dmaWw9awheH5EG6/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "amousa", "avatarUrl": "https://secure.gravatar.com/avatar/56dbb51128cd65d4867bc57e4afd88ab?default=retro&size=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/brandxmusic/climbing-high-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n \\n \\n float xoffset = (sin(time+ y *0.1)*0.3);\\n float yoffset = (cos(time+ x *0.1)*0.9);\\n\\n float ux = u * 2. - 1. ;\\n float vy = v * 2. - 1. ;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 15.0 / across;\\n gl_PointSize *= resolution.x / 600.0 * (((sin(0.6*time) + 1.0) / 2.0))+0.5;\\n\\n v_color = vec4((sin(0.5*time) + 1.0)/2.0 , (cos(0.4*time) + 1.0)/2.0,0.2, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/brandxmusic/climbing-high-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n \n \n float xoffset = (sin(time+ y *0.1)*0.3);\n float yoffset = (cos(time+ x *0.1)*0.9);\n\n float ux = u * 2. - 1. ;\n float vy = v * 2. - 1. ;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 15.0 / across;\n gl_PointSize *= resolution.x / 600.0 * (((sin(0.6*time) + 1.0) / 2.0))+0.5;\n\n v_color = vec4((sin(0.5*time) + 1.0)/2.0 , (cos(0.4*time) + 1.0)/2.0,0.2, 1);\n}" + }, "screenshotURL": "data/images/images-dgmo711z5eg342t6s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/h55dGWLy6iRdoRh3j/art.json b/art/h55dGWLy6iRdoRh3j/art.json index 557e0864..a248694a 100644 --- a/art/h55dGWLy6iRdoRh3j/art.json +++ b/art/h55dGWLy6iRdoRh3j/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richarddevine/strum-modular-patch\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/*\\n point cloud vs spheres by Kabuto remix by Macro Machines\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 1.0\\n#define SND 1.5\\n#define SND2 1.0\\n#define BPM 172.0\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.1492;\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5;\\n float l = length(posf)*1.45;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float tempo = 0.125*time*BPM/60.0;\\n float ramp = fract( tempo*2. );\\n float sine = sin(tempo);\\n float t = time*.10;\\n float i = vertexId+sin(vertexId)*0.10;\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n vec3 colmod = vec3(0.);\\n for (float f = -10.; f < 0.; f++) {\\n \\tfloat nn = f<-5.?0.0001:1.;\\n \\tfloat snd = texture2D(sound,vec2(-f*0.1,i*-f*0.1*nn)).a*SND;\\n\\t \\tofs += push(t+f*.105*snd,i,ofs,2.-exp(-f*.1*snd));\\n \\tofs -= snd*0.2;\\n \\tofs += SND*0.05;\\n \\tofs *= nn;\\n }\\n float snd2 = texture2D(sound,vec2(pos.yz)).a*SND2;\\n snd2*= ramp/sin(time*1.70);//*i;//*0.01;\\n ofs += push(t+snd2,i,ofs,0.999);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *= 1.;\\n pos.z += 0.7;\\n float moddepth = mix(0.2, 0.5, ramp*snd2);\\n pos.xy *= moddepth/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n float size = 1.0/pos.z* 0.1+1.;\\n size = clamp(size, 0.51, 2.0);\\n gl_PointSize = size;\\n \\n //gl_Position.z -= 1.*sine;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richarddevine/strum-modular-patch", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/*\n point cloud vs spheres by Kabuto remix by Macro Machines\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 1.0\n#define SND 1.5\n#define SND2 1.0\n#define BPM 172.0\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.1492;\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5;\n float l = length(posf)*1.45;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float tempo = 0.125*time*BPM/60.0;\n float ramp = fract( tempo*2. );\n float sine = sin(tempo);\n float t = time*.10;\n float i = vertexId+sin(vertexId)*0.10;\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n vec3 colmod = vec3(0.);\n for (float f = -10.; f < 0.; f++) {\n \tfloat nn = f<-5.?0.0001:1.;\n \tfloat snd = texture2D(sound,vec2(-f*0.1,i*-f*0.1*nn)).a*SND;\n\t \tofs += push(t+f*.105*snd,i,ofs,2.-exp(-f*.1*snd));\n \tofs -= snd*0.2;\n \tofs += SND*0.05;\n \tofs *= nn;\n }\n float snd2 = texture2D(sound,vec2(pos.yz)).a*SND2;\n snd2*= ramp/sin(time*1.70);//*i;//*0.01;\n ofs += push(t+snd2,i,ofs,0.999);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *= 1.;\n pos.z += 0.7;\n float moddepth = mix(0.2, 0.5, ramp*snd2);\n pos.xy *= moddepth/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n float size = 1.0/pos.z* 0.1+1.;\n size = clamp(size, 0.51, 2.0);\n gl_PointSize = size;\n \n //gl_Position.z -= 1.*sine;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\n}" + }, "screenshotURL": "data/images/images-r2mgbhgep3kkwy56u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/h5s7DzcTgYKsXec6J/art.json b/art/h5s7DzcTgYKsXec6J/art.json index cda22b02..87186e40 100644 --- a/art/h5s7DzcTgYKsXec6J/art.json +++ b/art/h5s7DzcTgYKsXec6J/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "joshua", "avatarUrl": "https://graph.facebook.com/10154113190027301/picture?type=large", - "settings": "{\"num\":2014,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.17254901960784313,0.1803921568627451,1],\"shader\":\"// GOAL - Replicate all of these https://vimeo.com/83943045\\n\\nvoid main(){\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId,across); // 0,1,2,3,0,1,2,3\\n float y = floor(vertexId / across); // 0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3\\n\\n float u = x / ( across - 1.0);\\n float v = y / ( across - 1.0);\\n \\n float xoff = sin(time + y * 0.32) * 0.001;\\n float yoff = sin(time + y * 0.2) * 0.1;\\n\\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float soff = abs(sin(time + x * y * 0.01)) * 10.;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1.0,vy,ux,1.0);\\n \\n}\"}", + "settings": { + "num": 2014, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.17254901960784313, + 0.1803921568627451, + 1 + ], + "shader": "// GOAL - Replicate all of these https://vimeo.com/83943045\n\nvoid main(){\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId,across); // 0,1,2,3,0,1,2,3\n float y = floor(vertexId / across); // 0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3\n\n float u = x / ( across - 1.0);\n float v = y / ( across - 1.0);\n \n float xoff = sin(time + y * 0.32) * 0.001;\n float yoff = sin(time + y * 0.2) * 0.1;\n\n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float soff = abs(sin(time + x * y * 0.01)) * 10.;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1.0,vy,ux,1.0);\n \n}" + }, "screenshotURL": "data/images/images-3t0jse8ztod6xqlot-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/h6BvsMWiHpgwT5Nhh/art.json b/art/h6BvsMWiHpgwT5Nhh/art.json index 7f6e9a20..a1b5335d 100644 --- a/art/h6BvsMWiHpgwT5Nhh/art.json +++ b/art/h6BvsMWiHpgwT5Nhh/art.json @@ -20,7 +20,19 @@ "origId": null, "name": "pointsprite plasma", "username": "optimus6128", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotDataId": "KCZfc4mKMbFz7BM49", "views": { "$numberInt": "2817" diff --git a/art/h8Ao3xWvFcr2BjkPn/art.json b/art/h8Ao3xWvFcr2BjkPn/art.json index b260fc55..9d9f75f3 100644 --- a/art/h8Ao3xWvFcr2BjkPn/art.json +++ b/art/h8Ao3xWvFcr2BjkPn/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"// Taking control - the moving grid\\n\\nvoid main() {\\n float scale = 1.;\\n float modi = 1.; //0.5 * (sin(time)+1.);\\n float grid = floor(modi * 5.) + 5.;\\n float xoff = -0.5 * scale;\\n float yoff = -0.5 * scale;\\n float x = mod(vertexId , grid);\\n float y = mod(floor(vertexId / grid), grid);\\n float ux = x * scale / grid + xoff;\\n float uy = y * scale / grid + yoff;\\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = 100./grid;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "// Taking control - the moving grid\n\nvoid main() {\n float scale = 1.;\n float modi = 1.; //0.5 * (sin(time)+1.);\n float grid = floor(modi * 5.) + 5.;\n float xoff = -0.5 * scale;\n float yoff = -0.5 * scale;\n float x = mod(vertexId , grid);\n float y = mod(floor(vertexId / grid), grid);\n float ux = x * scale / grid + xoff;\n float uy = y * scale / grid + yoff;\n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = 100./grid;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-5dhjkg0ehm37o0r29-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/h8BkWLf8vzaHjSvsv/art.json b/art/h8BkWLf8vzaHjSvsv/art.json index 0da101da..86bbac6e 100644 --- a/art/h8BkWLf8vzaHjSvsv/art.json +++ b/art/h8BkWLf8vzaHjSvsv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":6230,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Audio Reactive Art exercise\\n//2022 spring\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(300.0);\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1+ x * 0.3) * 0.2; //may can remove last one\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05 ,av * .25 -7.)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump =step(0.8,snd);\\n float hue = u * .1 +snd * 0.2 + time * .1;//+ sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.5,5.),pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 6230, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Audio Reactive Art exercise\n//2022 spring\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(300.0);\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1+ x * 0.3) * 0.2; //may can remove last one\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05 ,av * .25 -7.)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump =step(0.8,snd);\n float hue = u * .1 +snd * 0.2 + time * .1;//+ sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.5,5.),pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-6xrb56s4gj9dyuvuk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hDFNWtShKnbPxsk5g/art.json b/art/hDFNWtShKnbPxsk5g/art.json index 2ea19f19..a538eae2 100644 --- a/art/hDFNWtShKnbPxsk5g/art.json +++ b/art/hDFNWtShKnbPxsk5g/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"http://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n#define kp1 1.//KParameter 0.>>10.\\n#define kp2 2.//KParameter 0.>>5.\\n#define kp3 -.5//KParameter -4.>>22.\\n#define P4 1.//KParameter -1.>>8.\\n//KVertices_Number=10000\\n\\n#define PI radians(222.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 3.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, -1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = .3 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, .21);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 - a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 - a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 + a33 - a23 * a31,\\n b11 = a22 * a33 + a23 / a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 - a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis)*P4;\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0.201/sin(kp1*-snd),\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\\n\\treturn fract(p2.x * p2.y * 95.4337)*12.;\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s +v-s;\\n float z = 0.;\\n pos = vec3(x, y, z-0.25)*s; \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(1.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 3.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 3.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 1.5);\\n mat *= rotZ(ud * PI * 0.4);\\n position = (mat * vec4(p,2)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n float vertexCount = 16677. *kp1;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down + 1.3);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, .60, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .91 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -0.4, -eye.z*.76) * 8.5;\\n vec3 up = vec3(0,0.6,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 7.);\\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * .5);\\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -0.7));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1.1, 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat*snd, val*snd));\\n v_color = vec4(color * (dot(n, lightDir) * 0.165 + 0.5), pow(snd, 3.*P4));\\n v_color.rgb /= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "http://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n#define kp1 1.//KParameter 0.>>10.\n#define kp2 2.//KParameter 0.>>5.\n#define kp3 -.5//KParameter -4.>>22.\n#define P4 1.//KParameter -1.>>8.\n//KVertices_Number=10000\n\n#define PI radians(222.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 3.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, -1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = .3 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 3., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, .21);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 - a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 - a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 + a33 - a23 * a31,\n b11 = a22 * a33 + a23 / a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 - a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis)*P4;\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0.201/sin(kp1*-snd),\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\n\treturn fract(p2.x * p2.y * 95.4337)*12.;\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s +v-s;\n float z = 0.;\n pos = vec3(x, y, z-0.25)*s; \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(1.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 3.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 3.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 1.5);\n mat *= rotZ(ud * PI * 0.4);\n position = (mat * vec4(p,2)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n float vertexCount = 16677. *kp1;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down + 1.3);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, .60, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .91 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -0.4, -eye.z*.76) * 8.5;\n vec3 up = vec3(0,0.6,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 7.);\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * .5);\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -0.7));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1.1, 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat*snd, val*snd));\n v_color = vec4(color * (dot(n, lightDir) * 0.165 + 0.5), pow(snd, 3.*P4));\n v_color.rgb /= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-ewwkarcuf37j1lu2y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hDdt5XinuSqDPHKS9/art.json b/art/hDdt5XinuSqDPHKS9/art.json index 20e980ce..24bcdd68 100644 --- a/art/hDdt5XinuSqDPHKS9/art.json +++ b/art/hDdt5XinuSqDPHKS9/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#45825.0\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n// by @301z\\n// best viewed in 0.5\\n\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n\\n//uniform vec2 vertexResolution;\\n\\n#define rgb(r,g,b) vec3(float(r) / 255.0, float(g) / 255.0, float(b) / 255.0)\\nfloat borderWidth = 1.0 / vertexResolution.y;\\nvec3 borderColor = rgb(32, 32, 32);\\nvec3 hairColor0 = rgb(151, 200, 234);\\nvec3 hairColor1 = rgb(77, 135, 192);\\nvec3 hairColor2 = rgb(58, 103, 151);\\nvec3 faceColor0 = rgb(247, 223, 204);\\nvec3 faceColor1 = rgb(209, 173, 159);\\nvec3 faceColor2 = rgb(180, 148, 133);\\nvec3 eyeColor0 = rgb(145, 164, 176);\\nvec3 eyeColor1 = rgb(207, 216, 218);\\n\\nvec3 eyeColor2 = rgb(255, 255, 255);\\nvec3 eyeColor3 = rgb(0, 0, 0);\\nvec3 eyeColor4 = hairColor0;\\nvec3 eyeColor5 = hairColor2;\\nvec3 eyeColor6 = hairColor1;\\nvec3 mouthColor0 = rgb(78, 53, 40);\\nvec3 mouthColor1 = rgb(152, 78, 69);\\nvec3 mouthColor2 = rgb(170, 92, 83);\\nvec3 backgroundColor = rgb(51, 124, 221);\\n#undef rgb\\n\\nvec2 position() {\\n return vec2((simFragCoord.x - vertexResolution.x), simFragCoord.y) / vertexResolution.y;\\n}\\n\\nfloat cross2(vec2 v0, vec2 v1) {\\n return v0.x * v1.y - v0.y * v1.x;\\n}\\n\\nfloat circle(vec2 centre, float radius) {\\n return distance(centre, position()) - radius;\\n}\\n\\nfloat ellipse(vec2 focus0, vec2 focus1, float radius) {\\n vec2 p = position();\\n return distance(p, focus0) + distance(p, focus1) - distance(focus0, focus1) * radius;\\n}\\n\\nbool inside(float f) {\\n return f < -borderWidth;\\n}\\n\\nbool outside(float f) {\\n return f > borderWidth;\\n}\\n\\nbool hair0(out vec3 color) {\\n float upper = circle(vec2(-1.06, 0.795), 0.64);\\n float lower = circle(vec2(-0.851, -0.011), 1.001);\\n float right = circle(vec2(-0.84, 0.74), 0.5);\\n if (outside(upper) || inside(lower) || inside(right))\\n return false;\\n if (!inside(upper) || !outside(lower))\\n color = borderColor;\\n else {\\n float upper = circle(vec2(-1.01, 0.74), 0.6);\\n float lower = circle(vec2(-1.07, 0.13), 0.77);\\n color = (inside(upper) && outside(lower)) ? hairColor1 : hairColor0;\\n }\\n return true;\\n}\\n\\nbool hair1(out vec3 color) {\\n float upper = circle(vec2(-0.84, 0.74), 0.5);\\n float lower = circle(vec2(-1.8, 1.62), 0.9);\\n if (outside(upper) || outside(lower))\\n return false;\\n color = (inside(upper) && inside(lower)) ? hairColor1 : borderColor;\\n return true;\\n}\\n\\nbool hair2(out vec3 color) {\\n float upper = circle(vec2(-0.695, 0.74), 0.5);\\n float lower = circle(vec2(-3.5, 8.46), 8.1);\\n if (outside(upper) || outside(lower))\\n return false;\\n if (!inside(upper) || !inside(lower))\\n color = borderColor;\\n else {\\n float left = circle(vec2(-0.675, 0.78), 0.502);\\n if (outside(left))\\n color = hairColor0;\\n else {\\n float right = circle(vec2(-1.77, 2.99), 2.4);\\n color = inside(right) ? hairColor1 : hairColor2;\\n }\\n }\\n return true;\\n}\\n\\nbool hair3a(out vec3 color) {\\n float left = circle(vec2(-2.77, 1.86), 2.5);\\n float right = circle(vec2(-1.544, 1.777), 1.44);\\n if (inside(left) || outside(right))\\n return false;\\n color = hairColor1;\\n return true;\\n}\\n\\nbool hair3b(out vec3 color) {\\n float upper = circle(vec2(-2.654, 1.92), 2.39);\\n float lower = circle(vec2(-1.44, 1.777), 1.388);\\n float right = circle(vec2(-0.5, 0.5), 0.515);\\n if (inside(upper) || outside(lower) || outside(right))\\n return false;\\n color = (outside(upper) && inside(lower)) ? hairColor2 : borderColor;\\n return true;\\n}\\n\\nbool hair4a(out vec3 color) {\\n vec2 p0 = vec2(1.332, 0.8), p1 = vec2(-1.5, 0.36);\\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\\n float right = circle(vec2(-0.5, 0.97), 0.78);\\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\\n return false;\\n color = ((upper && inside(left0)) || (!upper && outside(left1))) && inside(right) ? hairColor2 : borderColor;\\n return true;\\n}\\n\\nbool hair4b(out vec3 color) {\\n vec2 p0 = vec2(0.504, 0.91), p1 = vec2(-1.7, 0.25);\\n float r0 = 0.79, r1 = distance(p0, p1) - r0;\\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\\n float right = circle(vec2(-0.62, 0.98), 0.78);\\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\\n return false;\\n color = hairColor1;\\n return true;\\n}\\n\\nbool hair5(out vec3 color) {\\n float left = circle(vec2(1.13, -1.07), 2.02);\\n float right = circle(vec2(-1.505, 1.15), 1.66);\\n if (outside(left) || outside(right))\\n return false;\\n if (!inside(left) || !inside(right))\\n color = borderColor;\\n else {\\n float upper = circle(vec2(1.205, 0.28), 1.58);\\n float lower = circle(vec2(-0.57, 0.78), 0.69);\\n float right = circle(vec2(-1.52, 1.10), 1.6);\\n color = ((inside(upper) && inside(lower)) || outside(right)) ? hairColor2 : hairColor1;\\n }\\n return true;\\n}\\n\\nbool layer0(out vec3 color) {\\n if (hair3a(color))\\n return true;\\n if (hair2(color))\\n return true;\\n if (hair3b(color))\\n return true;\\n if (hair4b(color))\\n return true;\\n if (hair4a(color))\\n return true;\\n if (hair5(color))\\n return true;\\n if (hair1(color))\\n return true;\\n return hair0(color);\\n}\\n\\nbool face0(out vec3 color) {\\n if (inside(circle(vec2(-0.7, 0.0), 0.2)))\\n color = faceColor1;\\n else {\\n vec2 p3 = vec2(-1.02, 0.25);\\n float r3 = 0.41, c3 = circle(p3, r3);\\n vec2 p2 = vec2(-1.12, 0.203);\\n float r2 = r3 - distance(p2, p3), c2 = circle(p2, r2);\\n vec2 p1 = vec2(-2.7, 0.87);\\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\\n vec2 p0 = vec2(-0.5, 0.66);\\n float r0 = distance(p0, p1) - r1, c0 = circle(p0, r0);\\n if (cross2(position() - p0, p1 - p0) > 0.0) {\\n if (outside(c0))\\n return false;\\n color = inside(c0) ? (inside(circle(vec2(-1.8, 1.57), 0.9)) ? faceColor2 : faceColor1) : borderColor;\\n } else if (cross2(position() - p1, p2 - p1) < 0.0) {\\n if (inside(c1))\\n return false;\\n color = outside(c1) ? (((inside(circle(vec2(-0.95, 0.31), 0.49))) && (c1 < 0.035)) ? faceColor0 : faceColor1) : borderColor;\\n } else if (cross2(position() - p2, p3 - p2) < 0.0) {\\n if (outside(c2))\\n return false;\\n color = inside(c2) ? ((c2 > -0.035) ? faceColor0 : faceColor1) : borderColor;\\n } else {\\n if (outside(c3))\\n return false;\\n color = inside(c3) ? ((c3 > -0.035) ? faceColor0 : faceColor1) : borderColor;\\n }\\n }\\n return true;\\n}\\n\\nbool face1(out vec3 color) {\\n float upper = circle(vec2(-0.6, 0.72), 0.5);\\n float lower = circle(vec2(-3.5, 8.004), 7.7);\\n if (outside(upper) || outside(lower))\\n return false;\\n color = faceColor2;\\n return true;\\n}\\n\\nbool face2(out vec3 color) {\\n float upper = circle(vec2(-3.182, 1.75), 2.8);\\n float lower = circle(vec2(-1.44, 1.777), 1.388);\\n if (inside(upper) || outside(lower))\\n return false;\\n color = faceColor2;\\n return true;\\n}\\n\\nbool face3(out vec3 color) {\\n vec2 p0 = vec2(1.332-0.044, 0.8), p1 = vec2(-1.5, 0.36);\\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\\n if ((upper && outside(left0)) || (!upper && inside(left1)))\\n return false;\\n color = faceColor2;\\n return true;\\n}\\n\\nbool layer1(out vec3 color) {\\n if (outside(circle(vec2(-1.2, 0.7), 1.0)))\\n return false;\\n if (face3(color))\\n return true;\\n if (face2(color))\\n return true;\\n if (face1(color))\\n return true;\\n return face0(color);\\n}\\n\\nbool layer2(out vec3 color) {\\n if (inside(circle(vec2(0.0, 0.0), 0.5))) {\\n color = hairColor1;\\n return true;\\n }\\n vec2 p2 = vec2(-0.42, -0.1);\\n float r2 = 1.14, c2 = circle(p2, r2);\\n vec2 p1 = vec2(-3.5, 1.56);\\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\\n bool b1 = inside(circle(vec2(-0.847, 0.5), 0.55));\\n bool b2 = inside(circle(vec2(-0.94, -0.06), 0.56));\\n if (cross2(position() - p1, p2 - p1) < 0.0) {\\n if (inside(c1))\\n return false;\\n color = outside(c1) ? (b1 ? hairColor1 : hairColor0) : borderColor;\\n } else {\\n if (outside(c2))\\n return false;\\n color = inside(c2) ? ((b1 || b2) ? hairColor1 : hairColor0) : borderColor;\\n }\\n return true;\\n}\\n\\nbool leftEye0(out vec3 color) {\\n float top = circle(vec2(-0.866, 0.4899), 0.428);\\n float left = circle(vec2(-0.986, 0.6), 0.3);\\n float bottom = circle(vec2(-1.14, 0.604), 0.2);\\n float right = circle(vec2(-1.54, 0.7), 0.51);\\n if (outside(top) || outside(left) || outside(bottom) || outside(right))\\n return false;\\n if (outside(circle(vec2(-0.919, 0.53), 0.344)))\\n color = borderColor;\\n else if (outside(circle(vec2(-0.918, 0.5), 0.338)))\\n color = eyeColor0;\\n else if (inside(circle(vec2(-1.05, 0.77), 0.1)) && outside(circle(vec2(-1.101, 0.67), 0.08)))\\n color = eyeColor0;\\n else\\n color = eyeColor1;\\n return true;\\n}\\n\\nbool leftEye1(out vec3 color) {\\n if (outside(circle(vec2(-1.0, 0.7), 0.08))\\n || inside(circle(vec2(-1.092, 0.667), 0.1))\\n || inside(circle(vec2(-0.919, 0.8), 0.1)))\\n return false;\\n if (outside(circle(vec2(-1.101, 0.69), 0.1)) && outside(circle(vec2(-0.879, 0.9), 0.2)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool leftEye2(out vec3 color) {\\n if (outside(ellipse(vec2(-1.156, 0.435), vec2(-1.091, 0.75), 1.074)))\\n return false;\\n if (inside(ellipse(vec2(-1.156, 0.636), vec2(-1.122, 0.726), 1.16))) {\\n color = eyeColor2;\\n return true;\\n }\\n if (inside(ellipse(vec2(-1.121, 0.593), vec2(-1.116, 0.614), 1.168))\\n || inside(ellipse(vec2(-1.113, 0.488), vec2(-1.111, 0.505), 1.23))) {\\n color = eyeColor4;\\n return true;\\n }\\n if (inside(ellipse(vec2(-1.154, 0.45), vec2(-1.1, 0.75), 1.05))\\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.552), 1.3))\\n && outside(ellipse(vec2(-1.13, 0.501), vec2(-1.116, 0.614), 1.177))) {\\n color = eyeColor6;\\n return true;\\n } if (inside(ellipse(vec2(-1.152, 0.445), vec2(-1.091, 0.75), 1.067))\\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.565), 1.3))\\n && outside(ellipse(vec2(-1.128, 0.52), vec2(-1.116, 0.614), 1.177))) {\\n color = eyeColor5;\\n return true;\\n }\\n color = eyeColor3;\\n return true;\\n}\\n\\nbool leftEye(out vec3 color) {\\n if (leftEye2(color))\\n return true;\\n if (leftEye1(color))\\n return true;\\n return leftEye0(color);\\n}\\n\\nbool rightEye0(out vec3 color) {\\n if (outside(circle(vec2(-0.609, 0.542), 0.129))\\n && inside(circle(vec2(-0.61, 0.584), 0.101))) {\\n color = borderColor;\\n return true;\\n }\\n if (inside(circle(vec2(-2.654, 1.92), 2.39))\\n || outside(circle(vec2(-0.685, 0.42), 0.285))\\n || inside(circle(vec2(-0.683, 0.432), 0.262))\\n || outside(circle(vec2(-0.638, 0.516), 0.3)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool rightEye1(out vec3 color) {\\n if (outside(circle(vec2(-2.654, 1.92), 2.39))\\n || outside(circle(vec2(-0.627, 0.583), 0.11))\\n || inside(circle(vec2(-0.65, 0.582), 0.11)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool rightEye2(out vec3 color) {\\n if (outside(circle(vec2(-0.57, 0.38), 0.3))\\n || outside(circle(vec2(-0.166, 0.34), 0.59))\\n || outside(circle(vec2(-0.34, 0.6), 0.505))\\n || outside(circle(vec2(-0.47, 0.763), 0.54))\\n || outside(circle(vec2(-0.638, 0.52), 0.3))\\n || outside(circle(vec2(-0.685, 0.42), 0.285)))\\n return false;\\n color = inside(ellipse(vec2(-0.625, 0.23), vec2(-0.59, 0.576), 1.38)) ? eyeColor1 : eyeColor0;\\n return true;\\n}\\n\\nbool rightEye3(out vec3 color) {\\n if (outside(ellipse(vec2(-0.61, 0.29), vec2(-0.538, 0.5844), 1.23)))\\n return false;\\n if (outside(ellipse(vec2(-0.584, 0.355), vec2(-0.56, 0.518), 1.24))\\n && inside(ellipse(vec2(-0.611, 0.31), vec2(-0.574, 0.42), 1.575))\\n && inside(ellipse(vec2(-0.701, 0.09), vec2(-0.58, 0.38), 1.17))) {\\n color = eyeColor6;\\n return true;\\n }\\n if (outside(ellipse(vec2(-0.584, 0.367), vec2(-0.546, 0.518), 1.2))\\n && inside(ellipse(vec2(-0.611, 0.299), vec2(-0.56, 0.48), 1.37))\\n && inside(ellipse(vec2(-0.68, 0.09), vec2(-0.58, 0.42), 1.17))) {\\n color = eyeColor5;\\n return true;\\n }\\n color = eyeColor3;\\n return true;\\n}\\n\\nbool rightEye4(out vec3 color) {\\n if (inside(ellipse(vec2(-0.627, 0.49), vec2(-0.589, 0.583), 1.35))) {\\n color = eyeColor2;\\n return true;\\n }\\n if (inside(circle(vec2(-0.576, 0.445), 0.01)) || inside(circle(vec2(-0.54, 0.32), 0.01))) {\\n color = eyeColor4;\\n return true;\\n }\\n return false;\\n}\\n\\nbool rightEye(out vec3 color) {\\n if (rightEye0(color))\\n return true;\\n if (rightEye1(color))\\n return true;\\n if (rightEye4(color))\\n return true;\\n if (rightEye3(color))\\n return true;\\n return rightEye2(color);\\n}\\n\\nbool layer3(out vec3 color) {\\n if (leftEye(color))\\n return true;\\n return rightEye(color);\\n}\\n\\nbool mouth(out vec3 color) {\\n if (outside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.44)))\\n return false;\\n if (inside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.4))\\n && inside(circle(vec2(-1.04, -0.045), 0.102))) {\\n color = inside(ellipse(vec2(-1.0, -0.09), vec2(-1.092, 0.002), 1.34)) ? mouthColor2 : mouthColor1;\\n return true;\\n }\\n color = mouthColor0;\\n return true;\\n}\\n\\nbool nose(out vec3 color) {\\n if (inside(circle(vec2(-1.061, 0.228), 0.1))\\n && inside(circle(vec2(-1.107, 0.304), 0.019))\\n && outside(circle(vec2(-1.058, 0.29), 0.045))) {\\n color = (inside(circle(vec2(-1.007, 0.31), 0.1)) && outside(circle(vec2(-1.176, 0.379), 0.1))) ? borderColor : faceColor2;\\n return true;\\n }\\n return false;\\n}\\n\\nbool leftEyebrow(out vec3 color) {\\n float c = circle(vec2(-0.85, 0.586), 0.502);\\n if (outside(c) || inside(c) || !inside(circle(vec2(-1.1, 1.072), 0.202)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool rightEyebrow(out vec3 color) {\\n if (inside(circle(vec2(-0.77, 0.42), 0.56)))\\n return false;\\n vec2 p0 = vec2(-0.66, 0.601), p1 = vec2(-0.57, 0.742);\\n float r0 = 0.397, r1 = r0 - distance(p0, p1);\\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\\n float f = cross2(position() - p0, p1 - p0);\\n if ((f < 0.0) ? (outside(c1) || inside(c1)) : (outside(c0) || inside(c0)))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool layer4(out vec3 color) {\\n if (leftEyebrow(color))\\n return true;\\n if (rightEyebrow(color))\\n return true;\\n if (mouth(color))\\n return true;\\n return nose(color);\\n}\\n\\nbool ear0(out vec3 color) {\\n vec2 p0 = vec2(-0.249, 0.192), p1 = vec2(-0.09, 0.25);\\n float r0 = 0.202, r1 = r0 - distance(p0, p1);\\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\\n float c = (cross2(position() - p0, p1 - p0) < 0.0) ? c1 : c0;\\n if (outside(c))\\n return false;\\n color = inside(c) ? faceColor1 : borderColor;\\n return true;\\n}\\n\\nbool ear1(out vec3 color) {\\n vec2 p1 = vec2(-0.155, 0.23), p2 = vec2(-0.11, 0.21);\\n float c1 = circle(vec2(-0.14, 0.397), 0.204);\\n float c2 = circle(p1, 0.06);\\n float e = ellipse(vec2(-0.144, 0.16), vec2(-0.099, 0.235), 1.18);\\n if (outside(c1) || outside(e))\\n return false;\\n if (!inside(e))\\n color = borderColor;\\n else {\\n if (outside(c2))\\n return false;\\n color = (inside(c1) && ((cross2(position() - p1, p2 - p1) < 0.0) || inside(c2))) ? faceColor2 : borderColor;\\n }\\n return true;\\n}\\n\\nbool ear2(out vec3 color) {\\n vec2 p1 = vec2(-0.2, -0.155);\\n float r1 = 0.2, c1 = circle(p1, r1);\\n vec2 p2 = vec2(-0.2, 0.1);\\n float r2 = distance(p1, p2) - r1, c2 = circle(p2, r2);\\n if (cross2(position() - p1, p2 - p1) < 0.0) {\\n if (inside(c1))\\n return false;\\n color = outside(c1) ? faceColor2 : borderColor;\\n } else {\\n vec2 p = vec2(-0.144, 0.156);\\n bool e = inside(ellipse(p, vec2(-0.36, -0.1), 1.04)) || inside(ellipse(p, vec2(-0.36, 0.1), 1.04));\\n if ((cross2(position() - p2, vec2(-0.15, 0.075) - p2) < 0.0)) {\\n if (!e)\\n return false;\\n color = faceColor2;\\n } else if (inside(c2)) {\\n if (!e)\\n return false;\\n color = faceColor2;\\n } else {\\n if (outside(c2))\\n return false;\\n color = borderColor;\\n }\\n }\\n return true;\\n}\\n\\nbool ear3(out vec3 color) {\\n if (inside(circle(vec2(-0.2, -0.155), 0.2)))\\n return false;\\n vec2 p1 = vec2(-0.64, 0.28);\\n float r1 = 0.5, c1 = circle(p1, r1);\\n vec2 p2 = vec2(-0.172, 0.144);\\n float r2 = r1 - distance(p1, p2), c2 = circle(p2, r2);\\n float c = (cross2(position() - p1, p2 - p1) < 0.0) ? c2 : c1;\\n if (inside(c) || outside(c))\\n return false;\\n color = borderColor;\\n return true;\\n}\\n\\nbool layer5(out vec3 color) {\\n if (inside(circle(vec2(-1.505, 1.15), 1.66)))\\n return false;\\n if (ear3(color))\\n return true;\\n if (ear2(color))\\n return true;\\n if (ear1(color))\\n return true;\\n return ear0(color);\\n}\\n\\nbool ikachan(out vec3 color) {\\n if (layer4(color))\\n return true;\\n if (layer0(color))\\n return true;\\n if (layer5(color))\\n return true;\\n if (layer3(color))\\n return true;\\n if (layer1(color))\\n return true;\\n return layer2(color);\\n}\\n\\t\\nvec3 filter(vec3 color) {\\n return color * 0.5 * (2.0 - simFragCoord.x / vertexResolution.x + simFragCoord.y / vertexResolution.y);\\n}\\n\\nvoid main() {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n vec3 color;\\n v_color = vec4(filter(ikachan(color) ? color : backgroundColor), 1.0);\\n}\\n\\n\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#45825.0\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n// by @301z\n// best viewed in 0.5\n\n#ifdef GL_ES\n//precision mediump float;\n#endif\n\n//uniform vec2 vertexResolution;\n\n#define rgb(r,g,b) vec3(float(r) / 255.0, float(g) / 255.0, float(b) / 255.0)\nfloat borderWidth = 1.0 / vertexResolution.y;\nvec3 borderColor = rgb(32, 32, 32);\nvec3 hairColor0 = rgb(151, 200, 234);\nvec3 hairColor1 = rgb(77, 135, 192);\nvec3 hairColor2 = rgb(58, 103, 151);\nvec3 faceColor0 = rgb(247, 223, 204);\nvec3 faceColor1 = rgb(209, 173, 159);\nvec3 faceColor2 = rgb(180, 148, 133);\nvec3 eyeColor0 = rgb(145, 164, 176);\nvec3 eyeColor1 = rgb(207, 216, 218);\n\nvec3 eyeColor2 = rgb(255, 255, 255);\nvec3 eyeColor3 = rgb(0, 0, 0);\nvec3 eyeColor4 = hairColor0;\nvec3 eyeColor5 = hairColor2;\nvec3 eyeColor6 = hairColor1;\nvec3 mouthColor0 = rgb(78, 53, 40);\nvec3 mouthColor1 = rgb(152, 78, 69);\nvec3 mouthColor2 = rgb(170, 92, 83);\nvec3 backgroundColor = rgb(51, 124, 221);\n#undef rgb\n\nvec2 position() {\n return vec2((simFragCoord.x - vertexResolution.x), simFragCoord.y) / vertexResolution.y;\n}\n\nfloat cross2(vec2 v0, vec2 v1) {\n return v0.x * v1.y - v0.y * v1.x;\n}\n\nfloat circle(vec2 centre, float radius) {\n return distance(centre, position()) - radius;\n}\n\nfloat ellipse(vec2 focus0, vec2 focus1, float radius) {\n vec2 p = position();\n return distance(p, focus0) + distance(p, focus1) - distance(focus0, focus1) * radius;\n}\n\nbool inside(float f) {\n return f < -borderWidth;\n}\n\nbool outside(float f) {\n return f > borderWidth;\n}\n\nbool hair0(out vec3 color) {\n float upper = circle(vec2(-1.06, 0.795), 0.64);\n float lower = circle(vec2(-0.851, -0.011), 1.001);\n float right = circle(vec2(-0.84, 0.74), 0.5);\n if (outside(upper) || inside(lower) || inside(right))\n return false;\n if (!inside(upper) || !outside(lower))\n color = borderColor;\n else {\n float upper = circle(vec2(-1.01, 0.74), 0.6);\n float lower = circle(vec2(-1.07, 0.13), 0.77);\n color = (inside(upper) && outside(lower)) ? hairColor1 : hairColor0;\n }\n return true;\n}\n\nbool hair1(out vec3 color) {\n float upper = circle(vec2(-0.84, 0.74), 0.5);\n float lower = circle(vec2(-1.8, 1.62), 0.9);\n if (outside(upper) || outside(lower))\n return false;\n color = (inside(upper) && inside(lower)) ? hairColor1 : borderColor;\n return true;\n}\n\nbool hair2(out vec3 color) {\n float upper = circle(vec2(-0.695, 0.74), 0.5);\n float lower = circle(vec2(-3.5, 8.46), 8.1);\n if (outside(upper) || outside(lower))\n return false;\n if (!inside(upper) || !inside(lower))\n color = borderColor;\n else {\n float left = circle(vec2(-0.675, 0.78), 0.502);\n if (outside(left))\n color = hairColor0;\n else {\n float right = circle(vec2(-1.77, 2.99), 2.4);\n color = inside(right) ? hairColor1 : hairColor2;\n }\n }\n return true;\n}\n\nbool hair3a(out vec3 color) {\n float left = circle(vec2(-2.77, 1.86), 2.5);\n float right = circle(vec2(-1.544, 1.777), 1.44);\n if (inside(left) || outside(right))\n return false;\n color = hairColor1;\n return true;\n}\n\nbool hair3b(out vec3 color) {\n float upper = circle(vec2(-2.654, 1.92), 2.39);\n float lower = circle(vec2(-1.44, 1.777), 1.388);\n float right = circle(vec2(-0.5, 0.5), 0.515);\n if (inside(upper) || outside(lower) || outside(right))\n return false;\n color = (outside(upper) && inside(lower)) ? hairColor2 : borderColor;\n return true;\n}\n\nbool hair4a(out vec3 color) {\n vec2 p0 = vec2(1.332, 0.8), p1 = vec2(-1.5, 0.36);\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\n float right = circle(vec2(-0.5, 0.97), 0.78);\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\n return false;\n color = ((upper && inside(left0)) || (!upper && outside(left1))) && inside(right) ? hairColor2 : borderColor;\n return true;\n}\n\nbool hair4b(out vec3 color) {\n vec2 p0 = vec2(0.504, 0.91), p1 = vec2(-1.7, 0.25);\n float r0 = 0.79, r1 = distance(p0, p1) - r0;\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\n float right = circle(vec2(-0.62, 0.98), 0.78);\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\n if ((upper && outside(left0)) || (!upper && inside(left1)) || outside(right))\n return false;\n color = hairColor1;\n return true;\n}\n\nbool hair5(out vec3 color) {\n float left = circle(vec2(1.13, -1.07), 2.02);\n float right = circle(vec2(-1.505, 1.15), 1.66);\n if (outside(left) || outside(right))\n return false;\n if (!inside(left) || !inside(right))\n color = borderColor;\n else {\n float upper = circle(vec2(1.205, 0.28), 1.58);\n float lower = circle(vec2(-0.57, 0.78), 0.69);\n float right = circle(vec2(-1.52, 1.10), 1.6);\n color = ((inside(upper) && inside(lower)) || outside(right)) ? hairColor2 : hairColor1;\n }\n return true;\n}\n\nbool layer0(out vec3 color) {\n if (hair3a(color))\n return true;\n if (hair2(color))\n return true;\n if (hair3b(color))\n return true;\n if (hair4b(color))\n return true;\n if (hair4a(color))\n return true;\n if (hair5(color))\n return true;\n if (hair1(color))\n return true;\n return hair0(color);\n}\n\nbool face0(out vec3 color) {\n if (inside(circle(vec2(-0.7, 0.0), 0.2)))\n color = faceColor1;\n else {\n vec2 p3 = vec2(-1.02, 0.25);\n float r3 = 0.41, c3 = circle(p3, r3);\n vec2 p2 = vec2(-1.12, 0.203);\n float r2 = r3 - distance(p2, p3), c2 = circle(p2, r2);\n vec2 p1 = vec2(-2.7, 0.87);\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\n vec2 p0 = vec2(-0.5, 0.66);\n float r0 = distance(p0, p1) - r1, c0 = circle(p0, r0);\n if (cross2(position() - p0, p1 - p0) > 0.0) {\n if (outside(c0))\n return false;\n color = inside(c0) ? (inside(circle(vec2(-1.8, 1.57), 0.9)) ? faceColor2 : faceColor1) : borderColor;\n } else if (cross2(position() - p1, p2 - p1) < 0.0) {\n if (inside(c1))\n return false;\n color = outside(c1) ? (((inside(circle(vec2(-0.95, 0.31), 0.49))) && (c1 < 0.035)) ? faceColor0 : faceColor1) : borderColor;\n } else if (cross2(position() - p2, p3 - p2) < 0.0) {\n if (outside(c2))\n return false;\n color = inside(c2) ? ((c2 > -0.035) ? faceColor0 : faceColor1) : borderColor;\n } else {\n if (outside(c3))\n return false;\n color = inside(c3) ? ((c3 > -0.035) ? faceColor0 : faceColor1) : borderColor;\n }\n }\n return true;\n}\n\nbool face1(out vec3 color) {\n float upper = circle(vec2(-0.6, 0.72), 0.5);\n float lower = circle(vec2(-3.5, 8.004), 7.7);\n if (outside(upper) || outside(lower))\n return false;\n color = faceColor2;\n return true;\n}\n\nbool face2(out vec3 color) {\n float upper = circle(vec2(-3.182, 1.75), 2.8);\n float lower = circle(vec2(-1.44, 1.777), 1.388);\n if (inside(upper) || outside(lower))\n return false;\n color = faceColor2;\n return true;\n}\n\nbool face3(out vec3 color) {\n vec2 p0 = vec2(1.332-0.044, 0.8), p1 = vec2(-1.5, 0.36);\n float r0 = 1.7, r1 = distance(p0, p1) - r0;\n float left0 = circle(p0, r0), left1 = circle(p1, r1);\n bool upper = cross2(position() - p1, p0 - p1) < 0.0;\n if ((upper && outside(left0)) || (!upper && inside(left1)))\n return false;\n color = faceColor2;\n return true;\n}\n\nbool layer1(out vec3 color) {\n if (outside(circle(vec2(-1.2, 0.7), 1.0)))\n return false;\n if (face3(color))\n return true;\n if (face2(color))\n return true;\n if (face1(color))\n return true;\n return face0(color);\n}\n\nbool layer2(out vec3 color) {\n if (inside(circle(vec2(0.0, 0.0), 0.5))) {\n color = hairColor1;\n return true;\n }\n vec2 p2 = vec2(-0.42, -0.1);\n float r2 = 1.14, c2 = circle(p2, r2);\n vec2 p1 = vec2(-3.5, 1.56);\n float r1 = distance(p1, p2) - r2, c1 = circle(p1, r1);\n bool b1 = inside(circle(vec2(-0.847, 0.5), 0.55));\n bool b2 = inside(circle(vec2(-0.94, -0.06), 0.56));\n if (cross2(position() - p1, p2 - p1) < 0.0) {\n if (inside(c1))\n return false;\n color = outside(c1) ? (b1 ? hairColor1 : hairColor0) : borderColor;\n } else {\n if (outside(c2))\n return false;\n color = inside(c2) ? ((b1 || b2) ? hairColor1 : hairColor0) : borderColor;\n }\n return true;\n}\n\nbool leftEye0(out vec3 color) {\n float top = circle(vec2(-0.866, 0.4899), 0.428);\n float left = circle(vec2(-0.986, 0.6), 0.3);\n float bottom = circle(vec2(-1.14, 0.604), 0.2);\n float right = circle(vec2(-1.54, 0.7), 0.51);\n if (outside(top) || outside(left) || outside(bottom) || outside(right))\n return false;\n if (outside(circle(vec2(-0.919, 0.53), 0.344)))\n color = borderColor;\n else if (outside(circle(vec2(-0.918, 0.5), 0.338)))\n color = eyeColor0;\n else if (inside(circle(vec2(-1.05, 0.77), 0.1)) && outside(circle(vec2(-1.101, 0.67), 0.08)))\n color = eyeColor0;\n else\n color = eyeColor1;\n return true;\n}\n\nbool leftEye1(out vec3 color) {\n if (outside(circle(vec2(-1.0, 0.7), 0.08))\n || inside(circle(vec2(-1.092, 0.667), 0.1))\n || inside(circle(vec2(-0.919, 0.8), 0.1)))\n return false;\n if (outside(circle(vec2(-1.101, 0.69), 0.1)) && outside(circle(vec2(-0.879, 0.9), 0.2)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool leftEye2(out vec3 color) {\n if (outside(ellipse(vec2(-1.156, 0.435), vec2(-1.091, 0.75), 1.074)))\n return false;\n if (inside(ellipse(vec2(-1.156, 0.636), vec2(-1.122, 0.726), 1.16))) {\n color = eyeColor2;\n return true;\n }\n if (inside(ellipse(vec2(-1.121, 0.593), vec2(-1.116, 0.614), 1.168))\n || inside(ellipse(vec2(-1.113, 0.488), vec2(-1.111, 0.505), 1.23))) {\n color = eyeColor4;\n return true;\n }\n if (inside(ellipse(vec2(-1.154, 0.45), vec2(-1.1, 0.75), 1.05))\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.552), 1.3))\n && outside(ellipse(vec2(-1.13, 0.501), vec2(-1.116, 0.614), 1.177))) {\n color = eyeColor6;\n return true;\n } if (inside(ellipse(vec2(-1.152, 0.445), vec2(-1.091, 0.75), 1.067))\n && inside(ellipse(vec2(-1.163, 0.445), vec2(-1.121, 0.565), 1.3))\n && outside(ellipse(vec2(-1.128, 0.52), vec2(-1.116, 0.614), 1.177))) {\n color = eyeColor5;\n return true;\n }\n color = eyeColor3;\n return true;\n}\n\nbool leftEye(out vec3 color) {\n if (leftEye2(color))\n return true;\n if (leftEye1(color))\n return true;\n return leftEye0(color);\n}\n\nbool rightEye0(out vec3 color) {\n if (outside(circle(vec2(-0.609, 0.542), 0.129))\n && inside(circle(vec2(-0.61, 0.584), 0.101))) {\n color = borderColor;\n return true;\n }\n if (inside(circle(vec2(-2.654, 1.92), 2.39))\n || outside(circle(vec2(-0.685, 0.42), 0.285))\n || inside(circle(vec2(-0.683, 0.432), 0.262))\n || outside(circle(vec2(-0.638, 0.516), 0.3)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool rightEye1(out vec3 color) {\n if (outside(circle(vec2(-2.654, 1.92), 2.39))\n || outside(circle(vec2(-0.627, 0.583), 0.11))\n || inside(circle(vec2(-0.65, 0.582), 0.11)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool rightEye2(out vec3 color) {\n if (outside(circle(vec2(-0.57, 0.38), 0.3))\n || outside(circle(vec2(-0.166, 0.34), 0.59))\n || outside(circle(vec2(-0.34, 0.6), 0.505))\n || outside(circle(vec2(-0.47, 0.763), 0.54))\n || outside(circle(vec2(-0.638, 0.52), 0.3))\n || outside(circle(vec2(-0.685, 0.42), 0.285)))\n return false;\n color = inside(ellipse(vec2(-0.625, 0.23), vec2(-0.59, 0.576), 1.38)) ? eyeColor1 : eyeColor0;\n return true;\n}\n\nbool rightEye3(out vec3 color) {\n if (outside(ellipse(vec2(-0.61, 0.29), vec2(-0.538, 0.5844), 1.23)))\n return false;\n if (outside(ellipse(vec2(-0.584, 0.355), vec2(-0.56, 0.518), 1.24))\n && inside(ellipse(vec2(-0.611, 0.31), vec2(-0.574, 0.42), 1.575))\n && inside(ellipse(vec2(-0.701, 0.09), vec2(-0.58, 0.38), 1.17))) {\n color = eyeColor6;\n return true;\n }\n if (outside(ellipse(vec2(-0.584, 0.367), vec2(-0.546, 0.518), 1.2))\n && inside(ellipse(vec2(-0.611, 0.299), vec2(-0.56, 0.48), 1.37))\n && inside(ellipse(vec2(-0.68, 0.09), vec2(-0.58, 0.42), 1.17))) {\n color = eyeColor5;\n return true;\n }\n color = eyeColor3;\n return true;\n}\n\nbool rightEye4(out vec3 color) {\n if (inside(ellipse(vec2(-0.627, 0.49), vec2(-0.589, 0.583), 1.35))) {\n color = eyeColor2;\n return true;\n }\n if (inside(circle(vec2(-0.576, 0.445), 0.01)) || inside(circle(vec2(-0.54, 0.32), 0.01))) {\n color = eyeColor4;\n return true;\n }\n return false;\n}\n\nbool rightEye(out vec3 color) {\n if (rightEye0(color))\n return true;\n if (rightEye1(color))\n return true;\n if (rightEye4(color))\n return true;\n if (rightEye3(color))\n return true;\n return rightEye2(color);\n}\n\nbool layer3(out vec3 color) {\n if (leftEye(color))\n return true;\n return rightEye(color);\n}\n\nbool mouth(out vec3 color) {\n if (outside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.44)))\n return false;\n if (inside(ellipse(vec2(-1.01, -0.04), vec2(-1.095, 0.02), 1.4))\n && inside(circle(vec2(-1.04, -0.045), 0.102))) {\n color = inside(ellipse(vec2(-1.0, -0.09), vec2(-1.092, 0.002), 1.34)) ? mouthColor2 : mouthColor1;\n return true;\n }\n color = mouthColor0;\n return true;\n}\n\nbool nose(out vec3 color) {\n if (inside(circle(vec2(-1.061, 0.228), 0.1))\n && inside(circle(vec2(-1.107, 0.304), 0.019))\n && outside(circle(vec2(-1.058, 0.29), 0.045))) {\n color = (inside(circle(vec2(-1.007, 0.31), 0.1)) && outside(circle(vec2(-1.176, 0.379), 0.1))) ? borderColor : faceColor2;\n return true;\n }\n return false;\n}\n\nbool leftEyebrow(out vec3 color) {\n float c = circle(vec2(-0.85, 0.586), 0.502);\n if (outside(c) || inside(c) || !inside(circle(vec2(-1.1, 1.072), 0.202)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool rightEyebrow(out vec3 color) {\n if (inside(circle(vec2(-0.77, 0.42), 0.56)))\n return false;\n vec2 p0 = vec2(-0.66, 0.601), p1 = vec2(-0.57, 0.742);\n float r0 = 0.397, r1 = r0 - distance(p0, p1);\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\n float f = cross2(position() - p0, p1 - p0);\n if ((f < 0.0) ? (outside(c1) || inside(c1)) : (outside(c0) || inside(c0)))\n return false;\n color = borderColor;\n return true;\n}\n\nbool layer4(out vec3 color) {\n if (leftEyebrow(color))\n return true;\n if (rightEyebrow(color))\n return true;\n if (mouth(color))\n return true;\n return nose(color);\n}\n\nbool ear0(out vec3 color) {\n vec2 p0 = vec2(-0.249, 0.192), p1 = vec2(-0.09, 0.25);\n float r0 = 0.202, r1 = r0 - distance(p0, p1);\n float c0 = circle(p0, r0), c1 = circle(p1, r1);\n float c = (cross2(position() - p0, p1 - p0) < 0.0) ? c1 : c0;\n if (outside(c))\n return false;\n color = inside(c) ? faceColor1 : borderColor;\n return true;\n}\n\nbool ear1(out vec3 color) {\n vec2 p1 = vec2(-0.155, 0.23), p2 = vec2(-0.11, 0.21);\n float c1 = circle(vec2(-0.14, 0.397), 0.204);\n float c2 = circle(p1, 0.06);\n float e = ellipse(vec2(-0.144, 0.16), vec2(-0.099, 0.235), 1.18);\n if (outside(c1) || outside(e))\n return false;\n if (!inside(e))\n color = borderColor;\n else {\n if (outside(c2))\n return false;\n color = (inside(c1) && ((cross2(position() - p1, p2 - p1) < 0.0) || inside(c2))) ? faceColor2 : borderColor;\n }\n return true;\n}\n\nbool ear2(out vec3 color) {\n vec2 p1 = vec2(-0.2, -0.155);\n float r1 = 0.2, c1 = circle(p1, r1);\n vec2 p2 = vec2(-0.2, 0.1);\n float r2 = distance(p1, p2) - r1, c2 = circle(p2, r2);\n if (cross2(position() - p1, p2 - p1) < 0.0) {\n if (inside(c1))\n return false;\n color = outside(c1) ? faceColor2 : borderColor;\n } else {\n vec2 p = vec2(-0.144, 0.156);\n bool e = inside(ellipse(p, vec2(-0.36, -0.1), 1.04)) || inside(ellipse(p, vec2(-0.36, 0.1), 1.04));\n if ((cross2(position() - p2, vec2(-0.15, 0.075) - p2) < 0.0)) {\n if (!e)\n return false;\n color = faceColor2;\n } else if (inside(c2)) {\n if (!e)\n return false;\n color = faceColor2;\n } else {\n if (outside(c2))\n return false;\n color = borderColor;\n }\n }\n return true;\n}\n\nbool ear3(out vec3 color) {\n if (inside(circle(vec2(-0.2, -0.155), 0.2)))\n return false;\n vec2 p1 = vec2(-0.64, 0.28);\n float r1 = 0.5, c1 = circle(p1, r1);\n vec2 p2 = vec2(-0.172, 0.144);\n float r2 = r1 - distance(p1, p2), c2 = circle(p2, r2);\n float c = (cross2(position() - p1, p2 - p1) < 0.0) ? c2 : c1;\n if (inside(c) || outside(c))\n return false;\n color = borderColor;\n return true;\n}\n\nbool layer5(out vec3 color) {\n if (inside(circle(vec2(-1.505, 1.15), 1.66)))\n return false;\n if (ear3(color))\n return true;\n if (ear2(color))\n return true;\n if (ear1(color))\n return true;\n return ear0(color);\n}\n\nbool ikachan(out vec3 color) {\n if (layer4(color))\n return true;\n if (layer0(color))\n return true;\n if (layer5(color))\n return true;\n if (layer3(color))\n return true;\n if (layer1(color))\n return true;\n return layer2(color);\n}\n\t\nvec3 filter(vec3 color) {\n return color * 0.5 * (2.0 - simFragCoord.x / vertexResolution.x + simFragCoord.y / vertexResolution.y);\n}\n\nvoid main() {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n vec3 color;\n v_color = vec4(filter(ikachan(color) ? color : backgroundColor), 1.0);\n}\n\n" + }, "screenshotURL": "data/images/images-5tuvnoje2dgz60iag-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hDtJF6ShctCpNfZNt/art.json b/art/hDtJF6ShctCpNfZNt/art.json index 3126a2af..68a194e5 100644 --- a/art/hDtJF6ShctCpNfZNt/art.json +++ b/art/hDtJF6ShctCpNfZNt/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "andros", "avatarUrl": "https://graph.facebook.com/10154858869027420/picture?type=large", - "settings": "{\"num\":999,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n gl_Position = vec4(vertexId/vertexCount*2.-1., sin(vertexId*mod(vertexId,9.)+time), 0, 1 );\\n v_color = vec4(0,1,0,1)\\n}\"}", + "settings": { + "num": 999, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n gl_Position = vec4(vertexId/vertexCount*2.-1., sin(vertexId*mod(vertexId,9.)+time), 0, 1 );\n v_color = vec4(0,1,0,1)\n}" + }, "screenshotURL": "data/images/images-7buyoxarbbs0ogfpa-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hFWjmNANJteP9NeAy/art.json b/art/hFWjmNANJteP9NeAy/art.json index 0c55ca76..23d64d1b 100644 --- a/art/hFWjmNANJteP9NeAy/art.json +++ b/art/hFWjmNANJteP9NeAy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 12;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 666. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.5 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 12;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 666. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.5 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\n}\n" + }, "screenshotURL": "data/images/images-u838bv1blw0dzxxin-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hGb3X2yH769jCbfDy/art.json b/art/hGb3X2yH769jCbfDy/art.json index 25bcbcf2..e6552d92 100644 --- a/art/hGb3X2yH769jCbfDy/art.json +++ b/art/hGb3X2yH769jCbfDy/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gaz", "avatarUrl": "https://secure.gravatar.com/avatar/1383190fac8e70cb725c3d76dbc811ba?default=retro&size=200", - "settings": "{\"num\":14680,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.011764705882352941,0.3607843137254902,0.47843137254901963,1],\"shader\":\"// http://jsdo.it/gaziya/zQos\\n\\n#define PI 3.14159265359\\n#define PI2 ( PI * 2.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n//https://www.shadertoy.com/view/ltXGW2 \\nvec3 gc1,gs1,gc2,gs2,gc3,gs3;\\nfloat freq2;\\n//knot's from dr2 @ https://www.shadertoy.com/view/4ts3zl\\nvoid InitCurve(float tm){\\n\\tfloat t=1.0+sin(tm);\\n\\tfreq2=mix(2.0,5.0,clamp(t-1.0,0.0,1.0));\\n\\tgc1 = mix(vec3 ( 41, 36, 0), mix(vec3 ( 32, 94, 16),vec3 ( -22, 11, 0),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\\n\\tgs1 = mix(vec3 (-18, 27, 45),mix(vec3 ( -51, 41, 73),vec3 (-128, 0, 0),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\\n\\tgc2 = mix(vec3 (-83, -113, -30),mix(vec3 (-104, 113, -211),vec3 ( 0, 34, 8),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\\n\\tgs2 = mix(vec3 (-83, 30, 113),mix(vec3 ( -34, 0, -39),vec3 ( 0, -39, -9),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\\n\\tgc3 = mix(vec3 (-11, 11, -11),mix(vec3 ( 104, -68, -99),vec3 ( -44, -43, 70),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\\n\\tgs3 = mix(vec3 ( 27, -27, 27),mix(vec3 ( -91, -124, -21),vec3 ( -78, 0, -40),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\\n}\\nvec3 F (float a) //dr2's knots\\n{\\n\\treturn (gc1 * cos (a) + gs1 * sin (a) +\\n\\t\\tgc2 * cos (freq2 * a) + gs2 * sin (freq2 * a) +\\n\\t\\tgc3 * cos (3. * a) + gs3 * sin (3. * a))*0.01;\\n}\\n/////////\\n\\n\\nvec3 func(in float a) {\\n InitCurve(time);\\n return F(a * PI2);\\n} \\n \\nvec4 quaternion(in vec3 axis, in float theta) {\\n return vec4(axis * sin(theta / 2.0), cos(theta / 2.0));\\n}\\n\\nvec3 qTransform(in vec4 q, in vec3 v) {\\n return v + 2.0 * cross(cross(v, q.xyz) - q.w * v, q.xyz);\\n}\\n\\nvec3 map(in vec2 uv) {\\n const float r = 0.15;\\n vec3 coord = func(uv.y);\\n vec3 delta = normalize(func(uv.y + 0.01) - func(uv.y - 0.01));\\n vec4 q = quaternion(delta, uv.x * PI2);\\n vec3 p = normalize(cross(\\n func(uv.y + 0.01) - coord,\\n func(uv.y - 0.01) - coord\\n )) * r;\\n return coord + qTransform(q, p);\\n} \\n \\nvec3 normal(in vec2 p) {\\n vec2 e = vec2(0.001, 0.0);\\n return normalize(cross(\\n map(p + e) - map(p - e),\\n map(p + e.yx) - map(p - e.yx)\\n ));\\n}\\n \\nmat4 perspective(in float fovy, in float aspect, in float near, in float far)\\n{\\n float top = near * tan(fovy * PI / 360.0);\\n float right = top * aspect;\\n float u = right * 2.0;\\n float v = top * 2.0;\\n float w = far - near;\\n return mat4(\\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \\n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \\n -(far + near) / w, -1.0, 0.0, 0.0,\\n -(far * near * 2.0) / w, 0.0\\n ); \\n}\\n\\nmat2 rotate(in float a) {\\n\\treturn mat2(cos(a), sin(a), -sin(a), cos(a));\\t\\n}\\n\\nvoid main() {\\n float a = floor(vertexId / 6.0);\\n float b = abs(3.0 - mod(vertexId, 6.0));\\n \\tfloat polyCount = vertexCount/6.0;\\n \\tvec2 dim = floor(vec2(sqrt(polyCount/8.0), sqrt(polyCount*8.0)));\\n \\t//vec2 dim = vec2(32, 256); //vertexCount = 49152\\n vec2 p = vec2(mod(a, dim.x), floor(a / dim.x));\\n vec2 offset = vec2(mod(b, 2.0), floor(b / 2.0));\\n vec2 uv = (p + offset) / dim;\\n vec3 pos = map(uv);\\n vec3 nor = normal(uv);\\n float t = time * 1.2;\\n pos.xz *= rotate(t); \\n nor.xz *= rotate(t);\\n mat4 vMatrix = mat4(1.0);\\n vMatrix[3].z = -8.0; \\n \\tmat4 pMatrix = perspective(45.0, resolution.x / resolution.y, 0.1, 100.0);\\n gl_Position = pMatrix * vMatrix * vec4(pos, 1.0);\\n vec3 light = normalize(vec3(0.2, 0.3, 1.0));\\n \\tvec3 col = hsv2rgb(vec3(time * 0.03, 0.8, 1.0));\\n \\tcol *= max(dot(light, nor), 0.2);\\n col += pow(max(dot(vec3(0, 0, 1), reflect(-light, nor)), 0.0), 50.0);\\n col = pow(col, vec3(0.8)); \\n \\tv_color = vec4(col,1.0);\\n}\\n\"}", + "settings": { + "num": 14680, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "CSS", + "backgroundColor": [ + 0.011764705882352941, + 0.3607843137254902, + 0.47843137254901963, + 1 + ], + "shader": "// http://jsdo.it/gaziya/zQos\n\n#define PI 3.14159265359\n#define PI2 ( PI * 2.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n//https://www.shadertoy.com/view/ltXGW2 \nvec3 gc1,gs1,gc2,gs2,gc3,gs3;\nfloat freq2;\n//knot's from dr2 @ https://www.shadertoy.com/view/4ts3zl\nvoid InitCurve(float tm){\n\tfloat t=1.0+sin(tm);\n\tfreq2=mix(2.0,5.0,clamp(t-1.0,0.0,1.0));\n\tgc1 = mix(vec3 ( 41, 36, 0), mix(vec3 ( 32, 94, 16),vec3 ( -22, 11, 0),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\n\tgs1 = mix(vec3 (-18, 27, 45),mix(vec3 ( -51, 41, 73),vec3 (-128, 0, 0),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\n\tgc2 = mix(vec3 (-83, -113, -30),mix(vec3 (-104, 113, -211),vec3 ( 0, 34, 8),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\n\tgs2 = mix(vec3 (-83, 30, 113),mix(vec3 ( -34, 0, -39),vec3 ( 0, -39, -9),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\n\tgc3 = mix(vec3 (-11, 11, -11),mix(vec3 ( 104, -68, -99),vec3 ( -44, -43, 70),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\n\tgs3 = mix(vec3 ( 27, -27, 27),mix(vec3 ( -91, -124, -21),vec3 ( -78, 0, -40),clamp(t-1.0,0.0,1.0)),clamp(t,0.0,1.0));\n}\nvec3 F (float a) //dr2's knots\n{\n\treturn (gc1 * cos (a) + gs1 * sin (a) +\n\t\tgc2 * cos (freq2 * a) + gs2 * sin (freq2 * a) +\n\t\tgc3 * cos (3. * a) + gs3 * sin (3. * a))*0.01;\n}\n/////////\n\n\nvec3 func(in float a) {\n InitCurve(time);\n return F(a * PI2);\n} \n \nvec4 quaternion(in vec3 axis, in float theta) {\n return vec4(axis * sin(theta / 2.0), cos(theta / 2.0));\n}\n\nvec3 qTransform(in vec4 q, in vec3 v) {\n return v + 2.0 * cross(cross(v, q.xyz) - q.w * v, q.xyz);\n}\n\nvec3 map(in vec2 uv) {\n const float r = 0.15;\n vec3 coord = func(uv.y);\n vec3 delta = normalize(func(uv.y + 0.01) - func(uv.y - 0.01));\n vec4 q = quaternion(delta, uv.x * PI2);\n vec3 p = normalize(cross(\n func(uv.y + 0.01) - coord,\n func(uv.y - 0.01) - coord\n )) * r;\n return coord + qTransform(q, p);\n} \n \nvec3 normal(in vec2 p) {\n vec2 e = vec2(0.001, 0.0);\n return normalize(cross(\n map(p + e) - map(p - e),\n map(p + e.yx) - map(p - e.yx)\n ));\n}\n \nmat4 perspective(in float fovy, in float aspect, in float near, in float far)\n{\n float top = near * tan(fovy * PI / 360.0);\n float right = top * aspect;\n float u = right * 2.0;\n float v = top * 2.0;\n float w = far - near;\n return mat4(\n near * 2.0 / u, 0.0, 0.0, 0.0, 0.0, \n near * 2.0 / v, 0.0, 0.0, 0.0, 0.0, \n -(far + near) / w, -1.0, 0.0, 0.0,\n -(far * near * 2.0) / w, 0.0\n ); \n}\n\nmat2 rotate(in float a) {\n\treturn mat2(cos(a), sin(a), -sin(a), cos(a));\t\n}\n\nvoid main() {\n float a = floor(vertexId / 6.0);\n float b = abs(3.0 - mod(vertexId, 6.0));\n \tfloat polyCount = vertexCount/6.0;\n \tvec2 dim = floor(vec2(sqrt(polyCount/8.0), sqrt(polyCount*8.0)));\n \t//vec2 dim = vec2(32, 256); //vertexCount = 49152\n vec2 p = vec2(mod(a, dim.x), floor(a / dim.x));\n vec2 offset = vec2(mod(b, 2.0), floor(b / 2.0));\n vec2 uv = (p + offset) / dim;\n vec3 pos = map(uv);\n vec3 nor = normal(uv);\n float t = time * 1.2;\n pos.xz *= rotate(t); \n nor.xz *= rotate(t);\n mat4 vMatrix = mat4(1.0);\n vMatrix[3].z = -8.0; \n \tmat4 pMatrix = perspective(45.0, resolution.x / resolution.y, 0.1, 100.0);\n gl_Position = pMatrix * vMatrix * vec4(pos, 1.0);\n vec3 light = normalize(vec3(0.2, 0.3, 1.0));\n \tvec3 col = hsv2rgb(vec3(time * 0.03, 0.8, 1.0));\n \tcol *= max(dot(light, nor), 0.2);\n col += pow(max(dot(vec3(0, 0, 1), reflect(-light, nor)), 0.0), 50.0);\n col = pow(col, vec3(0.8)); \n \tv_color = vec4(col,1.0);\n}\n" + }, "screenshotURL": "data/images/images-zfzfyo0zrl0msrsq9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hGiSXNAT8jpQc5o3a/art.json b/art/hGiSXNAT8jpQc5o3a/art.json index adcb48ac..cffaccfc 100644 --- a/art/hGiSXNAT8jpQc5o3a/art.json +++ b/art/hGiSXNAT8jpQc5o3a/art.json @@ -28,7 +28,19 @@ "name": "the flames of sleng teng", "private": false, "username": "visy", - "settings": "{\"num\":62776,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/finntengs/tuhannen-markan-finnteng\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float ltime = time*0.2;\\n float NUM_SEGMENTS = 512.0;\\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\\n float STEP = 0.5+0.4*cos(ltime);\\n float NUM_LINES_DOWN = 512.0+180.*cos(ltime);\\n\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN*15.0-ltime*0.1; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.35;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0+0.1*cos(v+point*snd*0.1);\\n float y = v * 2.0 - 1.0+0.1*sin(u+point*snd*0.1);\\n vec2 xy = vec2(\\n x * mix(0.0, 14.0, invV+0.3*cos(ltime*0.5)),\\n y + pow(snd, 2.0) * 4.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 2);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 62776, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/finntengs/tuhannen-markan-finnteng", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float ltime = time*0.2;\n float NUM_SEGMENTS = 512.0;\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\n float STEP = 0.5+0.4*cos(ltime);\n float NUM_LINES_DOWN = 512.0+180.*cos(ltime);\n\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN*15.0-ltime*0.1; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.35;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0+0.1*cos(v+point*snd*0.1);\n float y = v * 2.0 - 1.0+0.1*sin(u+point*snd*0.1);\n vec2 xy = vec2(\n x * mix(0.0, 14.0, invV+0.3*cos(ltime*0.5)),\n y + pow(snd, 2.0) * 4.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 2);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-6ulgxiduracoqi5p2-thumbnail.jpg", "views": { "$numberInt": "247" diff --git a/art/hJ9T5D48jyNh2Ziaf/art.json b/art/hJ9T5D48jyNh2Ziaf/art.json index f73d0011..35bbec89 100644 --- a/art/hJ9T5D48jyNh2Ziaf/art.json +++ b/art/hJ9T5D48jyNh2Ziaf/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":23285,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p) { return fract(fract(p*5.3983)*fract(p*.4427)*95.4337); }\\nvec2 r(vec2 p,float a) { return vec2(-1,1)*p.yx*sin(a)+p.xy*cos(a); }\\nvoid main() { float t=time, o=resolution.x/resolution.y, s=vertexId+t;\\n vec3 b=abs((fract(vec3(.25,.5,.125)*t)-.5)*2.), u=1.-step(.5,b)*2.,\\n a=(pow(vec3(2.),(40.*b-20.)*u)*u-u+1.)*.5,p=vec3(h(s),h(s*.731),h(s*1.319))*2.-1.,\\n d=1.-step(vec3(1,2,3),vec3(h(s*0.911)*3.)), v=d-vec3(0,d.xy);\\n p=mix(step(0.,p)*2.-1.,p,mix(1.-v,v,a.y));\\n p*=mix(1./length(p),1.,dot(a,p)*a.z-sin(t*.2)*2.*(a.x+.5));\\n p.xy=r(p.xy,t*.2+a.x*.2);p.xz=r(p.xz,t*.3+a.y);\\n v_color=vec4(a*.8+.2,1.); gl_Position=vec4(p.x,p.y*o,p.z,p.z+5.); gl_PointSize=2.;}\"}", + "settings": { + "num": 23285, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p) { return fract(fract(p*5.3983)*fract(p*.4427)*95.4337); }\nvec2 r(vec2 p,float a) { return vec2(-1,1)*p.yx*sin(a)+p.xy*cos(a); }\nvoid main() { float t=time, o=resolution.x/resolution.y, s=vertexId+t;\n vec3 b=abs((fract(vec3(.25,.5,.125)*t)-.5)*2.), u=1.-step(.5,b)*2.,\n a=(pow(vec3(2.),(40.*b-20.)*u)*u-u+1.)*.5,p=vec3(h(s),h(s*.731),h(s*1.319))*2.-1.,\n d=1.-step(vec3(1,2,3),vec3(h(s*0.911)*3.)), v=d-vec3(0,d.xy);\n p=mix(step(0.,p)*2.-1.,p,mix(1.-v,v,a.y));\n p*=mix(1./length(p),1.,dot(a,p)*a.z-sin(t*.2)*2.*(a.x+.5));\n p.xy=r(p.xy,t*.2+a.x*.2);p.xz=r(p.xz,t*.3+a.y);\n v_color=vec4(a*.8+.2,1.); gl_Position=vec4(p.x,p.y*o,p.z,p.z+5.); gl_PointSize=2.;}" + }, "screenshotURL": "data/images/images-n0w85h2g0ej3r9amv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hJS9jEgToDSA94vDA/art.json b/art/hJS9jEgToDSA94vDA/art.json index aadfa062..19c8e915 100644 --- a/art/hJS9jEgToDSA94vDA/art.json +++ b/art/hJS9jEgToDSA94vDA/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "molotovbliss", "avatarUrl": "https://avatars.githubusercontent.com/molotovbliss?s=200", - "settings": "{\"num\":98404,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09803921568627451,0.09803921568627451,0.09803921568627451,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * .6)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) / around * PI * 2.)\\n );\\n \\n float tm = time * 0.35;\\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\\n mat4 mat = persp(PI * .2, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(10.1, .005, hash(qu+qv)), mix(0., .012, hash(qv)))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.35, 2., pow(s, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 3.;\\n\\n float odd = mod(floor(quadId / 2.), 2.);\\n float hue = time * 0.02 + s * .15 + odd * .5;\\n float sat = mix(1., 1., odd);\\n float val = mix(0.25, 1., odd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 98404, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09803921568627451, + 0.09803921568627451, + 0.09803921568627451, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * .6)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) / around * PI * 2.)\n );\n \n float tm = time * 0.35;\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\n mat4 mat = persp(PI * .2, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(10.1, .005, hash(qu+qv)), mix(0., .012, hash(qv)))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.35, 2., pow(s, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 3.;\n\n float odd = mod(floor(quadId / 2.), 2.);\n float hue = time * 0.02 + s * .15 + odd * .5;\n float sat = mix(1., 1., odd);\n float val = mix(0.25, 1., odd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-alzu7hzvjaz1kt4fi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hKYwCnTKop5ukPrGH/art.json b/art/hKYwCnTKop5ukPrGH/art.json index fd2e416d..d9bd5f50 100644 --- a/art/hKYwCnTKop5ukPrGH/art.json +++ b/art/hKYwCnTKop5ukPrGH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lizell", "avatarUrl": "https://secure.gravatar.com/avatar/8cbc7cccd5a415ae64aab0284832279b?default=retro&size=200", - "settings": "{\"num\":1574,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/r2d2snbsociety/r2d2-x-madcore-x-valk-justice-clip\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat PI = 3.14;\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = 0.; //sin(time + x * y * 0.02) *5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\\n float sat = mix(1., pow(snd + 0.2, 5.), pump);\\n float val = pow(snd + 0.2, 5.); //sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1574, + "mode": "POINTS", + "sound": "https://soundcloud.com/r2d2snbsociety/r2d2-x-madcore-x-valk-justice-clip", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat PI = 3.14;\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = 0.; //sin(time + x * y * 0.02) *5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\n float sat = mix(1., pow(snd + 0.2, 5.), pump);\n float val = pow(snd + 0.2, 5.); //sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-2ukpgs09s1hiaz1a7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hKjwz37yK8sehZyC2/art.json b/art/hKjwz37yK8sehZyC2/art.json index 4dc61bd9..d5477d1b 100644 --- a/art/hKjwz37yK8sehZyC2/art.json +++ b/art/hKjwz37yK8sehZyC2/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "hyun", "avatarUrl": "https://lh6.googleusercontent.com/-85yu5m2ZywQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdO1OKKAqQzlgMFqnpApfbfi4i4Gw/mo/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(void)\\n{\\n gl_Position = vec4(0, 0, 0, 1);\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(void)\n{\n gl_Position = vec4(0, 0, 0, 1);\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-8q5f4nhfwqvmsqzwk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hMGCCTasLLBPQjRCG/art.json b/art/hMGCCTasLLBPQjRCG/art.json index be4c0a35..2e33e5bc 100644 --- a/art/hMGCCTasLLBPQjRCG/art.json +++ b/art/hMGCCTasLLBPQjRCG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n\\n#define seedFactor 0.75//KParameter 0.2>>2.\\n#define timeFactor 0.1//KParameter 0.1>>10.\\n\\n\\n#define MAX_ITER 64\\n\\nvec2 fractal(in vec2 p, in vec2 i) {\\n\\treturn vec2(dot(i, vec2(p.x, -p.y)), dot(p, i.yx));\\t\\n}\\n\\nvec3 color(in float c) {\\n\\treturn vec3(\\n\\t\\tc*sin(c*0.33),\\n\\t\\tc*sin(c*0.66),\\n\\t\\tc*sin(c)\\n\\t);\\n}\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by simFragCoord \\n //replace gl_FragColor by v_color\\n \\n\\tvec2 p = (( simFragCoord.xy / vertexResolution ) - 0.5) * 2.0;\\n\\tp.x *= resolution.x/resolution.y;\\n\\n\\tfloat angle = time * timeFactor;\\n\\tmat2 rot = mat2(cos(angle), -sin(angle),\\n\\t\\t sin(angle), cos(angle));\\n\\tp *= rot;\\n\\tvec2 seed = vec2(sin(angle)*.001, 1.0-cos(1.0/time));\\n\\n\\tvec2 i = p;\\n\\t\\n\\t\\n\\tfloat c = 1.0;\\n\\tfor (int n = 0; n < MAX_ITER; n++) {\\n\\t\\tvec2 r = i;\\n\\t\\ti = fractal(i,r) + seed;\\n\\t\\ti = fractal(i,r) + seed.yx;\\n\\t\\ti = fractal(i,r) + r;\\n\\t\\t\\n\\t\\tc += length(r);\\n\\t\\tif (length(i) > 10.0) {\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t}\\n \\n\\tc /= float(MAX_ITER);\\n\\tv_color = vec4( vec3( color(pow(dot(c+c+sin(time)*3., 2.0), 2.2)) ), 1.0 );//crazier colors\\n\\n\\n\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n\n#define seedFactor 0.75//KParameter 0.2>>2.\n#define timeFactor 0.1//KParameter 0.1>>10.\n\n\n#define MAX_ITER 64\n\nvec2 fractal(in vec2 p, in vec2 i) {\n\treturn vec2(dot(i, vec2(p.x, -p.y)), dot(p, i.yx));\t\n}\n\nvec3 color(in float c) {\n\treturn vec3(\n\t\tc*sin(c*0.33),\n\t\tc*sin(c*0.66),\n\t\tc*sin(c)\n\t);\n}\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by simFragCoord \n //replace gl_FragColor by v_color\n \n\tvec2 p = (( simFragCoord.xy / vertexResolution ) - 0.5) * 2.0;\n\tp.x *= resolution.x/resolution.y;\n\n\tfloat angle = time * timeFactor;\n\tmat2 rot = mat2(cos(angle), -sin(angle),\n\t\t sin(angle), cos(angle));\n\tp *= rot;\n\tvec2 seed = vec2(sin(angle)*.001, 1.0-cos(1.0/time));\n\n\tvec2 i = p;\n\t\n\t\n\tfloat c = 1.0;\n\tfor (int n = 0; n < MAX_ITER; n++) {\n\t\tvec2 r = i;\n\t\ti = fractal(i,r) + seed;\n\t\ti = fractal(i,r) + seed.yx;\n\t\ti = fractal(i,r) + r;\n\t\t\n\t\tc += length(r);\n\t\tif (length(i) > 10.0) {\n\t\t\tbreak;\n\t\t}\n\t}\n \n\tc /= float(MAX_ITER);\n\tv_color = vec4( vec3( color(pow(dot(c+c+sin(time)*3., 2.0), 2.2)) ), 1.0 );//crazier colors\n\n\n\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-k2wvzwy6g9r0ebm3h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hNysLh7LeD77n8RsG/art.json b/art/hNysLh7LeD77n8RsG/art.json index 65c1554c..bbda427e 100644 --- a/art/hNysLh7LeD77n8RsG/art.json +++ b/art/hNysLh7LeD77n8RsG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":72000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n#define fakeVerticeNumber 72000\\n\\n//const float travelSpeed = -100.;\\nconst float dim = 120.;\\nconst float off = 0.1;\\n\\n/////////////////////////////\\n//K Machine parameters\\n/////////////////////////////\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=72000\\n\\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 1. //KParameter 1.>>10.\\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 2. //KParameter 0.5>>40.\\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\n\\nvec3 getTrajPoint(const float _id) {\\n return vec3(\\n sin(_id * 0.99),\\n sin(_id * 2.43),\\n sin(_id * 1.57));\\n}\\n \\nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\\n{\\n \\n float pg = _rel + _delta;\\n \\n vec3 r0 = getTrajPoint(pg + off * 0.);\\n vec3 r1 = getTrajPoint(pg + off * 1.);\\n vec3 r2 = getTrajPoint(pg + off * 2.);\\n \\n _pos = mat3(\\n getTrajPoint(pg + off * 0.),\\n getTrajPoint(pg + off * 1.),\\n getTrajPoint(pg + off * 2.));\\n \\n vec3 s0 = normalize(_pos[1] - _pos[0]);\\n vec3 s1 = normalize(_pos[2] - _pos[1]);\\n \\n vec4 zaxis = vec4(normalize(s1 - s0),1.);\\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\\n \\n _axis = mat3(\\n xaxis,\\n yaxis,\\n zaxis);\\n\\n\\n}\\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\\n \\n \\n float prog = (_shapeId / _shapeCount)+_timeB;\\n \\n mat3 axis, mPos;\\n\\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\\n\\n //position matrix\\n _wmat = mat4(\\n vec4(axis[0], 0),\\n vec4(axis[1], 0),\\n vec4(axis[2], 0),\\n vec4(mPos[0] * dim, 1)); \\n \\n //orientation matrix\\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\\n vec3 target = mPos[1] * dim + axis[2];\\n vec3 up = axis[1];\\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\nmat4 rotationMatrix(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\n\\nvoid main() {\\n \\n //shape\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\\n \\n \\n float timeB = time * tubeSpeedFactor;\\n\\n /* \\n //Static eye\\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n */\\n \\n \\n //Following eye\\n \\n\\n mat3 axis, sPos;// = getAxisMat(0., timeB);\\n getPosAndAxisMat(0., timeB, axis, sPos);\\n /*\\n //rotation around eye z axis\\n mat4 rotMat = rotationMatrix(zaxis, time*PI);\\n xaxis = (rotMat*vec4(xaxis,1.)).xyz;\\n yaxis = (rotMat*vec4(yaxis,1.)).xyz;\\n */\\n //\\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\\n vec3 target = sPos[2] * dim + axis[2];\\n vec3 up = axis[1];\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n\\n vec4 cNorm;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\\n \\n mat4 scaleMat = scale(vec3(1.*cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n mat4 zrot = rotZ(relGroupId*2.*PI);\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n \\n //create the circle group\\n \\n \\n \\n float radius = 100.*radiusSizeFactor;\\n cubep.x+= radius*sin(2.*PI*relGroupId);\\n cubep.y+= radius*cos(2.*PI*relGroupId);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n\\n mat4 posmat, rotmat;\\n\\n getTrajMat(mod(shapeId-time*cudeSpeedFactor,shapeCount), shapeCount, timeB, posmat, rotmat);\\n \\n //shape orientation\\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\\n cNorm *= rotmat;\\n \\n //shape position\\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\\n \\n vec3 finalcolor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 72000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n#define fakeVerticeNumber 72000\n\n//const float travelSpeed = -100.;\nconst float dim = 120.;\nconst float off = 0.1;\n\n/////////////////////////////\n//K Machine parameters\n/////////////////////////////\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=72000\n\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 1. //KParameter 1.>>10.\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 2. //KParameter 0.5>>40.\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\n\nvec3 getTrajPoint(const float _id) {\n return vec3(\n sin(_id * 0.99),\n sin(_id * 2.43),\n sin(_id * 1.57));\n}\n \nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\n{\n \n float pg = _rel + _delta;\n \n vec3 r0 = getTrajPoint(pg + off * 0.);\n vec3 r1 = getTrajPoint(pg + off * 1.);\n vec3 r2 = getTrajPoint(pg + off * 2.);\n \n _pos = mat3(\n getTrajPoint(pg + off * 0.),\n getTrajPoint(pg + off * 1.),\n getTrajPoint(pg + off * 2.));\n \n vec3 s0 = normalize(_pos[1] - _pos[0]);\n vec3 s1 = normalize(_pos[2] - _pos[1]);\n \n vec4 zaxis = vec4(normalize(s1 - s0),1.);\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\n \n _axis = mat3(\n xaxis,\n yaxis,\n zaxis);\n\n\n}\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\n \n \n float prog = (_shapeId / _shapeCount)+_timeB;\n \n mat3 axis, mPos;\n\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\n\n //position matrix\n _wmat = mat4(\n vec4(axis[0], 0),\n vec4(axis[1], 0),\n vec4(axis[2], 0),\n vec4(mPos[0] * dim, 1)); \n \n //orientation matrix\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\n vec3 target = mPos[1] * dim + axis[2];\n vec3 up = axis[1];\n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\nmat4 rotationMatrix(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\n\nvoid main() {\n \n //shape\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float snd = 2.*texture2D(sound, vec2(shapeRelId, 0.)).a;\n \n \n float timeB = time * tubeSpeedFactor;\n\n /* \n //Static eye\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\n vec3 up = vec3(0.5, 0.5, 1.5);\n */\n \n \n //Following eye\n \n\n mat3 axis, sPos;// = getAxisMat(0., timeB);\n getPosAndAxisMat(0., timeB, axis, sPos);\n /*\n //rotation around eye z axis\n mat4 rotMat = rotationMatrix(zaxis, time*PI);\n xaxis = (rotMat*vec4(xaxis,1.)).xyz;\n yaxis = (rotMat*vec4(yaxis,1.)).xyz;\n */\n //\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\n vec3 target = sPos[2] * dim + axis[2];\n vec3 up = axis[1];\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n\n vec4 cNorm;\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\n \n mat4 scaleMat = scale(vec3(1.*cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n mat4 zrot = rotZ(relGroupId*2.*PI);\n cubep = (zrot*vec4(cubep,1.)).xyz;\n \n //create the circle group\n \n \n \n float radius = 100.*radiusSizeFactor;\n cubep.x+= radius*sin(2.*PI*relGroupId);\n cubep.y+= radius*cos(2.*PI*relGroupId);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n \n //shapeId = mod(shapeId+time, shapeCount);\n\n mat4 posmat, rotmat;\n\n getTrajMat(mod(shapeId-time*cudeSpeedFactor,shapeCount), shapeCount, timeB, posmat, rotmat);\n \n //shape orientation\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\n cNorm *= rotmat;\n \n //shape position\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\n \n vec3 finalcolor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-skabcsnam3xwarxt9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hQ22f6sNbz8Dczs4G/art.json b/art/hQ22f6sNbz8Dczs4G/art.json index 606127af..5c828d61 100644 --- a/art/hQ22f6sNbz8Dczs4G/art.json +++ b/art/hQ22f6sNbz8Dczs4G/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.33725490196078434,0.2823529411764706,0.2823529411764706,1],\"shader\":\"// Junsu Jang\\n// Exercise Making A Grid\\n// CS250 \\n// Spring/2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.33725490196078434, + 0.2823529411764706, + 0.2823529411764706, + 1 + ], + "shader": "// Junsu Jang\n// Exercise Making A Grid\n// CS250 \n// Spring/2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-ye4hhqykknkgh4wis-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hTATeX2kPux2LeQdD/art.json b/art/hTATeX2kPux2LeQdD/art.json index cc475e16..90335037 100644 --- a/art/hTATeX2kPux2LeQdD/art.json +++ b/art/hTATeX2kPux2LeQdD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.141\\n\\nfloat dis(float n) \\n{ \\n return fract(sin(n)*8.700); \\n}\\n\\n\\n\\nvoid main () \\n{\\n float Id = dis(vertexId);\\n float fr = dis(Id);\\n float tex = texture2D(sound, vec2(fr, Id)).a * cos(Id);\\n \\n tex = pow(tex, 2.9);\\n \\n float pang = vertexId;\\n float view = 7.5 * 2.0;\\n float t = (time * (fr + .1))*10.6;\\n float x = Id * sin(pang + t);\\n float y = Id * cos(pang + t);\\n \\n \\n \\n y += 52.25 * tex * (.12 - y);\\n y *= 87.78;\\n \\n \\n \\n float sizeAfter = tex / (y + 1.15);\\n \\n gl_Position = vec4(x, y, 0.4, 1.3);\\n gl_PointSize = 6.2 * sizeAfter;\\n \\n v_color = vec4(tex * 1.1 * (3. - fr), tex * 0.9 * cos(fr * PI), tex * 9.10, sizeAfter);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.141\n\nfloat dis(float n) \n{ \n return fract(sin(n)*8.700); \n}\n\n\n\nvoid main () \n{\n float Id = dis(vertexId);\n float fr = dis(Id);\n float tex = texture2D(sound, vec2(fr, Id)).a * cos(Id);\n \n tex = pow(tex, 2.9);\n \n float pang = vertexId;\n float view = 7.5 * 2.0;\n float t = (time * (fr + .1))*10.6;\n float x = Id * sin(pang + t);\n float y = Id * cos(pang + t);\n \n \n \n y += 52.25 * tex * (.12 - y);\n y *= 87.78;\n \n \n \n float sizeAfter = tex / (y + 1.15);\n \n gl_Position = vec4(x, y, 0.4, 1.3);\n gl_PointSize = 6.2 * sizeAfter;\n \n v_color = vec4(tex * 1.1 * (3. - fr), tex * 0.9 * cos(fr * PI), tex * 9.10, sizeAfter);\n \n}" + }, "screenshotURL": "data/images/images-e6l3c5pszer4ze7l6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hXDoWkGSTBFBQGXnN/art.json b/art/hXDoWkGSTBFBQGXnN/art.json index 357f13e1..a045f490 100644 --- a/art/hXDoWkGSTBFBQGXnN/art.json +++ b/art/hXDoWkGSTBFBQGXnN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Term : 2023 Fall\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-jvr097bu3nleexao4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hXusy4KBvn6oHTu4Q/art.json b/art/hXusy4KBvn6oHTu4Q/art.json index d515582e..857ebc09 100644 --- a/art/hXusy4KBvn6oHTu4Q/art.json +++ b/art/hXusy4KBvn6oHTu4Q/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 5.0\\n#define Z_NEAR 5.0\\n#define Z_FAR -5.0\\n\\n#define PI 3.14\\n\\n#define tMin -4.0 * PI\\n#define tMax 4.0 * PI\\n\\nvec3 ParametricCurve(float t) {\\n return vec3(cos(t), t * 0.25, sin(t));\\n}\\n\\nvoid main() {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\\n\\n float t = tMin + (tMax - tMin) * (vertexId / vertexCount);\\n\\n vec3 vertex = ParametricCurve(t);\\n vec3 color = vec3(1.0);\\n\\n vec2 rot = mouse * PI;\\n float cy = cos(rot.x), sy = sin(rot.x);\\n float cp = cos(rot.y), sp = sin(rot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 5.0\n#define Z_NEAR 5.0\n#define Z_FAR -5.0\n\n#define PI 3.14\n\n#define tMin -4.0 * PI\n#define tMax 4.0 * PI\n\nvec3 ParametricCurve(float t) {\n return vec3(cos(t), t * 0.25, sin(t));\n}\n\nvoid main() {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\n\n float t = tMin + (tMax - tMin) * (vertexId / vertexCount);\n\n vec3 vertex = ParametricCurve(t);\n vec3 color = vec3(1.0);\n\n vec2 rot = mouse * PI;\n float cy = cos(rot.x), sy = sin(rot.x);\n float cp = cos(rot.y), sp = sin(rot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-b18epr97tsevptzb2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hXxx7rTq8dZYFKSs5/art.json b/art/hXxx7rTq8dZYFKSs5/art.json index 3c760ff0..8209bb23 100644 --- a/art/hXxx7rTq8dZYFKSs5/art.json +++ b/art/hXxx7rTq8dZYFKSs5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2924,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n#define KP0 2.//KParameter -2.>>2.\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.5//KParameter 0.3>>7.\\n\\n#define KP2 .3//KParameter 0.4>>2.\\n//KVerticesNumber=4000\\n\\n\\n#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*\\n KP1, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.198,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 2924, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n#define KP0 2.//KParameter -2.>>2.\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.5//KParameter 0.3>>7.\n\n#define KP2 .3//KParameter 0.4>>2.\n//KVerticesNumber=4000\n\n\n#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*\n KP1, 2112.0, 3332.0); \ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.198,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-anlim9ijwf76f1pox-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hbcHxbJiDeAnvZ9Bf/art.json b/art/hbcHxbJiDeAnvZ9Bf/art.json index b1b83f36..7357b3c5 100644 --- a/art/hbcHxbJiDeAnvZ9Bf/art.json +++ b/art/hbcHxbJiDeAnvZ9Bf/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":99068,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n#define KP0 1.//KParameter 0.2>>3.\\n#define positionY 1.//KParameter 0.>>1.\\n#define colorR 1.//KParameter 0.>>1.\\n#define colorG 1.//KParameter 0.>>1.\\n#define colorB 1.//KParameter 0.>>1.\\n#define rotationFactorX 1.//KParameter 0.>>1.\\n#define rotationFactorY 1.//KParameter 0.>>1.\\n#define rotationFactorZ 1.//KParameter 0.>>1.\\n//KVerticesNumber=17300\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 195.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * .4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * .1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 2.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 1.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 0.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * .05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 1., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 99068, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n#define KP0 1.//KParameter 0.2>>3.\n#define positionY 1.//KParameter 0.>>1.\n#define colorR 1.//KParameter 0.>>1.\n#define colorG 1.//KParameter 0.>>1.\n#define colorB 1.//KParameter 0.>>1.\n#define rotationFactorX 1.//KParameter 0.>>1.\n#define rotationFactorY 1.//KParameter 0.>>1.\n#define rotationFactorZ 1.//KParameter 0.>>1.\n//KVerticesNumber=17300\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 195.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * .4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * .1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 2.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 1.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 0.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * .05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 1., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-bhfngc8huxyp5c86n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hdoyK6tHCoauDPZQL/art.json b/art/hdoyK6tHCoauDPZQL/art.json index ffd14f3f..1ef8b3ba 100644 --- a/art/hdoyK6tHCoauDPZQL/art.json +++ b/art/hdoyK6tHCoauDPZQL/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":16662,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n//KVertices_Number=16666\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 16662, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n\n//KVertices_Number=16666\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-3n7mcu0l7jpcztcpy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hffRc9FH8TMNKECkJ/art.json b/art/hffRc9FH8TMNKECkJ/art.json index 7b5647c4..4e2c7f86 100644 --- a/art/hffRc9FH8TMNKECkJ/art.json +++ b/art/hffRc9FH8TMNKECkJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/t0kisaki/u-got-that-halogen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"/*\\n\\n-=O=-\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n// mat *= trans(cpos);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/t0kisaki/u-got-that-halogen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n-=O=-\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n// mat *= trans(cpos);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-1pnaycawcq4h45nna-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hhDozSmRkW3ExvhoP/art.json b/art/hhDozSmRkW3ExvhoP/art.json index cb4155d5..00a264e0 100644 --- a/art/hhDozSmRkW3ExvhoP/art.json +++ b/art/hhDozSmRkW3ExvhoP/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye /45.), -dot(yAxis, eye -2.), -dot(zAxis * mouse.x, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.2 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.6,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * .6 + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + .5, 3.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\\n v_color.rgb = mix(v_color.rgb, vec3(0.4)+pump, 1.*pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye /45.), -dot(yAxis, eye -2.), -dot(zAxis * mouse.x, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.2 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.6,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * .6 + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + .5, 3.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\n v_color.rgb = mix(v_color.rgb, vec3(0.4)+pump, 1.*pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-pive2cjmewpwre7k5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hhK98FuyYZiyCZfjD/art.json b/art/hhK98FuyYZiyCZfjD/art.json index 1fe72112..bdb9a281 100644 --- a/art/hhK98FuyYZiyCZfjD/art.json +++ b/art/hhK98FuyYZiyCZfjD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=65536\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float lineId = 0.;//mod(shapeId, 3.0);\\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 30.;\\n float line = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float relXid = xPos/2.;\\n xPos =xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n //elemSize = (2./numberOfElement);\\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n \\n line/=numberOfElement;\\n\\n \\n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n \\n cubep = vec3(cubep.x, cubep.y+snd, cubep.z);\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);\\n \\n\\n //cubep .x*=aspect;\\n cubep .x+=xPos;\\n cubep .z+=line*2.;\\n \\n vec3 eye = vec3(eyeX, eyeY, -.1);\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 1.), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=65536\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float lineId = 0.;//mod(shapeId, 3.0);\n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 30.;\n float line = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float relXid = xPos/2.;\n xPos =xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n //elemSize = (2./numberOfElement);\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n \n vec3 color = vec3(1., 1., 1.);\n \n \n line/=numberOfElement;\n\n \n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n \n cubep = vec3(cubep.x, cubep.y+snd, cubep.z);\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);\n \n\n //cubep .x*=aspect;\n cubep .x+=xPos;\n cubep .z+=line*2.;\n \n vec3 eye = vec3(eyeX, eyeY, -.1);\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 1.), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-8xrt8awybmvxldi48-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hhSEYyu9RaWDJ54wu/art.json b/art/hhSEYyu9RaWDJ54wu/art.json index d3dd7b0b..fc40103e 100644 --- a/art/hhSEYyu9RaWDJ54wu/art.json +++ b/art/hhSEYyu9RaWDJ54wu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>8.\\n#define parameter1 3.//KParameter1 1.>>8.\\n#define parameter2 3.//KParameter2 0.>>40.\\n#define parameter3 15.//KParameter3 5>>100.\\n#define parameter4 0.1//KParameter4 0.01>>0.05\\n#define parameter5 30.//KParameter5 5.>>50.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 1.>>5.\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\\n{\\n vec3 u = _triangleVertices0 - _triangleVertices1;\\n vec3 v = _triangleVertices1 - _triangleVertices2;\\n return cross(v, u);\\n}\\n\\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\\n{\\n float localVid = mod(_vId,_vtn);\\n \\n if(localVid< 1.)\\n {\\n \\n _v = _vt[0];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n \\n }\\n else\\n if(localVid< 2.)\\n {\\n _v = _vt[1];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 3.)\\n {\\n _v = _vt[2];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 4.)\\n {\\n _v = _vt[3];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 5.)\\n {\\n _v = _vt[4];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 6.)\\n {\\n _v = _vt[5];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 7.)\\n {\\n _v = _vt[6];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 8.)\\n {\\n _v = _vt[7];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 9.)\\n {\\n _v = _vt[8];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 10.)\\n {\\n _v = _vt[9];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 11.)\\n {\\n _v = _vt[10];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 12.)\\n {\\n _v = _vt[11];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n \\n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\\n \\n _v = rotY(_v,_rot.y);\\n _n = rotY(_n,_rot.y);\\n \\n\\n _v = rotX(_v,_rot.x);\\n _n = rotX(_n,_rot.x);\\n \\n _v = rotZ(_v,_rot.z);\\n _n = rotZ(_n,_rot.z);\\n \\n _v += _pos;\\n //_n += _pos;\\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\\n specular = max(0.0, pow(NDoth, _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n \\n //KVsa\\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n //KVsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops = floor(parameter1);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n\\n \\n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops2 = floor(1.);\\n float subLoopLength2 = 1./numberOfSubLoops2;\\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n vec3 _n = vec3(0.,0.,0.);\\n \\n vec3 shapeVertices[12];\\n float shapeSize = 12.;\\n \\n \\n \\n \\n float maxShapeCount = floor(vertexCount/shapeSize);\\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\\n float shapeId = floor(finalVertexId/shapeSize);\\n float relShapeId = shapeId/maxShapeCount;\\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\\n \\n //create the big circle\\n float masterCircleRadius = 0.8;\\n float numberOfCirclesInMasterCircle = floor(parameter5);\\n float vertexPerSmallCircle = numberOfShape*shapeSize;\\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\\n \\n float scale = parameter4;\\n \\n \\n \\n float localShapeId = mod(shapeId,numberOfShape);\\n float localRelShapeId = localShapeId/numberOfShape;\\n \\n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\\n \\n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\\n float sndFactor = texture2D(sound, vec2(relMasterCircleId, 0.)).a ;\\n float factor1 = 1.;//+sndFactor*20.;\\n \\n float radius = sndFactor;//0.3+sndFactor/5.;//+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\\n \\n \\n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\\n \\n \\n \\n \\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\\n shapeVertices[1] = vec3(0.5,0.,-0.5);\\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\\n shapeVertices[3] = vec3(0.5,0.,-0.5);\\n shapeVertices[4] = vec3(0.5,0.,0.5);\\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\\n shapeVertices[6] =vec3(0.5,0.,0.5);\\n shapeVertices[7] =vec3(-0.5,0.,0.5);\\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\\n shapeVertices[9] =vec3(-0.5,0.,0.5);\\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\\n \\n vec3 shapeColors[4];\\n \\n shapeColors[0] = vec3(1.,1.,0.);\\n shapeColors[1] = vec3(0.,0.,1.);\\n shapeColors[2] = vec3(0.,1.,1.);\\n shapeColors[3] = vec3(1.,0.,1.);\\n \\n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\\n \\n \\n //vec3 eye = vec3(cos(time), 0., sin(time));\\n vec3 eye = vec3(0., 0., -1.);\\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\\n\\n vec3 p = lookAt(_v, eye, vec3(0.,0.,0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n \\n _v.x*=resolution.y/resolution.x;\\n\\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>8.\n#define parameter1 3.//KParameter1 1.>>8.\n#define parameter2 3.//KParameter2 0.>>40.\n#define parameter3 15.//KParameter3 5>>100.\n#define parameter4 0.1//KParameter4 0.01>>0.05\n#define parameter5 30.//KParameter5 5.>>50.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 1.>>5.\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\n{\n vec3 u = _triangleVertices0 - _triangleVertices1;\n vec3 v = _triangleVertices1 - _triangleVertices2;\n return cross(v, u);\n}\n\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\n{\n float localVid = mod(_vId,_vtn);\n \n if(localVid< 1.)\n {\n \n _v = _vt[0];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n \n }\n else\n if(localVid< 2.)\n {\n _v = _vt[1];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 3.)\n {\n _v = _vt[2];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 4.)\n {\n _v = _vt[3];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 5.)\n {\n _v = _vt[4];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 6.)\n {\n _v = _vt[5];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 7.)\n {\n _v = _vt[6];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 8.)\n {\n _v = _vt[7];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 9.)\n {\n _v = _vt[8];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 10.)\n {\n _v = _vt[9];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 11.)\n {\n _v = _vt[10];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 12.)\n {\n _v = _vt[11];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n \n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\n \n _v = rotY(_v,_rot.y);\n _n = rotY(_n,_rot.y);\n \n\n _v = rotX(_v,_rot.x);\n _n = rotX(_n,_rot.x);\n \n _v = rotZ(_v,_rot.z);\n _n = rotZ(_n,_rot.z);\n \n _v += _pos;\n //_n += _pos;\n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\n specular = max(0.0, pow(NDoth, _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n \n vec3 color = vec3(1.);\n \n //KVsa\n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n //KVsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops = floor(parameter1);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n\n \n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops2 = floor(1.);\n float subLoopLength2 = 1./numberOfSubLoops2;\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\n \n vec3 _v = vec3(0.,0.,0.);\n vec3 _n = vec3(0.,0.,0.);\n \n vec3 shapeVertices[12];\n float shapeSize = 12.;\n \n \n \n \n float maxShapeCount = floor(vertexCount/shapeSize);\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\n float shapeId = floor(finalVertexId/shapeSize);\n float relShapeId = shapeId/maxShapeCount;\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\n \n //create the big circle\n float masterCircleRadius = 0.8;\n float numberOfCirclesInMasterCircle = floor(parameter5);\n float vertexPerSmallCircle = numberOfShape*shapeSize;\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\n \n float scale = parameter4;\n \n \n \n float localShapeId = mod(shapeId,numberOfShape);\n float localRelShapeId = localShapeId/numberOfShape;\n \n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\n \n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\n float sndFactor = texture2D(sound, vec2(relMasterCircleId, 0.)).a ;\n float factor1 = 1.;//+sndFactor*20.;\n \n float radius = sndFactor;//0.3+sndFactor/5.;//+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\n \n \n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\n \n \n \n \n shapeVertices[0] = vec3(-0.5,0.,-0.5);\n shapeVertices[1] = vec3(0.5,0.,-0.5);\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\n shapeVertices[3] = vec3(0.5,0.,-0.5);\n shapeVertices[4] = vec3(0.5,0.,0.5);\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\n shapeVertices[6] =vec3(0.5,0.,0.5);\n shapeVertices[7] =vec3(-0.5,0.,0.5);\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\n shapeVertices[9] =vec3(-0.5,0.,0.5);\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\n \n vec3 shapeColors[4];\n \n shapeColors[0] = vec3(1.,1.,0.);\n shapeColors[1] = vec3(0.,0.,1.);\n shapeColors[2] = vec3(0.,1.,1.);\n shapeColors[3] = vec3(1.,0.,1.);\n \n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\n \n \n //vec3 eye = vec3(cos(time), 0., sin(time));\n vec3 eye = vec3(0., 0., -1.);\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\n\n vec3 p = lookAt(_v, eye, vec3(0.,0.,0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n \n _v.x*=resolution.y/resolution.x;\n\n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-rztzl6y99gg2wiq7h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hhsdvkiJ32bCTcezv/art.json b/art/hhsdvkiJ32bCTcezv/art.json index 3ec62bfe..85eceadf 100644 --- a/art/hhsdvkiJ32bCTcezv/art.json +++ b/art/hhsdvkiJ32bCTcezv/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "blendy", "username": "gman", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/blondish/should-be-higher-blondish-remix-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n gl_PointSize = resolution.x / 40.0 ;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float r2 = sin(orbitAngle);\\n float oC = cos(orbitAngle + time * count * 0.01) * r2;\\n float oS = sin(orbitAngle + time * count * 0.01) * r2;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n\\n float dd = length(xy);\\n float snd = pow(texture2D(sound, vec2(fract(count * 0.01) * 0.125, dd * 0.1)).a, 5.0);\\n \\n xy = xy + xy * snd ;\\n gl_Position = vec4(xy * aspect + mouse * 0.1, -fract(count * 0.01), 1);\\n \\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(mix(hsv2rgb(vec3(hue + snd, 1, 1)), vec3(1,1,1), snd), 0.1 + snd * 0.5);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/blondish/should-be-higher-blondish-remix-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n gl_PointSize = resolution.x / 40.0 ;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float r2 = sin(orbitAngle);\n float oC = cos(orbitAngle + time * count * 0.01) * r2;\n float oS = sin(orbitAngle + time * count * 0.01) * r2;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n\n float dd = length(xy);\n float snd = pow(texture2D(sound, vec2(fract(count * 0.01) * 0.125, dd * 0.1)).a, 5.0);\n \n xy = xy + xy * snd ;\n gl_Position = vec4(xy * aspect + mouse * 0.1, -fract(count * 0.01), 1);\n \n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(mix(hsv2rgb(vec3(hue + snd, 1, 1)), vec3(1,1,1), snd), 0.1 + snd * 0.5);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-cgwkt07m8oqodiaze-thumbnail.jpg", "views": { "$numberInt": "4273" diff --git a/art/hjpDj9NpsfdHuD6Ya/art.json b/art/hjpDj9NpsfdHuD6Ya/art.json index d2c29f7c..98706b6c 100644 --- a/art/hjpDj9NpsfdHuD6Ya/art.json +++ b/art/hjpDj9NpsfdHuD6Ya/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14976,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float t = (vertexId*9.0+mod(vertexId,2.0))*0.01;\\n float phase = -time+mod(vertexId,2.0);\\n float a = 0.5;\\n float b = 0.3063489;\\n float x = a * exp(b*t)*cos(t+phase)*0.015;\\n float y = a * exp(b*t)*sin(t+phase)*0.015;\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n \\n float hue = floor(time*0.0) / 0.23;\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 14976, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float t = (vertexId*9.0+mod(vertexId,2.0))*0.01;\n float phase = -time+mod(vertexId,2.0);\n float a = 0.5;\n float b = 0.3063489;\n float x = a * exp(b*t)*cos(t+phase)*0.015;\n float y = a * exp(b*t)*sin(t+phase)*0.015;\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n \n float hue = floor(time*0.0) / 0.23;\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-zv3xwlxbumoflar2a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hjusZffXbWpbtMDh7/art.json b/art/hjusZffXbWpbtMDh7/art.json index 0469fdfa..3cb632db 100644 --- a/art/hjusZffXbWpbtMDh7/art.json +++ b/art/hjusZffXbWpbtMDh7/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "dzozef", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvoid Track( float vertexid )\\n{\\n}\\n\\nvoid Background( float vertexid )\\n{\\n}\\n\\nvoid main() {\\n gl_Position = vec4(vertexId);\\n\\n \\n v_color = vec4(vec3(vertexId), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvoid Track( float vertexid )\n{\n}\n\nvoid Background( float vertexid )\n{\n}\n\nvoid main() {\n gl_Position = vec4(vertexId);\n\n \n v_color = vec4(vec3(vertexId), 1);\n}" + }, "screenshotURL": "data/images/images-zhfr478nbq4lal6o9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hmpjw2dG3vhXJ4Mhu/art.json b/art/hmpjw2dG3vhXJ4Mhu/art.json index d166447c..c82a8b27 100644 --- a/art/hmpjw2dG3vhXJ4Mhu/art.json +++ b/art/hmpjw2dG3vhXJ4Mhu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":14821,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/colorplus/make-u-wait\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define kp0 2.//KParameter -5.>>5.\\n#define kp1 1.//KParameter 0.>>5.\\n#define kp2 .3//KParameter 0.>>5.\\n#define kp3 2.//KParameter 1.>>5.\\n#define kp4 3.//KParameter 0.>>5.\\n#define kp5 1.1//KParameter 0.>>5.\\n\\n//KVerticesNumber=16622\\n\\n\\n\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n kp0*mouse.x;\\n kp1 *mouse.y;\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.0030;\\n \\tfloat transitionStrength = 1.3*kp5;\\n \\tvec3 colKernel0 = vec3(1,0,1.-kp3);\\n \\tvec3 colKernel1 = vec3(0,kp2,0);\\n \\tvec3 colTransition = vec3(kp0,kp4,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = .5 - kp1* 0.5;\\n\\tfloat ce = -1.5+ kp0* 3.+1.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 1, 0);\\n\\tvec3 up = vec3(0, 0.6,1.);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(33.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = .2 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * .23, 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis,0,\\n\\t\\tzAxis, -sin(mouse*0.021).y,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) /dot(det*det,\\n \\n 2.-b01);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),.45); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 14821, + "mode": "LINES", + "sound": "https://soundcloud.com/colorplus/make-u-wait", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define kp0 2.//KParameter -5.>>5.\n#define kp1 1.//KParameter 0.>>5.\n#define kp2 .3//KParameter 0.>>5.\n#define kp3 2.//KParameter 1.>>5.\n#define kp4 3.//KParameter 0.>>5.\n#define kp5 1.1//KParameter 0.>>5.\n\n//KVerticesNumber=16622\n\n\n\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\n return -log( res )/k;\n}\n\nvoid main()\n{\n kp0*mouse.x;\n kp1 *mouse.y;\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.0030;\n \tfloat transitionStrength = 1.3*kp5;\n \tvec3 colKernel0 = vec3(1,0,1.-kp3);\n \tvec3 colKernel1 = vec3(0,kp2,0);\n \tvec3 colTransition = vec3(kp0,kp4,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = .5 - kp1* 0.5;\n\tfloat ce = -1.5+ kp0* 3.+1.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 1, 0);\n\tvec3 up = vec3(0, 0.6,1.);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(33.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = .2 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * .23, 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis,0,\n\t\tzAxis, -sin(mouse*0.021).y,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) /dot(det*det,\n \n 2.-b01);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),.45); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-hklifsgrrs3xpsexy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hnZQWotZNLbSjY9bs/art.json b/art/hnZQWotZNLbSjY9bs/art.json index 75622d3e..c3ac6269 100644 --- a/art/hnZQWotZNLbSjY9bs/art.json +++ b/art/hnZQWotZNLbSjY9bs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-g84k9ktmw1u5u22tx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hppyeGQduA2gx5GYx/art.json b/art/hppyeGQduA2gx5GYx/art.json index 906d23d2..97be5b7d 100644 --- a/art/hppyeGQduA2gx5GYx/art.json +++ b/art/hppyeGQduA2gx5GYx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cjensen93", "avatarUrl": "https://secure.gravatar.com/avatar/0df4239ac208a0c9696c1edd2e895cee?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/100gecs/gec-2-ue-remix-feat-dorian\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.058823529411764705,0.4117647058823529,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n\\n}\\n\\n\\nvoid main(){\\n \\n #define PI 3.14159265;\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2.0 - 1.0 + xOff;\\n float uy = v * 2.0 - 1.0 + yOff;\\n \\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float angleV = length(vec2(su, sv));\\n float angleU = abs(atan(su, sv)) / PI;\\n // changes y value from center\\n //float sound = texture2D(sound, vec2(u * 0.125, sv * 0.125)).a;\\n \\n //Changes x value from center\\n //float sound = texture2D(sound, vec2(su * 0.125, 0.0)).a;\\n \\n float sound = texture2D(sound, vec2(angleU * 0.125, 0.0)).a;\\n\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n \\n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(sound, 4.0) * 30.0 + sOff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = 1.0;//u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float value = pow(sound, 4.0);//sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/100gecs/gec-2-ue-remix-feat-dorian", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.058823529411764705, + 0.4117647058823529, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n\n}\n\n\nvoid main(){\n \n #define PI 3.14159265;\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2.0 - 1.0 + xOff;\n float uy = v * 2.0 - 1.0 + yOff;\n \n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float angleV = length(vec2(su, sv));\n float angleU = abs(atan(su, sv)) / PI;\n // changes y value from center\n //float sound = texture2D(sound, vec2(u * 0.125, sv * 0.125)).a;\n \n //Changes x value from center\n //float sound = texture2D(sound, vec2(su * 0.125, 0.0)).a;\n \n float sound = texture2D(sound, vec2(angleU * 0.125, 0.0)).a;\n\n \n gl_Position = vec4(xy,0.0,1.0);\n \n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(sound, 4.0) * 30.0 + sOff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = 1.0;//u * 0.1 + sin(time + v * 20.0) * 0.05;\n float sat = 1.0;\n float value = pow(sound, 4.0);//sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-m9qb02p14g8c9pdqd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hrgNyucvZAE9WwRLF/art.json b/art/hrgNyucvZAE9WwRLF/art.json index d5231541..45a92c26 100644 --- a/art/hrgNyucvZAE9WwRLF/art.json +++ b/art/hrgNyucvZAE9WwRLF/art.json @@ -21,7 +21,19 @@ "origId": "asSnAehpD5b5tuJ27", "name": "round", "username": "artsime", - "settings": "{\"num\":88796,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jamie-berry/jamie-berry-sweet-rascal-original-mix-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.12941176470588237,0.01568627450980392,0.07058823529411765,1],\"shader\":\"#define NUM_SEGMENTS 64.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 32.0\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 16.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 1500.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.2 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.300;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n \\n gl_PointSize = min(32.0, 3.0 + pow((snd + 0.2) * 1.5, 10.0) * mix(13.0, 0.3, v));\\n\\n float x = u * PI * 1400.0 + snd - 0.5 + sin(count + time * 0.00000) * 0.1450;\\n float y = v - pow(snd, 1.5) * 0.4 + 0.5;\\n float c = cos(x);\\n float s = sin(x);\\n vec2 xy = vec2(c * y, s * y);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 88796, + "mode": "POINTS", + "sound": "https://soundcloud.com/jamie-berry/jamie-berry-sweet-rascal-original-mix-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0.12941176470588237, + 0.01568627450980392, + 0.07058823529411765, + 1 + ], + "shader": "#define NUM_SEGMENTS 64.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 32.0\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 16.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 1500.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.2 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.300;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n \n gl_PointSize = min(32.0, 3.0 + pow((snd + 0.2) * 1.5, 10.0) * mix(13.0, 0.3, v));\n\n float x = u * PI * 1400.0 + snd - 0.5 + sin(count + time * 0.00000) * 0.1450;\n float y = v - pow(snd, 1.5) * 0.4 + 0.5;\n float c = cos(x);\n float s = sin(x);\n vec2 xy = vec2(c * y, s * y);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "guDSJocAmZP4fmhiG", "views": { "$numberInt": "238" diff --git a/art/hsjAgdurCB49NCkC7/art.json b/art/hsjAgdurCB49NCkC7/art.json index 5f4af2f7..e139f926 100644 --- a/art/hsjAgdurCB49NCkC7/art.json +++ b/art/hsjAgdurCB49NCkC7/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":978,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// Seulbin Seo\\n// Exercise Color\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main ()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy)* 1.3;\\n \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 978, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Color\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main ()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy)* 1.3;\n \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-0ybjtzzbd9qjwrjsk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/huDQEAMcWYoP6hWGS/art.json b/art/huDQEAMcWYoP6hWGS/art.json index 1c93df3a..cff8bc79 100644 --- a/art/huDQEAMcWYoP6hWGS/art.json +++ b/art/huDQEAMcWYoP6hWGS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gearcode", "avatarUrl": "https://lh3.googleusercontent.com/-BsOS_RAUwtA/AAAAAAAAAAI/AAAAAAAAAG8/6g6FwPlfGb8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.141\\n\\nfloat dis(float n) \\n{ \\n return fract(sin(n)*1.50); \\n}\\n\\n\\n\\nvoid main () \\n{\\n float Id = dis(vertexId);\\n float fr = dis(Id);\\n float tex = texture2D(sound, vec2(fr, Id)).a * cos(Id);\\n \\n tex = pow(tex, 2.);\\n \\n float pang = vertexId;\\n float view = .5 * 1.2;\\n float t = (time * (fr + .1))*10.;\\n float x = Id * sin(pang + t);\\n float y = Id * cos(pang + t);\\n \\n \\n \\n y += .25 * tex * (1. - y);\\n y *= .78;\\n \\n \\n \\n float sizeAfter = tex / (y + 1.);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 6. * sizeAfter;\\n \\n v_color = vec4(tex * .1 * (3. - fr), tex * .9 * cos(fr * PI), tex * 9., sizeAfter);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.141\n\nfloat dis(float n) \n{ \n return fract(sin(n)*1.50); \n}\n\n\n\nvoid main () \n{\n float Id = dis(vertexId);\n float fr = dis(Id);\n float tex = texture2D(sound, vec2(fr, Id)).a * cos(Id);\n \n tex = pow(tex, 2.);\n \n float pang = vertexId;\n float view = .5 * 1.2;\n float t = (time * (fr + .1))*10.;\n float x = Id * sin(pang + t);\n float y = Id * cos(pang + t);\n \n \n \n y += .25 * tex * (1. - y);\n y *= .78;\n \n \n \n float sizeAfter = tex / (y + 1.);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 6. * sizeAfter;\n \n v_color = vec4(tex * .1 * (3. - fr), tex * .9 * cos(fr * PI), tex * 9., sizeAfter);\n \n}" + }, "screenshotURL": "data/images/images-k9rd874b9v2d6e13w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/huHtobGCf37pyxqDW/art.json b/art/huHtobGCf37pyxqDW/art.json index 2c585ada..035188a0 100644 --- a/art/huHtobGCf37pyxqDW/art.json +++ b/art/huHtobGCf37pyxqDW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "leodars", "avatarUrl": "https://secure.gravatar.com/avatar/4cb6f7468a7063cf9d0e6efeaa134438?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F4b7261fd1e30fe7006e6eb1c0300c662", - "settings": "{\"num\":20792,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .2 + sin(time + v * 20.) * .08;\\n float sat = 1.;\\n float val = sin(time +1.4 + v * u * 20.0) * .5 + 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 20792, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .2 + sin(time + v * 20.) * .08;\n float sat = 1.;\n float val = sin(time +1.4 + v * u * 20.0) * .5 + 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-9atowj5b205kphd6c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hvfx2JX4Hfg7zccE5/art.json b/art/hvfx2JX4Hfg7zccE5/art.json index 6a5e4cd2..b12bbf31 100644 --- a/art/hvfx2JX4Hfg7zccE5/art.json +++ b/art/hvfx2JX4Hfg7zccE5/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n//#define BASE_ANGLE 0.\\n//#define ANGLE_DELTA 0.02\\n//#define XOFF .7\\n\\n#define SPIN 0.5//KParameter 0.>>10.\\n#define SPIN2 .02//KParameter 0.02>>10.\\n\\n\\n//#ifdef GL_ES\\n//precision highp float;\\n//precision mediump float;\\n//#endif\\n\\n//uniform float time;\\n//varying vec2 surfacePosition;\\n \\n#define ptpi 1385.4557313670110891409199368797 //powten(pi)\\n#define pipi 36.462159607207911770990826022692 //pi pied, pi^pi\\n#define picu 31.006276680299820175476315067101 //pi cubed, pi^3\\n#define pepi 23.140692632779269005729086367949 //powe(pi);\\n#define chpi 11.59195327552152062775175205256 //cosh(pi)\\n#define shpi 11.548739357257748377977334315388 //sinh(pi)\\n#define pisq 9.8696044010893586188344909998762 //pi squared, pi^2\\n#define twpi 6.283185307179586476925286766559 //two pi, 2*pi\\n#define pi 3.1415926535897932384626433832795 //pi\\n#define e 2.7182818284590452353602874713526 //eulers number\\n#define sqpi 1.7724538509055160272981674833411 //square root of pi\\n#define phi 1.6180339887498948482045868343656 //golden ratio\\n#define hfpi 1.5707963267948966192313216916398 //half pi, 1/pi\\n#define cupi 1.4645918875615232630201425272638 //cube root of pi\\n#define prpi 1.4396194958475906883364908049738 //pi root of pi\\n#define lnpi 1.1447298858494001741434273513531 //logn(pi);\\n#define trpi 1.0471975511965977461542144610932 //one third of pi, pi/3\\n#define thpi 0.99627207622074994426469058001254//tanh(pi)\\n#define lgpi 0.4971498726941338543512682882909 //log(pi) \\n#define rcpi 0.31830988618379067153776752674503// reciprocal of pi , 1/pi \\n#define rcpipi 0.0274256931232981061195562708591 // reciprocal of pipi , 1/pipi\\n\\nfloat tt = ((time*e));\\nfloat t = (rcpi*(pi+tt/pisq))+pepi;\\nfloat k = (lgpi*(pi+tt/chpi))+chpi;\\n\\nvec3 qAxis = normalize(vec3(sin(t*(prpi)), cos(k*(cupi)), cos(k*(hfpi)) ));\\nvec3 wAxis = normalize(vec3(cos(k*(-trpi)/pi), sin(t*(rcpi)/pi), sin(k*(lgpi)/pi) ));\\nvec3 sAxis = normalize(vec3(cos(t*(trpi)), sin(t*(-rcpi)), sin(k*(lgpi)) ));\\nfloat axe = pow(qAxis.x+qAxis.y+qAxis.z+wAxis.x+wAxis.y+wAxis.z+sAxis.x+sAxis.y+sAxis.z,2.0);\\n\\nvec3 camPos = (vec3(0.0, 0.0, -1.0));\\nvec3 camUp = (vec3(0.0,1.0,0.0));\\nfloat focus = pi;\\nvec3 camTarget = vec3(0.1)*sAxis;\\n\\nvec3 rotate(vec3 vec, vec3 axis, float ang)\\n{\\n return vec * cos(ang) + cross(axis, vec) * sin(ang) + axis * dot(axis, vec) * (1.0 - cos(ang));\\n}\\n\\n\\n\\nvec3 pin(vec3 v)\\n{\\n vec3 q = vec3(0.0);\\n \\n q.x = sin(v.x)*0.5+0.5;\\n q.y = sin(v.y+0.66666667*pi)*0.5+0.5;\\n q.z = sin(v.z+1.33333333*pi)*0.5+0.5;\\n \\n return normalize(q);\\n}\\n\\nvec3 spin(vec3 v)\\n{\\n for(int i = 1; i <4; i++)\\n {\\n v=pin((v.yzx*twpi)*(float(i)));\\n }\\n return v.zxy;\\n}\\n\\n\\nfloat len( vec3 v )\\n{\\n\\tv=mod(v,vec3(0.5))-0.25;\\n\\treturn (max(0.0,length(v)-0.1)); \\n}\\n\\nvec3 nrm(vec3 p) {\\n\\tvec2 q = vec2(0.0, 0.1);\\n\\treturn normalize(vec3( len(p + q.yxx) - len(p - q.yxx),\\n\\t\\t len(p + q.xyx) - len(p - q.xyx),\\n\\t\\t len(p + q.xxy) - len(p - q.xxy) ));\\n}\\n\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by simFragCoord \\n //replace gl_FragColor by v_color\\n //replace iResolution by resolution\\n //replace resolution by vertexResolution\\n \\nvec2 pos = (surfacePosition)*twpi;//(sin(t*pi)+2.0);\\n float ang = (sin(t*lnpi)*pi)+(distance(sAxis,wAxis)+distance(qAxis,sAxis)+distance(wAxis,qAxis));\\n camPos = e*(camPos * cos(ang) + cross(qAxis, camPos) * sin(ang) + qAxis * dot(qAxis, camPos) * (1.0 - cos(ang)));\\n \\n vec3 camDir = normalize(camTarget-camPos);\\n camUp = rotate(camUp, camDir, sin(t*prpi)*pi);\\n vec3 camSide = cross(camDir, camUp);\\n vec3 sideNorm=normalize(cross(camUp, camDir));\\n vec3 upNorm=cross(camDir, sideNorm);\\n vec3 worldFacing=(camPos + camDir);\\n vec3 rayDir = -normalize((worldFacing+sideNorm*pos.x + upNorm*pos.y - camDir*((focus))));\\n \\n float show=0.0;\\n \\n float t = .1;\\n float temp = 0.;\\n for(int i = 0 ; i < 40; i++) {\\n\\ttemp = len((camPos + rayDir * (t)));\\n\\t if(temp < 0.001) {show = 1.0;break;}\\n\\t if(t>pisq){break;} \\n t += temp;\\n }\\n vec3 clr = rotate(mod((camPos + rayDir * (t)),vec3(SPIN))-0.25,rotate(sAxis,wAxis,ang*pisq),ang*pi+t);\\n clr = (show*(spin(clr))/(t))*(dot(rayDir,nrm(mod((camPos + rayDir * (t)),vec3(10.5))-0.25)));\\n v_color = vec4(clr, 1.0);\\n\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n//#define BASE_ANGLE 0.\n//#define ANGLE_DELTA 0.02\n//#define XOFF .7\n\n#define SPIN 0.5//KParameter 0.>>10.\n#define SPIN2 .02//KParameter 0.02>>10.\n\n\n//#ifdef GL_ES\n//precision highp float;\n//precision mediump float;\n//#endif\n\n//uniform float time;\n//varying vec2 surfacePosition;\n \n#define ptpi 1385.4557313670110891409199368797 //powten(pi)\n#define pipi 36.462159607207911770990826022692 //pi pied, pi^pi\n#define picu 31.006276680299820175476315067101 //pi cubed, pi^3\n#define pepi 23.140692632779269005729086367949 //powe(pi);\n#define chpi 11.59195327552152062775175205256 //cosh(pi)\n#define shpi 11.548739357257748377977334315388 //sinh(pi)\n#define pisq 9.8696044010893586188344909998762 //pi squared, pi^2\n#define twpi 6.283185307179586476925286766559 //two pi, 2*pi\n#define pi 3.1415926535897932384626433832795 //pi\n#define e 2.7182818284590452353602874713526 //eulers number\n#define sqpi 1.7724538509055160272981674833411 //square root of pi\n#define phi 1.6180339887498948482045868343656 //golden ratio\n#define hfpi 1.5707963267948966192313216916398 //half pi, 1/pi\n#define cupi 1.4645918875615232630201425272638 //cube root of pi\n#define prpi 1.4396194958475906883364908049738 //pi root of pi\n#define lnpi 1.1447298858494001741434273513531 //logn(pi);\n#define trpi 1.0471975511965977461542144610932 //one third of pi, pi/3\n#define thpi 0.99627207622074994426469058001254//tanh(pi)\n#define lgpi 0.4971498726941338543512682882909 //log(pi) \n#define rcpi 0.31830988618379067153776752674503// reciprocal of pi , 1/pi \n#define rcpipi 0.0274256931232981061195562708591 // reciprocal of pipi , 1/pipi\n\nfloat tt = ((time*e));\nfloat t = (rcpi*(pi+tt/pisq))+pepi;\nfloat k = (lgpi*(pi+tt/chpi))+chpi;\n\nvec3 qAxis = normalize(vec3(sin(t*(prpi)), cos(k*(cupi)), cos(k*(hfpi)) ));\nvec3 wAxis = normalize(vec3(cos(k*(-trpi)/pi), sin(t*(rcpi)/pi), sin(k*(lgpi)/pi) ));\nvec3 sAxis = normalize(vec3(cos(t*(trpi)), sin(t*(-rcpi)), sin(k*(lgpi)) ));\nfloat axe = pow(qAxis.x+qAxis.y+qAxis.z+wAxis.x+wAxis.y+wAxis.z+sAxis.x+sAxis.y+sAxis.z,2.0);\n\nvec3 camPos = (vec3(0.0, 0.0, -1.0));\nvec3 camUp = (vec3(0.0,1.0,0.0));\nfloat focus = pi;\nvec3 camTarget = vec3(0.1)*sAxis;\n\nvec3 rotate(vec3 vec, vec3 axis, float ang)\n{\n return vec * cos(ang) + cross(axis, vec) * sin(ang) + axis * dot(axis, vec) * (1.0 - cos(ang));\n}\n\n\n\nvec3 pin(vec3 v)\n{\n vec3 q = vec3(0.0);\n \n q.x = sin(v.x)*0.5+0.5;\n q.y = sin(v.y+0.66666667*pi)*0.5+0.5;\n q.z = sin(v.z+1.33333333*pi)*0.5+0.5;\n \n return normalize(q);\n}\n\nvec3 spin(vec3 v)\n{\n for(int i = 1; i <4; i++)\n {\n v=pin((v.yzx*twpi)*(float(i)));\n }\n return v.zxy;\n}\n\n\nfloat len( vec3 v )\n{\n\tv=mod(v,vec3(0.5))-0.25;\n\treturn (max(0.0,length(v)-0.1)); \n}\n\nvec3 nrm(vec3 p) {\n\tvec2 q = vec2(0.0, 0.1);\n\treturn normalize(vec3( len(p + q.yxx) - len(p - q.yxx),\n\t\t len(p + q.xyx) - len(p - q.xyx),\n\t\t len(p + q.xxy) - len(p - q.xxy) ));\n}\n\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by simFragCoord \n //replace gl_FragColor by v_color\n //replace iResolution by resolution\n //replace resolution by vertexResolution\n \nvec2 pos = (surfacePosition)*twpi;//(sin(t*pi)+2.0);\n float ang = (sin(t*lnpi)*pi)+(distance(sAxis,wAxis)+distance(qAxis,sAxis)+distance(wAxis,qAxis));\n camPos = e*(camPos * cos(ang) + cross(qAxis, camPos) * sin(ang) + qAxis * dot(qAxis, camPos) * (1.0 - cos(ang)));\n \n vec3 camDir = normalize(camTarget-camPos);\n camUp = rotate(camUp, camDir, sin(t*prpi)*pi);\n vec3 camSide = cross(camDir, camUp);\n vec3 sideNorm=normalize(cross(camUp, camDir));\n vec3 upNorm=cross(camDir, sideNorm);\n vec3 worldFacing=(camPos + camDir);\n vec3 rayDir = -normalize((worldFacing+sideNorm*pos.x + upNorm*pos.y - camDir*((focus))));\n \n float show=0.0;\n \n float t = .1;\n float temp = 0.;\n for(int i = 0 ; i < 40; i++) {\n\ttemp = len((camPos + rayDir * (t)));\n\t if(temp < 0.001) {show = 1.0;break;}\n\t if(t>pisq){break;} \n t += temp;\n }\n vec3 clr = rotate(mod((camPos + rayDir * (t)),vec3(SPIN))-0.25,rotate(sAxis,wAxis,ang*pisq),ang*pi+t);\n clr = (show*(spin(clr))/(t))*(dot(rayDir,nrm(mod((camPos + rayDir * (t)),vec3(10.5))-0.25)));\n v_color = vec4(clr, 1.0);\n\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-pop2mecp2pp2uz5e4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hwNhHN2Dy2kDpwmBD/art.json b/art/hwNhHN2Dy2kDpwmBD/art.json index 5d8c808b..77777e4e 100644 --- a/art/hwNhHN2Dy2kDpwmBD/art.json +++ b/art/hwNhHN2Dy2kDpwmBD/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/plu-collective/circuitry\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Lesson 05\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegements) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / 1. * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.;\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId,\\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float CircleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(CircleId, across);\\n float y = floor(CircleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.02 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/plu-collective/circuitry", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Lesson 05\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\n\n\nvec2 getCirclePoint(float id, float numCircleSegements) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / 1. * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.;\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId,\n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float CircleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(CircleId, across);\n float y = floor(CircleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.02 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-gofmoa8xhfztlo4si-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hwZKXhEqYhJTNoSZX/art.json b/art/hwZKXhEqYhJTNoSZX/art.json index ff4ee624..ca60cbb2 100644 --- a/art/hwZKXhEqYhJTNoSZX/art.json +++ b/art/hwZKXhEqYhJTNoSZX/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20001,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 20000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n // Good values for f:\\n // 0.0 in bass is always around 1\\n // 0.5 is in the mids, goes with music\\n // 1.0 is in the highs always 0\\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float theta = PI * 0.5 - t * PI;\\n float phi = TWO_PI * t * 11.0;\\n float r = sin(phi * 19.0) * 0.03 + 0.98;\\n \\n r -= 0.05 + 0.05 * sin(phi * 5.0);\\n theta += sin(phi * 11.0) * 0.08 * cos(theta) * cos(theta) * r;\\n phi += 2.0 * sin(theta) * cos(theta) * r;\\n \\n r -= 0.05 + 0.05 * cos(phi * 7.0 + r * 0.1);\\n theta += cos(phi * 13.0) * 0.05 * cos(theta);\\n phi += 2.0 * cos(theta);\\n \\n r -= 0.1 + 0.1 * sin(phi * 5.0 + r * 33.0);\\n theta += sin(phi * 5.0) * 0.25 * cos(theta) * (1.0 - r);\\n phi += 0.3 * sin(theta) * r;\\n \\n r -= 0.1 + 0.1 * cos(phi * 11.0 + r * 11.0);\\n theta += cos(phi * 17.0 + r) * 0.05 * cos(theta) * cos(theta);\\n phi += 0.01 * cos(phi * 19.0 + r) * cos(theta);\\n \\n theta += sin(phi * 23.0) * 0.1 * cos(theta);\\n phi += 0.1 * sin(phi * 2.0) * cos(phi);\\n \\n float x = cos(phi) * cos(theta);\\n float y = sin(phi) * cos(theta);\\n float z = sin(theta);\\n return r * vec3(x, y, z);\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\\n \\n float power = 0.0;\\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\\n power = sqrt(power);\\n \\n\\n float mix1 = getSound(r, 0.0) - r;\\n float mix2 = power - r + 0.3;\\n float mixt = mix1 * 3.0 + mix2 * 10.0;\\n \\n float rwave = sin(mixt * 0.8);\\n float tpulse = sin((time * 0.05 + t * 100.0) * TWO_PI + mixt * 0.05);\\n float trpulse = sin(r * 0.75 * TWO_PI - time);\\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\\n \\n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\\n \\n \\n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\\n float s = 1.0 - ((1.0 - rpulse) * pulse);\\n\\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\\n}\"}", + "settings": { + "num": 20001, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/sarahkreis/sets/sarah-kreis-live-recordings", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 20000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n // Good values for f:\n // 0.0 in bass is always around 1\n // 0.5 is in the mids, goes with music\n // 1.0 is in the highs always 0\n return texture2D(sound, vec2(f * 0.25, delay / soundRes.y)).a;\n}\n\nvec3 curvePos(float t) {\n float theta = PI * 0.5 - t * PI;\n float phi = TWO_PI * t * 11.0;\n float r = sin(phi * 19.0) * 0.03 + 0.98;\n \n r -= 0.05 + 0.05 * sin(phi * 5.0);\n theta += sin(phi * 11.0) * 0.08 * cos(theta) * cos(theta) * r;\n phi += 2.0 * sin(theta) * cos(theta) * r;\n \n r -= 0.05 + 0.05 * cos(phi * 7.0 + r * 0.1);\n theta += cos(phi * 13.0) * 0.05 * cos(theta);\n phi += 2.0 * cos(theta);\n \n r -= 0.1 + 0.1 * sin(phi * 5.0 + r * 33.0);\n theta += sin(phi * 5.0) * 0.25 * cos(theta) * (1.0 - r);\n phi += 0.3 * sin(theta) * r;\n \n r -= 0.1 + 0.1 * cos(phi * 11.0 + r * 11.0);\n theta += cos(phi * 17.0 + r) * 0.05 * cos(theta) * cos(theta);\n phi += 0.01 * cos(phi * 19.0 + r) * cos(theta);\n \n theta += sin(phi * 23.0) * 0.1 * cos(theta);\n phi += 0.1 * sin(phi * 2.0) * cos(phi);\n \n float x = cos(phi) * cos(theta);\n float y = sin(phi) * cos(theta);\n float z = sin(theta);\n return r * vec3(x, y, z);\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = (sqrt(p.x * p.x + p.y * p.y + p.z * p.z) - 0.5) / 0.5;\n \n float power = 0.0;\n for (int i = 0; i < 20; i++) power += 0.05 * pow(getSound(float(i) * 0.02 + 0.1, 0.0), 2.0);\n power = sqrt(power);\n \n\n float mix1 = getSound(r, 0.0) - r;\n float mix2 = power - r + 0.3;\n float mixt = mix1 * 3.0 + mix2 * 10.0;\n \n float rwave = sin(mixt * 0.8);\n float tpulse = sin((time * 0.05 + t * 100.0) * TWO_PI + mixt * 0.05);\n float trpulse = sin(r * 0.75 * TWO_PI - time);\n float trpulse_mixt = sin(r * 0.5 + mixt * 0.5);\n \n float rpulse = pow(0.5 + 0.5 * trpulse, 25.0);\n float rpulse_mixt = pow(0.5 + 0.5 * trpulse_mixt, 5.0);\n float pulse = pow(0.5 + 0.5 * tpulse, 150.0);\n \n \n float v = pulse * 0.5 + 0.5 * rpulse_mixt + 0.1;\n float h = sin(time * 0.2 + sin(t * TWO_PI) * 0.1);\n float s = 1.0 - ((1.0 - rpulse) * pulse);\n\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), v);\n}" + }, "screenshotURL": "data/images/images-z896sest5fiw4cm4v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hx3wegzB6mT7kmxAg/art.json b/art/hx3wegzB6mT7kmxAg/art.json index 9b3122bc..3d0c8b7a 100644 --- a/art/hx3wegzB6mT7kmxAg/art.json +++ b/art/hx3wegzB6mT7kmxAg/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "xi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GhDJubRRp-SM2AciN7fDuusjZXt4-We-Q9ZOwXU", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.0196078431372549,0.2784313725490196,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x/600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.0196078431372549, + 0.2784313725490196, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x/600.;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-hk5o5iprckn3tjki8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/hx9o8G4NbrqkXa8dd/art.json b/art/hx9o8G4NbrqkXa8dd/art.json index fc78aa1f..95859288 100644 --- a/art/hx9o8G4NbrqkXa8dd/art.json +++ b/art/hx9o8G4NbrqkXa8dd/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "michell", "avatarUrl": "https://graph.facebook.com/10214849161372343/picture?type=large", - "settings": "{\"num\":3567,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec2 getCircle(float id) \\n{\\n \\n float uxc= floor(id / 6.0) + mod(id, 2.0);\\n float vyc = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = uxc / 20.0 * radians(180.0) * 2.0; //20 segmentos\\n float radius = vyc + 1.0;\\n \\n \\n float xc = radius * cos(angle);\\n float yc = radius * sin(angle);\\n \\n return vec2(xc, yc);\\n}\\n\\nvoid main()\\n{\\n \\n vec2 circleXY = getCircle(vertexId);\\n \\n float circleId = floor(vertexId / 120.0);\\n float circleCount = floor(vertexCount / 120.0);\\n \\n float sqrTotal = floor(sqrt(circleCount));\\n float width = sqrTotal;\\n \\n float x = mod(circleId, width); \\n float y = floor(circleId / width); \\n\\n\\n float u = x / (width - 1.0) ;\\n float v = y/ (width - 1.0) ;\\n\\n float ux = u * 2.0 - 1.0 ;\\n float vy = v * 2.0 - 1.0 ;\\n \\n vec2 xy = circleXY * 0.1 + vec2( ux, vy);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\n\\n}\"}", + "settings": { + "num": 3567, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec2 getCircle(float id) \n{\n \n float uxc= floor(id / 6.0) + mod(id, 2.0);\n float vyc = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = uxc / 20.0 * radians(180.0) * 2.0; //20 segmentos\n float radius = vyc + 1.0;\n \n \n float xc = radius * cos(angle);\n float yc = radius * sin(angle);\n \n return vec2(xc, yc);\n}\n\nvoid main()\n{\n \n vec2 circleXY = getCircle(vertexId);\n \n float circleId = floor(vertexId / 120.0);\n float circleCount = floor(vertexCount / 120.0);\n \n float sqrTotal = floor(sqrt(circleCount));\n float width = sqrTotal;\n \n float x = mod(circleId, width); \n float y = floor(circleId / width); \n\n\n float u = x / (width - 1.0) ;\n float v = y/ (width - 1.0) ;\n\n float ux = u * 2.0 - 1.0 ;\n float vy = v * 2.0 - 1.0 ;\n \n vec2 xy = circleXY * 0.1 + vec2( ux, vy);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n \n\n}" + }, "screenshotURL": "data/images/images-1xm241qu4ezj4n4qj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/hzwNZWmd4xaC2Z6Wa/art.json b/art/hzwNZWmd4xaC2Z6Wa/art.json index 58a46966..8a65c437 100644 --- a/art/hzwNZWmd4xaC2Z6Wa/art.json +++ b/art/hzwNZWmd4xaC2Z6Wa/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n}" + }, "screenshotURL": "data/images/images-4rf8uhe8j0uzv8y70-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/i2H6FMn7RveYhnm4D/art.json b/art/i2H6FMn7RveYhnm4D/art.json index 068ea7ca..3e01c5f4 100644 --- a/art/i2H6FMn7RveYhnm4D/art.json +++ b/art/i2H6FMn7RveYhnm4D/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":10000,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 2. //KParameter4 1.>>10.\\n#define spikeFactor2 2. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * ((snd * 0.05) * abs(sin(time *4.5)));\\n rad += snd * 0.000000001; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n //point p2 = getPoint((vertexId - 1.) / vertexCount);\\n //point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n float turnSpeed = 0.1;\\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = (time * turnSpeed) - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n //p1.position.yz *= -rotateX;\\n p1.position.xz *= -rotateY;\\n //p1.position.xy *= -rotateZ; \\n\\n \\n float screenZ = 0.;\\n float eyeZ = -0.4;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 2. //KParameter4 1.>>10.\n#define spikeFactor2 2. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * ((snd * 0.05) * abs(sin(time *4.5)));\n rad += snd * 0.000000001; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n //point p2 = getPoint((vertexId - 1.) / vertexCount);\n //point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n float turnSpeed = 0.1;\n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = (time * turnSpeed) - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n //p1.position.yz *= -rotateX;\n p1.position.xz *= -rotateY;\n //p1.position.xy *= -rotateZ; \n\n \n float screenZ = 0.;\n float eyeZ = -0.4;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.a / (2. * PI) * PI/8. + (time * 0.05));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-z22555c71wz618mva-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/i2MzwYgwq9p5mJ42Q/art.json b/art/i2MzwYgwq9p5mJ42Q/art.json index e7cfa5ea..58d951a4 100644 --- a/art/i2MzwYgwq9p5mJ42Q/art.json +++ b/art/i2MzwYgwq9p5mJ42Q/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":8196,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n gl_PointSize = 5.0;\\n \\n v_color = vec4(\\n abs(sin(vertexId * 0.1 - time * 8.0)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\\n 1.0);\\n \\n gl_Position.x = sin(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\\n gl_Position.y = cos(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\\n gl_Position.z = 0.0;\\n gl_Position[3] = 1.0;\\n}\"}", + "settings": { + "num": 8196, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n gl_PointSize = 5.0;\n \n v_color = vec4(\n abs(sin(vertexId * 0.1 - time * 8.0)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\n 1.0);\n \n gl_Position.x = sin(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\n gl_Position.y = cos(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\n gl_Position.z = 0.0;\n gl_Position[3] = 1.0;\n}" + }, "screenshotURL": "data/images/images-v4151htp019pzzqtb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/i3Zcb8RFiak58hsFx/art.json b/art/i3Zcb8RFiak58hsFx/art.json index 5fd4ab33..1ed56b1b 100644 --- a/art/i3Zcb8RFiak58hsFx/art.json +++ b/art/i3Zcb8RFiak58hsFx/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":73,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 4\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 2., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \\ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \\ntriangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( 1326.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \\ntriangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \\ntriangles[ 8]=vec4( 4.0, 47.0, 1326.0, 4.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(mouse.y*2.)*rotZ(mouse.x)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/6.0+0.1*(vec4(.0,.0,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=10.0;\\n gl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 73, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 4\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\n\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 2., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \ntriangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \ntriangles[ 4]=vec4( 1326.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \ntriangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \ntriangles[ 8]=vec4( 4.0, 47.0, 1326.0, 4.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(mouse.y*2.)*rotZ(mouse.x)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/6.0+0.1*(vec4(.0,.0,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=10.0;\n gl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-1uwipxrqhluc9cp90-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/i45xFrKEbpDpjYMW8/art.json b/art/i45xFrKEbpDpjYMW8/art.json index 45bbdc12..e208afcd 100644 --- a/art/i45xFrKEbpDpjYMW8/art.json +++ b/art/i45xFrKEbpDpjYMW8/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.13725490196078433,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\\n vertexId;\\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\\n float x = mod(vertexId, across);\\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n gl_Position = vec4(xy, 0., 1.);\\n \\n float szoff = sin(time + x * y * 0.02) * 5.;\\n\\n gl_PointSize = 15.0 + szoff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1., 0., 0., 1.);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.13725490196078433, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\n vertexId;\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\n float x = mod(vertexId, across);\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n gl_Position = vec4(xy, 0., 1.);\n \n float szoff = sin(time + x * y * 0.02) * 5.;\n\n gl_PointSize = 15.0 + szoff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1., 0., 0., 1.);\n}" + }, "screenshotURL": "data/images/images-htvpv3yg3yfwurarj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/i47npurSmZHhWuwbZ/art.json b/art/i47npurSmZHhWuwbZ/art.json index 01b8706a..5f758989 100644 --- a/art/i47npurSmZHhWuwbZ/art.json +++ b/art/i47npurSmZHhWuwbZ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mikipom", "avatarUrl": "https://secure.gravatar.com/avatar/fb938bdfd01f14cf89f8e00712fde243?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nfloat squareid(float vid, float snum)\\n{\\n\\tfloat sid = floor(vid / snum);\\n \\treturn sid;\\n}\\n\\nfloat squareVertexid(float vid, float sid, float snum)\\n{\\n\\tfloat svid = vid - sid * snum;\\n \\treturn svid;\\n}\\n\\nfloat groupid(float svid, float segment)\\n{\\n float gid = floor(svid / segment);\\n return gid;\\n}\\n\\nfloat groupVertexid(float svid, float gid, float segment)\\n{\\n float gvid = svid - gid * segment;\\n return gvid;\\n}\\n\\nvec3 sPos(float sid, float svid, float gid, float gvid, float segmentLength, float segment)\\n{\\n float sl = segmentLength;\\n float sidl = sid + 1.;\\n sl *= sidl;//slはsidごとに固有\\n \\n vec3 pos;\\n \\n if(gid == 0.){\\n pos.x = 0. + gid + gvid * sl;\\n pos.y = 0.;\\n }else if(gid == 1.){\\n pos.x = 0. + gid * segment * sl;\\n pos.y = 0. - gvid * sl;\\n }else if(gid == 2.){\\n pos.x = gid * segment * sl - gvid * sl;\\n pos.y = 0. - (gid - 1.) * segment * sl;\\n }else{\\n pos.x = 0.;\\n pos.y = - (gid - 2.) * segment * sl + gvid * sl;\\n }\\n \\n //sidごとにoffset\\n float centerX = (0. + 1. * segment * sl) / 2.;\\n float centerY = (0. - (2. - 1.) * segment * sl ) / 2.;\\n \\n pos.x -= centerX;\\n pos.y -= centerY;\\n pos.z = sid;\\n \\n return pos;\\n}\\n\\n\\nvoid main()\\n{\\n \\n float x = vertexId / 20.0;\\n \\n float _vid = vertexId;\\n float _snum = 8.;\\n float _segment = 3.;\\n float _segmentLength = 1.;\\n \\n float _sid = squareid(_vid, _snum);\\n float _svid = squareVertexid(_vid, _sid, _snum);\\n float _gid = groupid(_svid, _segment);\\n float _gvid = groupVertexid(_svid, _gid, _segment);\\n \\n vec3 _pos = sPos(_sid, _svid, _gid, _gvid, _segmentLength, _segment);\\n \\n gl_Position = vec4(_pos, 1.);\\n gl_PointSize = 3.;\\n \\n\\tv_color = vec4(vec3(0.),1.);\\n}\\n\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nfloat squareid(float vid, float snum)\n{\n\tfloat sid = floor(vid / snum);\n \treturn sid;\n}\n\nfloat squareVertexid(float vid, float sid, float snum)\n{\n\tfloat svid = vid - sid * snum;\n \treturn svid;\n}\n\nfloat groupid(float svid, float segment)\n{\n float gid = floor(svid / segment);\n return gid;\n}\n\nfloat groupVertexid(float svid, float gid, float segment)\n{\n float gvid = svid - gid * segment;\n return gvid;\n}\n\nvec3 sPos(float sid, float svid, float gid, float gvid, float segmentLength, float segment)\n{\n float sl = segmentLength;\n float sidl = sid + 1.;\n sl *= sidl;//slはsidごとに固有\n \n vec3 pos;\n \n if(gid == 0.){\n pos.x = 0. + gid + gvid * sl;\n pos.y = 0.;\n }else if(gid == 1.){\n pos.x = 0. + gid * segment * sl;\n pos.y = 0. - gvid * sl;\n }else if(gid == 2.){\n pos.x = gid * segment * sl - gvid * sl;\n pos.y = 0. - (gid - 1.) * segment * sl;\n }else{\n pos.x = 0.;\n pos.y = - (gid - 2.) * segment * sl + gvid * sl;\n }\n \n //sidごとにoffset\n float centerX = (0. + 1. * segment * sl) / 2.;\n float centerY = (0. - (2. - 1.) * segment * sl ) / 2.;\n \n pos.x -= centerX;\n pos.y -= centerY;\n pos.z = sid;\n \n return pos;\n}\n\n\nvoid main()\n{\n \n float x = vertexId / 20.0;\n \n float _vid = vertexId;\n float _snum = 8.;\n float _segment = 3.;\n float _segmentLength = 1.;\n \n float _sid = squareid(_vid, _snum);\n float _svid = squareVertexid(_vid, _sid, _snum);\n float _gid = groupid(_svid, _segment);\n float _gvid = groupVertexid(_svid, _gid, _segment);\n \n vec3 _pos = sPos(_sid, _svid, _gid, _gvid, _segmentLength, _segment);\n \n gl_Position = vec4(_pos, 1.);\n gl_PointSize = 3.;\n \n\tv_color = vec4(vec3(0.),1.);\n}\n" + }, "screenshotURL": "data/images/images-k33hsz73eulug2jrv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/i6KKW4mstdDQe6aQK/art.json b/art/i6KKW4mstdDQe6aQK/art.json index f0b82ba6..a0139673 100644 --- a/art/i6KKW4mstdDQe6aQK/art.json +++ b/art/i6KKW4mstdDQe6aQK/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/marawan-alsyed/suzume-no-tojimari-ost-kanata?si=1492fc6220da413bb94e32ef88a586e3&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor( sqrt(vertexCount) );\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, sin(time) * .5 + .5);\\n \\n float soff = 0.; //sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(.8, snd);\\n float hue = u * 1. + snd * 0.2 + time * .2; //sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump); //mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/marawan-alsyed/suzume-no-tojimari-ost-kanata?si=1492fc6220da413bb94e32ef88a586e3&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor( sqrt(vertexCount) );\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, sin(time) * .5 + .5);\n \n float soff = 0.; //sin(time + x * y * .02) * 5.; \n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(.8, snd);\n float hue = u * 1. + snd * 0.2 + time * .2; //sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump); //mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\n}" + }, "screenshotURL": "data/images/images-y1h30l04ewwc6pb3m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/i7RCxecdC6AJ3heyF/art.json b/art/i7RCxecdC6AJ3heyF/art.json index f321426a..471007fa 100644 --- a/art/i7RCxecdC6AJ3heyF/art.json +++ b/art/i7RCxecdC6AJ3heyF/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/tim-e-aka-current-value/scenario\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\nvec2 project(vec2 position, vec2 a, vec2 b);\\nfloat bound(vec2 position, vec2 normal, float translation);\\nfloat sphere(vec2 position, float radius);\\nfloat torus(vec2 position, vec2 radius);\\nfloat cube(vec2 position, vec2 scale);\\nfloat simplex(vec2 position, float scale);\\nfloat segment(vec2 position, vec2 a, vec2 b);\\n\\nfloat contour(float x);\\nfloat point(vec2 position, float radius);\\nfloat point(vec2 position);\\nfloat circle(vec2 position, float radius);\\nfloat line(vec2 p, vec2 a, vec2 b);\\nfloat box(vec2 position, vec2 scale);\\nfloat triangle(vec2 position, vec2 scale);\\nmat2 rmat(float t);\\n\\n \\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.1)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\\n\\tvec2 p\\t= uv - .5;\\n\\tp \\t*= ASPECT;\\n\\t//p \\t= normalize(vec3(p, 1.-length(p))).xy;\\n\\t\\n\\tvec2 m\\t= vec2(2.*sin(time*.008), cos(time*.006)) - .5;\\n\\tm \\t*= ASPECT;\\n\\tm\\t*= 2.;\\n\\tfloat c \\t= 0.;\\n\\tfloat b \\t= 0.;\\n\\tfloat t\\t= 0.;\\n\\t\\n\\tvec2 d = normalize(m-p);\\n\\n\\t\\n\\tmat2 rm = rmat(m.x*(8.*atan(1.)));\\n\\tfor(int i = 0; i < 35; i++)\\n\\t{\\n\\t\\tp = abs(p)-.5;\\n\\t\\tp *= rm;\\n\\t//\\tp = p/dot(p,p);\\n\\t\\tc += circle(p, .25);\\n\\t\\tb += box(p, vec2(.5));\\n\\t\\tt += triangle(p, vec2(.5));\\n\\t\\tp *= 1. + 32.*fract(.001);\\n\\n\\t\\t\\n\\t}\\n\\t\\n\\tvec4 result = vec4(0.);\\n\\n\\tresult.x\\t\\t+= c;\\n\\tresult.z\\t\\t+= t;\\n\\tresult.y\\t\\t+= b;\\t\\n\\t\\n\\tresult.w \\t= 1.;\\n\\n v_color = result;\\n\\t\\n //camera\\n float r = 0.9;\\n float tm = 1.5;\\n float tm2 = 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n if(depth>=0.5)\\n {\\n depthFactor = depth/10.;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, depth*0.1*snd, 1.);\\n \\n gl_Position = mat*finalPos;\\n}\\n\\n\\n\\nfloat contour(float x)\\n{\\n\\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\\n}\\n\\t\\t\\t \\nvec2 project(vec2 position, vec2 a, vec2 b)\\n{\\n\\tvec2 q\\t \\t= b - a;\\t\\n\\tfloat u \\t\\t= dot(position - a, q)/dot(q, q);\\n\\tu \\t\\t= clamp(u, 0., 1.);\\n\\treturn mix(a, b, u);\\n}\\n\\nfloat bound(vec2 position, vec2 normal, float translation)\\n{\\n return dot(position, normal) + translation;\\n}\\n\\nfloat sphere(vec2 position, float radius)\\n{\\n\\treturn length(position)-radius;\\n}\\n\\nfloat torus(vec2 position, vec2 radius)\\n{\\n\\t\\n\\treturn abs(abs(length(position)-radius.x)-radius.y);\\n}\\n\\nfloat cube(vec2 position, vec2 scale)\\n{\\n\\tvec2 vertex \\t= abs(position) - scale;\\n\\tvec2 edge \\t= max(vertex, 0.);\\n\\tfloat interior\\t= max(vertex.x, vertex.y);\\n\\treturn min(interior, 0.) + length(edge);\\n}\\n\\nfloat simplex(vec2 position, float scale)\\n{\\t\\t\\n\\tconst float r3\\t= 1.73205080757;//sqrt(3.);\\n\\t\\n\\tposition.y\\t/= r3; \\n\\t\\n\\tvec3 edge\\t= vec3(0.);\\n\\tedge.x\\t\\t= position.y + position.x;\\n\\tedge.y\\t\\t= position.x - position.y;\\n\\tedge.z\\t\\t= position.y + position.y;\\n\\tedge\\t\\t*= .86602540358; //cos(pi/6.);\\n\\t\\n\\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\\n}\\n\\nfloat segment(vec2 position, vec2 a, vec2 b)\\n{\\n\\treturn distance(position, project(position, a, b));\\n}\\n\\nfloat point(vec2 position, float radius)\\n{\\n\\treturn contour(sphere(position*RESOLUTION_MIN, radius));\\t\\n}\\n\\nfloat point(vec2 position)\\n{\\n\\treturn point(position, 3.);\\t\\n}\\n\\nfloat circle(vec2 position, float radius)\\n{\\n\\treturn contour(torus(position, vec2(radius,0.)));\\n}\\n\\nfloat line(vec2 p, vec2 a, vec2 b)\\n{\\n\\treturn contour(segment(p, a, b));\\n}\\n\\nfloat box(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(cube(position, scale)));\\t\\n}\\n\\nfloat triangle(vec2 position, vec2 scale)\\n{\\n\\treturn contour(abs(simplex(position, scale.x)));\\t\\n}\\n\\t\\t\\t \\nmat2 rmat(float t)\\n{\\n\\tfloat c = cos(t);\\n\\tfloat s = sin(t);\\n\\treturn mat2(c, s, -s, c);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/tim-e-aka-current-value/scenario", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\nvec2 project(vec2 position, vec2 a, vec2 b);\nfloat bound(vec2 position, vec2 normal, float translation);\nfloat sphere(vec2 position, float radius);\nfloat torus(vec2 position, vec2 radius);\nfloat cube(vec2 position, vec2 scale);\nfloat simplex(vec2 position, float scale);\nfloat segment(vec2 position, vec2 a, vec2 b);\n\nfloat contour(float x);\nfloat point(vec2 position, float radius);\nfloat point(vec2 position);\nfloat circle(vec2 position, float radius);\nfloat line(vec2 p, vec2 a, vec2 b);\nfloat box(vec2 position, vec2 scale);\nfloat triangle(vec2 position, vec2 scale);\nmat2 rmat(float t);\n\n \n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.1)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 uv = vec2(u,v);//fragcoord.xy/resolution.xy;\n\tvec2 p\t= uv - .5;\n\tp \t*= ASPECT;\n\t//p \t= normalize(vec3(p, 1.-length(p))).xy;\n\t\n\tvec2 m\t= vec2(2.*sin(time*.008), cos(time*.006)) - .5;\n\tm \t*= ASPECT;\n\tm\t*= 2.;\n\tfloat c \t= 0.;\n\tfloat b \t= 0.;\n\tfloat t\t= 0.;\n\t\n\tvec2 d = normalize(m-p);\n\n\t\n\tmat2 rm = rmat(m.x*(8.*atan(1.)));\n\tfor(int i = 0; i < 35; i++)\n\t{\n\t\tp = abs(p)-.5;\n\t\tp *= rm;\n\t//\tp = p/dot(p,p);\n\t\tc += circle(p, .25);\n\t\tb += box(p, vec2(.5));\n\t\tt += triangle(p, vec2(.5));\n\t\tp *= 1. + 32.*fract(.001);\n\n\t\t\n\t}\n\t\n\tvec4 result = vec4(0.);\n\n\tresult.x\t\t+= c;\n\tresult.z\t\t+= t;\n\tresult.y\t\t+= b;\t\n\t\n\tresult.w \t= 1.;\n\n v_color = result;\n\t\n //camera\n float r = 0.9;\n float tm = 1.5;\n float tm2 = 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n if(depth>=0.5)\n {\n depthFactor = depth/10.;\n }\n \n vec4 finalPos = vec4(ux, vy, depth*0.1*snd, 1.);\n \n gl_Position = mat*finalPos;\n}\n\n\n\nfloat contour(float x)\n{\n\treturn 1.-clamp(.6 * x * RESOLUTION_MIN, 0., 1.);\n}\n\t\t\t \nvec2 project(vec2 position, vec2 a, vec2 b)\n{\n\tvec2 q\t \t= b - a;\t\n\tfloat u \t\t= dot(position - a, q)/dot(q, q);\n\tu \t\t= clamp(u, 0., 1.);\n\treturn mix(a, b, u);\n}\n\nfloat bound(vec2 position, vec2 normal, float translation)\n{\n return dot(position, normal) + translation;\n}\n\nfloat sphere(vec2 position, float radius)\n{\n\treturn length(position)-radius;\n}\n\nfloat torus(vec2 position, vec2 radius)\n{\n\t\n\treturn abs(abs(length(position)-radius.x)-radius.y);\n}\n\nfloat cube(vec2 position, vec2 scale)\n{\n\tvec2 vertex \t= abs(position) - scale;\n\tvec2 edge \t= max(vertex, 0.);\n\tfloat interior\t= max(vertex.x, vertex.y);\n\treturn min(interior, 0.) + length(edge);\n}\n\nfloat simplex(vec2 position, float scale)\n{\t\t\n\tconst float r3\t= 1.73205080757;//sqrt(3.);\n\t\n\tposition.y\t/= r3; \n\t\n\tvec3 edge\t= vec3(0.);\n\tedge.x\t\t= position.y + position.x;\n\tedge.y\t\t= position.x - position.y;\n\tedge.z\t\t= position.y + position.y;\n\tedge\t\t*= .86602540358; //cos(pi/6.);\n\t\n\treturn max(edge.x, max(-edge.y, -edge.z))-scale/r3;\n}\n\nfloat segment(vec2 position, vec2 a, vec2 b)\n{\n\treturn distance(position, project(position, a, b));\n}\n\nfloat point(vec2 position, float radius)\n{\n\treturn contour(sphere(position*RESOLUTION_MIN, radius));\t\n}\n\nfloat point(vec2 position)\n{\n\treturn point(position, 3.);\t\n}\n\nfloat circle(vec2 position, float radius)\n{\n\treturn contour(torus(position, vec2(radius,0.)));\n}\n\nfloat line(vec2 p, vec2 a, vec2 b)\n{\n\treturn contour(segment(p, a, b));\n}\n\nfloat box(vec2 position, vec2 scale)\n{\n\treturn contour(abs(cube(position, scale)));\t\n}\n\nfloat triangle(vec2 position, vec2 scale)\n{\n\treturn contour(abs(simplex(position, scale.x)));\t\n}\n\t\t\t \nmat2 rmat(float t)\n{\n\tfloat c = cos(t);\n\tfloat s = sin(t);\n\treturn mat2(c, s, -s, c);\n}" + }, "screenshotURL": "data/images/images-iav3j6b77modqy3b8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iAGxyHrFa3k6ZJq5k/art.json b/art/iAGxyHrFa3k6ZJq5k/art.json index 28734ec5..57b77cce 100644 --- a/art/iAGxyHrFa3k6ZJq5k/art.json +++ b/art/iAGxyHrFa3k6ZJq5k/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jonnynewo", "avatarUrl": "https://secure.gravatar.com/avatar/2ee3fa32fc5fe43ece0455f4e45b5c3b?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n \\tfloat down = floor(sqrt(vertexCount)); // est grid\\n \\tfloat across = floor(vertexCount / down); // more grid\\n \\n \\tfloat x = mod(vertexId, across); // red dot boi\\n \\tfloat y = floor(vertexId / across); // twin\\n\\n \\n \\tfloat u = x / (across -1.); \\n \\tfloat v = y / (across -1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1; //(motion)\\n \\tfloat yoff = sin(time * 1.1 + x * 0.3) * 0.1; //(motion)\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.0;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5.; // (motion)\\n \\n \\tgl_PointSize = 15.0 + soff; \\n \\tgl_PointSize *= 20. / across; \\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tfloat hue = u * .1 + sin(time + v * 20.) * 0.05;\\n \\tfloat sat = 1.;\\n \\tfloat val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); // refers to R, G, B, alpha\\n \\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n \tfloat down = floor(sqrt(vertexCount)); // est grid\n \tfloat across = floor(vertexCount / down); // more grid\n \n \tfloat x = mod(vertexId, across); // red dot boi\n \tfloat y = floor(vertexId / across); // twin\n\n \n \tfloat u = x / (across -1.); \n \tfloat v = y / (across -1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1; //(motion)\n \tfloat yoff = sin(time * 1.1 + x * 0.3) * 0.1; //(motion)\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.0;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5.; // (motion)\n \n \tgl_PointSize = 15.0 + soff; \n \tgl_PointSize *= 20. / across; \n \tgl_PointSize *= resolution.x / 600.;\n \n \tfloat hue = u * .1 + sin(time + v * 20.) * 0.05;\n \tfloat sat = 1.;\n \tfloat val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); // refers to R, G, B, alpha\n \n}\n" + }, "screenshotURL": "data/images/images-ri4l3og5qb4hwwvd8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iCRwaQsZvFQ2eLheK/art.json b/art/iCRwaQsZvFQ2eLheK/art.json index f25c7596..279d8218 100644 --- a/art/iCRwaQsZvFQ2eLheK/art.json +++ b/art/iCRwaQsZvFQ2eLheK/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":12649,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Audio Reactive\\n// CS250 Spring 2022\\n\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float PI = 3.14159265358979;\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = 0.0;\\n float yOffset = 0.0;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.1, av * 0.25)).a;\\n \\n gl_Position = vec4(xy + vec2(texture2D(sound, vec2(au * 0.0001, av * 0.1)).a) - vec2(0.8), 0.0, 1.0);\\n \\n float sizeOffset = 0.0;\\n \\n gl_PointSize = pow(snd + 0.1, 7.0) * 30.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n const float range = 120.0;\\n const float block = 120.0 / 240.0;\\n float sum = 0.0;\\n for (float b = 0.0; b < range / 240.0; b += block)\\n {\\n sum += texture2D(sound, vec2(b, av * 0.25)).a;\\n }\\n \\n float hue = sum / block;\\n float saturation = mix(0.0, 1.5, snd);\\n float value = mix(0.1, pow(snd + 0.15, 5.0), snd);\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 12649, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Audio Reactive\n// CS250 Spring 2022\n\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float PI = 3.14159265358979;\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = 0.0;\n float yOffset = 0.0;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.1, av * 0.25)).a;\n \n gl_Position = vec4(xy + vec2(texture2D(sound, vec2(au * 0.0001, av * 0.1)).a) - vec2(0.8), 0.0, 1.0);\n \n float sizeOffset = 0.0;\n \n gl_PointSize = pow(snd + 0.1, 7.0) * 30.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n const float range = 120.0;\n const float block = 120.0 / 240.0;\n float sum = 0.0;\n for (float b = 0.0; b < range / 240.0; b += block)\n {\n sum += texture2D(sound, vec2(b, av * 0.25)).a;\n }\n \n float hue = sum / block;\n float saturation = mix(0.0, 1.5, snd);\n float value = mix(0.1, pow(snd + 0.15, 5.0), snd);\n \n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-ncbpbz5360e6i9r4j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iE3Xz7bewdDm3shFC/art.json b/art/iE3Xz7bewdDm3shFC/art.json index 03830360..aa55ad6d 100644 --- a/art/iE3Xz7bewdDm3shFC/art.json +++ b/art/iE3Xz7bewdDm3shFC/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "Infinite Heart of Glass", "username": "c0d3rguy", - "settings": "{\"num\":256,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/special-guests-band/blondie-heart-of-glass-1979\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float t = time + 5.0;\\n \\n float sndx = texture2D(sound, vec2(0.4, 0.4)).a;\\n float sndy = texture2D(sound, vec2(0.2, 0.2)).a;\\n \\n float xo = vertexId / 128.0;\\n float yo = vertexId / 64.0;\\n \\n vec2 xy = vec2(cos(xo * t) * 2.0 * sndx, \\n sin(yo * t) * 2.0 * sndy * sndx);\\n xy *= 0.8;\\n\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n v_color = vec4(vec3(clamp(xy.y + 0.8, 0.0, 1.0), \\n clamp(xy.x + 0.7, 0.0, 1.0), \\n clamp(xy.y + 0.8, 0.0, 1.0)), 1.0);\\n}\"}", + "settings": { + "num": 256, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/special-guests-band/blondie-heart-of-glass-1979", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float t = time + 5.0;\n \n float sndx = texture2D(sound, vec2(0.4, 0.4)).a;\n float sndy = texture2D(sound, vec2(0.2, 0.2)).a;\n \n float xo = vertexId / 128.0;\n float yo = vertexId / 64.0;\n \n vec2 xy = vec2(cos(xo * t) * 2.0 * sndx, \n sin(yo * t) * 2.0 * sndy * sndx);\n xy *= 0.8;\n\n \n gl_Position = vec4(xy, 0, 1);\n\n v_color = vec4(vec3(clamp(xy.y + 0.8, 0.0, 1.0), \n clamp(xy.x + 0.7, 0.0, 1.0), \n clamp(xy.y + 0.8, 0.0, 1.0)), 1.0);\n}" + }, "screenshotURL": "data/images/images-9h2aq4d3g8kdx2xez-thumbnail.jpg", "views": { "$numberInt": "140" diff --git a/art/iEqWJsdh8qGqoogEL/art.json b/art/iEqWJsdh8qGqoogEL/art.json index 692765b8..671e08c5 100644 --- a/art/iEqWJsdh8qGqoogEL/art.json +++ b/art/iEqWJsdh8qGqoogEL/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "yuso", "avatarUrl": "https://lh6.googleusercontent.com/-18vnTfqanvU/AAAAAAAAAAI/AAAAAAAACG0/w2PJTF6mhiY/photo.jpg", - "settings": "{\"num\":25914,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*void main() {\\n \\n float width = 20.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\nvec2 xy = vec2(x, y) * 0.1;\\n \\n //float xOffset = cos(time + y * 0.2) * 0.1;\\n //float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n \\n //float ux = u * 2.0 - 1.0 + xOffset;\\n //float uy = v * 2.0 - 1.0 + yOffset;\\n\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0); // Posición del vector\\n v_color = vec4(1.0, 0.0, 1.0, 0.0);\\n gl_PointSize = 20.0;\\n \\n}*/\\n/*\\nvoid main() {\\n \\n float width = 20.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float u = cos(x -1.);\\n float v = cos(y- 1.0);\\n \\nvec2 xy = vec2(u, v) * 0.1;\\n \\n //float xOffset = cos(time + y * 0.2) * 0.1;\\n //float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n \\n //float ux = u * 2.0 - 1.0 + xOffset;\\n //float uy = v * 2.0 - 1.0 + yOffset;\\n\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0); // Posición del vector\\n v_color = vec4(1.0, 0.0, 1.0, 0.0);\\n gl_PointSize = 20.0;\\n \\n}*/\\n\\nvoid main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n float radius = 2.0 - y;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n vec2 xy = vec2(u, v) * 0.1;\\n \\n\\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 25914, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*void main() {\n \n float width = 20.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \nvec2 xy = vec2(x, y) * 0.1;\n \n //float xOffset = cos(time + y * 0.2) * 0.1;\n //float yOffset = sin(time + x * 0.3) * 0.1;\n \n \n //float ux = u * 2.0 - 1.0 + xOffset;\n //float uy = v * 2.0 - 1.0 + yOffset;\n\n \n \n gl_Position = vec4(xy, 0.0, 1.0); // Posición del vector\n v_color = vec4(1.0, 0.0, 1.0, 0.0);\n gl_PointSize = 20.0;\n \n}*/\n/*\nvoid main() {\n \n float width = 20.0;\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float u = cos(x -1.);\n float v = cos(y- 1.0);\n \nvec2 xy = vec2(u, v) * 0.1;\n \n //float xOffset = cos(time + y * 0.2) * 0.1;\n //float yOffset = sin(time + x * 0.3) * 0.1;\n \n \n //float ux = u * 2.0 - 1.0 + xOffset;\n //float uy = v * 2.0 - 1.0 + yOffset;\n\n \n \n gl_Position = vec4(xy, 0.0, 1.0); // Posición del vector\n v_color = vec4(1.0, 0.0, 1.0, 0.0);\n gl_PointSize = 20.0;\n \n}*/\n\nvoid main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float angle = x / 20.0 * radians(360.0);\n float radius = 2.0 - y;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n vec2 xy = vec2(u, v) * 0.1;\n \n\n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-9xenvn7aeibvynbn8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iGf4owSji9QC6P8yF/art.json b/art/iGf4owSji9QC6P8yF/art.json index 25b8e573..d018df73 100644 --- a/art/iGf4owSji9QC6P8yF/art.json +++ b/art/iGf4owSji9QC6P8yF/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":97150,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.50, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 0.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.20), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0.2,\\n 1.9-s, 0.2, 0, 0,\\n s, -0.6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, s, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, s/2.0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0, 0,\\n trans, 0.5);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0.1, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 2, 0.1, 0);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, mouse.x, 0, 0,\\n 0, s-2., 0, -0.1,\\n 0.5, 0, s, -mouse.y,\\n 0, 0, 0, -1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(11.5351, 34.3137));\\n\\treturn fract(p2.x * p2.y / 61.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 3.2 - 2.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.81 - (0.5*v);\\n}\\n\\nfloat inv(float v) {\\n return 2. * (v - mouse.x);\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.9);\\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 3.5 ); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI - tan(sin((11.6, 110.2) / PI * 1.10));\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v -s*2.;\\n float y = s * v-c;\\n float z = 0.05 * v;\\n pos = vec3(x, y, z -s *- u/36.); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) - mouse.y -t) + sin(t * 2.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 1.5)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\\n float end = start - 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu / abs(uv.x/ 1.8 - 1.3)-7.) * 1.5, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 2.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3((0.9, resolution.y / resolution.x , mouse.y)* 1.91);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId* snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 0. + snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.51, snd+6.));\\n v_color = vec4(2.1 *v_color.rgb * v_color.a, sin(v_color.a -9.));\\n}\"}", + "settings": { + "num": 97150, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.50, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 0.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.20), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0.2,\n 1.9-s, 0.2, 0, 0,\n s, -0.6, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, s, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, s/2.0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0, 0,\n trans, 0.5);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1,\n 0, -1, 1, -0.9,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0.1, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 2, 0.1, 0);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, mouse.x, 0, 0,\n 0, s-2., 0, -0.1,\n 0.5, 0, s, -mouse.y,\n 0, 0, 0, -1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(11.5351, 34.3137));\n\treturn fract(p2.x * p2.y / 61.4337);\n}\n\nfloat m1p1(float v) {\n return v * 3.2 - 2.;\n}\n\nfloat p1m1(float v) {\n return v * 1.81 - (0.5*v);\n}\n\nfloat inv(float v) {\n return 2. * (v - mouse.x);\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.9);\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 3.5 ); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI - tan(sin((11.6, 110.2) / PI * 1.10));\n float s = sin(a);\n float c = cos(a);\n float x = c * v -s*2.;\n float y = s * v-c;\n float z = 0.05 * v;\n pos = vec3(x, y, z -s *- u/36.); \n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) - mouse.y -t) + sin(t * 2.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 1.5)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\n float end = start - 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu / abs(uv.x/ 1.8 - 1.3)-7.) * 1.5, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 2.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3((0.9, resolution.y / resolution.x , mouse.y)* 1.91);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId* snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 0. + snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.51, snd+6.));\n v_color = vec4(2.1 *v_color.rgb * v_color.a, sin(v_color.a -9.));\n}" + }, "screenshotURL": "data/images/images-h00fwicu0d4pwunvt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iHAobXHhdNFgDxEiP/art.json b/art/iHAobXHhdNFgDxEiP/art.json index f420bafd..aad63d44 100644 --- a/art/iHAobXHhdNFgDxEiP/art.json +++ b/art/iHAobXHhdNFgDxEiP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"// Taking control - the moving grid\\n\\nvoid main() {\\n float scale = 2.;\\n float modi = 0.5 * (sin(time)+1.);\\n float grid = floor(modi * 50.) + 100.;\\n float xoff = -0.5 * scale;\\n float yoff = -0.5 * scale;\\n float x = mod(vertexId , grid);\\n float y = mod(floor(vertexId / grid), grid);\\n float ux = x * scale / grid + xoff;\\n float uy = y * scale / grid + yoff;\\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = 300./grid;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "// Taking control - the moving grid\n\nvoid main() {\n float scale = 2.;\n float modi = 0.5 * (sin(time)+1.);\n float grid = floor(modi * 50.) + 100.;\n float xoff = -0.5 * scale;\n float yoff = -0.5 * scale;\n float x = mod(vertexId , grid);\n float y = mod(floor(vertexId / grid), grid);\n float ux = x * scale / grid + xoff;\n float uy = y * scale / grid + yoff;\n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = 300./grid;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-hu0uowatgv7c84204-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iJobHmTq8ahMEWFSG/art.json b/art/iJobHmTq8ahMEWFSG/art.json index c586c8d7..ba7c0f8c 100644 --- a/art/iJobHmTq8ahMEWFSG/art.json +++ b/art/iJobHmTq8ahMEWFSG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":57536,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n#define CircleDepth 16.0;\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nvec2 circleVertexPos(float vertexId) {\\n float theta = PI * 2.0 / CircleDepth;\\n \\n float triId = floor(vertexId / 3.0);\\n float triVertexId = mod(vertexId, 3.0);\\n float thetaMultiplier = triId + triVertexId;\\n \\n float t = theta * thetaMultiplier;\\n float r = step(triVertexId, 1.5);\\n \\n return vec2(cos(t), sin(t)) * r;\\n}\\n\\nvoid main() {\\n vec3 cameraPos = vec3(0.0, 0.0, 0.0);\\n \\n float vPerCircle = 3.0 * CircleDepth;\\n float cId = floor(vertexId / vPerCircle);\\n float circleCount = floor(vertexCount / vPerCircle);\\n float gridWidth = 54.;\\n vec2 gridSize = vec2(gridWidth, floor(circleCount / gridWidth));\\n vec2 gridId = vec2(mod(cId, gridSize.x), floor(cId / gridSize.x));\\n gridId -= gridSize*0.5;\\n vec2 gridUv = gridId / (gridSize * 0.5);\\n float centerDist = length(gridId);\\n \\n float angle = atan(abs(gridId.x), gridId.y) / (PI);\\n float blurAngle = PI / 128.;\\n \\n vec2 sUV = vec2(angle, 0.0);\\n sUV.y *= 0.1;\\n sUV.x *= 0.33;\\n \\n int iterId = 1;\\n sUV.x -= blurAngle * 0.0 * 0.5;\\n float snd = 0.0;\\n for (int i = 0; i <= 0; i++) {\\n if (sUV.x < 0.0) {\\n sUV.x += blurAngle;\\n continue;\\n }\\n if (sUV.x > 1.0) {\\n break;\\n }\\n float strength = 1.0 / float(iterId);\\n snd = snd * (1.0 - strength) + texture2D(sound, sUV).a * strength;\\n sUV.x += blurAngle;\\n iterId++;\\n }\\n \\n snd *= 0.8+sUV.x; // enhance strength of high-end values\\n snd = smoothstep(0.2, 0.8, snd);\\n snd = pow(snd, 4.); // enhance enhance enhance\\n \\n \\n vec3 circlePos = vec3(gridId, 20.-snd-centerDist);\\n //vec3 circleNormal = cameraPos - circlePos;\\n \\n vec3 vertexPos = vec3(circleVertexPos(vertexId), 0.0);\\n //vertexPos *= mix(0.25, sqrt(2.), pow(snd, 2.0));\\n \\n mat4 P = persp(PI*0.5, resolution.x / resolution.y, 0.1, 100.);\\n float sinT = sin(time*0.25)*0.0625*PI;\\n vec4 lookDir = (rotY(sinT) * vec4(0.0, 0.0, 1.0, 1.0));\\n mat4 V = cameraLookAt(cameraPos, lookDir.xyz, vec3(0.0, 1.0, 0.0));\\n \\n gl_Position = P * V * vec4(vertexPos + circlePos, 1.0);\\n v_color = vec4(snd, 0.0, 0.0, 1.0);\\n //v_color = vec4(hsv2rgb(vec3(snd, 1.0, 1.0)), 1.0);\\n}\"}", + "settings": { + "num": 57536, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n#define CircleDepth 16.0;\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nvec2 circleVertexPos(float vertexId) {\n float theta = PI * 2.0 / CircleDepth;\n \n float triId = floor(vertexId / 3.0);\n float triVertexId = mod(vertexId, 3.0);\n float thetaMultiplier = triId + triVertexId;\n \n float t = theta * thetaMultiplier;\n float r = step(triVertexId, 1.5);\n \n return vec2(cos(t), sin(t)) * r;\n}\n\nvoid main() {\n vec3 cameraPos = vec3(0.0, 0.0, 0.0);\n \n float vPerCircle = 3.0 * CircleDepth;\n float cId = floor(vertexId / vPerCircle);\n float circleCount = floor(vertexCount / vPerCircle);\n float gridWidth = 54.;\n vec2 gridSize = vec2(gridWidth, floor(circleCount / gridWidth));\n vec2 gridId = vec2(mod(cId, gridSize.x), floor(cId / gridSize.x));\n gridId -= gridSize*0.5;\n vec2 gridUv = gridId / (gridSize * 0.5);\n float centerDist = length(gridId);\n \n float angle = atan(abs(gridId.x), gridId.y) / (PI);\n float blurAngle = PI / 128.;\n \n vec2 sUV = vec2(angle, 0.0);\n sUV.y *= 0.1;\n sUV.x *= 0.33;\n \n int iterId = 1;\n sUV.x -= blurAngle * 0.0 * 0.5;\n float snd = 0.0;\n for (int i = 0; i <= 0; i++) {\n if (sUV.x < 0.0) {\n sUV.x += blurAngle;\n continue;\n }\n if (sUV.x > 1.0) {\n break;\n }\n float strength = 1.0 / float(iterId);\n snd = snd * (1.0 - strength) + texture2D(sound, sUV).a * strength;\n sUV.x += blurAngle;\n iterId++;\n }\n \n snd *= 0.8+sUV.x; // enhance strength of high-end values\n snd = smoothstep(0.2, 0.8, snd);\n snd = pow(snd, 4.); // enhance enhance enhance\n \n \n vec3 circlePos = vec3(gridId, 20.-snd-centerDist);\n //vec3 circleNormal = cameraPos - circlePos;\n \n vec3 vertexPos = vec3(circleVertexPos(vertexId), 0.0);\n //vertexPos *= mix(0.25, sqrt(2.), pow(snd, 2.0));\n \n mat4 P = persp(PI*0.5, resolution.x / resolution.y, 0.1, 100.);\n float sinT = sin(time*0.25)*0.0625*PI;\n vec4 lookDir = (rotY(sinT) * vec4(0.0, 0.0, 1.0, 1.0));\n mat4 V = cameraLookAt(cameraPos, lookDir.xyz, vec3(0.0, 1.0, 0.0));\n \n gl_Position = P * V * vec4(vertexPos + circlePos, 1.0);\n v_color = vec4(snd, 0.0, 0.0, 1.0);\n //v_color = vec4(hsv2rgb(vec3(snd, 1.0, 1.0)), 1.0);\n}" + }, "screenshotURL": "data/images/images-k210otrzy5415ev5i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iKJAEsvWRjffu2QnA/art.json b/art/iKJAEsvWRjffu2QnA/art.json index a03ec6a7..7e249d11 100644 --- a/art/iKJAEsvWRjffu2QnA/art.json +++ b/art/iKJAEsvWRjffu2QnA/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":17740,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) /.4;\\n offset.y += goop(circleId + time * 0.13) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -1.79));\\n float sat = 0.2 * circleId/snd;\\n float val = .9;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) * tan(pos / 83.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\\n}\"}", + "settings": { + "num": 17740, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.18 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.05, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) /.4;\n offset.y += goop(circleId + time * 0.13) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 1.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, -.02)).xyz, 0.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId -1.79));\n float sat = 0.2 * circleId/snd;\n float val = .9;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (11. / uv.y) * tan(pos / 83.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*5., v_color.a);\n}" + }, "screenshotURL": "data/images/images-kokyudeccwz0cbz3x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iLmsLpSgTGLkxKPxP/art.json b/art/iLmsLpSgTGLkxKPxP/art.json index f4f82765..446cfe60 100644 --- a/art/iLmsLpSgTGLkxKPxP/art.json +++ b/art/iLmsLpSgTGLkxKPxP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":38953,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/didrec/ken-ishii-malfunction-10\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.0123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(t * .1) * 20., sin(t * .3) * 10.*s, 0.2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .017);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\\n float sat =1.0;step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb /= v_color.a*s;\\n \\n float super = step(0.9, 1.-s);\\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\\n \\n}\\n\"}", + "settings": { + "num": 38953, + "mode": "LINES", + "sound": "https://soundcloud.com/didrec/ken-ishii-malfunction-10", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.0123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(t * .1) * 20., sin(t * .3) * 10.*s, 0.2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .017);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\n float sat =1.0;step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb /= v_color.a*s;\n \n float super = step(0.9, 1.-s);\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\n \n}\n" + }, "screenshotURL": "data/images/images-orm852jzpbjddqq3l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iPNXnwa34wBgSSDGd/art.json b/art/iPNXnwa34wBgSSDGd/art.json index ba7dbe12..0aeec6e1 100644 --- a/art/iPNXnwa34wBgSSDGd/art.json +++ b/art/iPNXnwa34wBgSSDGd/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":79552,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 1.1;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 2.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.5;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 3.27) + sin(t * 0.13 - mouse.y) + sin(t * 3.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0., p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) * 1.1 *mouse.x);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 2.)) * 0.05, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 1.8, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.3 -mouse.y );\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.1 -snd , 0.9 *mouse.x, fract(circleId * 1.79 * snd));\\n float sat = 0.5;\\n float val = 1.0 * snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.21, snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 79552, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 1.1;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 2.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.5;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 3.27) + sin(t * 0.13 - mouse.y) + sin(t * 3.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0., p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) * 1.1 *mouse.x);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 - 2.)) * 0.05, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 1.8, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.3 -mouse.y );\n gl_PointSize = 4.;\n\n float hue = mix(0.1 -snd , 0.9 *mouse.x, fract(circleId * 1.79 * snd));\n float sat = 0.5;\n float val = 1.0 * snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.21, snd*6.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-qumn71pnrbrt4ri2y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iPiDjpBYDPGFTGp8Y/art.json b/art/iPiDjpBYDPGFTGp8Y/art.json index 9756349c..096f0eaa 100644 --- a/art/iPiDjpBYDPGFTGp8Y/art.json +++ b/art/iPiDjpBYDPGFTGp8Y/art.json @@ -27,7 +27,19 @@ "name": "residualfill", "private": false, "username": "spotline", - "settings": "{\"num\":3000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n //float osc = sin(4.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.03)).a,7.0);\\n float x = (u*60.0)-1.0;\\n float y = ((v+vold)*0.5);//*osc;\\n gl_PointSize = 10.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n //float osc = sin(4.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.03)).a,7.0);\n float x = (u*60.0)-1.0;\n float y = ((v+vold)*0.5);//*osc;\n gl_PointSize = 10.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\n}" + }, "screenshotURL": "data/images/images-fz2lm2mbb8jipbv2g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iQ3Lo8pe7QqDdz8qi/art.json b/art/iQ3Lo8pe7QqDdz8qi/art.json index 6b632e04..aed8558e 100644 --- a/art/iQ3Lo8pe7QqDdz8qi/art.json +++ b/art/iQ3Lo8pe7QqDdz8qi/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":7200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/meehanperkinsduo/nagoya-marimbas-steve-reich\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float height = 10.;\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n \\n float cv = cubeId / (numCubes - 1.);\\n float cy = 2. * cv - 1.;\\n \\n\\n float s = texture2D(sound, vec2(mix(0.25, 0.05, cv), 0)).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n\\n float sc = s * 10.;\\n mat *= cameraLookAt(eye, target, up);\\n //mat *= rotZ(0.5 * PI);\\n mat *= trans(vec3(1, cy * height, 1));\\n mat *= scale(vec3(sc, height / numCubes * 2., sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(0.4, 0.8, s);//abs(ca * cc) * 2.;\\n float sat = mix(0.1, 5., pow(s, 3.));//mix(0.0, 1., step(10.8, s));\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 7200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/meehanperkinsduo/nagoya-marimbas-steve-reich", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float height = 10.;\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n \n float cv = cubeId / (numCubes - 1.);\n float cy = 2. * cv - 1.;\n \n\n float s = texture2D(sound, vec2(mix(0.25, 0.05, cv), 0)).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n\n float sc = s * 10.;\n mat *= cameraLookAt(eye, target, up);\n //mat *= rotZ(0.5 * PI);\n mat *= trans(vec3(1, cy * height, 1));\n mat *= scale(vec3(sc, height / numCubes * 2., sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(0.4, 0.8, s);//abs(ca * cc) * 2.;\n float sat = mix(0.1, 5., pow(s, 3.));//mix(0.0, 1., step(10.8, s));\n float val = 1.;//mix(1., 1., step(0.8, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-nyzootsvhi46iv9ec-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iQAtnkJRC8XtvT4tW/art.json b/art/iQAtnkJRC8XtvT4tW/art.json index 928b76ad..fe578d9b 100644 --- a/art/iQAtnkJRC8XtvT4tW/art.json +++ b/art/iQAtnkJRC8XtvT4tW/art.json @@ -22,7 +22,19 @@ "origId": "mSDHF7AjBowN86DnJ", "name": "synapsicorporation2", "username": "visy", - "settings": "{\"num\":61324,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chiptune/05-boss-v2-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\n// music by rez! here we goooooooo-oo-oo-oooooooo.....\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float localTime = time + 20.0;\\n \\n float NUM_SEGMENTS = localTime*cos(texture2D(floatSound,vec2(localTime*0.0000001,cos(localTime*0.0000001))).a*0.00001);\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2+cos(texture2D(floatSound,vec2(count*0.01,angle*0.01)).a*0.0001*localTime);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01*texture2D(floatSound,vec2(localTime,s+vertexId*0.01)).a*0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n \\n \\n float aa = (localTime*0.001)*cos(localTime*0.0001*vertexId);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle-aa);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 61324, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chiptune/05-boss-v2-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\n// music by rez! here we goooooooo-oo-oo-oooooooo.....\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float localTime = time + 20.0;\n \n float NUM_SEGMENTS = localTime*cos(texture2D(floatSound,vec2(localTime*0.0000001,cos(localTime*0.0000001))).a*0.00001);\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2+cos(texture2D(floatSound,vec2(count*0.01,angle*0.01)).a*0.0001*localTime);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01*texture2D(floatSound,vec2(localTime,s+vertexId*0.01)).a*0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n \n \n float aa = (localTime*0.001)*cos(localTime*0.0001*vertexId);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle-aa);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "BA9SyAeKnoEgtTBgM", "views": { "$numberInt": "1884" diff --git a/art/iQGt7fDGEeR4vD6ez/art.json b/art/iQGt7fDGEeR4vD6ez/art.json index c72c8285..e72ef936 100644 --- a/art/iQGt7fDGEeR4vD6ez/art.json +++ b/art/iQGt7fDGEeR4vD6ez/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8745098039215686,0.5843137254901961,0.7098039215686275,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Making a grid\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1. * sin(time * 0.5);\\n float vy = v * 2. - 1. * cos(time * 0.5);\\n \\n gl_Position = vec4(ux - 1.0, vy - 1.0, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 400.0;\\n\\n v_color = vec4(0, 0, 0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8745098039215686, + 0.5843137254901961, + 0.7098039215686275, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Making a grid\n// Course Name: CS250\n// Term: Spring 2022\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1. * sin(time * 0.5);\n float vy = v * 2. - 1. * cos(time * 0.5);\n \n gl_Position = vec4(ux - 1.0, vy - 1.0, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 400.0;\n\n v_color = vec4(0, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-mwf2h05zvukz9dlhs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iRS5hcGrNPG5aAf3w/art.json b/art/iRS5hcGrNPG5aAf3w/art.json index 825e0b58..bef46c22 100644 --- a/art/iRS5hcGrNPG5aAf3w/art.json +++ b/art/iRS5hcGrNPG5aAf3w/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":54268,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/robundchris/eminem-vs-zombie-nation-without-kernkraft-400-rob-chris-bootleg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// johan\\n\\n#define PI radians(180.)\\n\\nvoid main() {\\n \\n float aspect = resolution.x / resolution.y;\\n\\n float cPoints = 64.0;\\n float circles = ceil(vertexCount / cPoints);\\n float cId = floor(vertexId / cPoints);\\n float cNorm = cId / circles;\\n float vId = mod(vertexId, cPoints);\\n \\n\\n float a = 2.1 * PI * vId / (cPoints - 1.2);\\n\\n float snd = pow(texture2D(sound, vec2(3.5, cNorm * 6.125)).a, 4.7);\\n \\n float rad = 1.5 + 8.1 * (1.2 - cNorm) + sin(a * 10.9) * (10.5 + 0.3 * snd);\\n float x = sin(a) * rad;\\n float y = cos(a) * rad;\\n \\n \\n x += sin(time * 1.23 + cId / 133.3) * 3.3;\\n y += cos(time * 1.9 - cId / 159.2) * 4.3 / aspect;\\n \\n x += sin(time * 1.31 + cId / 171.3) * .4;\\n y += cos(time * 1.49 - cId / 147.2) * .4 / aspect;\\n \\n\\n gl_Position = vec4(x, y * aspect, 0, 1);\\n \\n float r = sin(time * 1.42 - cNorm * 8.5) * 6.5 + 7.5;\\n float g = sin(time * 1.27 + a) * 8.5 + 9.5;\\n float b = sin(time * 1.12 + cNorm * 6.10) * 2.5 + .5;\\n\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 54268, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/robundchris/eminem-vs-zombie-nation-without-kernkraft-400-rob-chris-bootleg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// johan\n\n#define PI radians(180.)\n\nvoid main() {\n \n float aspect = resolution.x / resolution.y;\n\n float cPoints = 64.0;\n float circles = ceil(vertexCount / cPoints);\n float cId = floor(vertexId / cPoints);\n float cNorm = cId / circles;\n float vId = mod(vertexId, cPoints);\n \n\n float a = 2.1 * PI * vId / (cPoints - 1.2);\n\n float snd = pow(texture2D(sound, vec2(3.5, cNorm * 6.125)).a, 4.7);\n \n float rad = 1.5 + 8.1 * (1.2 - cNorm) + sin(a * 10.9) * (10.5 + 0.3 * snd);\n float x = sin(a) * rad;\n float y = cos(a) * rad;\n \n \n x += sin(time * 1.23 + cId / 133.3) * 3.3;\n y += cos(time * 1.9 - cId / 159.2) * 4.3 / aspect;\n \n x += sin(time * 1.31 + cId / 171.3) * .4;\n y += cos(time * 1.49 - cId / 147.2) * .4 / aspect;\n \n\n gl_Position = vec4(x, y * aspect, 0, 1);\n \n float r = sin(time * 1.42 - cNorm * 8.5) * 6.5 + 7.5;\n float g = sin(time * 1.27 + a) * 8.5 + 9.5;\n float b = sin(time * 1.12 + cNorm * 6.10) * 2.5 + .5;\n\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-kz6k5q5oxhtl1xf2j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iSvLhZ7QzyjMW2uAh/art.json b/art/iSvLhZ7QzyjMW2uAh/art.json index 0a4f83f5..4e0f3da4 100644 --- a/art/iSvLhZ7QzyjMW2uAh/art.json +++ b/art/iSvLhZ7QzyjMW2uAh/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jluethi", "avatarUrl": "https://secure.gravatar.com/avatar/21e93db3614e6e91a28d7f82b4e44433?default=retro&size=200", - "settings": "{\"num\":10,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.14901960784313725,0.12941176470588237,0.27058823529411763,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across) ;\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n \\ngl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 10, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.14901960784313725, + 0.12941176470588237, + 0.27058823529411763, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across) ;\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n \ngl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-eavhmd4hfzeosgyf6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iXKHFGqaAHrc6rZg2/art.json b/art/iXKHFGqaAHrc6rZg2/art.json index 5992606e..a375b8fb 100644 --- a/art/iXKHFGqaAHrc6rZg2/art.json +++ b/art/iXKHFGqaAHrc6rZg2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nvec3 triangle(float idx) // vec2:p / float triangleIndex\\n{\\n\\tfloat triangleIndex = floor(idx / 6.);\\n\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 p = vec2(0);\\n\\t\\n\\tif (index == 0.) p = vec2(0,0);\\n\\tif (index == 1.) p = vec2(1,0);\\n\\tif (index == 2.) p = vec2(1,1);\\n\\t\\n\\tif (index == 3.) p = vec2(0,0);\\n\\tif (index == 4.) p = vec2(1,1);\\n\\tif (index == 5.) p = vec2(0,1);\\n\\t\\n\\treturn vec3(p, triangleIndex);\\n}\\n\\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\\n{\\n\\tvec4 res;\\n\\tvec3 pi = triangle(idx);\\n\\t\\n\\tpi.y += floor(pi.z / countQuadsX);\\n pi.x += mod(pi.z, countQuadsX);\\n \\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadsX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\t\\n\\tif (centered == true)\\n\\t{\\n\\t\\tpi.x -= nx * 0.5;\\n\\t\\tpi.y -= ny * 0.5;\\n\\t}\\n\\t\\n\\treturn vec4(pi.xy, nx, ny);\\n}\\n\\n//https://www.shadertoy.com/view/ltK3WD\\nvec4 voronoi(vec2 g )\\n{\\n\\tvec4 f = vec4(9);\\n\\tvec2 p = g /= 200. ; f.x=9.;\\n \\n\\tg += time;\\n\\t\\n float t = time * 0.1;\\n \\n for(int x=-2;x<=2;x++)\\n for(int y=-2;y<=2;y++)\\n {\\t\\n p = vec2(x,y);\\n\\t\\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\\n\\t\\t//f.y = max(abs(p.x), abs(p.y));\\n\\t\\t//f.y = dot(p,p);\\n\\t\\tif (f.y < f.x)\\n {\\n f.x = f.y;\\n f.zw = p;\\n }\\n }\\n\\t\\n vec3 n = vec3(0);\\n \\n if ( f.x == -f.z*.866 - f.w*.5) \\tn = vec3(1,0,0);\\n\\tif ( f.x == f.z*.866 - f.w*.5) \\t\\tn = vec3(0,1,0);\\n\\tif ( f.x == f.w) \\t\\t\\t\\t\\tn = vec3(0,0,1);\\n\\t\\n return vec4(f.x, n);\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 2.;\\n\\t\\n \\tvec3 uSlider = vec3(50, 2, 1.2);\\n \\n\\tfloat thickNess = uSlider.x;\\n\\tfloat countMax = floor(vertexCount / 6.);\\n\\tfloat sizeEdge = floor(sqrt(countMax));\\n\\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\\n\\t\\n\\tvec4 voro = voronoi(p.xy * uSlider.y);\\n\\t\\n\\tfloat d = voro.x;\\n\\tvec3 n = voro.yzw;\\n\\t\\n\\tv_color = vec4(n*d,1);\\n\\t\\n\\tmat4 camera = ident();\\n\\t\\n\\tfloat ca = time * 0.1;\\n\\tfloat cd = 200.;\\n\\tfloat ce = PI * mouse.y;\\n\\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.5, p.y, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nvec3 triangle(float idx) // vec2:p / float triangleIndex\n{\n\tfloat triangleIndex = floor(idx / 6.);\n\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 p = vec2(0);\n\t\n\tif (index == 0.) p = vec2(0,0);\n\tif (index == 1.) p = vec2(1,0);\n\tif (index == 2.) p = vec2(1,1);\n\t\n\tif (index == 3.) p = vec2(0,0);\n\tif (index == 4.) p = vec2(1,1);\n\tif (index == 5.) p = vec2(0,1);\n\t\n\treturn vec3(p, triangleIndex);\n}\n\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\n{\n\tvec4 res;\n\tvec3 pi = triangle(idx);\n\t\n\tpi.y += floor(pi.z / countQuadsX);\n pi.x += mod(pi.z, countQuadsX);\n \n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadsX;\n\tfloat ny = floor(countQuads / nx);\n\t\t\n\tif (centered == true)\n\t{\n\t\tpi.x -= nx * 0.5;\n\t\tpi.y -= ny * 0.5;\n\t}\n\t\n\treturn vec4(pi.xy, nx, ny);\n}\n\n//https://www.shadertoy.com/view/ltK3WD\nvec4 voronoi(vec2 g )\n{\n\tvec4 f = vec4(9);\n\tvec2 p = g /= 200. ; f.x=9.;\n \n\tg += time;\n\t\n float t = time * 0.1;\n \n for(int x=-2;x<=2;x++)\n for(int y=-2;y<=2;y++)\n {\t\n p = vec2(x,y);\n\t\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\n //p *= mat2(cos(t), -sin(t), sin(t), cos(t));\n f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\n\t\t//f.y = max(abs(p.x), abs(p.y));\n\t\t//f.y = dot(p,p);\n\t\tif (f.y < f.x)\n {\n f.x = f.y;\n f.zw = p;\n }\n }\n\t\n vec3 n = vec3(0);\n \n if ( f.x == -f.z*.866 - f.w*.5) \tn = vec3(1,0,0);\n\tif ( f.x == f.z*.866 - f.w*.5) \t\tn = vec3(0,1,0);\n\tif ( f.x == f.w) \t\t\t\t\tn = vec3(0,0,1);\n\t\n return vec4(f.x, n);\n}\n\nvoid main()\n{\n\tgl_PointSize = 2.;\n\t\n \tvec3 uSlider = vec3(50, 2, 1.2);\n \n\tfloat thickNess = uSlider.x;\n\tfloat countMax = floor(vertexCount / 6.);\n\tfloat sizeEdge = floor(sqrt(countMax));\n\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\n\t\n\tvec4 voro = voronoi(p.xy * uSlider.y);\n\t\n\tfloat d = voro.x;\n\tvec3 n = voro.yzw;\n\t\n\tv_color = vec4(n*d,1);\n\t\n\tmat4 camera = ident();\n\t\n\tfloat ca = time * 0.1;\n\tfloat cd = 200.;\n\tfloat ce = PI * mouse.y;\n\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tcamera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.5, p.y, 1);\n}" + }, "screenshotURL": "data/images/images-xg621jspbuf31ss6r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iZwjTQ6SHPHX7EjSE/art.json b/art/iZwjTQ6SHPHX7EjSE/art.json index 3055bcdb..6ca88829 100644 --- a/art/iZwjTQ6SHPHX7EjSE/art.json +++ b/art/iZwjTQ6SHPHX7EjSE/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "good", "avatarUrl": "https://lh3.googleusercontent.com/a/AAcHTtdi7RB9cxYb8eQrW013DjbHjwp_BpDQVOUEQr28Bg=s96-c", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(su* 0.05, sv * 0.25 )).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);//mix(2., -10.,av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(su* 0.05, sv * 0.25 )).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);//mix(2., -10.,av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-h6jjph1p682q24gnv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ibwNoyQhKR6kMmj3j/art.json b/art/ibwNoyQhKR6kMmj3j/art.json index f989d2d4..22aea937 100644 --- a/art/ibwNoyQhKR6kMmj3j/art.json +++ b/art/ibwNoyQhKR6kMmj3j/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time / 1.5 + y * 0.2) * 0.11;\\n float yoff = cos(time * 1.8 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u + .1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 * 5.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time / 1.5 + y * 0.2) * 0.11;\n float yoff = cos(time * 1.8 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u + .1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 * 5.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-t4k86rmgz0zy8z5pm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/icmkfJD93vQnbZQfB/art.json b/art/icmkfJD93vQnbZQfB/art.json index 2060199b..21274581 100644 --- a/art/icmkfJD93vQnbZQfB/art.json +++ b/art/icmkfJD93vQnbZQfB/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "abhijit", "avatarUrl": "https://lh5.googleusercontent.com/-i3qvQNrpbfU/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd3L2Osg3Ys5HSXRn6QArB46T_mBA/photo.jpg", - "settings": "{\"num\":3855,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n \\n float vcount = floor(sqrt(vertexCount));\\n float across = floor(vertexCount /vcount) ;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vx = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux ,vx) * 0.7;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02 ) * 1.0;\\n \\n gl_PointSize = 5.0 + soff;\\n gl_PointSize += 20. / across;\\n gl_PointSize += resolution.x /600.;\\n \\n v_color = vec4(ux,vx,0,1); \\n}\"}", + "settings": { + "num": 3855, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n \n float vcount = floor(sqrt(vertexCount));\n float across = floor(vertexCount /vcount) ;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vx = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux ,vx) * 0.7;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02 ) * 1.0;\n \n gl_PointSize = 5.0 + soff;\n gl_PointSize += 20. / across;\n gl_PointSize += resolution.x /600.;\n \n v_color = vec4(ux,vx,0,1); \n}" + }, "screenshotURL": "data/images/images-877tlxbj9i8ihovq0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/icyvWgd8MgBnNT9rn/art.json b/art/icyvWgd8MgBnNT9rn/art.json index 938d3985..8fa4f348 100644 --- a/art/icyvWgd8MgBnNT9rn/art.json +++ b/art/icyvWgd8MgBnNT9rn/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "juan", "avatarUrl": "https://lh3.googleusercontent.com/a-/AFdZucoL0lP1434PdZotBF_QrR7BHy1cL8nZPDGU16LA=s96-c", - "settings": "{\"num\":6232,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define TAU (PI * 2.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 rotate(float freq, float phase, float radius, float index)\\n{\\n\\tfloat angle = (index * freq + phase) * TAU;\\n\\treturn vec2(radius * cos(angle), radius * sin(angle));\\n}\\n\\nfloat oscilate(float freq, float phase, float amp, float index)\\n{\\n return amp * sin((index * freq + phase) * TAU);\\n}\\n\\nvoid main() {\\n \\tfloat index = vertexId / vertexCount;\\n \\tfloat count = floor(index);\\n \\n \\n float r1_freq = 20.0;\\n float r1_phase = .30;\\n float r1_radius = .70;\\n float r1_osc_freq = 10.0;\\n float r1_osc_phase = 0.0;\\n float r1_osc_amp = 0.1;\\n \\n \\n float r2_freq = 556.0;\\n float r2_phase = .50;\\n float r2_radius = .90; \\n float r2_osc_freq = 20.0;\\n float r2_osc_phase = 0.0;\\n float r2_osc_amp = 0.3;\\n \\n vec2 xy = rotate( r1_freq, r1_phase + time*0.001, \\n r1_radius + oscilate(r1_osc_freq, \\n r1_osc_phase,\\n r1_osc_amp,\\n index), index) + \\n \\t\\trotate( r2_freq, r2_phase + time *0.01, \\n r2_radius + oscilate(r2_osc_freq, \\n r2_osc_phase, \\n r2_osc_amp,\\n index), index);\\n \\n //xy = vec2 (index,index);\\n\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n\\n gl_Position = vec4(xy * aspect, xy.y, 2);\\n\\n\\n float hue = 0.025;\\n float sat = 0.82;\\n float val = 0.925;\\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.001);\\n v_color = vec4(0.05,0.5,0.85,1);\\n}\"}", + "settings": { + "num": 6232, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define TAU (PI * 2.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 rotate(float freq, float phase, float radius, float index)\n{\n\tfloat angle = (index * freq + phase) * TAU;\n\treturn vec2(radius * cos(angle), radius * sin(angle));\n}\n\nfloat oscilate(float freq, float phase, float amp, float index)\n{\n return amp * sin((index * freq + phase) * TAU);\n}\n\nvoid main() {\n \tfloat index = vertexId / vertexCount;\n \tfloat count = floor(index);\n \n \n float r1_freq = 20.0;\n float r1_phase = .30;\n float r1_radius = .70;\n float r1_osc_freq = 10.0;\n float r1_osc_phase = 0.0;\n float r1_osc_amp = 0.1;\n \n \n float r2_freq = 556.0;\n float r2_phase = .50;\n float r2_radius = .90; \n float r2_osc_freq = 20.0;\n float r2_osc_phase = 0.0;\n float r2_osc_amp = 0.3;\n \n vec2 xy = rotate( r1_freq, r1_phase + time*0.001, \n r1_radius + oscilate(r1_osc_freq, \n r1_osc_phase,\n r1_osc_amp,\n index), index) + \n \t\trotate( r2_freq, r2_phase + time *0.01, \n r2_radius + oscilate(r2_osc_freq, \n r2_osc_phase, \n r2_osc_amp,\n index), index);\n \n //xy = vec2 (index,index);\n\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n\n gl_Position = vec4(xy * aspect, xy.y, 2);\n\n\n float hue = 0.025;\n float sat = 0.82;\n float val = 0.925;\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.001);\n v_color = vec4(0.05,0.5,0.85,1);\n}" + }, "screenshotURL": "data/images/images-p83p9ygvibp3ip5nq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ieaN3Qkmk29Y5CSpG/art.json b/art/ieaN3Qkmk29Y5CSpG/art.json index ba587646..642619ea 100644 --- a/art/ieaN3Qkmk29Y5CSpG/art.json +++ b/art/ieaN3Qkmk29Y5CSpG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":97200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0, 0, s,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n s, 0, 0, c); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n c, s, 0, 0,\\n s, c, c, 0,\\n 0, s, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, s, s, \\n s, c, 0, 0,\\n s, 0, c, 0,\\n s, 0, 0, c); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 1, 1, 0,\\n 0, 1, 0, 1,\\n 0, 0, 1, 1,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 1, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, s);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 0.9);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][1], m[2][2], \\n m[0][0], m[1][1], m[2][2], \\n m[0][0], m[1][1], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[1], t[0], \\n i[2], t[1],\\n i[0], t[2],\\n 3, 3, 2, 2);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][1], m[2][2], m[3][3], \\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2-4--5\\n //\\n // 0 1 0 1 0 1 0 0 0 1\\n // 0 0 1 0 1 1 0 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) / around * PI * 2.)\\n );\\n \\n float tm = time * 1.1;\\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.5, 2.5, pow(s + .15, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float odd = mod(floor(quadId / 2.), 2.);\\n float hue = time * .1 +s * .15;\\n float sat = mix(0., 3., pow(s, 5.));\\n float val = mix(0.1, 1., pow(s + .4, 15.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 97200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mixmag-1/premiere-michael-klein-pan-pot-haze-effect", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0, 0, s,\n 0, c, s, 0,\n 0, -s, c, 0,\n s, 0, 0, c); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n c, s, 0, 0,\n s, c, c, 0,\n 0, s, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, s, s, \n s, c, 0, 0,\n s, 0, c, 0,\n s, 0, 0, c); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 1, 1, 0,\n 0, 1, 0, 1,\n 0, 0, 1, 1,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 1, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, s);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 0.9);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][1], m[2][2], \n m[0][0], m[1][1], m[2][2], \n m[0][0], m[1][1], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[1], t[0], \n i[2], t[1],\n i[0], t[2],\n 3, 3, 2, 2);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][1], m[2][2], m[3][3], \n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2-4--5\n //\n // 0 1 0 1 0 1 0 0 0 1\n // 0 0 1 0 1 1 0 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) / around * PI * 2.)\n );\n \n float tm = time * 1.1;\n float rd = mix(2., 3.5, t5p5(sin(time * 0.11)));\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(0.1, .25, abs(qu * 2. - 1.)), mix(0., .12, qv))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.5, 2.5, pow(s + .15, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float odd = mod(floor(quadId / 2.), 2.);\n float hue = time * .1 +s * .15;\n float sat = mix(0., 3., pow(s, 5.));\n float val = mix(0.1, 1., pow(s + .4, 15.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-alk0e9anvbrewo38t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ig5e2CN4AbunM7REm/art.json b/art/ig5e2CN4AbunM7REm/art.json index ef574cdd..2da89d07 100644 --- a/art/ig5e2CN4AbunM7REm/art.json +++ b/art/ig5e2CN4AbunM7REm/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":127,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 3;\\t\\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n\\n gl_PointSize = vertexId/5.0; \\n \\n \\n v_color = vec4(vertexId/500.0,vertexId/255.0,0.5,1);\\n}\"}", + "settings": { + "num": 127, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 3;\t\n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n\n gl_PointSize = vertexId/5.0; \n \n \n v_color = vec4(vertexId/500.0,vertexId/255.0,0.5,1);\n}" + }, "screenshotURL": "data/images/images-1rkb1fwt4jwby5lxl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iiAQmTAWuGuLLKPiP/art.json b/art/iiAQmTAWuGuLLKPiP/art.json index d0449507..8c0f6b9f 100644 --- a/art/iiAQmTAWuGuLLKPiP/art.json +++ b/art/iiAQmTAWuGuLLKPiP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":39542,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner =mouse.y;\\n float start = mouse.x;\\n float end =step(0.13,0.5+s);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.4123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(-t * .63 +s) * 10., sin(t * .4+s)*20.*s, 0.);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0.5);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .017);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 23.5 +s *s* .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\\n float sat =1.0;step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb /= v_color.a*s;\\n \\n float super = step(0.9, 1.-s);\\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\\n \\n}\\n\"}", + "settings": { + "num": 39542, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner =mouse.y;\n float start = mouse.x;\n float end =step(0.13,0.5+s);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.4123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(-t * .63 +s) * 10., sin(t * .4+s)*20.*s, 0.);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0.5);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .017);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 23.5 +s *s* .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\n float sat =1.0;step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb /= v_color.a*s;\n \n float super = step(0.9, 1.-s);\n v_color = mix(v_color, vec4(s,0,0,0.7), super);\n \n}\n" + }, "screenshotURL": "data/images/images-fi7zat5g0zjit1o3s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iiz8rMJTpnjWQ9igc/art.json b/art/iiz8rMJTpnjWQ9igc/art.json index a28662a6..2d018df4 100644 --- a/art/iiz8rMJTpnjWQ9igc/art.json +++ b/art/iiz8rMJTpnjWQ9igc/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "xi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GhDJubRRp-SM2AciN7fDuusjZXt4-We-Q9ZOwXU", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.0196078431372549,0.2784313725490196,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz,0.0,1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y*0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x*0.2) * 0.1;\\n \\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x/600.;\\n\\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.0196078431372549, + 0.2784313725490196, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz,0.0,1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y*0.2) * 0.1;\n float yoff = sin(time * 1.1 + x*0.2) * 0.1;\n \n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x/600.;\n\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-6fovikina20ts9n2b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ijffwwNcMKiZYCxge/art.json b/art/ijffwwNcMKiZYCxge/art.json index 70cecd70..e8f00b95 100644 --- a/art/ijffwwNcMKiZYCxge/art.json +++ b/art/ijffwwNcMKiZYCxge/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/caleesi-sarah-kreis-mbr-sao\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 10000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n return texture2D(sound, vec2(f, delay)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float r = (0.6 + sin(t * 31.0 * TWO_PI) * 0.4);\\n float phi = sin(t * 43.0 * TWO_PI) * PI;\\n float theta = PI * sin(t * 41.0 * PI);\\n float x = cos(phi) * cos(theta);\\n float y = sin(phi) * cos(theta);\\n float z = sin(theta);\\n return r * vec3(x, y, z);\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = sqrt(p.x * p.x + p.y * p.y + p.z * p.z);\\n float h = 0.5; //0.5 + 0.5 * sin(r * TWO_PI + time + p.x);\\n float s = 1.0; // 0.5 + 0.5 * cos(r * TWO_PI + time + p.x);\\n \\n float pulse = sin((time * 0.3 + t * 500.0) * TWO_PI);\\n float v = //max(0.5, sin(r * 3.0 * TWO_PI + time * 0.1 + t * 100.0)) - 0.5)\\n pow(max(0.0, pulse), 5.0)\\n + getSound(0.1, 0.0);\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/sarahkreis/sets/caleesi-sarah-kreis-mbr-sao", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 10000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n return texture2D(sound, vec2(f, delay)).a;\n}\n\nvec3 curvePos(float t) {\n float r = (0.6 + sin(t * 31.0 * TWO_PI) * 0.4);\n float phi = sin(t * 43.0 * TWO_PI) * PI;\n float theta = PI * sin(t * 41.0 * PI);\n float x = cos(phi) * cos(theta);\n float y = sin(phi) * cos(theta);\n float z = sin(theta);\n return r * vec3(x, y, z);\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = sqrt(p.x * p.x + p.y * p.y + p.z * p.z);\n float h = 0.5; //0.5 + 0.5 * sin(r * TWO_PI + time + p.x);\n float s = 1.0; // 0.5 + 0.5 * cos(r * TWO_PI + time + p.x);\n \n float pulse = sin((time * 0.3 + t * 500.0) * TWO_PI);\n float v = //max(0.5, sin(r * 3.0 * TWO_PI + time * 0.1 + t * 100.0)) - 0.5)\n pow(max(0.0, pulse), 5.0)\n + getSound(0.1, 0.0);\n \n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1.0);\n}" + }, "screenshotURL": "data/images/images-d12lstbydjobppmuz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iko4zHPGCfdPcBr5s/art.json b/art/iko4zHPGCfdPcBr5s/art.json index 5e81ba8d..62a22778 100644 --- a/art/iko4zHPGCfdPcBr5s/art.json +++ b/art/iko4zHPGCfdPcBr5s/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alexisrubio96", "avatarUrl": "https://avatars.githubusercontent.com/AlexisRubio96?s=200", - "settings": "{\"num\":306,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n \\n \\tfloat x = floor(vertexId); \\n\\tfloat y = mod(vertexId + 1.0, 2.0);\\n \\n \\tfloat angle = x / 150.0 * radians(180.0);\\n \\tfloat radius = 2.0 - y;\\n \\n \\tfloat ux = radius * cos(angle);\\n \\tfloat uy = radius * sin(angle);\\n \\n \\tvec2 xy = vec2(ux,uy)*1.0;\\n \\n\\tgl_Position = vec4(xy, 0.0,10.0);\\t\\t//Posición final de un vertice\\n \\tv_color = vec4(x,y,0.0,1.0);\\n \\tgl_PointSize = 1.0;\\n\\n}\"}", + "settings": { + "num": 306, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n \n \tfloat x = floor(vertexId); \n\tfloat y = mod(vertexId + 1.0, 2.0);\n \n \tfloat angle = x / 150.0 * radians(180.0);\n \tfloat radius = 2.0 - y;\n \n \tfloat ux = radius * cos(angle);\n \tfloat uy = radius * sin(angle);\n \n \tvec2 xy = vec2(ux,uy)*1.0;\n \n\tgl_Position = vec4(xy, 0.0,10.0);\t\t//Posición final de un vertice\n \tv_color = vec4(x,y,0.0,1.0);\n \tgl_PointSize = 1.0;\n\n}" + }, "screenshotURL": "data/images/images-c49q3j4i72ofb8klq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/imESwJiuP9QDzXiWF/art.json b/art/imESwJiuP9QDzXiWF/art.json index c0f9afd8..cf81b855 100644 --- a/art/imESwJiuP9QDzXiWF/art.json +++ b/art/imESwJiuP9QDzXiWF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "soporus", "avatarUrl": "https://avatars.githubusercontent.com/soporus?s=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/bikeallmolten/tet-seq\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\nvec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2d(float _angle){\\n return mat2(cos(_angle),-sin(_angle),\\n sin(_angle),cos(_angle));\\n}\\n\\nmat2 scaler(vec2 _scale){\\n return mat2(_scale.x,0.0,\\n 0.0,_scale.y);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments){ \\n float ux = floor(id /6.0) + mod(id, 2.0);\\n //odd and even vertexes\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = ux/numCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n \\n}\\n\\nvoid main() {\\n float numCircleSegments = 5.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.0;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles/down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId/ across);\\n \\n float u = x / (across-1.0);\\n float v = y / (across-1.0);\\n\\n float xoff = sin(time + y * 0.2) * 0.025;\\n float yoff = cos(time + x * 0.3) * 0.025;\\n \\n float ux = u * 2.0 -1.0 + xoff;\\n float vy = v * 2.0 -1.0 + yoff;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float scale = pow(snd + 0.2, 3.0);\\n vec2 xy = circleXY * 0.05 *scale + vec2(ux, vy);\\n \\n xy *= rotate2d(sin(time*0.1)*PI);\\n xy *= scaler(vec2(1.33333));\\n gl_Position = vec4(xy,0,1) * vec4(1, aspect, 1, 1);\\n \\n \\n float pump = step(0.75, snd);\\n float hue = u*0.1*snd+0.5;\\n float sat = step(0.666,snd);\\n float val = mix(snd*0.25+0.125,snd,pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/bikeallmolten/tet-seq", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\nvec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2d(float _angle){\n return mat2(cos(_angle),-sin(_angle),\n sin(_angle),cos(_angle));\n}\n\nmat2 scaler(vec2 _scale){\n return mat2(_scale.x,0.0,\n 0.0,_scale.y);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments){ \n float ux = floor(id /6.0) + mod(id, 2.0);\n //odd and even vertexes\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = ux/numCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n \n}\n\nvoid main() {\n float numCircleSegments = 5.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.0;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles/down);\n \n float x = mod(circleId, across);\n float y = floor(circleId/ across);\n \n float u = x / (across-1.0);\n float v = y / (across-1.0);\n\n float xoff = sin(time + y * 0.2) * 0.025;\n float yoff = cos(time + x * 0.3) * 0.025;\n \n float ux = u * 2.0 -1.0 + xoff;\n float vy = v * 2.0 -1.0 + yoff;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float scale = pow(snd + 0.2, 3.0);\n vec2 xy = circleXY * 0.05 *scale + vec2(ux, vy);\n \n xy *= rotate2d(sin(time*0.1)*PI);\n xy *= scaler(vec2(1.33333));\n gl_Position = vec4(xy,0,1) * vec4(1, aspect, 1, 1);\n \n \n float pump = step(0.75, snd);\n float hue = u*0.1*snd+0.5;\n float sat = step(0.666,snd);\n float val = mix(snd*0.25+0.125,snd,pump);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-4kh4h34volmbxz5uz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ioLq6J2WDmNXguCmD/art.json b/art/ioLq6J2WDmNXguCmD/art.json index 4f429af8..19d90e0d 100644 --- a/art/ioLq6J2WDmNXguCmD/art.json +++ b/art/ioLq6J2WDmNXguCmD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "tomjakubowski", "avatarUrl": "https://avatars.githubusercontent.com/tomjakubowski?s=200", - "settings": "{\"num\":8000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat line(float id, float count) {\\n // x: 0.0 0.0 1/n 1/n 2/n 2/n 3/n 3/n .. n/n n/n\\n float x = id / (count - 1.0);\\n return x;\\n}\\n\\nvoid main() {\\n float t = vertexId/vertexCount;\\n float x = line(vertexId, vertexCount);\\n float y = sin(2.0*PI*x);\\n gl_Position = vec4(2.0*x-1.0, y, 0.0, 1.0);\\n gl_PointSize = 2.0;\\n v_color = 0.5 * vec4(hsv2rgb(vec3(t+time, 0.5, 0.6)), 1.0);\\n}\"}", + "settings": { + "num": 8000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat line(float id, float count) {\n // x: 0.0 0.0 1/n 1/n 2/n 2/n 3/n 3/n .. n/n n/n\n float x = id / (count - 1.0);\n return x;\n}\n\nvoid main() {\n float t = vertexId/vertexCount;\n float x = line(vertexId, vertexCount);\n float y = sin(2.0*PI*x);\n gl_Position = vec4(2.0*x-1.0, y, 0.0, 1.0);\n gl_PointSize = 2.0;\n v_color = 0.5 * vec4(hsv2rgb(vec3(t+time, 0.5, 0.6)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ocb28mk3k08ib8hbz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ipJH3aZcHmkBCGYZC/art.json b/art/ipJH3aZcHmkBCGYZC/art.json index f2e6f450..c4e0d6c0 100644 --- a/art/ipJH3aZcHmkBCGYZC/art.json +++ b/art/ipJH3aZcHmkBCGYZC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":2000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id *1.55),\\n cos(id *0.43),\\n sin(id*0.22));\\n}\\n\\nconst float expand = 120.;\\nconst float off = 0.1;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 eye = r0 * expand + zaxis * 1.;\\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n /*_emat = mat4(\\n 1.,0.,0.,0.,\\n 0.,1.,0.,0.,\\n 0.,0.,1.,0.,\\n 0.,0.,0.,1.); \\n */\\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n\\n float base = 14.5; // good place to adjust\\n base = time * 1.0;\\n\\n\\n vec3 b0 = getCurvePoint(base + off * 0.);\\n vec3 b1 = getCurvePoint(base + off * 1.);\\n vec3 b2 = getCurvePoint(base + off * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n \\n vec3 eye = b0 * expand + czaxis * 1.;\\n //eye = vec3(-60.,0.,40.);\\n vec3 target = b1 * expand + czaxis;\\n vec3 up = cyaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n \\n \\n //\\n float sizeFactor = 1./10.;\\n \\n float shapeCount = floor(vertexCount / 36.);\\n float shapeId = floor(vertexId / 36.);\\n float shapeVertexId = mod(vertexId, 36.);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n //cubep*= sizeFactor;\\n mat4 scaleMat = scale(vec3(sizeFactor,3.*sizeFactor,sizeFactor));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n //cbNi*=scaleMat;\\n vec3 pos;\\n vec4 color;\\n \\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n //base+= mod(time,2.);\\n mat4 wmat;\\n mat4 emat;\\n \\n track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n mat4 testId = mat4(\\n 1.,0.,0.,0.,\\n 0.,1.,0.,0.,\\n 0.,0.,1.,0.,\\n 0.,0.,0.,1.);\\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi;\\n //float rotx = atan( wmat.y, wmat.z );\\n //float roty = Math.atan2( x * Math.cos(rotx), z )\\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \\n \\n \\n //cbNi.xyz+= posi;\\n \\n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 2000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id *1.55),\n cos(id *0.43),\n sin(id*0.22));\n}\n\nconst float expand = 120.;\nconst float off = 0.1;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) {\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 eye = r0 * expand + zaxis * 1.;\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n /*_emat = mat4(\n 1.,0.,0.,0.,\n 0.,1.,0.,0.,\n 0.,0.,1.,0.,\n 0.,0.,0.,1.); \n */\n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n\n float base = 14.5; // good place to adjust\n base = time * 1.0;\n\n\n vec3 b0 = getCurvePoint(base + off * 0.);\n vec3 b1 = getCurvePoint(base + off * 1.);\n vec3 b2 = getCurvePoint(base + off * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n \n vec3 eye = b0 * expand + czaxis * 1.;\n //eye = vec3(-60.,0.,40.);\n vec3 target = b1 * expand + czaxis;\n vec3 up = cyaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n \n \n //\n float sizeFactor = 1./10.;\n \n float shapeCount = floor(vertexCount / 36.);\n float shapeId = floor(vertexId / 36.);\n float shapeVertexId = mod(vertexId, 36.);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n //cubep*= sizeFactor;\n mat4 scaleMat = scale(vec3(sizeFactor,3.*sizeFactor,sizeFactor));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n //cbNi*=scaleMat;\n vec3 pos;\n vec4 color;\n \n \n //shapeId = mod(shapeId+time, shapeCount);\n //base+= mod(time,2.);\n mat4 wmat;\n mat4 emat;\n \n track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n mat4 testId = mat4(\n 1.,0.,0.,0.,\n 0.,1.,0.,0.,\n 0.,0.,1.,0.,\n 0.,0.,0.,1.);\n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi;\n //float rotx = atan( wmat.y, wmat.z );\n //float roty = Math.atan2( x * Math.cos(rotx), z )\n //float rotz = Math.atan2( Math.cos(rotx), Math.sin(rotx) * Math.sin(roty) \n \n \n //cbNi.xyz+= posi;\n \n vec3 finalcolor = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-s3flsrxxba3sq1t6u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iqkc2EX6jbhg7NbT4/art.json b/art/iqkc2EX6jbhg7NbT4/art.json index 35f2e886..f2ef4604 100644 --- a/art/iqkc2EX6jbhg7NbT4/art.json +++ b/art/iqkc2EX6jbhg7NbT4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xxx) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) + radius;\\n float s = sin(angle + time) - radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xxx) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) + radius;\n float s = sin(angle + time) - radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-lw649r8isy4sqa324-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ircs8vH9TsNMjuWh4/art.json b/art/ircs8vH9TsNMjuWh4/art.json index 94911b32..4d94f00b 100644 --- a/art/ircs8vH9TsNMjuWh4/art.json +++ b/art/ircs8vH9TsNMjuWh4/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sergioerick", "avatarUrl": "https://lh6.googleusercontent.com/-6mWCYE7e8JE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcnyCK5B6N4hdhN62pAcPOwiFeA5g/mo/photo.jpg", - "settings": "{\"num\":500,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/irving-hernandez-500474196/este-pedacito-es-tuyo-uzielito-mixalu-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float width = 20.0;\\n \\n float x = mod(vertexId, width); \\n float y = floor(vertexId/width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2);\\n float yOffset = sin(time + x * 0.1); \\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux,vy)*0.4;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n v_color=vec4(0.0, 0.0,1.0,1.0);\\n gl_PointSize = 15.0;\\n \\n}\"}", + "settings": { + "num": 500, + "mode": "POINTS", + "sound": "https://soundcloud.com/irving-hernandez-500474196/este-pedacito-es-tuyo-uzielito-mixalu-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float width = 20.0;\n \n float x = mod(vertexId, width); \n float y = floor(vertexId/width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2);\n float yOffset = sin(time + x * 0.1); \n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux,vy)*0.4;\n \n gl_Position = vec4(xy,0.0,1.0);\n v_color=vec4(0.0, 0.0,1.0,1.0);\n gl_PointSize = 15.0;\n \n}" + }, "screenshotURL": "data/images/images-zc2vime8p8av4g2eg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/isgED2R7wSztcgg4J/art.json b/art/isgED2R7wSztcgg4J/art.json index 7236ec7c..937e1a63 100644 --- a/art/isgED2R7wSztcgg4J/art.json +++ b/art/isgED2R7wSztcgg4J/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":72000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n \\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n#define fakeVerticeNumber 72000\\n\\n//const float travelSpeed = -100.;\\nconst float dim = 120.;\\nconst float off = 0.1;\\n\\n/////////////////////////////\\n//K Machine parameters\\n/////////////////////////////\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=72000\\n\\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 1. //KParameter 1.>>10.\\n#define radiusSizeFactor 0.05 //KParameter 0.05>>0.2\\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 2. //KParameter 0.5>>40.\\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\n\\nvec3 getTrajPoint(const float _id) {\\n return vec3(\\n sin(_id * 0.99),\\n sin(_id * 2.43),\\n sin(_id * 1.57));\\n}\\n \\nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\\n{\\n \\n float pg = _rel + _delta;\\n \\n vec3 r0 = getTrajPoint(pg + off * 0.);\\n vec3 r1 = getTrajPoint(pg + off * 1.);\\n vec3 r2 = getTrajPoint(pg + off * 2.);\\n \\n _pos = mat3(\\n getTrajPoint(pg + off * 0.),\\n getTrajPoint(pg + off * 1.),\\n getTrajPoint(pg + off * 2.));\\n \\n vec3 s0 = normalize(_pos[1] - _pos[0]);\\n vec3 s1 = normalize(_pos[2] - _pos[1]);\\n \\n vec4 zaxis = vec4(normalize(s1 - s0),1.);\\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\\n \\n _axis = mat3(\\n xaxis,\\n yaxis,\\n zaxis);\\n\\n\\n}\\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\\n \\n \\n float prog = (_shapeId / _shapeCount)+_timeB;\\n \\n mat3 axis, mPos;\\n\\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\\n\\n //position matrix\\n _wmat = mat4(\\n vec4(axis[0], 0),\\n vec4(axis[1], 0),\\n vec4(axis[2], 0),\\n vec4(mPos[0] * dim, 1)); \\n \\n //orientation matrix\\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\\n vec3 target = mPos[1] * dim + axis[2];\\n vec3 up = axis[1];\\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\nmat4 rotationMatrix(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n//#define EYE_STATIC true\\n//#define STOP_TRAJ true\\n#define DYN_GROUPID true\\n//#define SOUND_REACT true\\n\\nvoid main() {\\n \\n //shape\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n #ifdef SOUND_REACT\\n float snd = 2.*texture2D(sound, vec2(0., (1.-relGroupId))).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n \\n #ifdef STOP_TRAJ\\n float timeB = 14.;\\n #else\\n float timeB = time * tubeSpeedFactor;\\n #endif\\n \\n\\n \\n //Static eye\\n #ifdef EYE_STATIC\\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n #else\\n //Following eye\\n mat3 axis, sPos;// = getAxisMat(0., timeB);\\n getPosAndAxisMat(0., timeB, axis, sPos);\\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\\n vec3 target = sPos[2] * dim + axis[2];\\n vec3 up = axis[1];\\n #endif\\n \\n \\n //rotation around eye z axis\\n //mat4 rotMat = rotationMatrix(zaxis, time*PI);\\n //xaxis = (rotMat*vec4(xaxis,1.)).xyz;\\n //yaxis = (rotMat*vec4(yaxis,1.)).xyz;\\n \\n //\\n\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n\\n vec4 cNorm;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\\n \\n \\n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n \\n //create the circle group\\n \\n \\n \\n float radius = 100.*radiusSizeFactor;\\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n\\n mat4 posmat, rotmat;\\n\\n #ifdef DYN_GROUPID\\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\\n #else\\n getTrajMat(groupId, groupCount, timeB, posmat, rotmat);\\n #endif\\n //shape orientation\\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\\n cNorm *= rotmat;\\n \\n //shape position\\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\\n \\n vec3 finalcolor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n v_color = vec4(finalcolor,1.);\\n}\\n\"}", + "settings": { + "num": 72000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n \n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n#define fakeVerticeNumber 72000\n\n//const float travelSpeed = -100.;\nconst float dim = 120.;\nconst float off = 0.1;\n\n/////////////////////////////\n//K Machine parameters\n/////////////////////////////\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=72000\n\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 1. //KParameter 1.>>10.\n#define radiusSizeFactor 0.05 //KParameter 0.05>>0.2\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 2. //KParameter 0.5>>40.\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\n\nvec3 getTrajPoint(const float _id) {\n return vec3(\n sin(_id * 0.99),\n sin(_id * 2.43),\n sin(_id * 1.57));\n}\n \nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\n{\n \n float pg = _rel + _delta;\n \n vec3 r0 = getTrajPoint(pg + off * 0.);\n vec3 r1 = getTrajPoint(pg + off * 1.);\n vec3 r2 = getTrajPoint(pg + off * 2.);\n \n _pos = mat3(\n getTrajPoint(pg + off * 0.),\n getTrajPoint(pg + off * 1.),\n getTrajPoint(pg + off * 2.));\n \n vec3 s0 = normalize(_pos[1] - _pos[0]);\n vec3 s1 = normalize(_pos[2] - _pos[1]);\n \n vec4 zaxis = vec4(normalize(s1 - s0),1.);\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\n \n _axis = mat3(\n xaxis,\n yaxis,\n zaxis);\n\n\n}\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\n \n \n float prog = (_shapeId / _shapeCount)+_timeB;\n \n mat3 axis, mPos;\n\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\n\n //position matrix\n _wmat = mat4(\n vec4(axis[0], 0),\n vec4(axis[1], 0),\n vec4(axis[2], 0),\n vec4(mPos[0] * dim, 1)); \n \n //orientation matrix\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\n vec3 target = mPos[1] * dim + axis[2];\n vec3 up = axis[1];\n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\nmat4 rotationMatrix(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n//#define EYE_STATIC true\n//#define STOP_TRAJ true\n#define DYN_GROUPID true\n//#define SOUND_REACT true\n\nvoid main() {\n \n //shape\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n #ifdef SOUND_REACT\n float snd = 2.*texture2D(sound, vec2(0., (1.-relGroupId))).a;\n #else\n float snd = 1.;\n #endif\n \n \n #ifdef STOP_TRAJ\n float timeB = 14.;\n #else\n float timeB = time * tubeSpeedFactor;\n #endif\n \n\n \n //Static eye\n #ifdef EYE_STATIC\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\n vec3 up = vec3(0.5, 0.5, 1.5);\n #else\n //Following eye\n mat3 axis, sPos;// = getAxisMat(0., timeB);\n getPosAndAxisMat(0., timeB, axis, sPos);\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\n vec3 target = sPos[2] * dim + axis[2];\n vec3 up = axis[1];\n #endif\n \n \n //rotation around eye z axis\n //mat4 rotMat = rotationMatrix(zaxis, time*PI);\n //xaxis = (rotMat*vec4(xaxis,1.)).xyz;\n //yaxis = (rotMat*vec4(yaxis,1.)).xyz;\n \n //\n\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n\n vec4 cNorm;\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\n \n \n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\n cubep = (zrot*vec4(cubep,1.)).xyz;\n \n //create the circle group\n \n \n \n float radius = 100.*radiusSizeFactor;\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n \n //shapeId = mod(shapeId+time, shapeCount);\n\n mat4 posmat, rotmat;\n\n #ifdef DYN_GROUPID\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\n #else\n getTrajMat(groupId, groupCount, timeB, posmat, rotmat);\n #endif\n //shape orientation\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\n cNorm *= rotmat;\n \n //shape position\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\n \n vec3 finalcolor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n v_color = vec4(finalcolor,1.);\n}\n" + }, "screenshotURL": "data/images/images-ajklcsj9u4e9wpz0z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/it3WZX5QHCABK6s7R/art.json b/art/it3WZX5QHCABK6s7R/art.json index 5810e605..4ae4acfa 100644 --- a/art/it3WZX5QHCABK6s7R/art.json +++ b/art/it3WZX5QHCABK6s7R/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.7;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.51)).a,10.0);\\n float x = (u*10.0)-0.8;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 800.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *20.0 + 0.7)/10.0;\\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.7;\n float osc = sin(200.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.51)).a,10.0);\n float x = (u*10.0)-0.8;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 800.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *20.0 + 0.7)/10.0;\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\n}" + }, "screenshotURL": "data/images/images-ouda8pqptsnu9u9qb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/itFYHyLvFpbtiqvaP/art.json b/art/itFYHyLvFpbtiqvaP/art.json index 9c5745c2..a625b86e 100644 --- a/art/itFYHyLvFpbtiqvaP/art.json +++ b/art/itFYHyLvFpbtiqvaP/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "도영", "avatarUrl": "https://lh4.googleusercontent.com/-U1yoYVQNRaI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdPOWnx_PVuWVFfdWUFWnYSBIUGSQ/mo/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*------------------------------------------------------------------------\\nFile Name:Extra Credit-Vertex Shader\\nCourse name: Cs230Kr\\nAssignment name/Number:Shader Programming Assignment/3\\nAuthor:Doyeong Yi\\nTerm:Spring 2019\\n------------------------------------------------------------------------*/\\nvoid main() \\n{\\n \\tfloat value = vertexId*10.0; \\n// Put value multiplied by vertexid and 10.0 for flotat type variable which named “value”\\n \\n\\tfloat x =mouse.x;\\n\\t// Put the float type variable that accepts the mouse's x coordinate\\n\\tfloat y = mouse.y;\\n \\t // Put the float type variable that accepts the mouse's y coordinate\\n\\n \\tfloat snd = texture2D(sound, vec2(0, 0)).a;\\n\\t//Put sound value in float type variable which named “snd”\\n\\n \\tgl_Position = vec4(cos(value), sin(value), 0, abs(snd*2.0));\\n \\t//set position\\n \\tgl_PointSize = 50.0;\\n \\t//set point size 50.0\\n\\n \\tv_color = vec4(cos(x), sin(y), tan(x*y), 1);\\n\\t//set color\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nFile Name:Extra Credit-Vertex Shader\nCourse name: Cs230Kr\nAssignment name/Number:Shader Programming Assignment/3\nAuthor:Doyeong Yi\nTerm:Spring 2019\n------------------------------------------------------------------------*/\nvoid main() \n{\n \tfloat value = vertexId*10.0; \n// Put value multiplied by vertexid and 10.0 for flotat type variable which named “value”\n \n\tfloat x =mouse.x;\n\t// Put the float type variable that accepts the mouse's x coordinate\n\tfloat y = mouse.y;\n \t // Put the float type variable that accepts the mouse's y coordinate\n\n \tfloat snd = texture2D(sound, vec2(0, 0)).a;\n\t//Put sound value in float type variable which named “snd”\n\n \tgl_Position = vec4(cos(value), sin(value), 0, abs(snd*2.0));\n \t//set position\n \tgl_PointSize = 50.0;\n \t//set point size 50.0\n\n \tv_color = vec4(cos(x), sin(y), tan(x*y), 1);\n\t//set color\n}\n" + }, "screenshotURL": "data/images/images-u01g02gjp1bvkq3ud-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iu7GYL94b7Hm5JyvB/art.json b/art/iu7GYL94b7Hm5JyvB/art.json index 36164c78..7420668d 100644 --- a/art/iu7GYL94b7Hm5JyvB/art.json +++ b/art/iu7GYL94b7Hm5JyvB/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":5,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Simple 2D Polygon generator, after enough vertices are added the geometry resolves to a circle\\n\\n\\nvoid main() {\\n float radius = 0.5;\\n float theta = vertexId / vertexCount * 6.28;\\n \\n float z = cos(theta + time);\\n float x = cos(theta + time) * radius;\\n float y = sin(theta + time) * radius;\\n \\n gl_Position = vec4(x, y, z, 1);\\n gl_PointSize = 1.0;\\n v_color = vec4(vertexId / vertexCount, z, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 5, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Simple 2D Polygon generator, after enough vertices are added the geometry resolves to a circle\n\n\nvoid main() {\n float radius = 0.5;\n float theta = vertexId / vertexCount * 6.28;\n \n float z = cos(theta + time);\n float x = cos(theta + time) * radius;\n float y = sin(theta + time) * radius;\n \n gl_Position = vec4(x, y, z, 1);\n gl_PointSize = 1.0;\n v_color = vec4(vertexId / vertexCount, z, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-ln62ap86yu91m5t3f-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iuT7hG7CEXwYqShtA/art.json b/art/iuT7hG7CEXwYqShtA/art.json index 5b2c4788..47fbd6fe 100644 --- a/art/iuT7hG7CEXwYqShtA/art.json +++ b/art/iuT7hG7CEXwYqShtA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":21491,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 -1.//KParameter 0.>>-10.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (333. *(P2+3.5))+10.;\\n float numQuads = floor( vertexCount/6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) -(mouse.y * r);\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, mouse*((qv * PI )));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId / 0.66663;\\n float sat = quadId -3.3;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 01.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 21491, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 -1.//KParameter 0.>>-10.\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3./snd), (2. *snd)); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (333. *(P2+3.5))+10.;\n float numQuads = floor( vertexCount/6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.-P3);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) -(mouse.y * r);\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, mouse*((qv * PI )));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y* P2, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId / 0.66663;\n float sat = quadId -3.3;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 01.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-3iyb2d3rw612vpk6k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ivFr7kf8D46ckANG4/art.json b/art/ivFr7kf8D46ckANG4/art.json index c5043432..96fe206c 100644 --- a/art/ivFr7kf8D46ckANG4/art.json +++ b/art/ivFr7kf8D46ckANG4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10721,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.1607843137254902,0.1607843137254902,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 11.//KParameter0 0.>>1000.\\n#define KP1 56.//KParameter1 0.0>>22.\\n#define K2 9.0//KParameter2 6.0>>10.\\n#define KP3 -0.01//KParameter3 -8.000>>0.5\\n#define KP4 6.2//KParameter4 0.000>>15.\\n#define KP5 553.0//KParameter5 30.000>>90000.0\\n\\n\\n\\n#define PI radians(180. -KP1)\\nfloat VertexCount = 10000. * K2;\\n \\n float KP2 = (K2 + mouse.y);\\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(y-x -x,.5*y+y, z*3.); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 1.125;\\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.52) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n ,1.15)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect );\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 10721, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.1607843137254902, + 0.1607843137254902, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 11.//KParameter0 0.>>1000.\n#define KP1 56.//KParameter1 0.0>>22.\n#define K2 9.0//KParameter2 6.0>>10.\n#define KP3 -0.01//KParameter3 -8.000>>0.5\n#define KP4 6.2//KParameter4 0.000>>15.\n#define KP5 553.0//KParameter5 30.000>>90000.0\n\n\n\n#define PI radians(180. -KP1)\nfloat VertexCount = 10000. * K2;\n \n float KP2 = (K2 + mouse.y);\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(y-x -x,.5*y+y, z*3.); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 1.125;\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.52) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n ,1.15)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect );\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-p5d1e9l4hxxtb85v8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ivk9RqX2vB24mkdwL/art.json b/art/ivk9RqX2vB24mkdwL/art.json index 264dbed2..8c06c44e 100644 --- a/art/ivk9RqX2vB24mkdwL/art.json +++ b/art/ivk9RqX2vB24mkdwL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":12010,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Motion\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.01) * 0.;\\n float yoff = sin(time + x ) * sin(time);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(sin(xy), 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 500.0;\\n v_color = (vec4(0.75-ux*ux, 0.75-vy*vy, 0.75-ux*vy, 1));\\n}\"}", + "settings": { + "num": 12010, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Motion\ncourse name : CS250\nterm : 2022 Spring\n*/\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.01) * 0.;\n float yoff = sin(time + x ) * sin(time);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(sin(xy), 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 500.0;\n v_color = (vec4(0.75-ux*ux, 0.75-vy*vy, 0.75-ux*vy, 1));\n}" + }, "screenshotURL": "data/images/images-gxh4794byxe3mpx0y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/iw8FH3ButdB4ZzpsQ/art.json b/art/iw8FH3ButdB4ZzpsQ/art.json index ed9b3bd4..7722714d 100644 --- a/art/iw8FH3ButdB4ZzpsQ/art.json +++ b/art/iw8FH3ButdB4ZzpsQ/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "nkkky", "avatarUrl": "https://avatars.githubusercontent.com/nkkky?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/nkkky/sir-rup\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rotr3(float x, float n) {\\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.0);\\n}\\n\\nvec3 cubePos(float x) {\\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n float near = -1.0;\\n float far = 0.99;\\n float aspectRatio = resolution.y / resolution.x;\\n float cubeIdx = floor(vertexId / 36.0);\\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\\n float faceDiv3 = floor(faceIdx / 3.0);\\n float faceMod3 = mod(faceIdx, 3.0);\\n float quadIdx = mod(vertexId, 6.0);\\n float baseIdx = faceIdx * 6.0;\\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\\n pos -= 0.5;\\n pos *= 0.02;\\n \\n float ct = time + mod(cubeIdx, 20.0);\\n float ct1 = time + floor(cubeIdx / 20.0);\\n float s = sin(ct*0.37), c = cos(ct*0.37);\\n float s1 = sin(ct1), c1 = cos(ct1);\\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\\n gl_Position = vec4(pos, 1.0) * rot * rot2;\\n\\n gl_Position.x += (mod(cubeIdx, 20.0) - 10.0) * 0.05;\\n gl_Position.y += (floor(cubeIdx / 20.0) - 10.0) * 0.05;\\n \\n gl_Position.y /= aspectRatio;\\n float zDist = gl_Position.z - near;\\n gl_Position.w = zDist;\\n\\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/nkkky/sir-rup", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rotr3(float x, float n) {\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.0);\n}\n\nvec3 cubePos(float x) {\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n float near = -1.0;\n float far = 0.99;\n float aspectRatio = resolution.y / resolution.x;\n float cubeIdx = floor(vertexId / 36.0);\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\n float faceDiv3 = floor(faceIdx / 3.0);\n float faceMod3 = mod(faceIdx, 3.0);\n float quadIdx = mod(vertexId, 6.0);\n float baseIdx = faceIdx * 6.0;\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\n vec3 pos = cubePos(mod(rotr3(vertIdx, 2.0 - faceMod3) + pow(2.0, faceMod3) * faceDiv3, 8.0));\n pos -= 0.5;\n pos *= 0.02;\n \n float ct = time + mod(cubeIdx, 20.0);\n float ct1 = time + floor(cubeIdx / 20.0);\n float s = sin(ct*0.37), c = cos(ct*0.37);\n float s1 = sin(ct1), c1 = cos(ct1);\n mat4 rot = mat4(vec4(c, s, 0.0, 0.0), vec4(-s, c, 0.0, 0.0), vec4(0.0, 0.0, 1.0, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n mat4 rot2 = mat4(vec4(c1, 0.0, s1, 0.0), vec4(0.0, 1.0, 0.0, 0.0), vec4(-s1, 0.0, c1, 0.0), vec4(0.0, 0.0, 0.0, 1.0));\n gl_Position = vec4(pos, 1.0) * rot * rot2;\n\n gl_Position.x += (mod(cubeIdx, 20.0) - 10.0) * 0.05;\n gl_Position.y += (floor(cubeIdx / 20.0) - 10.0) * 0.05;\n \n gl_Position.y /= aspectRatio;\n float zDist = gl_Position.z - near;\n gl_Position.w = zDist;\n\n v_color = vec4(mod2(faceIdx + 1.0), mod2((faceIdx + 1.0) / 2.0), mod2((faceIdx + 1.0) / 4.0), 1.0);\n}" + }, "screenshotURL": "data/images/images-fq4nmm894gb1pqy7o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iwn76AsDsRRmr5bae/art.json b/art/iwn76AsDsRRmr5bae/art.json index d8c99f96..f2d7bc8f 100644 --- a/art/iwn76AsDsRRmr5bae/art.json +++ b/art/iwn76AsDsRRmr5bae/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":17225,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define P1 3.//KParameter0 0.>>6.\\n\\n\\n\\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 1, 0,\\n 0, 0, 0.1, 0,\\n 0, 0, 2, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1.2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], -.1, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0.1, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 6.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.01;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5,1.30 * P1, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 8.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 2.);\\n float oddSlice = mod(sliceId, 12.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 1.5) * 4.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv))*5.;\\n \\n const int spots = 140;\\n float snd = 0.01;\\n float totalSnd = 0.14;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 2);\\n float spx = hash(spf *- 0.123);\\n float spy = hash(spf / .317);\\n float sps = hash(spf - 3.411);\\n \\n float sds = distance(vec2(u*step(11.9,snd*2.), -v+snd), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.111, sps), sds * .09)).a *\\n mix(2.95, 1.7*2., sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 0.94, 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n float sc = pow(snd, 4.) * 0.1 +snd *\\n oddSlice * 0.03;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 0.61));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0.10));\\n mat *= uniformScale(0.2 * sc * 5. / across);\\n mat *= rotZ(snd * 2. * sign(ux));\\n gl_PointSize = snd;\\n gl_Position = mat * pos;\\n \\n float soff = sin(time + x * y * .09) * 5.; \\n \\n float pump = step(0.27, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 1.1 + pump * .33;\\n hsv.z = mix(0.5, 4., pump);\\n v_color = vec4(hsv2rgb(hsv), 2);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 17225, + "mode": "POINTS", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define P1 3.//KParameter0 0.>>6.\n\n\n\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 1, 0,\n 0, 0, 0.1, 0,\n 0, 0, 2, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1.2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], -.1, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0.1, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 6.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.01;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5,1.30 * P1, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 8.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 2.);\n float oddSlice = mod(sliceId, 12.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 1.5) * 4.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv))*5.;\n \n const int spots = 140;\n float snd = 0.01;\n float totalSnd = 0.14;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 2);\n float spx = hash(spf *- 0.123);\n float spy = hash(spf / .317);\n float sps = hash(spf - 3.411);\n \n float sds = distance(vec2(u*step(11.9,snd*2.), -v+snd), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.111, sps), sds * .09)).a *\n mix(2.95, 1.7*2., sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 0.94, 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n float sc = pow(snd, 4.) * 0.1 +snd *\n oddSlice * 0.03;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 0.61));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0.10));\n mat *= uniformScale(0.2 * sc * 5. / across);\n mat *= rotZ(snd * 2. * sign(ux));\n gl_PointSize = snd;\n gl_Position = mat * pos;\n \n float soff = sin(time + x * y * .09) * 5.; \n \n float pump = step(0.27, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 1.1 + pump * .33;\n hsv.z = mix(0.5, 4., pump);\n v_color = vec4(hsv2rgb(hsv), 2);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-7i4sra99w3odylqk5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ixPJFSrp6TMRKW4xF/art.json b/art/ixPJFSrp6TMRKW4xF/art.json index 24103b48..55c985c2 100644 --- a/art/ixPJFSrp6TMRKW4xF/art.json +++ b/art/ixPJFSrp6TMRKW4xF/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richarddevine/strum-modular-patch\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n// <3 u richie\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n/*\\n \\tby Nicholas C. Raftis III MacroMachines.net Axiom-Crux.net\\n*/\\n\\n#define RATE 10.0\\n#define SND 1.25\\n#define SND2 0.95\\n#define BPM 172.0\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.1492;\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5;\\n float l = length(posf)*1.45;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float tempo = 0.125*time*BPM/60.0;\\n float ramp = fract( tempo*2. );\\n float sine = sin(tempo);\\n float t = time*.10;\\n float i = vertexId+sin(vertexId)*0.10;\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n vec3 colmod = vec3(0.);\\n for (float f = -10.; f < 0.; f++) {\\n \\tfloat nn = f<-5.?0.0001:1.;\\n \\tfloat snd = texture2D(sound,vec2(-f*0.1,i*-f*0.1*nn)).a*SND;\\n\\t \\tofs += push(t+f*.105*snd,i,ofs,2.-exp(-f*.1*snd));\\n \\tofs -= snd*0.2;\\n \\tofs += SND*0.05;\\n \\tofs *= nn;\\n }\\n float snd2 = texture2D(sound,vec2(pos.yz)).a*SND2;\\n snd2*= ramp/sin(time*1.70);//*i;//*0.01;\\n ofs += push(t+snd2,i,ofs,0.999);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *= 1.;\\n pos.z += 0.7;\\n float moddepth = mix(0.2, 0.5, ramp*snd2);\\n pos.xy *= moddepth/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n float size = 1.0/pos.z* 0.1+1.;\\n size = clamp(size, 0.51, 2.0);\\n gl_PointSize = size;\\n \\n //gl_Position.z -= 1.*sine;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/richarddevine/strum-modular-patch", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n// <3 u richie\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/*\n \tby Nicholas C. Raftis III MacroMachines.net Axiom-Crux.net\n*/\n\n#define RATE 10.0\n#define SND 1.25\n#define SND2 0.95\n#define BPM 172.0\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.1492;\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5;\n float l = length(posf)*1.45;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float tempo = 0.125*time*BPM/60.0;\n float ramp = fract( tempo*2. );\n float sine = sin(tempo);\n float t = time*.10;\n float i = vertexId+sin(vertexId)*0.10;\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n vec3 colmod = vec3(0.);\n for (float f = -10.; f < 0.; f++) {\n \tfloat nn = f<-5.?0.0001:1.;\n \tfloat snd = texture2D(sound,vec2(-f*0.1,i*-f*0.1*nn)).a*SND;\n\t \tofs += push(t+f*.105*snd,i,ofs,2.-exp(-f*.1*snd));\n \tofs -= snd*0.2;\n \tofs += SND*0.05;\n \tofs *= nn;\n }\n float snd2 = texture2D(sound,vec2(pos.yz)).a*SND2;\n snd2*= ramp/sin(time*1.70);//*i;//*0.01;\n ofs += push(t+snd2,i,ofs,0.999);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *= 1.;\n pos.z += 0.7;\n float moddepth = mix(0.2, 0.5, ramp*snd2);\n pos.xy *= moddepth/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n float size = 1.0/pos.z* 0.1+1.;\n size = clamp(size, 0.51, 2.0);\n gl_PointSize = size;\n \n //gl_Position.z -= 1.*sine;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.470, 0.97, 0.23);\n}" + }, "screenshotURL": "data/images/images-32uhk80z1xtzo7k2r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ixr3Pka4ChbtDzobh/art.json b/art/ixr3Pka4ChbtDzobh/art.json index 5e5dc184..4e1c7511 100644 --- a/art/ixr3Pka4ChbtDzobh/art.json +++ b/art/ixr3Pka4ChbtDzobh/art.json @@ -27,7 +27,19 @@ "name": "Spiral-Spring", "private": false, "username": "gman", - "settings": "{\"num\":16384,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\n//\\n// Move the mouse\\n//\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float tm = sin(time) * 20.;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.01;\\n float phase = -tm+mod(vertexId,2.0);\\n float a = 0.5;\\n float b = 0.3063489;\\n float x = a * exp(b*t*0.2)*cos(t+phase)*0.015;\\n float y = a * exp(b*t*0.2)*sin(t+phase)*0.015;\\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.00005));\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\\n\\n \\n float hue = (floor(vertexId * -.005) * 0.5 - time * 0.01);\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \n//\n// Move the mouse\n//\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float tm = sin(time) * 20.;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float t = (vertexId*2.0+mod(vertexId,2.0))*0.01;\n float phase = -tm+mod(vertexId,2.0);\n float a = 0.5;\n float b = 0.3063489;\n float x = a * exp(b*t*0.2)*cos(t+phase)*0.015;\n float y = a * exp(b*t*0.2)*sin(t+phase)*0.015;\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.00005));\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\n\n \n float hue = (floor(vertexId * -.005) * 0.5 - time * 0.01);\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ug7gazpjhxhs9mlj0-thumbnail.jpg", "views": { "$numberInt": "3892" diff --git a/art/iycvXPQfzvSbzg9JP/art.json b/art/iycvXPQfzvSbzg9JP/art.json index 9e9e9bdd..e520b662 100644 --- a/art/iycvXPQfzvSbzg9JP/art.json +++ b/art/iycvXPQfzvSbzg9JP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .1//KParameter .1>>2.\\n#define PointSizeValue 1.13//KParameter 1.>>4.\\n#define deltaFactor0 0.//KParameter 0.>>1.\\n#define deltaFactor1 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n\\n//KDrawmode=GL_POINTS\\n\\n\\nvec3 osc3(float t, float i)\\n{\\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 osc3Comb(float t, float i) {\\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\\n}\\n\\nvec3 incr(float _t, float _i, vec3 _add, float _l)\\n{\\n vec3 pos = osc3Comb(_t,_i)+_add;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\\n \\n\\n float t = time*timeFactor;\\n float i = localVertexId;\\n\\n vec3 pos = osc3Comb(t,i);\\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\\n \\n \\n for (float f = 0.; f < 10.; f++) \\n {\\n\\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\\n }\\n \\n posDelta += incr(t,i,posDelta,0.2);\\n \\n pos -= osc3(t,-1.)*posComp0;\\n \\n pos += posDelta;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n \\n if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\\n\\n}\\n\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .1//KParameter .1>>2.\n#define PointSizeValue 1.13//KParameter 1.>>4.\n#define deltaFactor0 0.//KParameter 0.>>1.\n#define deltaFactor1 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n\n//KDrawmode=GL_POINTS\n\n\nvec3 osc3(float t, float i)\n{\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 osc3Comb(float t, float i) {\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\n}\n\nvec3 incr(float _t, float _i, vec3 _add, float _l)\n{\n vec3 pos = osc3Comb(_t,_i)+_add;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/4.) );\n \n\n float t = time*timeFactor;\n float i = localVertexId;\n\n vec3 pos = osc3Comb(t,i);\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\n \n \n for (float f = 0.; f < 10.; f++) \n {\n\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\n }\n \n posDelta += incr(t,i,posDelta,0.2);\n \n pos -= osc3(t,-1.)*posComp0;\n \n pos += posDelta;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n \n if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\n\n}\n" + }, "screenshotURL": "data/images/images-toat9uk4bsl3yv7na-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/iye5kiPcXb3MgKAAN/art.json b/art/iye5kiPcXb3MgKAAN/art.json index 4a20edba..5267d385 100644 --- a/art/iye5kiPcXb3MgKAAN/art.json +++ b/art/iye5kiPcXb3MgKAAN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "taejukwon-digipen", "avatarUrl": "https://avatars.githubusercontent.com/taejuKwon-digipen?s=200", - "settings": "{\"num\":6003,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/kyleexum/bassthoven-feat-shawn-wasabi\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Taeju Kwon\\n//CS250\\n//2022_Spring\\n//04_AudioReactiveArt\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3 (c.x, clamp(c.yz, 0.0,1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p-K.xxx , 0.0, 1.0) , c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float sv = abs(v-0.5) * 2.;\\n float su = abs(u-0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au* .05,av * .25)).a;\\n \\n gl_Position = vec4(xy, 0,1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.)* 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //u * 1. + sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1.,pump);\\n float val = mix(-1.,pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0 ) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n}\"}", + "settings": { + "num": 6003, + "mode": "POINTS", + "sound": "https://soundcloud.com/kyleexum/bassthoven-feat-shawn-wasabi", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Taeju Kwon\n//CS250\n//2022_Spring\n//04_AudioReactiveArt\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3 (c.x, clamp(c.yz, 0.0,1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p-K.xxx , 0.0, 1.0) , c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float sv = abs(v-0.5) * 2.;\n float su = abs(u-0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au* .05,av * .25)).a;\n \n gl_Position = vec4(xy, 0,1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.)* 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //u * 1. + sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1.,pump);\n float val = mix(-1.,pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0 ) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n}" + }, "screenshotURL": "data/images/images-2fl7fjpjzpp0h83i3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/j2TsACSvPYuDJ2t2X/art.json b/art/j2TsACSvPYuDJ2t2X/art.json index c28e9744..66a4e17e 100644 --- a/art/j2TsACSvPYuDJ2t2X/art.json +++ b/art/j2TsACSvPYuDJ2t2X/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" \\n// shadertoy\\n// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\nconst vec3 ld = vec3(0.,1., .5);\\n\\nfloat t = 0.;\\n\\nfloat fullAtan(vec2 p)\\n{\\n return step(0.0,-p.x)*3.1415926535 + sign(p.x) * atan(p.x, sign(p.x) * p.y);\\n}\\n\\nfloat fractus(vec2 p, vec2 v)\\n{\\n\\tvec2 z = p;\\n vec2 c = v;\\n\\tfloat k = 1., h = 1.0; \\n float t = (sin(time * .5)*.5+.5) * 5.;\\n for (float i=0.;i<5.;i++)\\n {\\n if (i > t) break;\\n h *= 4.*k;\\n\\t\\tk = dot(z,z);\\n if(k > 4.) break;\\n\\t\\tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\\n }\\n float d = sqrt(k/h)*log(k);\\n \\n // next iteration\\n if (k > 4.)\\n \\tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\\n h *= 4.*k;\\n k = dot(z,z);\\n float d1 = sqrt(k/h)*log(k);\\n \\n // df blending\\n\\treturn mix(d, d1, fract(t));\\n}\\n\\nvec4 dfFractus(vec3 p)\\n{\\n\\tfloat a = fullAtan(p.xz); // axis y\\n \\n vec2 c;\\n c.x = mix(0.2, -0.5, sin(a * 2.));\\n c.y = mix(0.5, 0.0, sin(a * 3.));\\n \\n float path = length(p.xz) - 3.;\\n \\n vec2 rev = vec2(path, p.y);\\n float aa = a + time;\\n rev *= mat2(cos(aa),-sin(aa),sin(aa),cos(aa)); // rot near axis y\\n\\t\\n\\treturn vec4(fractus(rev, c) - 0.0, rev, 0);\\n}\\n\\nvec4 df(vec3 p)\\n{\\n\\treturn dfFractus(p); \\n}\\n\\nvec3 nor( vec3 p, float prec )\\n{\\n vec2 e = vec2( prec, 0. );\\n vec3 n = vec3(\\n\\t\\tdf(p+e.xyy).x - df(p-e.xyy).x,\\n\\t\\tdf(p+e.yxy).x - df(p-e.yxy).x,\\n\\t\\tdf(p+e.yyx).x - df(p-e.yyx).x );\\n return normalize(n);\\n}\\n\\n// from iq code\\nfloat softshadow( in vec3 ro, in vec3 rd, in float mint, in float tmax )\\n{\\n\\tfloat res = 1.0;\\n float t = mint;\\n for( int i=0; i<1; i++ )\\n {\\n\\t\\tfloat h = df( ro + rd*t ).x;\\n res = min( res, 8.0*h/t );\\n t += h*.25;\\n if( h<0.001 || t>tmax ) break;\\n }\\n return clamp( res, 0., 1. );\\n}\\n\\n// from iq code\\nfloat calcAO( in vec3 pos, in vec3 nor )\\n{\\n\\tfloat occ = 0.0;\\n float sca = 1.0;\\n for( int i=0; i<10; i++ )\\n {\\n float hr = 0.01 + 0.12*float(i)/4.0;\\n vec3 aopos = nor * hr + pos;\\n float dd = df( aopos ).x;\\n occ += -(dd-hr)*sca;\\n sca *= 0.95;\\n }\\n return clamp( 1.0 - 3.0*occ, 0.0, 1.0 ); \\n}\\n\\n//--------------------------------------------------------------------------\\n// Grab all sky information for a given ray from camera\\n// from Dave Hoskins // https://www.shadertoy.com/view/Xsf3zX\\nvec3 GetSky(in vec3 rd, in vec3 sunDir, in vec3 sunCol)\\n{\\n\\tfloat sunAmount = max( dot( rd, sunDir), 0.0 );\\n\\tfloat v = pow(1.0-max(rd.y,0.0),6.);\\n\\tvec3 sky = mix(vec3(.1, .2, .3), vec3(.32, .32, .32), v);\\n\\tsky = sky + sunCol * sunAmount * sunAmount * .25;\\n\\tsky = sky + sunCol * min(pow(sunAmount, 800.0)*1.5, .3);\\n\\treturn clamp(sky, 0.0, 1.0);\\n}\\n\\nvoid main() \\n{\\n if (vertexId == 0.) gl_Position = vec4(-1,-1,0,1);\\n if (vertexId == 1.) gl_Position = vec4(1,-1,0,1);\\n if (vertexId == 2.) gl_Position = vec4(1,1,0,1);\\n if (vertexId == 3.) gl_Position = vec4(-1,1,0,1);\\n \\n\\n\\n\\n\\n\\n\\n\\tvec4 fragColor = vec4(1);\\n\\t\\n\\tvec2 g = gl_Position.xy;\\n\\tvec2 si = resolution.xy;\\n\\tvec2 uv = (2.*g-si)/min(si.x, si.y);\\n\\t\\n float a = 1.57;\\n\\tvec3 rayOrg = vec3(cos(a),1.5,sin(a)) * 5.;\\n\\tvec3 camUp = vec3(0,1,0);\\n\\tvec3 camOrg = vec3(0,-1.5,0);\\n\\t\\n\\tfloat fov = .5;\\n\\tvec3 axisZ = normalize(camOrg - rayOrg);\\n\\tvec3 axisX = normalize(cross(camUp, axisZ));\\n\\tvec3 axisY = normalize(cross(axisZ, axisX));\\n\\tvec3 rayDir = normalize(axisZ + fov * uv.x * axisX + fov * uv.y * axisY);\\n\\t\\n\\tfloat s = 0.;\\n float d = 0.;\\n\\tfloat dMax = 20.;\\n\\tfloat count = 0.;\\n\\tfor (float i=0.; i<500.; i++)\\n\\t{\\n\\t\\tif (d*d/s>1e6 || d>dMax) break;\\n s = df(rayOrg + rayDir * d).x;\\n\\t\\td += s * 0.2;\\n\\t\\tcount+=1.;\\n\\t}\\n\\t\\n vec3 sky = GetSky(rayDir, ld, vec3(1.5));\\n\\n\\t\\n\\tif (d t) break;\n h *= 4.*k;\n\t\tk = dot(z,z);\n if(k > 4.) break;\n\t\tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\n }\n float d = sqrt(k/h)*log(k);\n \n // next iteration\n if (k > 4.)\n \tz = vec2(z.x * z.x - z.y * z.y, 2. * z.x * z.y) + c;\n h *= 4.*k;\n k = dot(z,z);\n float d1 = sqrt(k/h)*log(k);\n \n // df blending\n\treturn mix(d, d1, fract(t));\n}\n\nvec4 dfFractus(vec3 p)\n{\n\tfloat a = fullAtan(p.xz); // axis y\n \n vec2 c;\n c.x = mix(0.2, -0.5, sin(a * 2.));\n c.y = mix(0.5, 0.0, sin(a * 3.));\n \n float path = length(p.xz) - 3.;\n \n vec2 rev = vec2(path, p.y);\n float aa = a + time;\n rev *= mat2(cos(aa),-sin(aa),sin(aa),cos(aa)); // rot near axis y\n\t\n\treturn vec4(fractus(rev, c) - 0.0, rev, 0);\n}\n\nvec4 df(vec3 p)\n{\n\treturn dfFractus(p); \n}\n\nvec3 nor( vec3 p, float prec )\n{\n vec2 e = vec2( prec, 0. );\n vec3 n = vec3(\n\t\tdf(p+e.xyy).x - df(p-e.xyy).x,\n\t\tdf(p+e.yxy).x - df(p-e.yxy).x,\n\t\tdf(p+e.yyx).x - df(p-e.yyx).x );\n return normalize(n);\n}\n\n// from iq code\nfloat softshadow( in vec3 ro, in vec3 rd, in float mint, in float tmax )\n{\n\tfloat res = 1.0;\n float t = mint;\n for( int i=0; i<1; i++ )\n {\n\t\tfloat h = df( ro + rd*t ).x;\n res = min( res, 8.0*h/t );\n t += h*.25;\n if( h<0.001 || t>tmax ) break;\n }\n return clamp( res, 0., 1. );\n}\n\n// from iq code\nfloat calcAO( in vec3 pos, in vec3 nor )\n{\n\tfloat occ = 0.0;\n float sca = 1.0;\n for( int i=0; i<10; i++ )\n {\n float hr = 0.01 + 0.12*float(i)/4.0;\n vec3 aopos = nor * hr + pos;\n float dd = df( aopos ).x;\n occ += -(dd-hr)*sca;\n sca *= 0.95;\n }\n return clamp( 1.0 - 3.0*occ, 0.0, 1.0 ); \n}\n\n//--------------------------------------------------------------------------\n// Grab all sky information for a given ray from camera\n// from Dave Hoskins // https://www.shadertoy.com/view/Xsf3zX\nvec3 GetSky(in vec3 rd, in vec3 sunDir, in vec3 sunCol)\n{\n\tfloat sunAmount = max( dot( rd, sunDir), 0.0 );\n\tfloat v = pow(1.0-max(rd.y,0.0),6.);\n\tvec3 sky = mix(vec3(.1, .2, .3), vec3(.32, .32, .32), v);\n\tsky = sky + sunCol * sunAmount * sunAmount * .25;\n\tsky = sky + sunCol * min(pow(sunAmount, 800.0)*1.5, .3);\n\treturn clamp(sky, 0.0, 1.0);\n}\n\nvoid main() \n{\n if (vertexId == 0.) gl_Position = vec4(-1,-1,0,1);\n if (vertexId == 1.) gl_Position = vec4(1,-1,0,1);\n if (vertexId == 2.) gl_Position = vec4(1,1,0,1);\n if (vertexId == 3.) gl_Position = vec4(-1,1,0,1);\n \n\n\n\n\n\n\n\tvec4 fragColor = vec4(1);\n\t\n\tvec2 g = gl_Position.xy;\n\tvec2 si = resolution.xy;\n\tvec2 uv = (2.*g-si)/min(si.x, si.y);\n\t\n float a = 1.57;\n\tvec3 rayOrg = vec3(cos(a),1.5,sin(a)) * 5.;\n\tvec3 camUp = vec3(0,1,0);\n\tvec3 camOrg = vec3(0,-1.5,0);\n\t\n\tfloat fov = .5;\n\tvec3 axisZ = normalize(camOrg - rayOrg);\n\tvec3 axisX = normalize(cross(camUp, axisZ));\n\tvec3 axisY = normalize(cross(axisZ, axisX));\n\tvec3 rayDir = normalize(axisZ + fov * uv.x * axisX + fov * uv.y * axisY);\n\t\n\tfloat s = 0.;\n float d = 0.;\n\tfloat dMax = 20.;\n\tfloat count = 0.;\n\tfor (float i=0.; i<500.; i++)\n\t{\n\t\tif (d*d/s>1e6 || d>dMax) break;\n s = df(rayOrg + rayDir * d).x;\n\t\td += s * 0.2;\n\t\tcount+=1.;\n\t}\n\t\n vec3 sky = GetSky(rayDir, ld, vec3(1.5));\n\n\t\n\tif (d> comment all precision, extension, uniforms and varying\\n\\n#define factor0 0.01//KParameter 0.01>>0.9\\n#define factor1 0.05//KParameter 0.0001>>0.1\\n#define timeFactor 1.//KParameter 1.>>40.\\n\\nvec2 rotate(in vec2 v, in float a) {\\n\\treturn vec2(cos(a)*v.x + sin(a)*v.y, -sin(a)*v.x + cos(a)*v.y);\\n}\\n\\nfloat torus(in vec3 p, in vec2 t)\\n{\\n\\tvec2 q = abs(vec2(max(abs(p.x), abs(p.z))-t.x, p.y));\\n\\treturn max(q.x, q.y)-t.y;\\n}\\n\\nfloat trap(in vec3 p)\\n{\\n\\t//return abs(max(abs(p.z)-0.1, abs(p.x)-0.1))-0.01;\\n\\t//return length(max(abs(p.xy) - 0.05, 0.0));\\n\\t//return length(max(abs(p) - 0.35, 0.0));\\n\\t//return abs(length(p.xz)-0.2)-0.01;\\n\\t//return min(length(p.xz), min(length(p.yz), length(p.xy))) - 0.05;\\n\\treturn abs(min(torus(vec3(p.x, mod(p.y,factor0)-0.2, p.z), vec2(0.1, factor1)), max(abs(p.z)-0.05, abs(p.x)-0.05)))-0.005;\\n\\treturn abs(min(torus(p, vec2(0.3, 0.05)), max(abs(p.z)-0.05, abs(p.x)-0.05)))-0.005;\\n}\\n\\nfloat map(in vec3 p)\\n{\\n float time2 = time+60.0;\\n\\tfloat cutout = dot(abs(p.yz),vec2(0.5))-0.035;\\n\\t//float road = max(abs(p.y-0.025), abs(p.z)-0.035);\\n\\t\\n\\tvec3 z = abs(1.0-mod(p,2.0));\\n\\tz.yz = rotate(z.yz, time2*0.05);\\n\\n\\tfloat d = 999.0;\\n\\tfloat s = 1.0;\\n\\tfor (float i = 0.0; i < 3.0; i++) {\\n\\t\\tz.xz = rotate(z.xz, radians(i*10.0+time2));\\n\\t\\tz.zy = rotate(z.yz, radians((i+1.0)*20.0+time2*1.1234));\\n\\t\\tz = abs(1.0-mod(z+i/3.0,2.0));\\n\\t\\t\\n\\t\\tz = z*2.0 - 0.3;\\n\\t\\ts *= 0.5;\\n\\t\\td = min(d, trap(z) * s);\\n\\t}\\n\\treturn max(d, -cutout);\\n}\\n\\nvec3 hsv(in float h, in float s, in float v) {\\n\\treturn mix(vec3(1.0), clamp((abs(fract(h + vec3(3, 2, 1) / 3.0) * 6.0 - 3.0) - 1.0), 0.0 , 1.0), s) * v;\\n}\\n\\nvec3 intersect(in vec3 rayOrigin, in vec3 rayDir)\\n{\\n float time2 = time+60.0;\\n\\tfloat total_dist = 0.0;\\n\\tvec3 p = rayOrigin;\\n\\tfloat d = 1.0;\\n\\tfloat iter = 0.0;\\n\\tfloat mind = 3.14159+sin(time2*0.0)*0.0; // Move road from side to side slowly\\n\\t\\n\\tfor (int i = 0; i < 20; i++)\\n\\t{\\t\\t\\n\\t\\tif (d < 0.001) continue;\\n\\t\\t\\n\\t\\td = map(p);\\n\\t\\t// This rotation causes the occasional distortion - like you would see from heat waves\\n\\t\\tp += d*vec3(rayDir.x, rotate(rayDir.yz, sin(mind)));\\n\\t\\tmind = min(mind, d);\\n\\t\\ttotal_dist += d;\\n\\t\\titer++;\\n\\t}\\n\\n\\tvec3 color = vec3(0.0);\\n\\tif (d < 0.001) {\\n\\t\\tfloat x = (iter/59.0);\\n\\t\\tfloat y = (d-0.01)/0.01/(59.0);\\n\\t\\tfloat z = (0.01-d)/0.01/59.0;\\n\\t\\t\\n\\n\\t\\t\\tfloat q = 1.0-x-y*2.+z;\\n\\t\\t\\tcolor = hsv(q*0.2+0.85, 1.0-q*0.2, q);\\n\\t} \\n\\t\\t//color = hsv(d, 1.0, 1.0)*mind*45.0; // Background\\n\\treturn color;\\n}\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u_i = (x /vertexResolution.x);\\n float v_i = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u_i - 0.5);\\n float vy = sizeFactor*(v_i - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by simFragCoord \\n //replace gl_FragColor by v_color\\n //replace iResolution by resolution\\n //replace resolution by vertexResolution\\n \\n float time2 = timeFactor*time+60.0;\\n\\tvec3 upDirection = vec3(0, -1, 0);\\n\\tvec3 cameraDir = vec3(1,0,0);\\n\\tvec3 cameraOrigin = vec3(time2*0.1, 0, 0);\\n\\t\\n\\tvec3 u = normalize(cross(upDirection, cameraOrigin));\\n\\tvec3 v = normalize(cross(cameraDir, u));\\n\\tvec2 screenPos = -1.0 + 2.0 * simFragCoord.xy / vertexResolution.xy;\\n\\tscreenPos.x *= vertexResolution.x / vertexResolution.y;\\n\\tvec3 rayDir = normalize(u * screenPos.x + v * screenPos.y + cameraDir*(1.0-length(screenPos)*0.5));\\n\\tvec3 col = vec3( intersect(cameraOrigin, rayDir) );\\n\\tv_color = vec4(col,1.0);\\n \\n /****************************************************************/\\n \\n}\\n\\n\\n\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n\n#define factor0 0.01//KParameter 0.01>>0.9\n#define factor1 0.05//KParameter 0.0001>>0.1\n#define timeFactor 1.//KParameter 1.>>40.\n\nvec2 rotate(in vec2 v, in float a) {\n\treturn vec2(cos(a)*v.x + sin(a)*v.y, -sin(a)*v.x + cos(a)*v.y);\n}\n\nfloat torus(in vec3 p, in vec2 t)\n{\n\tvec2 q = abs(vec2(max(abs(p.x), abs(p.z))-t.x, p.y));\n\treturn max(q.x, q.y)-t.y;\n}\n\nfloat trap(in vec3 p)\n{\n\t//return abs(max(abs(p.z)-0.1, abs(p.x)-0.1))-0.01;\n\t//return length(max(abs(p.xy) - 0.05, 0.0));\n\t//return length(max(abs(p) - 0.35, 0.0));\n\t//return abs(length(p.xz)-0.2)-0.01;\n\t//return min(length(p.xz), min(length(p.yz), length(p.xy))) - 0.05;\n\treturn abs(min(torus(vec3(p.x, mod(p.y,factor0)-0.2, p.z), vec2(0.1, factor1)), max(abs(p.z)-0.05, abs(p.x)-0.05)))-0.005;\n\treturn abs(min(torus(p, vec2(0.3, 0.05)), max(abs(p.z)-0.05, abs(p.x)-0.05)))-0.005;\n}\n\nfloat map(in vec3 p)\n{\n float time2 = time+60.0;\n\tfloat cutout = dot(abs(p.yz),vec2(0.5))-0.035;\n\t//float road = max(abs(p.y-0.025), abs(p.z)-0.035);\n\t\n\tvec3 z = abs(1.0-mod(p,2.0));\n\tz.yz = rotate(z.yz, time2*0.05);\n\n\tfloat d = 999.0;\n\tfloat s = 1.0;\n\tfor (float i = 0.0; i < 3.0; i++) {\n\t\tz.xz = rotate(z.xz, radians(i*10.0+time2));\n\t\tz.zy = rotate(z.yz, radians((i+1.0)*20.0+time2*1.1234));\n\t\tz = abs(1.0-mod(z+i/3.0,2.0));\n\t\t\n\t\tz = z*2.0 - 0.3;\n\t\ts *= 0.5;\n\t\td = min(d, trap(z) * s);\n\t}\n\treturn max(d, -cutout);\n}\n\nvec3 hsv(in float h, in float s, in float v) {\n\treturn mix(vec3(1.0), clamp((abs(fract(h + vec3(3, 2, 1) / 3.0) * 6.0 - 3.0) - 1.0), 0.0 , 1.0), s) * v;\n}\n\nvec3 intersect(in vec3 rayOrigin, in vec3 rayDir)\n{\n float time2 = time+60.0;\n\tfloat total_dist = 0.0;\n\tvec3 p = rayOrigin;\n\tfloat d = 1.0;\n\tfloat iter = 0.0;\n\tfloat mind = 3.14159+sin(time2*0.0)*0.0; // Move road from side to side slowly\n\t\n\tfor (int i = 0; i < 20; i++)\n\t{\t\t\n\t\tif (d < 0.001) continue;\n\t\t\n\t\td = map(p);\n\t\t// This rotation causes the occasional distortion - like you would see from heat waves\n\t\tp += d*vec3(rayDir.x, rotate(rayDir.yz, sin(mind)));\n\t\tmind = min(mind, d);\n\t\ttotal_dist += d;\n\t\titer++;\n\t}\n\n\tvec3 color = vec3(0.0);\n\tif (d < 0.001) {\n\t\tfloat x = (iter/59.0);\n\t\tfloat y = (d-0.01)/0.01/(59.0);\n\t\tfloat z = (0.01-d)/0.01/59.0;\n\t\t\n\n\t\t\tfloat q = 1.0-x-y*2.+z;\n\t\t\tcolor = hsv(q*0.2+0.85, 1.0-q*0.2, q);\n\t} \n\t\t//color = hsv(d, 1.0, 1.0)*mind*45.0; // Background\n\treturn color;\n}\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u_i = (x /vertexResolution.x);\n float v_i = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u_i - 0.5);\n float vy = sizeFactor*(v_i - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by simFragCoord \n //replace gl_FragColor by v_color\n //replace iResolution by resolution\n //replace resolution by vertexResolution\n \n float time2 = timeFactor*time+60.0;\n\tvec3 upDirection = vec3(0, -1, 0);\n\tvec3 cameraDir = vec3(1,0,0);\n\tvec3 cameraOrigin = vec3(time2*0.1, 0, 0);\n\t\n\tvec3 u = normalize(cross(upDirection, cameraOrigin));\n\tvec3 v = normalize(cross(cameraDir, u));\n\tvec2 screenPos = -1.0 + 2.0 * simFragCoord.xy / vertexResolution.xy;\n\tscreenPos.x *= vertexResolution.x / vertexResolution.y;\n\tvec3 rayDir = normalize(u * screenPos.x + v * screenPos.y + cameraDir*(1.0-length(screenPos)*0.5));\n\tvec3 col = vec3( intersect(cameraOrigin, rayDir) );\n\tv_color = vec4(col,1.0);\n \n /****************************************************************/\n \n}\n\n\n" + }, "screenshotURL": "data/images/images-e0lszzik9jcyjeyeh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/j7WftWuJtPTYyhcxG/art.json b/art/j7WftWuJtPTYyhcxG/art.json index 30fa39b8..5040bb27 100644 --- a/art/j7WftWuJtPTYyhcxG/art.json +++ b/art/j7WftWuJtPTYyhcxG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1278,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.4549019607843137,0.5058823529411764,1],\"shader\":\"// Simple Line which responds to music\\n// This is intended to be super simple, to learn how to use VertexShaderArt\\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\\n\\nvoid main()\\n{\\n // vertex_percent is vertexId mapped to [0..1]\\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\\n \\n // sound texture has (amplitude, history) for (u,v). \\n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\\n // It is all in the alpha channel of the sound texture\\n \\n // Set y position to amplitude in [0..1] range.\\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\\n float y = -0.5+2.0*texture2D(sound,vec2(0.5*vertex_percent,0.0)).a*0.5; \\n \\n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\\n gl_Position = vec4(x,y,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\\n v_color = vec4(sin(time)*sin(time), y+1.0, 50.0*vertex_percent*y, 1.0);\\n vec4 aa = background;\\n} \\n\\n\"}", + "settings": { + "num": 1278, + "mode": "POINTS", + "sound": "https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.4549019607843137, + 0.5058823529411764, + 1 + ], + "shader": "// Simple Line which responds to music\n// This is intended to be super simple, to learn how to use VertexShaderArt\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\n\nvoid main()\n{\n // vertex_percent is vertexId mapped to [0..1]\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\n \n // sound texture has (amplitude, history) for (u,v). \n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\n // It is all in the alpha channel of the sound texture\n \n // Set y position to amplitude in [0..1] range.\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\n float y = -0.5+2.0*texture2D(sound,vec2(0.5*vertex_percent,0.0)).a*0.5; \n \n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\n gl_Position = vec4(x,y,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\n v_color = vec4(sin(time)*sin(time), y+1.0, 50.0*vertex_percent*y, 1.0);\n vec4 aa = background;\n} \n\n" + }, "screenshotURL": "data/images/images-alsxh8by3jbhw7cr8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/j7geNJncnTGfxf9ZX/art.json b/art/j7geNJncnTGfxf9ZX/art.json index 9c84dfed..d840839b 100644 --- a/art/j7geNJncnTGfxf9ZX/art.json +++ b/art/j7geNJncnTGfxf9ZX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":800,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n vec3 pos = vec3(tan(vertexId), tan(time+vertexId), 0.0);\\n \\n gl_PointSize = 15.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(pos.x, pos.y, -pos.x, 1.0)+0.3;\\n}\"}", + "settings": { + "num": 800, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n vec3 pos = vec3(tan(vertexId), tan(time+vertexId), 0.0);\n \n gl_PointSize = 15.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(pos.x, pos.y, -pos.x, 1.0)+0.3;\n}" + }, "screenshotURL": "data/images/images-3p9f3xi3zwufkvvpc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/j7v3Ha4S2hwxhSCi9/art.json b/art/j7v3Ha4S2hwxhSCi9/art.json index 47dba106..d671be47 100644 --- a/art/j7v3Ha4S2hwxhSCi9/art.json +++ b/art/j7v3Ha4S2hwxhSCi9/art.json @@ -28,7 +28,19 @@ "name": "the galactic loom of sound and light", "private": false, "username": "visy", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/pawel-osmolski/fairlight-c64-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n#define NUM_LINES_DOWN 512.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y*0.5;\\n float snd = texture2D(sound, vec2(historyX*0.05, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 8.0 - 1.0;\\n \\n float xx = 1.0;\\n float yy = 1.0;\\n \\n vec2 xy = vec2(\\n xx*x * mix(0.5, 1.0, invV),\\n yy*y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 1.0*cos(v*5.0+time*0.1), 0, 2.2);\\n\\n float hue = v*5.5;\\n float sat = invV;\\n float val = invV;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/pawel-osmolski/fairlight-c64-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n#define NUM_LINES_DOWN 512.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN + 0.5) / soundRes.y*0.5;\n float snd = texture2D(sound, vec2(historyX*0.05, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 8.0 - 1.0;\n \n float xx = 1.0;\n float yy = 1.0;\n \n vec2 xy = vec2(\n xx*x * mix(0.5, 1.0, invV),\n yy*y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 1.0*cos(v*5.0+time*0.1), 0, 2.2);\n\n float hue = v*5.5;\n float sat = invV;\n float val = invV;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-p59m6vciq421lc2e8-thumbnail.jpg", "views": { "$numberInt": "1217" diff --git a/art/j83YWD4DHLXrjrvxf/art.json b/art/j83YWD4DHLXrjrvxf/art.json index 09dd660a..f4a52971 100644 --- a/art/j83YWD4DHLXrjrvxf/art.json +++ b/art/j83YWD4DHLXrjrvxf/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": false, "username": "gman", - "settings": "{\"num\":73728,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/silver-romance/acdc-thunder-struck\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9921568627450981,0.984313725490196,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 256.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, 1. -ringV)).a;\\n \\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 2. * time * 1. + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = mix(inner, 1., level);\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.5;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n offset.z += 40.;\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n mat *= trans(offset);\\n mat *= scale(vec3(0.25, 0.25, -80.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float th = texture2D(sound, vec2(0.018 / 4., 0.0)).a;\\n\\n float h = sin(time * 0.1) + 0.4;\\n float hue = mix(h, h + .1, snd);\\n float sat = 0.2;\\n float val = mix(.065, 1., snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.a = 1.0 - uvf.y;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n v_color.rgb = mix(v_color.rgb, 1. - v_color.rgb, step(0.95, th));//pow(th, 10.));\\n}\"}", + "settings": { + "num": 73728, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/silver-romance/acdc-thunder-struck", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9921568627450981, + 0.984313725490196, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 256.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, 1. -ringV)).a;\n \n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 2. * time * 1. + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = mix(inner, 1., level);\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.5;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n offset.z += 40.;\n \n mat4 mat = ident(); \n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n mat *= trans(offset);\n mat *= scale(vec3(0.25, 0.25, -80.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float th = texture2D(sound, vec2(0.018 / 4., 0.0)).a;\n\n float h = sin(time * 0.1) + 0.4;\n float hue = mix(h, h + .1, snd);\n float sat = 0.2;\n float val = mix(.065, 1., snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.a = 1.0 - uvf.y;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n v_color.rgb = mix(v_color.rgb, 1. - v_color.rgb, step(0.95, th));//pow(th, 10.));\n}" + }, "screenshotURL": "data/images/images-m8qw2xmg4374uoz6b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/j99N9DxvqWDcDFv84/art.json b/art/j99N9DxvqWDcDFv84/art.json index 1a4a87e2..57c230a2 100644 --- a/art/j99N9DxvqWDcDFv84/art.json +++ b/art/j99N9DxvqWDcDFv84/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "der", "avatarUrl": "https://secure.gravatar.com/avatar/3edd222097c4b36118a8d5f5ab65ddb6?default=retro&size=200", - "settings": "{\"num\":79575,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/the-hypnotic-645693290/relentless?in=the-hypnotic-645693290/sets/the-hypnotic-vol-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//From VertexShaderArt Boilerplate Library: https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float angle = vertexId / 1000.0;\\n float radius = vertexId / 80000.0;\\n\\n float drums = texture2D(sound, vec2(0.55, 0.0)).a / 3.0 + 1.0;\\n\\n float aspect = resolution.y / resolution.x;\\n\\n gl_Position = uniformScale(drums) * vec4(cos(angle) * radius * aspect, sin(angle) * radius, 0.0, 1.0);\\n\\n float snd = texture2D(sound, vec2(0.55, vertexId / vertexCount)).a;\\n\\n float pump = 1.0 + step(0.1, snd);\\n\\n gl_PointSize = 1.0 + pump * mix(0.0, 10.0, snd);\\n\\n v_color = vec4(mix(0.2, 1.0, sin(time / 2.0) * 0.5 + 0.5), 0.7, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 79575, + "mode": "POINTS", + "sound": "https://soundcloud.com/the-hypnotic-645693290/relentless?in=the-hypnotic-645693290/sets/the-hypnotic-vol-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//From VertexShaderArt Boilerplate Library: https://www.vertexshaderart.com/art/qjkP6BDvEFyD6CfZC\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float angle = vertexId / 1000.0;\n float radius = vertexId / 80000.0;\n\n float drums = texture2D(sound, vec2(0.55, 0.0)).a / 3.0 + 1.0;\n\n float aspect = resolution.y / resolution.x;\n\n gl_Position = uniformScale(drums) * vec4(cos(angle) * radius * aspect, sin(angle) * radius, 0.0, 1.0);\n\n float snd = texture2D(sound, vec2(0.55, vertexId / vertexCount)).a;\n\n float pump = 1.0 + step(0.1, snd);\n\n gl_PointSize = 1.0 + pump * mix(0.0, 10.0, snd);\n\n v_color = vec4(mix(0.2, 1.0, sin(time / 2.0) * 0.5 + 0.5), 0.7, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-nee0gifh0v66fw051-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/j9rdg6agmx5hRCbSu/art.json b/art/j9rdg6agmx5hRCbSu/art.json index ee4a4474..ae835ac9 100644 --- a/art/j9rdg6agmx5hRCbSu/art.json +++ b/art/j9rdg6agmx5hRCbSu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "moon-jong", "avatarUrl": "https://avatars.githubusercontent.com/moon-jong?s=200", - "settings": "{\"num\":1606,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.047058823529411764,0.047058823529411764,1],\"shader\":\"void main() {\\n \\n \\tfloat down = floor(sqrt(vertexCount));\\n\\tfloat across = floor(vertexCount / down); \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\t\\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = cos(time + x * 0.3) * 0.2;\\n \\tfloat soff = sin(time + x) * 5.;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\tgl_Position = vec4(xy, 0, 1);\\n \\tgl_PointSize = 15.0 + soff;\\n\\tgl_PointSize *= 20.0 / across;\\n \\n \\t\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n\\tv_color = vec4(1, 0, 0, 1);\\n \\n\\n}\"}", + "settings": { + "num": 1606, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.047058823529411764, + 0.047058823529411764, + 1 + ], + "shader": "void main() {\n \n \tfloat down = floor(sqrt(vertexCount));\n\tfloat across = floor(vertexCount / down); \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \t\n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = cos(time + x * 0.3) * 0.2;\n \tfloat soff = sin(time + x) * 5.;\n \n \tfloat ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n\tgl_Position = vec4(xy, 0, 1);\n \tgl_PointSize = 15.0 + soff;\n\tgl_PointSize *= 20.0 / across;\n \n \t\n \tgl_PointSize *= resolution.x / 600.;\n \n\tv_color = vec4(1, 0, 0, 1);\n \n\n}" + }, "screenshotURL": "data/images/images-8101jvewpyk5zsjp9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jBYxLqMCJXqt6uG5C/art.json b/art/jBYxLqMCJXqt6uG5C/art.json index e06f98e2..65113227 100644 --- a/art/jBYxLqMCJXqt6uG5C/art.json +++ b/art/jBYxLqMCJXqt6uG5C/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "daff", "avatarUrl": "https://lh6.googleusercontent.com/-q6F2s0HNLkg/AAAAAAAAAAI/AAAAAAAAABQ/1TC-kZyFYM0/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/re_gain/alert\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x,clamp(c.yz, 0.0, 1.0));\\n vec4 k= vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p= abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y); \\n}\\n\\n\\n\\nvoid main() {\\n \\n #define PI radians(180.0)\\n //jkj\\n //\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2 (au * .05, av * .25)).a;//texture2D(sound, vec2 (su * .05, sv * .25)).a;//texture2D(sound, vec2 (u * 0.125, v)).a;//texture2D(sound, vec2 (u, v * 0.125)).a;//texture2D(sound, vec2 (u, v)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x *y * 0.02) * 5.;// sin(time * 1.2 + x *y * 0.02) * 5.;\\n \\n \\n gl_PointSize = pow(snd + 0.2, 5.)* 30.0 + soff;//snd * 30.0 + soff;//15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1;//u * .1 + sin(time + v * 20.) * 0.05;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05; //u;\\n float sat = mix(0., 1., pump);//mix(1., -10., av);//1.;\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//pow(snd + 0.2, 5.);//sound;//sin(time + v * u * 20.0) * .5 + .5;//sin(time * 1.4 + v * u * 20.0) * .5 + .5;//v;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat , val)), 1);//vec4(1,u,v,1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/re_gain/alert", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x,clamp(c.yz, 0.0, 1.0));\n vec4 k= vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p= abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y); \n}\n\n\n\nvoid main() {\n \n #define PI radians(180.0)\n //jkj\n //\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2 (au * .05, av * .25)).a;//texture2D(sound, vec2 (su * .05, sv * .25)).a;//texture2D(sound, vec2 (u * 0.125, v)).a;//texture2D(sound, vec2 (u, v * 0.125)).a;//texture2D(sound, vec2 (u, v)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x *y * 0.02) * 5.;// sin(time * 1.2 + x *y * 0.02) * 5.;\n \n \n gl_PointSize = pow(snd + 0.2, 5.)* 30.0 + soff;//snd * 30.0 + soff;//15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1;//u * .1 + sin(time + v * 20.) * 0.05;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05; //u;\n float sat = mix(0., 1., pump);//mix(1., -10., av);//1.;\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//pow(snd + 0.2, 5.);//sound;//sin(time + v * u * 20.0) * .5 + .5;//sin(time * 1.4 + v * u * 20.0) * .5 + .5;//v;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat , val)), 1);//vec4(1,u,v,1);\n}" + }, "screenshotURL": "data/images/images-5pe2at72sedul9uc2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jBpixD335L3o2unKj/art.json b/art/jBpixD335L3o2unKj/art.json index fdaa1ede..b907c5d0 100644 --- a/art/jBpixD335L3o2unKj/art.json +++ b/art/jBpixD335L3o2unKj/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "bostelk", "avatarUrl": "https://secure.gravatar.com/avatar/6a78fa85daeb414dfc2d3f77225779a1?default=retro&size=200", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n id = mod(id, 16.0);\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\nvec4 hypercube_lines(float id)\\n{\\n id = mod(vertexId, 64.0);\\n // outer cuber\\n if (id == 00.) return hypercube(0.);\\n if (id == 01.) return hypercube(3.);\\n if (id == 02.) return hypercube(3.);\\n if (id == 03.) return hypercube(8.);\\n if (id == 04.) return hypercube(8.);\\n if (id == 05.) return hypercube(2.);\\n if (id == 06.) return hypercube(2.);\\n if (id == 07.) return hypercube(0.);\\n if (id == 08.) return hypercube(0.);\\n if (id == 09.) return hypercube(4.);\\n if (id == 10.) return hypercube(4.);\\n if (id == 11.) return hypercube(10.);\\n if (id == 12.) return hypercube(10.);\\n if (id == 13.) return hypercube(3.);\\n if (id == 14.) return hypercube(8.);\\n if (id == 15.) return hypercube(13.);\\n if (id == 16.) return hypercube(2.);\\n if (id == 17.) return hypercube(9.);\\n if (id == 18.) return hypercube(4.);\\n if (id == 19.) return hypercube(9.);\\n if (id == 20.) return hypercube(10.);\\n if (id == 21.) return hypercube(13.);\\n if (id == 22.) return hypercube(13.);\\n if (id == 23.) return hypercube(9.);\\n // inner cube\\n if (id == 24.) return hypercube(1.);\\n if (id == 25.) return hypercube(6.);\\n if (id == 26.) return hypercube(6.);\\n if (id == 27.) return hypercube(11.);\\n if (id == 28.) return hypercube(11.);\\n if (id == 29.) return hypercube(5.);\\n if (id == 30.) return hypercube(5.);\\n if (id == 31.) return hypercube(1.);\\n if (id == 32.) return hypercube(7.);\\n if (id == 33.) return hypercube(14.);\\n if (id == 34.) return hypercube(14.);\\n if (id == 35.) return hypercube(15.);\\n if (id == 36.) return hypercube(15.);\\n if (id == 37.) return hypercube(12.);\\n if (id == 38.) return hypercube(12.);\\n if (id == 39.) return hypercube(7.);\\n if (id == 40.) return hypercube(1.);\\n if (id == 41.) return hypercube(7.);\\n if (id == 42.) return hypercube(6.);\\n if (id == 43.) return hypercube(14.);\\n if (id == 44.) return hypercube(11.);\\n if (id == 45.) return hypercube(15.);\\n if (id == 46.) return hypercube(5.);\\n if (id == 47.) return hypercube(12.);\\n // w\\n if (id == 48.) return hypercube(2.);\\n if (id == 49.) return hypercube(5.);\\n if (id == 50.) return hypercube(8.);\\n if (id == 51.) return hypercube(11.);\\n if (id == 52.) return hypercube(13.);\\n if (id == 53.) return hypercube(15.);\\n if (id == 54.) return hypercube(9.);\\n if (id == 55.) return hypercube(12.);\\n if (id == 56.) return hypercube(0.);\\n if (id == 57.) return hypercube(1.);\\n if (id == 58.) return hypercube(3.);\\n if (id == 59.) return hypercube(6.);\\n if (id == 60.) return hypercube(10.);\\n if (id == 61.) return hypercube(14.);\\n if (id == 62.) return hypercube(4.);\\n if (id == 63.) return hypercube(7.);\\n return vec4(0);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 0, 0, 0);\\n vec4 up4 = vec4(0, 1, 0, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(3.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n float theta3 = 45.0 * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.1 * TAU);\\n vec4 v4 = hypercube_lines(vertexId);\\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect, 0, 1);\\n v_color = vec4(1,1,1, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n id = mod(id, 16.0);\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\nvec4 hypercube_lines(float id)\n{\n id = mod(vertexId, 64.0);\n // outer cuber\n if (id == 00.) return hypercube(0.);\n if (id == 01.) return hypercube(3.);\n if (id == 02.) return hypercube(3.);\n if (id == 03.) return hypercube(8.);\n if (id == 04.) return hypercube(8.);\n if (id == 05.) return hypercube(2.);\n if (id == 06.) return hypercube(2.);\n if (id == 07.) return hypercube(0.);\n if (id == 08.) return hypercube(0.);\n if (id == 09.) return hypercube(4.);\n if (id == 10.) return hypercube(4.);\n if (id == 11.) return hypercube(10.);\n if (id == 12.) return hypercube(10.);\n if (id == 13.) return hypercube(3.);\n if (id == 14.) return hypercube(8.);\n if (id == 15.) return hypercube(13.);\n if (id == 16.) return hypercube(2.);\n if (id == 17.) return hypercube(9.);\n if (id == 18.) return hypercube(4.);\n if (id == 19.) return hypercube(9.);\n if (id == 20.) return hypercube(10.);\n if (id == 21.) return hypercube(13.);\n if (id == 22.) return hypercube(13.);\n if (id == 23.) return hypercube(9.);\n // inner cube\n if (id == 24.) return hypercube(1.);\n if (id == 25.) return hypercube(6.);\n if (id == 26.) return hypercube(6.);\n if (id == 27.) return hypercube(11.);\n if (id == 28.) return hypercube(11.);\n if (id == 29.) return hypercube(5.);\n if (id == 30.) return hypercube(5.);\n if (id == 31.) return hypercube(1.);\n if (id == 32.) return hypercube(7.);\n if (id == 33.) return hypercube(14.);\n if (id == 34.) return hypercube(14.);\n if (id == 35.) return hypercube(15.);\n if (id == 36.) return hypercube(15.);\n if (id == 37.) return hypercube(12.);\n if (id == 38.) return hypercube(12.);\n if (id == 39.) return hypercube(7.);\n if (id == 40.) return hypercube(1.);\n if (id == 41.) return hypercube(7.);\n if (id == 42.) return hypercube(6.);\n if (id == 43.) return hypercube(14.);\n if (id == 44.) return hypercube(11.);\n if (id == 45.) return hypercube(15.);\n if (id == 46.) return hypercube(5.);\n if (id == 47.) return hypercube(12.);\n // w\n if (id == 48.) return hypercube(2.);\n if (id == 49.) return hypercube(5.);\n if (id == 50.) return hypercube(8.);\n if (id == 51.) return hypercube(11.);\n if (id == 52.) return hypercube(13.);\n if (id == 53.) return hypercube(15.);\n if (id == 54.) return hypercube(9.);\n if (id == 55.) return hypercube(12.);\n if (id == 56.) return hypercube(0.);\n if (id == 57.) return hypercube(1.);\n if (id == 58.) return hypercube(3.);\n if (id == 59.) return hypercube(6.);\n if (id == 60.) return hypercube(10.);\n if (id == 61.) return hypercube(14.);\n if (id == 62.) return hypercube(4.);\n if (id == 63.) return hypercube(7.);\n return vec4(0);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 0, 0, 0);\n vec4 up4 = vec4(0, 1, 0, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(3.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n float theta3 = 45.0 * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.1 * TAU);\n vec4 v4 = hypercube_lines(vertexId);\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect, 0, 1);\n v_color = vec4(1,1,1, 1);\n}" + }, "screenshotURL": "data/images/images-40be2dp9b8a01cusc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jC6yjCA9eDW8oasNA/art.json b/art/jC6yjCA9eDW8oasNA/art.json index 11799e36..bfc00219 100644 --- a/art/jC6yjCA9eDW8oasNA/art.json +++ b/art/jC6yjCA9eDW8oasNA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.5;\\n float rightBottom = 0.0125;\\n \\n \\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n }\\n \\n \\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 1, 1, 1);\\n }\\n else {\\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.5;\n float rightBottom = 0.0125;\n \n \n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n }\n \n \n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 1, 1, 1);\n }\n else {\n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-4qyiacp8a0c2r682k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jDNMJCu4S7DSRconL/art.json b/art/jDNMJCu4S7DSRconL/art.json index 38a23ed8..41ff9656 100644 --- a/art/jDNMJCu4S7DSRconL/art.json +++ b/art/jDNMJCu4S7DSRconL/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":6006,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sacredbones/john-carpenter-night\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n \\n \\n _ ._ _|_ _ _ |_ _. _| _ ._ _. ._ _|_ \\n \\\\/ (/_ | |_ (/_ >< _> | | (_| (_| (/_ | (_| | |_ \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians( 180. )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotX( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nvoid getShapePoint(const float numPointsPerFace, const float id, const mat4 wvp, out vec4 pos) {\\n float numPointsPerShape = pow(numPointsPerFace, 3.);\\n float numPointsPerWhat = numPointsPerFace * numPointsPerFace;\\n float aId = mod(id, numPointsPerFace);\\n float a = aId / numPointsPerFace;\\n float bId = mod(floor(id / numPointsPerFace), numPointsPerFace);\\n float b = bId / numPointsPerFace;\\n float cId = floor(id / numPointsPerWhat);\\n float c = cId / numPointsPerFace;\\n float a0 = a * PI * 2.;\\n float b0 = b * PI * 2.;\\n float c0 = c * PI * 2.;\\n \\n mat4 m = wvp;\\n m *= rotZ(c0);\\n m *= rotY(b0);\\n m *= rotY(a0);\\n pos = m * vec4(1,1,1,1);\\n}\\n\\n\\nvoid main() { \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.03456;\\n \\tfloat elevation = sin(animTime * 0.223);\\n \\tfloat fOrbitDistance = 30.;\\n \\n vec3 target = vec3(0, 0, 0);\\n vec3 eye = vec3(0, 0, 10);\\n \\t eye = vec3( sin(orbitAngle) * fOrbitDistance , sin(elevation * 1.11) * 10. , cos(orbitAngle)* fOrbitDistance ) ;\\n vec3 up = vec3(0,1,0);\\n \\n float numPointsPerFace = 4.;\\n float numPointsPerShape = pow(numPointsPerFace, 3.);\\n float shapeId = floor(vertexId / numPointsPerShape); \\n float shapeCount = floor(vertexCount / numPointsPerShape);\\n float shapeV = shapeId / shapeCount;\\n float invShapeV = 1. - shapeV;\\n \\n float size = floor(pow(shapeCount, 1./3.));\\n vec3 p = vec3(\\n mod(shapeId, size),\\n mod(floor(shapeId / size), size),\\n floor(floor(shapeId / size) / size));\\n vec3 pv = p / size;\\n pv = vec3(0,0,0);\\n \\n float snd = 0.;\\n \\n vec4 pos;\\n mat4 m = ident();\\n m *= persp(45., resolution.x / resolution.y, 0.1, 60.);\\n m *= cameraLookAt(eye, target, up);\\n m *= rotY(sin(time * 0.051 + shapeId * sin(time * 0.13) * 0.07));\\n m *= rotZ(sin(time * 0.073 + shapeId * sin(time * 0.21) * 0.06));\\n m *= uniformScale(10. * invShapeV);\\n getShapePoint(numPointsPerFace, vertexId, m, pos);\\n\\n gl_Position = pos;\\n gl_PointSize = 4.;\\n float z = p1m1(pos.z / pos.w);\\n \\n \\t// Final output color\\n float hue = time * 0.01 + shapeV * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invShapeV + 0.1);\\n \\tv_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 6006, + "mode": "LINES", + "sound": "https://soundcloud.com/sacredbones/john-carpenter-night", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n \n \n _ ._ _|_ _ _ |_ _. _| _ ._ _. ._ _|_ \n \\/ (/_ | |_ (/_ >< _> | | (_| (_| (/_ | (_| | |_ \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians( 180. )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotX( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nvoid getShapePoint(const float numPointsPerFace, const float id, const mat4 wvp, out vec4 pos) {\n float numPointsPerShape = pow(numPointsPerFace, 3.);\n float numPointsPerWhat = numPointsPerFace * numPointsPerFace;\n float aId = mod(id, numPointsPerFace);\n float a = aId / numPointsPerFace;\n float bId = mod(floor(id / numPointsPerFace), numPointsPerFace);\n float b = bId / numPointsPerFace;\n float cId = floor(id / numPointsPerWhat);\n float c = cId / numPointsPerFace;\n float a0 = a * PI * 2.;\n float b0 = b * PI * 2.;\n float c0 = c * PI * 2.;\n \n mat4 m = wvp;\n m *= rotZ(c0);\n m *= rotY(b0);\n m *= rotY(a0);\n pos = m * vec4(1,1,1,1);\n}\n\n\nvoid main() { \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.03456;\n \tfloat elevation = sin(animTime * 0.223);\n \tfloat fOrbitDistance = 30.;\n \n vec3 target = vec3(0, 0, 0);\n vec3 eye = vec3(0, 0, 10);\n \t eye = vec3( sin(orbitAngle) * fOrbitDistance , sin(elevation * 1.11) * 10. , cos(orbitAngle)* fOrbitDistance ) ;\n vec3 up = vec3(0,1,0);\n \n float numPointsPerFace = 4.;\n float numPointsPerShape = pow(numPointsPerFace, 3.);\n float shapeId = floor(vertexId / numPointsPerShape); \n float shapeCount = floor(vertexCount / numPointsPerShape);\n float shapeV = shapeId / shapeCount;\n float invShapeV = 1. - shapeV;\n \n float size = floor(pow(shapeCount, 1./3.));\n vec3 p = vec3(\n mod(shapeId, size),\n mod(floor(shapeId / size), size),\n floor(floor(shapeId / size) / size));\n vec3 pv = p / size;\n pv = vec3(0,0,0);\n \n float snd = 0.;\n \n vec4 pos;\n mat4 m = ident();\n m *= persp(45., resolution.x / resolution.y, 0.1, 60.);\n m *= cameraLookAt(eye, target, up);\n m *= rotY(sin(time * 0.051 + shapeId * sin(time * 0.13) * 0.07));\n m *= rotZ(sin(time * 0.073 + shapeId * sin(time * 0.21) * 0.06));\n m *= uniformScale(10. * invShapeV);\n getShapePoint(numPointsPerFace, vertexId, m, pos);\n\n gl_Position = pos;\n gl_PointSize = 4.;\n float z = p1m1(pos.z / pos.w);\n \n \t// Final output color\n float hue = time * 0.01 + shapeV * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invShapeV + 0.1);\n \tv_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-xza33tgw9dpfbgoe2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jDZno8kPiDKAcaZgJ/art.json b/art/jDZno8kPiDKAcaZgJ/art.json index bfeec67d..499dd6fb 100644 --- a/art/jDZno8kPiDKAcaZgJ/art.json +++ b/art/jDZno8kPiDKAcaZgJ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jimhanks", "avatarUrl": "https://secure.gravatar.com/avatar/2bf167068c2de88c2a8119b5403a900b?default=retro&size=200", - "settings": "{\"num\":43618,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = (fract(pos+.5)-.5);\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*0.05;\\n float i = vertexId*.13;\\n\\n vec3 pos = posf(t,i);\\t\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += 1.7;\\n \\n pos.xy *= (3.-pos.z)*.7;\\n pos.x *= 3.;\\n pos.y *= 0.5;\\n pos.y += 0.6;\\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.01;\\n}\"}", + "settings": { + "num": 43618, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = (fract(pos+.5)-.5);\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*0.05;\n float i = vertexId*.13;\n\n vec3 pos = posf(t,i);\t\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += 1.7;\n \n pos.xy *= (3.-pos.z)*.7;\n pos.x *= 3.;\n pos.y *= 0.5;\n pos.y += 0.6;\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.01;\n}" + }, "screenshotURL": "data/images/images-0bs60z2zuv5qnt7r8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jDrqfnTPaPAoShgv2/art.json b/art/jDrqfnTPaPAoShgv2/art.json index 42da34c5..d829ff99 100644 --- a/art/jDrqfnTPaPAoShgv2/art.json +++ b/art/jDrqfnTPaPAoShgv2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "guilleperez", "avatarUrl": "https://avatars.githubusercontent.com/guilleperez?s=200", - "settings": "{\"num\":15,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() \\n{\\n float width = 10.0;\\n \\n //vertexId = 0, 1, 2, 3, 4, 5\\n float x = floor(vertexId / 2.0); //0, 0, 1, 1, 2, 2\\n float y = mod(vertexId + 1.0, 2.0); //1, 0, 1, 0\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0); //position del vec4\\n v_color = vec4(1.0, 0.0, 0.0, 1.0); //color\\n gl_PointSize = 20.0;\\n}\"}", + "settings": { + "num": 15, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() \n{\n float width = 10.0;\n \n //vertexId = 0, 1, 2, 3, 4, 5\n float x = floor(vertexId / 2.0); //0, 0, 1, 1, 2, 2\n float y = mod(vertexId + 1.0, 2.0); //1, 0, 1, 0\n \n vec2 xy = vec2(x, y) * 0.1;\n \n \n gl_Position = vec4(xy, 0.0, 1.0); //position del vec4\n v_color = vec4(1.0, 0.0, 0.0, 1.0); //color\n gl_PointSize = 20.0;\n}" + }, "screenshotURL": "data/images/images-ump78u3vechp01hkv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jETzmmycobJrRvXH9/art.json b/art/jETzmmycobJrRvXH9/art.json index fa27092d..398230fc 100644 --- a/art/jETzmmycobJrRvXH9/art.json +++ b/art/jETzmmycobJrRvXH9/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "mrshoor", "avatarUrl": "https://lh5.googleusercontent.com/-LXMYHmf3REM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3re1I0lelewVaOzZYQnhGBlwPNSlaA/photo.jpg", - "settings": "{\"num\":3281,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n vec4 vertPos = rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 3281, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n vec4 vertPos = rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-21oa7dgp61i7nxthk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jEoQzSA24YCzYycNu/art.json b/art/jEoQzSA24YCzYycNu/art.json index 09422a23..a1a02686 100644 --- a/art/jEoQzSA24YCzYycNu/art.json +++ b/art/jEoQzSA24YCzYycNu/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jpaquim", "avatarUrl": "https://secure.gravatar.com/avatar/374b09dacab582ca17818a391b59a214?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n // float across = 10.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * .2) * .1;\\n float yoff = sin(time + x * .3) * .2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n // float across = 10.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * .2) * .1;\n float yoff = sin(time + x * .3) * .2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-c9d1y9gdbnuenf6ra-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jH6uYuSxKSryZXLT8/art.json b/art/jH6uYuSxKSryZXLT8/art.json index ab0934e4..50b149b4 100644 --- a/art/jH6uYuSxKSryZXLT8/art.json +++ b/art/jH6uYuSxKSryZXLT8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "villain", "avatarUrl": "https://secure.gravatar.com/avatar/e5fb89319d83bfa0886440775a1acf6b?default=retro&size=200", - "settings": "{\"num\":667,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/coloresantos/juno\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.043137254901960784,0.03137254901960784,0.0196078431372549,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 1.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 2.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 87.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 4.02;\\n float angle = point * PI * 6.0 / NUM_SEGMENTS + offset;\\n float radius = 3.5;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 7.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 3);\\n\\n float hue = (time * 8.4 + count * 3.);\\n v_color = vec4(hsv2rgb(vec3(hue, 6, 4)), 3);\\n}\"}", + "settings": { + "num": 667, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/coloresantos/juno", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.043137254901960784, + 0.03137254901960784, + 0.0196078431372549, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 1.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 2.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 87.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 4.02;\n float angle = point * PI * 6.0 / NUM_SEGMENTS + offset;\n float radius = 3.5;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 7.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 3);\n\n float hue = (time * 8.4 + count * 3.);\n v_color = vec4(hsv2rgb(vec3(hue, 6, 4)), 3);\n}" + }, "screenshotURL": "data/images/images-ac901fl4pktj7o677-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jKgXdk6mRHxFesr5L/art.json b/art/jKgXdk6mRHxFesr5L/art.json index 2ec671e8..7ea86484 100644 --- a/art/jKgXdk6mRHxFesr5L/art.json +++ b/art/jKgXdk6mRHxFesr5L/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":24542,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /7. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 1, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0.5);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x / p2.y * 165.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 22.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 22.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.17) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.9)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.1 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = .3 + snd * .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*.62, v_color.a +2.0);\\n}\"}", + "settings": { + "num": 24542, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /7. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 1, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0.5);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\n\treturn fract(p2.x / p2.y * 165.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 22.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 22.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.17) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.9)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.1 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = .3 + snd * .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*.62, v_color.a +2.0);\n}" + }, "screenshotURL": "data/images/images-ld8jcaam55jqgqqkm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jLife2TGRq2pa6fXN/art.json b/art/jLife2TGRq2pa6fXN/art.json index 59d9603d..c5247962 100644 --- a/art/jLife2TGRq2pa6fXN/art.json +++ b/art/jLife2TGRq2pa6fXN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float phi = vertexId / vertexCount * 3.14159265*2.0;\\n \\n float x = cos(phi);\\n float y = sin(phi);\\n float z = 0.0;\\n \\n float theta = 5.0 * sin(sign(y)*cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\\n \\n y *= cos(theta);\\n z = sin(theta);\\n \\n vec4 pos = vec4(x, y, z, 1.0);\\n \\n vec3 eye = vec3(sin(time), 0, cos(time));\\n vec3 right = vec3(-eye.z, 0, eye.x);\\n vec3 look = -eye;\\n\\n mat4 L = mat4(vec4(right, 0),\\n vec4(0, 1, 0, 0),\\n vec4(look, 0),\\n vec4(0, 0, 0, 1));\\n \\n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\\n v_color = vec4(sin(theta) * 0.5 + 0.5,\\n cos(phi) * 0.5 + 0.5,\\n sin(time) * 0.5 + 0.5,\\n 1.0);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float phi = vertexId / vertexCount * 3.14159265*2.0;\n \n float x = cos(phi);\n float y = sin(phi);\n float z = 0.0;\n \n float theta = 5.0 * sin(sign(y)*cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\n \n y *= cos(theta);\n z = sin(theta);\n \n vec4 pos = vec4(x, y, z, 1.0);\n \n vec3 eye = vec3(sin(time), 0, cos(time));\n vec3 right = vec3(-eye.z, 0, eye.x);\n vec3 look = -eye;\n\n mat4 L = mat4(vec4(right, 0),\n vec4(0, 1, 0, 0),\n vec4(look, 0),\n vec4(0, 0, 0, 1));\n \n gl_Position = (L * pos) * vec4((resolution.y / resolution.x) * 0.5, 0.5, 0.5, 1);\n v_color = vec4(sin(theta) * 0.5 + 0.5,\n cos(phi) * 0.5 + 0.5,\n sin(time) * 0.5 + 0.5,\n 1.0);\n}" + }, "screenshotURL": "data/images/images-whz235ixlna47yedl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jLsTszfmYpHj49XKx/art.json b/art/jLsTszfmYpHj49XKx/art.json index 39aeba94..ac924f93 100644 --- a/art/jLsTszfmYpHj49XKx/art.json +++ b/art/jLsTszfmYpHj49XKx/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7082,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][3], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 0\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n mat4 mat = rotY(time);\\n vec3 point = vec3(0.0);\\n vec3 normal = vec3(0.0);\\n getCubePoint(vertexId, point, normal);\\n mat4 camera = mat4(\\n 0.5, 0.0, 0.0, 0.0,\\n 0.0, 1.0, 0.0, 0.0,\\n 0.0, 0.0, 1.0, 0.1,\\n 0.0, 0.0, 0.2, 1.0\\n );\\n gl_Position = camera * mat * vec4(point, 1);\\n //gl_Position /= gl_Position.w;\\n vec3 correctedNormal = (mat*vec4(normal, 1.0)).xyz;\\n float brightness = dot(correctedNormal, normalize(vec3(-1,-1,-1)));\\n v_color = vec4(1.0*brightness, 0.0, 0.0, 1.0);\\n}\\n\\n#endif\"}", + "settings": { + "num": 7082, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][3], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 0\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n mat4 mat = rotY(time);\n vec3 point = vec3(0.0);\n vec3 normal = vec3(0.0);\n getCubePoint(vertexId, point, normal);\n mat4 camera = mat4(\n 0.5, 0.0, 0.0, 0.0,\n 0.0, 1.0, 0.0, 0.0,\n 0.0, 0.0, 1.0, 0.1,\n 0.0, 0.0, 0.2, 1.0\n );\n gl_Position = camera * mat * vec4(point, 1);\n //gl_Position /= gl_Position.w;\n vec3 correctedNormal = (mat*vec4(normal, 1.0)).xyz;\n float brightness = dot(correctedNormal, normalize(vec3(-1,-1,-1)));\n v_color = vec4(1.0*brightness, 0.0, 0.0, 1.0);\n}\n\n#endif" + }, "screenshotURL": "data/images/images-82rnsdqwdfrktzgcp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jMGgLqSnkaQD9ZYns/art.json b/art/jMGgLqSnkaQD9ZYns/art.json index 6e47d306..7e836e3e 100644 --- a/art/jMGgLqSnkaQD9ZYns/art.json +++ b/art/jMGgLqSnkaQD9ZYns/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-3p4bxkwkk1tjxozv7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jSqNQQKbSrqoB8rrP/art.json b/art/jSqNQQKbSrqoB8rrP/art.json index 1aebf289..293d101c 100644 --- a/art/jSqNQQKbSrqoB8rrP/art.json +++ b/art/jSqNQQKbSrqoB8rrP/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"//KDrawmode=GL_TRIANGLES \\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\n#define kp1 3.//KParameter 0.>>10.\\n#define kp2 0.//KParameter 0.>>1.\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),16,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),(a*0.6),0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(-1,2,1,1.-z,0,1,0,x,x*8.,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5. * kp2 * kp1;\\n \\n \\tgl_PointSize = 3.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.0 +(kp1*0.2);\\n \\tvec2 height = vec2(10.,0.);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 3.);\\n\\tfloat indexCircle = floor(indexQuad / polySize)+26.0;\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES \n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\n#define kp1 3.//KParameter 0.>>10.\n#define kp2 0.//KParameter 0.>>1.\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),16,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),(a*0.6),0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(-1,2,1,1.-z,0,1,0,x,x*8.,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5. * kp2 * kp1;\n \n \tgl_PointSize = 3.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.0 +(kp1*0.2);\n \tvec2 height = vec2(10.,0.);\n \t\n\tfloat indexQuad = floor(vertexId / 3.);\n\tfloat indexCircle = floor(indexQuad / polySize)+26.0;\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-thhuqgincpar2u9dd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jXYNwHmBj5miEkeS6/art.json b/art/jXYNwHmBj5miEkeS6/art.json index ef052064..779f6f4d 100644 --- a/art/jXYNwHmBj5miEkeS6/art.json +++ b/art/jXYNwHmBj5miEkeS6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":25798,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12941176470588237,0.6705882352941176,0.9215686274509803,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 5.5\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = (offset * + 0.25) / soundRes.x;\\n // Match each line to a specific row in the sound texture\\n float historyV = (offset * + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n\\n vec2 aspect = vec2(1, historyX * snd / historyV * snd);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 25798, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12941176470588237, + 0.6705882352941176, + 0.9215686274509803, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 5.5\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = (offset * + 0.25) / soundRes.x;\n // Match each line to a specific row in the sound texture\n float historyV = (offset * + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n\n vec2 aspect = vec2(1, historyX * snd / historyV * snd);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-873y09mja4nztx8bd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jY9RXPEf9rZ5Gv89N/art.json b/art/jY9RXPEf9rZ5Gv89N/art.json index 933a5497..dc2629fa 100644 --- a/art/jY9RXPEf9rZ5Gv89N/art.json +++ b/art/jY9RXPEf9rZ5Gv89N/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-r4v5hs9o06rez0rnl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jYsMzcSq8HDB28JWY/art.json b/art/jYsMzcSq8HDB28JWY/art.json index a0509c9e..a813a79b 100644 --- a/art/jYsMzcSq8HDB28JWY/art.json +++ b/art/jYsMzcSq8HDB28JWY/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "molotovbliss", "avatarUrl": "https://avatars.githubusercontent.com/molotovbliss?s=200", - "settings": "{\"num\":85828,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/2methylbulbe1ol/2methylbulbe1ol-infected?in=2methylbulbe1ol/sets/ruff12-2methylbulbe1ol-dead&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.26666666666666666,0.3176470588235294,0.4823529411764706,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(0.6-mouse.y, 1.2-mouse.x, 0.) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.1, \\t0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 0.70, 0.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 1.0-mouse.x, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -1.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.8 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.7, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, -1, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 42.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.5 + quant(over, 3.) * 0.7;\\n float sat = step(0.75,s2);\\n float val = 1.;\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -0.);\\n float ca = 0.0001;\\n \\n // get sick!\\n ca = ca * .10* time + sin(time) * 0.1;\\n \\tvec3 vCameraUp = vec3( sin(ca), tan(ca),2. );\\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 85828, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/2methylbulbe1ol/2methylbulbe1ol-infected?in=2methylbulbe1ol/sets/ruff12-2methylbulbe1ol-dead&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.26666666666666666, + 0.3176470588235294, + 0.4823529411764706, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(0.6-mouse.y, 1.2-mouse.x, 0.) * 10.0; \n\nvec3 gSkyTop = vec3( 1.1, \t0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 0.70, 0.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 1.0-mouse.x, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -1.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.8 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.7, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, -1, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 42.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.5 + quant(over, 3.) * 0.7;\n float sat = step(0.75,s2);\n float val = 1.;\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -0.);\n float ca = 0.0001;\n \n // get sick!\n ca = ca * .10* time + sin(time) * 0.1;\n \tvec3 vCameraUp = vec3( sin(ca), tan(ca),2. );\n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-0swbc9i5aimjoupj3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jZbLsPiJ43jvcaq7M/art.json b/art/jZbLsPiJ43jvcaq7M/art.json index 2d654d53..723a2e90 100644 --- a/art/jZbLsPiJ43jvcaq7M/art.json +++ b/art/jZbLsPiJ43jvcaq7M/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5096,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 1.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\\n\"}", + "settings": { + "num": 5096, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 1.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}\n" + }, "screenshotURL": "data/images/images-yadqdx09qv7wvvg2a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jaG2f5XtrcpcNSePf/art.json b/art/jaG2f5XtrcpcNSePf/art.json index 71f01170..a8474a6c 100644 --- a/art/jaG2f5XtrcpcNSePf/art.json +++ b/art/jaG2f5XtrcpcNSePf/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount)); // gets the count of rows\\n float across = floor(vertexCount / down); // gets the count of columns\\n \\n // vertexId is the \\n float x = mod(vertexId, across); // always use floats\\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0; // gets value from -1 to 1\\n float uy = v * 2.0 - 1.0; // gets value from -1 to 1\\n \\n gl_Position = vec4(ux, uy, 0.0, 1.0);\\n \\n gl_PointSize = 200.0 / across; // set point size\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0, 0, 1); // this is unique to vertex shader art\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount)); // gets the count of rows\n float across = floor(vertexCount / down); // gets the count of columns\n \n // vertexId is the \n float x = mod(vertexId, across); // always use floats\n float y = floor(vertexId / across); // rounds numbers down 0.1 = 0, 10 = 1\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0; // gets value from -1 to 1\n float uy = v * 2.0 - 1.0; // gets value from -1 to 1\n \n gl_Position = vec4(ux, uy, 0.0, 1.0);\n \n gl_PointSize = 200.0 / across; // set point size\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0, 0, 1); // this is unique to vertex shader art\n}" + }, "screenshotURL": "data/images/images-279912njg6kxm0ey7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jabgpFXjj8umhyfzH/art.json b/art/jabgpFXjj8umhyfzH/art.json index 302d5e5d..0c497e9f 100644 --- a/art/jabgpFXjj8umhyfzH/art.json +++ b/art/jabgpFXjj8umhyfzH/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main() {\\n float n = vertexId / vertexCount;\\n float randX = rand(vec2(n, 10.0));\\n float randY = rand(vec2(10.0, n));\\n\\n float x = randX * 10.0;\\n float y = randY * 10.0;\\n float vy = mod((n * n) * time * 0.1, 2.0) + n * 5.0;\\n \\n gl_Position = vec4(x - 5.0, y - vy, 0, n);\\n gl_PointSize = n * 2.0;\\n v_color = vec4(n, n, abs(cos(time * n)), n);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main() {\n float n = vertexId / vertexCount;\n float randX = rand(vec2(n, 10.0));\n float randY = rand(vec2(10.0, n));\n\n float x = randX * 10.0;\n float y = randY * 10.0;\n float vy = mod((n * n) * time * 0.1, 2.0) + n * 5.0;\n \n gl_Position = vec4(x - 5.0, y - vy, 0, n);\n gl_PointSize = n * 2.0;\n v_color = vec4(n, n, abs(cos(time * n)), n);\n}" + }, "screenshotURL": "data/images/images-oczwqt9u1p2hz6w3v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/japgmuqb6SYNuHBb4/art.json b/art/japgmuqb6SYNuHBb4/art.json index ca0b9ca5..5e09ac7e 100644 --- a/art/japgmuqb6SYNuHBb4/art.json +++ b/art/japgmuqb6SYNuHBb4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":21017,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.30980392156862746,0.30980392156862746,0,1],\"shader\":\"varying vec2 surfacePosition;\\nvoid main(){\\n\\tvec2 pos = surfacePosition;\\n\\n\\tconst float pi = 3.14159;\\n\\tconst float n = 12.0;\\n\\t\\n\\tfloat radius = length(pos)*6. - 1.;\\n\\tfloat t = atan(pos.y, pos.x)/pi;\\n\\t\\n\\tfloat color = 0.0;\\n\\tfor (float i = 1.; i < n; i++){\\n\\t\\tcolor += 0.01/abs(color+i*0.15*sin(18.0*pi*(t + i/n*time*0.05)) - radius);\\n\\t}\\n\\t\\n\\tv_color = vec4(vec3(1., 1., 1.0) * color, color);\\n\\t\\n}\"}", + "settings": { + "num": 21017, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.30980392156862746, + 0.30980392156862746, + 0, + 1 + ], + "shader": "varying vec2 surfacePosition;\nvoid main(){\n\tvec2 pos = surfacePosition;\n\n\tconst float pi = 3.14159;\n\tconst float n = 12.0;\n\t\n\tfloat radius = length(pos)*6. - 1.;\n\tfloat t = atan(pos.y, pos.x)/pi;\n\t\n\tfloat color = 0.0;\n\tfor (float i = 1.; i < n; i++){\n\t\tcolor += 0.01/abs(color+i*0.15*sin(18.0*pi*(t + i/n*time*0.05)) - radius);\n\t}\n\t\n\tv_color = vec4(vec3(1., 1., 1.0) * color, color);\n\t\n}" + }, "screenshotURL": "data/images/images-m4kdlq8jon5l9hby8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jcatqfjkzF3ET7965/art.json b/art/jcatqfjkzF3ET7965/art.json index c316e694..8e14af07 100644 --- a/art/jcatqfjkzF3ET7965/art.json +++ b/art/jcatqfjkzF3ET7965/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "julien", "avatarUrl": "https://avatars.githubusercontent.com/julien?s=200", - "settings": "{\"num\":1183,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/photek/quadranttt\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.0196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\nvec3 hsv2rgb(vec3 c) {\\n\\t\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n \\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.1) * 0.25;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.0; // x,y pos and scale;\\n\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n \\n float soff = sin(time + x * y * 0.02) * 8.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 20.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n float pump = step(0.2, snd);\\n \\n float hue = u + 0.1 + snd * 0.2 + time * 0.1; // u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float saturation = mix(0.0, 1.0, pump);\\n float value = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1.0);\\n}\"}", + "settings": { + "num": 1183, + "mode": "POINTS", + "sound": "https://soundcloud.com/photek/quadranttt", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.0196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\nvec3 hsv2rgb(vec3 c) {\n\t\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n \n}\n\n#define PI radians(180.0)\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.1) * 0.25;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.0; // x,y pos and scale;\n\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n \n float soff = sin(time + x * y * 0.02) * 8.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 20.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n float pump = step(0.2, snd);\n \n float hue = u + 0.1 + snd * 0.2 + time * 0.1; // u * 0.1 + sin(time + v * 20.0) * 0.05;\n float saturation = mix(0.0, 1.0, pump);\n float value = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-hkjoeadwptk7cz4cc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jdAf5zLP6coQorz8g/art.json b/art/jdAf5zLP6coQorz8g/art.json index c712647c..3c68ab29 100644 --- a/art/jdAf5zLP6coQorz8g/art.json +++ b/art/jdAf5zLP6coQorz8g/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*11.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*11.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-oc05m0uhuh2x69n9o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jg5dRsCi6xDSFyCJ9/art.json b/art/jg5dRsCi6xDSFyCJ9/art.json index a1d93629..66c00613 100644 --- a/art/jg5dRsCi6xDSFyCJ9/art.json +++ b/art/jg5dRsCi6xDSFyCJ9/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "pheema", "avatarUrl": "https://secure.gravatar.com/avatar/129e0f34bca7cf4fd906f08271ab1ac9?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F979dbb28083b6cde8b4dce629ae3eaec", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/clg-2/ambient-sleep-music-astral\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nconst float kPI = 3.1415926535;\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float row_freq_amp = texture2D(sound, vec2( 1.0/240.0, 0.0)).a;\\n float high_freq_amp = texture2D(sound, vec2( 239.0/240.0, 0.0)).a;\\n float a = -1.4 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0005) * time + 0.5 * mouse.x + 0.05 * row_freq_amp)));\\n float b = 1.6;\\n float c = 1.0 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0007) * time + 0.5 * mouse.y + 0.01 * high_freq_amp)));;\\n float d = 0.7;\\n float x = 0.0;\\n float y = 0.0;\\n \\n for(int i = 1; i >= 0; ++i)\\n {\\n if (i >= int(vertexId)) break;\\n \\tfloat x_tmp = x;\\n x = sin(a * y) + c * cos(a * x);\\n y = sin(b * x_tmp) + d * cos(b * y);\\n }\\n x *= 0.5 * (resolution.y / resolution.x);\\n y *= 0.5;\\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1.0, 1.0)), 0.1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/clg-2/ambient-sleep-music-astral", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nconst float kPI = 3.1415926535;\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float row_freq_amp = texture2D(sound, vec2( 1.0/240.0, 0.0)).a;\n float high_freq_amp = texture2D(sound, vec2( 239.0/240.0, 0.0)).a;\n float a = -1.4 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0005) * time + 0.5 * mouse.x + 0.05 * row_freq_amp)));\n float b = 1.6;\n float c = 1.0 * (1.0 + 0.5 * sin(2.0 * kPI * (sqrt(0.0007) * time + 0.5 * mouse.y + 0.01 * high_freq_amp)));;\n float d = 0.7;\n float x = 0.0;\n float y = 0.0;\n \n for(int i = 1; i >= 0; ++i)\n {\n if (i >= int(vertexId)) break;\n \tfloat x_tmp = x;\n x = sin(a * y) + c * cos(a * x);\n y = sin(b * x_tmp) + d * cos(b * y);\n }\n x *= 0.5 * (resolution.y / resolution.x);\n y *= 0.5;\n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(hsv2rgb(vec3(vertexId / vertexCount, 1.0, 1.0)), 0.1);\n}" + }, "screenshotURL": "data/images/images-4sa82591jakgfpk6x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jgpwL4MjxvpeqZ2QN/art.json b/art/jgpwL4MjxvpeqZ2QN/art.json index 2eb85b9c..12f4e024 100644 --- a/art/jgpwL4MjxvpeqZ2QN/art.json +++ b/art/jgpwL4MjxvpeqZ2QN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "vincent23", "avatarUrl": "https://avatars.githubusercontent.com/vincent23?s=200", - "settings": "{\"num\":15000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mouthwateringrecords/dubokaj-trimoto-calim\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5568627450980392,0.611764705882353,0.5725490196078431,1],\"shader\":\"void main() {\\n float aspect = resolution.x / resolution.y;\\n float phi = vertexId * .3;\\n float radius = fract(vertexId / (10. + sin(time * .01 + phi * .1))) * .6;\\n phi += radius * 5.;\\n radius += (sin(phi * 5.) * .5 + .5) * .1;\\n float tau = acos(-1.) * 2.;\\n phi += clamp(fract(time * 80. / 60.) * 3., 0., 1.) * tau / 5.;\\n radius += .5 * radius * texture2D(sound, vec2(abs(fract(phi / tau - .25) - .5) * .25, 0.)).r;\\n gl_PointSize = mix(1., 3., fract(phi * .1));\\n vec3 pos = vec3(radius * cos(phi), radius * sin(phi), 0.);\\n pos.x /= aspect;\\n gl_Position = vec4(pos, 1);\\n vec3 color = vec3(0);\\n v_color = vec4(color, 1.);\\n\\n}\"}", + "settings": { + "num": 15000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mouthwateringrecords/dubokaj-trimoto-calim", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5568627450980392, + 0.611764705882353, + 0.5725490196078431, + 1 + ], + "shader": "void main() {\n float aspect = resolution.x / resolution.y;\n float phi = vertexId * .3;\n float radius = fract(vertexId / (10. + sin(time * .01 + phi * .1))) * .6;\n phi += radius * 5.;\n radius += (sin(phi * 5.) * .5 + .5) * .1;\n float tau = acos(-1.) * 2.;\n phi += clamp(fract(time * 80. / 60.) * 3., 0., 1.) * tau / 5.;\n radius += .5 * radius * texture2D(sound, vec2(abs(fract(phi / tau - .25) - .5) * .25, 0.)).r;\n gl_PointSize = mix(1., 3., fract(phi * .1));\n vec3 pos = vec3(radius * cos(phi), radius * sin(phi), 0.);\n pos.x /= aspect;\n gl_Position = vec4(pos, 1);\n vec3 color = vec3(0);\n v_color = vec4(color, 1.);\n\n}" + }, "screenshotURL": "data/images/images-vis2p69bcaheirw3u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jgwXiSzEkQzK3X2Fx/art.json b/art/jgwXiSzEkQzK3X2Fx/art.json index eb4fcd1a..cd424f1e 100644 --- a/art/jgwXiSzEkQzK3X2Fx/art.json +++ b/art/jgwXiSzEkQzK3X2Fx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":97200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dubstep/bones-noize-fire-against-fire\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ɹɓqןnɹ */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n \\n float numPerSpot = 3.;\\n float spotId = mod(floor(pointId / 36.), numPerSpot);\\n float spotV = spotId / numPerSpot;\\n float cubeId = floor(pointId / (36. * numPerSpot));\\n float numCubes = floor(vertexCount / (36. * numPerSpot));\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float s = texture2D(sound, vec2(mix(0.05, 0.5, (cx + cy * across) / numCubes), spotV * 0.01)).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, (cx + cy * across) / numCubes), spotV * 0.0)).a;\\n \\n float tm = time * 0.1 + s2 * 5.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n float r = mix(0.5, 1., sin(time) * .5 + .5);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * 1.1 * r + 2. * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= trans(vec3(0, 0, spotV * 0.001 + s * 0.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(\\n ca + hash(s * 0.231) * pow(s, 5.) * 0.3, \\n 0, \\n cd + hash(s * 0.412) * pow(s, 5.) * 0.3));\\n //mat *= rotX(time + abs(ca) * 5.);\\n //mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = spotV;\\n float sat = 1.;//mix(1., 0., abs(ca));\\n float val = 1.;//mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n color.x = spotId < 0.5 ? 1. : 0.;//step(1.5, spotId);\\n color.y = spotId > 0.5 && spotId < 1.5 ? 1. : 0.;//step(0.5, spotId);\\n color.z = spotId > 1.5 ? 1. : 0.;\\n v_color = vec4(color * pow(s * 1.5, 5.), 0.); \\n //v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 97200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dubstep/bones-noize-fire-against-fire", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ɹɓqןnɹ */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n \n float numPerSpot = 3.;\n float spotId = mod(floor(pointId / 36.), numPerSpot);\n float spotV = spotId / numPerSpot;\n float cubeId = floor(pointId / (36. * numPerSpot));\n float numCubes = floor(vertexCount / (36. * numPerSpot));\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float s = texture2D(sound, vec2(mix(0.05, 0.5, (cx + cy * across) / numCubes), spotV * 0.01)).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, (cx + cy * across) / numCubes), spotV * 0.0)).a;\n \n float tm = time * 0.1 + s2 * 5.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n float r = mix(0.5, 1., sin(time) * .5 + .5);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * 1.1 * r + 2. * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= trans(vec3(0, 0, spotV * 0.001 + s * 0.));\n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(\n ca + hash(s * 0.231) * pow(s, 5.) * 0.3, \n 0, \n cd + hash(s * 0.412) * pow(s, 5.) * 0.3));\n //mat *= rotX(time + abs(ca) * 5.);\n //mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = spotV;\n float sat = 1.;//mix(1., 0., abs(ca));\n float val = 1.;//mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n color.x = spotId < 0.5 ? 1. : 0.;//step(1.5, spotId);\n color.y = spotId > 0.5 && spotId < 1.5 ? 1. : 0.;//step(0.5, spotId);\n color.z = spotId > 1.5 ? 1. : 0.;\n v_color = vec4(color * pow(s * 1.5, 5.), 0.); \n //v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-1ksr6kbu4dn19c6sp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ji6xYT7wScL9QmPmH/art.json b/art/ji6xYT7wScL9QmPmH/art.json index 6094dae7..e0b6404d 100644 --- a/art/ji6xYT7wScL9QmPmH/art.json +++ b/art/ji6xYT7wScL9QmPmH/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, -1, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n v_color.rgb = vec3(1) - v_color.rgb;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, -1, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n v_color.rgb = vec3(1) - v_color.rgb;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-feghmwtod2ct5fr7n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jiYAbdiu7oseTcBzg/art.json b/art/jiYAbdiu7oseTcBzg/art.json index 69da4d04..6871c32a 100644 --- a/art/jiYAbdiu7oseTcBzg/art.json +++ b/art/jiYAbdiu7oseTcBzg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":72568,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*9.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 72568, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*9.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-mrbx9fhle4vyspycj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jjFQmoBi82cZBgTCj/art.json b/art/jjFQmoBi82cZBgTCj/art.json index ac9f3c72..1fa1cb73 100644 --- a/art/jjFQmoBi82cZBgTCj/art.json +++ b/art/jjFQmoBi82cZBgTCj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09019607843137255,0.08235294117647059,0.09019607843137255,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle + 3. );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 2.); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], -0.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n\\n -0.1 -s, 0, 0, 0.1,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 2) /2.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. + 0.1;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.07;\\n pos = vec3(x, y +1., z +2. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(.1, mod(circleId*2., 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles -parameter4;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n\\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.0203) * 1.4;\\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 * 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\\n float sat = 0.9 - circleId;\\n float val = .75;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9 /parameter6, 0.2));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09019607843137255, + 0.08235294117647059, + 0.09019607843137255, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n \n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 3.0), c.y)*2.;\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle + 3. );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 2.); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], -0.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n\n -0.1 -s, 0, 0, 0.1,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 2) /2.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. + 0.1;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.07;\n pos = vec3(x, y +1., z +2. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(.1, mod(circleId*2., 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles -parameter4;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.0203) * 1.4;\n offset.y += goop(circleId + time * 0.013) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 * 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId + 0.79));\n float sat = 0.9 - circleId;\n float val = .75;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (3. - uv.y) * pow(snd - .9 /parameter6, 0.2));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-as6azf3utovpf5nzd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jjpd8XtJ5nJAcmyLh/art.json b/art/jjpd8XtJ5nJAcmyLh/art.json index a26d4b57..6587cb13 100644 --- a/art/jjpd8XtJ5nJAcmyLh/art.json +++ b/art/jjpd8XtJ5nJAcmyLh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float width = 10.0;\\n float x = mod(vertexId, width) * 0.05;\\n float y = floor(vertexId / width) * 0.05;\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n gl_Position = vec4(u, v, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float width = 10.0;\n float x = mod(vertexId, width) * 0.05;\n float y = floor(vertexId / width) * 0.05;\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n gl_Position = vec4(u, v, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-kpkavv057r7ie8vyf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jmoBvZevCB2QeEtAN/art.json b/art/jmoBvZevCB2QeEtAN/art.json index 83aaad99..ee0358f7 100644 --- a/art/jmoBvZevCB2QeEtAN/art.json +++ b/art/jmoBvZevCB2QeEtAN/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "상민", "avatarUrl": "https://lh5.googleusercontent.com/-FBZLbE_y4_Q/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reklXxy3FykkwCC2DQh9jjtzFC4fg/mo/photo.jpg", - "settings": "{\"num\":950,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.48627450980392156,0.48627450980392156,0.48627450980392156,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t = sangmin.kim \\nAssignment Name/Number = Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t= CS230\\nTerm\\t\\t\\t\\t\\t= Spring 2019\\n------------------------------------------------------------------------*/\\nvoid main()\\n{\\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 150.;\\n \\n\\n gl_PointSize *= sin(time * 8.);\\n gl_PointSize *= 3.;\\n \\n v_color = vec4(mouse.x, mouse.y, mouse.x + mouse.y, 1);\\n}\"}", + "settings": { + "num": 950, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.48627450980392156, + 0.48627450980392156, + 0.48627450980392156, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t = sangmin.kim \nAssignment Name/Number = Shader/3 (Extra Credit)\nCourse Name\t\t\t\t= CS230\nTerm\t\t\t\t\t= Spring 2019\n------------------------------------------------------------------------*/\nvoid main()\n{\n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 150.;\n \n\n gl_PointSize *= sin(time * 8.);\n gl_PointSize *= 3.;\n \n v_color = vec4(mouse.x, mouse.y, mouse.x + mouse.y, 1);\n}" + }, "screenshotURL": "data/images/images-k09nulow9wba5m94n-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jpy7t2fKy3TKStRPG/art.json b/art/jpy7t2fKy3TKStRPG/art.json index b0ff6323..75a9b493 100644 --- a/art/jpy7t2fKy3TKStRPG/art.json +++ b/art/jpy7t2fKy3TKStRPG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/peter-jeong-284275317/last-minute-of-party?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0196078431372549,0.0196078431372549,0.0196078431372549,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Audio Reactive\\n// Course : CS250\\n// Spring 2023\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\n float su = abs(u -.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n \\n // Angular\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n // Sound\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n // [0, 1)\\n float pump = pow(0.1, snd);\\n float hue = v * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \\n float sat = mix(0.7, 1., pump);//mix(1., -10., 1. - av);\\n float val = mix(0.1, 0.2 ,snd + .2 + 5.);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/peter-jeong-284275317/last-minute-of-party?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0196078431372549, + 0.0196078431372549, + 0.0196078431372549, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Audio Reactive\n// Course : CS250\n// Spring 2023\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n\n float su = abs(u -.5) * 2.;\n float sv = abs(v - .5) * 2.;\n \n // Angular\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n // Sound\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n // [0, 1)\n float pump = pow(0.1, snd);\n float hue = v * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \n float sat = mix(0.7, 1., pump);//mix(1., -10., 1. - av);\n float val = mix(0.1, 0.2 ,snd + .2 + 5.);//sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-kls32gpon54liu3f1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jqQ7JEPy2w8vDnkiC/art.json b/art/jqQ7JEPy2w8vDnkiC/art.json index 31b1db40..d1c7d008 100644 --- a/art/jqQ7JEPy2w8vDnkiC/art.json +++ b/art/jqQ7JEPy2w8vDnkiC/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "chaerinpark", "avatarUrl": "https://avatars.githubusercontent.com/ChaerinPark?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/yoasobimusic/jqiurhdzp3dy?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Chaerin Park\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n \\treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat xoff = 0.0; //sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2.0 - 1.0 + xoff;\\n \\tfloat vy = v * 2.0 - 1.0 + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\\n \\n \\tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tfloat pump = step(0.8, snd);\\n \\tfloat hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\\n \\tfloat sat = mix(0.0, 1.0, pump);\\n \\tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/yoasobimusic/jqiurhdzp3dy?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Chaerin Park\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n \treturn c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat xoff = 0.0; //sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2.0 - 1.0 + xoff;\n \tfloat vy = v * 2.0 - 1.0 + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \n \tfloat su = abs(u - 0.5) * 2.0;\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\n \n \tgl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tfloat pump = step(0.8, snd);\n \tfloat hue = u * 0.1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\n \tfloat sat = mix(0.0, 1.0, pump);\n \tfloat val = mix(0.1, pow(snd + 0.2, 5.0), pump);\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-hl0yy2ub7sucim8rw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jqRhLrTMA3GFEk2m5/art.json b/art/jqRhLrTMA3GFEk2m5/art.json index 9618effc..734376d7 100644 --- a/art/jqRhLrTMA3GFEk2m5/art.json +++ b/art/jqRhLrTMA3GFEk2m5/art.json @@ -20,7 +20,19 @@ "origId": "h6BvsMWiHpgwT5Nhh", "name": "pointsprite plasma 3D", "username": "optimus6128", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define width 384.0\\n#define height 256.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(3.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\\n gl_PointSize = 24.0;\\n\\n \\n v_color = vec4(0.5 + c, 0.5 + c, 1.5 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define width 384.0\n#define height 256.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(3.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\n gl_PointSize = 24.0;\n\n \n v_color = vec4(0.5 + c, 0.5 + c, 1.5 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-7frecwp7ycvgrar50-thumbnail.jpg", "views": { "$numberInt": "449" diff --git a/art/jqwWnsecfchT8qKg8/art.json b/art/jqwWnsecfchT8qKg8/art.json index 0d137a88..11542801 100644 --- a/art/jqwWnsecfchT8qKg8/art.json +++ b/art/jqwWnsecfchT8qKg8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jpaquim", "avatarUrl": "https://secure.gravatar.com/avatar/374b09dacab582ca17818a391b59a214?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n // float xoff = 0.;\\n float xoff = sin(time + y * .2) * .1;\\n // float yoff = 0.;\\n float yoff = sin(time * 1.1 + x * .3) * .2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.0;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n // float soff = 0.;\\n float soff = sin(time * 1.2 + x * y * .02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + u * v * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n // float xoff = 0.;\n float xoff = sin(time + y * .2) * .1;\n // float yoff = 0.;\n float yoff = sin(time * 1.1 + x * .3) * .2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.0;\n \n gl_Position = vec4(xy, 0, 1);\n \n // float soff = 0.;\n float soff = sin(time * 1.2 + x * y * .02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time * 1.4 + u * v * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-mjjdvcw3uro90kqec-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jsKeJ8QviCT2KuxC4/art.json b/art/jsKeJ8QviCT2KuxC4/art.json index 7a142ccd..c7ed2165 100644 --- a/art/jsKeJ8QviCT2KuxC4/art.json +++ b/art/jsKeJ8QviCT2KuxC4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16384,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 2.0 * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-1.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/244. ) );\\n}\"}", + "settings": { + "num": 16384, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 2.0 * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-1.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/244. ) );\n}" + }, "screenshotURL": "data/images/images-rx1hi7qayn3soj0v8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jtB7xCrYixyTqmxB8/art.json b/art/jtB7xCrYixyTqmxB8/art.json index 0461e3ff..5eb8737f 100644 --- a/art/jtB7xCrYixyTqmxB8/art.json +++ b/art/jtB7xCrYixyTqmxB8/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":76979,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aqueous/spl-back-at-it-aqueous-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.48627450980392156,0.38823529411764707,0.047058823529411764,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 3.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 4.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count - sin(time * 0.1) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle * time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 1.08);\\n float innerRadius = pow(count * 0.005, 1.2);\\n float oC = cos(orbitAngle * count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC - c*2.,\\n oS + s);\\n gl_Position = vec4(xy / aspect + mouse * -0.1, -1, 1);\\n\\n float b = 1.0 - pow(sin(count * 4.4) * 10.5 - 0.5, 10.0);\\n b = 0.0;mix(0.0, sin(1.7), 8.);\\n v_color = vec4(b, c, b, 1);\\n}\"}", + "settings": { + "num": 76979, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aqueous/spl-back-at-it-aqueous-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.48627450980392156, + 0.38823529411764707, + 0.047058823529411764, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 3.0\n\nvoid main() {\n float point = mod(floor(vertexId / 4.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count - sin(time * 0.1) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle * time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 1.08);\n float innerRadius = pow(count * 0.005, 1.2);\n float oC = cos(orbitAngle * count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.01) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC - c*2.,\n oS + s);\n gl_Position = vec4(xy / aspect + mouse * -0.1, -1, 1);\n\n float b = 1.0 - pow(sin(count * 4.4) * 10.5 - 0.5, 10.0);\n b = 0.0;mix(0.0, sin(1.7), 8.);\n v_color = vec4(b, c, b, 1);\n}" + }, "screenshotURL": "data/images/images-4wxp4a6f57zp9hlej-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jtFAXNm8ngq4kTFhA/art.json b/art/jtFAXNm8ngq4kTFhA/art.json index e92e63f1..5fec6f89 100644 --- a/art/jtFAXNm8ngq4kTFhA/art.json +++ b/art/jtFAXNm8ngq4kTFhA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "r21nomi", "avatarUrl": "https://avatars.githubusercontent.com/r21nomi?s=200", - "settings": "{\"num\":17703,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/meiden/zedd-find-youmeiden-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define PI radians(180.0)\\n\\nvec3 saturate(vec3 x) {\\n\\treturn clamp(x, 0.0, 1.0);\\n}\\n\\nvec3 hue2rgb(float h) {\\n h = fract(h) * 6.0 - 2.0;\\n return saturate(vec3(abs(h - 1.0) - 1.0, 2.0 - abs(h), 2.0 - abs(h - 2.0)));\\n}\\n\\nvec2 getCirclePoint(float id, float numCircles, float radiusOffset) {\\n \\tfloat ux = floor(id / 6.0) + mod(id, 2.0);\\n \\tfloat uy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\t\\n \\tfloat angle = ux / numCircles * PI * 2.0;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n \\n \\tfloat radius = uy + radiusOffset;\\n \\n \\tfloat x = c * radius;\\n \\tfloat y = s * radius;\\n \\n \\treturn vec2(x, y);\\n}\\n\\nvoid main() {\\n \\t// Point num for simple circle with line.\\n \\tfloat pointNumOfCircle = 20.0;\\n \\n \\t// Point num consist of circle.\\n \\tfloat totalPointNumPerCircle = pointNumOfCircle * 6.0;\\n \\n \\tfloat circleId = floor(vertexId / totalPointNumPerCircle);\\n \\tfloat numCircles = floor(vertexCount / totalPointNumPerCircle);\\n \\n \\tfloat down = floor(sqrt(numCircles));\\n \\tfloat across = floor(numCircles / down);\\n \\n \\tfloat x = mod(circleId, across);\\n \\tfloat y = floor(circleId / across);\\n \\n \\tfloat u = x / (across - 1.0);\\n \\tfloat v = y / (across - 1.0);\\n \\n \\tfloat ux = u * 2.0 - 1.0;\\n \\tfloat vy = v * 2.0 - 1.0;\\n \\n \\tfloat radiusOffset = abs(sin(time * 3.0 + circleId));\\n \\tvec2 circleXY= getCirclePoint(vertexId, pointNumOfCircle, radiusOffset);\\n \\n \\tfloat su = abs(u - 0.5) * 1.0;\\n \\tfloat sv = abs(v - 0.5) * 1.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.05)).a;\\n \\n \\tfloat scale = snd * 2.5;\\n \\tvec2 xy = circleXY * 0.1 + vec2(ux, vy) * scale;\\n \\tvec3 pos = vec3(xy * 0.5, 0.0);\\n \\n \\tgl_Position = vec4(pos, 1.0);\\n \\tfloat pump = step(0.5, snd);\\n \\tvec3 hue = hue2rgb(snd);\\n \\tvec3 color = vec3(pump, pump, 0.5) * hue;\\n \\n \\tv_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 17703, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/meiden/zedd-find-youmeiden-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define PI radians(180.0)\n\nvec3 saturate(vec3 x) {\n\treturn clamp(x, 0.0, 1.0);\n}\n\nvec3 hue2rgb(float h) {\n h = fract(h) * 6.0 - 2.0;\n return saturate(vec3(abs(h - 1.0) - 1.0, 2.0 - abs(h), 2.0 - abs(h - 2.0)));\n}\n\nvec2 getCirclePoint(float id, float numCircles, float radiusOffset) {\n \tfloat ux = floor(id / 6.0) + mod(id, 2.0);\n \tfloat uy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \t\n \tfloat angle = ux / numCircles * PI * 2.0;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n \n \tfloat radius = uy + radiusOffset;\n \n \tfloat x = c * radius;\n \tfloat y = s * radius;\n \n \treturn vec2(x, y);\n}\n\nvoid main() {\n \t// Point num for simple circle with line.\n \tfloat pointNumOfCircle = 20.0;\n \n \t// Point num consist of circle.\n \tfloat totalPointNumPerCircle = pointNumOfCircle * 6.0;\n \n \tfloat circleId = floor(vertexId / totalPointNumPerCircle);\n \tfloat numCircles = floor(vertexCount / totalPointNumPerCircle);\n \n \tfloat down = floor(sqrt(numCircles));\n \tfloat across = floor(numCircles / down);\n \n \tfloat x = mod(circleId, across);\n \tfloat y = floor(circleId / across);\n \n \tfloat u = x / (across - 1.0);\n \tfloat v = y / (across - 1.0);\n \n \tfloat ux = u * 2.0 - 1.0;\n \tfloat vy = v * 2.0 - 1.0;\n \n \tfloat radiusOffset = abs(sin(time * 3.0 + circleId));\n \tvec2 circleXY= getCirclePoint(vertexId, pointNumOfCircle, radiusOffset);\n \n \tfloat su = abs(u - 0.5) * 1.0;\n \tfloat sv = abs(v - 0.5) * 1.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.05)).a;\n \n \tfloat scale = snd * 2.5;\n \tvec2 xy = circleXY * 0.1 + vec2(ux, vy) * scale;\n \tvec3 pos = vec3(xy * 0.5, 0.0);\n \n \tgl_Position = vec4(pos, 1.0);\n \tfloat pump = step(0.5, snd);\n \tvec3 hue = hue2rgb(snd);\n \tvec3 color = vec3(pump, pump, 0.5) * hue;\n \n \tv_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-ri2grzcx1zd0v5qmy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/jtaqrSsdjgWqPPqJ4/art.json b/art/jtaqrSsdjgWqPPqJ4/art.json index a078e99b..f954fa46 100644 --- a/art/jtaqrSsdjgWqPPqJ4/art.json +++ b/art/jtaqrSsdjgWqPPqJ4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Term : 2023 Fall\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4( hsv2rgb( vec3(hue, sat, val) ), 1 );\n}" + }, "screenshotURL": "data/images/images-emwx40ioq1pdw28ng-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ju4uMD2zrxMd4z9HK/art.json b/art/ju4uMD2zrxMd4z9HK/art.json index fd9d97ed..2a625a88 100644 --- a/art/ju4uMD2zrxMd4z9HK/art.json +++ b/art/ju4uMD2zrxMd4z9HK/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "illus0r", "avatarUrl": "https://secure.gravatar.com/avatar/40ddd2170e07cc280f3726d08985fbc7?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define rnd(x) fract(921.97 * sin(87.15 * mod(x,120.21)+.1))\\n#define rot(a) mat2(cos(a),-sin(a),sin(a),cos(a))\\n\\nvoid main() {\\n float r = pow(fract(time*1.1+floor(rnd(vertexId)*8.)/8.+.5*rnd(vertexId)),.1);\\n gl_Position = vec4(r,0, 0, 1);\\n gl_Position.xy *= rot(time*.1+1e3*rnd(vertexId*.8));\\n gl_Position.zy *= rot(1e3*rnd(vertexId));\\n gl_PointSize=.1;\\n v_color = vec4(1,0,0,1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define rnd(x) fract(921.97 * sin(87.15 * mod(x,120.21)+.1))\n#define rot(a) mat2(cos(a),-sin(a),sin(a),cos(a))\n\nvoid main() {\n float r = pow(fract(time*1.1+floor(rnd(vertexId)*8.)/8.+.5*rnd(vertexId)),.1);\n gl_Position = vec4(r,0, 0, 1);\n gl_Position.xy *= rot(time*.1+1e3*rnd(vertexId*.8));\n gl_Position.zy *= rot(1e3*rnd(vertexId));\n gl_PointSize=.1;\n v_color = vec4(1,0,0,1);\n}\n" + }, "screenshotURL": "data/images/images-kjyh0snnxsglvoyxt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/juJGnxZcspgX7dGMB/art.json b/art/juJGnxZcspgX7dGMB/art.json index 41049ae6..9ba924af 100644 --- a/art/juJGnxZcspgX7dGMB/art.json +++ b/art/juJGnxZcspgX7dGMB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 5.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*10.,2.);\\n lineId/=numberOfElement;\\n\\n cubep*= min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+7.*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+= xPos;\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 2., -1.2);//29./2.*abs(cos(time/5.))\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., -1.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 5.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*10.,2.);\n lineId/=numberOfElement;\n\n cubep*= min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+7.*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+= xPos;\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 2., -1.2);//29./2.*abs(cos(time/5.))\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., -1.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-ln1xwp93s5cqp83s1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/juXJpMEpt8YSWxSWY/art.json b/art/juXJpMEpt8YSWxSWY/art.json index e3cbaa3d..02e371f6 100644 --- a/art/juXJpMEpt8YSWxSWY/art.json +++ b/art/juXJpMEpt8YSWxSWY/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n#define kp1 -.2\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.20;\\n float spd = 4.96;\\n float tm = time * spd;\\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px*2., py) * 4.60)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y + c * 0.615+kp1) / py, 0.0, 1);\\n gl_PointSize = 2.0;\\n\\n \\n v_color = vec4(2.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n#define kp1 -.2\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos)\n{\n float c = 0.20;\n float spd = 4.96;\n float tm = time * spd;\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px*2., py) * 4.60)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y + c * 0.615+kp1) / py, 0.0, 1);\n gl_PointSize = 2.0;\n\n \n v_color = vec4(2.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-oyh2y8fnl7hvchhqc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/jvGyFQeYoge2TgFbx/art.json b/art/jvGyFQeYoge2TgFbx/art.json index 6a6c318c..5485afbb 100644 --- a/art/jvGyFQeYoge2TgFbx/art.json +++ b/art/jvGyFQeYoge2TgFbx/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":2742,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/dan-hekate-1/mercury-in-stasis\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.08235294117647059,0.08235294117647059,1],\"shader\":\"\\n#define parameter0 0.//KParameter 0.>>6.\\n#define P2 -3.//KParameter -5.>>10.\\n#define P3 0.1//KParameter 0.1>>3.\\n#define P6 9.//KParameter 0.1>>10.\\n#define P5 1.//KParameter -1.>>1.\\n#define P4 0.5//KParameter 0.0>>1.\\n#define mx 0.3//KParameter -1.0>>1.0\\n#define my 0.54//KParameter -1.0>>1.0\\n//KVerticesNumber=5000\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,0.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.2); \\n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 12. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.25;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 12.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down*3.);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 4.) * r;\\n \\n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mouse.x *3.0) + 2.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *.01;\\n float sat = P4;\\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 2742, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/dan-hekate-1/mercury-in-stasis", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.08235294117647059, + 0.08235294117647059, + 1 + ], + "shader": "\n#define parameter0 0.//KParameter 0.>>6.\n#define P2 -3.//KParameter -5.>>10.\n#define P3 0.1//KParameter 0.1>>3.\n#define P6 9.//KParameter 0.1>>10.\n#define P5 1.//KParameter -1.>>1.\n#define P4 0.5//KParameter 0.0>>1.\n#define mx 0.3//KParameter -1.0>>1.0\n#define my 0.54//KParameter -1.0>>1.0\n//KVerticesNumber=5000\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,0.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.2); \n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 12. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.25;\n float down = numQuads / around;\n float quadId = floor(vertexId / 12.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down*3.);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 4.) * r;\n \n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mouse.x *3.0) + 2.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *.01;\n float sat = P4;\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-5l9wv47hoiykpnzcb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k2vXaRzFT8Nqdwfit/art.json b/art/k2vXaRzFT8Nqdwfit/art.json index baefd83a..f016bbfa 100644 --- a/art/k2vXaRzFT8Nqdwfit/art.json +++ b/art/k2vXaRzFT8Nqdwfit/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/protector-101/protector-101-a-dancing-comet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 02, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 12); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 12, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 12); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/protector-101/protector-101-a-dancing-comet", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 4.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 02, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 12); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 12, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 12); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-w02lk9av2jdvdyqe3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k4wpsPnafQ4YQs6dJ/art.json b/art/k4wpsPnafQ4YQs6dJ/art.json index 06548672..d609b99d 100644 --- a/art/k4wpsPnafQ4YQs6dJ/art.json +++ b/art/k4wpsPnafQ4YQs6dJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21176470588235294,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n#define KP0 2.//KParameter -0.5>>2.5\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.5//KParameter 1.0>>7.\\n#define KP2 .3//KParameter 0.4>>2.\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0 * zoom;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n float beat = texture2D(sound, vec2(0.007, 0)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0.65; + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(5,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8 + KP2;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/minimalhammerers/hammerers-the-roads-of-heaven", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21176470588235294, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n#define KP0 2.//KParameter -0.5>>2.5\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.5//KParameter 1.0>>7.\n#define KP2 .3//KParameter 0.4>>2.\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0 * zoom;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n float beat = texture2D(sound, vec2(0.007, 0)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin * pow(beat, 3.) * 2.);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0.65; + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(5,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8 + KP2;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., sin(time * 0.17) * 80., cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-ty96knkj7ql6eacdy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k5BBCA2vPq6sY6xv5/art.json b/art/k5BBCA2vPq6sY6xv5/art.json index e9a4057d..5ddebd3f 100644 --- a/art/k5BBCA2vPq6sY6xv5/art.json +++ b/art/k5BBCA2vPq6sY6xv5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4242,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.4549019607843137,0.5058823529411764,1],\"shader\":\"// Simple Line which responds to music\\n// This is intended to be super simple, to learn how to use VertexShaderArt\\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\\n\\nvoid main()\\n{\\n // vertex_percent is vertexId mapped to [0..1]\\n float nb_circles = 10.0;\\n float nbpointspercircle = vertexCount/nb_circles;\\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\\n \\n // sound texture has (amplitude, history) for (u,v). \\n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\\n // It is all in the alpha channel of the sound texture\\n \\n // Set y position to amplitude in [0..1] range.\\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\\n float circ_num= mod(vertexId, nb_circles)/nb_circles;\\n float y = -0.5+2.0*texture2D(sound,vec2(circ_num,0.0)).a*0.5; \\n \\n float r = 0.3;\\n float posx = (0.01*sin(r*time)+r)*(circ_num+1.0) * cos(vertex_percent*2.0*3.14+0.05*time)*0.8*((y*2.0)-1.0);\\n float posy = (0.01*sin(r*time)+r)*(circ_num+1.0) * sin(vertex_percent*2.0*3.14+0.01*time)*0.8*((y*2.0)-1.0);\\n \\n \\n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\\n gl_Position = vec4(posx,posy,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\\n v_color = vec4(sin(time)*sin(time), y+1.0, circ_num, 1.0);\\n vec4 aa = background;\\n} \\n\\n\"}", + "settings": { + "num": 4242, + "mode": "POINTS", + "sound": "https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.4549019607843137, + 0.5058823529411764, + 1 + ], + "shader": "// Simple Line which responds to music\n// This is intended to be super simple, to learn how to use VertexShaderArt\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\n\nvoid main()\n{\n // vertex_percent is vertexId mapped to [0..1]\n float nb_circles = 10.0;\n float nbpointspercircle = vertexCount/nb_circles;\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\n \n // sound texture has (amplitude, history) for (u,v). \n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\n // It is all in the alpha channel of the sound texture\n \n // Set y position to amplitude in [0..1] range.\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\n float circ_num= mod(vertexId, nb_circles)/nb_circles;\n float y = -0.5+2.0*texture2D(sound,vec2(circ_num,0.0)).a*0.5; \n \n float r = 0.3;\n float posx = (0.01*sin(r*time)+r)*(circ_num+1.0) * cos(vertex_percent*2.0*3.14+0.05*time)*0.8*((y*2.0)-1.0);\n float posy = (0.01*sin(r*time)+r)*(circ_num+1.0) * sin(vertex_percent*2.0*3.14+0.01*time)*0.8*((y*2.0)-1.0);\n \n \n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\n gl_Position = vec4(posx,posy,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\n v_color = vec4(sin(time)*sin(time), y+1.0, circ_num, 1.0);\n vec4 aa = background;\n} \n\n" + }, "screenshotURL": "data/images/images-31ah01abvwhxbpv0l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k5hPuKGzdkGEvfoZk/art.json b/art/k5hPuKGzdkGEvfoZk/art.json index ce405e40..3d9df881 100644 --- a/art/k5hPuKGzdkGEvfoZk/art.json +++ b/art/k5hPuKGzdkGEvfoZk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.2, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n0, s, 0, (0.1 -s),\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -0.2 ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) -1.4;\\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 6.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .02)).xyz, 1.2);\\n gl_PointSize = tan(5. *snd);\\n float hue = mix(1.3*snd, 12.6/snd, fract(circleId -21.79)*3.);\\n float sat = 45.2 * circleId/snd;\\n float val = .29;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-2.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0)- 0.5);\n vec4 K = vec4(0.3, 4.0 / 2.4, 2.0 / 6.0, 3.00);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 0.3), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.2, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n0, s, 0, (0.1 -s),\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE + .7);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI *.1 + PI * 2.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -0.2 ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 2.27) + tan(t * 0.13+mouse.x) + cos(t- 8.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 0.076)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(sin(0.073), cos(time * 2.2), p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x - 1.18 )) * 0.25, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) -1.4;\n offset.y += goop(circleId + time * 0.013) * 1.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, snd *.2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 6.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .02)).xyz, 1.2);\n gl_PointSize = tan(5. *snd);\n float hue = mix(1.3*snd, 12.6/snd, fract(circleId -21.79)*3.);\n float sat = 45.2 * circleId/snd;\n float val = .29;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. / uv.y)- tan(uv * 18.1* snd));\n v_color = vec4(v_color.rgb * v_color.a*3., v_color.a-2.0);\n}" + }, "screenshotURL": "data/images/images-w0qqhx9tjuduhxhf7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k5izvwNxYrHYx6WBr/art.json b/art/k5izvwNxYrHYx6WBr/art.json index a14de199..802427a6 100644 --- a/art/k5izvwNxYrHYx6WBr/art.json +++ b/art/k5izvwNxYrHYx6WBr/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":12733,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Circles from Triangles\\n// CS250 \\n// Spring/2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n float ux = floor(id/6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux/numCircleSegments * PI*2.;\\n float c =cos(angle);\\n float s =sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\treturn vec2(x,y);\\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 36.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n float numPointsPerCircle = numCircleSegments *6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount/numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/6.);\\n float oddSlice = mod(sliceId,2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down); \\n \\n float x = mod(circleId,across);\\n float y = floor(circleId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n //vec2 xy = circleXY*0.1*sc + vec2(ux, vy) * 1.3;\\n \\n float aspect = resolution.x/resolution.y;\\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\\n sc*=20./across;\\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n mat*= scale(vec3(1,aspect,1));\\n mat*= rotZ(time*0.1);\\n mat *= trans(vec3(ux,vy,0) *1.4);\\n mat*= rotZ(snd*20.*sign(ux));\\n mat*= uniformScale(0.03*sc);\\n \\n gl_Position = mat*pos;\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0., 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue +pump* oddSlice*0.5 + pump*0.33;\\n val += oddSlice*pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 12733, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Circles from Triangles\n// CS250 \n// Spring/2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\nvec2 getCirclePoint(float id, float numCircleSegments){\n float ux = floor(id/6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux/numCircleSegments * PI*2.;\n float c =cos(angle);\n float s =sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n\treturn vec2(x,y);\n}\n\n\nvoid main() {\n \n float numCircleSegments = 36.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n float numPointsPerCircle = numCircleSegments *6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount/numPointsPerCircle);\n \n float sliceId = floor(vertexId/6.);\n float oddSlice = mod(sliceId,2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down); \n \n float x = mod(circleId,across);\n float y = floor(circleId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n //vec2 xy = circleXY*0.1*sc + vec2(ux, vy) * 1.3;\n \n float aspect = resolution.x/resolution.y;\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\n sc*=20./across;\n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n mat*= scale(vec3(1,aspect,1));\n mat*= rotZ(time*0.1);\n mat *= trans(vec3(ux,vy,0) *1.4);\n mat*= rotZ(snd*20.*sign(ux));\n mat*= uniformScale(0.03*sc);\n \n gl_Position = mat*pos;\n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0., 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue +pump* oddSlice*0.5 + pump*0.33;\n val += oddSlice*pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-li32jubojh7kmxl9i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k7w6BKgeSJxKx3Z6L/art.json b/art/k7w6BKgeSJxKx3Z6L/art.json index edc4e5a8..242654e6 100644 --- a/art/k7w6BKgeSJxKx3Z6L/art.json +++ b/art/k7w6BKgeSJxKx3Z6L/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.14901960784313725,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.14901960784313725, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 10, cos(time * 0.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-ogl9iezuaimhelhgm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k92jG6hXfdYZmDDxp/art.json b/art/k92jG6hXfdYZmDDxp/art.json index 2364009c..c1e2ef38 100644 --- a/art/k92jG6hXfdYZmDDxp/art.json +++ b/art/k92jG6hXfdYZmDDxp/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":7000,\"mode\":\"LINES\",\"sound\":\"https://on.soundcloud.com/pM2ak\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Motion\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 5. - 1. + yoff;\\n \\n \\tfloat red = sin(time) * 4.;\\n \\tfloat blue = sin(time) * 4.;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.0;\\n \\n \\tv_color = vec4(red, 0, blue, 1);\\n}\\n\"}", + "settings": { + "num": 7000, + "mode": "LINES", + "sound": "https://on.soundcloud.com/pM2ak", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Motion\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 5. - 1. + yoff;\n \n \tfloat red = sin(time) * 4.;\n \tfloat blue = sin(time) * 4.;\n \n \tvec2 xy = vec2(ux, vy) * 1.;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.0;\n \n \tv_color = vec4(red, 0, blue, 1);\n}\n" + }, "screenshotURL": "data/images/images-rcygyp439ef1xsoxc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/k9wLKsfTxHABY5b7P/art.json b/art/k9wLKsfTxHABY5b7P/art.json index 270dd69b..e3cba6d7 100644 --- a/art/k9wLKsfTxHABY5b7P/art.json +++ b/art/k9wLKsfTxHABY5b7P/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 10.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n/*\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n sin(id * 0.5+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}\\n*/\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 1.),\\n sin(id * 0.5),\\n sin(id * 0.25));\\n}\\n\\n\\nconst float expand = 120.;\\nconst float off = 0.1;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \\n{\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n //float off = 0.1;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n _wmat = wmat;//mat4(\\n \\n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 eye = r0 * expand + zaxis * 1.;\\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 target = r1 * expand + zaxis;\\n vec3 up = yaxis;\\n \\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n /*_emat = mat4(\\n 1.,0.,0.,0.,\\n 0.,1.,0.,0.,\\n 0.,0.,1.,0.,\\n 0.,0.,0.,1.); \\n */\\n \\n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\\n color = vec4(1.,1.,1., 1);\\n\\n}\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n \\n float sizeFactor = 1./100.;\\n\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElementPerGroup = lineNumber;\\n \\n \\n float groupId = floor(shapeId/numberOfElementPerGroup);\\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n mat4 scaleMat = scale(vec3(sizeFactor,sizeFactor,sizeFactor));\\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n //create the circle group\\n float radius = 3.*sizeFactor;\\n cubep.x+= radius+sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n cubep.y+= radius+cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\\n \\n \\n mat4 wmat;\\n mat4 emat;\\n \\n float base = 14.5; \\n base = time * 10.0;\\n vec4 color2 = vec4(1.,1.,1.,1.);\\n vec3 pos;\\n //void track(shapeId, shapeCount, base, pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \\n track(groupId, groupCount/10., base, pos, color2, wmat, emat);\\n \\n // track(shapeId, shapeCount, base, pos, color, wmat, emat);\\n \\n //mat4 invmat = inverse(wmat);\\n //wmat.z = vec4(0.,0.,0.,1.);\\n \\n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\\n \\n \\n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\\n \\n cbNi = cbNi*wmat;\\n cubep+= posi/expand;\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 10.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n/*\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n sin(id * 0.5+_time*10.),\n sin(id * 0.25+_time*10.));\n}\n*/\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 1.),\n sin(id * 0.5),\n sin(id * 0.25));\n}\n\n\nconst float expand = 120.;\nconst float off = 0.1;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \n{\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n //float off = 0.1;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n _wmat = wmat;//mat4(\n \n //vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 eye = r0 * expand + zaxis * 1.;\n //vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 target = r1 * expand + zaxis;\n vec3 up = yaxis;\n \n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n /*_emat = mat4(\n 1.,0.,0.,0.,\n 0.,1.,0.,0.,\n 0.,0.,1.,0.,\n 0.,0.,0.,1.); \n */\n \n pos = (wmat * vec4(1.,1.,1., 1)).xyz;\n //_cubep = (wmat * vec4(_cubep, 1)).xyz;\n color = vec4(1.,1.,1., 1);\n\n}\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n \n float sizeFactor = 1./100.;\n\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElementPerGroup = lineNumber;\n \n \n float groupId = floor(shapeId/numberOfElementPerGroup);\n float groupCount = floor(shapeCount/numberOfElementPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfElementPerGroup);\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n mat4 scaleMat = scale(vec3(sizeFactor,sizeFactor,sizeFactor));\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n //create the circle group\n float radius = 3.*sizeFactor;\n cubep.x+= radius+sin(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n cubep.y+= radius+cos(2.*PI*shapeIdInGroup/numberOfElementPerGroup);\n \n \n mat4 wmat;\n mat4 emat;\n \n float base = 14.5; \n base = time * 10.0;\n vec4 color2 = vec4(1.,1.,1.,1.);\n vec3 pos;\n //void track(shapeId, shapeCount, base, pos, out vec4 color, out mat4 _wmat, out mat4 _emat) \n track(groupId, groupCount/10., base, pos, color2, wmat, emat);\n \n // track(shapeId, shapeCount, base, pos, color, wmat, emat);\n \n //mat4 invmat = inverse(wmat);\n //wmat.z = vec4(0.,0.,0.,1.);\n \n vec3 posi = (wmat * vec4(0.,0.,0., 1)).xyz;\n \n \n cubep = (vec4(cubep.xyz,1.)*emat).xyz;\n \n cbNi = cbNi*wmat;\n cubep+= posi/expand;\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-rpqb2rwnyijb01m4l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kAANx8FwJoSeR9B4c/art.json b/art/kAANx8FwJoSeR9B4c/art.json index a07f9f64..e3cd4b31 100644 --- a/art/kAANx8FwJoSeR9B4c/art.json +++ b/art/kAANx8FwJoSeR9B4c/art.json @@ -27,7 +27,19 @@ "name": "filters", "private": false, "username": "gman", - "settings": "{\"num\":1024,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 4.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat select(float v, float t) {\\n return step(t * 0.9, v) * step(v, t * 1.1);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (0. * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float historyV2 = (1. * NUM_LINES_DOWN + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float snd2 = texture2D(sound, vec2(historyX, historyV2)).a;\\n \\n float s_norm = select(count, 0.);\\n float s_low = select(count, 1.);\\n float s_high = select(count, 2.);\\n float s_powd = select(count, 3.);\\n \\n float ds = abs(snd - snd2);\\n float norm = snd;\\n float low = step(ds, 0.1) * snd;\\n float high = step(0.1, ds) * snd;\\n float powd = pow(snd, 5.0);\\n \\n float s = \\n norm * s_norm + \\n low * s_low +\\n high * s_high + \\n powd * s_powd +\\n 0.;\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x,\\n s * 0.2 + v - 0.3);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = count * 0.25;\\n float sat = 1.0;\\n float val = 1.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 4.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat select(float v, float t) {\n return step(t * 0.9, v) * step(v, t * 1.1);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (0. * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float historyV2 = (1. * NUM_LINES_DOWN + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float snd2 = texture2D(sound, vec2(historyX, historyV2)).a;\n \n float s_norm = select(count, 0.);\n float s_low = select(count, 1.);\n float s_high = select(count, 2.);\n float s_powd = select(count, 3.);\n \n float ds = abs(snd - snd2);\n float norm = snd;\n float low = step(ds, 0.1) * snd;\n float high = step(0.1, ds) * snd;\n float powd = pow(snd, 5.0);\n \n float s = \n norm * s_norm + \n low * s_low +\n high * s_high + \n powd * s_powd +\n 0.;\n \n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x,\n s * 0.2 + v - 0.3);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = count * 0.25;\n float sat = 1.0;\n float val = 1.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-f4ib10y0x2xberr3r-thumbnail.jpg", "views": { "$numberInt": "492" diff --git a/art/kAmQqozAAzPSXNaps/art.json b/art/kAmQqozAAzPSXNaps/art.json index 92c759b5..1fc1487a 100644 --- a/art/kAmQqozAAzPSXNaps/art.json +++ b/art/kAmQqozAAzPSXNaps/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lambmother/april\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\tif(v>0.5)\\n v = 1.- v;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*1.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 1.3;\\n float tm = 0.5 *time;\\n float tm2 = 0.5*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n //vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.03) * r, sin(tm) * r);\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux+cos(time)*sign(ux)*v_color.x/10., vy+cos(time+0.33)*sign(vy)*v_color.y/10., 0.+sin(time+0.23)*v_color.z/10. , 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 2.;///abs(gl_Position.z);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lambmother/april", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\tif(v>0.5)\n v = 1.- v;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*1.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 1.3;\n float tm = 0.5 *time;\n float tm2 = 0.5*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n //vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.03) * r, sin(tm) * r);\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux+cos(time)*sign(ux)*v_color.x/10., vy+cos(time+0.33)*sign(vy)*v_color.y/10., 0.+sin(time+0.23)*v_color.z/10. , 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 2.;///abs(gl_Position.z);\n \n //v_color = vec4(1.,1.,1.,1.);\n}\n\n" + }, "screenshotURL": "data/images/images-ximim24nm8r5xgdf9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kDijkHtJWk62e82Du/art.json b/art/kDijkHtJWk62e82Du/art.json index d5692c16..79cb949a 100644 --- a/art/kDijkHtJWk62e82Du/art.json +++ b/art/kDijkHtJWk62e82Du/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n//\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n//\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-lf4ws0ugo1frr9hj3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kEah2e6FjeaExoiWN/art.json b/art/kEah2e6FjeaExoiWN/art.json index 6aa934ee..5eb571e5 100644 --- a/art/kEah2e6FjeaExoiWN/art.json +++ b/art/kEah2e6FjeaExoiWN/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":3492,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.23529411764705882,0.25882352941176473,0.34509803921568627,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Colors\\n// CS250 \\n// Spring/2022\\n\\nvec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time * 0.5+ y * 0.4) * .1;\\n float yoff = sin(time *0.1 + x * 0.8) * 1.8;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time*1.2 + x * y * .02) * 10.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u*0.1+sin(time*8.3+v*20.)*0.5;\\n float sat = 1.;\\n float val = sin(time *1.4 + v*u*20.0)*0.5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue*.5,sat,val*3.)), 0.6);\\n}\"}", + "settings": { + "num": 3492, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.23529411764705882, + 0.25882352941176473, + 0.34509803921568627, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Colors\n// CS250 \n// Spring/2022\n\nvec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time * 0.5+ y * 0.4) * .1;\n float yoff = sin(time *0.1 + x * 0.8) * 1.8;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time*1.2 + x * y * .02) * 10.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u*0.1+sin(time*8.3+v*20.)*0.5;\n float sat = 1.;\n float val = sin(time *1.4 + v*u*20.0)*0.5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue*.5,sat,val*3.)), 0.6);\n}" + }, "screenshotURL": "data/images/images-42ql98hyqqld567a6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kFw99h7A55BoqmFND/art.json b/art/kFw99h7A55BoqmFND/art.json index f00cb050..c5a071d6 100644 --- a/art/kFw99h7A55BoqmFND/art.json +++ b/art/kFw99h7A55BoqmFND/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":55071,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/didrec/ken-ishii-malfunction-10\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,12.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 2.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.005, 0.5, hash(fract(gv * 5.))*0.4), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner =mouse.y;\\n float start = mouse.x;\\n float end =step(0.3,0.5+s);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.0123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(t * .1) * 20., sin(t * .3) * 10.*s, 0.42);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .9);\\n \\n mat4 wmat = rotY(t * .017);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 2.;\\n \\n \\n\\n float hue = fract(gv *1.2) *time *0.03 /groupId * 6./s;\\n float sat =1.0-step(pow(s, 3.), gt-3.);\\n float val = 1. /pow(s * .5, 2.2) ;//.3 + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0.5*s, 1.-s, 1.-s)) < 0.23) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,21));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb /= v_color.a*s;\\n \\n float super = step(0.2, 1.-s);\\n v_color = mix(v_color, vec4(s,s,0,0.7), super);\\n \\n}\\n\"}", + "settings": { + "num": 55071, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/didrec/ken-ishii-malfunction-10", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,12.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 2.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.005, 0.5, hash(fract(gv * 5.))*0.4), 0.)).a * 1.3; \n \n vec3 pos;\n float inner =mouse.y;\n float start = mouse.x;\n float end =step(0.3,0.5+s);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.0123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(t * .1) * 20., sin(t * .3) * 10.*s, 0.42);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .9);\n \n mat4 wmat = rotY(t * .017);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s *1.6, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 2.;\n \n \n\n float hue = fract(gv *1.2) *time *0.03 /groupId * 6./s;\n float sat =1.0-step(pow(s, 3.), gt-3.);\n float val = 1. /pow(s * .5, 2.2) ;//.3 + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0.5*s, 1.-s, 1.-s)) < 0.23) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,21));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb /= v_color.a*s;\n \n float super = step(0.2, 1.-s);\n v_color = mix(v_color, vec4(s,s,0,0.7), super);\n \n}\n" + }, "screenshotURL": "data/images/images-poqb0wbuh8c22rach-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kFydmLK7cBEcShhrj/art.json b/art/kFydmLK7cBEcShhrj/art.json index 0d40dbf2..d86c48f1 100644 --- a/art/kFydmLK7cBEcShhrj/art.json +++ b/art/kFydmLK7cBEcShhrj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1411764705882353,0.32941176470588235,0.5803921568627451,1],\"shader\":\"\\nvoid main() {\\n\\tgl_Position = vec4(1, 0, 0, 0);\\n \\n \\tgl_PointSize = 10.0;\\n\\n \\tv_color = vec4(1, 0, 0, 1);\\n} \"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1411764705882353, + 0.32941176470588235, + 0.5803921568627451, + 1 + ], + "shader": "\nvoid main() {\n\tgl_Position = vec4(1, 0, 0, 0);\n \n \tgl_PointSize = 10.0;\n\n \tv_color = vec4(1, 0, 0, 1);\n} " + }, "screenshotURL": "data/images/images-qtjl1olthuh77fo1n-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kHbJM2qswt6BscdP3/art.json b/art/kHbJM2qswt6BscdP3/art.json index 27fcd2d8..c7e975b4 100644 --- a/art/kHbJM2qswt6BscdP3/art.json +++ b/art/kHbJM2qswt6BscdP3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvec3 getColor(int index)\\n{\\n\\tif (index == 0)\\n\\t\\treturn vec3(0.0, 0.0, 0.0);\\n\\tif (index == 1)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\tif (index == 2)\\n\\t\\treturn vec3(0.0, 0.0, 0.0);\\n\\tif (index == 3)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\tif (index == 4)\\n\\t\\treturn vec3(0.0, 0.0, 0.0);\\n\\tif (index == 5)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\tif (index == 6)\\n\\t\\treturn vec3(0.0, 0.0, 0.);\\n\\tif (index == 7)\\n\\t\\treturn vec3(1., 1., 1.);\\n\\t\\n}\\n\\n\\nvoid main ()\\n{\\n //float snd = texture2D(sound, vec2(0., 0.)).a;\\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( u * 2.0 - 1.0) *1./ratio;\\n float vy = ( v/ratio * 2.0 - 1.0);\\n \\n\\n \\n \\n //apply fragment logic\\n\\n\\tconst float colorCount = 8.0;\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n if(position.y>1.)\\n position.y = 2.-position.y;\\n\\t\\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\tj *= 1.;\\n\\tj = mod(j + time/2., 1.0);\\n\\t\\n\\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\\n\\ti = mod(position.y * colorCount * j, i / j);\\n\\ti *= 2.;\\n\\t\\n\\ti = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( getColor(int(i)), 1.0 );\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvec3 getColor(int index)\n{\n\tif (index == 0)\n\t\treturn vec3(0.0, 0.0, 0.0);\n\tif (index == 1)\n\t\treturn vec3(1., 1., 1.);\n\tif (index == 2)\n\t\treturn vec3(0.0, 0.0, 0.0);\n\tif (index == 3)\n\t\treturn vec3(1., 1., 1.);\n\tif (index == 4)\n\t\treturn vec3(0.0, 0.0, 0.0);\n\tif (index == 5)\n\t\treturn vec3(1., 1., 1.);\n\tif (index == 6)\n\t\treturn vec3(0.0, 0.0, 0.);\n\tif (index == 7)\n\t\treturn vec3(1., 1., 1.);\n\t\n}\n\n\nvoid main ()\n{\n //float snd = texture2D(sound, vec2(0., 0.)).a;\n float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(finalVertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( u * 2.0 - 1.0) *1./ratio;\n float vy = ( v/ratio * 2.0 - 1.0);\n \n\n \n \n //apply fragment logic\n\n\tconst float colorCount = 8.0;\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n if(position.y>1.)\n position.y = 2.-position.y;\n\t\n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\tj *= 1.;\n\tj = mod(j + time/2., 1.0);\n\t\n\tfloat i = mod(position.x * colorCount + 10.*sin(time/12.0), sin(time/12.0) + 2.0);\n\ti = mod(position.y * colorCount * j, i / j);\n\ti *= 2.;\n\t\n\ti = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( getColor(int(i)), 1.0 );\n \n\n}" + }, "screenshotURL": "data/images/images-3or9x7trr98pwaxtq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kJKd3eS8axidSmEcA/art.json b/art/kJKd3eS8axidSmEcA/art.json index 113881c7..1f967738 100644 --- a/art/kJKd3eS8axidSmEcA/art.json +++ b/art/kJKd3eS8axidSmEcA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-5v52a6er3xjixg7j5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kJKq7oy8zBvieKhsE/art.json b/art/kJKq7oy8zBvieKhsE/art.json index c62dd039..598d0576 100644 --- a/art/kJKq7oy8zBvieKhsE/art.json +++ b/art/kJKq7oy8zBvieKhsE/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00392156862745098,0.023529411764705882,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; // sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float val = sin(time + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00392156862745098, + 0.023529411764705882, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; // sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time + v * 20.0) * 0.05;\n float sat = 1.0;\n float val = sin(time + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-r4v4hac03qbkmnri0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kQB2kyZz5geDYpNeo/art.json b/art/kQB2kyZz5geDYpNeo/art.json index 73ea0423..4c06a145 100644 --- a/art/kQB2kyZz5geDYpNeo/art.json +++ b/art/kQB2kyZz5geDYpNeo/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-961665354/yt5scom-bondhu-kala-chanponkoj-roy-jk-shanto-bangla-new-dance-video-2021-320-kbps\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n __ __ ______ ______ ______ ______ __ __ ______ __ __ ______ _____ ______ ______ ______ ______ ______ \\n/\\\\ \\\\ / / /\\\\ ___\\\\ /\\\\ == \\\\ /\\\\__ _\\\\ /\\\\ ___\\\\ /\\\\_\\\\_\\\\_\\\\ /\\\\ ___\\\\ /\\\\ \\\\_\\\\ \\\\ /\\\\ __ \\\\ /\\\\ __-. /\\\\ ___\\\\ /\\\\ == \\\\ /\\\\ __ \\\\ /\\\\ == \\\\ /\\\\__ _\\\\ \\n\\\\ \\\\ \\\\'/ \\\\ \\\\ __\\\\ \\\\ \\\\ __< \\\\/_/\\\\ \\\\/ \\\\ \\\\ __\\\\ \\\\/_/\\\\_\\\\/_ \\\\ \\\\___ \\\\ \\\\ \\\\ __ \\\\ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\/\\\\ \\\\ \\\\ \\\\ __\\\\ \\\\ \\\\ __< \\\\ \\\\ __ \\\\ \\\\ \\\\ __< \\\\/_/\\\\ \\\\/ \\n \\\\ \\\\__| \\\\ \\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\ \\\\_____\\\\ /\\\\_\\\\/\\\\_\\\\ \\\\/\\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\____- \\\\ \\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\n \\\\/_/ \\\\/_____/ \\\\/_/ /_/ \\\\/_/ \\\\/_____/ \\\\/_/\\\\/_/ \\\\/_____/ \\\\/_/\\\\/_/ \\\\/_/\\\\/_/ \\\\/____/ \\\\/_____/ \\\\/_/ /_/ \\\\/_/\\\\/_/ \\\\/_/ /_/ \\\\/_/ \\n \\n\\n\\n\\n*/\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n float size = floor(pow(vertexCount, 1./3.));\\n float div = size - 1.;\\n vec3 p = vec3(\\n mod(vertexId, size),\\n mod(floor(vertexId / size), size),\\n floor(floor(vertexId / size) / size));\\n \\n vec3 snd = vec3(\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.1) * 0.25, 0.0)).a,\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.3) * 0.25, 0.0)).a,\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.5) * 0.25, 0.0)).a);\\n \\n float a = time * 0.01;\\n float r = 1.0;\\n float c = cos(a) * r;\\n float s = sin(a) * r;\\n float y = sin(time * 0.011);\\n \\n vec3 target = vec3(0,0,0);\\n vec3 up = vec3(0,1,0);\\n vec3 eye = vec3(c, y, s);\\n \\n \\n mat4 m = ident();\\n m *= persp(radians(45.), resolution.x / resolution.y, 0.1, 2.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(-1, -1, -1));\\n m *= uniformScale(2. / div);\\n \\n vec3 sp = snd * snd * snd * snd * snd * snd * snd * snd * snd;\\n gl_Position = m * vec4(p + sp * .5, 1);\\n\\n float z = gl_Position.z * 0.5 + 0.5;\\n float sm = max(max(sp.x, sp.y), sp.z);\\n float hue = 1.;//(time * 0.01 + count * 1.001);\\n v_color = vec4(mix(p / div * vec3(0,1,1) * z, vec3(1,0,0), step(0.7, sm)), mix(0.8,1.5, mod(floor(vertexId * 0.33 + time * 30.0), 2.)));\\n v_color.r += snd.b;\\n v_color.g += snd.g;\\n v_color.b /= snd.r;\\n \\n v_color = vec4(hsv2rgb(v_color.rbg), v_color.b * 1.2);\\n gl_PointSize = mix(10.3, 0.0, z) + step(0.7, sm) * 2.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-961665354/yt5scom-bondhu-kala-chanponkoj-roy-jk-shanto-bangla-new-dance-video-2021-320-kbps", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n __ __ ______ ______ ______ ______ __ __ ______ __ __ ______ _____ ______ ______ ______ ______ ______ \n/\\ \\ / / /\\ ___\\ /\\ == \\ /\\__ _\\ /\\ ___\\ /\\_\\_\\_\\ /\\ ___\\ /\\ \\_\\ \\ /\\ __ \\ /\\ __-. /\\ ___\\ /\\ == \\ /\\ __ \\ /\\ == \\ /\\__ _\\ \n\\ \\ \\'/ \\ \\ __\\ \\ \\ __< \\/_/\\ \\/ \\ \\ __\\ \\/_/\\_\\/_ \\ \\___ \\ \\ \\ __ \\ \\ \\ __ \\ \\ \\ \\/\\ \\ \\ \\ __\\ \\ \\ __< \\ \\ __ \\ \\ \\ __< \\/_/\\ \\/ \n \\ \\__| \\ \\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\ \\_____\\ /\\_\\/\\_\\ \\/\\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\____- \\ \\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\_\\ \n \\/_/ \\/_____/ \\/_/ /_/ \\/_/ \\/_____/ \\/_/\\/_/ \\/_____/ \\/_/\\/_/ \\/_/\\/_/ \\/____/ \\/_____/ \\/_/ /_/ \\/_/\\/_/ \\/_/ /_/ \\/_/ \n \n\n\n\n*/\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n float size = floor(pow(vertexCount, 1./3.));\n float div = size - 1.;\n vec3 p = vec3(\n mod(vertexId, size),\n mod(floor(vertexId / size), size),\n floor(floor(vertexId / size) / size));\n \n vec3 snd = vec3(\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.1) * 0.25, 0.0)).a,\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.3) * 0.25, 0.0)).a,\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.5) * 0.25, 0.0)).a);\n \n float a = time * 0.01;\n float r = 1.0;\n float c = cos(a) * r;\n float s = sin(a) * r;\n float y = sin(time * 0.011);\n \n vec3 target = vec3(0,0,0);\n vec3 up = vec3(0,1,0);\n vec3 eye = vec3(c, y, s);\n \n \n mat4 m = ident();\n m *= persp(radians(45.), resolution.x / resolution.y, 0.1, 2.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(-1, -1, -1));\n m *= uniformScale(2. / div);\n \n vec3 sp = snd * snd * snd * snd * snd * snd * snd * snd * snd;\n gl_Position = m * vec4(p + sp * .5, 1);\n\n float z = gl_Position.z * 0.5 + 0.5;\n float sm = max(max(sp.x, sp.y), sp.z);\n float hue = 1.;//(time * 0.01 + count * 1.001);\n v_color = vec4(mix(p / div * vec3(0,1,1) * z, vec3(1,0,0), step(0.7, sm)), mix(0.8,1.5, mod(floor(vertexId * 0.33 + time * 30.0), 2.)));\n v_color.r += snd.b;\n v_color.g += snd.g;\n v_color.b /= snd.r;\n \n v_color = vec4(hsv2rgb(v_color.rbg), v_color.b * 1.2);\n gl_PointSize = mix(10.3, 0.0, z) + step(0.7, sm) * 2.;\n}" + }, "screenshotURL": "data/images/images-ljyteb19bhwlfgock-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kR26egNf7BwrsJHyM/art.json b/art/kR26egNf7BwrsJHyM/art.json index 65af7811..cbe6ff42 100644 --- a/art/kR26egNf7BwrsJHyM/art.json +++ b/art/kR26egNf7BwrsJHyM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jorenvo", "avatarUrl": "https://avatars.githubusercontent.com/jorenvo?s=200", - "settings": "{\"num\":46,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/vassvik/linear-sine-wave-sweep-30sec\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.011764705882352941,0.054901960784313725,0.24705882352941178,1],\"shader\":\"// from https://www.laurivan.com/rgb-to-hsv-to-rgb-for-shaders/\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat norm_sin(float x) {\\n \\treturn (sin(x) + 1.) / 2.;\\n}\\n\\nfloat flip(float n) {\\n return n > 0.5 ? 0. : 1.;\\n}\\n\\n/*\\n 6----7\\n /| /|\\n2----3 |\\n| 4 | 5\\n|/ |/\\n0----1\\n\\n*/\\n// render with 8 * 6 vertices in LINES\\n#define V_PER_LINE 2.\\n#define V_PER_FACE 4.\\n#define V_PER_CORNER 6.\\n#define V_PER_CUBE 8.\\n#define AVG_SAMPLES 4\\n#define FREQ_BUCKETS 1\\nvoid main() {\\n float vertex_id = floor(vertexId / V_PER_CORNER);\\n float face_id = mod(vertex_id, V_PER_FACE);\\n float corner_id = mod(vertex_id, V_PER_FACE);\\n vec3 c = vec3(mod(vertex_id, V_PER_LINE),\\n floor(corner_id / V_PER_LINE),\\n 1);\\n\\n float is_backface = floor(vertex_id / V_PER_FACE);\\n if(mod(vertexId, 2.) != 0.) {\\n \\tfloat line_point = mod(vertexId, V_PER_CORNER);\\n if (line_point >= 5.){\\n c.x = flip(c.x); \\n } else if (line_point >= 3.) {\\n c.y = flip(c.y);\\n } else if (line_point >= 1.) {\\n\\t is_backface = 1.;\\n }\\n }\\n \\n float yoffset = 0.;\\n if(c.y == 10.0) { // bottom\\n for(int i = 0; i < AVG_SAMPLES; i++) {\\n float ampl = texture2D(sound, vec2(0, i)).a;\\n \\t yoffset += ampl;// > .90 ? ampl : ampl * .95;\\n }\\n \\n \\tyoffset /= float(AVG_SAMPLES);\\n \\tfloat m = 100.;\\n \\tc.y -= pow(yoffset * m, 4.) / pow(m, 4.) * 125.;\\n }\\n \\n yoffset = 0.;\\n if(c.y == 1.0) { // top\\n for(int i = 0; i < AVG_SAMPLES; i++) {\\n float ampl = texture2D(sound, vec2(i, 50)).a;\\n \\t yoffset += ampl;\\n }\\n \\n \\tyoffset /= float(AVG_SAMPLES);\\n \\tfloat m = 100.;\\n \\tc.y += pow(yoffset * m, 4.) / pow(m, 4.) * 125.;\\n }\\n \\n float face_offset = .35 * is_backface;\\n c += face_offset;\\n \\n // go from [0,1] -> [0,2]\\n c *= 2.0;\\n \\n // go from [0,2] -> [-1, 1]\\n c -= 1.0;\\n \\n c *= .2;\\n \\n gl_Position = vec4(c, 1);\\n \\n gl_PointSize = 5.;\\n v_color = vec4(hsv2rgb(vec3(1, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 46, + "mode": "LINES", + "sound": "https://soundcloud.com/vassvik/linear-sine-wave-sweep-30sec", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.011764705882352941, + 0.054901960784313725, + 0.24705882352941178, + 1 + ], + "shader": "// from https://www.laurivan.com/rgb-to-hsv-to-rgb-for-shaders/\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat norm_sin(float x) {\n \treturn (sin(x) + 1.) / 2.;\n}\n\nfloat flip(float n) {\n return n > 0.5 ? 0. : 1.;\n}\n\n/*\n 6----7\n /| /|\n2----3 |\n| 4 | 5\n|/ |/\n0----1\n\n*/\n// render with 8 * 6 vertices in LINES\n#define V_PER_LINE 2.\n#define V_PER_FACE 4.\n#define V_PER_CORNER 6.\n#define V_PER_CUBE 8.\n#define AVG_SAMPLES 4\n#define FREQ_BUCKETS 1\nvoid main() {\n float vertex_id = floor(vertexId / V_PER_CORNER);\n float face_id = mod(vertex_id, V_PER_FACE);\n float corner_id = mod(vertex_id, V_PER_FACE);\n vec3 c = vec3(mod(vertex_id, V_PER_LINE),\n floor(corner_id / V_PER_LINE),\n 1);\n\n float is_backface = floor(vertex_id / V_PER_FACE);\n if(mod(vertexId, 2.) != 0.) {\n \tfloat line_point = mod(vertexId, V_PER_CORNER);\n if (line_point >= 5.){\n c.x = flip(c.x); \n } else if (line_point >= 3.) {\n c.y = flip(c.y);\n } else if (line_point >= 1.) {\n\t is_backface = 1.;\n }\n }\n \n float yoffset = 0.;\n if(c.y == 10.0) { // bottom\n for(int i = 0; i < AVG_SAMPLES; i++) {\n float ampl = texture2D(sound, vec2(0, i)).a;\n \t yoffset += ampl;// > .90 ? ampl : ampl * .95;\n }\n \n \tyoffset /= float(AVG_SAMPLES);\n \tfloat m = 100.;\n \tc.y -= pow(yoffset * m, 4.) / pow(m, 4.) * 125.;\n }\n \n yoffset = 0.;\n if(c.y == 1.0) { // top\n for(int i = 0; i < AVG_SAMPLES; i++) {\n float ampl = texture2D(sound, vec2(i, 50)).a;\n \t yoffset += ampl;\n }\n \n \tyoffset /= float(AVG_SAMPLES);\n \tfloat m = 100.;\n \tc.y += pow(yoffset * m, 4.) / pow(m, 4.) * 125.;\n }\n \n float face_offset = .35 * is_backface;\n c += face_offset;\n \n // go from [0,1] -> [0,2]\n c *= 2.0;\n \n // go from [0,2] -> [-1, 1]\n c -= 1.0;\n \n c *= .2;\n \n gl_Position = vec4(c, 1);\n \n gl_PointSize = 5.;\n v_color = vec4(hsv2rgb(vec3(1, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-zojv0lh8ezks53vlp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kRDzJyojeaeAei2M4/art.json b/art/kRDzJyojeaeAei2M4/art.json index 805a17e6..a837d9fe 100644 --- a/art/kRDzJyojeaeAei2M4/art.json +++ b/art/kRDzJyojeaeAei2M4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":17548,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=40344\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>30.\\n#define parameter1 0.1//KParameter1 0.>>1.\\n#define parameter2 0.1//KParameter2 0.>>1.\\n#define parameter3 .0//KParameter3 0.>>0.5\\n#define parameter4 0.//KParameter4 0.>>1.\\n#define parameter5 0.//KParameter5 0.>>1.\\n#define parameter6 0.//KParameter6 0.>>1.\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.113) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = parameter3;\\n float start = 0.4;\\n float end = start + parameter2;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \\n mat *= rotZ((parameter0 + uvfl.y * PI) * time * parameter1);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n /*\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\\n float val = 0.;\\n*/\\n v_color = vec4(parameter4,parameter5, parameter6, 1.);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n// v_color.a = 1.0 - uvf.y;\\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 17548, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=40344\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>30.\n#define parameter1 0.1//KParameter1 0.>>1.\n#define parameter2 0.1//KParameter2 0.>>1.\n#define parameter3 .0//KParameter3 0.>>0.5\n#define parameter4 0.//KParameter4 0.>>1.\n#define parameter5 0.//KParameter5 0.>>1.\n#define parameter6 0.//KParameter6 0.>>1.\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.113) + sin(t * 0.73);\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.15, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = parameter3;\n float start = 0.4;\n float end = start + parameter2;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 0.8) * .04 - min(resolution.x / resolution.y, 1.7)); \n mat *= rotZ((parameter0 + uvfl.y * PI) * time * parameter1);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n /*\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\n float val = 0.;\n*/\n v_color = vec4(parameter4,parameter5, parameter6, 1.);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n// v_color.a = 1.0 - uvf.y;\n// v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-va4dg84q5wjt773lf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kReqbFTiLEP7PXoRp/art.json b/art/kReqbFTiLEP7PXoRp/art.json index 19f9cad0..b8ce857c 100644 --- a/art/kReqbFTiLEP7PXoRp/art.json +++ b/art/kReqbFTiLEP7PXoRp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.41568627450980394,0.18823529411764706,0.5372549019607843,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define P1 3.//KParameter 0.>>4.\\n\\n\\n//KDrawmode=TRIANGLES\\n//KVerticesNumber=1000000\\n\\n#define PI radians(120.0)\\n\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,-1.5);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.15);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n mat == uniformScale(1.);\\n mat *= uniformScale(mix(1.1, 1., 1.1 - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.8, 0.4, -1));\\n\\n float hue = mix(1.8, 2.4*su, s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 1.));\\n float sat = mix(1.0, 1.-s, step(0.95, s));\\n float val = mix(0.2, 1., step(0.19, su));\\n vec3 color = hsv2rgb(vec3(hue*0.27*P1, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 1.5);\\n v_color = vec4(color * pinch(lt, 3.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.41568627450980394, + 0.18823529411764706, + 0.5372549019607843, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define P1 3.//KParameter 0.>>4.\n\n\n//KDrawmode=TRIANGLES\n//KVerticesNumber=1000000\n\n#define PI radians(120.0)\n\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,-1.5);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.15);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n mat == uniformScale(1.);\n mat *= uniformScale(mix(1.1, 1., 1.1 - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.8, 0.4, -1));\n\n float hue = mix(1.8, 2.4*su, s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 1.));\n float sat = mix(1.0, 1.-s, step(0.95, s));\n float val = mix(0.2, 1., step(0.19, su));\n vec3 color = hsv2rgb(vec3(hue*0.27*P1, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 1.5);\n v_color = vec4(color * pinch(lt, 3.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-erswykw22b6f7ygjc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kRguYk2Yft2HDLmiP/art.json b/art/kRguYk2Yft2HDLmiP/art.json index c23c2175..fcaa8222 100644 --- a/art/kRguYk2Yft2HDLmiP/art.json +++ b/art/kRguYk2Yft2HDLmiP/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":91125,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 5.0\\n\\n#define PI 3.1415\\n\\n#define RESOLUTION vec3(45.0)\\n#define SIZE vec3(1.5)\\n\\n// New hash based on hash13() from \\\"Hash without Sine\\\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\\n// 4 in, 1 out\\nfloat Hash41(in vec4 p) {\\n\\tp = fract(p * 0.1031);\\n p += dot(p, p.zwyx + 31.32);\\n return fract((p.x + p.y) * p.z - p.x * p.w);\\n}\\n\\n\\nfloat SmoothNoise4D(in vec4 p) {\\n vec4 cell = floor(p);\\n vec4 local = fract(p);\\n local *= local * (3.0 - 2.0 * local);\\n\\n float ldbq = Hash41(cell);\\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\\n float rufw = Hash41(cell + 1.0);\\n\\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\\n mix(lubq, rubq, local.x),\\n local.y),\\n\\n mix(mix(ldfq, rdfq, local.x),\\n mix(lufq, rufq, local.x),\\n local.y),\\n\\n local.z),\\n\\n mix(mix(mix(ldbw, rdbw, local.x),\\n mix(lubw, rubw, local.x),\\n local.y),\\n\\n mix(mix(ldfw, rdfw, local.x),\\n mix(lufw, rufw, local.x),\\n local.y),\\n\\n local.z),\\n\\n local.w);\\n}\\n\\nfloat FractalNoise4D(in vec4 p) {\\n p *= 2.0;\\n\\n float nscale = 1.0;\\n float tscale = 0.0;\\n float value = 0.0;\\n\\n for (int octave=0; octave < 5; octave++) {\\n value += SmoothNoise4D(p) * nscale;\\n tscale += nscale;\\n nscale *= 0.5;\\n p *= 2.0;\\n }\\n\\n return value / tscale;\\n}\\n\\nfloat mapShape(vec3 p) {\\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\\n}\\n\\nvec3 mapColor(in vec3 p) {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\\n vec2 e = vec2(0.001, 0.0);\\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\\n\\n return vec3(max(0.0, dot(normal, lightDir)) + 0.1);\\n}\\n\\nvoid main() {\\n float t = time * 0.25;\\n\\n float cellId = vertexId;\\n float gridX = mod(cellId, RESOLUTION.x);\\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\\n\\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\\n vec3 color = mapColor(vertex);\\n\\n vec2 mouseRot = mouse * PI;\\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 91125, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 5.0\n\n#define PI 3.1415\n\n#define RESOLUTION vec3(45.0)\n#define SIZE vec3(1.5)\n\n// New hash based on hash13() from \"Hash without Sine\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\n// 4 in, 1 out\nfloat Hash41(in vec4 p) {\n\tp = fract(p * 0.1031);\n p += dot(p, p.zwyx + 31.32);\n return fract((p.x + p.y) * p.z - p.x * p.w);\n}\n\n\nfloat SmoothNoise4D(in vec4 p) {\n vec4 cell = floor(p);\n vec4 local = fract(p);\n local *= local * (3.0 - 2.0 * local);\n\n float ldbq = Hash41(cell);\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\n float rufw = Hash41(cell + 1.0);\n\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\n mix(lubq, rubq, local.x),\n local.y),\n\n mix(mix(ldfq, rdfq, local.x),\n mix(lufq, rufq, local.x),\n local.y),\n\n local.z),\n\n mix(mix(mix(ldbw, rdbw, local.x),\n mix(lubw, rubw, local.x),\n local.y),\n\n mix(mix(ldfw, rdfw, local.x),\n mix(lufw, rufw, local.x),\n local.y),\n\n local.z),\n\n local.w);\n}\n\nfloat FractalNoise4D(in vec4 p) {\n p *= 2.0;\n\n float nscale = 1.0;\n float tscale = 0.0;\n float value = 0.0;\n\n for (int octave=0; octave < 5; octave++) {\n value += SmoothNoise4D(p) * nscale;\n tscale += nscale;\n nscale *= 0.5;\n p *= 2.0;\n }\n\n return value / tscale;\n}\n\nfloat mapShape(vec3 p) {\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\n}\n\nvec3 mapColor(in vec3 p) {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, 1.0));\n vec2 e = vec2(0.001, 0.0);\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\n\n return vec3(max(0.0, dot(normal, lightDir)) + 0.1);\n}\n\nvoid main() {\n float t = time * 0.25;\n\n float cellId = vertexId;\n float gridX = mod(cellId, RESOLUTION.x);\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\n\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\n vec3 color = mapColor(vertex);\n\n vec2 mouseRot = mouse * PI;\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-91t1366qo2iy6q8hv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kT6fN7Mtscfe8NeGA/art.json b/art/kT6fN7Mtscfe8NeGA/art.json index c420b042..4a1a02c5 100644 --- a/art/kT6fN7Mtscfe8NeGA/art.json +++ b/art/kT6fN7Mtscfe8NeGA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "byungchan.park", "avatarUrl": "https://secure.gravatar.com/avatar/424f43cf40258729598fe64824076748?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07450980392156863,0.050980392156862744,0.18823529411764706,1],\"shader\":\"//name : Byungchan Park\\n//assignment : Exercise - Vertexshaderart : color\\n//course name : CS250\\n//term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1; \\n float yoff = sin(time * 1.1 + x * 0.2) * 0.2;\\n\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07450980392156863, + 0.050980392156862744, + 0.18823529411764706, + 1 + ], + "shader": "//name : Byungchan Park\n//assignment : Exercise - Vertexshaderart : color\n//course name : CS250\n//term : Spring 2023\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1; \n float yoff = sin(time * 1.1 + x * 0.2) * 0.2;\n\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-xfqzgake3x9yg7ltt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kTER7eQ7zASKMtkpo/art.json b/art/kTER7eQ7zASKMtkpo/art.json index cf92de3a..82c3a374 100644 --- a/art/kTER7eQ7zASKMtkpo/art.json +++ b/art/kTER7eQ7zASKMtkpo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":2000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec3 hsl2rgb(vec3 c) {\\n c = vec3(fract(c.x), clamp(c.yz, 0.0, 1.0));\\n vec3 rgb = clamp(abs(mod(c.x * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0, 0.0, 1.0);\\n return c.z + c.y * (rgb - 0.5) * (1.0 - abs(2.0 * c.z - 1.0));\\n}\\n\\n// ---- start here ----\\n\\n\\n// original\\n// \\n\\nvoid main() {\\n // 2 points per line\\n float lineId = floor(vertexId / 2.);\\n float numLines = floor(vertexCount / 2.);\\n float i = lineId / numLines * 3.; \\n float odd = mod(vertexId, 2.);\\n \\n // g.fillStyle='hsla('+360/(i%9)+t+',100%,50%,0.3)';\\n float h = mod(i, 300.) + time;\\n float s = 1.;\\n float l = .5;\\n v_color.rgb = hsl2rgb(vec3(h,s,l));\\n v_color.a = 0.3;\\n v_color.rgb *= v_color.a;\\n \\n float lineOffset = floor(lineId / (numLines / 3.));\\n gl_Position.x = fract(i + lineOffset * 0.331) * 2. - 1.;\\n gl_Position.y = mix(0., sin(i + i * 5. + time * 10.), odd);\\n gl_Position.z = 0.;\\n gl_Position.w = 1.;\\n}\"}", + "settings": { + "num": 2000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec3 hsl2rgb(vec3 c) {\n c = vec3(fract(c.x), clamp(c.yz, 0.0, 1.0));\n vec3 rgb = clamp(abs(mod(c.x * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0, 0.0, 1.0);\n return c.z + c.y * (rgb - 0.5) * (1.0 - abs(2.0 * c.z - 1.0));\n}\n\n// ---- start here ----\n\n\n// original\n// \n\nvoid main() {\n // 2 points per line\n float lineId = floor(vertexId / 2.);\n float numLines = floor(vertexCount / 2.);\n float i = lineId / numLines * 3.; \n float odd = mod(vertexId, 2.);\n \n // g.fillStyle='hsla('+360/(i%9)+t+',100%,50%,0.3)';\n float h = mod(i, 300.) + time;\n float s = 1.;\n float l = .5;\n v_color.rgb = hsl2rgb(vec3(h,s,l));\n v_color.a = 0.3;\n v_color.rgb *= v_color.a;\n \n float lineOffset = floor(lineId / (numLines / 3.));\n gl_Position.x = fract(i + lineOffset * 0.331) * 2. - 1.;\n gl_Position.y = mix(0., sin(i + i * 5. + time * 10.), odd);\n gl_Position.z = 0.;\n gl_Position.w = 1.;\n}" + }, "screenshotURL": "data/images/images-qq13ef31pslbk4ebh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kWRaQgwjzbFw55cxw/art.json b/art/kWRaQgwjzbFw55cxw/art.json index 2cb918de..45d8c527 100644 --- a/art/kWRaQgwjzbFw55cxw/art.json +++ b/art/kWRaQgwjzbFw55cxw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * vec2(sin(time*time),cos(time*sin(time*time))), 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * vec2(sin(time*time),cos(time*sin(time*time))), 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-otechd48mxfewps2n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kWmwejucFuShxKNSa/art.json b/art/kWmwejucFuShxKNSa/art.json index 863340f3..d50cc35b 100644 --- a/art/kWmwejucFuShxKNSa/art.json +++ b/art/kWmwejucFuShxKNSa/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name:Exercise - Vertexshaderart : Motion\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x/(across-1.);\\n float v = y/(across -1.);\\n \\n float xoff = sin(time+y*0.2);\\n float yoff = sin(time+x*0.3);\\n \\n float ux = u*2.-1.+xoff;\\n float vy = v*2.-1.+yoff;\\n \\n vec2 xy = vec2(ux,vy)*1.3;\\n \\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time+x*y*0.02)*5.0;\\n \\n \\n \\n gl_PointSize = 15.0+soff;\\n gl_PointSize +=20./across;\\n gl_PointSize += resolution.x / 600.;\\n \\n v_color = vec4(abs(xy)+0.1,vy+0.1,1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name:Exercise - Vertexshaderart : Motion\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x/(across-1.);\n float v = y/(across -1.);\n \n float xoff = sin(time+y*0.2);\n float yoff = sin(time+x*0.3);\n \n float ux = u*2.-1.+xoff;\n float vy = v*2.-1.+yoff;\n \n vec2 xy = vec2(ux,vy)*1.3;\n \n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time+x*y*0.02)*5.0;\n \n \n \n gl_PointSize = 15.0+soff;\n gl_PointSize +=20./across;\n gl_PointSize += resolution.x / 600.;\n \n v_color = vec4(abs(xy)+0.1,vy+0.1,1);\n \n}" + }, "screenshotURL": "data/images/images-yfop08wyyubp1f2on-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kcWfwPALkyhAgj6ET/art.json b/art/kcWfwPALkyhAgj6ET/art.json index 40f43809..a9056a10 100644 --- a/art/kcWfwPALkyhAgj6ET/art.json +++ b/art/kcWfwPALkyhAgj6ET/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n//\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n//\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-6jtz7rp4trfxne870-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ke5bF6hENE8zphaSp/art.json b/art/ke5bF6hENE8zphaSp/art.json index ac6b045b..15d61293 100644 --- a/art/ke5bF6hENE8zphaSp/art.json +++ b/art/ke5bF6hENE8zphaSp/art.json @@ -11,7 +11,19 @@ "origId": null, "name": "torus", "username": "-anon-", - "settings": "{\"num\":16384,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/gargaj/fractured-impulse-monolithic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// nice little fun toy, i like integration with soundcloud\\n// [commercial] \\n// also check out http://polycu.be\\n// [/commercial]\\n\\n#define W 128\\n#define H 64\\n#define PI 3.1415926535\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float fv = floor(vertexId / float(W));\\n float fu = vertexId - fv*float(W);\\n fu /= float(W);\\n fv /= float(H);\\n float u = fu*2.*PI;\\n float v = fv*2.*PI;\\n u += time;\\n \\n float sin_u = sin(u), cos_u = cos(u);\\n float sin_v = sin(v), cos_v = cos(v);\\n float f = texture2D(sound, vec2(abs(fu-.5)+.1,fv*.1)).x+.05;\\n vec3 p = vec3(cos_u*(cos_v*f+1.), sin_u*(cos_v*f+1.), sin_v*f);\\n float sin_t = sin(time), cos_t = cos(time);\\n p *= mat3(cos_t,0,sin_t, 0,1,0, -sin_t,0,cos_t);\\n sin_t = sin(time*.7), cos_t = cos(time*.7);\\n p *= mat3(cos_t,sin_t,0, -sin_t,cos_t,0, 0,0,1);\\n p.x *= resolution.y/resolution.x;\\n p.z += 3.;\\n p.xy *= 3./p.z;\\n gl_Position = vec4(p.x, p.y, 1., p.z);\\n\\n v_color = vec4(hsv2rgb(vec3(fu*3., 1., 1.)), 1);\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/gargaj/fractured-impulse-monolithic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// nice little fun toy, i like integration with soundcloud\n// [commercial] \n// also check out http://polycu.be\n// [/commercial]\n\n#define W 128\n#define H 64\n#define PI 3.1415926535\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float fv = floor(vertexId / float(W));\n float fu = vertexId - fv*float(W);\n fu /= float(W);\n fv /= float(H);\n float u = fu*2.*PI;\n float v = fv*2.*PI;\n u += time;\n \n float sin_u = sin(u), cos_u = cos(u);\n float sin_v = sin(v), cos_v = cos(v);\n float f = texture2D(sound, vec2(abs(fu-.5)+.1,fv*.1)).x+.05;\n vec3 p = vec3(cos_u*(cos_v*f+1.), sin_u*(cos_v*f+1.), sin_v*f);\n float sin_t = sin(time), cos_t = cos(time);\n p *= mat3(cos_t,0,sin_t, 0,1,0, -sin_t,0,cos_t);\n sin_t = sin(time*.7), cos_t = cos(time*.7);\n p *= mat3(cos_t,sin_t,0, -sin_t,cos_t,0, 0,0,1);\n p.x *= resolution.y/resolution.x;\n p.z += 3.;\n p.xy *= 3./p.z;\n gl_Position = vec4(p.x, p.y, 1., p.z);\n\n v_color = vec4(hsv2rgb(vec3(fu*3., 1., 1.)), 1);\n}\n" + }, "screenshotDataId": "kbexK8e8mwDP5wkEi", "views": { "$numberInt": "1644" diff --git a/art/keYAR2P7hmm2ei9uF/art.json b/art/keYAR2P7hmm2ei9uF/art.json index e0648643..61062b93 100644 --- a/art/keYAR2P7hmm2ei9uF/art.json +++ b/art/keYAR2P7hmm2ei9uF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/expresswayrecords/axiom-crux-this-is-ubiquity?si=376df53447784541980aeab9b847a63e&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.123 * cgv + snd * .125);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n gl_Position = mat * vec4(pos, .25);\\n gl_PointSize = 1.;\\n \\n float pump = step(.45, snd);\\n float hue = 1.- cgId * 1.05 + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 7.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\\n v_color.rgb /= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/expresswayrecords/axiom-crux-this-is-ubiquity?si=376df53447784541980aeab9b847a63e&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time+groupId)*0.5+0.5)*0.4+0.5;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.123 * cgv + snd * .125);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n gl_Position = mat * vec4(pos, .25);\n gl_PointSize = 1.;\n \n float pump = step(.45, snd);\n float hue = 1.- cgId * 1.05 + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 7.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.95);\n v_color.rgb = mix(v_color.rgb, vec3(1.,0.,0.), pump);\n v_color.rgb /= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-0xa64yi4r9gkhttr9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kga2uesxPaH3HJqyT/art.json b/art/kga2uesxPaH3HJqyT/art.json index 439e3906..8d72d21c 100644 --- a/art/kga2uesxPaH3HJqyT/art.json +++ b/art/kga2uesxPaH3HJqyT/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hzktqr", "avatarUrl": "https://secure.gravatar.com/avatar/c5ca7d7d4b527ab960b78f57cfbe61c2?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){}" + }, "screenshotURL": "data/images/images-3xet0v9sv5pegqe1l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/khayHGH4sQWpPkn92/art.json b/art/khayHGH4sQWpPkn92/art.json index c7ed14fe..bf60873d 100644 --- a/art/khayHGH4sQWpPkn92/art.json +++ b/art/khayHGH4sQWpPkn92/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n\\n// simple xmas tree\\n// just customize with some presents!\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n if (vertexId < 90000.) {\\n float needleId = floor(vertexId/6.);\\n float subId = vertexId - needleId*6.;\\n float branch = floor(sqrt(needleId+0.5));\\n needleId -= branch*branch;\\n\\n float y = .9-branch*.01-needleId*.005 - (1.-abs(mod(subId,3.)-1.))*.06;\\n float l = needleId*.003+mod(subId,3.)*.005;\\n float a = branch * 3.88 + time + (1.-abs(mod(subId,3.)-1.))*.05/l * sign(subId-2.5);\\n\\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\\n\\n\\n gl_Position = vec4(p.xy, p.z+.5, 1);\\n\\n v_color = vec4(vec3(.3,.8,.2)*(sin(needleId*.07)*.5+2.)*.2,1);\\n } else if (vertexId < 90090.) {\\n float id = vertexId - 90000.;\\n float needleId = floor(id/3.);\\n float subId = id - needleId*3.;\\n\\n float y = .9- abs(mod(subId,3.)-1.)*1.9;\\n float l = abs(mod(subId,3.)-1.)*.03;\\n float a = time + (needleId + floor(subId*.5))*.21;\\n\\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\\n\\n\\n gl_Position = vec4(p.xy, p.z+.5, 1);\\n\\n v_color = vec4(vec3(.5,.2,0.)*(sin(needleId*.7)*.5+2.)*.2,1);\\n \\n } else {\\n float id = vertexId - 90090.;\\n float sphereId = floor(id/300.);\\n float subId = id - sphereId*300.;\\n\\n float y = sqrt(sqrt((sin(sphereId)+1.)*.5));\\n float l = (sin(sphereId*3.7)*.1+1.)*y*.45;\\n float a = y*100.+l*312. + time;\\n \\n y = .85-y*1.5;\\n\\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\\n p += vec3(cos(subId*2.3)*.6,sin(subId*2.3)-.9,0)*.08*exp(subId*subId*-.00008)+vec3(0,0,subId*-.0001);\\n\\n\\n gl_Position = vec4(p.xy, p.z+.5, 1);\\n\\n float v = vertexId*.002;\\n vec3 vc = vec3(cos(v),cos(v+2.1),cos(v-2.1))*.2+.5+subId*subId*.00002;\\n \\n v_color = vec4(vc*vc,1.);\\n \\n }\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n\n// simple xmas tree\n// just customize with some presents!\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n if (vertexId < 90000.) {\n float needleId = floor(vertexId/6.);\n float subId = vertexId - needleId*6.;\n float branch = floor(sqrt(needleId+0.5));\n needleId -= branch*branch;\n\n float y = .9-branch*.01-needleId*.005 - (1.-abs(mod(subId,3.)-1.))*.06;\n float l = needleId*.003+mod(subId,3.)*.005;\n float a = branch * 3.88 + time + (1.-abs(mod(subId,3.)-1.))*.05/l * sign(subId-2.5);\n\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\n\n\n gl_Position = vec4(p.xy, p.z+.5, 1);\n\n v_color = vec4(vec3(.3,.8,.2)*(sin(needleId*.07)*.5+2.)*.2,1);\n } else if (vertexId < 90090.) {\n float id = vertexId - 90000.;\n float needleId = floor(id/3.);\n float subId = id - needleId*3.;\n\n float y = .9- abs(mod(subId,3.)-1.)*1.9;\n float l = abs(mod(subId,3.)-1.)*.03;\n float a = time + (needleId + floor(subId*.5))*.21;\n\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\n\n\n gl_Position = vec4(p.xy, p.z+.5, 1);\n\n v_color = vec4(vec3(.5,.2,0.)*(sin(needleId*.7)*.5+2.)*.2,1);\n \n } else {\n float id = vertexId - 90090.;\n float sphereId = floor(id/300.);\n float subId = id - sphereId*300.;\n\n float y = sqrt(sqrt((sin(sphereId)+1.)*.5));\n float l = (sin(sphereId*3.7)*.1+1.)*y*.45;\n float a = y*100.+l*312. + time;\n \n y = .85-y*1.5;\n\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\n p += vec3(cos(subId*2.3)*.6,sin(subId*2.3)-.9,0)*.08*exp(subId*subId*-.00008)+vec3(0,0,subId*-.0001);\n\n\n gl_Position = vec4(p.xy, p.z+.5, 1);\n\n float v = vertexId*.002;\n vec3 vc = vec3(cos(v),cos(v+2.1),cos(v-2.1))*.2+.5+subId*subId*.00002;\n \n v_color = vec4(vc*vc,1.);\n \n }\n}" + }, "screenshotURL": "data/images/images-kveenifu7xlki1ef0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/khesbmKPst2TQsnnL/art.json b/art/khesbmKPst2TQsnnL/art.json index 0794ee00..11e14c3f 100644 --- a/art/khesbmKPst2TQsnnL/art.json +++ b/art/khesbmKPst2TQsnnL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sean", "avatarUrl": "https://lh4.googleusercontent.com/-2XVr7oP52uM/AAAAAAAAAAI/AAAAAAAAF8w/OxC5EHp2Xvk/photo.jpg", - "settings": "{\"num\":1677,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n vec2 foci[4];\\n foci[0] = vec2(0,0);\\n foci[1] = vec2(.2, sin(time));\\n foci[2] = vec2(sin(time*.3), sin(time*.3));\\n foci[3] = mouse;\\n \\n vec2 holes[3];\\n holes[0] = vec2(0.5, 0.5);\\n holes[1] = vec2(-0.7, .2);\\n holes[2] = mouse;\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n vec2 pos = vec2(ux, vy);\\n \\n \\n \\n for (int i = 0; i < 3; i++)\\n {\\n vec2 dir = foci[i] - pos;\\n float dist = length(dir);\\n \\tvec2 u_dir = dir / dist;\\n \\tvec2 offset = -0.05 * u_dir;\\n pos += offset;\\n \\n dir = holes[i] - pos;\\n dist = length(dir);\\n \\tu_dir = dir / dist;\\n \\toffset = 0.1 * u_dir;\\n \\n pos += offset;\\n }\\n \\n\\n gl_Position = vec4(pos, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(.5,.5,0,1);\\n \\n}\\n \\n\"}", + "settings": { + "num": 1677, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n vec2 foci[4];\n foci[0] = vec2(0,0);\n foci[1] = vec2(.2, sin(time));\n foci[2] = vec2(sin(time*.3), sin(time*.3));\n foci[3] = mouse;\n \n vec2 holes[3];\n holes[0] = vec2(0.5, 0.5);\n holes[1] = vec2(-0.7, .2);\n holes[2] = mouse;\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n vec2 pos = vec2(ux, vy);\n \n \n \n for (int i = 0; i < 3; i++)\n {\n vec2 dir = foci[i] - pos;\n float dist = length(dir);\n \tvec2 u_dir = dir / dist;\n \tvec2 offset = -0.05 * u_dir;\n pos += offset;\n \n dir = holes[i] - pos;\n dist = length(dir);\n \tu_dir = dir / dist;\n \toffset = 0.1 * u_dir;\n \n pos += offset;\n }\n \n\n gl_Position = vec4(pos, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(.5,.5,0,1);\n \n}\n \n" + }, "screenshotURL": "data/images/images-sb7ldapnfuxbpqfun-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/khgXvsD296RRokHhE/art.json b/art/khgXvsD296RRokHhE/art.json index b2693f19..a9d6e098 100644 --- a/art/khgXvsD296RRokHhE/art.json +++ b/art/khgXvsD296RRokHhE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Colors\\n// Course : CS250\\n// Spring 2023\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main()\\n{\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time *1.1 + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n // [0, 1)\\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05; \\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Colors\n// Course : CS250\n// Spring 2023\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main()\n{\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time *1.1 + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n // [0, 1)\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05; \n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-f72eb7ren8bdnzwds-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kiZueaqhT8s7yr7Tr/art.json b/art/kiZueaqhT8s7yr7Tr/art.json index fd070f8a..a9a52302 100644 --- a/art/kiZueaqhT8s7yr7Tr/art.json +++ b/art/kiZueaqhT8s7yr7Tr/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/christopher-camplin/qlabmilano\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 0 0 0 0 1 1 1 1 1 1 1\\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n\\n float ux = floor(id / 6.0) + mod(id, 2.);\\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\\n //\\t 0 0 1 1 2 2 3 3 4 4 5 5 6\\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\\n // _____________________________\\n //\\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\\t\\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.0;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n \\n return vec2(x, y);\\n}\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n \\t// \\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float cols = floor(sqrt(numCubes));\\n float rows = floor(numCubes / cols);\\n \\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(cubeId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(cubeId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat c = cos(PI * time + x * 0.25);\\n \\tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\\n \\tfloat yOff = cos(time + x * 0.25) * 0.2;\\n \\tfloat zOff = sin(time * x * y * 0.005) * 0.05;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\\\\\n\\n float ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. - zOff;\\n\\n \\t// concentrate on center\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\n // circular - atan returns values between PI & -PI\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n // sound\\n\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\\n \\tscl *= 20. / rows;\\t\\n \\t//vec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\\n \\tfloat z = -pow(snd + c, 2.) - zOff + snd;\\n \\t//pos -= vec3(circleXY, z);\\n \\tmat4 mat = ident();\\n float tm = time * 0.1;\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.5) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n //mat *= cameraLookAt(eye, target, up);\\n\\n \\tmat *= scale(vec3(1, aspect, 1));\\n mat *= rotX(radians(45. * mouse.x * mouse.y));\\n //mat *= rotY(radians(-45.));\\n \\tmat *= rotZ(time * 0.1);\\n\\tmat += transpose(mat * snd * mouse.x * mouse.y);\\n \\tmat *= trans(vec3(ux, vy, 0) * 1.3);\\n \\tmat *= uniformScale(0.02 * scl);\\n \\tmat *= rotY(PI * snd * 0.1 * sign(ux));\\n \\tmat *= rotZ(time * sign(ux));\\n \\n\\tgl_Position = mat * vec4(pos, 1.);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n \\n \\tfloat pump = step(0.6, snd);\\n float hue = 0.5 - pump * mouse.x * 0.1;\\n hue = hue + smoothstep(x, y, snd);\\n float sat = 0.8;\\n \\t// add more impact using pow\\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\\n \\t//val += oddSlice;\\n vec3 color = vec3(hsv2rgb(vec3(fract(hue), sat, val)));\\n //color *= snd;\\n //background += 0.1;\\n \\tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\\n //vec3 finalColor = mix(vec4(color, 1.), background, s);\\n\\t//finalColor = mix(color, newColor, c);\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n }\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/christopher-camplin/qlabmilano", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float vy = mod(floor(id / 2.0) + floor( id / 3.0), 2.);\n // floor: division; throw away the remainder 000000 111111 222222 333333 444444\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 0 0 0 0 1 1 1 1 1 1 1\n // + 0 1 0 1 0 1 0 1 0 1 0 1 0\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n\n float ux = floor(id / 6.0) + mod(id, 2.);\n // id: 0 1 2 3 4 5 6 7 8 9 10 11 12\n //\t 0 0 1 1 2 2 3 3 4 4 5 5 6\n // + 0 0 0 1 1 1 2 2 2 3 3 3 4\n // _____________________________\n //\t= 0 1 0 1 0 1 0 2 1 2 1 2 1\t\n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.0;\n\n float x = c * radius;\n float y = s * radius;\n\n \n return vec2(x, y);\n}\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n \t// \n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float cols = floor(sqrt(numCubes));\n float rows = floor(numCubes / cols);\n \n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0); // ) if it's even, one if it's odd\n \t// vertex ID is number of the vertex\n \tfloat x = mod(cubeId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(cubeId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat c = cos(PI * time + x * 0.25);\n \tfloat xOff = sin(PI * time * 1.5 + y * 0.25) * 0.01;\n \tfloat yOff = cos(time + x * 0.25) * 0.2;\n \tfloat zOff = sin(time * x * y * 0.005) * 0.05;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\\\n\n float ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. - zOff;\n\n \t// concentrate on center\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat su = abs(u - 0.5) * 2.0;\n \n // circular - atan returns values between PI & -PI\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n // sound\n\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \tfloat aspect = resolution.x / resolution.y;\n \tfloat scl = pow(snd + 0.2, 5.); //* mix(1., 1.1, oddSlice); //mix: multiply by 1.0 or 1.1 if it's odd or even\n \tscl *= 20. / rows;\t\n \t//vec2 xy = circleXY * 0.1 * scl + vec2(ux, vy) * 1.25;\n \tfloat z = -pow(snd + c, 2.) - zOff + snd;\n \t//pos -= vec3(circleXY, z);\n \tmat4 mat = ident();\n float tm = time * 0.1;\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.5) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n //mat *= cameraLookAt(eye, target, up);\n\n \tmat *= scale(vec3(1, aspect, 1));\n mat *= rotX(radians(45. * mouse.x * mouse.y));\n //mat *= rotY(radians(-45.));\n \tmat *= rotZ(time * 0.1);\n\tmat += transpose(mat * snd * mouse.x * mouse.y);\n \tmat *= trans(vec3(ux, vy, 0) * 1.3);\n \tmat *= uniformScale(0.02 * scl);\n \tmat *= rotY(PI * snd * 0.1 * sign(ux));\n \tmat *= rotZ(time * sign(ux));\n \n\tgl_Position = mat * vec4(pos, 1.);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n \n \tfloat pump = step(0.6, snd);\n float hue = 0.5 - pump * mouse.x * 0.1;\n hue = hue + smoothstep(x, y, snd);\n float sat = 0.8;\n \t// add more impact using pow\n float val = 1.0; //mix(.1, pow(snd + 0.2, 5.), pump);pow(snd + 0.1, 5.0);\n \t//val += oddSlice;\n vec3 color = vec3(hsv2rgb(vec3(fract(hue), sat, val)));\n //color *= snd;\n //background += 0.1;\n \tvec4 newColor = vec4(0.25, 0.02, 0.5, 1.0);\n //vec3 finalColor = mix(vec4(color, 1.), background, s);\n\t//finalColor = mix(color, newColor, c);\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n }\n\n" + }, "screenshotURL": "data/images/images-xa6pg16zvcen1ldio-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kmHZWuJ5wjmz7RQzS/art.json b/art/kmHZWuJ5wjmz7RQzS/art.json index ded21118..3cfc6f3b 100644 --- a/art/kmHZWuJ5wjmz7RQzS/art.json +++ b/art/kmHZWuJ5wjmz7RQzS/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "przemyslawzaworski", "avatarUrl": "https://secure.gravatar.com/avatar/3a3abcfa29dc9b0fa9fd2fb25ff10892?default=retro&size=200", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// In absence of bitwise operators in WebGL 1.0:\\n// https://gist.github.com/EliCDavis/f35a9e4afb8e1c9ae94cce8f3c2c9b9a\\nint AND(int n1, int n2)\\n{ \\n\\tfloat v1 = float(n1);\\n\\tfloat v2 = float(n2); \\n\\tint byteVal = 1;\\n\\tint result = 0;\\n\\tfor(int i = 0; i < 32; i++)\\n\\t{\\n\\t\\tbool keepGoing = v1 > 0.0 || v2 > 0.0;\\n\\t\\tif(keepGoing)\\n\\t\\t{\\n\\t\\t\\tbool addOn = mod(v1, 2.0) > 0.0 && mod(v2, 2.0) > 0.0; \\n\\t\\t\\tif(addOn) result += byteVal; \\n\\t\\t\\tv1 = floor(v1 / 2.0);\\n\\t\\t\\tv2 = floor(v2 / 2.0);\\n\\t\\t\\tbyteVal *= 2;\\n\\t\\t} \\n\\t\\telse \\n\\t\\t{\\n\\t\\t\\treturn result;\\n\\t\\t}\\n\\t}\\n\\treturn result;\\n}\\n\\nvec3 hash(vec2 p)\\n{\\n\\tvec2 a0 = fract(p*3.14159265359*(1./1024.))*1024.;\\n\\tvec2 a1 = fract(a0*a0*(1./1739.))*1739.;\\n\\tvec2 a2 = a1.yx + fract(a1*a1*(1./1739.))*1739.;\\n\\tvec2 a3 = a2.yx + fract(a2*a2*(1./1739.))*1739.;\\n\\treturn fract((a2.xyx + a3.xxy + a1.xyy)*(1./1739.));\\n}\\n\\n// GPU PRO 3, Advanced Rendering Techniques, A K Peters/CRC Press 2012\\n// Chapter 1 - Vertex shader tessellation, Holger Gruen\\nvoid main() \\n{\\n \\t\\n\\tint id = int(vertexId);\\n\\tint tessellationFactor = int(max(floor((sin(time*0.5)*0.5+0.5)*32.),2.0));\\n\\tif (id > (tessellationFactor * tessellationFactor * 3)) return; \\n\\tvec3 p1 = vec3( 0.00, 0.75, 0.00);\\n\\tvec3 p2 = vec3( 0.75, -0.75, 0.00);\\n\\tvec3 p3 = vec3(-0.75, -0.75, 0.00);\\n\\tint subtriangles = (tessellationFactor * tessellationFactor);\\n\\tfloat triangleID = mod(float( id / 3 ), float(subtriangles)); \\n\\tfloat row = floor (sqrt( triangleID ));\\n\\tint column = int(triangleID - ( row * row ));\\n\\tfloat incuv = 1.0 / float(tessellationFactor);\\n\\tfloat u = (1.0 + row) / float(tessellationFactor);\\n\\tfloat v = incuv * floor (float(column) * 0.5);\\n\\tu -= v;\\n\\tfloat w = 1.0 - u - v;\\n\\tint vID = int(float(id / 3 / subtriangles) * 3. + mod(float(id), 3.));\\n\\tint remainder = int(mod(float(vID), 3.0));\\n\\tif (remainder == 0)\\n\\t{\\n\\t\\tif (AND(column, 1) != 0)\\n\\t\\t{\\n\\t\\t\\tv += incuv, u -= incuv;\\n\\t\\t}\\n\\t}\\n\\telse if (remainder == 1)\\n\\t{\\n\\t\\tif (AND(column, 1) == 0)\\n\\t\\t{\\n\\t\\t\\tv += incuv, u -= incuv;\\n\\t\\t}\\n\\t\\telse\\n\\t\\t{\\n\\t\\t\\tv += incuv, u -= incuv;\\n\\t\\t\\tw += incuv, u -= incuv;\\n\\t\\t}\\n\\t}\\n\\telse if (remainder == 2)\\n\\t{\\n\\t\\tif (AND(column, 1) == 0)\\n\\t\\t{\\n\\t\\t\\tu -= incuv, w += incuv;\\n\\t\\t}\\n\\t\\telse \\n\\t\\t{\\n\\t\\t\\tw += incuv, u -= incuv;\\n\\t\\t}\\n\\t}\\n\\tgl_Position = vec4(u * p1 + v * p2 + w * p3, 1.0);\\n\\tv_color = vec4(hash(vec2(triangleID , triangleID + 19999.)), 1);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// In absence of bitwise operators in WebGL 1.0:\n// https://gist.github.com/EliCDavis/f35a9e4afb8e1c9ae94cce8f3c2c9b9a\nint AND(int n1, int n2)\n{ \n\tfloat v1 = float(n1);\n\tfloat v2 = float(n2); \n\tint byteVal = 1;\n\tint result = 0;\n\tfor(int i = 0; i < 32; i++)\n\t{\n\t\tbool keepGoing = v1 > 0.0 || v2 > 0.0;\n\t\tif(keepGoing)\n\t\t{\n\t\t\tbool addOn = mod(v1, 2.0) > 0.0 && mod(v2, 2.0) > 0.0; \n\t\t\tif(addOn) result += byteVal; \n\t\t\tv1 = floor(v1 / 2.0);\n\t\t\tv2 = floor(v2 / 2.0);\n\t\t\tbyteVal *= 2;\n\t\t} \n\t\telse \n\t\t{\n\t\t\treturn result;\n\t\t}\n\t}\n\treturn result;\n}\n\nvec3 hash(vec2 p)\n{\n\tvec2 a0 = fract(p*3.14159265359*(1./1024.))*1024.;\n\tvec2 a1 = fract(a0*a0*(1./1739.))*1739.;\n\tvec2 a2 = a1.yx + fract(a1*a1*(1./1739.))*1739.;\n\tvec2 a3 = a2.yx + fract(a2*a2*(1./1739.))*1739.;\n\treturn fract((a2.xyx + a3.xxy + a1.xyy)*(1./1739.));\n}\n\n// GPU PRO 3, Advanced Rendering Techniques, A K Peters/CRC Press 2012\n// Chapter 1 - Vertex shader tessellation, Holger Gruen\nvoid main() \n{\n \t\n\tint id = int(vertexId);\n\tint tessellationFactor = int(max(floor((sin(time*0.5)*0.5+0.5)*32.),2.0));\n\tif (id > (tessellationFactor * tessellationFactor * 3)) return; \n\tvec3 p1 = vec3( 0.00, 0.75, 0.00);\n\tvec3 p2 = vec3( 0.75, -0.75, 0.00);\n\tvec3 p3 = vec3(-0.75, -0.75, 0.00);\n\tint subtriangles = (tessellationFactor * tessellationFactor);\n\tfloat triangleID = mod(float( id / 3 ), float(subtriangles)); \n\tfloat row = floor (sqrt( triangleID ));\n\tint column = int(triangleID - ( row * row ));\n\tfloat incuv = 1.0 / float(tessellationFactor);\n\tfloat u = (1.0 + row) / float(tessellationFactor);\n\tfloat v = incuv * floor (float(column) * 0.5);\n\tu -= v;\n\tfloat w = 1.0 - u - v;\n\tint vID = int(float(id / 3 / subtriangles) * 3. + mod(float(id), 3.));\n\tint remainder = int(mod(float(vID), 3.0));\n\tif (remainder == 0)\n\t{\n\t\tif (AND(column, 1) != 0)\n\t\t{\n\t\t\tv += incuv, u -= incuv;\n\t\t}\n\t}\n\telse if (remainder == 1)\n\t{\n\t\tif (AND(column, 1) == 0)\n\t\t{\n\t\t\tv += incuv, u -= incuv;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tv += incuv, u -= incuv;\n\t\t\tw += incuv, u -= incuv;\n\t\t}\n\t}\n\telse if (remainder == 2)\n\t{\n\t\tif (AND(column, 1) == 0)\n\t\t{\n\t\t\tu -= incuv, w += incuv;\n\t\t}\n\t\telse \n\t\t{\n\t\t\tw += incuv, u -= incuv;\n\t\t}\n\t}\n\tgl_Position = vec4(u * p1 + v * p2 + w * p3, 1.0);\n\tv_color = vec4(hash(vec2(triangleID , triangleID + 19999.)), 1);\n}" + }, "screenshotURL": "data/images/images-dyruw6q6d1pz74oq5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kmN3hqhTHv4SCqYcx/art.json b/art/kmN3hqhTHv4SCqYcx/art.json index eb15e29e..31664823 100644 --- a/art/kmN3hqhTHv4SCqYcx/art.json +++ b/art/kmN3hqhTHv4SCqYcx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n// Tuned via XShade (http://www.funparadigm.com/xshad\\n#define kp0 12.//KParameter -12.>>22.\\n#define kp1 2.//KParameter -2.>>2.\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(90.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,2,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 1.1415926\\n#define _05pi 2.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 8.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.20*kp1;\\n \\tvec2 height = vec2(22.*kp1,0.6);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n//KDrawmode=GL_TRIANGLE_STRIP\n// Tuned via XShade (http://www.funparadigm.com/xshad\n#define kp0 12.//KParameter -12.>>22.\n#define kp1 2.//KParameter -2.>>2.\n\n////////////////////////////////////////////////////////////\n#define PI radians(90.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,2,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 1.1415926\n#define _05pi 2.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 8.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.20*kp1;\n \tvec2 height = vec2(22.*kp1,0.6);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-b695s6en17kjgxda6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kmm2Kb8Ti4vcYGQri/art.json b/art/kmm2Kb8Ti4vcYGQri/art.json index ee6280b8..2f2e8877 100644 --- a/art/kmm2Kb8Ti4vcYGQri/art.json +++ b/art/kmm2Kb8Ti4vcYGQri/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Making a grid\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Making a grid\n// Course Name: CS250\n// Term: Spring 2022\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-vhmpk0ubo5ohzag1m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ko66wgrdNeNbx9WDz/art.json b/art/ko66wgrdNeNbx9WDz/art.json index 3b2e2fdd..49f74c86 100644 --- a/art/ko66wgrdNeNbx9WDz/art.json +++ b/art/ko66wgrdNeNbx9WDz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":31941,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/takugotbeats/night-17?in=helennpham/sets/lofi-hip-hop&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.9176470588235294,0,1],\"shader\":\"#define NUM 1.\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float a = mod(vertexCount, down);\\n float cad = a + down / NUM;\\n \\n float x = mod(vertexId, NUM);\\n float y = floor(vertexId / NUM);\\n \\n float u = x * NUM / cad;\\n float v = y * NUM / cad;\\n \\n float ux = u * 5.0 / cad;\\n float vy = v * 2.0 / cad;\\n \\n float snd = pow(texture2D(sound, vec2(ux * 0.01, vy * 0.01)).a, 4.);\\n \\n gl_PointSize = 10.0;\\n \\n gl_Position = vec4(x / cad + snd, y / cad, 4.9, 5);\\n \\n v_color = vec4(1, 2, 4, 5);\\n}\"}", + "settings": { + "num": 31941, + "mode": "POINTS", + "sound": "https://soundcloud.com/takugotbeats/night-17?in=helennpham/sets/lofi-hip-hop&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.9176470588235294, + 0, + 1 + ], + "shader": "#define NUM 1.\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float a = mod(vertexCount, down);\n float cad = a + down / NUM;\n \n float x = mod(vertexId, NUM);\n float y = floor(vertexId / NUM);\n \n float u = x * NUM / cad;\n float v = y * NUM / cad;\n \n float ux = u * 5.0 / cad;\n float vy = v * 2.0 / cad;\n \n float snd = pow(texture2D(sound, vec2(ux * 0.01, vy * 0.01)).a, 4.);\n \n gl_PointSize = 10.0;\n \n gl_Position = vec4(x / cad + snd, y / cad, 4.9, 5);\n \n v_color = vec4(1, 2, 4, 5);\n}" + }, "screenshotURL": "data/images/images-nxrc35d6f0s6kkgxa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/koFtCvuibJTEPuswi/art.json b/art/koFtCvuibJTEPuswi/art.json index 25bc7220..877d479d 100644 --- a/art/koFtCvuibJTEPuswi/art.json +++ b/art/koFtCvuibJTEPuswi/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n//KDrawmode=GL_\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0.2, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -0.2,\\n yAxis, -0.7,\\n zAxis, s,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), s); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 3.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.81;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.*s;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf -= 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 0.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 3.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, qu, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\\n vec3 n0 = getQuadPoint(nId + 0.1, s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.*-mouse.x);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, s, 0.5+s));\\n \\n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-s*(mouse.x*0.5));\\n \\n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 4.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y);\\n v_color = mix(v_color, background, 0.2 * cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n//KDrawmode=GL_\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0.2, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -0.2,\n yAxis, -0.7,\n zAxis, s,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), s); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 3.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.81;\n\tf = 0.5000*noise( p ); p = mr*p*2.*s;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf -= 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 0.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 3.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, qu, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\n vec3 n0 = getQuadPoint(nId + 0.1, s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.*-mouse.x);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, s, 0.5+s));\n \n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-s*(mouse.x*0.5));\n \n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 4.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y);\n v_color = mix(v_color, background, 0.2 * cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-eol6flav1bkhsub6k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kpxXuKKj3zwRaQ23J/art.json b/art/kpxXuKKj3zwRaQ23J/art.json index eef08797..61fea4e3 100644 --- a/art/kpxXuKKj3zwRaQ23J/art.json +++ b/art/kpxXuKKj3zwRaQ23J/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":45000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1803921568627451,0.2627450980392157,0.25098039215686274,1],\"shader\":\"#define pi 3.14159\\n#define Dir(a) vec2(cos(a), sin(a))\\n\\nvoid main() {\\n float vc = vertexCount;\\n float svc = sqrt(vertexCount);\\n float id = vertexId;\\n id /= vc;\\n \\n float t = 0.3 * time;\\n \\n\\n vec2 uv = vec2(mod(vertexId, svc), floor(vertexId / svc)) / svc - 0.5;\\n \\n float d = 0.;\\n const float n = 12.;\\n for (float i = 0.; i < n; i++) {\\n \\tfloat a = atan(uv.y, uv.x);\\n \\tvec2 dir = 0.1 * sin(2.*a + t) * Dir(8.*pi*uv.x) \\n \\t + 0.1 * cos(2.*a + t) * Dir(8.*pi*uv.y);\\n \\td += length(dir);\\n \\tuv += dir; \\n }\\n\\n gl_Position = vec4(uv, 0, 1);\\n gl_PointSize = 3.*(1.-exp(-0.5*d*d));\\n v_color = vec4(4. * exp(-d*d));\\n}\\n\"}", + "settings": { + "num": 45000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1803921568627451, + 0.2627450980392157, + 0.25098039215686274, + 1 + ], + "shader": "#define pi 3.14159\n#define Dir(a) vec2(cos(a), sin(a))\n\nvoid main() {\n float vc = vertexCount;\n float svc = sqrt(vertexCount);\n float id = vertexId;\n id /= vc;\n \n float t = 0.3 * time;\n \n\n vec2 uv = vec2(mod(vertexId, svc), floor(vertexId / svc)) / svc - 0.5;\n \n float d = 0.;\n const float n = 12.;\n for (float i = 0.; i < n; i++) {\n \tfloat a = atan(uv.y, uv.x);\n \tvec2 dir = 0.1 * sin(2.*a + t) * Dir(8.*pi*uv.x) \n \t + 0.1 * cos(2.*a + t) * Dir(8.*pi*uv.y);\n \td += length(dir);\n \tuv += dir; \n }\n\n gl_Position = vec4(uv, 0, 1);\n gl_PointSize = 3.*(1.-exp(-0.5*d*d));\n v_color = vec4(4. * exp(-d*d));\n}\n" + }, "screenshotURL": "data/images/images-dlr1602tjq4skbp8k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kqeeKhm5BKJ8vexmL/art.json b/art/kqeeKhm5BKJ8vexmL/art.json index 8b3a99e0..3e8a2be4 100644 --- a/art/kqeeKhm5BKJ8vexmL/art.json +++ b/art/kqeeKhm5BKJ8vexmL/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"///GLSL\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\\n /*RGB */\\n v_color = vec4(0.0, .0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "///GLSL\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1);\n /*RGB */\n v_color = vec4(0.0, .0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-wsz0i65rrew3zfip0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kuj37HBHLw5zWqqTD/art.json b/art/kuj37HBHLw5zWqqTD/art.json index 66e19238..69f5536a 100644 --- a/art/kuj37HBHLw5zWqqTD/art.json +++ b/art/kuj37HBHLw5zWqqTD/art.json @@ -26,7 +26,19 @@ "name": "cobweb", "private": true, "username": "kabuto", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n sin(i*.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76),\\n sin(i*.79553+2.1) +\\n sin(i*1.1311+2.1) +\\n sin(i*1.353-2.1) +\\n sin(i*.476-2.1),\\n sin(i*.5553-2.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*.36+2.1)\\n\\t)*.2;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n cos(i*.9553)*.9553 +\\n cos(i) +\\n cos(i*1.53)*1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*1.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n cos(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*.2;\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n vec3 pos = posf2(vertexId*.002);\\n vec3 posd = posf2d(vertexId*.002);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n posd.yz *= m;\\n posd.zx *= m2;\\n\\n pos.z += .7;\\n float blurDist = .7;\\n \\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n gl_PointSize = size+blur;\\n\\n vec3 colour = abs(normalize(posd));\\n \\n v_color = vec4(size/(size+blur)*size/(size+blur))*length(posd)*2.*vec4(colour,1.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76),\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476-2.1),\n sin(i*.5553-2.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*.36+2.1)\n\t)*.2;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n cos(i*.9553)*.9553 +\n cos(i) +\n cos(i*1.53)*1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*1.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n cos(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*.2;\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n vec3 pos = posf2(vertexId*.002);\n vec3 posd = posf2d(vertexId*.002);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n posd.yz *= m;\n posd.zx *= m2;\n\n pos.z += .7;\n float blurDist = .7;\n \n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n gl_PointSize = size+blur;\n\n vec3 colour = abs(normalize(posd));\n \n v_color = vec4(size/(size+blur)*size/(size+blur))*length(posd)*2.*vec4(colour,1.);\n}" + }, "screenshotURL": "data/images/images-5w3tgve905gqu11ix-thumbnail.jpg", "views": { "$numberInt": "4" diff --git a/art/kwFY2DhDLc57jBEKg/art.json b/art/kwFY2DhDLc57jBEKg/art.json index 1b4f8b4b..0b969e9e 100644 --- a/art/kwFY2DhDLc57jBEKg/art.json +++ b/art/kwFY2DhDLc57jBEKg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom =3.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.7,1. ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 0.4, 1.0);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom =3.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.7,1. ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 0.4, 1.0);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-s9y66gudoj1qz35ot-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/kwpkNNSAmpsM6G7DB/art.json b/art/kwpkNNSAmpsM6G7DB/art.json index 3e8fe08c..ceb81ae5 100644 --- a/art/kwpkNNSAmpsM6G7DB/art.json +++ b/art/kwpkNNSAmpsM6G7DB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.054901960784313725,0.25882352941176473,1],\"shader\":\"\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n float u = x / (across-1.);\\n float v = y / (across-1.); \\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n \\n\\n\\n v_color = vec4(0, 1, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.054901960784313725, + 0.25882352941176473, + 1 + ], + "shader": "\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n float u = x / (across-1.);\n float v = y / (across-1.); \n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n \n\n\n v_color = vec4(0, 1, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ssczqusw55ei5q9sn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/kyrjHeuSM5skDfpNo/art.json b/art/kyrjHeuSM5skDfpNo/art.json index 6292e5f0..163fd309 100644 --- a/art/kyrjHeuSM5skDfpNo/art.json +++ b/art/kyrjHeuSM5skDfpNo/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":837,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n // float a = vertexId /20.;\\n float x = mod(vertexId, 10.);\\n float y = floor(vertexId /10.);\\n float u = x/10.;\\n float v = y/10.;\\n float ucorr = (u*2.)-1.;\\n float vcorr = (v*2.)-1.;\\n \\n gl_Position = vec4(ucorr, vcorr, 0, 1);\\n gl_PointSize = 10.;\\n v_color = vec4(1, 0, 0, 1);\\n \\n}\\n\"}", + "settings": { + "num": 837, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n // float a = vertexId /20.;\n float x = mod(vertexId, 10.);\n float y = floor(vertexId /10.);\n float u = x/10.;\n float v = y/10.;\n float ucorr = (u*2.)-1.;\n float vcorr = (v*2.)-1.;\n \n gl_Position = vec4(ucorr, vcorr, 0, 1);\n gl_PointSize = 10.;\n v_color = vec4(1, 0, 0, 1);\n \n}\n" + }, "screenshotURL": "data/images/images-d48640mgldk59utzh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/m64jEsLp4hidcsd7a/art.json b/art/m64jEsLp4hidcsd7a/art.json index bf66c143..c374ccaa 100644 --- a/art/m64jEsLp4hidcsd7a/art.json +++ b/art/m64jEsLp4hidcsd7a/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Color exercise\\n//2022 spring\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time/2. + y * 0.2 ) * 0.1;\\n float yoff = sin(time/2. * x * 0.3 ) ; //may can remove last one\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 2.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) ;\\n float sat = 0.5;\\n float val = sin(time * 1.4 * v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Color exercise\n//2022 spring\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time/2. + y * 0.2 ) * 0.1;\n float yoff = sin(time/2. * x * 0.3 ) ; //may can remove last one\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 2.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) ;\n float sat = 0.5;\n float val = sin(time * 1.4 * v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-az15a58bufjv3iz47-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/m6Sw7fXzNji9JqQRk/art.json b/art/m6Sw7fXzNji9JqQRk/art.json index a2192d8f..59b62cac 100644 --- a/art/m6Sw7fXzNji9JqQRk/art.json +++ b/art/m6Sw7fXzNji9JqQRk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":20150,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.;\\n float down = numQuads / around -1.1;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI *.1+r) * r;\\n float y = sin(qu * PI *-1.012) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * mix(0.01,mouse.x,-.05) * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = sin(quadId *.01813333333);\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.b = v_color.r;\\n}\"}", + "settings": { + "num": 20150, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * .27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.;\n float down = numQuads / around -1.1;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI *.1+r) * r;\n float y = sin(qu * PI *-1.012) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * mix(0.01,mouse.x,-.05) * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .125, resolution.x / resolution.y,5.101, 111.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * -.19) * 11.0 + 0.1, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(time*1.2-cos(time*.1666))-1.*sin(time),0.22);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = sin(quadId *.01813333333);\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.b = v_color.r;\n}" + }, "screenshotURL": "data/images/images-lrrjprp4nc8lvdpi3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/m9FwKSvyF6tR6wxKy/art.json b/art/m9FwKSvyF6tR6wxKy/art.json index 0c309fb7..75354a6a 100644 --- a/art/m9FwKSvyF6tR6wxKy/art.json +++ b/art/m9FwKSvyF6tR6wxKy/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Colors\\n// CS250 Spring 2022\\n\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = sin(time + y * 0.2) * 0.1;\\n float yOffset = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float saturation = 1.0;\\n float value = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Colors\n// CS250 Spring 2022\n\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = sin(time + y * 0.2) * 0.1;\n float yOffset = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float sizeOffset = sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float saturation = 1.0;\n float value = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-z7j8355d4202us7vt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mAZixq6fNzd7qSpQs/art.json b/art/mAZixq6fNzd7qSpQs/art.json index c8e5c946..2d59aa0d 100644 --- a/art/mAZixq6fNzd7qSpQs/art.json +++ b/art/mAZixq6fNzd7qSpQs/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "demoniak", "avatarUrl": "https://avatars.githubusercontent.com/johanberonius?s=200", - "settings": "{\"num\":20000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/victorruiz/robots\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * 4.), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * 4.), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * 1.4;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n// normal.xz *= rotateX;\\n// normal.yz *= rotateY;\\n \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -1.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/victorruiz/robots", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * 4.), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * 4.), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * 1.4;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n// normal.xz *= rotateX;\n// normal.yz *= rotateY;\n \n\n \n float screenZ = -0.;\n float eyeZ = -1.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-aym3fl4txz1wdqhif-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mAic85DgmMrZTGaph/art.json b/art/mAic85DgmMrZTGaph/art.json index 6b1aaa8f..b40cb52e 100644 --- a/art/mAic85DgmMrZTGaph/art.json +++ b/art/mAic85DgmMrZTGaph/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "dailylightdebris", "avatarUrl": "https://secure.gravatar.com/avatar/4db47dcfffbaa9c15631f445ed4951ea?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 2.0 * (mouse.y+2.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 1.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 2.0 * (mouse.y+2.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/2.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 1.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-9mdg4pv8yd55lnoxe-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mAzBS3pdAM6PxJku9/art.json b/art/mAzBS3pdAM6PxJku9/art.json index d82aa1e6..521a21c1 100644 --- a/art/mAzBS3pdAM6PxJku9/art.json +++ b/art/mAzBS3pdAM6PxJku9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":12010,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Motion\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.01) * 0.5;\\n float yoff = sin(time + x ) * sin(time);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(sin(xy), 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 500.0;\\n v_color = (vec4(0.75-ux*ux, 0.75-vy*vy, 0.75-ux*vy, 1));\\n}\"}", + "settings": { + "num": 12010, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Motion\ncourse name : CS250\nterm : 2022 Spring\n*/\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.01) * 0.5;\n float yoff = sin(time + x ) * sin(time);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(sin(xy), 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 500.0;\n v_color = (vec4(0.75-ux*ux, 0.75-vy*vy, 0.75-ux*vy, 1));\n}" + }, "screenshotURL": "data/images/images-uds5z9znotnbxqock-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mBEqnn3WYWhAt7vLy/art.json b/art/mBEqnn3WYWhAt7vLy/art.json index 9f0ddd8d..b103791b 100644 --- a/art/mBEqnn3WYWhAt7vLy/art.json +++ b/art/mBEqnn3WYWhAt7vLy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":18099,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.3254901960784314,0.34901960784313724,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n//KVerticesNumber=18000\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 12.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 3.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle + 3. );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 2.); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, -0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, -1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0.01, 0.3);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0.2, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n\\n 1.1 -s, 0, 0, 0.1,\\n 0, s, 0, -.025,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 2) /2.;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(111.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. + 0.1;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 55.) + floor(id / 3.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 11.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 0.1, level);\\n float a = mix(start, end, u) * PI * 2. - PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 2./ s *.04;\\n float z = 0.1;\\n pos = vec3(x, y -1., z ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(.1, mod(circleId*22., 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles -parameter4;\\n vec3 pos;\\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - 1.3 +time ; start - hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n\\n float snd = texture2D(sound, vec2((cu + abs(uv.x / 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.000203) * 11.4;\\n offset.y += goop(circleId + time * 0.000013) *1.31*mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 *snd);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6*snd, fract(circleId + 10.79));\\n float sat = 0.9 - circleId;\\n float val = .75;sin(\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (0.2 - uv.y) * pow(snd*2.*uv.x*parameter6, snd+2.2-time)));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a+.6);\\n}\"}", + "settings": { + "num": 18099, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.3254901960784314, + 0.34901960784313724, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n//KVerticesNumber=18000\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 12.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 1.2, 3.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle + 3. );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 2.); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, -0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, -1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0.01, 0.3);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0.2, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n\n 1.1 -s, 0, 0, 0.1,\n 0, s, 0, -.025,\n 0, 0, s, 0,\n 0, 0, 0.1, 2) /2.;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 2.4427));\n p2 += dot(p2.yx, p2.xy + vec2(111.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. + 0.1;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 55.) + floor(id / 3.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE -2.01);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 11.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 0.1, level);\n float a = mix(start, end, u) * PI * 2. - PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 2./ s *.04;\n float z = 0.1;\n pos = vec3(x, y -1., z ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t - 3.+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(.1, mod(circleId*22., 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles -parameter4;\n vec3 pos;\n float inner = mix(-0.73, 2.2, p1m1(sin(goop(circleId) / sin(time - 1.1))));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - 1.3 +time ; start - hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n\n float snd = texture2D(sound, vec2((cu + abs(uv.x / 1.8 )) * 0.025, uv.y + parameter6 - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.000203) * 11.4;\n offset.y += goop(circleId + time * 0.000013) *1.31*mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 2.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.12)).xyz, parameter3 *snd);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6*snd, fract(circleId + 10.79));\n float sat = 0.9 - circleId;\n float val = .75;sin(\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (0.2 - uv.y) * pow(snd*2.*uv.x*parameter6, snd+2.2-time)));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a+.6);\n}" + }, "screenshotURL": "data/images/images-zy3wq7pw7m0zmz4bs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mBsFXyLJxoL2yPqjz/art.json b/art/mBsFXyLJxoL2yPqjz/art.json index 5288ff4f..fa0daf6f 100644 --- a/art/mBsFXyLJxoL2yPqjz/art.json +++ b/art/mBsFXyLJxoL2yPqjz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1734,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.4549019607843137,0.5058823529411764,1],\"shader\":\"// Simple Line which responds to music\\n// This is intended to be super simple, to learn how to use VertexShaderArt\\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\\n\\nvoid main()\\n{\\n // vertex_percent is vertexId mapped to [0..1]\\n float nb_circles = 10.0;\\n float nbpointspercircle = vertexCount/nb_circles;\\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\\n \\n // sound texture has (amplitude, history) for (u,v). \\n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\\n // It is all in the alpha channel of the sound texture\\n \\n // Set y position to amplitude in [0..1] range.\\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\\n float y = -0.5+2.0*texture2D(sound,vec2(0.5*vertex_percent,0.0)).a*0.5; \\n \\n float r = 0.1;\\n float posx = r*(mod(vertexId, nb_circles)+1.0) * cos(vertex_percent*2.0*3.14)*0.5*((y*2.0)-1.0);\\n float posy = r*(mod(vertexId, nb_circles)+1.0) * sin(vertex_percent*2.0*3.14)*0.5*((y*2.0)-1.0);\\n \\n \\n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\\n gl_Position = vec4(posx,posy,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\\n v_color = vec4(sin(time)*sin(time), y+1.0, 50.0*vertex_percent*y, 1.0);\\n vec4 aa = background;\\n} \\n\\n\"}", + "settings": { + "num": 1734, + "mode": "POINTS", + "sound": "https://soundcloud.com/mortengranau/motorcycle-as-the-rush-comes-metronome-morten-granau-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.4549019607843137, + 0.5058823529411764, + 1 + ], + "shader": "// Simple Line which responds to music\n// This is intended to be super simple, to learn how to use VertexShaderArt\n// If you're just beginning please feel free to experiment with this or use as a starting point for your shaders\n\nvoid main()\n{\n // vertex_percent is vertexId mapped to [0..1]\n float nb_circles = 10.0;\n float nbpointspercircle = vertexCount/nb_circles;\n float vertex_percent = (vertexId) / (vertexCount-1.0); // We use -1.0 to ensure a point exists at the end\n float x = (vertex_percent*2.0-1.0)*0.7; // Mapping vertex_percent [0..1] to X screen range, which is [-1..1]\n \n // sound texture has (amplitude, history) for (u,v). \n // u range is [0..1]: 0 is lowest bass, 1 is highest treble\n // v range is [0..1]: 0 is right now, 1 is 4 seconds in the past\n // It is all in the alpha channel of the sound texture\n \n // Set y position to amplitude in [0..1] range.\n // Y will be 1.0 at peak amplitude (top of screen) and 0.0 for silence (middle of screen)\n float y = -0.5+2.0*texture2D(sound,vec2(0.5*vertex_percent,0.0)).a*0.5; \n \n float r = 0.1;\n float posx = r*(mod(vertexId, nb_circles)+1.0) * cos(vertex_percent*2.0*3.14)*0.5*((y*2.0)-1.0);\n float posy = r*(mod(vertexId, nb_circles)+1.0) * sin(vertex_percent*2.0*3.14)*0.5*((y*2.0)-1.0);\n \n \n gl_PointSize = 5.0; // Set point size in case want to render points instead of line, not used in line\n gl_Position = vec4(posx,posy,0,1); // simply plot onto screen space at z=0 with opacity=1, screen range is [-1..1] for both x and y\n v_color = vec4(sin(time)*sin(time), y+1.0, 50.0*vertex_percent*y, 1.0);\n vec4 aa = background;\n} \n\n" + }, "screenshotURL": "data/images/images-h2paqfm9n19o4vpgv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mCcXsBtD9XZ5LAoW8/art.json b/art/mCcXsBtD9XZ5LAoW8/art.json index d8d8306b..fd201231 100644 --- a/art/mCcXsBtD9XZ5LAoW8/art.json +++ b/art/mCcXsBtD9XZ5LAoW8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":45106,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/graham-panter/synthahol\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 4.);\\n float quadId = floor(vertexId / 4.);\\n float down = floor(sqrt(numQuads));\\n float across = floor(numQuads / down);\\n \\n float gx = mod(quadId, across);\\n float gy = floor(quadId / across);\\n \\n float vId = mod(vertexId, 4.);\\n \\n float x = gx + mod(vId, 2.) - step(3., vId);\\n float y = gy + step(3., vId);\\n\\n \\n \\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\\n \\n vec2 sp = xy * aspect * 1.1;\\n \\n const int count = 60;\\n for (int i = 0; i < count; ++i) {\\n float iv = 1. - float(i) / float(count - 1);\\n float hist = (float(i) + 0.5) / soundRes.y;\\n vec2 m = texture2D(touch, vec2(0, hist)).xy;\\n vec2 dm = m - sp;\\n float dist = length(dm);\\n float effect = mix(1., 0., clamp(dist * 3., 0., 1.));\\n sp = sp - dm * pow(abs(effect), 2.5) * 0.5 * pow(iv, 5.);\\n }\\n \\n float ang = fract(time * + abs(atan(sp.x, sp.y) / PI));\\n float rad = length(sp);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.030, ang), rad * 0.2)).a;\\n \\n sp += pow(snd, 5.) * 0.025;\\n \\n \\n gl_Position = vec4(sp, 0, 1);\\n \\n float pump = step(1., snd);\\n\\n v_color = vec4(vec3(mix(0.1, 1., pow(snd, 5.))), 1);\\n \\n v_color = mix(v_color, vec4(1,0,0,1), pump);\\n}\"}", + "settings": { + "num": 45106, + "mode": "LINES", + "sound": "https://soundcloud.com/graham-panter/synthahol", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n float numQuads = floor(vertexCount / 4.);\n float quadId = floor(vertexId / 4.);\n float down = floor(sqrt(numQuads));\n float across = floor(numQuads / down);\n \n float gx = mod(quadId, across);\n float gy = floor(quadId / across);\n \n float vId = mod(vertexId, 4.);\n \n float x = gx + mod(vId, 2.) - step(3., vId);\n float y = gy + step(3., vId);\n\n \n \n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\n \n vec2 sp = xy * aspect * 1.1;\n \n const int count = 60;\n for (int i = 0; i < count; ++i) {\n float iv = 1. - float(i) / float(count - 1);\n float hist = (float(i) + 0.5) / soundRes.y;\n vec2 m = texture2D(touch, vec2(0, hist)).xy;\n vec2 dm = m - sp;\n float dist = length(dm);\n float effect = mix(1., 0., clamp(dist * 3., 0., 1.));\n sp = sp - dm * pow(abs(effect), 2.5) * 0.5 * pow(iv, 5.);\n }\n \n float ang = fract(time * + abs(atan(sp.x, sp.y) / PI));\n float rad = length(sp);\n float snd = texture2D(sound, vec2(mix(0.001, 0.030, ang), rad * 0.2)).a;\n \n sp += pow(snd, 5.) * 0.025;\n \n \n gl_Position = vec4(sp, 0, 1);\n \n float pump = step(1., snd);\n\n v_color = vec4(vec3(mix(0.1, 1., pow(snd, 5.))), 1);\n \n v_color = mix(v_color, vec4(1,0,0,1), pump);\n}" + }, "screenshotURL": "data/images/images-lcgkadxafc26sz0vk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mD6W2p47kSDX2WqK4/art.json b/art/mD6W2p47kSDX2WqK4/art.json index ffee07c8..e1828c0a 100644 --- a/art/mD6W2p47kSDX2WqK4/art.json +++ b/art/mD6W2p47kSDX2WqK4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5165,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVertexCount=12000.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 12.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner =mouse.y;\\n float start = mouse.x;\\n float end =step(0.13,0.5+s);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n //vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.4123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(-t * .63 +s) * 10., sin(t * .4+s)*20.*s, 0.);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up =vec3(0,1,0.5);\\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n float VertexCount = 50000.*(mouse.x*mouse.y);\\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .017);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 8.5 +s *s* .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s *1.8, 6.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\\n float sat =1.0;step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb /= v_color.a*s;\\n \\n float super = step(0.9, 1.-s);\\n v_color = mix(v_color, vec4(s-1.,0,0,0.7), super);\\n \\n}\\n\"}", + "settings": { + "num": 5165, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-2-old-gregg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVertexCount=12000.\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 12.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner =mouse.y;\n float start = mouse.x;\n float end =step(0.13,0.5+s);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n //vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.4123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,1.2*rd,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(-t * .63 +s) * 10., sin(t * .4+s)*20.*s, 0.);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up =vec3(0,1,0.5);\n // vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n float VertexCount = 50000.*(mouse.x*mouse.y);\n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .017);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 8.5 +s *s* .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s *1.8, 6.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .21 + time * .1;// + groupId * 0.5;\n float sat =1.0;step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb /= v_color.a*s;\n \n float super = step(0.9, 1.-s);\n v_color = mix(v_color, vec4(s-1.,0,0,0.7), super);\n \n}\n" + }, "screenshotURL": "data/images/images-ka4ooo1ckn1ev851e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mDEaiqSfNT6Lxq4A7/art.json b/art/mDEaiqSfNT6Lxq4A7/art.json index 92809e5f..51623857 100644 --- a/art/mDEaiqSfNT6Lxq4A7/art.json +++ b/art/mDEaiqSfNT6Lxq4A7/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "gman", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.6039215686274509,0.5137254901960784,1],\"shader\":\"/*\\n __ .__ .___ __ \\n___ __ ____________/ |_ ____ ___ ___ _____| |__ _____ __| _/________________ ________/ |_ \\n\\\\ \\\\/ // __ \\\\_ __ \\\\ __\\\\/ __ \\\\\\\\ \\\\/ / / ___/ | \\\\\\\\__ \\\\ / __ |/ __ \\\\_ __ \\\\__ \\\\\\\\_ __ \\\\ __\\\\\\n \\\\ /\\\\ ___/| | \\\\/| | \\\\ ___/ > < \\\\___ \\\\| Y \\\\/ __ \\\\_/ /_/ \\\\ ___/| | \\\\// __ \\\\| | \\\\/| | \\n \\\\_/ \\\\___ >__| |__| \\\\___ >__/\\\\_ \\\\/____ >___| (____ /\\\\____ |\\\\___ >__| (____ /__| |__| \\n \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\nvoid getCirclePoint(const float id, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);//outId / (NUM_EDGE_POINTS_PER_CIRCLE - 1.);\\n float vy = mod(floor(id / 2.), 2.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(0.5, 1., vy);\\n float a = u * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = s * v;\\n float y = c * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n getCirclePoint(vertexId, pos); \\n \\n float sideId = floor(circleId / 2.);// + floor(time * 10.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n vec3 offset = vec3(hash(sideId), m1p1(hash(sideId * 0.37)), 0);\\n offset.x += goop(sideId + time) * 0.1;\\n offset.y += goop(sideId + time * 1.13) * 0.1;\\n offset.x *= side;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n float snd = 0.;\\n\\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.2, hash(sideId)) + pow(snd, 5.0) * 0.1);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.3, 0.8, fract(sideId * 0.79));\\n float sat = 0.5;\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.6039215686274509, + 0.5137254901960784, + 1 + ], + "shader": "/*\n __ .__ .___ __ \n___ __ ____________/ |_ ____ ___ ___ _____| |__ _____ __| _/________________ ________/ |_ \n\\ \\/ // __ \\_ __ \\ __\\/ __ \\\\ \\/ / / ___/ | \\\\__ \\ / __ |/ __ \\_ __ \\__ \\\\_ __ \\ __\\\n \\ /\\ ___/| | \\/| | \\ ___/ > < \\___ \\| Y \\/ __ \\_/ /_/ \\ ___/| | \\// __ \\| | \\/| | \n \\_/ \\___ >__| |__| \\___ >__/\\_ \\/____ >___| (____ /\\____ |\\___ >__| (____ /__| |__| \n \\/ \\/ \\/ \\/ \\/ \\/ \\/ \\/ \\/ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \nvoid getCirclePoint(const float id, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);//outId / (NUM_EDGE_POINTS_PER_CIRCLE - 1.);\n float vy = mod(floor(id / 2.), 2.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(0.5, 1., vy);\n float a = u * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = s * v;\n float y = c * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n getCirclePoint(vertexId, pos); \n \n float sideId = floor(circleId / 2.);// + floor(time * 10.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n vec3 offset = vec3(hash(sideId), m1p1(hash(sideId * 0.37)), 0);\n offset.x += goop(sideId + time) * 0.1;\n offset.y += goop(sideId + time * 1.13) * 0.1;\n offset.x *= side;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n float snd = 0.;\n\n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.2, hash(sideId)) + pow(snd, 5.0) * 0.1);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.3, 0.8, fract(sideId * 0.79));\n float sat = 0.5;\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-qq4t22ph8jayug9dz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mEjRHW328Fknag6wR/art.json b/art/mEjRHW328Fknag6wR/art.json index 9aec5495..13f4c2ea 100644 --- a/art/mEjRHW328Fknag6wR/art.json +++ b/art/mEjRHW328Fknag6wR/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":48000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/elektrik-dreams-music/analog-trip-for-love-chill-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = 2.;//floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = 1.0;//floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float NUM_POINTS_PER_PAIR = NUM_POINTS_PER_CIRCLE * 2.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_PAIR);\\n float circlePart = mod(floor(vertexId / NUM_POINTS_PER_CIRCLE), 2.0);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = circlePart * 2.;\\n float start = 0.;\\n float end = start + 1.0;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n \\n float tm = 0.0;//time * 0.1;\\n float r = 30.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(0, 0, 5); //vec3(cos(tm) * r, sin(tm * 0.9) * .0 + 0., sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(0, 0, -(cu * 2.0) - circlePart * 0.01));\\n float rot = uvfl.y * -PI * 2. * abs(sin(time * 0.1)) + time;\\n mat *= rotY(sin(time * 0.97) * 0.5);\\n mat *= rotX(sin(time * 0.731) * 0.5);\\n mat *= rotX(-0.5);\\n mat *= uniformScale(mix(1.0, 1.00 - pow(cu, 4.0), circlePart) * cu * 30.0);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.6, 0.4, fract(cu * 30.0));//time * 0.0 + modStep(uvfl.w, 2.);// * abs(sin(time * 0.13));\\n float sat = mix(.1, 1.0, mod(floor(circleId / 2.0), 2.0));// + sin(time * 0.07) * 0.3;\\n float val = 1.;//t5p5(abs(sin(rot)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, vec4(0, 0, 0, 1), mod(circlePart, 2.0));\\n \\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 48000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/elektrik-dreams-music/analog-trip-for-love-chill-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = 2.;//floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = 1.0;//floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float NUM_POINTS_PER_PAIR = NUM_POINTS_PER_CIRCLE * 2.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_PAIR);\n float circlePart = mod(floor(vertexId / NUM_POINTS_PER_CIRCLE), 2.0);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = circlePart * 2.;\n float start = 0.;\n float end = start + 1.0;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n \n float tm = 0.0;//time * 0.1;\n float r = 30.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(0, 0, 5); //vec3(cos(tm) * r, sin(tm * 0.9) * .0 + 0., sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(0, 0, -(cu * 2.0) - circlePart * 0.01));\n float rot = uvfl.y * -PI * 2. * abs(sin(time * 0.1)) + time;\n mat *= rotY(sin(time * 0.97) * 0.5);\n mat *= rotX(sin(time * 0.731) * 0.5);\n mat *= rotX(-0.5);\n mat *= uniformScale(mix(1.0, 1.00 - pow(cu, 4.0), circlePart) * cu * 30.0);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.6, 0.4, fract(cu * 30.0));//time * 0.0 + modStep(uvfl.w, 2.);// * abs(sin(time * 0.13));\n float sat = mix(.1, 1.0, mod(floor(circleId / 2.0), 2.0));// + sin(time * 0.07) * 0.3;\n float val = 1.;//t5p5(abs(sin(rot)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, vec4(0, 0, 0, 1), mod(circlePart, 2.0));\n \n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-nq6mhpq8ieqolgdeo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mFBiFkPxwQ73XQizR/art.json b/art/mFBiFkPxwQ73XQizR/art.json index b0b7334b..111cc514 100644 --- a/art/mFBiFkPxwQ73XQizR/art.json +++ b/art/mFBiFkPxwQ73XQizR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":2027,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2784313725490196,0.24313725490196078,0.24313725490196078,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Audio Reactive Art exercise\\n//2022 spring\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0);\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1+ x * 0.3) * 0.2; //may can remove last one\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05,av * .25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump =step(0.8,snd);\\n float hue = u * .1 +snd * 0.2 + time * .1;//+ sin(time + v * 20.) * 0.05;\\n float sat = mix(0.,1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd + 0.2,5.),pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n}\"}", + "settings": { + "num": 2027, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2784313725490196, + 0.24313725490196078, + 0.24313725490196078, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Audio Reactive Art exercise\n//2022 spring\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0);\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1+ x * 0.3) * 0.2; //may can remove last one\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05,av * .25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump =step(0.8,snd);\n float hue = u * .1 +snd * 0.2 + time * .1;//+ sin(time + v * 20.) * 0.05;\n float sat = mix(0.,1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd + 0.2,5.),pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n}" + }, "screenshotURL": "data/images/images-t9in9drpzdqjo8iuz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mFDp3QZvpN8MbqN9R/art.json b/art/mFDp3QZvpN8MbqN9R/art.json index 3bec818d..bf563b3e 100644 --- a/art/mFDp3QZvpN8MbqN9R/art.json +++ b/art/mFDp3QZvpN8MbqN9R/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":511,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Audio Reactive\\n// CS250 Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;\\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 511, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Audio Reactive\n// CS250 Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-vkho7xkk5ema72z2j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mFr92RbhPmuJXKXWK/art.json b/art/mFr92RbhPmuJXKXWK/art.json index 1de15998..5f229a91 100644 --- a/art/mFr92RbhPmuJXKXWK/art.json +++ b/art/mFr92RbhPmuJXKXWK/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":11610,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define RESOLUTION vec2(45.0)\\n\\n#define PI 3.1415\\n\\nstruct VertexAndNormal {\\n vec3 pos;\\n vec3 nor;\\n};\\n\\nVertexAndNormal getPos(in float id) {\\n float t1 = time * 0.5, t2 = time, t3 = time * 1.25;\\n\\n float c1 = cos(t1), s1 = sin(t1);\\n float c2 = cos(t2), s2 = sin(t2);\\n float c3 = cos(t3), s3 = sin(t3);\\n\\n vec3 a = vec3(c3, s2, s1) * 1.25;\\n vec3 b = vec3(s3 * s2, c1, s3) * 1.25;\\n vec3 c = vec3(c2, c1, s3) * 1.25;\\n vec3 d = vec3(s1, c2 * c3, s2) * 1.25;\\n\\n float fid = floor(id / 6.0);\\n int cid = int(mod(id, 6.0));\\n\\n vec2 edgeStep = 1.0 / RESOLUTION;\\n\\n float x = mod(fid, RESOLUTION.x);\\n float y = (fid - x) / RESOLUTION.x;\\n\\n float u = x / RESOLUTION.x;\\n float v = y / RESOLUTION.y;\\n\\n vec3 v1 = mix(mix(a, b, u + edgeStep.x), mix(c, d, u + edgeStep.x), v);\\n vec3 v2 = mix(mix(a, b, u), mix(c, d, u), v);\\n vec3 v3 = mix(mix(a, b, u), mix(c, d, u), v + edgeStep.y);\\n vec3 nor = normalize(cross(v2 - v1, v3 - v1));\\n\\n if (cid == 1) u += edgeStep.x;\\n if (cid == 2 || cid == 3) u += edgeStep.x, v += edgeStep.y;\\n if (cid == 4) v += edgeStep.y;\\n\\n vec3 pos = mix(mix(a, b, u), mix(c, d, u), v);\\n return VertexAndNormal(pos, nor);\\n}\\n\\nvoid main() {\\n //vec3 light = normalize(vec3(-1.0, 1.0, 1.0));\\n\\n //vec2 mouseRot = mouse * PI;\\n //float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n //float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n\\n VertexAndNormal vertex = getPos(vertexId);\\n //vertex.pos.xz *= mat2(cy, sy, -sy, cy);\\n //vertex.pos.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.pos.xy / (EYE_DISTANCE - vertex.pos.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.pos.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n v_color = vec4(abs(vertex.nor), 1.0);\\n}\"}", + "settings": { + "num": 11610, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define RESOLUTION vec2(45.0)\n\n#define PI 3.1415\n\nstruct VertexAndNormal {\n vec3 pos;\n vec3 nor;\n};\n\nVertexAndNormal getPos(in float id) {\n float t1 = time * 0.5, t2 = time, t3 = time * 1.25;\n\n float c1 = cos(t1), s1 = sin(t1);\n float c2 = cos(t2), s2 = sin(t2);\n float c3 = cos(t3), s3 = sin(t3);\n\n vec3 a = vec3(c3, s2, s1) * 1.25;\n vec3 b = vec3(s3 * s2, c1, s3) * 1.25;\n vec3 c = vec3(c2, c1, s3) * 1.25;\n vec3 d = vec3(s1, c2 * c3, s2) * 1.25;\n\n float fid = floor(id / 6.0);\n int cid = int(mod(id, 6.0));\n\n vec2 edgeStep = 1.0 / RESOLUTION;\n\n float x = mod(fid, RESOLUTION.x);\n float y = (fid - x) / RESOLUTION.x;\n\n float u = x / RESOLUTION.x;\n float v = y / RESOLUTION.y;\n\n vec3 v1 = mix(mix(a, b, u + edgeStep.x), mix(c, d, u + edgeStep.x), v);\n vec3 v2 = mix(mix(a, b, u), mix(c, d, u), v);\n vec3 v3 = mix(mix(a, b, u), mix(c, d, u), v + edgeStep.y);\n vec3 nor = normalize(cross(v2 - v1, v3 - v1));\n\n if (cid == 1) u += edgeStep.x;\n if (cid == 2 || cid == 3) u += edgeStep.x, v += edgeStep.y;\n if (cid == 4) v += edgeStep.y;\n\n vec3 pos = mix(mix(a, b, u), mix(c, d, u), v);\n return VertexAndNormal(pos, nor);\n}\n\nvoid main() {\n //vec3 light = normalize(vec3(-1.0, 1.0, 1.0));\n\n //vec2 mouseRot = mouse * PI;\n //float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n //float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n\n VertexAndNormal vertex = getPos(vertexId);\n //vertex.pos.xz *= mat2(cy, sy, -sy, cy);\n //vertex.pos.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.pos.xy / (EYE_DISTANCE - vertex.pos.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.pos.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n v_color = vec4(abs(vertex.nor), 1.0);\n}" + }, "screenshotURL": "data/images/images-cz9gbdzg0o72kd02f-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mHgyhLsuwpJinyxDH/art.json b/art/mHgyhLsuwpJinyxDH/art.json index 72a0fef4..a4f1a611 100644 --- a/art/mHgyhLsuwpJinyxDH/art.json +++ b/art/mHgyhLsuwpJinyxDH/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cristianvarela/ken-ishii-play-biting-cristian\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21176470588235294,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 30.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.5, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvec3 getRandomCubePoint(float seed) {\\n vec3 p = vec3(\\n m1p1(hash(seed)), \\n m1p1(hash(seed * 0.731)),\\n m1p1(hash(seed * 1.319)));\\n float axis = hash(seed * 0.911) * 3.;\\n if (axis < 1.) {\\n p[0] = mix(-1., 1., step(0., p[0]));\\n } else if (axis < 2.) {\\n p[1] = mix(-1., 1., step(0., p[1]));\\n } else {\\n p[2] = mix(-1., 1., step(0., p[2]));\\n }\\n return p;\\n}\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * .5));\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n //vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n //vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = getRandomCubePoint(fCubeId * 0.177);\\n vec3 ax = (rotZ(PI * 0.25) * rotY(PI * 0.25) * vec4(vCubeOrigin, 1)).xyz;\\n vCubeOrigin += (vec3(hash(fCubeId * 0.317), hash(fCubeId * 0.591), hash(fCubeId * 0.781)) * 2. - 1.) * 0.01;\\n //vCubeOrigin += sign(vCubeOrigin);\\n vCubeOrigin *= 32.0;\\n \\n float ps = p1m1(atan(ax.y, ax.z) / PI);\\n float snd = texture2D(sound, vec2(mix(0.006, 0.019, ps), p1m1(ax.x / 1.4142) * 0.5)).a;\\n float beat = 0.;texture2D(sound, vec2(0.007, 0)).a;\\n \\n vCubeOrigin += normalize(vec3(PI * 0.25, PI * .25, 0)) * snd * -8.;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin + sign(normalize(vCubeOrigin)) * pow(snd, 5.) * -0.);\\n mat *= rotZ(p1m1(snd) * 20.);\\n mat *= rotY(p1m1(snd) * 20.);\\n mat *= uniformScale(mix(1.5, 1.5, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \\n 0.3, //st,//pow(snd, 0.), \\n pow(snd, 5.)));\\n // vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,-20,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,5.-snd), step(mix(0.9, 0.55, ps), snd));\\n vCubeCol.a =1.- snd;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( sin(time * 0.13) * -20., -20., sin(time * 0.13) * -20.0 );\\n \\tvec3 vCameraPos = vec3(5) + vec3(sin(time * 0.1) * 7., sin(time * 0.17) * 7., cos(time * 0.1) * 7.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( mouse.y, 1, mouse.x);\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(90.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;//min( gExposure, sin( time * 0.21) );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cristianvarela/ken-ishii-play-biting-cristian", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 30.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.5, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvec3 getRandomCubePoint(float seed) {\n vec3 p = vec3(\n m1p1(hash(seed)), \n m1p1(hash(seed * 0.731)),\n m1p1(hash(seed * 1.319)));\n float axis = hash(seed * 0.911) * 3.;\n if (axis < 1.) {\n p[0] = mix(-1., 1., step(0., p[0]));\n } else if (axis < 2.) {\n p[1] = mix(-1., 1., step(0., p[1]));\n } else {\n p[2] = mix(-1., 1., step(0., p[2]));\n }\n return p;\n}\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * .5));\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n //vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n //vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = getRandomCubePoint(fCubeId * 0.177);\n vec3 ax = (rotZ(PI * 0.25) * rotY(PI * 0.25) * vec4(vCubeOrigin, 1)).xyz;\n vCubeOrigin += (vec3(hash(fCubeId * 0.317), hash(fCubeId * 0.591), hash(fCubeId * 0.781)) * 2. - 1.) * 0.01;\n //vCubeOrigin += sign(vCubeOrigin);\n vCubeOrigin *= 32.0;\n \n float ps = p1m1(atan(ax.y, ax.z) / PI);\n float snd = texture2D(sound, vec2(mix(0.006, 0.019, ps), p1m1(ax.x / 1.4142) * 0.5)).a;\n float beat = 0.;texture2D(sound, vec2(0.007, 0)).a;\n \n vCubeOrigin += normalize(vec3(PI * 0.25, PI * .25, 0)) * snd * -8.;\n \n mat = ident();\n mat *= trans(vCubeOrigin + sign(normalize(vCubeOrigin)) * pow(snd, 5.) * -0.);\n mat *= rotZ(p1m1(snd) * 20.);\n mat *= rotY(p1m1(snd) * 20.);\n mat *= uniformScale(mix(1.5, 1.5, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h, st), \n 0.3, //st,//pow(snd, 0.), \n pow(snd, 5.)));\n // vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,-20,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,5.-snd), step(mix(0.9, 0.55, ps), snd));\n vCubeCol.a =1.- snd;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( sin(time * 0.13) * -20., -20., sin(time * 0.13) * -20.0 );\n \tvec3 vCameraPos = vec3(5) + vec3(sin(time * 0.1) * 7., sin(time * 0.17) * 7., cos(time * 0.1) * 7.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( mouse.y, 1, mouse.x);\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(90.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;//min( gExposure, sin( time * 0.21) );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-divw09ujzictphpq4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mHhjmNiF2DCevuYMz/art.json b/art/mHhjmNiF2DCevuYMz/art.json index 817a8aa9..f7e9a8b9 100644 --- a/art/mHhjmNiF2DCevuYMz/art.json +++ b/art/mHhjmNiF2DCevuYMz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":30511,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Colors Assignment\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. -1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 3. + v * 20.) * 2.05;\\n float sat = 1.;\\n float val = sin(-time * 7. + v * u * 10.0) * .3 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n\\n}\"}", + "settings": { + "num": 30511, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Colors Assignment\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. -1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 3. + v * 20.) * 2.05;\n float sat = 1.;\n float val = sin(-time * 7. + v * u * 10.0) * .3 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n\n}" + }, "screenshotURL": "data/images/images-2u64rc9d3h1edpm9z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mJLSnvDjL3N6wkYDR/art.json b/art/mJLSnvDjL3N6wkYDR/art.json index 00de8134..a3d44330 100644 --- a/art/mJLSnvDjL3N6wkYDR/art.json +++ b/art/mJLSnvDjL3N6wkYDR/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "guilleperez", "avatarUrl": "https://avatars.githubusercontent.com/guilleperez?s=200", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/nightclubband/show-it-2-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.5019607843137255,1,1],\"shader\":\"void main() \\n{\\n float width = 10.0;\\n float x = mod(vertexId, width); \\n float y = floor(vertexId / width);\\n \\n float u = x /(width - 1.0);\\n float v = y / (width - 1.0);\\n \\n \\n //Desfamiento\\n //desfazamiento + [x = diferente] * r\\n float xOffset = cos(time + y) * 0.1;\\n float yOffset = sin(time + x) * 0.1;\\n \\n\\n //Acomodar en los cuadrantes\\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n \\n vec2 xy = vec2(ux, uy); //se puede crear vec4 con vectores 2 -> vec4(xy, 0.0, 1.0);\\n \\n gl_Position = vec4(xy, 0.0, 1.0); //position del vec4\\n v_color = vec4(1.0, 0.0, 0.0, 1.0); //color\\n gl_PointSize = 20.0;\\n}\\n\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "https://soundcloud.com/nightclubband/show-it-2-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.5019607843137255, + 1, + 1 + ], + "shader": "void main() \n{\n float width = 10.0;\n float x = mod(vertexId, width); \n float y = floor(vertexId / width);\n \n float u = x /(width - 1.0);\n float v = y / (width - 1.0);\n \n \n //Desfamiento\n //desfazamiento + [x = diferente] * r\n float xOffset = cos(time + y) * 0.1;\n float yOffset = sin(time + x) * 0.1;\n \n\n //Acomodar en los cuadrantes\n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n \n vec2 xy = vec2(ux, uy); //se puede crear vec4 con vectores 2 -> vec4(xy, 0.0, 1.0);\n \n gl_Position = vec4(xy, 0.0, 1.0); //position del vec4\n v_color = vec4(1.0, 0.0, 0.0, 1.0); //color\n gl_PointSize = 20.0;\n}\n" + }, "screenshotURL": "data/images/images-jho3j3dzxbxj9i28v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mJadpKnhXS6qgpQ5g/art.json b/art/mJadpKnhXS6qgpQ5g/art.json index 59b2d1ed..ab9e1aee 100644 --- a/art/mJadpKnhXS6qgpQ5g/art.json +++ b/art/mJadpKnhXS6qgpQ5g/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Circles from Triangles\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4 (\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main() {\\n float numCircleSegments = 42.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(0.5, 2., oddSlice);\\n \\n sc += 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.5);\\n mat *= trans(vec3(ux, vy, 0) * snd * 3.);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.02 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0.5 * snd, 1., pump); //mix(1., -10.,av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * 20.) * .05;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Circles from Triangles\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4 (\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main() {\n float numCircleSegments = 42.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(0.5, 2., oddSlice);\n \n sc += 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.5);\n mat *= trans(vec3(ux, vy, 0) * snd * 3.);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.02 * sc);\n \n gl_Position = mat * pos;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0.5 * snd, 1., pump); //mix(1., -10.,av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * 20.) * .05;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-tz93zniv5b3sq1nav-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mLtQNvFM6AJhHKbYq/art.json b/art/mLtQNvFM6AJhHKbYq/art.json index e661da81..7562eea8 100644 --- a/art/mLtQNvFM6AJhHKbYq/art.json +++ b/art/mLtQNvFM6AJhHKbYq/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "abjeni", "avatarUrl": "https://secure.gravatar.com/avatar/91501fff291d7e034ce6fecaebc60854?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n#define NUM_CUBES (SIZE*SIZE*SIZE)\\n#define NUM_TRIANGLES (NUM_CUBES*18)\\n#define NUM_VERTICES (NUM_TRIANGLES*6)\\n\\n#define STEP 5.0\\n\\n#define ipol(corners,values,id1, id2) mix(corners[id1].xyz,corners[id2].xyz,values[id1]/(values[id1]-values[id2]))\\n\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nvec3 camPath(float t){\\n \\n //return vec3(0, 0, t); // Straight path.\\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\\n \\n //float s = sin(t/24.)*cos(t/12.);\\n //return vec3(s*12., 0., t);\\n \\n float a = sin(t * 0.11);\\n float b = cos(t * 0.14);\\n return vec3(a*4. -b*1.5, b*1.7 + a*1.5, t);\\n \\n}\\n\\n//https://www.shadertoy.com/view/4ttGDH\\nfloat map(vec3 p){\\n \\n p.xy -= camPath(p.z).xy; // Perturb the object around the camera path.\\n \\n p *= 0.4;\\n \\n\\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\\n \\n \\n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\\n \\n return n-1.0;\\n \\n}\\n\\nvoid main() {\\n \\n float speed = 10.0;\\n \\n vec3 wpos = vec3(0);\\n \\n vec3 pos = camPath(time*speed);\\n \\n vec3 lookat = camPath(time*speed+2.0);\\n vec3 forward = normalize(lookat-pos);\\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\\n vec3 up = cross(forward,left);\\n \\n float cid = floor(vertexId/30.0);\\n int tid = int(floor(vertexId/6.0)-cid*5.0);\\n int vid = int(mod(vertexId,6.0));\\n \\n \\n \\n float size = floor(pow(vertexCount/30.0,1.0/3.0));\\n \\n vec3 cpos = vec3(\\n mod(floor(cid),size),\\n mod(floor(cid/size),size),\\n floor(cid/size/size))\\n -vec2(floor(size*0.5),0).xxy+floor(pos);\\n \\n \\n\\n mat4 corners = mat4(\\n 0,0,0,0,\\n 0,1,1,0,\\n 1,0,1,0,\\n 1,1,0,0\\n );\\n\\n bool flip = tid == 4;\\n if (!flip) {\\n if (tid == 0) corners[0].xyz = 1.0-corners[0].xyz;\\n if (tid == 1) corners[1].xyz = 1.0-corners[1].xyz;\\n if (tid == 2) corners[2].xyz = 1.0-corners[2].xyz;\\n if (tid == 3) corners[3].xyz = 1.0-corners[3].xyz;\\n }\\n\\n if (mod(dot(cpos,vec3(1)),2.0) < 0.5) {\\n flip = !flip;\\n corners = 1.0-corners;\\n }\\n\\n corners[0].xyz += cpos;\\n corners[1].xyz += cpos;\\n corners[2].xyz += cpos;\\n corners[3].xyz += cpos;\\n\\n vec4 values = vec4(\\n map(corners[0].xyz),\\n map(corners[1].xyz),\\n map(corners[2].xyz),\\n map(corners[3].xyz)\\n );\\n\\n int id = 0;\\n if (values[0] > 0.0) id+=1;\\n if (values[1] > 0.0) id+=2;\\n if (values[2] > 0.0) id+=4;\\n if (values[3] > 0.0) id+=8;\\n\\n gl_Position = vec4(0);\\n vec3 vpos = vec3(0);\\n\\n if (id == 15 || id == 0) {\\n return;\\n }\\n\\n if (id < 8) {\\n flip = !flip;\\n }\\n\\n if (flip) {\\n if (vid == 0) vid = 1;\\n else if (vid == 1) vid = 0;\\n else if (vid == 3) vid = 4;\\n else if (vid == 4) vid = 3;\\n }\\n\\n if (id == 1 || id == 14) {\\n if (vid == 0) vpos = ipol(corners,values,0,1);\\n else if (vid == 1) vpos = ipol(corners,values,0,2);\\n else if (vid == 2) vpos = ipol(corners,values,0,3);\\n else return;\\n }\\n\\n if (id == 2 || id == 13) {\\n if (vid == 0) vpos = ipol(corners,values,1,0);\\n else if (vid == 1) vpos = ipol(corners,values,1,3);\\n else if (vid == 2) vpos = ipol(corners,values,1,2);\\n else return;\\n }\\n\\n else if (id == 4 || id == 11) {\\n if (vid == 0) vpos = ipol(corners,values,2,0);\\n else if (vid == 1) vpos = ipol(corners,values,2,1);\\n else if (vid == 2) vpos = ipol(corners,values,2,3);\\n else return;\\n }\\n\\n else if (id == 8 || id == 7) {\\n if (vid == 0) vpos = ipol(corners,values,3,0);\\n else if (vid == 1) vpos = ipol(corners,values,3,1);\\n else if (vid == 2) vpos = ipol(corners,values,3,2);\\n else return;\\n }\\n\\n else if (id == 3 || id == 12) {\\n if (vid == 0) vpos = ipol(corners,values,0,2);\\n else if (vid == 1) vpos = ipol(corners,values,0,3);\\n else if (vid == 2) vpos = ipol(corners,values,1,2);\\n else if (vid == 3) vpos = ipol(corners,values,1,3);\\n else if (vid == 4) vpos = ipol(corners,values,1,2);\\n else if (vid == 5) vpos = ipol(corners,values,0,3);\\n }\\n\\n else if (id == 5 || id == 10) {\\n if (vid == 0) vpos = ipol(corners,values,0,3);\\n else if (vid == 1) vpos = ipol(corners,values,0,1);\\n else if (vid == 2) vpos = ipol(corners,values,2,1);\\n else if (vid == 3) vpos = ipol(corners,values,2,1);\\n else if (vid == 4) vpos = ipol(corners,values,2,3);\\n else if (vid == 5) vpos = ipol(corners,values,0,3);\\n }\\n\\n else if (id == 6 || id == 9) {\\n if (vid == 0) vpos = ipol(corners,values,1,0);\\n else if (vid == 1) vpos = ipol(corners,values,1,3);\\n else if (vid == 2) vpos = ipol(corners,values,2,0);\\n else if (vid == 3) vpos = ipol(corners,values,2,3);\\n else if (vid == 4) vpos = ipol(corners,values,2,0);\\n else if (vid == 5) vpos = ipol(corners,values,1,3);\\n }\\n\\n vec3 p = vpos-pos;\\n\\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\\n\\n p.x *= resolution.y/resolution.x;\\n\\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\\n \\n v_color = vec4(fract(vpos*0.3),1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n#define NUM_CUBES (SIZE*SIZE*SIZE)\n#define NUM_TRIANGLES (NUM_CUBES*18)\n#define NUM_VERTICES (NUM_TRIANGLES*6)\n\n#define STEP 5.0\n\n#define ipol(corners,values,id1, id2) mix(corners[id1].xyz,corners[id2].xyz,values[id1]/(values[id1]-values[id2]))\n\n\n//https://www.shadertoy.com/view/4ttGDH\nvec3 camPath(float t){\n \n //return vec3(0, 0, t); // Straight path.\n //return vec3(-sin(t/2.), sin(t/2.)*.5 + 1.57, t); // Windy path.\n \n //float s = sin(t/24.)*cos(t/12.);\n //return vec3(s*12., 0., t);\n \n float a = sin(t * 0.11);\n float b = cos(t * 0.14);\n return vec3(a*4. -b*1.5, b*1.7 + a*1.5, t);\n \n}\n\n//https://www.shadertoy.com/view/4ttGDH\nfloat map(vec3 p){\n \n p.xy -= camPath(p.z).xy; // Perturb the object around the camera path.\n \n p *= 0.4;\n \n\tp = cos(p*.315*1.25 + sin(p.zxy*.875*1.25)); // 3D sinusoidal mutation.\n \n \n float n = length(p); // Spherize. The result is some mutated, spherical blob-like shapes.\n \n return n-1.0;\n \n}\n\nvoid main() {\n \n float speed = 10.0;\n \n vec3 wpos = vec3(0);\n \n vec3 pos = camPath(time*speed);\n \n vec3 lookat = camPath(time*speed+2.0);\n vec3 forward = normalize(lookat-pos);\n vec3 left = normalize(cross(vec3(camPath(time*speed+1.0).xy,0),forward));\n vec3 up = cross(forward,left);\n \n float cid = floor(vertexId/30.0);\n int tid = int(floor(vertexId/6.0)-cid*5.0);\n int vid = int(mod(vertexId,6.0));\n \n \n \n float size = floor(pow(vertexCount/30.0,1.0/3.0));\n \n vec3 cpos = vec3(\n mod(floor(cid),size),\n mod(floor(cid/size),size),\n floor(cid/size/size))\n -vec2(floor(size*0.5),0).xxy+floor(pos);\n \n \n\n mat4 corners = mat4(\n 0,0,0,0,\n 0,1,1,0,\n 1,0,1,0,\n 1,1,0,0\n );\n\n bool flip = tid == 4;\n if (!flip) {\n if (tid == 0) corners[0].xyz = 1.0-corners[0].xyz;\n if (tid == 1) corners[1].xyz = 1.0-corners[1].xyz;\n if (tid == 2) corners[2].xyz = 1.0-corners[2].xyz;\n if (tid == 3) corners[3].xyz = 1.0-corners[3].xyz;\n }\n\n if (mod(dot(cpos,vec3(1)),2.0) < 0.5) {\n flip = !flip;\n corners = 1.0-corners;\n }\n\n corners[0].xyz += cpos;\n corners[1].xyz += cpos;\n corners[2].xyz += cpos;\n corners[3].xyz += cpos;\n\n vec4 values = vec4(\n map(corners[0].xyz),\n map(corners[1].xyz),\n map(corners[2].xyz),\n map(corners[3].xyz)\n );\n\n int id = 0;\n if (values[0] > 0.0) id+=1;\n if (values[1] > 0.0) id+=2;\n if (values[2] > 0.0) id+=4;\n if (values[3] > 0.0) id+=8;\n\n gl_Position = vec4(0);\n vec3 vpos = vec3(0);\n\n if (id == 15 || id == 0) {\n return;\n }\n\n if (id < 8) {\n flip = !flip;\n }\n\n if (flip) {\n if (vid == 0) vid = 1;\n else if (vid == 1) vid = 0;\n else if (vid == 3) vid = 4;\n else if (vid == 4) vid = 3;\n }\n\n if (id == 1 || id == 14) {\n if (vid == 0) vpos = ipol(corners,values,0,1);\n else if (vid == 1) vpos = ipol(corners,values,0,2);\n else if (vid == 2) vpos = ipol(corners,values,0,3);\n else return;\n }\n\n if (id == 2 || id == 13) {\n if (vid == 0) vpos = ipol(corners,values,1,0);\n else if (vid == 1) vpos = ipol(corners,values,1,3);\n else if (vid == 2) vpos = ipol(corners,values,1,2);\n else return;\n }\n\n else if (id == 4 || id == 11) {\n if (vid == 0) vpos = ipol(corners,values,2,0);\n else if (vid == 1) vpos = ipol(corners,values,2,1);\n else if (vid == 2) vpos = ipol(corners,values,2,3);\n else return;\n }\n\n else if (id == 8 || id == 7) {\n if (vid == 0) vpos = ipol(corners,values,3,0);\n else if (vid == 1) vpos = ipol(corners,values,3,1);\n else if (vid == 2) vpos = ipol(corners,values,3,2);\n else return;\n }\n\n else if (id == 3 || id == 12) {\n if (vid == 0) vpos = ipol(corners,values,0,2);\n else if (vid == 1) vpos = ipol(corners,values,0,3);\n else if (vid == 2) vpos = ipol(corners,values,1,2);\n else if (vid == 3) vpos = ipol(corners,values,1,3);\n else if (vid == 4) vpos = ipol(corners,values,1,2);\n else if (vid == 5) vpos = ipol(corners,values,0,3);\n }\n\n else if (id == 5 || id == 10) {\n if (vid == 0) vpos = ipol(corners,values,0,3);\n else if (vid == 1) vpos = ipol(corners,values,0,1);\n else if (vid == 2) vpos = ipol(corners,values,2,1);\n else if (vid == 3) vpos = ipol(corners,values,2,1);\n else if (vid == 4) vpos = ipol(corners,values,2,3);\n else if (vid == 5) vpos = ipol(corners,values,0,3);\n }\n\n else if (id == 6 || id == 9) {\n if (vid == 0) vpos = ipol(corners,values,1,0);\n else if (vid == 1) vpos = ipol(corners,values,1,3);\n else if (vid == 2) vpos = ipol(corners,values,2,0);\n else if (vid == 3) vpos = ipol(corners,values,2,3);\n else if (vid == 4) vpos = ipol(corners,values,2,0);\n else if (vid == 5) vpos = ipol(corners,values,1,3);\n }\n\n vec3 p = vpos-pos;\n\n p = vec3(-dot(p,left),dot(p,up),dot(p,forward));\n\n p.x *= resolution.y/resolution.x;\n\n gl_Position = vec4(p.xy, p.z*p.z*0.01, p.z);\n \n v_color = vec4(fract(vpos*0.3),1);\n}" + }, "screenshotURL": "data/images/images-eq5uuag7aifi06hhw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mM93aaccacmA9o34t/art.json b/art/mM93aaccacmA9o34t/art.json index a1d2f09f..7ca98b8c 100644 --- a/art/mM93aaccacmA9o34t/art.json +++ b/art/mM93aaccacmA9o34t/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "gman", - "settings": "{\"num\":98304,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nautylus-productions/falomir-feat-dila-libertine-lounge-deep-mix\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// ==========================================\\n// ^\\n// |\\n// +-- click \\\"hide\\\" then MOVE YOUR MOUSE!!!!\\n// ==========================================\\n\\n#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define QUADS_PER_LINE 256.\\n#define SUBDIVISIONS_PER_QUAD 16.\\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\\nconst float tension = 0.5;\\n\\n\\nvec3 getCenterPoint(const float id) {\\n vec4 t = vec4(0);\\n const int samples = 4;\\n for (int ii = 0; ii < samples; ++ii) {\\n t += texture2D(touch, \\n vec2(0.,\\n (id * 0.2) / (soundRes.y * 1.) \\n + float(ii) / float(samples) * 0.01));\\n }\\n t /= 4.;\\n //t.xy = vec2(m1p1(hash(id)), m1p1(hash(id * 0.37))) * 0.5;\\n return vec3(t.x, t.y, 0);\\n}\\n\\nvec3 getCurvePoint(const float superId) {\\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n vec3 q0 = getCenterPoint(quadId - 1.);\\n vec3 q1 = getCenterPoint(quadId + 0.);\\n vec3 q2 = getCenterPoint(quadId + 1.);\\n vec3 q3 = getCenterPoint(quadId + 2.);\\n vec3 q4 = getCenterPoint(quadId + 3.);\\n vec3 q5 = getCenterPoint(quadId + 4.);\\n \\n float s2 = pow(subV, 2.);\\n float s3 = pow(subV, 3.);\\n \\n float c1 = 2. * s3 - 3. * s2 + 1.;\\n float c2 = -(2. * s3) + 3. * s2; \\n float c3 = s3 - 2. * s2 + subV; \\n float c4 = s3 - s2; \\n\\n vec3 t1 = (q2 - q0) * tension;\\n vec3 t2 = (q3 - q1) * tension;\\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \\n}\\n\\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\\n float subV = subId / SUBDIVISIONS_PER_QUAD;\\n \\n vec3 q0 = getCurvePoint(cpId + 0.);\\n vec3 q1 = getCurvePoint(cpId + 1.);\\n vec3 q2 = getCurvePoint(cpId + 2.);\\n vec3 q3 = getCurvePoint(cpId + 3.);\\n vec3 q4 = getCurvePoint(cpId + 4.);\\n vec3 q5 = getCurvePoint(cpId + 5.);\\n\\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n #if 0\\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #else\\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 1, 0) * thickness;\\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n #endif\\n \\n uv = vec2(ux, vy);\\n}\\n\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n float quadV = quadId / quadCount;\\n float invQuadV = inv(quadV);\\n vec3 pos;\\n vec2 uv;\\n\\n float snd0 = texture2D(sound, vec2(0.03, quadV * 0.2)).a;\\n float snd1 = 0.6;texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId, pointId, mix(0.01, 0.25, pow(snd0 + 0.2, 15.)), vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n \\n// vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(vec3(\\n mix(1., -1., mod(lineId, 2.)),\\n mix(1., -1., mod(floor(lineId / 2.), 2.)),\\n 1));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n// gl_Position.z = -m1p1(quadId / quadCount);\\n// gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.95, snd0);\\n float sat = 1.;\\n float val = mix(1.0, 0.0, step(50., mod(quadId, 100.)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invQuadV);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n\\n}\\n\\n\"}", + "settings": { + "num": 98304, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nautylus-productions/falomir-feat-dila-libertine-lounge-deep-mix", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// ==========================================\n// ^\n// |\n// +-- click \"hide\" then MOVE YOUR MOUSE!!!!\n// ==========================================\n\n#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define QUADS_PER_LINE 256.\n#define SUBDIVISIONS_PER_QUAD 16.\n#define POINTS_PER_LINE (QUADS_PER_LINE * SUBDIVISIONS_PER_QUAD * 6.)\nconst float tension = 0.5;\n\n\nvec3 getCenterPoint(const float id) {\n vec4 t = vec4(0);\n const int samples = 4;\n for (int ii = 0; ii < samples; ++ii) {\n t += texture2D(touch, \n vec2(0.,\n (id * 0.2) / (soundRes.y * 1.) \n + float(ii) / float(samples) * 0.01));\n }\n t /= 4.;\n //t.xy = vec2(m1p1(hash(id)), m1p1(hash(id * 0.37))) * 0.5;\n return vec3(t.x, t.y, 0);\n}\n\nvec3 getCurvePoint(const float superId) {\n float quadId = floor(superId / SUBDIVISIONS_PER_QUAD);\n float subId = mod(superId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n vec3 q0 = getCenterPoint(quadId - 1.);\n vec3 q1 = getCenterPoint(quadId + 0.);\n vec3 q2 = getCenterPoint(quadId + 1.);\n vec3 q3 = getCenterPoint(quadId + 2.);\n vec3 q4 = getCenterPoint(quadId + 3.);\n vec3 q5 = getCenterPoint(quadId + 4.);\n \n float s2 = pow(subV, 2.);\n float s3 = pow(subV, 3.);\n \n float c1 = 2. * s3 - 3. * s2 + 1.;\n float c2 = -(2. * s3) + 3. * s2; \n float c3 = s3 - 2. * s2 + subV; \n float c4 = s3 - s2; \n\n vec3 t1 = (q2 - q0) * tension;\n vec3 t2 = (q3 - q1) * tension;\n return c1 * q1 + c2 * q2 + c3 * t1 + c4 * t2; \n}\n\nvoid getQuadPoint(const float cpId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n float subId = mod(cpId, SUBDIVISIONS_PER_QUAD);\n float subV = subId / SUBDIVISIONS_PER_QUAD;\n \n vec3 q0 = getCurvePoint(cpId + 0.);\n vec3 q1 = getCurvePoint(cpId + 1.);\n vec3 q2 = getCurvePoint(cpId + 2.);\n vec3 q3 = getCurvePoint(cpId + 3.);\n vec3 q4 = getCurvePoint(cpId + 4.);\n vec3 q5 = getCurvePoint(cpId + 5.);\n\n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n #if 0\n vec3 p0 = mix(mix(q0, q1, subV), mix(q1, q2, subV), subV);\n vec3 p1 = mix(mix(q1, q2, subV), mix(q2, q3, subV), subV);\n vec3 p2 = mix(mix(q2, q3, subV), mix(q3, q4, subV), subV);\n vec3 p3 = mix(mix(q3, q4, subV), mix(q4, q5, subV), subV);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #else\n vec3 perp0 = normalize(q2 - q0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(q3 - q1).yxz * vec3(-1, 1, 0) * thickness;\n pos = vec3(mix(q1, q2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n #endif\n \n uv = vec2(ux, vy);\n}\n\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n float quadV = quadId / quadCount;\n float invQuadV = inv(quadV);\n vec3 pos;\n vec2 uv;\n\n float snd0 = texture2D(sound, vec2(0.03, quadV * 0.2)).a;\n float snd1 = 0.6;texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId, pointId, mix(0.01, 0.25, pow(snd0 + 0.2, 15.)), vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n \n// vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(vec3(\n mix(1., -1., mod(lineId, 2.)),\n mix(1., -1., mod(floor(lineId / 2.), 2.)),\n 1));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n// gl_Position.z = -m1p1(quadId / quadCount);\n// gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.95, snd0);\n float sat = 1.;\n float val = mix(1.0, 0.0, step(50., mod(quadId, 100.)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invQuadV);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n\n}\n\n" + }, "screenshotURL": "data/images/images-5qa18pssovt8dhfbl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mMNQ38uN94rxmoWBh/art.json b/art/mMNQ38uN94rxmoWBh/art.json index dc1dea51..d2ffddcf 100644 --- a/art/mMNQ38uN94rxmoWBh/art.json +++ b/art/mMNQ38uN94rxmoWBh/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":57111,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -1. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\\n float sat = 2.9 / circleId;\\n float val = .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 57111, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -1. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\n float sat = 2.9 / circleId;\n float val = .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-xo3d4mt2arrrppuyw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mMtFqJYFAoMttvdnt/art.json b/art/mMtFqJYFAoMttvdnt/art.json index 06ddfe1c..70c2aa9f 100644 --- a/art/mMtFqJYFAoMttvdnt/art.json +++ b/art/mMtFqJYFAoMttvdnt/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lapixmusic/lapix-louder-louder\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n//http://glslsandbox.com/e#44575.1\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\t//vec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n \\tconst float colorCount = 8.0;\\n\\n\\tvec2 p = vec2(x,y);\\n vec2 res = vec2(across,down);\\n \\n\\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\\n\\t\\n vec3 destColor = vec3(1., 1.0, 1. );\\n\\tfloat f = 0.1;\\n\\t\\n\\tfor(float i = 0.001; i < 10.0; i++){\\n\\t\\t\\n\\t\\tfloat s = cos(sin(10. * time / i )) ;\\n\\t\\tfloat c = tan(cos(0.1* time + i ));\\n\\t\\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\\n\\t}\\n\\n v_color = vec4(vec3(destColor * f), 1.0);\\n\\t\\n \\n //camera\\n float r = .2;\\n float tm = time * 0.05;\\n float tm2 = time * 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 3.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n if(depth>=0.5)\\n {\\n depthFactor = depth/20.;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, sin(depthFactor*v* 3.14)*0.1, 1.);\\n \\n gl_Position = mat*finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lapixmusic/lapix-louder-louder", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n//http://glslsandbox.com/e#44575.1\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\t//vec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n \tconst float colorCount = 8.0;\n\n\tvec2 p = vec2(x,y);\n vec2 res = vec2(across,down);\n \n\tvec2 position = abs( p.xy * 2.0 - res) / min(res.x, res.y);\n\t\n vec3 destColor = vec3(1., 1.0, 1. );\n\tfloat f = 0.1;\n\t\n\tfor(float i = 0.001; i < 10.0; i++){\n\t\t\n\t\tfloat s = cos(sin(10. * time / i )) ;\n\t\tfloat c = tan(cos(0.1* time + i ));\n\t\tf +=abs( (0.001+snd/100.) / abs(length( (9.0+snd/100.)* position *f - vec2(c, s)) -0.5));\n\t}\n\n v_color = vec4(vec3(destColor * f), 1.0);\n\t\n \n //camera\n float r = .2;\n float tm = time * 0.05;\n float tm2 = time * 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 3.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n if(depth>=0.5)\n {\n depthFactor = depth/20.;\n }\n \n vec4 finalPos = vec4(ux, vy, sin(depthFactor*v* 3.14)*0.1, 1.);\n \n gl_Position = mat*finalPos;\n}" + }, "screenshotURL": "data/images/images-u8uvb3fzednicph1l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mNBny7JXpBGwQnMwG/art.json b/art/mNBny7JXpBGwQnMwG/art.json index ab32a2c5..48b3c154 100644 --- a/art/mNBny7JXpBGwQnMwG/art.json +++ b/art/mNBny7JXpBGwQnMwG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-jyume-18-phantasm-plus-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n🍩\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(0., 1., vy);\\n \\n float gv = (groupId + vy) / numGroups; \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n float s = texture2D(sound, vec2(mix(0.1, 0.15, abs(gv * 2. - 1.)), 0)).a;\\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE /2., ux, inner, start, end, pos); \\n vec3 nrm = pos;\\n \\n float r = 4.;\\n float ct = time * .15;\\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\\n vec3 target = vec3(0, -3, 0);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotY(gv * PI * 2.);\\n mat *= trans(vec3(5,0,0));\\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n vec3 n = (mat * vec4(nrm, 0)).xyz;\\n\\n float hue = ct + sin(gv * PI) * 0.1;\\n float sat = 1. - pow(s + .45, 15.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\\n float l = dot(n, lightDir) * .5 + .5;\\n \\n v_color.rgb *= mix(1., l, sat);\\n v_color.rgb *= v_color.a;\\n \\n //v_color.rgb = n * .5 + .5;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-jyume-18-phantasm-plus-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n🍩\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\n#define NUM_POINTS_PER_GROUP (NUM_POINTS_PER_CIRCLE * NUM_CIRCLES_PER_GROUP)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float id = mod(vertexId, NUM_POINTS_PER_GROUP);\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(0., 1., vy);\n \n float gv = (groupId + vy) / numGroups; \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n float s = texture2D(sound, vec2(mix(0.1, 0.15, abs(gv * 2. - 1.)), 0)).a;\n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE /2., ux, inner, start, end, pos); \n vec3 nrm = pos;\n \n float r = 4.;\n float ct = time * .15;\n vec3 eye = vec3(sin(ct) * r, 3. + sin(ct * 1.7) * 1., cos(ct) * r);\n vec3 target = vec3(0, -3, 0);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n float sp = pow(snd, 5.0);\n\n mat *= rotY(gv * PI * 2.);\n mat *= trans(vec3(5,0,0));\n mat *= uniformScale(mix(.2, 1., pow(s + .5, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n vec3 n = (mat * vec4(nrm, 0)).xyz;\n\n float hue = ct + sin(gv * PI) * 0.1;\n float sat = 1. - pow(s + .45, 15.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n vec3 lightDir = normalize(vec3(sin(time)*1.,.1,0.1));\n float l = dot(n, lightDir) * .5 + .5;\n \n v_color.rgb *= mix(1., l, sat);\n v_color.rgb *= v_color.a;\n \n //v_color.rgb = n * .5 + .5;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-cttxn3rlriag87k1u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mP36iPeKidJ9NCRwX/art.json b/art/mP36iPeKidJ9NCRwX/art.json index 87e7e39d..07906003 100644 --- a/art/mP36iPeKidJ9NCRwX/art.json +++ b/art/mP36iPeKidJ9NCRwX/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n\\nvoid main ()\\n{\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize);//*resolution.x/resolution.y);\\n \\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);// * (across/resolution.x);// (across - 1.0);\\n float v = (y /down);// * (across/resolution.x);// (down - 1.0);\\n \\n float ux = ((u * (across/resolution.x))* 2.0 - 1.0* (across/resolution.x));//(u * 2.0 - 1.0) * (across/resolution.x);\\n float vy = (v * (across/resolution.x )* 2.0 - 1.0* (across/resolution.x));//(v * 2.0 - 1.0) * (across/resolution.x);\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n //apply fragment logic\\n\\n\\tfloat colorCount = 8.+ snd/10.;\\n\\n\\tvec2 position = vec2(u,v);\\n \\n\\tposition.x = abs(position.x - 0.5);\\n //if(v>0.5)\\n {\\n //position.y = mod(position.y,0.5);\\n position.x = mod(position.x,0.5);\\n }\\n\\n if(v>0.5)\\n position.y = (1. -position.y);\\n \\n\\tfloat j = 1.0;\\n\\tj += position.y + position.x/position.y;\\n\\tj *= 1.;\\n\\tj = mod(j + time/2., 1.0);\\n\\t\\n\\tfloat i = mod(position.x * colorCount + 10.*cos(time/12.0), sin(time/12.0) + 2.0);\\n\\t\\n i = mod(position.y * colorCount * j, i / j);\\n\\ti *= 2.;\\n\\t\\n\\ti = mod(i - time/2.0 - j, colorCount);\\n\\t\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 1.;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n\\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\\n //if(v>0.5)\\n // v_color = vec4( vec3(0.,0.,0.), 1.0 );\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n\nvoid main ()\n{\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize);//*resolution.x/resolution.y);\n \n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);// * (across/resolution.x);// (across - 1.0);\n float v = (y /down);// * (across/resolution.x);// (down - 1.0);\n \n float ux = ((u * (across/resolution.x))* 2.0 - 1.0* (across/resolution.x));//(u * 2.0 - 1.0) * (across/resolution.x);\n float vy = (v * (across/resolution.x )* 2.0 - 1.0* (across/resolution.x));//(v * 2.0 - 1.0) * (across/resolution.x);\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n //apply fragment logic\n\n\tfloat colorCount = 8.+ snd/10.;\n\n\tvec2 position = vec2(u,v);\n \n\tposition.x = abs(position.x - 0.5);\n //if(v>0.5)\n {\n //position.y = mod(position.y,0.5);\n position.x = mod(position.x,0.5);\n }\n\n if(v>0.5)\n position.y = (1. -position.y);\n \n\tfloat j = 1.0;\n\tj += position.y + position.x/position.y;\n\tj *= 1.;\n\tj = mod(j + time/2., 1.0);\n\t\n\tfloat i = mod(position.x * colorCount + 10.*cos(time/12.0), sin(time/12.0) + 2.0);\n\t\n i = mod(position.y * colorCount * j, i / j);\n\ti *= 2.;\n\t\n\ti = mod(i - time/2.0 - j, colorCount);\n\t\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 1.;//(resolution.y/numAcrossDown) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n\n v_color = vec4( vec3(mod(floor(i),2.)), 1.0 );\n //if(v>0.5)\n // v_color = vec4( vec3(0.,0.,0.), 1.0 );\n\n}" + }, "screenshotURL": "data/images/images-ne8us15vhzytmyabl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mQ966EQcC2e2h8cjZ/art.json b/art/mQ966EQcC2e2h8cjZ/art.json index 7d2a1541..01555020 100644 --- a/art/mQ966EQcC2e2h8cjZ/art.json +++ b/art/mQ966EQcC2e2h8cjZ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n //float width = 10.0;\\n \\n float x = floor(vertexId / 2.0);\\n float y = floor(vertexId / 3.0) * 0.5;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n \\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 3, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n //float width = 10.0;\n \n float x = floor(vertexId / 2.0);\n float y = floor(vertexId / 3.0) * 0.5;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n \n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-yclpn5pgty8enqbsl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mQuMhKJA2PG4x8j7h/art.json b/art/mQuMhKJA2PG4x8j7h/art.json index 7874ad74..d760375c 100644 --- a/art/mQuMhKJA2PG4x8j7h/art.json +++ b/art/mQuMhKJA2PG4x8j7h/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 5.//KParameter0 -15.>>20.\\n#define parameter1 5.//KParameter1 -15.>>20.\\n#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 0.5;\\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(0, 0);\\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\\n float beatwave =\\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\\n float sampleRange = beatwave * 0.025 + 0.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.0625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1. + soundTexCoords0.x) + 0.1;\\n r = pow(r, 5.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 5.//KParameter0 -15.>>20.\n#define parameter1 5.//KParameter1 -15.>>20.\n#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 0.5;\n float sy = cy - circlesPerColumn * 0.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(0, 0);\n float soundXTimeOffset = 0.; //sin(time) * 0.015625;\n float beatwave =\n ( 1. - abs( sin( time ) ) - 1. ) * sign( sin( time * 0.5 ) );\n float sampleRange = beatwave * 0.025 + 0.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 0.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 0.5, 2.) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.0625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1. + soundTexCoords0.x) + 0.1;\n r = pow(r, 5.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-vc09dbwhblm6w9gee-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mSDHF7AjBowN86DnJ/art.json b/art/mSDHF7AjBowN86DnJ/art.json index a4403d35..43a3a388 100644 --- a/art/mSDHF7AjBowN86DnJ/art.json +++ b/art/mSDHF7AjBowN86DnJ/art.json @@ -22,7 +22,19 @@ "origId": null, "name": "synapsicorporation", "username": "visy", - "settings": "{\"num\":20785,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chiptune/05-boss-v2-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\n// music by rez! here we goooooooo-oo-oo-oooooooo.....\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float localTime = time + 20.0;\\n \\n float NUM_SEGMENTS = localTime*cos(texture2D(floatSound,vec2(localTime*0.0000001,cos(localTime*0.0000001))).a*0.00001);\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2+cos(texture2D(floatSound,vec2(count*0.01,angle*0.01)).a*0.0001*localTime);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01*texture2D(floatSound,vec2(localTime,s+vertexId*0.01)).a*0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n \\n float aa = (localTime*0.001)*cos(localTime*0.0001*vertexId);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle-aa);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 20785, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chiptune/05-boss-v2-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\n// music by rez! here we goooooooo-oo-oo-oooooooo.....\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float localTime = time + 20.0;\n \n float NUM_SEGMENTS = localTime*cos(texture2D(floatSound,vec2(localTime*0.0000001,cos(localTime*0.0000001))).a*0.00001);\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2+cos(texture2D(floatSound,vec2(count*0.01,angle*0.01)).a*0.0001*localTime);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01*texture2D(floatSound,vec2(localTime,s+vertexId*0.01)).a*0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n \n float aa = (localTime*0.001)*cos(localTime*0.0001*vertexId);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle-aa);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotDataId": "iZngnCo9QYyKxdt9w", "views": { "$numberInt": "1058" diff --git a/art/mTJbRgMm8M8FK2iEr/art.json b/art/mTJbRgMm8M8FK2iEr/art.json index 05de685f..eb70a894 100644 --- a/art/mTJbRgMm8M8FK2iEr/art.json +++ b/art/mTJbRgMm8M8FK2iEr/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.16470588235294117,0.22745098039215686,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.16470588235294117, + 0.22745098039215686, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-ra4w5n5ln927b1l5h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mTN89iZPCffApkuoc/art.json b/art/mTN89iZPCffApkuoc/art.json index 55727dea..14b8652a 100644 --- a/art/mTN89iZPCffApkuoc/art.json +++ b/art/mTN89iZPCffApkuoc/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "digaus", "avatarUrl": "https://secure.gravatar.com/avatar/905731a406a90585de08ead028282160?default=retro&size=200", - "settings": "{\"num\":5496,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float x = vertexId / 10.0;\\n float y = vertexId /10.0;\\n \\n gl_Position = vec4(x,0,0,1);\\n gl_PointSize = 10.0;\\n v_color = vec4(1,1,0,1);\\n}\"}", + "settings": { + "num": 5496, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float x = vertexId / 10.0;\n float y = vertexId /10.0;\n \n gl_Position = vec4(x,0,0,1);\n gl_PointSize = 10.0;\n v_color = vec4(1,1,0,1);\n}" + }, "screenshotURL": "data/images/images-8ry1tt6zaq33z2ner-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mTt5zkdxxpb2F9px7/art.json b/art/mTt5zkdxxpb2F9px7/art.json index 30a454b6..8d0a263d 100644 --- a/art/mTt5zkdxxpb2F9px7/art.json +++ b/art/mTt5zkdxxpb2F9px7/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Hexagon Tile Strings by Justin Shrake (https://twitter.com/j2rgb)\\n// Inspired by https://twitter.com/etiennejcb/status/974037218330382336?s=20\\n// CC BY-NC 4.0 https://creativecommons.org/licenses/by-nc/4.0/\\n\\n// Submission for https://twitter.com/sableRaph #WCCChallenge\\n// Topic: non-rectangular tiles\\n// https://www.twitch.tv/sableraph\\n\\n\\n#ifndef TAU\\n#define TAU 6.28318530718\\n#endif\\n#ifndef PI\\n#define PI 3.14159265359\\n#endif\\n\\n\\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\\n// Licensed under CC BY-SA 3.0\\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\\nvec2 parametric_ngon(float n, float theta) {\\n theta = mod(TAU * theta, TAU);\\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\\n float x = r * cos(theta);\\n float y = r * sin(theta);\\n return vec2(x, y);\\n}\\n\\nvec4 grid2(float id, float w, float h) {\\n float ux = w == 1.0 ? 0.0 : mod(id, w);\\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\\n return vec4(x, y, ux, uy);\\n}\\n\\nmat2 rot2(float t) {\\n float ct = cos(t);\\n float st = sin(t);\\n return mat2(ct, -st, st, ct);\\n}\\n\\nmat4 frustum(float left, float right, float bottom, float top, float near,\\n float far) {\\n float x = 2.0 * near / (right - left);\\n float y = 2.0 * near / (top - bottom);\\n float A = (right + left) / (right - left);\\n float B = (top + bottom) / (top - bottom);\\n float C = -(far + near) / (far - near);\\n float D = -2.0 * far * near / (far - near);\\n // clang-format off\\n return mat4(\\n x, 0, 0, 0,\\n 0, y, 0, 0,\\n A, B, C, -1,\\n 0, 0, D, 0\\n );\\n // clang-format on\\n}\\n\\nmat4 perspective(float hfov_deg, float aspect, float near, float far) {\\n float hfov_rad = radians(hfov_deg);\\n float vfov_rad = 2.0 * atan(tan(hfov_rad * 0.5) / aspect);\\n // Tangent of half-FOV\\n float tangent = tan(0.5 * vfov_rad);\\n // Half the height of the near plane\\n float height = near * tangent;\\n // Half the width of the near plane\\n float width = height * aspect;\\n return frustum(-width, width, -height, height, near, far);\\n}\\n\\n\\nfloat quadraticInOut(float t) {\\n float p = 2.0 * t * t;\\n return t < 0.5 ? p : -p + (4.0 * t) - 1.0;\\n}\\n\\n//\\n// GLSL textureless classic 2D noise \\\"cnoise\\\",\\n// with an RSL-style periodic variant \\\"pnoise\\\".\\n// Author: Stefan Gustavson (stefan.gustavson@liu.se)\\n// Version: 2011-08-22\\n//\\n// Many thanks to Ian McEwan of Ashima Arts for the\\n// ideas for permutation and gradient selection.\\n//\\n// Copyright (c) 2011 Stefan Gustavson. All rights reserved.\\n// Distributed under the MIT license. See LICENSE file.\\n// https://github.com/stegu/webgl-noise\\n//\\n\\nvec4 mod289(vec4 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\\n\\nvec4 permute(vec4 x) { return mod289(((x * 34.0) + 10.0) * x); }\\n\\nvec4 taylorInvSqrt(vec4 r) { return 1.79284291400159 - 0.85373472095314 * r; }\\n\\nvec2 fade(vec2 t) { return t * t * t * (t * (t * 6.0 - 15.0) + 10.0); }\\n\\n// Classic Perlin noise\\nfloat perlin(vec2 P) {\\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\\n Pi = mod289(Pi); // To avoid truncation effects in permutation\\n vec4 ix = Pi.xzxz;\\n vec4 iy = Pi.yyww;\\n vec4 fx = Pf.xzxz;\\n vec4 fy = Pf.yyww;\\n\\n vec4 i = permute(permute(ix) + iy);\\n\\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\\n vec4 gy = abs(gx) - 0.5;\\n vec4 tx = floor(gx + 0.5);\\n gx = gx - tx;\\n\\n vec2 g00 = vec2(gx.x, gy.x);\\n vec2 g10 = vec2(gx.y, gy.y);\\n vec2 g01 = vec2(gx.z, gy.z);\\n vec2 g11 = vec2(gx.w, gy.w);\\n\\n vec4 norm = taylorInvSqrt(\\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\\n g00 *= norm.x;\\n g01 *= norm.y;\\n g10 *= norm.z;\\n g11 *= norm.w;\\n\\n float n00 = dot(g00, vec2(fx.x, fy.x));\\n float n10 = dot(g10, vec2(fx.y, fy.y));\\n float n01 = dot(g01, vec2(fx.z, fy.z));\\n float n11 = dot(g11, vec2(fx.w, fy.w));\\n\\n vec2 fade_xy = fade(Pf.xy);\\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\\n return 2.3 * n_xy;\\n}\\n\\n// Classic Perlin noise, periodic variant\\nfloat pnoise(vec2 P, vec2 rep) {\\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\\n Pi = mod(Pi, rep.xyxy); // To create noise with explicit period\\n Pi = mod289(Pi); // To avoid truncation effects in permutation\\n vec4 ix = Pi.xzxz;\\n vec4 iy = Pi.yyww;\\n vec4 fx = Pf.xzxz;\\n vec4 fy = Pf.yyww;\\n\\n vec4 i = permute(permute(ix) + iy);\\n\\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\\n vec4 gy = abs(gx) - 0.5;\\n vec4 tx = floor(gx + 0.5);\\n gx = gx - tx;\\n\\n vec2 g00 = vec2(gx.x, gy.x);\\n vec2 g10 = vec2(gx.y, gy.y);\\n vec2 g01 = vec2(gx.z, gy.z);\\n vec2 g11 = vec2(gx.w, gy.w);\\n\\n vec4 norm = taylorInvSqrt(\\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\\n g00 *= norm.x;\\n g01 *= norm.y;\\n g10 *= norm.z;\\n g11 *= norm.w;\\n\\n float n00 = dot(g00, vec2(fx.x, fy.x));\\n float n10 = dot(g10, vec2(fx.y, fy.y));\\n float n01 = dot(g01, vec2(fx.z, fy.z));\\n float n11 = dot(g11, vec2(fx.w, fy.w));\\n\\n vec2 fade_xy = fade(Pf.xy);\\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\\n return 2.3 * n_xy;\\n}\\n\\n\\nmat4 rot3(vec3 axis, float angle) {\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n\\n return mat4(\\n oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s,\\n oc * axis.z * axis.x + axis.y * s, 0.0, oc * axis.x * axis.y + axis.z * s,\\n oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s,\\n oc * axis.z * axis.z + c, 0.0, 0.0, 0.0, 0.0, 1.0);\\n}\\n\\n\\nvoid main() {\\n // Loop timings\\n float loop_len = 4.0;\\n float time_off = 0.0;\\n float loop_pct = mod(time + time_off, loop_len) / (loop_len);\\n // The size of the hexagon tile grid\\n float gridw = 20.;\\n float gridh = 20.;\\n // The number of particles per hexagon\\n float particles_per_tile = 250.0;\\n // The particle index\\n float i = vertexId;\\n // The particle perctange\\n float pct = i / (vertexCount - 1.0);\\n\\n // The hexagon index\\n float tile_i = floor(i / particles_per_tile);\\n // The total number of hexagons\\n float tile_count = gridw * gridh;\\n\\n // The particle index wrt the hexagon\\n float tile_pi = mod(i, particles_per_tile);\\n // The particle percentage wrt the hexagon\\n float tile_ppct = tile_pi / particles_per_tile;\\n\\n \\n float row = floor(tile_i/gridw);\\n float col = mod(tile_i, gridw);\\n float eo = mod(row, 2.0);\\n \\n float ar = resolution.y < resolution.x ? resolution.x/resolution.y : resolution.y/resolution.x;\\n\\n\\n // Hexagon tile size\\n float size = 1.0/(gridw - 1.0);\\n // padding between hexagons, 1.0 for no padding\\n float padding = 1.2;\\n // hexagon math courtesy of https://www.redblobgames.com/grids/hexagons/\\n vec2 grid_scale = padding*vec2(1.0*sqrt(3.0)*size, 1.5*ar*size);\\n vec2 tile_scale = vec2(size, size*ar);\\n // The center of the hexagon\\n vec2 tile_center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\\n tile_center.y += 2.5;\\n // Calculate the position of each particle in the tile\\n float ngon = 6.0;\\n float swirl = 0.5;\\n // The animation interpolates a point in the hexagon to another point in the hexagon\\n vec2 tile_a = parametric_ngon(ngon, tile_ppct);\\n float pn = 0.5*perlin(vec2(3.3)*tile_center) + 0.5;\\n float anim_delay = mix(0.0, 0.7, pn) + mix(0.0, 0.1, tile_ppct);\\n float anim_len = 0.2;\\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\\n vec3 tile = vec3(tile_a, 0.0);\\n tile.xy = rot2(0.25*TAU)*tile.xy;\\n tile.xy *= tile_scale;\\n tile.x += 1.0 * eo * tile_scale.x;\\n tile.y += 1.0*size;\\n float amt = 1.0;\\n float start_z = -0.6;\\n tile.z = mix(start_z, start_z - amt, quadraticInOut(m));\\n tile.z += mix(0.0, amt, (loop_pct));\\n \\n // Outputs\\n vec4 pos;\\n pos.xyz = vec3(tile_center, 0.0) + tile;\\n pos.w = 1.0;\\n pos = rot3(vec3(1.0, 0.0, 0.0), 0.75*0.25*TAU)*rot3(vec3(0.0, 2.0, 1.0), 0.0*TAU)*pos;\\n mat4 p = perspective(60.0, 1.0, 0.01, 10.0);\\n gl_Position = p * pos;\\n gl_PointSize = 3.0;\\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Hexagon Tile Strings by Justin Shrake (https://twitter.com/j2rgb)\n// Inspired by https://twitter.com/etiennejcb/status/974037218330382336?s=20\n// CC BY-NC 4.0 https://creativecommons.org/licenses/by-nc/4.0/\n\n// Submission for https://twitter.com/sableRaph #WCCChallenge\n// Topic: non-rectangular tiles\n// https://www.twitch.tv/sableraph\n\n\n#ifndef TAU\n#define TAU 6.28318530718\n#endif\n#ifndef PI\n#define PI 3.14159265359\n#endif\n\n\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\n// Licensed under CC BY-SA 3.0\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\nvec2 parametric_ngon(float n, float theta) {\n theta = mod(TAU * theta, TAU);\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\n float x = r * cos(theta);\n float y = r * sin(theta);\n return vec2(x, y);\n}\n\nvec4 grid2(float id, float w, float h) {\n float ux = w == 1.0 ? 0.0 : mod(id, w);\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\n return vec4(x, y, ux, uy);\n}\n\nmat2 rot2(float t) {\n float ct = cos(t);\n float st = sin(t);\n return mat2(ct, -st, st, ct);\n}\n\nmat4 frustum(float left, float right, float bottom, float top, float near,\n float far) {\n float x = 2.0 * near / (right - left);\n float y = 2.0 * near / (top - bottom);\n float A = (right + left) / (right - left);\n float B = (top + bottom) / (top - bottom);\n float C = -(far + near) / (far - near);\n float D = -2.0 * far * near / (far - near);\n // clang-format off\n return mat4(\n x, 0, 0, 0,\n 0, y, 0, 0,\n A, B, C, -1,\n 0, 0, D, 0\n );\n // clang-format on\n}\n\nmat4 perspective(float hfov_deg, float aspect, float near, float far) {\n float hfov_rad = radians(hfov_deg);\n float vfov_rad = 2.0 * atan(tan(hfov_rad * 0.5) / aspect);\n // Tangent of half-FOV\n float tangent = tan(0.5 * vfov_rad);\n // Half the height of the near plane\n float height = near * tangent;\n // Half the width of the near plane\n float width = height * aspect;\n return frustum(-width, width, -height, height, near, far);\n}\n\n\nfloat quadraticInOut(float t) {\n float p = 2.0 * t * t;\n return t < 0.5 ? p : -p + (4.0 * t) - 1.0;\n}\n\n//\n// GLSL textureless classic 2D noise \"cnoise\",\n// with an RSL-style periodic variant \"pnoise\".\n// Author: Stefan Gustavson (stefan.gustavson@liu.se)\n// Version: 2011-08-22\n//\n// Many thanks to Ian McEwan of Ashima Arts for the\n// ideas for permutation and gradient selection.\n//\n// Copyright (c) 2011 Stefan Gustavson. All rights reserved.\n// Distributed under the MIT license. See LICENSE file.\n// https://github.com/stegu/webgl-noise\n//\n\nvec4 mod289(vec4 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\n\nvec4 permute(vec4 x) { return mod289(((x * 34.0) + 10.0) * x); }\n\nvec4 taylorInvSqrt(vec4 r) { return 1.79284291400159 - 0.85373472095314 * r; }\n\nvec2 fade(vec2 t) { return t * t * t * (t * (t * 6.0 - 15.0) + 10.0); }\n\n// Classic Perlin noise\nfloat perlin(vec2 P) {\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\n Pi = mod289(Pi); // To avoid truncation effects in permutation\n vec4 ix = Pi.xzxz;\n vec4 iy = Pi.yyww;\n vec4 fx = Pf.xzxz;\n vec4 fy = Pf.yyww;\n\n vec4 i = permute(permute(ix) + iy);\n\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\n vec4 gy = abs(gx) - 0.5;\n vec4 tx = floor(gx + 0.5);\n gx = gx - tx;\n\n vec2 g00 = vec2(gx.x, gy.x);\n vec2 g10 = vec2(gx.y, gy.y);\n vec2 g01 = vec2(gx.z, gy.z);\n vec2 g11 = vec2(gx.w, gy.w);\n\n vec4 norm = taylorInvSqrt(\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\n g00 *= norm.x;\n g01 *= norm.y;\n g10 *= norm.z;\n g11 *= norm.w;\n\n float n00 = dot(g00, vec2(fx.x, fy.x));\n float n10 = dot(g10, vec2(fx.y, fy.y));\n float n01 = dot(g01, vec2(fx.z, fy.z));\n float n11 = dot(g11, vec2(fx.w, fy.w));\n\n vec2 fade_xy = fade(Pf.xy);\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\n return 2.3 * n_xy;\n}\n\n// Classic Perlin noise, periodic variant\nfloat pnoise(vec2 P, vec2 rep) {\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\n Pi = mod(Pi, rep.xyxy); // To create noise with explicit period\n Pi = mod289(Pi); // To avoid truncation effects in permutation\n vec4 ix = Pi.xzxz;\n vec4 iy = Pi.yyww;\n vec4 fx = Pf.xzxz;\n vec4 fy = Pf.yyww;\n\n vec4 i = permute(permute(ix) + iy);\n\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\n vec4 gy = abs(gx) - 0.5;\n vec4 tx = floor(gx + 0.5);\n gx = gx - tx;\n\n vec2 g00 = vec2(gx.x, gy.x);\n vec2 g10 = vec2(gx.y, gy.y);\n vec2 g01 = vec2(gx.z, gy.z);\n vec2 g11 = vec2(gx.w, gy.w);\n\n vec4 norm = taylorInvSqrt(\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\n g00 *= norm.x;\n g01 *= norm.y;\n g10 *= norm.z;\n g11 *= norm.w;\n\n float n00 = dot(g00, vec2(fx.x, fy.x));\n float n10 = dot(g10, vec2(fx.y, fy.y));\n float n01 = dot(g01, vec2(fx.z, fy.z));\n float n11 = dot(g11, vec2(fx.w, fy.w));\n\n vec2 fade_xy = fade(Pf.xy);\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\n return 2.3 * n_xy;\n}\n\n\nmat4 rot3(vec3 axis, float angle) {\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n\n return mat4(\n oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s,\n oc * axis.z * axis.x + axis.y * s, 0.0, oc * axis.x * axis.y + axis.z * s,\n oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s,\n oc * axis.z * axis.z + c, 0.0, 0.0, 0.0, 0.0, 1.0);\n}\n\n\nvoid main() {\n // Loop timings\n float loop_len = 4.0;\n float time_off = 0.0;\n float loop_pct = mod(time + time_off, loop_len) / (loop_len);\n // The size of the hexagon tile grid\n float gridw = 20.;\n float gridh = 20.;\n // The number of particles per hexagon\n float particles_per_tile = 250.0;\n // The particle index\n float i = vertexId;\n // The particle perctange\n float pct = i / (vertexCount - 1.0);\n\n // The hexagon index\n float tile_i = floor(i / particles_per_tile);\n // The total number of hexagons\n float tile_count = gridw * gridh;\n\n // The particle index wrt the hexagon\n float tile_pi = mod(i, particles_per_tile);\n // The particle percentage wrt the hexagon\n float tile_ppct = tile_pi / particles_per_tile;\n\n \n float row = floor(tile_i/gridw);\n float col = mod(tile_i, gridw);\n float eo = mod(row, 2.0);\n \n float ar = resolution.y < resolution.x ? resolution.x/resolution.y : resolution.y/resolution.x;\n\n\n // Hexagon tile size\n float size = 1.0/(gridw - 1.0);\n // padding between hexagons, 1.0 for no padding\n float padding = 1.2;\n // hexagon math courtesy of https://www.redblobgames.com/grids/hexagons/\n vec2 grid_scale = padding*vec2(1.0*sqrt(3.0)*size, 1.5*ar*size);\n vec2 tile_scale = vec2(size, size*ar);\n // The center of the hexagon\n vec2 tile_center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\n tile_center.y += 2.5;\n // Calculate the position of each particle in the tile\n float ngon = 6.0;\n float swirl = 0.5;\n // The animation interpolates a point in the hexagon to another point in the hexagon\n vec2 tile_a = parametric_ngon(ngon, tile_ppct);\n float pn = 0.5*perlin(vec2(3.3)*tile_center) + 0.5;\n float anim_delay = mix(0.0, 0.7, pn) + mix(0.0, 0.1, tile_ppct);\n float anim_len = 0.2;\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\n vec3 tile = vec3(tile_a, 0.0);\n tile.xy = rot2(0.25*TAU)*tile.xy;\n tile.xy *= tile_scale;\n tile.x += 1.0 * eo * tile_scale.x;\n tile.y += 1.0*size;\n float amt = 1.0;\n float start_z = -0.6;\n tile.z = mix(start_z, start_z - amt, quadraticInOut(m));\n tile.z += mix(0.0, amt, (loop_pct));\n \n // Outputs\n vec4 pos;\n pos.xyz = vec3(tile_center, 0.0) + tile;\n pos.w = 1.0;\n pos = rot3(vec3(1.0, 0.0, 0.0), 0.75*0.25*TAU)*rot3(vec3(0.0, 2.0, 1.0), 0.0*TAU)*pos;\n mat4 p = perspective(60.0, 1.0, 0.01, 10.0);\n gl_Position = p * pos;\n gl_PointSize = 3.0;\n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-mc214dfiqr1fp63b7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mYvJWJgSmFTeFydSy/art.json b/art/mYvJWJgSmFTeFydSy/art.json index 6e7eb36a..f9e3c637 100644 --- a/art/mYvJWJgSmFTeFydSy/art.json +++ b/art/mYvJWJgSmFTeFydSy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 67.//KParameter 0.>>1000.\\n#define KP1 6.//KParameter 0.0>>22.\\n#define KP2 9.0//KParameter -6.0>>10.\\n#define KP3 -0.01//KParameter -8.000>>0.5\\n#define KP4 11.2//KParameter 0.000>>5.\\n#define KP5 1130.0//KParameter 30.000>>90000.0\\n\\n//KVerticesNumber=338000\\n#define PI radians(180. -KP1)\\n\\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.02 +KP4, 1.-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 67.//KParameter 0.>>1000.\n#define KP1 6.//KParameter 0.0>>22.\n#define KP2 9.0//KParameter -6.0>>10.\n#define KP3 -0.01//KParameter -8.000>>0.5\n#define KP4 11.2//KParameter 0.000>>5.\n#define KP5 1130.0//KParameter 30.000>>90000.0\n\n//KVerticesNumber=338000\n#define PI radians(180. -KP1)\n\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.02 +KP4, 1.-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-l9k0vprz1e8atordh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/maYBia4hupYbN3YjZ/art.json b/art/maYBia4hupYbN3YjZ/art.json index 9b4dba40..644a76ef 100644 --- a/art/maYBia4hupYbN3YjZ/art.json +++ b/art/maYBia4hupYbN3YjZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(pattern(3.*c));;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(pattern(3.*c));;\n \n\n}" + }, "screenshotURL": "data/images/images-oyeqpgry1ja1gj9y7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mar5ufbpzahGtPyPj/art.json b/art/mar5ufbpzahGtPyPj/art.json index 0505dbaa..4cc37317 100644 --- a/art/mar5ufbpzahGtPyPj/art.json +++ b/art/mar5ufbpzahGtPyPj/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "kerem", "avatarUrl": "https://lh5.googleusercontent.com/-z7y0urriCCM/AAAAAAAAAAI/AAAAAAAADLE/NRSX6XDPDgU/photo.jpg", - "settings": "{\"num\":360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03529411764705882,0.050980392156862744,0.09411764705882353,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 6.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float accross = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, accross);\\n float y = floor(vertexId / accross);\\n \\n // 1 2 3 4 5 6 7 8 9 0 1 2 3 4\\n // 0 0 0 0 0 0 0 0 0 0 1 1 1 1\\n \\n float xoff = sin(time + y * 0.2) * 0.5;\\n float yoff = sin(time + x * 0.2) * 0.5;\\n \\n float soff = sin(time + x * 0.2) * 20.;\\n \\n\\n float ux = x / accross;\\n float uy = y / accross;\\n \\n ux = 2.*ux - 1.;\\n uy = 2.*uy - 1.;\\n \\n gl_Position = vec4(ux + xoff, uy + yoff, 0, 1);\\n \\n gl_PointSize = 10. + soff;\\n \\n v_color = vec4(hsv2rgb(vec3(1,1,1)), 1);\\n\\n}\"}", + "settings": { + "num": 360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03529411764705882, + 0.050980392156862744, + 0.09411764705882353, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 6.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float accross = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, accross);\n float y = floor(vertexId / accross);\n \n // 1 2 3 4 5 6 7 8 9 0 1 2 3 4\n // 0 0 0 0 0 0 0 0 0 0 1 1 1 1\n \n float xoff = sin(time + y * 0.2) * 0.5;\n float yoff = sin(time + x * 0.2) * 0.5;\n \n float soff = sin(time + x * 0.2) * 20.;\n \n\n float ux = x / accross;\n float uy = y / accross;\n \n ux = 2.*ux - 1.;\n uy = 2.*uy - 1.;\n \n gl_Position = vec4(ux + xoff, uy + yoff, 0, 1);\n \n gl_PointSize = 10. + soff;\n \n v_color = vec4(hsv2rgb(vec3(1,1,1)), 1);\n\n}" + }, "screenshotURL": "data/images/images-qlwz4g2wambibn1cf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mb3aos8CkHBeJdfkt/art.json b/art/mb3aos8CkHBeJdfkt/art.json index 24908b3c..c3c0cdfd 100644 --- a/art/mb3aos8CkHBeJdfkt/art.json +++ b/art/mb3aos8CkHBeJdfkt/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 1, 0,\\n 0, 0, 1, 0,\\n 0, 0, 2, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1.2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.01;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 5.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 12.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 4.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 40;\\n float snd = 0.01;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf *- 0.123);\\n float spy = hash(spf / 0.317);\\n float sps = hash(spf - 3.411);\\n \\n float sds = distance(vec2(u*step(1.9,snd*2.), -v+snd), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7*2., sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 33. / across);\\n mat *= rotZ(snd * 2. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.17, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 1, 0,\n 0, 0, 1, 0,\n 0, 0, 2, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1.2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.01;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 5.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 12.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 4.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 40;\n float snd = 0.01;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf *- 0.123);\n float spy = hash(spf / 0.317);\n float sps = hash(spf - 3.411);\n \n float sds = distance(vec2(u*step(1.9,snd*2.), -v+snd), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7*2., sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 33. / across);\n mat *= rotZ(snd * 2. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = sin(time + x * y * .02) * 5.; \n \n float pump = step(0.17, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-v4p2fs6coo6a74xz5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mbkRD28NZpJtGu2af/art.json b/art/mbkRD28NZpJtGu2af/art.json index 3fff39fe..acdb0375 100644 --- a/art/mbkRD28NZpJtGu2af/art.json +++ b/art/mbkRD28NZpJtGu2af/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1443,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rot(vec3 axis, float angle) {\\n \\n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n \\n mat4 mr = rot(vec3(0.019, 0.2, atan(time * 10.0) +0.3), time);\\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 30.0; \\n\\n v_color = vec4(gl_Position.z,(vertexId / vertexCount),0.0,1.0);\\n}\"}", + "settings": { + "num": 1443, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rot(vec3 axis, float angle) {\n \n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n \n mat4 mr = rot(vec3(0.019, 0.2, atan(time * 10.0) +0.3), time);\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 30.0; \n\n v_color = vec4(gl_Position.z,(vertexId / vertexCount),0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-u3sd5xmcqhln5o142-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mc9ScBATcEnpry3q2/art.json b/art/mc9ScBATcEnpry3q2/art.json index d0b22879..dd211ac5 100644 --- a/art/mc9ScBATcEnpry3q2/art.json +++ b/art/mc9ScBATcEnpry3q2/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "daniel", "avatarUrl": "https://lh3.googleusercontent.com/-qXZbQEgaXn0/AAAAAAAAAAI/AAAAAAAAA6k/Q8oMgqryECw/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/doubleday/milk-run\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() \\n{\\n\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor (vertexId / 3.0), 3.0);\\n \\n float angle = ux / 50. * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(0.2 * sin(0.015 * time) * angle);\\n float y = radius * sin(0.2 * sin(0.01 * time) * angle);\\n \\n \\n vec2 xy = vec2(x,y);\\n float snd = texture2D(sound, 0.5 * xy).a;\\n gl_Position= vec4(snd * xy * 0.2,0, 0.1 * sin(time) + 0.5);\\n v_color = vec4((sin(0.5 * time)), (sin(time) + 0.5), (sin(cos(0.2 * time)) + 2.) / 2., 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/doubleday/milk-run", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() \n{\n\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor (vertexId / 3.0), 3.0);\n \n float angle = ux / 50. * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(0.2 * sin(0.015 * time) * angle);\n float y = radius * sin(0.2 * sin(0.01 * time) * angle);\n \n \n vec2 xy = vec2(x,y);\n float snd = texture2D(sound, 0.5 * xy).a;\n gl_Position= vec4(snd * xy * 0.2,0, 0.1 * sin(time) + 0.5);\n v_color = vec4((sin(0.5 * time)), (sin(time) + 0.5), (sin(cos(0.2 * time)) + 2.) / 2., 1);\n}" + }, "screenshotURL": "data/images/images-7i4cmaoy4icia2ibl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/md47PJjYvynaWJqMy/art.json b/art/md47PJjYvynaWJqMy/art.json index 19ef94d6..4f5abc67 100644 --- a/art/md47PJjYvynaWJqMy/art.json +++ b/art/md47PJjYvynaWJqMy/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sail", "avatarUrl": "https://secure.gravatar.com/avatar/bca4a2f3b0c91f779e8844c21bc4b296?default=retro&size=200", - "settings": "{\"num\":887,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/giorgiomoroder/eurythmics-sweet-dreams-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06274509803921569,0.10588235294117647,0.10588235294117647,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float h = (sin(time/15.)*10. + 15.) + mod(2., time);\\n\\n float across = floor(vertexCount / h);\\n \\n float u = mod(vertexId, h);\\n float v = mod(vertexId, across);\\n float x = v / across - .5;\\n\\n float snd = texture2D(floatSound, vec2(v/across,u/5.)).a;\\n \\n float y = u / h * 6.5 + snd/100. - .5;\\n \\n gl_Position = vec4(x, y*.2-.5, 0, 1);\\n gl_PointSize = 3.;\\n vec3 c = vec3(v/across *.2+.2*sin(time+u/10.), 1.,.5);\\n v_color = vec4(hsv2rgb(c),1);\\n\\n}\"}", + "settings": { + "num": 887, + "mode": "POINTS", + "sound": "https://soundcloud.com/giorgiomoroder/eurythmics-sweet-dreams-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06274509803921569, + 0.10588235294117647, + 0.10588235294117647, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float h = (sin(time/15.)*10. + 15.) + mod(2., time);\n\n float across = floor(vertexCount / h);\n \n float u = mod(vertexId, h);\n float v = mod(vertexId, across);\n float x = v / across - .5;\n\n float snd = texture2D(floatSound, vec2(v/across,u/5.)).a;\n \n float y = u / h * 6.5 + snd/100. - .5;\n \n gl_Position = vec4(x, y*.2-.5, 0, 1);\n gl_PointSize = 3.;\n vec3 c = vec3(v/across *.2+.2*sin(time+u/10.), 1.,.5);\n v_color = vec4(hsv2rgb(c),1);\n\n}" + }, "screenshotURL": "data/images/images-gn0j9oum4zgacafk1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mf6PsGZxpSdyu4gkb/art.json b/art/mf6PsGZxpSdyu4gkb/art.json index 4472b5d4..61102999 100644 --- a/art/mf6PsGZxpSdyu4gkb/art.json +++ b/art/mf6PsGZxpSdyu4gkb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":25540,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1411764705882353,0.2980392156862745,0.2235294117647059,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 2.0, 1.0 / 3.0, 1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 4.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 1,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 1, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 1, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[2][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a10 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 0.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 0.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\\n \\n \\n\\n float hue = sz * 12. + s * .0;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2);\\n}\\n \\n\"}", + "settings": { + "num": 25540, + "mode": "LINES", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1411764705882353, + 0.2980392156862745, + 0.2235294117647059, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 2.0, 1.0 / 3.0, 1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 4.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 1,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 1, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 1, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[2][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a10 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 0.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 0.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\n \n \n\n float hue = sz * 12. + s * .0;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2);\n}\n \n" + }, "screenshotURL": "data/images/images-feg1s9rz0iydgm7tu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mfEsB2oGhBqM3k3Rt/art.json b/art/mfEsB2oGhBqM3k3Rt/art.json index 04dc63c5..c3e8fe52 100644 --- a/art/mfEsB2oGhBqM3k3Rt/art.json +++ b/art/mfEsB2oGhBqM3k3Rt/art.json @@ -22,7 +22,19 @@ "origId": null, "name": "the connectedness of all", "username": "visy", - "settings": "{\"num\":3753,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/valmet-children/valmet-children-aegon-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI 3.14159\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n\\n float localTime = time + 20.0;\\n float NUM_SEGMENTS = 0.1+localTime*0.00000001-texture2D(sound,vec2(vertexId*0.001,vertexId*0.001)).a*0.0001;\\n float NUM_POINTS = (NUM_SEGMENTS * 1.0);\\n\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n \\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0,0.99999);\\n\\n \\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 3753, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/valmet-children/valmet-children-aegon-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI 3.14159\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n\n float localTime = time + 20.0;\n float NUM_SEGMENTS = 0.1+localTime*0.00000001-texture2D(sound,vec2(vertexId*0.001,vertexId*0.001)).a*0.0001;\n float NUM_POINTS = (NUM_SEGMENTS * 1.0);\n\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n \n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0,0.99999);\n\n \n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-c0twy3q6tdy1vgd6t-thumbnail.jpg", "views": { "$numberInt": "144" diff --git a/art/mhYRaecedTJazqZtJ/art.json b/art/mhYRaecedTJazqZtJ/art.json index d727f4cf..aba69f59 100644 --- a/art/mhYRaecedTJazqZtJ/art.json +++ b/art/mhYRaecedTJazqZtJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n\\n#define patternFactor0 0.0012//KParameter 0.0012>>0.12\\n#define timeFactor0 0.1//KParameter 0.1>>1.\\n#define timeFactorAmp 10.//KParameter 1.>>40.\\n#define timeFactorAmp2 10.//KParameter 1.>>40.\\n#define patternFactor1Rot 10.//KParameter 1.>>100.\\n#define patternSymFactor 3.0//KParameter 1.>>10.\\n\\nvec2 pattern(vec2 p) {\\n\\t\\n\\tfloat a = atan(p.x,p.y);\\n\\tfloat r = 9.0 * pow(1.0/length(p), 0.4);\\n\\tfloat t = time + length(p) * patternFactor0;\\n\\treturn vec2(sin(a*3.0+cos(t*0.25)*patternFactor1Rot), sin(r*2.+sin(time*timeFactor0)*timeFactorAmp));\\n}\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simfragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by vfragCoord \\n //replace gl_FragColor by v_color\\n \\n\\n\\tvec2 p = surfacePosition * 99.0;\\n\\tvec3 col = vec3(0.0);\\n\\t\\n\\tfor (int i=0; i<3; i++)\\n\\t\\tp.xy = pattern(p);\\n\\t\\n\\tcol.xy = sin(p.xy);\\n\\tcol.z = max(step(abs(p.x*p.x),0.5), -1.0 / abs(p.y));\\n\\t\\n\\tv_color = vec4( col, 1.0 );\\n\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n\n#define patternFactor0 0.0012//KParameter 0.0012>>0.12\n#define timeFactor0 0.1//KParameter 0.1>>1.\n#define timeFactorAmp 10.//KParameter 1.>>40.\n#define timeFactorAmp2 10.//KParameter 1.>>40.\n#define patternFactor1Rot 10.//KParameter 1.>>100.\n#define patternSymFactor 3.0//KParameter 1.>>10.\n\nvec2 pattern(vec2 p) {\n\t\n\tfloat a = atan(p.x,p.y);\n\tfloat r = 9.0 * pow(1.0/length(p), 0.4);\n\tfloat t = time + length(p) * patternFactor0;\n\treturn vec2(sin(a*3.0+cos(t*0.25)*patternFactor1Rot), sin(r*2.+sin(time*timeFactor0)*timeFactorAmp));\n}\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simfragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by vfragCoord \n //replace gl_FragColor by v_color\n \n\n\tvec2 p = surfacePosition * 99.0;\n\tvec3 col = vec3(0.0);\n\t\n\tfor (int i=0; i<3; i++)\n\t\tp.xy = pattern(p);\n\t\n\tcol.xy = sin(p.xy);\n\tcol.z = max(step(abs(p.x*p.x),0.5), -1.0 / abs(p.y));\n\t\n\tv_color = vec4( col, 1.0 );\n\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-hhnfvsdx8fv9sfu8z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mhyHwfLBurtz8PKsw/art.json b/art/mhyHwfLBurtz8PKsw/art.json index 8036d950..d5f219b5 100644 --- a/art/mhyHwfLBurtz8PKsw/art.json +++ b/art/mhyHwfLBurtz8PKsw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25,]\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25,]\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-d16ig95j94du9covs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mkFSba4s7DTHBu57L/art.json b/art/mkFSba4s7DTHBu57L/art.json index e34cbe96..beeedd8f 100644 --- a/art/mkFSba4s7DTHBu57L/art.json +++ b/art/mkFSba4s7DTHBu57L/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":14069,\"mode\":\"LINES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*a ) + exp( -k*b );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.00570;\\n \\tfloat transitionStrength = 1.5;\\n \\tvec3 colKernel0 = vec3(1,0,1);\\n \\tvec3 colKernel1 = vec3(0,0 ,0);\\n \\tvec3 colTransition = vec3(1,1,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*1.5;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 0.5 - mouse.x * 0.5;\\n\\tfloat ce = -1.5+mouse.y * 3.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(76.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = 1.0 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) *-dot(det*-det,2.-mouse.y);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.945); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 14069, + "mode": "LINES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*a ) + exp( -k*b );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.00570;\n \tfloat transitionStrength = 1.5;\n \tvec3 colKernel0 = vec3(1,0,1);\n \tvec3 colKernel1 = vec3(0,0 ,0);\n \tvec3 colTransition = vec3(1,1,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*1.5;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 0.5 - mouse.x * 0.5;\n\tfloat ce = -1.5+mouse.y * 3.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(76.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = 1.0 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) *-dot(det*-det,2.-mouse.y);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.945); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-6dvkbzy32j7ddsozg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mmB8umNE8t5qoNNJo/art.json b/art/mmB8umNE8t5qoNNJo/art.json index ec80c6c7..ccfe1b9c 100644 --- a/art/mmB8umNE8t5qoNNJo/art.json +++ b/art/mmB8umNE8t5qoNNJo/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":39377,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1450980392156863,0.08627450980392157,0.41568627450980394,1],\"shader\":\"/*\\nSeongwon Jang\\ncs250\\ncolor\\n2022 spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n\\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\\n\\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n\\n float ux = floor(id / 6.) + mod(id,2.);\\n \\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n \\n\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/ 6.0);\\n float oddSlice = mod(sliceId,2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2,5.) * mix(1.0,1.1,oddSlice);\\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ((time * 0.1));\\n mat *= trans(vec3(ux,vy,0));\\n mat *= rotZ(snd * 20.0 * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\\n \\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\\n\\n\\n float pump = step(0.8,snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1 + sliceId * 0.01;//+ sin(time + v * 20.) * 0.05;\\n float sat = 1.;mix(0.5,1.,pump);\\n float val = mix(.4,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\\n}\\n\"}", + "settings": { + "num": 39377, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1450980392156863, + 0.08627450980392157, + 0.41568627450980394, + 1 + ], + "shader": "/*\nSeongwon Jang\ncs250\ncolor\n2022 spring\n*/\n\nvec3 hsv2rgb(vec3 c)\n{\n\tc = vec3(c.x,clamp(c.yz,0.0,1.0));\n vec4 k = vec4(1.0,2.0/3.0,1.0/3.0,3.0);\n vec3 p = abs(fract(c.xxx+k.xyz)* 6.0 - k.www);\n return c.z * mix(k.xxx,clamp(p-k.xxx,0.0,1.0),c.y);\n\n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n\n float ux = floor(id / 6.) + mod(id,2.);\n \n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n \n\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId/ 6.0);\n float oddSlice = mod(sliceId,2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;// sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .05,av *.25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2,5.) * mix(1.0,1.1,oddSlice);\n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ((time * 0.1));\n mat *= trans(vec3(ux,vy,0));\n mat *= rotZ(snd * 20.0 * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\n \n \n gl_Position = mat * pos;\n\n float soff = 0.;// sin(time + x* y* 0.02) * 5.;\n\n\n float pump = step(0.8,snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1 + sliceId * 0.01;//+ sin(time + v * 20.) * 0.05;\n float sat = 1.;mix(0.5,1.,pump);\n float val = mix(.4,pow(snd + 0.2,5.),pump);// sin(time * 1.4 + v*u*20.0)*.5+.5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-3ncxh97tjoyi01wu4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mmn5xXR2yHGyorvsd/art.json b/art/mmn5xXR2yHGyorvsd/art.json index 0ea58347..a2b878da 100644 --- a/art/mmn5xXR2yHGyorvsd/art.json +++ b/art/mmn5xXR2yHGyorvsd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float dotsPerRow = 250.;\\n float dotsPerColumn = floor(vertexCount / dotsPerRow);\\n \\n float x = mod(vertexId, dotsPerRow);\\n float y = floor(vertexId / dotsPerRow);\\n vec2 pos = vec2(x, y);\\n pos *= vec2(1, resolution.x / resolution.y);\\n pos -= vec2(dotsPerRow * 0.5, dotsPerColumn * 0.5);\\n pos *= 1. / (2. * 2. * 2. * 2. * 2. * 2. * 2. * 2.);\\n gl_Position = vec4(pos, 0, 1);\\n float c = texture2D(sound, vec2(x / dotsPerRow, y / dotsPerColumn)).a;\\n c = pow(c * 1.5, 3.) - 0.25;\\n v_color = vec4(c, c, c, 0);\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float dotsPerRow = 250.;\n float dotsPerColumn = floor(vertexCount / dotsPerRow);\n \n float x = mod(vertexId, dotsPerRow);\n float y = floor(vertexId / dotsPerRow);\n vec2 pos = vec2(x, y);\n pos *= vec2(1, resolution.x / resolution.y);\n pos -= vec2(dotsPerRow * 0.5, dotsPerColumn * 0.5);\n pos *= 1. / (2. * 2. * 2. * 2. * 2. * 2. * 2. * 2.);\n gl_Position = vec4(pos, 0, 1);\n float c = texture2D(sound, vec2(x / dotsPerRow, y / dotsPerColumn)).a;\n c = pow(c * 1.5, 3.) - 0.25;\n v_color = vec4(c, c, c, 0);\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-v25djn1numzcz55wn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mmoaXfjg9s32v5Cpw/art.json b/art/mmoaXfjg9s32v5Cpw/art.json index 646b69e4..49aadee3 100644 --- a/art/mmoaXfjg9s32v5Cpw/art.json +++ b/art/mmoaXfjg9s32v5Cpw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\n\\n\\nfloat norm(float n)\\n{\\n if (n >= 0.49)\\n return 1.;\\n else\\n return 0.;\\n}\\n\\nfloat getb(float n, float pos)\\n{\\n return norm(mod(n / (pos * 2.), 1.0));\\n}\\n\\nfloat round(float n)\\n{\\n return floor(n + .5);\\n}\\n\\nfloat not(float n)\\n{\\n return floor(n * -1. + 1.);\\n}\\n\\nvec4 hypercube_lines(float id)\\n{\\n // outer cuber\\n float F = getb(id, 1.);\\n float E = getb(id, 2.);\\n float D = getb(id, 4.);\\n float C = getb(id, 8.);\\n float B = getb(id, 16.);\\n float A = getb(id, 32.);\\n \\n float FA = B*not(C)*not(D)*F+A*not(B)*C*not(E)+not(A)*C*D*F+B*not(C)*not(E)*F+not(A)*B*E*F+not(A)*B*D*E+A*not(B)*not(E)*not(F)+A*B*not(D)*not(E)*F+not(A)*B*C*not(E)*not(F)+B*C*D*E*F+A*not(B)*not(C)*E*F+A*B*not(C)*D*not(F)+not(A)*not(C)*not(D)*not(E)*F+A*not(B)*C*D*not(F)+not(A)*not(B)*not(C)*not(D)*E*not(F)+A*B*C*not(D)*E*not(F);\\n float FB = C*not(D)*E*F+not(B)*C*D*not(E)+C*D*not(E)*not(F)+B*C*not(D)*E+A*not(B)*not(D)*F+A*not(B)*not(D)*E+A*not(D)*E*F+not(A)*not(B)*not(C)*not(E)*F+not(A)*not(B)*not(C)*E*not(F)+not(A)*B*not(C)*not(E)*not(F)+B*not(C)*not(D)*not(E)*not(F)+not(A)*B*C*not(D)*F+A*not(B)*not(C)*not(E)*not(F)+A*not(B)*not(C)*E*F+A*B*D*not(E)*F+A*B*C*E*F;\\n float FC = A*D*F+A*not(B)*not(C)+A*not(B)*F+A*not(C)*D*not(E)+A*not(C)*not(E)*F+B*D*not(E)*F+not(A)*B*E*not(F)+A*C*D*E+A*C*E*F+not(B)*C*not(D)*E*not(F)+not(B)*C*D*E*F+not(A)*C*not(D)*not(E)*F;\\n float FD = D*not(E)*not(F)+B*not(C)*D+A*D*not(E)+not(A)*not(D)*E*F+not(C)*not(D)*E*F+not(B)*C*E*F+not(A)*B*not(C)*F+A*not(C)*E*not(F)+not(A)*not(B)*C*D*not(F)+A*not(B)*not(C)*not(D)*F;\\n\\n FA = norm(FA);\\n FB = norm(FB);\\n FC = norm(FC);\\n FD = norm(FD);\\n \\n float FF = mod(FA + FB * 2. + FC * 4. + FD * 8., 16.);\\n \\n return hypercube(FF);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 0, 0, 0);\\n vec4 up4 = vec4(0, 1, 0, 0);\\n vec4 over4 = vec4(0, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(3.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n float theta3 = 45.0 * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.1 * TAU);\\n vec4 v4 = hypercube_lines(mod(vertexId, 64.0));\\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect, 0, 1);\\n v_color = vec4(1,1,1, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\n\n\nfloat norm(float n)\n{\n if (n >= 0.49)\n return 1.;\n else\n return 0.;\n}\n\nfloat getb(float n, float pos)\n{\n return norm(mod(n / (pos * 2.), 1.0));\n}\n\nfloat round(float n)\n{\n return floor(n + .5);\n}\n\nfloat not(float n)\n{\n return floor(n * -1. + 1.);\n}\n\nvec4 hypercube_lines(float id)\n{\n // outer cuber\n float F = getb(id, 1.);\n float E = getb(id, 2.);\n float D = getb(id, 4.);\n float C = getb(id, 8.);\n float B = getb(id, 16.);\n float A = getb(id, 32.);\n \n float FA = B*not(C)*not(D)*F+A*not(B)*C*not(E)+not(A)*C*D*F+B*not(C)*not(E)*F+not(A)*B*E*F+not(A)*B*D*E+A*not(B)*not(E)*not(F)+A*B*not(D)*not(E)*F+not(A)*B*C*not(E)*not(F)+B*C*D*E*F+A*not(B)*not(C)*E*F+A*B*not(C)*D*not(F)+not(A)*not(C)*not(D)*not(E)*F+A*not(B)*C*D*not(F)+not(A)*not(B)*not(C)*not(D)*E*not(F)+A*B*C*not(D)*E*not(F);\n float FB = C*not(D)*E*F+not(B)*C*D*not(E)+C*D*not(E)*not(F)+B*C*not(D)*E+A*not(B)*not(D)*F+A*not(B)*not(D)*E+A*not(D)*E*F+not(A)*not(B)*not(C)*not(E)*F+not(A)*not(B)*not(C)*E*not(F)+not(A)*B*not(C)*not(E)*not(F)+B*not(C)*not(D)*not(E)*not(F)+not(A)*B*C*not(D)*F+A*not(B)*not(C)*not(E)*not(F)+A*not(B)*not(C)*E*F+A*B*D*not(E)*F+A*B*C*E*F;\n float FC = A*D*F+A*not(B)*not(C)+A*not(B)*F+A*not(C)*D*not(E)+A*not(C)*not(E)*F+B*D*not(E)*F+not(A)*B*E*not(F)+A*C*D*E+A*C*E*F+not(B)*C*not(D)*E*not(F)+not(B)*C*D*E*F+not(A)*C*not(D)*not(E)*F;\n float FD = D*not(E)*not(F)+B*not(C)*D+A*D*not(E)+not(A)*not(D)*E*F+not(C)*not(D)*E*F+not(B)*C*E*F+not(A)*B*not(C)*F+A*not(C)*E*not(F)+not(A)*not(B)*C*D*not(F)+A*not(B)*not(C)*not(D)*F;\n\n FA = norm(FA);\n FB = norm(FB);\n FC = norm(FC);\n FD = norm(FD);\n \n float FF = mod(FA + FB * 2. + FC * 4. + FD * 8., 16.);\n \n return hypercube(FF);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 0, 0, 0);\n vec4 up4 = vec4(0, 1, 0, 0);\n vec4 over4 = vec4(0, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(3.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n float theta3 = 45.0 * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.1 * TAU);\n vec4 v4 = hypercube_lines(mod(vertexId, 64.0));\n vec3 v3 = project4(v4, from4, 1.0, theta4, t4);\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect, 0, 1);\n v_color = vec4(1,1,1, 1);\n}" + }, "screenshotURL": "data/images/images-9d88j4bsb7bk7ioya-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mmxfYzJp3mCehkHcH/art.json b/art/mmxfYzJp3mCehkHcH/art.json index ee9d5b40..4604c8e0 100644 --- a/art/mmxfYzJp3mCehkHcH/art.json +++ b/art/mmxfYzJp3mCehkHcH/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/victorruiz/robots\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/victorruiz/robots", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-9yodmfgzylfb0202f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/moFoJGxvvHCxBdedE/art.json b/art/moFoJGxvvHCxBdedE/art.json index 47b7ff1f..091966ed 100644 --- a/art/moFoJGxvvHCxBdedE/art.json +++ b/art/moFoJGxvvHCxBdedE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.21568627450980393,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Colors\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.21568627450980393, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Colors\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-uuwss033ul0tqav60-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mp4Z7X2u8Njkoe3Cg/art.json b/art/mp4Z7X2u8Njkoe3Cg/art.json index 58a676db..dada22f0 100644 --- a/art/mp4Z7X2u8Njkoe3Cg/art.json +++ b/art/mp4Z7X2u8Njkoe3Cg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":21615,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//[commercial] \\n\\n//Another K Machine exposed shader\\n//See it in action in the K Machine v2 on https://vimeo.com/217012333\\n//the 'K beginning' comments allows the K Machine to recognize \\n//and build adapted events controllers\\n//This shader can be copied in a text file with .glsl extension and\\n//uploaded to the K Machine. \\n//For more instructions for K Machine compliance see the doc on\\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\\n//More about the K Machine v2\\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\\n//as the K Machine has it's own relLoopProgress float parameter\\n//corresponding to the progression in the selected loop\\n\\n//[/commercial]\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n#define parameter0 2.5//KParameter0 1.>>8.\\n#define parameter1 -0.782//KParameter1 -1.>>1.\\n#define parameter2 -0.2//KParameter2 -3.>>3.\\n#define parameter3 0.6//KParameter3 0.>>12.\\n#define parameter4 6.1//KP0arameter4 0.>>2.\\n#define parameter5 0.2//KParameter5 0.1>>4.5\\n#define parameter6 1.2//KParameter6 0.>>3.\\n#define parameter7 0.1//KParameter7 0.0>>10.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define SYMMETRY_H 0\\n#define SYMMETRY_V 1\\n#define COLOR_MODE 2\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\\n{\\n \\n \\n \\n \\n vec4 result = vec4(0., 0.,-1., 1.);\\n \\n \\n float localVertexId = _vertexId - _startVertexId;\\n \\n if(localVertexId<1.)\\n {\\n result.xy = _letter[11,2,0].xy;\\n }\\n else\\n \\n if(localVertexId<2.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n \\n else\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[6,16].xy;\\n }\\n else //2nd triangle\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<5.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<6.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n else\\n if(localVertexId<7.) \\n {\\n result.xy = _letter[2].xy;\\n }\\n else\\n if(localVertexId<8.)\\n {\\n result.xy = _letter[2].xy;\\n }\\n else\\n if(localVertexId<9.)\\n {\\n result.xy = _letter[8].xy;\\n \\n }\\n \\n else\\n if(localVertexId<10.)//4eme triangle\\n {\\n result.xy = _letter[4].xy;\\n \\n }\\n else\\n if(localVertexId<11.)\\n {\\n result.xy = _letter[10].xy;\\n \\n }\\n \\n else\\n if(localVertexId<12.)\\n {\\n result.xy = _letter[1,13].xy;\\n \\n }\\n else\\n if(localVertexId>=(3.,4.+parameter1))\\n {\\n result.xy = _letter[15,2].xy;\\n \\n }\\n else\\n if(localVertexId<14.)\\n {\\n result.xy = _letter[13].xy;\\n \\n }\\n else\\n if(localVertexId<15.)\\n {\\n result.xy = _letter[14,3,13].xy;\\n \\n }\\n else\\n if(localVertexId>6.)\\n {\\n result.xy = _letter[5,11].xy;\\n \\n }\\n else\\n if(localVertexId<17.)\\n {\\n result.xy = _letter[16].xy;\\n \\n }\\n else\\n if(localVertexId<18.)\\n {\\n result.xy = _letter[1,3].xy;\\n \\n }\\n result.xy+=_pos;\\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\\n result.xyz =rotZ(result.xyz, _rotation);\\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\\n result *= uniformScale(_scale);\\n \\n \\n return result.xyz;\\n}\\n\\n\\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\\n{\\n vec2 finalPos = _pos;\\n \\n \\n vec2 additionalPos = vec2(0.,0.);\\n \\n float transfoMode = floor(parameter3);\\n \\n \\n //additionalPos.x = _relLetterTimeProgress*0.5;\\n if(transfoMode<1.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n else\\n if(transfoMode<2.)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<3.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<4.)\\n {\\n additionalPos = -finalPos;\\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\\n \\n additionalPos.x+= m.x;\\n additionalPos.y+= m.y;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<5.)\\n {\\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<6.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<7.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n finalPos+= additionalPos;\\n }\\n \\n }\\n else\\n if(transfoMode<8.)\\n {\\n additionalPos = -finalPos;\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*2.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<9.)\\n {\\n additionalPos = -finalPos;\\n \\n if(mod(_shapeId,2.)<1.)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*3.-(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n \\n if(transfoMode<10.)\\n {\\n //if(_selectedShape == _shapeId)\\n {\\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\\n additionalPos.y = m.x*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n \\n else\\n \\n if(transfoMode<11.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\\n finalPos+= additionalPos;\\n }\\n \\n return finalPos;\\n}\\n\\n\\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\\n{\\n float finalRot = _rotation;\\n \\n float additionalRotation = 0.;\\n \\n float transfoMode = floor(parameter3);\\n \\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n else\\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n \\n \\n finalRot+= additionalRotation;\\n \\n /*\\n float additionalRotation = 0.;\\n \\n if(selectedLetterIndex == shapeId)\\n {\\n additionalRotation = 2.*PI*relLetterTimeProgress;\\n }\\n \\n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\\n */\\n \\n return finalRot;\\n}\\n\\n\\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\\n{\\n vec2 finalCenter = _center;\\n \\n \\n /*\\n vec2 additionalCenter = vec2(0.,0.);\\n \\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalCenter.x = _relLetterTimeProgress*0.5;\\n additionalCenter.y = _relLetterTimeProgress*0.5;\\n }\\n \\n finalCenter+= additionalCenter;\\n */\\n \\n return finalCenter;\\n}\\n\\n#define elementPerShapeLetterK 18.\\n\\n#define defaultRotationForShapeLetterK 0.13\\n#define defaultRotationForShapeLetterM - 0.09\\n#define defaultRotationForShapeLetterN 0.04\\n#define defaultRotationForShapeLetterA 0.1\\n#define defaultRotationForShapeLetterC - 0.05\\n#define defaultRotationForShapeLetterE - 0.03\\n#define defaultRotationForShapeLetterH 0.04\\n#define defaultRotationForShapeLetterI - 0.2\\n\\n\\n#define shapeNumber 8.\\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\\n\\nvoid main() {\\n \\n \\n vec3 color = vec3(1.);\\n \\n float sndFactor = texture2D(sound, vec2(1., .2)).r;\\n float _junctionY = 0.5 +parameter4*sndFactor/14.;\\n \\n float _barWidth = 0.2 + parameter4*sndFactor/100.;\\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\\n \\n float shapeId = 0.;\\n \\n vec2 letterK[18];\\n letterK[0] = vec2(0.,2.);\\n letterK[1] = vec2(0.,1.);\\n letterK[2] = vec2(_barWidth,1.);\\n letterK[3] = vec2(0.,0.0);\\n letterK[4] = vec2(_barWidth,1.);\\n letterK[5] = vec2(_barWidth,0.);\\n letterK[6] = vec2(_barWidth,_junctionY);\\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\\n letterK[8] = vec2(_secondVertY,1.);\\n letterK[9] = vec2(_barWidth,_junctionY);\\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\\n letterK[11] = vec2(_secondVertY,0.);\\n letterK[12] = vec2(_secondVertY,0.);\\n letterK[13] = vec2(_secondVertY,1.);\\n letterK[14] = vec2(_secondVertY,0.);\\n letterK[15] = vec2(_secondVertY,0.);\\n letterK[16] = vec2(_secondVertY,0.);\\n letterK[17] = vec2(_secondVertY,0.);\\n \\n vec2 letterM[18];\\n letterM[0] = vec2(0.,0.);\\n letterM[1] = vec2(0.,1.);\\n letterM[2] = vec2(_barWidth,1.);\\n letterM[3] = vec2(0.,0.0);\\n letterM[4] = vec2(_barWidth,1.);\\n letterM[5] = vec2(_barWidth,1.);//PROBLEM !!\\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterM[7] = vec2(_barWidth,1.);\\n letterM[8] = vec2(_barWidth*2.,_junctionY);\\n letterM[9] = vec2(_barWidth*2.,_junctionY);\\n letterM[10] = vec2((_barWidth*3.),1.);\\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\\n letterM[12] = vec2(_barWidth*3.,1.);\\n letterM[13] = vec2(_barWidth*4.,1.);\\n letterM[14] = vec2(_barWidth*3.,0.);\\n letterM[15] = vec2(_barWidth*3.,0.);\\n letterM[16] = vec2(_barWidth*4.,1.);\\n letterM[17] = vec2(_barWidth*4.,0.);\\n \\n \\n vec2 letterN[18];\\n letterN[0] = vec2(0.,0.);\\n letterN[1] = vec2(0.,1.);\\n letterN[2] = vec2(_barWidth,1.);\\n letterN[3] = vec2(0.,0.0);\\n letterN[4] = vec2(_barWidth,1.);\\n letterN[5] = vec2(_barWidth,0.);\\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterN[7] = vec2(_barWidth,1.);\\n letterN[8] = vec2(_barWidth*2.,_junctionY);\\n letterN[9] = vec2(_barWidth*2.,1.);\\n letterN[10] = vec2(_barWidth*3.,1.);\\n letterN[11] = vec2(_barWidth*2.,0.);\\n \\n letterN[12] = vec2(_barWidth*2.,0.);\\n letterN[13] = vec2(_barWidth*3.,1.);\\n letterN[14] = vec2(_barWidth*3.,0.);\\n letterN[15] = vec2(_barWidth*3.,0.);\\n \\n letterN[16] = vec2(_barWidth*3.,0.);\\n letterN[17] = vec2(_barWidth*3.,0.);\\n \\n \\n vec2 letterA[18];\\n letterA[0] = vec2(0.,0.);\\n letterA[1] = vec2(_barWidth,0.);\\n letterA[2] = vec2(_barWidth*2.,1.);\\n letterA[3] = vec2(_barWidth*4.,0.0);\\n letterA[4] = vec2(_barWidth*2.,1.);\\n letterA[5] = vec2(_barWidth*3.,0.);\\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\\n letterA[8] = vec2(_barWidth*3.,_junctionY);\\n letterA[9] = vec2(_barWidth*3.,_junctionY);\\n letterA[10] = vec2(_barWidth*3.,_junctionY);\\n letterA[11] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[12] = vec2(_barWidth*3.,_junctionY);\\n letterA[13] = vec2(_barWidth*3.,_junctionY);\\n letterA[14] = vec2(_barWidth*3.,_junctionY);\\n letterA[15] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[16] = vec2(_barWidth*3.,_junctionY);\\n letterA[17] = vec2(_barWidth*3.,_junctionY);\\n \\n \\n vec2 letterE[18];\\n letterE[0] = vec2(0.,0.);\\n letterE[1] = vec2(0.,1.);\\n letterE[2] = vec2(_barWidth,1.);\\n letterE[3] = vec2(0.,0.0);\\n letterE[4] = vec2(_barWidth,1.);\\n letterE[5] = vec2(_barWidth,0.);\\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\\n letterE[7] = vec2(_barWidth,1.);\\n letterE[8] = vec2(_barWidth*3.,1.);\\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\\n letterE[10] = vec2(_barWidth,0.);\\n letterE[11] = vec2(_barWidth*3.,0.);\\n letterE[12] = vec2(_barWidth,_junctionY);\\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n \\n \\n vec2 letterC[18];\\n letterC[0] = vec2(0.,0.);\\n letterC[1] = vec2(0.,1.);\\n letterC[2] = vec2(_barWidth,1.);\\n letterC[3] = vec2(0.,0.0);\\n letterC[4] = vec2(_barWidth,1.);\\n letterC[5] = vec2(_barWidth,0.);\\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\\n letterC[7] = vec2(_barWidth,1.);\\n letterC[8] = vec2(_barWidth*3.,1.);\\n letterC[9] = vec2(_barWidth,0.);\\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\\n letterC[11] = vec2(_barWidth*3.,0.);\\n letterC[12] = vec2(_barWidth*3.,0.);\\n letterC[13] = vec2(_barWidth*3.,0.);\\n letterC[14] = vec2(_barWidth*3.,0.);\\n letterC[15] = vec2(_barWidth*3.,0.);\\n letterC[16] = vec2(_barWidth*3.,0.);\\n letterC[17] = vec2(_barWidth*3.,0.);\\n \\n vec2 letterH[18];\\n letterH[0] = vec2(0.,0.);\\n letterH[1] = vec2(0.,1.);\\n letterH[2] = vec2(_barWidth,1.);\\n letterH[3] = vec2(0.,0.0);\\n letterH[4] = vec2(_barWidth,1.);\\n letterH[5] = vec2(_barWidth,0.);\\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\\n letterH[8] = vec2(_barWidth*2.,_junctionY);\\n letterH[9] = vec2(_barWidth*2.,_junctionY);\\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\\n letterH[12] = vec2(_barWidth*3.,1.);\\n letterH[13] = vec2(_barWidth*4.,1.);\\n letterH[14] = vec2(_barWidth*3.,0.);\\n letterH[15] = vec2(_barWidth*3.,0.);\\n letterH[16] = vec2(_barWidth*4.,1.);\\n letterH[17] = vec2(_barWidth*4.,0.);\\n \\n vec2 letterI[18];\\n letterI[0] = vec2(0.,0.);\\n letterI[1] = vec2(0.,_junctionY+_barWidth);\\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[3] = vec2(0.,0.0);\\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterI[6] = vec2(0.,1.-_barWidth);\\n letterI[7] = vec2(0.,1.);\\n letterI[8] = vec2(_barWidth,1.-_barWidth);\\n letterI[9] = vec2(_barWidth,1.-_barWidth);\\n letterI[10] = vec2(0.,1.);\\n letterI[11] = vec2(_barWidth,1.);\\n letterI[12] = vec2(_barWidth,1.);\\n letterI[13] = vec2(_barWidth,1.);\\n letterI[14] = vec2(_barWidth,1.);\\n letterI[15] = vec2(_barWidth,1.);\\n letterI[16] = vec2(_barWidth,1.);\\n letterI[17] = vec2(_barWidth,1.);\\n \\n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\\n \\n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\\n \\n finalVertexId = min(maxNumberOfVertices,vertexId);\\n \\n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\\n \\n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\\n //float relMetaShapeId = metaShapeId/256.;\\n \\n float masterScale = parameter5;//parameter6;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n \\n vec2 letterPos = vec2(0.,0.);\\n \\n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\\n \\n float scaleK = 0.1*masterScale;\\n float scale = 0.2*masterScale;\\n float startPosK = parameter2;\\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\\n \\n vec2 shapeCenter = vec2(0.1,0.15);\\n \\n //for vsa\\n \\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n \\n //end for vsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n \\n float numberOfSubLoops = floor(parameter0);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n \\n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\\n \\n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\\n \\n /////////////////////////\\n \\n float rotation = PI/2.*time*shapeId;\\n \\n if(finalVertexId0\\n else\\n if(vertexId0\\n else\\n if(vertexId1 && SYMMETRY_H >0\\n else\\n if(vertexId>8.\n#define parameter1 -0.782//KParameter1 -1.>>1.\n#define parameter2 -0.2//KParameter2 -3.>>3.\n#define parameter3 0.6//KParameter3 0.>>12.\n#define parameter4 6.1//KP0arameter4 0.>>2.\n#define parameter5 0.2//KParameter5 0.1>>4.5\n#define parameter6 1.2//KParameter6 0.>>3.\n#define parameter7 0.1//KParameter7 0.0>>10.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n#define SYMMETRY_H 0\n#define SYMMETRY_V 1\n#define COLOR_MODE 2\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\n{\n \n \n \n \n vec4 result = vec4(0., 0.,-1., 1.);\n \n \n float localVertexId = _vertexId - _startVertexId;\n \n if(localVertexId<1.)\n {\n result.xy = _letter[11,2,0].xy;\n }\n else\n \n if(localVertexId<2.)\n {\n result.xy = _letter[1].xy;\n }\n \n else\n if(localVertexId<4.)\n {\n result.xy = _letter[6,16].xy;\n }\n else //2nd triangle\n if(localVertexId<4.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<5.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<6.)\n {\n result.xy = _letter[1].xy;\n }\n else\n if(localVertexId<7.) \n {\n result.xy = _letter[2].xy;\n }\n else\n if(localVertexId<8.)\n {\n result.xy = _letter[2].xy;\n }\n else\n if(localVertexId<9.)\n {\n result.xy = _letter[8].xy;\n \n }\n \n else\n if(localVertexId<10.)//4eme triangle\n {\n result.xy = _letter[4].xy;\n \n }\n else\n if(localVertexId<11.)\n {\n result.xy = _letter[10].xy;\n \n }\n \n else\n if(localVertexId<12.)\n {\n result.xy = _letter[1,13].xy;\n \n }\n else\n if(localVertexId>=(3.,4.+parameter1))\n {\n result.xy = _letter[15,2].xy;\n \n }\n else\n if(localVertexId<14.)\n {\n result.xy = _letter[13].xy;\n \n }\n else\n if(localVertexId<15.)\n {\n result.xy = _letter[14,3,13].xy;\n \n }\n else\n if(localVertexId>6.)\n {\n result.xy = _letter[5,11].xy;\n \n }\n else\n if(localVertexId<17.)\n {\n result.xy = _letter[16].xy;\n \n }\n else\n if(localVertexId<18.)\n {\n result.xy = _letter[1,3].xy;\n \n }\n result.xy+=_pos;\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\n result.xyz =rotZ(result.xyz, _rotation);\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\n result *= uniformScale(_scale);\n \n \n return result.xyz;\n}\n\n\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\n{\n vec2 finalPos = _pos;\n \n \n vec2 additionalPos = vec2(0.,0.);\n \n float transfoMode = floor(parameter3);\n \n \n //additionalPos.x = _relLetterTimeProgress*0.5;\n if(transfoMode<1.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n else\n if(transfoMode<2.)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<3.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<4.)\n {\n additionalPos = -finalPos;\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\n \n additionalPos.x+= m.x;\n additionalPos.y+= m.y;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<5.)\n {\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<6.)\n {\n additionalPos = -finalPos;\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<7.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n finalPos+= additionalPos;\n }\n \n }\n else\n if(transfoMode<8.)\n {\n additionalPos = -finalPos;\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*2.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<9.)\n {\n additionalPos = -finalPos;\n \n if(mod(_shapeId,2.)<1.)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*3.-(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n \n if(transfoMode<10.)\n {\n //if(_selectedShape == _shapeId)\n {\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\n additionalPos.y = m.x*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n \n else\n \n if(transfoMode<11.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\n finalPos+= additionalPos;\n }\n \n return finalPos;\n}\n\n\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\n{\n float finalRot = _rotation;\n \n float additionalRotation = 0.;\n \n float transfoMode = floor(parameter3);\n \n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\n \n }\n }\n else\n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\n \n }\n }\n \n \n finalRot+= additionalRotation;\n \n /*\n float additionalRotation = 0.;\n \n if(selectedLetterIndex == shapeId)\n {\n additionalRotation = 2.*PI*relLetterTimeProgress;\n }\n \n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\n */\n \n return finalRot;\n}\n\n\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\n{\n vec2 finalCenter = _center;\n \n \n /*\n vec2 additionalCenter = vec2(0.,0.);\n \n \n if(_selectedShape == _shapeId)\n {\n additionalCenter.x = _relLetterTimeProgress*0.5;\n additionalCenter.y = _relLetterTimeProgress*0.5;\n }\n \n finalCenter+= additionalCenter;\n */\n \n return finalCenter;\n}\n\n#define elementPerShapeLetterK 18.\n\n#define defaultRotationForShapeLetterK 0.13\n#define defaultRotationForShapeLetterM - 0.09\n#define defaultRotationForShapeLetterN 0.04\n#define defaultRotationForShapeLetterA 0.1\n#define defaultRotationForShapeLetterC - 0.05\n#define defaultRotationForShapeLetterE - 0.03\n#define defaultRotationForShapeLetterH 0.04\n#define defaultRotationForShapeLetterI - 0.2\n\n\n#define shapeNumber 8.\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\n\nvoid main() {\n \n \n vec3 color = vec3(1.);\n \n float sndFactor = texture2D(sound, vec2(1., .2)).r;\n float _junctionY = 0.5 +parameter4*sndFactor/14.;\n \n float _barWidth = 0.2 + parameter4*sndFactor/100.;\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\n \n float shapeId = 0.;\n \n vec2 letterK[18];\n letterK[0] = vec2(0.,2.);\n letterK[1] = vec2(0.,1.);\n letterK[2] = vec2(_barWidth,1.);\n letterK[3] = vec2(0.,0.0);\n letterK[4] = vec2(_barWidth,1.);\n letterK[5] = vec2(_barWidth,0.);\n letterK[6] = vec2(_barWidth,_junctionY);\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\n letterK[8] = vec2(_secondVertY,1.);\n letterK[9] = vec2(_barWidth,_junctionY);\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\n letterK[11] = vec2(_secondVertY,0.);\n letterK[12] = vec2(_secondVertY,0.);\n letterK[13] = vec2(_secondVertY,1.);\n letterK[14] = vec2(_secondVertY,0.);\n letterK[15] = vec2(_secondVertY,0.);\n letterK[16] = vec2(_secondVertY,0.);\n letterK[17] = vec2(_secondVertY,0.);\n \n vec2 letterM[18];\n letterM[0] = vec2(0.,0.);\n letterM[1] = vec2(0.,1.);\n letterM[2] = vec2(_barWidth,1.);\n letterM[3] = vec2(0.,0.0);\n letterM[4] = vec2(_barWidth,1.);\n letterM[5] = vec2(_barWidth,1.);//PROBLEM !!\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterM[7] = vec2(_barWidth,1.);\n letterM[8] = vec2(_barWidth*2.,_junctionY);\n letterM[9] = vec2(_barWidth*2.,_junctionY);\n letterM[10] = vec2((_barWidth*3.),1.);\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\n letterM[12] = vec2(_barWidth*3.,1.);\n letterM[13] = vec2(_barWidth*4.,1.);\n letterM[14] = vec2(_barWidth*3.,0.);\n letterM[15] = vec2(_barWidth*3.,0.);\n letterM[16] = vec2(_barWidth*4.,1.);\n letterM[17] = vec2(_barWidth*4.,0.);\n \n \n vec2 letterN[18];\n letterN[0] = vec2(0.,0.);\n letterN[1] = vec2(0.,1.);\n letterN[2] = vec2(_barWidth,1.);\n letterN[3] = vec2(0.,0.0);\n letterN[4] = vec2(_barWidth,1.);\n letterN[5] = vec2(_barWidth,0.);\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterN[7] = vec2(_barWidth,1.);\n letterN[8] = vec2(_barWidth*2.,_junctionY);\n letterN[9] = vec2(_barWidth*2.,1.);\n letterN[10] = vec2(_barWidth*3.,1.);\n letterN[11] = vec2(_barWidth*2.,0.);\n \n letterN[12] = vec2(_barWidth*2.,0.);\n letterN[13] = vec2(_barWidth*3.,1.);\n letterN[14] = vec2(_barWidth*3.,0.);\n letterN[15] = vec2(_barWidth*3.,0.);\n \n letterN[16] = vec2(_barWidth*3.,0.);\n letterN[17] = vec2(_barWidth*3.,0.);\n \n \n vec2 letterA[18];\n letterA[0] = vec2(0.,0.);\n letterA[1] = vec2(_barWidth,0.);\n letterA[2] = vec2(_barWidth*2.,1.);\n letterA[3] = vec2(_barWidth*4.,0.0);\n letterA[4] = vec2(_barWidth*2.,1.);\n letterA[5] = vec2(_barWidth*3.,0.);\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\n letterA[8] = vec2(_barWidth*3.,_junctionY);\n letterA[9] = vec2(_barWidth*3.,_junctionY);\n letterA[10] = vec2(_barWidth*3.,_junctionY);\n letterA[11] = vec2(_barWidth*3.,_junctionY);\n \n letterA[12] = vec2(_barWidth*3.,_junctionY);\n letterA[13] = vec2(_barWidth*3.,_junctionY);\n letterA[14] = vec2(_barWidth*3.,_junctionY);\n letterA[15] = vec2(_barWidth*3.,_junctionY);\n \n letterA[16] = vec2(_barWidth*3.,_junctionY);\n letterA[17] = vec2(_barWidth*3.,_junctionY);\n \n \n vec2 letterE[18];\n letterE[0] = vec2(0.,0.);\n letterE[1] = vec2(0.,1.);\n letterE[2] = vec2(_barWidth,1.);\n letterE[3] = vec2(0.,0.0);\n letterE[4] = vec2(_barWidth,1.);\n letterE[5] = vec2(_barWidth,0.);\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\n letterE[7] = vec2(_barWidth,1.);\n letterE[8] = vec2(_barWidth*3.,1.);\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\n letterE[10] = vec2(_barWidth,0.);\n letterE[11] = vec2(_barWidth*3.,0.);\n letterE[12] = vec2(_barWidth,_junctionY);\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n \n \n vec2 letterC[18];\n letterC[0] = vec2(0.,0.);\n letterC[1] = vec2(0.,1.);\n letterC[2] = vec2(_barWidth,1.);\n letterC[3] = vec2(0.,0.0);\n letterC[4] = vec2(_barWidth,1.);\n letterC[5] = vec2(_barWidth,0.);\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\n letterC[7] = vec2(_barWidth,1.);\n letterC[8] = vec2(_barWidth*3.,1.);\n letterC[9] = vec2(_barWidth,0.);\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\n letterC[11] = vec2(_barWidth*3.,0.);\n letterC[12] = vec2(_barWidth*3.,0.);\n letterC[13] = vec2(_barWidth*3.,0.);\n letterC[14] = vec2(_barWidth*3.,0.);\n letterC[15] = vec2(_barWidth*3.,0.);\n letterC[16] = vec2(_barWidth*3.,0.);\n letterC[17] = vec2(_barWidth*3.,0.);\n \n vec2 letterH[18];\n letterH[0] = vec2(0.,0.);\n letterH[1] = vec2(0.,1.);\n letterH[2] = vec2(_barWidth,1.);\n letterH[3] = vec2(0.,0.0);\n letterH[4] = vec2(_barWidth,1.);\n letterH[5] = vec2(_barWidth,0.);\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\n letterH[8] = vec2(_barWidth*2.,_junctionY);\n letterH[9] = vec2(_barWidth*2.,_junctionY);\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\n letterH[12] = vec2(_barWidth*3.,1.);\n letterH[13] = vec2(_barWidth*4.,1.);\n letterH[14] = vec2(_barWidth*3.,0.);\n letterH[15] = vec2(_barWidth*3.,0.);\n letterH[16] = vec2(_barWidth*4.,1.);\n letterH[17] = vec2(_barWidth*4.,0.);\n \n vec2 letterI[18];\n letterI[0] = vec2(0.,0.);\n letterI[1] = vec2(0.,_junctionY+_barWidth);\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[3] = vec2(0.,0.0);\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterI[6] = vec2(0.,1.-_barWidth);\n letterI[7] = vec2(0.,1.);\n letterI[8] = vec2(_barWidth,1.-_barWidth);\n letterI[9] = vec2(_barWidth,1.-_barWidth);\n letterI[10] = vec2(0.,1.);\n letterI[11] = vec2(_barWidth,1.);\n letterI[12] = vec2(_barWidth,1.);\n letterI[13] = vec2(_barWidth,1.);\n letterI[14] = vec2(_barWidth,1.);\n letterI[15] = vec2(_barWidth,1.);\n letterI[16] = vec2(_barWidth,1.);\n letterI[17] = vec2(_barWidth,1.);\n \n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\n \n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\n \n finalVertexId = min(maxNumberOfVertices,vertexId);\n \n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\n \n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\n //float relMetaShapeId = metaShapeId/256.;\n \n float masterScale = parameter5;//parameter6;\n \n vec3 _v = vec3(0.,0.,0.);\n \n vec2 letterPos = vec2(0.,0.);\n \n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\n \n float scaleK = 0.1*masterScale;\n float scale = 0.2*masterScale;\n float startPosK = parameter2;\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\n \n vec2 shapeCenter = vec2(0.1,0.15);\n \n //for vsa\n \n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n \n //end for vsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n \n float numberOfSubLoops = floor(parameter0);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n \n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\n \n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\n \n /////////////////////////\n \n float rotation = PI/2.*time*shapeId;\n \n if(finalVertexId0\n else\n if(vertexId0\n else\n if(vertexId1 && SYMMETRY_H >0\n else\n if(vertexId .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < .5) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*510.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = .5;\\n \\n vec3 colour = vec3(0.);\\n\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n \\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/180.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,-22.);\\n}\"}", + "settings": { + "num": 16222, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"wired\" by kabuto\n// drawing a smoothed 3d hilbert curve\n\n// if this runs too slowly try zooming in\n// (ctrl + mousewheel up)\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*4.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76),\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476-2.1),\n sin(i*4.5553-2.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*3.36+2.1)\n\t)*.2;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n tan(i*.9553)*.9553 +\n cos(i) +\n cos(i*1.53)*1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*1.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n tan(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2.;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < .5) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*510.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = .5;\n \n vec3 colour = vec3(0.);\n\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n \n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/180.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,-22.);\n}" + }, "screenshotURL": "data/images/images-989fzhdu6slufo2tf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mxRdBjjLpuHvEjbMu/art.json b/art/mxRdBjjLpuHvEjbMu/art.json index cf6b6ad6..94de52ae 100644 --- a/art/mxRdBjjLpuHvEjbMu/art.json +++ b/art/mxRdBjjLpuHvEjbMu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "8bitrick", "avatarUrl": "https://avatars.githubusercontent.com/8BitRick?s=200", - "settings": "{\"num\":967,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/v-e-r-t-e/track1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n \\n //float y = texture2D(sound,vec2(vertex_per,row_per)).a + (row_per) - 1.;\\n gl_PointSize = 10.0;\\n //gl_Position = vec4(x,y,0,1);\\n //v_color = mix(vec4(hsv2rgb(vec3(0.25, fract(time+row_per), 1.)), 1.-row_per), background, row_per - 0.2);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 967, + "mode": "POINTS", + "sound": "https://soundcloud.com/v-e-r-t-e/track1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n \n //float y = texture2D(sound,vec2(vertex_per,row_per)).a + (row_per) - 1.;\n gl_PointSize = 10.0;\n //gl_Position = vec4(x,y,0,1);\n //v_color = mix(vec4(hsv2rgb(vec3(0.25, fract(time+row_per), 1.)), 1.-row_per), background, row_per - 0.2);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-csq4cswmswyrw64h8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/myzkqKCqtFmmhW5sv/art.json b/art/myzkqKCqtFmmhW5sv/art.json index ecbecc01..214e8a5c 100644 --- a/art/myzkqKCqtFmmhW5sv/art.json +++ b/art/myzkqKCqtFmmhW5sv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "guilleperez", "avatarUrl": "https://avatars.githubusercontent.com/guilleperez?s=200", - "settings": "{\"num\":62,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() \\n{\\n float width = 10.0;\\n \\n //vertexId = 0, 1, 2, 3, 4, 5\\n float x = floor(vertexId / 2.0); //0, 0, 1, 1, 2, 2\\n float y = mod(vertexId + 1.0, 2.0); //1, 0, 1, 0\\n \\n \\n float angle = x / 30.0 * radians(360.0);\\n float r = 2.0 - y;\\n \\n float u = r * cos(angle);\\n float v = r * sin(angle);\\n \\n vec2 xy = vec2(u, v) * 0.1; //se puede crear vec4 con vectores 2 -> vec4(xy, 0.0, 1.0);\\n\\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0); //position del vec4\\n v_color = vec4(1.0, 0.0, 0.0, 1.0); //color\\n gl_PointSize = 20.0;\\n}\"}", + "settings": { + "num": 62, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() \n{\n float width = 10.0;\n \n //vertexId = 0, 1, 2, 3, 4, 5\n float x = floor(vertexId / 2.0); //0, 0, 1, 1, 2, 2\n float y = mod(vertexId + 1.0, 2.0); //1, 0, 1, 0\n \n \n float angle = x / 30.0 * radians(360.0);\n float r = 2.0 - y;\n \n float u = r * cos(angle);\n float v = r * sin(angle);\n \n vec2 xy = vec2(u, v) * 0.1; //se puede crear vec4 con vectores 2 -> vec4(xy, 0.0, 1.0);\n\n \n \n gl_Position = vec4(xy, 0.0, 1.0); //position del vec4\n v_color = vec4(1.0, 0.0, 0.0, 1.0); //color\n gl_PointSize = 20.0;\n}" + }, "screenshotURL": "data/images/images-ie8wy3m53r6l938qc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mzP3C2u6pnBFBmKvu/art.json b/art/mzP3C2u6pnBFBmKvu/art.json index 9fc76dfd..b7d03d11 100644 --- a/art/mzP3C2u6pnBFBmKvu/art.json +++ b/art/mzP3C2u6pnBFBmKvu/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":4608,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8392156862745098,0.9450980392156862,1,1],\"shader\":\"/*frrrrrr\\neee\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nfloat easeInOutPow(float pos, float pw) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, pw);\\n }\\n return 0.5 * (pow((pos - 2.), pw) + 2.);\\n}\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float vId = mod(vertexId, 36.);\\n vec3 qpos;\\n vec3 qnrm;\\n getCubePoint(vId, qpos, qnrm);\\n \\n float ux = floor(vId / 6.) + mod(vId, 2.);\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \\n \\n float quadsPerArea = 4.;\\n float pointsPerArea = quadsPerArea * 36.;\\n float areaId = floor(vertexId / pointsPerArea);\\n float numAreas = floor(vertexCount / pointsPerArea);\\n float areaV = areaId / numAreas;\\n float areaVertId = mod(vertexId, pointsPerArea);\\n float rowId = floor(areaVertId / 36.);\\n \\n float maxBarHeight = 0.025;\\n const int numSamples = 20; // number of history samples to read. So 30 = 1/2 second\\n const int samplesPerArea = 64; // samples across a row. There are 4096 samples I think\\n // 128 would be 32 area\\n \\n \\n float sampleRangePerArea = soundRes.x / float(samplesPerArea);\\n float sampleRangeMult = sampleRangePerArea / float(samplesPerArea) / soundRes.x; \\n \\n float timeMaxS = 0.0;\\n float instMaxS = 0.0;\\n float avgS = 0.0;\\n float timeAvgS = 0.0;\\n for (int j = 0; j < samplesPerArea; ++j) {\\n float su = mix(0., 0.6, pow(areaV, 1.0) + float(j) * sampleRangeMult);\\n float s = texture2D(sound, vec2(su, 0)).a;\\n avgS += s;\\n timeAvgS += s;\\n instMaxS = max(s, instMaxS);\\n timeMaxS = max(s, timeMaxS);\\n for (int i = 1; i < numSamples; ++i) {\\n s = texture2D(sound, vec2(su, (float(i) + .5) / soundRes.y)).a;\\n timeAvgS += s;\\n timeMaxS = max(s, timeMaxS);\\n }\\n } \\n \\n avgS /= float(samplesPerArea);\\n timeAvgS /= float(samplesPerArea * numSamples);\\n \\n float isRow2 = step(1.5, rowId);\\n float isRow3 = step(2.5, rowId);\\n \\n float radius = numAreas * .5;\\n mat4 pmat = persp(radians(60.), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(0, numAreas * .3, radius);\\n vec3 target = vec3(0, 3, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up);\\n mat4 wmat = ident();\\n \\n float height = 10.;\\n float row0 = 0.;\\n float row1 = timeMaxS - maxBarHeight * .9;\\n float row2 = avgS - maxBarHeight * .9;\\n wmat *= scale(\\n mix(vec3(1), vec3(1, 0.001, 1.1), isRow3));\\n wmat *= rotY(areaV * PI * 2. + time * -.1);\\n wmat *= rotZ(mix(-.3, .3, timeAvgS * .7 + sin(time + areaV * PI * 2.) * .1));\\n wmat *= trans(vec3(\\n numAreas / 4.5, //(areaId - numAreas * .5) * 1.9, \\n mix(mix(row0, row1, step(0.5, rowId)), row2, isRow2) * height * step(rowId, 2.5),\\n mix(0., 0., step(2.5,rowId))));\\n float scaleFudge = mix(0.75, 1.0, step(0.5, rowId));\\n wmat *= scale(vec3(\\n scaleFudge, \\n mix(instMaxS, maxBarHeight, step(0.5, rowId)) * height, \\n scaleFudge));\\n wmat *= trans(vec3(0., .5, 0));\\n wmat *= uniformScale(.5 / .7);\\n \\n gl_Position = pmat * vmat * wmat * vec4(qpos, 1);\\n \\n float l = dot(mat3(wmat) * qnrm, normalize(vec3(1,1,3))) * .5 + .5;\\n\\n float hue = mix(.3, 0., instMaxS) /* ;areaV * .2 */ + rowId * .8 + step(1.5, rowId) * .0;\\n float sat = mix(0.5, 1., instMaxS);\\n float val = mix(mix(0.8, 1.0, pow(instMaxS, 3.)), mix(0.2, 2.0, pow(timeMaxS + .2, 5.0)), rowId);\\n val = mix(val, mix(0.4, 1.0, avgS), isRow2);\\n sat = mix(1., 0., isRow3);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * l, 1);\\n}//\"}", + "settings": { + "num": 4608, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8392156862745098, + 0.9450980392156862, + 1, + 1 + ], + "shader": "/*frrrrrr\neee\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nfloat easeInOutPow(float pos, float pw) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, pw);\n }\n return 0.5 * (pow((pos - 2.), pw) + 2.);\n}\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float vId = mod(vertexId, 36.);\n vec3 qpos;\n vec3 qnrm;\n getCubePoint(vId, qpos, qnrm);\n \n float ux = floor(vId / 6.) + mod(vId, 2.);\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \n \n float quadsPerArea = 4.;\n float pointsPerArea = quadsPerArea * 36.;\n float areaId = floor(vertexId / pointsPerArea);\n float numAreas = floor(vertexCount / pointsPerArea);\n float areaV = areaId / numAreas;\n float areaVertId = mod(vertexId, pointsPerArea);\n float rowId = floor(areaVertId / 36.);\n \n float maxBarHeight = 0.025;\n const int numSamples = 20; // number of history samples to read. So 30 = 1/2 second\n const int samplesPerArea = 64; // samples across a row. There are 4096 samples I think\n // 128 would be 32 area\n \n \n float sampleRangePerArea = soundRes.x / float(samplesPerArea);\n float sampleRangeMult = sampleRangePerArea / float(samplesPerArea) / soundRes.x; \n \n float timeMaxS = 0.0;\n float instMaxS = 0.0;\n float avgS = 0.0;\n float timeAvgS = 0.0;\n for (int j = 0; j < samplesPerArea; ++j) {\n float su = mix(0., 0.6, pow(areaV, 1.0) + float(j) * sampleRangeMult);\n float s = texture2D(sound, vec2(su, 0)).a;\n avgS += s;\n timeAvgS += s;\n instMaxS = max(s, instMaxS);\n timeMaxS = max(s, timeMaxS);\n for (int i = 1; i < numSamples; ++i) {\n s = texture2D(sound, vec2(su, (float(i) + .5) / soundRes.y)).a;\n timeAvgS += s;\n timeMaxS = max(s, timeMaxS);\n }\n } \n \n avgS /= float(samplesPerArea);\n timeAvgS /= float(samplesPerArea * numSamples);\n \n float isRow2 = step(1.5, rowId);\n float isRow3 = step(2.5, rowId);\n \n float radius = numAreas * .5;\n mat4 pmat = persp(radians(60.), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(0, numAreas * .3, radius);\n vec3 target = vec3(0, 3, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 vmat = cameraLookAt(eye, target, up);\n mat4 wmat = ident();\n \n float height = 10.;\n float row0 = 0.;\n float row1 = timeMaxS - maxBarHeight * .9;\n float row2 = avgS - maxBarHeight * .9;\n wmat *= scale(\n mix(vec3(1), vec3(1, 0.001, 1.1), isRow3));\n wmat *= rotY(areaV * PI * 2. + time * -.1);\n wmat *= rotZ(mix(-.3, .3, timeAvgS * .7 + sin(time + areaV * PI * 2.) * .1));\n wmat *= trans(vec3(\n numAreas / 4.5, //(areaId - numAreas * .5) * 1.9, \n mix(mix(row0, row1, step(0.5, rowId)), row2, isRow2) * height * step(rowId, 2.5),\n mix(0., 0., step(2.5,rowId))));\n float scaleFudge = mix(0.75, 1.0, step(0.5, rowId));\n wmat *= scale(vec3(\n scaleFudge, \n mix(instMaxS, maxBarHeight, step(0.5, rowId)) * height, \n scaleFudge));\n wmat *= trans(vec3(0., .5, 0));\n wmat *= uniformScale(.5 / .7);\n \n gl_Position = pmat * vmat * wmat * vec4(qpos, 1);\n \n float l = dot(mat3(wmat) * qnrm, normalize(vec3(1,1,3))) * .5 + .5;\n\n float hue = mix(.3, 0., instMaxS) /* ;areaV * .2 */ + rowId * .8 + step(1.5, rowId) * .0;\n float sat = mix(0.5, 1., instMaxS);\n float val = mix(mix(0.8, 1.0, pow(instMaxS, 3.)), mix(0.2, 2.0, pow(timeMaxS + .2, 5.0)), rowId);\n val = mix(val, mix(0.4, 1.0, avgS), isRow2);\n sat = mix(1., 0., isRow3);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * l, 1);\n}//" + }, "screenshotURL": "data/images/images-fyc3sujwzfffrya2g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/mzuqTuSfSh92e3vBL/art.json b/art/mzuqTuSfSh92e3vBL/art.json index a8d1f2a7..96a31954 100644 --- a/art/mzuqTuSfSh92e3vBL/art.json +++ b/art/mzuqTuSfSh92e3vBL/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lizell", "avatarUrl": "https://secure.gravatar.com/avatar/8cbc7cccd5a415ae64aab0284832279b?default=retro&size=200", - "settings": "{\"num\":2421,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x * y * 0.02) *5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 2421, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x * y * 0.02) *5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-5ixrtlzv2ewsw4h75-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/mzzBJYvnnyvaq6xcD/art.json b/art/mzzBJYvnnyvaq6xcD/art.json index 1dd31020..82c61e6a 100644 --- a/art/mzzBJYvnnyvaq6xcD/art.json +++ b/art/mzzBJYvnnyvaq6xcD/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":3739,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00392156862745098,0.023529411764705882,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 8.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float val = sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 3739, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00392156862745098, + 0.023529411764705882, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 8.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = 1.0;\n float val = sin(time * 1. + v * u * 20.0) + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-gtxhoo1885m3mk2eu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/n352wBmDRgQWXEJoN/art.json b/art/n352wBmDRgQWXEJoN/art.json index 1f2afbd6..61017969 100644 --- a/art/n352wBmDRgQWXEJoN/art.json +++ b/art/n352wBmDRgQWXEJoN/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n//\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 1.33) + sin(time * 0.83 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n\\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n//\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 1.33) + sin(time * 0.83 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 2.8 / 2.)) * 0.05, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-1bk2kajwk22mthqzg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/n4dz8Mdn2qsYrcyZq/art.json b/art/n4dz8Mdn2qsYrcyZq/art.json index d58c2025..e92c50c4 100644 --- a/art/n4dz8Mdn2qsYrcyZq/art.json +++ b/art/n4dz8Mdn2qsYrcyZq/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "8bitrick", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution vertexCount\\n\\n// -- Just added the dynamic width and height to allow different # of vertices --\\n//\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define temp sqrt(vertexCount / 0.24)\\n#define width temp*0.6\\n#define height temp*0.4\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(3.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\\n gl_PointSize = 1.0;\\n\\n \\n v_color = vec4(0.5 + c, 0.5 + c, 1.5 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution vertexCount\n\n// -- Just added the dynamic width and height to allow different # of vertices --\n//\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define temp sqrt(vertexCount / 0.24)\n#define width temp*0.6\n#define height temp*0.4\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(3.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\n gl_PointSize = 1.0;\n\n \n v_color = vec4(0.5 + c, 0.5 + c, 1.5 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-dyga3hqff4olb05j3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/n52WuRHLrJFWonAPp/art.json b/art/n52WuRHLrJFWonAPp/art.json index 100b559b..f043a4d0 100644 --- a/art/n52WuRHLrJFWonAPp/art.json +++ b/art/n52WuRHLrJFWonAPp/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "mark", "avatarUrl": "https://lh3.googleusercontent.com/-Lca4UGau1OU/AAAAAAAAAAI/AAAAAAAAAI4/dSttspxaINs/photo.jpg", - "settings": "{\"num\":8086,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define FALLTIME 5.\\n\\nfloat rand(vec2 co){\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nvoid main () {\\n float i = vertexId;\\n float tdiff = 0.;\\n if (mod(vertexId, 2.) > 0.) {\\n i -= 1.;\\n tdiff = -.01;\\n }\\n \\n float fallTime = 1. + rand(vec2(i, 0.2423424)) * FALLTIME;\\n \\n float t = mod(time, fallTime) + tdiff;\\n\\n float y = -2. * (t / fallTime) + 1.;\\n float x = -1.5 + rand(\\n vec2(i, floor(time / fallTime))\\n ) * 3. + .2 / fallTime * t;\\n y += .1 * sin(x + t);\\n \\n \\n float l = .7 + .3 * sin(t);\\n gl_Position = vec4(x, y, 0, 1);\\n v_color = vec4(l, l, l, 1);\\n}\"}", + "settings": { + "num": 8086, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define FALLTIME 5.\n\nfloat rand(vec2 co){\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nvoid main () {\n float i = vertexId;\n float tdiff = 0.;\n if (mod(vertexId, 2.) > 0.) {\n i -= 1.;\n tdiff = -.01;\n }\n \n float fallTime = 1. + rand(vec2(i, 0.2423424)) * FALLTIME;\n \n float t = mod(time, fallTime) + tdiff;\n\n float y = -2. * (t / fallTime) + 1.;\n float x = -1.5 + rand(\n vec2(i, floor(time / fallTime))\n ) * 3. + .2 / fallTime * t;\n y += .1 * sin(x + t);\n \n \n float l = .7 + .3 * sin(t);\n gl_Position = vec4(x, y, 0, 1);\n v_color = vec4(l, l, l, 1);\n}" + }, "screenshotURL": "data/images/images-actdexf2ej4ggy30m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/n5oxjfMDGtJusocHH/art.json b/art/n5oxjfMDGtJusocHH/art.json index c72461e1..1d5209c3 100644 --- a/art/n5oxjfMDGtJusocHH/art.json +++ b/art/n5oxjfMDGtJusocHH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.49411764705882355,0.49411764705882355,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nmat4 camera(){\\n float a = resolution.y / resolution.x;\\n float fov = radians(110.);\\n float f = tan(PI * 0.5 - fov * 0.5);\\n float near = 0.1;\\n float far = 1000.;\\n float invrange = 1. / (near - far);\\n \\n return mat4(\\n f * a, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (near + far) * invrange, -1,\\n 0, 0, near * far * invrange * 2., 1);\\n}\\n\\nvoid main()\\n{\\n float triId = floor(vertexId / 3.);\\n float triIdx = mod(vertexId, 3.);\\n float quadHalf = mod(triId, 2.);\\n // 0 1 2 2 3 0 0 1 2 2 3 0\\n float quadIdx = mod(triIdx + quadHalf * 2., 4.);\\n float quadId = floor(vertexId / 6.);\\n float s = sin(quadIdx / 4. * TAU + (PI / 4.));\\n float c = cos(quadIdx / 4. * TAU + (PI / 4.));\\n vec3 v_pos = vec3(s, c, 0);\\n \\n float qs_across = 25.;\\n vec3 q_pos = vec3(floor(quadId / qs_across) * sqrt(2.), mod(quadId, qs_across) * sqrt(2.), 0);\\n \\n vec4 offset = vec4(-10, -10, 0, 0);\\n \\n gl_Position = camera() * vec4((q_pos + v_pos).xy, -5., 1) + offset;\\n v_color = vec4(sin(v_pos.y * v_pos.x + time) * 0.5 + 0.5, v_pos.y * 0.5 + 0.5, 0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.49411764705882355, + 0.49411764705882355, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nmat4 camera(){\n float a = resolution.y / resolution.x;\n float fov = radians(110.);\n float f = tan(PI * 0.5 - fov * 0.5);\n float near = 0.1;\n float far = 1000.;\n float invrange = 1. / (near - far);\n \n return mat4(\n f * a, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (near + far) * invrange, -1,\n 0, 0, near * far * invrange * 2., 1);\n}\n\nvoid main()\n{\n float triId = floor(vertexId / 3.);\n float triIdx = mod(vertexId, 3.);\n float quadHalf = mod(triId, 2.);\n // 0 1 2 2 3 0 0 1 2 2 3 0\n float quadIdx = mod(triIdx + quadHalf * 2., 4.);\n float quadId = floor(vertexId / 6.);\n float s = sin(quadIdx / 4. * TAU + (PI / 4.));\n float c = cos(quadIdx / 4. * TAU + (PI / 4.));\n vec3 v_pos = vec3(s, c, 0);\n \n float qs_across = 25.;\n vec3 q_pos = vec3(floor(quadId / qs_across) * sqrt(2.), mod(quadId, qs_across) * sqrt(2.), 0);\n \n vec4 offset = vec4(-10, -10, 0, 0);\n \n gl_Position = camera() * vec4((q_pos + v_pos).xy, -5., 1) + offset;\n v_color = vec4(sin(v_pos.y * v_pos.x + time) * 0.5 + 0.5, v_pos.y * 0.5 + 0.5, 0, 1);\n}" + }, "screenshotURL": "data/images/images-qljwrmsm5u37u127y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/n7ehxG4s62oNWw5S3/art.json b/art/n7ehxG4s62oNWw5S3/art.json index 327ed4bc..9fa45c5f 100644 --- a/art/n7ehxG4s62oNWw5S3/art.json +++ b/art/n7ehxG4s62oNWw5S3/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "♫♪♭♮{{triplesix g}}♯♪♫", "avatarUrl": "https://i1.sndcdn.com/avatars-000125357779-rcbpr2-large.jpg", - "settings": "{\"num\":99427,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/diskore/m4r-2017-01-31\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n#define KP0 3. *mouse.x//KParameter0 0.>>10.\\n#define KP1 3. *mouse.y//Kparameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>5.\\n#define KP3 0.//KParameter3 0.>>0.5\\n#define KP4 2.//KParameter4 0.>>2.0\\n#define KP5 2222.0//KParameter5 1000.>>180000.\\n//KVerticesNumber=KP5\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 8.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p /K.xxx, 1.005, 1.0 -KP4), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 1, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1) ; \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -0.2, 0, 1, 0,\\n trans, 1.5);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -0.5, 1, 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.2 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect + f, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v -sin(time-3.);\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE (6. *mouse.x)\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE - sin(2. /FACES_PER_CUBE))\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE+ 11.5);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -11., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE)*sin(-1.5 * time + flip);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), time-6.0);\\n float a = pointId * PI * 2. / 4. + PI * .25;\\n vec3 p = vec3(cos(a + 1.), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, time-0.34, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.-KP0);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2. +mouse.x)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross -21.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * tan(11.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.2, 0.5 /cu, gs), gt * (0.05 + KP3))).a; \\n float VC = vertexCount;\\n float (KP5 /mouse.y)*s2;\\n \\n vec3 pos;\\n float inner = sin(-1.3-KP2);\\n float start = 0.5- 0.0003 +s2;\\n float end = 2./tan(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv ,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0.5,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, s2* .1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2.3, mod(circleId, 2.)) + gy * (0.0 +KP2) * cos(time * .1));\\n //[sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) - KP3 * 1. * sign(h)); \\n mat *= scale(vec3(0.8/KP0, sin(11.9 * s2)* 8.0, 1.5));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, KP3+ .5)*cos(s /s2);\\n gl_PointSize = 2.;\\n\\n float hue = 1. + cgId - 1.4;\\n float sat = 1.7 - step(pow(s2, mouse.y * 2.), abs(gt+ 2. * 11.) * .33);\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x/KP1, sat/s2*5., val)), (0.3 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 99427, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/diskore/m4r-2017-01-31", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n#define KP0 3. *mouse.x//KParameter0 0.>>10.\n#define KP1 3. *mouse.y//Kparameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>5.\n#define KP3 0.//KParameter3 0.>>0.5\n#define KP4 2.//KParameter4 0.>>2.0\n#define KP5 2222.0//KParameter5 1000.>>180000.\n//KVerticesNumber=KP5\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 8.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p /K.xxx, 1.005, 1.0 -KP4), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 1, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1) ; \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -0.2, 0, 1, 0,\n trans, 1.5);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -0.5, 1, 0,\n 0, 0, 0, 2);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.2 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect + f, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v -sin(time-3.);\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE (6. *mouse.x)\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE - sin(2. /FACES_PER_CUBE))\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE+ 11.5);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -11., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE)*sin(-1.5 * time + flip);\n float pointId = mod(facePointId - floor(facePointId / 3.0), time-6.0);\n float a = pointId * PI * 2. / 4. + PI * .25;\n vec3 p = vec3(cos(a + 1.), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, time-0.34, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.-KP0);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2. +mouse.x)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross -21.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * tan(11.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.2, 0.5 /cu, gs), gt * (0.05 + KP3))).a; \n float VC = vertexCount;\n float (KP5 /mouse.y)*s2;\n \n vec3 pos;\n float inner = sin(-1.3-KP2);\n float start = 0.5- 0.0003 +s2;\n float end = 2./tan(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv ,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0.5,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, s2* .1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2.3, mod(circleId, 2.)) + gy * (0.0 +KP2) * cos(time * .1));\n //[sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) - KP3 * 1. * sign(h)); \n mat *= scale(vec3(0.8/KP0, sin(11.9 * s2)* 8.0, 1.5));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, KP3+ .5)*cos(s /s2);\n gl_PointSize = 2.;\n\n float hue = 1. + cgId - 1.4;\n float sat = 1.7 - step(pow(s2, mouse.y * 2.), abs(gt+ 2. * 11.) * .33);\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x/KP1, sat/s2*5., val)), (0.3 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-mncdi9e3zm7j55kau-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/n7ipvkgkeT93uBRGq/art.json b/art/n7ipvkgkeT93uBRGq/art.json index 88ff6621..da047cfc 100644 --- a/art/n7ipvkgkeT93uBRGq/art.json +++ b/art/n7ipvkgkeT93uBRGq/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "박상준(학부학생/생명시스템대학생명공학)", "avatarUrl": "https://lh3.googleusercontent.com/a/AATXAJxAcrrfeg8eOCyYB8T3b6U0NeCy6gg3LvHlRvc_=s96-c", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03529411764705882,0,0.2196078431372549,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y /(across - 1.);\\n \\n float xoff = sin(time + y * 0.1);\\n float yoff = sin(time + x * 0.2);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy)*0.5;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time) * 5.;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n v_color = vec4(1, 0, 0, 1);\\n \\n\\n}\\n \"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03529411764705882, + 0, + 0.2196078431372549, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y /(across - 1.);\n \n float xoff = sin(time + y * 0.1);\n float yoff = sin(time + x * 0.2);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy)*0.5;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time) * 5.;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n v_color = vec4(1, 0, 0, 1);\n \n\n}\n " + }, "screenshotURL": "data/images/images-uiea4vnub5pkp631k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/n8PMuEQT8BEAXbPgC/art.json b/art/n8PMuEQT8BEAXbPgC/art.json index 550835e3..db4311d0 100644 --- a/art/n8PMuEQT8BEAXbPgC/art.json +++ b/art/n8PMuEQT8BEAXbPgC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nmat4 persp (float fov, float aspect, float zNear, float zFar)\\n{\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n \\n return mat4(\\n \\tf / aspect, 0, 0, 0,\\n \\t0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n \\t0, 0, zNear * zFar * rangeInv * 2.0, 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\\n{\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n \\n return mat4(\\n zAxis, 0,\\n xAxis, 0,\\n yAxis, 0,\\n eye , 2\\n );\\n}\\n\\nvec3 pos_point[10];\\nvec3 colors[10];\\nvoid drow_point()\\n{\\n pos_point[0] = vec3(-.5, -.5, .0);\\n pos_point[1] = vec3(-.5 , .5, .0);\\n pos_point[2] = vec3(.5 , -.5, .0);\\n pos_point[3] = vec3(.5 , .5, .0);\\n pos_point[4] = vec3(.5 , -.5, .5);\\n pos_point[5] = vec3(.5 , .5, .5);\\n pos_point[6] = vec3(-.5, -.5, .5);\\n pos_point[7] = vec3(-.5 , .5, .5);\\n pos_point[8] = vec3(-.5, -.5, .0);\\n pos_point[9] = vec3(-.5 , .5, .0);\\n \\n colors[0] = vec3(1, 0, 0);\\n colors[1] = vec3(1, 0, 0);\\n colors[2] = vec3(0, 0, 1);\\n colors[3] = vec3(0, 0, 1);\\n colors[4] = vec3(1, 1, 1);\\n colors[5] = vec3(1, 1, 1);\\n colors[6] = vec3(0.2, 1, 0);\\n colors[7] = vec3(0.2, 1, 0);\\n colors[8] = vec3(0.5, 0, 0.5);\\n colors[9] = vec3(0.5, 0, 0.5);\\n}\\n\\nvoid main() {\\n drow_point();\\n int VD = int(vertexId);\\n vec2 m = mouse;\\n \\n float ct = time *0.3;\\n vec3 p = vec3(0 , m.y, -2.5);\\n vec3 t = vec3(25.*cos(ct), 0., 25.*sin(ct));\\n vec3 u = vec3(0, 1, 0);\\n\\n for( int i=0; i<10; i++)\\n {\\n if(VD == i)\\n {\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= lookAt(p, t, u);\\n gl_Position = m * vec4(pos_point[i], 1);\\n gl_PointSize = 20.;\\n v_color = vec4(colors[i], 1.0);\\n }\\n }\\n\\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nmat4 persp (float fov, float aspect, float zNear, float zFar)\n{\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n \n return mat4(\n \tf / aspect, 0, 0, 0,\n \t0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n \t0, 0, zNear * zFar * rangeInv * 2.0, 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up)\n{\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n \n return mat4(\n zAxis, 0,\n xAxis, 0,\n yAxis, 0,\n eye , 2\n );\n}\n\nvec3 pos_point[10];\nvec3 colors[10];\nvoid drow_point()\n{\n pos_point[0] = vec3(-.5, -.5, .0);\n pos_point[1] = vec3(-.5 , .5, .0);\n pos_point[2] = vec3(.5 , -.5, .0);\n pos_point[3] = vec3(.5 , .5, .0);\n pos_point[4] = vec3(.5 , -.5, .5);\n pos_point[5] = vec3(.5 , .5, .5);\n pos_point[6] = vec3(-.5, -.5, .5);\n pos_point[7] = vec3(-.5 , .5, .5);\n pos_point[8] = vec3(-.5, -.5, .0);\n pos_point[9] = vec3(-.5 , .5, .0);\n \n colors[0] = vec3(1, 0, 0);\n colors[1] = vec3(1, 0, 0);\n colors[2] = vec3(0, 0, 1);\n colors[3] = vec3(0, 0, 1);\n colors[4] = vec3(1, 1, 1);\n colors[5] = vec3(1, 1, 1);\n colors[6] = vec3(0.2, 1, 0);\n colors[7] = vec3(0.2, 1, 0);\n colors[8] = vec3(0.5, 0, 0.5);\n colors[9] = vec3(0.5, 0, 0.5);\n}\n\nvoid main() {\n drow_point();\n int VD = int(vertexId);\n vec2 m = mouse;\n \n float ct = time *0.3;\n vec3 p = vec3(0 , m.y, -2.5);\n vec3 t = vec3(25.*cos(ct), 0., 25.*sin(ct));\n vec3 u = vec3(0, 1, 0);\n\n for( int i=0; i<10; i++)\n {\n if(VD == i)\n {\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= lookAt(p, t, u);\n gl_Position = m * vec4(pos_point[i], 1);\n gl_PointSize = 20.;\n v_color = vec4(colors[i], 1.0);\n }\n }\n\n\n}" + }, "screenshotURL": "data/images/images-wgaod2em2qmev5308-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nA8PWiYuAPACxMYNa/art.json b/art/nA8PWiYuAPACxMYNa/art.json index 0a427346..24618a63 100644 --- a/art/nA8PWiYuAPACxMYNa/art.json +++ b/art/nA8PWiYuAPACxMYNa/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\\n\\n\\n\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}\n\n\n" + }, "screenshotURL": "data/images/images-afq0ggpue985lpxbl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nAEy8qdNR79dxXtex/art.json b/art/nAEy8qdNR79dxXtex/art.json index b620bbea..90f877f6 100644 --- a/art/nAEy8qdNR79dxXtex/art.json +++ b/art/nAEy8qdNR79dxXtex/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "seoseulbin", "avatarUrl": "https://avatars.githubusercontent.com/seoseulbin?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.14901960784313725,0.12549019607843137,0.33725490196078434,1],\"shader\":\"// Seulbin Seo\\n// Exercise Audio Reactive Art\\n// CS250 Spring 2023\\n\\nvec3 hav2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.)\\n\\nvoid main ()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy)* 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(sv, su));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n\\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; // + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);\\n float val =mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\\n}\\n\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.14901960784313725, + 0.12549019607843137, + 0.33725490196078434, + 1 + ], + "shader": "// Seulbin Seo\n// Exercise Audio Reactive Art\n// CS250 Spring 2023\n\nvec3 hav2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.x * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.)\n\nvoid main ()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy)* 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(sv, su));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n\n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; // + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);\n float val =mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4 (hav2rgb(vec3(hue, sat, val)), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-1g9qblb0o9ewh1rwv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nBFQ8eYqePsxmzozA/art.json b/art/nBFQ8eYqePsxmzozA/art.json index 8f0c7dbc..49aaafab 100644 --- a/art/nBFQ8eYqePsxmzozA/art.json +++ b/art/nBFQ8eYqePsxmzozA/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n gl_PointSize = 10.0;\\n gl_Position = vec4(0.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n gl_PointSize = 10.0;\n gl_Position = vec4(0.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-2ky8oynlnr8hv1k4x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nBtQo8jPpr5y4bKyK/art.json b/art/nBtQo8jPpr5y4bKyK/art.json index 4c737d95..f5f04a86 100644 --- a/art/nBtQo8jPpr5y4bKyK/art.json +++ b/art/nBtQo8jPpr5y4bKyK/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\n//\\tClassic Perlin 3D Noise \\n//\\tby Stefan Gustavson\\n//\\nvec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\\n\\nfloat cnoise(vec3 P){\\n vec3 Pi0 = floor(P); // Integer part for indexing\\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\\n Pi0 = mod(Pi0, 289.0);\\n Pi1 = mod(Pi1, 289.0);\\n vec3 Pf0 = fract(P); // Fractional part for interpolation\\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\\n vec4 iz0 = Pi0.zzzz;\\n vec4 iz1 = Pi1.zzzz;\\n\\n vec4 ixy = permute(permute(ix) + iy);\\n vec4 ixy0 = permute(ixy + iz0);\\n vec4 ixy1 = permute(ixy + iz1);\\n\\n vec4 gx0 = ixy0 / 7.0;\\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\\n gx0 = fract(gx0);\\n vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\\n vec4 sz0 = step(gz0, vec4(0.0));\\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\\n\\n vec4 gx1 = ixy1 / 7.0;\\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\\n gx1 = fract(gx1);\\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\\n vec4 sz1 = step(gz1, vec4(0.0));\\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\\n\\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\\n\\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\\n g000 *= norm0.x;\\n g010 *= norm0.y;\\n g100 *= norm0.z;\\n g110 *= norm0.w;\\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\\n g001 *= norm1.x;\\n g011 *= norm1.y;\\n g101 *= norm1.z;\\n g111 *= norm1.w;\\n\\n float n000 = dot(g000, Pf0);\\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\\n float n111 = dot(g111, Pf1);\\n\\n vec3 fade_xyz = fade(Pf0);\\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \\n return 2.2 * n_xyz;\\n}\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angle) {\\nfloat Snd =texture2D(sound,vec2(0)).a;\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, Snd, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount));\\n \\tfloat cols = floor(vertexCount / rows);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\tfloat a = atan(x, y);\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\\n \\tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\\n \\tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\\n float Snd =texture2D(sound,vec2(0)).a;\\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n vec4 pos = vec4(ux, vy, 0, 1);\\n \\tvec3 n = vec3(cnoise(pos.xyz*.51));\\n \\t//pos.x += n.x*1.9762*sin(n.x+time);\\n \\t//pos.y += n.y*.62;\\n \\t//pos.z += n.z*.9762;\\n \\t//pos*=rotY(PI*time*.125);\\n \\t//pos*=rotX(PI*time*.0125);\\n\\tgl_Position = pos;\\n \\tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \\n \\n float S =texture2D(volume,vec2(0)).a;\\n// 72.0 /Snd+cols; \\n \\tgl_PointSize *= resolution.x / 222.-S; \\n float hue = s;\\n hue = smoothstep(x, y-S, xOff);\\n float sat = v * xOff;\\n float val = u;\\n \\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(-PI * soff);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n\\n v_color = finalColor;\\n }\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\n//\tClassic Perlin 3D Noise \n//\tby Stefan Gustavson\n//\nvec4 permute(vec4 x){return mod(((x*34.0)+1.0)*x, 289.0);}\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\n\nfloat cnoise(vec3 P){\n vec3 Pi0 = floor(P); // Integer part for indexing\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\n Pi0 = mod(Pi0, 289.0);\n Pi1 = mod(Pi1, 289.0);\n vec3 Pf0 = fract(P); // Fractional part for interpolation\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\n vec4 iz0 = Pi0.zzzz;\n vec4 iz1 = Pi1.zzzz;\n\n vec4 ixy = permute(permute(ix) + iy);\n vec4 ixy0 = permute(ixy + iz0);\n vec4 ixy1 = permute(ixy + iz1);\n\n vec4 gx0 = ixy0 / 7.0;\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\n gx0 = fract(gx0);\n vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\n vec4 sz0 = step(gz0, vec4(0.0));\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\n\n vec4 gx1 = ixy1 / 7.0;\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\n gx1 = fract(gx1);\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\n vec4 sz1 = step(gz1, vec4(0.0));\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\n\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\n\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\n g000 *= norm0.x;\n g010 *= norm0.y;\n g100 *= norm0.z;\n g110 *= norm0.w;\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\n g001 *= norm1.x;\n g011 *= norm1.y;\n g101 *= norm1.z;\n g111 *= norm1.w;\n\n float n000 = dot(g000, Pf0);\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\n float n111 = dot(g111, Pf1);\n\n vec3 fade_xyz = fade(Pf0);\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \n return 2.2 * n_xyz;\n}\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angle) {\nfloat Snd =texture2D(sound,vec2(0)).a;\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, Snd, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount));\n \tfloat cols = floor(vertexCount / rows);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\tfloat a = atan(x, y);\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\n \tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\n \tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\n float Snd =texture2D(sound,vec2(0)).a;\n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n vec4 pos = vec4(ux, vy, 0, 1);\n \tvec3 n = vec3(cnoise(pos.xyz*.51));\n \t//pos.x += n.x*1.9762*sin(n.x+time);\n \t//pos.y += n.y*.62;\n \t//pos.z += n.z*.9762;\n \t//pos*=rotY(PI*time*.125);\n \t//pos*=rotX(PI*time*.0125);\n\tgl_Position = pos;\n \tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \n \n float S =texture2D(volume,vec2(0)).a;\n// 72.0 /Snd+cols; \n \tgl_PointSize *= resolution.x / 222.-S; \n float hue = s;\n hue = smoothstep(x, y-S, xOff);\n float sat = v * xOff;\n float val = u;\n \n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(-PI * soff);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n\n v_color = finalColor;\n }" + }, "screenshotURL": "data/images/images-672pqtfjkume65ir7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nCfNyk6WPr6gn4kSB/art.json b/art/nCfNyk6WPr6gn4kSB/art.json index 392578c0..5b3ddf81 100644 --- a/art/nCfNyk6WPr6gn4kSB/art.json +++ b/art/nCfNyk6WPr6gn4kSB/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":84989,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\n//\\n// Move the mouse\\n//\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 10.0, 1.0));\\n vec4 K = vec4(1.0, 1.0 / 31.0* 3., 0.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.3, 0.6), c.y);\\n}\\n\\nvoid main() {\\n float tm = cos(time) *120.;\\n vec2 aspect = vec2(0.011, resolution.x / resolution.y);\\n float t = (vertexId* 0.9-mod(vertexId,2.0))*0.3;\\n float phase = -tm*mod(vertexId,2.0);\\n float a = 0.173;\\n float b = 0.3063489;\\n float x = a * exp(b+t*1.3)*cos(t+phase)*0.015;\\n float y = a * exp(-b*1.3)*sin(t*phase)*0.015;\\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.05));\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\\n\\n \\n float hue = (floor(vertexId * -.005) * 0.5 - time * 0.01);\\n float sat = 1.;\\n float val = 0.5+mod(vertexId,2.0)*3.8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 84989, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \n//\n// Move the mouse\n//\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 10.0, 1.0));\n vec4 K = vec4(1.0, 1.0 / 31.0* 3., 0.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.3, 0.6), c.y);\n}\n\nvoid main() {\n float tm = cos(time) *120.;\n vec2 aspect = vec2(0.011, resolution.x / resolution.y);\n float t = (vertexId* 0.9-mod(vertexId,2.0))*0.3;\n float phase = -tm*mod(vertexId,2.0);\n float a = 0.173;\n float b = 0.3063489;\n float x = a * exp(b+t*1.3)*cos(t+phase)*0.015;\n float y = a * exp(-b*1.3)*sin(t*phase)*0.015;\n vec4 m = texture2D(touch, vec2(0., vertexId * 0.05));\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * aspect + m.xy, 0, 1);\n\n \n float hue = (floor(vertexId * -.005) * 0.5 - time * 0.01);\n float sat = 1.;\n float val = 0.5+mod(vertexId,2.0)*3.8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-0y1vthbsd0sykza4b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nCs6tW5ZLeSx7QoHm/art.json b/art/nCs6tW5ZLeSx7QoHm/art.json index 440af9b2..7ecac390 100644 --- a/art/nCs6tW5ZLeSx7QoHm/art.json +++ b/art/nCs6tW5ZLeSx7QoHm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 90. )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 2.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 37.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 10.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.50;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 1.1);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 4.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 6.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 3.))));\\n \\n vCubeCol.xyz = vec3(0,0,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.9;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 1)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId*snd*222., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(10.), resolution.x / resolution.y, 0.0001, 110.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 1.9);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,2,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, .770),\\n snd -.5,0.9,1.-snd), color*snd, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/johnnormanmusic/john-norman-space-modulator-preview", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 90. )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 2.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 37.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 10.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.50;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 1.1);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 4.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 6.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 3.))));\n \n vCubeCol.xyz = vec3(0,0,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.9;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 1)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId*snd*222., fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(10.), resolution.x / resolution.y, 0.0001, 110.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 1.9);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,2,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, .770),\n snd -.5,0.9,1.-snd), color*snd, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-lgjohokupvnv60ml4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nDoX6LaHSyK8R6WTL/art.json b/art/nDoX6LaHSyK8R6WTL/art.json index fcbfd139..283e86c1 100644 --- a/art/nDoX6LaHSyK8R6WTL/art.json +++ b/art/nDoX6LaHSyK8R6WTL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n //float t = float(vertexId) / float(vertexCount);\\n \\n //vec3 xyz = vec3(cos(t), sin(t), 1.0);\\n \\n //gl_Position = vec4(xyz * 50.0, 1.0);\\n //v_color = min(vec4(2.),vec4(xyz.x,xyz.y,2,1))/max(0.,(-xyz.z*5.+5.));\\n float phi = vertexId / vertexCount * 3.14159265*2.0;\\n \\n float x = cos(phi);\\n float y = sin(phi);\\n float z = 0.0;\\n \\n float theta = 5.0 * sin(sign(y)*cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\\n \\n //x *= cos(theta);\\n y *= cos(theta);\\n z = sin(theta);\\n \\n vec4 pos = vec4(x, y, z, 1.0);\\n \\n \\n vec3 eye = vec3(sin(time), 0, cos(time));\\n vec3 right = vec3(-eye.z, 0, eye.x);\\n vec3 look = -eye;\\n /*\\nm[0]=right.x\\nm[1]=right.y\\nm[2]=right.z\\n\\nm[4]=up.x\\nm[5]=up.y\\nm[6]=up.z\\n\\nm[8]=look.x\\nm[9]=look.y\\nm[10]=look.z\\n*/\\n \\n mat4 L = mat4(vec4(right, 0), vec4(0, 1, 0, 0), vec4(look, 0), vec4(0, 0, 0, 1));\\n \\n gl_Position = (L * pos) * vec4(0.5, 0.5, 0.5, 1);\\n v_color = vec4(sin(theta) *0.5 + 0.5,\\n cos(phi) *0.5 + 0.5,\\n sin(time) * 0.5 + 0.5,\\n 1.0);\\n}\"}", + "settings": { + "num": 1024, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n //float t = float(vertexId) / float(vertexCount);\n \n //vec3 xyz = vec3(cos(t), sin(t), 1.0);\n \n //gl_Position = vec4(xyz * 50.0, 1.0);\n //v_color = min(vec4(2.),vec4(xyz.x,xyz.y,2,1))/max(0.,(-xyz.z*5.+5.));\n float phi = vertexId / vertexCount * 3.14159265*2.0;\n \n float x = cos(phi);\n float y = sin(phi);\n float z = 0.0;\n \n float theta = 5.0 * sin(sign(y)*cos(phi)*3.1415192) * sin(time);//(x+time * 0.3) * 3.141592*2.0;\n \n //x *= cos(theta);\n y *= cos(theta);\n z = sin(theta);\n \n vec4 pos = vec4(x, y, z, 1.0);\n \n \n vec3 eye = vec3(sin(time), 0, cos(time));\n vec3 right = vec3(-eye.z, 0, eye.x);\n vec3 look = -eye;\n /*\nm[0]=right.x\nm[1]=right.y\nm[2]=right.z\n\nm[4]=up.x\nm[5]=up.y\nm[6]=up.z\n\nm[8]=look.x\nm[9]=look.y\nm[10]=look.z\n*/\n \n mat4 L = mat4(vec4(right, 0), vec4(0, 1, 0, 0), vec4(look, 0), vec4(0, 0, 0, 1));\n \n gl_Position = (L * pos) * vec4(0.5, 0.5, 0.5, 1);\n v_color = vec4(sin(theta) *0.5 + 0.5,\n cos(phi) *0.5 + 0.5,\n sin(time) * 0.5 + 0.5,\n 1.0);\n}" + }, "screenshotURL": "data/images/images-ek203ioir9x6t1slq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nE9ZSZiLSQQpqKTjE/art.json b/art/nE9ZSZiLSQQpqKTjE/art.json index 9bcf671d..1548bdf6 100644 --- a/art/nE9ZSZiLSQQpqKTjE/art.json +++ b/art/nE9ZSZiLSQQpqKTjE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":15328,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>5.\\n#define KP3 0.000//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>2.0\\n#define KP5 4000.0//KParameter5 30.000>>100000.0\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 15328, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>5.\n#define KP3 0.000//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>2.0\n#define KP5 4000.0//KParameter5 30.000>>100000.0\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-tfebtw7l8zebc1dyw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nERwc23zjdTrQfzjD/art.json b/art/nERwc23zjdTrQfzjD/art.json index 7e445193..b19dedd2 100644 --- a/art/nERwc23zjdTrQfzjD/art.json +++ b/art/nERwc23zjdTrQfzjD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "rubinhuang9239", "avatarUrl": "https://avatars.githubusercontent.com/Rubinhuang9239?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.11372549019607843,0.07450980392156863,0.26666666666666666,1],\"shader\":\"void main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor (vertexCount/down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x/ (across - 1.0);\\n \\tfloat v = y/ (across - 1.0);\\n \\n float ux = u*2.0-1.0;\\n float vy = v*2.0-1.0;\\n\\n \\tgl_Position = vec4( ux + cos(sin(ux + time)) * 0.1, vy + cos(sin(vy + time))*0.1, 0.0, 1.0); \\n\\t\\n \\tgl_PointSize = 16.0 + sin(time)*12.0;\\n \\tgl_PointSize *= 20.0/across;\\t\\n \\tgl_PointSize *= resolution.x/600.0;\\t\\n \\n \\tv_color = vec4(ux + cos(sin(ux + time)), vy + cos(sin(vy + time)), 0.75,1.0);\\n\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.11372549019607843, + 0.07450980392156863, + 0.26666666666666666, + 1 + ], + "shader": "void main() {\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor (vertexCount/down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x/ (across - 1.0);\n \tfloat v = y/ (across - 1.0);\n \n float ux = u*2.0-1.0;\n float vy = v*2.0-1.0;\n\n \tgl_Position = vec4( ux + cos(sin(ux + time)) * 0.1, vy + cos(sin(vy + time))*0.1, 0.0, 1.0); \n\t\n \tgl_PointSize = 16.0 + sin(time)*12.0;\n \tgl_PointSize *= 20.0/across;\t\n \tgl_PointSize *= resolution.x/600.0;\t\n \n \tv_color = vec4(ux + cos(sin(ux + time)), vy + cos(sin(vy + time)), 0.75,1.0);\n\n}\n" + }, "screenshotURL": "data/images/images-j0d408nqn07t977bk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nEpiQXnFSAvRvgwTY/art.json b/art/nEpiQXnFSAvRvgwTY/art.json index 4e0ddfda..ceb5cb71 100644 --- a/art/nEpiQXnFSAvRvgwTY/art.json +++ b/art/nEpiQXnFSAvRvgwTY/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Hexagon Tile Strings by Justin Shrake (https://twitter.com/j2rgb)\\n// CC BY-NC 4.0 https://creativecommons.org/licenses/by-nc/4.0/\\n\\n// Submission for https://twitter.com/sableRaph #WCCChallenge\\n// Topic: non-rectangular tiles\\n// https://www.twitch.tv/sableraph\\n\\n\\n#ifndef TAU\\n#define TAU 6.28318530718\\n#endif\\n#ifndef PI\\n#define PI 3.14159265359\\n#endif\\n\\n\\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\\n// Licensed under CC BY-SA 3.0\\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\\nvec2 parametric_ngon(float n, float theta) {\\n theta = mod(TAU * theta, TAU);\\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\\n float x = r * cos(theta);\\n float y = r * sin(theta);\\n return vec2(x, y);\\n}\\n\\nvec4 grid2(float id, float w, float h) {\\n float ux = w == 1.0 ? 0.0 : mod(id, w);\\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\\n return vec4(x, y, ux, uy);\\n}\\n\\nmat2 rot2(float t) {\\n float ct = cos(t);\\n float st = sin(t);\\n return mat2(ct, -st, st, ct);\\n}\\n\\n\\nvoid main() {\\n // Loop timings\\n float loop_len = 4.0;\\n float time_off = 0.0;\\n float loop_pct = mod(time + time_off, loop_len) / (loop_len - 1.0);\\n // The size of the hexagon tile grid\\n float gridw = 20.;\\n float gridh = 20.;\\n // The number of particles per hexagon\\n float particles_per_tile = 250.0;\\n // The particle index\\n float i = vertexId;\\n // The particle perctange\\n float pct = i / (vertexCount - 1.0);\\n\\n // The hexagon index\\n float tile_i = floor(i / particles_per_tile);\\n // The total number of hexagons\\n float tile_count = gridw * gridh;\\n\\n // The particle index wrt the hexagon\\n float tile_pi = mod(i, particles_per_tile);\\n // The particle percentage wrt the hexagon\\n float tile_ppct = tile_pi / particles_per_tile;\\n\\n \\n float row = floor(tile_i/gridw);\\n float col = mod(tile_i, gridw);\\n float eo = mod(row, 2.0);\\n \\n float ar = resolution.y < resolution.x ? resolution.x/resolution.y : resolution.y/resolution.x;\\n\\n\\n // Hexagon tile size\\n float size = 1.0/(gridw - 1.0);\\n // padding between hexagons, 1.0 for no padding\\n float padding = 1.2;\\n // hexagon math courtesy of https://www.redblobgames.com/grids/hexagons/\\n vec2 grid_scale = padding*vec2(1.0*sqrt(3.0)*size, 1.5*ar*size);\\n vec2 tile_scale = vec2(size, size*ar);\\n // The center of the hexagon\\n vec2 tile_center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\\n\\n // Calculate the position of each particle in the tile\\n float ngon = 6.0;\\n float swirl = 0.5;\\n // The animation interpolates a point in the hexagon to another point in the hexagon\\n vec2 tile_a = parametric_ngon(ngon, tile_ppct);\\n vec2 tile_b = parametric_ngon(ngon, tile_ppct + swirl);\\n // Animation delay outwards w/ some magic numbers for taste\\n float anim_delay = mix(0.0, 0.6, length(tile_center + 0.0001)/(0.93*sqrt(2.0))) + mix(0.0, 0.2, tile_ppct);\\n float anim_len = 0.2;\\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\\n vec2 tile = mix(tile_a, tile_b, m);\\n tile = rot2(0.25*TAU)*tile;\\n tile *= tile_scale;\\n tile.x += 1.0 * eo * tile_scale.x;\\n tile.y += 1.0*size;\\n \\n // Outputs\\n gl_Position.xy = tile_center + tile;\\n gl_Position.zw = vec2(0.0, 1.0);\\n gl_PointSize = 3.0;\\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Hexagon Tile Strings by Justin Shrake (https://twitter.com/j2rgb)\n// CC BY-NC 4.0 https://creativecommons.org/licenses/by-nc/4.0/\n\n// Submission for https://twitter.com/sableRaph #WCCChallenge\n// Topic: non-rectangular tiles\n// https://www.twitch.tv/sableraph\n\n\n#ifndef TAU\n#define TAU 6.28318530718\n#endif\n#ifndef PI\n#define PI 3.14159265359\n#endif\n\n\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\n// Licensed under CC BY-SA 3.0\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\nvec2 parametric_ngon(float n, float theta) {\n theta = mod(TAU * theta, TAU);\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\n float x = r * cos(theta);\n float y = r * sin(theta);\n return vec2(x, y);\n}\n\nvec4 grid2(float id, float w, float h) {\n float ux = w == 1.0 ? 0.0 : mod(id, w);\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\n return vec4(x, y, ux, uy);\n}\n\nmat2 rot2(float t) {\n float ct = cos(t);\n float st = sin(t);\n return mat2(ct, -st, st, ct);\n}\n\n\nvoid main() {\n // Loop timings\n float loop_len = 4.0;\n float time_off = 0.0;\n float loop_pct = mod(time + time_off, loop_len) / (loop_len - 1.0);\n // The size of the hexagon tile grid\n float gridw = 20.;\n float gridh = 20.;\n // The number of particles per hexagon\n float particles_per_tile = 250.0;\n // The particle index\n float i = vertexId;\n // The particle perctange\n float pct = i / (vertexCount - 1.0);\n\n // The hexagon index\n float tile_i = floor(i / particles_per_tile);\n // The total number of hexagons\n float tile_count = gridw * gridh;\n\n // The particle index wrt the hexagon\n float tile_pi = mod(i, particles_per_tile);\n // The particle percentage wrt the hexagon\n float tile_ppct = tile_pi / particles_per_tile;\n\n \n float row = floor(tile_i/gridw);\n float col = mod(tile_i, gridw);\n float eo = mod(row, 2.0);\n \n float ar = resolution.y < resolution.x ? resolution.x/resolution.y : resolution.y/resolution.x;\n\n\n // Hexagon tile size\n float size = 1.0/(gridw - 1.0);\n // padding between hexagons, 1.0 for no padding\n float padding = 1.2;\n // hexagon math courtesy of https://www.redblobgames.com/grids/hexagons/\n vec2 grid_scale = padding*vec2(1.0*sqrt(3.0)*size, 1.5*ar*size);\n vec2 tile_scale = vec2(size, size*ar);\n // The center of the hexagon\n vec2 tile_center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\n\n // Calculate the position of each particle in the tile\n float ngon = 6.0;\n float swirl = 0.5;\n // The animation interpolates a point in the hexagon to another point in the hexagon\n vec2 tile_a = parametric_ngon(ngon, tile_ppct);\n vec2 tile_b = parametric_ngon(ngon, tile_ppct + swirl);\n // Animation delay outwards w/ some magic numbers for taste\n float anim_delay = mix(0.0, 0.6, length(tile_center + 0.0001)/(0.93*sqrt(2.0))) + mix(0.0, 0.2, tile_ppct);\n float anim_len = 0.2;\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\n vec2 tile = mix(tile_a, tile_b, m);\n tile = rot2(0.25*TAU)*tile;\n tile *= tile_scale;\n tile.x += 1.0 * eo * tile_scale.x;\n tile.y += 1.0*size;\n \n // Outputs\n gl_Position.xy = tile_center + tile;\n gl_Position.zw = vec2(0.0, 1.0);\n gl_PointSize = 3.0;\n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-zbuhh9hpbmomg0wok-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nFBJtXmmBdabjqLW9/art.json b/art/nFBJtXmmBdabjqLW9/art.json index 0b7903de..e478f926 100644 --- a/art/nFBJtXmmBdabjqLW9/art.json +++ b/art/nFBJtXmmBdabjqLW9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "yejin-shin", "avatarUrl": "https://avatars.githubusercontent.com/yejin-shin?s=200", - "settings": "{\"num\":5000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/tommisch/disco-yes-feat-poppy-ajudha-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Yejin Shin\\n//Assignment : Circles from Triangles\\n//Course : CS250\\n//Spring, 2023\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotz(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n\\n return mat4(\\n c, -s, 0, 0,\\n s, c, 0, 0, \\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident()\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0, \\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0, \\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n\\n float radius = vy + 1.;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n return vec2(x, y);\\n}\\n\\nvoid main() \\n{\\n float numCircleSegments = 25.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n\\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleID = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n\\n float sliceId = floor(vertexId / 5.0);\\n float oddSlice = mod(sliceId, 4.);\\n\\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n float x = mod(circleID, across);\\n float y = floor(circleID / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .08, av * .23)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotz(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotz(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc); \\n \\n gl_Position = mat * pos;\\n\\n float soff = 0.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd + 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = mix(.2, pow(snd + 0.5, 2.0), pump);\\n\\n hue = hue + pump * oddSlice * 0.5 + pump * 0.22;\\n val += oddSlice * pump;\\n\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/tommisch/disco-yes-feat-poppy-ajudha-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Yejin Shin\n//Assignment : Circles from Triangles\n//Course : CS250\n//Spring, 2023\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotz(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n\n return mat4(\n c, -s, 0, 0,\n s, c, 0, 0, \n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident()\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s)\n{\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0, \n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0, \n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n\n float radius = vy + 1.;\n\n float x = c * radius;\n float y = s * radius;\n\n return vec2(x, y);\n}\n\nvoid main() \n{\n float numCircleSegments = 25.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n\n float numPointsPerCircle = numCircleSegments * 6.;\n float circleID = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n\n float sliceId = floor(vertexId / 5.0);\n float oddSlice = mod(sliceId, 4.);\n\n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n float x = mod(circleID, across);\n float y = floor(circleID / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .08, av * .23)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotz(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotz(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc); \n \n gl_Position = mat * pos;\n\n float soff = 0.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd + 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = mix(.2, pow(snd + 0.5, 2.0), pump);\n\n hue = hue + pump * oddSlice * 0.5 + pump * 0.22;\n val += oddSlice * pump;\n\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-aknajyq6v93abs4o5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nJ6nKdcJq6zW3SoZs/art.json b/art/nJ6nKdcJq6zW3SoZs/art.json index cd6d860e..679c83db 100644 --- a/art/nJ6nKdcJq6zW3SoZs/art.json +++ b/art/nJ6nKdcJq6zW3SoZs/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "austinbhale", "avatarUrl": "https://avatars.githubusercontent.com/austinbhale?s=200", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/tonycuozzo/space-song-beach-house-slowed\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time * 1.2 + y * 0.1) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.2) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.2; // stretches grid past 1.\\n \\n float sv = abs(v - 0.5) * 2.;\\n float su = abs(u - 0.5) * 2.;\\n float sound = texture2D(sound, vec2(su * .05, sv + .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(sound + 0.2, 5.) * 7. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time + v * 10.) * 0.15;\\n float sat = 1.;\\n float val = sound * sin(time + v * u * 20.0) * .6 + .8;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/tonycuozzo/space-song-beach-house-slowed", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time * 1.2 + y * 0.1) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.2) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.2; // stretches grid past 1.\n \n float sv = abs(v - 0.5) * 2.;\n float su = abs(u - 0.5) * 2.;\n float sound = texture2D(sound, vec2(su * .05, sv + .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(sound + 0.2, 5.) * 7. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time + v * 10.) * 0.15;\n float sat = 1.;\n float val = sound * sin(time + v * u * 20.0) * .6 + .8;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-r77wwl05rzofrehvx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nK3MebRPLrLMMTFab/art.json b/art/nK3MebRPLrLMMTFab/art.json index 40c5b2d3..89ac5367 100644 --- a/art/nK3MebRPLrLMMTFab/art.json +++ b/art/nK3MebRPLrLMMTFab/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid main() {\\n vec2 grid = floor((resolution + 511.0) / 512.0) + 2.;\\n float units = grid.x * grid.y;\\n \\n float vId = floor(vertexId / units);\\n float unitId = mod(vertexId, units);\\n float unitX = mod(unitId, grid.x);\\n float unitY = floor(unitId / grid.x);\\n \\n float s = 1.0;\\n float c = hash(vId * 0.929);\\n float sp = mix(0.05, 0.1, s);\\n float x = t2m1(fract(-time * sp + hash(vId * 0.373)));\\n float y = t2m1(hash(vId * 0.641));\\n \\n vec2 p = vec2(x, y) / (resolution / 256.0);\\n \\n float f = hash(vertexId * 0.721) * PI * 2. + time * PI * 4. / 10.;\\n \\n vec2 gp = (vec2(unitX, unitY) - grid / 2. + 1.) / (resolution / 512.0);\\n \\n gl_Position = vec4(p + gp, 0, 1);\\n gl_PointSize = c * 2. * sin(f);\\n \\n \\n v_color = vec4(hsv2rgb(vec3(c, 0.2, c)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid main() {\n vec2 grid = floor((resolution + 511.0) / 512.0) + 2.;\n float units = grid.x * grid.y;\n \n float vId = floor(vertexId / units);\n float unitId = mod(vertexId, units);\n float unitX = mod(unitId, grid.x);\n float unitY = floor(unitId / grid.x);\n \n float s = 1.0;\n float c = hash(vId * 0.929);\n float sp = mix(0.05, 0.1, s);\n float x = t2m1(fract(-time * sp + hash(vId * 0.373)));\n float y = t2m1(hash(vId * 0.641));\n \n vec2 p = vec2(x, y) / (resolution / 256.0);\n \n float f = hash(vertexId * 0.721) * PI * 2. + time * PI * 4. / 10.;\n \n vec2 gp = (vec2(unitX, unitY) - grid / 2. + 1.) / (resolution / 512.0);\n \n gl_Position = vec4(p + gp, 0, 1);\n gl_PointSize = c * 2. * sin(f);\n \n \n v_color = vec4(hsv2rgb(vec3(c, 0.2, c)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-jin9fwagzh1ogaai6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nKFqYp9wtAJ4hM3mF/art.json b/art/nKFqYp9wtAJ4hM3mF/art.json index 55e26e7c..21d432b1 100644 --- a/art/nKFqYp9wtAJ4hM3mF/art.json +++ b/art/nKFqYp9wtAJ4hM3mF/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mipmap", "avatarUrl": "https://secure.gravatar.com/avatar/2840df8e29cba840a5b7f90f66bc66cd?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b07 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) ;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y)) * 6.;\\n float down = floor(vertexCount / across) * 6.;\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 1. + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 8;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.8 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(p.z, 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b07 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) ;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y)) * 6.;\n float down = floor(vertexCount / across) * 6.;\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 1. + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 8;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.8 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(p.z, 1.4);\n}\n" + }, "screenshotURL": "data/images/images-mrb098ekplpzf5vmi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nKrw8457n4cFANsJu/art.json b/art/nKrw8457n4cFANsJu/art.json index eda206e8..17d2019e 100644 --- a/art/nKrw8457n4cFANsJu/art.json +++ b/art/nKrw8457n4cFANsJu/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":99999,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 7.0\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.1492;\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5;\\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.0;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 99999, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 7.0\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.1492;\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*.3,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5;\n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.0;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-zz43o9nv5pd05xrqy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nKzNvfJNE5DnDYssR/art.json b/art/nKzNvfJNE5DnDYssR/art.json index 18dd77b6..c1bfe906 100644 --- a/art/nKzNvfJNE5DnDYssR/art.json +++ b/art/nKzNvfJNE5DnDYssR/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":18432,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/geotheorymusic/work-it-girl\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9921568627450981,0.984313725490196,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 1,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = mix(inner, 1., level);\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.5;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += 10.;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n mat *= scale(vec3(0.25, 0.25, -20.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(.65, 1., step(0.75, snd));\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n v_color.a = 1.0 - uvf.y;\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 18432, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/geotheorymusic/work-it-girl", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9921568627450981, + 0.984313725490196, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 1,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 64.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = mix(inner, 1., level);\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.5;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += 10.;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n mat *= scale(vec3(0.25, 0.25, -20.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = mix(.65, 1., step(0.75, snd));\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\n v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n v_color.a = 1.0 - uvf.y;\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-j5a4mvmwzo535a9ud-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nL6YpkW8YvGKNEKtj/art.json b/art/nL6YpkW8YvGKNEKtj/art.json index 9e416f17..2c55eccf 100644 --- a/art/nL6YpkW8YvGKNEKtj/art.json +++ b/art/nL6YpkW8YvGKNEKtj/art.json @@ -20,7 +20,19 @@ "origId": null, "name": "point cloud vs spheres", "username": "kabuto", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotDataId": "x3JPBAA3a52pgi2jH", "views": { "$numberInt": "27220" diff --git a/art/nMNG7eAXWv6j4E7cX/art.json b/art/nMNG7eAXWv6j4E7cX/art.json index 59a0f098..46da84ce 100644 --- a/art/nMNG7eAXWv6j4E7cX/art.json +++ b/art/nMNG7eAXWv6j4E7cX/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/diskore/m4r\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.10980392156862745,0.11764705882352941,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 2.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle/parameter7 );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 1.-parameter0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 65.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v / 21. - v;}\\n\\nfloat p1m1(float v) {\\n return v * mod(0.1 *time, 6.0*parameter2) ;\\n}\\n\\nfloat inv(float v) {\\n return 1. + v + 2.;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) * PI - 21.16 / PI * 5.0* parameter3;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = 1.0;\\n pos = vec3(x, y+1., -5.* parameter4); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t - 1.7) + tan((t *= 1.13) - mouse.y -t) + sin(t - 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles+ 2.;\\n vec3 pos;\\n float inner = mix(0.03, 11.1-parameter4, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 21.033) - sin(time * 1.083 + circleId) *0.1/ parameter4);\\n float end = start + 3.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/.8 - 0.3)*7.)* 0.05, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId -1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time + 0.103) - 1.4;\\n offset.y += goop(circleId + time - 0.13) * 1.31 *parameter4;\\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset- parameter1);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId- 11.)));\\n gl_Position = vec4((mat * vec4(pos,.5)).xyz, 11.3 +parameter4 -(circleId + mouse.x));\\n gl_PointSize = 2. -parameter3;\\n\\n float hue = mix(0.01 *snd , 1.9 *parameter3/ circleId/snd , fract(circleId * 12.79 /snd));\\n float sat = 1. / snd;\\n float val = 0.9- snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. -parameter2 - uv.y) * pow(snd * 2.51, snd-3. /parameter6));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/diskore/m4r", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.10980392156862745, + 0.11764705882352941, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 2.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle/parameter7 );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 1.-parameter0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 65.4337);\n}\n\nfloat m1p1(float v) {\n return v / 21. - v;}\n\nfloat p1m1(float v) {\n return v * mod(0.1 *time, 6.0*parameter2) ;\n}\n\nfloat inv(float v) {\n return 1. + v + 2.;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) * PI - 21.16 / PI * 5.0* parameter3;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = 1.0;\n pos = vec3(x, y+1., -5.* parameter4); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t - 1.7) + tan((t *= 1.13) - mouse.y -t) + sin(t - 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles+ 2.;\n vec3 pos;\n float inner = mix(0.03, 11.1-parameter4, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 21.033) - sin(time * 1.083 + circleId) *0.1/ parameter4);\n float end = start + 3.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/.8 - 0.3)*7.)* 0.05, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId -1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time + 0.103) - 1.4;\n offset.y += goop(circleId + time - 0.13) * 1.31 *parameter4;\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset- parameter1);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId- 11.)));\n gl_Position = vec4((mat * vec4(pos,.5)).xyz, 11.3 +parameter4 -(circleId + mouse.x));\n gl_PointSize = 2. -parameter3;\n\n float hue = mix(0.01 *snd , 1.9 *parameter3/ circleId/snd , fract(circleId * 12.79 /snd));\n float sat = 1. / snd;\n float val = 0.9- snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. -parameter2 - uv.y) * pow(snd * 2.51, snd-3. /parameter6));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\n}" + }, "screenshotURL": "data/images/images-y8fmawuzblekeut6a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nNYZMHxiLMR2xAncW/art.json b/art/nNYZMHxiLMR2xAncW/art.json index 649564a7..9a4893e1 100644 --- a/art/nNYZMHxiLMR2xAncW/art.json +++ b/art/nNYZMHxiLMR2xAncW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/doornrecords/david-tort-our-love\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️ */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float maxPoints = vertexCount;\\n float numPoints = mix(2000., maxPoints, sin(time * .1) * .5 + .5);\\n float pointId = vertexId; \\n float mv = numPoints / maxPoints;\\n \\n if (pointId > numPoints) {\\n gl_Position = vec4(0, 0, 100, 1);\\n return;\\n }\\n\\n vec3 loc = fibonacciSphere(numPoints, pointId);\\n\\n float cv = pointId / numPoints;\\n float su = fract(cv + -time);\\n //su = hash(cubeId / maxCubes);\\n \\n float tm = time * .0;\\n float r = 30.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - cv, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(time * 0.37);\\n mat *= rotY(time * 0.21);\\n \\n float s2 = texture2D(sound, vec2(0.5, 0.)).a * 2.;\\n \\n float s = texture2D(sound, vec2(fract(cv * mix(3., 20., fract(s2))),0)).a;\\n \\n \\n gl_Position = mat * vec4(loc * mix(25., 35., pow(s, 5.)), 1);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float pm = step(.5, s);\\n\\n float hue = 1.;//.4 + floor(pow(s, 5.) * 20.) * .33 + time * 0.1;\\n float sat = 1.;// + pow(s + .5, 5.);\\n float val = pm;\\n v_color.rgb = hsv2rgb(vec3(hue, sat, val));\\n v_color.a = 1.;\\n v_color.rgb *= v_color.a; \\n \\n gl_PointSize = mix(6., 0.1, 1. - pow(1. - mv, 1.5));\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/doornrecords/david-tort-our-love", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️ */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float maxPoints = vertexCount;\n float numPoints = mix(2000., maxPoints, sin(time * .1) * .5 + .5);\n float pointId = vertexId; \n float mv = numPoints / maxPoints;\n \n if (pointId > numPoints) {\n gl_Position = vec4(0, 0, 100, 1);\n return;\n }\n\n vec3 loc = fibonacciSphere(numPoints, pointId);\n\n float cv = pointId / numPoints;\n float su = fract(cv + -time);\n //su = hash(cubeId / maxCubes);\n \n float tm = time * .0;\n float r = 30.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - cv, 10.));\n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(time * 0.37);\n mat *= rotY(time * 0.21);\n \n float s2 = texture2D(sound, vec2(0.5, 0.)).a * 2.;\n \n float s = texture2D(sound, vec2(fract(cv * mix(3., 20., fract(s2))),0)).a;\n \n \n gl_Position = mat * vec4(loc * mix(25., 35., pow(s, 5.)), 1);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float pm = step(.5, s);\n\n float hue = 1.;//.4 + floor(pow(s, 5.) * 20.) * .33 + time * 0.1;\n float sat = 1.;// + pow(s + .5, 5.);\n float val = pm;\n v_color.rgb = hsv2rgb(vec3(hue, sat, val));\n v_color.a = 1.;\n v_color.rgb *= v_color.a; \n \n gl_PointSize = mix(6., 0.1, 1. - pow(1. - mv, 1.5));\n}\n\n" + }, "screenshotURL": "data/images/images-41ojtzexku9lwfeco-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nNmmtcBPupGfffRQy/art.json b/art/nNmmtcBPupGfffRQy/art.json index 5bfbe383..eb4296cb 100644 --- a/art/nNmmtcBPupGfffRQy/art.json +++ b/art/nNmmtcBPupGfffRQy/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.13725490196078433,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0/3.0, 1.0/3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\\n vertexId;\\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\\n float x = mod(vertexId, across);\\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n gl_Position = vec4(xy, 0., 1.);\\n \\n float szoff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n\\n gl_PointSize = 15.0 + szoff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u*.1 + sin(time * 1.3 + v * 20.) * 0.10;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.) * 0.5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.13725490196078433, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0/3.0, 1.0/3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // 0 1 2 3 4 5 ... 10 11 12 13 ... 80 81 82 83 ...\n vertexId;\n // 0 1 2 3 4 5 ... 0 1 2 3 ... 0 1 2 3 ...\n float x = mod(vertexId, across);\n // 0 0 0 0 0 0 ... 1 1 1 1 ... 8 8 8 8 ...\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n gl_Position = vec4(xy, 0., 1.);\n \n float szoff = sin(time * 1.2 + x * y * 0.02) * 5.;\n\n gl_PointSize = 15.0 + szoff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u*.1 + sin(time * 1.3 + v * 20.) * 0.10;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.) * 0.5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-5uqvtuprxymojmlea-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nNzkBw7xZnKhutAAz/art.json b/art/nNzkBw7xZnKhutAAz/art.json index 2e1d306f..61f896af 100644 --- a/art/nNzkBw7xZnKhutAAz/art.json +++ b/art/nNzkBw7xZnKhutAAz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1389,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 3.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 10.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .5));\\n gl_PointSize =pow(sz, s) * resolution.y / 476. * s* 130.;\\n \\n \\n\\n float hue = sz * 2. + s * 0.953;\\n float sat = 1.;\\n float val = s*2.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 1389, + "mode": "POINTS", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 3.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 10.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .9+ .5));\n gl_PointSize =pow(sz, s) * resolution.y / 476. * s* 130.;\n \n \n\n float hue = sz * 2. + s * 0.953;\n float sat = 1.;\n float val = s*2.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-ogjtu8n5tqt976e3m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nPZN7YmgWJCMBFrNd/art.json b/art/nPZN7YmgWJCMBFrNd/art.json index 90f1d1f1..8b8adb3d 100644 --- a/art/nPZN7YmgWJCMBFrNd/art.json +++ b/art/nPZN7YmgWJCMBFrNd/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-5-greyze-dubday-nyc\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"/*\\n\\n-=O=-\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1.-c, 0,\\n 0, 0, 0, (1.*s)); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n s-c,c-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, (1.*s)); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 1.-sin(time), 1.5, 0,\\n trans, (1.));\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0.5, 0,\\n 0, 0, 1, 0,\\n 0, 0, -1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n// mat *= trans(cpos);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-5-greyze-dubday-nyc", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n-=O=-\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, 1.-c, 0,\n 0, 0, 0, (1.*s)); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n s-c,c-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, (1.*s)); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 1.-sin(time), 1.5, 0,\n trans, (1.));\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0.5, 0,\n 0, 0, 1, 0,\n 0, 0, -1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n// mat *= trans(cpos);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-0f6rpxyljhcpn4z14-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nQQ7HMj7XNCMLMMRp/art.json b/art/nQQ7HMj7XNCMLMMRp/art.json index 7de529cb..f7650d00 100644 --- a/art/nQQ7HMj7XNCMLMMRp/art.json +++ b/art/nQQ7HMj7XNCMLMMRp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6561,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/wavecraftcollective/wav-craft-vol-5-greyze-dubday-nyc\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, (1.-c), 0,\\n 0, 0, 0, (1.*s)); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n s-c,c-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, (1.*s)); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 1.-sin(time), 1.5, 0,\\n trans, (1.));\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0.5, 0,\\n 0, 0, 1, 0,\\n 0, 0, -1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n// mat *= trans(cpos);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 6561, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/wavecraftcollective/wav-craft-vol-5-greyze-dubday-nyc", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, (1.-c), 0,\n 0, 0, 0, (1.*s)); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n s-c,c-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, (1.*s)); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 1.-sin(time), 1.5, 0,\n trans, (1.));\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0.5, 0,\n 0, 0, 1, 0,\n 0, 0, -1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n// mat *= trans(cpos);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-qxi8eogzmfsn6ilzj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nQhGyYPDnC9Sj6iak/art.json b/art/nQhGyYPDnC9Sj6iak/art.json index a4882284..349b896e 100644 --- a/art/nQhGyYPDnC9Sj6iak/art.json +++ b/art/nQhGyYPDnC9Sj6iak/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "rus-abd", "avatarUrl": "https://avatars.githubusercontent.com/Rus-Abd?s=200", - "settings": "{\"num\":226,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-610439645/timur-mutsuraev-den-pobedy?in_system_playlist=your-moods%3A%3A266771761%3A0\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\nvec2 getPosition(){\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount/down);\\n \\n \\tfloat x = mod(vertexId,across);\\n \\tfloat y = floor(vertexId/across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n \\tvec2 res = (vec2(u,v) - .5) *2.;\\n\\treturn vec2(res);\\n}\\n\\nvoid main() {\\n \\n vec3 position = vec3(getPosition(),.1);\\n\\n \\n gl_PointSize = 2. * (1./position.z);\\n \\n \\n \\n \\n gl_Position = vec4(position,1.);\\n v_color = vec4(1.,1.,1.,1.);\\n}\"}", + "settings": { + "num": 226, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-610439645/timur-mutsuraev-den-pobedy?in_system_playlist=your-moods%3A%3A266771761%3A0", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\nvec2 getPosition(){\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount/down);\n \n \tfloat x = mod(vertexId,across);\n \tfloat y = floor(vertexId/across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n \tvec2 res = (vec2(u,v) - .5) *2.;\n\treturn vec2(res);\n}\n\nvoid main() {\n \n vec3 position = vec3(getPosition(),.1);\n\n \n gl_PointSize = 2. * (1./position.z);\n \n \n \n \n gl_Position = vec4(position,1.);\n v_color = vec4(1.,1.,1.,1.);\n}" + }, "screenshotURL": "data/images/images-wxo5k4qgmxm5z95nv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nQhMRh5xxazydRqaC/art.json b/art/nQhMRh5xxazydRqaC/art.json index 87c91091..5336a3ad 100644 --- a/art/nQhMRh5xxazydRqaC/art.json +++ b/art/nQhMRh5xxazydRqaC/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":47881,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#40190.0\\n//Another experiment of 'vertexification' of a fragment shader \\n\\n#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\tif(v>0.5)\\n v = 1.- v;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u*cos(time),v-1.4);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = normalize(vec2(u,v));//\\n \\t\\n float s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*.1 - floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 1.3;\\n float tm = .5 *time;\\n float tm2 = 0.25*time;\\n mat4 mat = persp(radians(60.0), resolution.x /resolution.y *-1., .3-sin(tm),2.0);\\n //vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0.,-0.001,0.1);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, -snd*depth , .9);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 2.;///abs(gl_Position.z);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\\n\\n\"}", + "settings": { + "num": 47881, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#40190.0\n//Another experiment of 'vertexification' of a fragment shader \n\n#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\tif(v>0.5)\n v = 1.- v;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u*cos(time),v-1.4);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = normalize(vec2(u,v));//\n \t\n float s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*.1 - floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 1.3;\n float tm = .5 *time;\n float tm2 = 0.25*time;\n mat4 mat = persp(radians(60.0), resolution.x /resolution.y *-1., .3-sin(tm),2.0);\n //vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0.,-0.001,0.1);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, -snd*depth , .9);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 2.;///abs(gl_Position.z);\n \n //v_color = vec4(1.,1.,1.,1.);\n}\n\n" + }, "screenshotURL": "data/images/images-is36aw3iy0s29gjbc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nRwxhgevXpt2torRC/art.json b/art/nRwxhgevXpt2torRC/art.json index 636cc975..ffaaea97 100644 --- a/art/nRwxhgevXpt2torRC/art.json +++ b/art/nRwxhgevXpt2torRC/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "brlrt", "avatarUrl": "https://avatars.githubusercontent.com/brlrt?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 2.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 2.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-1t4440rejzyz6f7ae-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nSFFYqXN2ekMfQBzn/art.json b/art/nSFFYqXN2ekMfQBzn/art.json index 0bd580d1..60e907b3 100644 --- a/art/nSFFYqXN2ekMfQBzn/art.json +++ b/art/nSFFYqXN2ekMfQBzn/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Making a Grid\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Making a Grid\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-jaf4q89jrtkva6al9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nSfY6r4aXmvWBHYyo/art.json b/art/nSfY6r4aXmvWBHYyo/art.json index b2e1e32a..24072af9 100644 --- a/art/nSfY6r4aXmvWBHYyo/art.json +++ b/art/nSfY6r4aXmvWBHYyo/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":333,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/settle-the-score\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.23529411764705882,0.027450980392156862,0.10588235294117647,1],\"shader\":\"void main() {\\n \\n \\n \\n float x = sin(time+cos(vertexId));\\n float yy = sin(vertexId *- time*1.09);\\n float dim = sin(yy-x/yy)+ 24.*x*yy;\\n float red = sin(vertexId) * 33.;\\n float bleu = sin(vertexId) * 255.;\\n float green = asin(vertexId) *5.5;\\n gl_Position = vec4(x,1.-mod(yy,dim)*.5,x*0.5,1);\\n gl_PointSize = (dim/x)*yy;\\n v_color = vec4(mouse.x,1.-bleu,green,0.2);\\n \\n}\"}", + "settings": { + "num": 333, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/settle-the-score", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.23529411764705882, + 0.027450980392156862, + 0.10588235294117647, + 1 + ], + "shader": "void main() {\n \n \n \n float x = sin(time+cos(vertexId));\n float yy = sin(vertexId *- time*1.09);\n float dim = sin(yy-x/yy)+ 24.*x*yy;\n float red = sin(vertexId) * 33.;\n float bleu = sin(vertexId) * 255.;\n float green = asin(vertexId) *5.5;\n gl_Position = vec4(x,1.-mod(yy,dim)*.5,x*0.5,1);\n gl_PointSize = (dim/x)*yy;\n v_color = vec4(mouse.x,1.-bleu,green,0.2);\n \n}" + }, "screenshotURL": "data/images/images-u6i85k7ljn4iag5mn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nTr5zAmYQHMvhjYy4/art.json b/art/nTr5zAmYQHMvhjYy4/art.json index d0a80e26..852774b4 100644 --- a/art/nTr5zAmYQHMvhjYy4/art.json +++ b/art/nTr5zAmYQHMvhjYy4/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jpaquim", "avatarUrl": "https://secure.gravatar.com/avatar/374b09dacab582ca17818a391b59a214?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//VertexShaderArt Boilerplate Library\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//VertexShaderArt Boilerplate Library\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-r3e7dujv7x5udrox3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nXTGqimMaXu22Nqjs/art.json b/art/nXTGqimMaXu22Nqjs/art.json index ba801ce5..07a62b99 100644 --- a/art/nXTGqimMaXu22Nqjs/art.json +++ b/art/nXTGqimMaXu22Nqjs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/sarahkreis/sets/caleesi-sarah-kreis-mbr-sao\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 10000.0\\n#define PI 3.14159265\\n#define TWO_PI (PI * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat getSound(float f, float delay) {\\n return texture2D(sound, vec2(f, delay)).a;\\n}\\n\\nvec3 curvePos(float t) {\\n float r = (0.6 + sin(t * 31.0 * TWO_PI) * 0.4);\\n float phi = sin(t * 43.0 * TWO_PI) * PI;\\n float theta = PI * sin(t * 41.0 * PI);\\n float x = cos(phi) * cos(theta);\\n float y = sin(phi) * cos(theta);\\n float z = sin(theta);\\n return r * vec3(x, y, z);\\n}\\n\\nvoid main() {\\n float t = vertexId / NUM_POINTS;\\n vec3 p = curvePos(t);\\n float r = sqrt(p.x * p.x + p.y * p.y + p.z * p.z);\\n float h = getSound(t, 0.0); //0.5 + 0.5 * sin(r * TWO_PI + time + p.x);\\n float s = getSound(0.3, t); // 0.5 + 0.5 * cos(r * TWO_PI + time + p.x);\\n \\n float pulse = sin((time * 0.3 + t * 500.0) * TWO_PI);\\n float rpulse = sin(r * 1.0 * TWO_PI - time + getSound(0.2, 0.0));\\n float v = //max(0.5, sin(r * 3.0 * TWO_PI + time * 0.1 + t * 100.0)) - 0.5)\\n pow(max(0.0, pulse), 5.0) * 0.5\\n + 0.1 * getSound(0.3, 0.0)\\n + pow(max(0.0, rpulse), 10.0);\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1.0);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/sarahkreis/sets/caleesi-sarah-kreis-mbr-sao", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 10000.0\n#define PI 3.14159265\n#define TWO_PI (PI * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat getSound(float f, float delay) {\n return texture2D(sound, vec2(f, delay)).a;\n}\n\nvec3 curvePos(float t) {\n float r = (0.6 + sin(t * 31.0 * TWO_PI) * 0.4);\n float phi = sin(t * 43.0 * TWO_PI) * PI;\n float theta = PI * sin(t * 41.0 * PI);\n float x = cos(phi) * cos(theta);\n float y = sin(phi) * cos(theta);\n float z = sin(theta);\n return r * vec3(x, y, z);\n}\n\nvoid main() {\n float t = vertexId / NUM_POINTS;\n vec3 p = curvePos(t);\n float r = sqrt(p.x * p.x + p.y * p.y + p.z * p.z);\n float h = getSound(t, 0.0); //0.5 + 0.5 * sin(r * TWO_PI + time + p.x);\n float s = getSound(0.3, t); // 0.5 + 0.5 * cos(r * TWO_PI + time + p.x);\n \n float pulse = sin((time * 0.3 + t * 500.0) * TWO_PI);\n float rpulse = sin(r * 1.0 * TWO_PI - time + getSound(0.2, 0.0));\n float v = //max(0.5, sin(r * 3.0 * TWO_PI + time * 0.1 + t * 100.0)) - 0.5)\n pow(max(0.0, pulse), 5.0) * 0.5\n + 0.1 * getSound(0.3, 0.0)\n + pow(max(0.0, rpulse), 10.0);\n \n vec4 vertPos = rotY(time*0.1) * vec4(p, 1.0) + vec4(0.0, 0.0, -3.0, 0.0);\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1.0);\n}" + }, "screenshotURL": "data/images/images-xrpyaeiu2d2ffsh8j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nZYhMKriEvZQFNh9y/art.json b/art/nZYhMKriEvZQFNh9y/art.json index ebbc6c33..0971c680 100644 --- a/art/nZYhMKriEvZQFNh9y/art.json +++ b/art/nZYhMKriEvZQFNh9y/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "monimoy", "avatarUrl": "https://lh6.googleusercontent.com/-rYhxHwokiLU/AAAAAAAAAAI/AAAAAAAABZY/cTDYJkyyjtY/photo.jpg", - "settings": "{\"num\":5096,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 1.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\\n\"}", + "settings": { + "num": 5096, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 1.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}\n" + }, "screenshotURL": "data/images/images-us66itju55qmb68bs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/na6qJtpJXmYZhkDxM/art.json b/art/na6qJtpJXmYZhkDxM/art.json index 0a243d89..d2e4bd1f 100644 --- a/art/na6qJtpJXmYZhkDxM/art.json +++ b/art/na6qJtpJXmYZhkDxM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "chuck", "avatarUrl": "https://lh4.googleusercontent.com/-M2l823dVzS4/AAAAAAAAAAI/AAAAAAAABaM/2SfesIQoVCw/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8901960784313725,0.8901960784313725,0.8901960784313725,1],\"shader\":\"// simple line visualizer\\n\\n#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8901960784313725, + 0.8901960784313725, + 0.8901960784313725, + 1 + ], + "shader": "// simple line visualizer\n\n#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-7wv53la63ep113hji-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/naucTfFjkhTtNMkk4/art.json b/art/naucTfFjkhTtNMkk4/art.json index 767e50ba..03004da0 100644 --- a/art/naucTfFjkhTtNMkk4/art.json +++ b/art/naucTfFjkhTtNMkk4/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":97150,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.50, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 0.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.70), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0.2,\\n 1.9-s, 0.2, 0, 0,\\n s, -0.6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, s, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, s/2.0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 0, 0,\\n trans, 0.5);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0.1, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 2, 0.1, 0);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, mouse.x, 0, 0,\\n 0, s-2., 0, -0.1,\\n 0.5, 0, s, -mouse.y,\\n 0, 0, 0, -1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(11.5351, 34.3137));\\n\\treturn fract(p2.x * p2.y / 61.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 3.2 - 2.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.81 - (0.5*v);\\n}\\n\\nfloat inv(float v) {\\n return 2. * (v - mouse.x);\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.9);\\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 3.5 ); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI - tan(sin((11.6, 110.2) / PI * 1.10));\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v -s*2.;\\n float y = s * v-c;\\n float z = 0.05 * v;\\n pos = vec3(x, y, z -s *- u/36.); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) - mouse.y -t) + sin(t * 2.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 1.5)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\\n float end = start - 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu / abs(uv.x/ 1.8 - 1.3)-7.) * 1.5, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 2.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31;\\n vec3 aspect = vec3((0.9, resolution.y / resolution.x , mouse.y)* 1.91);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5.;\\n\\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId* snd , fract(circleId * 12.79 - snd));\\n float sat = 0.5 + snd;\\n float val = 0. + snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.51, snd+6.));\\n v_color = vec4(2.1 *v_color.rgb * v_color.a, sin(v_color.a -9.));\\n}\"}", + "settings": { + "num": 97150, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.50, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 0.0 / 0.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.70), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0.2,\n 1.9-s, 0.2, 0, 0,\n s, -0.6, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, s, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, s/2.0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 0, 0,\n trans, 0.5);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1,\n 0, -1, 1, -0.9,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0.1, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 2, 0.1, 0);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, mouse.x, 0, 0,\n 0, s-2., 0, -0.1,\n 0.5, 0, s, -mouse.y,\n 0, 0, 0, -1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(11.5351, 34.3137));\n\treturn fract(p2.x * p2.y / 61.4337);\n}\n\nfloat m1p1(float v) {\n return v * 3.2 - 2.;\n}\n\nfloat p1m1(float v) {\n return v * 1.81 - (0.5*v);\n}\n\nfloat inv(float v) {\n return 2. * (v - mouse.x);\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 0.9);\n float vy = mod(floor(id / 2.) + floor(id / 1.5 + edgeId), 3.5 ); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 5.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI - tan(sin((11.6, 110.2) / PI * 1.10));\n float s = sin(a);\n float c = cos(a);\n float x = c * v -s*2.;\n float y = s * v-c;\n float z = 0.05 * v;\n pos = vec3(x, y, z -s *- u/36.); \n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.17) + tan((t * 0.13) - mouse.y -t) + sin(t * 2.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 1.5)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.03, 0.1, p1m1(sin(goop(circleId) - time / 3.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.83 + circleId) *2.1 *mouse.x);\n float end = start - 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu / abs(uv.x/ 1.8 - 1.3)-7.) * 1.5, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 2.5, m1p1(hash(circleId * 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31;\n vec3 aspect = vec3((0.9, resolution.y / resolution.x , mouse.y)* 1.91);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.01, 0.2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.5)).xyz, 12.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5.;\n\n float hue = mix(1.51 *snd , 1.9 *mouse.x/ circleId* snd , fract(circleId * 12.79 - snd));\n float sat = 0.5 + snd;\n float val = 0. + snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.51, snd+6.));\n v_color = vec4(2.1 *v_color.rgb * v_color.a, sin(v_color.a -9.));\n}" + }, "screenshotURL": "data/images/images-6zzufr4z3pxxkwz6d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nb7JYJJLQtbayZHzh/art.json b/art/nb7JYJJLQtbayZHzh/art.json index c2b9b8b3..940484be 100644 --- a/art/nb7JYJJLQtbayZHzh/art.json +++ b/art/nb7JYJJLQtbayZHzh/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 ctr = vec2(0.5);\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 4.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 80. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown * snd; \\n gl_PointSize *= resolution.x / 30. * xOff; \\n xy -= ctr;\\n xy *= rotate2D(snd * PI * 2.0 +s);\\n xy += ctr;\\n xy *= pow(xy, ctr + xy);\\n xy *= -3.;\\n //xy = fract(xy / 0.1);\\n vec4 pos = vec4(xy / yOff, xOff , 1.-xOff);\\n pos *= rotY(PI * s);\\n gl_Position = pos;\\n xy -= vec2(0.5);\\n xy *= rotate2D(-snd * -PI * 2.0);\\n xy += vec2(0.5);\\n xy *= mouse;\\n float hue = snd -s;\\n hue = smoothstep(xy.x, xy.y, s);\\n float sat = 1.0;\\n float val = invV;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n //color *= rotY(PI * snd * s);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n \\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n vec2 ctr = vec2(0.5);\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 4.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 80. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown * snd; \n gl_PointSize *= resolution.x / 30. * xOff; \n xy -= ctr;\n xy *= rotate2D(snd * PI * 2.0 +s);\n xy += ctr;\n xy *= pow(xy, ctr + xy);\n xy *= -3.;\n //xy = fract(xy / 0.1);\n vec4 pos = vec4(xy / yOff, xOff , 1.-xOff);\n pos *= rotY(PI * s);\n gl_Position = pos;\n xy -= vec2(0.5);\n xy *= rotate2D(-snd * -PI * 2.0);\n xy += vec2(0.5);\n xy *= mouse;\n float hue = snd -s;\n hue = smoothstep(xy.x, xy.y, s);\n float sat = 1.0;\n float val = invV;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n //color *= rotY(PI * snd * s);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n \n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-h30ilp6q57jd83df0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nbFWWPZ79M6W6WTNB/art.json b/art/nbFWWPZ79M6W6WTNB/art.json index 3a78492d..e8640a53 100644 --- a/art/nbFWWPZ79M6W6WTNB/art.json +++ b/art/nbFWWPZ79M6W6WTNB/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.29411764705882354,0.5882352941176471,0.9450980392156862,1],\"shader\":\"\\nvoid main() {\\n gl_PointSize = 10.0;\\n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\\n gl_Position = vec4(xy,0.0,1.0);\\n v_color = vec4(1.0,0.0,0.0,1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.29411764705882354, + 0.5882352941176471, + 0.9450980392156862, + 1 + ], + "shader": "\nvoid main() {\n gl_PointSize = 10.0;\n vec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\n gl_Position = vec4(xy,0.0,1.0);\n v_color = vec4(1.0,0.0,0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-s575sgj7bbw3euy7z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nbFhti5B3jMmZX2Te/art.json b/art/nbFhti5B3jMmZX2Te/art.json index 0397d189..341341db 100644 --- a/art/nbFhti5B3jMmZX2Te/art.json +++ b/art/nbFhti5B3jMmZX2Te/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":34509,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float NUM_SEGMENTS = 6.0 + time*0.0;\\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\\n float STEP = time*2.1;\\n if (STEP > 0.03) STEP = 3.3;\\n float localTime = time*4.1 + 2.5;\\n float point = mod(floor(vertexId / 10.) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * localTime*0.0001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;\\n mix(0.3, 0.2, b);\\n v_color = vec4(0.8-b, 0.4-c*10.0, 1.0-s*10.0, 1);\\n}\"}", + "settings": { + "num": 34509, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvoid main() {\n float NUM_SEGMENTS = 6.0 + time*0.0;\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\n float STEP = time*2.1;\n if (STEP > 0.03) STEP = 3.3;\n float localTime = time*4.1 + 2.5;\n float point = mod(floor(vertexId / 10.) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * localTime*0.0001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;\n mix(0.3, 0.2, b);\n v_color = vec4(0.8-b, 0.4-c*10.0, 1.0-s*10.0, 1);\n}" + }, "screenshotURL": "data/images/images-hzsenv9pm5aucaqq8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nbmdLoxbimLhzSeAx/art.json b/art/nbmdLoxbimLhzSeAx/art.json index eef60e0b..639a535e 100644 --- a/art/nbmdLoxbimLhzSeAx/art.json +++ b/art/nbmdLoxbimLhzSeAx/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "savash", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GiSY6NYT8sMqDGK2iowOrlmdgPpY-gZiOQumjedfA=s96-c", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7803921568627451,0.7803921568627451,0.7803921568627451,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u *2. -1.;\\n float vy = v *2. -1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 255, 0, 1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7803921568627451, + 0.7803921568627451, + 0.7803921568627451, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u *2. -1.;\n float vy = v *2. -1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 255, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-dn1jzjtu5f94nv0aq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ne6ENatKHpRDSgJRv/art.json b/art/ne6ENatKHpRDSgJRv/art.json index 6a9a5be2..a260bcc5 100644 --- a/art/ne6ENatKHpRDSgJRv/art.json +++ b/art/ne6ENatKHpRDSgJRv/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 1.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 1.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 1.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 1.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-j77711km99pxe0jr2-thumbnail.jpg", "views": { "$numberInt": "36" diff --git a/art/nfh8MJW78b4zW9WWW/art.json b/art/nfh8MJW78b4zW9WWW/art.json index a2c7bb41..d5722554 100644 --- a/art/nfh8MJW78b4zW9WWW/art.json +++ b/art/nfh8MJW78b4zW9WWW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=65536\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 3.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 10.;\\n //float lineId = mod(shapeId, numberOfElement);\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float relXid = xPos/2.;\\n xPos =xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n \\n lineId/=numberOfElement;\\n\\n \\n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\\n \\n cubep = vec3(cubep.x, cubep.y+snd, cubep.z);\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n cubep.x+=xPos;\\n cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n \\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=65536\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 3.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 10.;\n //float lineId = mod(shapeId, numberOfElement);\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float relXid = xPos/2.;\n xPos =xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi) * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n \n lineId/=numberOfElement;\n\n \n float snd = texture2D(sound, vec2(relXid, shapeRelId)).a/2.;\n \n cubep = vec3(cubep.x, cubep.y+snd, cubep.z);\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n cubep.x+=xPos;\n cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n \n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 2.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-kqv36tmwy32irhr4q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nfi9NM8Y8gRZNqaEF/art.json b/art/nfi9NM8Y8gRZNqaEF/art.json index 26d26400..fe010af3 100644 --- a/art/nfi9NM8Y8gRZNqaEF/art.json +++ b/art/nfi9NM8Y8gRZNqaEF/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":1352,\"mode\":\"TRIANGLES\",\"sound\":\"//KDrawmode=GL_TRIANGLES #define parameter0 1.//KParameter0 1.>>8. #define parameter1 -0.2//KParameter1 -1.>>1. #define parameter2 -1.//KParameter2 -1.>>1. #define parameter3 0.//KParameter3 0.>>12. #define parameter4 2.//KParameter4 0.>>2. #define parameter5 1.//KParameter5 0.1>>1.5 #define parameter6 0.3//KParameter6 0.>>1. #define parameter7 0.//KParameter7 0.>>10. #define HPI 1.570796326795 #define PI 3.1415926535898 #define SYMMETRY_H 1 #define SYMMETRY_V 1 #define COLOR_MODE 1 vec3 rotZ(vec3 _v, float _rad) { vec2 f = sin(vec2(_rad, _rad + HPI)); vec3 r = _v; r.x = _v.x * f.x + _v.y * f.y; r.y = _v.x * -f.y + _v.y * f.x; return r; } mat4 uniformScale(float _s) { return mat4( _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, 1); } vec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18]) { vec4 result = vec4(0., 0.,-1., 1.); float localVertexId = _vertexId - _startVertexId; if(localVertexId<1.) { result.xy = _letter[0].xy; } else if(localVertexId<2.) { result.xy = _letter[1].xy; } else if(localVertexId<3.) { result.xy = _letter[2].xy; } else //2nd triangle if(localVertexId<4.) { result.xy = _letter[3].xy; } else if(localVertexId<5.) { result.xy = _letter[4].xy; } else if(localVertexId<6.) { result.xy = _letter[5].xy; } else if(localVertexId<7.)//3 eme triangle { result.xy = _letter[6].xy; } else if(localVertexId<8.) { result.xy = _letter[7].xy; } else if(localVertexId<9.) { result.xy = _letter[8].xy; } else if(localVertexId<10.)//4eme triangle { result.xy = _letter[9].xy; } else if(localVertexId<11.) { result.xy = _letter[10].xy; } else if(localVertexId<12.) { result.xy = _letter[11].xy; } else if(localVertexId<13.) { result.xy = _letter[12].xy; } else if(localVertexId<14.) { result.xy = _letter[13].xy; } else if(localVertexId<15.) { result.xy = _letter[14].xy; } else if(localVertexId<16.) { result.xy = _letter[15].xy; } else if(localVertexId<17.) { result.xy = _letter[16].xy; } else if(localVertexId<18.) { result.xy = _letter[17].xy; } result.xy+=_pos; result.xy-=vec2(_barWidth*2.,0.5)+_pos; result.xyz =rotZ(result.xyz, _rotation); result.xy+=vec2(_barWidth*2.,0.5)+_pos; result *= uniformScale(_scale); return result.xyz; } vec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos) { vec2 finalPos = _pos; vec2 additionalPos = vec2(0.,0.); float transfoMode = floor(parameter3); //additionalPos.x = _relLetterTimeProgress*0.5; if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<2.) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6; finalPos+= additionalPos; } else if(transfoMode<3.) { additionalPos = -finalPos; additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI ); additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI ); finalPos+= additionalPos; } else if(transfoMode<4.) { additionalPos = -finalPos; vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) )); additionalPos.x+= m.x; additionalPos.y+= m.y; finalPos+= additionalPos; } else if(transfoMode<5.) { additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time)); finalPos+= additionalPos; } else if(transfoMode<6.) { additionalPos = -finalPos; additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5; additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));; finalPos+= additionalPos; } else if(transfoMode<7.) { if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); finalPos+= additionalPos; } } else if(transfoMode<8.) { additionalPos = -finalPos; if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<9.) { additionalPos = -finalPos; if(mod(_shapeId,2.)<1.) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<10.) { //if(_selectedShape == _shapeId) { vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. )); additionalPos.y = m.x*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<11.) { additionalPos = -finalPos; additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time ); additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time); finalPos+= additionalPos; } return finalPos; } float getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation) { float finalRot = _rotation; float additionalRotation = 0.; float transfoMode = floor(parameter3); if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress; } } else if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = 2.*2.*PI*_relLetterTimeProgress; } } finalRot+= additionalRotation; /* float additionalRotation = 0.; if(selectedLetterIndex == shapeId) { additionalRotation = 2.*PI*relLetterTimeProgress; } rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId; */ return finalRot; } vec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth) { vec2 finalCenter = _center; /* vec2 additionalCenter = vec2(0.,0.); if(_selectedShape == _shapeId) { additionalCenter.x = _relLetterTimeProgress*0.5; additionalCenter.y = _relLetterTimeProgress*0.5; } finalCenter+= additionalCenter; */ return finalCenter; } #define elementPerShapeLetterK 18. #define defaultRotationForShapeLetterK 0.13 #define defaultRotationForShapeLetterM - 0.09 #define defaultRotationForShapeLetterN 0.04 #define defaultRotationForShapeLetterA 0.1 #define defaultRotationForShapeLetterC - 0.05 #define defaultRotationForShapeLetterE - 0.03 #define defaultRotationForShapeLetterH 0.04 #define defaultRotationForShapeLetterI - 0.02 #define shapeNumber 8. #define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber void main() { vec3 color = vec3(1.); float sndFactor = texture2D(sound, vec2(0.01, 0.)).r; float _junctionY = 0.5 +parameter4*sndFactor/10.; float _barWidth = 0.2 ;// + parameter4*sndFactor/100.; float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.; float shapeId = 0.; vec2 letterK[18]; letterK[0] = vec2(0.,0.); letterK[1] = vec2(0.,1.); letterK[2] = vec2(_barWidth,1.); letterK[3] = vec2(0.,0.0); letterK[4] = vec2(_barWidth,1.); letterK[5] = vec2(_barWidth,0.); letterK[6] = vec2(_barWidth,_junctionY); letterK[7] = vec2((_secondVertY+_barWidth),1.); letterK[8] = vec2(_secondVertY,1.); letterK[9] = vec2(_barWidth,_junctionY); letterK[10] = vec2((_secondVertY+_barWidth),0.); letterK[11] = vec2(_secondVertY,0.); letterK[12] = vec2(_secondVertY,0.); letterK[13] = vec2(_secondVertY,0.); letterK[14] = vec2(_secondVertY,0.); letterK[15] = vec2(_secondVertY,0.); letterK[16] = vec2(_secondVertY,0.); letterK[17] = vec2(_secondVertY,0.); vec2 letterM[18]; letterM[0] = vec2(0.,0.); letterM[1] = vec2(0.,1.); letterM[2] = vec2(_barWidth,1.); letterM[3] = vec2(0.,0.0); letterM[4] = vec2(_barWidth,1.); letterM[5] = vec2(_barWidth,0.);//PROBLEM !! letterM[6] = vec2(_barWidth,_junctionY+_barWidth); letterM[7] = vec2(_barWidth,1.); letterM[8] = vec2(_barWidth*2.,_junctionY); letterM[9] = vec2(_barWidth*2.,_junctionY); letterM[10] = vec2((_barWidth*3.),1.); letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth); letterM[12] = vec2(_barWidth*3.,1.); letterM[13] = vec2(_barWidth*4.,1.); letterM[14] = vec2(_barWidth*3.,0.); letterM[15] = vec2(_barWidth*3.,0.); letterM[16] = vec2(_barWidth*4.,1.); letterM[17] = vec2(_barWidth*4.,0.); vec2 letterN[18]; letterN[0] = vec2(0.,0.); letterN[1] = vec2(0.,1.); letterN[2] = vec2(_barWidth,1.); letterN[3] = vec2(0.,0.0); letterN[4] = vec2(_barWidth,1.); letterN[5] = vec2(_barWidth,0.); letterN[6] = vec2(_barWidth,_junctionY+_barWidth); letterN[7] = vec2(_barWidth,1.); letterN[8] = vec2(_barWidth*2.,_junctionY); letterN[9] = vec2(_barWidth*2.,1.); letterN[10] = vec2(_barWidth*3.,1.); letterN[11] = vec2(_barWidth*2.,0.); letterN[12] = vec2(_barWidth*2.,0.); letterN[13] = vec2(_barWidth*3.,1.); letterN[14] = vec2(_barWidth*3.,0.); letterN[15] = vec2(_barWidth*3.,0.); letterN[16] = vec2(_barWidth*3.,0.); letterN[17] = vec2(_barWidth*3.,0.); vec2 letterA[18]; letterA[0] = vec2(0.,0.); letterA[1] = vec2(_barWidth,0.); letterA[2] = vec2(_barWidth*2.,1.); letterA[3] = vec2(_barWidth*4.,0.0); letterA[4] = vec2(_barWidth*2.,1.); letterA[5] = vec2(_barWidth*3.,0.); letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.); letterA[8] = vec2(_barWidth*3.,_junctionY); letterA[9] = vec2(_barWidth*3.,_junctionY); letterA[10] = vec2(_barWidth*3.,_junctionY); letterA[11] = vec2(_barWidth*3.,_junctionY); letterA[12] = vec2(_barWidth*3.,_junctionY); letterA[13] = vec2(_barWidth*3.,_junctionY); letterA[14] = vec2(_barWidth*3.,_junctionY); letterA[15] = vec2(_barWidth*3.,_junctionY); letterA[16] = vec2(_barWidth*3.,_junctionY); letterA[17] = vec2(_barWidth*3.,_junctionY); vec2 letterE[18]; letterE[0] = vec2(0.,0.); letterE[1] = vec2(0.,1.); letterE[2] = vec2(_barWidth,1.); letterE[3] = vec2(0.,0.0); letterE[4] = vec2(_barWidth,1.); letterE[5] = vec2(_barWidth,0.); letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5); letterE[7] = vec2(_barWidth,1.); letterE[8] = vec2(_barWidth*3.,1.); letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5); letterE[10] = vec2(_barWidth,0.); letterE[11] = vec2(_barWidth*3.,0.); letterE[12] = vec2(_barWidth,_junctionY); letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.); letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); vec2 letterC[18]; letterC[0] = vec2(0.,0.); letterC[1] = vec2(0.,1.); letterC[2] = vec2(_barWidth,1.); letterC[3] = vec2(0.,0.0); letterC[4] = vec2(_barWidth,1.); letterC[5] = vec2(_barWidth,0.); letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5); letterC[7] = vec2(_barWidth,1.); letterC[8] = vec2(_barWidth*3.,1.); letterC[9] = vec2(_barWidth,0.); letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5); letterC[11] = vec2(_barWidth*3.,0.); letterC[12] = vec2(_barWidth*3.,0.); letterC[13] = vec2(_barWidth*3.,0.); letterC[14] = vec2(_barWidth*3.,0.); letterC[15] = vec2(_barWidth*3.,0.); letterC[16] = vec2(_barWidth*3.,0.); letterC[17] = vec2(_barWidth*3.,0.); vec2 letterH[18]; letterH[0] = vec2(0.,0.); letterH[1] = vec2(0.,1.); letterH[2] = vec2(_barWidth,1.); letterH[3] = vec2(0.,0.0); letterH[4] = vec2(_barWidth,1.); letterH[5] = vec2(_barWidth,0.); letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.); letterH[8] = vec2(_barWidth*2.,_junctionY); letterH[9] = vec2(_barWidth*2.,_junctionY); letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.); letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.); letterH[12] = vec2(_barWidth*3.,1.); letterH[13] = vec2(_barWidth*4.,1.); letterH[14] = vec2(_barWidth*3.,0.); letterH[15] = vec2(_barWidth*3.,0.); letterH[16] = vec2(_barWidth*4.,1.); letterH[17] = vec2(_barWidth*4.,0.); vec2 letterI[18]; letterI[0] = vec2(0.,0.); letterI[1] = vec2(0.,_junctionY+_barWidth); letterI[2] = vec2(_barWidth,_junctionY+_barWidth); letterI[3] = vec2(0.,0.0); letterI[4] = vec2(_barWidth,_junctionY+_barWidth); letterI[5] = vec2(_barWidth,0.);//PROBLEM !! letterI[6] = vec2(0.,1.-_barWidth); letterI[7] = vec2(0.,1.); letterI[8] = vec2(_barWidth,1.-_barWidth); letterI[9] = vec2(_barWidth,1.-_barWidth); letterI[10] = vec2(0.,1.); letterI[11] = vec2(_barWidth,1.); letterI[12] = vec2(_barWidth,1.); letterI[13] = vec2(_barWidth,1.); letterI[14] = vec2(_barWidth,1.); letterI[15] = vec2(_barWidth,1.); letterI[16] = vec2(_barWidth,1.); letterI[17] = vec2(_barWidth,1.); float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord)); float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;// float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId); //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord); finalVertexId = min(maxNumberOfVertices,vertexId); finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord)); //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord); //float relMetaShapeId = metaShapeId/256.; float masterScale = parameter5;//parameter6; vec3 _v = vec3(0.,0.,0.); vec2 letterPos = vec2(0.,0.); float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.; float scaleK = 0.4*masterScale; float scale = 0.2*masterScale; float startPosK = parameter2; float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters); vec2 shapeCenter = vec2(0.,0.5); //for vsa float loopDurationMs = 4000.; float timeProgress = mod(time*1000.,loopDurationMs); float relLoopProgress = timeProgress/loopDurationMs; //end for vsa float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor)); float numberOfSubLoops = floor(parameter0); float subLoopLength = 1./numberOfSubLoops; finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength; float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber)); float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber); float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress); ///////////////////////// float rotation = PI/3.*time*shapeId; if(finalVertexId0 else if(vertexId0 else if(vertexId0 && SYMMETRY_H >0 else if(vertexId>8.\\n#define parameter1 -0.2//KParameter1 -1.>>1.\\n#define parameter2 -1.//KParameter2 -1.>>1.\\n#define parameter3 0.//KParameter3 0.>>12.\\n#define parameter4 2.//KParameter4 0.>>2.\\n#define parameter5 1.//KParameter5 0.1>>1.5\\n#define parameter6 0.3//KParameter6 0.>>1.\\n#define parameter7 0.//KParameter7 0.>>10.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define SYMMETRY_H 1\\n#define SYMMETRY_V 1\\n#define COLOR_MODE 1\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\\n{\\n \\n \\n \\n \\n vec4 result = vec4(0., 0.,-1., 1.);\\n \\n \\n float localVertexId = _vertexId - _startVertexId;\\n \\n if(localVertexId<1.)\\n {\\n result.xy = _letter[0].xy;\\n }\\n else\\n \\n if(localVertexId<2.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n \\n else\\n if(localVertexId<3.)\\n {\\n result.xy = _letter[2].xy;\\n }\\n else //2nd triangle\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[3].xy;\\n }\\n else\\n if(localVertexId<5.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<6.)\\n {\\n result.xy = _letter[5].xy;\\n }\\n else\\n if(localVertexId<7.)//3 eme triangle\\n {\\n result.xy = _letter[6].xy;\\n }\\n else\\n if(localVertexId<8.)\\n {\\n result.xy = _letter[7].xy;\\n }\\n else\\n if(localVertexId<9.)\\n {\\n result.xy = _letter[8].xy;\\n \\n }\\n \\n else\\n if(localVertexId<10.)//4eme triangle\\n {\\n result.xy = _letter[9].xy;\\n \\n }\\n else\\n if(localVertexId<11.)\\n {\\n result.xy = _letter[10].xy;\\n \\n }\\n \\n else\\n if(localVertexId<12.)\\n {\\n result.xy = _letter[11].xy;\\n \\n }\\n else\\n if(localVertexId<13.)\\n {\\n result.xy = _letter[12].xy;\\n \\n }\\n else\\n if(localVertexId<14.)\\n {\\n result.xy = _letter[13].xy;\\n \\n }\\n else\\n if(localVertexId<15.)\\n {\\n result.xy = _letter[14].xy;\\n \\n }\\n else\\n if(localVertexId<16.)\\n {\\n result.xy = _letter[15].xy;\\n \\n }\\n else\\n if(localVertexId<17.)\\n {\\n result.xy = _letter[16].xy;\\n \\n }\\n else\\n if(localVertexId<18.)\\n {\\n result.xy = _letter[17].xy;\\n \\n }\\n result.xy+=_pos;\\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\\n result.xyz =rotZ(result.xyz, _rotation);\\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\\n result *= uniformScale(_scale);\\n \\n \\n return result.xyz;\\n}\\n\\n\\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\\n{\\n vec2 finalPos = _pos;\\n \\n \\n vec2 additionalPos = vec2(0.,0.);\\n \\n float transfoMode = floor(parameter3);\\n \\n \\n //additionalPos.x = _relLetterTimeProgress*0.5;\\n if(transfoMode<1.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n else\\n if(transfoMode<2.)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<3.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<4.)\\n {\\n additionalPos = -finalPos;\\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\\n \\n additionalPos.x+= m.x;\\n additionalPos.y+= m.y;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<5.)\\n {\\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<6.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<7.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n finalPos+= additionalPos;\\n }\\n \\n }\\n else\\n if(transfoMode<8.)\\n {\\n additionalPos = -finalPos;\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<9.)\\n {\\n additionalPos = -finalPos;\\n \\n if(mod(_shapeId,2.)<1.)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n \\n if(transfoMode<10.)\\n {\\n //if(_selectedShape == _shapeId)\\n {\\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\\n additionalPos.y = m.x*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n \\n else\\n \\n if(transfoMode<11.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\\n finalPos+= additionalPos;\\n }\\n \\n return finalPos;\\n}\\n\\n\\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\\n{\\n float finalRot = _rotation;\\n \\n float additionalRotation = 0.;\\n \\n float transfoMode = floor(parameter3);\\n \\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n else\\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n \\n \\n finalRot+= additionalRotation;\\n \\n /*\\n float additionalRotation = 0.;\\n \\n if(selectedLetterIndex == shapeId)\\n {\\n additionalRotation = 2.*PI*relLetterTimeProgress;\\n }\\n \\n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\\n */\\n \\n return finalRot;\\n}\\n\\n\\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\\n{\\n vec2 finalCenter = _center;\\n \\n \\n /*\\n vec2 additionalCenter = vec2(0.,0.);\\n \\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalCenter.x = _relLetterTimeProgress*0.5;\\n additionalCenter.y = _relLetterTimeProgress*0.5;\\n }\\n \\n finalCenter+= additionalCenter;\\n */\\n \\n return finalCenter;\\n}\\n\\n#define elementPerShapeLetterK 18.\\n\\n#define defaultRotationForShapeLetterK 0.13\\n#define defaultRotationForShapeLetterM - 0.09\\n#define defaultRotationForShapeLetterN 0.04\\n#define defaultRotationForShapeLetterA 0.06\\n#define defaultRotationForShapeLetterC - 0.7\\n#define defaultRotationForShapeLetterE - 0.03\\n#define defaultRotationForShapeLetterH 0.04\\n#define defaultRotationForShapeLetterI - 0.3\\n\\n\\n#define shapeNumber 8.\\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\\n\\nvoid main() {\\n \\n \\n vec3 color = vec3(1.);\\n \\n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\\n float _junctionY = 0.5 +parameter4*sndFactor/10.;\\n \\n float _barWidth = 0.2 ;// + parameter4*sndFactor/100.;\\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\\n \\n float shapeId = 0.;\\n \\n vec2 letterK[18];\\n letterK[0] = vec2(0.,0.);\\n letterK[1] = vec2(0.,1.);\\n letterK[2] = vec2(_barWidth,1.);\\n letterK[3] = vec2(0.,0.0);\\n letterK[4] = vec2(_barWidth,1.);\\n letterK[5] = vec2(_barWidth,0.);\\n letterK[6] = vec2(_barWidth,_junctionY);\\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\\n letterK[8] = vec2(_secondVertY,1.);\\n letterK[9] = vec2(_barWidth,_junctionY);\\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\\n letterK[11] = vec2(_secondVertY,0.);\\n letterK[12] = vec2(_secondVertY,0.);\\n letterK[13] = vec2(_secondVertY,0.);\\n letterK[14] = vec2(_secondVertY,0.);\\n letterK[15] = vec2(_secondVertY,0.);\\n letterK[16] = vec2(_secondVertY,0.);\\n letterK[17] = vec2(_secondVertY,0.);\\n \\n vec2 letterM[18];\\n letterM[0] = vec2(0.,0.);\\n letterM[1] = vec2(0.,1.);\\n letterM[2] = vec2(_barWidth,1.);\\n letterM[3] = vec2(0.,0.0);\\n letterM[4] = vec2(_barWidth,1.);\\n letterM[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterM[7] = vec2(_barWidth,1.);\\n letterM[8] = vec2(_barWidth*2.,_junctionY);\\n letterM[9] = vec2(_barWidth*2.,_junctionY);\\n letterM[10] = vec2((_barWidth*3.),1.);\\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\\n letterM[12] = vec2(_barWidth*3.,1.);\\n letterM[13] = vec2(_barWidth*4.,1.);\\n letterM[14] = vec2(_barWidth*3.,0.);\\n letterM[15] = vec2(_barWidth*3.,0.);\\n letterM[16] = vec2(_barWidth*4.,1.);\\n letterM[17] = vec2(_barWidth*4.,0.);\\n \\n \\n vec2 letterN[18];\\n letterN[0] = vec2(0.,0.);\\n letterN[1] = vec2(0.,1.);\\n letterN[2] = vec2(_barWidth,1.);\\n letterN[3] = vec2(0.,0.0);\\n letterN[4] = vec2(_barWidth,1.);\\n letterN[5] = vec2(_barWidth,0.);\\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterN[7] = vec2(_barWidth,1.);\\n letterN[8] = vec2(_barWidth*2.,_junctionY);\\n letterN[9] = vec2(_barWidth*2.,1.);\\n letterN[10] = vec2(_barWidth*3.,1.);\\n letterN[11] = vec2(_barWidth*2.,0.);\\n \\n letterN[12] = vec2(_barWidth*2.,0.);\\n letterN[13] = vec2(_barWidth*3.,1.);\\n letterN[14] = vec2(_barWidth*3.,0.);\\n letterN[15] = vec2(_barWidth*3.,0.);\\n \\n letterN[16] = vec2(_barWidth*3.,0.);\\n letterN[17] = vec2(_barWidth*5.,1.);\\n \\n \\n vec2 letterA[18];\\n letterA[0] = vec2(0.,0.);\\n letterA[1] = vec2(_barWidth,0.);\\n letterA[2] = vec2(_barWidth*2.,1.);\\n letterA[3] = vec2(_barWidth*4.,0.0);\\n letterA[4] = vec2(_barWidth*2.,1.);\\n letterA[5] = vec2(_barWidth*3.,0.);\\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\\n letterA[8] = vec2(_barWidth*3.,_junctionY);\\n letterA[9] = vec2(_barWidth*3.,_junctionY);\\n letterA[10] = vec2(_barWidth*3.,_junctionY);\\n letterA[11] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[12] = vec2(_barWidth*3.,_junctionY);\\n letterA[13] = vec2(_barWidth*3.,_junctionY);\\n letterA[14] = vec2(_barWidth*3.,_junctionY);\\n letterA[15] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[16] = vec2(_barWidth*3.,_junctionY);\\n letterA[17] = vec2(_barWidth*3.,_junctionY);\\n \\n \\n vec2 letterE[18];\\n letterE[0] = vec2(0.,0.);\\n letterE[1] = vec2(0.,1.);\\n letterE[2] = vec2(_barWidth,1.);\\n letterE[3] = vec2(0.,0.0);\\n letterE[4] = vec2(_barWidth,1.);\\n letterE[5] = vec2(_barWidth,0.);\\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\\n letterE[7] = vec2(_barWidth,1.);\\n letterE[8] = vec2(_barWidth*3.,1.);\\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\\n letterE[10] = vec2(_barWidth,0.);\\n letterE[11] = vec2(_barWidth*3.,0.);\\n letterE[12] = vec2(_barWidth,_junctionY);\\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n \\n \\n vec2 letterC[18];\\n letterC[0] = vec2(0.,0.);\\n letterC[1] = vec2(0.,1.);\\n letterC[2] = vec2(_barWidth,1.);\\n letterC[3] = vec2(0.,0.0);\\n letterC[4] = vec2(_barWidth,1.);\\n letterC[5] = vec2(_barWidth,0.);\\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\\n letterC[7] = vec2(_barWidth,1.);\\n letterC[8] = vec2(_barWidth*3.,1.);\\n letterC[9] = vec2(_barWidth,0.);\\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\\n letterC[11] = vec2(_barWidth*3.,0.);\\n letterC[12] = vec2(_barWidth*3.,0.);\\n letterC[13] = vec2(_barWidth*3.,0.);\\n letterC[14] = vec2(_barWidth*3.,0.);\\n letterC[15] = vec2(_barWidth*3.,0.);\\n letterC[16] = vec2(_barWidth*3.,0.);\\n letterC[17] = vec2(_barWidth*3.,0.);\\n \\n vec2 letterH[18];\\n letterH[0] = vec2(0.,0.);\\n letterH[1] = vec2(0.,1.);\\n letterH[2] = vec2(_barWidth,1.);\\n letterH[3] = vec2(0.,0.0);\\n letterH[4] = vec2(_barWidth,1.);\\n letterH[5] = vec2(_barWidth,0.);\\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\\n letterH[8] = vec2(_barWidth*2.,_junctionY);\\n letterH[9] = vec2(_barWidth*2.,_junctionY);\\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\\n letterH[12] = vec2(_barWidth*3.,1.);\\n letterH[13] = vec2(_barWidth*4.,1.);\\n letterH[14] = vec2(_barWidth*3.,0.);\\n letterH[15] = vec2(_barWidth*3.,0.);\\n letterH[16] = vec2(_barWidth*4.,1.);\\n letterH[17] = vec2(_barWidth*4.,0.);\\n \\n vec2 letterI[18];\\n letterI[0] = vec2(0.,0.);\\n letterI[1] = vec2(0.,_junctionY+_barWidth);\\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[3] = vec2(0.,0.0);\\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterI[6] = vec2(0.,1.-_barWidth);\\n letterI[7] = vec2(0.,1.);\\n letterI[8] = vec2(_barWidth,1.-_barWidth);\\n letterI[9] = vec2(_barWidth,1.-_barWidth);\\n letterI[10] = vec2(0.,1.);\\n letterI[11] = vec2(_barWidth,1.);\\n letterI[12] = vec2(_barWidth,1.);\\n letterI[13] = vec2(_barWidth,1.);\\n letterI[14] = vec2(_barWidth,1.);\\n letterI[15] = vec2(_barWidth,1.);\\n letterI[16] = vec2(_barWidth,1.);\\n letterI[17] = vec2(_barWidth,1.);\\n \\n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\\n \\n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\\n \\n finalVertexId = min(maxNumberOfVertices,vertexId);\\n \\n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\\n \\n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\\n //float relMetaShapeId = metaShapeId/256.;\\n \\n float masterScale = parameter5;//parameter6;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n \\n vec2 letterPos = vec2(0.,0.);\\n \\n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\\n \\n float scaleK = 0.4*masterScale;\\n float scale = 0.2*masterScale;\\n float startPosK = parameter2;\\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\\n \\n vec2 shapeCenter = vec2(0.,0.5);\\n \\n //for vsa\\n \\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n \\n //end for vsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n \\n float numberOfSubLoops = floor(parameter0);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n \\n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\\n \\n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\\n \\n /////////////////////////\\n \\n float rotation = PI/3.*time*shapeId;\\n \\n if(finalVertexId0\\n else\\n if(vertexId0\\n else\\n if(vertexId0 && SYMMETRY_H >0\\n else\\n if(vertexId>8. #define parameter1 -0.2//KParameter1 -1.>>1. #define parameter2 -1.//KParameter2 -1.>>1. #define parameter3 0.//KParameter3 0.>>12. #define parameter4 2.//KParameter4 0.>>2. #define parameter5 1.//KParameter5 0.1>>1.5 #define parameter6 0.3//KParameter6 0.>>1. #define parameter7 0.//KParameter7 0.>>10. #define HPI 1.570796326795 #define PI 3.1415926535898 #define SYMMETRY_H 1 #define SYMMETRY_V 1 #define COLOR_MODE 1 vec3 rotZ(vec3 _v, float _rad) { vec2 f = sin(vec2(_rad, _rad + HPI)); vec3 r = _v; r.x = _v.x * f.x + _v.y * f.y; r.y = _v.x * -f.y + _v.y * f.x; return r; } mat4 uniformScale(float _s) { return mat4( _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, _s, 0, 0, 0, 0, 1); } vec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18]) { vec4 result = vec4(0., 0.,-1., 1.); float localVertexId = _vertexId - _startVertexId; if(localVertexId<1.) { result.xy = _letter[0].xy; } else if(localVertexId<2.) { result.xy = _letter[1].xy; } else if(localVertexId<3.) { result.xy = _letter[2].xy; } else //2nd triangle if(localVertexId<4.) { result.xy = _letter[3].xy; } else if(localVertexId<5.) { result.xy = _letter[4].xy; } else if(localVertexId<6.) { result.xy = _letter[5].xy; } else if(localVertexId<7.)//3 eme triangle { result.xy = _letter[6].xy; } else if(localVertexId<8.) { result.xy = _letter[7].xy; } else if(localVertexId<9.) { result.xy = _letter[8].xy; } else if(localVertexId<10.)//4eme triangle { result.xy = _letter[9].xy; } else if(localVertexId<11.) { result.xy = _letter[10].xy; } else if(localVertexId<12.) { result.xy = _letter[11].xy; } else if(localVertexId<13.) { result.xy = _letter[12].xy; } else if(localVertexId<14.) { result.xy = _letter[13].xy; } else if(localVertexId<15.) { result.xy = _letter[14].xy; } else if(localVertexId<16.) { result.xy = _letter[15].xy; } else if(localVertexId<17.) { result.xy = _letter[16].xy; } else if(localVertexId<18.) { result.xy = _letter[17].xy; } result.xy+=_pos; result.xy-=vec2(_barWidth*2.,0.5)+_pos; result.xyz =rotZ(result.xyz, _rotation); result.xy+=vec2(_barWidth*2.,0.5)+_pos; result *= uniformScale(_scale); return result.xyz; } vec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos) { vec2 finalPos = _pos; vec2 additionalPos = vec2(0.,0.); float transfoMode = floor(parameter3); //additionalPos.x = _relLetterTimeProgress*0.5; if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<2.) { additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6; finalPos+= additionalPos; } else if(transfoMode<3.) { additionalPos = -finalPos; additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI ); additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI ); finalPos+= additionalPos; } else if(transfoMode<4.) { additionalPos = -finalPos; vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) )); additionalPos.x+= m.x; additionalPos.y+= m.y; finalPos+= additionalPos; } else if(transfoMode<5.) { additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time)); finalPos+= additionalPos; } else if(transfoMode<6.) { additionalPos = -finalPos; additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5; additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));; finalPos+= additionalPos; } else if(transfoMode<7.) { if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) ); finalPos+= additionalPos; } } else if(transfoMode<8.) { additionalPos = -finalPos; if(_selectedShape == _shapeId) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<9.) { additionalPos = -finalPos; if(mod(_shapeId,2.)<1.) { additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) ); additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) ); } finalPos+= additionalPos; } else if(transfoMode<10.) { //if(_selectedShape == _shapeId) { vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. )); additionalPos.y = m.x*parameter6*2.; finalPos+= additionalPos; } } else if(transfoMode<11.) { additionalPos = -finalPos; additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time ); additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time); finalPos+= additionalPos; } return finalPos; } float getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation) { float finalRot = _rotation; float additionalRotation = 0.; float transfoMode = floor(parameter3); if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress; } } else if(transfoMode<1.) { if(_selectedShape == _shapeId) { additionalRotation = 2.*2.*PI*_relLetterTimeProgress; } } finalRot+= additionalRotation; /* float additionalRotation = 0.; if(selectedLetterIndex == shapeId) { additionalRotation = 2.*PI*relLetterTimeProgress; } rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId; */ return finalRot; } vec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth) { vec2 finalCenter = _center; /* vec2 additionalCenter = vec2(0.,0.); if(_selectedShape == _shapeId) { additionalCenter.x = _relLetterTimeProgress*0.5; additionalCenter.y = _relLetterTimeProgress*0.5; } finalCenter+= additionalCenter; */ return finalCenter; } #define elementPerShapeLetterK 18. #define defaultRotationForShapeLetterK 0.13 #define defaultRotationForShapeLetterM - 0.09 #define defaultRotationForShapeLetterN 0.04 #define defaultRotationForShapeLetterA 0.1 #define defaultRotationForShapeLetterC - 0.05 #define defaultRotationForShapeLetterE - 0.03 #define defaultRotationForShapeLetterH 0.04 #define defaultRotationForShapeLetterI - 0.02 #define shapeNumber 8. #define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber void main() { vec3 color = vec3(1.); float sndFactor = texture2D(sound, vec2(0.01, 0.)).r; float _junctionY = 0.5 +parameter4*sndFactor/10.; float _barWidth = 0.2 ;// + parameter4*sndFactor/100.; float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.; float shapeId = 0.; vec2 letterK[18]; letterK[0] = vec2(0.,0.); letterK[1] = vec2(0.,1.); letterK[2] = vec2(_barWidth,1.); letterK[3] = vec2(0.,0.0); letterK[4] = vec2(_barWidth,1.); letterK[5] = vec2(_barWidth,0.); letterK[6] = vec2(_barWidth,_junctionY); letterK[7] = vec2((_secondVertY+_barWidth),1.); letterK[8] = vec2(_secondVertY,1.); letterK[9] = vec2(_barWidth,_junctionY); letterK[10] = vec2((_secondVertY+_barWidth),0.); letterK[11] = vec2(_secondVertY,0.); letterK[12] = vec2(_secondVertY,0.); letterK[13] = vec2(_secondVertY,0.); letterK[14] = vec2(_secondVertY,0.); letterK[15] = vec2(_secondVertY,0.); letterK[16] = vec2(_secondVertY,0.); letterK[17] = vec2(_secondVertY,0.); vec2 letterM[18]; letterM[0] = vec2(0.,0.); letterM[1] = vec2(0.,1.); letterM[2] = vec2(_barWidth,1.); letterM[3] = vec2(0.,0.0); letterM[4] = vec2(_barWidth,1.); letterM[5] = vec2(_barWidth,0.);//PROBLEM !! letterM[6] = vec2(_barWidth,_junctionY+_barWidth); letterM[7] = vec2(_barWidth,1.); letterM[8] = vec2(_barWidth*2.,_junctionY); letterM[9] = vec2(_barWidth*2.,_junctionY); letterM[10] = vec2((_barWidth*3.),1.); letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth); letterM[12] = vec2(_barWidth*3.,1.); letterM[13] = vec2(_barWidth*4.,1.); letterM[14] = vec2(_barWidth*3.,0.); letterM[15] = vec2(_barWidth*3.,0.); letterM[16] = vec2(_barWidth*4.,1.); letterM[17] = vec2(_barWidth*4.,0.); vec2 letterN[18]; letterN[0] = vec2(0.,0.); letterN[1] = vec2(0.,1.); letterN[2] = vec2(_barWidth,1.); letterN[3] = vec2(0.,0.0); letterN[4] = vec2(_barWidth,1.); letterN[5] = vec2(_barWidth,0.); letterN[6] = vec2(_barWidth,_junctionY+_barWidth); letterN[7] = vec2(_barWidth,1.); letterN[8] = vec2(_barWidth*2.,_junctionY); letterN[9] = vec2(_barWidth*2.,1.); letterN[10] = vec2(_barWidth*3.,1.); letterN[11] = vec2(_barWidth*2.,0.); letterN[12] = vec2(_barWidth*2.,0.); letterN[13] = vec2(_barWidth*3.,1.); letterN[14] = vec2(_barWidth*3.,0.); letterN[15] = vec2(_barWidth*3.,0.); letterN[16] = vec2(_barWidth*3.,0.); letterN[17] = vec2(_barWidth*3.,0.); vec2 letterA[18]; letterA[0] = vec2(0.,0.); letterA[1] = vec2(_barWidth,0.); letterA[2] = vec2(_barWidth*2.,1.); letterA[3] = vec2(_barWidth*4.,0.0); letterA[4] = vec2(_barWidth*2.,1.); letterA[5] = vec2(_barWidth*3.,0.); letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.); letterA[8] = vec2(_barWidth*3.,_junctionY); letterA[9] = vec2(_barWidth*3.,_junctionY); letterA[10] = vec2(_barWidth*3.,_junctionY); letterA[11] = vec2(_barWidth*3.,_junctionY); letterA[12] = vec2(_barWidth*3.,_junctionY); letterA[13] = vec2(_barWidth*3.,_junctionY); letterA[14] = vec2(_barWidth*3.,_junctionY); letterA[15] = vec2(_barWidth*3.,_junctionY); letterA[16] = vec2(_barWidth*3.,_junctionY); letterA[17] = vec2(_barWidth*3.,_junctionY); vec2 letterE[18]; letterE[0] = vec2(0.,0.); letterE[1] = vec2(0.,1.); letterE[2] = vec2(_barWidth,1.); letterE[3] = vec2(0.,0.0); letterE[4] = vec2(_barWidth,1.); letterE[5] = vec2(_barWidth,0.); letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5); letterE[7] = vec2(_barWidth,1.); letterE[8] = vec2(_barWidth*3.,1.); letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5); letterE[10] = vec2(_barWidth,0.); letterE[11] = vec2(_barWidth*3.,0.); letterE[12] = vec2(_barWidth,_junctionY); letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.); letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.); vec2 letterC[18]; letterC[0] = vec2(0.,0.); letterC[1] = vec2(0.,1.); letterC[2] = vec2(_barWidth,1.); letterC[3] = vec2(0.,0.0); letterC[4] = vec2(_barWidth,1.); letterC[5] = vec2(_barWidth,0.); letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5); letterC[7] = vec2(_barWidth,1.); letterC[8] = vec2(_barWidth*3.,1.); letterC[9] = vec2(_barWidth,0.); letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5); letterC[11] = vec2(_barWidth*3.,0.); letterC[12] = vec2(_barWidth*3.,0.); letterC[13] = vec2(_barWidth*3.,0.); letterC[14] = vec2(_barWidth*3.,0.); letterC[15] = vec2(_barWidth*3.,0.); letterC[16] = vec2(_barWidth*3.,0.); letterC[17] = vec2(_barWidth*3.,0.); vec2 letterH[18]; letterH[0] = vec2(0.,0.); letterH[1] = vec2(0.,1.); letterH[2] = vec2(_barWidth,1.); letterH[3] = vec2(0.,0.0); letterH[4] = vec2(_barWidth,1.); letterH[5] = vec2(_barWidth,0.); letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.); letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.); letterH[8] = vec2(_barWidth*2.,_junctionY); letterH[9] = vec2(_barWidth*2.,_junctionY); letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.); letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.); letterH[12] = vec2(_barWidth*3.,1.); letterH[13] = vec2(_barWidth*4.,1.); letterH[14] = vec2(_barWidth*3.,0.); letterH[15] = vec2(_barWidth*3.,0.); letterH[16] = vec2(_barWidth*4.,1.); letterH[17] = vec2(_barWidth*4.,0.); vec2 letterI[18]; letterI[0] = vec2(0.,0.); letterI[1] = vec2(0.,_junctionY+_barWidth); letterI[2] = vec2(_barWidth,_junctionY+_barWidth); letterI[3] = vec2(0.,0.0); letterI[4] = vec2(_barWidth,_junctionY+_barWidth); letterI[5] = vec2(_barWidth,0.);//PROBLEM !! letterI[6] = vec2(0.,1.-_barWidth); letterI[7] = vec2(0.,1.); letterI[8] = vec2(_barWidth,1.-_barWidth); letterI[9] = vec2(_barWidth,1.-_barWidth); letterI[10] = vec2(0.,1.); letterI[11] = vec2(_barWidth,1.); letterI[12] = vec2(_barWidth,1.); letterI[13] = vec2(_barWidth,1.); letterI[14] = vec2(_barWidth,1.); letterI[15] = vec2(_barWidth,1.); letterI[16] = vec2(_barWidth,1.); letterI[17] = vec2(_barWidth,1.); float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord)); float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;// float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId); //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord); finalVertexId = min(maxNumberOfVertices,vertexId); finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord)); //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord); //float relMetaShapeId = metaShapeId/256.; float masterScale = parameter5;//parameter6; vec3 _v = vec3(0.,0.,0.); vec2 letterPos = vec2(0.,0.); float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.; float scaleK = 0.4*masterScale; float scale = 0.2*masterScale; float startPosK = parameter2; float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters); vec2 shapeCenter = vec2(0.,0.5); //for vsa float loopDurationMs = 4000.; float timeProgress = mod(time*1000.,loopDurationMs); float relLoopProgress = timeProgress/loopDurationMs; //end for vsa float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor)); float numberOfSubLoops = floor(parameter0); float subLoopLength = 1./numberOfSubLoops; finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength; float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber)); float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber); float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress); ///////////////////////// float rotation = PI/3.*time*shapeId; if(finalVertexId0 else if(vertexId0 else if(vertexId0 && SYMMETRY_H >0 else if(vertexId>8.\n#define parameter1 -0.2//KParameter1 -1.>>1.\n#define parameter2 -1.//KParameter2 -1.>>1.\n#define parameter3 0.//KParameter3 0.>>12.\n#define parameter4 2.//KParameter4 0.>>2.\n#define parameter5 1.//KParameter5 0.1>>1.5\n#define parameter6 0.3//KParameter6 0.>>1.\n#define parameter7 0.//KParameter7 0.>>10.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n#define SYMMETRY_H 1\n#define SYMMETRY_V 1\n#define COLOR_MODE 1\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\n{\n \n \n \n \n vec4 result = vec4(0., 0.,-1., 1.);\n \n \n float localVertexId = _vertexId - _startVertexId;\n \n if(localVertexId<1.)\n {\n result.xy = _letter[0].xy;\n }\n else\n \n if(localVertexId<2.)\n {\n result.xy = _letter[1].xy;\n }\n \n else\n if(localVertexId<3.)\n {\n result.xy = _letter[2].xy;\n }\n else //2nd triangle\n if(localVertexId<4.)\n {\n result.xy = _letter[3].xy;\n }\n else\n if(localVertexId<5.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<6.)\n {\n result.xy = _letter[5].xy;\n }\n else\n if(localVertexId<7.)//3 eme triangle\n {\n result.xy = _letter[6].xy;\n }\n else\n if(localVertexId<8.)\n {\n result.xy = _letter[7].xy;\n }\n else\n if(localVertexId<9.)\n {\n result.xy = _letter[8].xy;\n \n }\n \n else\n if(localVertexId<10.)//4eme triangle\n {\n result.xy = _letter[9].xy;\n \n }\n else\n if(localVertexId<11.)\n {\n result.xy = _letter[10].xy;\n \n }\n \n else\n if(localVertexId<12.)\n {\n result.xy = _letter[11].xy;\n \n }\n else\n if(localVertexId<13.)\n {\n result.xy = _letter[12].xy;\n \n }\n else\n if(localVertexId<14.)\n {\n result.xy = _letter[13].xy;\n \n }\n else\n if(localVertexId<15.)\n {\n result.xy = _letter[14].xy;\n \n }\n else\n if(localVertexId<16.)\n {\n result.xy = _letter[15].xy;\n \n }\n else\n if(localVertexId<17.)\n {\n result.xy = _letter[16].xy;\n \n }\n else\n if(localVertexId<18.)\n {\n result.xy = _letter[17].xy;\n \n }\n result.xy+=_pos;\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\n result.xyz =rotZ(result.xyz, _rotation);\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\n result *= uniformScale(_scale);\n \n \n return result.xyz;\n}\n\n\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\n{\n vec2 finalPos = _pos;\n \n \n vec2 additionalPos = vec2(0.,0.);\n \n float transfoMode = floor(parameter3);\n \n \n //additionalPos.x = _relLetterTimeProgress*0.5;\n if(transfoMode<1.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n else\n if(transfoMode<2.)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<3.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<4.)\n {\n additionalPos = -finalPos;\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\n \n additionalPos.x+= m.x;\n additionalPos.y+= m.y;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<5.)\n {\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<6.)\n {\n additionalPos = -finalPos;\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<7.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n finalPos+= additionalPos;\n }\n \n }\n else\n if(transfoMode<8.)\n {\n additionalPos = -finalPos;\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<9.)\n {\n additionalPos = -finalPos;\n \n if(mod(_shapeId,2.)<1.)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n \n if(transfoMode<10.)\n {\n //if(_selectedShape == _shapeId)\n {\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\n additionalPos.y = m.x*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n \n else\n \n if(transfoMode<11.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\n finalPos+= additionalPos;\n }\n \n return finalPos;\n}\n\n\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\n{\n float finalRot = _rotation;\n \n float additionalRotation = 0.;\n \n float transfoMode = floor(parameter3);\n \n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\n \n }\n }\n else\n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\n \n }\n }\n \n \n finalRot+= additionalRotation;\n \n /*\n float additionalRotation = 0.;\n \n if(selectedLetterIndex == shapeId)\n {\n additionalRotation = 2.*PI*relLetterTimeProgress;\n }\n \n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\n */\n \n return finalRot;\n}\n\n\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\n{\n vec2 finalCenter = _center;\n \n \n /*\n vec2 additionalCenter = vec2(0.,0.);\n \n \n if(_selectedShape == _shapeId)\n {\n additionalCenter.x = _relLetterTimeProgress*0.5;\n additionalCenter.y = _relLetterTimeProgress*0.5;\n }\n \n finalCenter+= additionalCenter;\n */\n \n return finalCenter;\n}\n\n#define elementPerShapeLetterK 18.\n\n#define defaultRotationForShapeLetterK 0.13\n#define defaultRotationForShapeLetterM - 0.09\n#define defaultRotationForShapeLetterN 0.04\n#define defaultRotationForShapeLetterA 0.06\n#define defaultRotationForShapeLetterC - 0.7\n#define defaultRotationForShapeLetterE - 0.03\n#define defaultRotationForShapeLetterH 0.04\n#define defaultRotationForShapeLetterI - 0.3\n\n\n#define shapeNumber 8.\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\n\nvoid main() {\n \n \n vec3 color = vec3(1.);\n \n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\n float _junctionY = 0.5 +parameter4*sndFactor/10.;\n \n float _barWidth = 0.2 ;// + parameter4*sndFactor/100.;\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\n \n float shapeId = 0.;\n \n vec2 letterK[18];\n letterK[0] = vec2(0.,0.);\n letterK[1] = vec2(0.,1.);\n letterK[2] = vec2(_barWidth,1.);\n letterK[3] = vec2(0.,0.0);\n letterK[4] = vec2(_barWidth,1.);\n letterK[5] = vec2(_barWidth,0.);\n letterK[6] = vec2(_barWidth,_junctionY);\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\n letterK[8] = vec2(_secondVertY,1.);\n letterK[9] = vec2(_barWidth,_junctionY);\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\n letterK[11] = vec2(_secondVertY,0.);\n letterK[12] = vec2(_secondVertY,0.);\n letterK[13] = vec2(_secondVertY,0.);\n letterK[14] = vec2(_secondVertY,0.);\n letterK[15] = vec2(_secondVertY,0.);\n letterK[16] = vec2(_secondVertY,0.);\n letterK[17] = vec2(_secondVertY,0.);\n \n vec2 letterM[18];\n letterM[0] = vec2(0.,0.);\n letterM[1] = vec2(0.,1.);\n letterM[2] = vec2(_barWidth,1.);\n letterM[3] = vec2(0.,0.0);\n letterM[4] = vec2(_barWidth,1.);\n letterM[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterM[7] = vec2(_barWidth,1.);\n letterM[8] = vec2(_barWidth*2.,_junctionY);\n letterM[9] = vec2(_barWidth*2.,_junctionY);\n letterM[10] = vec2((_barWidth*3.),1.);\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\n letterM[12] = vec2(_barWidth*3.,1.);\n letterM[13] = vec2(_barWidth*4.,1.);\n letterM[14] = vec2(_barWidth*3.,0.);\n letterM[15] = vec2(_barWidth*3.,0.);\n letterM[16] = vec2(_barWidth*4.,1.);\n letterM[17] = vec2(_barWidth*4.,0.);\n \n \n vec2 letterN[18];\n letterN[0] = vec2(0.,0.);\n letterN[1] = vec2(0.,1.);\n letterN[2] = vec2(_barWidth,1.);\n letterN[3] = vec2(0.,0.0);\n letterN[4] = vec2(_barWidth,1.);\n letterN[5] = vec2(_barWidth,0.);\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterN[7] = vec2(_barWidth,1.);\n letterN[8] = vec2(_barWidth*2.,_junctionY);\n letterN[9] = vec2(_barWidth*2.,1.);\n letterN[10] = vec2(_barWidth*3.,1.);\n letterN[11] = vec2(_barWidth*2.,0.);\n \n letterN[12] = vec2(_barWidth*2.,0.);\n letterN[13] = vec2(_barWidth*3.,1.);\n letterN[14] = vec2(_barWidth*3.,0.);\n letterN[15] = vec2(_barWidth*3.,0.);\n \n letterN[16] = vec2(_barWidth*3.,0.);\n letterN[17] = vec2(_barWidth*5.,1.);\n \n \n vec2 letterA[18];\n letterA[0] = vec2(0.,0.);\n letterA[1] = vec2(_barWidth,0.);\n letterA[2] = vec2(_barWidth*2.,1.);\n letterA[3] = vec2(_barWidth*4.,0.0);\n letterA[4] = vec2(_barWidth*2.,1.);\n letterA[5] = vec2(_barWidth*3.,0.);\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\n letterA[8] = vec2(_barWidth*3.,_junctionY);\n letterA[9] = vec2(_barWidth*3.,_junctionY);\n letterA[10] = vec2(_barWidth*3.,_junctionY);\n letterA[11] = vec2(_barWidth*3.,_junctionY);\n \n letterA[12] = vec2(_barWidth*3.,_junctionY);\n letterA[13] = vec2(_barWidth*3.,_junctionY);\n letterA[14] = vec2(_barWidth*3.,_junctionY);\n letterA[15] = vec2(_barWidth*3.,_junctionY);\n \n letterA[16] = vec2(_barWidth*3.,_junctionY);\n letterA[17] = vec2(_barWidth*3.,_junctionY);\n \n \n vec2 letterE[18];\n letterE[0] = vec2(0.,0.);\n letterE[1] = vec2(0.,1.);\n letterE[2] = vec2(_barWidth,1.);\n letterE[3] = vec2(0.,0.0);\n letterE[4] = vec2(_barWidth,1.);\n letterE[5] = vec2(_barWidth,0.);\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\n letterE[7] = vec2(_barWidth,1.);\n letterE[8] = vec2(_barWidth*3.,1.);\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\n letterE[10] = vec2(_barWidth,0.);\n letterE[11] = vec2(_barWidth*3.,0.);\n letterE[12] = vec2(_barWidth,_junctionY);\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n \n \n vec2 letterC[18];\n letterC[0] = vec2(0.,0.);\n letterC[1] = vec2(0.,1.);\n letterC[2] = vec2(_barWidth,1.);\n letterC[3] = vec2(0.,0.0);\n letterC[4] = vec2(_barWidth,1.);\n letterC[5] = vec2(_barWidth,0.);\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\n letterC[7] = vec2(_barWidth,1.);\n letterC[8] = vec2(_barWidth*3.,1.);\n letterC[9] = vec2(_barWidth,0.);\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\n letterC[11] = vec2(_barWidth*3.,0.);\n letterC[12] = vec2(_barWidth*3.,0.);\n letterC[13] = vec2(_barWidth*3.,0.);\n letterC[14] = vec2(_barWidth*3.,0.);\n letterC[15] = vec2(_barWidth*3.,0.);\n letterC[16] = vec2(_barWidth*3.,0.);\n letterC[17] = vec2(_barWidth*3.,0.);\n \n vec2 letterH[18];\n letterH[0] = vec2(0.,0.);\n letterH[1] = vec2(0.,1.);\n letterH[2] = vec2(_barWidth,1.);\n letterH[3] = vec2(0.,0.0);\n letterH[4] = vec2(_barWidth,1.);\n letterH[5] = vec2(_barWidth,0.);\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\n letterH[8] = vec2(_barWidth*2.,_junctionY);\n letterH[9] = vec2(_barWidth*2.,_junctionY);\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\n letterH[12] = vec2(_barWidth*3.,1.);\n letterH[13] = vec2(_barWidth*4.,1.);\n letterH[14] = vec2(_barWidth*3.,0.);\n letterH[15] = vec2(_barWidth*3.,0.);\n letterH[16] = vec2(_barWidth*4.,1.);\n letterH[17] = vec2(_barWidth*4.,0.);\n \n vec2 letterI[18];\n letterI[0] = vec2(0.,0.);\n letterI[1] = vec2(0.,_junctionY+_barWidth);\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[3] = vec2(0.,0.0);\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterI[6] = vec2(0.,1.-_barWidth);\n letterI[7] = vec2(0.,1.);\n letterI[8] = vec2(_barWidth,1.-_barWidth);\n letterI[9] = vec2(_barWidth,1.-_barWidth);\n letterI[10] = vec2(0.,1.);\n letterI[11] = vec2(_barWidth,1.);\n letterI[12] = vec2(_barWidth,1.);\n letterI[13] = vec2(_barWidth,1.);\n letterI[14] = vec2(_barWidth,1.);\n letterI[15] = vec2(_barWidth,1.);\n letterI[16] = vec2(_barWidth,1.);\n letterI[17] = vec2(_barWidth,1.);\n \n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\n \n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\n \n finalVertexId = min(maxNumberOfVertices,vertexId);\n \n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\n \n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\n //float relMetaShapeId = metaShapeId/256.;\n \n float masterScale = parameter5;//parameter6;\n \n vec3 _v = vec3(0.,0.,0.);\n \n vec2 letterPos = vec2(0.,0.);\n \n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\n \n float scaleK = 0.4*masterScale;\n float scale = 0.2*masterScale;\n float startPosK = parameter2;\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\n \n vec2 shapeCenter = vec2(0.,0.5);\n \n //for vsa\n \n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n \n //end for vsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n \n float numberOfSubLoops = floor(parameter0);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n \n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\n \n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\n \n /////////////////////////\n \n float rotation = PI/3.*time*shapeId;\n \n if(finalVertexId0\n else\n if(vertexId0\n else\n if(vertexId0 && SYMMETRY_H >0\n else\n if(vertexId 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\nvec3 GetSunPosition()\\n{\\n \\tfloat fSunDistance = 14000.0;\\n \\treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\\n}\\nvec3 GetSunDir( vec3 vCameraPos )\\n{\\n \\treturn normalize( GetSunPosition() - vCameraPos );\\n}\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, DirLight,\\n sv) ; \\n vertexIndex -= floorVertexCount ; \\n #pragma endregion \\n \\n #pragma region Sphere\\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo,\\n DirLight, \\n camPos,\\n sv);\\n m *= uniformScale(1.5);\\n m *= trans(vec3(0. , 4. , 0. )) ; \\n }\\n vertexIndex -= fSphereVertexCount ; \\n #pragma endregion \\n#pragma endregion \\n \\n \\n#pragma region PostEffect\\n // PE_Vignette(sv) ;\\n#pragma endregion \\n \\n#pragma region ApplySetting\\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n#pragma endregion \\n}\"}", + "settings": { + "num": 24579, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.403921568627451, + 0.403921568627451, + 0.403921568627451, + 1 + ], + "shader": "\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 0.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t \n vec3 vOrigin;\n float fRadius ; \n \n float fSlices ; \n float fSegments ; \n }; \n \n struct Material \n {\n vec4 diffuseAlebdo;\n vec3 FresenlR0 ;\n float Roughness ;\n mat4 MatTransform ; \n }; \n struct Light\n {\n\n vec3 vStrength ; \n float FalloffStart ; \n vec3 vDirection ; \n float FalloffEnd ; \n vec3 vPosition ; \n float SpotPower ; \n };\n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\nvec3 GetSunPosition()\n{\n \tfloat fSunDistance = 14000.0;\n \treturn vec3( 0.0, 0.1, 1.0 ) * fSunDistance;\n}\nvec3 GetSunDir( vec3 vCameraPos )\n{\n \treturn normalize( GetSunPosition() - vCameraPos );\n}\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, DirLight,\n sv) ; \n vertexIndex -= floorVertexCount ; \n #pragma endregion \n \n #pragma region Sphere\n float fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo,\n DirLight, \n camPos,\n sv);\n m *= uniformScale(1.5);\n m *= trans(vec3(0. , 4. , 0. )) ; \n }\n vertexIndex -= fSphereVertexCount ; \n #pragma endregion \n#pragma endregion \n \n \n#pragma region PostEffect\n // PE_Vignette(sv) ;\n#pragma endregion \n \n#pragma region ApplySetting\n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n#pragma endregion \n}" + }, "screenshotURL": "data/images/images-we13h662eoncnka3l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nmasbtKEtxwPRbcSm/art.json b/art/nmasbtKEtxwPRbcSm/art.json index a7895ccd..a14234db 100644 --- a/art/nmasbtKEtxwPRbcSm/art.json +++ b/art/nmasbtKEtxwPRbcSm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=40000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 3.//KParameter0 1.>>5.\\n#define parameter1 1.1//KParameter1 0.>>1.\\n#define parameter2 0.1//KParameter2 0.>>1.\\n#define parameter3 0.5//KParameter3 0.>>0.5\\n#define parameter4 0.//KParameter4 0.>>1.\\n#define parameter5 0.//KParameter5 0.>>1.\\n#define parameter6 0.//KParameter6 0.>>1.\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvoid main() {\\n \\n float symCount = parameter0;\\n float shapeVertexCount = vertexCount/symCount;\\n \\n float fVertexId = mod(vertexId,shapeVertexCount);\\n \\n float point = mod(floor(fVertexId / 2.0) + mod(fVertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(fVertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.05, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n \\n float shapeId = floor(vertexId/shapeVertexCount);\\n vec4 pos = vec4(xy, 0, 1);\\n mat4 rotz = rotZ(shapeId*2.*PI/symCount);\\n pos*=rotz;\\n pos.x += (shapeId/2.);\\n pos.xy *= aspect;\\n gl_Position = pos;\\n\\n gl_PointSize = 5.;\\n \\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(0, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=40000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 3.//KParameter0 1.>>5.\n#define parameter1 1.1//KParameter1 0.>>1.\n#define parameter2 0.1//KParameter2 0.>>1.\n#define parameter3 0.5//KParameter3 0.>>0.5\n#define parameter4 0.//KParameter4 0.>>1.\n#define parameter5 0.//KParameter5 0.>>1.\n#define parameter6 0.//KParameter6 0.>>1.\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nvoid main() {\n \n float symCount = parameter0;\n float shapeVertexCount = vertexCount/symCount;\n \n float fVertexId = mod(vertexId,shapeVertexCount);\n \n float point = mod(floor(fVertexId / 2.0) + mod(fVertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(fVertexId / NUM_POINTS);\n float offset = count * sin(time * 0.001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.05, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \n vec2 xy = vec2(\n oC + c,\n oS + s);\n \n float shapeId = floor(vertexId/shapeVertexCount);\n vec4 pos = vec4(xy, 0, 1);\n mat4 rotz = rotZ(shapeId*2.*PI/symCount);\n pos*=rotz;\n pos.x += (shapeId/2.);\n pos.xy *= aspect;\n gl_Position = pos;\n\n gl_PointSize = 5.;\n \n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(0, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-tor3tijoqrnht1b0b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/noguJmpMuwNJdw6Nc/art.json b/art/noguJmpMuwNJdw6Nc/art.json index 00e2cca2..d61e2396 100644 --- a/art/noguJmpMuwNJdw6Nc/art.json +++ b/art/noguJmpMuwNJdw6Nc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chris-camplin/in-my-mind\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 80;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.5 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chris-camplin/in-my-mind", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 0.09 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 80;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.5 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(abs(p.z), 1.4);\n}\n" + }, "screenshotURL": "data/images/images-4jmn9p3in3joublzy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/norTBstC9KdiXjzoH/art.json b/art/norTBstC9KdiXjzoH/art.json index d6f12eea..bedc79b6 100644 --- a/art/norTBstC9KdiXjzoH/art.json +++ b/art/norTBstC9KdiXjzoH/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "ayrton", "avatarUrl": "https://lh3.googleusercontent.com/-kJnxzWp-q0E/AAAAAAAAAAI/AAAAAAAABhA/oo6N_UGj_Yg/photo.jpg", - "settings": "{\"num\":80946,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/fpdotrem/dona-maria-ontem-eu-transei-com-sua-filha-2018-150-bpm\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 24.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float circlesPerRow = 33.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow) * 2.;\\n float cy = floor(circleId / circlesPerRow) * 2.;\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n float sx = cx - circlesPerRow;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx, cy, 0, 0);\\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\\n \\n // scale\\n gl_Position *= scale(1. / 16.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r - 0.2, 1, 1, 0);\\n}\"}", + "settings": { + "num": 80946, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/fpdotrem/dona-maria-ontem-eu-transei-com-sua-filha-2018-150-bpm", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 24.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float circlesPerRow = 33.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow) * 2.;\n float cy = floor(circleId / circlesPerRow) * 2.;\n \n vec2 soundTexCoords = vec2(0, 0);\n float sx = cx - circlesPerRow;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx, cy, 0, 0);\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\n \n // scale\n gl_Position *= scale(1. / 16.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r - 0.2, 1, 1, 0);\n}" + }, "screenshotURL": "data/images/images-aipfix3jd5kt5kkiv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nqMDDwykATsSM2ABy/art.json b/art/nqMDDwykATsSM2ABy/art.json index 4b0a93ab..4e871c00 100644 --- a/art/nqMDDwykATsSM2ABy/art.json +++ b/art/nqMDDwykATsSM2ABy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"mic\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define NUM_SEGMENTS 128.00\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV * 0.5)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = invV;// * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 1.0) * 1.0) ;\\n float a = (u * 2. - 1.) * PI + time * 0.1;// * invV * PI;//u * PI * .2 + time * 0. + v * 0. + snd;\\n float c = cos(a);\\n float s = sin(a);\\n mat2 mat = mat2(c, s, -s, c);\\n gl_Position = vec4(mat * (xy * 0.5), v, 1);\\n\\n float s2 = 1. - pow(1. - snd, 5.);\\n float hue = sin(u * PI * 2.) * .0 + time * 0.;\\n float sat = s2;\\n float val = s2;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, 0.);\\n v_color.a = s2;\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "mic", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.00\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV * 0.5)).a;\n\n float x = u * 2.0 - 1.0;\n float y = invV;// * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 1.0) * 1.0) ;\n float a = (u * 2. - 1.) * PI + time * 0.1;// * invV * PI;//u * PI * .2 + time * 0. + v * 0. + snd;\n float c = cos(a);\n float s = sin(a);\n mat2 mat = mat2(c, s, -s, c);\n gl_Position = vec4(mat * (xy * 0.5), v, 1);\n\n float s2 = 1. - pow(1. - snd, 5.);\n float hue = sin(u * PI * 2.) * .0 + time * 0.;\n float sat = s2;\n float val = s2;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, 0.);\n v_color.a = s2;\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-m2f6e9q8i6a2amt1k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nr3EiyXWLMpwoouHt/art.json b/art/nr3EiyXWLMpwoouHt/art.json index 30661e06..767f60b8 100644 --- a/art/nr3EiyXWLMpwoouHt/art.json +++ b/art/nr3EiyXWLMpwoouHt/art.json @@ -21,7 +21,19 @@ "origId": "QH3gSYw84QKSqtGr2", "name": "lazer", "username": "gman", - "settings": "{\"num\":1400,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/enditmanagement/option4-deep-diamonds\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.01568627450980392,0.11372549019607843,1],\"shader\":\"/*\\n\\n ^\\n /|\\\\\\n |\\n +-- click hide then ...\\n\\n __ .__ \\n _____ _______ __ ____ _/ |_| |__ ____ _____ ____ __ __ ______ ____ \\n / \\\\ / _ \\\\ \\\\/ // __ \\\\ \\\\ __\\\\ | \\\\_/ __ \\\\ / \\\\ / _ \\\\| | \\\\/ ___// __ \\\\ \\n| Y Y ( <_> ) /\\\\ ___/ | | | Y \\\\ ___/ | Y Y ( <_> ) | /\\\\___ \\\\\\\\ ___/ \\n|__|_| /\\\\____/ \\\\_/ \\\\___ > |__| |___| /\\\\___ > |__|_| /\\\\____/|____//____ >\\\\___ >\\n \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\\\/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n#define NUM_SEGMENTS 2.\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float snd = texture2D(sound, vec2(0.1, 0.0)).a;\\n float localTime = time * 0.01 + snd * 0.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS + snd);\\n float count = floor(vertexId / NUM_POINTS + snd);\\n float offset = count * sin(localTime * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.0025, 0.8);\\n float innerRadius = pow(count * 0.00005, 1.2);\\n float oC = cos(orbitAngle + count * 0.00001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.00001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec4 m = texture2D(touch, vec2(0., count / 1400.));\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + m.xy * 1.4, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n float hue = snd;\\n float sat = 1.0 - fract(count * 0.01);\\n float val = snd * 2.0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1400, + "mode": "LINES", + "sound": "https://soundcloud.com/enditmanagement/option4-deep-diamonds", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.01568627450980392, + 0.11372549019607843, + 1 + ], + "shader": "/*\n\n ^\n /|\\\n |\n +-- click hide then ...\n\n __ .__ \n _____ _______ __ ____ _/ |_| |__ ____ _____ ____ __ __ ______ ____ \n / \\ / _ \\ \\/ // __ \\ \\ __\\ | \\_/ __ \\ / \\ / _ \\| | \\/ ___// __ \\ \n| Y Y ( <_> ) /\\ ___/ | | | Y \\ ___/ | Y Y ( <_> ) | /\\___ \\\\ ___/ \n|__|_| /\\____/ \\_/ \\___ > |__| |___| /\\___ > |__|_| /\\____/|____//____ >\\___ >\n \\/ \\/ \\/ \\/ \\/ \\/ \\/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n#define NUM_SEGMENTS 2.\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float snd = texture2D(sound, vec2(0.1, 0.0)).a;\n float localTime = time * 0.01 + snd * 0.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS + snd);\n float count = floor(vertexId / NUM_POINTS + snd);\n float offset = count * sin(localTime * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.0025, 0.8);\n float innerRadius = pow(count * 0.00005, 1.2);\n float oC = cos(orbitAngle + count * 0.00001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.00001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec4 m = texture2D(touch, vec2(0., count / 1400.));\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + m.xy * 1.4, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n float hue = snd;\n float sat = 1.0 - fract(count * 0.01);\n float val = snd * 2.0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotDataId": "d87Kz3HWKtJi4mZQP", "views": { "$numberInt": "842" diff --git a/art/nrAECwQ8yDDyTrSit/art.json b/art/nrAECwQ8yDDyTrSit/art.json index 4709ac0c..ad6fa254 100644 --- a/art/nrAECwQ8yDDyTrSit/art.json +++ b/art/nrAECwQ8yDDyTrSit/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":7600,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nightclubband/show-it-2-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.23137254901960785,0.23137254901960785,0.23137254901960785,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() { \\n float units = 40.0;\\n float perSet = units * 6.0;\\n float numSets = floor(vertexCount / perSet);\\n \\n float id = mod(vertexId, perSet);\\n float setId = floor(vertexId / perSet);\\n \\n float vId = mod(vertexId, perSet);\\n float ux = floor(vId / 6.) + mod(vId, 2.) * 2.;\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.) * 2. - 1.; \\n \\n float u = ux / (units + 1.);\\n \\n float sv = setId / (numSets - 1.);\\n \\n float s0 = texture2D(sound, vec2(mix(.05, .2, abs(sv * 2. - 1.)), u * .1)).a;\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(0, 0, 50);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n vec3 pos = vec3(ux, vy, u);\\n mat *= cameraLookAt(eye, target, up);\\n //mat *= trans(vec3(units * .5, 0, 0));\\n mat *= rotZ(PI * .5 +\\n sin(time * .3) * .5 +\\n time * sign(setId - numSets / 2.) + \\n sv * PI * 2. + \\n sin(time + u * 6. * sin(time * 0.2)) * u * 1.1 * sign(setId - numSets / 2.));\\n mat *= trans(vec3(0., 0, 0));\\n mat *= scale(vec3(1, (1. - pow(u, 15.)) * mix(0., 5., pow(clamp(s0 + .3, 0., 1.), 15.)), 1));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.0;\\n float hue = u * .1;\\n float sat = 1.;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = mix(vec4(0,0,0,1), vec4(color, 1), mod(setId, 2.));\\n //v_color.a = s0;\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 7600, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nightclubband/show-it-2-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.23137254901960785, + 0.23137254901960785, + 0.23137254901960785, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() { \n float units = 40.0;\n float perSet = units * 6.0;\n float numSets = floor(vertexCount / perSet);\n \n float id = mod(vertexId, perSet);\n float setId = floor(vertexId / perSet);\n \n float vId = mod(vertexId, perSet);\n float ux = floor(vId / 6.) + mod(vId, 2.) * 2.;\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.) * 2. - 1.; \n \n float u = ux / (units + 1.);\n \n float sv = setId / (numSets - 1.);\n \n float s0 = texture2D(sound, vec2(mix(.05, .2, abs(sv * 2. - 1.)), u * .1)).a;\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(0, 0, 50);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n vec3 pos = vec3(ux, vy, u);\n mat *= cameraLookAt(eye, target, up);\n //mat *= trans(vec3(units * .5, 0, 0));\n mat *= rotZ(PI * .5 +\n sin(time * .3) * .5 +\n time * sign(setId - numSets / 2.) + \n sv * PI * 2. + \n sin(time + u * 6. * sin(time * 0.2)) * u * 1.1 * sign(setId - numSets / 2.));\n mat *= trans(vec3(0., 0, 0));\n mat *= scale(vec3(1, (1. - pow(u, 15.)) * mix(0., 5., pow(clamp(s0 + .3, 0., 1.), 15.)), 1));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.0;\n float hue = u * .1;\n float sat = 1.;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = mix(vec4(0,0,0,1), vec4(color, 1), mod(setId, 2.));\n //v_color.a = s0;\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-vulr2yputsk3y1y16-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nrNx2zLxLnq4oDubh/art.json b/art/nrNx2zLxLnq4oDubh/art.json index e5b7840a..848f96f8 100644 --- a/art/nrNx2zLxLnq4oDubh/art.json +++ b/art/nrNx2zLxLnq4oDubh/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":2000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n float n = vertexId / vertexCount;\\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \\n float angle = n * 6.28;\\n \\n float avx = 0.5;\\n float axy = 0.5;\\n \\n float dx = cos(angle * time * avx) * vertexId / 1000.0;\\n float dy = sin(angle * time * axy) * vertexId / 1000.0;\\n \\n gl_Position = vec4(dx, dy, 0.0, 1);\\n gl_PointSize = vertexId;\\n v_color = vec4(snd.a, snd.a * n, cos(time * n), 1.0);\\n}\"}", + "settings": { + "num": 2000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n float n = vertexId / vertexCount;\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \n float angle = n * 6.28;\n \n float avx = 0.5;\n float axy = 0.5;\n \n float dx = cos(angle * time * avx) * vertexId / 1000.0;\n float dy = sin(angle * time * axy) * vertexId / 1000.0;\n \n gl_Position = vec4(dx, dy, 0.0, 1);\n gl_PointSize = vertexId;\n v_color = vec4(snd.a, snd.a * n, cos(time * n), 1.0);\n}" + }, "screenshotURL": "data/images/images-dz6aunjr4th22lzr5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nrQMSTcrvmsdCH5uD/art.json b/art/nrQMSTcrvmsdCH5uD/art.json index 396e0a75..bffdc438 100644 --- a/art/nrQMSTcrvmsdCH5uD/art.json +++ b/art/nrQMSTcrvmsdCH5uD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "hinga-", "avatarUrl": "https://avatars.githubusercontent.com/hinga-?s=200", - "settings": "{\"num\":10433,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = (fract(pos+.5)-.5);\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.2;\\n float i = vertexId*.13;\\n\\n// vec3 pos = posf(t,i);\\n vec3 pos = posf(0.6, 0.5);\\n vec3 ofs = vec3(0.);\\n //for (float f = -1.; f < 0.; f++) {\\n\\t //ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n //}\\n ofs += push(t,i,ofs,0.5);\\n \\n //pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n //pos.yz *= mat2(.8,.6,-.6,.8);\\n //pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 0.5;\\n \\n\\n pos.z += 1.7;\\n \\n //pos.xy *= (3.-pos.z)*.7;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.1;\\n}\"}", + "settings": { + "num": 10433, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = (fract(pos+.5)-.5);\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.2;\n float i = vertexId*.13;\n\n// vec3 pos = posf(t,i);\n vec3 pos = posf(0.6, 0.5);\n vec3 ofs = vec3(0.);\n //for (float f = -1.; f < 0.; f++) {\n\t //ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n //}\n ofs += push(t,i,ofs,0.5);\n \n //pos -= posf0(t);\n \n pos += ofs;\n \n \n //pos.yz *= mat2(.8,.6,-.6,.8);\n //pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 0.5;\n \n\n pos.z += 1.7;\n \n //pos.xy *= (3.-pos.z)*.7;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 1.-vertexId*0.000001, 1);\n gl_PointSize = 1./pos.z*(1.+10.*pow(sin(time*0.3+vertexId)*.5+.5,8000.))*(1.+30.*pow(sin(time*0.03+vertexId*0.4352)*.5+.5,400000.))*3.;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1)*.1;\n}" + }, "screenshotURL": "data/images/images-1qyedcizd6prarsg1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ns6ensiZRZmzyi3of/art.json b/art/ns6ensiZRZmzyi3of/art.json index 4c7778f9..b8281f4b 100644 --- a/art/ns6ensiZRZmzyi3of/art.json +++ b/art/ns6ensiZRZmzyi3of/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":14474,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 2.//KParameter 0.>>6.\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.527) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (1000. *(P2+1.5))+10.;\\n float numQuads = floor( vertexCount/6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 4.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) + mouse.y * r;\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv *mouse.y - PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.3+P2) * (-mouse.x *3.0) + 0., sin(P3 + tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 14474, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 2.//KParameter 0.>>6.\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.527) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (1000. *(P2+1.5))+10.;\n float numQuads = floor( vertexCount/6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 4.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) + mouse.y * r;\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, cos(qv *mouse.y - PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.3+P2) * (-mouse.x *3.0) + 0., sin(P3 + tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-4ila0kumreip1zb2a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nsh5oH8N9MEBb9AbT/art.json b/art/nsh5oH8N9MEBb9AbT/art.json index 230de14e..538a3029 100644 --- a/art/nsh5oH8N9MEBb9AbT/art.json +++ b/art/nsh5oH8N9MEBb9AbT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/djipi69/abba-chiquitita?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 808.0), fract(count / 500000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/djipi69/abba-chiquitita?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 808.0), fract(count / 500000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-j6kf7gq4ag3espkos-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ntCWzzdvXfp33a6oz/art.json b/art/ntCWzzdvXfp33a6oz/art.json index a67b0f33..7c056453 100644 --- a/art/ntCWzzdvXfp33a6oz/art.json +++ b/art/ntCWzzdvXfp33a6oz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":5184,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caravan-palace-official/lone-digger?in=caravan-palace-official%2Fsets%2Freleases\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.9921568627450981,0.996078431372549,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n float pv = pointId / NUM_POINTS_PER_CIRCLE;\\n vec3 pos;\\n float inner = mix(0.1, 0.9, step(0.1, circleId)); //mix(0.2, 0.9, p1m1(sin(goop(circleId) + time * 0.0)));\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = 1.0 - cu;\\n \\n float snd = 0.0;\\n const int numSamplers = 10;\\n for (int i = 0; i < numSamplers; ++i) {\\n snd += texture2D(sound, vec2(mix(0.005, 0.105, cu), float(i) * 0.002)).a;\\n }\\n snd /= float(numSamplers);\\n\\n vec3 offset = vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\\n offset.x += m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\\n offset.y += goop(circleId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n// mat *= trans(offset);\\n mat *= rotZ(cu * 1.);//rotZ(snd * PI);\\n mat *= uniformScale(pow(cu, 2.0) + mix(0., 1., pow(snd, 5.0)) + sliceId * 0.01);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.6, 1.0, step(0.5, fract(cu * numCircles * 0.5)));\\n hue = mix(0.165, hue, step(0.1, circleId));\\n float sat = 1.;//1. -pow(snd, 5.);\\n float val = mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 5184, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caravan-palace-official/lone-digger?in=caravan-palace-official%2Fsets%2Freleases", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.9921568627450981, + 0.996078431372549, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n float pv = pointId / NUM_POINTS_PER_CIRCLE;\n vec3 pos;\n float inner = mix(0.1, 0.9, step(0.1, circleId)); //mix(0.2, 0.9, p1m1(sin(goop(circleId) + time * 0.0)));\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = 1.0 - cu;\n \n float snd = 0.0;\n const int numSamplers = 10;\n for (int i = 0; i < numSamplers; ++i) {\n snd += texture2D(sound, vec2(mix(0.005, 0.105, cu), float(i) * 0.002)).a;\n }\n snd /= float(numSamplers);\n\n vec3 offset = vec3(hash(circleId) * 0.8, m1p1(hash(circleId * 0.37)), 0);\n offset.x += m1p1(pow(snd, 20.0) + goop(circleId + time * 0.) * 0.1);\n offset.y += goop(circleId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n// mat *= trans(offset);\n mat *= rotZ(cu * 1.);//rotZ(snd * PI);\n mat *= uniformScale(pow(cu, 2.0) + mix(0., 1., pow(snd, 5.0)) + sliceId * 0.01);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(0.6, 1.0, step(0.5, fract(cu * numCircles * 0.5)));\n hue = mix(0.165, hue, step(0.1, circleId));\n float sat = 1.;//1. -pow(snd, 5.);\n float val = mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-0bv01h1a07p5y5q0r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ntwDMXMwDGY8aMF7M/art.json b/art/ntwDMXMwDGY8aMF7M/art.json index 136d9c2d..79df6665 100644 --- a/art/ntwDMXMwDGY8aMF7M/art.json +++ b/art/ntwDMXMwDGY8aMF7M/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/diskore/m4r\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.10980392156862745,0.11764705882352941,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 -1.//KParameter2 -1.>>2.\\n#define parameter3 1.//KParameter3 -0.5>>4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>5.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / parameter0 *3.0, 2.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle/parameter7 );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 1.-parameter0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(121.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v / 21. - v;}\\n\\nfloat p1m1(float v) {\\n return v * mod(4.1 *time, 2.0*parameter2) ;\\n}\\n\\nfloat inv(float v) {\\n return 1. + v - 2.;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, time);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE +1.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) -PI - 1.16 / PI * 7.0* parameter3;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = 0.2;\\n pos = vec3(x, y+1., -5.* parameter4); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t - 1.7) + tan((t *= 1.13) - -t) + sin(t - 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles+ 4.;\\n vec3 pos;\\n float inner = mix(0.03, 11.1-parameter4, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 21.033) - sin(time * .083 + circleId) *0.1- parameter4);\\n float end = start + 3.;//start + hash(sideId + 3.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/.8 - 0.3)*7.)* 0.05, uv.y * 1.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId -1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time + 0.103) - 1.4;\\n offset.y += goop(circleId + time - 1.13) * 1.31 *parameter4;\\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset- parameter1);\\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\\n gl_Position = vec4((mat * vec4(pos,.5)).xyz, 11.3 +parameter4 -(circleId + mouse.x));\\n gl_PointSize = 2. -parameter3;\\n\\n float hue = mix(0.01 *snd , 1.9 *parameter3/ circleId/snd , fract(circleId * 12.79 /snd));\\n float sat = 1. / snd;\\n float val = 0.9- snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. -parameter2 - uv.y) * pow(snd * 2.51, snd-3. /parameter6));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/diskore/m4r", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.10980392156862745, + 0.11764705882352941, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 -1.//KParameter2 -1.>>2.\n#define parameter3 1.//KParameter3 -0.5>>4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>5.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / parameter0 *3.0, 2.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle/parameter7 );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 1.-parameter0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(121.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v / 21. - v;}\n\nfloat p1m1(float v) {\n return v * mod(4.1 *time, 2.0*parameter2) ;\n}\n\nfloat inv(float v) {\n return 1. + v - 2.;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, time);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE +1.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) -PI - 1.16 / PI * 7.0* parameter3;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = 0.2;\n pos = vec3(x, y+1., -5.* parameter4); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t - 1.7) + tan((t *= 1.13) - -t) + sin(t - 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles+ 4.;\n vec3 pos;\n float inner = mix(0.03, 11.1-parameter4, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 21.033) - sin(time * .083 + circleId) *0.1- parameter4);\n float end = start + 3.;//start + hash(sideId + 3.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/.8 - 0.3)*7.)* 0.05, uv.y * 1.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId -1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time + 0.103) - 1.4;\n offset.y += goop(circleId + time - 1.13) * 1.31 *parameter4;\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset- parameter1);\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\n gl_Position = vec4((mat * vec4(pos,.5)).xyz, 11.3 +parameter4 -(circleId + mouse.x));\n gl_PointSize = 2. -parameter3;\n\n float hue = mix(0.01 *snd , 1.9 *parameter3/ circleId/snd , fract(circleId * 12.79 /snd));\n float sat = 1. / snd;\n float val = 0.9- snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. -parameter2 - uv.y) * pow(snd * 2.51, snd-3. /parameter6));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\n}" + }, "screenshotURL": "data/images/images-ih2zhgj8jaml0c08z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nvRC9PH5c7FhYT6vm/art.json b/art/nvRC9PH5c7FhYT6vm/art.json index 11c9d4bd..8e41a13d 100644 --- a/art/nvRC9PH5c7FhYT6vm/art.json +++ b/art/nvRC9PH5c7FhYT6vm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 7.0\\n\\n#define PI 3.1415\\n\\n#define RESOLUTION vec3(45.0)\\n#define SIZE vec3(2.5)\\n\\n// New hash based on hash13() from \\\"Hash without Sine\\\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\\n// 4 in, 1 out\\nfloat Hash41(in vec4 p) {\\n\\tp = fract(p * 0.1031);\\n p += dot(p, p.zwyx + 31.32);\\n return fract((p.x + p.y) * p.z - p.x * p.w);\\n}\\n\\n\\nfloat SmoothNoise4D(in vec4 p) {\\n vec4 cell = floor(p);\\n vec4 local = fract(p);\\n local *= local * (3.0 - 2.0 * local);\\n\\n float ldbq = Hash41(cell);\\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\\n float rufw = Hash41(cell + 1.0);\\n\\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\\n mix(lubq, rubq, local.x),\\n local.y),\\n\\n mix(mix(ldfq, rdfq, local.x),\\n mix(lufq, rufq, local.x),\\n local.y),\\n\\n local.z),\\n\\n mix(mix(mix(ldbw, rdbw, local.x),\\n mix(lubw, rubw, local.x),\\n local.y),\\n\\n mix(mix(ldfw, rdfw, local.x),\\n mix(lufw, rufw, local.x),\\n local.y),\\n\\n local.z),\\n\\n local.w);\\n}\\n\\nfloat FractalNoise4D(in vec4 p) {\\n p *= 2.0;\\n\\n float nscale = .80;\\n float tscale = -0.21;\\n float value = -.10;\\n\\n for (int octave=0; octave < 5; octave++) {\\n value += SmoothNoise4D(p) * nscale;\\n tscale += nscale;\\n nscale *= 0.5;\\n p *= 1.0;\\n }\\n\\n return value / tscale;\\n}\\n\\nfloat mapShape(vec3 p) {\\n return FractalNoise4D(vec4(p, time * 0.25)) - .4;\\n}\\n\\nvec3 mapColor(in vec3 p) {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, -1.40));\\n vec2 e = vec2(0.001, 0.0);\\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\\n\\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\\n}\\n\\nvoid main() {\\n float t = time * 0.25;\\n\\n float cellId = vertexId;\\n float gridX = mod(cellId, RESOLUTION.x);\\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\\n\\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\\n vec3 color = mapColor(vertex);\\n\\n vec2 mouseRot = mouse * PI;\\n float cy = cos(mouseRot.x)*sin(time-0.825)+.5, sy = sin(mouseRot.x*cos(time*0.2)*2.);\\n float cp = cos(mouseRot.y)*cos(time+2.), sp = sin(mouseRot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, .750);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 7.0\n\n#define PI 3.1415\n\n#define RESOLUTION vec3(45.0)\n#define SIZE vec3(2.5)\n\n// New hash based on hash13() from \"Hash without Sine\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\n// 4 in, 1 out\nfloat Hash41(in vec4 p) {\n\tp = fract(p * 0.1031);\n p += dot(p, p.zwyx + 31.32);\n return fract((p.x + p.y) * p.z - p.x * p.w);\n}\n\n\nfloat SmoothNoise4D(in vec4 p) {\n vec4 cell = floor(p);\n vec4 local = fract(p);\n local *= local * (3.0 - 2.0 * local);\n\n float ldbq = Hash41(cell);\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\n float rufw = Hash41(cell + 1.0);\n\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\n mix(lubq, rubq, local.x),\n local.y),\n\n mix(mix(ldfq, rdfq, local.x),\n mix(lufq, rufq, local.x),\n local.y),\n\n local.z),\n\n mix(mix(mix(ldbw, rdbw, local.x),\n mix(lubw, rubw, local.x),\n local.y),\n\n mix(mix(ldfw, rdfw, local.x),\n mix(lufw, rufw, local.x),\n local.y),\n\n local.z),\n\n local.w);\n}\n\nfloat FractalNoise4D(in vec4 p) {\n p *= 2.0;\n\n float nscale = .80;\n float tscale = -0.21;\n float value = -.10;\n\n for (int octave=0; octave < 5; octave++) {\n value += SmoothNoise4D(p) * nscale;\n tscale += nscale;\n nscale *= 0.5;\n p *= 1.0;\n }\n\n return value / tscale;\n}\n\nfloat mapShape(vec3 p) {\n return FractalNoise4D(vec4(p, time * 0.25)) - .4;\n}\n\nvec3 mapColor(in vec3 p) {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, -1.40));\n vec2 e = vec2(0.001, 0.0);\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\n\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\n}\n\nvoid main() {\n float t = time * 0.25;\n\n float cellId = vertexId;\n float gridX = mod(cellId, RESOLUTION.x);\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\n\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\n vec3 color = mapColor(vertex);\n\n vec2 mouseRot = mouse * PI;\n float cy = cos(mouseRot.x)*sin(time-0.825)+.5, sy = sin(mouseRot.x*cos(time*0.2)*2.);\n float cp = cos(mouseRot.y)*cos(time+2.), sp = sin(mouseRot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, .750);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-vq06qn55we3h7mh6i-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nw2X8ECBMqrgNbcQL/art.json b/art/nw2X8ECBMqrgNbcQL/art.json index a4930ac1..49a77ece 100644 --- a/art/nw2X8ECBMqrgNbcQL/art.json +++ b/art/nw2X8ECBMqrgNbcQL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":38360,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/soma-radio-cover-at-valencia\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Spiral Circle thingy\\n// Testing music sync\\n\\n\\n//paramater0 // general scale 0.1 to 0.5\\n//parameter1 // spiral stop 1.0 to 2.0\\n//parameter2 // color sensitivity\\n//parameter3 // sound sensitivity 5.0 to 10.\\n//arameter4 // point size 1.0 to 5.0\\n\\n\\n\\n\\n\\nvoid main () {\\n float v = vertexId * 200. * sin(time/20000.);\\n //float sndFactor = texture2D(sound, vec2(;\\n \\n float spiral = 1. - 1.9 * vertexId / (vertexCount+vertexCount);\\n \\n float grid = floor(vertexCount / 1000.);\\n float step100 = floor (100. * vertexId / vertexCount); \\n float sndFactor = texture2D(sound, vec2(mod(step100, 4.), step100/400.)).a;\\n float scale = 0.5 * (5. * sndFactor);\\n \\n float xoff = sndFactor * (sin(time/1.)/2.) * 0.5;\\n float yoff = sndFactor * (sin(time/1.1)/2.) * 0.5;\\n \\n float y = sin(v / (50. * (2. + sin(time * 2000.)))) * spiral;\\n float x = cos(v / (50. * (2. + sin(time * 2010.)))) * spiral;\\n \\n float ux = x * scale - xoff;\\n float uy = y * scale - yoff;\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = sndFactor * 3.;//v / (sndFactor *100000.) ;// grid;\\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\\n //v_color = vec4(sin(spiral * 5. +time + sndFactor), 0.1, 0.5, 1);\\n v_color = vec4(sndFactor * 2., sin(1./spiral), 1./spiral, 1);\\n}\"}", + "settings": { + "num": 38360, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/soma-radio-cover-at-valencia", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Spiral Circle thingy\n// Testing music sync\n\n\n//paramater0 // general scale 0.1 to 0.5\n//parameter1 // spiral stop 1.0 to 2.0\n//parameter2 // color sensitivity\n//parameter3 // sound sensitivity 5.0 to 10.\n//arameter4 // point size 1.0 to 5.0\n\n\n\n\n\nvoid main () {\n float v = vertexId * 200. * sin(time/20000.);\n //float sndFactor = texture2D(sound, vec2(;\n \n float spiral = 1. - 1.9 * vertexId / (vertexCount+vertexCount);\n \n float grid = floor(vertexCount / 1000.);\n float step100 = floor (100. * vertexId / vertexCount); \n float sndFactor = texture2D(sound, vec2(mod(step100, 4.), step100/400.)).a;\n float scale = 0.5 * (5. * sndFactor);\n \n float xoff = sndFactor * (sin(time/1.)/2.) * 0.5;\n float yoff = sndFactor * (sin(time/1.1)/2.) * 0.5;\n \n float y = sin(v / (50. * (2. + sin(time * 2000.)))) * spiral;\n float x = cos(v / (50. * (2. + sin(time * 2010.)))) * spiral;\n \n float ux = x * scale - xoff;\n float uy = y * scale - yoff;\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = sndFactor * 3.;//v / (sndFactor *100000.) ;// grid;\n //v_color = vec4(sin(spiral), sin(time/1.1), sin(time), 1);\n //v_color = vec4(sin(spiral * 5. +time + sndFactor), 0.1, 0.5, 1);\n v_color = vec4(sndFactor * 2., sin(1./spiral), 1./spiral, 1);\n}" + }, "screenshotURL": "data/images/images-u8nhcfhp19qjxg8h7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nwiNgNXfwAjCRaYPP/art.json b/art/nwiNgNXfwAjCRaYPP/art.json index 21719abe..e25516ce 100644 --- a/art/nwiNgNXfwAjCRaYPP/art.json +++ b/art/nwiNgNXfwAjCRaYPP/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n \\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x/ (width - 1.0);\\n float v = y/ (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) *0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n\\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n \n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x/ (width - 1.0);\n float v = y/ (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) *0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n\n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-x1rmsggd298896rs6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nwzXPvrrBth6sRSHi/art.json b/art/nwzXPvrrBth6sRSHi/art.json index 7267d563..9af3434a 100644 --- a/art/nwzXPvrrBth6sRSHi/art.json +++ b/art/nwzXPvrrBth6sRSHi/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// terrain\\n\\n//KDrawmode=GL_\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0.2, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.2,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.81;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.*s;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf -= 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, qu, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\\n vec3 n0 = getQuadPoint(nId + 0.01, s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 0, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-(mouse.x*0.5));\\n \\n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y+1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// terrain\n\n//KDrawmode=GL_\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0.2, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.2,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.81;\n\tf = 0.5000*noise( p ); p = mr*p*2.*s;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf -= 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) *(1.0-(mouse.y*0.22)));\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, qu, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / (5. *mouse.x*s)) ;\n vec3 n0 = getQuadPoint(nId + 0.01, s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 0, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p-(mouse.x*0.5), 1.5-(mouse.x*0.5));\n \n float hue = 0.5 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mouse.y+1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-8yr1ir5p3dffl27pt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nxDSonR2aWTKY6XYt/art.json b/art/nxDSonR2aWTKY6XYt/art.json index e77abf80..7344c95f 100644 --- a/art/nxDSonR2aWTKY6XYt/art.json +++ b/art/nxDSonR2aWTKY6XYt/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//vertex shader:\\nvoid main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.75;\\n float rightBottom = 0.0125;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 0, 0, 1);\\n }\\n else {\\n v_color = vec4(0, 0, 1, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//vertex shader:\nvoid main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.75;\n float rightBottom = 0.0125;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 0, 0, 1);\n }\n else {\n v_color = vec4(0, 0, 1, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-zf9u8zro24oxqnzb4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nxbZAMQjGvme7F55J/art.json b/art/nxbZAMQjGvme7F55J/art.json index 05b17269..2e64728a 100644 --- a/art/nxbZAMQjGvme7F55J/art.json +++ b/art/nxbZAMQjGvme7F55J/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "legileurs", "avatarUrl": "https://secure.gravatar.com/avatar/a48c633acb8ed21d176343fa75931ff6?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F8839ade8e32fd3ea8c1ca8ac8b2590a3", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"///GLSL\\nvoid main() {\\n gl_PointSize = 100.0;\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n /*RGB */\\n v_color = vec4(1.0, .0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "///GLSL\nvoid main() {\n gl_PointSize = 100.0;\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n /*RGB */\n v_color = vec4(1.0, .0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-zljwjcglcf3vm7nvh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/nxqCRh7kbHBXK4qNn/art.json b/art/nxqCRh7kbHBXK4qNn/art.json index 7fc5e2b5..bf3cb690 100644 --- a/art/nxqCRh7kbHBXK4qNn/art.json +++ b/art/nxqCRh7kbHBXK4qNn/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":843,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float h(float p)\\n{\\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\\n}\\n\\nvec2 r(vec2 p, float a)\\n{\\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\\n}\\n\\nvoid main()\\n{\\n float t = time;\\n float o = resolution.x / resolution.y;\\n float s = vertexId + t;\\n\\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\\n vec3 u = 1. - step(.5, b) * 2.;\\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\\n\\n vec3 p = vec3(h(s), h(s * .731), h(s * 5.319)) * 2. - 1.;\\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\\n vec3 v = d - vec3(0, d.xy);\\n\\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\\n p.xy = r(p.xy, t * .2 + a.x * .2);\\n p.xz = r(p.xz, t * .3 + a.y);\\n\\n v_color = vec4(a * .8 + .2, 1.);\\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 843, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float h(float p)\n{\n return fract(fract(p * 7.3983) * fract(p * .4427) * 95.4337);\n}\n\nvec2 r(vec2 p, float a)\n{\n return vec2(-1, 1) * p.yx * sin(a) + p.xy * cos(a);\n}\n\nvoid main()\n{\n float t = time;\n float o = resolution.x / resolution.y;\n float s = vertexId + t;\n\n vec3 b = abs((fract(vec3(.95, .5, .125) * t) - .5) * 2.);\n vec3 u = 1. - step(.5, b) * 2.;\n vec3 a = (pow(vec3(2.), (40. * b - 20.) * u) * u - u + 1.) * .5;\n\n vec3 p = vec3(h(s), h(s * .731), h(s * 5.319)) * 2. - 1.;\n vec3 d = 1. - step(vec3(1, 2, 3), vec3(h(s * 0.911) * 3.));\n vec3 v = d - vec3(0, d.xy);\n\n p = mix(step(0., p) * 2. - 1., p, mix(1. - v, v, a.y));\n p *= mix(1. / length(p), 1., dot(a, p) * a.z - sin(t * .2) * 2. * (a.x + .5));\n p.xy = r(p.xy, t * .2 + a.x * .2);\n p.xz = r(p.xz, t * .3 + a.y);\n\n v_color = vec4(a * .8 + .2, 1.);\n gl_Position = vec4(p.x, p.y * o, p.z, p.z + 5.);\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-p9gppiaro099sb4fv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ny5RDoPy8ubuGtKS6/art.json b/art/ny5RDoPy8ubuGtKS6/art.json index d36baaa0..d37f8311 100644 --- a/art/ny5RDoPy8ubuGtKS6/art.json +++ b/art/ny5RDoPy8ubuGtKS6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.13725490196078433,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 8.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.13725490196078433, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 8.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-zq8enawb0hnayhwvj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nyGuXdDQvXKEPcSGJ/art.json b/art/nyGuXdDQvXKEPcSGJ/art.json index a9afaa2e..32374d29 100644 --- a/art/nyGuXdDQvXKEPcSGJ/art.json +++ b/art/nyGuXdDQvXKEPcSGJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":46,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n \\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float angle = (x/20.0) * radians(360.0);\\n float r = 2.0 - y;\\n \\n float ux = r * cos(angle)*0.2;\\n float uy = r * sin(angle)*0.2;\\n\\n \\n //float xOffset = cos(17.0 + x) + sin(70.0 + y) * 0.1;\\n //float yOffset = cos(-6.0 + y) + sin(93.0 + x) * 0.1;\\n \\n \\n gl_Position = vec4(ux, uy, 0.0 , 1.0);\\n v_color = vec4(cos(time * x), sin(time * y), tan(time), 1.0);\\n gl_PointSize = 10.0;\\n \\n}\"}", + "settings": { + "num": 46, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n \n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float angle = (x/20.0) * radians(360.0);\n float r = 2.0 - y;\n \n float ux = r * cos(angle)*0.2;\n float uy = r * sin(angle)*0.2;\n\n \n //float xOffset = cos(17.0 + x) + sin(70.0 + y) * 0.1;\n //float yOffset = cos(-6.0 + y) + sin(93.0 + x) * 0.1;\n \n \n gl_Position = vec4(ux, uy, 0.0 , 1.0);\n v_color = vec4(cos(time * x), sin(time * y), tan(time), 1.0);\n gl_PointSize = 10.0;\n \n}" + }, "screenshotURL": "data/images/images-3edsltzez4bfaljgn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/nyvAkYFYd4Ffhu7Gz/art.json b/art/nyvAkYFYd4Ffhu7Gz/art.json index 3a182a7e..16e0aadf 100644 --- a/art/nyvAkYFYd4Ffhu7Gz/art.json +++ b/art/nyvAkYFYd4Ffhu7Gz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "lizell", "avatarUrl": "https://secure.gravatar.com/avatar/8cbc7cccd5a415ae64aab0284832279b?default=retro&size=200", - "settings": "{\"num\":548,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 548, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-w28l6odfjkvz0f4ee-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/o2p6Z9SdrQn7eafB9/art.json b/art/o2p6Z9SdrQn7eafB9/art.json index c01c3a7b..bc26a8f6 100644 --- a/art/o2p6Z9SdrQn7eafB9/art.json +++ b/art/o2p6Z9SdrQn7eafB9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Audio Reactive\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Audio Reactive\ncourse name : CS250\nterm : 2022 Spring\n*/\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-9nq12mxnln7m593b8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/o39WoEQsYbe48X2id/art.json b/art/o39WoEQsYbe48X2id/art.json index c31244d7..92774747 100644 --- a/art/o39WoEQsYbe48X2id/art.json +++ b/art/o39WoEQsYbe48X2id/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/protector-101/protector-101-a-dancing-comet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 02, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 12); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 12, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 12); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/protector-101/protector-101-a-dancing-comet", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* ⭕️⭕️⭕️⭕️⭕️⭕️⭕️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 4.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 02, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 12); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 12, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 12); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-4tvt6i7su76kxx0w9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/o3FG9dxvZ25tAQFxj/art.json b/art/o3FG9dxvZ25tAQFxj/art.json index d45de36f..b7a91142 100644 --- a/art/o3FG9dxvZ25tAQFxj/art.json +++ b/art/o3FG9dxvZ25tAQFxj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1319,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.3137254901960784,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/ across);\\n \\n float u = x / (across - .1);\\n float v = y / (across - .1);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across; \\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1319, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.3137254901960784, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/ across);\n \n float u = x / (across - .1);\n float v = y / (across - .1);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across; \n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-c3ffx2q5l725bn8ov-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/o3iK4vsbQQx2dD4jM/art.json b/art/o3iK4vsbQQx2dD4jM/art.json index 123a41e0..fd38e821 100644 --- a/art/o3iK4vsbQQx2dD4jM/art.json +++ b/art/o3iK4vsbQQx2dD4jM/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":50000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.01568627450980392,0.10588235294117647,1],\"shader\":\"//KDrawmode=GL_LINE_LOOP\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvarying float soundValues[10];\\nconst int windowSize = 10;\\nfloat movingAverage(float value) {\\n // Add the new value to the soundValues array\\n for (int i = windowSize - 1; i > 0; i--) {\\n soundValues[i] = soundValues[i-1];\\n }\\n soundValues[0] = value; \\n\\n // Calculate the moving average\\n float sum = 0.0;\\n float peak = 0.0;\\n for (int i = 0; i < windowSize; i++) {\\n sum += soundValues[i];\\n if (soundValues[i]>peak)\\n {\\n peak = soundValues[i];\\n }\\n }\\n float average = sum / float(windowSize);\\n\\n\\n return (average + peak)/2.;\\n}\\n\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i, float soundIn) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd =soundIn;// pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.350;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n float snd = movingAverage(pow(texture2D(sound, vec2(0.005, 0.5)).a, 4.)) * 1.;\\n //float snd = pow(texture2D(sound, vec2(0.005, 0.025)).a, 4.);\\n\\n point p1 = getPoint(vertexId / vertexCount,snd);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/globalliquidity/20230302-deep-blue-amoeba", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.01568627450980392, + 0.10588235294117647, + 1 + ], + "shader": "//KDrawmode=GL_LINE_LOOP\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvarying float soundValues[10];\nconst int windowSize = 10;\nfloat movingAverage(float value) {\n // Add the new value to the soundValues array\n for (int i = windowSize - 1; i > 0; i--) {\n soundValues[i] = soundValues[i-1];\n }\n soundValues[0] = value; \n\n // Calculate the moving average\n float sum = 0.0;\n float peak = 0.0;\n for (int i = 0; i < windowSize; i++) {\n sum += soundValues[i];\n if (soundValues[i]>peak)\n {\n peak = soundValues[i];\n }\n }\n float average = sum / float(windowSize);\n\n\n return (average + peak)/2.;\n}\n\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i, float soundIn) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd =soundIn;// pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.350;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n float snd = movingAverage(pow(texture2D(sound, vec2(0.005, 0.5)).a, 4.)) * 1.;\n //float snd = pow(texture2D(sound, vec2(0.005, 0.025)).a, 4.);\n\n point p1 = getPoint(vertexId / vertexCount,snd);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-4h8e3jfje75pbeyxs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/o8GYn89ZNMgQTnQut/art.json b/art/o8GYn89ZNMgQTnQut/art.json index 1c8cbb84..cf535851 100644 --- a/art/o8GYn89ZNMgQTnQut/art.json +++ b/art/o8GYn89ZNMgQTnQut/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/joe-blobs/naga-baba-the-jabberwocky-joe-blobs-rmx\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/**/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n#if 1\\nvoid main() {\\n float numSides = 4.0;\\n float numPointsPerShape = numSides * 2.0;\\n float p = floor(vertexId / 2.0) + mod(vertexId, 2.0);\\n float a = p / numSides * PI * 2.0;\\n vec3 pos = vec3(\\n cos(a),\\n sin(a),\\n 0);\\n float shapeId = floor(vertexId / numPointsPerShape);\\n float numShapes = floor(vertexCount / numPointsPerShape);\\n float u = shapeId / numShapes;\\n \\n float aspect = resolution.x / resolution.y;\\n float across = floor(sqrt(numShapes) * aspect);\\n float down = floor(numShapes / across);\\n float x = mod(shapeId, across);\\n float y = floor(shapeId / across);\\n float ux = x / across;\\n float vy = y / down;\\n \\n float s = texture2D(sound, vec2(\\n ux * 0.8,\\n vy\\n )).r;\\n \\n mat4 mat = persp(PI * 0.25, aspect, 0.1, 20.);\\n mat = mat4(\\n 2. / across, 0, 0, 0,\\n 0, 2. / down, 0, 0,\\n 0, 0, 1, 0,\\n -1, -1, 0, 1);\\n \\n //mat *= cameraLookAt(\\n // vec3(0, 0, -3),\\n // vec3(0, 0, 0),\\n // vec3(0, 1, 0));\\n mat *= trans(vec3(x, y, 0));\\n mat *= rotZ(time);\\n mat *= uniformScale(0.5);\\n gl_Position = mat * vec4(pos, 1);\\n vec3 color1 = vec3(1, 0, 0);\\n vec3 color2 = vec3(0, 1, 1);\\n vec3 color = mix(color1, color2, s);\\n v_color = vec4(color, 1);\\n}\\n\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/joe-blobs/naga-baba-the-jabberwocky-joe-blobs-rmx", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/**/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n#if 1\nvoid main() {\n float numSides = 4.0;\n float numPointsPerShape = numSides * 2.0;\n float p = floor(vertexId / 2.0) + mod(vertexId, 2.0);\n float a = p / numSides * PI * 2.0;\n vec3 pos = vec3(\n cos(a),\n sin(a),\n 0);\n float shapeId = floor(vertexId / numPointsPerShape);\n float numShapes = floor(vertexCount / numPointsPerShape);\n float u = shapeId / numShapes;\n \n float aspect = resolution.x / resolution.y;\n float across = floor(sqrt(numShapes) * aspect);\n float down = floor(numShapes / across);\n float x = mod(shapeId, across);\n float y = floor(shapeId / across);\n float ux = x / across;\n float vy = y / down;\n \n float s = texture2D(sound, vec2(\n ux * 0.8,\n vy\n )).r;\n \n mat4 mat = persp(PI * 0.25, aspect, 0.1, 20.);\n mat = mat4(\n 2. / across, 0, 0, 0,\n 0, 2. / down, 0, 0,\n 0, 0, 1, 0,\n -1, -1, 0, 1);\n \n //mat *= cameraLookAt(\n // vec3(0, 0, -3),\n // vec3(0, 0, 0),\n // vec3(0, 1, 0));\n mat *= trans(vec3(x, y, 0));\n mat *= rotZ(time);\n mat *= uniformScale(0.5);\n gl_Position = mat * vec4(pos, 1);\n vec3 color1 = vec3(1, 0, 0);\n vec3 color2 = vec3(0, 1, 1);\n vec3 color = mix(color1, color2, s);\n v_color = vec4(color, 1);\n}\n\n#endif\n\n" + }, "screenshotURL": "data/images/images-ubaye26d23n6eky0h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oBkFr7rtycBbgMasK/art.json b/art/oBkFr7rtycBbgMasK/art.json index d33f7afa..7aecfcda 100644 --- a/art/oBkFr7rtycBbgMasK/art.json +++ b/art/oBkFr7rtycBbgMasK/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "radim", "avatarUrl": "https://lh5.googleusercontent.com/-dpQgdDwFdh4/AAAAAAAAAAI/AAAAAAAAAa0/ht-QikUlpKQ/photo.jpg", - "settings": "{\"num\":8323,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/arjunajungle/arjuna-chemical-jungle-parvati-rec\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 6.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float halfpoint = floor(vertexId / 2.0);\\n float chooser = mod(vertexId, 2.0);\\n float timestep = floor(4.0*time+1.0);\\n \\n float a = halfpoint*(1.0+timestep*chooser);\\n float b = mod(a, NUM_SEGMENTS);\\n float stepper = mod(halfpoint,NUM_SEGMENTS*STEP)/STEP;\\n float combine = mod(stepper+b, NUM_SEGMENTS);\\n float cno = combine/NUM_SEGMENTS;\\n \\n vec2 points = 0.5*vec2(cos(cno*2.0*PI), sin(cno*2.0*PI));\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4((points)*aspect, 0.0, 1.0);\\n float hue = stepper/NUM_SEGMENTS;\\n //float hue = floor(mod((vertexId/2.0),NUM_PARTS)/(NUM_PARTS/4.0))/4.0;\\n v_color = vec4(hsv2rgb(vec3(hue, 1.0, 1.0)), 1.0);\\n}\"}", + "settings": { + "num": 8323, + "mode": "LINES", + "sound": "https://soundcloud.com/arjunajungle/arjuna-chemical-jungle-parvati-rec", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 6.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float halfpoint = floor(vertexId / 2.0);\n float chooser = mod(vertexId, 2.0);\n float timestep = floor(4.0*time+1.0);\n \n float a = halfpoint*(1.0+timestep*chooser);\n float b = mod(a, NUM_SEGMENTS);\n float stepper = mod(halfpoint,NUM_SEGMENTS*STEP)/STEP;\n float combine = mod(stepper+b, NUM_SEGMENTS);\n float cno = combine/NUM_SEGMENTS;\n \n vec2 points = 0.5*vec2(cos(cno*2.0*PI), sin(cno*2.0*PI));\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4((points)*aspect, 0.0, 1.0);\n float hue = stepper/NUM_SEGMENTS;\n //float hue = floor(mod((vertexId/2.0),NUM_PARTS)/(NUM_PARTS/4.0))/4.0;\n v_color = vec4(hsv2rgb(vec3(hue, 1.0, 1.0)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ku9oiv4ddwvowib7e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oBmtsD4bYK6h3htfS/art.json b/art/oBmtsD4bYK6h3htfS/art.json index 60b53845..e0b5a658 100644 --- a/art/oBmtsD4bYK6h3htfS/art.json +++ b/art/oBmtsD4bYK6h3htfS/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3686274509803922,0.03137254901960784,0.49019607843137253,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Audio Reactive\\n// Course : CS250\\n// Spring 2023\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\n float su = abs(u -.5) * 2.;\\n float sv = abs(v - .5) * 2.;\\n \\n // Angular\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n // Sound\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n // [0, 1)\\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \\n float sat = mix(0., 1., pump);//mix(1., -10., 1. - av);\\n float val = mix(.1, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n} \"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3686274509803922, + 0.03137254901960784, + 0.49019607843137253, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Audio Reactive\n// Course : CS250\n// Spring 2023\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n\n float su = abs(u -.5) * 2.;\n float sv = abs(v - .5) * 2.;\n \n // Angular\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n // Sound\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + .2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n // [0, 1)\n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;//sin(time + v * 20.) * 0.05; \n float sat = mix(0., 1., pump);//mix(1., -10., 1. - av);\n float val = mix(.1, pow(snd + .2, 5.), pump);//sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n} " + }, "screenshotURL": "data/images/images-9euw21i8xyxawksol-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oEaayNGujJaMMkRSu/art.json b/art/oEaayNGujJaMMkRSu/art.json index 2d0674ec..7d703d32 100644 --- a/art/oEaayNGujJaMMkRSu/art.json +++ b/art/oEaayNGujJaMMkRSu/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "watermeloon", "avatarUrl": "https://secure.gravatar.com/avatar/e0a1c061d10e360fcf5646229dd6e29a?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/drumandbassarena/azifm-corkscrew\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9215686274509803,0.984313725490196,0.9176470588235294,1],\"shader\":\"#define RESOLUTION_OF_MY_DISPLAY 2000.0\\n#define PI radians(180.)\\n\\n//6956\\n \\n//X axis rotation\\nmat4 rotateX(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n \\n//Y axis rotation\\nmat4 rotateY(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n//Z axis rotation\\nmat4 rotateZ(float angleInRadians){\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n//returns the evenly distributed points\\nvec4 FIBO(float rad, float id, float sum){\\n\\n \\t//golden angle in radians\\n float phi = PI * (3. - sqrt(5.));\\n\\n \\t// y goes from 1 to -1\\n float y = 1. - (id / (sum - 1.)) * 2.; \\n float radius = sqrt(1. - y * y);\\n\\n float theta = phi * id;\\n\\n float x = cos(theta) * radius;\\n float z = sin(theta) * radius;\\n \\t\\n vec4 point = vec4(x * rad, y * rad, z * rad, 1.);\\n \\n float xz = abs(atan(point.x, point.z) - rad / 2.) / PI;\\n float yy = abs(point.y) * 1.;\\n\\n float snd = texture2D(sound, vec2(mix(0.1, 0.5, xz), yy)).a;\\n \\n point.x *= pow(0.2 + snd, 0.2);\\n point.y *= pow(0.2 + snd, 0.2);\\n point.z *= pow(0.2 + snd, 0.2);\\n \\t\\n \\n return point;\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nvoid main(void){\\n \\n //rotation velocity\\n mat4 rotX = rotateX(time * 0.3);\\n mat4 rotY = rotateY(time * 0.2);\\n mat4 rotZ = rotateZ(time * 0.3);\\n \\n vec4 sphere;\\n float radius = (abs(sin(time * 0.02)) + 0.9) * .8;\\n \\n //initializing the vertices\\n if(mod(vertexId, 3.) == 0.){\\n radius *= 0.7;\\n \\tsphere = FIBO(radius, vertexId, floor(vertexCount / 10.));\\n //rotation of the sphere\\n \\tsphere *= rotX;\\n \\tsphere *= rotY;\\n \\t//sphere *= rotZ;\\n }else if(mod(vertexId, 3.) == 1.){\\n radius *= 0.5;\\n \\tsphere = FIBO(radius, vertexId, floor(vertexCount / 10.));\\n //rotation of the sphere\\n \\t//sphere *= rotX;\\n \\tsphere *= rotY;\\n \\tsphere *= rotZ;\\n }else{\\n radius *= 0.4;\\n sphere = FIBO(radius * 0.6, vertexId, floor(vertexCount / 10.));\\n //rotation of the sphere\\n \\tsphere *= rotX;\\n \\t//sphere *= rotY;\\n \\tsphere *= rotZ;\\n }\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n mat *= inverse(lookAt(eye, target, up));\\n \\n vec4 denorm = mat * sphere;\\n \\n //the sphere\\n gl_Position = denorm;\\n\\n //setting a base point size\\n gl_PointSize = 10.;\\n //adjusting the point size based on the depth\\n //gl_PointSize += pow(radius, 4.) * 600.;\\n //adjustment \\n gl_PointSize *= 0.03; \\n //resolution indipendent\\n gl_PointSize *= resolution.x / RESOLUTION_OF_MY_DISPLAY;\\n \\n vec3 color = mix(vec3(0.5, 0, 0), vec3(0, 0, 0.5), sphere.z * 7.3);\\n v_color = vec4(color, mix(.0, 1., pow(1. * radius * .6 * gl_Position.z, 2.)));\\n v_color.rgb *= v_color.a;\\n\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/drumandbassarena/azifm-corkscrew", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9215686274509803, + 0.984313725490196, + 0.9176470588235294, + 1 + ], + "shader": "#define RESOLUTION_OF_MY_DISPLAY 2000.0\n#define PI radians(180.)\n\n//6956\n \n//X axis rotation\nmat4 rotateX(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n \n//Y axis rotation\nmat4 rotateY(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n//Z axis rotation\nmat4 rotateZ(float angleInRadians){\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n//returns the evenly distributed points\nvec4 FIBO(float rad, float id, float sum){\n\n \t//golden angle in radians\n float phi = PI * (3. - sqrt(5.));\n\n \t// y goes from 1 to -1\n float y = 1. - (id / (sum - 1.)) * 2.; \n float radius = sqrt(1. - y * y);\n\n float theta = phi * id;\n\n float x = cos(theta) * radius;\n float z = sin(theta) * radius;\n \t\n vec4 point = vec4(x * rad, y * rad, z * rad, 1.);\n \n float xz = abs(atan(point.x, point.z) - rad / 2.) / PI;\n float yy = abs(point.y) * 1.;\n\n float snd = texture2D(sound, vec2(mix(0.1, 0.5, xz), yy)).a;\n \n point.x *= pow(0.2 + snd, 0.2);\n point.y *= pow(0.2 + snd, 0.2);\n point.z *= pow(0.2 + snd, 0.2);\n \t\n \n return point;\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nvoid main(void){\n \n //rotation velocity\n mat4 rotX = rotateX(time * 0.3);\n mat4 rotY = rotateY(time * 0.2);\n mat4 rotZ = rotateZ(time * 0.3);\n \n vec4 sphere;\n float radius = (abs(sin(time * 0.02)) + 0.9) * .8;\n \n //initializing the vertices\n if(mod(vertexId, 3.) == 0.){\n radius *= 0.7;\n \tsphere = FIBO(radius, vertexId, floor(vertexCount / 10.));\n //rotation of the sphere\n \tsphere *= rotX;\n \tsphere *= rotY;\n \t//sphere *= rotZ;\n }else if(mod(vertexId, 3.) == 1.){\n radius *= 0.5;\n \tsphere = FIBO(radius, vertexId, floor(vertexCount / 10.));\n //rotation of the sphere\n \t//sphere *= rotX;\n \tsphere *= rotY;\n \tsphere *= rotZ;\n }else{\n radius *= 0.4;\n sphere = FIBO(radius * 0.6, vertexId, floor(vertexCount / 10.));\n //rotation of the sphere\n \tsphere *= rotX;\n \t//sphere *= rotY;\n \tsphere *= rotZ;\n }\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n mat *= inverse(lookAt(eye, target, up));\n \n vec4 denorm = mat * sphere;\n \n //the sphere\n gl_Position = denorm;\n\n //setting a base point size\n gl_PointSize = 10.;\n //adjusting the point size based on the depth\n //gl_PointSize += pow(radius, 4.) * 600.;\n //adjustment \n gl_PointSize *= 0.03; \n //resolution indipendent\n gl_PointSize *= resolution.x / RESOLUTION_OF_MY_DISPLAY;\n \n vec3 color = mix(vec3(0.5, 0, 0), vec3(0, 0, 0.5), sphere.z * 7.3);\n v_color = vec4(color, mix(.0, 1., pow(1. * radius * .6 * gl_Position.z, 2.)));\n v_color.rgb *= v_color.a;\n\n}\n" + }, "screenshotURL": "data/images/images-z3q0env186w8aditu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oG23xNxiPkfCLufzk/art.json b/art/oG23xNxiPkfCLufzk/art.json index e7a80c53..d5b735fc 100644 --- a/art/oG23xNxiPkfCLufzk/art.json +++ b/art/oG23xNxiPkfCLufzk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=TRIANGLES\\n//KVerticesNumber=1000000\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n // mat *= uniformScale(1.);\\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0.2, 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=TRIANGLES\n//KVerticesNumber=1000000\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n // mat *= uniformScale(1.);\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0.2, 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-x8m9efaqldxxkoip3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oJEAooRzirpb8qcPe/art.json b/art/oJEAooRzirpb8qcPe/art.json index 29c47c1d..a071fe37 100644 --- a/art/oJEAooRzirpb8qcPe/art.json +++ b/art/oJEAooRzirpb8qcPe/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.14901960784313725,0.0392156862745098,0.21176470588235294,1],\"shader\":\"/////////////////////////////////////////////////////////////////////\\n/// https://github.com/glslify/glsl-inverse/blob/master/index.glsl //\\n/////////////////////////////////////////////////////////////////////\\n\\nmat3 inverse(mat3 m) {\\n float a00 = m[0][0], a01 = m[0][1], a02 = m[0][2];\\n float a10 = m[1][0], a11 = m[1][1], a12 = m[1][2];\\n float a20 = m[2][0], a21 = m[2][1], a22 = m[2][2];\\n\\n float b01 = a22 * a11 - a12 * a21;\\n float b11 = -a22 * a10 + a12 * a20;\\n float b21 = a21 * a10 - a11 * a20;\\n\\n float det = a00 * b01 + a01 * b11 + a02 * b21;\\n\\n return mat3(b01, (-a22 * a01 + a02 * a21), (a12 * a01 - a02 * a11),\\n b11, (a22 * a00 - a02 * a20), (-a12 * a00 + a02 * a10),\\n b21, (-a21 * a00 + a01 * a20), (a11 * a00 - a01 * a10)) / det;\\n}\\n\\n//////////////////////////////////////////////\\n//// ShaderDough from @tdhooper in \\n//// https://www.shadertoy.com/view/4tc3WB\\n//////////////////////////////////////////////\\n// Disable to see more colour variety\\n#define SEAMLESS_LOOP\\n//#define COLOUR_CYCLE\\n#define PI 3.14159265359\\n#define PHI (1.618033988749895)\\nfloat t;\\n#define saturate(x) clamp(x, 0., 1.)\\n// --------------------------------------------------------\\n// http://www.neilmendoza.com/glsl-rotation-about-an-arbitrary-axis/\\n// --------------------------------------------------------\\nmat3 rotationMatrix(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n\\n return mat3(\\n oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c\\n );\\n}\\n// --------------------------------------------------------\\n// http://math.stackexchange.com/a/897677\\n// --------------------------------------------------------\\nmat3 orientMatrix(vec3 A, vec3 B) {\\n mat3 Fi = mat3(\\n A,\\n (B - dot(A, B) * A) / length(B - dot(A, B) * A),\\n cross(B, A)\\n );\\n mat3 G = mat3(\\n dot(A, B), -length(cross(A, B)), 0,\\n length(cross(A, B)), dot(A, B), 0,\\n 0, 0, 1\\n );\\n return Fi * G * inverse(Fi);\\n}\\n// --------------------------------------------------------\\n// HG_SDF\\n// https://www.shadertoy.com/view/Xs3GRB\\n// --------------------------------------------------------\\n#define GDFVector3 normalize(vec3(1, 1, 1 ))\\n#define GDFVector3b normalize(vec3(-1, -1, -1 ))\\n#define GDFVector4 normalize(vec3(-1, 1, 1))\\n#define GDFVector4b normalize(vec3(-1, -1, 1))\\n#define GDFVector5 normalize(vec3(1, -1, 1))\\n#define GDFVector5b normalize(vec3(1, -1, -1))\\n#define GDFVector6 normalize(vec3(1, 1, -1))\\n#define GDFVector6b normalize(vec3(-1, 1, -1))\\n#define GDFVector7 normalize(vec3(0, 1, PHI+1.))\\n#define GDFVector7b normalize(vec3(0, 1, -PHI-1.))\\n#define GDFVector8 normalize(vec3(0, -1, PHI+1.))\\n#define GDFVector8b normalize(vec3(0, -1, -PHI-1.))\\n#define GDFVector9 normalize(vec3(PHI+1., 0, 1))\\n#define GDFVector9b normalize(vec3(PHI+1., 0, -1))\\n#define GDFVector10 normalize(vec3(-PHI-1., 0, 1))\\n#define GDFVector10b normalize(vec3(-PHI-1., 0, -1))\\n#define GDFVector11 normalize(vec3(1, PHI+1., 0))\\n#define GDFVector11b normalize(vec3(1, -PHI-1., 0))\\n#define GDFVector12 normalize(vec3(-1, PHI+1., 0))\\n#define GDFVector12b normalize(vec3(-1, -PHI-1., 0))\\n#define GDFVector13 normalize(vec3(0, PHI, 1))\\n#define GDFVector13b normalize(vec3(0, PHI, -1))\\n#define GDFVector14 normalize(vec3(0, -PHI, 1))\\n#define GDFVector14b normalize(vec3(0, -PHI, -1))\\n#define GDFVector15 normalize(vec3(1, 0, PHI))\\n#define GDFVector15b normalize(vec3(1, 0, -PHI))\\n#define GDFVector16 normalize(vec3(-1, 0, PHI))\\n#define GDFVector16b normalize(vec3(-1, 0, -PHI))\\n#define GDFVector17 normalize(vec3(PHI, 1, 0))\\n#define GDFVector17b normalize(vec3(PHI, -1, 0))\\n#define GDFVector18 normalize(vec3(-PHI, 1, 0))\\n#define GDFVector18b normalize(vec3(-PHI, -1, 0))\\n#define fGDFBegin float d = 0.;\\n// Version with variable exponent.\\n// This is slow and does not produce correct distances, but allows for bulging of objects.\\n#define fGDFExp(v) d += pow(abs(dot(p, v)), e);\\n// Version with without exponent, creates objects with sharp edges and flat faces\\n#define fGDF(v) d = max(d, abs(dot(p, v)));\\n#define fGDFExpEnd return pow(d, 1./e) - r;\\n#define fGDFEnd return d - r;\\n// Primitives follow:\\nfloat fDodecahedron(vec3 p, float r) {\\n fGDFBegin\\n fGDF(GDFVector13) fGDF(GDFVector14) fGDF(GDFVector15) fGDF(GDFVector16)\\n fGDF(GDFVector17) fGDF(GDFVector18)\\n fGDFEnd\\n}\\nfloat fIcosahedron(vec3 p, float r) {\\n fGDFBegin\\n fGDF(GDFVector3) fGDF(GDFVector4) fGDF(GDFVector5) fGDF(GDFVector6)\\n fGDF(GDFVector7) fGDF(GDFVector8) fGDF(GDFVector9) fGDF(GDFVector10)\\n fGDF(GDFVector11) fGDF(GDFVector12)\\n fGDFEnd\\n}\\nfloat vmax(vec3 v) {\\n return max(max(v.x, v.y), v.z);\\n}\\nfloat sgn(float x) {\\n\\treturn (x<0.)?-1.:1.;\\n}\\n// Plane with normal n (n is normalized) at some distance from the origin\\nfloat fPlane(vec3 p, vec3 n, float distanceFromOrigin) {\\n return dot(p, n) + distanceFromOrigin;\\n}\\n\\n// Box: correct distance to corners\\nfloat fBox(vec3 p, vec3 b) {\\n\\tvec3 d = abs(p) - b;\\n\\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\\n}\\n// Distance to line segment between and , used for fCapsule() version 2below\\nfloat fLineSegment(vec3 p, vec3 a, vec3 b) {\\n\\tvec3 ab = b - a;\\n\\tfloat t = saturate(dot(p - a, ab) / dot(ab, ab));\\n\\treturn length((ab*t + a) - p);\\n}\\n// Capsule version 2: between two end points and with radius r \\nfloat fCapsule(vec3 p, vec3 a, vec3 b, float r) {\\n\\treturn fLineSegment(p, a, b) - r;\\n}\\n// Rotate around a coordinate axis (i.e. in a plane perpendicular to that axis) by angle .\\n// Read like this: R(p.xz, a) rotates \\\"x towards z\\\".\\n// This is fast if is a compile-time constant and slower (but still practical) if not.\\nvoid pR(inout vec2 p, float a) {\\n p = cos(a)*p + sin(a)*vec2(p.y, -p.x);\\n}\\n// Reflect space at a plane\\nfloat pReflect(inout vec3 p, vec3 planeNormal, float offset) {\\n float t = dot(p, planeNormal)+offset;\\n if (t < 0.) {\\n p = p - (2.*t)*planeNormal;\\n }\\n return sign(t);\\n}\\n// Repeat around the origin by a fixed angle.\\n// For easier use, num of repetitions is use to specify the angle.\\nfloat pModPolar(inout vec2 p, float repetitions) {\\n\\tfloat angle = 2.*PI/repetitions;\\n\\tfloat a = atan(p.y, p.x) + angle/2.;\\n\\tfloat r = length(p);\\n\\tfloat c = floor(a/angle);\\n\\ta = mod(a,angle) - angle/2.;\\n\\tp = vec2(cos(a), sin(a))*r;\\n\\t// For an odd number of repetitions, fix cell index of the cell in -x direction\\n\\t// (cell index would be e.g. -5 and 5 in the two halves of the cell):\\n\\tif (abs(c) >= (repetitions/2.)) c = abs(c);\\n\\treturn c;\\n}\\n// Repeat around an axis\\nvoid pModPolar(inout vec3 p, vec3 axis, float repetitions, float offset) {\\n vec3 z = vec3(0,0,1);\\n\\tmat3 m = orientMatrix(axis, z);\\n p *= inverse(m);\\n pR(p.xy, offset);\\n pModPolar(p.xy, repetitions);\\n pR(p.xy, -offset);\\n p *= m;\\n}\\n// --------------------------------------------------------\\n// knighty\\n// https://www.shadertoy.com/view/MsKGzw\\n// --------------------------------------------------------\\nint Type=5;\\nvec3 nc;\\nvec3 pbc;\\nvec3 pca;\\nvoid initIcosahedron() {//setup folding planes and vertex\\n float cospin=cos(PI/float(Type)), scospin=sqrt(0.75-cospin*cospin);\\n nc=vec3(-0.5,-cospin,scospin);//3rd folding plane. The two others are xz and yz planes\\n\\tpbc=vec3(scospin,0.,0.5);//No normalization in order to have 'barycentric' coordinates work evenly\\n\\tpca=vec3(0.,scospin,cospin);\\n\\tpbc=normalize(pbc);\\tpca=normalize(pca);//for slightly better DE. In reality it's not necesary to apply normalization :) \\n\\n}\\nvoid pModIcosahedron(inout vec3 p) {\\n p = abs(p);\\n pReflect(p, nc, 0.);\\n p.xy = abs(p.xy);\\n pReflect(p, nc, 0.);\\n p.xy = abs(p.xy);\\n pReflect(p, nc, 0.);\\n}\\nfloat indexSgn(float s) {\\n\\treturn s / 2. + 0.5;\\n}\\nbool boolSgn(float s) {\\n\\treturn bool(s / 2. + 0.5);\\n}\\nfloat pModIcosahedronIndexed(inout vec3 p, int subdivisions) {\\n\\tfloat x = indexSgn(sgn(p.x));\\n\\tfloat y = indexSgn(sgn(p.y));\\n\\tfloat z = indexSgn(sgn(p.z));\\n p = abs(p);\\n\\tpReflect(p, nc, 0.);\\n\\n\\tfloat xai = sgn(p.x);\\n\\tfloat yai = sgn(p.y);\\n p.xy = abs(p.xy);\\n\\tfloat sideBB = pReflect(p, nc, 0.);\\n\\n\\tfloat ybi = sgn(p.y);\\n\\tfloat xbi = sgn(p.x);\\n p.xy = abs(p.xy);\\n\\tpReflect(p, nc, 0.);\\n \\n float idx = 0.;\\n\\n float faceGroupAi = indexSgn(ybi * yai * -1.);\\n float faceGroupBi = indexSgn(yai);\\n float faceGroupCi = clamp((xai - ybi -1.), 0., 1.);\\n float faceGroupDi = clamp(1. - faceGroupAi - faceGroupBi - faceGroupCi, 0., 1.);\\n\\n idx += faceGroupAi * (x + (2. * y) + (4. * z));\\n idx += faceGroupBi * (8. + y + (2. * z));\\n # ifndef SEAMLESS_LOOP\\n \\tidx += faceGroupCi * (12. + x + (2. * z));\\n # endif\\n idx += faceGroupDi * (12. + x + (2. * y));\\n\\n\\treturn idx;\\n}\\n// --------------------------------------------------------\\n// IQ\\n// https://www.shadertoy.com/view/ll2GD3\\n// --------------------------------------------------------\\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\\n return a + b*cos( 6.28318*(c*t+d) );\\n}\\n\\nvec3 spectrum(float n) {\\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\\n}\\n// --------------------------------------------------------\\n// tdhooper\\n// https://www.shadertoy.com/view/Mtc3RX\\n// --------------------------------------------------------\\nvec3 vMin(vec3 p, vec3 a, vec3 b, vec3 c) {\\n float la = length(p - a);\\n float lb = length(p - b);\\n float lc = length(p - c);\\n if (la < lb) {\\n if (la < lc) {\\n return a;\\n } else {\\n return c;\\n }\\n } else {\\n if (lb < lc) {\\n return b;\\n } else {\\n return c;\\n }\\n }\\n}\\nvec3 icosahedronVertex(vec3 p) {\\n if (p.z > 0.) {\\n if (p.x > 0.) {\\n if (p.y > 0.) {\\n return vMin(p, GDFVector13, GDFVector15, GDFVector17);\\n } else {\\n return vMin(p, GDFVector14, GDFVector15, GDFVector17b);\\n }\\n } else {\\n if (p.y > 0.) {\\n return vMin(p, GDFVector13, GDFVector16, GDFVector18);\\n } else {\\n return vMin(p, GDFVector14, GDFVector16, GDFVector18b);\\n }\\n }\\n } else {\\n if (p.x > 0.) {\\n if (p.y > 0.) {\\n return vMin(p, GDFVector13b, GDFVector15b, GDFVector17);\\n } else {\\n return vMin(p, GDFVector14b, GDFVector15b, GDFVector17b);\\n }\\n } else {\\n if (p.y > 0.) {\\n return vMin(p, GDFVector13b, GDFVector16b, GDFVector18);\\n } else {\\n return vMin(p, GDFVector14b, GDFVector16b, GDFVector18b);\\n }\\n }\\n }\\n}\\nvec4 icosahedronAxisDistance(vec3 p) {\\n vec3 iv = icosahedronVertex(p);\\n vec3 originalIv = iv;\\n\\n vec3 pn = normalize(p);\\n pModIcosahedron(pn);\\n pModIcosahedron(iv);\\n\\n float boundryDist = dot(pn, vec3(1, 0, 0));\\n float boundryMax = dot(iv, vec3(1, 0, 0));\\n boundryDist /= boundryMax;\\n\\n float roundDist = length(iv - pn);\\n float roundMax = length(iv - vec3(0, 0, 1.));\\n roundDist /= roundMax;\\n roundDist = -roundDist + 1.;\\n\\n float blend = 1. - boundryDist;\\n\\tblend = pow(blend, 6.);\\n \\n float dist = mix(roundDist, boundryDist, blend);\\n\\n return vec4(originalIv, dist);\\n}\\nvoid pTwistIcosahedron(inout vec3 p, float amount) {\\n vec4 a = icosahedronAxisDistance(p);\\n vec3 axis = a.xyz;\\n float dist = a.a;\\n mat3 m = rotationMatrix(axis, dist * amount);\\n p *= m;\\n}\\nstruct Model {\\n float dist;\\n vec3 colour;\\n float id;\\n};\\nModel fInflatedIcosahedron(vec3 p, vec3 axis) {\\n float d = 1000.;\\n \\n # ifdef SEAMLESS_LOOP\\n \\t// Radially repeat along the rotation axis, so the\\n \\t// colours repeat more frequently and we can use\\n \\t// less frames for a seamless loop\\n \\tpModPolar(p, axis, 3., PI/2.);\\n\\t# endif\\n \\n // Slightly inflated icosahedron\\n float idx = pModIcosahedronIndexed(p, 0);\\n d = min(d, dot(p, pca) - .9);\\n d = mix(d, length(p) - .9, .5);\\n\\n // Colour each icosahedron face differently\\n # ifdef SEAMLESS_LOOP\\n \\tif (idx == 3.) {\\n \\t\\tidx = 2.;\\n \\t}\\n \\tidx /= 10.;\\n \\t# else\\n \\tidx /= 20.;\\n # endif\\n # ifdef COLOUR_CYCLE\\n \\tidx = mod(idx + t*1.75, 1.);\\n # endif\\n vec3 colour = floor(spectrum(idx) * 6.) / 6. ;\\n \\n d *= .6;\\n\\treturn Model(d, colour, 1.);\\n}\\nvoid pTwistIcosahedron(inout vec3 p, vec3 center, float amount) {\\n p += center;\\n pTwistIcosahedron(p, 5.5);\\n p -= center;\\n}\\nModel model(vec3 p) {\\n float rate = PI/6.;\\n vec3 axis = pca;\\n\\n vec3 twistCenter = vec3(0);\\n twistCenter.x = cos(t * rate * -3.) * .3;\\n\\ttwistCenter.y = sin(t * rate * -3.) * .3;\\n\\n\\tmat3 m = rotationMatrix(\\n reflect(axis, vec3(0,1,0)),\\n t * -rate\\n \\t);\\n p *= m;\\n twistCenter *= m;\\n\\n pTwistIcosahedron(p, twistCenter, 5.5);\\n\\n\\treturn fInflatedIcosahedron(p, axis);\\n}\\n// The MINIMIZED version of https://www.shadertoy.com/view/Xl2XWt\\nconst float MAX_TRACE_DISTANCE = 30.0; // max trace distance\\nconst float INTERSECTION_PRECISION = 0.001; // precision of the intersection\\nconst int NUM_OF_TRACE_STEPS = 100;\\nvec2 opU( vec2 d1, vec2 d2 ){\\n return (d1.x abs(uv.y)) uv.y -= (uv.x - abs(uv.y))*s;\\n if (-uv.x > abs(uv.y)) uv.y -= (uv.x + abs(uv.y))*s;\\n if ( uv.y > abs(uv.x)) uv.x -= (uv.y - abs(uv.x))*s;\\n if (-uv.y > abs(uv.x)) uv.x -= (uv.y + abs(uv.x))*s;\\n return normalize(vec3(uv , 0.8*(1.0-pow(max(abs(uv.x),abs(uv.y)),2.0)) *s));\\n}\\n\\n//////////////////////////////////////////////\\n//////////////////////////////////////////////\\n//////////////////////////////////////////////\\n\\nvec3 getPoint(float vId)\\n{\\n\\tvec3 p = meshSqhere(vertexId);\\n\\t\\n\\tfloat d = 0.;\\n\\tvec3 rd = normalize(p);\\n\\tvec3 ro = rd * -3.;\\n\\tfor (int i=0;i<5;i++)\\n\\t{\\n\\t\\td += map(ro + rd * d).dist;\\n\\t}\\n\\t\\n\\treturn ro + rd * d;\\n}\\n\\nvec3 getNormal( vec3 p, float prec )\\n{\\n vec2 e = vec2( prec, 0. );\\n vec3 n = vec3(\\n map(p+e.xyy).dist - map(p-e.xyy).dist,\\n map(p+e.yxy).dist - map(p-e.yxy).dist,\\n map(p+e.yyx).dist - map(p-e.yyx).dist );\\n return normalize(n);\\n}\\n\\nvoid main() \\n{\\n\\tinitIcosahedron();\\n t = time * 0.8;\\n \\t//t = 0.;\\n \\n vec3 p = getPoint(vertexId);\\n\\t\\n \\tvec3 ro = vec3(0,0,-3.);\\n float d = length(ro-p);\\n\\t\\n \\tgl_PointSize = 3.;//8.-d;\\n \\n\\tvec3 rd = vec3(0,0,-1.);\\n\\tvec3 ld = normalize(vec3(1.,0,-1.));\\n\\tvec3 n = getNormal(p, 0.0001);\\n\\tfloat sd = map(p + n).dist;\\n\\t\\n\\tfloat diff = max(dot(n, ld), 0.);\\n float spec = pow(max(dot( reflect(-ld, n), rd), 0.), 2.); \\n\\tvec3 col = map(p).colour * 0.8 + diff * 0.2 + spec * 0.8;\\n \\tcol /= sd;\\n\\t\\n \\tfloat screenZ = -0.;\\n\\tfloat eyeZ = -4.5;\\n\\tp.xy *= (eyeZ - screenZ) / (p.z - eyeZ);\\n\\tp.x /= resolution.x / resolution.y;\\n \\n\\tgl_Position = vec4(p, 1);\\n \\t\\n \\t//v_color = vec4(0.);\\n //if (p.z < 0.)\\n\\t \\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.14901960784313725, + 0.0392156862745098, + 0.21176470588235294, + 1 + ], + "shader": "/////////////////////////////////////////////////////////////////////\n/// https://github.com/glslify/glsl-inverse/blob/master/index.glsl //\n/////////////////////////////////////////////////////////////////////\n\nmat3 inverse(mat3 m) {\n float a00 = m[0][0], a01 = m[0][1], a02 = m[0][2];\n float a10 = m[1][0], a11 = m[1][1], a12 = m[1][2];\n float a20 = m[2][0], a21 = m[2][1], a22 = m[2][2];\n\n float b01 = a22 * a11 - a12 * a21;\n float b11 = -a22 * a10 + a12 * a20;\n float b21 = a21 * a10 - a11 * a20;\n\n float det = a00 * b01 + a01 * b11 + a02 * b21;\n\n return mat3(b01, (-a22 * a01 + a02 * a21), (a12 * a01 - a02 * a11),\n b11, (a22 * a00 - a02 * a20), (-a12 * a00 + a02 * a10),\n b21, (-a21 * a00 + a01 * a20), (a11 * a00 - a01 * a10)) / det;\n}\n\n//////////////////////////////////////////////\n//// ShaderDough from @tdhooper in \n//// https://www.shadertoy.com/view/4tc3WB\n//////////////////////////////////////////////\n// Disable to see more colour variety\n#define SEAMLESS_LOOP\n//#define COLOUR_CYCLE\n#define PI 3.14159265359\n#define PHI (1.618033988749895)\nfloat t;\n#define saturate(x) clamp(x, 0., 1.)\n// --------------------------------------------------------\n// http://www.neilmendoza.com/glsl-rotation-about-an-arbitrary-axis/\n// --------------------------------------------------------\nmat3 rotationMatrix(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n\n return mat3(\n oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c\n );\n}\n// --------------------------------------------------------\n// http://math.stackexchange.com/a/897677\n// --------------------------------------------------------\nmat3 orientMatrix(vec3 A, vec3 B) {\n mat3 Fi = mat3(\n A,\n (B - dot(A, B) * A) / length(B - dot(A, B) * A),\n cross(B, A)\n );\n mat3 G = mat3(\n dot(A, B), -length(cross(A, B)), 0,\n length(cross(A, B)), dot(A, B), 0,\n 0, 0, 1\n );\n return Fi * G * inverse(Fi);\n}\n// --------------------------------------------------------\n// HG_SDF\n// https://www.shadertoy.com/view/Xs3GRB\n// --------------------------------------------------------\n#define GDFVector3 normalize(vec3(1, 1, 1 ))\n#define GDFVector3b normalize(vec3(-1, -1, -1 ))\n#define GDFVector4 normalize(vec3(-1, 1, 1))\n#define GDFVector4b normalize(vec3(-1, -1, 1))\n#define GDFVector5 normalize(vec3(1, -1, 1))\n#define GDFVector5b normalize(vec3(1, -1, -1))\n#define GDFVector6 normalize(vec3(1, 1, -1))\n#define GDFVector6b normalize(vec3(-1, 1, -1))\n#define GDFVector7 normalize(vec3(0, 1, PHI+1.))\n#define GDFVector7b normalize(vec3(0, 1, -PHI-1.))\n#define GDFVector8 normalize(vec3(0, -1, PHI+1.))\n#define GDFVector8b normalize(vec3(0, -1, -PHI-1.))\n#define GDFVector9 normalize(vec3(PHI+1., 0, 1))\n#define GDFVector9b normalize(vec3(PHI+1., 0, -1))\n#define GDFVector10 normalize(vec3(-PHI-1., 0, 1))\n#define GDFVector10b normalize(vec3(-PHI-1., 0, -1))\n#define GDFVector11 normalize(vec3(1, PHI+1., 0))\n#define GDFVector11b normalize(vec3(1, -PHI-1., 0))\n#define GDFVector12 normalize(vec3(-1, PHI+1., 0))\n#define GDFVector12b normalize(vec3(-1, -PHI-1., 0))\n#define GDFVector13 normalize(vec3(0, PHI, 1))\n#define GDFVector13b normalize(vec3(0, PHI, -1))\n#define GDFVector14 normalize(vec3(0, -PHI, 1))\n#define GDFVector14b normalize(vec3(0, -PHI, -1))\n#define GDFVector15 normalize(vec3(1, 0, PHI))\n#define GDFVector15b normalize(vec3(1, 0, -PHI))\n#define GDFVector16 normalize(vec3(-1, 0, PHI))\n#define GDFVector16b normalize(vec3(-1, 0, -PHI))\n#define GDFVector17 normalize(vec3(PHI, 1, 0))\n#define GDFVector17b normalize(vec3(PHI, -1, 0))\n#define GDFVector18 normalize(vec3(-PHI, 1, 0))\n#define GDFVector18b normalize(vec3(-PHI, -1, 0))\n#define fGDFBegin float d = 0.;\n// Version with variable exponent.\n// This is slow and does not produce correct distances, but allows for bulging of objects.\n#define fGDFExp(v) d += pow(abs(dot(p, v)), e);\n// Version with without exponent, creates objects with sharp edges and flat faces\n#define fGDF(v) d = max(d, abs(dot(p, v)));\n#define fGDFExpEnd return pow(d, 1./e) - r;\n#define fGDFEnd return d - r;\n// Primitives follow:\nfloat fDodecahedron(vec3 p, float r) {\n fGDFBegin\n fGDF(GDFVector13) fGDF(GDFVector14) fGDF(GDFVector15) fGDF(GDFVector16)\n fGDF(GDFVector17) fGDF(GDFVector18)\n fGDFEnd\n}\nfloat fIcosahedron(vec3 p, float r) {\n fGDFBegin\n fGDF(GDFVector3) fGDF(GDFVector4) fGDF(GDFVector5) fGDF(GDFVector6)\n fGDF(GDFVector7) fGDF(GDFVector8) fGDF(GDFVector9) fGDF(GDFVector10)\n fGDF(GDFVector11) fGDF(GDFVector12)\n fGDFEnd\n}\nfloat vmax(vec3 v) {\n return max(max(v.x, v.y), v.z);\n}\nfloat sgn(float x) {\n\treturn (x<0.)?-1.:1.;\n}\n// Plane with normal n (n is normalized) at some distance from the origin\nfloat fPlane(vec3 p, vec3 n, float distanceFromOrigin) {\n return dot(p, n) + distanceFromOrigin;\n}\n\n// Box: correct distance to corners\nfloat fBox(vec3 p, vec3 b) {\n\tvec3 d = abs(p) - b;\n\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\n}\n// Distance to line segment between and , used for fCapsule() version 2below\nfloat fLineSegment(vec3 p, vec3 a, vec3 b) {\n\tvec3 ab = b - a;\n\tfloat t = saturate(dot(p - a, ab) / dot(ab, ab));\n\treturn length((ab*t + a) - p);\n}\n// Capsule version 2: between two end points and with radius r \nfloat fCapsule(vec3 p, vec3 a, vec3 b, float r) {\n\treturn fLineSegment(p, a, b) - r;\n}\n// Rotate around a coordinate axis (i.e. in a plane perpendicular to that axis) by angle .\n// Read like this: R(p.xz, a) rotates \"x towards z\".\n// This is fast if is a compile-time constant and slower (but still practical) if not.\nvoid pR(inout vec2 p, float a) {\n p = cos(a)*p + sin(a)*vec2(p.y, -p.x);\n}\n// Reflect space at a plane\nfloat pReflect(inout vec3 p, vec3 planeNormal, float offset) {\n float t = dot(p, planeNormal)+offset;\n if (t < 0.) {\n p = p - (2.*t)*planeNormal;\n }\n return sign(t);\n}\n// Repeat around the origin by a fixed angle.\n// For easier use, num of repetitions is use to specify the angle.\nfloat pModPolar(inout vec2 p, float repetitions) {\n\tfloat angle = 2.*PI/repetitions;\n\tfloat a = atan(p.y, p.x) + angle/2.;\n\tfloat r = length(p);\n\tfloat c = floor(a/angle);\n\ta = mod(a,angle) - angle/2.;\n\tp = vec2(cos(a), sin(a))*r;\n\t// For an odd number of repetitions, fix cell index of the cell in -x direction\n\t// (cell index would be e.g. -5 and 5 in the two halves of the cell):\n\tif (abs(c) >= (repetitions/2.)) c = abs(c);\n\treturn c;\n}\n// Repeat around an axis\nvoid pModPolar(inout vec3 p, vec3 axis, float repetitions, float offset) {\n vec3 z = vec3(0,0,1);\n\tmat3 m = orientMatrix(axis, z);\n p *= inverse(m);\n pR(p.xy, offset);\n pModPolar(p.xy, repetitions);\n pR(p.xy, -offset);\n p *= m;\n}\n// --------------------------------------------------------\n// knighty\n// https://www.shadertoy.com/view/MsKGzw\n// --------------------------------------------------------\nint Type=5;\nvec3 nc;\nvec3 pbc;\nvec3 pca;\nvoid initIcosahedron() {//setup folding planes and vertex\n float cospin=cos(PI/float(Type)), scospin=sqrt(0.75-cospin*cospin);\n nc=vec3(-0.5,-cospin,scospin);//3rd folding plane. The two others are xz and yz planes\n\tpbc=vec3(scospin,0.,0.5);//No normalization in order to have 'barycentric' coordinates work evenly\n\tpca=vec3(0.,scospin,cospin);\n\tpbc=normalize(pbc);\tpca=normalize(pca);//for slightly better DE. In reality it's not necesary to apply normalization :) \n\n}\nvoid pModIcosahedron(inout vec3 p) {\n p = abs(p);\n pReflect(p, nc, 0.);\n p.xy = abs(p.xy);\n pReflect(p, nc, 0.);\n p.xy = abs(p.xy);\n pReflect(p, nc, 0.);\n}\nfloat indexSgn(float s) {\n\treturn s / 2. + 0.5;\n}\nbool boolSgn(float s) {\n\treturn bool(s / 2. + 0.5);\n}\nfloat pModIcosahedronIndexed(inout vec3 p, int subdivisions) {\n\tfloat x = indexSgn(sgn(p.x));\n\tfloat y = indexSgn(sgn(p.y));\n\tfloat z = indexSgn(sgn(p.z));\n p = abs(p);\n\tpReflect(p, nc, 0.);\n\n\tfloat xai = sgn(p.x);\n\tfloat yai = sgn(p.y);\n p.xy = abs(p.xy);\n\tfloat sideBB = pReflect(p, nc, 0.);\n\n\tfloat ybi = sgn(p.y);\n\tfloat xbi = sgn(p.x);\n p.xy = abs(p.xy);\n\tpReflect(p, nc, 0.);\n \n float idx = 0.;\n\n float faceGroupAi = indexSgn(ybi * yai * -1.);\n float faceGroupBi = indexSgn(yai);\n float faceGroupCi = clamp((xai - ybi -1.), 0., 1.);\n float faceGroupDi = clamp(1. - faceGroupAi - faceGroupBi - faceGroupCi, 0., 1.);\n\n idx += faceGroupAi * (x + (2. * y) + (4. * z));\n idx += faceGroupBi * (8. + y + (2. * z));\n # ifndef SEAMLESS_LOOP\n \tidx += faceGroupCi * (12. + x + (2. * z));\n # endif\n idx += faceGroupDi * (12. + x + (2. * y));\n\n\treturn idx;\n}\n// --------------------------------------------------------\n// IQ\n// https://www.shadertoy.com/view/ll2GD3\n// --------------------------------------------------------\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\n return a + b*cos( 6.28318*(c*t+d) );\n}\n\nvec3 spectrum(float n) {\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\n}\n// --------------------------------------------------------\n// tdhooper\n// https://www.shadertoy.com/view/Mtc3RX\n// --------------------------------------------------------\nvec3 vMin(vec3 p, vec3 a, vec3 b, vec3 c) {\n float la = length(p - a);\n float lb = length(p - b);\n float lc = length(p - c);\n if (la < lb) {\n if (la < lc) {\n return a;\n } else {\n return c;\n }\n } else {\n if (lb < lc) {\n return b;\n } else {\n return c;\n }\n }\n}\nvec3 icosahedronVertex(vec3 p) {\n if (p.z > 0.) {\n if (p.x > 0.) {\n if (p.y > 0.) {\n return vMin(p, GDFVector13, GDFVector15, GDFVector17);\n } else {\n return vMin(p, GDFVector14, GDFVector15, GDFVector17b);\n }\n } else {\n if (p.y > 0.) {\n return vMin(p, GDFVector13, GDFVector16, GDFVector18);\n } else {\n return vMin(p, GDFVector14, GDFVector16, GDFVector18b);\n }\n }\n } else {\n if (p.x > 0.) {\n if (p.y > 0.) {\n return vMin(p, GDFVector13b, GDFVector15b, GDFVector17);\n } else {\n return vMin(p, GDFVector14b, GDFVector15b, GDFVector17b);\n }\n } else {\n if (p.y > 0.) {\n return vMin(p, GDFVector13b, GDFVector16b, GDFVector18);\n } else {\n return vMin(p, GDFVector14b, GDFVector16b, GDFVector18b);\n }\n }\n }\n}\nvec4 icosahedronAxisDistance(vec3 p) {\n vec3 iv = icosahedronVertex(p);\n vec3 originalIv = iv;\n\n vec3 pn = normalize(p);\n pModIcosahedron(pn);\n pModIcosahedron(iv);\n\n float boundryDist = dot(pn, vec3(1, 0, 0));\n float boundryMax = dot(iv, vec3(1, 0, 0));\n boundryDist /= boundryMax;\n\n float roundDist = length(iv - pn);\n float roundMax = length(iv - vec3(0, 0, 1.));\n roundDist /= roundMax;\n roundDist = -roundDist + 1.;\n\n float blend = 1. - boundryDist;\n\tblend = pow(blend, 6.);\n \n float dist = mix(roundDist, boundryDist, blend);\n\n return vec4(originalIv, dist);\n}\nvoid pTwistIcosahedron(inout vec3 p, float amount) {\n vec4 a = icosahedronAxisDistance(p);\n vec3 axis = a.xyz;\n float dist = a.a;\n mat3 m = rotationMatrix(axis, dist * amount);\n p *= m;\n}\nstruct Model {\n float dist;\n vec3 colour;\n float id;\n};\nModel fInflatedIcosahedron(vec3 p, vec3 axis) {\n float d = 1000.;\n \n # ifdef SEAMLESS_LOOP\n \t// Radially repeat along the rotation axis, so the\n \t// colours repeat more frequently and we can use\n \t// less frames for a seamless loop\n \tpModPolar(p, axis, 3., PI/2.);\n\t# endif\n \n // Slightly inflated icosahedron\n float idx = pModIcosahedronIndexed(p, 0);\n d = min(d, dot(p, pca) - .9);\n d = mix(d, length(p) - .9, .5);\n\n // Colour each icosahedron face differently\n # ifdef SEAMLESS_LOOP\n \tif (idx == 3.) {\n \t\tidx = 2.;\n \t}\n \tidx /= 10.;\n \t# else\n \tidx /= 20.;\n # endif\n # ifdef COLOUR_CYCLE\n \tidx = mod(idx + t*1.75, 1.);\n # endif\n vec3 colour = floor(spectrum(idx) * 6.) / 6. ;\n \n d *= .6;\n\treturn Model(d, colour, 1.);\n}\nvoid pTwistIcosahedron(inout vec3 p, vec3 center, float amount) {\n p += center;\n pTwistIcosahedron(p, 5.5);\n p -= center;\n}\nModel model(vec3 p) {\n float rate = PI/6.;\n vec3 axis = pca;\n\n vec3 twistCenter = vec3(0);\n twistCenter.x = cos(t * rate * -3.) * .3;\n\ttwistCenter.y = sin(t * rate * -3.) * .3;\n\n\tmat3 m = rotationMatrix(\n reflect(axis, vec3(0,1,0)),\n t * -rate\n \t);\n p *= m;\n twistCenter *= m;\n\n pTwistIcosahedron(p, twistCenter, 5.5);\n\n\treturn fInflatedIcosahedron(p, axis);\n}\n// The MINIMIZED version of https://www.shadertoy.com/view/Xl2XWt\nconst float MAX_TRACE_DISTANCE = 30.0; // max trace distance\nconst float INTERSECTION_PRECISION = 0.001; // precision of the intersection\nconst int NUM_OF_TRACE_STEPS = 100;\nvec2 opU( vec2 d1, vec2 d2 ){\n return (d1.x abs(uv.y)) uv.y -= (uv.x - abs(uv.y))*s;\n if (-uv.x > abs(uv.y)) uv.y -= (uv.x + abs(uv.y))*s;\n if ( uv.y > abs(uv.x)) uv.x -= (uv.y - abs(uv.x))*s;\n if (-uv.y > abs(uv.x)) uv.x -= (uv.y + abs(uv.x))*s;\n return normalize(vec3(uv , 0.8*(1.0-pow(max(abs(uv.x),abs(uv.y)),2.0)) *s));\n}\n\n//////////////////////////////////////////////\n//////////////////////////////////////////////\n//////////////////////////////////////////////\n\nvec3 getPoint(float vId)\n{\n\tvec3 p = meshSqhere(vertexId);\n\t\n\tfloat d = 0.;\n\tvec3 rd = normalize(p);\n\tvec3 ro = rd * -3.;\n\tfor (int i=0;i<5;i++)\n\t{\n\t\td += map(ro + rd * d).dist;\n\t}\n\t\n\treturn ro + rd * d;\n}\n\nvec3 getNormal( vec3 p, float prec )\n{\n vec2 e = vec2( prec, 0. );\n vec3 n = vec3(\n map(p+e.xyy).dist - map(p-e.xyy).dist,\n map(p+e.yxy).dist - map(p-e.yxy).dist,\n map(p+e.yyx).dist - map(p-e.yyx).dist );\n return normalize(n);\n}\n\nvoid main() \n{\n\tinitIcosahedron();\n t = time * 0.8;\n \t//t = 0.;\n \n vec3 p = getPoint(vertexId);\n\t\n \tvec3 ro = vec3(0,0,-3.);\n float d = length(ro-p);\n\t\n \tgl_PointSize = 3.;//8.-d;\n \n\tvec3 rd = vec3(0,0,-1.);\n\tvec3 ld = normalize(vec3(1.,0,-1.));\n\tvec3 n = getNormal(p, 0.0001);\n\tfloat sd = map(p + n).dist;\n\t\n\tfloat diff = max(dot(n, ld), 0.);\n float spec = pow(max(dot( reflect(-ld, n), rd), 0.), 2.); \n\tvec3 col = map(p).colour * 0.8 + diff * 0.2 + spec * 0.8;\n \tcol /= sd;\n\t\n \tfloat screenZ = -0.;\n\tfloat eyeZ = -4.5;\n\tp.xy *= (eyeZ - screenZ) / (p.z - eyeZ);\n\tp.x /= resolution.x / resolution.y;\n \n\tgl_Position = vec4(p, 1);\n \t\n \t//v_color = vec4(0.);\n //if (p.z < 0.)\n\t \tv_color = vec4(clamp(col,0.,1.), 1);\n}" + }, "screenshotURL": "data/images/images-h1gh8djesgxas9aba-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/oJQe4ewvBJqv3RxZX/art.json b/art/oJQe4ewvBJqv3RxZX/art.json index 38ef3f03..8a9122d6 100644 --- a/art/oJQe4ewvBJqv3RxZX/art.json +++ b/art/oJQe4ewvBJqv3RxZX/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":33957,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_FAN\\n//KVerticesNumber=30000\\n#define KP0 11. / sin(time +mouse.x)\\nvec3 gSunColor = vec3(1.4, 1.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 1.1, 1.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 1.15, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.93;\\n#define MOVE_OUTWARDS\\n\\n\\nfloat gCubeColorRandom = 2.0;\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( \\t22.0, 40.3, -1.4 +KP0) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 3.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.15 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 12.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 6.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 1.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock)-2.0;\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 1.;\\n float z = vP * down * 1.4 + bzId * 0.2;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.16, 1.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\\n float ca = 0.004;\\n \\n // get sick!\\n ca = time * 0.51;\\n \\tvec3 vCameraUp = vec3( sin(ca), time *0.3, cos(ca) );\\n // \\tvec3 vCameraUp = vec3( 0, 0, 1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount )-1.;\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, (.1), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 0.5);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(0.7) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.5), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 33957, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_FAN\n//KVerticesNumber=30000\n#define KP0 11. / sin(time +mouse.x)\nvec3 gSunColor = vec3(1.4, 1.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 1.1, 1.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 1.15, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.93;\n#define MOVE_OUTWARDS\n\n\nfloat gCubeColorRandom = 2.0;\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( \t22.0, 40.3, -1.4 +KP0) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 3.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.15 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 12.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 6.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 1.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock)-2.0;\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 1.;\n float z = vP * down * 1.4 + bzId * 0.2;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0.16, 1.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\n float ca = 0.004;\n \n // get sick!\n ca = time * 0.51;\n \tvec3 vCameraUp = vec3( sin(ca), time *0.3, cos(ca) );\n // \tvec3 vCameraUp = vec3( 0, 0, 1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount )-1.;\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, (.1), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 0.5);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(0.7) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.5), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-q99r6x1p4bwn9y5dr-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oJdntdCZF5fpa95wk/art.json b/art/oJdntdCZF5fpa95wk/art.json index 9213dec3..c8a6fa76 100644 --- a/art/oJdntdCZF5fpa95wk/art.json +++ b/art/oJdntdCZF5fpa95wk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "wooknick", "avatarUrl": "https://avatars.githubusercontent.com/wooknick?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.7803921568627451,0.9882352941176471,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, 1.0);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.7803921568627451, + 0.9882352941176471, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, 1.0);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-r212odmwyt84rz3cq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/oLoR8sPXf6aPStvw8/art.json b/art/oLoR8sPXf6aPStvw8/art.json index 0cd64051..29cfaf06 100644 --- a/art/oLoR8sPXf6aPStvw8/art.json +++ b/art/oLoR8sPXf6aPStvw8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":19339,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 19339, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-ftnn49a7ol7iobtiq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oMwCvkkRyEiZkio4h/art.json b/art/oMwCvkkRyEiZkio4h/art.json index fbf4334b..3e25b557 100644 --- a/art/oMwCvkkRyEiZkio4h/art.json +++ b/art/oMwCvkkRyEiZkio4h/art.json @@ -11,7 +11,19 @@ "origId": "nL6YpkW8YvGKNEKtj", "name": "point cloud vs spheres", "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.9,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.9,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, 0, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(normalize(ofs))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-iar6a5q4jtsxmf4xw-thumbnail.jpg", "views": { "$numberInt": "182" diff --git a/art/oNxBgiL2gw39fW6DS/art.json b/art/oNxBgiL2gw39fW6DS/art.json index 9762e14f..cf62234f 100644 --- a/art/oNxBgiL2gw39fW6DS/art.json +++ b/art/oNxBgiL2gw39fW6DS/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mipmap", "avatarUrl": "https://secure.gravatar.com/avatar/2840df8e29cba840a5b7f90f66bc66cd?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nvertexshaderart\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b07 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) ;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y)) * 6.;\\n float down = floor(vertexCount / across) * 6.;\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n float c = u;\\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\\n \\n float x = u * 2. - 1.;\\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\\n\\n x += sin(time * 0.04 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\\n\\n float snd = 0.;\\n const int cnt = 8;\\n for (int i = 0; i < cnt; ++i) {\\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\\n }\\n snd /= float(cnt);\\n \\n vec3 p = vec3(x, y, -1.5 + s * 1.);\\n \\n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n m *= rotZ(time * -0.01 + u);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.4 + time * 0.02;\\n float sat = 0.5 + snd;\\n float val = 1. - snd * 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.5 / pow(p.z, 1.4);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/boostmusic/boosttv-004-tk5-slow-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nvertexshaderart\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b07 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) ;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y)) * 6.;\n float down = floor(vertexCount / across) * 6.;\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n float c = u;\n float s = 1. - pow(1. - p1m1(sin(time * 0.2 + c * PI * 2. + PI * 0.5)), 4.);\n s = s * p1m1(sin(u * p1m1(sin(time * 0.111)) * 2.1));\n \n float x = u * 2. - 1.;\n float y = m1p1(fract(v + mix(-1., 1., mod(gx, 2.)) * time * 0.02 * m1p1(1. - u))) * 4.;\n\n x += sin(time * 0.04 + y * (p1m1(sin(time * 0.123)) + 0.1) * 10.) * 0.1;\n\n float snd = 0.;\n const int cnt = 8;\n for (int i = 0; i < cnt; ++i) {\n snd += texture2D(sound, vec2(p1m1(x) * 0.1, float(i) * 3. / soundRes.y + p1m1(sin(PI * 2. * fract(p1m1(y)))))).a;\n }\n snd /= float(cnt);\n \n vec3 p = vec3(x, y, -1.5 + s * 1.);\n \n mat4 m = persp(radians(125.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n m *= rotZ(time * -0.01 + u);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.4 + time * 0.02;\n float sat = 0.5 + snd;\n float val = 1. - snd * 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.5 / pow(p.z, 1.4);\n}\n" + }, "screenshotURL": "data/images/images-8820rb4t44itmoalq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oQwndAmHzdhn3TLGK/art.json b/art/oQwndAmHzdhn3TLGK/art.json index 2e3961ec..81e4ad53 100644 --- a/art/oQwndAmHzdhn3TLGK/art.json +++ b/art/oQwndAmHzdhn3TLGK/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kaoztheory/jamie-jones-new-skool-acid-matthias-tanzmann-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n \\n float su = fract(p.x * 0.0125);\\n float sv = (p.y + 0.5) / soundRes.y;\\n float st = sin(time * 0.01) * 10. * 0.;\\n float su2 = fract(mix(sv * 13.8 + st, (sv + 1.) * 140.8 + st, su * 0.00349));\\n float su3 = mix(0.005, 0.54, su2);\\n float s = 0.;\\n const int count = 8;\\n for (int i = 0; i < count; ++i) {\\n s += texture2D(sound, vec2(su3, (float(i * 1) + 0.5) / soundRes.y)).a * float(count - i);\\n }\\n return pow(s / float((count * (count + 1)) / 2), 0.75);\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off, out vec3 preScale) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n preScale = vec3(ux, 0, vy) + off;\\n vec3 pos = preScale * scale + vec3(0, fbm(preScale.xz), 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float realQuadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD) / 2.;\\n float quadId = mod(realQuadId, numQuads);\\n float totalQuads = numQuads * 2.;\\n float down = soundRes.y;\\n float across = floor(numQuads / down);\\n \\n float secondHalf = step(numQuads, realQuadId);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n vec3 preScale;\\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q, preScale);\\n vec3 n1 = getQuadPoint(nId + 1., s, q, preScale);\\n vec3 n2 = getQuadPoint(nId + 2., s, q, preScale);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q, preScale);\\n p.y *= mix(1.00001, 1.0, secondHalf);\\n p.y -= mix(0.200012, 0.2, secondHalf);\\n \\n\\n float ct = time * 0.1;\\n float ct2 = ct + 2.0;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct) * 3., 1., cos(ct) * 10. + 10.);\\n vec3 cameraTarget = vec3(sin(ct2) * 2., 0, cos(ct2) * 10. + 10.);\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n //m *= rotX(preScale.z * mix(-0.1, -0.5, sin(time * 0.01)));\\n //m *= rotY(preScale.x * mix(-0.1, -0.5, sin(time * 0.011)));\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 1.1 + qu * 0. + pow(p.y, 5.) * 0.5;//1.;m1p1(n.z);\\n float sat = 1.;//pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.25, 1., pow(l, 0.5));\\n \\n sat -= secondHalf * 0.25;\\n hue += secondHalf * 0.52;\\n \\n float punch = step(0.8, p.y);\\n l = mix(l, 1., punch);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs(((preScale.x / across) * 2. - 1.)), 10.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n //v_color = mix(vec4(0, 0, 0, 1), v_color, 1. - secondHalf); \\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kaoztheory/jamie-jones-new-skool-acid-matthias-tanzmann-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n \n float su = fract(p.x * 0.0125);\n float sv = (p.y + 0.5) / soundRes.y;\n float st = sin(time * 0.01) * 10. * 0.;\n float su2 = fract(mix(sv * 13.8 + st, (sv + 1.) * 140.8 + st, su * 0.00349));\n float su3 = mix(0.005, 0.54, su2);\n float s = 0.;\n const int count = 8;\n for (int i = 0; i < count; ++i) {\n s += texture2D(sound, vec2(su3, (float(i * 1) + 0.5) / soundRes.y)).a * float(count - i);\n }\n return pow(s / float((count * (count + 1)) / 2), 0.75);\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off, out vec3 preScale) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n preScale = vec3(ux, 0, vy) + off;\n vec3 pos = preScale * scale + vec3(0, fbm(preScale.xz), 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float realQuadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD) / 2.;\n float quadId = mod(realQuadId, numQuads);\n float totalQuads = numQuads * 2.;\n float down = soundRes.y;\n float across = floor(numQuads / down);\n \n float secondHalf = step(numQuads, realQuadId);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n vec3 preScale;\n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q, preScale);\n vec3 n1 = getQuadPoint(nId + 1., s, q, preScale);\n vec3 n2 = getQuadPoint(nId + 2., s, q, preScale);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q, preScale);\n p.y *= mix(1.00001, 1.0, secondHalf);\n p.y -= mix(0.200012, 0.2, secondHalf);\n \n\n float ct = time * 0.1;\n float ct2 = ct + 2.0;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct) * 3., 1., cos(ct) * 10. + 10.);\n vec3 cameraTarget = vec3(sin(ct2) * 2., 0, cos(ct2) * 10. + 10.);\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n //m *= rotX(preScale.z * mix(-0.1, -0.5, sin(time * 0.01)));\n //m *= rotY(preScale.x * mix(-0.1, -0.5, sin(time * 0.011)));\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 1.1 + qu * 0. + pow(p.y, 5.) * 0.5;//1.;m1p1(n.z);\n float sat = 1.;//pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.25, 1., pow(l, 0.5));\n \n sat -= secondHalf * 0.25;\n hue += secondHalf * 0.52;\n \n float punch = step(0.8, p.y);\n l = mix(l, 1., punch);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs(((preScale.x / across) * 2. - 1.)), 10.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n //v_color = mix(vec4(0, 0, 0, 1), v_color, 1. - secondHalf); \n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-0we6gc1fqi80qd3x5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oQzXFjHPCApgXWGq3/art.json b/art/oQzXFjHPCApgXWGq3/art.json index 9f9cd62f..f87fce6a 100644 --- a/art/oQzXFjHPCApgXWGq3/art.json +++ b/art/oQzXFjHPCApgXWGq3/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":6000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 aspect = mat4(\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 1,\\n 0, 0, 0, 1);\\n\\nmat4 scale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY() {\\n float s = sin(time / 2.);\\n float c = cos(time / 2.);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotX() {\\n float deg = radians((-0.5 * (mouse.y + 1.)) * 360.);\\n float s = sin(deg);\\n float c = cos(deg);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, -s, 0,\\n 0, s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main()\\n{\\n float pointsPerSphere = 1000.;\\n float pointsPerLoop = 10.;\\n \\n float sphereId = floor(vertexId / pointsPerSphere);\\n float spherePointId = mod(vertexId, pointsPerSphere);\\n \\n vec4 center = vec4(sin(sphereId) * 5., cos(sphereId) * 5., 0, 1);\\n \\n float yPos = cos(spherePointId / pointsPerSphere * PI);\\n float xyLen = sin(spherePointId / pointsPerSphere * PI);\\n float xPos = sin(spherePointId / pointsPerLoop) * xyLen;\\n float zPos = cos(spherePointId / pointsPerLoop) * xyLen;\\n \\n vec4 pos = vec4(xPos, yPos, zPos, 1) + center;\\n pos = aspect * scale(0.1) * rotX() * rotY() * pos;\\n gl_Position = pos;\\n gl_PointSize = (-pos.z + 1.) * 4.;\\n v_color = mix(vec4(1, 0, 0, 1), vec4(0, 0, 1, 1), spherePointId / pointsPerSphere);\\n}\"}", + "settings": { + "num": 6000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 aspect = mat4(\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 1,\n 0, 0, 0, 1);\n\nmat4 scale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY() {\n float s = sin(time / 2.);\n float c = cos(time / 2.);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotX() {\n float deg = radians((-0.5 * (mouse.y + 1.)) * 360.);\n float s = sin(deg);\n float c = cos(deg);\n return mat4(\n 1, 0, 0, 0,\n 0, c, -s, 0,\n 0, s, c, 0,\n 0, 0, 0, 1);\n}\n\nvoid main()\n{\n float pointsPerSphere = 1000.;\n float pointsPerLoop = 10.;\n \n float sphereId = floor(vertexId / pointsPerSphere);\n float spherePointId = mod(vertexId, pointsPerSphere);\n \n vec4 center = vec4(sin(sphereId) * 5., cos(sphereId) * 5., 0, 1);\n \n float yPos = cos(spherePointId / pointsPerSphere * PI);\n float xyLen = sin(spherePointId / pointsPerSphere * PI);\n float xPos = sin(spherePointId / pointsPerLoop) * xyLen;\n float zPos = cos(spherePointId / pointsPerLoop) * xyLen;\n \n vec4 pos = vec4(xPos, yPos, zPos, 1) + center;\n pos = aspect * scale(0.1) * rotX() * rotY() * pos;\n gl_Position = pos;\n gl_PointSize = (-pos.z + 1.) * 4.;\n v_color = mix(vec4(1, 0, 0, 1), vec4(0, 0, 1, 1), spherePointId / pointsPerSphere);\n}" + }, "screenshotURL": "data/images/images-er8x7nsxo8aq0bsl7-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/oRdsbtoX2Yngp5jeC/art.json b/art/oRdsbtoX2Yngp5jeC/art.json index 8d5d5876..dcaf54de 100644 --- a/art/oRdsbtoX2Yngp5jeC/art.json +++ b/art/oRdsbtoX2Yngp5jeC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":30914,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 10.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\\n \\n \\n\\n float hue = sz * 3. + s * 0.3;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 30914, + "mode": "POINTS", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 10.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\n \n \n\n float hue = sz * 3. + s * 0.3;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-gtobhr6a4f452mj5t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oX5wEFKffEhvZmeJT/art.json b/art/oX5wEFKffEhvZmeJT/art.json index 0281ff9b..e4de50e3 100644 --- a/art/oX5wEFKffEhvZmeJT/art.json +++ b/art/oX5wEFKffEhvZmeJT/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define POINT_SIZE 5.0\\n\\n#define PI 3.1415\\n\\n#define RESOLUTION vec3(45.0)\\n#define SIZE vec3(2.5)\\n\\n// New hash based on hash13() from \\\"Hash without Sine\\\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\\n// 4 in, 1 out\\nfloat Hash41(in vec4 p) {\\n\\tp = fract(p * 0.1031);\\n p += dot(p, p.zwyx + 31.32);\\n return fract((p.x + p.y) * p.z - p.x * p.w);\\n}\\n\\n\\nfloat SmoothNoise4D(in vec4 p) {\\n vec4 cell = floor(p);\\n vec4 local = fract(p);\\n local *= local * (3.0 - 2.0 * local);\\n\\n float ldbq = Hash41(cell);\\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\\n float rufw = Hash41(cell + 1.0);\\n\\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\\n mix(lubq, rubq, local.x),\\n local.y),\\n\\n mix(mix(ldfq, rdfq, local.x),\\n mix(lufq, rufq, local.x),\\n local.y),\\n\\n local.z),\\n\\n mix(mix(mix(ldbw, rdbw, local.x),\\n mix(lubw, rubw, local.x),\\n local.y),\\n\\n mix(mix(ldfw, rdfw, local.x),\\n mix(lufw, rufw, local.x),\\n local.y),\\n\\n local.z),\\n\\n local.w);\\n}\\n\\nfloat FractalNoise4D(in vec4 p) {\\n p *= 2.0;\\n\\n float nscale = 1.0;\\n float tscale = -0.21;\\n float value = 0.0;\\n\\n for (int octave=0; octave < 5; octave++) {\\n value += SmoothNoise4D(p) * nscale;\\n tscale += nscale;\\n nscale *= 0.5;\\n p *= 1.0;\\n }\\n\\n return value / tscale;\\n}\\n\\nfloat mapShape(vec3 p) {\\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\\n}\\n\\nvec3 mapColor(in vec3 p) {\\n vec3 lightDir = normalize(vec3(-1.0, 1.0, .40));\\n vec2 e = vec2(0.001, 0.0);\\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\\n\\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\\n}\\n\\nvoid main() {\\n float t = time * 0.25;\\n\\n float cellId = vertexId;\\n float gridX = mod(cellId, RESOLUTION.x);\\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\\n\\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\\n vec3 color = mapColor(vertex);\\n\\n vec2 mouseRot = mouse * PI;\\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n vertex.xz *= mat2(cy, sy, -sy, cy);\\n vertex.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.50);\\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\\n v_color = vec4(color, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define POINT_SIZE 5.0\n\n#define PI 3.1415\n\n#define RESOLUTION vec3(45.0)\n#define SIZE vec3(2.5)\n\n// New hash based on hash13() from \"Hash without Sine\" by Dave_Hoskins (https://www.shadertoy.com/view/4djSRW)\n// 4 in, 1 out\nfloat Hash41(in vec4 p) {\n\tp = fract(p * 0.1031);\n p += dot(p, p.zwyx + 31.32);\n return fract((p.x + p.y) * p.z - p.x * p.w);\n}\n\n\nfloat SmoothNoise4D(in vec4 p) {\n vec4 cell = floor(p);\n vec4 local = fract(p);\n local *= local * (3.0 - 2.0 * local);\n\n float ldbq = Hash41(cell);\n float rdbq = Hash41(cell + vec4(1.0, 0.0, 0.0, 0.0));\n float ldfq = Hash41(cell + vec4(0.0, 0.0, 1.0, 0.0));\n float rdfq = Hash41(cell + vec4(1.0, 0.0, 1.0, 0.0));\n float lubq = Hash41(cell + vec4(0.0, 1.0, 0.0, 0.0));\n float rubq = Hash41(cell + vec4(1.0, 1.0, 0.0, 0.0));\n float lufq = Hash41(cell + vec4(0.0, 1.0, 1.0, 0.0));\n float rufq = Hash41(cell + vec4(1.0, 1.0, 1.0, 0.0));\n float ldbw = Hash41(cell + vec4(0.0, 0.0, 0.0, 1.0));\n float rdbw = Hash41(cell + vec4(1.0, 0.0, 0.0, 1.0));\n float ldfw = Hash41(cell + vec4(0.0, 0.0, 1.0, 1.0));\n float rdfw = Hash41(cell + vec4(1.0, 0.0, 1.0, 1.0));\n float lubw = Hash41(cell + vec4(0.0, 1.0, 0.0, 1.0));\n float rubw = Hash41(cell + vec4(1.0, 1.0, 0.0, 1.0));\n float lufw = Hash41(cell + vec4(0.0, 1.0, 1.0, 1.0));\n float rufw = Hash41(cell + 1.0);\n\n return mix(mix(mix(mix(ldbq, rdbq, local.x),\n mix(lubq, rubq, local.x),\n local.y),\n\n mix(mix(ldfq, rdfq, local.x),\n mix(lufq, rufq, local.x),\n local.y),\n\n local.z),\n\n mix(mix(mix(ldbw, rdbw, local.x),\n mix(lubw, rubw, local.x),\n local.y),\n\n mix(mix(ldfw, rdfw, local.x),\n mix(lufw, rufw, local.x),\n local.y),\n\n local.z),\n\n local.w);\n}\n\nfloat FractalNoise4D(in vec4 p) {\n p *= 2.0;\n\n float nscale = 1.0;\n float tscale = -0.21;\n float value = 0.0;\n\n for (int octave=0; octave < 5; octave++) {\n value += SmoothNoise4D(p) * nscale;\n tscale += nscale;\n nscale *= 0.5;\n p *= 1.0;\n }\n\n return value / tscale;\n}\n\nfloat mapShape(vec3 p) {\n return FractalNoise4D(vec4(p, time * 0.25)) - 0.4;\n}\n\nvec3 mapColor(in vec3 p) {\n vec3 lightDir = normalize(vec3(-1.0, 1.0, .40));\n vec2 e = vec2(0.001, 0.0);\n vec3 normal = normalize(vec3(mapShape(p + e.xyy) - mapShape(p - e.xyy),\n mapShape(p + e.yxy) - mapShape(p - e.yxy),\n mapShape(p + e.yyx) - mapShape(p - e.yyx)));\n\n return vec3(max(0.0, dot(normal, lightDir)) + 0.31);\n}\n\nvoid main() {\n float t = time * 0.25;\n\n float cellId = vertexId;\n float gridX = mod(cellId, RESOLUTION.x);\n float gridY = mod(cellId - gridX, RESOLUTION.x * RESOLUTION.y) / RESOLUTION.x;\n float gridZ = (cellId - gridX - gridY * RESOLUTION.x) / RESOLUTION.x / RESOLUTION.y;\n vec3 gridPoint = vec3(gridX, gridY, gridZ) / RESOLUTION * SIZE - 0.45 * SIZE;\n\n vec3 vertex = mapShape(gridPoint) < 0.0 ? gridPoint : vec3(0.0);\n vec3 color = mapColor(vertex);\n\n vec2 mouseRot = mouse * PI;\n float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n vertex.xz *= mat2(cy, sy, -sy, cy);\n vertex.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.xy / (EYE_DISTANCE - vertex.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.50);\n gl_PointSize = POINT_SIZE / (EYE_DISTANCE - vertex.z);\n v_color = vec4(color, 1.0);\n}" + }, "screenshotURL": "data/images/images-alsdehi0rp2qwwoua-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/oXxzi5z7poEFFGEkQ/art.json b/art/oXxzi5z7poEFFGEkQ/art.json index e6430bcf..50ed5308 100644 --- a/art/oXxzi5z7poEFFGEkQ/art.json +++ b/art/oXxzi5z7poEFFGEkQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":38360,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/richtowns/elastic-drums-preset-abc\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Spiral Circle thingy\\n// Testing music sync\\n// K Machine ready\\n// now ok\\n\\n\\n#define parameter0 0.2//KParameter0 0.1>>1.5\\n#define parameter1 1.9//KParameter1 1.0>>2.0\\n#define parameter2 2.0//KParameter2 2.0>>5.0\\n#define parameter3 5.0//KParameter3 5.0>>10.0\\n#define parameter4 3.0//KParameter4 1.0>>5.0\\n\\nvoid main () {\\n float v = vertexId * 200. * sin(time/20000.);\\n \\n float spiral = 1. - parameter1 * vertexId / (vertexCount+vertexCount);\\n \\n float grid = floor(vertexCount / 1000.);\\n float step100 = floor (100. * vertexId / vertexCount); \\n float sndFactor = texture2D(sound, vec2(mod(step100, 4.), step100/400.)).a;\\n float scale = parameter0 * (parameter3 * sndFactor);\\n \\n float xoff = sndFactor * (sin(time/1.)/2.) * 0.5;\\n float yoff = sndFactor * (sin(time/1.)/2.) * 0.5;\\n \\n float y = sin(v / (50. * (2. + sin(time * 2000.)))) * spiral;\\n float x = cos(v / (50. * (2. + sin(time * 2000.)))) * spiral;\\n \\n float ux = x * scale - xoff;\\n float uy = y * scale - yoff;\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = sndFactor * parameter4;//v / (sndFactor *100000.) ;// grid;\\n\\n v_color = vec4(sndFactor * parameter2, sin(1./spiral), 1./spiral, 1);\\n}\"}", + "settings": { + "num": 38360, + "mode": "POINTS", + "sound": "https://soundcloud.com/richtowns/elastic-drums-preset-abc", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Spiral Circle thingy\n// Testing music sync\n// K Machine ready\n// now ok\n\n\n#define parameter0 0.2//KParameter0 0.1>>1.5\n#define parameter1 1.9//KParameter1 1.0>>2.0\n#define parameter2 2.0//KParameter2 2.0>>5.0\n#define parameter3 5.0//KParameter3 5.0>>10.0\n#define parameter4 3.0//KParameter4 1.0>>5.0\n\nvoid main () {\n float v = vertexId * 200. * sin(time/20000.);\n \n float spiral = 1. - parameter1 * vertexId / (vertexCount+vertexCount);\n \n float grid = floor(vertexCount / 1000.);\n float step100 = floor (100. * vertexId / vertexCount); \n float sndFactor = texture2D(sound, vec2(mod(step100, 4.), step100/400.)).a;\n float scale = parameter0 * (parameter3 * sndFactor);\n \n float xoff = sndFactor * (sin(time/1.)/2.) * 0.5;\n float yoff = sndFactor * (sin(time/1.)/2.) * 0.5;\n \n float y = sin(v / (50. * (2. + sin(time * 2000.)))) * spiral;\n float x = cos(v / (50. * (2. + sin(time * 2000.)))) * spiral;\n \n float ux = x * scale - xoff;\n float uy = y * scale - yoff;\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = sndFactor * parameter4;//v / (sndFactor *100000.) ;// grid;\n\n v_color = vec4(sndFactor * parameter2, sin(1./spiral), 1./spiral, 1);\n}" + }, "screenshotURL": "data/images/images-j3lbil9y1c6lfntic-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oYPxM5nT76rkag9tD/art.json b/art/oYPxM5nT76rkag9tD/art.json index 66b2fc8a..3f0ddd31 100644 --- a/art/oYPxM5nT76rkag9tD/art.json +++ b/art/oYPxM5nT76rkag9tD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/marikarossa/ken-ishii-alberto-ruiz-transmission-marika-rossa-remix-stick-recordings-cut-version\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 3.;\\n float maxEdge = 16.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 loc = fibonacciSphere(numGroups, groupId);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(time * .17);\\n wmat *= rotX(time * .13);\\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\\n wmat *= uniformScale(mix(0.6, 1., mv));\\n wmat *= rotZ(groupId * PI / 3.);\\n \\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\\n float sat = .5;//step(pow(s, 3.), gt);\\n float val = pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = dot(litDir, nrm) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb *= v_color.a;\\n \\n float super = step(0.99, s);\\n v_color = mix(v_color, vec4(1,0,0,1), super);\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/marikarossa/ken-ishii-alberto-ruiz-transmission-marika-rossa-remix-stick-recordings-cut-version", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 3.;\n float maxEdge = 16.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 loc = fibonacciSphere(numGroups, groupId);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(time * .17);\n wmat *= rotX(time * .13);\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\n wmat *= uniformScale(mix(0.6, 1., mv));\n wmat *= rotZ(groupId * PI / 3.);\n \n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\n float sat = .5;//step(pow(s, 3.), gt);\n float val = pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = dot(litDir, nrm) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb *= v_color.a;\n \n float super = step(0.99, s);\n v_color = mix(v_color, vec4(1,0,0,1), super);\n \n}\n" + }, "screenshotURL": "data/images/images-munr2t4ylovpstktl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ob22bGQDdRk6wsWTw/art.json b/art/ob22bGQDdRk6wsWTw/art.json index 29007deb..b8c185d6 100644 --- a/art/ob22bGQDdRk6wsWTw/art.json +++ b/art/ob22bGQDdRk6wsWTw/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//vertex shader:\\nvoid main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.75;\\n float rightBottom = 0.75;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 0, 0, 1);\\n }\\n else {\\n v_color = vec4(0, 0, 1, 1);\\n }\\n \\n \\n \\n}\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//vertex shader:\nvoid main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.75;\n float rightBottom = 0.75;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 0, 0, 1);\n }\n else {\n v_color = vec4(0, 0, 1, 1);\n }\n \n \n \n}" + }, "screenshotURL": "data/images/images-82avy3h71xe1w9kqc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/obL3NXCsSpjdP4EX9/art.json b/art/obL3NXCsSpjdP4EX9/art.json index b9beffd7..6e32426a 100644 --- a/art/obL3NXCsSpjdP4EX9/art.json +++ b/art/obL3NXCsSpjdP4EX9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1024,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"plasma grid\\\" by johanberonius\\n\\nvoid main() {\\n float pixels = resolution.x * resolution.y;\\n float pxGrid = pixels / vertexCount;\\n float size = sqrt(pxGrid);\\n \\n float across = ceil(resolution.x / size);\\n float down = floor(vertexCount / across);\\n float x = mod(vertexId+0.01, across);\\n float y = floor((vertexId+0.01) / across);\\n \\n\\n float u = (x + 0.5) / across;\\n float v = (y + 0.5) / down;\\n\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n \\n \\n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\\n float b = snd * pow(cos(time * 1.21 + u * 1.9) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 1024, + "mode": "POINTS", + "sound": "https://soundcloud.com/fantomenk/fantomenk-a-tiny-spaceships", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"plasma grid\" by johanberonius\n\nvoid main() {\n float pixels = resolution.x * resolution.y;\n float pxGrid = pixels / vertexCount;\n float size = sqrt(pxGrid);\n \n float across = ceil(resolution.x / size);\n float down = floor(vertexCount / across);\n float x = mod(vertexId+0.01, across);\n float y = floor((vertexId+0.01) / across);\n \n\n float u = (x + 0.5) / across;\n float v = (y + 0.5) / down;\n\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n \n \n gl_PointSize = max(resolution.x / across, resolution.y / down) + 1.;\n float r = snd * pow(cos(time * 1.92 + u * 2.9) * sin(-time * 1.63 + v * 2.9) * 0.5 + 0.5, 4.);\n float g = snd * pow(cos(time * 1.74 - u * 2.41) * sin(time * 1.34 - v * 3.4) * 0.5 + 0.5, 4.);\n float b = snd * pow(cos(time * 1.21 + u * 1.9) * sin(time * 1.53 + v * 1.41) * 0.5 + 0.5, 4.);\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-j8qy58ya4z0i3do4v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/obrPubQ8WrCrbvYfb/art.json b/art/obrPubQ8WrCrbvYfb/art.json index 10316de4..058d4a78 100644 --- a/art/obrPubQ8WrCrbvYfb/art.json +++ b/art/obrPubQ8WrCrbvYfb/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.0) * 0.05;\\n float sat = mix(0., 1., pump); // mix(1., -10.,av);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.www, clamp(p-K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; // sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; // sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; // sin(time * 1.3 + v * 20.0) * 0.05;\n float sat = mix(0., 1., pump); // mix(1., -10.,av);\n float val = mix(.1, pow(snd + 0.2, 5.), pump); //sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-31dkfsfn7pvvue4as-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ocZSLuzxqD2QALRCq/art.json b/art/ocZSLuzxqD2QALRCq/art.json index 08951a6e..fd978a9e 100644 --- a/art/ocZSLuzxqD2QALRCq/art.json +++ b/art/ocZSLuzxqD2QALRCq/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":9966,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 0.55//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float vertexCount= (1000. *(P2+1.5))+10.;\\n float numQuads = floor( vertexCount/6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) + mouse.y * r;\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 9966, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 0.55//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float vertexCount= (1000. *(P2+1.5))+10.;\n float numQuads = floor( vertexCount/6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) + mouse.y * r;\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-5n4fxjk8ihu5gikmd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/odJ6uwG5QzaD47cTh/art.json b/art/odJ6uwG5QzaD47cTh/art.json index cc478a19..51a12bbc 100644 --- a/art/odJ6uwG5QzaD47cTh/art.json +++ b/art/odJ6uwG5QzaD47cTh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ziad-husni/skyguide-music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = .5;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r * 419.;\\n float z = sin(phi) * r * 137.;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nfloat easeInOutPow(float pos, float pw) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, pw);\\n }\\n return 0.5 * (pow((pos - 2.), pw) + 2.);\\n}\\n\\n\\nvoid main() {\\n vec3 pos = vec3(0, 0, 0);\\n //pos *= vec3(100, 100, 10);\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\\n float tm = time * -0.05;\\n float t2 = time * 0.05;\\n float t3 = time * 0.04;\\n float r = mix(10., 5., sin(t3) * .5 + .5);\\n vec3 eye = vec3(cos(tm) * r, sin(t2) * 2. + 3., sin(tm) * r);\\n vec3 target = vec3(0, sin(t2) * -2.5, 0);\\n vec3 up = vec3(0, 1, 0);\\n mat *= cameraLookAt(eye, target, up);\\n \\n vec3 n = normalize(\\n vec3(\\n hash(vertexId * 0.123), \\n hash(vertexId * 0.357), \\n hash(vertexId * 0.531)\\n ) * 2. - 1.\\n );\\n \\n if (vertexId < 5000.0) {\\n mat *= trans(n * 84.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.25;;\\n v_color = vec4(hash(vertexId * 0.211));\\n } else {\\n float d = hash(vertexId * 0.713);// * (sin(vertexId * 1.5) * .5 + .5);\\n \\n float s = texture2D(sound, vec2(d * .1, 0)).a;\\n \\n mat *= rotY(time * mix(0.01, 0.3, (1. - d)) + sin(atan(n.x,n.z) * 20.));\\n mat *= scale(vec3(10, easeInOutPow((1. - d), 4.) * 5., 10));\\n mat *= trans(n * pow(d, 3.));\\n gl_Position = mat * vec4(pos, 1);\\n\\n vec4 f = mat * vec4(1,1,pos.z,1);\\n f = f / f.w;\\n\\n gl_PointSize = mix(1.5, 2.5, (1. - d)); //f.y * 0.5;\\n float hue = mix(0.4, 0.8, s);\\n float sat = 0.45;\\n float val = mix(1., 1., s);\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), pow(1.-d, 0.2));\\n } \\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ziad-husni/skyguide-music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = .5;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r * 419.;\n float z = sin(phi) * r * 137.;\n\n return vec3(x, y, z);\n}\n\n\nfloat easeInOutPow(float pos, float pw) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, pw);\n }\n return 0.5 * (pow((pos - 2.), pw) + 2.);\n}\n\n\nvoid main() {\n vec3 pos = vec3(0, 0, 0);\n //pos *= vec3(100, 100, 10);\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\n float tm = time * -0.05;\n float t2 = time * 0.05;\n float t3 = time * 0.04;\n float r = mix(10., 5., sin(t3) * .5 + .5);\n vec3 eye = vec3(cos(tm) * r, sin(t2) * 2. + 3., sin(tm) * r);\n vec3 target = vec3(0, sin(t2) * -2.5, 0);\n vec3 up = vec3(0, 1, 0);\n mat *= cameraLookAt(eye, target, up);\n \n vec3 n = normalize(\n vec3(\n hash(vertexId * 0.123), \n hash(vertexId * 0.357), \n hash(vertexId * 0.531)\n ) * 2. - 1.\n );\n \n if (vertexId < 5000.0) {\n mat *= trans(n * 84.);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.25;;\n v_color = vec4(hash(vertexId * 0.211));\n } else {\n float d = hash(vertexId * 0.713);// * (sin(vertexId * 1.5) * .5 + .5);\n \n float s = texture2D(sound, vec2(d * .1, 0)).a;\n \n mat *= rotY(time * mix(0.01, 0.3, (1. - d)) + sin(atan(n.x,n.z) * 20.));\n mat *= scale(vec3(10, easeInOutPow((1. - d), 4.) * 5., 10));\n mat *= trans(n * pow(d, 3.));\n gl_Position = mat * vec4(pos, 1);\n\n vec4 f = mat * vec4(1,1,pos.z,1);\n f = f / f.w;\n\n gl_PointSize = mix(1.5, 2.5, (1. - d)); //f.y * 0.5;\n float hue = mix(0.4, 0.8, s);\n float sat = 0.45;\n float val = mix(1., 1., s);\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), pow(1.-d, 0.2));\n } \n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-qcjupbo9jcyz3uacd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ofYQfSm7FHtddg7on/art.json b/art/ofYQfSm7FHtddg7on/art.json index 4febcd52..26daa3af 100644 --- a/art/ofYQfSm7FHtddg7on/art.json +++ b/art/ofYQfSm7FHtddg7on/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2590,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8784313725490196,0.9333333333333333,0.8313725490196079,1],\"shader\":\"\\nconst float line = 3. ; \\nvec2 drawTriangle(in float vertexId ,out vec3 color )\\n{\\n vec2 res = vec2(1.);\\n // res.x = floor(mod(vertexId , line))/line;\\n // res.y = floor(vertexId/ line) ; \\n if(vertexId < (vertexCount / 4. ))\\n {\\n res.x = -0.5 ; \\n res.y = -0.5 ; \\n color.r = 1.;\\n color.g = 0. ; \\n color.b = 0. ; \\n res.x += (sin(-time * 3.0) * 0.1);\\n res.y += (cos(-time * 10.0) * 0.1);\\n } \\n else if (vertexId > (vertexCount * 2. /3. )) \\n {\\n res.x = 0.5 ; \\n res.y = -0.5 ; \\n color.r = 0.;\\n color.g = 1. ; \\n color.b = 0. ; \\n res.x += (sin(-time * 10.0) * 0.1);\\n res.y += (cos(time * 7.0) * 0.1);\\n }\\n else\\n {\\n res.x = 0. ; \\n res.y = 0.5 ;\\n color.r = 0.;\\n color.g = 0. ; \\n color.b = 1. ; \\n res.x += (sin(time * 5.0) * 0.1);\\n res.y += (cos(time * 11.0) * 0.1);\\n }\\n return res; \\n \\n}\\n\\nvoid main()\\n{\\n vec3 color = vec3(0.);\\n \\n \\n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\\n \\n gl_PointSize = 10. ; \\n \\n v_color = vec4(color , 1.0);\\n}\"}", + "settings": { + "num": 2590, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8784313725490196, + 0.9333333333333333, + 0.8313725490196079, + 1 + ], + "shader": "\nconst float line = 3. ; \nvec2 drawTriangle(in float vertexId ,out vec3 color )\n{\n vec2 res = vec2(1.);\n // res.x = floor(mod(vertexId , line))/line;\n // res.y = floor(vertexId/ line) ; \n if(vertexId < (vertexCount / 4. ))\n {\n res.x = -0.5 ; \n res.y = -0.5 ; \n color.r = 1.;\n color.g = 0. ; \n color.b = 0. ; \n res.x += (sin(-time * 3.0) * 0.1);\n res.y += (cos(-time * 10.0) * 0.1);\n } \n else if (vertexId > (vertexCount * 2. /3. )) \n {\n res.x = 0.5 ; \n res.y = -0.5 ; \n color.r = 0.;\n color.g = 1. ; \n color.b = 0. ; \n res.x += (sin(-time * 10.0) * 0.1);\n res.y += (cos(time * 7.0) * 0.1);\n }\n else\n {\n res.x = 0. ; \n res.y = 0.5 ;\n color.r = 0.;\n color.g = 0. ; \n color.b = 1. ; \n res.x += (sin(time * 5.0) * 0.1);\n res.y += (cos(time * 11.0) * 0.1);\n }\n return res; \n \n}\n\nvoid main()\n{\n vec3 color = vec3(0.);\n \n \n gl_Position = vec4(drawTriangle(vertexId ,color) , 0.0 ,1.) ;\n \n gl_PointSize = 10. ; \n \n v_color = vec4(color , 1.0);\n}" + }, "screenshotURL": "data/images/images-mamdgcfyuprsi5hju-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ogZuw7WfJkAypj7nW/art.json b/art/ogZuw7WfJkAypj7nW/art.json index 256ed388..02a3a291 100644 --- a/art/ogZuw7WfJkAypj7nW/art.json +++ b/art/ogZuw7WfJkAypj7nW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gyabo", "avatarUrl": "https://secure.gravatar.com/avatar/4c346a45401eb00f419d66174540a232?default=retro&size=200", - "settings": "{\"num\":133,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float zig = mod(vertexId, 2.0);\\n float id = (vertexId * 3.141592653 * 2.0) / (vertexCount - 3.0);\\n \\n vec2 p = zig * vec2(cos(id), sin(id));\\n gl_Position = vec4(p, 0, 1);\\n\\n float k = pow(1.0 - dot(p.xy, p.xy), 1.0);\\n v_color = vec4(k);\\n v_color = max(vec4(0.0), v_color);\\n}\"}", + "settings": { + "num": 133, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float zig = mod(vertexId, 2.0);\n float id = (vertexId * 3.141592653 * 2.0) / (vertexCount - 3.0);\n \n vec2 p = zig * vec2(cos(id), sin(id));\n gl_Position = vec4(p, 0, 1);\n\n float k = pow(1.0 - dot(p.xy, p.xy), 1.0);\n v_color = vec4(k);\n v_color = max(vec4(0.0), v_color);\n}" + }, "screenshotURL": "data/images/images-hc7p6u9dhkd1trd0s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ohBmRghggdTnjtnNi/art.json b/art/ohBmRghggdTnjtnNi/art.json index 58c70ec2..0fc7e758 100644 --- a/art/ohBmRghggdTnjtnNi/art.json +++ b/art/ohBmRghggdTnjtnNi/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evilmandarine", "avatarUrl": "https://secure.gravatar.com/avatar/89340ad27602758e65227662f476c233?default=retro&size=200", - "settings": "{\"num\":20497,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/pornographicrecordings/ken-ishii-play-biting-original\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.23137254901960785,0.7490196078431373,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 1800.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float snd0 = texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n float snd1 = texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId * 0.02 + time * 3.1 * (lineId + 1.), pointId, pow(snd0, 5.0) * 0.25, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(quadId / quadCount);\\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.5, lineId * 0.1);\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 20497, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/pornographicrecordings/ken-ishii-play-biting-original", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.23137254901960785, + 0.7490196078431373, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 1800.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float snd0 = texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n float snd1 = texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId * 0.02 + time * 3.1 * (lineId + 1.), pointId, pow(snd0, 5.0) * 0.25, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(quadId / quadCount);\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.5, lineId * 0.1);\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-90o2fttzk5dblbypm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oiHNm3fKqWoxXW5yJ/art.json b/art/oiHNm3fKqWoxXW5yJ/art.json index 066dfd20..a4aa2a12 100644 --- a/art/oiHNm3fKqWoxXW5yJ/art.json +++ b/art/oiHNm3fKqWoxXW5yJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":9373,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/a-boogie-wit-da-hoodie/drowning-feat-kodak-black-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*a ) + exp( -k*b );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.00570;\\n \\tfloat transitionStrength = 1.5;\\n \\tvec3 colKernel0 = vec3(1,0,1);\\n \\tvec3 colKernel1 = vec3(0,0 ,0);\\n \\tvec3 colTransition = vec3(1,1,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*1.5;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = 0.5 - mouse.x * 0.5;\\n\\tfloat ce = -1.5+mouse.y * 3.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(76.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = 1.0 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) *-dot(det*-det,2.-mouse.y);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 0,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.945); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 9373, + "mode": "LINES", + "sound": "https://soundcloud.com/a-boogie-wit-da-hoodie/drowning-feat-kodak-black-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Created by Stephane Cuillerdier - Aiekick/2018 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*a ) + exp( -k*b );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.00570;\n \tfloat transitionStrength = 1.5;\n \tvec3 colKernel0 = vec3(1,0,1);\n \tvec3 colKernel1 = vec3(0,0 ,0);\n \tvec3 colTransition = vec3(1,1,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.0, (1.-rk0)*0.2)).x*1.5;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.2)).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = 0.5 - mouse.x * 0.5;\n\tfloat ce = -1.5+mouse.y * 3.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(76.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = 1.0 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) *-dot(det*-det,2.-mouse.y);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 0,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.945); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-cek3e40f8h9cxkznt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ojPoZ3NHuEgtAPr3Z/art.json b/art/ojPoZ3NHuEgtAPr3Z/art.json index 8c6c4242..1e5d68c3 100644 --- a/art/ojPoZ3NHuEgtAPr3Z/art.json +++ b/art/ojPoZ3NHuEgtAPr3Z/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":99870,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n// best count : 99870\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 3.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.0;\\n \\tvec2 height = vec2(10.,0.);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t//\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 99870, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n// best count : 99870\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 3.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.0;\n \tvec2 height = vec2(10.,0.);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t//\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-174t4idwngdudj5ho-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/omsdK8ycyfF9ofeYS/art.json b/art/omsdK8ycyfF9ofeYS/art.json index a7359301..80529f1e 100644 --- a/art/omsdK8ycyfF9ofeYS/art.json +++ b/art/omsdK8ycyfF9ofeYS/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "aaron1924", "avatarUrl": "https://secure.gravatar.com/avatar/401c5d5fc2a9202f44ee18595001dbac?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n\\nvec3 hash(vec3 p)\\n{\\n p = fract(p * vec3(.1031,.11369,.13787));\\n p += dot(p, p.yxz+19.19);\\n return fract(vec3((p.x + p.y)*p.z, (p.x+p.z)*p.y, (p.y+p.z)*p.x));\\n}\\n\\n\\n\\nvec2 solve( float a, float b, float c )\\n{\\n float d = sqrt( b * b - 4.0 * a * c );\\n vec2 dV = vec2( d, -d );\\n return (-b + dV) / (2.0 * a);\\n}\\n\\n\\nvec3 throw( vec3 pos, vec3 vel, float h, float t )\\n{\\n vec3 g = vec3(0, -4., 0);\\n \\n for( int iBounce=0; iBounce < 3; iBounce++)\\n {\\n vec2 q = solve( 0.5 * g.y, vel.y, -h + pos.y);\\n float tInt = max( q.x, q.y );\\n tInt -= 0.0001;\\n \\n if ( t < tInt )\\n {\\n pos += vel*t + 0.5*g*t*t;\\n break;\\n }\\n else\\n {\\n vec3 v = vel + g * tInt;\\n pos += vel * tInt + 0.5 * g * tInt * tInt;\\n vel = v;\\n \\n vel.y = -vel.y * 0.3;\\n vel.xz *= 0.6;\\n\\n t -= tInt;\\n }\\n }\\n\\n return pos;\\n}\\n\\n\\n\\nfloat box(vec3 p)\\n{\\n p = abs(p);\\n return max(p.x, max(p.y, p.z));\\n}\\n\\nmat2 rot(float a)\\n{\\n float s=sin(a), c=cos(a);\\n return mat2(c,s,-s,c);\\n}\\n\\n\\n\\nvec3 fountain(float id, float count)\\n{\\n vec3 d = normalize(hash(vec3(id))-0.5);\\n d.y=abs(d.y);\\n \\n float t=fract(0.3*time + id/count);\\n vec3 p=d*t;\\n p.y = max(-8. * t * (t-.9), 0.1*sin(t));\\n \\n return p;\\n}\\n\\n/*vec3 boom(float id, float count, float t)\\n{\\n vec3 d = hash(vec3(id))-0.5;\\n d *= (1.0 + id/count) / length(d);\\n \\n vec3 p=d*pow(t, 0.6);\\n \\n return p;\\n}*/\\n\\nvec3 boom(float id, float count, vec3 pos, float t)\\n{\\n vec3 d = hash(vec3(id))-0.5;\\n d *= (1.0 + id/count) / length(d);\\n \\n return throw(pos, d, -1.0, t);\\n}\\n\\nvec3 spiral(float id, float count)\\n{\\n vec3 rnd = hash(vec3(id)) - 0.5;\\n \\n float t = time + id/count;\\n \\n float a = 2. * t + rnd.x;\\n if(2.*id > count)a += 0.5*TAU;\\n \\n vec3 td = (2. + rnd.z) * vec3(sin(a), 0.1 * rnd.y, cos(a));\\n vec3 to = vec3(0,1,0);\\n \\n return throw(to, td, -2.0, fract(t+a));\\n}\\n\\n\\nvoid main() {\\n vec3 p = vec3(0);\\n \\n float md = 32.0;\\n float gr = floor(md*vertexId/vertexCount+md*time);\\n \\n float t = time;\\n p = 2. * hash(vec3(gr)) - 1.; p.xz *= vec2(5, 3); p.y += 2.;\\n p = boom(vertexId, vertexCount, p, fract(t - gr/md));\\n \\n //p.z -= 3. * fract(t - gr/md);\\n \\n p.z += 4.;\\n \\n vec2 uv = p.xy / p.z;\\n uv.x *= resolution.y / resolution.x;\\n \\n gl_PointSize = 4. / p.z;\\n gl_Position = vec4(uv, 0, 1);\\n \\n vec3 col = hash(vec3(3.*gr));\\n col /= box(col);\\n \\n v_color = vec4(col, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n\nvec3 hash(vec3 p)\n{\n p = fract(p * vec3(.1031,.11369,.13787));\n p += dot(p, p.yxz+19.19);\n return fract(vec3((p.x + p.y)*p.z, (p.x+p.z)*p.y, (p.y+p.z)*p.x));\n}\n\n\n\nvec2 solve( float a, float b, float c )\n{\n float d = sqrt( b * b - 4.0 * a * c );\n vec2 dV = vec2( d, -d );\n return (-b + dV) / (2.0 * a);\n}\n\n\nvec3 throw( vec3 pos, vec3 vel, float h, float t )\n{\n vec3 g = vec3(0, -4., 0);\n \n for( int iBounce=0; iBounce < 3; iBounce++)\n {\n vec2 q = solve( 0.5 * g.y, vel.y, -h + pos.y);\n float tInt = max( q.x, q.y );\n tInt -= 0.0001;\n \n if ( t < tInt )\n {\n pos += vel*t + 0.5*g*t*t;\n break;\n }\n else\n {\n vec3 v = vel + g * tInt;\n pos += vel * tInt + 0.5 * g * tInt * tInt;\n vel = v;\n \n vel.y = -vel.y * 0.3;\n vel.xz *= 0.6;\n\n t -= tInt;\n }\n }\n\n return pos;\n}\n\n\n\nfloat box(vec3 p)\n{\n p = abs(p);\n return max(p.x, max(p.y, p.z));\n}\n\nmat2 rot(float a)\n{\n float s=sin(a), c=cos(a);\n return mat2(c,s,-s,c);\n}\n\n\n\nvec3 fountain(float id, float count)\n{\n vec3 d = normalize(hash(vec3(id))-0.5);\n d.y=abs(d.y);\n \n float t=fract(0.3*time + id/count);\n vec3 p=d*t;\n p.y = max(-8. * t * (t-.9), 0.1*sin(t));\n \n return p;\n}\n\n/*vec3 boom(float id, float count, float t)\n{\n vec3 d = hash(vec3(id))-0.5;\n d *= (1.0 + id/count) / length(d);\n \n vec3 p=d*pow(t, 0.6);\n \n return p;\n}*/\n\nvec3 boom(float id, float count, vec3 pos, float t)\n{\n vec3 d = hash(vec3(id))-0.5;\n d *= (1.0 + id/count) / length(d);\n \n return throw(pos, d, -1.0, t);\n}\n\nvec3 spiral(float id, float count)\n{\n vec3 rnd = hash(vec3(id)) - 0.5;\n \n float t = time + id/count;\n \n float a = 2. * t + rnd.x;\n if(2.*id > count)a += 0.5*TAU;\n \n vec3 td = (2. + rnd.z) * vec3(sin(a), 0.1 * rnd.y, cos(a));\n vec3 to = vec3(0,1,0);\n \n return throw(to, td, -2.0, fract(t+a));\n}\n\n\nvoid main() {\n vec3 p = vec3(0);\n \n float md = 32.0;\n float gr = floor(md*vertexId/vertexCount+md*time);\n \n float t = time;\n p = 2. * hash(vec3(gr)) - 1.; p.xz *= vec2(5, 3); p.y += 2.;\n p = boom(vertexId, vertexCount, p, fract(t - gr/md));\n \n //p.z -= 3. * fract(t - gr/md);\n \n p.z += 4.;\n \n vec2 uv = p.xy / p.z;\n uv.x *= resolution.y / resolution.x;\n \n gl_PointSize = 4. / p.z;\n gl_Position = vec4(uv, 0, 1);\n \n vec3 col = hash(vec3(3.*gr));\n col /= box(col);\n \n v_color = vec4(col, 1);\n}" + }, "screenshotURL": "data/images/images-4w7oc77vc9lq6arxz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ooyoRuuYEYCGkfLhx/art.json b/art/ooyoRuuYEYCGkfLhx/art.json index 77792ce7..6044f63c 100644 --- a/art/ooyoRuuYEYCGkfLhx/art.json +++ b/art/ooyoRuuYEYCGkfLhx/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES\\n#define my 0.6//KParameter -1.0>>20.\\n#define mx 2.//KParameter -1.0>>20.\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0.2, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -0.2,\\n yAxis, -0.7,\\n zAxis, s,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), s); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 3.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n return sin(p.y * 4.);\\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.81;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.*s;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf -= 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 0.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 3.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) *(1.0-(my*0.22)));\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, qu, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / (5. *mx*s)) ;\\n vec3 n0 = getQuadPoint(nId + 0.1, s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n+s, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n//vec3 cameraPos = vec3(mx * 4., mix(5., 1., p1m1(my)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1.-s, sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 3.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, s, 100.*-mx*s);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 3. * s, s, 0.5+s));\\n \\n gl_Position = m * vec4(p-(my*0.5), 1.5-s*(mx*0.5));\\n \\n float hue = 0.95 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 4.-s);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), my);\\n v_color = mix(v_color, background, 0.2 * cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES\n#define my 0.6//KParameter -1.0>>20.\n#define mx 2.//KParameter -1.0>>20.\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0.2, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -0.2,\n yAxis, -0.7,\n zAxis, s,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), s); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 3.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n return sin(p.y * 4.);\n return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.81;\n\tf = 0.5000*noise( p ); p = mr*p*2.*s;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf -= 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn (f /2.)+(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 0.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 3.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) *(1.0-(my*0.22)));\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, qu, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / (5. *mx*s)) ;\n vec3 n0 = getQuadPoint(nId + 0.1, s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n+s, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n//vec3 cameraPos = vec3(mx * 4., mix(5., 1., p1m1(my)), -3);\n vec3 cameraPos = vec3(sin(ct), 1.-s, sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 3.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, s, 100.*-mx*s);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 3. * s, s, 0.5+s));\n \n gl_Position = m * vec4(p-(my*0.5), 1.5-s*(mx*0.5));\n \n float hue = 0.95 + sin(time * 0.1) * 0.1 + qu * 1.2 + p.y * -1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 4.-s);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), my);\n v_color = mix(v_color, background, 0.2 * cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-00l99ntdlchd2rpby-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/opSgihs7RaD5mY8E3/art.json b/art/opSgihs7RaD5mY8E3/art.json index 1ca86ecd..10dfe912 100644 --- a/art/opSgihs7RaD5mY8E3/art.json +++ b/art/opSgihs7RaD5mY8E3/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":3000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/allaboutthebeat/distant-friends-gen-neo\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n \\n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0); // last value for overall peak of color\\n \\n float x = (u*10.0)-1.0;\\n float y = 0.0;\\n gl_PointSize = 40.0;\\n gl_Position = vec4(x,y,0,0.1); // change last value for resolution\\n \\n float lum = floor(v *10.0 + 1.9)/20.0;\\n //float lum = 1.0; // tester\\n v_color = vec4(v*lum*0.4,lum*0.2,lum*1.0,1); // v * lum * R, lum * G, lum * B, ?\\n\\n}\"}", + "settings": { + "num": 3000, + "mode": "POINTS", + "sound": "https://soundcloud.com/allaboutthebeat/distant-friends-gen-neo", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n \n v+= 10.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0); // last value for overall peak of color\n \n float x = (u*10.0)-1.0;\n float y = 0.0;\n gl_PointSize = 40.0;\n gl_Position = vec4(x,y,0,0.1); // change last value for resolution\n \n float lum = floor(v *10.0 + 1.9)/20.0;\n //float lum = 1.0; // tester\n v_color = vec4(v*lum*0.4,lum*0.2,lum*1.0,1); // v * lum * R, lum * G, lum * B, ?\n\n}" + }, "screenshotURL": "data/images/images-6iwrp5d002ewr0ba1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/owafrZFoFvRzyqEL6/art.json b/art/owafrZFoFvRzyqEL6/art.json index eeed4689..32fed097 100644 --- a/art/owafrZFoFvRzyqEL6/art.json +++ b/art/owafrZFoFvRzyqEL6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":5920,\"mode\":\"LINE_LOOP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define KP0 -1.//KParameter -2.>>2.\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 2.//KParameter 0.3>>7.\\n\\n#define KP2 2.//KParameter 0.2>>2.\\n//KVerticesNumber=4000\\n\\n\\n#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 int(5.-KP0)\\n\\nfloat M=mouse.x*KP1;\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*KP0, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 4333.0)*M;\\ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.198,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 5920, + "mode": "LINE_LOOP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n\n#define KP0 -1.//KParameter -2.>>2.\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 2.//KParameter 0.3>>7.\n\n#define KP2 2.//KParameter 0.2>>2.\n//KVerticesNumber=4000\n\n\n#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 int(5.-KP0)\n\nfloat M=mouse.x*KP1;\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*KP0, 2112.0, 3332.0); \ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 4333.0)*M;\ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.198,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-bgcod1vgm2begnfrl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oxrytziMEpETXEtcv/art.json b/art/oxrytziMEpETXEtcv/art.json index db03f457..3bf15e57 100644 --- a/art/oxrytziMEpETXEtcv/art.json +++ b/art/oxrytziMEpETXEtcv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":5970,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Exercise Colors\\n// CS250 Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() \\n{\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 10.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float second = abs(cos(time + v)) * 0.5 + 0.5;\\n float third = abs(sin(time + u * v)) * 0.5 + 0.5;\\n float first = sin(time + u) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(first, second, third)), 1);\\n}\\n\"}", + "settings": { + "num": 5970, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Exercise Colors\n// CS250 Spring 2022\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() \n{\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 10.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float second = abs(cos(time + v)) * 0.5 + 0.5;\n float third = abs(sin(time + u * v)) * 0.5 + 0.5;\n float first = sin(time + u) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(first, second, third)), 1);\n}\n" + }, "screenshotURL": "data/images/images-6ddl2ayseof113u9t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/oyvKbFbwkDRrreeMy/art.json b/art/oyvKbFbwkDRrreeMy/art.json index ac442746..eb59c860 100644 --- a/art/oyvKbFbwkDRrreeMy/art.json +++ b/art/oyvKbFbwkDRrreeMy/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aticatac", "avatarUrl": "https://secure.gravatar.com/avatar/16cf649c9adc34f00e2d2acd119c4b37?default=retro&size=200", - "settings": "{\"num\":20,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10588235294117647,0.09411764705882353,0.09411764705882353,1],\"shader\":\"void main() {\\n \\n}\"}", + "settings": { + "num": 20, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10588235294117647, + 0.09411764705882353, + 0.09411764705882353, + 1 + ], + "shader": "void main() {\n \n}" + }, "screenshotURL": "data/images/images-fwad47cbntvrbk5b3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ozQWQuhmD57BYJsPh/art.json b/art/ozQWQuhmD57BYJsPh/art.json index f3c10050..bbb8b7f9 100644 --- a/art/ozQWQuhmD57BYJsPh/art.json +++ b/art/ozQWQuhmD57BYJsPh/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":54802,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/666gangstaz/biggy-lives\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>1.\\n#define kpx 2.0//KParameter 0.>>9.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n//KverticesNumber=533333\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\n\\n#define elementPerTriangleShape 3.\\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\\n result = rotZ(result,_angle);\\n result.xy+=_center.xy;\\n return result;\\n}\\n\\n\\nvoid main() {\\n \\n //fix a maximum vertexId\\n float localVertexId = vertexId;\\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\\n \\n float relVertexId = vertexId/vertexCount*kpx;\\n \\n maxShapeCount = floor(maxShapeCount/2.);\\n \\n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\\n \\n if(localVertexId>=maxVerticesNumber)\\n localVertexId = maxVerticesNumber-1.5;\\n \\n float shapeId = floor(localVertexId / elementPerTriangleShape);\\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\\n float relShapeId = shapeId/maxShapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n \\n vec2 center=vec2(0., 0.);\\n \\n if(localVertexId>=(maxVerticesNumber/2.))\\n {\\n localVertexId = localVertexId - (maxVerticesNumber/2.);\\n }\\n \\n float localShapeId = floor(localVertexId/elementPerTriangleShape);\\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\\n \\n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\\n float snd = texture2D(floatSound, vec2(localRelShapeId,0.4) ).a* sndFactor;\\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\\n \\n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\\n ;\\n \\n \\n shapep.x/=aspect;\\n vec4 m = texture2D(touch, vec2(0.009-snd, localShapeId /(maxShapeCount/2.)));\\n \\n shapep += vec3( m.xy, shapep.z+1.);\\n \\n if(shapeId>maxShapeCount/2.)\\n {\\n shapep.x = -shapep.x;\\n }\\n\\n \\n \\n \\n gl_Position = vec4(shapep,1.);\\n gl_PointSize = 3.*PointSizeFactor;\\n \\n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 54802, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/666gangstaz/biggy-lives", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>1.\n#define kpx 2.0//KParameter 0.>>9.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n//KverticesNumber=533333\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\n\n#define elementPerTriangleShape 3.\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\n result = rotZ(result,_angle);\n result.xy+=_center.xy;\n return result;\n}\n\n\nvoid main() {\n \n //fix a maximum vertexId\n float localVertexId = vertexId;\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\n \n float relVertexId = vertexId/vertexCount*kpx;\n \n maxShapeCount = floor(maxShapeCount/2.);\n \n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\n \n if(localVertexId>=maxVerticesNumber)\n localVertexId = maxVerticesNumber-1.5;\n \n float shapeId = floor(localVertexId / elementPerTriangleShape);\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\n float relShapeId = shapeId/maxShapeCount;\n \n float aspect = resolution.x / resolution.y;\n \n vec2 center=vec2(0., 0.);\n \n if(localVertexId>=(maxVerticesNumber/2.))\n {\n localVertexId = localVertexId - (maxVerticesNumber/2.);\n }\n \n float localShapeId = floor(localVertexId/elementPerTriangleShape);\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\n \n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\n float snd = texture2D(floatSound, vec2(localRelShapeId,0.4) ).a* sndFactor;\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\n \n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\n ;\n \n \n shapep.x/=aspect;\n vec4 m = texture2D(touch, vec2(0.009-snd, localShapeId /(maxShapeCount/2.)));\n \n shapep += vec3( m.xy, shapep.z+1.);\n \n if(shapeId>maxShapeCount/2.)\n {\n shapep.x = -shapep.x;\n }\n\n \n \n \n gl_Position = vec4(shapep,1.);\n gl_PointSize = 3.*PointSizeFactor;\n \n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-suc6hnm9n2apny0k9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p2AWNesbs8S8c9WaR/art.json b/art/p2AWNesbs8S8c9WaR/art.json index 08a933a5..6a016438 100644 --- a/art/p2AWNesbs8S8c9WaR/art.json +++ b/art/p2AWNesbs8S8c9WaR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":20784,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Minki Cho\\n// Exercise a moving Grid\\n// CS250 Spring 2022\\n\\n//\\nvoid main() \\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.1;\\n float yoff = sin(time + y * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + xoff;\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n vec4 color1 = vec4(1.0, sin(time * 0.5) * 0.5 + 0.5, 0.0, 1.0);\\n vec4 color2 = vec4(0.0, 0.0, cos(time * 0.5) * 0.5 + 0.5, 1.0);\\n vec4 blendedColor = mix(color1, color2, (sin(time * 0.5) + 1.0) * 0.5);\\n \\n vec4 pointColor = vec4(ux, 1.0 - vy, 1., 1.0);\\n v_color = mix(pointColor, blendedColor, 0.5);\\n}\\n \\n\"}", + "settings": { + "num": 20784, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Minki Cho\n// Exercise a moving Grid\n// CS250 Spring 2022\n\n//\nvoid main() \n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.1;\n float yoff = sin(time + y * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + xoff;\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.;\n \n \n vec4 color1 = vec4(1.0, sin(time * 0.5) * 0.5 + 0.5, 0.0, 1.0);\n vec4 color2 = vec4(0.0, 0.0, cos(time * 0.5) * 0.5 + 0.5, 1.0);\n vec4 blendedColor = mix(color1, color2, (sin(time * 0.5) + 1.0) * 0.5);\n \n vec4 pointColor = vec4(ux, 1.0 - vy, 1., 1.0);\n v_color = mix(pointColor, blendedColor, 0.5);\n}\n \n" + }, "screenshotURL": "data/images/images-0hip5isywxebvlw8e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p2aq6zzbjEuF3wArG/art.json b/art/p2aq6zzbjEuF3wArG/art.json index 2ba7a737..07ec9abc 100644 --- a/art/p2aq6zzbjEuF3wArG/art.json +++ b/art/p2aq6zzbjEuF3wArG/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.18823529411764706,0.18823529411764706,0.18823529411764706,1],\"shader\":\"// Junsu Jang\\n// Exercise Making A Grid\\n// CS250 \\n// Spring/2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy , 0., 1.);\\n \\n gl_PointSize = 10.0 * (sin(time)+1.1);\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 1200.;\\n \\n float distNum = 20.;\\n vec2 pos = gl_Position.xy/resolution;\\n pos += vec2(sin(time*0.1),cos(time*0.1));\\n pos *= distNum;\\n vec2 intPos = floor(pos)*resolution ;\\n \\n v_color = vec4(sin(intPos.x),sin(intPos.y),cos(intPos.x),1);\\n //background = vec4(sin(intPos.y),sin(intPos.x),cos(intPos.y));\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.18823529411764706, + 0.18823529411764706, + 0.18823529411764706, + 1 + ], + "shader": "// Junsu Jang\n// Exercise Making A Grid\n// CS250 \n// Spring/2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy , 0., 1.);\n \n gl_PointSize = 10.0 * (sin(time)+1.1);\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 1200.;\n \n float distNum = 20.;\n vec2 pos = gl_Position.xy/resolution;\n pos += vec2(sin(time*0.1),cos(time*0.1));\n pos *= distNum;\n vec2 intPos = floor(pos)*resolution ;\n \n v_color = vec4(sin(intPos.x),sin(intPos.y),cos(intPos.x),1);\n //background = vec4(sin(intPos.y),sin(intPos.x),cos(intPos.y));\n \n}" + }, "screenshotURL": "data/images/images-hfz1852nwjwbk5yv2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/p357zGcrjjsz4KYMt/art.json b/art/p357zGcrjjsz4KYMt/art.json index 26b7d523..3521f6dc 100644 --- a/art/p357zGcrjjsz4KYMt/art.json +++ b/art/p357zGcrjjsz4KYMt/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":26702,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define TAU radians(360.)#define PI radians(180.)\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.625 + (time * 20.));\\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (.85 + pow(texture2D(sound, vec2(sx * 0.0365, sy)).a, 4.) * 2.) * (1. - sy);\\n \\n float x = sin(deg) * radius * .9;\\n float y = cos(deg) * radius * 1.9;\\n float z = vertexId * sx * 0.125;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0.1*mouse.y, 1.-radius-mouse.y, 0,\\n -0.3/radius, -1.1*mouse.x*radius, .1, 0,\\n -0.06, 0.01, 0.31-mouse.y*0.1, 0.1,\\n 0, 0, -0.5, 1)/radius*2.;\\n \\n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\\n v_color = vec4(1, (vertexId / vertexCount) / 2.5 * 12.1, 0.4, 0.41);\\n}\"}", + "settings": { + "num": 26702, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define TAU radians(360.)#define PI radians(180.)\n\nvoid main()\n{\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.625 + (time * 20.));\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (.85 + pow(texture2D(sound, vec2(sx * 0.0365, sy)).a, 4.) * 2.) * (1. - sy);\n \n float x = sin(deg) * radius * .9;\n float y = cos(deg) * radius * 1.9;\n float z = vertexId * sx * 0.125;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0.1*mouse.y, 1.-radius-mouse.y, 0,\n -0.3/radius, -1.1*mouse.x*radius, .1, 0,\n -0.06, 0.01, 0.31-mouse.y*0.1, 0.1,\n 0, 0, -0.5, 1)/radius*2.;\n \n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\n v_color = vec4(1, (vertexId / vertexCount) / 2.5 * 12.1, 0.4, 0.41);\n}" + }, "screenshotURL": "data/images/images-6szunn5txovg2jcal-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p3J4jE3L87RgWNw5f/art.json b/art/p3J4jE3L87RgWNw5f/art.json index 1f4f6608..f1a49b3f 100644 --- a/art/p3J4jE3L87RgWNw5f/art.json +++ b/art/p3J4jE3L87RgWNw5f/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":8571,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_STRIP\\n\\n#define KP0 2.//KParameter -2.>>2.\\n#define KP1 -1.5//KParameter -2.>>2.\\n#define zoom 1.//KParameter 0.3>>7.\\n\\n#define KP2 .3//KParameter 0.2>>2.\\n//KVerticesNumber=9000\\n\\n\\n#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n\\n\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.198,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 8571, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_STRIP\n\n#define KP0 2.//KParameter -2.>>2.\n#define KP1 -1.5//KParameter -2.>>2.\n#define zoom 1.//KParameter 0.3>>7.\n\n#define KP2 .3//KParameter 0.2>>2.\n//KVerticesNumber=9000\n\n\n#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n\n\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( KP1*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \ntriangles[ 4]=vec4( KP0*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 111., 42.0, 13256.0, 3.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.198,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-5et9m0aa2yanjcxdc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p3XWczEaFrc4XJCKu/art.json b/art/p3XWczEaFrc4XJCKu/art.json index c7cbd1bb..0fe44597 100644 --- a/art/p3XWczEaFrc4XJCKu/art.json +++ b/art/p3XWczEaFrc4XJCKu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trevor", "avatarUrl": "https://lh6.googleusercontent.com/-5kLKsPjdMwg/AAAAAAAAAAI/AAAAAAAABpc/UHOkxSB_ZkQ/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/tennysonmusic/angus-julia-stone-for-you?in=tennysonmusic/sets/singles\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 180. + vertexId * 0.1925 + (time * 20.));\\n float sx = mod(vertexId,pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float snd = texture2D(sound,vec2(sx*0.125,sy)).a;\\n float radius = (1.85 + pow(snd,2.)*2.) * (1.-sy);\\n \\n float x = sin(radius);\\n float y = cos(deg) * radius;\\n float z = vertexId * 0.125;\\n vec3 pos = vec3(x,y,z);\\n \\n float aspect = resolution.y / resolution.x;\\n \\n mat4 camera = mat4(\\n aspect, 1., 0, -0.5,\\n -1, 1., 0., 0,\\n 0, 0.1, 0.1, 0.1,\\n 4., 2., -1, 0.1);\\n \\n gl_Position = camera * vec4(pos.x-4.5,pos.y-2.,pos.z,1.);\\n float hue = (time * 0.01 + radius * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n //v_color = vec4(1., (vertexId/vertexCount) / 2. + .5, 1., 1. );\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/tennysonmusic/angus-julia-stone-for-you?in=tennysonmusic/sets/singles", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 180. + vertexId * 0.1925 + (time * 20.));\n float sx = mod(vertexId,pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float snd = texture2D(sound,vec2(sx*0.125,sy)).a;\n float radius = (1.85 + pow(snd,2.)*2.) * (1.-sy);\n \n float x = sin(radius);\n float y = cos(deg) * radius;\n float z = vertexId * 0.125;\n vec3 pos = vec3(x,y,z);\n \n float aspect = resolution.y / resolution.x;\n \n mat4 camera = mat4(\n aspect, 1., 0, -0.5,\n -1, 1., 0., 0,\n 0, 0.1, 0.1, 0.1,\n 4., 2., -1, 0.1);\n \n gl_Position = camera * vec4(pos.x-4.5,pos.y-2.,pos.z,1.);\n float hue = (time * 0.01 + radius * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n //v_color = vec4(1., (vertexId/vertexCount) / 2. + .5, 1., 1. );\n \n}" + }, "screenshotURL": "data/images/images-btx4qbqo122y27bv6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p4K2Kjnj8QoYLkffM/art.json b/art/p4K2Kjnj8QoYLkffM/art.json index d9cfa00f..450866a4 100644 --- a/art/p4K2Kjnj8QoYLkffM/art.json +++ b/art/p4K2Kjnj8QoYLkffM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "randomstarz", "avatarUrl": "https://secure.gravatar.com/avatar/742ed793ae5d9783e12bdf3ff554e51a?default=retro&size=200", - "settings": "{\"num\":36,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb (vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#if 0\\nvoid main ()\\n{\\n\\tfloat id = vertexId;\\n \\n \\tfloat ux = floor( id / 6. ) + mod( id, 2. );\\n \\tfloat vy = mod( floor( id / 2. ) + floor( id / 3. ), 2. );\\n \\n \\tfloat nSides = 6.;\\n \\n \\tfloat angle = ux * 2. * PI / nSides;\\n \\tfloat c = cos( angle );\\n float s = sin( angle );\\n\\n float radius = vy + 1.;\\n\\n float x = c * radius;\\n float y = s * radius;\\n \\n \\t//float x = ux;\\n \\t//float y = vy;\\n\\n vec2 xy = vec2( x, y );\\n gl_Position = vec4( xy * .1, 0, 1 );\\n v_color = vec4( .5, .7, .9, 1 );\\n}\\n#endif\\n\\nvec2 getCirclePoint ( float id, float nSides )\\n{\\n \\n \\tfloat ux = floor( id / 6. ) + mod( id, 2. );\\n \\t// id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\\n // 0 0 0 0 0 0 1 1 1 1 1 1 2 2\\n // 0 1 0 1 0 1 0 1 0 1 0 1 0 1\\n // ux = 0 1 0 1 0 1 1 2 1 2 1 2 2 3\\n \\tfloat vy = mod( floor( id / 2. ) + floor( id / 3. ), 2. );\\n \\t// id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\\n // 0 0 1 1 2 2 3 3 4 4 5 5 6 6\\n // 0 0 0 1 1 1 2 2 2 3 3 3 4 4\\n // 0 0 1 2 3 3 5 5 6 7 8 8 10 10\\n // vy = 0 0 1 0 1 1 1 1 0 1 0 0 0 0\\n\\n \\t// 0 0\\n // 1 0\\n // 0 1\\n // 1 0\\n // 0 1\\n // 1 1\\n // 1 1\\n // 2 1\\n\\n \\tfloat angle = ux * 2. * PI / nSides;\\n \\tfloat c = cos( angle );\\n float s = sin( angle );\\n\\n float radius = vy + 1.;\\n\\n float x = c * radius;\\n float y = s * radius;\\n\\n return vec2( x, y );\\n}\\n\\nvoid main ()\\n{\\n\\n\\tfloat nSides = 8.;\\n \\tvec2 circleXY = getCirclePoint( vertexId, nSides );\\n \\t//circleXY *= vec2( 2. );\\n \\n \\t// lol\\n \\n \\n \\tvec2 xy = circleXY;\\n \\n \\tfloat aspect = resolution.x / resolution.y;\\n \\t//gl_Position = vec4( xy * .1, 0, 1 );\\n gl_Position = vec4( xy * .1, 0, 1 ) * vec4( 1, aspect, 1, 1 );\\n v_color = vec4( .5, .7, .9, 1 );\\n}\"}", + "settings": { + "num": 36, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb (vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#if 0\nvoid main ()\n{\n\tfloat id = vertexId;\n \n \tfloat ux = floor( id / 6. ) + mod( id, 2. );\n \tfloat vy = mod( floor( id / 2. ) + floor( id / 3. ), 2. );\n \n \tfloat nSides = 6.;\n \n \tfloat angle = ux * 2. * PI / nSides;\n \tfloat c = cos( angle );\n float s = sin( angle );\n\n float radius = vy + 1.;\n\n float x = c * radius;\n float y = s * radius;\n \n \t//float x = ux;\n \t//float y = vy;\n\n vec2 xy = vec2( x, y );\n gl_Position = vec4( xy * .1, 0, 1 );\n v_color = vec4( .5, .7, .9, 1 );\n}\n#endif\n\nvec2 getCirclePoint ( float id, float nSides )\n{\n \n \tfloat ux = floor( id / 6. ) + mod( id, 2. );\n \t// id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\n // 0 0 0 0 0 0 1 1 1 1 1 1 2 2\n // 0 1 0 1 0 1 0 1 0 1 0 1 0 1\n // ux = 0 1 0 1 0 1 1 2 1 2 1 2 2 3\n \tfloat vy = mod( floor( id / 2. ) + floor( id / 3. ), 2. );\n \t// id = 0 1 2 3 4 5 6 7 8 9 10 11 12 13\n // 0 0 1 1 2 2 3 3 4 4 5 5 6 6\n // 0 0 0 1 1 1 2 2 2 3 3 3 4 4\n // 0 0 1 2 3 3 5 5 6 7 8 8 10 10\n // vy = 0 0 1 0 1 1 1 1 0 1 0 0 0 0\n\n \t// 0 0\n // 1 0\n // 0 1\n // 1 0\n // 0 1\n // 1 1\n // 1 1\n // 2 1\n\n \tfloat angle = ux * 2. * PI / nSides;\n \tfloat c = cos( angle );\n float s = sin( angle );\n\n float radius = vy + 1.;\n\n float x = c * radius;\n float y = s * radius;\n\n return vec2( x, y );\n}\n\nvoid main ()\n{\n\n\tfloat nSides = 8.;\n \tvec2 circleXY = getCirclePoint( vertexId, nSides );\n \t//circleXY *= vec2( 2. );\n \n \t// lol\n \n \n \tvec2 xy = circleXY;\n \n \tfloat aspect = resolution.x / resolution.y;\n \t//gl_Position = vec4( xy * .1, 0, 1 );\n gl_Position = vec4( xy * .1, 0, 1 ) * vec4( 1, aspect, 1, 1 );\n v_color = vec4( .5, .7, .9, 1 );\n}" + }, "screenshotURL": "data/images/images-yoytyme58sxiczr12-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/p7CgySg8MmsZK4MDE/art.json b/art/p7CgySg8MmsZK4MDE/art.json index bfdbc622..6bd46bd2 100644 --- a/art/p7CgySg8MmsZK4MDE/art.json +++ b/art/p7CgySg8MmsZK4MDE/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "isaín", "avatarUrl": "https://lh6.googleusercontent.com/-PShsQ2rITQc/AAAAAAAAAAI/AAAAAAAAARc/ffHK8TazFeI/photo.jpg", - "settings": "{\"num\":83,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8392156862745098,0.9450980392156862,1,1],\"shader\":\"void main(){\\n \\n float y = mod(vertexId,2.0);\\n float x = floor(vertexId/2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n \\n float r = 2.0 - y;\\n \\n float vx = r*cos(angle);\\n float vy = r*sin(angle);\\n \\n vec2 xy = vec2(vx, vy) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(cos(time*x), sin(time*y), tan(time), 1.0);\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 83, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8392156862745098, + 0.9450980392156862, + 1, + 1 + ], + "shader": "void main(){\n \n float y = mod(vertexId,2.0);\n float x = floor(vertexId/2.0);\n \n float angle = x / 20.0 * radians(360.0);\n \n float r = 2.0 - y;\n \n float vx = r*cos(angle);\n float vy = r*sin(angle);\n \n vec2 xy = vec2(vx, vy) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(cos(time*x), sin(time*y), tan(time), 1.0);\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-x4dwfyl93vml29lbm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p8TY2jvG3n6GQFuwT/art.json b/art/p8TY2jvG3n6GQFuwT/art.json index 69e24d8d..ed340805 100644 --- a/art/p8TY2jvG3n6GQFuwT/art.json +++ b/art/p8TY2jvG3n6GQFuwT/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":64436,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(80.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0.2, c, -0.3,\\n 0, 0, 0, 0.1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, -1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.15 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -1. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.62, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\\n float sat = 2.9 / circleId;\\n float val = .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 64436, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(80.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 4.0 / 2.4, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0.2, c, -0.3,\n 0, 0, 0, 0.1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, -1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.15 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -1. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.62, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\n float sat = 2.9 / circleId;\n float val = .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-szgwlt3iu5kt1l88e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/p9DefxpaJdaYTQAWZ/art.json b/art/p9DefxpaJdaYTQAWZ/art.json index b376fa0d..86c5fc05 100644 --- a/art/p9DefxpaJdaYTQAWZ/art.json +++ b/art/p9DefxpaJdaYTQAWZ/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 5.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 5.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-0r2yq8kg07dpjouh7-thumbnail.jpg", "views": { "$numberInt": "75" diff --git a/art/p9pecgaEBJ3kz5r7g/art.json b/art/p9pecgaEBJ3kz5r7g/art.json index ea0a2adc..0d45781d 100644 --- a/art/p9pecgaEBJ3kz5r7g/art.json +++ b/art/p9pecgaEBJ3kz5r7g/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/proposal-records/jose-ayen-apsara-brooklyn-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n// vsa\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n float snd = texture2D(sound, vec2(abs(m1p1(a2n / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n float t = time * 0.05;\\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.3,1.))\\n \\t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.5,1.))\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.7,1.))\\n \\t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.4,1.));\\n\\n light *= mix(0.5, 2.0, snd);\\n //light *= mix(vec3(1,0,0), vec3(0,0,1), vertexId / 32./ 32. / 3.);\\n light *= mix(vec3(1), vec3(1,0,0), step(0.66, snd));\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n v_color = vec4(vec3(light), 1);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/proposal-records/jose-ayen-apsara-brooklyn-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n// vsa\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n float snd = texture2D(sound, vec2(abs(m1p1(a2n / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n float t = time * 0.05;\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.3,1.))\n \t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.5,1.))\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.7,1.))\n \t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.4,1.));\n\n light *= mix(0.5, 2.0, snd);\n //light *= mix(vec3(1,0,0), vec3(0,0,1), vertexId / 32./ 32. / 3.);\n light *= mix(vec3(1), vec3(1,0,0), step(0.66, snd));\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n v_color = vec4(vec3(light), 1);\n}" + }, "screenshotURL": "data/images/images-yd4p2szloec3drzfm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pAkR8AWie7zgEskjh/art.json b/art/pAkR8AWie7zgEskjh/art.json index 166926f7..cb228ee8 100644 --- a/art/pAkR8AWie7zgEskjh/art.json +++ b/art/pAkR8AWie7zgEskjh/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cakeller98", "avatarUrl": "https://secure.gravatar.com/avatar/812a8b66a6ed48004ce62d7e88fdaf1f?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.027450980392156862,0.09411764705882353,0.9137254901960784,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.2, 0.0, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = .4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.001;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t8.0\\n#define g_backdropSlices \\t\\t\\t8.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 5.0;\\n\\n \\tfloat o = 10.0 / 900.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 100.0, 80.0, 3000.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.027450980392156862, + 0.09411764705882353, + 0.9137254901960784, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.2, 0.0, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = .4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.001;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t8.0\n#define g_backdropSlices \t\t\t8.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 5.0;\n\n \tfloat o = 10.0 / 900.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 100.0, 80.0, 3000.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-og59nkbjpqgxlugrb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pAqsg4vT33xiFePoG/art.json b/art/pAqsg4vT33xiFePoG/art.json index efa1594e..91b92538 100644 --- a/art/pAqsg4vT33xiFePoG/art.json +++ b/art/pAqsg4vT33xiFePoG/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lin", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocItxa3CU8ttId5P4Pmbp6Gb5DFHRbIOODB20e1pJNv5kQ=s96-c", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9686274509803922,0.9529411764705882,0.9529411764705882,1],\"shader\":\"\\nfloat x0 = 0.0;\\nfloat y0 = 0.0;\\n\\nfloat x1 = 0.0;\\nfloat y1 = 0.0;\\n\\nfloat x2 = 0.5;\\nfloat y2 = 0.0;\\n\\nfloat x3 = 0.5;\\nfloat y3 = 0.0;\\n\\n\\n\\n//float x3 = 0.6;\\n//float y3 = 0.3;\\n\\n//float x4 = 0.4;\\n//float y4 = 0.5;\\n\\n// 2 ->6\\n//3 -> 6*(N-1) = 6x2 =12\\n//4 -> 6*3= 18\\n\\n\\nvoid main() {\\n \\n // test 1 :4 vertices, starts from offset:0\\n float offset =0.;\\n \\n float u_thickness = 0.1;\\n \\n \\n float id = vertexId;\\n \\n float line_i = floor(id / 6.);//line index\\n float tri_i = mod(id, 6.);// point index in two triangles\\n \\n \\n \\n \\n vec4 va[4];\\n \\n va[0] = vec4(x0,y0,0,1);\\n va[1] = vec4(x1,y1,0,1);\\n va[2] = vec4(x2,y2,0,1);\\n va[3] = vec4(x3,y3,0,1);\\n \\n vec2 v_line = normalize(va[2].xy-va[1].xy);\\n vec2 nv_line = vec2(-v_line.y, v_line.x);\\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\\n vec2 v_miter1 = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\\n vec2 v_miter2 = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\\n \\n vec4 pos;\\n\\tif (tri_i == 0. || tri_i == 1. || tri_i == 3.)\\n{\\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\\n vec2 v_miter = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\\n\\n pos = va[1];\\n pos.xy += v_miter * u_thickness * (tri_i == 1. ? -0.5 : 0.5) / dot(v_miter, nv_line);\\n}\\nelse\\n{\\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\\n vec2 v_miter = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\\n\\n pos = va[2];\\n pos.xy += v_miter * u_thickness * (tri_i == 5. ? 0.5 : -0.5) / dot(v_miter, nv_line);\\n}\\n \\n \\n gl_Position = vec4(pos.xy, 0, 1);\\n \\n gl_PointSize = 30.0;\\n\\n\\n v_color = vec4(vertexId, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9686274509803922, + 0.9529411764705882, + 0.9529411764705882, + 1 + ], + "shader": "\nfloat x0 = 0.0;\nfloat y0 = 0.0;\n\nfloat x1 = 0.0;\nfloat y1 = 0.0;\n\nfloat x2 = 0.5;\nfloat y2 = 0.0;\n\nfloat x3 = 0.5;\nfloat y3 = 0.0;\n\n\n\n//float x3 = 0.6;\n//float y3 = 0.3;\n\n//float x4 = 0.4;\n//float y4 = 0.5;\n\n// 2 ->6\n//3 -> 6*(N-1) = 6x2 =12\n//4 -> 6*3= 18\n\n\nvoid main() {\n \n // test 1 :4 vertices, starts from offset:0\n float offset =0.;\n \n float u_thickness = 0.1;\n \n \n float id = vertexId;\n \n float line_i = floor(id / 6.);//line index\n float tri_i = mod(id, 6.);// point index in two triangles\n \n \n \n \n vec4 va[4];\n \n va[0] = vec4(x0,y0,0,1);\n va[1] = vec4(x1,y1,0,1);\n va[2] = vec4(x2,y2,0,1);\n va[3] = vec4(x3,y3,0,1);\n \n vec2 v_line = normalize(va[2].xy-va[1].xy);\n vec2 nv_line = vec2(-v_line.y, v_line.x);\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\n vec2 v_miter1 = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\n vec2 v_miter2 = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\n \n vec4 pos;\n\tif (tri_i == 0. || tri_i == 1. || tri_i == 3.)\n{\n vec2 v_pred = normalize(va[1].xy - va[0].xy);\n vec2 v_miter = normalize(nv_line + vec2(-v_pred.y, v_pred.x));\n\n pos = va[1];\n pos.xy += v_miter * u_thickness * (tri_i == 1. ? -0.5 : 0.5) / dot(v_miter, nv_line);\n}\nelse\n{\n vec2 v_succ = normalize(va[3].xy - va[2].xy);\n vec2 v_miter = normalize(nv_line + vec2(-v_succ.y, v_succ.x));\n\n pos = va[2];\n pos.xy += v_miter * u_thickness * (tri_i == 5. ? 0.5 : -0.5) / dot(v_miter, nv_line);\n}\n \n \n gl_Position = vec4(pos.xy, 0, 1);\n \n gl_PointSize = 30.0;\n\n\n v_color = vec4(vertexId, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-8qjowkbg7cqxzohyu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pCCMuqhftZ6T2yx6X/art.json b/art/pCCMuqhftZ6T2yx6X/art.json index b70e509f..7108ba9a 100644 --- a/art/pCCMuqhftZ6T2yx6X/art.json +++ b/art/pCCMuqhftZ6T2yx6X/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6170,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n cos(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 6170, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n cos(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-dwadzg1f1m0fmz315-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pCWSvcCDfiHokP3jK/art.json b/art/pCWSvcCDfiHokP3jK/art.json index a6305be4..4763b6dd 100644 --- a/art/pCWSvcCDfiHokP3jK/art.json +++ b/art/pCWSvcCDfiHokP3jK/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":23604,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n int num = 5;\\t\\n \\n \\n \\n if(num == 1){\\n\\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n }\\n else if(num == 2) {\\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \\n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n }\\n else if(num == 3) {\\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\\n }\\n else if(num == 4) {\\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\\n }\\n \\n else if(num == 5) {\\n gl_Position = vec4(cos(vertexId/50.0),sin(vertexId),0.0,1.0);\\n }\\n\\n gl_PointSize = 5.0*sin(1.0)+sin(time*vertexId/500.0); \\n \\n \\n v_color = vec4(sin(vertexId/122.0),\\n sin(vertexId/122.0),\\n sin(vertexId/122.0),1);\\n}\"}", + "settings": { + "num": 23604, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n int num = 5;\t\n \n \n \n if(num == 1){\n\t//gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n }\n else if(num == 2) {\n gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, \n -1.0+cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n }\n else if(num == 3) {\n gl_Position = vec4(sin(vertexId),cos(vertexId),0.0,1.0);\n }\n else if(num == 4) {\n gl_Position = vec4(sin(time),1.0-acos(cos(time)),0.0,1.0);\n }\n \n else if(num == 5) {\n gl_Position = vec4(cos(vertexId/50.0),sin(vertexId),0.0,1.0);\n }\n\n gl_PointSize = 5.0*sin(1.0)+sin(time*vertexId/500.0); \n \n \n v_color = vec4(sin(vertexId/122.0),\n sin(vertexId/122.0),\n sin(vertexId/122.0),1);\n}" + }, "screenshotURL": "data/images/images-i3qhcxmx8xogwwrvg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pCY7S7Ct9Du7rc4LS/art.json b/art/pCY7S7Ct9Du7rc4LS/art.json index 83bd639d..288744a6 100644 --- a/art/pCY7S7Ct9Du7rc4LS/art.json +++ b/art/pCY7S7Ct9Du7rc4LS/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":6080,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Making a Grid\\n// CS250 Spring 2022\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, vy, 0.0, 1.0);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 6080, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Making a Grid\n// CS250 Spring 2022\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, vy, 0.0, 1.0);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-9jm0w5uj48500npvp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pDA68wnR6YFYgpH8G/art.json b/art/pDA68wnR6YFYgpH8G/art.json index bb844c2b..1cf644b9 100644 --- a/art/pDA68wnR6YFYgpH8G/art.json +++ b/art/pDA68wnR6YFYgpH8G/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":300,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(((sin(vertexId * time)*2.0) / resolution.x) * 100.0, ((cos(vertexId * time)*2.0) / resolution.y) * 100.0);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\\n\"}", + "settings": { + "num": 300, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float count = floor(vertexId / NUM_POINTS);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(((sin(vertexId * time)*2.0) / resolution.x) * 100.0, ((cos(vertexId * time)*2.0) / resolution.y) * 100.0);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}\n" + }, "screenshotURL": "data/images/images-d70c9odnh34fo1h8y-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pGdr2hxn77WNvKPcH/art.json b/art/pGdr2hxn77WNvKPcH/art.json index b945f1a8..57110868 100644 --- a/art/pGdr2hxn77WNvKPcH/art.json +++ b/art/pGdr2hxn77WNvKPcH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tExercise - Vertexshaderart : Circles from Triangles\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n \\tc, -s, 0, 0,\\n \\ts, c, 0, 0,\\n \\t0, 0, 1, 0,\\n \\t0, 0, 0, 1\\n );\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n\\t1, 0, 0, 0,\\n\\t0, 1, 0, 0,\\n\\t0, 0, 1, 0,\\n\\ttrans, 1\\n );\\n}\\n\\nmat4 ident()\\n{\\n\\treturn mat4(\\n\\t\\t1, 0, 0, 0,\\n\\t\\t0, 1, 0, 0,\\n\\t\\t0, 0, 1, 0,\\n\\t\\t0, 0, 0, 1\\n );\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n\\treturn mat4(\\n\\t\\ts.x, 0, 0, 0,\\n\\t\\t0, s.y, 0, 0,\\n\\t\\t0, 0, s.z, 0,\\n\\t\\t0, 0, 0, 1\\n );\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n\\treturn mat4(\\n\\t\\ts, 0, 0, 0,\\n\\t\\t0, s, 0, 0,\\n\\t\\t0, 0, s, 0,\\n\\t\\t0, 0, 0, 1\\n );\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / numCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\nvoid main()\\n{\\n \\tfloat numCircleSegments = 12.0;\\n \\tvec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n \\tfloat numPointsPerCircle = numCircleSegments * 6.0;\\n \\tfloat circleId = floor(vertexId / numPointsPerCircle);\\n \\tfloat numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\tfloat sliceId = floor(vertexId / 6.0);\\n \\tfloat oddSlice = mod(sliceId, 2.0);\\n \\n\\tfloat down = floor(sqrt(numCircles));\\n \\tfloat across = floor(numCircles / down);\\n \\n \\tfloat x = mod(circleId, across);\\n \\tfloat y = floor(circleId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tfloat su = abs(u - 0.5) * 2.0;\\n \\tfloat sv = abs(v - 0.5) * 2.0;\\n \\tfloat au = abs(atan(su, sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n \\tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n \\tfloat aspect = resolution.x / resolution.y;\\n \\tfloat sc = pow(snd + 0.2, 5.0) * mix(1., 1.1, oddSlice);\\n \\n \\tsc *= 20. / across;\\n \\n \\tvec4 pos = vec4(circleXY, 0, 1);\\n \\tmat4 mat = ident();\\n \\tmat *= scale(vec3(1, aspect, 1));\\n \\tmat *= rotZ(time * 0.1);\\n \\tmat *= trans(vec3(ux, vy, 0));\\n \\tmat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n \\tgl_Position = mat * pos;\\n \\n \\tfloat soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\t\\n \\tfloat pump = step(0.8, snd);\\n \\tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\\n \\tfloat sat = 1.;//mix(0.5, 1.0, pump);\\n \\tfloat val = mix(0.4, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\thue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n \\tval += oddSlice * pump;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hausofartsasha/lady-gaga-tony-bennett-the-lady-is-a-tramp-cheek-to-cheek-tour-studio-version?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\tseongryul.park\n//\tCS250 spring 2023\n//\tExercise - Vertexshaderart : Circles from Triangles\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n \tc, -s, 0, 0,\n \ts, c, 0, 0,\n \t0, 0, 1, 0,\n \t0, 0, 0, 1\n );\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n\t1, 0, 0, 0,\n\t0, 1, 0, 0,\n\t0, 0, 1, 0,\n\ttrans, 1\n );\n}\n\nmat4 ident()\n{\n\treturn mat4(\n\t\t1, 0, 0, 0,\n\t\t0, 1, 0, 0,\n\t\t0, 0, 1, 0,\n\t\t0, 0, 0, 1\n );\n}\n\nmat4 scale(vec3 s)\n{\n\treturn mat4(\n\t\ts.x, 0, 0, 0,\n\t\t0, s.y, 0, 0,\n\t\t0, 0, s.z, 0,\n\t\t0, 0, 0, 1\n );\n}\n\nmat4 uniformScale(float s)\n{\n\treturn mat4(\n\t\ts, 0, 0, 0,\n\t\t0, s, 0, 0,\n\t\t0, 0, s, 0,\n\t\t0, 0, 0, 1\n );\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.0);\n float vy = mod(floor(id / 2.) + floor(id / 3.0), 2.0);\n \n float angle = ux / numCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\nvoid main()\n{\n \tfloat numCircleSegments = 12.0;\n \tvec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n \tfloat numPointsPerCircle = numCircleSegments * 6.0;\n \tfloat circleId = floor(vertexId / numPointsPerCircle);\n \tfloat numCircles = floor(vertexCount / numPointsPerCircle);\n \n \tfloat sliceId = floor(vertexId / 6.0);\n \tfloat oddSlice = mod(sliceId, 2.0);\n \n\tfloat down = floor(sqrt(numCircles));\n \tfloat across = floor(numCircles / down);\n \n \tfloat x = mod(circleId, across);\n \tfloat y = floor(circleId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = 0.;//sin(time + y * 0.2) * 0.1;\n \tfloat yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tfloat su = abs(u - 0.5) * 2.0;\n \tfloat sv = abs(v - 0.5) * 2.0;\n \tfloat au = abs(atan(su, sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n \tfloat snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n \tfloat aspect = resolution.x / resolution.y;\n \tfloat sc = pow(snd + 0.2, 5.0) * mix(1., 1.1, oddSlice);\n \n \tsc *= 20. / across;\n \n \tvec4 pos = vec4(circleXY, 0, 1);\n \tmat4 mat = ident();\n \tmat *= scale(vec3(1, aspect, 1));\n \tmat *= rotZ(time * 0.1);\n \tmat *= trans(vec3(ux, vy, 0));\n \tmat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n \tgl_Position = mat * pos;\n \n \tfloat soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \t\n \tfloat pump = step(0.8, snd);\n \tfloat hue = u * .1 + snd * 0.2 + time * 0.1;\n \tfloat sat = 1.;//mix(0.5, 1.0, pump);\n \tfloat val = mix(0.4, pow(snd + 0.2, 5.0), pump);//sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \thue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n \tval += oddSlice * pump;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-58jumq6sagh6evvq5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pGvDuYEiAcZ95p7Cw/art.json b/art/pGvDuYEiAcZ95p7Cw/art.json index f2e0f186..1e329065 100644 --- a/art/pGvDuYEiAcZ95p7Cw/art.json +++ b/art/pGvDuYEiAcZ95p7Cw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "vanoog", "avatarUrl": "https://secure.gravatar.com/avatar/896efd4abc5be73fd287b615b8a43698?default=retro&size=200", - "settings": "{\"num\":17300,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec2 circle(float circleId,float grid,float distance){\\n\\tfloat y = mod(vertexId,2.0);\\n\\tfloat x = floor(vertexId/2.0);\\n\\tfloat angle = x / 20.0 * radians(360.0);\\n\\n float r = 2.0 - y;\\n\\n x = r*cos(angle);\\n\\ty = r*sin(angle);\\n \\n \\tx += 0.0+mod(circleId,grid)*distance;\\n \\ty += 0.0+floor(circleId/grid)*distance;\\n \\n \\t\\n \\tfloat u = x/grid*3.0;// / (grid);\\n \\tfloat v = y/grid*3.0;// / (grid);\\n\\n vec2 xy = vec2(u, v) * 0.2;\\n return xy;\\n}\\n\\nvoid main(){\\n \\tfloat vertexPerCircle = 126.0;\\n \\tfloat circleId = floor(vertexId/vertexPerCircle);\\n \\tfloat grid = 9.0;\\n \\tfloat distance = 4.5;\\n\\n vec2 xy = circle(circleId,grid,distance);\\n \\n gl_Position = vec4(xy.x-1.0,xy.y-1.0, 0.0, 1.0);\\n v_color = vec4(sin(time*xy.x), cos(time*xy.y), cos(xy.x*xy.y), 1.0);\\n\\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 17300, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec2 circle(float circleId,float grid,float distance){\n\tfloat y = mod(vertexId,2.0);\n\tfloat x = floor(vertexId/2.0);\n\tfloat angle = x / 20.0 * radians(360.0);\n\n float r = 2.0 - y;\n\n x = r*cos(angle);\n\ty = r*sin(angle);\n \n \tx += 0.0+mod(circleId,grid)*distance;\n \ty += 0.0+floor(circleId/grid)*distance;\n \n \t\n \tfloat u = x/grid*3.0;// / (grid);\n \tfloat v = y/grid*3.0;// / (grid);\n\n vec2 xy = vec2(u, v) * 0.2;\n return xy;\n}\n\nvoid main(){\n \tfloat vertexPerCircle = 126.0;\n \tfloat circleId = floor(vertexId/vertexPerCircle);\n \tfloat grid = 9.0;\n \tfloat distance = 4.5;\n\n vec2 xy = circle(circleId,grid,distance);\n \n gl_Position = vec4(xy.x-1.0,xy.y-1.0, 0.0, 1.0);\n v_color = vec4(sin(time*xy.x), cos(time*xy.y), cos(xy.x*xy.y), 1.0);\n\n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-8avrkfo47ch9ofmsk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pJM2rdtSkSBnEkMeG/art.json b/art/pJM2rdtSkSBnEkMeG/art.json index e18c95d4..80ed2f56 100644 --- a/art/pJM2rdtSkSBnEkMeG/art.json +++ b/art/pJM2rdtSkSBnEkMeG/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":92244,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/bit-shifter/the-connector-conspiracy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \\n /_/\\\\ /\\\\_\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\_______)\\\\ /\\\\_____\\\\/\\\\ /\\\\ /\\\\/ ____/\\\\ /\\\\_\\\\ /_/\\\\ /\\\\___/\\\\ /\\\\ __/\\\\ /\\\\_____\\\\/_/\\\\__/\\\\ /\\\\___/\\\\ /_/\\\\__/\\\\ /\\\\_______)\\\\ \\n ) ) ) ( (( (_____/) ) ) ) )\\\\(___ __\\\\/( (_____/\\\\ \\\\ \\\\/ / /) ) __\\\\/( ( (_) ) ) / / _ \\\\ \\\\ ) ) \\\\ \\\\( (_____/) ) ) ) ) / / _ \\\\ \\\\ ) ) ) ) )\\\\(___ __\\\\/ \\n/_/ / \\\\ \\\\_\\\\\\\\ \\\\__\\\\ /_/ /_/_/ / / / \\\\ \\\\__\\\\ \\\\ \\\\ / / \\\\ \\\\ \\\\ \\\\ \\\\___/ / \\\\ \\\\(_)/ // / /\\\\ \\\\ \\\\\\\\ \\\\__\\\\ /_/ /_/_/ \\\\ \\\\(_)/ //_/ /_/_/ / / / \\n\\\\ \\\\ \\\\_/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( / /__/_ / / \\\\ \\\\ _\\\\ \\\\ \\\\ / / _ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\/ / // /__/_\\\\ \\\\ \\\\ \\\\ \\\\ / / _ \\\\ \\\\\\\\ \\\\ \\\\ \\\\ \\\\ ( ( ( \\n \\\\ \\\\ / /( (_____\\\\)_) ) \\\\ \\\\ \\\\ \\\\ \\\\ ( (_____\\\\/ / /\\\\ \\\\ \\\\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\\\)_) ) \\\\ \\\\( (_( )_) ))_) ) \\\\ \\\\ \\\\ \\\\ \\\\ \\n \\\\_\\\\_/_/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ /_/_/ \\\\/_____/\\\\/__\\\\/__\\\\/\\\\____\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\/___\\\\/ \\\\/_____/\\\\_\\\\/ \\\\_\\\\/ \\\\/_/ \\\\_\\\\/ \\\\_\\\\/ \\\\_\\\\/ /_/_/ \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.5, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.03 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((0.02 + cu + abs(uv.x * 2. - 1.)) * 0.20, uv.y * 0.05)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.3) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = mix(mix(0.6, 0.7, fract(circleId * 0.79)), 1., step(0.75, snd));\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 92244, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/bit-shifter/the-connector-conspiracy", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n _ _ _____ __ __ _______ _____ __ __ ______ __ __ _____ _____ _____ __ __ _____ __ __ _______ \n /_/\\ /\\_\\ /\\_____\\/_/\\__/\\ /\\_______)\\ /\\_____\\/\\ /\\ /\\/ ____/\\ /\\_\\ /_/\\ /\\___/\\ /\\ __/\\ /\\_____\\/_/\\__/\\ /\\___/\\ /_/\\__/\\ /\\_______)\\ \n ) ) ) ( (( (_____/) ) ) ) )\\(___ __\\/( (_____/\\ \\ \\/ / /) ) __\\/( ( (_) ) ) / / _ \\ \\ ) ) \\ \\( (_____/) ) ) ) ) / / _ \\ \\ ) ) ) ) )\\(___ __\\/ \n/_/ / \\ \\_\\\\ \\__\\ /_/ /_/_/ / / / \\ \\__\\ \\ \\ / / \\ \\ \\ \\ \\___/ / \\ \\(_)/ // / /\\ \\ \\\\ \\__\\ /_/ /_/_/ \\ \\(_)/ //_/ /_/_/ / / / \n\\ \\ \\_/ / // /__/_\\ \\ \\ \\ \\ ( ( ( / /__/_ / / \\ \\ _\\ \\ \\ / / _ \\ \\ / / _ \\ \\\\ \\ \\/ / // /__/_\\ \\ \\ \\ \\ / / _ \\ \\\\ \\ \\ \\ \\ ( ( ( \n \\ \\ / /( (_____\\)_) ) \\ \\ \\ \\ \\ ( (_____\\/ / /\\ \\ \\)____) )( (_( )_) )( (_( )_) )) )__/ /( (_____\\)_) ) \\ \\( (_( )_) ))_) ) \\ \\ \\ \\ \\ \n \\_\\_/_/ \\/_____/\\_\\/ \\_\\/ /_/_/ \\/_____/\\/__\\/__\\/\\____\\/ \\/_/ \\_\\/ \\/_/ \\_\\/ \\/___\\/ \\/_____/\\_\\/ \\_\\/ \\/_/ \\_\\/ \\_\\/ \\_\\/ /_/_/ \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.5, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.03 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((0.02 + cu + abs(uv.x * 2. - 1.)) * 0.20, uv.y * 0.05)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.3) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = mix(mix(0.6, 0.7, fract(circleId * 0.79)), 1., step(0.75, snd));\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-3iomdyru04pexyw7p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pL2zZjniYbicHizRf/art.json b/art/pL2zZjniYbicHizRf/art.json index 1759c146..5085d2da 100644 --- a/art/pL2zZjniYbicHizRf/art.json +++ b/art/pL2zZjniYbicHizRf/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "shortwavedave", "avatarUrl": "https://secure.gravatar.com/avatar/5999d47c7003bd60c3f1bfd965a79666?default=retro&size=200", - "settings": "{\"num\":20536,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/col_eco/noir-master\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * .1;\\n float yoff = 0.;//sin(time + x * 0.2) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n float sv = abs(v - 0.5)*2.;\\n float su = abs(u - 0.5)*2.;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au*0.05, av*.25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n \\n float soff = 0.;//sin(time+x*y*0.02) * 5.;\\n \\n \\n gl_PointSize = pow(snd+0.2, 8.) + 30. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u*.1 + snd*.2 + time *.1;//sin(time + v * 20.)*0.05;\\n float sat = mix(0., 1., pump); //step(0.8, snd);;//mix(2.,-10., av);\\n float val = mix(.1, pow(snd + 0.2, 16.), pump);//sin(time + v*u*20.)*.5 +.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 20536, + "mode": "POINTS", + "sound": "https://soundcloud.com/col_eco/noir-master", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * .1;\n float yoff = 0.;//sin(time + x * 0.2) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n float sv = abs(v - 0.5)*2.;\n float su = abs(u - 0.5)*2.;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au*0.05, av*.25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n \n float soff = 0.;//sin(time+x*y*0.02) * 5.;\n \n \n gl_PointSize = pow(snd+0.2, 8.) + 30. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u*.1 + snd*.2 + time *.1;//sin(time + v * 20.)*0.05;\n float sat = mix(0., 1., pump); //step(0.8, snd);;//mix(2.,-10., av);\n float val = mix(.1, pow(snd + 0.2, 16.), pump);//sin(time + v*u*20.)*.5 +.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-mgrtfvjevpwahma4r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pPELYFMqZXHXgn5Yx/art.json b/art/pPELYFMqZXHXgn5Yx/art.json index f8c16d20..e01c6289 100644 --- a/art/pPELYFMqZXHXgn5Yx/art.json +++ b/art/pPELYFMqZXHXgn5Yx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":59348,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 3.0, 1.0));\\n vec4 K = vec4(-1.0, 4.0 / 1.0, 7.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, 1.-c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 1, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 2); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 0);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nvec3 triangle(float idx) // vec2:p / float triangleIndex\\n{\\n\\tfloat triangleIndex = floor(idx / 16.);\\n\\n\\tfloat index = mod(idx, 6.);\\n\\t\\n\\tvec2 p = vec2(0);\\n\\t\\n\\tif (index == 0.) p = vec2(0,1);\\n\\tif (index == 1.) p = vec2(1,0);\\n\\tif (index == 2.) p = vec2(0,0);\\n\\t\\n\\tif (index == 3.) p = vec2(0,0);\\n\\tif (index == 4.) p = vec2(2,1);\\n\\tif (index == 5.) p = vec2(0,1);\\n\\t\\n\\treturn vec3(p, triangleIndex);\\n}\\n\\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\\n{\\n\\tvec4 res;\\n\\tvec3 pi = triangle(idx);\\n\\t\\n\\tpi.y += floor(pi.z / countQuadsX);\\n pi.x += mod(pi.z, countQuadsX);\\n \\n\\tfloat countQuads = floor(vertexCount / 6.);\\n\\tfloat nx = countQuadsX;\\n\\tfloat ny = floor(countQuads / nx);\\n\\t\\t\\n\\tif (centered == true)\\n\\t{\\n\\t\\tpi.x -= nx * 0.5;\\n\\t\\tpi.y -= ny * 0.5;\\n\\t}\\n\\t\\n\\treturn vec4(pi.xy, nx, ny);\\n}\\n\\n//https://www.shadertoy.com/view/ltK3WD\\nvec4 voronoi(vec2 g )\\n{\\n\\tvec4 f = vec4(9);\\n\\tvec2 p = g /= 120.2 ; f.x=11100.;\\n \\n\\tg += time;\\n\\t\\n float t = time * 0.1;\\n \\n for(int x=-2;x<=2;x++)\\n for(int y=-2;y<=2;y++)\\n {\\t\\n p = vec2(x,y);\\n\\t\\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\\n p *= mat2(cos(t), -sin(t), sin(t), cos(t));\\n //f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\\n\\t\\tf.y = max(abs(p.x), abs(p.y));\\n\\tf.y = dot(p+0.2,p)*0.117;\\n\\t\\tif (f.y < f.x/2.8-f.w)\\n {\\n f.x = f.y;\\n f.zw = p;\\n }\\n }\\n\\t\\n vec3 n = vec3(0);\\n \\n if ( f.x == -f.z*.866 * f.w*1.e2)\\tn = vec3(1,0,0);\\n\\tif ( f.y== f.z*.866 * tan(f.w*1.5)*5.) vec3(1,1,0);\\n\\tif ( f.x >+f.w) \\t\\t\\t\\t\\tn = vec3(1,0,1);\\n\\t\\n return vec4(f.x, n);\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 1.;\\n\\t\\n \\tvec3 uSlider = vec3(322,3, 1.2);\\n \\n\\tfloat thickNess = uSlider.x;\\n\\tfloat countMax = floor(vertexCount / 11.);\\n\\tfloat sizeEdge = floor(sqrt(countMax));\\n\\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\\n\\t\\n\\tvec4 voro = voronoi(p.xy * uSlider.y);\\n\\t\\n\\tfloat d = voro.x;\\n\\tvec3 n = voro.yzw;\\n\\t\\n\\tv_color = vec4(n*d,12.-n);\\n\\n\\tmat4 camera = ident();\\n\\t\\n\\tfloat ca = time * 0.1;\\n\\tfloat cd = 160.;\\n\\tfloat ce = PI * mouse.y;\\n\\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\\n\\tvec3 target = vec3(0,-1, 1);\\n\\tvec3 up = vec3(1,0, 1);\\n \\n\\tcamera = persp(111./ PI / 3., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\\n}\"}", + "settings": { + "num": 59348, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 3.0, 1.0));\n vec4 K = vec4(-1.0, 4.0 / 1.0, 7.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 3.0, 2.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, 1.-c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 1, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 2); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 0);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nvec3 triangle(float idx) // vec2:p / float triangleIndex\n{\n\tfloat triangleIndex = floor(idx / 16.);\n\n\tfloat index = mod(idx, 6.);\n\t\n\tvec2 p = vec2(0);\n\t\n\tif (index == 0.) p = vec2(0,1);\n\tif (index == 1.) p = vec2(1,0);\n\tif (index == 2.) p = vec2(0,0);\n\t\n\tif (index == 3.) p = vec2(0,0);\n\tif (index == 4.) p = vec2(2,1);\n\tif (index == 5.) p = vec2(0,1);\n\t\n\treturn vec3(p, triangleIndex);\n}\n\nvec4 gridMesh(float idx, float countQuadsX, bool centered) // vec2 p / vec2 size\n{\n\tvec4 res;\n\tvec3 pi = triangle(idx);\n\t\n\tpi.y += floor(pi.z / countQuadsX);\n pi.x += mod(pi.z, countQuadsX);\n \n\tfloat countQuads = floor(vertexCount / 6.);\n\tfloat nx = countQuadsX;\n\tfloat ny = floor(countQuads / nx);\n\t\t\n\tif (centered == true)\n\t{\n\t\tpi.x -= nx * 0.5;\n\t\tpi.y -= ny * 0.5;\n\t}\n\t\n\treturn vec4(pi.xy, nx, ny);\n}\n\n//https://www.shadertoy.com/view/ltK3WD\nvec4 voronoi(vec2 g )\n{\n\tvec4 f = vec4(9);\n\tvec2 p = g /= 120.2 ; f.x=11100.;\n \n\tg += time;\n\t\n float t = time * 0.1;\n \n for(int x=-2;x<=2;x++)\n for(int y=-2;y<=2;y++)\n {\t\n p = vec2(x,y);\n\t\tp += .5 + .5*sin( t * 10. + 9. * fract(sin((floor(g)+p)*mat2(2,5,5,2)))) - fract(g);\n p *= mat2(cos(t), -sin(t), sin(t), cos(t));\n //f.y = max(abs(p.x)*.866 - p.y*.5, p.y);\n\t\tf.y = max(abs(p.x), abs(p.y));\n\tf.y = dot(p+0.2,p)*0.117;\n\t\tif (f.y < f.x/2.8-f.w)\n {\n f.x = f.y;\n f.zw = p;\n }\n }\n\t\n vec3 n = vec3(0);\n \n if ( f.x == -f.z*.866 * f.w*1.e2)\tn = vec3(1,0,0);\n\tif ( f.y== f.z*.866 * tan(f.w*1.5)*5.) vec3(1,1,0);\n\tif ( f.x >+f.w) \t\t\t\t\tn = vec3(1,0,1);\n\t\n return vec4(f.x, n);\n}\n\nvoid main()\n{\n\tgl_PointSize = 1.;\n\t\n \tvec3 uSlider = vec3(322,3, 1.2);\n \n\tfloat thickNess = uSlider.x;\n\tfloat countMax = floor(vertexCount / 11.);\n\tfloat sizeEdge = floor(sqrt(countMax));\n\tvec4 p = gridMesh(vertexId, sizeEdge, true) * uSlider.z;\n\t\n\tvec4 voro = voronoi(p.xy * uSlider.y);\n\t\n\tfloat d = voro.x;\n\tvec3 n = voro.yzw;\n\t\n\tv_color = vec4(n*d,12.-n);\n\n\tmat4 camera = ident();\n\t\n\tfloat ca = time * 0.1;\n\tfloat cd = 160.;\n\tfloat ce = PI * mouse.y;\n\tvec3 eye = vec3(sin(ca), sin(ce), cos(ca)) * cd;\n\tvec3 target = vec3(0,-1, 1);\n\tvec3 up = vec3(1,0, 1);\n \n\tcamera = persp(111./ PI / 3., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p.x, voro.x * thickNess - thickNess * 0.2, p.y, 1);\n}" + }, "screenshotURL": "data/images/images-bs0h3qbgcy93ex5ji-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pRZmCzjhGZcbAydiQ/art.json b/art/pRZmCzjhGZcbAydiQ/art.json index 8020c9e9..0bc19547 100644 --- a/art/pRZmCzjhGZcbAydiQ/art.json +++ b/art/pRZmCzjhGZcbAydiQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":82255,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 * mouse.x\\n#define KP1 3.0 * mouse.y\\n#define K0 KP0 KP0//KParameter0 0.>>1000.\\n#define K1 KP1 KP1//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>10.\\n#define KP3 0.0//KParameter3 0.000>>0.5\\n#define KP4 5.0//KParameter4 0.000>>5.\\n#define KP5 10000.0//KParameter5 30.000>>100000.0\\n\\n\\n#define PI radians(180. -KP1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.4 / 3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0.04, 0, 0,\\n 0, -(2.*c), s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.003,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][2], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 3.\\n#define FACES_PER_CUBE 4.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(1.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 2.0), 6.0);\\n float a = pointId * PI * 2. / 2. + PI * 1.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.15)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 4.), 1.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(1.2 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP5 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 10.01;\\n float end = 2.*sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv*4.,mouse.xy;\\n \\n vec3 eye = vec3(-s, s/KP1, 1)*KP1;//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 1.-s2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(s-0.5),1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(2, aspect, s) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.-s2)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) *-h + pow(s2+22.2, 5.) * KP3 - 110. * sign(h));\\n mat *= scale(vec3(1.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 1.3 + cgId * s /0.4;\\n float sat = 11. * step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 1.*s2;\\n v_color = vec4(hsv2rgb(vec3(hue*s *mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 82255, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 * mouse.x\n#define KP1 3.0 * mouse.y\n#define K0 KP0 KP0//KParameter0 0.>>1000.\n#define K1 KP1 KP1//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>10.\n#define KP3 0.0//KParameter3 0.000>>0.5\n#define KP4 5.0//KParameter4 0.000>>5.\n#define KP5 10000.0//KParameter5 30.000>>100000.0\n\n\n#define PI radians(180. -KP1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.4 / 3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0.04, 0, 0,\n 0, -(2.*c), s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.003,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][2], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 3.\n#define FACES_PER_CUBE 4.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(1.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 2.0), 6.0);\n float a = pointId * PI * 2. / 2. + PI * 1.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.15)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 4.), 1.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(1.2 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP5 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 10.01;\n float end = 2.*sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv*4.,mouse.xy;\n \n vec3 eye = vec3(-s, s/KP1, 1)*KP1;//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 1.-s2);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(s-0.5),1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(2, aspect, s) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.-s2)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) *-h + pow(s2+22.2, 5.) * KP3 - 110. * sign(h));\n mat *= scale(vec3(1.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 1.3 + cgId * s /0.4;\n float sat = 11. * step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 1.*s2;\n v_color = vec4(hsv2rgb(vec3(hue*s *mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-u1matgvqlff34c2pb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pRauSxj3mNSdRas9Y/art.json b/art/pRauSxj3mNSdRas9Y/art.json index 40f33a5d..99eecc5b 100644 --- a/art/pRauSxj3mNSdRas9Y/art.json +++ b/art/pRauSxj3mNSdRas9Y/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#40190.0\\n//Another experiment of 'vertexification' of a fragment shader \\n\\n#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0.8,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\tif(v>0.5)\\n v = 1.- v;\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., 0.0)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = .3;\\n float tm = 1.5 *time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\\n //vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0.,0.,0.);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n //gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\\n \\n gl_Position = mat*finalPos;\\n gl_PointSize = 2.;///abs(gl_Position.z);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/dark_trance/azzault-technicolors-of-lsd", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#40190.0\n//Another experiment of 'vertexification' of a fragment shader \n\n#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0.8,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\tif(v>0.5)\n v = 1.- v;\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., 0.0)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*(3.+15.))/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = .3;\n float tm = 1.5 *time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r/10., 0.3, r);\n //vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0.,0.,0.);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n //gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+snd*depth , 1.);\n \n gl_Position = mat*finalPos;\n gl_PointSize = 2.;///abs(gl_Position.z);\n \n //v_color = vec4(1.,1.,1.,1.);\n}\n\n" + }, "screenshotURL": "data/images/images-tlr2zldpo04caak0a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pSfPvCpxgd22izj4C/art.json b/art/pSfPvCpxgd22izj4C/art.json index f206ee5b..9de7f1dc 100644 --- a/art/pSfPvCpxgd22izj4C/art.json +++ b/art/pSfPvCpxgd22izj4C/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 1.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = tan( angle/time );\\n float c =cos( angle *2.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle - 33. );\\n float c = fract(mix( time,angle *17.,s)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 1, 1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 1.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 0.5));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = tan( angle/time );\n float c =cos( angle *2.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle - 33. );\n float c = fract(mix( time,angle *17.,s)/ time*22.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 1, 1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /12.0);\n}" + }, "screenshotURL": "data/images/images-eumxgg61iadmtn6pj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pTwLX9y5LQfFD3iey/art.json b/art/pTwLX9y5LQfFD3iey/art.json index 472f4fbd..ef712d40 100644 --- a/art/pTwLX9y5LQfFD3iey/art.json +++ b/art/pTwLX9y5LQfFD3iey/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec2 field(vec2 pos) {\\n // just for easier readability\\n float x = pos.x;\\n float y = pos.y;\\n \\n // vector field mapping\\n return vec2(\\n -y,\\n x\\n );\\n}\\n\\nvoid main() {\\n // mouse position is the droplets position in this example\\n gl_Position = vec4(mouse.x, mouse.y, 0,1);\\n \\n // apply vector field to the next point\\n // to demonstrate effect of vector field\\n if (vertexId == 1.) {\\n vec2 d = field(mouse.xy);\\n d = normalize(d);\\n gl_Position += vec4(d.x, d.y, 0,1);\\n }\\n \\n \\n gl_PointSize = vertexId * 2.;\\n v_color = vec4(1.0 - vertexId,1,1,1);\\n}\"}", + "settings": { + "num": 2, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec2 field(vec2 pos) {\n // just for easier readability\n float x = pos.x;\n float y = pos.y;\n \n // vector field mapping\n return vec2(\n -y,\n x\n );\n}\n\nvoid main() {\n // mouse position is the droplets position in this example\n gl_Position = vec4(mouse.x, mouse.y, 0,1);\n \n // apply vector field to the next point\n // to demonstrate effect of vector field\n if (vertexId == 1.) {\n vec2 d = field(mouse.xy);\n d = normalize(d);\n gl_Position += vec4(d.x, d.y, 0,1);\n }\n \n \n gl_PointSize = vertexId * 2.;\n v_color = vec4(1.0 - vertexId,1,1,1);\n}" + }, "screenshotURL": "data/images/images-s282s8olr9u4abgtn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pXFLLtyZTzr6G4BSt/art.json b/art/pXFLLtyZTzr6G4BSt/art.json index dd84a454..386dde49 100644 --- a/art/pXFLLtyZTzr6G4BSt/art.json +++ b/art/pXFLLtyZTzr6G4BSt/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "優斗", "avatarUrl": "https://lh6.googleusercontent.com/-7lDk3Xe1fns/AAAAAAAAAAI/AAAAAAAAxfY/U4fHGcEU_pQ/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.34901960784313724,0.8470588235294118,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = \\n sin(time + su * 11.2) + \\n sin(time + sin(su * sv * 2.) * 17.2) + \\n sin(time + sv * 40.0) +\\n sin(time * -5. + sv * 33.) * .2;\\n s *= 0.15;\\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*1.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5 + sin(time);\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, 0, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * .1;\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 10. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + .5) * 1.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1) + sin(time) * .5;\\n \\n float hue = 0.6 + qu * 0. + p.y * 0.1; \\n float sat = pow(1. - p.y, 2.);\\n float val = mix(0.05 + time * .1, 1., l);\\n \\n float ss = texture2D(sound, vec2(fract(hash(qu) + qv + time * 0.5) + sin(time) * 1.5, 1.)).a;\\n float pop = step(.45, ss);\\n val = mix(val, 1., pop);\\n hue = mix(hue, hue + .5 + time * .1, pop);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/absolutevalentine/absolute-valentine-in-the-42nd-street", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.34901960784313724, + 0.8470588235294118, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = \n sin(time + su * 11.2) + \n sin(time + sin(su * sv * 2.) * 17.2) + \n sin(time + sv * 40.0) +\n sin(time * -5. + sv * 33.) * .2;\n s *= 0.15;\n // texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*1.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5 + sin(time);\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, 0, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * .1;\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 10. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + .5) * 1.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1) + sin(time) * .5;\n \n float hue = 0.6 + qu * 0. + p.y * 0.1; \n float sat = pow(1. - p.y, 2.);\n float val = mix(0.05 + time * .1, 1., l);\n \n float ss = texture2D(sound, vec2(fract(hash(qu) + qv + time * 0.5) + sin(time) * 1.5, 1.)).a;\n float pop = step(.45, ss);\n val = mix(val, 1., pop);\n hue = mix(hue, hue + .5 + time * .1, pop);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-sdzr9m42nihvb188f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pYmg39piqotd25sYc/art.json b/art/pYmg39piqotd25sYc/art.json index 0d165283..91c3d4c4 100644 --- a/art/pYmg39piqotd25sYc/art.json +++ b/art/pYmg39piqotd25sYc/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7082,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][3], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 0\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n mat4 mat = rotY(time);\\n vec3 point = vec3(0.0);\\n vec3 normal = vec3(0.0);\\n getCubePoint(vertexId, point, normal);\\n mat4 camera = mat4(\\n 0.45, 0.0, 0.0, 0.0,\\n 0.0, 1.0, 0.0, 0.0,\\n 0.0, 0.0, 1.0, 0.1,\\n 0.0, 0.0, 0.2, 1.0\\n );\\n gl_Position = camera * mat * vec4(point, 1);\\n //gl_Position /= gl_Position.w;\\n vec3 correctedNormal = (mat*vec4(normal, 1.0)).xyz;\\n float brightness = dot(correctedNormal, normalize(vec3(-1,-1,-1)));\\n v_color = vec4(1.0*brightness, 0.0, 0.0, 1.0);\\n}\\n\\n#endif\"}", + "settings": { + "num": 7082, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][3], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 0\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n mat4 mat = rotY(time);\n vec3 point = vec3(0.0);\n vec3 normal = vec3(0.0);\n getCubePoint(vertexId, point, normal);\n mat4 camera = mat4(\n 0.45, 0.0, 0.0, 0.0,\n 0.0, 1.0, 0.0, 0.0,\n 0.0, 0.0, 1.0, 0.1,\n 0.0, 0.0, 0.2, 1.0\n );\n gl_Position = camera * mat * vec4(point, 1);\n //gl_Position /= gl_Position.w;\n vec3 correctedNormal = (mat*vec4(normal, 1.0)).xyz;\n float brightness = dot(correctedNormal, normalize(vec3(-1,-1,-1)));\n v_color = vec4(1.0*brightness, 0.0, 0.0, 1.0);\n}\n\n#endif" + }, "screenshotURL": "data/images/images-3cpxxovn8lkbtvifn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pcFf7Ynz5GZBSca78/art.json b/art/pcFf7Ynz5GZBSca78/art.json index 92724e88..4b541ecb 100644 --- a/art/pcFf7Ynz5GZBSca78/art.json +++ b/art/pcFf7Ynz5GZBSca78/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":11341,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles.\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n\\n \\tfloat ux = floor(id/ 6.) + mod(id,2.);\\n \\tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\\n \\n \\tfloat angle = ux / numCircleSegments * PI * 2.;\\n \\tfloat c = cos(angle);\\n \\tfloat s = sin(angle);\\n\\n \\tfloat radius = vy + 1.;\\n \\n \\tfloat x = c * radius;\\n \\tfloat y = s * radius;\\n \\n \\treturn vec2(x,y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 36.;\\n \\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.5, av * .25)).a;\\n\\n\\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2,5.) + mix(1.,1.1,oddSlice);\\n \\n sc *= 20. / across ;\\n \\n vec4 pos = vec4(circleXY, 0 ,1);\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(1,aspect,1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux,vy,0) * 1.3);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03*sc);\\n\\n\\n \\n gl_Position = mat * pos;\\n \\n\\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n\\n \\n float pump = step(0.3, snd)* abs(sin(time));\\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\\n float sat = 1.;mix(0.5, 1., pump) * oddSlice;\\n float val = 1.;mix(.4, pow(snd + 0.2, 5.), pump );\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 11341, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Circles from Triangles.\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n\n \tfloat ux = floor(id/ 6.) + mod(id,2.);\n \tfloat vy = mod(floor(id/2.) + floor(id / 3.), 2.);\n \n \tfloat angle = ux / numCircleSegments * PI * 2.;\n \tfloat c = cos(angle);\n \tfloat s = sin(angle);\n\n \tfloat radius = vy + 1.;\n \n \tfloat x = c * radius;\n \tfloat y = s * radius;\n \n \treturn vec2(x,y);\n}\n\n\nvoid main() {\n float numCircleSegments = 36.;\n \n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.5, av * .25)).a;\n\n\n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2,5.) + mix(1.,1.1,oddSlice);\n \n sc *= 20. / across ;\n \n vec4 pos = vec4(circleXY, 0 ,1);\n mat4 mat = ident();\n \n mat *= scale(vec3(1,aspect,1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux,vy,0) * 1.3);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03*sc);\n\n\n \n gl_Position = mat * pos;\n \n\n float soff = 0.;//sin(time + x * y * .02) * 5.; \n\n \n float pump = step(0.3, snd)* abs(sin(time));\n float hue = u * .1 + snd * 0.2 + time * .1 + sliceId * 0.1; //sin(time + v * 20.) * .05;\n float sat = 1.;mix(0.5, 1., pump) * oddSlice;\n float val = 1.;mix(.4, pow(snd + 0.2, 5.), pump );\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-do92yaihpb4gnjk0i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pd5cBhZ239NhxnEim/art.json b/art/pd5cBhZ239NhxnEim/art.json index 1eb5db5e..097e0258 100644 --- a/art/pd5cBhZ239NhxnEim/art.json +++ b/art/pd5cBhZ239NhxnEim/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":29897,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 4\\n#define KP0 mouse.y\\n#define KP1 mouse.x\\n#define zoom (mouse.x+mouse.y)\\n#define KP2 0.\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\n\\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 2., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \\ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \\ntriangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( 126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \\ntriangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \\ntriangles[ 8]=vec4( 1., 42.0, 1326.0, 4.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 29897, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 4\n#define KP0 mouse.y\n#define KP1 mouse.x\n#define zoom (mouse.x+mouse.y)\n#define KP2 0.\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\n\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 2., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \ntriangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \ntriangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \ntriangles[ 4]=vec4( 126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \ntriangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \ntriangles[ 8]=vec4( 1., 42.0, 1326.0, 4.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-n0ga9ljlw8bb8x7ex-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pdBhFCkcfrYsBY3P5/art.json b/art/pdBhFCkcfrYsBY3P5/art.json index 6a597f88..84169ac4 100644 --- a/art/pdBhFCkcfrYsBY3P5/art.json +++ b/art/pdBhFCkcfrYsBY3P5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 1.5 * 0.5 * fov);\\n float rangeInv = 0.3 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = max(b04, -b01)* b11 - b02 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0.1,\\n zAxis, -1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.2,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.0);}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 11.1;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\t\\n\\tvec3 p = vec3(0.1);\\n\\t\\n\\tfloat indexQuad = floor(vertexId / 6.);\\n\\t\\n\\tfloat index = mod(vertexId, 6.);\\n\\t\\n\\tfloat countSection = floor(6.);\\n\\t\\n\\tfloat indexCircle = floor(indexQuad / countSection);\\n\\t\\n\\tfloat astep = 3.14159 * 2.0 / countSection;\\n\\t\\n\\tfloat angle0 = indexQuad * astep;\\n\\tfloat angle1 = (indexQuad + 1.) * astep;\\n\\t\\n\\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\\n\\tfloat angleTorus = indexCircle * astepTorus;\\n\\t\\n\\tfloat radius = 4. * cos(angleTorus * 1.5 + time) * 2.;\\n\\t\\n\\t// triangle 1\\n\\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\\n\\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\t\\n\\t// triangle 2\\n\\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\\n\\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\\n\\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\\n\\t\\n \\tfloat atten = p.x;\\n \\n\\tp *= RotX(-angleTorus);\\n\\t\\n\\tp.z += 11. * cos(angleTorus);\\n\\tp.y += 11. + sin(angleTorus)*22.0*mouse.y;\\n\\t\\n\\t// cam\\n\\tfloat ca = 3.14159 * 0.6;\\n\\tfloat cd = 50.;\\n\\tvec3 eye = vec3(sin(ca), 1.5, cos(ca)) * cd;\\n\\tvec3 target = vec3(2.*mouse.x, -mouse.y, 0.5);\\n\\tvec3 up = vec3(0.9+mouse.x, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI /190., resolution.x / resolution.y, 0.1 , 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n \\t// pos\\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\t// color\\n \\tp /= atten;\\n \\n\\tv_color = vec4(normalize(p) * -.5 + .3, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "////////////////////////////////////////////////////////////\n#define PI radians(180.)\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 1.5 * 0.5 * fov);\n float rangeInv = 0.3 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = max(b04, -b01)* b11 - b02 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0.1,\n zAxis, -1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.2,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.0);}\n\nvoid main()\n{\n\tgl_PointSize = 11.1;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\t\n\tvec3 p = vec3(0.1);\n\t\n\tfloat indexQuad = floor(vertexId / 6.);\n\t\n\tfloat index = mod(vertexId, 6.);\n\t\n\tfloat countSection = floor(6.);\n\t\n\tfloat indexCircle = floor(indexQuad / countSection);\n\t\n\tfloat astep = 3.14159 * 2.0 / countSection;\n\t\n\tfloat angle0 = indexQuad * astep;\n\tfloat angle1 = (indexQuad + 1.) * astep;\n\t\n\tfloat astepTorus = 3.14159 * 2.0 / floor(66.);\n\tfloat angleTorus = indexCircle * astepTorus;\n\t\n\tfloat radius = 4. * cos(angleTorus * 1.5 + time) * 2.;\n\t\n\t// triangle 1\n\tif (index == 0.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 1.) p = vec3(cos(angle1) * radius, 0., sin(angle1) * radius);\n\tif (index == 2.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\t\n\t// triangle 2\n\tif (index == 3.) p = vec3(cos(angle0) * radius, 0., sin(angle0) * radius);\n\tif (index == 4.) p = vec3(cos(angle1) * radius, 1., sin(angle1) * radius);\n\tif (index == 5.) p = vec3(cos(angle0) * radius, 1., sin(angle0) * radius);\n\t\n \tfloat atten = p.x;\n \n\tp *= RotX(-angleTorus);\n\t\n\tp.z += 11. * cos(angleTorus);\n\tp.y += 11. + sin(angleTorus)*22.0*mouse.y;\n\t\n\t// cam\n\tfloat ca = 3.14159 * 0.6;\n\tfloat cd = 50.;\n\tvec3 eye = vec3(sin(ca), 1.5, cos(ca)) * cd;\n\tvec3 target = vec3(2.*mouse.x, -mouse.y, 0.5);\n\tvec3 up = vec3(0.9+mouse.x, 1, 0);\n \n\tmat4 camera = persp(45. * PI /190., resolution.x / resolution.y, 0.1 , 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n \t// pos\n\tgl_Position = camera * vec4(p, 1);\n\t\n \t// color\n \tp /= atten;\n \n\tv_color = vec4(normalize(p) * -.5 + .3, 1);\n}" + }, "screenshotURL": "data/images/images-lgo0r2pt0r9sl3k76-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pdHu6xfHPYi6Yznt5/art.json b/art/pdHu6xfHPYi6Yznt5/art.json index 6aa56b9b..4e150d45 100644 --- a/art/pdHu6xfHPYi6Yznt5/art.json +++ b/art/pdHu6xfHPYi6Yznt5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mike-tobia", "avatarUrl": "https://avatars.githubusercontent.com/mike-tobia?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/louisfuton/venice\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float snd = texture2D(sound, vec2(u, v)).a;\\n \\n float xoff = 0.; // sin(time + y * .2) * .1;\\n float yoff = 0.; // sin(time + x * .3) * .1;\\n float zoff = 0.; // sin(time + 1. * .3) * .1;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float scalar = 1.3;\\n float scale = scalar;\\n \\n vec2 xy = vec2(ux, vy) * scale;\\n float z = 1. * mod(scale * zoff, 1.);\\n \\n gl_Position = vec4(xy, z, 1.);\\n \\n float soff = sin(time + xy.x * xy.y * .002);\\n \\n gl_PointSize = 150. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n float hue = 1.29;\\n float sat = 1.;\\n float val = snd;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/louisfuton/venice", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float snd = texture2D(sound, vec2(u, v)).a;\n \n float xoff = 0.; // sin(time + y * .2) * .1;\n float yoff = 0.; // sin(time + x * .3) * .1;\n float zoff = 0.; // sin(time + 1. * .3) * .1;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float scalar = 1.3;\n float scale = scalar;\n \n vec2 xy = vec2(ux, vy) * scale;\n float z = 1. * mod(scale * zoff, 1.);\n \n gl_Position = vec4(xy, z, 1.);\n \n float soff = sin(time + xy.x * xy.y * .002);\n \n gl_PointSize = 150. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n float hue = 1.29;\n float sat = 1.;\n float val = snd;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-2gkh89tc26uhtf521-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pezdXhrAjHoNYKCWE/art.json b/art/pezdXhrAjHoNYKCWE/art.json index 8140099c..7b85dca6 100644 --- a/art/pezdXhrAjHoNYKCWE/art.json +++ b/art/pezdXhrAjHoNYKCWE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 11\\\\\\\\ 13\\\\\\\\ 15,(16,17) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n \\n \\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.5,1.0);\\n float sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\\n gl_PointSize=sample*3.0;\\n gl_Position.z=(sample);\\n v_color =vec4(sample);\\n \\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n \n \n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.5,1.0);\n float sample =texture2D(sound, (gl_Position.xy+1.0)/2.0 ).a;\n gl_PointSize=sample*3.0;\n gl_Position.z=(sample);\n v_color =vec4(sample);\n \n \n}" + }, "screenshotURL": "data/images/images-bv9tqqzvlik4ueum1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pfa9757K3NJx6euhN/art.json b/art/pfa9757K3NJx6euhN/art.json index 838bb4d2..abaf5c60 100644 --- a/art/pfa9757K3NJx6euhN/art.json +++ b/art/pfa9757K3NJx6euhN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n \\n float near = 0.01;\\n float far = 25.0;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, near, far);\\n mat4 cmat = ident();\\n cmat *= rotX(mouse.y * PI);\\n cmat *= rotY(mouse.x * -PI);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos = vec3(\\n hash(vertexId * 0.123), \\n hash(vertexId * 0.357), \\n // fract(hash(vertexId * 0.531) - time * .01)) * vec3(2, 2, -40) - vec3(1, 1, -20);\\n fract(hash(vertexId * 0.531) + time * .05)) * 2. - 1.;\\n float d = length(pos);\\n pos *= vec3(2);\\n \\n vec3 boxMin = (cmat * vec4(-1, -1, 0, 1)).xyz;\\n vec3 boxMax = (cmat * vec4(1, 1, -20, 1)).xyz;\\n \\n \\n \\n\\n /*\\n\\n +--------+--------+--------+--------+\\n | | | | |\\n | |\\\\ | | |\\n | | \\\\ | | |\\n | | \\\\ | | |\\n +--------+--------+--------+--------+\\n | | \\\\ | | |\\n | | \\\\ | | |\\n | | \\\\ | | |\\n | | \\\\| | |\\n +--------+--------c--------+--------+\\n | | /| | |\\n | | / | | |\\n | | / | | |\\n | | / | | |\\n +--------+--------+--------+--------+\\n | | / | | |\\n | | / | | |\\n | |/ | | |\\n | | | | |\\n +--------+--------+--------+--------+\\n\\n */\\n \\n \\n //mat[2][2] /= far;\\n //mat[2][3] /= far;\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n // gl_Position.z = gl_Position.z * gl_Position.w / far; \\n\\n \\n /*\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n rangeInv = 1.0 / (near - far)\\n rangnInv = 1.0 / (0.01 - 25.0)\\n rangeInv = 1.0 / -24.99\\n rangeInv = -0.040016006402561027\\n\\n -0.1 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = -0.000996\\n -20 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = 0.1988\\n\\n\\n */\\n \\n vec4 f = gl_Position;\\n float depth = f.z * .5 + .5;\\n \\n gl_PointSize = mix(10.0, 1.0, depth);\\n v_color = vec4(hsv2rgb(vec3(hash(vertexId * 0.237), 0.25, 1)), 1. - d);\\n v_color.rgb *= v_color.a;\\n// v_color = vec4(hsv2rgb(vec3(depth, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n \n float near = 0.01;\n float far = 25.0;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, near, far);\n mat4 cmat = ident();\n cmat *= rotX(mouse.y * PI);\n cmat *= rotY(mouse.x * -PI);\n mat4 vmat = inverse(cmat);\n \n vec3 pos = vec3(\n hash(vertexId * 0.123), \n hash(vertexId * 0.357), \n // fract(hash(vertexId * 0.531) - time * .01)) * vec3(2, 2, -40) - vec3(1, 1, -20);\n fract(hash(vertexId * 0.531) + time * .05)) * 2. - 1.;\n float d = length(pos);\n pos *= vec3(2);\n \n vec3 boxMin = (cmat * vec4(-1, -1, 0, 1)).xyz;\n vec3 boxMax = (cmat * vec4(1, 1, -20, 1)).xyz;\n \n \n \n\n /*\n\n +--------+--------+--------+--------+\n | | | | |\n | |\\ | | |\n | | \\ | | |\n | | \\ | | |\n +--------+--------+--------+--------+\n | | \\ | | |\n | | \\ | | |\n | | \\ | | |\n | | \\| | |\n +--------+--------c--------+--------+\n | | /| | |\n | | / | | |\n | | / | | |\n | | / | | |\n +--------+--------+--------+--------+\n | | / | | |\n | | / | | |\n | |/ | | |\n | | | | |\n +--------+--------+--------+--------+\n\n */\n \n \n //mat[2][2] /= far;\n //mat[2][3] /= far;\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n // gl_Position.z = gl_Position.z * gl_Position.w / far; \n\n \n /*\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n rangeInv = 1.0 / (near - far)\n rangnInv = 1.0 / (0.01 - 25.0)\n rangeInv = 1.0 / -24.99\n rangeInv = -0.040016006402561027\n\n -0.1 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = -0.000996\n -20 * (0.1 + 25.0) * -0.04001 + 1 * (0.1 * 25.0 * -0.04001) * 2 = 0.1988\n\n\n */\n \n vec4 f = gl_Position;\n float depth = f.z * .5 + .5;\n \n gl_PointSize = mix(10.0, 1.0, depth);\n v_color = vec4(hsv2rgb(vec3(hash(vertexId * 0.237), 0.25, 1)), 1. - d);\n v_color.rgb *= v_color.a;\n// v_color = vec4(hsv2rgb(vec3(depth, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-7zplw5h84p814v76s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pfvzcjCrHYCpRDiaz/art.json b/art/pfvzcjCrHYCpRDiaz/art.json index b55d52b8..053c8ff8 100644 --- a/art/pfvzcjCrHYCpRDiaz/art.json +++ b/art/pfvzcjCrHYCpRDiaz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":19218,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12156862745098039,0.12156862745098039,0.12156862745098039,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n cos(t+i*16.9553) +\\n sin(t*1.311*i) +\\n sin(t*1.4+i*1.53) +\\n cos(t*1.84+sin(i*1.76)),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311/12.1) +\\n sin(t*1.4+i*1.353/2.1) /\\n tan(t*1.84+i*.476* 12.1),\\n sin(t+i*.5553-2.1)*\\n cos(t/2.3-i*1.1-32.1) +\\n sin(t-3.4*t-1.23+2.1) -\\n sin(t*cos(.088-i*12.1))\\n\\t)*11.002;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)-3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)-ofs;\\n \\n vec3 posf = fract(pos-0.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(9.4-smoothstep(lerpEnd, 11.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)-10.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.001));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,1.8);\\n pos.xz *= mat2(.8,.6,10.6, mouse.x* 111.8);\\n \\n pos *= 0.8;\\n \\n\\n pos.z += .37;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 0.1/pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs)*mouse.y/6.,1e-9))- 2.01- 0.7,0.03);\\n}\"}", + "settings": { + "num": 19218, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12156862745098039, + 0.12156862745098039, + 0.12156862745098039, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n cos(t+i*16.9553) +\n sin(t*1.311*i) +\n sin(t*1.4+i*1.53) +\n cos(t*1.84+sin(i*1.76)),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311/12.1) +\n sin(t*1.4+i*1.353/2.1) /\n tan(t*1.84+i*.476* 12.1),\n sin(t+i*.5553-2.1)*\n cos(t/2.3-i*1.1-32.1) +\n sin(t-3.4*t-1.23+2.1) -\n sin(t*cos(.088-i*12.1))\n\t)*11.002;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)-3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)-ofs;\n \n vec3 posf = fract(pos-0.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(9.4-smoothstep(lerpEnd, 11.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)-10.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.001));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,1.8);\n pos.xz *= mat2(.8,.6,10.6, mouse.x* 111.8);\n \n pos *= 0.8;\n \n\n pos.z += .37;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 0.1/pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs)*mouse.y/6.,1e-9))- 2.01- 0.7,0.03);\n}" + }, "screenshotURL": "data/images/images-q6m6c0pnixfb796e2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pggHYRd53sWWpFR39/art.json b/art/pggHYRd53sWWpFR39/art.json index 06966ec1..79d49deb 100644 --- a/art/pggHYRd53sWWpFR39/art.json +++ b/art/pggHYRd53sWWpFR39/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "evan_chen", "avatarUrl": "https://secure.gravatar.com/avatar/cf83fa7e8a58a2de525a1b42e8550220?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n/* \\n \\n \\n .___ __ . \\n [__ . , _.._ / `|_ _ ._ \\n [___ \\\\/ (_][ )____\\\\__.[ )(/,[ ) \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n \\n 01/01/2019 \\n*/ \\n\\n#pragma region \\n#pragma endregion \\n\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\n\\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif \\n\\n#pragma region Pre_Define\\n\\t#define PI radians(180.)\\n#pragma endregion \\n\\n#pragma region const\\n\\tconst float FARCLIPPED = 1000. ;\\n\\tconst float NEARCLIPPED = 0.1\\t ; \\n float g_cameraFar = 1000.0;\\n\\n#pragma endregion \\n\\n\\n#pragma region MatrixConverte \\n\\t\\n mat4 mAspect = mat4\\n (\\n 1, 0, 0, 0,\\n 0, resolution.x / resolution.y, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1\\n ); \\n vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\n\\n mat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n }\\n\\n\\n mat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n }\\n\\n mat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n }\\n\\n mat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n }\\n\\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n }\\n\\n mat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n\\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n }\\n\\n mat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n }\\n\\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n }\\n\\n mat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n }\\n#pragma region \\n\\n#pragma region Func \\n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\\n {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n\\n }\\n // hash function from https://www.shadertoy.com/view/4djSRW\\n float hash(float p) \\n {\\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x * p2.y * 95.4337);\\n }\\n\\n float m1p1(float v) //normalize to NDC \\n {\\n return v * 2. - 1.;\\n }\\n\\n float inv(float v) \\n {\\n return 1. - v;\\n } \\n\\n\\n\\t\\n#pragma endregion \\n\\n\\n#pragma region Scene_Vertex_Collection \\n struct SceneVertex\\n {\\n vec3 vWorldPos;\\n vec3 vColor;\\n float fAlpha;\\n };\\n\\n struct SurfaceInfo \\n {\\n vec3 vPos;\\n vec3 vNormal;\\n float fGloss;\\n };\\n struct SphereInfo\\n {\\t\\n\\t \\n vec3 vOrigin;\\n float fRadius ; \\n \\n \\n \\n float fSlices ; \\n float fSegments ; \\n }; \\n#pragma endregion \\n \\n\\n\\n#pragma region GetInfo \\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nvoid GetQuadInfo(const float vertexIndex,\\n out vec2 quadVertId,\\n \\n out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\t\\nvoid GetQuadTileInfo(const vec2 quadVertId,\\n const float quadId,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo(const float vertexIndex,\\n const vec2 vDim,\\n \\n out vec2 vQuadTileIndex,\\n out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\\n{\\n return in_Normal ; \\n}\\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\\n{\\n return in_SI.vOrigin + vPos ; \\n}\\nfloat GetSphereQuadCount(const SphereInfo in_SI)\\n{\\n return in_SI.fSegments * in_SI.fSlices; \\n}\\nfloat GetSphereVertexCount(const SphereInfo in_SI)\\n{ \\n return GetSphereQuadCount(in_SI) * 6.; \\n}\\n\\n\\n// From Shadertoy \\\"Hash without sine - Dave Hoskins\\\"\\n// https://www.shadertoy.com/view/4djSRW\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nvec4 hash41(float p)\\n{\\n\\tvec4 p4 = fract(vec4(p) * MOD4);\\n p4 += dot(p4, p4.wzxy+19.19);\\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\\n \\n}\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\n//FBM step \\n#define k_fmbSteps 10\\nfloat FBM( vec2 p, float repeat, float ps ) {\\n\\tfloat f = 0.0;\\n float tot = 0.0;\\n float a = 1.0; \\t\\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\\n GenFloor(camPos , vertexId, sv) ; \\n vertexIndex -= floorTileCount ; \\n \\n /*draw the sphere*/\\n /*\\n \\tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\\n {\\n GenSphere(vertexIndex, sphereInfo, sv);\\n }\\n \\tvertexIndex -= fSphereVertexCount ; \\n */\\n \\n #pragma endregion \\n \\n \\n #pragma region add to glsl\\n \\n gl_Position = m * vec4(sv.vWorldPos, 1.); \\n \\tgl_PointSize = 10. ; \\n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\\n #pragma endregion \\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n/* \n \n \n .___ __ . \n [__ . , _.._ / `|_ _ ._ \n [___ \\/ (_][ )____\\__.[ )(/,[ ) \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n 01/01/2019 \n*/ \n\n#pragma region \n#pragma endregion \n\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\n\tvec3 gFloorColor = vec3(0.5, 0.1, 0.2);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif \n\n#pragma region Pre_Define\n\t#define PI radians(180.)\n#pragma endregion \n\n#pragma region const\n\tconst float FARCLIPPED = 1000. ;\n\tconst float NEARCLIPPED = 0.1\t ; \n float g_cameraFar = 1000.0;\n\n#pragma endregion \n\n\n#pragma region MatrixConverte \n\t\n mat4 mAspect = mat4\n (\n 1, 0, 0, 0,\n 0, resolution.x / resolution.y, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ); \n vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\n\n mat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n }\n\n\n mat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n }\n\n mat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n }\n\n mat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n }\n\n mat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n }\n\n mat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n }\n\n mat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n }\n\n mat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n\n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n }\n\n mat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n }\n\n mat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n }\n\n mat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n }\n#pragma region \n\n#pragma region Func \n mat4 cameraLookAt(vec3 eye, vec3 target, vec3 up)\n {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n\n }\n // hash function from https://www.shadertoy.com/view/4djSRW\n float hash(float p) \n {\n vec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x * p2.y * 95.4337);\n }\n\n float m1p1(float v) //normalize to NDC \n {\n return v * 2. - 1.;\n }\n\n float inv(float v) \n {\n return 1. - v;\n } \n\n\n\t\n#pragma endregion \n\n\n#pragma region Scene_Vertex_Collection \n struct SceneVertex\n {\n vec3 vWorldPos;\n vec3 vColor;\n float fAlpha;\n };\n\n struct SurfaceInfo \n {\n vec3 vPos;\n vec3 vNormal;\n float fGloss;\n };\n struct SphereInfo\n {\t\n\t \n vec3 vOrigin;\n float fRadius ; \n \n \n \n float fSlices ; \n float fSegments ; \n }; \n#pragma endregion \n \n\n\n#pragma region GetInfo \n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nvoid GetQuadInfo(const float vertexIndex,\n out vec2 quadVertId,\n \n out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\t\nvoid GetQuadTileInfo(const vec2 quadVertId,\n const float quadId,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo(const float vertexIndex,\n const vec2 vDim,\n \n out vec2 vQuadTileIndex,\n out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\nvec3 GetNormalToWorld(SphereInfo in_SI, vec3 in_Normal)\n{\n return in_Normal ; \n}\nvec3 GetPosToWorld(SphereInfo in_SI, vec3 vPos)\n{\n return in_SI.vOrigin + vPos ; \n}\nfloat GetSphereQuadCount(const SphereInfo in_SI)\n{\n return in_SI.fSegments * in_SI.fSlices; \n}\nfloat GetSphereVertexCount(const SphereInfo in_SI)\n{ \n return GetSphereQuadCount(in_SI) * 6.; \n}\n\n\n// From Shadertoy \"Hash without sine - Dave Hoskins\"\n// https://www.shadertoy.com/view/4djSRW\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nvec4 hash41(float p)\n{\n\tvec4 p4 = fract(vec4(p) * MOD4);\n p4 += dot(p4, p4.wzxy+19.19);\n return fract(vec4((p4.x + p4.y)*p4.z, (p4.x + p4.z)*p4.y, (p4.y + p4.z)*p4.w, (p4.z + p4.w)*p4.x));\n \n}\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\n//FBM step \n#define k_fmbSteps 10\nfloat FBM( vec2 p, float repeat, float ps ) {\n\tfloat f = 0.0;\n float tot = 0.0;\n float a = 1.0; \t\n for( int i=0; i= 0. && vertexIndex < floorVertexCount)\n GenFloor(camPos , vertexId, sv) ; \n vertexIndex -= floorTileCount ; \n \n /*draw the sphere*/\n /*\n \tfloat fSphereVertexCount = GetSphereVertexCount(sphereInfo);\n if(vertexIndex >= 0. && vertexIndex < fSphereVertexCount)\n {\n GenSphere(vertexIndex, sphereInfo, sv);\n }\n \tvertexIndex -= fSphereVertexCount ; \n */\n \n #pragma endregion \n \n \n #pragma region add to glsl\n \n gl_Position = m * vec4(sv.vWorldPos, 1.); \n \tgl_PointSize = 10. ; \n v_color = vec4(sv.vColor * sv.fAlpha, sv.fAlpha);\n #pragma endregion \n}" + }, "screenshotURL": "data/images/images-4pcf9zotk3qpu3qdq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pgneaCJDnJfFAzhbJ/art.json b/art/pgneaCJDnJfFAzhbJ/art.json index 353ba485..d95365f7 100644 --- a/art/pgneaCJDnJfFAzhbJ/art.json +++ b/art/pgneaCJDnJfFAzhbJ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minsu-kim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/minsu-kim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Minsu Kim\\n// Assignment : Exercise - Vertexshaderart : Colors\\n// Course : CS250\\n// Spring 2023\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main()\\n{\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time *1.1 + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n // [0, 1)\\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05; \\n float sat = cos(time * 1.5);\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Minsu Kim\n// Assignment : Exercise - Vertexshaderart : Colors\n// Course : CS250\n// Spring 2023\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main()\n{\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time *1.1 + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n // [0, 1)\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05; \n float sat = cos(time * 1.5);\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-rhl816v002w7ua28u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pheZX35Sbfgfj5ZJC/art.json b/art/pheZX35Sbfgfj5ZJC/art.json index fee18930..af9eedba 100644 --- a/art/pheZX35Sbfgfj5ZJC/art.json +++ b/art/pheZX35Sbfgfj5ZJC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1926,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/martinovichh/space-travel\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 10.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\\n \\n \\n\\n float hue = sz * 3. + s * 0.3;\\n float sat = 1.;\\n float val = s;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 1926, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/martinovichh/space-travel", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 10.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .5 + .5));\n gl_PointSize =pow(sz, 1.) * resolution.y / 885. * 180.;\n \n \n\n float hue = sz * 3. + s * 0.3;\n float sat = 1.;\n float val = s;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-msqkc2cq8zxi2mzck-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pi26Yd2oHdMNecbqi/art.json b/art/pi26Yd2oHdMNecbqi/art.json index 492f1666..71145d9e 100644 --- a/art/pi26Yd2oHdMNecbqi/art.json +++ b/art/pi26Yd2oHdMNecbqi/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":9775,\"mode\":\"TRIANGLES\",\"sound\":\"feedback\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 3.//KParameter 0.1>>3.\\n#define P6 3.//KParameter 0.1>>10.\\n#define P5 1.//KParameter 0.1>>3.\\n//KVerticesNumber=2000.\\n\\n\\n//KDrawmode=GL_TRIANGLE\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 1000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 6. *fract(mouse.x-mouse.y)));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos,sin(1.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *1.001;\\n float sat = 0.;\\n float val = vertexCount/(vertexId * 21.)*0.6;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 9775, + "mode": "TRIANGLES", + "sound": "feedback", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 3.//KParameter 0.1>>3.\n#define P6 3.//KParameter 0.1>>10.\n#define P5 1.//KParameter 0.1>>3.\n//KVerticesNumber=2000.\n\n\n//KDrawmode=GL_TRIANGLE\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 1000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 6. *fract(mouse.x-mouse.y)));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos,sin(1.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *1.001;\n float sat = 0.;\n float val = vertexCount/(vertexId * 21.)*0.6;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-f45gv3m635kq0cv0j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/piodzReMZfEvAXgh4/art.json b/art/piodzReMZfEvAXgh4/art.json index fd911ec3..a64b5afc 100644 --- a/art/piodzReMZfEvAXgh4/art.json +++ b/art/piodzReMZfEvAXgh4/art.json @@ -28,7 +28,19 @@ "name": "unnamed", "private": true, "username": "andrea", - "settings": "{\"num\":6588,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 60.0;\\n float point = mod(floor(vertexId / 8.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 3.14 / NUM_SEGMENTS + offset;\\n float radius = 0.1;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 6588, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 60.0;\n float point = mod(floor(vertexId / 8.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 3.14 / NUM_SEGMENTS + offset;\n float radius = 0.1;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-3ycyrlxnyfkbnxi31-thumbnail.jpg", "views": { "$numberInt": "7" diff --git a/art/pmGvqyPkPbnfcQoLm/art.json b/art/pmGvqyPkPbnfcQoLm/art.json index 0299026b..84affa1d 100644 --- a/art/pmGvqyPkPbnfcQoLm/art.json +++ b/art/pmGvqyPkPbnfcQoLm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alejandrocamara", "avatarUrl": "https://avatars.githubusercontent.com/AlejandroCamara?s=200", - "settings": "{\"num\":360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n \\n float angle = radians(vertexId);\\n float radius = 1.0;\\n \\n float u = radius * cos(angle);\\n float v = radius * sin(angle);\\n \\n vec2 xy = vec2(u, v) * 0.5;\\n \\n\\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n /*if (mod(vertexId, 42.0) > 1.0) {\\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\\n }else if (mod(vertexId, 42.0) == 0.0) {\\n v_color = vec4(0.0, 1.0, 1.0, 1.0);\\n }*/\\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n \n float angle = radians(vertexId);\n float radius = 1.0;\n \n float u = radius * cos(angle);\n float v = radius * sin(angle);\n \n vec2 xy = vec2(u, v) * 0.5;\n \n\n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 1.0;\n /*if (mod(vertexId, 42.0) > 1.0) {\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\n }else if (mod(vertexId, 42.0) == 0.0) {\n v_color = vec4(0.0, 1.0, 1.0, 1.0);\n }*/\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-qs5kp7e8vpddtd9p3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pnWPM9mLnuLMMHCFy/art.json b/art/pnWPM9mLnuLMMHCFy/art.json index e8cd7d17..28ce70ca 100644 --- a/art/pnWPM9mLnuLMMHCFy/art.json +++ b/art/pnWPM9mLnuLMMHCFy/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "molotovbliss", "avatarUrl": "https://avatars.githubusercontent.com/molotovbliss?s=200", - "settings": "{\"num\":94761,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.5019607843137255,0.25098039215686274,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1.9);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float faceId = mod(floor(pointId / 6.), 6.);\\n float numCubes = floor(vertexCount / 44.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = PI * 0.175;time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.7, sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 0.87);\\n //mat *= rotX(time + abs(ca) * 0.02);\\n //mat *= rotZ(time + abs(cd) * 0.2);\\n //mat *= rotY(time / cos(cd) * 2.0);\\n float d = length(vec2(ca, cd));\\n mat *= scale(vec3(\\n 1, \\n mix(2., \\n 12., \\n pow(sin(time * -2. + d * PI * 1.) * 0.5 + 0.5, \\n 1.5 + (1. - d) * 2.)), \\n 1));\\n mat *= uniformScale(0.3);\\n \\n \\n gl_Position = mat * vec4(pos, 8.5);\\n vec3 n = normalize((mat * vec4(normal, 2)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.1, 1.0, -1));\\n\\n float hue = 0.36 + mod(faceId, 10.10) * 4.0;\\n float sat = 1. + mod(1.2, 30.3);\\n float val = 1.0;\\n vec3 color = hsv2rgb(vec3(hue, sat, val)) * 1.125;\\n v_color = vec4(color * (dot(n, lightDir) * 0.2 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 94761, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.5019607843137255, + 0.25098039215686274, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1.9);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float faceId = mod(floor(pointId / 6.), 6.);\n float numCubes = floor(vertexCount / 44.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = PI * 0.175;time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 0.7, sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 0.87);\n //mat *= rotX(time + abs(ca) * 0.02);\n //mat *= rotZ(time + abs(cd) * 0.2);\n //mat *= rotY(time / cos(cd) * 2.0);\n float d = length(vec2(ca, cd));\n mat *= scale(vec3(\n 1, \n mix(2., \n 12., \n pow(sin(time * -2. + d * PI * 1.) * 0.5 + 0.5, \n 1.5 + (1. - d) * 2.)), \n 1));\n mat *= uniformScale(0.3);\n \n \n gl_Position = mat * vec4(pos, 8.5);\n vec3 n = normalize((mat * vec4(normal, 2)).xyz);\n \n vec3 lightDir = normalize(vec3(0.1, 1.0, -1));\n\n float hue = 0.36 + mod(faceId, 10.10) * 4.0;\n float sat = 1. + mod(1.2, 30.3);\n float val = 1.0;\n vec3 color = hsv2rgb(vec3(hue, sat, val)) * 1.125;\n v_color = vec4(color * (dot(n, lightDir) * 0.2 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-33q069wty019i4jip-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/poNyz9Zbo5iQ6HjDH/art.json b/art/poNyz9Zbo5iQ6HjDH/art.json index 7fc683b3..4bebf166 100644 --- a/art/poNyz9Zbo5iQ6HjDH/art.json +++ b/art/poNyz9Zbo5iQ6HjDH/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 10.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-ecx2s6c9g65phl32v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pouFFooTnek4sRsuE/art.json b/art/pouFFooTnek4sRsuE/art.json index f2264c55..c2a920d8 100644 --- a/art/pouFFooTnek4sRsuE/art.json +++ b/art/pouFFooTnek4sRsuE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":1907,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - make a grid\\n// spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n\\tgl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1907, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - make a grid\n// spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n\tgl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n \n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-cl321zlnuuwiqnvie-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pp2M9hcuBjqq4QFPH/art.json b/art/pp2M9hcuBjqq4QFPH/art.json index e107afad..a06e3b62 100644 --- a/art/pp2M9hcuBjqq4QFPH/art.json +++ b/art/pp2M9hcuBjqq4QFPH/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":168,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KPxx 62.//KParameter0 0.>>1000.\\n#define KPx 12.//KParameter1 0.0>>22.\\n#define KPxxx 9.0//KParameter2 -6.0>>10.\\n#define KP3 -0.0//KParameter3 -8.000>>0.5\\n#define KP4 1.2//KParameter4 0.000>>15.\\n#define KP5 130.0//KParameter5 30.000>>90000.0\\n\\n//KVerticesNumber=10000 \\n#define PI radians(180. /KP1)\\n#define KP1 (KPx * mouse.y)\\n#define KP0 (KPxx * mouse.x)\\n#define KP2 (KPxxx * mouse.x *mouse.y)\\n\\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 + a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det *(2.2 / KPx);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, xAxis));\\n vec3 yAxis = cross(zAxis, zAxis *KP2);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137*KP1));\\n\\treturn fract(p2.x * p2.y * 12.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle /2.;\\n float v = mix(inner, 4., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 1.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv, mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.125, sin(time * (0.21+mouse.x)) * 0.5, .5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, );\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * 0.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 168, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KPxx 62.//KParameter0 0.>>1000.\n#define KPx 12.//KParameter1 0.0>>22.\n#define KPxxx 9.0//KParameter2 -6.0>>10.\n#define KP3 -0.0//KParameter3 -8.000>>0.5\n#define KP4 1.2//KParameter4 0.000>>15.\n#define KP5 130.0//KParameter5 30.000>>90000.0\n\n//KVerticesNumber=10000 \n#define PI radians(180. /KP1)\n#define KP1 (KPx * mouse.y)\n#define KP0 (KPxx * mouse.x)\n#define KP2 (KPxxx * mouse.x *mouse.y)\n\nfloat K1 = (KP0 * mouse.y)-(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 + a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det *(2.2 / KPx);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, xAxis));\n vec3 yAxis = cross(zAxis, zAxis *KP2);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137*KP1));\n\treturn fract(p2.x * p2.y * 12.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle /2.;\n float v = mix(inner, 4., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 1.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv, mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.125, sin(time * (0.21+mouse.x)) * 0.5, .5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, );\n \n mat4 mat = scale(vec3(1, aspect, 1) * 0.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-iq4zovcxqhrcbatqx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ppKnynEzM2GHfQfXo/art.json b/art/ppKnynEzM2GHfQfXo/art.json index 36a839f4..90b6929d 100644 --- a/art/ppKnynEzM2GHfQfXo/art.json +++ b/art/ppKnynEzM2GHfQfXo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":7723,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define PHI_A (3.-sqrt(5.))* PI\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float scale = .5; // repeats/extends\\n float size = 0.001; // stretch/squeeze\\n float rad_max = (vertexCount * size);\\n \\n float theta = PHI_A * vertexId;// * PHI_A;\\n float radius = sqrt(vertexId * size);\\n \\n radius = radius * scale;\\n \\n float xoff = sin(time*0.8) * 0.8;\\n float yoff = sin(time*1.3) * 0.1;\\n gl_Position = vec4(cos(theta) * radius,\\n sin(theta) * radius,\\n 0, 1);\\n gl_PointSize = 5. * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\\n\\n float hue = time * 0.1;\\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 7723, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define PHI_A (3.-sqrt(5.))* PI\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float scale = .5; // repeats/extends\n float size = 0.001; // stretch/squeeze\n float rad_max = (vertexCount * size);\n \n float theta = PHI_A * vertexId;// * PHI_A;\n float radius = sqrt(vertexId * size);\n \n radius = radius * scale;\n \n float xoff = sin(time*0.8) * 0.8;\n float yoff = sin(time*1.3) * 0.1;\n gl_Position = vec4(cos(theta) * radius,\n sin(theta) * radius,\n 0, 1);\n gl_PointSize = 5. * sqrt(pow(resolution.x, 2.) + pow(resolution.y, 2.)) / 600.;\n\n float hue = time * 0.1;\n v_color = vec4(hsv2rgb(vec3(radius + hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-bzra69a1odrpx1mth-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/prW9D82SGpoazGXyC/art.json b/art/prW9D82SGpoazGXyC/art.json index 41e2c21c..eb56afc0 100644 --- a/art/prW9D82SGpoazGXyC/art.json +++ b/art/prW9D82SGpoazGXyC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/david-wurden/popcorn-dreams?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n\\n vec2 xy = vec2(0.0,0.0);\\n\\n\\n if (vertexId < 2.0) {\\n \\txy = vec2(vertexId - 0.5,0.0);\\n } else {\\n xy = vec2(vertexId/100.0 - 0.5, mod(vertexId, 2.0) - 0.5 );\\n\\n float s = texture2D(sound, (xy+ vec2(0.5,0.5))*0.2).a;\\n xy.y +=s;\\n\\n }\\n \\n \\n \\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n v_color = vec4(1.0,1.0,1.0,1.0)\\n}\"}", + "settings": { + "num": 100, + "mode": "LINES", + "sound": "https://soundcloud.com/david-wurden/popcorn-dreams?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n\n vec2 xy = vec2(0.0,0.0);\n\n\n if (vertexId < 2.0) {\n \txy = vec2(vertexId - 0.5,0.0);\n } else {\n xy = vec2(vertexId/100.0 - 0.5, mod(vertexId, 2.0) - 0.5 );\n\n float s = texture2D(sound, (xy+ vec2(0.5,0.5))*0.2).a;\n xy.y +=s;\n\n }\n \n \n \n gl_Position = vec4(xy * 0.5, 0, 1);\n\n v_color = vec4(1.0,1.0,1.0,1.0)\n}" + }, "screenshotURL": "data/images/images-mekiw39krlj07ju1k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/puW9t4JQ9LnRbMkTK/art.json b/art/puW9t4JQ9LnRbMkTK/art.json index b39e991e..845bf1a5 100644 --- a/art/puW9t4JQ9LnRbMkTK/art.json +++ b/art/puW9t4JQ9LnRbMkTK/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16222,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"wired\\\" by kabuto\\n// drawing a smoothed 3d hilbert curve\\n\\n// if this runs too slowly try zooming in\\n// (ctrl + mousewheel up)\\n\\n#define PI 3.14159\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n sin(i*14.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76),\\n sin(i*.79553+2.1) +\\n sin(i*1.1311+2.1) +\\n sin(i*1.353-2.1) +\\n sin(i*.476/2.1) * cos(i * 3.0),\\n sin(i*4.5553-2.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*9.36+2.1)\\n\\t)*11.2;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n tan(i*.553)*.9553 +\\n cos(i) +\\n cos(i*1.53)/1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*4.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*11.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n tan(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*.2;\\n}\\n\\nvec3 hilbert(float s) {\\n\\t\\t vec3 p;\\n\\t\\t {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,3.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\t\\t p = vec3(xi,yi,zi);\\n\\t\\t }\\n\\tfloat n = 2.;\\n\\t\\t for (int i = 1; i < 7; i++) {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,3.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\n\\t \\n\\tif (xi > .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < 1.1) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 2.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*50.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = .5;\\n \\n vec3 colour = vec3(0.);\\n\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n \\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/180.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,-1.);\\n}\"}", + "settings": { + "num": 16222, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"wired\" by kabuto\n// drawing a smoothed 3d hilbert curve\n\n// if this runs too slowly try zooming in\n// (ctrl + mousewheel up)\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*14.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76),\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476/2.1) * cos(i * 3.0),\n sin(i*4.5553-2.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*9.36+2.1)\n\t)*11.2;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n tan(i*.553)*.9553 +\n cos(i) +\n cos(i*1.53)/1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*4.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*11.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n tan(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,3.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2.;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,3.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < 1.1) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 2.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*50.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = .5;\n \n vec3 colour = vec3(0.);\n\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n \n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/180.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,-1.);\n}" + }, "screenshotURL": "data/images/images-darlod3nyeduhkm4a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/pubHuPRcYrgB8xLXg/art.json b/art/pubHuPRcYrgB8xLXg/art.json index 08b1d7dc..fe683071 100644 --- a/art/pubHuPRcYrgB8xLXg/art.json +++ b/art/pubHuPRcYrgB8xLXg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1480,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/galimatias/galimatias-ocean-floor-kisses\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\\n float down = floor(vertexCount / across);\\n \\n float gx = mod(vertexId, across);\\n float gy = floor(vertexId / across);\\n \\n float u = gx / (across - 1.);\\n float v = gy / (down - 1.);\\n \\n float s = sin((u + v) * 4. + time);\\n \\n float x = u * 2. - 1. + sin(time * 0.04 + v * sin(time * 0.03) * 10.) * 0.05;\\n float y = v * 2. - 1. + sin(time * 0.02 + u * sin(time * 0.01) * 10.) * 0.05;\\n \\n float sx = m1p1(u);\\n float sy = m1p1(v);\\n float sa = abs(atan(sx, sy) / PI);\\n float sr = length(vec2(sx, sy));\\n// float snd = texture2D(sound, vec2(fract(abs(m1p1(u)) + time * 0.1) * 0.2, abs(m1p1(v)) * 0.1)).a;\\n float snd = texture2D(sound, vec2(p1m1(sa) * 0.1, p1m1(sr) * .2)).a;\\n \\n vec3 p = vec3(x, y, -1.5 + s * .1);\\n \\n mat4 m = persp(radians(65.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\\n \\n gl_Position = m * vec4(p, 1.);\\n\\n float hue = p1m1(s) * 0.1 + time * 0.02;\\n float sat = mix(0.2, 0.8, snd);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n gl_PointSize = resolution.x / across * 0.7 * p1m1(sin(3. + u*sin(time * 0.1)*30.+cos(time * 0.217) * 30.123 + sin(time*0.482) * 21.8));\\n gl_PointSize *= min(pow(snd * (1. + u), 5.0), 2.);\\n}\\n\"}", + "settings": { + "num": 1480, + "mode": "POINTS", + "sound": "https://soundcloud.com/galimatias/galimatias-ocean-floor-kisses", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid main() {\n float across = floor(sqrt(vertexCount * resolution.x / resolution.y));\n float down = floor(vertexCount / across);\n \n float gx = mod(vertexId, across);\n float gy = floor(vertexId / across);\n \n float u = gx / (across - 1.);\n float v = gy / (down - 1.);\n \n float s = sin((u + v) * 4. + time);\n \n float x = u * 2. - 1. + sin(time * 0.04 + v * sin(time * 0.03) * 10.) * 0.05;\n float y = v * 2. - 1. + sin(time * 0.02 + u * sin(time * 0.01) * 10.) * 0.05;\n \n float sx = m1p1(u);\n float sy = m1p1(v);\n float sa = abs(atan(sx, sy) / PI);\n float sr = length(vec2(sx, sy));\n// float snd = texture2D(sound, vec2(fract(abs(m1p1(u)) + time * 0.1) * 0.2, abs(m1p1(v)) * 0.1)).a;\n float snd = texture2D(sound, vec2(p1m1(sa) * 0.1, p1m1(sr) * .2)).a;\n \n vec3 p = vec3(x, y, -1.5 + s * .1);\n \n mat4 m = persp(radians(65.), 1. + 0. * resolution.x / resolution.y, 0.1, 10.);\n \n gl_Position = m * vec4(p, 1.);\n\n float hue = p1m1(s) * 0.1 + time * 0.02;\n float sat = mix(0.2, 0.8, snd);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n gl_PointSize = resolution.x / across * 0.7 * p1m1(sin(3. + u*sin(time * 0.1)*30.+cos(time * 0.217) * 30.123 + sin(time*0.482) * 21.8));\n gl_PointSize *= min(pow(snd * (1. + u), 5.0), 2.);\n}\n" + }, "screenshotURL": "data/images/images-uncb3clud2pql0sww-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/puvZxbRgEiG2MK4Rp/art.json b/art/puvZxbRgEiG2MK4Rp/art.json index 30febdb9..7efd560a 100644 --- a/art/puvZxbRgEiG2MK4Rp/art.json +++ b/art/puvZxbRgEiG2MK4Rp/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":2111,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// complex numbers\\n// vec2(real part, complex part)\\nvec2 cProd(vec2 a, vec2 b) {\\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\\n}\\nfloat cModSqrd(vec2 a) {\\n return (a.x*a.x + a.y*a.y);\\n}\\nint mandelbrot(float x, float y) {\\n int n = 0;\\n vec2 z = vec2(0,0);\\n vec2 c = vec2(x,y);\\n \\n // no loops in glsl so jsut repeat 100 times\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n \\n return n;\\n}\\nfloat clamped_mandelbrot(float x, float y) {\\n return float(mandelbrot(x,y))/25.;\\n}\\n\\nvoid main() {\\n float resArea = resolution.x * resolution.y;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertAcrossX = floor(resolution.x/vertLen);\\n float vertAcrossY = floor(resolution.y/vertLen);\\n \\n float u = (mod(vertexId, vertAcrossX)-.5)/(vertAcrossX-1.);\\n u = (u - 0.5) * 2.;\\n float v = (floor(vertexId / vertAcrossX)-.5)/(vertAcrossY-1.);\\n v = (v - 0.5) * 2.;\\n \\n float x = u * resolution.x / resolution.y;\\n float y = v * resolution.x / resolution.x;\\n vec2 m = vec2(mouse.x/resolution.y, mouse.y/resolution.x);\\n \\n gl_Position = vec4(u, v, 0, 1);\\n gl_PointSize = vertLen*1.05;\\n \\n float fractal = clamped_mandelbrot(x, y);\\n v_color = vec4(hsv2rgb(vec3(1.-fractal, 1., 1.-fractal)), 1.);\\n}\"}", + "settings": { + "num": 2111, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// complex numbers\n// vec2(real part, complex part)\nvec2 cProd(vec2 a, vec2 b) {\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\n}\nfloat cModSqrd(vec2 a) {\n return (a.x*a.x + a.y*a.y);\n}\nint mandelbrot(float x, float y) {\n int n = 0;\n vec2 z = vec2(0,0);\n vec2 c = vec2(x,y);\n \n // no loops in glsl so jsut repeat 100 times\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n \n return n;\n}\nfloat clamped_mandelbrot(float x, float y) {\n return float(mandelbrot(x,y))/25.;\n}\n\nvoid main() {\n float resArea = resolution.x * resolution.y;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertAcrossX = floor(resolution.x/vertLen);\n float vertAcrossY = floor(resolution.y/vertLen);\n \n float u = (mod(vertexId, vertAcrossX)-.5)/(vertAcrossX-1.);\n u = (u - 0.5) * 2.;\n float v = (floor(vertexId / vertAcrossX)-.5)/(vertAcrossY-1.);\n v = (v - 0.5) * 2.;\n \n float x = u * resolution.x / resolution.y;\n float y = v * resolution.x / resolution.x;\n vec2 m = vec2(mouse.x/resolution.y, mouse.y/resolution.x);\n \n gl_Position = vec4(u, v, 0, 1);\n gl_PointSize = vertLen*1.05;\n \n float fractal = clamped_mandelbrot(x, y);\n v_color = vec4(hsv2rgb(vec3(1.-fractal, 1., 1.-fractal)), 1.);\n}" + }, "screenshotURL": "data/images/images-2x79mlcwew2c9r6wr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pvmyoREztmWqtKWdC/art.json b/art/pvmyoREztmWqtKWdC/art.json index 2bddf358..ee31f126 100644 --- a/art/pvmyoREztmWqtKWdC/art.json +++ b/art/pvmyoREztmWqtKWdC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":23,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n \\n float radio = 5.0;\\n \\n \\n float xOffset = cos(x);\\n float yOffset = sin(y);\\n vec2 xy = vec2(x*yOffset, y*xOffset) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n \\n // E2\\n /*\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n */\\n \\n // E1\\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 23, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n \n float radio = 5.0;\n \n \n float xOffset = cos(x);\n float yOffset = sin(y);\n vec2 xy = vec2(x*yOffset, y*xOffset) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n \n // E2\n /*\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n */\n \n // E1\n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-hsjay6qnvymma5xj0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/pwG88jNmzsgZMjxxB/art.json b/art/pwG88jNmzsgZMjxxB/art.json index d15cabba..13fe8fe9 100644 --- a/art/pwG88jNmzsgZMjxxB/art.json +++ b/art/pwG88jNmzsgZMjxxB/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":16384,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/globalliquidity/until-that-time\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n if (gl_Position.x < 0.) {\\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/globalliquidity/until-that-time", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n if (gl_Position.x < 0.) {\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n}\n" + }, "screenshotURL": "data/images/images-yd7u7xom7e40nx9j5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q2CemJwQMdeCQ7S7P/art.json b/art/q2CemJwQMdeCQ7S7P/art.json index 08e241fb..e70c9da5 100644 --- a/art/q2CemJwQMdeCQ7S7P/art.json +++ b/art/q2CemJwQMdeCQ7S7P/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/thenoiseprocess/xf0_x9f_xa4_x99_xf0_x9f_xa4_x9\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 50\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//Karameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.0\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.141592653589880\\n\\nvec3 noise(vec3 _v) {\\n \\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./200.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n \\n //LOGISTIC\\n \\n vec2 vp = vec2(0.,0.);\\n float z = 0.4+snd;//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n \\n\\n cubep.y+= z;\\n cubep.x+= shapeRelId;\\n //END LOGISTIC\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(0.5+sin(time/1.3)/4., 0.5+sin(time/1.)/4., cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/thenoiseprocess/xf0_x9f_xa4_x99_xf0_x9f_xa4_x9", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 50\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//Karameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.0\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.141592653589880\n\nvec3 noise(vec3 _v) {\n \n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./200.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n \n //LOGISTIC\n \n vec2 vp = vec2(0.,0.);\n float z = 0.4+snd;//sin(shapeRelId+fract(time/100.));//fract(0.02);\n\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n \n\n cubep.y+= z;\n cubep.x+= shapeRelId;\n //END LOGISTIC\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(0.5+sin(time/1.3)/4., 0.5+sin(time/1.)/4., cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-0mbkcuckpr1nxiv4a-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q4fMv7cFv8FYfDYw9/art.json b/art/q4fMv7cFv8FYfDYw9/art.json index e00e9587..4167dd27 100644 --- a/art/q4fMv7cFv8FYfDYw9/art.json +++ b/art/q4fMv7cFv8FYfDYw9/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jairhumberto", "avatarUrl": "https://secure.gravatar.com/avatar/b39c05ec440599cda2aa819673a481cf?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/haddaway-what-is-love\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 k = vec4(1.0, 2.0/3.0, 1.0/0.3, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(av * 0.05, av * 0.05)).a;\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = sin(v * snd) * 2.5 - 1.;\\n \\n vec2 xy = vec2(ux, vy);\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(snd * 1.2 + x * y);\\n \\n gl_PointSize = pow(snd + 0.1, 0.5) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 1900.0;\\n \\n float hue = sin(u * 0.1) + snd * 0.2 + time * 0.1;\\n float sat = mix(0.0, 1.0, snd);\\n float val = mix(0.0, pow(snd + 2., 6.0), snd);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/haddaway-what-is-love", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 k = vec4(1.0, 2.0/3.0, 1.0/0.3, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(av * 0.05, av * 0.05)).a;\n \n float ux = u * 2.0 - 1.0;\n float vy = sin(v * snd) * 2.5 - 1.;\n \n vec2 xy = vec2(ux, vy);\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(snd * 1.2 + x * y);\n \n gl_PointSize = pow(snd + 0.1, 0.5) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 1900.0;\n \n float hue = sin(u * 0.1) + snd * 0.2 + time * 0.1;\n float sat = mix(0.0, 1.0, snd);\n float val = mix(0.0, pow(snd + 2., 6.0), snd);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-yw0yop1xfz5njax2r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q4sbfetgGafn5By2Z/art.json b/art/q4sbfetgGafn5By2Z/art.json index 4ed89b8d..450f0e54 100644 --- a/art/q4sbfetgGafn5By2Z/art.json +++ b/art/q4sbfetgGafn5By2Z/art.json @@ -11,7 +11,19 @@ "origId": "wTaKE9X796qNFqgEM", "name": "trippy", "username": "-anon-", - "settings": "{\"num\":34509,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float NUM_SEGMENTS = 6.0 + time*0.001;\\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\\n float STEP = time*0.0001;\\n if (STEP > 0.03) STEP = 0.03;\\n float localTime = time*0.1 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * localTime*0.0001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;\\n mix(0.3, 0.2, b);\\n v_color = vec4(0.8-b, 0.4-c*10.0, 1.0-s*10.0, 1);\\n}\"}", + "settings": { + "num": 34509, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvoid main() {\n float NUM_SEGMENTS = 6.0 + time*0.001;\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\n float STEP = time*0.0001;\n if (STEP > 0.03) STEP = 0.03;\n float localTime = time*0.1 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * localTime*0.0001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;\n mix(0.3, 0.2, b);\n v_color = vec4(0.8-b, 0.4-c*10.0, 1.0-s*10.0, 1);\n}" + }, "screenshotDataId": "6jaYFoyMEwovP2wgZ", "views": { "$numberInt": "438" diff --git a/art/q4uaR7yAp5C3rEQ5u/art.json b/art/q4uaR7yAp5C3rEQ5u/art.json index 4e052a22..ee58efbb 100644 --- a/art/q4uaR7yAp5C3rEQ5u/art.json +++ b/art/q4uaR7yAp5C3rEQ5u/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":25797,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n#define KP0 3.//KParameter0 0.>>10.\\n#define KP1 3.//Kparameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>5.\\n#define KP3 0.//KParameter3 0.>>0.5\\n#define KP4 2.//KParameter4 0.>>2.0\\n#define KP5 2222.0//KParameter5 1000.>>180000.\\n//KVerticesNumber=KP5\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.005, 1.0 -KP4), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1) ; \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -0.2, 0, 1, 0,\\n trans, 1.5);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -0.5, 1, 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.2 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect + f, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time * cgv * tan(1.2 - KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.2, 0.5 /cu, gs), gt * (0.00005 + KP3))).a; \\n float VC = vertexCount;\\n float (KP5 /mouse.y)*s2;\\n \\n vec3 pos;\\n float inner = sin(-1.3-KP2);\\n float start = 0.5- 0.0003 +s2;\\n float end = 2./tan(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv ,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0.5,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, s2* .1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2.3, mod(circleId, 2.)) + gy * (0.0 +KP2) * cos(time * .1));\\n //[sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) - KP3 * 1. * sign(h)); \\n mat *= scale(vec3(0.8/KP0, sin(11.9 * s2)* 8.0, 1.5));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, KP3+ .5)*cos(s /s2);\\n gl_PointSize = 2.;\\n\\n float hue = 1. + cgId - 1.4;\\n float sat = 1.7 - step(pow(s2, mouse.y * 2.), abs(gt+ 2. * 11.) * .33);\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x/KP1, sat/s2*5., val)), (0.3 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 25797, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n#define KP0 3.//KParameter0 0.>>10.\n#define KP1 3.//Kparameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>5.\n#define KP3 0.//KParameter3 0.>>0.5\n#define KP4 2.//KParameter4 0.>>2.0\n#define KP5 2222.0//KParameter5 1000.>>180000.\n//KVerticesNumber=KP5\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.005, 1.0 -KP4), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1) ; \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -0.2, 0, 1, 0,\n trans, 1.5);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -0.5, 1, 0,\n 0, 0, 0, 2);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.2 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect + f, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time * cgv * tan(1.2 - KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.2, 0.5 /cu, gs), gt * (0.00005 + KP3))).a; \n float VC = vertexCount;\n float (KP5 /mouse.y)*s2;\n \n vec3 pos;\n float inner = sin(-1.3-KP2);\n float start = 0.5- 0.0003 +s2;\n float end = 2./tan(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv ,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0.5,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, s2* .1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2.3, mod(circleId, 2.)) + gy * (0.0 +KP2) * cos(time * .1));\n //[sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) - KP3 * 1. * sign(h)); \n mat *= scale(vec3(0.8/KP0, sin(11.9 * s2)* 8.0, 1.5));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, KP3+ .5)*cos(s /s2);\n gl_PointSize = 2.;\n\n float hue = 1. + cgId - 1.4;\n float sat = 1.7 - step(pow(s2, mouse.y * 2.), abs(gt+ 2. * 11.) * .33);\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x/KP1, sat/s2*5., val)), (0.3 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-klrhqtfqqqfqj48dk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q5ixDP7gFemPmYGSG/art.json b/art/q5ixDP7gFemPmYGSG/art.json index 7210e0e6..63824db6 100644 --- a/art/q5ixDP7gFemPmYGSG/art.json +++ b/art/q5ixDP7gFemPmYGSG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27058823529411763,0.23921568627450981,0.6823529411764706,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Motion\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27058823529411763, + 0.23921568627450981, + 0.6823529411764706, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Motion\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-cqlcdg0bzs1ir2o7n-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/q6CuGQiqZmHzrJ8N3/art.json b/art/q6CuGQiqZmHzrJ8N3/art.json index 950cf6f6..2358e0ab 100644 --- a/art/q6CuGQiqZmHzrJ8N3/art.json +++ b/art/q6CuGQiqZmHzrJ8N3/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":3233,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n// Minki Cho\\n// Exercise Grid\\n// CS250 Spring 2022\\n\\n\\nvoid main() \\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n\\n float speed = 2.5;\\n ux += sin(time * speed + u * 3. + vy * 0.5) * 0.06;\\n vy += cos(time * speed + v * 3. + ux * 0.5) * 0.1;\\n \\n gl_Position = vec4(vy, ux, 0, 1);\\n\\n gl_PointSize = sin(time)*10.0;\\n gl_PointSize *= resolution.x / 800.0;\\n\\n vec4 color1 = vec4(0.0, sin(time * 0.5) * 0.5 + 0.5, 0.0, 1.0);\\n vec4 color2 = vec4(0.0, 0.0, cos(time * 1.5) * 0.5 + 0.5, 1.0);\\n vec4 blendedColor = mix(color1, color2, (sin(time * 1.5) + 1.0) * 0.5);\\n \\n vec4 pointColor = vec4(ux, 1.0 - vy, 1., 1.0);\\n v_color = mix(blendedColor, pointColor, 0.5);\\n}\"}", + "settings": { + "num": 3233, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n// Minki Cho\n// Exercise Grid\n// CS250 Spring 2022\n\n\nvoid main() \n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n\n float speed = 2.5;\n ux += sin(time * speed + u * 3. + vy * 0.5) * 0.06;\n vy += cos(time * speed + v * 3. + ux * 0.5) * 0.1;\n \n gl_Position = vec4(vy, ux, 0, 1);\n\n gl_PointSize = sin(time)*10.0;\n gl_PointSize *= resolution.x / 800.0;\n\n vec4 color1 = vec4(0.0, sin(time * 0.5) * 0.5 + 0.5, 0.0, 1.0);\n vec4 color2 = vec4(0.0, 0.0, cos(time * 1.5) * 0.5 + 0.5, 1.0);\n vec4 blendedColor = mix(color1, color2, (sin(time * 1.5) + 1.0) * 0.5);\n \n vec4 pointColor = vec4(ux, 1.0 - vy, 1., 1.0);\n v_color = mix(blendedColor, pointColor, 0.5);\n}" + }, "screenshotURL": "data/images/images-fi07ve1bi59fpi0c9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/q7EZvDZLoN2EqR9Fa/art.json b/art/q7EZvDZLoN2EqR9Fa/art.json index b3e1d23d..ae7f793f 100644 --- a/art/q7EZvDZLoN2EqR9Fa/art.json +++ b/art/q7EZvDZLoN2EqR9Fa/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/taeoxo/ty-x-baekhyun-monroe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9686274509803922,0.8784313725490196,1,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Colors\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff * 2.0;\\n float vy = v * 2. + yoff * 5.0;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .9;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + .8;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/taeoxo/ty-x-baekhyun-monroe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9686274509803922, + 0.8784313725490196, + 1, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Colors\n// Course Name: CS250\n// Term: Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff * 2.0;\n float vy = v * 2. + yoff * 5.0;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .9;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + .8;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-0jlw545648if1ka1z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q9BoWL6vYgWMPi8CP/art.json b/art/q9BoWL6vYgWMPi8CP/art.json index d6f29ad2..3935ab91 100644 --- a/art/q9BoWL6vYgWMPi8CP/art.json +++ b/art/q9BoWL6vYgWMPi8CP/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/plu-collective/circuitry\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Lesson04\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.) ;\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.4;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .09, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/plu-collective/circuitry", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Lesson04\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.) ;\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.4;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .09, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-1fwcpq5j6mgyuwqzo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q9Fv9bJfBujZM8GFF/art.json b/art/q9Fv9bJfBujZM8GFF/art.json index f07143b4..cc41056d 100644 --- a/art/q9Fv9bJfBujZM8GFF/art.json +++ b/art/q9Fv9bJfBujZM8GFF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":72279,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/bufirolas/bananarama-venus-bufi-edit\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// tobbo\\n\\n#define NUM_SEGMENTS 500.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 5.0 / 3.0, 4.0 / 3.0, 4.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown - 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 72279, + "mode": "LINES", + "sound": "https://soundcloud.com/bufirolas/bananarama-venus-bufi-edit", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// tobbo\n\n#define NUM_SEGMENTS 500.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 5.0 / 3.0, 4.0 / 3.0, 4.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown - 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-gkklitq3dttooe1n7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/q9kGY6PexnYDi9oCF/art.json b/art/q9kGY6PexnYDi9oCF/art.json index 836729a0..2a04996c 100644 --- a/art/q9kGY6PexnYDi9oCF/art.json +++ b/art/q9kGY6PexnYDi9oCF/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9527,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat anim(float t) {\\n float st = sin(t);\\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvec3 SampleCubePos(float idx, float num) {\\n float side = floor(pow(num, 1.0/3.0)+0.5);\\n vec3 res;\\n res.x = mod(idx, side);\\n res.y = floor( mod(idx, side*side)/side );\\n res.z = floor( mod(idx, side*side*side)/side/side );\\n res -= vec3(side * 0.5);\\n res *= 1.5/side;\\n return res;\\n}\\n\\nvoid main() {\\n //vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\\n vec3 samplePos = SampleSpherePos(vertexId, vertexCount);\\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 9527, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat anim(float t) {\n float st = sin(t);\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvec3 SampleCubePos(float idx, float num) {\n float side = floor(pow(num, 1.0/3.0)+0.5);\n vec3 res;\n res.x = mod(idx, side);\n res.y = floor( mod(idx, side*side)/side );\n res.z = floor( mod(idx, side*side*side)/side/side );\n res -= vec3(side * 0.5);\n res *= 1.5/side;\n return res;\n}\n\nvoid main() {\n //vec3 samplePos = mix(SampleCubePos(vertexId, vertexCount), SampleSpherePos(vertexId, vertexCount), anim(time));\n vec3 samplePos = SampleSpherePos(vertexId, vertexCount);\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-q1koyr5tydd0ay6dr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/q9prYaawf95rZ4Bas/art.json b/art/q9prYaawf95rZ4Bas/art.json index ea7c609f..4fd6147f 100644 --- a/art/q9prYaawf95rZ4Bas/art.json +++ b/art/q9prYaawf95rZ4Bas/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 0, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1,-s, 1,\\n 1, 1, 1, 1,\\n s, 1, c, 1,\\n 1, 1, 1, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 2, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 3,\\n 0, 2, 0, 0,\\n 0, 0, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 1, 1, 0, 0,\\n 1, 0, 1, 0,\\n 0, 1, 1, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[2], 0, 0, 1,\\n 1, s[2], 1, 0,\\n 0, 1, s[2], 0,\\n 0, 0, 1, 2);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 1, 2,\\n 2, f, 1, 0,\\n 1, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][1], m[2][2], \\n m[0][0], m[1][1], m[2][2], \\n m[0][0], m[1][1], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[1], t[0], \\n i[2], t[1],\\n i[1], t[2],\\n 3, 2, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][1], m[2][2], m[3][3], \\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 3,\\n yAxis, 2,\\n zAxis, 1,\\n eye, 0);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * .4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(floor(time * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * .1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 2. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.z)), abs(t.z) * 1.)).a;\\n\\n float pump = step(10.7, s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\\n hue = time * .1 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + .2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 0.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * .05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 0., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ruidohorrible/vertex-germ-untitled-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 0, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 0); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1,-s, 1,\n 1, 1, 1, 1,\n s, 1, c, 1,\n 1, 1, 1, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 2, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 3,\n 0, 2, 0, 0,\n 0, 0, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 1, 1, 0, 0,\n 1, 0, 1, 0,\n 0, 1, 1, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[2], 0, 0, 1,\n 1, s[2], 1, 0,\n 0, 1, s[2], 0,\n 0, 0, 1, 2);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 1, 2,\n 2, f, 1, 0,\n 1, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][1], m[2][2], \n m[0][0], m[1][1], m[2][2], \n m[0][0], m[1][1], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[1], t[0], \n i[2], t[1],\n i[1], t[2],\n 3, 2, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][1], m[2][2], m[3][3], \n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 3,\n yAxis, 2,\n zAxis, 1,\n eye, 0);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * .4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(floor(time * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * .1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 2. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.z)), abs(t.z) * 1.)).a;\n\n float pump = step(10.7, s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\n hue = time * .1 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + .2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 0.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * .05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 0., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 0., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-c9dvtdnu6t2hw3djl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qA2y7ctcsE5EDRetu/art.json b/art/qA2y7ctcsE5EDRetu/art.json index 5c460572..42c60526 100644 --- a/art/qA2y7ctcsE5EDRetu/art.json +++ b/art/qA2y7ctcsE5EDRetu/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mike-tobia", "avatarUrl": "https://avatars.githubusercontent.com/mike-tobia?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * .2) * .02;\\n float yoff = sin(time + x * .2) * .02;\\n \\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float scalar = .0;\\n float scale = scalar + (resolution.y + resolution.x) / 400.;\\n \\n vec2 xy = vec2(ux, vy) * scale;\\n float z = clamp(sin(time), 0.5 , 1.);\\n \\n gl_Position = vec4(xy, z, 1);\\n \\n float soff = sin(time + xy.x * xy.y * .002) * 15.;\\n \\n gl_PointSize = 10. + soff;\\n gl_PointSize *= 10. / across;\\n gl_PointSize *= scale;\\n \\n\\n float hue = u;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * .2) * .02;\n float yoff = sin(time + x * .2) * .02;\n \n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float scalar = .0;\n float scale = scalar + (resolution.y + resolution.x) / 400.;\n \n vec2 xy = vec2(ux, vy) * scale;\n float z = clamp(sin(time), 0.5 , 1.);\n \n gl_Position = vec4(xy, z, 1);\n \n float soff = sin(time + xy.x * xy.y * .002) * 15.;\n \n gl_PointSize = 10. + soff;\n gl_PointSize *= 10. / across;\n gl_PointSize *= scale;\n \n\n float hue = u;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-t3ptynoh0jwsdq2zc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qAx2pkLWXDYQgRtq8/art.json b/art/qAx2pkLWXDYQgRtq8/art.json index 4e2e58e1..5864615c 100644 --- a/art/qAx2pkLWXDYQgRtq8/art.json +++ b/art/qAx2pkLWXDYQgRtq8/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 48.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n float radius = by;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n gl_Position = vec4(x, y, 0, 1);\\n \\n // offset circles\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float cx = mod(circleId, 10.) * 2.;\\n float cy = floor(circleId / 10.) * 2.;\\n gl_Position += vec4(cx, cy, 0, 0); \\n \\n // scale\\n gl_Position *= scale(0.125);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 48.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n float radius = by;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n gl_Position = vec4(x, y, 0, 1);\n \n // offset circles\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float cx = mod(circleId, 10.) * 2.;\n float cy = floor(circleId / 10.) * 2.;\n gl_Position += vec4(cx, cy, 0, 0); \n \n // scale\n gl_Position *= scale(0.125);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-nz8is91261b2p9df4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qB4krC8RnH5HEFLww/art.json b/art/qB4krC8RnH5HEFLww/art.json index dd983c05..b2038478 100644 --- a/art/qB4krC8RnH5HEFLww/art.json +++ b/art/qB4krC8RnH5HEFLww/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>8.\\n#define parameter1 3.//KParameter1 1.>>8.\\n#define parameter2 3.//KParameter2 0.>>40.\\n#define parameter3 20.//KParameter3 5>>100.\\n#define parameter4 0.02//KParameter4 0.01>>0.05\\n#define parameter5 30.//KParameter5 5.>>50.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 1.>>5.\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\\n{\\n vec3 u = _triangleVertices0 - _triangleVertices1;\\n vec3 v = _triangleVertices1 - _triangleVertices2;\\n return cross(v, u);\\n}\\n\\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\\n{\\n float localVid = mod(_vId,_vtn);\\n \\n if(localVid< 1.)\\n {\\n \\n _v = _vt[0];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n \\n }\\n else\\n if(localVid< 2.)\\n {\\n _v = _vt[1];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 3.)\\n {\\n _v = _vt[2];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 4.)\\n {\\n _v = _vt[3];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 5.)\\n {\\n _v = _vt[4];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 6.)\\n {\\n _v = _vt[5];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 7.)\\n {\\n _v = _vt[6];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 8.)\\n {\\n _v = _vt[7];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 9.)\\n {\\n _v = _vt[8];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 10.)\\n {\\n _v = _vt[9];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 11.)\\n {\\n _v = _vt[10];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 12.)\\n {\\n _v = _vt[11];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n \\n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\\n \\n _v = rotY(_v,_rot.y);\\n _n = rotY(_n,_rot.y);\\n \\n\\n _v = rotX(_v,_rot.x);\\n _n = rotX(_n,_rot.x);\\n \\n _v = rotZ(_v,_rot.z);\\n _n = rotZ(_n,_rot.z);\\n \\n _v += _pos;\\n //_n += _pos;\\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\\n specular = max(0.0, pow(NDoth, _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n \\n //KVsa\\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n //KVsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops = floor(parameter1);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n\\n \\n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops2 = floor(1.);\\n float subLoopLength2 = 1./numberOfSubLoops2;\\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n vec3 _n = vec3(0.,0.,0.);\\n \\n vec3 shapeVertices[12];\\n float shapeSize = 12.;\\n \\n \\n \\n \\n float maxShapeCount = floor(vertexCount/shapeSize);\\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\\n float shapeId = floor(finalVertexId/shapeSize);\\n float relShapeId = shapeId/maxShapeCount;\\n float scale = parameter4;\\n \\n \\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\\n float localShapeId = mod(shapeId,numberOfShape);\\n float localRelShapeId = localShapeId/numberOfShape;\\n \\n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\\n \\n \\n float radius = 0.1+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\\n \\n \\n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\\n \\n \\n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\\n float factor1 = 1.;\\n \\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\\n shapeVertices[1] = vec3(0.5,0.,-0.5);\\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\\n shapeVertices[3] = vec3(0.5,0.,-0.5);\\n shapeVertices[4] = vec3(0.5,0.,0.5);\\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\\n shapeVertices[6] =vec3(0.5,0.,0.5);\\n shapeVertices[7] =vec3(-0.5,0.,0.5);\\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\\n shapeVertices[9] =vec3(-0.5,0.,0.5);\\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\\n \\n vec3 shapeColors[4];\\n \\n shapeColors[0] = vec3(1.,0.,0.);\\n shapeColors[1] = vec3(0.,1.,1.);\\n shapeColors[2] = vec3(1.,0.,0.);\\n shapeColors[3] = vec3(1.,1.,0.);\\n \\n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\\n \\n //create the big circle\\n float masterCircleRadius = 0.4;\\n float numberOfCirclesInMasterCircle = floor(parameter5);\\n float vertexPerSmallCircle = numberOfShape*shapeSize;\\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\\n \\n _v.y-=masterCircleRadius;\\n \\n _v = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\\n _n = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\\n _v.z-=0.58;\\n \\n vec3 eye = vec3(0., 0., -1.);\\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\\n\\n vec3 p = lookAt(_v, eye, vec3(0.,1.7,0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n \\n _v.x*=resolution.y/resolution.x;\\n\\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>8.\n#define parameter1 3.//KParameter1 1.>>8.\n#define parameter2 3.//KParameter2 0.>>40.\n#define parameter3 20.//KParameter3 5>>100.\n#define parameter4 0.02//KParameter4 0.01>>0.05\n#define parameter5 30.//KParameter5 5.>>50.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 1.>>5.\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\n{\n vec3 u = _triangleVertices0 - _triangleVertices1;\n vec3 v = _triangleVertices1 - _triangleVertices2;\n return cross(v, u);\n}\n\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\n{\n float localVid = mod(_vId,_vtn);\n \n if(localVid< 1.)\n {\n \n _v = _vt[0];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n \n }\n else\n if(localVid< 2.)\n {\n _v = _vt[1];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 3.)\n {\n _v = _vt[2];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 4.)\n {\n _v = _vt[3];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 5.)\n {\n _v = _vt[4];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 6.)\n {\n _v = _vt[5];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 7.)\n {\n _v = _vt[6];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 8.)\n {\n _v = _vt[7];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 9.)\n {\n _v = _vt[8];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 10.)\n {\n _v = _vt[9];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 11.)\n {\n _v = _vt[10];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 12.)\n {\n _v = _vt[11];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n \n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\n \n _v = rotY(_v,_rot.y);\n _n = rotY(_n,_rot.y);\n \n\n _v = rotX(_v,_rot.x);\n _n = rotX(_n,_rot.x);\n \n _v = rotZ(_v,_rot.z);\n _n = rotZ(_n,_rot.z);\n \n _v += _pos;\n //_n += _pos;\n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\n specular = max(0.0, pow(NDoth, _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n \n vec3 color = vec3(1.);\n \n //KVsa\n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n //KVsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops = floor(parameter1);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n\n \n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops2 = floor(1.);\n float subLoopLength2 = 1./numberOfSubLoops2;\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\n \n vec3 _v = vec3(0.,0.,0.);\n vec3 _n = vec3(0.,0.,0.);\n \n vec3 shapeVertices[12];\n float shapeSize = 12.;\n \n \n \n \n float maxShapeCount = floor(vertexCount/shapeSize);\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\n float shapeId = floor(finalVertexId/shapeSize);\n float relShapeId = shapeId/maxShapeCount;\n float scale = parameter4;\n \n \n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\n float localShapeId = mod(shapeId,numberOfShape);\n float localRelShapeId = localShapeId/numberOfShape;\n \n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\n \n \n float radius = 0.1+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\n \n \n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\n \n \n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\n float factor1 = 1.;\n \n shapeVertices[0] = vec3(-0.5,0.,-0.5);\n shapeVertices[1] = vec3(0.5,0.,-0.5);\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\n shapeVertices[3] = vec3(0.5,0.,-0.5);\n shapeVertices[4] = vec3(0.5,0.,0.5);\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\n shapeVertices[6] =vec3(0.5,0.,0.5);\n shapeVertices[7] =vec3(-0.5,0.,0.5);\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\n shapeVertices[9] =vec3(-0.5,0.,0.5);\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\n \n vec3 shapeColors[4];\n \n shapeColors[0] = vec3(1.,0.,0.);\n shapeColors[1] = vec3(0.,1.,1.);\n shapeColors[2] = vec3(1.,0.,0.);\n shapeColors[3] = vec3(1.,1.,0.);\n \n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\n \n //create the big circle\n float masterCircleRadius = 0.4;\n float numberOfCirclesInMasterCircle = floor(parameter5);\n float vertexPerSmallCircle = numberOfShape*shapeSize;\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\n \n _v.y-=masterCircleRadius;\n \n _v = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\n _n = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\n _v.z-=0.58;\n \n vec3 eye = vec3(0., 0., -1.);\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\n\n vec3 p = lookAt(_v, eye, vec3(0.,1.7,0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n \n _v.x*=resolution.y/resolution.x;\n\n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-ekjnf41sgez49ne0z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qCsikb8WubwZjoq9G/art.json b/art/qCsikb8WubwZjoq9G/art.json index 23138681..8b4bcdd4 100644 --- a/art/qCsikb8WubwZjoq9G/art.json +++ b/art/qCsikb8WubwZjoq9G/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "윤수", "avatarUrl": "https://lh5.googleusercontent.com/-uoLq7WqJDyE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rePSz3yuG_mKNfPWq5PvUl80AL7Hw/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t : yoonsoo.kwon \\nAssignment Name/Number : Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n\\nvoid main()\\n{\\n //vertexId is 0,1,2,3,4 .....\\n //By dividing by 10, it's going to be 0.0, 0.1, 0.2 , 0.3.....\\n float value = vertexId/10.;\\n \\n //We can get a bunch of form by sending mouse position * value\\n gl_Position = vec4(mouse.x*value , mouse.y*value , 0,1);\\n //By using sin we can get loop of sin and the size will be from 0 to 50.\\n gl_PointSize = abs(sin(time+value))*50.;\\n \\n //Set with sin, cos, tan to get various color. \\n v_color = vec4(sin(time), cos(time), tan(time), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t : yoonsoo.kwon \nAssignment Name/Number : Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n\nvoid main()\n{\n //vertexId is 0,1,2,3,4 .....\n //By dividing by 10, it's going to be 0.0, 0.1, 0.2 , 0.3.....\n float value = vertexId/10.;\n \n //We can get a bunch of form by sending mouse position * value\n gl_Position = vec4(mouse.x*value , mouse.y*value , 0,1);\n //By using sin we can get loop of sin and the size will be from 0 to 50.\n gl_PointSize = abs(sin(time+value))*50.;\n \n //Set with sin, cos, tan to get various color. \n v_color = vec4(sin(time), cos(time), tan(time), 1);\n}" + }, "screenshotURL": "data/images/images-2taf52nr9vwi9khoc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qELXXCPFytjJabB9R/art.json b/art/qELXXCPFytjJabB9R/art.json index b894f4ca..7a33aba9 100644 --- a/art/qELXXCPFytjJabB9R/art.json +++ b/art/qELXXCPFytjJabB9R/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jemin.Shin\\n//Exercise - Vertexshaderart : Colors\\n//Course : CS250\\n//Date : 2023 Spring \\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n \\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jemin.Shin\n//Exercise - Vertexshaderart : Colors\n//Course : CS250\n//Date : 2023 Spring \n\nvec3 hsv2rgb(vec3 c) \n{\n \n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-d2l6zr1thg9zq538i-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qF38BqQYdKFFENMag/art.json b/art/qF38BqQYdKFFENMag/art.json index 32875062..dde5aa7f 100644 --- a/art/qF38BqQYdKFFENMag/art.json +++ b/art/qF38BqQYdKFFENMag/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nName : Sehun Kim\\nassignment name : Exercise - Vertexshaderart : Circles from Triangles\\ncourse name : CS250\\nterm : 2022 Spring\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n float ux = floor(id/6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux/numCircleSegments * PI*2.;\\n float c =cos(angle);\\n float s =sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\treturn vec2(x,y);\\n}\\n\\n\\nvoid main() {\\n \\n float numCircleSegments = 10.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n float numPointsPerCircle = numCircleSegments *6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount/numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/6.);\\n float oddSlice = mod(sliceId,1.5);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down); \\n \\n float x = mod(circleId,across);\\n float y = floor(circleId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n \\n float aspect = resolution.x/resolution.y;\\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\\n sc*=20./across;\\n \\n vec4 pos = vec4(circleXY,0,1);\\n mat4 mat = ident();\\n mat*= scale(vec3(1,aspect,1));\\n mat*= rotZ(time*0.1);\\n mat *= trans(vec3(vy,ux,0) *1.4);\\n mat*= rotZ(snd*20.*sign(ux));\\n mat*= uniformScale(0.03*sc);\\n \\n gl_Position = mat*pos;\\n \\n float soff = 0.;\\n\\n float pump = step(0.8, snd);\\n float hue = u * x + snd * 0.2 + time * x * y;\\n float sat = 1.;\\n float val = mix(x*y, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue +pump* oddSlice*0.5 + pump*0.33;\\n val += oddSlice*pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nName : Sehun Kim\nassignment name : Exercise - Vertexshaderart : Circles from Triangles\ncourse name : CS250\nterm : 2022 Spring\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\nvec2 getCirclePoint(float id, float numCircleSegments){\n float ux = floor(id/6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux/numCircleSegments * PI*2.;\n float c =cos(angle);\n float s =sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n\treturn vec2(x,y);\n}\n\n\nvoid main() {\n \n float numCircleSegments = 10.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n float numPointsPerCircle = numCircleSegments *6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount/numPointsPerCircle);\n \n float sliceId = floor(vertexId/6.);\n float oddSlice = mod(sliceId,1.5);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down); \n \n float x = mod(circleId,across);\n float y = floor(circleId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n \n float aspect = resolution.x/resolution.y;\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\n sc*=20./across;\n \n vec4 pos = vec4(circleXY,0,1);\n mat4 mat = ident();\n mat*= scale(vec3(1,aspect,1));\n mat*= rotZ(time*0.1);\n mat *= trans(vec3(vy,ux,0) *1.4);\n mat*= rotZ(snd*20.*sign(ux));\n mat*= uniformScale(0.03*sc);\n \n gl_Position = mat*pos;\n \n float soff = 0.;\n\n float pump = step(0.8, snd);\n float hue = u * x + snd * 0.2 + time * x * y;\n float sat = 1.;\n float val = mix(x*y, pow(snd + 0.2, 5.0), pump);\n \n hue = hue +pump* oddSlice*0.5 + pump*0.33;\n val += oddSlice*pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-xu5m8irj9038y3v9g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qGALguswrydAHGpCK/art.json b/art/qGALguswrydAHGpCK/art.json index e85c4f38..c4959cf5 100644 --- a/art/qGALguswrydAHGpCK/art.json +++ b/art/qGALguswrydAHGpCK/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oneshade", "avatarUrl": "https://secure.gravatar.com/avatar/f0d8718b5dc6efb4cf47453275108912?default=retro&size=200", - "settings": "{\"num\":11610,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define EYE_DISTANCE 2.0\\n#define Z_NEAR 2.5\\n#define Z_FAR -2.5\\n\\n#define RESOLUTION vec2(45.0)\\n\\n#define PI 3.1415\\n\\nstruct VertexAndNormal {\\n vec3 pos;\\n vec3 nor;\\n};\\n\\nvec3 QuadBezier1D(in vec3 a, in vec3 b, in vec3 c, in float t) {\\n float tInv = 1.0 - t;\\n return a * tInv * tInv + 2.0 * b * tInv * t + c * t * t;\\n}\\n\\nvec3 QuadBezier2D(in vec3 a, in vec3 b, in vec3 c,\\n in vec3 d, in vec3 e, in vec3 f,\\n in vec3 g, in vec3 h, in vec3 i,\\n in float u, in float v) {\\n return QuadBezier1D(QuadBezier1D(a, b, c, u), QuadBezier1D(d, e, f, u), QuadBezier1D(g, h, i, u), v);\\n}\\n\\nVertexAndNormal getPos(in float id) {\\n float t1 = time * 0.5, t2 = time, t3 = time * 1.25;\\n\\n float c1 = cos(t1), s1 = sin(t1);\\n float c2 = cos(t2), s2 = sin(t2);\\n float c3 = cos(t3), s3 = sin(t3);\\n\\n vec3 a = vec3(c3, s2, s1) * 1.25;\\n vec3 b = vec3(s3 * s2, c1, s3) * 1.25;\\n vec3 c = vec3(c2, c1, s3) * 1.25;\\n vec3 d = vec3(s1, c2 * c3, s2) * 1.25;\\n vec3 e = vec3(c2, c3, s1) * 1.25;\\n vec3 f = vec3(c3, s1, c2) * 1.25;\\n vec3 g = vec3(c2, s3, c1) * 1.25;\\n vec3 h = vec3(c1, s3, s2) * 1.25;\\n vec3 i = vec3(s1, s2, c3) * 1.25;\\n\\n float fid = floor(id / 6.0);\\n int cid = int(mod(id, 6.0));\\n\\n vec2 edgeStep = 1.0 / RESOLUTION;\\n\\n float x = mod(fid, RESOLUTION.x);\\n float y = (fid - x) / RESOLUTION.x;\\n\\n float u = x / RESOLUTION.x;\\n float v = y / RESOLUTION.y;\\n\\n vec3 v1 = QuadBezier2D(a, b, c, d, e, f, g, h, i, u + edgeStep.x, v);\\n vec3 v2 = QuadBezier2D(a, b, c, d, e, f, g, h, i, u, v);\\n vec3 v3 = QuadBezier2D(a, b, c, d, e, f, g, h, i, u, v + edgeStep.y);\\n vec3 nor = normalize(cross(v2 - v1, v3 - v1));\\n\\n if (cid == 1) u += edgeStep.x;\\n if (cid == 2 || cid == 3) u += edgeStep.x, v += edgeStep.y;\\n if (cid == 4) v += edgeStep.y;\\n\\n vec3 pos = QuadBezier2D(a, b, c, d, e, f, g, h, i, u, v);\\n return VertexAndNormal(pos, nor);\\n}\\n\\nvoid main() {\\n //vec2 mouseRot = mouse * PI;\\n //float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\\n //float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\\n\\n VertexAndNormal vertex = getPos(vertexId);\\n //vertex.pos.xz *= mat2(cy, sy, -sy, cy);\\n //vertex.pos.yz *= mat2(cp, sp, -sp, cp);\\n\\n vec2 screenCoords = vertex.pos.xy / (EYE_DISTANCE - vertex.pos.z);\\n screenCoords.x *= resolution.y / resolution.x;\\n float depth = (vertex.pos.z - Z_NEAR) / (Z_FAR - Z_NEAR);\\n gl_Position = vec4(screenCoords, depth, 1.0);\\n v_color = vec4(abs(vertex.nor), 1.0);\\n}\"}", + "settings": { + "num": 11610, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define EYE_DISTANCE 2.0\n#define Z_NEAR 2.5\n#define Z_FAR -2.5\n\n#define RESOLUTION vec2(45.0)\n\n#define PI 3.1415\n\nstruct VertexAndNormal {\n vec3 pos;\n vec3 nor;\n};\n\nvec3 QuadBezier1D(in vec3 a, in vec3 b, in vec3 c, in float t) {\n float tInv = 1.0 - t;\n return a * tInv * tInv + 2.0 * b * tInv * t + c * t * t;\n}\n\nvec3 QuadBezier2D(in vec3 a, in vec3 b, in vec3 c,\n in vec3 d, in vec3 e, in vec3 f,\n in vec3 g, in vec3 h, in vec3 i,\n in float u, in float v) {\n return QuadBezier1D(QuadBezier1D(a, b, c, u), QuadBezier1D(d, e, f, u), QuadBezier1D(g, h, i, u), v);\n}\n\nVertexAndNormal getPos(in float id) {\n float t1 = time * 0.5, t2 = time, t3 = time * 1.25;\n\n float c1 = cos(t1), s1 = sin(t1);\n float c2 = cos(t2), s2 = sin(t2);\n float c3 = cos(t3), s3 = sin(t3);\n\n vec3 a = vec3(c3, s2, s1) * 1.25;\n vec3 b = vec3(s3 * s2, c1, s3) * 1.25;\n vec3 c = vec3(c2, c1, s3) * 1.25;\n vec3 d = vec3(s1, c2 * c3, s2) * 1.25;\n vec3 e = vec3(c2, c3, s1) * 1.25;\n vec3 f = vec3(c3, s1, c2) * 1.25;\n vec3 g = vec3(c2, s3, c1) * 1.25;\n vec3 h = vec3(c1, s3, s2) * 1.25;\n vec3 i = vec3(s1, s2, c3) * 1.25;\n\n float fid = floor(id / 6.0);\n int cid = int(mod(id, 6.0));\n\n vec2 edgeStep = 1.0 / RESOLUTION;\n\n float x = mod(fid, RESOLUTION.x);\n float y = (fid - x) / RESOLUTION.x;\n\n float u = x / RESOLUTION.x;\n float v = y / RESOLUTION.y;\n\n vec3 v1 = QuadBezier2D(a, b, c, d, e, f, g, h, i, u + edgeStep.x, v);\n vec3 v2 = QuadBezier2D(a, b, c, d, e, f, g, h, i, u, v);\n vec3 v3 = QuadBezier2D(a, b, c, d, e, f, g, h, i, u, v + edgeStep.y);\n vec3 nor = normalize(cross(v2 - v1, v3 - v1));\n\n if (cid == 1) u += edgeStep.x;\n if (cid == 2 || cid == 3) u += edgeStep.x, v += edgeStep.y;\n if (cid == 4) v += edgeStep.y;\n\n vec3 pos = QuadBezier2D(a, b, c, d, e, f, g, h, i, u, v);\n return VertexAndNormal(pos, nor);\n}\n\nvoid main() {\n //vec2 mouseRot = mouse * PI;\n //float cy = cos(mouseRot.x), sy = sin(mouseRot.x);\n //float cp = cos(mouseRot.y), sp = sin(mouseRot.y);\n\n VertexAndNormal vertex = getPos(vertexId);\n //vertex.pos.xz *= mat2(cy, sy, -sy, cy);\n //vertex.pos.yz *= mat2(cp, sp, -sp, cp);\n\n vec2 screenCoords = vertex.pos.xy / (EYE_DISTANCE - vertex.pos.z);\n screenCoords.x *= resolution.y / resolution.x;\n float depth = (vertex.pos.z - Z_NEAR) / (Z_FAR - Z_NEAR);\n gl_Position = vec4(screenCoords, depth, 1.0);\n v_color = vec4(abs(vertex.nor), 1.0);\n}" + }, "screenshotURL": "data/images/images-fz6drbm3nq64ozhc4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qGKmWQ4t3CedrMdN2/art.json b/art/qGKmWQ4t3CedrMdN2/art.json index 653fe069..eff39fd3 100644 --- a/art/qGKmWQ4t3CedrMdN2/art.json +++ b/art/qGKmWQ4t3CedrMdN2/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":36,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 triangle(int vtx) {\\n if (vtx == 0) {\\n return vec3(-1.0, -1.0, 0.0);\\n } else if (vtx == 1) {\\n return vec3(0.0, 1.0, 0.0);\\n } else if (vtx == 2) {\\n return vec3(1.0, -1.0, 0.0);\\n } else {\\n return vec3(0.0, sin(time)*sin(time), 0.0);\\n }\\n}\\n\\nvoid main() {\\n float triangleId = floor(vertexId / 3.0);\\n float triangleCount = floor(vertexCount / 3.0);\\n float triVtx = mod(vertexId, 3.0);\\n \\n // uniformly spaced in (0, 1)\\n float t = mix(triangleId/triangleCount,\\n (triangleId+1.)/triangleCount,\\n 0.5);\\n \\n float angle = 2. * PI * t;\\n angle += time;\\n vec3 pos = triangle(int(triVtx));\\n mat3 rot = mat3(\\n vec3(cos(angle), -sin(angle), 0.0),\\n vec3(sin(angle), cos(angle), 0.0),\\n vec3(0.0, 0.0, 1.0)\\n );\\n mat3 scal = mat3(0.2);\\n pos = scal * rot * pos;\\n \\n pos.y *= resolution.x/resolution.y;\\n\\n gl_Position = vec4(pos, 1.0);\\n vec3 col = hsv2rgb(vec3(t, 0.7, 0.7));\\n v_color = vec4(col, 1.0 - t);\\n}\"}", + "settings": { + "num": 36, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 triangle(int vtx) {\n if (vtx == 0) {\n return vec3(-1.0, -1.0, 0.0);\n } else if (vtx == 1) {\n return vec3(0.0, 1.0, 0.0);\n } else if (vtx == 2) {\n return vec3(1.0, -1.0, 0.0);\n } else {\n return vec3(0.0, sin(time)*sin(time), 0.0);\n }\n}\n\nvoid main() {\n float triangleId = floor(vertexId / 3.0);\n float triangleCount = floor(vertexCount / 3.0);\n float triVtx = mod(vertexId, 3.0);\n \n // uniformly spaced in (0, 1)\n float t = mix(triangleId/triangleCount,\n (triangleId+1.)/triangleCount,\n 0.5);\n \n float angle = 2. * PI * t;\n angle += time;\n vec3 pos = triangle(int(triVtx));\n mat3 rot = mat3(\n vec3(cos(angle), -sin(angle), 0.0),\n vec3(sin(angle), cos(angle), 0.0),\n vec3(0.0, 0.0, 1.0)\n );\n mat3 scal = mat3(0.2);\n pos = scal * rot * pos;\n \n pos.y *= resolution.x/resolution.y;\n\n gl_Position = vec4(pos, 1.0);\n vec3 col = hsv2rgb(vec3(t, 0.7, 0.7));\n v_color = vec4(col, 1.0 - t);\n}" + }, "screenshotURL": "data/images/images-i0mv6mart8riqkik2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qKGoihMGbyYe64imT/art.json b/art/qKGoihMGbyYe64imT/art.json index a1835040..a53d8c48 100644 --- a/art/qKGoihMGbyYe64imT/art.json +++ b/art/qKGoihMGbyYe64imT/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres", "private": false, "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.45,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.5,-.5,.8);\\n pos.xz *= mat2(.8,.5,-.5,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .5;\\n \\n pos.xy *= .5/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.5,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.45,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.5,-.5,.8);\n pos.xz *= mat2(.8,.5,-.5,.8);\n \n pos *= 1.;\n \n\n pos.z += .5;\n \n pos.xy *= .5/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.5,1);\n}" + }, "screenshotURL": "data/images/images-vvq2sdbr9vj2gigoc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qL56Nfe9M96bTaqYj/art.json b/art/qL56Nfe9M96bTaqYj/art.json index 0a016b7a..75e2893c 100644 --- a/art/qL56Nfe9M96bTaqYj/art.json +++ b/art/qL56Nfe9M96bTaqYj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":74843,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/combatrecordings/dead-fader-dancefloor-nemesis-preview\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.1, 0.2, 1.4) * 11.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 2.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 0.1 ) * 0.5;\\n\\nvec3 gCubeColor = vec3(0.1, 1.2, 0.1)*3.;\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom =11.8;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 2.8;\\nfloat gFloorHeight = 11.5;\\nfloat g_cameraFar = 1000.0;\\n#define PI radians( 111.-(mouse.y * 3. -4.) )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 2.0, 110.3, 10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 14.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-3., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 2.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 0.2)).xyz;\\n \\tv3 = (mat * vec4(v3, 0.5)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 100 );\\n\\n outSceneVertex.fAlpha = 0.2; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 12.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, mouse.y * 3.0, 2.0*mouse.x);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, -0.2,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, -0.6, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n c, 0, 1, 0,\\n 0, s, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 0, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 172, 2 -mouse.x);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 2);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][2], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 - a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 + a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, -up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, -1,\\n zAxis, 0.11,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 3. - 0.5;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.5);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * (2. /mouse.y));\\n}\\n\\nconst float perBlock = 6.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 3.5));\\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z-snd*5.; \\n float height = 0.5 + snd;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0+snd, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t + 0.27) * sin(t * 1.13) + sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8-(mouse.x,mouse.y);\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., 0.);\\n \\n \\tvec3 vCameraTarget = vec3( -mouse.x, 0., 0.5+ mouse );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1-mouse.x) * 50., 21.*mouse.y, cos(time * 1.1) * 50.0);\\n float ca = 1.;\\n \\n // get sick!\\n ca = time * 1.1;\\n \\tvec3 vCameraUp = vec3( 0.5, 1, 0.5 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(0.17) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 74843, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/combatrecordings/dead-fader-dancefloor-nemesis-preview", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.1, 0.2, 1.4) * 11.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 2.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 0.1 ) * 0.5;\n\nvec3 gCubeColor = vec3(0.1, 1.2, 0.1)*3.;\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom =11.8;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 2.8;\nfloat gFloorHeight = 11.5;\nfloat g_cameraFar = 1000.0;\n#define PI radians( 111.-(mouse.y * 3. -4.) )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 2.0, 110.3, 10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 14.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-3., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 2.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 0.2)).xyz;\n \tv3 = (mat * vec4(v3, 0.5)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 100 );\n\n outSceneVertex.fAlpha = 0.2; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 12.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, mouse.y * 3.0, 2.0*mouse.x);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, -0.2,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, -0.6, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n c, 0, 1, 0,\n 0, s, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 0, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 172, 2 -mouse.x);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 2);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][2], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 - a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 + a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, -up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, -1,\n zAxis, 0.11,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 3. - 0.5;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.5);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * (2. /mouse.y));\n}\n\nconst float perBlock = 6.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 3.5));\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z-snd*5.; \n float height = 0.5 + snd;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0+snd, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t + 0.27) * sin(t * 1.13) + sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8-(mouse.x,mouse.y);\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., 0.);\n \n \tvec3 vCameraTarget = vec3( -mouse.x, 0., 0.5+ mouse );\n \tvec3 vCameraPos = vec3(sin(time * 0.1-mouse.x) * 50., 21.*mouse.y, cos(time * 1.1) * 50.0);\n float ca = 1.;\n \n // get sick!\n ca = time * 1.1;\n \tvec3 vCameraUp = vec3( 0.5, 1, 0.5 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(0.17) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-ulv24gc01elrggl6p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qMttNCuB7HFezcMnW/art.json b/art/qMttNCuB7HFezcMnW/art.json index 5bb83cf4..c5102ba1 100644 --- a/art/qMttNCuB7HFezcMnW/art.json +++ b/art/qMttNCuB7HFezcMnW/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":2592,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/everythinggorillazp2/feelgoodinc\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float angleOffset = 5.0;\\n float theta = radians(mod(vertexId * angleOffset, 180.0));\\n float fi = radians(mod(floor(vertexId / (180.0 / angleOffset)) * angleOffset, 360.0));\\n \\n float x = sin(theta) * cos(fi);\\n float y = sin(theta) * sin(fi);\\n float z = cos(theta);\\n \\n vec3 pos = vec3(x, y, z) * (texture2D(sound, vec2(0.225, 0)).a);\\n \\n mat4 rotx = mat4(1.0);\\n rotx[1][1] = cos(time);\\n rotx[2][1] = -sin(time);\\n rotx[1][2] = sin(time);\\n rotx[2][2] = cos(time);\\n \\n mat4 rotz = mat4(1.0);\\n rotz[0][0] = cos(time);\\n rotz[1][0] = -sin(time);\\n rotz[0][1] = sin(time);\\n rotz[1][1] = cos(time);\\n \\n \\n gl_Position = rotz * rotx * vec4(pos, 1.0);\\n gl_PointSize = 2.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 2592, + "mode": "POINTS", + "sound": "https://soundcloud.com/everythinggorillazp2/feelgoodinc", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float angleOffset = 5.0;\n float theta = radians(mod(vertexId * angleOffset, 180.0));\n float fi = radians(mod(floor(vertexId / (180.0 / angleOffset)) * angleOffset, 360.0));\n \n float x = sin(theta) * cos(fi);\n float y = sin(theta) * sin(fi);\n float z = cos(theta);\n \n vec3 pos = vec3(x, y, z) * (texture2D(sound, vec2(0.225, 0)).a);\n \n mat4 rotx = mat4(1.0);\n rotx[1][1] = cos(time);\n rotx[2][1] = -sin(time);\n rotx[1][2] = sin(time);\n rotx[2][2] = cos(time);\n \n mat4 rotz = mat4(1.0);\n rotz[0][0] = cos(time);\n rotz[1][0] = -sin(time);\n rotz[0][1] = sin(time);\n rotz[1][1] = cos(time);\n \n \n gl_Position = rotz * rotx * vec4(pos, 1.0);\n gl_PointSize = 2.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-nnjgd3hdo3tniqw0o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qRGKhfL3wRe3KqPob/art.json b/art/qRGKhfL3wRe3KqPob/art.json index 6572f8ab..502c0c4e 100644 --- a/art/qRGKhfL3wRe3KqPob/art.json +++ b/art/qRGKhfL3wRe3KqPob/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":17548,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle * mouse.y );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.7) + sin(t * 0.113) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.15, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.03;\\n float end = start + .8;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 2.8) * .4 - min(resolution.x / resolution.y, 1.7)); \\n mat *= rotZ((0.2 + uvfl.y - PI) * time * 3.);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n//1v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n //v_color.a = 1.0 - uvf.y;\\n //1v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 17548, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle * mouse.y );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.7) + sin(t * 0.113) + sin(t * 0.73);\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.15, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.03;\n float end = start + .8;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 2.8) * .4 - min(resolution.x / resolution.y, 1.7)); \n mat *= rotZ((0.2 + uvfl.y - PI) * time * 3.);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = 0.;mix(0.3, 1.0, abs(m1p1(uvfl.x)));\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n//1v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n //v_color.a = 1.0 - uvf.y;\n //1v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-7a4kx1l8omlierqtt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qRP5HEWEavfkjMpzp/art.json b/art/qRP5HEWEavfkjMpzp/art.json index e106a90e..69aa3d7e 100644 --- a/art/qRP5HEWEavfkjMpzp/art.json +++ b/art/qRP5HEWEavfkjMpzp/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thenoiseprocess/ousia\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#44575.1\\n\\n#define PI radians(180.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0.);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 p = uv;//(-resolution + 2.0*uv.xy)/resolution.y;\\n\\t\\n float timeFactor = 10.;\\n \\n\\tfor(int i = 0; i < 8; i++) {\\n\\t\\tp = abs(p)/clamp(dot(p, p), 0.7, 1.0) - vec2(abs(cos(time/timeFactor)), abs(sin(time/timeFactor)));\\n\\t\\t\\n\\t\\tp *= mat2(cos(time/timeFactor), sin(time/timeFactor), -sin(time/timeFactor), cos(time/timeFactor));\\n\\t}\\n\\t\\n\\tvec3 col = mix(vec3(0, 0.1, 0.2), vec3(0.3, 0.5, 1.0), smoothstep(0.0, 1.0, abs(p.x)));\\n\\tcol = mix(col, vec3(0.3, 0.3, 4), smoothstep(0.9, 1.0, abs(p.y)));\\n\\t//gl_FragColor = vec4(col, 1);\\n\\t\\n\\t//gl_FragColor = vec4(vec3(pattern), 1.0);\\n \\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n \\n\\t\\n //camera\\n float r = .7;\\n float tm = time * 0.05;\\n float tm2 = time * 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 2.;//finalDesiredPointSize;\\n\\n v_color = vec4(col, 1);\\n float depth = (v_color.x*v_color.y*v_color.z)/2.;\\n \\n vec4 finalPos = vec4(ux, vy, depth+snd/5., 1.);\\n \\n gl_Position = mat*finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thenoiseprocess/ousia", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#44575.1\n\n#define PI radians(180.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0.);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 p = uv;//(-resolution + 2.0*uv.xy)/resolution.y;\n\t\n float timeFactor = 10.;\n \n\tfor(int i = 0; i < 8; i++) {\n\t\tp = abs(p)/clamp(dot(p, p), 0.7, 1.0) - vec2(abs(cos(time/timeFactor)), abs(sin(time/timeFactor)));\n\t\t\n\t\tp *= mat2(cos(time/timeFactor), sin(time/timeFactor), -sin(time/timeFactor), cos(time/timeFactor));\n\t}\n\t\n\tvec3 col = mix(vec3(0, 0.1, 0.2), vec3(0.3, 0.5, 1.0), smoothstep(0.0, 1.0, abs(p.x)));\n\tcol = mix(col, vec3(0.3, 0.3, 4), smoothstep(0.9, 1.0, abs(p.y)));\n\t//gl_FragColor = vec4(col, 1);\n\t\n\t//gl_FragColor = vec4(vec3(pattern), 1.0);\n \n\t//gl_FragColor = vec4(pattern(3.*c));\n \n\t\n //camera\n float r = .7;\n float tm = time * 0.05;\n float tm2 = time * 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 2.;//finalDesiredPointSize;\n\n v_color = vec4(col, 1);\n float depth = (v_color.x*v_color.y*v_color.z)/2.;\n \n vec4 finalPos = vec4(ux, vy, depth+snd/5., 1.);\n \n gl_Position = mat*finalPos;\n}" + }, "screenshotURL": "data/images/images-m8hvz5l4uzqyfvm1e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qSJ4doZdZD5GW3Y5g/art.json b/art/qSJ4doZdZD5GW3Y5g/art.json index eb7ea5c4..f94635a4 100644 --- a/art/qSJ4doZdZD5GW3Y5g/art.json +++ b/art/qSJ4doZdZD5GW3Y5g/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float mouseX = max(mouse.x, -.5);\\n mouseX = min(mouseX, 0.5);\\n \\n float xOffset = sin(time + y * 0.2) * mouseX * 0.2;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float dx = u * 2.0 - 1.0 + xOffset;\\n float dy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(dx, dy) * 0.75;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n gl_PointSize = 200.0 / across;\\n gl_PointSize *= resolution.x / 600.0 * vertexId / vertexCount;\\n \\n v_color = vec4(vertexId / vertexCount, 0.0, abs(cos(time)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float mouseX = max(mouse.x, -.5);\n mouseX = min(mouseX, 0.5);\n \n float xOffset = sin(time + y * 0.2) * mouseX * 0.2;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float dx = u * 2.0 - 1.0 + xOffset;\n float dy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(dx, dy) * 0.75;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n gl_PointSize = 200.0 / across;\n gl_PointSize *= resolution.x / 600.0 * vertexId / vertexCount;\n \n v_color = vec4(vertexId / vertexCount, 0.0, abs(cos(time)), 1);\n}" + }, "screenshotURL": "data/images/images-fofkuy5cmrb8az76m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qSNjoFSsTFZD2TJcg/art.json b/art/qSNjoFSsTFZD2TJcg/art.json index 70cb3be1..b9c70f78 100644 --- a/art/qSNjoFSsTFZD2TJcg/art.json +++ b/art/qSNjoFSsTFZD2TJcg/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trevor", "avatarUrl": "https://lh6.googleusercontent.com/-5kLKsPjdMwg/AAAAAAAAAAI/AAAAAAAABpc/UHOkxSB_ZkQ/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/tennysonmusic/angus-julia-stone-for-you?in=tennysonmusic/sets/singles\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.996078431372549,0.996078431372549,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 180. + vertexId * 0.1925 + (time * 20.));\\n float sx = mod(vertexId,pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float snd = texture2D(sound,vec2(sx*0.125,sy)).a;\\n float radius = (2.55 + pow(snd,2.)*3.) * (sin(30.)-sy);\\n \\n float x = sin(radius);\\n float y = cos(deg) * radius;\\n float z = vertexId * 0.125;\\n vec3 pos = vec3(x,y,z);\\n \\n float aspect = resolution.y / resolution.x;\\n \\n mat4 camera = mat4(\\n aspect, 0.1, 0., 0.,\\n 0.2, 1., 0., 0.,\\n -0.03, .006, .1, .1,\\n 0., -3., 0., 3.);\\n \\n mat4 rotZee = rotZ(radians(-81.));\\n mat4 rotEx = rotX(radians(-5.));\\n mat4 rotWhy = rotY(radians(1.));\\n mat4 moveIt = trans(vec3(-0.8,1.,-5.));\\n mat4 size = uniformScale(10.);\\n \\n gl_Position = camera * rotEx * rotZee * rotWhy * moveIt * size * vec4(pos.x-4.5,pos.y-2.,pos.z,1.);\\n float hue = (time * 0.01 + radius * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n //v_color = vec4(1., (vertexId/vertexCount) / 2. + .5, 1., 1. );\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/tennysonmusic/angus-julia-stone-for-you?in=tennysonmusic/sets/singles", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.996078431372549, + 0.996078431372549, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 180. + vertexId * 0.1925 + (time * 20.));\n float sx = mod(vertexId,pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float snd = texture2D(sound,vec2(sx*0.125,sy)).a;\n float radius = (2.55 + pow(snd,2.)*3.) * (sin(30.)-sy);\n \n float x = sin(radius);\n float y = cos(deg) * radius;\n float z = vertexId * 0.125;\n vec3 pos = vec3(x,y,z);\n \n float aspect = resolution.y / resolution.x;\n \n mat4 camera = mat4(\n aspect, 0.1, 0., 0.,\n 0.2, 1., 0., 0.,\n -0.03, .006, .1, .1,\n 0., -3., 0., 3.);\n \n mat4 rotZee = rotZ(radians(-81.));\n mat4 rotEx = rotX(radians(-5.));\n mat4 rotWhy = rotY(radians(1.));\n mat4 moveIt = trans(vec3(-0.8,1.,-5.));\n mat4 size = uniformScale(10.);\n \n gl_Position = camera * rotEx * rotZee * rotWhy * moveIt * size * vec4(pos.x-4.5,pos.y-2.,pos.z,1.);\n float hue = (time * 0.01 + radius * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n //v_color = vec4(1., (vertexId/vertexCount) / 2. + .5, 1., 1. );\n \n}" + }, "screenshotURL": "data/images/images-9ypis39ot97mfaohe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qSRWCBPJwjsffzsKb/art.json b/art/qSRWCBPJwjsffzsKb/art.json index 2a17a8d5..579ceae1 100644 --- a/art/qSRWCBPJwjsffzsKb/art.json +++ b/art/qSRWCBPJwjsffzsKb/art.json @@ -28,7 +28,19 @@ "name": "vibrations", "private": false, "username": "mark", - "settings": "{\"num\":25957,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/muterecords/balanescu-quartet-autobahn\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.058823529411764705,0.058823529411764705,0.058823529411764705,1],\"shader\":\"#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n\\nvoid main () {\\n float i = hash(vertexId);\\n float f = hash(i);\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 2.);\\n \\n float ang = vertexId / 1000.;\\n float perspective = .3 * (1. + mouse.y);\\n float t = time * (f + .1) + mouse.x;\\n float x = i * sin(ang + t) * .8;\\n float y = i * cos(ang + t);\\n y += .1 * snd * (1. - y);\\n y *= perspective;\\n \\n float vis = snd / (y + 1.);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 10. * vis;\\n \\n v_color = vec4(\\n snd * .7 * (1. - f),\\n snd * .8 * cos(f * PI),\\n snd * 2.,\\n vis);\\n}\"}", + "settings": { + "num": 25957, + "mode": "POINTS", + "sound": "https://soundcloud.com/muterecords/balanescu-quartet-autobahn", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.058823529411764705, + 0.058823529411764705, + 0.058823529411764705, + 1 + ], + "shader": "#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n\nvoid main () {\n float i = hash(vertexId);\n float f = hash(i);\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 2.);\n \n float ang = vertexId / 1000.;\n float perspective = .3 * (1. + mouse.y);\n float t = time * (f + .1) + mouse.x;\n float x = i * sin(ang + t) * .8;\n float y = i * cos(ang + t);\n y += .1 * snd * (1. - y);\n y *= perspective;\n \n float vis = snd / (y + 1.);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 10. * vis;\n \n v_color = vec4(\n snd * .7 * (1. - f),\n snd * .8 * cos(f * PI),\n snd * 2.,\n vis);\n}" + }, "screenshotURL": "data/images/images-cm496gm3zn7w4pmpm-thumbnail.jpg", "views": { "$numberInt": "656" diff --git a/art/qShjbKXDhES9fS66n/art.json b/art/qShjbKXDhES9fS66n/art.json index 0a76b34f..aa427f4e 100644 --- a/art/qShjbKXDhES9fS66n/art.json +++ b/art/qShjbKXDhES9fS66n/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":8795,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/ambassador21/ambassador21-sniff-your-leader-out-april-10th-2015-on-industrial-strength\",\"lineSize\":\"CSS\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n _ _ _ _ \\n ( ) ( ) ( ) ( ) \\n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \\n( V )( o_)( _)( _)( o_)\\\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\\n \\\\_/ \\\\( /_\\\\ /_\\\\ \\\\( /_^_\\\\/__)/_\\\\||/_^_\\\\\\\\___\\\\ \\\\( /_\\\\ /_^_\\\\/_\\\\ /_\\\\ \\n \\n\\n\\n\\n*/\\n\\n\\n\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\\n \\n \\n \\n \\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = hash(u) * 0.25 + 0.1;\\n // Match each line to a specific row in the sound texture\\n float historyV = v * 0.004;\\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\\n vec2 off = vec2(\\n cos(snd1 * PI * 8.),\\n sin(snd2 * PI * 6.4));\\n\\n vec2 xy = vec2(\\n m1p1(hash(time + vertexId)),\\n m1p1(hash(time + vertexId + 1.)));\\n// snd1 * 2. - 1.,\\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\\n\\n float hue = u;\\n float sat = 0.;\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\\n gl_PointSize = 4.;\\n}\"}", + "settings": { + "num": 8795, + "mode": "LINES", + "sound": "https://soundcloud.com/ambassador21/ambassador21-sniff-your-leader-out-april-10th-2015-on-industrial-strength", + "lineSize": "CSS", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n _ _ _ _ \n ( ) ( ) ( ) ( ) \n _ _ ___ __ | | ___ __ __ __ | |_ ___ _| | ___ __ ___ __ | | \n( V )( o_)( _)( _)( o_)\\ V /(_' ( _ )( o )/ o )( o_)( _)( o )( _)( _)\n \\_/ \\( /_\\ /_\\ \\( /_^_\\/__)/_\\||/_^_\\\\___\\ \\( /_\\ /_^_\\/_\\ /_\\ \n \n\n\n\n*/\n\n\n\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float v = floor(vertexId / 2.0) / vertexCount * 2.;\n float u = sin(time * 0.001 + time * (vertexId + 1.) * 0.1) * 1.;\n \n \n \n \n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = hash(u) * 0.25 + 0.1;\n // Match each line to a specific row in the sound texture\n float historyV = v * 0.004;\n float snd1 = texture2D(sound, vec2(historyX, historyV)).a;\n float snd2 = texture2D(sound, vec2(historyX + 0.1, historyV)).a;\n float snd3 = texture2D(sound, vec2(0.1, v)).a;\n vec2 off = vec2(\n cos(snd1 * PI * 8.),\n sin(snd2 * PI * 6.4));\n\n vec2 xy = vec2(\n m1p1(hash(time + vertexId)),\n m1p1(hash(time + vertexId + 1.)));\n// snd1 * 2. - 1.,\n// snd2 * 2. - 1.);// * mix(1., -1., mod((time + vertexId * 0.1 + snd1) * 60., 2.));\n gl_Position = vec4(xy * 0.1 + off, 0, 1);\n\n float hue = u;\n float sat = 0.;\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color = mix(v_color, vec4(1,0,0,1), step(0.78, snd3));\n gl_PointSize = 4.;\n}" + }, "screenshotURL": "data/images/images-2jgp30uettorasyt2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qXiLEbW6jk6fh9rJj/art.json b/art/qXiLEbW6jk6fh9rJj/art.json index be2c6c32..9c5a253c 100644 --- a/art/qXiLEbW6jk6fh9rJj/art.json +++ b/art/qXiLEbW6jk6fh9rJj/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":87408,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 3.//KParameter0 0.>>10.\\n#define parameter1 1.//KParameter1 0.>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 -0.5>>1.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n#define PI radians(90.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0 - parameter7), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n parameter3, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1,-0.5, parameter5,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 87408, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 3.//KParameter0 0.>>10.\n#define parameter1 1.//KParameter1 0.>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 -0.5>>1.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n#define PI radians(90.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0 - parameter7), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n parameter3, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1,-0.5, parameter5,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-zgv7y0b964ifuzls7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qZCxqkkWDsfd8gqGS/art.json b/art/qZCxqkkWDsfd8gqGS/art.json index f45cf6a9..8f83b25e 100644 --- a/art/qZCxqkkWDsfd8gqGS/art.json +++ b/art/qZCxqkkWDsfd8gqGS/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":4608,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8392156862745098,0.9450980392156862,1,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nfloat easeInOutPow(float pos, float pw) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, pw);\\n }\\n return 0.5 * (pow((pos - 2.), pw) + 2.);\\n}\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float vId = mod(vertexId, 36.);\\n vec3 qpos;\\n vec3 qnrm;\\n getCubePoint(vId, qpos, qnrm);\\n \\n float ux = floor(vId / 6.) + mod(vId, 2.);\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \\n \\n float quadsPerArea = 4.;\\n float pointsPerArea = quadsPerArea * 36.;\\n float areaId = floor(vertexId / pointsPerArea);\\n float numAreas = floor(vertexCount / pointsPerArea);\\n float areaV = areaId / numAreas;\\n float areaVertId = mod(vertexId, pointsPerArea);\\n float rowId = floor(areaVertId / 36.);\\n \\n float maxBarHeight = 0.025;\\n const int numSamples = 20; // number of history samples to read. So 30 = 1/2 second\\n const int samplesPerArea = 64; // samples across a row. There are 4096 samples I think\\n // 128 would be 32 area\\n \\n \\n float sampleRangePerArea = soundRes.x / float(samplesPerArea);\\n float sampleRangeMult = sampleRangePerArea / float(samplesPerArea) / soundRes.x; \\n \\n float timeMaxS = 0.0;\\n float instMaxS = 0.0;\\n float avgS = 0.0;\\n float timeAvgS = 0.0;\\n for (int j = 0; j < samplesPerArea; ++j) {\\n float su = mix(0., 0.6, pow(areaV, 1.0) + float(j) * sampleRangeMult);\\n float s = texture2D(sound, vec2(su, 0)).a;\\n avgS += s;\\n timeAvgS += s;\\n instMaxS = max(s, instMaxS);\\n timeMaxS = max(s, timeMaxS);\\n for (int i = 1; i < numSamples; ++i) {\\n s = texture2D(sound, vec2(su, (float(i) + .5) / soundRes.y)).a;\\n timeAvgS += s;\\n timeMaxS = max(s, timeMaxS);\\n }\\n } \\n \\n avgS /= float(samplesPerArea);\\n timeAvgS /= float(samplesPerArea * numSamples);\\n \\n float isRow2 = step(1.5, rowId);\\n float isRow3 = step(2.5, rowId);\\n \\n float radius = numAreas * .5;\\n mat4 pmat = persp(radians(60.), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(0, numAreas * .3, radius);\\n vec3 target = vec3(0, 3, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up);\\n mat4 wmat = ident();\\n \\n float height = 10.;\\n float row0 = 0.;\\n float row1 = timeMaxS - maxBarHeight * .9;\\n float row2 = avgS - maxBarHeight * .9;\\n wmat *= scale(\\n mix(vec3(1), vec3(1, 0.001, 1.1), isRow3));\\n wmat *= rotY(areaV * PI * 2. + time * -.1);\\n wmat *= rotZ(mix(-.3, .3, timeAvgS * .7 + sin(time + areaV * PI * 2.) * .1));\\n wmat *= trans(vec3(\\n numAreas / 4.5, //(areaId - numAreas * .5) * 1.9, \\n mix(mix(row0, row1, step(0.5, rowId)), row2, isRow2) * height * step(rowId, 2.5),\\n mix(0., 0., step(2.5,rowId))));\\n float scaleFudge = mix(0.75, 1.0, step(0.5, rowId));\\n wmat *= scale(vec3(\\n scaleFudge, \\n mix(instMaxS, maxBarHeight, step(0.5, rowId)) * height, \\n scaleFudge));\\n wmat *= trans(vec3(0., .5, 0));\\n wmat *= uniformScale(.5 / .7);\\n \\n gl_Position = pmat * vmat * wmat * vec4(qpos, 1);\\n \\n float l = dot(mat3(wmat) * qnrm, normalize(vec3(1,1,3))) * .5 + .5;\\n\\n float hue = mix(.3, 0., instMaxS) /* ;areaV * .2 */ + rowId * .8 + step(1.5, rowId) * .0;\\n float sat = mix(0.5, 1., instMaxS);\\n float val = mix(mix(0.8, 1.0, pow(instMaxS, 3.)), mix(0.2, 2.0, pow(timeMaxS + .2, 5.0)), rowId);\\n val = mix(val, mix(0.4, 1.0, avgS), isRow2);\\n sat = mix(1., 0., isRow3);\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * l, 1);\\n}\"}", + "settings": { + "num": 4608, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sayyida-ghazia-sartaj/yeh-kia-jaga-hai-asha-bhosle", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8392156862745098, + 0.9450980392156862, + 1, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nfloat easeInOutPow(float pos, float pw) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, pw);\n }\n return 0.5 * (pow((pos - 2.), pw) + 2.);\n}\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float vId = mod(vertexId, 36.);\n vec3 qpos;\n vec3 qnrm;\n getCubePoint(vId, qpos, qnrm);\n \n float ux = floor(vId / 6.) + mod(vId, 2.);\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \n \n float quadsPerArea = 4.;\n float pointsPerArea = quadsPerArea * 36.;\n float areaId = floor(vertexId / pointsPerArea);\n float numAreas = floor(vertexCount / pointsPerArea);\n float areaV = areaId / numAreas;\n float areaVertId = mod(vertexId, pointsPerArea);\n float rowId = floor(areaVertId / 36.);\n \n float maxBarHeight = 0.025;\n const int numSamples = 20; // number of history samples to read. So 30 = 1/2 second\n const int samplesPerArea = 64; // samples across a row. There are 4096 samples I think\n // 128 would be 32 area\n \n \n float sampleRangePerArea = soundRes.x / float(samplesPerArea);\n float sampleRangeMult = sampleRangePerArea / float(samplesPerArea) / soundRes.x; \n \n float timeMaxS = 0.0;\n float instMaxS = 0.0;\n float avgS = 0.0;\n float timeAvgS = 0.0;\n for (int j = 0; j < samplesPerArea; ++j) {\n float su = mix(0., 0.6, pow(areaV, 1.0) + float(j) * sampleRangeMult);\n float s = texture2D(sound, vec2(su, 0)).a;\n avgS += s;\n timeAvgS += s;\n instMaxS = max(s, instMaxS);\n timeMaxS = max(s, timeMaxS);\n for (int i = 1; i < numSamples; ++i) {\n s = texture2D(sound, vec2(su, (float(i) + .5) / soundRes.y)).a;\n timeAvgS += s;\n timeMaxS = max(s, timeMaxS);\n }\n } \n \n avgS /= float(samplesPerArea);\n timeAvgS /= float(samplesPerArea * numSamples);\n \n float isRow2 = step(1.5, rowId);\n float isRow3 = step(2.5, rowId);\n \n float radius = numAreas * .5;\n mat4 pmat = persp(radians(60.), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(0, numAreas * .3, radius);\n vec3 target = vec3(0, 3, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 vmat = cameraLookAt(eye, target, up);\n mat4 wmat = ident();\n \n float height = 10.;\n float row0 = 0.;\n float row1 = timeMaxS - maxBarHeight * .9;\n float row2 = avgS - maxBarHeight * .9;\n wmat *= scale(\n mix(vec3(1), vec3(1, 0.001, 1.1), isRow3));\n wmat *= rotY(areaV * PI * 2. + time * -.1);\n wmat *= rotZ(mix(-.3, .3, timeAvgS * .7 + sin(time + areaV * PI * 2.) * .1));\n wmat *= trans(vec3(\n numAreas / 4.5, //(areaId - numAreas * .5) * 1.9, \n mix(mix(row0, row1, step(0.5, rowId)), row2, isRow2) * height * step(rowId, 2.5),\n mix(0., 0., step(2.5,rowId))));\n float scaleFudge = mix(0.75, 1.0, step(0.5, rowId));\n wmat *= scale(vec3(\n scaleFudge, \n mix(instMaxS, maxBarHeight, step(0.5, rowId)) * height, \n scaleFudge));\n wmat *= trans(vec3(0., .5, 0));\n wmat *= uniformScale(.5 / .7);\n \n gl_Position = pmat * vmat * wmat * vec4(qpos, 1);\n \n float l = dot(mat3(wmat) * qnrm, normalize(vec3(1,1,3))) * .5 + .5;\n\n float hue = mix(.3, 0., instMaxS) /* ;areaV * .2 */ + rowId * .8 + step(1.5, rowId) * .0;\n float sat = mix(0.5, 1., instMaxS);\n float val = mix(mix(0.8, 1.0, pow(instMaxS, 3.)), mix(0.2, 2.0, pow(timeMaxS + .2, 5.0)), rowId);\n val = mix(val, mix(0.4, 1.0, avgS), isRow2);\n sat = mix(1., 0., isRow3);\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * l, 1);\n}" + }, "screenshotURL": "data/images/images-zzze8dozfdddc3swq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qa68ydunsujhkHGZ6/art.json b/art/qa68ydunsujhkHGZ6/art.json index 1f416a26..c2b56348 100644 --- a/art/qa68ydunsujhkHGZ6/art.json +++ b/art/qa68ydunsujhkHGZ6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/laweffect/bass-attack\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define KP0 0.5//KParameter0\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3., c-1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.y, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w ,q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, sin(1.9-time)*KP0+0.50,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 1.0-s,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.01;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 5.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 20;\\n float snd = 0.;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf * 7.123);\\n float spy = hash(spf * 0.317);\\n float sps = hash(spf * 3.411);\\n \\n float sds = distance(vec2(u, v), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7, sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 20. / across);\\n //mat *= rotZ(snd * 10. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.7, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/laweffect/bass-attack", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define KP0 0.5//KParameter0\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3., c-1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.y, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w ,q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, sin(1.9-time)*KP0+0.50,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 1.0-s,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.01;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 5.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 20;\n float snd = 0.;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf * 7.123);\n float spy = hash(spf * 0.317);\n float sps = hash(spf * 3.411);\n \n float sds = distance(vec2(u, v), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7, sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 20. / across);\n //mat *= rotZ(snd * 10. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.7, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-8k5kfovq2uwimawm3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qbZNX3pQENCDwdJvA/art.json b/art/qbZNX3pQENCDwdJvA/art.json index 07c93062..715bbd97 100644 --- a/art/qbZNX3pQENCDwdJvA/art.json +++ b/art/qbZNX3pQENCDwdJvA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "♫♪♭♮{{triplesix g}}♯♪♫", "avatarUrl": "https://i1.sndcdn.com/avatars-000125357779-rcbpr2-large.jpg", - "settings": "{\"num\":15599,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 * mouse.x\\n#define KP1 3.0 * mouse.y\\n#define K0 KP0 KP0//KParameter0 0.>>1000.\\n#define K1 KP1 KP1//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>10.\\n#define KP3 0.0//KParameter3 0.000>>0.5\\n#define KP4 5.0//KParameter4 0.000>>5.\\n#define KP5 10000.0//KParameter5 30.000>>100000.0\\n\\n\\n#define PI radians(180. -KP1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 15599, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 * mouse.x\n#define KP1 3.0 * mouse.y\n#define K0 KP0 KP0//KParameter0 0.>>1000.\n#define K1 KP1 KP1//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>10.\n#define KP3 0.0//KParameter3 0.000>>0.5\n#define KP4 5.0//KParameter4 0.000>>5.\n#define KP5 10000.0//KParameter5 30.000>>100000.0\n\n\n#define PI radians(180. -KP1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-kvxcyyfdexw0e8epj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qbg8npmnJ2J23WmBm/art.json b/art/qbg8npmnJ2J23WmBm/art.json index 9a60ceda..464d3973 100644 --- a/art/qbg8npmnJ2J23WmBm/art.json +++ b/art/qbg8npmnJ2J23WmBm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":17570,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nfloat smoothMix(float minV, float maxV, float time) {\\n return mix(minV, maxV, t5p5(sin(time)));\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 info) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n info = vec3(ux, vy, u);\\n}\\n\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 14.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n vec3 info;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos, info); \\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 0);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(20. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(circleId * smoothMix(1., 4., time * 0.001));\\n mat *= trans(vec3(3, 0, (1. - cu) * -100.));\\n mat *= uniformScale(mix(0.1, 0.2, mod(info.x, 2.0)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = cu;\\n float sat = mix(0.0, 1., fract(time * 20. + circleId * 0.1));\\n float val = mix(0.6, 1., fract(time * 21. + circleId * 0.11));\\n float alpha = 1. - length(pos.xy) * mod(info.y, 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alpha);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 17570, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nfloat smoothMix(float minV, float maxV, float time) {\n return mix(minV, maxV, t5p5(sin(time)));\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos, out vec3 info) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n info = vec3(ux, vy, u);\n}\n\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 14.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n vec3 info;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos, info); \n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 0);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(20. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(circleId * smoothMix(1., 4., time * 0.001));\n mat *= trans(vec3(3, 0, (1. - cu) * -100.));\n mat *= uniformScale(mix(0.1, 0.2, mod(info.x, 2.0)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = cu;\n float sat = mix(0.0, 1., fract(time * 20. + circleId * 0.1));\n float val = mix(0.6, 1., fract(time * 21. + circleId * 0.11));\n float alpha = 1. - length(pos.xy) * mod(info.y, 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alpha);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-iswtyoap99b0ag4o5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qbuQhWtriSLNLQhJF/art.json b/art/qbuQhWtriSLNLQhJF/art.json index 26ab47aa..99dc3a13 100644 --- a/art/qbuQhWtriSLNLQhJF/art.json +++ b/art/qbuQhWtriSLNLQhJF/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "allen", "avatarUrl": "https://lh3.googleusercontent.com/a-/ACNPEu_O3bvsyDIr94ZElp2XWO7TMHPnxykRhtxM_15luA=s96-c", - "settings": "{\"num\":2532,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.5;\\n float yoff = sin(time + x * 0.7) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.75;\\n\\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * vy * 0.05) * 10.0;\\n \\n gl_PointSize = 1.5 + soff;\\n gl_PointSize *= 25.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n float hue = u * time + 0.5;\\n float sat = 1.0 * (time * 0.5);\\n float value = sin(u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1);\\n\\n\\n}\"}", + "settings": { + "num": 2532, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.5;\n float yoff = sin(time + x * 0.7) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.75;\n\n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * vy * 0.05) * 10.0;\n \n gl_PointSize = 1.5 + soff;\n gl_PointSize *= 25.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n float hue = u * time + 0.5;\n float sat = 1.0 * (time * 0.5);\n float value = sin(u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1);\n\n\n}" + }, "screenshotURL": "data/images/images-g9118lb45fnrmohh6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qcQGXHYoBo5f2Tn7W/art.json b/art/qcQGXHYoBo5f2Tn7W/art.json index 0540a0cc..7fecb506 100644 --- a/art/qcQGXHYoBo5f2Tn7W/art.json +++ b/art/qcQGXHYoBo5f2Tn7W/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":3600,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nmat4 scaleXYZ(float _x, float _y, float _z)\\n{\\n return mat4(_x, 0, 0, 0,\\n 0, _y, 0, 0,\\n 0, 0, _z, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n 1., 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, 1., 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n/*\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n sin(id * 0.5+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}*/\\n\\n\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n \\n cos(2.*PI*id),\\n sin(2.*PI*id),0.\\n );\\n}\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./50.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n cubep*= sizeFactor;\\n \\n \\n \\n \\n float off = 0.14;\\n float expand = 1.;\\n float curveFactor = time/20.;\\n vec3 r0 = getCurvePoint(shapeRelId + off * 0., curveFactor);\\n vec3 r1 = getCurvePoint(shapeRelId + off * 1., curveFactor);\\n vec3 r2 = getCurvePoint(shapeRelId + off * 2., curveFactor);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n cubep = (vec4(cubep,1.)*scaleXYZ(1., 10., 1.)).xyz;\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n\\n //cubep = rotX(cubep.xyz, acos(dot(vec3(1., 0., 0.),xaxis)));\\n //cubep = rotY(cubep.xyz, acos(dot(vec3(0., 1., 0.),yaxis)));\\n //cubep = rotZ(cubep.xyz, acos(dot(vec3(1., 1., 1.),xaxis)));\\n cubep = rotZ(cubep.xyz, snd+shapeRelId*2.*PI);//EXPECTED\\n \\n //cubep*= sizeFactor;//resize\\n //cubep.xyz*= (wmat*vec4(cubep,1.)).xyz;\\n \\n\\n //cubep+=r0;\\n cubep+= getCurvePoint(shapeRelId, curveFactor) ;\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n //vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 0., 2.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0., 0., 0.), vec3(0.0, 01.0, 0.0));\\n float aspect = resolution.y / resolution.x;\\n \\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n //gl_Position.x*=aspect;\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 3600, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nmat4 scaleXYZ(float _x, float _y, float _z)\n{\n return mat4(_x, 0, 0, 0,\n 0, _y, 0, 0,\n 0, 0, _z, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n 1., 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, 1., 0,\n 0, 0, 0, 1);\n}\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n/*\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n sin(id * 0.5+_time*10.),\n sin(id * 0.25+_time*10.));\n}*/\n\n\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n \n cos(2.*PI*id),\n sin(2.*PI*id),0.\n );\n}\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./50.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n cubep*= sizeFactor;\n \n \n \n \n float off = 0.14;\n float expand = 1.;\n float curveFactor = time/20.;\n vec3 r0 = getCurvePoint(shapeRelId + off * 0., curveFactor);\n vec3 r1 = getCurvePoint(shapeRelId + off * 1., curveFactor);\n vec3 r2 = getCurvePoint(shapeRelId + off * 2., curveFactor);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n cubep = (vec4(cubep,1.)*scaleXYZ(1., 10., 1.)).xyz;\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n\n //cubep = rotX(cubep.xyz, acos(dot(vec3(1., 0., 0.),xaxis)));\n //cubep = rotY(cubep.xyz, acos(dot(vec3(0., 1., 0.),yaxis)));\n //cubep = rotZ(cubep.xyz, acos(dot(vec3(1., 1., 1.),xaxis)));\n cubep = rotZ(cubep.xyz, snd+shapeRelId*2.*PI);//EXPECTED\n \n //cubep*= sizeFactor;//resize\n //cubep.xyz*= (wmat*vec4(cubep,1.)).xyz;\n \n\n //cubep+=r0;\n cubep+= getCurvePoint(shapeRelId, curveFactor) ;\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n //vec3 eye = vec3(2.5+sin(time/1.3)/4., 2.5+sin(time/1.)/4., 2.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 0., 2.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0., 0., 0.), vec3(0.0, 01.0, 0.0));\n float aspect = resolution.y / resolution.x;\n \n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n //gl_Position.x*=aspect;\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-h91ug6r1b0rmu2o6h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qcTbvPRuZkj3tL2jB/art.json b/art/qcTbvPRuZkj3tL2jB/art.json index f9819ee1..c6f1bc40 100644 --- a/art/qcTbvPRuZkj3tL2jB/art.json +++ b/art/qcTbvPRuZkj3tL2jB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "ray7551", "avatarUrl": "https://avatars.githubusercontent.com/ray7551?s=200", - "settings": "{\"num\":839,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"precision highp float;\\nvoid main() {\\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\\n float gridWidth = resolution.x / xCount;\\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 100. / xCount; // if xCount > 100 then make pointSize smaller\\n \\n vec2 p = vec2(\\n mod(vertexId, xCount) * gridWidth,\\n floor(vertexId / xCount) * gridHeight\\n );\\n \\n gl_Position = vec4(\\n (p / resolution * 2. - vec2(1.)),\\n 0., 1.\\n ); \\n v_color = vec4(vec3(1., 1., 1.0), 1.); // for debugging grid\\n \\n \\n}\"}", + "settings": { + "num": 839, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "precision highp float;\nvoid main() {\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\n float gridWidth = resolution.x / xCount;\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\n \n gl_PointSize = 10.;\n gl_PointSize *= 100. / xCount; // if xCount > 100 then make pointSize smaller\n \n vec2 p = vec2(\n mod(vertexId, xCount) * gridWidth,\n floor(vertexId / xCount) * gridHeight\n );\n \n gl_Position = vec4(\n (p / resolution * 2. - vec2(1.)),\n 0., 1.\n ); \n v_color = vec4(vec3(1., 1., 1.0), 1.); // for debugging grid\n \n \n}" + }, "screenshotURL": "data/images/images-5gzp3hvwftvrhbwdx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qcXAqrGwABRk4ge5N/art.json b/art/qcXAqrGwABRk4ge5N/art.json index 2f1fb6fa..88f6d8bb 100644 --- a/art/qcXAqrGwABRk4ge5N/art.json +++ b/art/qcXAqrGwABRk4ge5N/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Silly Shadertoy adapter \\n\\n// based on https://www.shadertoy.com/view/Msl3Rn\\n// chains and gears - @P_Malin\\n\\n// Shadertoy variables:\\n#define iResolution vec2(1024.0, 1024.0)\\n#define iGlobalTime time\\n\\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord );\\n\\n//#define RANDOM_POSITIONS\\n\\n#ifdef RANDOM_POSITIONS\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\n\\nvec2 hash21(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n\\tp3 += dot(p3, p3.yzx + 19.19);\\n\\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\\n}\\n\\n#endif // RANDOM_POSITIONS\\n\\nvoid main() \\n{ \\n\\tvec2 vDim = vec2( 160.0, 100.0 );\\n\\n\\tfloat fQuadIndex = floor(vertexId / 6.0);//\\n\\n\\tvec2 vUV;\\n\\n\\tvUV.x = mod( fQuadIndex, vDim.x );\\n\\tvUV.y = fQuadIndex / vDim.x;\\n\\n\\tvUV = vUV / vDim;\\n \\n#ifdef RANDOM_POSITIONS\\n \\tvUV = hash21( fQuadIndex );\\n#endif // RANDOM_POSITIONS \\n\\n\\tfloat triVert = mod( vertexId, 6.0 );\\n\\tfloat quadVert = mod( vertexId, 3.0 );\\n\\n\\tif( triVert >= 3.0 )\\n\\t{\\n quadVert = quadVert + 1.0;\\n\\t}\\n\\n\\tvec2 vSize = 1.0 / vDim;\\n\\tif( quadVert < 0.5 )\\n\\t{\\n vUV += vec2(0.0, 0.0);\\n\\t}\\n\\telse if( quadVert < 1.5 )\\n\\t{\\n vUV += vec2(vSize.x, 0.0);\\n\\t}\\n\\telse if( quadVert < 2.5 )\\n\\t{\\n vUV += vec2(0.0, vSize.y);\\n\\t}\\n\\telse if( quadVert < 3.5 )\\n\\t{\\n vUV += vec2(vSize.x, vSize.y);\\n\\t}\\n \\n\\tmainImage( v_color, vUV * iResolution );\\n\\n gl_Position = vec4(vUV * 2.0 - 1.0, 0, 1); \\n}\\n\\n// Pasted shadertoy code here\\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \\n\\n// Shadertoy adapter \\n\\n// based on https://www.shadertoy.com/view/Msl3Rn\\n// chains and gears - @P_Malin\\n\\n#define ENABLE_AMBIENT_OCCLUSION\\n#define ENABLE_SPECULAR\\n#define ENABLE_REFLECTIONS\\n#define ENABLE_SHADOWS\\n#define ENABLE_FOG\\n\\n//#define ENABLE_DIRECTIONAL_LIGHT\\n//#define ENABLE_DIRECTIONAL_LIGHT_FLARE\\n\\n#define ENABLE_POINT_LIGHT\\n//#define ENABLE_POINT_LIGHT_FLARE\\n\\n#define kRaymarchMaxIter 28\\n\\nconst float kPI = 3.141592654;\\nconst float kTwoPI = kPI * 2.0;\\n\\nstruct C_Ray\\n{\\n vec3 vOrigin;\\n vec3 vDir;\\n float fStartDistance;\\n float fLength;\\n};\\n\\nstruct C_HitInfo\\n{\\n vec3 vPos;\\n float fDistance;\\n vec3 vObjectId;\\n};\\n \\nstruct C_Surface\\n{\\n vec3 vNormal;\\n vec3 cReflection;\\n vec3 cTransmission; \\n};\\n\\nstruct C_Material\\n{\\n vec3 cAlbedo;\\n float fR0;\\n float fSmoothness;\\n vec2 vParam;\\n};\\n\\nstruct C_Shading\\n{\\n vec3 cDiffuse;\\n vec3 cSpecular;\\n};\\n\\nstruct C_PointLight\\n{\\n vec3 vPos;\\n vec3 cColour;\\n};\\n\\nstruct C_DirectionalLight\\n{\\n vec3 vDir;\\n vec3 cColour;\\n};\\n\\nvec3 RotateX( const in vec3 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec3 vResult = vec3( vPos.x, c * vPos.y + s * vPos.z, -s * vPos.y + c * vPos.z);\\n \\n return vResult;\\n}\\n\\nvec3 RotateY( const in vec3 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec3 vResult = vec3( c * vPos.x + s * vPos.z, vPos.y, -s * vPos.x + c * vPos.z);\\n \\n return vResult;\\n}\\n\\nvec3 RotateZ( const in vec3 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec3 vResult = vec3( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y, vPos.z);\\n \\n return vResult;\\n}\\n\\n/////////////////////////////////////\\n// Distance Field CSG\\n// These carry with them the material parameters in yzw\\n\\nvec4 DistCombineUnion( const in vec4 v1, const in vec4 v2 )\\n{\\n //if(v1.x < v2.x) return v1; else return v2;\\n return mix(v1, v2, step(v2.x, v1.x));\\n}\\n\\nvec4 DistCombineUnionConditional( const in vec4 v1, const in vec4 v2, const in float fCondition )\\n{ \\n\\t//if( fCondition < 0.0 )\\n\\t// return v1;\\n \\n return mix(v1, v2, step(v2.x, v1.x) * step(0.0, fCondition));\\n}\\n\\nvec4 DistCombineIntersect( const in vec4 v1, const in vec4 v2 )\\n{\\n return mix(v2, v1, step(v2.x,v1.x));\\n}\\n\\nvec4 DistCombineSubtract( const in vec4 v1, const in vec4 v2 )\\n{\\n return DistCombineIntersect(v1, vec4(-v2.x, v2.yzw));\\n}\\n\\nvec3 DomainRepeatXZGetTile( const in vec3 vPos, const in vec2 vRepeat, out vec2 vTile )\\n{\\n\\tvec3 vResult = vPos;\\n\\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\\n\\tvTile = floor(vTilePos + 1000.0);\\n\\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\\n\\treturn vResult;\\n}\\n\\nvec3 DomainRepeatXZ( const in vec3 vPos, const in vec2 vRepeat )\\n{\\n\\tvec3 vResult = vPos;\\n\\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\\n\\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\\n\\treturn vResult;\\n}\\n\\nvec3 DomainRepeatY( const in vec3 vPos, const in float fSize )\\n{\\n\\tvec3 vResult = vPos;\\n\\tvResult.y = (fract(vPos.y / fSize + 0.5) - 0.5) * fSize;\\n\\treturn vResult;\\n}\\n\\nvec3 DomainRotateSymmetry( const in vec3 vPos, const in float fSteps )\\n{\\n\\tfloat angle = atan( vPos.x, vPos.z );\\n\\t\\n\\tfloat fScale = fSteps / (kPI * 2.0);\\n\\tfloat steppedAngle = (floor(angle * fScale + 0.5)) / fScale;\\n\\t\\n\\tfloat s = sin(-steppedAngle);\\n\\tfloat c = cos(-steppedAngle);\\n\\t\\n\\tvec3 vResult = vec3( c * vPos.x + s * vPos.z, \\n\\t\\t\\t vPos.y,\\n\\t\\t\\t -s * vPos.x + c * vPos.z);\\n\\t\\n\\treturn vResult;\\n}\\n\\nfloat GetDistanceXYTorus( const in vec3 p, const in float r1, const in float r2 )\\n{\\n vec2 q = vec2(length(p.xy)-r1,p.z);\\n return length(q)-r2;\\n}\\n\\nfloat GetDistanceYZTorus( const in vec3 p, const in float r1, const in float r2 )\\n{\\n vec2 q = vec2(length(p.yz)-r1,p.x);\\n return length(q)-r2;\\n}\\n\\nfloat GetDistanceCylinderY(const in vec3 vPos, const in float r)\\n{\\n\\treturn length(vPos.xz) - r;\\n}\\n\\nfloat GetDistanceChain( const in vec3 vPos )\\n{\\n\\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\\n\\tif(fOuterCylinder > 0.5)\\n\\t{\\n\\t\\treturn fOuterCylinder;\\n\\t}\\n\\t\\n\\tvec3 vChainDomain = vPos;\\n\\t\\n\\tvChainDomain.y = fract(vChainDomain.y + 0.5) - 0.5;\\t\\t\\n\\tfloat fDistTorus1 = GetDistanceXYTorus(vChainDomain, 0.35, 0.1);\\n\\t\\n\\tvChainDomain.y = fract(vChainDomain.y + 1.0) - 0.5;\\t\\t\\n\\tfloat fDistTorus2 = GetDistanceYZTorus(vChainDomain, 0.35, 0.1);\\n\\t\\n\\tfloat fDist = min(fDistTorus1, fDistTorus2);\\n\\n\\treturn fDist;\\n}\\n\\nfloat GetDistanceGear( const in vec3 vPos )\\n{\\n\\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\\n\\tif(fOuterCylinder > 0.5)\\n\\t{\\n\\t\\treturn fOuterCylinder;\\n\\t}\\n\\t\\n\\tvec3 vToothDomain = DomainRotateSymmetry(vPos, 16.0);\\n\\tvToothDomain.xz = abs(vToothDomain.xz);\\n\\tfloat fGearDist = dot(vToothDomain.xz,normalize(vec2(1.0, 0.55))) - 0.55;\\n\\tfloat fSlabDist = abs(vPos.y + 0.1) - 0.15;\\n\\t\\n\\tvec3 vHoleDomain = abs(vPos);\\n\\tvHoleDomain -= 0.35;\\n\\tfloat fHoleDist = length(vHoleDomain.xz) - 0.2;\\n\\t\\n\\tfloat fBarDist =vToothDomain.z - 0.15;\\n\\tfBarDist = max(vPos.y - 0.1, fBarDist);\\n\\t\\n\\tfloat fResult = fGearDist;\\n\\tfResult = max(fResult, fSlabDist);\\n\\tfResult = max(fResult, fOuterCylinder);\\n\\tfResult = max(fResult, -fHoleDist);\\n\\tfResult = min(fResult, fBarDist);\\n\\treturn fResult;\\n}\\n\\nvec4 GetDistanceScene( const in vec3 vPos )\\n{ \\t\\n\\tvec2 vChainTile;\\n\\tvec2 vRepeat = vec2(4.0, 8.0);\\n\\tvec3 vRepeatDomain = DomainRepeatXZGetTile(vPos, vRepeat, vChainTile);\\n\\t\\t\\n\\tvec4 vDistFloor = vec4(vPos.y + 0.5, 1.0, vec2(0.0));\\n\\tvec4 vResult = vDistFloor;\\n\\t{\\n\\t\\tvec3 vGearDomain1 = DomainRepeatXZ(vPos+vec3(0.0, 0.0, 4.0), vRepeat);\\n\\t\\tvGearDomain1 = RotateY( vGearDomain1, iGlobalTime);\\n\\t\\tvec4 vDistGear = vec4(GetDistanceGear(vGearDomain1), 3.0, vec2(0.0));\\n\\t\\tvResult = DistCombineUnion( vResult, vDistGear );\\n\\t\\t\\n\\t\\tvec3 vGearDomain2 = DomainRepeatXZ(vPos+vec3(2.0, 0.0, 4.0), vRepeat);\\n\\t\\tvGearDomain2 = RotateY( vGearDomain2, -iGlobalTime + (2.0 * kPI / 32.0));\\n\\t\\tvec4 vDistGear2 = vec4(GetDistanceGear(vGearDomain2), 3.0, vec2(0.0));\\t\\t\\n\\t\\tvResult = DistCombineUnion( vResult, vDistGear2 );\\n\\t\\t\\n\\t}\\n\\n\\t{\\n\\t\\tvec4 vDistChainHole = vec4( GetDistanceCylinderY(vRepeatDomain, 0.7), 2.0, vec2(0.0));\\n\\t\\tvResult = DistCombineSubtract( vResult, vDistChainHole );\\n\\n\\t\\tvec3 vChainDomain = vRepeatDomain;\\n\\t\\tfloat fSpeed = (sin(vChainTile.y + vChainTile.x) + 1.1) * 0.5;\\n\\t\\tvChainDomain.y += sin(iGlobalTime * fSpeed);\\n\\t\\tvec4 vDistChain = vec4( GetDistanceChain(vChainDomain), 4.0, vec2(0.0));\\n\\t\\tvResult = DistCombineUnion( vResult, vDistChain );\\n\\t}\\n\\treturn vResult;\\n}\\n\\nC_Material GetObjectMaterial( const in C_HitInfo hitInfo )\\n{\\n\\tC_Material mat;\\n\\n\\tif(hitInfo.vObjectId.x < 1.5)\\n\\t{\\n\\t\\t// floor\\n\\t\\tmat.fR0 = 0.02;\\n\\t\\tmat.fSmoothness = 0.8;\\n\\t\\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\\n\\t}\\n\\telse\\n\\tif(hitInfo.vObjectId.x < 2.5)\\n\\t{\\n\\t\\t// hole interior\\n\\t\\tmat.fR0 = 0.0;\\n\\t\\tmat.fSmoothness = 0.0;\\n\\t\\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\\n\\t}\\n\\telse\\n\\tif(hitInfo.vObjectId.x < 3.5)\\n\\t{\\n\\t\\t// gear\\n\\t\\tmat.fR0 = 0.4;\\n\\t\\tmat.fSmoothness = 0.7;\\n\\t\\tmat.cAlbedo = vec3(0.5, 0.6, 0.6);\\n\\t}\\n\\telse\\n\\t{\\n\\t\\t// chain\\n\\t\\tmat.fR0 = 0.2;\\n\\t\\tmat.fSmoothness = 0.1;\\n\\t\\tmat.cAlbedo = vec3(0.15, 0.125, 0.1);\\n\\t}\\n\\t\\n\\treturn mat;\\n}\\n\\nfloat GetRayFirstStep( const in C_Ray ray )\\n{\\n return ray.fStartDistance; \\n}\\n\\n\\nvec3 GetSkyGradient( const in vec3 vDir )\\n{\\n const vec3 cColourTop = vec3(0.7, 0.9, 1.0);\\n const vec3 cColourHorizon = vec3(0.2, 0.3, 0.4);\\n\\n float fBlend = clamp(vDir.y, 0.0, 1.0);\\n return mix(cColourHorizon, cColourTop, fBlend);\\n}\\n\\nC_PointLight GetPointLight()\\n{\\n C_PointLight result;\\n\\n result.vPos = vec3(sin(iGlobalTime), 2.0 + cos(iGlobalTime * 1.231), cos(iGlobalTime));\\n result.cColour = vec3(32.0, 6.0, 1.0);\\n\\n return result;\\n}\\n\\nC_DirectionalLight GetDirectionalLight()\\n{\\n C_DirectionalLight result;\\n\\n result.vDir = normalize(vec3(-0.2, -0.3, 0.5));\\n result.cColour = vec3(8.0, 7.5, 7.0);\\n\\n return result;\\n}\\n\\nvec3 GetAmbientLight(const in vec3 vNormal)\\n{\\n return GetSkyGradient(vNormal);\\n}\\n\\n/////////////////////////////////////\\n// Raymarching \\n\\nvec3 GetSceneNormal( const in vec3 vPos )\\n{\\n // tetrahedron normal\\n const float fDelta = 0.01;\\n\\n vec3 vOffset1 = vec3( fDelta, -fDelta, -fDelta);\\n vec3 vOffset2 = vec3(-fDelta, -fDelta, fDelta);\\n vec3 vOffset3 = vec3(-fDelta, fDelta, -fDelta);\\n vec3 vOffset4 = vec3( fDelta, fDelta, fDelta);\\n\\n float f1 = GetDistanceScene( vPos + vOffset1 ).x;\\n float f2 = GetDistanceScene( vPos + vOffset2 ).x;\\n float f3 = GetDistanceScene( vPos + vOffset3 ).x;\\n float f4 = GetDistanceScene( vPos + vOffset4 ).x;\\n\\n vec3 vNormal = vOffset1 * f1 + vOffset2 * f2 + vOffset3 * f3 + vOffset4 * f4;\\n\\n return normalize( vNormal );\\n}\\n\\n#define kRaymarchEpsilon 0.01\\n// This is an excellent resource on ray marching -> http://www.iquilezles.org/www/articles/distfunctions/distfunctions.htm\\nvoid Raymarch( const in C_Ray ray, out C_HitInfo result, const int maxIter )\\n{ \\n result.fDistance = GetRayFirstStep( ray );\\n result.vObjectId.x = 0.0;\\n \\n for(int i=0;i<=kRaymarchMaxIter;i++) \\n {\\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\\n vec4 vSceneDist = GetDistanceScene( result.vPos );\\n result.vObjectId = vSceneDist.yzw;\\n \\n // abs allows backward stepping - should only be necessary for non uniform distance functions\\n if((abs(vSceneDist.x) <= kRaymarchEpsilon) || (result.fDistance >= ray.fLength) || (i > maxIter))\\n {\\n break;\\n } \\n\\n result.fDistance = result.fDistance + vSceneDist.x; \\n }\\n\\n\\n if(result.fDistance >= ray.fLength)\\n {\\n result.fDistance = 1000.0;\\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\\n result.vObjectId.x = 0.0;\\n }\\n}\\n\\nfloat GetShadow( const in vec3 vPos, const in vec3 vNormal, const in vec3 vLightDir, const in float fLightDistance )\\n{\\n #ifdef ENABLE_SHADOWS\\n\\t\\tC_Ray shadowRay;\\n\\t\\tshadowRay.vDir = vLightDir;\\n\\t\\tshadowRay.vOrigin = vPos;\\n\\t\\tconst float fShadowBias = 0.05;\\n\\t\\tshadowRay.fStartDistance = fShadowBias / abs(dot(vLightDir, vNormal));\\n\\t\\tshadowRay.fLength = fLightDistance - shadowRay.fStartDistance;\\n\\t\\n\\t\\tC_HitInfo shadowIntersect;\\n\\t\\tRaymarch(shadowRay, shadowIntersect, 32);\\n\\t\\t\\n\\t\\tfloat fShadow = step(0.0, shadowIntersect.fDistance) * step(fLightDistance, shadowIntersect.fDistance );\\n\\t\\t\\n\\t\\treturn fShadow; \\n #else\\n \\treturn 1.0;\\n #endif\\n}\\n\\n// use distance field to evaluate ambient occlusion\\nfloat GetAmbientOcclusion(const in C_HitInfo intersection, const in C_Surface surface)\\n{\\n #ifdef ENABLE_AMBIENT_OCCLUSION \\n\\t\\tvec3 vPos = intersection.vPos;\\n\\t\\tvec3 vNormal = surface.vNormal;\\n\\t\\n\\t\\tfloat fAmbientOcclusion = 1.0;\\n\\t\\n\\t\\tfloat fDist = 0.0;\\n\\t\\tfor(int i=0; i<=5; i++)\\n\\t\\t{\\n\\t\\t\\tfDist += 0.1;\\n\\t\\n\\t\\t\\tvec4 vSceneDist = GetDistanceScene(vPos + vNormal * fDist);\\n\\t\\n\\t\\t\\tfAmbientOcclusion *= 1.0 - max(0.0, (fDist - vSceneDist.x) * 0.2 / fDist ); \\n\\t\\t}\\n\\t\\n\\t\\treturn fAmbientOcclusion;\\n #else\\n\\t return 1.0;\\n #endif \\n}\\n\\n/////////////////////////////////////\\n// Lighting and Shading\\n\\n#define kFogDensity 0.1\\n\\nvoid ApplyAtmosphere(inout vec3 col, const in C_Ray ray, const in C_HitInfo hitInfo)\\n{\\n #ifdef ENABLE_FOG\\n // fog\\n float fFogAmount = exp(hitInfo.fDistance * -kFogDensity);\\n vec3 cFog = GetSkyGradient(ray.vDir);\\n\\n #ifdef ENABLE_DIRECTIONAL_LIGHT_FLARE\\n C_DirectionalLight directionalLight = GetDirectionalLight();\\n float fDirDot = clamp(dot(-directionalLight.vDir, ray.vDir), 0.0, 1.0);\\n cFog += directionalLight.cColour * pow(fDirDot, 10.0);\\n #endif \\n\\n col = mix(cFog, col, fFogAmount);\\n #endif\\n\\n // glare from light (a bit hacky - use length of closest approach from ray to light)\\n #ifdef ENABLE_POINT_LIGHT_FLARE\\n C_PointLight pointLight = GetPointLight();\\n\\n vec3 vToLight = pointLight.vPos - ray.vOrigin;\\n float fPointDot = dot(vToLight, ray.vDir);\\n fPointDot = clamp(fPointDot, 0.0, hitInfo.fDistance);\\n\\n vec3 vClosestPoint = ray.vOrigin + ray.vDir * fPointDot;\\n float fDist = length(vClosestPoint - pointLight.vPos);\\n col += pointLight.cColour * 0.01/ (fDist * fDist);\\n #endif \\n}\\n\\n// http://en.wikipedia.org/wiki/Schlick's_approximation\\nfloat Schlick( const in vec3 vNormal, const in vec3 vView, const in float fR0, const in float fSmoothFactor)\\n{\\n float fDot = dot(vNormal, -vView);\\n fDot = clamp((1.0 - fDot), 0.0, 1.0);\\n float fDotPow = pow(fDot, 5.0);\\n return fR0 + (1.0 - fR0) * fDotPow * fSmoothFactor;\\n}\\n\\nvec3 ApplyFresnel(const in vec3 vDiffuse, const in vec3 vSpecular, const in vec3 vNormal, const in vec3 vView, const in C_Material material)\\n{\\n float fFresnel = Schlick(vNormal, vView, material.fR0, material.fSmoothness * 0.9 + 0.1);\\n return mix(vDiffuse, vSpecular, fFresnel); \\n}\\n\\nfloat GetBlinnPhongIntensity(const in vec3 vIncidentDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness)\\n{ \\n vec3 vHalf = normalize(vLightDir - vIncidentDir);\\n float fNdotH = max(0.0, dot(vHalf, vNormal));\\n\\n float fSpecPower = exp2(4.0 + 6.0 * fSmoothness);\\n float fSpecIntensity = (fSpecPower + 2.0) * 0.125;\\n\\n return pow(fNdotH, fSpecPower) * fSpecIntensity;\\n}\\n\\nC_Shading ApplyPointLight( const in C_PointLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\\n{\\n C_Shading shading;\\n \\n vec3 vToLight = light.vPos - vSurfacePos;\\n vec3 vLightDir = normalize(vToLight);\\n float fLightDistance = length(vToLight);\\n \\n float fAttenuation = 1.0 / (fLightDistance * fLightDistance);\\n \\n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, fLightDistance );\\n vec3 vIncidentLight = light.cColour * fShadowFactor * fAttenuation * max(0.0, dot(vLightDir, vNormal));\\n \\n shading.cDiffuse = vIncidentLight; \\n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\\n \\n return shading;\\n} \\n\\nC_Shading ApplyDirectionalLight( const in C_DirectionalLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\\n{\\n C_Shading shading;\\n\\n const float kShadowRayLength = 10.0; \\n vec3 vLightDir = -light.vDir;\\n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, kShadowRayLength );\\n vec3 vIncidentLight = light.cColour * fShadowFactor * max(0.0, dot(vLightDir, vNormal));\\n \\n shading.cDiffuse = vIncidentLight; \\n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\\n \\n return shading;\\n} \\n\\n\\nvec3 ShadeSurface(const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface, const in C_Material material)\\n{\\n vec3 cScene;\\n \\n C_Shading shading;\\n\\n shading.cDiffuse = vec3(0.0);\\n shading.cSpecular = vec3(0.0);\\n \\n float fAmbientOcclusion = GetAmbientOcclusion(hitInfo, surface);\\n vec3 vAmbientLight = GetAmbientLight(surface.vNormal) * fAmbientOcclusion;\\n \\n shading.cDiffuse += vAmbientLight;\\n shading.cSpecular += surface.cReflection;\\n \\n #ifdef ENABLE_POINT_LIGHT\\n C_PointLight pointLight = GetPointLight(); \\n C_Shading pointLighting = ApplyPointLight(pointLight, hitInfo.vPos,ray.vDir, surface.vNormal, material);\\n shading.cDiffuse += pointLighting.cDiffuse;\\n shading.cSpecular += pointLighting.cSpecular;\\n #endif\\n\\n #ifdef ENABLE_DIRECTIONAL_LIGHT\\n\\tC_DirectionalLight directionalLight = GetDirectionalLight();\\n C_Shading directionLighting = ApplyDirectionalLight(directionalLight, hitInfo.vPos, ray.vDir, surface.vNormal, material);\\n shading.cDiffuse += directionLighting.cDiffuse;\\n shading.cSpecular += directionLighting.cSpecular;\\n #endif\\n\\t\\n\\t// fire in the hole\\n\\tshading.cDiffuse += clamp(-hitInfo.vPos.y - 0.5, 0.0, 1.0) * vec3(5.0, 0.25, 0.05);\\n\\n vec3 vDiffuseReflection = shading.cDiffuse * material.cAlbedo; \\n\\n #ifdef ENABLE_SPECULAR\\n cScene = ApplyFresnel(vDiffuseReflection , shading.cSpecular, surface.vNormal, ray.vDir, material);\\n #else\\n cScene = vDiffuseReflection;\\n #endif\\n \\n return cScene;\\n}\\n\\nvec3 GetSceneColourSecondary( const in C_Ray ray );\\n\\nvec3 GetReflection( const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface )\\n{\\n #ifdef ENABLE_REFLECTIONS \\n {\\n // get colour from reflected ray\\n const float fSeparation = 0.1;\\n\\n C_Ray reflectRay;\\n reflectRay.vDir = reflect(ray.vDir, surface.vNormal);\\n reflectRay.vOrigin = hitInfo.vPos;\\n reflectRay.fLength = 16.0;\\n reflectRay.fStartDistance = fSeparation / abs(dot(reflectRay.vDir, surface.vNormal));\\n \\n return GetSceneColourSecondary(reflectRay); \\n }\\n #else\\n return GetSkyGradient(reflect(ray.vDir, surface.vNormal)); \\n #endif\\n}\\n\\n// no reflections, no transparency, used for secondary rays\\nvec3 GetSceneColourSecondary( const in C_Ray ray )\\n{\\n C_HitInfo hitInfo;\\n Raymarch(ray, hitInfo, 32);\\n \\n vec3 cScene;\\n\\n if(hitInfo.vObjectId.x < 0.5)\\n {\\n cScene = GetSkyGradient(ray.vDir);\\n }\\n else\\n {\\n C_Surface surface; \\n surface.vNormal = GetSceneNormal(hitInfo.vPos);\\n\\n C_Material material = GetObjectMaterial(hitInfo);\\n\\n // use sky gradient instead of reflection\\n surface.cReflection = GetSkyGradient(reflect(ray.vDir, surface.vNormal));\\n\\n // apply lighting\\n cScene = ShadeSurface(ray, hitInfo, surface, material);\\n }\\n\\n ApplyAtmosphere(cScene, ray, hitInfo);\\n\\n return cScene;\\n}\\n\\nvec3 GetSceneColourPrimary( const in C_Ray ray )\\n{ \\n C_HitInfo intersection;\\n Raymarch(ray, intersection, 256);\\n \\n vec3 cScene;\\n\\n if(intersection.vObjectId.x < 0.5)\\n {\\n cScene = GetSkyGradient(ray.vDir);\\n }\\n else\\n {\\n C_Surface surface;\\n \\n surface.vNormal = GetSceneNormal(intersection.vPos);\\n\\n C_Material material = GetObjectMaterial(intersection);\\n\\n surface.cReflection = GetReflection(ray, intersection, surface);\\n\\n // apply lighting\\n cScene = ShadeSurface(ray, intersection, surface, material);\\n }\\n\\n ApplyAtmosphere(cScene, ray, intersection);\\n\\n return cScene;\\n}\\n\\nfloat kFarClip = 30.0;\\n\\nvoid GetCameraRay( const in vec3 vPos, const in vec3 vForwards, const in vec3 vWorldUp, const in vec2 fragCoord, out C_Ray ray)\\n{\\n vec2 vUV = ( fragCoord.xy / iResolution.xy );\\n vec2 vViewCoord = vUV * 2.0 - 1.0;\\n\\n float fRatio = iResolution.x / iResolution.y;\\n vViewCoord.y /= fRatio; \\n\\n ray.vOrigin = vPos;\\n\\n vec3 vRight = normalize(cross(vForwards, vWorldUp));\\n vec3 vUp = cross(vRight, vForwards);\\n \\n ray.vDir = normalize( vRight * vViewCoord.x + vUp * vViewCoord.y + vForwards); \\n ray.fStartDistance = 0.0;\\n ray.fLength = kFarClip; \\n}\\n\\nvoid GetCameraRayLookat( const in vec3 vPos, const in vec3 vInterest, const in vec2 fragCoord, out C_Ray ray)\\n{\\n vec3 vForwards = normalize(vInterest - vPos);\\n vec3 vUp = vec3(0.0, 1.0, 0.0);\\n\\n GetCameraRay(vPos, vForwards, vUp, fragCoord, ray);\\n}\\n\\nvec3 OrbitPoint( const in float fHeading, const in float fElevation )\\n{\\n return vec3(sin(fHeading) * cos(fElevation), sin(fElevation), cos(fHeading) * cos(fElevation));\\n}\\n\\nvec3 Gamma( const in vec3 cCol )\\n{\\n return sqrt(cCol);\\n}\\n\\nvec3 Tonemap( const in vec3 cCol )\\n{\\n vec3 vResult = 1.0 - exp2(-cCol);\\n\\n return vResult;\\n}\\n\\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord )\\n{\\n C_Ray ray;\\n\\n \\tGetCameraRayLookat( OrbitPoint(iGlobalTime * 0.3, cos(iGlobalTime * 0.2) * 0.3 + 0.4) * 7.0, vec3(0.0, 0.0, 0.0), fragCoord, ray);\\n\\n vec3 cScene = GetSceneColourPrimary( ray ); \\n\\n const float fExposure = 1.5; \\n fragColor = vec4( Tonemap(cScene * fExposure), 1.0 );\\n}\\n\\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \\n// End pasted shadertoy code\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Silly Shadertoy adapter \n\n// based on https://www.shadertoy.com/view/Msl3Rn\n// chains and gears - @P_Malin\n\n// Shadertoy variables:\n#define iResolution vec2(1024.0, 1024.0)\n#define iGlobalTime time\n\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord );\n\n//#define RANDOM_POSITIONS\n\n#ifdef RANDOM_POSITIONS\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\n\nvec2 hash21(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n\tp3 += dot(p3, p3.yzx + 19.19);\n\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\n}\n\n#endif // RANDOM_POSITIONS\n\nvoid main() \n{ \n\tvec2 vDim = vec2( 160.0, 100.0 );\n\n\tfloat fQuadIndex = floor(vertexId / 6.0);//\n\n\tvec2 vUV;\n\n\tvUV.x = mod( fQuadIndex, vDim.x );\n\tvUV.y = fQuadIndex / vDim.x;\n\n\tvUV = vUV / vDim;\n \n#ifdef RANDOM_POSITIONS\n \tvUV = hash21( fQuadIndex );\n#endif // RANDOM_POSITIONS \n\n\tfloat triVert = mod( vertexId, 6.0 );\n\tfloat quadVert = mod( vertexId, 3.0 );\n\n\tif( triVert >= 3.0 )\n\t{\n quadVert = quadVert + 1.0;\n\t}\n\n\tvec2 vSize = 1.0 / vDim;\n\tif( quadVert < 0.5 )\n\t{\n vUV += vec2(0.0, 0.0);\n\t}\n\telse if( quadVert < 1.5 )\n\t{\n vUV += vec2(vSize.x, 0.0);\n\t}\n\telse if( quadVert < 2.5 )\n\t{\n vUV += vec2(0.0, vSize.y);\n\t}\n\telse if( quadVert < 3.5 )\n\t{\n vUV += vec2(vSize.x, vSize.y);\n\t}\n \n\tmainImage( v_color, vUV * iResolution );\n\n gl_Position = vec4(vUV * 2.0 - 1.0, 0, 1); \n}\n\n// Pasted shadertoy code here\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \n\n// Shadertoy adapter \n\n// based on https://www.shadertoy.com/view/Msl3Rn\n// chains and gears - @P_Malin\n\n#define ENABLE_AMBIENT_OCCLUSION\n#define ENABLE_SPECULAR\n#define ENABLE_REFLECTIONS\n#define ENABLE_SHADOWS\n#define ENABLE_FOG\n\n//#define ENABLE_DIRECTIONAL_LIGHT\n//#define ENABLE_DIRECTIONAL_LIGHT_FLARE\n\n#define ENABLE_POINT_LIGHT\n//#define ENABLE_POINT_LIGHT_FLARE\n\n#define kRaymarchMaxIter 28\n\nconst float kPI = 3.141592654;\nconst float kTwoPI = kPI * 2.0;\n\nstruct C_Ray\n{\n vec3 vOrigin;\n vec3 vDir;\n float fStartDistance;\n float fLength;\n};\n\nstruct C_HitInfo\n{\n vec3 vPos;\n float fDistance;\n vec3 vObjectId;\n};\n \nstruct C_Surface\n{\n vec3 vNormal;\n vec3 cReflection;\n vec3 cTransmission; \n};\n\nstruct C_Material\n{\n vec3 cAlbedo;\n float fR0;\n float fSmoothness;\n vec2 vParam;\n};\n\nstruct C_Shading\n{\n vec3 cDiffuse;\n vec3 cSpecular;\n};\n\nstruct C_PointLight\n{\n vec3 vPos;\n vec3 cColour;\n};\n\nstruct C_DirectionalLight\n{\n vec3 vDir;\n vec3 cColour;\n};\n\nvec3 RotateX( const in vec3 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec3 vResult = vec3( vPos.x, c * vPos.y + s * vPos.z, -s * vPos.y + c * vPos.z);\n \n return vResult;\n}\n\nvec3 RotateY( const in vec3 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec3 vResult = vec3( c * vPos.x + s * vPos.z, vPos.y, -s * vPos.x + c * vPos.z);\n \n return vResult;\n}\n\nvec3 RotateZ( const in vec3 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec3 vResult = vec3( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y, vPos.z);\n \n return vResult;\n}\n\n/////////////////////////////////////\n// Distance Field CSG\n// These carry with them the material parameters in yzw\n\nvec4 DistCombineUnion( const in vec4 v1, const in vec4 v2 )\n{\n //if(v1.x < v2.x) return v1; else return v2;\n return mix(v1, v2, step(v2.x, v1.x));\n}\n\nvec4 DistCombineUnionConditional( const in vec4 v1, const in vec4 v2, const in float fCondition )\n{ \n\t//if( fCondition < 0.0 )\n\t// return v1;\n \n return mix(v1, v2, step(v2.x, v1.x) * step(0.0, fCondition));\n}\n\nvec4 DistCombineIntersect( const in vec4 v1, const in vec4 v2 )\n{\n return mix(v2, v1, step(v2.x,v1.x));\n}\n\nvec4 DistCombineSubtract( const in vec4 v1, const in vec4 v2 )\n{\n return DistCombineIntersect(v1, vec4(-v2.x, v2.yzw));\n}\n\nvec3 DomainRepeatXZGetTile( const in vec3 vPos, const in vec2 vRepeat, out vec2 vTile )\n{\n\tvec3 vResult = vPos;\n\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\n\tvTile = floor(vTilePos + 1000.0);\n\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\n\treturn vResult;\n}\n\nvec3 DomainRepeatXZ( const in vec3 vPos, const in vec2 vRepeat )\n{\n\tvec3 vResult = vPos;\n\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\n\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\n\treturn vResult;\n}\n\nvec3 DomainRepeatY( const in vec3 vPos, const in float fSize )\n{\n\tvec3 vResult = vPos;\n\tvResult.y = (fract(vPos.y / fSize + 0.5) - 0.5) * fSize;\n\treturn vResult;\n}\n\nvec3 DomainRotateSymmetry( const in vec3 vPos, const in float fSteps )\n{\n\tfloat angle = atan( vPos.x, vPos.z );\n\t\n\tfloat fScale = fSteps / (kPI * 2.0);\n\tfloat steppedAngle = (floor(angle * fScale + 0.5)) / fScale;\n\t\n\tfloat s = sin(-steppedAngle);\n\tfloat c = cos(-steppedAngle);\n\t\n\tvec3 vResult = vec3( c * vPos.x + s * vPos.z, \n\t\t\t vPos.y,\n\t\t\t -s * vPos.x + c * vPos.z);\n\t\n\treturn vResult;\n}\n\nfloat GetDistanceXYTorus( const in vec3 p, const in float r1, const in float r2 )\n{\n vec2 q = vec2(length(p.xy)-r1,p.z);\n return length(q)-r2;\n}\n\nfloat GetDistanceYZTorus( const in vec3 p, const in float r1, const in float r2 )\n{\n vec2 q = vec2(length(p.yz)-r1,p.x);\n return length(q)-r2;\n}\n\nfloat GetDistanceCylinderY(const in vec3 vPos, const in float r)\n{\n\treturn length(vPos.xz) - r;\n}\n\nfloat GetDistanceChain( const in vec3 vPos )\n{\n\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\n\tif(fOuterCylinder > 0.5)\n\t{\n\t\treturn fOuterCylinder;\n\t}\n\t\n\tvec3 vChainDomain = vPos;\n\t\n\tvChainDomain.y = fract(vChainDomain.y + 0.5) - 0.5;\t\t\n\tfloat fDistTorus1 = GetDistanceXYTorus(vChainDomain, 0.35, 0.1);\n\t\n\tvChainDomain.y = fract(vChainDomain.y + 1.0) - 0.5;\t\t\n\tfloat fDistTorus2 = GetDistanceYZTorus(vChainDomain, 0.35, 0.1);\n\t\n\tfloat fDist = min(fDistTorus1, fDistTorus2);\n\n\treturn fDist;\n}\n\nfloat GetDistanceGear( const in vec3 vPos )\n{\n\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\n\tif(fOuterCylinder > 0.5)\n\t{\n\t\treturn fOuterCylinder;\n\t}\n\t\n\tvec3 vToothDomain = DomainRotateSymmetry(vPos, 16.0);\n\tvToothDomain.xz = abs(vToothDomain.xz);\n\tfloat fGearDist = dot(vToothDomain.xz,normalize(vec2(1.0, 0.55))) - 0.55;\n\tfloat fSlabDist = abs(vPos.y + 0.1) - 0.15;\n\t\n\tvec3 vHoleDomain = abs(vPos);\n\tvHoleDomain -= 0.35;\n\tfloat fHoleDist = length(vHoleDomain.xz) - 0.2;\n\t\n\tfloat fBarDist =vToothDomain.z - 0.15;\n\tfBarDist = max(vPos.y - 0.1, fBarDist);\n\t\n\tfloat fResult = fGearDist;\n\tfResult = max(fResult, fSlabDist);\n\tfResult = max(fResult, fOuterCylinder);\n\tfResult = max(fResult, -fHoleDist);\n\tfResult = min(fResult, fBarDist);\n\treturn fResult;\n}\n\nvec4 GetDistanceScene( const in vec3 vPos )\n{ \t\n\tvec2 vChainTile;\n\tvec2 vRepeat = vec2(4.0, 8.0);\n\tvec3 vRepeatDomain = DomainRepeatXZGetTile(vPos, vRepeat, vChainTile);\n\t\t\n\tvec4 vDistFloor = vec4(vPos.y + 0.5, 1.0, vec2(0.0));\n\tvec4 vResult = vDistFloor;\n\t{\n\t\tvec3 vGearDomain1 = DomainRepeatXZ(vPos+vec3(0.0, 0.0, 4.0), vRepeat);\n\t\tvGearDomain1 = RotateY( vGearDomain1, iGlobalTime);\n\t\tvec4 vDistGear = vec4(GetDistanceGear(vGearDomain1), 3.0, vec2(0.0));\n\t\tvResult = DistCombineUnion( vResult, vDistGear );\n\t\t\n\t\tvec3 vGearDomain2 = DomainRepeatXZ(vPos+vec3(2.0, 0.0, 4.0), vRepeat);\n\t\tvGearDomain2 = RotateY( vGearDomain2, -iGlobalTime + (2.0 * kPI / 32.0));\n\t\tvec4 vDistGear2 = vec4(GetDistanceGear(vGearDomain2), 3.0, vec2(0.0));\t\t\n\t\tvResult = DistCombineUnion( vResult, vDistGear2 );\n\t\t\n\t}\n\n\t{\n\t\tvec4 vDistChainHole = vec4( GetDistanceCylinderY(vRepeatDomain, 0.7), 2.0, vec2(0.0));\n\t\tvResult = DistCombineSubtract( vResult, vDistChainHole );\n\n\t\tvec3 vChainDomain = vRepeatDomain;\n\t\tfloat fSpeed = (sin(vChainTile.y + vChainTile.x) + 1.1) * 0.5;\n\t\tvChainDomain.y += sin(iGlobalTime * fSpeed);\n\t\tvec4 vDistChain = vec4( GetDistanceChain(vChainDomain), 4.0, vec2(0.0));\n\t\tvResult = DistCombineUnion( vResult, vDistChain );\n\t}\n\treturn vResult;\n}\n\nC_Material GetObjectMaterial( const in C_HitInfo hitInfo )\n{\n\tC_Material mat;\n\n\tif(hitInfo.vObjectId.x < 1.5)\n\t{\n\t\t// floor\n\t\tmat.fR0 = 0.02;\n\t\tmat.fSmoothness = 0.8;\n\t\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\n\t}\n\telse\n\tif(hitInfo.vObjectId.x < 2.5)\n\t{\n\t\t// hole interior\n\t\tmat.fR0 = 0.0;\n\t\tmat.fSmoothness = 0.0;\n\t\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\n\t}\n\telse\n\tif(hitInfo.vObjectId.x < 3.5)\n\t{\n\t\t// gear\n\t\tmat.fR0 = 0.4;\n\t\tmat.fSmoothness = 0.7;\n\t\tmat.cAlbedo = vec3(0.5, 0.6, 0.6);\n\t}\n\telse\n\t{\n\t\t// chain\n\t\tmat.fR0 = 0.2;\n\t\tmat.fSmoothness = 0.1;\n\t\tmat.cAlbedo = vec3(0.15, 0.125, 0.1);\n\t}\n\t\n\treturn mat;\n}\n\nfloat GetRayFirstStep( const in C_Ray ray )\n{\n return ray.fStartDistance; \n}\n\n\nvec3 GetSkyGradient( const in vec3 vDir )\n{\n const vec3 cColourTop = vec3(0.7, 0.9, 1.0);\n const vec3 cColourHorizon = vec3(0.2, 0.3, 0.4);\n\n float fBlend = clamp(vDir.y, 0.0, 1.0);\n return mix(cColourHorizon, cColourTop, fBlend);\n}\n\nC_PointLight GetPointLight()\n{\n C_PointLight result;\n\n result.vPos = vec3(sin(iGlobalTime), 2.0 + cos(iGlobalTime * 1.231), cos(iGlobalTime));\n result.cColour = vec3(32.0, 6.0, 1.0);\n\n return result;\n}\n\nC_DirectionalLight GetDirectionalLight()\n{\n C_DirectionalLight result;\n\n result.vDir = normalize(vec3(-0.2, -0.3, 0.5));\n result.cColour = vec3(8.0, 7.5, 7.0);\n\n return result;\n}\n\nvec3 GetAmbientLight(const in vec3 vNormal)\n{\n return GetSkyGradient(vNormal);\n}\n\n/////////////////////////////////////\n// Raymarching \n\nvec3 GetSceneNormal( const in vec3 vPos )\n{\n // tetrahedron normal\n const float fDelta = 0.01;\n\n vec3 vOffset1 = vec3( fDelta, -fDelta, -fDelta);\n vec3 vOffset2 = vec3(-fDelta, -fDelta, fDelta);\n vec3 vOffset3 = vec3(-fDelta, fDelta, -fDelta);\n vec3 vOffset4 = vec3( fDelta, fDelta, fDelta);\n\n float f1 = GetDistanceScene( vPos + vOffset1 ).x;\n float f2 = GetDistanceScene( vPos + vOffset2 ).x;\n float f3 = GetDistanceScene( vPos + vOffset3 ).x;\n float f4 = GetDistanceScene( vPos + vOffset4 ).x;\n\n vec3 vNormal = vOffset1 * f1 + vOffset2 * f2 + vOffset3 * f3 + vOffset4 * f4;\n\n return normalize( vNormal );\n}\n\n#define kRaymarchEpsilon 0.01\n// This is an excellent resource on ray marching -> http://www.iquilezles.org/www/articles/distfunctions/distfunctions.htm\nvoid Raymarch( const in C_Ray ray, out C_HitInfo result, const int maxIter )\n{ \n result.fDistance = GetRayFirstStep( ray );\n result.vObjectId.x = 0.0;\n \n for(int i=0;i<=kRaymarchMaxIter;i++) \n {\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\n vec4 vSceneDist = GetDistanceScene( result.vPos );\n result.vObjectId = vSceneDist.yzw;\n \n // abs allows backward stepping - should only be necessary for non uniform distance functions\n if((abs(vSceneDist.x) <= kRaymarchEpsilon) || (result.fDistance >= ray.fLength) || (i > maxIter))\n {\n break;\n } \n\n result.fDistance = result.fDistance + vSceneDist.x; \n }\n\n\n if(result.fDistance >= ray.fLength)\n {\n result.fDistance = 1000.0;\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\n result.vObjectId.x = 0.0;\n }\n}\n\nfloat GetShadow( const in vec3 vPos, const in vec3 vNormal, const in vec3 vLightDir, const in float fLightDistance )\n{\n #ifdef ENABLE_SHADOWS\n\t\tC_Ray shadowRay;\n\t\tshadowRay.vDir = vLightDir;\n\t\tshadowRay.vOrigin = vPos;\n\t\tconst float fShadowBias = 0.05;\n\t\tshadowRay.fStartDistance = fShadowBias / abs(dot(vLightDir, vNormal));\n\t\tshadowRay.fLength = fLightDistance - shadowRay.fStartDistance;\n\t\n\t\tC_HitInfo shadowIntersect;\n\t\tRaymarch(shadowRay, shadowIntersect, 32);\n\t\t\n\t\tfloat fShadow = step(0.0, shadowIntersect.fDistance) * step(fLightDistance, shadowIntersect.fDistance );\n\t\t\n\t\treturn fShadow; \n #else\n \treturn 1.0;\n #endif\n}\n\n// use distance field to evaluate ambient occlusion\nfloat GetAmbientOcclusion(const in C_HitInfo intersection, const in C_Surface surface)\n{\n #ifdef ENABLE_AMBIENT_OCCLUSION \n\t\tvec3 vPos = intersection.vPos;\n\t\tvec3 vNormal = surface.vNormal;\n\t\n\t\tfloat fAmbientOcclusion = 1.0;\n\t\n\t\tfloat fDist = 0.0;\n\t\tfor(int i=0; i<=5; i++)\n\t\t{\n\t\t\tfDist += 0.1;\n\t\n\t\t\tvec4 vSceneDist = GetDistanceScene(vPos + vNormal * fDist);\n\t\n\t\t\tfAmbientOcclusion *= 1.0 - max(0.0, (fDist - vSceneDist.x) * 0.2 / fDist ); \n\t\t}\n\t\n\t\treturn fAmbientOcclusion;\n #else\n\t return 1.0;\n #endif \n}\n\n/////////////////////////////////////\n// Lighting and Shading\n\n#define kFogDensity 0.1\n\nvoid ApplyAtmosphere(inout vec3 col, const in C_Ray ray, const in C_HitInfo hitInfo)\n{\n #ifdef ENABLE_FOG\n // fog\n float fFogAmount = exp(hitInfo.fDistance * -kFogDensity);\n vec3 cFog = GetSkyGradient(ray.vDir);\n\n #ifdef ENABLE_DIRECTIONAL_LIGHT_FLARE\n C_DirectionalLight directionalLight = GetDirectionalLight();\n float fDirDot = clamp(dot(-directionalLight.vDir, ray.vDir), 0.0, 1.0);\n cFog += directionalLight.cColour * pow(fDirDot, 10.0);\n #endif \n\n col = mix(cFog, col, fFogAmount);\n #endif\n\n // glare from light (a bit hacky - use length of closest approach from ray to light)\n #ifdef ENABLE_POINT_LIGHT_FLARE\n C_PointLight pointLight = GetPointLight();\n\n vec3 vToLight = pointLight.vPos - ray.vOrigin;\n float fPointDot = dot(vToLight, ray.vDir);\n fPointDot = clamp(fPointDot, 0.0, hitInfo.fDistance);\n\n vec3 vClosestPoint = ray.vOrigin + ray.vDir * fPointDot;\n float fDist = length(vClosestPoint - pointLight.vPos);\n col += pointLight.cColour * 0.01/ (fDist * fDist);\n #endif \n}\n\n// http://en.wikipedia.org/wiki/Schlick's_approximation\nfloat Schlick( const in vec3 vNormal, const in vec3 vView, const in float fR0, const in float fSmoothFactor)\n{\n float fDot = dot(vNormal, -vView);\n fDot = clamp((1.0 - fDot), 0.0, 1.0);\n float fDotPow = pow(fDot, 5.0);\n return fR0 + (1.0 - fR0) * fDotPow * fSmoothFactor;\n}\n\nvec3 ApplyFresnel(const in vec3 vDiffuse, const in vec3 vSpecular, const in vec3 vNormal, const in vec3 vView, const in C_Material material)\n{\n float fFresnel = Schlick(vNormal, vView, material.fR0, material.fSmoothness * 0.9 + 0.1);\n return mix(vDiffuse, vSpecular, fFresnel); \n}\n\nfloat GetBlinnPhongIntensity(const in vec3 vIncidentDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness)\n{ \n vec3 vHalf = normalize(vLightDir - vIncidentDir);\n float fNdotH = max(0.0, dot(vHalf, vNormal));\n\n float fSpecPower = exp2(4.0 + 6.0 * fSmoothness);\n float fSpecIntensity = (fSpecPower + 2.0) * 0.125;\n\n return pow(fNdotH, fSpecPower) * fSpecIntensity;\n}\n\nC_Shading ApplyPointLight( const in C_PointLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\n{\n C_Shading shading;\n \n vec3 vToLight = light.vPos - vSurfacePos;\n vec3 vLightDir = normalize(vToLight);\n float fLightDistance = length(vToLight);\n \n float fAttenuation = 1.0 / (fLightDistance * fLightDistance);\n \n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, fLightDistance );\n vec3 vIncidentLight = light.cColour * fShadowFactor * fAttenuation * max(0.0, dot(vLightDir, vNormal));\n \n shading.cDiffuse = vIncidentLight; \n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\n \n return shading;\n} \n\nC_Shading ApplyDirectionalLight( const in C_DirectionalLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\n{\n C_Shading shading;\n\n const float kShadowRayLength = 10.0; \n vec3 vLightDir = -light.vDir;\n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, kShadowRayLength );\n vec3 vIncidentLight = light.cColour * fShadowFactor * max(0.0, dot(vLightDir, vNormal));\n \n shading.cDiffuse = vIncidentLight; \n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\n \n return shading;\n} \n\n\nvec3 ShadeSurface(const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface, const in C_Material material)\n{\n vec3 cScene;\n \n C_Shading shading;\n\n shading.cDiffuse = vec3(0.0);\n shading.cSpecular = vec3(0.0);\n \n float fAmbientOcclusion = GetAmbientOcclusion(hitInfo, surface);\n vec3 vAmbientLight = GetAmbientLight(surface.vNormal) * fAmbientOcclusion;\n \n shading.cDiffuse += vAmbientLight;\n shading.cSpecular += surface.cReflection;\n \n #ifdef ENABLE_POINT_LIGHT\n C_PointLight pointLight = GetPointLight(); \n C_Shading pointLighting = ApplyPointLight(pointLight, hitInfo.vPos,ray.vDir, surface.vNormal, material);\n shading.cDiffuse += pointLighting.cDiffuse;\n shading.cSpecular += pointLighting.cSpecular;\n #endif\n\n #ifdef ENABLE_DIRECTIONAL_LIGHT\n\tC_DirectionalLight directionalLight = GetDirectionalLight();\n C_Shading directionLighting = ApplyDirectionalLight(directionalLight, hitInfo.vPos, ray.vDir, surface.vNormal, material);\n shading.cDiffuse += directionLighting.cDiffuse;\n shading.cSpecular += directionLighting.cSpecular;\n #endif\n\t\n\t// fire in the hole\n\tshading.cDiffuse += clamp(-hitInfo.vPos.y - 0.5, 0.0, 1.0) * vec3(5.0, 0.25, 0.05);\n\n vec3 vDiffuseReflection = shading.cDiffuse * material.cAlbedo; \n\n #ifdef ENABLE_SPECULAR\n cScene = ApplyFresnel(vDiffuseReflection , shading.cSpecular, surface.vNormal, ray.vDir, material);\n #else\n cScene = vDiffuseReflection;\n #endif\n \n return cScene;\n}\n\nvec3 GetSceneColourSecondary( const in C_Ray ray );\n\nvec3 GetReflection( const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface )\n{\n #ifdef ENABLE_REFLECTIONS \n {\n // get colour from reflected ray\n const float fSeparation = 0.1;\n\n C_Ray reflectRay;\n reflectRay.vDir = reflect(ray.vDir, surface.vNormal);\n reflectRay.vOrigin = hitInfo.vPos;\n reflectRay.fLength = 16.0;\n reflectRay.fStartDistance = fSeparation / abs(dot(reflectRay.vDir, surface.vNormal));\n \n return GetSceneColourSecondary(reflectRay); \n }\n #else\n return GetSkyGradient(reflect(ray.vDir, surface.vNormal)); \n #endif\n}\n\n// no reflections, no transparency, used for secondary rays\nvec3 GetSceneColourSecondary( const in C_Ray ray )\n{\n C_HitInfo hitInfo;\n Raymarch(ray, hitInfo, 32);\n \n vec3 cScene;\n\n if(hitInfo.vObjectId.x < 0.5)\n {\n cScene = GetSkyGradient(ray.vDir);\n }\n else\n {\n C_Surface surface; \n surface.vNormal = GetSceneNormal(hitInfo.vPos);\n\n C_Material material = GetObjectMaterial(hitInfo);\n\n // use sky gradient instead of reflection\n surface.cReflection = GetSkyGradient(reflect(ray.vDir, surface.vNormal));\n\n // apply lighting\n cScene = ShadeSurface(ray, hitInfo, surface, material);\n }\n\n ApplyAtmosphere(cScene, ray, hitInfo);\n\n return cScene;\n}\n\nvec3 GetSceneColourPrimary( const in C_Ray ray )\n{ \n C_HitInfo intersection;\n Raymarch(ray, intersection, 256);\n \n vec3 cScene;\n\n if(intersection.vObjectId.x < 0.5)\n {\n cScene = GetSkyGradient(ray.vDir);\n }\n else\n {\n C_Surface surface;\n \n surface.vNormal = GetSceneNormal(intersection.vPos);\n\n C_Material material = GetObjectMaterial(intersection);\n\n surface.cReflection = GetReflection(ray, intersection, surface);\n\n // apply lighting\n cScene = ShadeSurface(ray, intersection, surface, material);\n }\n\n ApplyAtmosphere(cScene, ray, intersection);\n\n return cScene;\n}\n\nfloat kFarClip = 30.0;\n\nvoid GetCameraRay( const in vec3 vPos, const in vec3 vForwards, const in vec3 vWorldUp, const in vec2 fragCoord, out C_Ray ray)\n{\n vec2 vUV = ( fragCoord.xy / iResolution.xy );\n vec2 vViewCoord = vUV * 2.0 - 1.0;\n\n float fRatio = iResolution.x / iResolution.y;\n vViewCoord.y /= fRatio; \n\n ray.vOrigin = vPos;\n\n vec3 vRight = normalize(cross(vForwards, vWorldUp));\n vec3 vUp = cross(vRight, vForwards);\n \n ray.vDir = normalize( vRight * vViewCoord.x + vUp * vViewCoord.y + vForwards); \n ray.fStartDistance = 0.0;\n ray.fLength = kFarClip; \n}\n\nvoid GetCameraRayLookat( const in vec3 vPos, const in vec3 vInterest, const in vec2 fragCoord, out C_Ray ray)\n{\n vec3 vForwards = normalize(vInterest - vPos);\n vec3 vUp = vec3(0.0, 1.0, 0.0);\n\n GetCameraRay(vPos, vForwards, vUp, fragCoord, ray);\n}\n\nvec3 OrbitPoint( const in float fHeading, const in float fElevation )\n{\n return vec3(sin(fHeading) * cos(fElevation), sin(fElevation), cos(fHeading) * cos(fElevation));\n}\n\nvec3 Gamma( const in vec3 cCol )\n{\n return sqrt(cCol);\n}\n\nvec3 Tonemap( const in vec3 cCol )\n{\n vec3 vResult = 1.0 - exp2(-cCol);\n\n return vResult;\n}\n\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord )\n{\n C_Ray ray;\n\n \tGetCameraRayLookat( OrbitPoint(iGlobalTime * 0.3, cos(iGlobalTime * 0.2) * 0.3 + 0.4) * 7.0, vec3(0.0, 0.0, 0.0), fragCoord, ray);\n\n vec3 cScene = GetSceneColourPrimary( ray ); \n\n const float fExposure = 1.5; \n fragColor = vec4( Tonemap(cScene * fExposure), 1.0 );\n}\n\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \n// End pasted shadertoy code\n\n" + }, "screenshotURL": "data/images/images-ylklxefy7cyj6qr79-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qh4PDg5QYbN3rGiXh/art.json b/art/qh4PDg5QYbN3rGiXh/art.json index b89a3c46..137158f7 100644 --- a/art/qh4PDg5QYbN3rGiXh/art.json +++ b/art/qh4PDg5QYbN3rGiXh/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "w.chae", "avatarUrl": "https://secure.gravatar.com/avatar/e33886e1d2ddd9c8199ae2b5bbb15df9?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Wonhyeong Chae\\n// Exercise Color\\n// CS250 Spring 2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float centerX = (across - 1.) / 2.0;\\n float centerY = (down - 1.) / 2.0;\\n\\n float xOffset = x - centerX;\\n float yOffset = y - centerY;\\n\\n float normalizedX = xOffset / centerX;\\n float normalizedY = yOffset / centerY;\\n\\n float spread = 0.5;\\n float spreadX = normalizedX * spread;\\n float spreadY = normalizedY * spread;\\n\\n float u = (normalizedX + 1. + spreadX) / 2.;\\n float v = (normalizedY + 1. + spreadY) / 2.;\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float angle = time * 0.5;\\n float cosAngle = cos(angle);\\n float sinAngle = sin(angle);\\n float rotatedX = ux * cosAngle - vy * sinAngle;\\n float rotatedY = ux * sinAngle + vy * cosAngle;\\n\\n gl_Position = vec4(rotatedX, rotatedY, 0., 1.);\\n\\n float soff = sin(time + x * y * 0.02) * 5.;\\n\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n float colorModRed = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float colorModGreen = 1.;\\n float colorModBlue = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n\\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Wonhyeong Chae\n// Exercise Color\n// CS250 Spring 2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float centerX = (across - 1.) / 2.0;\n float centerY = (down - 1.) / 2.0;\n\n float xOffset = x - centerX;\n float yOffset = y - centerY;\n\n float normalizedX = xOffset / centerX;\n float normalizedY = yOffset / centerY;\n\n float spread = 0.5;\n float spreadX = normalizedX * spread;\n float spreadY = normalizedY * spread;\n\n float u = (normalizedX + 1. + spreadX) / 2.;\n float v = (normalizedY + 1. + spreadY) / 2.;\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float angle = time * 0.5;\n float cosAngle = cos(angle);\n float sinAngle = sin(angle);\n float rotatedX = ux * cosAngle - vy * sinAngle;\n float rotatedY = ux * sinAngle + vy * cosAngle;\n\n gl_Position = vec4(rotatedX, rotatedY, 0., 1.);\n\n float soff = sin(time + x * y * 0.02) * 5.;\n\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n float colorModRed = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float colorModGreen = 1.;\n float colorModBlue = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n\n v_color = vec4(colorModRed, colorModGreen, colorModBlue, 1.0);\n}\n" + }, "screenshotURL": "data/images/images-akofkcl9azfowa0i9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qividt2tw6AP89Bn7/art.json b/art/qividt2tw6AP89Bn7/art.json index 5eabfd88..30017d66 100644 --- a/art/qividt2tw6AP89Bn7/art.json +++ b/art/qividt2tw6AP89Bn7/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Colors\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05 + mod(time, 1.0); // Modified hue calculation\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Colors\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05 + mod(time, 1.0); // Modified hue calculation\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-08waa7vmldaafop14-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qjLQadWFssvPKLLCN/art.json b/art/qjLQadWFssvPKLLCN/art.json index 68af1315..de1568ef 100644 --- a/art/qjLQadWFssvPKLLCN/art.json +++ b/art/qjLQadWFssvPKLLCN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10300,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/tangerinedreamofficial2015/tangerine-dream-quantum-years-soundcloud\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n ⓥⓔⓡⓣⓔⓧⓢⓗⓐⓓⓔⓡⓐⓡⓣ\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 54.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.) * 1.; // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = mod(id, 2.) * 0.1;\\n pos = vec3(x, y, z); \\n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles * 0.5;\\n vec3 pos;\\n float inner = 0.0; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\\n float start = fract(hash(circleId * 0.33) + sin(time * 0.03 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((0.02 + cu + abs(uv.x * 2. - 1.)) * 0.20, uv.y * 0.05)).a;\\n \\n vec3 offset = vec3(\\n m1p1(hash(circleId)) * 0.1,\\n m1p1(hash(circleId * 0.37)) * 0.1, \\n 0);\\n offset.x += goop(circleId + time * 0.03) * 0.05;\\n offset.y += goop(circleId + time * 0.013) * 0.05;\\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n float sc = 2.; //mix(0.1, 0.4, hash(circleId) * exp(snd));\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= scale(vec3(sc, sc, 1));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1.;\\n float sat = 1.;\\n float val = mod(circleId, 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);//pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 10300, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/tangerinedreamofficial2015/tangerine-dream-quantum-years-soundcloud", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n ⓥⓔⓡⓣⓔⓧⓢⓗⓐⓓⓔⓡⓐⓡⓣ\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 54.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.) * 1.; // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = mod(id, 2.) * 0.1;\n pos = vec3(x, y, z); \n uv = vec2(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles * 0.5;\n vec3 pos;\n float inner = 0.0; //mix(0.0, 0.5, p1m1(sin(goop(circleId) + time * 0.1)));\n float start = fract(hash(circleId * 0.33) + sin(time * 0.03 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((0.02 + cu + abs(uv.x * 2. - 1.)) * 0.20, uv.y * 0.05)).a;\n \n vec3 offset = vec3(\n m1p1(hash(circleId)) * 0.1,\n m1p1(hash(circleId * 0.37)) * 0.1, \n 0);\n offset.x += goop(circleId + time * 0.03) * 0.05;\n offset.y += goop(circleId + time * 0.013) * 0.05;\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n float sc = 2.; //mix(0.1, 0.4, hash(circleId) * exp(snd));\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= scale(vec3(sc, sc, 1));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = 1.;\n float sat = 1.;\n float val = mod(circleId, 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);//pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-up351nmrh7g6tkdzj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qjkP6BDvEFyD6CfZC/art.json b/art/qjkP6BDvEFyD6CfZC/art.json index ccf55f9e..aa697c5f 100644 --- a/art/qjkP6BDvEFyD6CfZC/art.json +++ b/art/qjkP6BDvEFyD6CfZC/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-6mm135r72bhkmpe2h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qof5bDEpQyu2B6HFC/art.json b/art/qof5bDEpQyu2B6HFC/art.json index ce6177f7..69cf71d6 100644 --- a/art/qof5bDEpQyu2B6HFC/art.json +++ b/art/qof5bDEpQyu2B6HFC/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":16132,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Motion Assignment\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time * 10. + y * 0.3) * 0.1;\\n float yoff = sin(time + x * 0.2) * 0.1;\\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. -1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 * (sin(time * 3.) + 2.) + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(u, v, 1. - u - v, 1);\\n\\n}\"}", + "settings": { + "num": 16132, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Motion Assignment\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time * 10. + y * 0.3) * 0.1;\n float yoff = sin(time + x * 0.2) * 0.1;\n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. -1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 * (sin(time * 3.) + 2.) + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(u, v, 1. - u - v, 1);\n\n}" + }, "screenshotURL": "data/images/images-38clki6a3670updx3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qrDZ3LmPSpDcsogS3/art.json b/art/qrDZ3LmPSpDcsogS3/art.json index 7b7e79eb..e18d1fab 100644 --- a/art/qrDZ3LmPSpDcsogS3/art.json +++ b/art/qrDZ3LmPSpDcsogS3/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":16417,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define TAU radians(360.)#define PI radians(180.)\\n\\nvoid main()\\n{\\n \\n float pointsPerLoop = 30.;\\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.625 + (time * 20.));\\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.265, sy)).a, 4.) * 2.) * (1. - sy);\\n \\n float x = sin(deg) * radius * .9;\\n float y = cos(deg) * radius * .9;\\n float z = vertexId * sx * 0.125;\\n vec3 pos = vec3(x, y, z);\\n \\n float aspect = resolution.y / resolution.x;\\n mat4 camera = mat4(\\n aspect, 0, 0, 0,\\n 0, -1.1*mouse.x*radius, 0, 0,\\n -0.06, 0.01, 0.31, 0.1,\\n 0, 0, 0, 1);\\n \\n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\\n v_color = vec4(1, (vertexId / vertexCount) / 2.5 * 12.1, 0.4, 0.41);\\n}\"}", + "settings": { + "num": 16417, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define TAU radians(360.)#define PI radians(180.)\n\nvoid main()\n{\n \n float pointsPerLoop = 30.;\n float deg = radians(vertexId / pointsPerLoop * 360. + vertexId * 0.625 + (time * 20.));\n float sx = mod(vertexId, pointsPerLoop) / pointsPerLoop;\n float sy = floor(vertexId / pointsPerLoop) / floor(vertexCount / pointsPerLoop);\n float radius = (1.85 + pow(texture2D(sound, vec2(sx * 0.265, sy)).a, 4.) * 2.) * (1. - sy);\n \n float x = sin(deg) * radius * .9;\n float y = cos(deg) * radius * .9;\n float z = vertexId * sx * 0.125;\n vec3 pos = vec3(x, y, z);\n \n float aspect = resolution.y / resolution.x;\n mat4 camera = mat4(\n aspect, 0, 0, 0,\n 0, -1.1*mouse.x*radius, 0, 0,\n -0.06, 0.01, 0.31, 0.1,\n 0, 0, 0, 1);\n \n mix(gl_Position = camera * vec4(pos.xyz, 0.5),\n gl_Position = camera * vec4(1.-pos.xyz, 0.5), 0.5);\n v_color = vec4(1, (vertexId / vertexCount) / 2.5 * 12.1, 0.4, 0.41);\n}" + }, "screenshotURL": "data/images/images-l8b5lyp1yu629cgp4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qtwQmSqQKkS3ptSYN/art.json b/art/qtwQmSqQKkS3ptSYN/art.json index 8fb8841f..fd6e8284 100644 --- a/art/qtwQmSqQKkS3ptSYN/art.json +++ b/art/qtwQmSqQKkS3ptSYN/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1728,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 0.1 * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 1728, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 0.1 * qv;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-s4wnt5w35abjlnnuz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/qvctZ7frDWv9mM6Do/art.json b/art/qvctZ7frDWv9mM6Do/art.json index 07e1d839..6248b1a2 100644 --- a/art/qvctZ7frDWv9mM6Do/art.json +++ b/art/qvctZ7frDWv9mM6Do/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":16662,\"mode\":\"TRIANGLES\",\"sound\":\"https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z-0.5); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, 1.0, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 16662, + "mode": "TRIANGLES", + "sound": "https://m.soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z-0.5); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.2, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, 1.0, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.5) * .1 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -1, -eye.z*2.) * 8.5;\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 1. + abs(ca) * 5.);\n mat *= rotZ(pow(snd + .3, 5.5) * 1. + abs(cd) * 7.);\n float sc = mix(0.02, 0.25, pow(snd + 0.23, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.2 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1.5));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), pow(snd, 2.));\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-2udscj6jid87vslkx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qwTpNwa5NsAWRHJvh/art.json b/art/qwTpNwa5NsAWRHJvh/art.json index 135a9733..5ff78c03 100644 --- a/art/qwTpNwa5NsAWRHJvh/art.json +++ b/art/qwTpNwa5NsAWRHJvh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":33967,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 222.//KParameter 0.>>1000.\\n#define KP1 56.//KParameter 0.0>>22.\\n#define K2 9.0//KParameter 6.0>>10.\\n#define KP3 -0.01//KParameter -8.0>>0.5\\n#define KP4 6.2//KParameter 0.0>>15.\\n#define KP5 553.0//KParameter 30.000>>90000.0\\n\\n\\n\\n#define PI radians(180. -KP1)\\nfloat VertexCount = (1000. * K2) ;\\n \\n float KP2 = (K2 + mouse.y);\\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n \\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(y-x -x,.5*y+y, z*3.); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 1.125;\\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.52) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n ,1.15)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect );\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 33967, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 222.//KParameter 0.>>1000.\n#define KP1 56.//KParameter 0.0>>22.\n#define K2 9.0//KParameter 6.0>>10.\n#define KP3 -0.01//KParameter -8.0>>0.5\n#define KP4 6.2//KParameter 0.0>>15.\n#define KP5 553.0//KParameter 30.000>>90000.0\n\n\n\n#define PI radians(180. -KP1)\nfloat VertexCount = (1000. * K2) ;\n \n float KP2 = (K2 + mouse.y);\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n \n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(y-x -x,.5*y+y, z*3.); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 1.125;\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.52) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n ,1.15)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect );\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-jj8ekqkw55jjvc36c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/qx8oB3iGpxgR5q3GB/art.json b/art/qx8oB3iGpxgR5q3GB/art.json index c34b41f0..0414f874 100644 --- a/art/qx8oB3iGpxgR5q3GB/art.json +++ b/art/qx8oB3iGpxgR5q3GB/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "malcolm", "avatarUrl": "https://lh4.googleusercontent.com/-bHZA0RHFP2U/AAAAAAAAAAI/AAAAAAAAALw/mDyzWg5puHk/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,\\n 1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,\n 1);\n}" + }, "screenshotURL": "data/images/images-9jse7jkdtubt8t6h5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/r2tz6uDybuH3HESEN/art.json b/art/r2tz6uDybuH3HESEN/art.json index 0852871d..b44bc964 100644 --- a/art/r2tz6uDybuH3HESEN/art.json +++ b/art/r2tz6uDybuH3HESEN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.3333333333333333,0.7803921568627451,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 1;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/phil-hartnoll/lowdown-and-dirty-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.3333333333333333, + 0.7803921568627451, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 1;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-vaykbal6owtecrdlv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/r3aahkgwBNMpNsWRz/art.json b/art/r3aahkgwBNMpNsWRz/art.json index 4b0cc80d..b008913a 100644 --- a/art/r3aahkgwBNMpNsWRz/art.json +++ b/art/r3aahkgwBNMpNsWRz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 3. + PI * 0.9;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c - v;\\n float y = s * v*.2;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + tan(t * 0.3+mouse.x) + cos(-t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId - 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 1.33) + sin(time * .13 + circleId) * 3.1);\\n float end = start - 6.2 *time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.131-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz,.9);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - 7.9));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + .01, 5.));\\n v_color = vec4(v_color.rgb * v_color.a+.03, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 3. + PI * 0.9;\n float s = sin(a);\n float c = cos(a);\n float x = c - v;\n float y = s * v*.2;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + tan(t * 0.3+mouse.x) + cos(-t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId - 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 1.33) + sin(time * .13 + circleId) * 3.1);\n float end = start - 6.2 *time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.131-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz,.9);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - 7.9));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + .01, 5.));\n v_color = vec4(v_color.rgb * v_color.a+.03, v_color.a);\n}" + }, "screenshotURL": "data/images/images-lux1nnxt4yqhxogp6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/r7gmxrfBnFMN5mm9r/art.json b/art/r7gmxrfBnFMN5mm9r/art.json index b8be5d42..cea8eb7b 100644 --- a/art/r7gmxrfBnFMN5mm9r/art.json +++ b/art/r7gmxrfBnFMN5mm9r/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":9997,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hug-life/hood-nigga-si-begg-rhythm-hugdealer-bootleg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define KP0 1.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0.3, 0,\\n 0, 0, 1, 10,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye) *snd1 *22.;\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, snd1,\\n yAxis, snd0,\\n zAxis, snd2 * 22.,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 51.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 1195.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 12. - 12.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 11.)* time;\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3. *time), 4.)*time; // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(12.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 12. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 1.4)))*37.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0+6.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(1.6,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 2.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * .4 + v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * .2;\\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (1. - length(p)) * sz * .1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 2.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(500, 1000, -2000);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 1.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n // color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 0.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * .05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 2.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 5.6, cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 1.4, cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 1., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, -tan(time *0.3));\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 9997, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hug-life/hood-nigga-si-begg-rhythm-hugdealer-bootleg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define KP0 1.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0.3, 0,\n 0, 0, 1, 10,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye) *snd1 *22.;\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, snd1,\n yAxis, snd0,\n zAxis, snd2 * 22.,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 51.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 1195.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 12. - 12.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 11.)* time;\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3. *time), 4.)*time; // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(12.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 12. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 1.4)))*37.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0+6.0*f);\n\n return mix(mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(1.6,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 2.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * .4 + v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * .2;\n float sat = mix(.5, 1., mod(floor(time * 60. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 1. - length(p));\n// color.rgb *= color.a;\n gl_PointSize = (1. - length(p)) * sz * .1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 2.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(500, 1000, -2000);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 1.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 40.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n // color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = .5 + (pow(s1, 5.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 0.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * .05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 2.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 5.6, cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 1.4, cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 1., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, -tan(time *0.3));\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-r085px7tuaiu2qqp4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/r7tpZqAYFwZsQarPw/art.json b/art/r7tpZqAYFwZsQarPw/art.json index d6b10338..84bcd2e6 100644 --- a/art/r7tpZqAYFwZsQarPw/art.json +++ b/art/r7tpZqAYFwZsQarPw/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat3 rotx(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 roty(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 rotz(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\n\\nvec3 to3D( float idx, vec3 side ) \\n{\\n float z = floor(idx / (side.x * side.y));\\n idx -= (z * side.x * side.y);\\n float y = (idx / side.x);\\n float x = mod(idx, side.x);\\n return vec3(x,y,z);\\n}\\n\\nfloat grow = 1.;\\n\\nfloat df(vec3 p)\\n{\\n\\tp.xyz += 1.000*sin( 2.0*p.yzx )*grow;\\n \\tp.xyz += 0.500*sin( 4.0*p.yzx )*grow;\\n return length(p)-1.;\\n}\\n\\nvoid main()\\n{\\n\\tgl_PointSize = 2.;\\n\\tfloat sideCount = pow(vertexCount, 1./3.);\\n\\tvec3 p = to3D(vertexId, vec3(sideCount)) - sideCount * .5;\\n\\tfloat d = df(p);\\n\\tvec3 ro = p;\\n\\tvec3 rd = normalize(vec3(0) - ro);//\\n\\tgrow = sin(time * 0.5)*.6;\\n\\tfloat s = 1.;\\n\\tfor (int i = 0;i <200; i++)\\n\\t{\\n\\t\\ts = df(ro+rd*d);\\n\\t\\td += abs(s) * .1;\\n\\t}\\n\\t\\t\\n\\tvec3 pos = ro + rd * d;\\n\\tpos *= 0.23;\\n\\tpos *= rotx(-time*0.1) * roty(time*0.3);\\n \\tpos.y *= resolution.x / resolution.y;\\n\\tgl_Position = vec4(pos,1);\\n\\n \\tfloat hue = (time * 0.01 + floor(vertexId) * 1.001);\\n \\tv_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat3 rotx(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 roty(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 rotz(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\n\nvec3 to3D( float idx, vec3 side ) \n{\n float z = floor(idx / (side.x * side.y));\n idx -= (z * side.x * side.y);\n float y = (idx / side.x);\n float x = mod(idx, side.x);\n return vec3(x,y,z);\n}\n\nfloat grow = 1.;\n\nfloat df(vec3 p)\n{\n\tp.xyz += 1.000*sin( 2.0*p.yzx )*grow;\n \tp.xyz += 0.500*sin( 4.0*p.yzx )*grow;\n return length(p)-1.;\n}\n\nvoid main()\n{\n\tgl_PointSize = 2.;\n\tfloat sideCount = pow(vertexCount, 1./3.);\n\tvec3 p = to3D(vertexId, vec3(sideCount)) - sideCount * .5;\n\tfloat d = df(p);\n\tvec3 ro = p;\n\tvec3 rd = normalize(vec3(0) - ro);//\n\tgrow = sin(time * 0.5)*.6;\n\tfloat s = 1.;\n\tfor (int i = 0;i <200; i++)\n\t{\n\t\ts = df(ro+rd*d);\n\t\td += abs(s) * .1;\n\t}\n\t\t\n\tvec3 pos = ro + rd * d;\n\tpos *= 0.23;\n\tpos *= rotx(-time*0.1) * roty(time*0.3);\n \tpos.y *= resolution.x / resolution.y;\n\tgl_Position = vec4(pos,1);\n\n \tfloat hue = (time * 0.01 + floor(vertexId) * 1.001);\n \tv_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}\n" + }, "screenshotURL": "data/images/images-bx45df8qlkhztfhrk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rABYouScqWKneNWRS/art.json b/art/rABYouScqWKneNWRS/art.json index 0df948c3..0a09c043 100644 --- a/art/rABYouScqWKneNWRS/art.json +++ b/art/rABYouScqWKneNWRS/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define SCALE 112.0\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 5 \\n#define KP0 mouse.y\\n#define KP1 mouse.x\\n#define zoom 1.0-(mouse.x+mouse.y)\\n#define KP2 0.4\\t\\nfloat aspect=resolution.x/resolution.y;\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\\nvec4 unpackVertex(float a)\\n{\\n vec4 r = vec4(a-1.);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\nconst float znear=0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\n\\nmat4 persp = mat4(\\n 1.0 / aspect, 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 3., 0);\\n\\nvoid populate(){ \\n\\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \\ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \\ntriangles[ 2]=vec4( mouse.x*91.0, 112.0, 91.0, 96.0); \\ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \\ntriangles[ 4]=vec4( mouse.y*126.0, 91.0, 47.0, 91.0); \\ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \\ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \\ntriangles[ 8]=vec4( 11., 42.0, 1326.0, 4.0); \\n \\nnormals[0]=vec3(0.,0.,-1.);\\nnormals[1]=vec3(0.,0.,-1.);\\nnormals[2]=vec3(0.,0.,-1.);\\nnormals[3]=vec3(0.09,0.97,0.19);\\nnormals[4]=vec3(0.27,0.85,0.43);\\nnormals[5]=vec3(0.16,0.90,0.39);\\nnormals[6]=vec3(0.51,0.84,0.10);\\nnormals[7]=vec3(0.,0.80,0.58);\\nnormals[8]=vec3(0.,-1.,0.);\\nnormals[9]=vec3(0.,-1.,0.);\\nnormals[10]=vec3(0.16,-0.98,0.);\\nnormals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\\n //Mirror the model in x-axis\\n gl_Position.x=-gl_Position.x;\\n normal=reflect(normal,vec3(1.,0.,0.));\\n }\\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\\n gl_Position=tr*gl_Position;\\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\\n v_color.w=1.0;\\n gl_Position.z-=8./zoom;\\ngl_Position = persp * vec4(gl_Position.xyz, 1);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define SCALE 112.0\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 5 \n#define KP0 mouse.y\n#define KP1 mouse.x\n#define zoom 1.0-(mouse.x+mouse.y)\n#define KP2 0.4\t\nfloat aspect=resolution.x/resolution.y;\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\nconst vec3 masker = vec3(MASK,.70,MASK*MASK);\nvec4 unpackVertex(float a)\n{\n vec4 r = vec4(a-1.);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\nconst float znear=0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\n\nmat4 persp = mat4(\n 1.0 / aspect, 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 3., 0);\n\nvoid populate(){ \n\ntriangles[ 0]=vec4( cos(time*0.3), 96.0, 4.0, 91.0)*cos(time*0.33); \ntriangles[ 1]=vec4( 4.0, 12., 47.0, 4.0); \ntriangles[ 2]=vec4( mouse.x*91.0, 112.0, 91.0, 96.0); \ntriangles[ 3]=vec4( 13332.0, 91.0*mouse.y, 2112.0, 3332.0); \ntriangles[ 4]=vec4( mouse.y*126.0, 91.0, 47.0, 91.0); \ntriangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \ntriangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0)-sin(time); \ntriangles[ 7]=vec4( 4.0, sin(3332.0*time), 1326.0, 43332.0)*mouse.y; \ntriangles[ 8]=vec4( 11., 42.0, 1326.0, 4.0); \n \nnormals[0]=vec3(0.,0.,-1.);\nnormals[1]=vec3(0.,0.,-1.);\nnormals[2]=vec3(0.,0.,-1.);\nnormals[3]=vec3(0.09,0.97,0.19);\nnormals[4]=vec3(0.27,0.85,0.43);\nnormals[5]=vec3(0.16,0.90,0.39);\nnormals[6]=vec3(0.51,0.84,0.10);\nnormals[7]=vec3(0.,0.80,0.58);\nnormals[8]=vec3(0.,-1.,0.);\nnormals[9]=vec3(0.,-1.,0.);\nnormals[10]=vec3(0.16,-0.98,0.);\nnormals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=((TOTAL_TRI)*VERTICES_PER_TRI)){\n //Mirror the model in x-axis\n gl_Position.x=-gl_Position.x;\n normal=reflect(normal,vec3(1.,0.,0.));\n }\n mat4 tr=rotX(KP0*2.)*rotZ(KP1)*rotY(sin(time/4.));;\n vec4 n2 =tr*normal.xyzz;n2.w=1.0;\n n2=vec4(dot(n2,vec4(-.8,.8,-.2,1.0)));\n gl_Position=tr*gl_Position;\n v_color = n2/3.0+0.1*(vec4( 1.0,3.0*KP2,.70,1.0));//vec4((vertexId/float(TOTAL_TRI*VERTICES_PER_TRI))+.1,0.0,0.0,1.0);\n v_color.w=1.0;\n gl_Position.z-=8./zoom;\ngl_Position = persp * vec4(gl_Position.xyz, 1);\n\n}" + }, "screenshotURL": "data/images/images-5wbqx7525jtkwa1yy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rATARASTHX6xvj5Aa/art.json b/art/rATARASTHX6xvj5Aa/art.json index 8af10a0c..ec441398 100644 --- a/art/rATARASTHX6xvj5Aa/art.json +++ b/art/rATARASTHX6xvj5Aa/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/alvaro-macip/kiss-the-rain-yiruma\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float v = count / (vertexCount / NUM_SEGMENTS);\\n vec2 m = texture2D(touch, vec2(0, v)).xy;\\n float snd = texture2D(sound, vec2(0.05, v * 1.)).a;\\n float orbitAngle = snd * PI * 2.; //pow(time + count * 0.25, 0.8);\\n float innerRadius = pow(count * 0.00007, 1.2);\\n float oC = cos(orbitAngle + count * 0.003 + time) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.004 + time * 0.01) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * 20. * mix(0.9, 0.7, snd), 0.4, 1);\\n\\n v_color = vec4(0.3, 0.6, .7, 1. - v);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/alvaro-macip/kiss-the-rain-yiruma", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float v = count / (vertexCount / NUM_SEGMENTS);\n vec2 m = texture2D(touch, vec2(0, v)).xy;\n float snd = texture2D(sound, vec2(0.05, v * 1.)).a;\n float orbitAngle = snd * PI * 2.; //pow(time + count * 0.25, 0.8);\n float innerRadius = pow(count * 0.00007, 1.2);\n float oC = cos(orbitAngle + count * 0.003 + time) * innerRadius;\n float oS = sin(orbitAngle + count * 0.004 + time * 0.01) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * 20. * mix(0.9, 0.7, snd), 0.4, 1);\n\n v_color = vec4(0.3, 0.6, .7, 1. - v);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-l8y2mzlfhh1le8da5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rAzqz9fhRarpgzdC2/art.json b/art/rAzqz9fhRarpgzdC2/art.json index 450ba12a..52f89fa7 100644 --- a/art/rAzqz9fhRarpgzdC2/art.json +++ b/art/rAzqz9fhRarpgzdC2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n gl_Position = vec4(0,0,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n gl_Position = vec4(0,0,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-on7wa45l7howaanl6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rBjrdN2CvsneEkgEk/art.json b/art/rBjrdN2CvsneEkgEk/art.json index 61cc755a..793d2b2a 100644 --- a/art/rBjrdN2CvsneEkgEk/art.json +++ b/art/rBjrdN2CvsneEkgEk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/brianne-becker/charlie-brown-o-tannenbaum\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9764705882352941,1,0.984313725490196,1],\"shader\":\"/*\\n\\n _____, ____, ___, ___, __ _, \\n(-| | | (-|_, (-|_) (-|_) (-\\\\ | \\n _| | |_, _|__, _| \\\\_, _| \\\\_, \\\\| \\n( ( ( ( (__/ \\n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \\n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\\\_,(-(__`\\n \\\\___, _| |_, _| \\\\_, _|__, ____) _| _| | |_, _| ) ____)\\n ( ( ( ( ( ( ( ( \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat t5p5(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQPoint(const float id) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 pos = vec3(ux, vy, 0); \\n return pos;\\n}\\n\\n#define PER_TREE 200.\\n#define PER_SIDE (PER_TREE / 2.)\\nvoid main() {\\n float vId = mod(vertexId, PER_TREE);\\n float treeId = floor(vertexId / PER_TREE);\\n float numTrees = floor(vertexCount / PER_TREE);\\n float treeV = treeId / numTrees;\\n float sideId = mod(vId, 2.);\\n float stemId = floor(vId / 2.);\\n float stemV = stemId / (PER_SIDE - 1.);\\n \\n \\n float r = 50.0;\\n float ct = time * .05;\\n vec3 camera = vec3(sin(ct) * r, mix(5., 15., t5p5(sin(time * .13))), cos(ct) * r);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 200.);\\n m *= cameraLookAt(camera, target, up);\\n m *= trans(vec3(m1p1(hash(treeV)), 0, m1p1(hash(treeV * 1.237))) * 100.);\\n m *= scale(vec3(1, mix(1., 3., hash(treeV * 0.541)), 1));\\n mat4 tm = rotY(stemV * PI * 6. + sideId * PI);\\n tm *= trans(vec3(0, (1. - stemV) * 5., -stemV * 2.));\\n gl_Position = m * tm * vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0 * stemV;\\n \\n vec3 p = vec3(tm[0]);\\n float light = dot(normalize(vec3(10,-20,5)), normalize(p)) * .5 + .5;\\n v_color = mix(vec4(1,0,0,1), vec4(0,.8,0,1), sideId);\\n v_color = vec4(v_color.rgb * v_color.a * light, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/brianne-becker/charlie-brown-o-tannenbaum", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9764705882352941, + 1, + 0.984313725490196, + 1 + ], + "shader": "/*\n\n _____, ____, ___, ___, __ _, \n(-| | | (-|_, (-|_) (-|_) (-\\ | \n _| | |_, _|__, _| \\_, _| \\_, \\| \n( ( ( ( (__/ \n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\_,(-(__`\n \\___, _| |_, _| \\_, _|__, ____) _| _| | |_, _| ) ____)\n ( ( ( ( ( ( ( ( \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat t5p5(float v) {\n return v * .5 + .5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQPoint(const float id) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 pos = vec3(ux, vy, 0); \n return pos;\n}\n\n#define PER_TREE 200.\n#define PER_SIDE (PER_TREE / 2.)\nvoid main() {\n float vId = mod(vertexId, PER_TREE);\n float treeId = floor(vertexId / PER_TREE);\n float numTrees = floor(vertexCount / PER_TREE);\n float treeV = treeId / numTrees;\n float sideId = mod(vId, 2.);\n float stemId = floor(vId / 2.);\n float stemV = stemId / (PER_SIDE - 1.);\n \n \n float r = 50.0;\n float ct = time * .05;\n vec3 camera = vec3(sin(ct) * r, mix(5., 15., t5p5(sin(time * .13))), cos(ct) * r);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 200.);\n m *= cameraLookAt(camera, target, up);\n m *= trans(vec3(m1p1(hash(treeV)), 0, m1p1(hash(treeV * 1.237))) * 100.);\n m *= scale(vec3(1, mix(1., 3., hash(treeV * 0.541)), 1));\n mat4 tm = rotY(stemV * PI * 6. + sideId * PI);\n tm *= trans(vec3(0, (1. - stemV) * 5., -stemV * 2.));\n gl_Position = m * tm * vec4(0, 0, 0, 1);\n gl_PointSize = 10.0 * stemV;\n \n vec3 p = vec3(tm[0]);\n float light = dot(normalize(vec3(10,-20,5)), normalize(p)) * .5 + .5;\n v_color = mix(vec4(1,0,0,1), vec4(0,.8,0,1), sideId);\n v_color = vec4(v_color.rgb * v_color.a * light, v_color.a);\n}" + }, "screenshotURL": "data/images/images-tq1ep9crzpm965d5r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rBqQqL5j4orqHbrPz/art.json b/art/rBqQqL5j4orqHbrPz/art.json index 82f207f8..2995b384 100644 --- a/art/rBqQqL5j4orqHbrPz/art.json +++ b/art/rBqQqL5j4orqHbrPz/art.json @@ -21,7 +21,19 @@ "private": false, "unlisted": false, "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n //v_color = vec4(1.0 * abs(c), 4.0 * c, -4.0 * c, 1);\\n v_color = vec4(1.0 * abs(c), 1.0 * abs(1.0 - c), 0.15 * abs(2.0 - c), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n //v_color = vec4(1.0 * abs(c), 4.0 * c, -4.0 * c, 1);\n v_color = vec4(1.0 * abs(c), 1.0 * abs(1.0 - c), 0.15 * abs(2.0 - c), 1);\n}" + }, "screenshotURL": "data/images/images-eha59va25847naeip-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rCHrvqDdspQzQoxu9/art.json b/art/rCHrvqDdspQzQoxu9/art.json index 827beaa3..10a5f700 100644 --- a/art/rCHrvqDdspQzQoxu9/art.json +++ b/art/rCHrvqDdspQzQoxu9/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/moods-grooves-records/phaze-dee-game-of-life-web\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25882352941176473,0.25882352941176473,0.25882352941176473,1],\"shader\":\"// data from https://github.com/Jezzamonn/fourier\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec2 fft(int freq, float amplitude, float phase, float time) {\\n float angle = PI * 2.0 * float(freq) * time + phase;\\n return vec2(cos(angle), sin(angle)) * amplitude;\\n}\\n\\nvec2 computeFFT(float t) {\\n vec2 p = vec2(0);\\n p += fft(0, 296.524077607952, 0.5328692201872761, t);\\n p += fft(1, 129.16512258296828, -2.90016335218518, t);\\n p += fft(-1, 63.77796615668684, 2.9224545501551584, t);\\n p += fft(3, 19.64466960507052, -2.4341521827648407, t);\\n p += fft(2, 15.225563957670408, 2.1065920733999985, t);\\n p += fft(4, 10.816890879510945, 2.768243749294925, t);\\n p += fft(6, 7.7798714613757785, 2.790776515902791, t);\\n p += fft(8, 6.679135366586027, -2.691421192706561, t);\\n p += fft(18, 6.618481262601785, -2.7811427287619805, t);\\n p += fft(-17, 6.194427860122354, 1.0295557956864945, t);\\n p += fft(-20, 6.068497179066321, 2.0845633129083545, t);\\n p += fft(13, 6.026155883530845, -2.9082280887418843, t);\\n p += fft(20, 5.87547467169867, 0.6567893346845978, t);\\n p += fft(12, 5.664082795931505, -0.7736185409154058, t);\\n p += fft(22, 5.504599257383946, -0.5566360694751388, t);\\n p += fft(-22, 5.146718591504782, -2.7391457150277336, t);\\n p += fft(-19, 4.967122293367857, -1.4319471520699776, t);\\n p += fft(-11, 4.537800748903001, 0.7806248091011616, t);\\n p += fft(16, 4.409897469465315, 2.5618942112767407, t);\\n p += fft(-25, 4.3819383386473865, -1.5151030062564892, t);\\n p += fft(-16, 4.149297744113447, 0.575845737238003, t);\\n p += fft(-12, 4.139174393444163, 2.982857273406526, t);\\n p += fft(-34, 4.07501017913087, 1.5981185989542064, t);\\n p += fft(-8, 4.074809962485297, -0.42486073575722444, t);\\n p += fft(5, 4.0206048747056125, -2.3082375418458945, t);\\n p += fft(11, 3.990542905551988, 2.3627881868284972, t);\\n p += fft(17, 3.955727644969372, 2.456663236004692, t);\\n p += fft(19, 3.8658362150758534, -1.6701042175865948, t);\\n p += fft(10, 3.8517952416210557, -1.9882991837519308, t);\\n p += fft(25, 3.8215186298010257, -0.9536339281017274, t);\\n p += fft(-6, 3.6465818944687634, -0.4459221391524853, t);\\n p += fft(-29, 3.2133268799952712, 2.9249873354735345, t);\\n p += fft(-13, 3.172984702723984, -0.25267920294558227, t);\\n p += fft(15, 3.1374261306697373, 2.4403069911326685, t);\\n p += fft(7, 3.0955422513620245, -1.711872929589281, t);\\n p += fft(-9, 2.880155339148816, 0.32676693145089336, t);\\n p += fft(-15, 2.8798999832519403, 0.9375984752072446, t);\\n p += fft(26, 2.79967174195265, -2.049901239880178, t);\\n p += fft(29, 2.7803332403386336, 0.5231959777340147, t);\\n p += fft(28, 2.7414647126009593, 0.4708642708868981, t);\\n p += fft(41, 2.6437612024221844, -2.9636977093225685, t);\\n p += fft(39, 2.6295641656754234, -2.277801278923058, t);\\n p += fft(27, 2.6183263816781324, 2.784381034343638, t);\\n p += fft(-4, 2.612279805775902, 1.1701981679810707, t);\\n p += fft(34, 2.5896488928989925, 0.8874838650026977, t);\\n p += fft(-18, 2.568509187236616, -0.9803167206473404, t);\\n p += fft(-28, 2.507964971759851, 3.026960979082897, t);\\n p += fft(-14, 2.4945338840886677, -0.18814398163405743, t);\\n p += fft(-3, 2.4553487715159696, -2.515704298686429, t);\\n p += fft(-10, 2.347972482924663, -0.9661461748548102, t);\\n p += fft(9, 2.3353227667810943, 2.6662410983119873, t);\\n p += fft(-27, 2.2841877482065778, 0.6357945200731572, t);\\n p += fft(-33, 2.2359717418821874, -2.6756775052827853, t);\\n p += fft(37, 2.0731181353939196, -2.8767957104561597, t);\\n p += fft(43, 2.046908477381298, -0.848325445419195, t);\\n p += fft(40, 1.9650400072060998, 1.4954865245732736, t);\\n p += fft(31, 1.920647139346876, -0.8820561267540269, t);\\n p += fft(-37, 1.8264609429322551, -0.6283518255686783, t);\\n p += fft(-30, 1.8191188807994465, -2.078648696472338, t);\\n p += fft(-21, 1.7570644633051382, 2.614905728603112, t);\\n p += fft(24, 1.7380651990304348, 1.797588764641598, t);\\n p += fft(44, 1.6560026933156917, 0.27276010910919374, t);\\n p += fft(-44, 1.649213368528592, -2.697758361982687, t);\\n p += fft(-32, 1.6482613051000077, 1.7281181963111363, t);\\n p += fft(-38, 1.5957955338176892, 3.0229778848579327, t);\\n p += fft(50, 1.594057606604889, -2.705446593070425, t);\\n p += fft(33, 1.5853686682207064, -0.5898590645559981, t);\\n p += fft(-26, 1.567072721585987, -0.6245687779647491, t);\\n p += fft(23, 1.5345223856234949, -2.2815578356210735, t);\\n p += fft(36, 1.5087867231807512, -0.5742399182534951, t);\\n p += fft(-24, 1.4664813474877614, 2.7549795210299215, t);\\n p += fft(57, 1.4430652246678877, 2.1241473623512697, t);\\n p += fft(32, 1.406056560977162, 2.4473930566249096, t);\\n p += fft(54, 1.397187168634832, -1.5290316283596388, t);\\n p += fft(-35, 1.378962288401975, 1.030170830294626, t);\\n p += fft(-51, 1.3443697534460952, 0.7824834836125082, t);\\n p += fft(38, 1.2073849482228887, -1.417621395841823, t);\\n p += fft(52, 1.1813148530266455, -2.7146718708831226, t);\\n p += fft(58, 1.1546285984367923, -2.0469226839957546, t);\\n p += fft(-2, 1.148242184394193, 1.1600574990999488, t);\\n p += fft(-49, 1.1389035886326317, 2.536779536914916, t);\\n p += fft(14, 1.1329760186659397, 3.040831768189552, t);\\n p += fft(45, 1.1260078033316239, -2.6485676515902887, t);\\n p += fft(-36, 1.0505189643915007, 1.1512408246664814, t);\\n p += fft(48, 1.0434710403748044, -1.587473666465379, t);\\n p += fft(35, 1.0264643367771464, 0.8533152135907922, t);\\n p += fft(-77, 0.9957083595939865, 2.3018398053793176, t);\\n p += fft(-50, 0.9539520583808928, -1.8737321231607105, t);\\n p += fft(-23, 0.9292718478810791, -1.6156932158409079, t);\\n p += fft(-43, 0.9257761649922747, -0.9528711445133002, t);\\n p += fft(-46, 0.868581952908317, -1.7531859162182506, t);\\n p += fft(-47, 0.8477347332294584, 1.5654529539919164, t);\\n p += fft(-45, 0.8130585468017898, -0.6663785358206237, t);\\n p += fft(60, 0.7908050200984377, -0.1023181049126883, t);\\n p += fft(62, 0.7872325903381513, 1.030198597230489, t);\\n p += fft(-48, 0.7858142817398769, 1.387565504131415, t);\\n p += fft(49, 0.7704030031060537, 2.627354289464034, t);\\n p += fft(-84, 0.7688630997732272, -2.564222992505424, t);\\n p += fft(-39, 0.761830091495416, -2.4526438973987954, t);\\n p += fft(78, 0.7543732213279061, 2.343001847272033, t);\\n p += fft(-59, 0.7488095838105383, -3.1131016762144443, t);\\n p += fft(55, 0.7285003537607938, -0.9786713526593741, t);\\n p += fft(-31, 0.7248134830134255, -0.5543123381122909, t);\\n p += fft(-54, 0.7219542814654896, 2.94943367544441, t);\\n p += fft(-53, 0.7139986380620472, -1.2338229580467204, t);\\n p += fft(46, 0.6985299047036991, -0.3033719700149987, t);\\n p += fft(69, 0.6940778952546749, -1.0238518940571633, t);\\n p += fft(-40, 0.6927457316683343, 2.0054202454179775, t);\\n p += fft(-57, 0.67709432212438, -2.783806233466308, t);\\n p += fft(47, 0.6602293673831037, 1.1829982386683053, t);\\n p += fft(74, 0.6545825289163747, -0.6313191364037845, t);\\n p += fft(-5, 0.6200531105206556, -1.012708917351053, t);\\n p += fft(30, 0.6145303942405808, -0.006575553587373788, t);\\n p += fft(-65, 0.6130907552103994, -1.2775992452682625, t);\\n p += fft(83, 0.6078433173163771, -1.3921353502568135, t);\\n p += fft(53, 0.6029346402536699, 3.118126806639058, t);\\n p += fft(64, 0.593655747614559, -0.12929981693431084, t);\\n p += fft(87, 0.5917638000158103, 2.8165282828931195, t);\\n p += fft(75, 0.562070427870424, 2.935821150408132, t);\\n p += fft(51, 0.553965684266993, 0.8857804427580288, t);\\n p += fft(-69, 0.5402011495014111, -2.393077154815434, t);\\n p += fft(-67, 0.5247046263885512, -0.12626924765950584, t);\\n p += fft(80, 0.5211530645039045, -2.313552855619569, t);\\n p += fft(56, 0.5057370766773879, -2.628846336188085, t);\\n p += fft(-75, 0.5038585813938068, -1.8904143929736488, t);\\n p += fft(-73, 0.48644277854405304, 1.3709055508801584, t);\\n p += fft(-7, 0.47307925137425644, -2.55202847874333, t);\\n p += fft(94, 0.4614308523932489, 2.545636098697929, t);\\n p += fft(-74, 0.4419918759755517, 0.11529437409844774, t);\\n p += fft(65, 0.44169553192805927, 2.439841086433652, t);\\n p += fft(72, 0.43611612862779375, 0.9074545441173122, t);\\n p += fft(-66, 0.43502792411907976, -2.063079991837712, t);\\n p += fft(-42, 0.4314569651112275, 0.33687123321689777, t);\\n p += fft(-64, 0.40521665336797635, 0.003486215133649564, t);\\n p += fft(99, 0.40417092365602253, -1.8240004200677489, t);\\n p += fft(59, 0.3936963912394369, -1.6362215309246326, t);\\n p += fft(-60, 0.3815954958269982, -0.7754496988180308, t);\\n p += fft(-63, 0.3792381066868484, -1.9391548308871835, t);\\n p += fft(73, 0.37854582778783324, 0.043442146165603684, t);\\n p += fft(42, 0.37453717681808335, 2.38737562405369, t);\\n p += fft(21, 0.35583878846131595, -2.7839176861684014, t);\\n p += fft(112, 0.3547233494213232, 2.954248286045894, t);\\n p += fft(108, 0.35083273251102737, 2.5458627704061483, t);\\n p += fft(93, 0.35040473622512436, -0.029550910229384195, t);\\n p += fft(89, 0.3403049133299473, -2.885129447081889, t);\\n p += fft(-70, 0.3370256731757577, -0.46771663832106974, t);\\n p += fft(-78, 0.3366544726218109, -0.24724720507658238, t);\\n p += fft(82, 0.32610868403027304, -1.4954241039751592, t);\\n p += fft(-91, 0.32419682164009966, -1.3417496079852937, t);\\n p += fft(-90, 0.3234753025960112, -3.0133578986946814, t);\\n p += fft(-80, 0.2998816486209547, 3.096207886158368, t);\\n p += fft(71, 0.2984964350635909, -0.6377008416229164, t);\\n p += fft(85, 0.2961360685518227, 2.9392297581041658, t);\\n p += fft(111, 0.2939868074077519, 1.066357674174694, t);\\n p += fft(84, 0.2882922892341542, -0.2824472092836136, t);\\n p += fft(-62, 0.2823355494458707, 0.5392478382746477, t);\\n p += fft(101, 0.28043862110007006, 1.8969467658422987, t);\\n p += fft(-58, 0.27927463219687665, -2.5066886208410595, t);\\n p += fft(-114, 0.2787101344869982, -2.3945575768789205, t);\\n p += fft(-81, 0.27344747273177633, 0.19849972308144362, t);\\n p += fft(96, 0.268848539128237, 2.352065707231053, t);\\n p += fft(104, 0.2667328677077002, -2.6894745409478773, t);\\n p += fft(90, 0.2623194708267266, 2.6305846168436604, t);\\n p += fft(105, 0.2587320115138661, -0.44809280212853925, t);\\n p += fft(91, 0.25666403259093135, -0.42872274693200485, t);\\n p += fft(-94, 0.25344187481961844, -1.1325746386338256, t);\\n p += fft(67, 0.24928071126959497, 1.783113342037483, t);\\n p += fft(-61, 0.2486431701299056, -3.0289630409059964, t);\\n p += fft(-102, 0.24833449653800949, 2.814031321792728, t);\\n p += fft(115, 0.24216361168985745, 2.5259661057434784, t);\\n p += fft(-83, 0.24082180762961733, 2.327373899411901, t);\\n p += fft(-71, 0.2404736569240409, 2.8270765856325983, t);\\n p += fft(-95, 0.23819976781292496, 0.25934694371445854, t);\\n p += fft(128, 0.23600151920093423, -2.2635194564211036, t);\\n p += fft(-82, 0.23162812218159617, -0.40811639028183505, t);\\n p += fft(63, 0.231108841604306, 0.7896297030534211, t);\\n p += fft(66, 0.22876820962806374, -2.20689386652509, t);\\n p += fft(145, 0.22683296568648012, -2.871130626679519, t);\\n p += fft(114, 0.22579541537273998, -0.03888650023606557, t);\\n p += fft(-115, 0.22449806848298495, 1.7267840321105514, t);\\n p += fft(-101, 0.2201367259955669, -1.2160405006932076, t);\\n p += fft(70, 0.21924416034549526, -1.8300948469474085, t);\\n p += fft(-41, 0.2167988567102195, -0.8439248313023797, t);\\n p += fft(110, 0.21645852077265354, -0.959164313163234, t);\\n p += fft(158, 0.2151250144734518, 1.0174468948847888, t);\\n p += fft(106, 0.21196244851082488, -0.7429833668933534, t);\\n p += fft(-137, 0.20545059106326097, 2.8523980589526516, t);\\n p += fft(-99, 0.20544620480189876, 2.378277723073504, t);\\n p += fft(157, 0.20466861943591227, 1.5525202358047085, t);\\n p += fft(-97, 0.20297792194129058, -0.24324542189056148, t);\\n p += fft(168, 0.20130500227008466, -1.094673594091641, t);\\n p += fft(117, 0.19993871414763503, 2.850736702421766, t);\\n p += fft(98, 0.19737263515643355, 0.5877762863368731, t);\\n p += fft(-72, 0.1929911058483345, 0.010089217287886454, t);\\n p += fft(107, 0.19264056832987778, 0.704220700877197, t);\\n p += fft(-112, 0.19130748611122012, -2.392875008529597, t);\\n p += fft(-89, 0.1896856318579048, -1.952634273837995, t);\\n p += fft(-118, 0.1840849374841271, 2.66760266379526, t);\\n p += fft(-106, 0.1831571823504252, -0.22353534215395926, t);\\n p += fft(68, 0.18268583480820008, -1.6209797108511708, t);\\n p += fft(-55, 0.18120542886859284, 0.467068135124605, t);\\n p += fft(95, 0.17907416077732574, 1.0948396281940986, t);\\n p += fft(148, 0.17866061557325139, 2.3602934407666574, t);\\n p += fft(177, 0.17832736193972554, -1.6046679924839198, t);\\n p += fft(-108, 0.17809221310240264, -1.3634658504175172, t);\\n p += fft(-98, 0.17770123200232602, -2.319713221578887, t);\\n p += fft(100, 0.176886631202939, -1.121794475824346, t);\\n p += fft(124, 0.17654047192131325, -2.379198871802532, t);\\n p += fft(-88, 0.17639283951454524, -2.402190307443758, t);\\n p += fft(-174, 0.1759528058963321, -2.2025378411458227, t);\\n p += fft(140, 0.1753854668907291, 0.42397843457703155, t);\\n p += fft(-96, 0.1753429914194849, -2.5609307243169104, t);\\n p += fft(86, 0.17047016491561567, -2.1287646574123906, t);\\n p += fft(-116, 0.16955079792541142, 1.330523857460539, t);\\n p += fft(61, 0.16905959469199813, -2.6057097347432614, t);\\n p += fft(-121, 0.1688420653965695, -0.5090905584523955, t);\\n p += fft(155, 0.16680443183652535, -1.2332547487780734, t);\\n p += fft(171, 0.16582399968407263, -0.8747323409363787, t);\\n p += fft(-87, 0.1652225600618143, -2.085937535924309, t);\\n p += fft(-131, 0.16214898761358187, 1.9650981796384732, t);\\n p += fft(92, 0.15699998077784863, -0.18853113336883437, t);\\n p += fft(166, 0.1554844992569468, 2.2850556504133888, t);\\n p += fft(161, 0.15373402046283416, -0.7486102426340269, t);\\n p += fft(144, 0.15312278232769228, -0.3587853130578195, t);\\n p += fft(125, 0.15278331508565252, 0.6417517362772722, t);\\n p += fft(97, 0.15144010052991969, 1.0282568217837087, t);\\n p += fft(135, 0.15129294602934487, -0.6387137369146754, t);\\n p += fft(-56, 0.1457904354443015, 2.356685746244658, t);\\n p += fft(103, 0.1453915874749691, -0.6785631327279983, t);\\n p += fft(146, 0.14379520492495512, -0.7855888994349319, t);\\n p += fft(142, 0.1412707218042313, -0.1618563085599607, t);\\n p += fft(126, 0.13936676935400355, -2.4453404815078725, t);\\n p += fft(81, 0.13772359181353372, 0.5044424044942989, t);\\n p += fft(163, 0.13762314582762275, 1.639822161059763, t);\\n p += fft(134, 0.13545232146341332, 2.3024168785102312, t);\\n p += fft(165, 0.13509475913506178, -0.8279398617821645, t);\\n p += fft(-76, 0.13455680964642944, -3.0716219607883164, t);\\n p += fft(-127, 0.13207374762677063, -2.6599668223479727, t);\\n p += fft(-152, 0.13117632063169987, -2.5293527274604246, t);\\n p += fft(-105, 0.1311202673313172, -2.693197028055788, t);\\n p += fft(-145, 0.12945158970649637, 2.3951255425463125, t);\\n p += fft(119, 0.12925458048582072, 2.1883428437365144, t);\\n p += fft(132, 0.12746981347132513, -3.033026520788066, t);\\n p += fft(-85, 0.12653240774860508, -2.8680500174257837, t);\\n p += fft(-144, 0.12465405936107726, -0.37790452498667604, t);\\n p += fft(76, 0.12463110048880623, 0.12012177237288406, t);\\n p += fft(-142, 0.12459485706573038, 0.3051081828140754, t);\\n p += fft(-138, 0.12451331383970095, 0.584148256098649, t);\\n p += fft(149, 0.12401784752155019, -1.8125703421505832, t);\\n p += fft(-147, 0.12362040139712106, 0.03028190421886324, t);\\n p += fft(131, 0.12297013103130192, -1.7612969157441667, t);\\n p += fft(-148, 0.12201071321640686, -2.0282746264394236, t);\\n p += fft(-68, 0.12130140373799272, -0.9290611617024176, t);\\n p += fft(116, 0.12128775362324593, -1.5007597875190253, t);\\n p += fft(-135, 0.12111941530251287, -0.9133882438391181, t);\\n p += fft(-104, 0.12079045102618642, 0.9539883001598056, t);\\n p += fft(-86, 0.12063181239660088, -1.9105367933076451, t);\\n p += fft(102, 0.11858318427484749, 3.116549695906647, t);\\n p += fft(162, 0.11672334871059657, -0.43512865812715645, t);\\n p += fft(-128, 0.11555594493778179, 1.594914753823693, t);\\n p += fft(147, 0.11507078486852833, -1.8015902273798317, t);\\n p += fft(-125, 0.11380569936104315, -0.02432076846797433, t);\\n p += fft(-129, 0.1137850317216325, -2.6266191242164822, t);\\n p += fft(77, 0.11284625921171428, 0.6500879168724161, t);\\n p += fft(159, 0.11039859551711936, -2.8651146672170977, t);\\n p += fft(-206, 0.10898089539528502, 1.0381666149725348, t);\\n p += fft(-92, 0.10835773802225089, 0.6916172775229433, t);\\n p += fft(127, 0.10811810875499965, -2.998228956999233, t);\\n p += fft(-199, 0.10803687786223723, -2.46851901448902, t);\\n p += fft(-184, 0.1079436817269362, 1.3191475812437883, t);\\n p += fft(-161, 0.10743289221697289, 1.3169047201119328, t);\\n p += fft(-139, 0.10723255868931553, -1.7855768275688515, t);\\n p += fft(-130, 0.10575112607516497, 1.2885726884003454, t);\\n p += fft(-198, 0.10555774123223534, 2.3378343445027423, t);\\n p += fft(88, 0.1037982678523408, -2.57743331926905, t);\\n p += fft(-219, 0.10310221059641228, -1.2625859044047876, t);\\n p += fft(-103, 0.10235558593739706, 0.7768959419271573, t);\\n p += fft(-201, 0.10189587875806011, 2.395004608187347, t);\\n p += fft(174, 0.10047600105014917, -1.7769904121389015, t);\\n p += fft(113, 0.10019192995096364, 0.6613060769884679, t);\\n p += fft(186, 0.09888320495036292, 2.4232322332757033, t);\\n p += fft(143, 0.09873568608937729, -0.6230636594392547, t);\\n p += fft(-155, 0.0967869591188688, -1.7298363196681086, t);\\n p += fft(185, 0.09658335995961313, 1.1754529148166517, t);\\n p += fft(-177, 0.09656910791483884, 2.0163242572983346, t);\\n p += fft(-167, 0.09620604020928483, 2.643429513987398, t);\\n p += fft(170, 0.09573558303359174, -0.30695931132003684, t);\\n p += fft(180, 0.09461328604462575, -1.6239251039930218, t);\\n p += fft(-220, 0.0943272029181478, -1.4319742082110574, t);\\n p += fft(-52, 0.09420059423208178, 0.34189504423155104, t);\\n p += fft(-172, 0.09359535175565478, -0.6516984922913376, t);\\n p += fft(-110, 0.0928047006450446, 1.6652587522465396, t);\\n p += fft(151, 0.09250606338361644, -1.9756734220597145, t);\\n p += fft(-93, 0.09207328457476618, -1.8386442351917063, t);\\n p += fft(-136, 0.09192815271017309, 1.7852892175474182, t);\\n p += fft(-113, 0.09189336119191194, 0.1795575241258869, t);\\n p += fft(195, 0.09021546713204244, 2.2961250797130024, t);\\n p += fft(-150, 0.0890214588284327, -0.4242294361284968, t);\\n p += fft(-193, 0.08814677822860856, -3.032675290767406, t);\\n p += fft(172, 0.08787933668637724, 0.8937743898253856, t);\\n p += fft(-132, 0.08776566211120278, 1.6786784797215824, t);\\n p += fft(120, 0.08739819001501205, 2.0491345267796923, t);\\n p += fft(-237, 0.08676446852578372, -2.7506065977853367, t);\\n p += fft(-195, 0.08631820577015377, -2.292066178728447, t);\\n p += fft(-178, 0.08621869133141169, -2.289445548826154, t);\\n p += fft(-160, 0.0859070990539687, 0.8565575603400595, t);\\n p += fft(169, 0.08564275849176227, 1.4922004704741865, t);\\n p += fft(150, 0.08528562752062617, -2.271332020864171, t);\\n p += fft(136, 0.08341789857084404, 1.0652798481992052, t);\\n p += fft(199, 0.08332375555828694, -2.172498972819133, t);\\n p += fft(-235, 0.08327425440106223, -0.8722079224698919, t);\\n p += fft(-141, 0.08287851144036412, -0.2817694914314737, t);\\n p += fft(138, 0.08255129464089862, 2.481725429548499, t);\\n p += fft(-109, 0.0814238813994593, 2.810607915964862, t);\\n p += fft(-79, 0.08115343666484522, 3.0130919888081964, t);\\n p += fft(153, 0.0806615747018418, -2.90631621064385, t);\\n p += fft(-175, 0.0803741234494402, 2.4278323040306384, t);\\n p += fft(-143, 0.07972332355377411, -0.14610097282743986, t);\\n p += fft(-202, 0.07962980675194098, -0.2920969138999907, t);\\n p += fft(-120, 0.07894459678944289, -1.0822564599135749, t);\\n p += fft(-249, 0.07849391554379236, -1.5893682918262941, t);\\n p += fft(156, 0.07754124056908816, 2.6380926428153773, t);\\n p += fft(-158, 0.07639110613035878, -2.2498824982419814, t);\\n p += fft(191, 0.07543660088489744, 1.53576512075985, t);\\n p += fft(133, 0.07531833041051382, -0.29986287547697626, t);\\n p += fft(-176, 0.07501869195137476, -1.095228282011871, t);\\n p += fft(-173, 0.07438185135275685, -2.8547930590312265, t);\\n p += fft(-246, 0.07320459577858625, 3.004959078587308, t);\\n p += fft(-163, 0.07264231502260868, 0.5663326139154473, t);\\n /* ------ move this line up for more speed, down for more precision ----------\\n p += fft(206, 0.07185257960899775, -1.2074544409708887, t);\\n p += fft(-123, 0.07180358234742663, 1.177001822427382, t);\\n p += fft(164, 0.07179115512969167, 2.1602573633251723, t);\\n p += fft(188, 0.07150545575062967, 1.7193031745778165, t);\\n p += fft(224, 0.06999271922532711, -2.208456590100925, t);\\n p += fft(-194, 0.06998312687642928, -2.18523653052791, t);\\n p += fft(79, 0.06890472640127111, 1.3075753662847636, t);\\n p += fft(109, 0.06860075505611797, 1.6822381082814495, t);\\n p += fft(-212, 0.0678853204605727, 2.1130583033793853, t);\\n p += fft(160, 0.06721168671629134, 1.5355417936258289, t);\\n p += fft(-168, 0.06478428292880746, 1.8082125748786089, t);\\n p += fft(-100, 0.06418217011920442, 0.7154587151883682, t);\\n p += fft(-208, 0.06360704141059366, -2.403277839995585, t);\\n p += fft(137, 0.06324033312067673, -2.2610437967492656, t);\\n p += fft(123, 0.06295636338637589, 0.3970547395559689, t);\\n p += fft(-196, 0.0627324819432708, -2.6051526033441235, t);\\n p += fft(219, 0.06250233205660669, 2.203023925786526, t);\\n p += fft(-185, 0.0621114667768006, -0.5698975168684676, t);\\n p += fft(-166, 0.06210684036807704, 2.607205641731383, t);\\n p += fft(-205, 0.06175529499391064, 1.9171825820936816, t);\\n p += fft(-156, 0.061488097661469475, 1.4966065847312549, t);\\n p += fft(154, 0.061272027059191166, -2.6984551455468564, t);\\n p += fft(-231, 0.06035266134446573, 1.3615530640708646, t);\\n p += fft(141, 0.05955849823049297, 1.5515335051172228, t);\\n p += fft(-254, 0.05936948658056223, 0.08947841208696573, t);\\n p += fft(-223, 0.05924934830234196, -2.5888981145084804, t);\\n p += fft(-232, 0.05887059032744145, 0.01941763325695256, t);\\n p += fft(167, 0.05881968845436434, -1.0357803375284511, t);\\n p += fft(193, 0.058152494480082216, -0.4725096726740279, t);\\n p += fft(121, 0.05729621516472733, 1.7676238462353928, t);\\n p += fft(-268, 0.05725394282425765, -2.613958061844803, t);\\n p += fft(-302, 0.05709087761847913, 1.7622838278216528, t);\\n p += fft(-169, 0.05703481887597677, -0.6061202003738857, t);\\n p += fft(-228, 0.05673330948726983, 1.5024729233397405, t);\\n p += fft(222, 0.05638702685887402, -1.2302130026999638, t);\\n p += fft(-260, 0.05595371621472635, 1.2791472131268498, t);\\n p += fft(211, 0.05588512333449684, -1.8863675524330432, t);\\n p += fft(237, 0.05577640817605678, 0.9044485733453621, t);\\n p += fft(-210, 0.055436889934911734, -2.17570469763129, t);\\n p += fft(-107, 0.054515606954931885, 1.6064878994455691, t);\\n p += fft(-192, 0.054378774601921455, 0.177220838503605, t);\\n p += fft(-182, 0.053953358377995975, -2.1280204079638576, t);\\n p += fft(-263, 0.0538060156192732, -1.6125700112210792, t);\\n p += fft(212, 0.05372692488622374, 0.9420856343907927, t);\\n p += fft(-213, 0.053418601872005124, 2.7878022389569965, t);\\n p += fft(-248, 0.05287392885207208, 0.18442109948336485, t);\\n p += fft(226, 0.05219567026185329, -1.9364295452150295, t);\\n p += fft(198, 0.05216791125481548, -1.3500769286288878, t);\\n p += fft(-282, 0.05185758906196177, -1.0531164762937948, t);\\n p += fft(-111, 0.051505065799642175, -1.5496533180287155, t);\\n p += fft(-241, 0.05085304364706675, -0.46354003864012305, t);\\n p += fft(-124, 0.05032731737587234, -0.9525802310682452, t);\\n p += fft(-250, 0.050246365262025194, 0.8026967297965477, t);\\n p += fft(-211, 0.05012936662149643, 0.7247623593388082, t);\\n p += fft(-209, 0.05002408512494514, 1.8132755265361036, t);\\n p += fft(-252, 0.049775105705583016, 0.5996942868760795, t);\\n p += fft(223, 0.04939534137917373, -2.695791674918428, t);\\n p += fft(122, 0.04894575970718128, 2.8830421586085544, t);\\n p += fft(-153, 0.04887699031380359, 0.3334054103895581, t);\\n p += fft(-181, 0.047900428231714746, -2.21806751268122, t);\\n p += fft(299, 0.04768730955214819, 0.3243053297596023, t);\\n p += fft(-259, 0.04760097318206576, -0.8705493020585283, t);\\n p += fft(-227, 0.04622658586057274, 1.2806504451219154, t);\\n p += fft(-226, 0.04575599938137761, 2.99718633620427, t);\\n p += fft(-165, 0.04562578928136969, -0.9599207008754989, t);\\n p += fft(-119, 0.0452353353928757, -2.8588596616336357, t);\\n p += fft(-151, 0.04518238397772298, -0.13718441224107195, t);\\n p += fft(-255, 0.04513692897501351, 1.860335619309556, t);\\n p += fft(173, 0.04502237604956329, -0.810579987098727, t);\\n p += fft(-164, 0.04491854079446375, -2.2251696607200238, t);\\n p += fft(367, 0.04463225444542998, -1.3682718846259723, t);\\n p += fft(-238, 0.044492812350265004, -1.30018967859005, t);\\n p += fft(213, 0.04433393493985305, -2.5049897246887496, t);\\n p += fft(-217, 0.04394773639883994, 0.3578708012733398, t);\\n p += fft(-191, 0.04378025799588553, -0.0033036474870014217, t);\\n p += fft(252, 0.04323472173070737, -0.6242705523897715, t);\\n p += fft(208, 0.04304212913333182, 1.2308490125522018, t);\\n p += fft(-303, 0.04296800234600092, 0.5114427759851766, t);\\n p += fft(-224, 0.04272023945142006, 1.7783110640430169, t);\\n p += fft(-239, 0.04266679157025011, 1.9482200717681597, t);\\n p += fft(-299, 0.04173701435724602, 0.13365408028225706, t);\\n p += fft(-157, 0.04146038143450164, -2.27864544691768, t);\\n p += fft(-122, 0.04130127409599373, 1.0179985736718389, t);\\n p += fft(244, 0.04122532274063034, -3.067112795949472, t);\\n p += fft(-257, 0.04120260956232949, -0.542088172379074, t);\\n p += fft(243, 0.0411840750974049, -1.1270227690299983, t);\\n p += fft(-197, 0.04049657874199362, -1.3153250227799558, t);\\n p += fft(-245, 0.040487242733518884, -0.8056762003801902, t);\\n p += fft(-159, 0.039968494906456264, 2.131425507643933, t);\\n p += fft(-307, 0.03996735676224505, -2.953588109997123, t);\\n p += fft(-117, 0.03996366100725931, -0.49760194876592045, t);\\n p += fft(196, 0.03980123228825173, -2.4873720845122835, t);\\n p += fft(129, 0.03949030893082138, 2.6844282955405814, t);\\n p += fft(-229, 0.03917242300752811, 0.4902693841571348, t);\\n p += fft(139, 0.03902865341873541, 0.25084178188044515, t);\\n p += fft(181, 0.03890376427607834, 1.0907389035558301, t);\\n p += fft(205, 0.038225435143225045, 3.038754339328246, t);\\n p += fft(-270, 0.03814390562327705, -1.8861478767357396, t);\\n p += fft(-322, 0.0377875627108128, 2.054761498465224, t);\\n p += fft(254, 0.037644552308180375, 1.226339480136378, t);\\n p += fft(118, 0.0376169651010232, -2.950034729024326, t);\\n p += fft(178, 0.03755225537409213, -2.0429020234266275, t);\\n p += fft(-171, 0.037539637959647765, -2.628755546161329, t);\\n p += fft(-285, 0.03747836134545755, 1.6722531286069764, t);\\n p += fft(-180, 0.037460621587516375, 0.24951421594634987, t);\\n p += fft(-247, 0.03717014294939771, 0.4975746705003909, t);\\n p += fft(-243, 0.037110747818183125, -2.0522437006131544, t);\\n p += fft(-216, 0.03709475821552742, -2.3116936028551125, t);\\n p += fft(220, 0.036592206760702885, -1.1344479951397493, t);\\n p += fft(-179, 0.03633519628480489, 3.112577471269461, t);\\n p += fft(176, 0.03587107527180269, 2.0913103131787256, t);\\n p += fft(-207, 0.035809732499114115, 1.927035559915993, t);\\n p += fft(263, 0.03562581086066016, 2.1725008985745626, t);\\n p += fft(-233, 0.0354009108649777, 3.090965188758471, t);\\n p += fft(-274, 0.03518550659845451, -2.609254318579163, t);\\n p += fft(255, 0.03514669947246087, -0.5836113629270486, t);\\n p += fft(-319, 0.035071528591647944, -0.9287687613033353, t);\\n p += fft(250, 0.035032432208899206, -1.3555387953817497, t);\\n p += fft(246, 0.03497955004685989, -2.900549119786685, t);\\n p += fft(187, 0.03497207390971293, 0.6419092201499581, t);\\n p += fft(-261, 0.034866141687325505, -2.8459055041516237, t);\\n p += fft(235, 0.03476696606441066, -2.0933815844908445, t);\\n p += fft(-323, 0.03432989757242964, 3.043376257611318, t);\\n p += fft(217, 0.03432513334072705, -2.870512549124132, t);\\n p += fft(-162, 0.034206181317519346, 1.7603609329802217, t);\\n p += fft(228, 0.033806131017560914, 2.744224194820961, t);\\n p += fft(-214, 0.03361470625565273, 1.3269768758946363, t);\\n p += fft(-215, 0.033529573748044716, -0.6672480021154472, t);\\n p += fft(218, 0.033108296214315436, -0.745234197490618, t);\\n p += fft(-146, 0.03308604353605592, 3.1073329337196274, t);\\n p += fft(-304, 0.03303159902623534, -2.4351923422168493, t);\\n p += fft(311, 0.032929142894730805, -1.2404835833846408, t);\\n p += fft(242, 0.03292110918943753, -2.843217129365357, t);\\n p += fft(-134, 0.03288854877053813, 0.9130453422359837, t);\\n p += fft(-351, 0.03216220452946286, 2.9238550334113036, t);\\n p += fft(370, 0.032067363608954395, -2.7224346201619336, t);\\n p += fft(-272, 0.0320561856904509, -2.2145797900542075, t);\\n p += fft(-154, 0.031753153031045644, -0.16349530311453386, t);\\n p += fft(-297, 0.03170814258815033, 1.4299668847082438, t);\\n p += fft(182, 0.031686346431849116, 1.0404018878433685, t);\\n p += fft(209, 0.031631761114312575, 2.68111660535219, t);\\n p += fft(-170, 0.03155091422698183, 0.025639469483387113, t);\\n p += fft(-186, 0.031481161179575994, -2.4201773456994196, t);\\n p += fft(-149, 0.031378407408703936, -0.29780149545874124, t);\\n p += fft(-189, 0.03115713943498147, -2.644731527056393, t);\\n p += fft(-140, 0.031108294831552176, -2.15723791130607, t);\\n p += fft(-230, 0.031069499597997076, -1.8351044204097733, t);\\n p += fft(-347, 0.030916908832951683, 2.4988906781918887, t);\\n p += fft(179, 0.030863310224088517, -2.7337664596225717, t);\\n p += fft(403, 0.03079754590699015, 2.304354929974498, t);\\n p += fft(-327, 0.030401389085025158, 0.6776045430119092, t);\\n p += fft(348, 0.030373006761288658, -0.8679493927914637, t);\\n p += fft(-283, 0.030223082183547217, 2.321654263572609, t);\\n p += fft(363, 0.029978631780089162, -2.0372134669252153, t);\\n p += fft(300, 0.029897933119460138, -0.6676919620602354, t);\\n p += fft(-291, 0.029861596312070346, 1.7523875509536528, t);\\n p += fft(-188, 0.029753115428544207, 1.9857575444023974, t);\\n p += fft(225, 0.02930280842219607, -2.476715232579848, t);\\n p += fft(429, 0.029179633135401076, -1.1583720910674902, t);\\n p += fft(-244, 0.028727529620259963, -2.1143873737131402, t);\\n p += fft(-262, 0.02871955668992869, -3.0313512511556326, t);\\n p += fft(183, 0.02846822983732852, -2.748892137103645, t);\\n p += fft(371, 0.02837026069110045, 0.01709695974620803, t);\\n p += fft(261, 0.02827365028172563, -3.1104354673121124, t);\\n p += fft(265, 0.028272672120935843, 2.3187637649532733, t);\\n p += fft(-225, 0.02812970136713906, -2.391287474012119, t);\\n p += fft(-498, 0.027947522439068676, -2.2990766978458765, t);\\n p += fft(-280, 0.027914429972500227, 1.013046879856245, t);\\n p += fft(-286, 0.027473151353735275, -2.49136323587289, t);\\n p += fft(175, 0.027082599263012368, -1.5491745606494223, t);\\n p += fft(-312, 0.027012987931504247, 2.04498781689676, t);\\n p += fft(-269, 0.02695999871732734, 1.9901497475231744, t);\\n p += fft(-360, 0.026873297237023055, -0.1910603902232436, t);\\n p += fft(210, 0.026869883314267793, 2.2196865134172485, t);\\n p += fft(297, 0.026812580694708738, -0.9588922853385715, t);\\n p += fft(-301, 0.026740603460076486, 3.129150821124547, t);\\n p += fft(249, 0.026705638457446366, 1.222748808928071, t);\\n p += fft(-265, 0.02664609481949143, -2.053872209655098, t);\\n p += fft(234, 0.026552097720191792, 1.791539306291776, t);\\n p += fft(227, 0.026483242165273254, 1.820370612047031, t);\\n p += fft(-278, 0.026454482953384536, -0.05035777064958111, t);\\n p += fft(130, 0.02643932663595854, -0.99756238511126, t);\\n p += fft(231, 0.026426198746353186, 0.5809494198615022, t);\\n p += fft(259, 0.026227035759586497, 0.048293120841955764, t);\\n p += fft(-484, 0.025920236965447943, -1.3145326416833631, t);\\n p += fft(-200, 0.02582688982027274, 2.9933704442672058, t);\\n p += fft(306, 0.025717614417685275, 1.8836489796514166, t);\\n p += fft(325, 0.025633895244435108, 1.3357894296294839, t);\\n p += fft(347, 0.025591567492861077, 0.7714686164660547, t);\\n p += fft(350, 0.02537545484909361, 1.0770352597787496, t);\\n p += fft(269, 0.025281161653424446, -0.8907061117584099, t);\\n p += fft(-133, 0.025264087654711557, -2.2018152563461086, t);\\n p += fft(302, 0.025261769856955805, -2.355108757850705, t);\\n p += fft(-386, 0.02501819794981099, -2.1477266907940398, t);\\n p += fft(-350, 0.025002909823313272, -0.918163604040018, t);\\n p += fft(333, 0.02498494266415943, -2.4432604967090743, t);\\n p += fft(-126, 0.024859518286652924, -1.6045017067489493, t);\\n p += fft(387, 0.02467625356087282, 1.3070718064311373, t);\\n p += fft(334, 0.024653917539731205, -1.2008707105925764, t);\\n p += fft(-240, 0.024383901745244567, -2.988241565566239, t);\\n p += fft(-264, 0.024335184695854287, -2.6872316547229813, t);\\n p += fft(-295, 0.024162332511406915, 2.688135808330894, t);\\n p += fft(-276, 0.023836127347152083, 1.7406463579323161, t);\\n p += fft(203, 0.02379133257240037, -0.3391371830055463, t);\\n p += fft(238, 0.023765709007479915, -0.5242076860175524, t);\\n p += fft(-483, 0.023685530454379034, -2.7588368682276188, t);\\n p += fft(-342, 0.023608418137766377, -2.8422263956774603, t);\\n p += fft(-329, 0.02352667163920514, -1.3751865534697134, t);\\n p += fft(-325, 0.023484462227501834, 0.9927626044567095, t);\\n p += fft(230, 0.023456797688559062, 2.986455504190948, t);\\n p += fft(-251, 0.023318098398379915, 0.001782273200166798, t);\\n p += fft(349, 0.023228733757422806, -1.072303089214612, t);\\n p += fft(-187, 0.02322820420005635, -1.3088872022943903, t);\\n p += fft(207, 0.023124953262124194, 2.861078526577945, t);\\n p += fft(202, 0.023092047214425013, 1.0903724835034125, t);\\n p += fft(256, 0.022985204913763314, -2.423841790239499, t);\\n p += fft(275, 0.022818988303534807, 0.6902607477729654, t);\\n p += fft(241, 0.022704874638607323, -2.7649106335200497, t);\\n p += fft(425, 0.0227031562735846, -0.012766251035448749, t);\\n p += fft(341, 0.022687393671458885, 2.5287999264265917, t);\\n p += fft(365, 0.02259089981517188, -3.0023071719734364, t);\\n p += fft(298, 0.022430755305941547, 2.1440768785920277, t);\\n p += fft(282, 0.022286640564131238, 1.6952796376817658, t);\\n p += fft(-222, 0.02225904133709741, -0.11321484605745279, t);\\n p += fft(-358, 0.02217999232999693, 1.7758821914468246, t);\\n p += fft(-279, 0.022095177947215737, -0.5192730492996941, t);\\n p += fft(-321, 0.022090473578627715, -0.07844498829588367, t);\\n p += fft(-359, 0.021942659529941247, -1.4465606944335514, t);\\n p += fft(295, 0.021938469715302247, -2.262517021888232, t);\\n p += fft(276, 0.02187149419277873, -0.48075610553317366, t);\\n p += fft(502, 0.021702319512468666, 3.0296543113191032, t);\\n p += fft(-330, 0.021623659938299806, 1.125358184849381, t);\\n p += fft(437, 0.021598487358667418, -3.140123913594686, t);\\n p += fft(329, 0.02151039012029828, 2.581279012552966, t);\\n p += fft(316, 0.021367306895449877, -1.4951973637160159, t);\\n p += fft(-267, 0.021347948106670487, -2.131762505311679, t);\\n p += fft(-357, 0.02130909397626576, -1.6191594501730688, t);\\n p += fft(267, 0.021293781075476997, -1.8017482889635452, t);\\n p += fft(-345, 0.021048837931442004, -2.7069477620313958, t);\\n p += fft(-408, 0.02091001972463279, -1.769848404933256, t);\\n p += fft(320, 0.02088425179811783, -2.0704408556221447, t);\\n p += fft(-387, 0.020820573842865432, -1.0930901397929305, t);\\n p += fft(-242, 0.020794137395108606, -2.9605829129168324, t);\\n p += fft(-344, 0.020671452626722698, -1.7987821089995277, t);\\n p += fft(322, 0.02067088832181214, -0.22912612763676568, t);\\n p += fft(-253, 0.02061794621791137, -2.0073683043484953, t);\\n p += fft(152, 0.020610241493015494, 0.7098290286508013, t);\\n p += fft(303, 0.020592932879901157, 0.2719935974041692, t);\\n p += fft(369, 0.020565205999609194, 1.1339865732671597, t);\\n p += fft(-273, 0.020564513440436215, 0.7955462603371597, t);\\n p += fft(215, 0.020563199492889896, -2.73682346996378, t);\\n p += fft(491, 0.020543180022284717, -0.666788850668437, t);\\n p += fft(-356, 0.020468707035038124, 0.6390339134967551, t);\\n p += fft(293, 0.02045422037494547, 2.0389477913494334, t);\\n p += fft(201, 0.02044920037993446, 0.020014295722637722, t);\\n p += fft(346, 0.020343417891833488, -0.725558513377337, t);\\n p += fft(-399, 0.020300294108822257, 0.4272740878635683, t);\\n p += fft(464, 0.020245436748592072, -1.684969251038007, t);\\n p += fft(221, 0.020152569151655777, 3.0652577733184607, t);\\n p += fft(489, 0.020112656771664496, -1.8042417759245823, t);\\n p += fft(318, 0.020056388889540793, -0.6707185351758385, t);\\n p += fft(-339, 0.02001479126183757, 2.949145490351578, t);\\n p += fft(236, 0.019954859133684905, -2.5428580801661353, t);\\n p += fft(270, 0.0199321804912115, 0.37878519439460373, t);\\n p += fft(379, 0.01983906743081143, -0.6343495825544784, t);\\n p += fft(397, 0.019807948769945526, 1.8820880074650208, t);\\n p += fft(-221, 0.019691977663300008, 1.0514616478563783, t);\\n p += fft(421, 0.019623337934699885, 2.745363616281166, t);\\n p += fft(290, 0.01953008037132682, 0.8843912942541152, t);\\n p += fft(197, 0.019375944562943694, 2.0356527234870283, t);\\n p += fft(308, 0.0193527600669189, 2.81162774010797, t);\\n p += fft(-328, 0.019285400376087076, -0.19114063563029987, t);\\n p += fft(467, 0.019178891795281015, -1.1263460951000444, t);\\n p += fft(-277, 0.019079718249143097, 2.6331532845129404, t);\\n p += fft(280, 0.018994654616752097, 0.1675185745565849, t);\\n p += fft(260, 0.018913994053827352, -0.5044184838532041, t);\\n p += fft(427, 0.018852739951118917, 2.662217288999046, t);\\n p += fft(499, 0.01882350931017547, -3.0149846935153795, t);\\n p += fft(189, 0.018757809943370472, -2.674046839704885, t);\\n p += fft(342, 0.01874747510581987, -0.5786367177428741, t);\\n p += fft(416, 0.018566064359446622, -2.4176951579501798, t);\\n p += fft(-348, 0.018437843583245718, -2.43964557130452, t);\\n p += fft(465, 0.018437257369033726, 1.9214782275571987, t);\\n p += fft(284, 0.01833544793734469, 1.9968963624882772, t);\\n p += fft(-470, 0.01831002225764508, 0.5156559884673433, t);\\n p += fft(-309, 0.018308015252553246, 2.312871173198566, t);\\n p += fft(490, 0.018216767412652893, 1.0140583098689544, t);\\n p += fft(410, 0.0182153814183295, -0.7582160151193984, t);\\n p += fft(-258, 0.018128466510949046, 1.1118990006128406, t);\\n p += fft(375, 0.018057552391933036, -3.1017254547912794, t);\\n p += fft(321, 0.01794587346556815, -1.8663932495219484, t);\\n p += fft(248, 0.017863597777448885, -0.5496798132550856, t);\\n p += fft(-317, 0.01782644768907149, 2.2802015955382537, t);\\n p += fft(-452, 0.01780336641082023, 2.690346714053042, t);\\n p += fft(-353, 0.0176913084429108, 2.711049147139238, t);\\n p += fft(-306, 0.017552300595371273, 2.9506692681038973, t);\\n p += fft(-288, 0.017544324110289406, 2.6323855434673655, t);\\n p += fft(-460, 0.017443786885044096, -0.9299541940735817, t);\\n p += fft(309, 0.017419145135487844, 1.3460311128048443, t);\\n p += fft(305, 0.017152445993384516, -1.7361791397832658, t);\\n p += fft(-256, 0.01714047466479905, 2.2799787723913836, t);\\n p += fft(355, 0.017058849062613846, -0.6615483742229916, t);\\n p += fft(-320, 0.016979227333377315, 2.6388512636510377, t);\\n p += fft(-382, 0.01695615705889803, 2.555957382259133, t);\\n p += fft(390, 0.016953475958207665, 2.3322367819625027, t);\\n p += fft(-398, 0.01694687182836866, 2.171099613653392, t);\\n p += fft(411, 0.01692398609281921, -2.3970294940597237, t);\\n p += fft(391, 0.01688742438332487, -2.6741985703550384, t);\\n p += fft(-383, 0.01671254896861024, -1.809831893039911, t);\\n p += fft(-438, 0.016700025869992145, -3.0263950471937577, t);\\n p += fft(498, 0.016577067431832987, 1.4628404900222298, t);\\n p += fft(441, 0.016528444933087572, -2.5534170728688195, t);\\n p += fft(396, 0.016469294170931584, -1.0778883003395043, t);\\n p += fft(194, 0.016387929541844138, 0.27285370222194255, t);\\n p += fft(288, 0.01632089028121901, -2.499948895627382, t);\\n p += fft(-453, 0.016282171657074507, -1.8352466594182715, t);\\n p += fft(-491, 0.0162466408620674, 0.751075739658446, t);\\n p += fft(-271, 0.01618413446166483, -1.9240760733216773, t);\\n p += fft(374, 0.01597286278830038, 1.4727297170481586, t);\\n p += fft(245, 0.01595638314751546, -2.5020467251265117, t);\\n p += fft(492, 0.015955522695669654, -2.11250121739465, t);\\n p += fft(292, 0.015938735781863788, 2.8886197298108702, t);\\n p += fft(356, 0.015930093359693635, 3.119487581363237, t);\\n p += fft(-336, 0.01588376130850545, 0.28597008022586234, t);\\n p += fft(386, 0.01579744464348149, -0.6427892645860717, t);\\n p += fft(424, 0.015781071608576305, 0.06038150421307685, t);\\n p += fft(286, 0.015677276287429535, 2.6843830865968843, t);\\n p += fft(-439, 0.01566577624464125, -0.40437157307800353, t);\\n p += fft(-316, 0.015653156388410593, -0.49543109291627363, t);\\n p += fft(-480, 0.015631631437216433, 2.2355153900157636, t);\\n p += fft(400, 0.015537542523719335, -2.445474568008316, t);\\n p += fft(-447, 0.015437071879756518, 2.7865636796309072, t);\\n p += fft(366, 0.015353947913814526, 2.0058503224480564, t);\\n p += fft(-492, 0.015303110265234265, 2.3874477585758074, t);\\n p += fft(-445, 0.015280750696461273, 0.444334272791586, t);\\n p += fft(353, 0.015251950793442146, -2.7836080531188006, t);\\n p += fft(-500, 0.015226472622413946, -2.6103075874608708, t);\\n p += fft(-380, 0.015222967220547282, -2.881867749906817, t);\\n p += fft(506, 0.015150418703193842, 2.0075105204746566, t);\\n p += fft(-335, 0.015124331759979636, 1.009943322524843, t);\\n p += fft(483, 0.015097172526301886, 2.0959180943388027, t);\\n p += fft(240, 0.015078862676021213, -1.2930571972964564, t);\\n p += fft(-401, 0.01507870517510355, 2.715454154162096, t);\\n p += fft(449, 0.015061353079694497, 1.8733248116188075, t);\\n p += fft(412, 0.015050927296007339, 2.2976965232943307, t);\\n p += fft(323, 0.014984653022696854, -3.0935557999938292, t);\\n p += fft(-396, 0.014977404461351117, 0.30211159558289086, t);\\n p += fft(273, 0.01483460564366501, -1.4596850118087714, t);\\n p += fft(345, 0.014833234000572936, -0.32539675758169934, t);\\n p += fft(-417, 0.014811822655002693, -2.5447030635824297, t);\\n p += fft(-394, 0.014768485010995914, 0.8420120899555257, t);\\n p += fft(-326, 0.014757622857210374, -0.9559941626829623, t);\\n p += fft(-373, 0.01470773104483892, 2.794549031160765, t);\\n p += fft(340, 0.014690011817124374, -2.2126006109671352, t);\\n p += fft(-390, 0.014674589859169042, -0.9855117184354396, t);\\n p += fft(317, 0.014671770616686048, -0.4111710755329078, t);\\n p += fft(-308, 0.014630448864418246, -2.6132662944333247, t);\\n p += fft(-419, 0.014612974424031182, 1.890332423869268, t);\\n p += fft(472, 0.014573773093057102, -0.15746800733732982, t);\\n p += fft(257, 0.014541893370249208, -1.3953361182084414, t);\\n p += fft(436, 0.014503458130718185, 1.473439813394881, t);\\n p += fft(-218, 0.014473405505827206, -2.2614161401120723, t);\\n p += fft(-384, 0.014387460588666384, 0.4846527714087321, t);\\n p += fft(214, 0.014373508138361935, -0.9929984801205258, t);\\n p += fft(327, 0.014363924720838923, 0.6705953026310363, t);\\n p += fft(-443, 0.014247709886683415, 0.6588561068584213, t);\\n p += fft(216, 0.014201020492534005, 2.6741170951719297, t);\\n p += fft(278, 0.014195739673546514, 0.45380564178946164, t);\\n p += fft(474, 0.01417224313980241, -2.946490401046988, t);\\n p += fft(361, 0.014169743346048109, 0.7656558005070042, t);\\n p += fft(418, 0.014153025125774113, 0.6544601775463792, t);\\n p += fft(-204, 0.014098068158582331, 1.570589753704267, t);\\n p += fft(409, 0.01408416890434566, 0.5791110199136934, t);\\n p += fft(332, 0.014064077521337141, -1.96196450322835, t);\\n p += fft(-411, 0.014055381190387442, -2.1050532273937193, t);\\n p += fft(-504, 0.014042491970392819, -2.4507746476472416, t);\\n p += fft(-331, 0.014021056796023198, -0.9466573694669207, t);\\n p += fft(331, 0.01401815399131699, 2.9486255021269, t);\\n p += fft(381, 0.014006914694692865, -1.1186058737646056, t);\\n p += fft(291, 0.013994629362131503, 1.9007976843424446, t);\\n p += fft(330, 0.013949517263636396, -0.49986286341122593, t);\\n p += fft(312, 0.013936760778201074, 3.0721230148366017, t);\\n p += fft(417, 0.013934783414901307, -2.257422367097522, t);\\n p += fft(-337, 0.01391371567127865, 2.895113197666846, t);\\n p += fft(385, 0.013891315233703376, -1.1352978862346337, t);\\n p += fft(-435, 0.013873332760801304, -0.32090186205450033, t);\\n p += fft(-385, 0.013844120558174551, -3.119969137357533, t);\\n p += fft(315, 0.013828233021495205, -3.0524501599722305, t);\\n p += fft(-343, 0.01378875650901319, -0.6263451828356061, t);\\n p += fft(459, 0.013771797001534768, 1.3512327925116, t);\\n p += fft(319, 0.013701983237761646, -3.0552359101211772, t);\\n p += fft(-421, 0.013685546780447071, 0.6168243016650519, t);\\n p += fft(307, 0.013681679811588384, -0.8864069492779628, t);\\n p += fft(-477, 0.01367630727868223, 2.7521796191613754, t);\\n p += fft(-465, 0.013581831625402187, -1.220520995405941, t);\\n p += fft(326, 0.013574391629771329, -3.1202874287266082, t);\\n p += fft(360, 0.0135341266402344, 2.664064685853016, t);\\n p += fft(-377, 0.013529068169515567, 0.2646391557351839, t);\\n p += fft(-459, 0.013509914775589568, -1.0462062859265808, t);\\n p += fft(-436, 0.013509169672166503, 3.060808353213404, t);\\n p += fft(-442, 0.013378848325932797, -2.943169899395721, t);\\n p += fft(281, 0.013324886668795041, 0.7702604219139404, t);\\n p += fft(402, 0.013309784889240976, 3.0462417371183212, t);\\n p += fft(413, 0.0133092395072314, -2.5644879288039295, t);\\n p += fft(-289, 0.013200751727554779, -0.42679700259876185, t);\\n p += fft(484, 0.013164831415710608, 1.1147833223969785, t);\\n p += fft(401, 0.01310573625374175, -0.45440514371321855, t);\\n p += fft(277, 0.013041278781405874, 2.710518166070806, t);\\n p += fft(-349, 0.013024136574205064, 0.368816551131045, t);\\n p += fft(-346, 0.012977337347580263, -0.26417451603147596, t);\\n p += fft(420, 0.012845882619135234, 2.002998951036915, t);\\n p += fft(445, 0.01284579635338418, -2.0677013276140324, t);\\n p += fft(428, 0.01279398105157776, 1.2926796180614086, t);\\n p += fft(376, 0.01276786373111407, 1.9367911037174024, t);\\n p += fft(-376, 0.01272502179107737, -3.1282891850863908, t);\\n p += fft(-507, 0.012722242687719345, 1.8939443453134572, t);\\n p += fft(-294, 0.012712310194407102, -1.188628976570537, t);\\n p += fft(-415, 0.012670552135729969, -0.9868907915235011, t);\\n p += fft(-428, 0.012607664240827194, -0.031095597497390378, t);\\n p += fft(473, 0.012543542480353977, -3.0690769712824704, t);\\n p += fft(430, 0.012541336274083313, -2.048475426543982, t);\\n p += fft(-341, 0.012469363963888485, 1.1697948865306476, t);\\n p += fft(-509, 0.012466468154148012, 0.38059867841898043, t);\\n p += fft(-481, 0.01242592353445654, -1.913914863175826, t);\\n p += fft(-314, 0.01239765783707375, -2.1235472871525767, t);\\n p += fft(-313, 0.012376173120752695, 1.03944125297012, t);\\n p += fft(-471, 0.012345159783470094, 2.6516490082388215, t);\\n p += fft(-310, 0.012284310170666665, -2.1698685017205785, t);\\n p += fft(-300, 0.01227542981113322, -2.017710213505234, t);\\n p += fft(247, 0.012240477217121775, 0.41935200430886505, t);\\n p += fft(-466, 0.012240125520371849, 0.019480587267466563, t);\\n p += fft(503, 0.01222533405281694, 0.6840099173444322, t);\\n p += fft(200, 0.012220403742265044, 2.887981253820241, t);\\n p += fft(304, 0.012182539431900842, 2.632403848640596, t);\\n p += fft(-425, 0.01215230910385176, 0.8806489351275139, t);\\n p += fft(351, 0.01214911658400834, -2.451703539504316, t);\\n p += fft(404, 0.012113298811467181, -0.1782921248032119, t);\\n p += fft(-404, 0.012098227853860725, -1.9073495889414767, t);\\n p += fft(500, 0.01206287854228493, 1.0185472742352673, t);\\n p += fft(-499, 0.012052977984837707, -2.947829310783775, t);\\n p += fft(296, 0.01203564352441712, -2.5371259687889496, t);\\n p += fft(344, 0.012030880992025202, -1.5507150201535012, t);\\n p += fft(-490, 0.011980159644615596, -0.06316472136582, t);\\n p += fft(-352, 0.011969909686558968, -0.40224393964822713, t);\\n p += fft(-506, 0.01193447069907937, -1.174788671161676, t);\\n p += fft(268, 0.011916136745930814, 1.8609641665108294, t);\\n p += fft(456, 0.011855122323403295, -0.25549478912944407, t);\\n p += fft(477, 0.011851778387300449, -0.7824493403677418, t);\\n p += fft(258, 0.011823107744589997, 0.4702714456912564, t);\\n p += fft(504, 0.011813789783172548, -2.1593068285941017, t);\\n p += fft(285, 0.01180532967217003, 1.9107235273443852, t);\\n p += fft(294, 0.011771073591615677, -3.0221374579820486, t);\\n p += fft(-340, 0.011737380405027845, -0.09560932985103796, t);\\n p += fft(-412, 0.011693563396162478, 0.03547230271148827, t);\\n p += fft(-473, 0.01167087995314407, -2.983087290342926, t);\\n p += fft(-381, 0.011633614975664468, 0.05696443428106514, t);\\n p += fft(423, 0.011627989857404918, 0.07675195602888493, t);\\n p += fft(-324, 0.01161418553014038, -2.471424070407224, t);\\n p += fft(399, 0.011577011391338602, 0.8371784427311489, t);\\n p += fft(-478, 0.011557125479527306, -2.2282000740788677, t);\\n p += fft(283, 0.011531997122870051, -0.7010609826477285, t);\\n p += fft(511, 0.0114760434011943, 1.734049648533497, t);\\n p += fft(279, 0.011460842192281833, 1.4668325872315813, t);\\n p += fft(447, 0.011454898078003161, -0.13946735136066804, t);\\n p += fft(-485, 0.011428486636959046, 0.34886175616311715, t);\\n p += fft(-472, 0.011389433654382263, 0.45069667769887467, t);\\n p += fft(-505, 0.011374024792638228, -0.16038515681074883, t);\\n p += fft(496, 0.011367209747096613, -0.5789335748725059, t);\\n p += fft(287, 0.011353094401163121, -2.6544713993331595, t);\\n p += fft(-476, 0.011339897348846054, 2.760999701731875, t);\\n p += fft(-203, 0.011246318318210755, -2.655330740012455, t);\\n p += fft(-298, 0.011240592231092321, -0.8535304917183064, t);\\n p += fft(435, 0.011199052278348127, -2.221842104143809, t);\\n p += fft(-397, 0.011179697495765209, 1.9050162197469025, t);\\n p += fft(339, 0.011177696172867731, -1.5279335419082853, t);\\n p += fft(314, 0.01113945595405601, -2.665298378120776, t);\\n p += fft(408, 0.011075489731786133, -1.6517945429682814, t);\\n p += fft(446, 0.01101171854080183, -0.48257443448194115, t);\\n p += fft(-333, 0.011005844536439355, -2.23571436410032, t);\\n p += fft(450, 0.01098336159814381, -2.3282935745461235, t);\\n p += fft(-293, 0.010866838807767636, -2.08175340759797, t);\\n p += fft(336, 0.010820760748971349, 1.7112356086996947, t);\\n p += fft(414, 0.010787409392539691, 2.807079317517186, t);\\n p += fft(-318, 0.010742470447882757, 2.8752872175583497, t);\\n p += fft(406, 0.010725007874053354, 3.063825957806161, t);\\n p += fft(-413, 0.010690874318868027, -3.119832148809836, t);\\n p += fft(415, 0.010685727067395259, 0.8983819808171652, t);\\n p += fft(-503, 0.010659993246209611, 0.3133119607095941, t);\\n p += fft(-355, 0.010621606166054188, -2.3472131268696774, t);\\n p += fft(-281, 0.01061443706876594, -0.7561374672674868, t);\\n p += fft(-366, 0.010605967113792601, -2.711774616807628, t);\\n p += fft(-479, 0.010586221430330002, -2.5484256879947855, t);\\n p += fft(-426, 0.010490344441220769, 1.0668022268161381, t);\\n p += fft(-405, 0.010385062881632077, 2.306115157954148, t);\\n p += fft(-290, 0.010384484051949614, -2.2711503576547094, t);\\n p += fft(364, 0.010311227119556366, 1.3569201451071267, t);\\n p += fft(239, 0.01030448004807976, -1.9386533731670805, t);\\n p += fft(-424, 0.010283240609725826, 0.8760921385535031, t);\\n p += fft(338, 0.010272254653901589, -1.0871306303800126, t);\\n p += fft(-482, 0.01024776632548479, -0.6515462866676507, t);\\n p += fft(-494, 0.01024564906483858, 2.395078651689155, t);\\n p += fft(-236, 0.010162897249939504, 1.9785592807626329, t);\\n p += fft(494, 0.010150992333137729, -0.01780121101171699, t);\\n p += fft(233, 0.010096455886289615, -2.5741668393876806, t);\\n p += fft(192, 0.010084734213336314, -0.8855447372541574, t);\\n p += fft(-234, 0.010056081638657548, 1.9417984487245914, t);\\n p += fft(-266, 0.010020076168818585, -0.561779230785278, t);\\n*/\\n return (p + vec2(-250, -150)) * 0.01 /* center and scale */\\n ;\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 640.0;\\n float pointsPerCircle = segmentsPerCircle * 2.0;\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n \\n float vId = mod(vertexId, pointsPerCircle);\\n float cId = floor(vertexId / pointsPerCircle);\\n float cv = cId / numCircles;\\n float u = floor(vId / 2.0) + mod(vId, 2.0);\\n float v = u / segmentsPerCircle;\\n float a = v * PI * 2.0 + cv;\\n\\n vec2 p = computeFFT(v + time + cv);\\n \\n float distFromCenter = length(p);\\n\\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.1, abs(v * 2. - 1.)),\\n cv * 0.2)).r;\\n float s2 = texture2D(sound, vec2(0.1, cv*0.1)).r;\\n \\n vec3 pos = vec3(p, 0); \\n \\n \\n float ct = time * 0.3;\\n vec3 eye = vec3(vec2(sin(ct), cos(ct)) * 2.5, -5.0);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 250.); \\n mat *= cameraLookAt(eye, target, up);\\n //mat *= trans(vec3(computeFFT(cv + time), 0));\\n mat *= trans(vec3(0, 0, cv * 2. - 1.) * 0.3);\\n mat *= rotZ(PI + pow(s, 5.0) * 0.2 - 0.1);\\n mat *= uniformScale(mix(0.9, 1.2, pow(s, 5.0)) + s2);\\n gl_Position = mat * vec4(pos, 1);\\n\\n\\n float boost = step(0.7, s);\\n \\n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\\n float sat = 1.0;1.0 - pow(pos.z, 1.) - pow(s, 4.);\\n float val = sin(v) * 0.5 + 0.5;mix(0.25, 2.0, pow(s, 2.));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n} //utter madness\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/moods-grooves-records/phaze-dee-game-of-life-web", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25882352941176473, + 0.25882352941176473, + 0.25882352941176473, + 1 + ], + "shader": "// data from https://github.com/Jezzamonn/fourier\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec2 fft(int freq, float amplitude, float phase, float time) {\n float angle = PI * 2.0 * float(freq) * time + phase;\n return vec2(cos(angle), sin(angle)) * amplitude;\n}\n\nvec2 computeFFT(float t) {\n vec2 p = vec2(0);\n p += fft(0, 296.524077607952, 0.5328692201872761, t);\n p += fft(1, 129.16512258296828, -2.90016335218518, t);\n p += fft(-1, 63.77796615668684, 2.9224545501551584, t);\n p += fft(3, 19.64466960507052, -2.4341521827648407, t);\n p += fft(2, 15.225563957670408, 2.1065920733999985, t);\n p += fft(4, 10.816890879510945, 2.768243749294925, t);\n p += fft(6, 7.7798714613757785, 2.790776515902791, t);\n p += fft(8, 6.679135366586027, -2.691421192706561, t);\n p += fft(18, 6.618481262601785, -2.7811427287619805, t);\n p += fft(-17, 6.194427860122354, 1.0295557956864945, t);\n p += fft(-20, 6.068497179066321, 2.0845633129083545, t);\n p += fft(13, 6.026155883530845, -2.9082280887418843, t);\n p += fft(20, 5.87547467169867, 0.6567893346845978, t);\n p += fft(12, 5.664082795931505, -0.7736185409154058, t);\n p += fft(22, 5.504599257383946, -0.5566360694751388, t);\n p += fft(-22, 5.146718591504782, -2.7391457150277336, t);\n p += fft(-19, 4.967122293367857, -1.4319471520699776, t);\n p += fft(-11, 4.537800748903001, 0.7806248091011616, t);\n p += fft(16, 4.409897469465315, 2.5618942112767407, t);\n p += fft(-25, 4.3819383386473865, -1.5151030062564892, t);\n p += fft(-16, 4.149297744113447, 0.575845737238003, t);\n p += fft(-12, 4.139174393444163, 2.982857273406526, t);\n p += fft(-34, 4.07501017913087, 1.5981185989542064, t);\n p += fft(-8, 4.074809962485297, -0.42486073575722444, t);\n p += fft(5, 4.0206048747056125, -2.3082375418458945, t);\n p += fft(11, 3.990542905551988, 2.3627881868284972, t);\n p += fft(17, 3.955727644969372, 2.456663236004692, t);\n p += fft(19, 3.8658362150758534, -1.6701042175865948, t);\n p += fft(10, 3.8517952416210557, -1.9882991837519308, t);\n p += fft(25, 3.8215186298010257, -0.9536339281017274, t);\n p += fft(-6, 3.6465818944687634, -0.4459221391524853, t);\n p += fft(-29, 3.2133268799952712, 2.9249873354735345, t);\n p += fft(-13, 3.172984702723984, -0.25267920294558227, t);\n p += fft(15, 3.1374261306697373, 2.4403069911326685, t);\n p += fft(7, 3.0955422513620245, -1.711872929589281, t);\n p += fft(-9, 2.880155339148816, 0.32676693145089336, t);\n p += fft(-15, 2.8798999832519403, 0.9375984752072446, t);\n p += fft(26, 2.79967174195265, -2.049901239880178, t);\n p += fft(29, 2.7803332403386336, 0.5231959777340147, t);\n p += fft(28, 2.7414647126009593, 0.4708642708868981, t);\n p += fft(41, 2.6437612024221844, -2.9636977093225685, t);\n p += fft(39, 2.6295641656754234, -2.277801278923058, t);\n p += fft(27, 2.6183263816781324, 2.784381034343638, t);\n p += fft(-4, 2.612279805775902, 1.1701981679810707, t);\n p += fft(34, 2.5896488928989925, 0.8874838650026977, t);\n p += fft(-18, 2.568509187236616, -0.9803167206473404, t);\n p += fft(-28, 2.507964971759851, 3.026960979082897, t);\n p += fft(-14, 2.4945338840886677, -0.18814398163405743, t);\n p += fft(-3, 2.4553487715159696, -2.515704298686429, t);\n p += fft(-10, 2.347972482924663, -0.9661461748548102, t);\n p += fft(9, 2.3353227667810943, 2.6662410983119873, t);\n p += fft(-27, 2.2841877482065778, 0.6357945200731572, t);\n p += fft(-33, 2.2359717418821874, -2.6756775052827853, t);\n p += fft(37, 2.0731181353939196, -2.8767957104561597, t);\n p += fft(43, 2.046908477381298, -0.848325445419195, t);\n p += fft(40, 1.9650400072060998, 1.4954865245732736, t);\n p += fft(31, 1.920647139346876, -0.8820561267540269, t);\n p += fft(-37, 1.8264609429322551, -0.6283518255686783, t);\n p += fft(-30, 1.8191188807994465, -2.078648696472338, t);\n p += fft(-21, 1.7570644633051382, 2.614905728603112, t);\n p += fft(24, 1.7380651990304348, 1.797588764641598, t);\n p += fft(44, 1.6560026933156917, 0.27276010910919374, t);\n p += fft(-44, 1.649213368528592, -2.697758361982687, t);\n p += fft(-32, 1.6482613051000077, 1.7281181963111363, t);\n p += fft(-38, 1.5957955338176892, 3.0229778848579327, t);\n p += fft(50, 1.594057606604889, -2.705446593070425, t);\n p += fft(33, 1.5853686682207064, -0.5898590645559981, t);\n p += fft(-26, 1.567072721585987, -0.6245687779647491, t);\n p += fft(23, 1.5345223856234949, -2.2815578356210735, t);\n p += fft(36, 1.5087867231807512, -0.5742399182534951, t);\n p += fft(-24, 1.4664813474877614, 2.7549795210299215, t);\n p += fft(57, 1.4430652246678877, 2.1241473623512697, t);\n p += fft(32, 1.406056560977162, 2.4473930566249096, t);\n p += fft(54, 1.397187168634832, -1.5290316283596388, t);\n p += fft(-35, 1.378962288401975, 1.030170830294626, t);\n p += fft(-51, 1.3443697534460952, 0.7824834836125082, t);\n p += fft(38, 1.2073849482228887, -1.417621395841823, t);\n p += fft(52, 1.1813148530266455, -2.7146718708831226, t);\n p += fft(58, 1.1546285984367923, -2.0469226839957546, t);\n p += fft(-2, 1.148242184394193, 1.1600574990999488, t);\n p += fft(-49, 1.1389035886326317, 2.536779536914916, t);\n p += fft(14, 1.1329760186659397, 3.040831768189552, t);\n p += fft(45, 1.1260078033316239, -2.6485676515902887, t);\n p += fft(-36, 1.0505189643915007, 1.1512408246664814, t);\n p += fft(48, 1.0434710403748044, -1.587473666465379, t);\n p += fft(35, 1.0264643367771464, 0.8533152135907922, t);\n p += fft(-77, 0.9957083595939865, 2.3018398053793176, t);\n p += fft(-50, 0.9539520583808928, -1.8737321231607105, t);\n p += fft(-23, 0.9292718478810791, -1.6156932158409079, t);\n p += fft(-43, 0.9257761649922747, -0.9528711445133002, t);\n p += fft(-46, 0.868581952908317, -1.7531859162182506, t);\n p += fft(-47, 0.8477347332294584, 1.5654529539919164, t);\n p += fft(-45, 0.8130585468017898, -0.6663785358206237, t);\n p += fft(60, 0.7908050200984377, -0.1023181049126883, t);\n p += fft(62, 0.7872325903381513, 1.030198597230489, t);\n p += fft(-48, 0.7858142817398769, 1.387565504131415, t);\n p += fft(49, 0.7704030031060537, 2.627354289464034, t);\n p += fft(-84, 0.7688630997732272, -2.564222992505424, t);\n p += fft(-39, 0.761830091495416, -2.4526438973987954, t);\n p += fft(78, 0.7543732213279061, 2.343001847272033, t);\n p += fft(-59, 0.7488095838105383, -3.1131016762144443, t);\n p += fft(55, 0.7285003537607938, -0.9786713526593741, t);\n p += fft(-31, 0.7248134830134255, -0.5543123381122909, t);\n p += fft(-54, 0.7219542814654896, 2.94943367544441, t);\n p += fft(-53, 0.7139986380620472, -1.2338229580467204, t);\n p += fft(46, 0.6985299047036991, -0.3033719700149987, t);\n p += fft(69, 0.6940778952546749, -1.0238518940571633, t);\n p += fft(-40, 0.6927457316683343, 2.0054202454179775, t);\n p += fft(-57, 0.67709432212438, -2.783806233466308, t);\n p += fft(47, 0.6602293673831037, 1.1829982386683053, t);\n p += fft(74, 0.6545825289163747, -0.6313191364037845, t);\n p += fft(-5, 0.6200531105206556, -1.012708917351053, t);\n p += fft(30, 0.6145303942405808, -0.006575553587373788, t);\n p += fft(-65, 0.6130907552103994, -1.2775992452682625, t);\n p += fft(83, 0.6078433173163771, -1.3921353502568135, t);\n p += fft(53, 0.6029346402536699, 3.118126806639058, t);\n p += fft(64, 0.593655747614559, -0.12929981693431084, t);\n p += fft(87, 0.5917638000158103, 2.8165282828931195, t);\n p += fft(75, 0.562070427870424, 2.935821150408132, t);\n p += fft(51, 0.553965684266993, 0.8857804427580288, t);\n p += fft(-69, 0.5402011495014111, -2.393077154815434, t);\n p += fft(-67, 0.5247046263885512, -0.12626924765950584, t);\n p += fft(80, 0.5211530645039045, -2.313552855619569, t);\n p += fft(56, 0.5057370766773879, -2.628846336188085, t);\n p += fft(-75, 0.5038585813938068, -1.8904143929736488, t);\n p += fft(-73, 0.48644277854405304, 1.3709055508801584, t);\n p += fft(-7, 0.47307925137425644, -2.55202847874333, t);\n p += fft(94, 0.4614308523932489, 2.545636098697929, t);\n p += fft(-74, 0.4419918759755517, 0.11529437409844774, t);\n p += fft(65, 0.44169553192805927, 2.439841086433652, t);\n p += fft(72, 0.43611612862779375, 0.9074545441173122, t);\n p += fft(-66, 0.43502792411907976, -2.063079991837712, t);\n p += fft(-42, 0.4314569651112275, 0.33687123321689777, t);\n p += fft(-64, 0.40521665336797635, 0.003486215133649564, t);\n p += fft(99, 0.40417092365602253, -1.8240004200677489, t);\n p += fft(59, 0.3936963912394369, -1.6362215309246326, t);\n p += fft(-60, 0.3815954958269982, -0.7754496988180308, t);\n p += fft(-63, 0.3792381066868484, -1.9391548308871835, t);\n p += fft(73, 0.37854582778783324, 0.043442146165603684, t);\n p += fft(42, 0.37453717681808335, 2.38737562405369, t);\n p += fft(21, 0.35583878846131595, -2.7839176861684014, t);\n p += fft(112, 0.3547233494213232, 2.954248286045894, t);\n p += fft(108, 0.35083273251102737, 2.5458627704061483, t);\n p += fft(93, 0.35040473622512436, -0.029550910229384195, t);\n p += fft(89, 0.3403049133299473, -2.885129447081889, t);\n p += fft(-70, 0.3370256731757577, -0.46771663832106974, t);\n p += fft(-78, 0.3366544726218109, -0.24724720507658238, t);\n p += fft(82, 0.32610868403027304, -1.4954241039751592, t);\n p += fft(-91, 0.32419682164009966, -1.3417496079852937, t);\n p += fft(-90, 0.3234753025960112, -3.0133578986946814, t);\n p += fft(-80, 0.2998816486209547, 3.096207886158368, t);\n p += fft(71, 0.2984964350635909, -0.6377008416229164, t);\n p += fft(85, 0.2961360685518227, 2.9392297581041658, t);\n p += fft(111, 0.2939868074077519, 1.066357674174694, t);\n p += fft(84, 0.2882922892341542, -0.2824472092836136, t);\n p += fft(-62, 0.2823355494458707, 0.5392478382746477, t);\n p += fft(101, 0.28043862110007006, 1.8969467658422987, t);\n p += fft(-58, 0.27927463219687665, -2.5066886208410595, t);\n p += fft(-114, 0.2787101344869982, -2.3945575768789205, t);\n p += fft(-81, 0.27344747273177633, 0.19849972308144362, t);\n p += fft(96, 0.268848539128237, 2.352065707231053, t);\n p += fft(104, 0.2667328677077002, -2.6894745409478773, t);\n p += fft(90, 0.2623194708267266, 2.6305846168436604, t);\n p += fft(105, 0.2587320115138661, -0.44809280212853925, t);\n p += fft(91, 0.25666403259093135, -0.42872274693200485, t);\n p += fft(-94, 0.25344187481961844, -1.1325746386338256, t);\n p += fft(67, 0.24928071126959497, 1.783113342037483, t);\n p += fft(-61, 0.2486431701299056, -3.0289630409059964, t);\n p += fft(-102, 0.24833449653800949, 2.814031321792728, t);\n p += fft(115, 0.24216361168985745, 2.5259661057434784, t);\n p += fft(-83, 0.24082180762961733, 2.327373899411901, t);\n p += fft(-71, 0.2404736569240409, 2.8270765856325983, t);\n p += fft(-95, 0.23819976781292496, 0.25934694371445854, t);\n p += fft(128, 0.23600151920093423, -2.2635194564211036, t);\n p += fft(-82, 0.23162812218159617, -0.40811639028183505, t);\n p += fft(63, 0.231108841604306, 0.7896297030534211, t);\n p += fft(66, 0.22876820962806374, -2.20689386652509, t);\n p += fft(145, 0.22683296568648012, -2.871130626679519, t);\n p += fft(114, 0.22579541537273998, -0.03888650023606557, t);\n p += fft(-115, 0.22449806848298495, 1.7267840321105514, t);\n p += fft(-101, 0.2201367259955669, -1.2160405006932076, t);\n p += fft(70, 0.21924416034549526, -1.8300948469474085, t);\n p += fft(-41, 0.2167988567102195, -0.8439248313023797, t);\n p += fft(110, 0.21645852077265354, -0.959164313163234, t);\n p += fft(158, 0.2151250144734518, 1.0174468948847888, t);\n p += fft(106, 0.21196244851082488, -0.7429833668933534, t);\n p += fft(-137, 0.20545059106326097, 2.8523980589526516, t);\n p += fft(-99, 0.20544620480189876, 2.378277723073504, t);\n p += fft(157, 0.20466861943591227, 1.5525202358047085, t);\n p += fft(-97, 0.20297792194129058, -0.24324542189056148, t);\n p += fft(168, 0.20130500227008466, -1.094673594091641, t);\n p += fft(117, 0.19993871414763503, 2.850736702421766, t);\n p += fft(98, 0.19737263515643355, 0.5877762863368731, t);\n p += fft(-72, 0.1929911058483345, 0.010089217287886454, t);\n p += fft(107, 0.19264056832987778, 0.704220700877197, t);\n p += fft(-112, 0.19130748611122012, -2.392875008529597, t);\n p += fft(-89, 0.1896856318579048, -1.952634273837995, t);\n p += fft(-118, 0.1840849374841271, 2.66760266379526, t);\n p += fft(-106, 0.1831571823504252, -0.22353534215395926, t);\n p += fft(68, 0.18268583480820008, -1.6209797108511708, t);\n p += fft(-55, 0.18120542886859284, 0.467068135124605, t);\n p += fft(95, 0.17907416077732574, 1.0948396281940986, t);\n p += fft(148, 0.17866061557325139, 2.3602934407666574, t);\n p += fft(177, 0.17832736193972554, -1.6046679924839198, t);\n p += fft(-108, 0.17809221310240264, -1.3634658504175172, t);\n p += fft(-98, 0.17770123200232602, -2.319713221578887, t);\n p += fft(100, 0.176886631202939, -1.121794475824346, t);\n p += fft(124, 0.17654047192131325, -2.379198871802532, t);\n p += fft(-88, 0.17639283951454524, -2.402190307443758, t);\n p += fft(-174, 0.1759528058963321, -2.2025378411458227, t);\n p += fft(140, 0.1753854668907291, 0.42397843457703155, t);\n p += fft(-96, 0.1753429914194849, -2.5609307243169104, t);\n p += fft(86, 0.17047016491561567, -2.1287646574123906, t);\n p += fft(-116, 0.16955079792541142, 1.330523857460539, t);\n p += fft(61, 0.16905959469199813, -2.6057097347432614, t);\n p += fft(-121, 0.1688420653965695, -0.5090905584523955, t);\n p += fft(155, 0.16680443183652535, -1.2332547487780734, t);\n p += fft(171, 0.16582399968407263, -0.8747323409363787, t);\n p += fft(-87, 0.1652225600618143, -2.085937535924309, t);\n p += fft(-131, 0.16214898761358187, 1.9650981796384732, t);\n p += fft(92, 0.15699998077784863, -0.18853113336883437, t);\n p += fft(166, 0.1554844992569468, 2.2850556504133888, t);\n p += fft(161, 0.15373402046283416, -0.7486102426340269, t);\n p += fft(144, 0.15312278232769228, -0.3587853130578195, t);\n p += fft(125, 0.15278331508565252, 0.6417517362772722, t);\n p += fft(97, 0.15144010052991969, 1.0282568217837087, t);\n p += fft(135, 0.15129294602934487, -0.6387137369146754, t);\n p += fft(-56, 0.1457904354443015, 2.356685746244658, t);\n p += fft(103, 0.1453915874749691, -0.6785631327279983, t);\n p += fft(146, 0.14379520492495512, -0.7855888994349319, t);\n p += fft(142, 0.1412707218042313, -0.1618563085599607, t);\n p += fft(126, 0.13936676935400355, -2.4453404815078725, t);\n p += fft(81, 0.13772359181353372, 0.5044424044942989, t);\n p += fft(163, 0.13762314582762275, 1.639822161059763, t);\n p += fft(134, 0.13545232146341332, 2.3024168785102312, t);\n p += fft(165, 0.13509475913506178, -0.8279398617821645, t);\n p += fft(-76, 0.13455680964642944, -3.0716219607883164, t);\n p += fft(-127, 0.13207374762677063, -2.6599668223479727, t);\n p += fft(-152, 0.13117632063169987, -2.5293527274604246, t);\n p += fft(-105, 0.1311202673313172, -2.693197028055788, t);\n p += fft(-145, 0.12945158970649637, 2.3951255425463125, t);\n p += fft(119, 0.12925458048582072, 2.1883428437365144, t);\n p += fft(132, 0.12746981347132513, -3.033026520788066, t);\n p += fft(-85, 0.12653240774860508, -2.8680500174257837, t);\n p += fft(-144, 0.12465405936107726, -0.37790452498667604, t);\n p += fft(76, 0.12463110048880623, 0.12012177237288406, t);\n p += fft(-142, 0.12459485706573038, 0.3051081828140754, t);\n p += fft(-138, 0.12451331383970095, 0.584148256098649, t);\n p += fft(149, 0.12401784752155019, -1.8125703421505832, t);\n p += fft(-147, 0.12362040139712106, 0.03028190421886324, t);\n p += fft(131, 0.12297013103130192, -1.7612969157441667, t);\n p += fft(-148, 0.12201071321640686, -2.0282746264394236, t);\n p += fft(-68, 0.12130140373799272, -0.9290611617024176, t);\n p += fft(116, 0.12128775362324593, -1.5007597875190253, t);\n p += fft(-135, 0.12111941530251287, -0.9133882438391181, t);\n p += fft(-104, 0.12079045102618642, 0.9539883001598056, t);\n p += fft(-86, 0.12063181239660088, -1.9105367933076451, t);\n p += fft(102, 0.11858318427484749, 3.116549695906647, t);\n p += fft(162, 0.11672334871059657, -0.43512865812715645, t);\n p += fft(-128, 0.11555594493778179, 1.594914753823693, t);\n p += fft(147, 0.11507078486852833, -1.8015902273798317, t);\n p += fft(-125, 0.11380569936104315, -0.02432076846797433, t);\n p += fft(-129, 0.1137850317216325, -2.6266191242164822, t);\n p += fft(77, 0.11284625921171428, 0.6500879168724161, t);\n p += fft(159, 0.11039859551711936, -2.8651146672170977, t);\n p += fft(-206, 0.10898089539528502, 1.0381666149725348, t);\n p += fft(-92, 0.10835773802225089, 0.6916172775229433, t);\n p += fft(127, 0.10811810875499965, -2.998228956999233, t);\n p += fft(-199, 0.10803687786223723, -2.46851901448902, t);\n p += fft(-184, 0.1079436817269362, 1.3191475812437883, t);\n p += fft(-161, 0.10743289221697289, 1.3169047201119328, t);\n p += fft(-139, 0.10723255868931553, -1.7855768275688515, t);\n p += fft(-130, 0.10575112607516497, 1.2885726884003454, t);\n p += fft(-198, 0.10555774123223534, 2.3378343445027423, t);\n p += fft(88, 0.1037982678523408, -2.57743331926905, t);\n p += fft(-219, 0.10310221059641228, -1.2625859044047876, t);\n p += fft(-103, 0.10235558593739706, 0.7768959419271573, t);\n p += fft(-201, 0.10189587875806011, 2.395004608187347, t);\n p += fft(174, 0.10047600105014917, -1.7769904121389015, t);\n p += fft(113, 0.10019192995096364, 0.6613060769884679, t);\n p += fft(186, 0.09888320495036292, 2.4232322332757033, t);\n p += fft(143, 0.09873568608937729, -0.6230636594392547, t);\n p += fft(-155, 0.0967869591188688, -1.7298363196681086, t);\n p += fft(185, 0.09658335995961313, 1.1754529148166517, t);\n p += fft(-177, 0.09656910791483884, 2.0163242572983346, t);\n p += fft(-167, 0.09620604020928483, 2.643429513987398, t);\n p += fft(170, 0.09573558303359174, -0.30695931132003684, t);\n p += fft(180, 0.09461328604462575, -1.6239251039930218, t);\n p += fft(-220, 0.0943272029181478, -1.4319742082110574, t);\n p += fft(-52, 0.09420059423208178, 0.34189504423155104, t);\n p += fft(-172, 0.09359535175565478, -0.6516984922913376, t);\n p += fft(-110, 0.0928047006450446, 1.6652587522465396, t);\n p += fft(151, 0.09250606338361644, -1.9756734220597145, t);\n p += fft(-93, 0.09207328457476618, -1.8386442351917063, t);\n p += fft(-136, 0.09192815271017309, 1.7852892175474182, t);\n p += fft(-113, 0.09189336119191194, 0.1795575241258869, t);\n p += fft(195, 0.09021546713204244, 2.2961250797130024, t);\n p += fft(-150, 0.0890214588284327, -0.4242294361284968, t);\n p += fft(-193, 0.08814677822860856, -3.032675290767406, t);\n p += fft(172, 0.08787933668637724, 0.8937743898253856, t);\n p += fft(-132, 0.08776566211120278, 1.6786784797215824, t);\n p += fft(120, 0.08739819001501205, 2.0491345267796923, t);\n p += fft(-237, 0.08676446852578372, -2.7506065977853367, t);\n p += fft(-195, 0.08631820577015377, -2.292066178728447, t);\n p += fft(-178, 0.08621869133141169, -2.289445548826154, t);\n p += fft(-160, 0.0859070990539687, 0.8565575603400595, t);\n p += fft(169, 0.08564275849176227, 1.4922004704741865, t);\n p += fft(150, 0.08528562752062617, -2.271332020864171, t);\n p += fft(136, 0.08341789857084404, 1.0652798481992052, t);\n p += fft(199, 0.08332375555828694, -2.172498972819133, t);\n p += fft(-235, 0.08327425440106223, -0.8722079224698919, t);\n p += fft(-141, 0.08287851144036412, -0.2817694914314737, t);\n p += fft(138, 0.08255129464089862, 2.481725429548499, t);\n p += fft(-109, 0.0814238813994593, 2.810607915964862, t);\n p += fft(-79, 0.08115343666484522, 3.0130919888081964, t);\n p += fft(153, 0.0806615747018418, -2.90631621064385, t);\n p += fft(-175, 0.0803741234494402, 2.4278323040306384, t);\n p += fft(-143, 0.07972332355377411, -0.14610097282743986, t);\n p += fft(-202, 0.07962980675194098, -0.2920969138999907, t);\n p += fft(-120, 0.07894459678944289, -1.0822564599135749, t);\n p += fft(-249, 0.07849391554379236, -1.5893682918262941, t);\n p += fft(156, 0.07754124056908816, 2.6380926428153773, t);\n p += fft(-158, 0.07639110613035878, -2.2498824982419814, t);\n p += fft(191, 0.07543660088489744, 1.53576512075985, t);\n p += fft(133, 0.07531833041051382, -0.29986287547697626, t);\n p += fft(-176, 0.07501869195137476, -1.095228282011871, t);\n p += fft(-173, 0.07438185135275685, -2.8547930590312265, t);\n p += fft(-246, 0.07320459577858625, 3.004959078587308, t);\n p += fft(-163, 0.07264231502260868, 0.5663326139154473, t);\n /* ------ move this line up for more speed, down for more precision ----------\n p += fft(206, 0.07185257960899775, -1.2074544409708887, t);\n p += fft(-123, 0.07180358234742663, 1.177001822427382, t);\n p += fft(164, 0.07179115512969167, 2.1602573633251723, t);\n p += fft(188, 0.07150545575062967, 1.7193031745778165, t);\n p += fft(224, 0.06999271922532711, -2.208456590100925, t);\n p += fft(-194, 0.06998312687642928, -2.18523653052791, t);\n p += fft(79, 0.06890472640127111, 1.3075753662847636, t);\n p += fft(109, 0.06860075505611797, 1.6822381082814495, t);\n p += fft(-212, 0.0678853204605727, 2.1130583033793853, t);\n p += fft(160, 0.06721168671629134, 1.5355417936258289, t);\n p += fft(-168, 0.06478428292880746, 1.8082125748786089, t);\n p += fft(-100, 0.06418217011920442, 0.7154587151883682, t);\n p += fft(-208, 0.06360704141059366, -2.403277839995585, t);\n p += fft(137, 0.06324033312067673, -2.2610437967492656, t);\n p += fft(123, 0.06295636338637589, 0.3970547395559689, t);\n p += fft(-196, 0.0627324819432708, -2.6051526033441235, t);\n p += fft(219, 0.06250233205660669, 2.203023925786526, t);\n p += fft(-185, 0.0621114667768006, -0.5698975168684676, t);\n p += fft(-166, 0.06210684036807704, 2.607205641731383, t);\n p += fft(-205, 0.06175529499391064, 1.9171825820936816, t);\n p += fft(-156, 0.061488097661469475, 1.4966065847312549, t);\n p += fft(154, 0.061272027059191166, -2.6984551455468564, t);\n p += fft(-231, 0.06035266134446573, 1.3615530640708646, t);\n p += fft(141, 0.05955849823049297, 1.5515335051172228, t);\n p += fft(-254, 0.05936948658056223, 0.08947841208696573, t);\n p += fft(-223, 0.05924934830234196, -2.5888981145084804, t);\n p += fft(-232, 0.05887059032744145, 0.01941763325695256, t);\n p += fft(167, 0.05881968845436434, -1.0357803375284511, t);\n p += fft(193, 0.058152494480082216, -0.4725096726740279, t);\n p += fft(121, 0.05729621516472733, 1.7676238462353928, t);\n p += fft(-268, 0.05725394282425765, -2.613958061844803, t);\n p += fft(-302, 0.05709087761847913, 1.7622838278216528, t);\n p += fft(-169, 0.05703481887597677, -0.6061202003738857, t);\n p += fft(-228, 0.05673330948726983, 1.5024729233397405, t);\n p += fft(222, 0.05638702685887402, -1.2302130026999638, t);\n p += fft(-260, 0.05595371621472635, 1.2791472131268498, t);\n p += fft(211, 0.05588512333449684, -1.8863675524330432, t);\n p += fft(237, 0.05577640817605678, 0.9044485733453621, t);\n p += fft(-210, 0.055436889934911734, -2.17570469763129, t);\n p += fft(-107, 0.054515606954931885, 1.6064878994455691, t);\n p += fft(-192, 0.054378774601921455, 0.177220838503605, t);\n p += fft(-182, 0.053953358377995975, -2.1280204079638576, t);\n p += fft(-263, 0.0538060156192732, -1.6125700112210792, t);\n p += fft(212, 0.05372692488622374, 0.9420856343907927, t);\n p += fft(-213, 0.053418601872005124, 2.7878022389569965, t);\n p += fft(-248, 0.05287392885207208, 0.18442109948336485, t);\n p += fft(226, 0.05219567026185329, -1.9364295452150295, t);\n p += fft(198, 0.05216791125481548, -1.3500769286288878, t);\n p += fft(-282, 0.05185758906196177, -1.0531164762937948, t);\n p += fft(-111, 0.051505065799642175, -1.5496533180287155, t);\n p += fft(-241, 0.05085304364706675, -0.46354003864012305, t);\n p += fft(-124, 0.05032731737587234, -0.9525802310682452, t);\n p += fft(-250, 0.050246365262025194, 0.8026967297965477, t);\n p += fft(-211, 0.05012936662149643, 0.7247623593388082, t);\n p += fft(-209, 0.05002408512494514, 1.8132755265361036, t);\n p += fft(-252, 0.049775105705583016, 0.5996942868760795, t);\n p += fft(223, 0.04939534137917373, -2.695791674918428, t);\n p += fft(122, 0.04894575970718128, 2.8830421586085544, t);\n p += fft(-153, 0.04887699031380359, 0.3334054103895581, t);\n p += fft(-181, 0.047900428231714746, -2.21806751268122, t);\n p += fft(299, 0.04768730955214819, 0.3243053297596023, t);\n p += fft(-259, 0.04760097318206576, -0.8705493020585283, t);\n p += fft(-227, 0.04622658586057274, 1.2806504451219154, t);\n p += fft(-226, 0.04575599938137761, 2.99718633620427, t);\n p += fft(-165, 0.04562578928136969, -0.9599207008754989, t);\n p += fft(-119, 0.0452353353928757, -2.8588596616336357, t);\n p += fft(-151, 0.04518238397772298, -0.13718441224107195, t);\n p += fft(-255, 0.04513692897501351, 1.860335619309556, t);\n p += fft(173, 0.04502237604956329, -0.810579987098727, t);\n p += fft(-164, 0.04491854079446375, -2.2251696607200238, t);\n p += fft(367, 0.04463225444542998, -1.3682718846259723, t);\n p += fft(-238, 0.044492812350265004, -1.30018967859005, t);\n p += fft(213, 0.04433393493985305, -2.5049897246887496, t);\n p += fft(-217, 0.04394773639883994, 0.3578708012733398, t);\n p += fft(-191, 0.04378025799588553, -0.0033036474870014217, t);\n p += fft(252, 0.04323472173070737, -0.6242705523897715, t);\n p += fft(208, 0.04304212913333182, 1.2308490125522018, t);\n p += fft(-303, 0.04296800234600092, 0.5114427759851766, t);\n p += fft(-224, 0.04272023945142006, 1.7783110640430169, t);\n p += fft(-239, 0.04266679157025011, 1.9482200717681597, t);\n p += fft(-299, 0.04173701435724602, 0.13365408028225706, t);\n p += fft(-157, 0.04146038143450164, -2.27864544691768, t);\n p += fft(-122, 0.04130127409599373, 1.0179985736718389, t);\n p += fft(244, 0.04122532274063034, -3.067112795949472, t);\n p += fft(-257, 0.04120260956232949, -0.542088172379074, t);\n p += fft(243, 0.0411840750974049, -1.1270227690299983, t);\n p += fft(-197, 0.04049657874199362, -1.3153250227799558, t);\n p += fft(-245, 0.040487242733518884, -0.8056762003801902, t);\n p += fft(-159, 0.039968494906456264, 2.131425507643933, t);\n p += fft(-307, 0.03996735676224505, -2.953588109997123, t);\n p += fft(-117, 0.03996366100725931, -0.49760194876592045, t);\n p += fft(196, 0.03980123228825173, -2.4873720845122835, t);\n p += fft(129, 0.03949030893082138, 2.6844282955405814, t);\n p += fft(-229, 0.03917242300752811, 0.4902693841571348, t);\n p += fft(139, 0.03902865341873541, 0.25084178188044515, t);\n p += fft(181, 0.03890376427607834, 1.0907389035558301, t);\n p += fft(205, 0.038225435143225045, 3.038754339328246, t);\n p += fft(-270, 0.03814390562327705, -1.8861478767357396, t);\n p += fft(-322, 0.0377875627108128, 2.054761498465224, t);\n p += fft(254, 0.037644552308180375, 1.226339480136378, t);\n p += fft(118, 0.0376169651010232, -2.950034729024326, t);\n p += fft(178, 0.03755225537409213, -2.0429020234266275, t);\n p += fft(-171, 0.037539637959647765, -2.628755546161329, t);\n p += fft(-285, 0.03747836134545755, 1.6722531286069764, t);\n p += fft(-180, 0.037460621587516375, 0.24951421594634987, t);\n p += fft(-247, 0.03717014294939771, 0.4975746705003909, t);\n p += fft(-243, 0.037110747818183125, -2.0522437006131544, t);\n p += fft(-216, 0.03709475821552742, -2.3116936028551125, t);\n p += fft(220, 0.036592206760702885, -1.1344479951397493, t);\n p += fft(-179, 0.03633519628480489, 3.112577471269461, t);\n p += fft(176, 0.03587107527180269, 2.0913103131787256, t);\n p += fft(-207, 0.035809732499114115, 1.927035559915993, t);\n p += fft(263, 0.03562581086066016, 2.1725008985745626, t);\n p += fft(-233, 0.0354009108649777, 3.090965188758471, t);\n p += fft(-274, 0.03518550659845451, -2.609254318579163, t);\n p += fft(255, 0.03514669947246087, -0.5836113629270486, t);\n p += fft(-319, 0.035071528591647944, -0.9287687613033353, t);\n p += fft(250, 0.035032432208899206, -1.3555387953817497, t);\n p += fft(246, 0.03497955004685989, -2.900549119786685, t);\n p += fft(187, 0.03497207390971293, 0.6419092201499581, t);\n p += fft(-261, 0.034866141687325505, -2.8459055041516237, t);\n p += fft(235, 0.03476696606441066, -2.0933815844908445, t);\n p += fft(-323, 0.03432989757242964, 3.043376257611318, t);\n p += fft(217, 0.03432513334072705, -2.870512549124132, t);\n p += fft(-162, 0.034206181317519346, 1.7603609329802217, t);\n p += fft(228, 0.033806131017560914, 2.744224194820961, t);\n p += fft(-214, 0.03361470625565273, 1.3269768758946363, t);\n p += fft(-215, 0.033529573748044716, -0.6672480021154472, t);\n p += fft(218, 0.033108296214315436, -0.745234197490618, t);\n p += fft(-146, 0.03308604353605592, 3.1073329337196274, t);\n p += fft(-304, 0.03303159902623534, -2.4351923422168493, t);\n p += fft(311, 0.032929142894730805, -1.2404835833846408, t);\n p += fft(242, 0.03292110918943753, -2.843217129365357, t);\n p += fft(-134, 0.03288854877053813, 0.9130453422359837, t);\n p += fft(-351, 0.03216220452946286, 2.9238550334113036, t);\n p += fft(370, 0.032067363608954395, -2.7224346201619336, t);\n p += fft(-272, 0.0320561856904509, -2.2145797900542075, t);\n p += fft(-154, 0.031753153031045644, -0.16349530311453386, t);\n p += fft(-297, 0.03170814258815033, 1.4299668847082438, t);\n p += fft(182, 0.031686346431849116, 1.0404018878433685, t);\n p += fft(209, 0.031631761114312575, 2.68111660535219, t);\n p += fft(-170, 0.03155091422698183, 0.025639469483387113, t);\n p += fft(-186, 0.031481161179575994, -2.4201773456994196, t);\n p += fft(-149, 0.031378407408703936, -0.29780149545874124, t);\n p += fft(-189, 0.03115713943498147, -2.644731527056393, t);\n p += fft(-140, 0.031108294831552176, -2.15723791130607, t);\n p += fft(-230, 0.031069499597997076, -1.8351044204097733, t);\n p += fft(-347, 0.030916908832951683, 2.4988906781918887, t);\n p += fft(179, 0.030863310224088517, -2.7337664596225717, t);\n p += fft(403, 0.03079754590699015, 2.304354929974498, t);\n p += fft(-327, 0.030401389085025158, 0.6776045430119092, t);\n p += fft(348, 0.030373006761288658, -0.8679493927914637, t);\n p += fft(-283, 0.030223082183547217, 2.321654263572609, t);\n p += fft(363, 0.029978631780089162, -2.0372134669252153, t);\n p += fft(300, 0.029897933119460138, -0.6676919620602354, t);\n p += fft(-291, 0.029861596312070346, 1.7523875509536528, t);\n p += fft(-188, 0.029753115428544207, 1.9857575444023974, t);\n p += fft(225, 0.02930280842219607, -2.476715232579848, t);\n p += fft(429, 0.029179633135401076, -1.1583720910674902, t);\n p += fft(-244, 0.028727529620259963, -2.1143873737131402, t);\n p += fft(-262, 0.02871955668992869, -3.0313512511556326, t);\n p += fft(183, 0.02846822983732852, -2.748892137103645, t);\n p += fft(371, 0.02837026069110045, 0.01709695974620803, t);\n p += fft(261, 0.02827365028172563, -3.1104354673121124, t);\n p += fft(265, 0.028272672120935843, 2.3187637649532733, t);\n p += fft(-225, 0.02812970136713906, -2.391287474012119, t);\n p += fft(-498, 0.027947522439068676, -2.2990766978458765, t);\n p += fft(-280, 0.027914429972500227, 1.013046879856245, t);\n p += fft(-286, 0.027473151353735275, -2.49136323587289, t);\n p += fft(175, 0.027082599263012368, -1.5491745606494223, t);\n p += fft(-312, 0.027012987931504247, 2.04498781689676, t);\n p += fft(-269, 0.02695999871732734, 1.9901497475231744, t);\n p += fft(-360, 0.026873297237023055, -0.1910603902232436, t);\n p += fft(210, 0.026869883314267793, 2.2196865134172485, t);\n p += fft(297, 0.026812580694708738, -0.9588922853385715, t);\n p += fft(-301, 0.026740603460076486, 3.129150821124547, t);\n p += fft(249, 0.026705638457446366, 1.222748808928071, t);\n p += fft(-265, 0.02664609481949143, -2.053872209655098, t);\n p += fft(234, 0.026552097720191792, 1.791539306291776, t);\n p += fft(227, 0.026483242165273254, 1.820370612047031, t);\n p += fft(-278, 0.026454482953384536, -0.05035777064958111, t);\n p += fft(130, 0.02643932663595854, -0.99756238511126, t);\n p += fft(231, 0.026426198746353186, 0.5809494198615022, t);\n p += fft(259, 0.026227035759586497, 0.048293120841955764, t);\n p += fft(-484, 0.025920236965447943, -1.3145326416833631, t);\n p += fft(-200, 0.02582688982027274, 2.9933704442672058, t);\n p += fft(306, 0.025717614417685275, 1.8836489796514166, t);\n p += fft(325, 0.025633895244435108, 1.3357894296294839, t);\n p += fft(347, 0.025591567492861077, 0.7714686164660547, t);\n p += fft(350, 0.02537545484909361, 1.0770352597787496, t);\n p += fft(269, 0.025281161653424446, -0.8907061117584099, t);\n p += fft(-133, 0.025264087654711557, -2.2018152563461086, t);\n p += fft(302, 0.025261769856955805, -2.355108757850705, t);\n p += fft(-386, 0.02501819794981099, -2.1477266907940398, t);\n p += fft(-350, 0.025002909823313272, -0.918163604040018, t);\n p += fft(333, 0.02498494266415943, -2.4432604967090743, t);\n p += fft(-126, 0.024859518286652924, -1.6045017067489493, t);\n p += fft(387, 0.02467625356087282, 1.3070718064311373, t);\n p += fft(334, 0.024653917539731205, -1.2008707105925764, t);\n p += fft(-240, 0.024383901745244567, -2.988241565566239, t);\n p += fft(-264, 0.024335184695854287, -2.6872316547229813, t);\n p += fft(-295, 0.024162332511406915, 2.688135808330894, t);\n p += fft(-276, 0.023836127347152083, 1.7406463579323161, t);\n p += fft(203, 0.02379133257240037, -0.3391371830055463, t);\n p += fft(238, 0.023765709007479915, -0.5242076860175524, t);\n p += fft(-483, 0.023685530454379034, -2.7588368682276188, t);\n p += fft(-342, 0.023608418137766377, -2.8422263956774603, t);\n p += fft(-329, 0.02352667163920514, -1.3751865534697134, t);\n p += fft(-325, 0.023484462227501834, 0.9927626044567095, t);\n p += fft(230, 0.023456797688559062, 2.986455504190948, t);\n p += fft(-251, 0.023318098398379915, 0.001782273200166798, t);\n p += fft(349, 0.023228733757422806, -1.072303089214612, t);\n p += fft(-187, 0.02322820420005635, -1.3088872022943903, t);\n p += fft(207, 0.023124953262124194, 2.861078526577945, t);\n p += fft(202, 0.023092047214425013, 1.0903724835034125, t);\n p += fft(256, 0.022985204913763314, -2.423841790239499, t);\n p += fft(275, 0.022818988303534807, 0.6902607477729654, t);\n p += fft(241, 0.022704874638607323, -2.7649106335200497, t);\n p += fft(425, 0.0227031562735846, -0.012766251035448749, t);\n p += fft(341, 0.022687393671458885, 2.5287999264265917, t);\n p += fft(365, 0.02259089981517188, -3.0023071719734364, t);\n p += fft(298, 0.022430755305941547, 2.1440768785920277, t);\n p += fft(282, 0.022286640564131238, 1.6952796376817658, t);\n p += fft(-222, 0.02225904133709741, -0.11321484605745279, t);\n p += fft(-358, 0.02217999232999693, 1.7758821914468246, t);\n p += fft(-279, 0.022095177947215737, -0.5192730492996941, t);\n p += fft(-321, 0.022090473578627715, -0.07844498829588367, t);\n p += fft(-359, 0.021942659529941247, -1.4465606944335514, t);\n p += fft(295, 0.021938469715302247, -2.262517021888232, t);\n p += fft(276, 0.02187149419277873, -0.48075610553317366, t);\n p += fft(502, 0.021702319512468666, 3.0296543113191032, t);\n p += fft(-330, 0.021623659938299806, 1.125358184849381, t);\n p += fft(437, 0.021598487358667418, -3.140123913594686, t);\n p += fft(329, 0.02151039012029828, 2.581279012552966, t);\n p += fft(316, 0.021367306895449877, -1.4951973637160159, t);\n p += fft(-267, 0.021347948106670487, -2.131762505311679, t);\n p += fft(-357, 0.02130909397626576, -1.6191594501730688, t);\n p += fft(267, 0.021293781075476997, -1.8017482889635452, t);\n p += fft(-345, 0.021048837931442004, -2.7069477620313958, t);\n p += fft(-408, 0.02091001972463279, -1.769848404933256, t);\n p += fft(320, 0.02088425179811783, -2.0704408556221447, t);\n p += fft(-387, 0.020820573842865432, -1.0930901397929305, t);\n p += fft(-242, 0.020794137395108606, -2.9605829129168324, t);\n p += fft(-344, 0.020671452626722698, -1.7987821089995277, t);\n p += fft(322, 0.02067088832181214, -0.22912612763676568, t);\n p += fft(-253, 0.02061794621791137, -2.0073683043484953, t);\n p += fft(152, 0.020610241493015494, 0.7098290286508013, t);\n p += fft(303, 0.020592932879901157, 0.2719935974041692, t);\n p += fft(369, 0.020565205999609194, 1.1339865732671597, t);\n p += fft(-273, 0.020564513440436215, 0.7955462603371597, t);\n p += fft(215, 0.020563199492889896, -2.73682346996378, t);\n p += fft(491, 0.020543180022284717, -0.666788850668437, t);\n p += fft(-356, 0.020468707035038124, 0.6390339134967551, t);\n p += fft(293, 0.02045422037494547, 2.0389477913494334, t);\n p += fft(201, 0.02044920037993446, 0.020014295722637722, t);\n p += fft(346, 0.020343417891833488, -0.725558513377337, t);\n p += fft(-399, 0.020300294108822257, 0.4272740878635683, t);\n p += fft(464, 0.020245436748592072, -1.684969251038007, t);\n p += fft(221, 0.020152569151655777, 3.0652577733184607, t);\n p += fft(489, 0.020112656771664496, -1.8042417759245823, t);\n p += fft(318, 0.020056388889540793, -0.6707185351758385, t);\n p += fft(-339, 0.02001479126183757, 2.949145490351578, t);\n p += fft(236, 0.019954859133684905, -2.5428580801661353, t);\n p += fft(270, 0.0199321804912115, 0.37878519439460373, t);\n p += fft(379, 0.01983906743081143, -0.6343495825544784, t);\n p += fft(397, 0.019807948769945526, 1.8820880074650208, t);\n p += fft(-221, 0.019691977663300008, 1.0514616478563783, t);\n p += fft(421, 0.019623337934699885, 2.745363616281166, t);\n p += fft(290, 0.01953008037132682, 0.8843912942541152, t);\n p += fft(197, 0.019375944562943694, 2.0356527234870283, t);\n p += fft(308, 0.0193527600669189, 2.81162774010797, t);\n p += fft(-328, 0.019285400376087076, -0.19114063563029987, t);\n p += fft(467, 0.019178891795281015, -1.1263460951000444, t);\n p += fft(-277, 0.019079718249143097, 2.6331532845129404, t);\n p += fft(280, 0.018994654616752097, 0.1675185745565849, t);\n p += fft(260, 0.018913994053827352, -0.5044184838532041, t);\n p += fft(427, 0.018852739951118917, 2.662217288999046, t);\n p += fft(499, 0.01882350931017547, -3.0149846935153795, t);\n p += fft(189, 0.018757809943370472, -2.674046839704885, t);\n p += fft(342, 0.01874747510581987, -0.5786367177428741, t);\n p += fft(416, 0.018566064359446622, -2.4176951579501798, t);\n p += fft(-348, 0.018437843583245718, -2.43964557130452, t);\n p += fft(465, 0.018437257369033726, 1.9214782275571987, t);\n p += fft(284, 0.01833544793734469, 1.9968963624882772, t);\n p += fft(-470, 0.01831002225764508, 0.5156559884673433, t);\n p += fft(-309, 0.018308015252553246, 2.312871173198566, t);\n p += fft(490, 0.018216767412652893, 1.0140583098689544, t);\n p += fft(410, 0.0182153814183295, -0.7582160151193984, t);\n p += fft(-258, 0.018128466510949046, 1.1118990006128406, t);\n p += fft(375, 0.018057552391933036, -3.1017254547912794, t);\n p += fft(321, 0.01794587346556815, -1.8663932495219484, t);\n p += fft(248, 0.017863597777448885, -0.5496798132550856, t);\n p += fft(-317, 0.01782644768907149, 2.2802015955382537, t);\n p += fft(-452, 0.01780336641082023, 2.690346714053042, t);\n p += fft(-353, 0.0176913084429108, 2.711049147139238, t);\n p += fft(-306, 0.017552300595371273, 2.9506692681038973, t);\n p += fft(-288, 0.017544324110289406, 2.6323855434673655, t);\n p += fft(-460, 0.017443786885044096, -0.9299541940735817, t);\n p += fft(309, 0.017419145135487844, 1.3460311128048443, t);\n p += fft(305, 0.017152445993384516, -1.7361791397832658, t);\n p += fft(-256, 0.01714047466479905, 2.2799787723913836, t);\n p += fft(355, 0.017058849062613846, -0.6615483742229916, t);\n p += fft(-320, 0.016979227333377315, 2.6388512636510377, t);\n p += fft(-382, 0.01695615705889803, 2.555957382259133, t);\n p += fft(390, 0.016953475958207665, 2.3322367819625027, t);\n p += fft(-398, 0.01694687182836866, 2.171099613653392, t);\n p += fft(411, 0.01692398609281921, -2.3970294940597237, t);\n p += fft(391, 0.01688742438332487, -2.6741985703550384, t);\n p += fft(-383, 0.01671254896861024, -1.809831893039911, t);\n p += fft(-438, 0.016700025869992145, -3.0263950471937577, t);\n p += fft(498, 0.016577067431832987, 1.4628404900222298, t);\n p += fft(441, 0.016528444933087572, -2.5534170728688195, t);\n p += fft(396, 0.016469294170931584, -1.0778883003395043, t);\n p += fft(194, 0.016387929541844138, 0.27285370222194255, t);\n p += fft(288, 0.01632089028121901, -2.499948895627382, t);\n p += fft(-453, 0.016282171657074507, -1.8352466594182715, t);\n p += fft(-491, 0.0162466408620674, 0.751075739658446, t);\n p += fft(-271, 0.01618413446166483, -1.9240760733216773, t);\n p += fft(374, 0.01597286278830038, 1.4727297170481586, t);\n p += fft(245, 0.01595638314751546, -2.5020467251265117, t);\n p += fft(492, 0.015955522695669654, -2.11250121739465, t);\n p += fft(292, 0.015938735781863788, 2.8886197298108702, t);\n p += fft(356, 0.015930093359693635, 3.119487581363237, t);\n p += fft(-336, 0.01588376130850545, 0.28597008022586234, t);\n p += fft(386, 0.01579744464348149, -0.6427892645860717, t);\n p += fft(424, 0.015781071608576305, 0.06038150421307685, t);\n p += fft(286, 0.015677276287429535, 2.6843830865968843, t);\n p += fft(-439, 0.01566577624464125, -0.40437157307800353, t);\n p += fft(-316, 0.015653156388410593, -0.49543109291627363, t);\n p += fft(-480, 0.015631631437216433, 2.2355153900157636, t);\n p += fft(400, 0.015537542523719335, -2.445474568008316, t);\n p += fft(-447, 0.015437071879756518, 2.7865636796309072, t);\n p += fft(366, 0.015353947913814526, 2.0058503224480564, t);\n p += fft(-492, 0.015303110265234265, 2.3874477585758074, t);\n p += fft(-445, 0.015280750696461273, 0.444334272791586, t);\n p += fft(353, 0.015251950793442146, -2.7836080531188006, t);\n p += fft(-500, 0.015226472622413946, -2.6103075874608708, t);\n p += fft(-380, 0.015222967220547282, -2.881867749906817, t);\n p += fft(506, 0.015150418703193842, 2.0075105204746566, t);\n p += fft(-335, 0.015124331759979636, 1.009943322524843, t);\n p += fft(483, 0.015097172526301886, 2.0959180943388027, t);\n p += fft(240, 0.015078862676021213, -1.2930571972964564, t);\n p += fft(-401, 0.01507870517510355, 2.715454154162096, t);\n p += fft(449, 0.015061353079694497, 1.8733248116188075, t);\n p += fft(412, 0.015050927296007339, 2.2976965232943307, t);\n p += fft(323, 0.014984653022696854, -3.0935557999938292, t);\n p += fft(-396, 0.014977404461351117, 0.30211159558289086, t);\n p += fft(273, 0.01483460564366501, -1.4596850118087714, t);\n p += fft(345, 0.014833234000572936, -0.32539675758169934, t);\n p += fft(-417, 0.014811822655002693, -2.5447030635824297, t);\n p += fft(-394, 0.014768485010995914, 0.8420120899555257, t);\n p += fft(-326, 0.014757622857210374, -0.9559941626829623, t);\n p += fft(-373, 0.01470773104483892, 2.794549031160765, t);\n p += fft(340, 0.014690011817124374, -2.2126006109671352, t);\n p += fft(-390, 0.014674589859169042, -0.9855117184354396, t);\n p += fft(317, 0.014671770616686048, -0.4111710755329078, t);\n p += fft(-308, 0.014630448864418246, -2.6132662944333247, t);\n p += fft(-419, 0.014612974424031182, 1.890332423869268, t);\n p += fft(472, 0.014573773093057102, -0.15746800733732982, t);\n p += fft(257, 0.014541893370249208, -1.3953361182084414, t);\n p += fft(436, 0.014503458130718185, 1.473439813394881, t);\n p += fft(-218, 0.014473405505827206, -2.2614161401120723, t);\n p += fft(-384, 0.014387460588666384, 0.4846527714087321, t);\n p += fft(214, 0.014373508138361935, -0.9929984801205258, t);\n p += fft(327, 0.014363924720838923, 0.6705953026310363, t);\n p += fft(-443, 0.014247709886683415, 0.6588561068584213, t);\n p += fft(216, 0.014201020492534005, 2.6741170951719297, t);\n p += fft(278, 0.014195739673546514, 0.45380564178946164, t);\n p += fft(474, 0.01417224313980241, -2.946490401046988, t);\n p += fft(361, 0.014169743346048109, 0.7656558005070042, t);\n p += fft(418, 0.014153025125774113, 0.6544601775463792, t);\n p += fft(-204, 0.014098068158582331, 1.570589753704267, t);\n p += fft(409, 0.01408416890434566, 0.5791110199136934, t);\n p += fft(332, 0.014064077521337141, -1.96196450322835, t);\n p += fft(-411, 0.014055381190387442, -2.1050532273937193, t);\n p += fft(-504, 0.014042491970392819, -2.4507746476472416, t);\n p += fft(-331, 0.014021056796023198, -0.9466573694669207, t);\n p += fft(331, 0.01401815399131699, 2.9486255021269, t);\n p += fft(381, 0.014006914694692865, -1.1186058737646056, t);\n p += fft(291, 0.013994629362131503, 1.9007976843424446, t);\n p += fft(330, 0.013949517263636396, -0.49986286341122593, t);\n p += fft(312, 0.013936760778201074, 3.0721230148366017, t);\n p += fft(417, 0.013934783414901307, -2.257422367097522, t);\n p += fft(-337, 0.01391371567127865, 2.895113197666846, t);\n p += fft(385, 0.013891315233703376, -1.1352978862346337, t);\n p += fft(-435, 0.013873332760801304, -0.32090186205450033, t);\n p += fft(-385, 0.013844120558174551, -3.119969137357533, t);\n p += fft(315, 0.013828233021495205, -3.0524501599722305, t);\n p += fft(-343, 0.01378875650901319, -0.6263451828356061, t);\n p += fft(459, 0.013771797001534768, 1.3512327925116, t);\n p += fft(319, 0.013701983237761646, -3.0552359101211772, t);\n p += fft(-421, 0.013685546780447071, 0.6168243016650519, t);\n p += fft(307, 0.013681679811588384, -0.8864069492779628, t);\n p += fft(-477, 0.01367630727868223, 2.7521796191613754, t);\n p += fft(-465, 0.013581831625402187, -1.220520995405941, t);\n p += fft(326, 0.013574391629771329, -3.1202874287266082, t);\n p += fft(360, 0.0135341266402344, 2.664064685853016, t);\n p += fft(-377, 0.013529068169515567, 0.2646391557351839, t);\n p += fft(-459, 0.013509914775589568, -1.0462062859265808, t);\n p += fft(-436, 0.013509169672166503, 3.060808353213404, t);\n p += fft(-442, 0.013378848325932797, -2.943169899395721, t);\n p += fft(281, 0.013324886668795041, 0.7702604219139404, t);\n p += fft(402, 0.013309784889240976, 3.0462417371183212, t);\n p += fft(413, 0.0133092395072314, -2.5644879288039295, t);\n p += fft(-289, 0.013200751727554779, -0.42679700259876185, t);\n p += fft(484, 0.013164831415710608, 1.1147833223969785, t);\n p += fft(401, 0.01310573625374175, -0.45440514371321855, t);\n p += fft(277, 0.013041278781405874, 2.710518166070806, t);\n p += fft(-349, 0.013024136574205064, 0.368816551131045, t);\n p += fft(-346, 0.012977337347580263, -0.26417451603147596, t);\n p += fft(420, 0.012845882619135234, 2.002998951036915, t);\n p += fft(445, 0.01284579635338418, -2.0677013276140324, t);\n p += fft(428, 0.01279398105157776, 1.2926796180614086, t);\n p += fft(376, 0.01276786373111407, 1.9367911037174024, t);\n p += fft(-376, 0.01272502179107737, -3.1282891850863908, t);\n p += fft(-507, 0.012722242687719345, 1.8939443453134572, t);\n p += fft(-294, 0.012712310194407102, -1.188628976570537, t);\n p += fft(-415, 0.012670552135729969, -0.9868907915235011, t);\n p += fft(-428, 0.012607664240827194, -0.031095597497390378, t);\n p += fft(473, 0.012543542480353977, -3.0690769712824704, t);\n p += fft(430, 0.012541336274083313, -2.048475426543982, t);\n p += fft(-341, 0.012469363963888485, 1.1697948865306476, t);\n p += fft(-509, 0.012466468154148012, 0.38059867841898043, t);\n p += fft(-481, 0.01242592353445654, -1.913914863175826, t);\n p += fft(-314, 0.01239765783707375, -2.1235472871525767, t);\n p += fft(-313, 0.012376173120752695, 1.03944125297012, t);\n p += fft(-471, 0.012345159783470094, 2.6516490082388215, t);\n p += fft(-310, 0.012284310170666665, -2.1698685017205785, t);\n p += fft(-300, 0.01227542981113322, -2.017710213505234, t);\n p += fft(247, 0.012240477217121775, 0.41935200430886505, t);\n p += fft(-466, 0.012240125520371849, 0.019480587267466563, t);\n p += fft(503, 0.01222533405281694, 0.6840099173444322, t);\n p += fft(200, 0.012220403742265044, 2.887981253820241, t);\n p += fft(304, 0.012182539431900842, 2.632403848640596, t);\n p += fft(-425, 0.01215230910385176, 0.8806489351275139, t);\n p += fft(351, 0.01214911658400834, -2.451703539504316, t);\n p += fft(404, 0.012113298811467181, -0.1782921248032119, t);\n p += fft(-404, 0.012098227853860725, -1.9073495889414767, t);\n p += fft(500, 0.01206287854228493, 1.0185472742352673, t);\n p += fft(-499, 0.012052977984837707, -2.947829310783775, t);\n p += fft(296, 0.01203564352441712, -2.5371259687889496, t);\n p += fft(344, 0.012030880992025202, -1.5507150201535012, t);\n p += fft(-490, 0.011980159644615596, -0.06316472136582, t);\n p += fft(-352, 0.011969909686558968, -0.40224393964822713, t);\n p += fft(-506, 0.01193447069907937, -1.174788671161676, t);\n p += fft(268, 0.011916136745930814, 1.8609641665108294, t);\n p += fft(456, 0.011855122323403295, -0.25549478912944407, t);\n p += fft(477, 0.011851778387300449, -0.7824493403677418, t);\n p += fft(258, 0.011823107744589997, 0.4702714456912564, t);\n p += fft(504, 0.011813789783172548, -2.1593068285941017, t);\n p += fft(285, 0.01180532967217003, 1.9107235273443852, t);\n p += fft(294, 0.011771073591615677, -3.0221374579820486, t);\n p += fft(-340, 0.011737380405027845, -0.09560932985103796, t);\n p += fft(-412, 0.011693563396162478, 0.03547230271148827, t);\n p += fft(-473, 0.01167087995314407, -2.983087290342926, t);\n p += fft(-381, 0.011633614975664468, 0.05696443428106514, t);\n p += fft(423, 0.011627989857404918, 0.07675195602888493, t);\n p += fft(-324, 0.01161418553014038, -2.471424070407224, t);\n p += fft(399, 0.011577011391338602, 0.8371784427311489, t);\n p += fft(-478, 0.011557125479527306, -2.2282000740788677, t);\n p += fft(283, 0.011531997122870051, -0.7010609826477285, t);\n p += fft(511, 0.0114760434011943, 1.734049648533497, t);\n p += fft(279, 0.011460842192281833, 1.4668325872315813, t);\n p += fft(447, 0.011454898078003161, -0.13946735136066804, t);\n p += fft(-485, 0.011428486636959046, 0.34886175616311715, t);\n p += fft(-472, 0.011389433654382263, 0.45069667769887467, t);\n p += fft(-505, 0.011374024792638228, -0.16038515681074883, t);\n p += fft(496, 0.011367209747096613, -0.5789335748725059, t);\n p += fft(287, 0.011353094401163121, -2.6544713993331595, t);\n p += fft(-476, 0.011339897348846054, 2.760999701731875, t);\n p += fft(-203, 0.011246318318210755, -2.655330740012455, t);\n p += fft(-298, 0.011240592231092321, -0.8535304917183064, t);\n p += fft(435, 0.011199052278348127, -2.221842104143809, t);\n p += fft(-397, 0.011179697495765209, 1.9050162197469025, t);\n p += fft(339, 0.011177696172867731, -1.5279335419082853, t);\n p += fft(314, 0.01113945595405601, -2.665298378120776, t);\n p += fft(408, 0.011075489731786133, -1.6517945429682814, t);\n p += fft(446, 0.01101171854080183, -0.48257443448194115, t);\n p += fft(-333, 0.011005844536439355, -2.23571436410032, t);\n p += fft(450, 0.01098336159814381, -2.3282935745461235, t);\n p += fft(-293, 0.010866838807767636, -2.08175340759797, t);\n p += fft(336, 0.010820760748971349, 1.7112356086996947, t);\n p += fft(414, 0.010787409392539691, 2.807079317517186, t);\n p += fft(-318, 0.010742470447882757, 2.8752872175583497, t);\n p += fft(406, 0.010725007874053354, 3.063825957806161, t);\n p += fft(-413, 0.010690874318868027, -3.119832148809836, t);\n p += fft(415, 0.010685727067395259, 0.8983819808171652, t);\n p += fft(-503, 0.010659993246209611, 0.3133119607095941, t);\n p += fft(-355, 0.010621606166054188, -2.3472131268696774, t);\n p += fft(-281, 0.01061443706876594, -0.7561374672674868, t);\n p += fft(-366, 0.010605967113792601, -2.711774616807628, t);\n p += fft(-479, 0.010586221430330002, -2.5484256879947855, t);\n p += fft(-426, 0.010490344441220769, 1.0668022268161381, t);\n p += fft(-405, 0.010385062881632077, 2.306115157954148, t);\n p += fft(-290, 0.010384484051949614, -2.2711503576547094, t);\n p += fft(364, 0.010311227119556366, 1.3569201451071267, t);\n p += fft(239, 0.01030448004807976, -1.9386533731670805, t);\n p += fft(-424, 0.010283240609725826, 0.8760921385535031, t);\n p += fft(338, 0.010272254653901589, -1.0871306303800126, t);\n p += fft(-482, 0.01024776632548479, -0.6515462866676507, t);\n p += fft(-494, 0.01024564906483858, 2.395078651689155, t);\n p += fft(-236, 0.010162897249939504, 1.9785592807626329, t);\n p += fft(494, 0.010150992333137729, -0.01780121101171699, t);\n p += fft(233, 0.010096455886289615, -2.5741668393876806, t);\n p += fft(192, 0.010084734213336314, -0.8855447372541574, t);\n p += fft(-234, 0.010056081638657548, 1.9417984487245914, t);\n p += fft(-266, 0.010020076168818585, -0.561779230785278, t);\n*/\n return (p + vec2(-250, -150)) * 0.01 /* center and scale */\n ;\n}\n\nvoid main() {\n float segmentsPerCircle = 640.0;\n float pointsPerCircle = segmentsPerCircle * 2.0;\n float numCircles = floor(vertexCount / pointsPerCircle);\n \n float vId = mod(vertexId, pointsPerCircle);\n float cId = floor(vertexId / pointsPerCircle);\n float cv = cId / numCircles;\n float u = floor(vId / 2.0) + mod(vId, 2.0);\n float v = u / segmentsPerCircle;\n float a = v * PI * 2.0 + cv;\n\n vec2 p = computeFFT(v + time + cv);\n \n float distFromCenter = length(p);\n\n float s = texture2D(sound, vec2(\n mix(0.01, 0.1, abs(v * 2. - 1.)),\n cv * 0.2)).r;\n float s2 = texture2D(sound, vec2(0.1, cv*0.1)).r;\n \n vec3 pos = vec3(p, 0); \n \n \n float ct = time * 0.3;\n vec3 eye = vec3(vec2(sin(ct), cos(ct)) * 2.5, -5.0);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = persp(45. * PI / 180., resolution.x / resolution.y, 0.001, 250.); \n mat *= cameraLookAt(eye, target, up);\n //mat *= trans(vec3(computeFFT(cv + time), 0));\n mat *= trans(vec3(0, 0, cv * 2. - 1.) * 0.3);\n mat *= rotZ(PI + pow(s, 5.0) * 0.2 - 0.1);\n mat *= uniformScale(mix(0.9, 1.2, pow(s, 5.0)) + s2);\n gl_Position = mat * vec4(pos, 1);\n\n\n float boost = step(0.7, s);\n \n float hue = (time * 0.01) + pow(s, 3.) * 0.2 + boost * 0.5;\n float sat = 1.0;1.0 - pow(pos.z, 1.) - pow(s, 4.);\n float val = sin(v) * 0.5 + 0.5;mix(0.25, 2.0, pow(s, 2.));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n} //utter madness" + }, "screenshotURL": "data/images/images-5s4z0rt97tmzq2b6g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rDnXafrSKJvBn8q89/art.json b/art/rDnXafrSKJvBn8q89/art.json index 7fd0e35b..f581d0fa 100644 --- a/art/rDnXafrSKJvBn8q89/art.json +++ b/art/rDnXafrSKJvBn8q89/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\nvec3 getCurvePoint(const float id, const float _time) {\\n return vec3(\\n sin(id * 1.+_time*10.),\\n cos(id * 1.+_time*10.),\\n sin(id * 0.25+_time*10.));\\n}\\n\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./50.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n \\n //LOGISTIC\\n /*\\n vec2 vp = vec2(0.,0.);\\n float z = fract(0.02+snd*snd);//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n \\n\\n cubep.y+= z;\\n cubep.x+= shapeRelId;\\n //END LOGISTIC\\n */\\n \\n cubep+= getCurvePoint(shapeId, time/10.+snd);\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(0.5+sin(time/1.3)/4., 0.5+sin(time/1.)/4., 0.5*cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\nvec3 getCurvePoint(const float id, const float _time) {\n return vec3(\n sin(id * 1.+_time*10.),\n cos(id * 1.+_time*10.),\n sin(id * 0.25+_time*10.));\n}\n\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./50.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n \n //LOGISTIC\n /*\n vec2 vp = vec2(0.,0.);\n float z = fract(0.02+snd*snd);//sin(shapeRelId+fract(time/100.));//fract(0.02);\n\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n \n\n cubep.y+= z;\n cubep.x+= shapeRelId;\n //END LOGISTIC\n */\n \n cubep+= getCurvePoint(shapeId, time/10.+snd);\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(0.5+sin(time/1.3)/4., 0.5+sin(time/1.)/4., 0.5*cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-zxi303fx03kpk4fnp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rF2WSQ98F7YxgjTH9/art.json b/art/rF2WSQ98F7YxgjTH9/art.json index 95c61587..31876d99 100644 --- a/art/rF2WSQ98F7YxgjTH9/art.json +++ b/art/rF2WSQ98F7YxgjTH9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":102,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float id = vertexId;\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux * radians(180.0) / (vertexCount * sin(time) * 0.009);\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy;\\n \\n float a = resolution.x / resolution.y;\\n \\n float x = c * radius / a;\\n float y = s * radius;\\n \\n vec2 xy = vec2(x,y);\\n gl_Position = vec4(xy* .5, 0, 1);\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 102, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float id = vertexId;\n \n float ux = floor(id / 6.) + mod(id, 2.);\n \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux * radians(180.0) / (vertexCount * sin(time) * 0.009);\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy;\n \n float a = resolution.x / resolution.y;\n \n float x = c * radius / a;\n float y = s * radius;\n \n vec2 xy = vec2(x,y);\n gl_Position = vec4(xy* .5, 0, 1);\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-rah654vfzjqthepmm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rGsksAzL2wfEQZTc9/art.json b/art/rGsksAzL2wfEQZTc9/art.json index 5ac8b302..e2c1ecf0 100644 --- a/art/rGsksAzL2wfEQZTc9/art.json +++ b/art/rGsksAzL2wfEQZTc9/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/dzasterpeace/somewhere\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 scale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotX( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, -s, 0,\\n 0, s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nstruct vertexData {\\n vec3 position;\\n vec2 uv;\\n vec3 normal;\\n};\\n \\n vec3 quadPos(float vId) {\\n float vIdQuad = mod(vId, 6.); // 0 1 2 3 4 5\\n \\n float vIdTri = mod(vIdQuad, 3.); // 0 1 2 0 1 2\\n float tId = floor(vIdQuad / 3.); // 0 0 0 1 1 1\\n \\n float x = mod(vIdQuad, 2.); // 0 1 0 1 0 1\\n float yRaw = floor(vIdTri / 2.); // 0 0 1 0 0 1\\n float y = abs(yRaw - tId); // 0 0 1 1 1 0\\n return vec3(x, y, 0.);\\n }\\n\\nvertexData get_VertexData(float vId, float vCount) {\\n float triId = floor(vId / 3.);\\n float triVertexId = mod(vId, 3.);\\n float quadCount = floor(vCount / 6.);\\n float quadIdx = floor(triId/2.);\\n \\n vec2 planeSize = vec2(floor(quadCount / 32.), 32.);\\n float xId = floor(quadIdx / (planeSize.y * 2.));\\n float yId = mod(quadIdx, planeSize.y * 2.);\\n float zId = floor(yId / planeSize.y);\\n vec3 quadId = vec3(xId, mod(yId, planeSize.y), 1.);\\n \\n float xPos = mod(vId, 2.) + quadId.x;\\n float yPos = abs(floor(triVertexId / 2.) - mod(triId, 2.)) + quadId.y;\\n \\n vec3 position = vec3(xPos, yPos, (zId*2.+1.)*0.01);\\n vec3 offset = vec3(-planeSize.x * 0.25, -planeSize.y*0.5, 0.);\\n //vec3 position = vec3(xPos, sin(yPos/quadSize.y * PI * 2.), cos(yPos/quadSize.y * PI * 2.));\\n //vec3 offset = vec3(-quadSize.x * 0.5, 0., 0.);\\n position += offset;\\n \\n vec3 normal = vec3(0., 0., -1.) + vec3(0., 0., 2.)*zId;\\n \\n float spinStrength = 4.;\\n mat4 spiral = rotX(((position.x+time*8.)/planeSize.x)*PI*spinStrength);\\n position = (spiral * vec4(position, 1.)).xyz;\\n \\n vec2 uv = vec2(xPos/(planeSize.x+1.), yPos/(planeSize.y+1.));\\n \\n vertexData data;\\n data.position = position;\\n data.uv = uv;\\n data.normal = (spiral * vec4(normal, 0.)).xyz;\\n return data;\\n}\\n\\nvoid main() {\\n float vTriId = mod(vertexId, 3.);\\n vertexData v = get_VertexData(vertexId, vertexCount);\\n \\n vec3 v0 = get_VertexData(vertexId - vTriId, vertexCount).position;\\n vec3 v1 = get_VertexData(vertexId - (vTriId - 1.), vertexCount).position;\\n vec3 v2 = get_VertexData(vertexId - (vTriId - 2.), vertexCount).position;\\n vec3 e1 = v0 - v1;\\n vec3 e2 = v2 - v1;\\n vec3 normal = cross(e1, e2);\\n \\n normal = v.normal;\\n vec2 m = mouse * PI * 0.5;\\n vec3 lightPos = vec3(0., sin(m.y), -cos(m.y));\\n vec3 lightDir = normalize(lightPos);\\n vec3 lightColor = hsv2rgb(vec3(v.uv.x + time * 0.1, 1.0, 1.0));\\n float ambientLight = 0.1;\\n \\n mat4 view = trans(vec3(0., 0., -50.));\\n //mat4 proj = scale(1./pow(2., 8.));\\n mat4 proj = persp(PI * 0.5, resolution.x / resolution.y, 0.1, 100.);\\n gl_Position = proj * view * vec4(v.position, 1.);\\n \\n float directLightStrength = clamp(dot(normal, lightDir), 0., 1.);\\n v_color = vec4(clamp(directLightStrength + ambientLight, 0.0, 1.0) * lightColor, 1.);\\n //v_color = vec4(hsv2rgb(vec3(v.uv.x+time*0.5, 1.0, 1.0)), 1.);\\n gl_PointSize = 1.;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/dzasterpeace/somewhere", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 scale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotX( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, -s, 0,\n 0, s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nstruct vertexData {\n vec3 position;\n vec2 uv;\n vec3 normal;\n};\n \n vec3 quadPos(float vId) {\n float vIdQuad = mod(vId, 6.); // 0 1 2 3 4 5\n \n float vIdTri = mod(vIdQuad, 3.); // 0 1 2 0 1 2\n float tId = floor(vIdQuad / 3.); // 0 0 0 1 1 1\n \n float x = mod(vIdQuad, 2.); // 0 1 0 1 0 1\n float yRaw = floor(vIdTri / 2.); // 0 0 1 0 0 1\n float y = abs(yRaw - tId); // 0 0 1 1 1 0\n return vec3(x, y, 0.);\n }\n\nvertexData get_VertexData(float vId, float vCount) {\n float triId = floor(vId / 3.);\n float triVertexId = mod(vId, 3.);\n float quadCount = floor(vCount / 6.);\n float quadIdx = floor(triId/2.);\n \n vec2 planeSize = vec2(floor(quadCount / 32.), 32.);\n float xId = floor(quadIdx / (planeSize.y * 2.));\n float yId = mod(quadIdx, planeSize.y * 2.);\n float zId = floor(yId / planeSize.y);\n vec3 quadId = vec3(xId, mod(yId, planeSize.y), 1.);\n \n float xPos = mod(vId, 2.) + quadId.x;\n float yPos = abs(floor(triVertexId / 2.) - mod(triId, 2.)) + quadId.y;\n \n vec3 position = vec3(xPos, yPos, (zId*2.+1.)*0.01);\n vec3 offset = vec3(-planeSize.x * 0.25, -planeSize.y*0.5, 0.);\n //vec3 position = vec3(xPos, sin(yPos/quadSize.y * PI * 2.), cos(yPos/quadSize.y * PI * 2.));\n //vec3 offset = vec3(-quadSize.x * 0.5, 0., 0.);\n position += offset;\n \n vec3 normal = vec3(0., 0., -1.) + vec3(0., 0., 2.)*zId;\n \n float spinStrength = 4.;\n mat4 spiral = rotX(((position.x+time*8.)/planeSize.x)*PI*spinStrength);\n position = (spiral * vec4(position, 1.)).xyz;\n \n vec2 uv = vec2(xPos/(planeSize.x+1.), yPos/(planeSize.y+1.));\n \n vertexData data;\n data.position = position;\n data.uv = uv;\n data.normal = (spiral * vec4(normal, 0.)).xyz;\n return data;\n}\n\nvoid main() {\n float vTriId = mod(vertexId, 3.);\n vertexData v = get_VertexData(vertexId, vertexCount);\n \n vec3 v0 = get_VertexData(vertexId - vTriId, vertexCount).position;\n vec3 v1 = get_VertexData(vertexId - (vTriId - 1.), vertexCount).position;\n vec3 v2 = get_VertexData(vertexId - (vTriId - 2.), vertexCount).position;\n vec3 e1 = v0 - v1;\n vec3 e2 = v2 - v1;\n vec3 normal = cross(e1, e2);\n \n normal = v.normal;\n vec2 m = mouse * PI * 0.5;\n vec3 lightPos = vec3(0., sin(m.y), -cos(m.y));\n vec3 lightDir = normalize(lightPos);\n vec3 lightColor = hsv2rgb(vec3(v.uv.x + time * 0.1, 1.0, 1.0));\n float ambientLight = 0.1;\n \n mat4 view = trans(vec3(0., 0., -50.));\n //mat4 proj = scale(1./pow(2., 8.));\n mat4 proj = persp(PI * 0.5, resolution.x / resolution.y, 0.1, 100.);\n gl_Position = proj * view * vec4(v.position, 1.);\n \n float directLightStrength = clamp(dot(normal, lightDir), 0., 1.);\n v_color = vec4(clamp(directLightStrength + ambientLight, 0.0, 1.0) * lightColor, 1.);\n //v_color = vec4(hsv2rgb(vec3(v.uv.x+time*0.5, 1.0, 1.0)), 1.);\n gl_PointSize = 1.;\n}" + }, "screenshotURL": "data/images/images-kyahbhq14imcddtpn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rM3dTWcBEhMiFfgEm/art.json b/art/rM3dTWcBEhMiFfgEm/art.json index 517d9cea..c64409d5 100644 --- a/art/rM3dTWcBEhMiFfgEm/art.json +++ b/art/rM3dTWcBEhMiFfgEm/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "artramo", "avatarUrl": "https://secure.gravatar.com/avatar/558e3844e500b86614c77ce6e23b8363?default=retro&size=200", - "settings": "{\"num\":2,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main () {\\n \\n \\n float x = vertexId * .1;\\n float y = vertexId * .1;\\n \\n \\n gl_Position = vec4(x,y,0,1);\\n \\n gl_PointSize = 20.0;\\n \\n v_color = vec4(1,0,0,1); \\n}\"}", + "settings": { + "num": 2, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main () {\n \n \n float x = vertexId * .1;\n float y = vertexId * .1;\n \n \n gl_Position = vec4(x,y,0,1);\n \n gl_PointSize = 20.0;\n \n v_color = vec4(1,0,0,1); \n}" + }, "screenshotURL": "data/images/images-j24g6nm6ykvr95qch-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rMKz3eBbT4NuADdZY/art.json b/art/rMKz3eBbT4NuADdZY/art.json index 4de6553f..7e8a81f8 100644 --- a/art/rMKz3eBbT4NuADdZY/art.json +++ b/art/rMKz3eBbT4NuADdZY/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "shtrompel", "avatarUrl": "https://lh4.googleusercontent.com/-zzOobLO0ab8/AAAAAAAAAAI/AAAAAAAAANE/T3yiwRxnSlA/photo.jpg", - "settings": "{\"num\":4000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\n// Pseudo-random number generator\\n// Taken from \\\"The Book Of Shader\\\"\\n// https://thebookofshaders.com/10/\\nfloat random(vec2 st) {\\n return fract(sin(dot(st.xy,vec2(120.9898,708.233) * 43758.5453123)));\\n}\\n\\nvoid main() {\\n //Generate random x and y position\\n float x_Pos = random(vec2(vertexId / vertexCount, 0));\\n x_Pos = 4.0 * (x_Pos - 0.5);\\n float y_Pos = random(vec2(vertexId / vertexCount, 1));\\n y_Pos = 4.0 * (y_Pos - 0.5);\\n \\n //Create circular movement with the sin and cos functions theme\\n x_Pos += sin(time / 4. + vertexId / vertexCount);\\n y_Pos += cos(time * 1.25 + vertexId / vertexCount);\\n \\n \\n vec2 position = vec2(x_Pos, y_Pos);\\n \\n //Some mouse interactivity\\n position += position * distance(mouse, position) * 2.0 * step(distance(mouse, position), 0.6);\\n \\n //Apply position\\n gl_Position = vec4(position, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n \\n //Generate random color\\n float r = random(vec2(vertexId / vertexCount, 2)) / 4.;\\n float g = random(vec2(vertexId / vertexCount, 3)) / 4.;\\n float b = random(vec2(vertexId / vertexCount, 4)) / 4.;\\n \\n //Create smooth color transitioning with the sin function\\n r += sin(time / 1.4 + 1.12) / 4.0 * 3.0;\\n g += sin(time / 0.9 + 0.25) / 4.0 * 3.0;\\n b += sin(time / 1.2 + 1.62) / 4.0 * 3.0;\\n \\n //Apply color\\n v_color = vec4(r, g, b, 0.25);\\n}\"}", + "settings": { + "num": 4000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\n// Pseudo-random number generator\n// Taken from \"The Book Of Shader\"\n// https://thebookofshaders.com/10/\nfloat random(vec2 st) {\n return fract(sin(dot(st.xy,vec2(120.9898,708.233) * 43758.5453123)));\n}\n\nvoid main() {\n //Generate random x and y position\n float x_Pos = random(vec2(vertexId / vertexCount, 0));\n x_Pos = 4.0 * (x_Pos - 0.5);\n float y_Pos = random(vec2(vertexId / vertexCount, 1));\n y_Pos = 4.0 * (y_Pos - 0.5);\n \n //Create circular movement with the sin and cos functions theme\n x_Pos += sin(time / 4. + vertexId / vertexCount);\n y_Pos += cos(time * 1.25 + vertexId / vertexCount);\n \n \n vec2 position = vec2(x_Pos, y_Pos);\n \n //Some mouse interactivity\n position += position * distance(mouse, position) * 2.0 * step(distance(mouse, position), 0.6);\n \n //Apply position\n gl_Position = vec4(position, 0, 1);\n \n gl_PointSize = 10.0;\n \n \n //Generate random color\n float r = random(vec2(vertexId / vertexCount, 2)) / 4.;\n float g = random(vec2(vertexId / vertexCount, 3)) / 4.;\n float b = random(vec2(vertexId / vertexCount, 4)) / 4.;\n \n //Create smooth color transitioning with the sin function\n r += sin(time / 1.4 + 1.12) / 4.0 * 3.0;\n g += sin(time / 0.9 + 0.25) / 4.0 * 3.0;\n b += sin(time / 1.2 + 1.62) / 4.0 * 3.0;\n \n //Apply color\n v_color = vec4(r, g, b, 0.25);\n}" + }, "screenshotURL": "data/images/images-jzyzpjjyy5qz9j5im-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rRHoXfKZBnnwFz4bZ/art.json b/art/rRHoXfKZBnnwFz4bZ/art.json index cc4460fc..10207031 100644 --- a/art/rRHoXfKZBnnwFz4bZ/art.json +++ b/art/rRHoXfKZBnnwFz4bZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"void main() {\\n \\n float density = 10.;\\n \\n float xoff = -1.;\\n \\n float yoff = -1.;\\n \\n float ux = 0.2;\\n \\n float uy = 0.2;\\n \\n float x = mod(vertexId , density);\\n \\n float y = mod(floor(vertexId / density), density);\\n \\n float step = mod(vertexId, density * density);\\n \\n float psize = mod(step, 3.) * 3. * (sin(time) + 1.);\\n \\n \\n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\\n \\n \\n gl_PointSize = psize;\\n\\n v_color = vec4(y * 100.,x * 100., time, 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "void main() {\n \n float density = 10.;\n \n float xoff = -1.;\n \n float yoff = -1.;\n \n float ux = 0.2;\n \n float uy = 0.2;\n \n float x = mod(vertexId , density);\n \n float y = mod(floor(vertexId / density), density);\n \n float step = mod(vertexId, density * density);\n \n float psize = mod(step, 3.) * 3. * (sin(time) + 1.);\n \n \n gl_Position = vec4(x * ux + xoff, y * uy + yoff, 0, 1);\n \n \n gl_PointSize = psize;\n\n v_color = vec4(y * 100.,x * 100., time, 1);\n\n}" + }, "screenshotURL": "data/images/images-apti4og1951tg8v07-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rSBQxzNrXNNi9dKme/art.json b/art/rSBQxzNrXNNi9dKme/art.json index 9abfc68e..7c81d195 100644 --- a/art/rSBQxzNrXNNi9dKme/art.json +++ b/art/rSBQxzNrXNNi9dKme/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "xingchen0085", "avatarUrl": "https://secure.gravatar.com/avatar/8c9ba36ee71e9137874a23642ee6e100?default=retro&size=200", - "settings": "{\"num\":80000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rand(vec2 co) {\\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\\n}\\n\\nfloat noise(vec2 r) {\\n\\tvec2 p = floor(r);\\n vec2 f = fract(r);\\n f = smoothstep(0.,1.,f);\\n vec2 e = vec2(0,1);\\n float p00 = rand(p+e.xx);\\n float p01 = rand(p+e.xy);\\n float p10 = rand(p+e.yx);\\n float p11 = rand(p+e.yy);\\n\\treturn mix(\\n mix(p00,p01,f.y),\\n mix(p10,p11,f.y),\\n f.x) - 0.5;\\n}\\n\\nfloat ot(vec2 r) {\\n\\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\\n return v * 0.5 + 0.5;\\n}\\n\\nvoid shift(inout vec3 p) {\\n\\tp.y += pow(ot(p.xz),1.2)*0.5;\\n}\\n\\nvoid main() {\\n vec3 pos, color;\\n float alpha = 1.0;\\n vec2 div;\\n int i = int(mod(vertexId,6.));\\n if(i==0) {\\n div = vec2(-1,-1);\\n } else if(i==1) {\\n div = vec2(-1,1);\\n } else if(i==2) {\\n div = vec2(1,-1);\\n } else if(i==3) {\\n div = vec2(1,-1);\\n } else if(i==4) {\\n div = vec2(-1,1);\\n } else if(i==5) {\\n div = vec2(1,1);\\n }\\n if(vertexId < 6.) {\\n pos = vec3(0,0,100.);\\n pos.xy += div * 1000.;\\n color = vec3(0.03);\\n } else if(vertexId < 12.) {\\n pos = vec3(0,0.2,0);\\n pos.xz += div * 100.;\\n color = vec3(0,0,0.2);\\n } else if(vertexId < 4812.) {\\n float vid = vertexId-6.;\\n float unitIx = floor(vid/6.);\\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\\n p.x -= 20.5;\\n p *= 0.5;\\n vec2 origP = p;\\n \\n p += div * 0.25;\\n\\tpos = vec3(p.x,0,p.y);\\n shift(pos);\\n \\n color = vec3(0.1,0.1,0.3);\\n color *= noise(pos.xz) * 0.5 + 0.5;\\n \\n vec3 u = pos - vec3(1,1.5,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - abs(u.y*0.2);\\n \\n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\\n } else if(vertexId < 15000.) {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float per = time*3. + rand(vec2(unitIx,3));\\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\\n float th = rand(vec2(seed,0))*3.1415926535*2.;\\n th += rand(vec2(seed,1));\\n float rad = rand(vec2(seed,2))*10. + 0.2;\\n pos = vec3(cos(th),0,sin(th)) * rad;\\n float ww = rand(vec2(seed,400))*0.02;\\n float ww2 = rand(vec2(seed,6))*0.5;\\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\\n pos.y += 3.0;\\n pos.z -= 1.0;\\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\\n \\tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\\n } else {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float v = rand(vec2(unitIx,9.))*2.-1.;\\n float per = time * 0.02 * v;\\n float au = time*0.05 + rand(vec2(unitIx,10.));\\n pos = vec3(\\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\\n rand(vec2(unitIx,2.)) * 2.,\\n rand(vec2(unitIx,3.)) * 2. - 1.\\n );\\n pos.x += sin(au*3.1415926535*2.)*0.1;\\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\\n vec3 ddiv = vec3(div,0.);\\n float ra = time*(1. + rand(vec2(unitIx,8.)));\\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n ra *= 2.;\\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n float size = rand(vec2(unitIx,5.))+0.5;\\n pos += ddiv*0.01*size;\\n \\n vec3 u = pos - vec3(1,1.8,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - u.y*0.05;\\n \\n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\\n \\talpha = 0.;\\n }\\n vec3 cam = vec3(0.,1.,0.);\\n pos -= cam;\\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\\n\\n float near = 0.001;\\n float far = 1000.;\\n float fovy = 3.1415926535 * 0.4;\\n float aspect = resolution.x / resolution.y;\\n float f = 1. / tan(fovy / 2.);\\n mat4 P = mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0,0,-2./(far-near),1,\\n 0,0,-(far+near)/(far-near),1\\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\\n // 0, 0, -1, 0\\n );\\n gl_Position = P * vec4(pos,1.);\\n v_color = vec4(color,alpha);\\n}\"}", + "settings": { + "num": 80000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rand(vec2 co) {\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\n}\n\nfloat noise(vec2 r) {\n\tvec2 p = floor(r);\n vec2 f = fract(r);\n f = smoothstep(0.,1.,f);\n vec2 e = vec2(0,1);\n float p00 = rand(p+e.xx);\n float p01 = rand(p+e.xy);\n float p10 = rand(p+e.yx);\n float p11 = rand(p+e.yy);\n\treturn mix(\n mix(p00,p01,f.y),\n mix(p10,p11,f.y),\n f.x) - 0.5;\n}\n\nfloat ot(vec2 r) {\n\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\n return v * 0.5 + 0.5;\n}\n\nvoid shift(inout vec3 p) {\n\tp.y += pow(ot(p.xz),1.2)*0.5;\n}\n\nvoid main() {\n vec3 pos, color;\n float alpha = 1.0;\n vec2 div;\n int i = int(mod(vertexId,6.));\n if(i==0) {\n div = vec2(-1,-1);\n } else if(i==1) {\n div = vec2(-1,1);\n } else if(i==2) {\n div = vec2(1,-1);\n } else if(i==3) {\n div = vec2(1,-1);\n } else if(i==4) {\n div = vec2(-1,1);\n } else if(i==5) {\n div = vec2(1,1);\n }\n if(vertexId < 6.) {\n pos = vec3(0,0,100.);\n pos.xy += div * 1000.;\n color = vec3(0.03);\n } else if(vertexId < 12.) {\n pos = vec3(0,0.2,0);\n pos.xz += div * 100.;\n color = vec3(0,0,0.2);\n } else if(vertexId < 4812.) {\n float vid = vertexId-6.;\n float unitIx = floor(vid/6.);\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\n p.x -= 20.5;\n p *= 0.5;\n vec2 origP = p;\n \n p += div * 0.25;\n\tpos = vec3(p.x,0,p.y);\n shift(pos);\n \n color = vec3(0.1,0.1,0.3);\n color *= noise(pos.xz) * 0.5 + 0.5;\n \n vec3 u = pos - vec3(1,1.5,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - abs(u.y*0.2);\n \n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\n } else if(vertexId < 15000.) {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float per = time*3. + rand(vec2(unitIx,3));\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\n float th = rand(vec2(seed,0))*3.1415926535*2.;\n th += rand(vec2(seed,1));\n float rad = rand(vec2(seed,2))*10. + 0.2;\n pos = vec3(cos(th),0,sin(th)) * rad;\n float ww = rand(vec2(seed,400))*0.02;\n float ww2 = rand(vec2(seed,6))*0.5;\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\n pos.y += 3.0;\n pos.z -= 1.0;\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\n \tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\n } else {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float v = rand(vec2(unitIx,9.))*2.-1.;\n float per = time * 0.02 * v;\n float au = time*0.05 + rand(vec2(unitIx,10.));\n pos = vec3(\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\n rand(vec2(unitIx,2.)) * 2.,\n rand(vec2(unitIx,3.)) * 2. - 1.\n );\n pos.x += sin(au*3.1415926535*2.)*0.1;\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\n vec3 ddiv = vec3(div,0.);\n float ra = time*(1. + rand(vec2(unitIx,8.)));\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n ra *= 2.;\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n float size = rand(vec2(unitIx,5.))+0.5;\n pos += ddiv*0.01*size;\n \n vec3 u = pos - vec3(1,1.8,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - u.y*0.05;\n \n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\n \talpha = 0.;\n }\n vec3 cam = vec3(0.,1.,0.);\n pos -= cam;\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\n\n float near = 0.001;\n float far = 1000.;\n float fovy = 3.1415926535 * 0.4;\n float aspect = resolution.x / resolution.y;\n float f = 1. / tan(fovy / 2.);\n mat4 P = mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0,0,-2./(far-near),1,\n 0,0,-(far+near)/(far-near),1\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\n // 0, 0, -1, 0\n );\n gl_Position = P * vec4(pos,1.);\n v_color = vec4(color,alpha);\n}" + }, "screenshotURL": "data/images/images-0ry2vjecixxjc6jbr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rSR7ydT97j9GZb8nH/art.json b/art/rSR7ydT97j9GZb8nH/art.json index 41bc3361..02eae3ba 100644 --- a/art/rSR7ydT97j9GZb8nH/art.json +++ b/art/rSR7ydT97j9GZb8nH/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n gl_Position = vec4(0, 1, 0, 1);\\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(0, 1, 0, 1);\n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-dwgp12nto4k49dp5i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rSizteb9kM93uMPS6/art.json b/art/rSizteb9kM93uMPS6/art.json index 7f0c0804..f944f418 100644 --- a/art/rSizteb9kM93uMPS6/art.json +++ b/art/rSizteb9kM93uMPS6/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":8000,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 1.3//KParameter 0.>>2.\\n\\n//KVerticesNumber=50000 \\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv - 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI* 2. + PI * 1.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * -0.2;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(-t * 0.27) + sin(t * -0.013) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.)-1., 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI-2.);\\n float x = cos(qu * PI * 2.) + mouse.y * r*(21.*P3);\\n float y = sin(qu * PI *1.) * r*2.;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 1.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1.);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat/sin(time), val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 8000, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 1.3//KParameter 0.>>2.\n\n//KVerticesNumber=50000 \n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv - 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI* 2. + PI * 1.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * -0.2;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(-t * 0.27) + sin(t * -0.013) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.)-1., 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI-2.);\n float x = cos(qu * PI * 2.) + mouse.y * r*(21.*P3);\n float y = sin(qu * PI *1.) * r*2.;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 1.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1.);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat/sin(time), val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-39wjxjg7tqofganqv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rSvWfDGEoaa5hqb5j/art.json b/art/rSvWfDGEoaa5hqb5j/art.json index ec5fc582..7585b53b 100644 --- a/art/rSvWfDGEoaa5hqb5j/art.json +++ b/art/rSvWfDGEoaa5hqb5j/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":41901,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/hobac/just-once-james-ingram?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(18.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n gl_PointSize = 10.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue + snd, 1, 1)), snd);\\n}\"}", + "settings": { + "num": 41901, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/hobac/just-once-james-ingram?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(18.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n gl_PointSize = 10.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue + snd, 1, 1)), snd);\n}" + }, "screenshotURL": "data/images/images-l7ilf7htifrovzg7t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rTaKpcsBkfYB9EWPk/art.json b/art/rTaKpcsBkfYB9EWPk/art.json index e359ac43..f7528eeb 100644 --- a/art/rTaKpcsBkfYB9EWPk/art.json +++ b/art/rTaKpcsBkfYB9EWPk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":4170,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/whitneysix/didnt-we-almost-have-it-all?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 9.5\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.50));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 9.4) + mod(vertexId, 9.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.015;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + 10.500 * 0.02, 0.55, 5);\\n float hue = (time * s + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 4170, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/whitneysix/didnt-we-almost-have-it-all?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 9.5\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.50));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 9.4) + mod(vertexId, 9.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.015;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + 10.500 * 0.02, 0.55, 5);\n float hue = (time * s + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-kq333heq8zn3tb5kh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rXA7dW2QF9uYGive2/art.json b/art/rXA7dW2QF9uYGive2/art.json index 05c6c4e5..4f8c91a6 100644 --- a/art/rXA7dW2QF9uYGive2/art.json +++ b/art/rXA7dW2QF9uYGive2/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "argonblue", "avatarUrl": "https://secure.gravatar.com/avatar/33a85e016ea152866eb10da331df9bb7?default=retro&size=200", - "settings": "{\"num\":12600,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n#define imod(a, b) ((a) - (b)*((a)/(b)))\\n#define CS(th) (vec2(cos(th), sin(th)))\\n#define N(v) (normalize(vec2(-(v).y, (v).x)))\\n\\n#define NFIGS 7\\n\\n#define V_PER_SEG 9\\n#define P_PER_FIG (int(vertexCount)/(NFIGS*V_PER_SEG))\\n#define V_PER_FIG (P_PER_FIG * V_PER_SEG)\\n\\n#define SPIN 0.5\\n#define BREATHE 0.1\\n\\n#define LINEWIDTH 10.\\n#define ORBIT 0.18\\n#define R_ORBIT 0.63\\n\\nvoid init_figs(out vec2 a[NFIGS]) {\\n a[0] = vec2(-3, 1);\\n a[1] = vec2(3, 1);\\n a[2] = vec2(5, 1);\\n a[3] = vec2(3, 1);\\n a[4] = vec2(5, 2);\\n a[5] = vec2(7, 2);\\n a[6] = vec2(-2, 1);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// Triangles for main rect of line segment\\nvec2 rect_tri(vec2 pn[3], int vnum, float nlw) {\\n vec2 n = N(pn[1] - pn[0]);\\n vec2 wv = 0.5 * n * nlw;\\n mat3 pm = mat3(vec3(pn[0], 0),\\n vec3(pn[1], 0),\\n vec3(wv, 0));\\n // This vertex order allows easier visualization\\n // using LINE_STRIP\\n vec3 ops[6];\\n // No array initializers in ES 100...\\n // Columns of pm are (pn[0], pn[1], wv)\\n ops[0] = vec3(1, 0, 1);\\n ops[1] = vec3(1, 0, -1);\\n ops[2] = vec3(0, 1, -1);\\n ops[3] = vec3(0, 1, 1);\\n ops[4] = vec3(1, 0, 1);\\n ops[5] = vec3(0, 1, -1);\\n // Work around constant-index-expression...\\n for (int i = 0; i < 6; i++) {\\n if (vnum == i) {\\n return (pm * ops[i]).xy;\\n }\\n }\\n}\\n\\n// Bevel triangle to fill joints\\nvec2 bevel_tri(vec2 pn[3], int vnum, float nlw) {\\n vec2 n1 = N(pn[1] - pn[0]);\\n vec2 n2 = N(pn[2] - pn[1]);\\n // Cross product to decide which side to draw on\\n vec3 s = cross(vec3(n1, 0), vec3(n2, 0));\\n float d = -sign(s.z) * 0.5 * nlw;\\n mat3 pm = mat3(vec3(pn[1], 0),\\n vec3(n1 * d, 0),\\n vec3(n2 * d, 0));\\n bvec2 sel = equal(ivec2(0, 1), ivec2(vnum));\\n return (pm * vec3(1, sel)).xy;\\n}\\n\\n// Thick line triangulation\\nvec2 genvert(vec2 pn[3], int vnum, float lw) {\\n float nlw = lw/min(resolution.x, resolution.y);\\n if (vnum < 6) {\\n return rect_tri(pn, vnum, nlw);\\n } else {\\n return bevel_tri(pn, vnum - 6, nlw);\\n }\\n}\\n\\n// Actual trochoid calculation\\nvec2 curvepoint(float th, float ph, float a, float b, float rph) {\\n vec2 p1 = CS(b*th);\\n vec2 p2 = CS((b-a)*th+ph/b);\\n float r = cos(rph);\\n r = 1.-(r*r);\\n return 0.21 * vec2(mix(p1, p2, r));\\n}\\n\\nvec2 fig(vec2 fig, int vnum, float pnum, float bph, float lw) {\\n float pmax = float(P_PER_FIG);\\n float ph = 2.*PI*time*SPIN;\\n float rph = 2.*PI*time*BREATHE + bph;\\n vec2 pn[3];\\n float th;\\n for (int i = 0; i < 3; i++) {\\n th = 2.*PI*((pnum-float(2-i))/(pmax-1.));\\n pn[i] = curvepoint(th, ph, fig[0], fig[1], rph);\\n }\\n return genvert(pn, vnum, lw);\\n}\\n\\nvoid main() {\\n gl_PointSize = 4.;\\n\\n vec2 figs[NFIGS];\\n init_figs(figs);\\n\\n int fnum = int(vertexId)/V_PER_FIG;\\n // Vertex number within a line segment\\n int vnum = imod(int(vertexId), V_PER_SEG);\\n float pnum = float(imod(int(vertexId), V_PER_FIG)/V_PER_SEG);\\n float pmax = float(P_PER_FIG);\\n\\n float bph = 2.*PI*float(fnum)/float(NFIGS);\\n vec2 xy;\\n for (int i = 0; i < NFIGS; i++) {\\n if (i != fnum) { continue; }\\n xy = fig(figs[i], vnum, pnum, bph, LINEWIDTH);\\n }\\n\\n vec2 offset = R_ORBIT*CS(2.*PI*(float(fnum)/float(NFIGS)+time*ORBIT));\\n xy += offset;\\n\\n vec2 aspect;\\n if (resolution.x > resolution.y) {\\n aspect = vec2(resolution.y/resolution.x, 1);\\n } else {\\n aspect = vec2(1, resolution.x/resolution.y);\\n }\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n // v_color = vec4(.2,.8,1.,1.);\\n float v = fract(time*.21+2.*pnum/pmax);\\n v = 2. * mix(v, (1. - v), step(0.5, v));\\n float hue = .5+.27*v;\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n if (fnum >= NFIGS) {\\n v_color = vec4(1,1,0,1);\\n }\\n}\\n\"}", + "settings": { + "num": 12600, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n#define imod(a, b) ((a) - (b)*((a)/(b)))\n#define CS(th) (vec2(cos(th), sin(th)))\n#define N(v) (normalize(vec2(-(v).y, (v).x)))\n\n#define NFIGS 7\n\n#define V_PER_SEG 9\n#define P_PER_FIG (int(vertexCount)/(NFIGS*V_PER_SEG))\n#define V_PER_FIG (P_PER_FIG * V_PER_SEG)\n\n#define SPIN 0.5\n#define BREATHE 0.1\n\n#define LINEWIDTH 10.\n#define ORBIT 0.18\n#define R_ORBIT 0.63\n\nvoid init_figs(out vec2 a[NFIGS]) {\n a[0] = vec2(-3, 1);\n a[1] = vec2(3, 1);\n a[2] = vec2(5, 1);\n a[3] = vec2(3, 1);\n a[4] = vec2(5, 2);\n a[5] = vec2(7, 2);\n a[6] = vec2(-2, 1);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// Triangles for main rect of line segment\nvec2 rect_tri(vec2 pn[3], int vnum, float nlw) {\n vec2 n = N(pn[1] - pn[0]);\n vec2 wv = 0.5 * n * nlw;\n mat3 pm = mat3(vec3(pn[0], 0),\n vec3(pn[1], 0),\n vec3(wv, 0));\n // This vertex order allows easier visualization\n // using LINE_STRIP\n vec3 ops[6];\n // No array initializers in ES 100...\n // Columns of pm are (pn[0], pn[1], wv)\n ops[0] = vec3(1, 0, 1);\n ops[1] = vec3(1, 0, -1);\n ops[2] = vec3(0, 1, -1);\n ops[3] = vec3(0, 1, 1);\n ops[4] = vec3(1, 0, 1);\n ops[5] = vec3(0, 1, -1);\n // Work around constant-index-expression...\n for (int i = 0; i < 6; i++) {\n if (vnum == i) {\n return (pm * ops[i]).xy;\n }\n }\n}\n\n// Bevel triangle to fill joints\nvec2 bevel_tri(vec2 pn[3], int vnum, float nlw) {\n vec2 n1 = N(pn[1] - pn[0]);\n vec2 n2 = N(pn[2] - pn[1]);\n // Cross product to decide which side to draw on\n vec3 s = cross(vec3(n1, 0), vec3(n2, 0));\n float d = -sign(s.z) * 0.5 * nlw;\n mat3 pm = mat3(vec3(pn[1], 0),\n vec3(n1 * d, 0),\n vec3(n2 * d, 0));\n bvec2 sel = equal(ivec2(0, 1), ivec2(vnum));\n return (pm * vec3(1, sel)).xy;\n}\n\n// Thick line triangulation\nvec2 genvert(vec2 pn[3], int vnum, float lw) {\n float nlw = lw/min(resolution.x, resolution.y);\n if (vnum < 6) {\n return rect_tri(pn, vnum, nlw);\n } else {\n return bevel_tri(pn, vnum - 6, nlw);\n }\n}\n\n// Actual trochoid calculation\nvec2 curvepoint(float th, float ph, float a, float b, float rph) {\n vec2 p1 = CS(b*th);\n vec2 p2 = CS((b-a)*th+ph/b);\n float r = cos(rph);\n r = 1.-(r*r);\n return 0.21 * vec2(mix(p1, p2, r));\n}\n\nvec2 fig(vec2 fig, int vnum, float pnum, float bph, float lw) {\n float pmax = float(P_PER_FIG);\n float ph = 2.*PI*time*SPIN;\n float rph = 2.*PI*time*BREATHE + bph;\n vec2 pn[3];\n float th;\n for (int i = 0; i < 3; i++) {\n th = 2.*PI*((pnum-float(2-i))/(pmax-1.));\n pn[i] = curvepoint(th, ph, fig[0], fig[1], rph);\n }\n return genvert(pn, vnum, lw);\n}\n\nvoid main() {\n gl_PointSize = 4.;\n\n vec2 figs[NFIGS];\n init_figs(figs);\n\n int fnum = int(vertexId)/V_PER_FIG;\n // Vertex number within a line segment\n int vnum = imod(int(vertexId), V_PER_SEG);\n float pnum = float(imod(int(vertexId), V_PER_FIG)/V_PER_SEG);\n float pmax = float(P_PER_FIG);\n\n float bph = 2.*PI*float(fnum)/float(NFIGS);\n vec2 xy;\n for (int i = 0; i < NFIGS; i++) {\n if (i != fnum) { continue; }\n xy = fig(figs[i], vnum, pnum, bph, LINEWIDTH);\n }\n\n vec2 offset = R_ORBIT*CS(2.*PI*(float(fnum)/float(NFIGS)+time*ORBIT));\n xy += offset;\n\n vec2 aspect;\n if (resolution.x > resolution.y) {\n aspect = vec2(resolution.y/resolution.x, 1);\n } else {\n aspect = vec2(1, resolution.x/resolution.y);\n }\n gl_Position = vec4(xy * aspect, 0, 1);\n\n // v_color = vec4(.2,.8,1.,1.);\n float v = fract(time*.21+2.*pnum/pmax);\n v = 2. * mix(v, (1. - v), step(0.5, v));\n float hue = .5+.27*v;\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n if (fnum >= NFIGS) {\n v_color = vec4(1,1,0,1);\n }\n}\n" + }, "screenshotURL": "data/images/images-nuewkledrnmenfsgg-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rY5QZeD8g5uu2MF75/art.json b/art/rY5QZeD8g5uu2MF75/art.json index 3e0afc44..6fb60fbf 100644 --- a/art/rY5QZeD8g5uu2MF75/art.json +++ b/art/rY5QZeD8g5uu2MF75/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.1\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 2.3;\\n c = sin(sin(pos.x) + sin(1.2 * pos.y) + sin(3.3 * pos.x + pos.y + 3.4 * time) + sin(pos.x + sin(pos.y + 2.5 * time))) + (sin(pos.x * pos.y - 3.6 * time) * 7.5 + 8.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.9) / (w / 2.10);\\n float py = (floor(vId / w) - h / 2.1) / (h / 2.2);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.4;\\n\\n float c = plasma(vec2(px, py) * 4.7);\\n v_color = vec4(c, 2.8 * c, 3.9 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.1\n\nfloat plasma(vec2 pos)\n{\n float c = 2.3;\n c = sin(sin(pos.x) + sin(1.2 * pos.y) + sin(3.3 * pos.x + pos.y + 3.4 * time) + sin(pos.x + sin(pos.y + 2.5 * time))) + (sin(pos.x * pos.y - 3.6 * time) * 7.5 + 8.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.9) / (w / 2.10);\n float py = (floor(vId / w) - h / 2.1) / (h / 2.2);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.4;\n\n float c = plasma(vec2(px, py) * 4.7);\n v_color = vec4(c, 2.8 * c, 3.9 * c, 1);\n}" + }, "screenshotURL": "data/images/images-9ej646lhpae1eczpe-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rYnPNYL9sQiTPrSfz/art.json b/art/rYnPNYL9sQiTPrSfz/art.json index 3d84547e..9819abeb 100644 --- a/art/rYnPNYL9sQiTPrSfz/art.json +++ b/art/rYnPNYL9sQiTPrSfz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/butterflycrash/butterfly-crash-4-dem-filthy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),2.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 12.;\\n\\n \\tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\\n\\tfloat hexSpace = 1.0;\\n \\tvec2 height = vec2(1.,0.4);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 33.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 12.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (snd2 * pow(ringCircle,2.) + 3. * ringCircle /snd) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\\n float rangeInv = 0.2 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.143,\\n yAxis, 0.001,\\n zAxis, .210,\\n eye, sin(1.51*time));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 * a10 * b09 - a12 * b06,\\n a00 * b09 - a01 / b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) * det;\\n}\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye+(3.*mouse.y), target*2., (up-1.,-up)))\\n\\n;\\n #else\\n vec3 zAxis = normalize(target * eye)/mouse.x;\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1.,\\n yAxis, -1.2+snd\\n zAxis, 1.2\\n -dot(xAxis, 1.-eye)*mouse, *dot(yAxis, mouse*eye),-dot(zAxis, eye), .6); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/butterflycrash/butterfly-crash-4-dem-filthy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),1.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),2.,sin(a),0.,1.1,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),2.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,1,z,1,0,1,0,0,x,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 12.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 2., 6.);\n\tfloat hexSpace = 1.0;\n \tvec2 height = vec2(1.,0.4);\n \t\n\tfloat indexQuad = floor(vertexId / 33.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 12.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 2.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, sin(ringCircle * 1.1))*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (snd2 * pow(ringCircle,2.) + 3. * ringCircle /snd) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.95 - sin(time * 0.65) * fov+fov);\n float rangeInv = 0.2 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, f-0.1,\n 0, 0, zNear * zFar * rangeInv * 3., 0.5);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.143,\n yAxis, 0.001,\n zAxis, .210,\n eye, sin(1.51*time));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 * a10 * b09 - a12 * b06,\n a00 * b09 - a01 / b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) * det;\n}\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye+(3.*mouse.y), target*2., (up-1.,-up)))\n\n;\n #else\n vec3 zAxis = normalize(target * eye)/mouse.x;\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1.,\n yAxis, -1.2+snd\n zAxis, 1.2\n -dot(xAxis, 1.-eye)*mouse, *dot(yAxis, mouse*eye),-dot(zAxis, eye), .6); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-3jssc64o3ih3hg3wm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rYriGa7yHEJZnvYrG/art.json b/art/rYriGa7yHEJZnvYrG/art.json index 66d8b8d5..ccd84fd6 100644 --- a/art/rYriGa7yHEJZnvYrG/art.json +++ b/art/rYriGa7yHEJZnvYrG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "dailylightdebris", "avatarUrl": "https://secure.gravatar.com/avatar/4db47dcfffbaa9c15631f445ed4951ea?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.5)\\n#define STEP 1.1\\t\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.01, 0, 1);\\n\\n float b = 2.0 - pow(sin(count * 1.0) * 0.3 + 0.9, 0.1);\\n b = 0.0;mix(0.3, 0.1, b);\\n v_color = vec4(0.5, 0.2, 0.2, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.5)\n#define STEP 1.1\t\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.01, 0, 1);\n\n float b = 2.0 - pow(sin(count * 1.0) * 0.3 + 0.9, 0.1);\n b = 0.0;mix(0.3, 0.1, b);\n v_color = vec4(0.5, 0.2, 0.2, 1);\n}" + }, "screenshotURL": "data/images/images-0wbd718wlugtp9b47-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rZXHyphbAzHHHzkAc/art.json b/art/rZXHyphbAzHHHzkAc/art.json index 9566bf4b..6a463267 100644 --- a/art/rZXHyphbAzHHHzkAc/art.json +++ b/art/rZXHyphbAzHHHzkAc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":20,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = vertexId / vertexCount;\\n float angle = point * PI * 2.0;\\n float radius = 0.8;\\n float t = time * 0.5;\\n float c = cos(angle + t) * radius;\\n float s = sin(angle + t) * radius;\\n\\n //vec2 aspect = vec2(1, resolution.x / resolution.y);\\n //float x = c, y = s, z = 1.1, sz = 1./z;\\n float fov = 1. + (clamp(mouse.x, -1., 1.) + 1.); // 1.4;\\n float x = c, y = s * mouse.y * -0.3, z = (fov + 1.) + s, sz = 1./z;\\n float fovxy = fov;\\n gl_Position = vec4(vec2(x, y)*fovxy, -sz, z);\\n gl_PointSize = resolution.x/15.*sz;\\n\\n float hue = (time * 0.01 + point * 1.001);\\n float accent = clamp(1./(z-fov), 0., 1.);\\n v_color = vec4(hsv2rgb(vec3(hue, accent, accent)), 1);\\n}\"}", + "settings": { + "num": 20, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = vertexId / vertexCount;\n float angle = point * PI * 2.0;\n float radius = 0.8;\n float t = time * 0.5;\n float c = cos(angle + t) * radius;\n float s = sin(angle + t) * radius;\n\n //vec2 aspect = vec2(1, resolution.x / resolution.y);\n //float x = c, y = s, z = 1.1, sz = 1./z;\n float fov = 1. + (clamp(mouse.x, -1., 1.) + 1.); // 1.4;\n float x = c, y = s * mouse.y * -0.3, z = (fov + 1.) + s, sz = 1./z;\n float fovxy = fov;\n gl_Position = vec4(vec2(x, y)*fovxy, -sz, z);\n gl_PointSize = resolution.x/15.*sz;\n\n float hue = (time * 0.01 + point * 1.001);\n float accent = clamp(1./(z-fov), 0., 1.);\n v_color = vec4(hsv2rgb(vec3(hue, accent, accent)), 1);\n}" + }, "screenshotURL": "data/images/images-80jhf3s1ev6vkv6qw-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rZcr6zk3jJKzwJ2mD/art.json b/art/rZcr6zk3jJKzwJ2mD/art.json index 871f1158..8e3698d1 100644 --- a/art/rZcr6zk3jJKzwJ2mD/art.json +++ b/art/rZcr6zk3jJKzwJ2mD/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":18000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cristianvarela/ken-ishii-play-biting-cristian\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.23137254901960785,0.7490196078431373,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 1800.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float snd0 = texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n float snd1 = texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId * 0.02 + time * 3.1 * (lineId + 1.), pointId, pow(snd0, 5.0) * 0.25, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(quadId / quadCount);\\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.10;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.5, lineId * 0.1);\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 18000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cristianvarela/ken-ishii-play-biting-cristian", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.23137254901960785, + 0.7490196078431373, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 1800.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float snd0 = texture2D(sound, vec2(0.13 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n float snd1 = texture2D(sound, vec2(0.14 + lineId * 0.05, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId * 0.02 + time * 3.1 * (lineId + 1.), pointId, pow(snd0, 5.0) * 0.25, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n \n vec3 aspect = vec3(resolution.y / resolution.x, 1, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(quadId / quadCount);\n gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.10;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.5, lineId * 0.1);\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-6gr89azxk9gli8n8b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/raCeFgW4uDJ8yZBwD/art.json b/art/raCeFgW4uDJ8yZBwD/art.json index 7a9e6229..fc8e2578 100644 --- a/art/raCeFgW4uDJ8yZBwD/art.json +++ b/art/raCeFgW4uDJ8yZBwD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,2,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 1.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 3.;\\n\\n \\tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.0;\\n \\tvec2 height = vec2(10.,0.6);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/mike-destiny-bootlegs/sugarmikedestinyinfact", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekick)\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\n////////////////////////////////////////////////////////////\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,2,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 1.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 3.;\n\n \tfloat polySize = 6.;//clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.0;\n \tvec2 height = vec2(10.,0.6);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 1.) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 1.) / 12.0) - 0.5) + 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(0.1, ringCircle * 0.1)*.1).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(1.0, ringCircle * 0.1)*.1).a * 3.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-7l5rj2ekldfap0aow-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ranzZohyvMMY5qhCs/art.json b/art/ranzZohyvMMY5qhCs/art.json index 0ca5d1db..ee36f0c3 100644 --- a/art/ranzZohyvMMY5qhCs/art.json +++ b/art/ranzZohyvMMY5qhCs/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thenoiseprocess/ousia\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//In progress. Based on http://glslsandbox.com/e#44575.1\\n\\n#define PI radians(270.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0,2.0)), \\n\\t\\t\\t random(i + vec2(sin(time-1.5*3.), 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0.);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 p = uv;//(-resolution + 2.0*uv.xy)/resolution.y;\\n\\t\\n float timeFactor = 10.;\\n \\n\\tfor(int i = 0; i < 8; i++) {\\n\\t\\tp = abs(p)/clamp(dot(p, p), 0.7, 1.0) - vec2(abs(cos(time/timeFactor)), abs(sin(time/timeFactor)));\\n\\t\\t\\n\\t\\tp *= mat2(cos(time/timeFactor), sin(time/timeFactor), -sin(time/timeFactor), cos(time/timeFactor));\\n\\t}\\n\\t\\n\\tvec3 col = mix(vec3(0, 0.1, 0.2), vec3(0.3, 0.5, 1.0), smoothstep(0.0, 1.0, abs(p.x)));\\n\\tcol = mix(col, vec3(0.3, 0.3, 4), smoothstep(0.9, 1.0, abs(p.y)));\\n\\t//gl_FragColor = vec4(col, 1);\\n\\t\\n\\t//gl_FragColor = vec4(vec3(pattern), 1.0);\\n \\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n \\n\\t\\n //camera\\n float r = .7;\\n float tm = time * 0.05;\\n float tm2 = time * 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 2.;//finalDesiredPointSize;\\n\\n v_color = vec4(col, 1);\\n float depth = (v_color.x*v_color.y*v_color.z)/2.;\\n \\n vec4 finalPos = vec4(ux, vy, depth+snd/5., 1.);\\n \\n gl_Position = mat*finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thenoiseprocess/ousia", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//In progress. Based on http://glslsandbox.com/e#44575.1\n\n#define PI radians(270.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0,2.0)), \n\t\t\t random(i + vec2(sin(time-1.5*3.), 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0.);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 p = uv;//(-resolution + 2.0*uv.xy)/resolution.y;\n\t\n float timeFactor = 10.;\n \n\tfor(int i = 0; i < 8; i++) {\n\t\tp = abs(p)/clamp(dot(p, p), 0.7, 1.0) - vec2(abs(cos(time/timeFactor)), abs(sin(time/timeFactor)));\n\t\t\n\t\tp *= mat2(cos(time/timeFactor), sin(time/timeFactor), -sin(time/timeFactor), cos(time/timeFactor));\n\t}\n\t\n\tvec3 col = mix(vec3(0, 0.1, 0.2), vec3(0.3, 0.5, 1.0), smoothstep(0.0, 1.0, abs(p.x)));\n\tcol = mix(col, vec3(0.3, 0.3, 4), smoothstep(0.9, 1.0, abs(p.y)));\n\t//gl_FragColor = vec4(col, 1);\n\t\n\t//gl_FragColor = vec4(vec3(pattern), 1.0);\n \n\t//gl_FragColor = vec4(pattern(3.*c));\n \n\t\n //camera\n float r = .7;\n float tm = time * 0.05;\n float tm2 = time * 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 2.;//finalDesiredPointSize;\n\n v_color = vec4(col, 1);\n float depth = (v_color.x*v_color.y*v_color.z)/2.;\n \n vec4 finalPos = vec4(ux, vy, depth+snd/5., 1.);\n \n gl_Position = mat*finalPos;\n}" + }, "screenshotURL": "data/images/images-vs63o79i0liusp7g9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rb2d6ReqHPiEK4ahj/art.json b/art/rb2d6ReqHPiEK4ahj/art.json index 1b9584e9..0683dbc8 100644 --- a/art/rb2d6ReqHPiEK4ahj/art.json +++ b/art/rb2d6ReqHPiEK4ahj/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macromachines", "avatarUrl": "https://avatars.githubusercontent.com/MacroMachines?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.92553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.92553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-jgdiqgtfv2c0h1de8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rbtQZi9Ks5R8zkRRF/art.json b/art/rbtQZi9Ks5R8zkRRF/art.json index c3110490..4f7e0959 100644 --- a/art/rbtQZi9Ks5R8zkRRF/art.json +++ b/art/rbtQZi9Ks5R8zkRRF/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tColors\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tfloat hue = u * .1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n \\tfloat sat = 1.0;\\n \\tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\tseongryul.park\n//\tCS250 spring 2023\n//\tColors\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n \tfloat hue = u * .1 + sin(time * 1.3 + v * 20.0) * 0.05;\n \tfloat sat = 1.0;\n \tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-5u1e0t58qj54qky9m-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rcKFeaikB2g9P6Wf5/art.json b/art/rcKFeaikB2g9P6Wf5/art.json index 4b403af4..f6fbf0ca 100644 --- a/art/rcKFeaikB2g9P6Wf5/art.json +++ b/art/rcKFeaikB2g9P6Wf5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3514,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.1 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 3514, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.1 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-sw27b7anx7rdr38ow-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rdnpitzwjjAHK9Aef/art.json b/art/rdnpitzwjjAHK9Aef/art.json index f32fab27..ed1ab00c 100644 --- a/art/rdnpitzwjjAHK9Aef/art.json +++ b/art/rdnpitzwjjAHK9Aef/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":14339,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0,0,1],\"shader\":\"// remix by www.Axiom-Crux.net\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n\\n\\n////////////////////////////////\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n\\n\\n\\n\\n\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\\n\\n#define QUANT(X,Y) floor(X*Y)/Y\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n \\n float quantize = 4.;\\n \\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n \\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.2, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n \\n float tt = fract(time); \\n \\n float inner = (sin(time)*0.5+0.5)*0.9;\\n float start = 0.;\\n float end = 1.;\\n \\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n \\n mat *= scale(vec3(aspect, 1, 1) * 1.);\\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \\n QUANT(mod(groupId*4.,2.) ,5.)) );\\n \\n //mat = QUANT(mat,mat4(quantize));\\n \\n offset = QUANT(offset,quantize);\\n mat *= trans(vec3(offset));\\n \\n \\n \\n float gt = time + gv * PI * 0.1;\\n \\n \\n \\n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\\n mat *= uniformScale(0.23 * cgv + snd * .5);\\n //mat *= rotZ(PI * 1.5);\\n \\n //pos = QUANT(pos,quantize);\\n \\n gl_Position = mat * vec4(pos, .75);\\n gl_PointSize = 1.;\\n \\n float pump = step(0.5, snd);\\n float hue = 1. + cgId * 1. + pump * .17;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 14339, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0, + 0, + 1 + ], + "shader": "// remix by www.Axiom-Crux.net\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n\n\n////////////////////////////////\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n\n\n\n\n\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n#define QUANT(X,Y) floor(X*Y)/Y\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n \n float quantize = 4.;\n \n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n \n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.2, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n \n float tt = fract(time); \n \n float inner = (sin(time)*0.5+0.5)*0.9;\n float start = 0.;\n float end = 1.;\n \n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n \n mat *= scale(vec3(aspect, 1, 1) * 1.);\n mat *= rotZ( QUANT(time , 1. ) * mix(-1. , 1. , \n QUANT(mod(groupId*4.,2.) ,5.)) );\n \n //mat = QUANT(mat,mat4(quantize));\n \n offset = QUANT(offset,quantize);\n mat *= trans(vec3(offset));\n \n \n \n float gt = time + gv * PI * 0.1;\n \n \n \n mat *= trans(vec3(sin(-gt), cos(gt), 3) * -.005 * ( 1. - cgv * 2.50));\n mat *= uniformScale(0.23 * cgv + snd * .5);\n //mat *= rotZ(PI * 1.5);\n \n //pos = QUANT(pos,quantize);\n \n gl_Position = mat * vec4(pos, .75);\n gl_PointSize = 1.;\n \n float pump = step(0.5, snd);\n float hue = 1. + cgId * 1. + pump * .17;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-1umeb0fpmqzlt8p50-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rfN5XjXn3a69T3A7z/art.json b/art/rfN5XjXn3a69T3A7z/art.json index ba651c13..c8155e3f 100644 --- a/art/rfN5XjXn3a69T3A7z/art.json +++ b/art/rfN5XjXn3a69T3A7z/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 2D Sin Wave\\n\\nvoid main() {\\n float vertexNorm = vertexId/vertexCount;\\n float x = vertexNorm - 0.5;\\n float y = 0.25 * sin(time + vertexNorm * 2.0);\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n gl_PointSize = vertexNorm * 10.0;\\n v_color = vec4(vertexNorm, 0.0, x, 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 2D Sin Wave\n\nvoid main() {\n float vertexNorm = vertexId/vertexCount;\n float x = vertexNorm - 0.5;\n float y = 0.25 * sin(time + vertexNorm * 2.0);\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n gl_PointSize = vertexNorm * 10.0;\n v_color = vec4(vertexNorm, 0.0, x, 1.0);\n}" + }, "screenshotURL": "data/images/images-n7i6m2xz4hcud33jk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rfTkbTfLZfroxDvEZ/art.json b/art/rfTkbTfLZfroxDvEZ/art.json index 500bcc01..7cb59031 100644 --- a/art/rfTkbTfLZfroxDvEZ/art.json +++ b/art/rfTkbTfLZfroxDvEZ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cjensen93", "avatarUrl": "https://secure.gravatar.com/avatar/0df4239ac208a0c9696c1edd2e895cee?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.058823529411764705,0.4117647058823529,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n\\n}\\n\\n\\nvoid main(){\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2.0 - 1.0 + xOff;\\n float uy = v * 2.0 - 1.0 + yOff;\\n \\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n \\n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sOff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = 1.0;//u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float value = 1.0;//sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.058823529411764705, + 0.4117647058823529, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n\n}\n\n\nvoid main(){\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2.0 - 1.0 + xOff;\n float uy = v * 2.0 - 1.0 + yOff;\n \n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n gl_Position = vec4(xy,0.0,1.0);\n \n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sOff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = 1.0;//u * 0.1 + sin(time + v * 20.0) * 0.05;\n float sat = 1.0;\n float value = 1.0;//sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-z12wzh0j4jxpzdzp5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rgGNodWBZBJxDsyQx/art.json b/art/rgGNodWBZBJxDsyQx/art.json index 93a7bdde..92395d47 100644 --- a/art/rgGNodWBZBJxDsyQx/art.json +++ b/art/rgGNodWBZBJxDsyQx/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jaewoo.choi", "avatarUrl": "https://secure.gravatar.com/avatar/d216764c49a53ce2f15ebd1c1d4a9c7f?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Jaewoo.choi\\n//Assignment Name: Exercise - Vertexshaderart : Colors\\n//Course Name: CS250\\n//Term&Year: 2022&Spring\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 2.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 7.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + yoff;\\n float vy = v * 2. - 1. + xoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1) +sin(time) * 0.3;\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = cos(time * 1.4 * v * u * 20.) * .5 + 0.5;\\n val *= sin(time + 1.4 * v * u * 30.) * .5 + 0.5;\\n\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Jaewoo.choi\n//Assignment Name: Exercise - Vertexshaderart : Colors\n//Course Name: CS250\n//Term&Year: 2022&Spring\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 2.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 7.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + yoff;\n float vy = v * 2. - 1. + xoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1) +sin(time) * 0.3;\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = cos(time * 1.4 * v * u * 20.) * .5 + 0.5;\n val *= sin(time + 1.4 * v * u * 30.) * .5 + 0.5;\n\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-bfg2j8fk0522ei77c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rghHKREPitTaTLiyH/art.json b/art/rghHKREPitTaTLiyH/art.json index c0b9a13c..297ab1be 100644 --- a/art/rghHKREPitTaTLiyH/art.json +++ b/art/rghHKREPitTaTLiyH/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":22578,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.17647058823529413,0.25098039215686274,0.3215686274509804,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 1.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.3\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\\n\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, .9);\\n float innerRadius = pow(count * 0.0005, .2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius*mouse.y;\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius*mouse.x;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * 0.90161, sin(time), 1);\\n\\n float b = 1.2 - pow(sin(count * 0.4+T) * 1.3 + 0.7, 1.8);\\n b = 0.0;mix(0.3, 0.7, b);\\n v_color = vec4(c, b, sin(T*.1)+c*b, 0.6);\\n}\\n\"}", + "settings": { + "num": 22578, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.17647058823529413, + 0.25098039215686274, + 0.3215686274509804, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 1.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.3\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\n\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, .9);\n float innerRadius = pow(count * 0.0005, .2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius*mouse.y;\n float oS = sin(orbitAngle + count * 0.01) * innerRadius*mouse.x;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * 0.90161, sin(time), 1);\n\n float b = 1.2 - pow(sin(count * 0.4+T) * 1.3 + 0.7, 1.8);\n b = 0.0;mix(0.3, 0.7, b);\n v_color = vec4(c, b, sin(T*.1)+c*b, 0.6);\n}\n" + }, "screenshotURL": "data/images/images-1b6nxvxr6g7tjaqux-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rowacMf39CKSm6S8s/art.json b/art/rowacMf39CKSm6S8s/art.json index f0bd2e62..7b7f330c 100644 --- a/art/rowacMf39CKSm6S8s/art.json +++ b/art/rowacMf39CKSm6S8s/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":51401,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\ninspired by:\\nhttp://codepen.io/xposedbones/full/aOrQVy\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\n\\n\\n\\n \\n \\n\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 10.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle * mouse.y );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\\n snd = 1.;\\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\\n float x = c * v * z * ss;\\n float y = s * v * z * ss;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.7) + sin(t * 0.113) + sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.15, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.03;\\n float end = start + .8;\\n float snd;\\n vec4 uvfl;\\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \\n \\n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 2.8) * .4 - min(resolution.x / resolution.y, 1.7)); \\n mat *= rotZ((0.2 + uvfl.y - PI) * time * 3.);\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float ho = time * 0.01;\\n float cc = abs(goop(uvfl.w));\\n float cs = step(0.5, fract(cc * 1.));\\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\\n float sat = 0.;mix(0.3, 1.9, abs(m1p1(uvfl.x)));\\n float val = 0.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n//1v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\\n //v_color.a = 1.0 - uvf.y;\\n //1v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 51401, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/samuraimusicgroup/homemade-weapons-negative-space-remixed-smde006", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\ninspired by:\nhttp://codepen.io/xposedbones/full/aOrQVy\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\n\n\n\n \n \n\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 10.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle * mouse.y );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n//#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n// snd = texture2D(sound, vec2(0.02 + su * 0.10, (1. - ringV) * 0.1)).a;\n snd = 1.;\n float ss = mix(0.0, 1.0, pow(snd, 1.0));\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. * sin(time * 1.) + snd * 7.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.1;\n float x = c * v * z * ss;\n float y = s * v * z * ss;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.7) + sin(t * 0.113) + sin(t * 0.73);\n}\n\nvoid main() {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.15, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.;\n float start = 0.03;\n float end = start + .8;\n float snd;\n vec4 uvfl;\n getCirclePoint(pointId, inner, start, end, pos, uvfl, snd); \n \n mat4 mat = scale(vec3(resolution.y / resolution.x, 1.91, 2.8) * .4 - min(resolution.x / resolution.y, 1.7)); \n mat *= rotZ((0.2 + uvfl.y - PI) * time * 3.);\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float ho = time * 0.01;\n float cc = abs(goop(uvfl.w));\n float cs = step(0.5, fract(cc * 1.));\n float hue = mix(0.0 + ho, 0.5 + ho, cs);\n float sat = 0.;mix(0.3, 1.9, abs(m1p1(uvfl.x)));\n float val = 0.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n//1v_color = mix(v_color.rgba, vec4(1,1,1,1), mod(uvf.z, 2.));\n //v_color.a = 1.0 - uvf.y;\n //1v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-kpnla7bzxwec21bgw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rpRcyCMh5R2XDbm49/art.json b/art/rpRcyCMh5R2XDbm49/art.json index 8a607ea5..3754690c 100644 --- a/art/rpRcyCMh5R2XDbm49/art.json +++ b/art/rpRcyCMh5R2XDbm49/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "morimea", "avatarUrl": "https://secure.gravatar.com/avatar/8ff4b4cacdf52d8d31a020cd244c5269?default=retro&size=200", - "settings": "{\"num\":60750,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.043137254901960784,0.0392156862745098,0.03529411764705882,1],\"shader\":\" //#define vertexId float(gl_InstanceID+gl_VertexID)\\n\\n\\n // default number of particles 15*15*15*6*3=60750 15 is cube size\\n\\n const float size=1.; \\n\\n //out vec4 v_color;\\n\\n const float PI = 3.1415926535898;\\n\\n const float VertX = 15.0;\\n const float VertY = 15.0;\\n\\n const float tscale = 0.2;\\n const vec3 obj_pos = vec3(-1.5);\\n\\n mat3 rotx(float a){float s = sin(a);float c = cos(a);return mat3(vec3(1.0, 0.0, 0.0), vec3(0.0, c, s), vec3(0.0, -s, c)); }\\n mat3 roty(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, 0.0, s), vec3(0.0, 1.0, 0.0), vec3(-s, 0.0, c));}\\n mat3 rotz(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0 ));}\\n\\n\\n const float degree_to_rad = PI / 180.0;\\n\\n mat4 perspectiveMatrix(float fovYInRad, float aspectRatio)\\n {\\n float yScale = 1.0 / tan(fovYInRad / 2.0);\\n float xScale = yScale / aspectRatio;\\n float zf = 100.0;\\n float zn = 0.3;\\n\\n float z1 = zf / (zf - zn);\\n float z2 = -zn * zf / (zf - zn);\\n\\n mat4 result = mat4(xScale, 0.0, 0.0, 0.0, 0.0, yScale, 0.0, 0.0, 0.0, 0.0, -z1, -1., 0.0, 0.0, z2, 0.0);\\n\\n return result;\\n }\\n\\n mat4 lookat(vec3 eye, vec3 look, vec3 up)\\n {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *\\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\\n }\\n\\n vec3 voxelPosToWorld(vec3 vp)\\n {\\n return vp * (tscale / (size)) + obj_pos;\\n }\\n\\n float sphereSDF(vec3 p, float r)\\n {\\n return length(p) - r;\\n }\\n\\n float sdBox( vec3 p, vec3 b )\\n {\\n vec3 q = abs(p) - b;\\n return length(max(q,0.0)) + min(max(q.x,max(q.y,q.z)),0.0);\\n }\\n\\n float sdfUnion( const float a, const float b )\\n {\\n return min(a, b);\\n }\\n\\n float sdfDifference( const float a, const float b)\\n {\\n return max(a, -b);\\n }\\n\\n float sdfIntersection( const float a, const float b )\\n {\\n return max(a, b);\\n }\\n\\n float scene(vec3 p)\\n {\\n float d = 0.0;\\n d = sdfDifference(sphereSDF(p + vec3(0., 0.3, 0.), .8),\\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\\n d = sdfDifference(sdBox(p + vec3(0., 0.3, 0.), vec3(.8)),\\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\\n\\n return d;\\n }\\n\\n vec3 sceneNormal(vec3 p)\\n {\\n vec3 EPS = vec3(0.01, 0.0, 0.0);\\n vec3 n;\\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\\n return normalize(n);\\n }\\n\\n vec3 vertexSmooth(vec3 ip)\\n {\\n vec3 p = ip;\\n vec3 n = sceneNormal(p);\\n for (int i = 0; i < 8; i++)\\n {\\n float d = scene(p);\\n p -= n * d;\\n if (abs(d) < 0.01)\\n {\\n break;\\n }\\n }\\n return p;\\n }\\n\\n vec3 phongContribForLight(vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 lightPos, vec3 lightIntensity, vec3 N)\\n {\\n vec3 L = normalize(lightPos - p);\\n vec3 V = normalize(eye - p);\\n vec3 R = normalize(reflect(-L, N));\\n\\n float dotLN = dot(L, N);\\n float dotRV = dot(R, V);\\n\\n if (dotLN < 0.0)\\n {\\n return vec3(0.0, 0.0, 0.0);\\n }\\n\\n if (dotRV < 0.0)\\n {\\n return lightIntensity * (k_d * dotLN);\\n }\\n return lightIntensity * (k_d * dotLN + k_s * pow(dotRV, alpha));\\n }\\n\\n vec3 phongIllumination(vec3 k_a, vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 norm)\\n {\\n const vec3 ambientLight = 0.5 * vec3(1.0, 1.0, 1.0);\\n vec3 color = ambientLight * k_a;\\n\\n vec3 light1Pos = normalize(vec3(mouse.x, mouse.y, .20));\\n vec3 light1Intensity = 2. * vec3(0.4, 0.4, 0.4);\\n\\n color += phongContribForLight(k_d, k_s, alpha, p, eye, light1Pos, light1Intensity, norm);\\n\\n return color;\\n }\\n\\n vec4 color_phong(vec3 p, vec3 ro, vec3 n, vec3 col)\\n {\\n vec3 K_a = col;\\n vec3 K_d = K_a;\\n vec3 K_s = vec3(1.0, 1.0, 1.0);\\n float shininess = 12.0;\\n\\n col = phongIllumination(K_a, K_d, K_s, shininess, p, ro, n);\\n return vec4(col, 1.);\\n }\\n\\n void main()\\n {\\n // vertex index in quad face, two triangles\\n float id_Vert = mod(vertexId, 6.0);\\n // face index\\n float id_Face = floor(vertexId / 6.0);\\n // corner face index\\n float id_Face_corner = mod(id_Face, 3.0);\\n // corner edge index\\n float id_Edge = mod(id_Face, 3.0);\\n // corner index 1 corner is 3 faces is 3*6 verts\\n float id_Corner = floor(vertexId / 18.0);\\n // corner position\\n vec3 cornerP;\\n float tVertX = VertX * size;\\n float tVertY = VertY * size;\\n cornerP.x = mod(id_Corner, tVertX);\\n cornerP.y = mod(floor(id_Corner / tVertX), tVertY);\\n cornerP.z = mod(floor(id_Corner / (tVertX * tVertY)), tVertY);\\n\\n vec3 faceNorm;\\n vec3 faceTan;\\n vec3 faceaTan;\\n if (id_Edge == 0.0)\\n {\\n faceNorm = vec3(1.0, 0.0, 0.0);\\n faceTan = vec3(0.0, 0.0, -1.0);\\n faceaTan = vec3(0.0, 1.0, 0.0);\\n }\\n else if (id_Edge == 1.0)\\n {\\n faceNorm = vec3(0.0, 1.0, 0.0);\\n faceTan = vec3(1.0, 0.0, 0.0);\\n faceaTan = vec3(0.0, 0.0, -1.0);\\n }\\n else\\n {\\n faceNorm = vec3(0.0, 0.0, 1.0);\\n faceTan = vec3(1.0, 0.0, 0.0);\\n faceaTan = vec3(0.0, 1.0, 0.0);\\n }\\n vec3 aPos = cornerP + faceNorm;\\n\\n // sampling points\\n vec3 p0 = voxelPosToWorld(cornerP);\\n vec3 p1 = voxelPosToWorld(aPos);\\n\\n // field value\\n float d0 = scene(p0);\\n float d1 = scene(p1);\\n\\n vec3 p;\\n vec3 vertNorm;\\n\\n if (d0 * d1 > 0.0)\\n {\\n // no face\\n p = p0;\\n vertNorm = vec3(1.0, 1.0, 1.0);\\n }\\n else\\n {\\n // have a face\\n if (d1 < d0)\\n {\\n // 0->1 is standard normal.\\n // otherwise flip triangle\\n if (id_Vert == 0.0)\\n {\\n id_Vert = 2.0;\\n }\\n else if (id_Vert == 2.0)\\n {\\n id_Vert = 0.0;\\n }\\n else if (id_Vert == 3.0)\\n {\\n id_Vert = 5.0;\\n }\\n else if (id_Vert == 5.0)\\n {\\n id_Vert = 3.0;\\n }\\n faceNorm *= -1.0;\\n }\\n\\n /*\\n face\\n 2 4-5\\n |\\\\ \\\\|\\n 0-1 3\\n */\\n float faceSize = mix(0.45, 0.5, clamp(cos(time * .75) * 4.0 + 0.5, 0.0, 1.0));\\n vec3 edgeMidP = (cornerP + aPos) * 0.5;\\n vec3 faceVertP;\\n if (id_Vert == 0.0)\\n {\\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * -faceSize;\\n }\\n else if (id_Vert == 1.0)\\n {\\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\\n }\\n else if (id_Vert == 2.0)\\n {\\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\\n }\\n else if (id_Vert == 3.0)\\n {\\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\\n }\\n else if (id_Vert == 4.0)\\n {\\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\\n }\\n else if (id_Vert == 5.0)\\n {\\n faceVertP = edgeMidP + faceTan * 0.5 + faceaTan * 0.5;\\n }\\n p = voxelPosToWorld(faceVertP);\\n\\n // smoothing\\n vec3 sp = vertexSmooth(p);\\n vertNorm = sceneNormal(p);\\n\\n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\\n vmix = 1.;\\n p = mix(p, sp, vmix);\\n vertNorm = mix(faceNorm, vertNorm, vmix);\\n }\\n\\n vec3 eye = vec3(0.0, 0.0, 3.5) * rotx(clamp(mouse.y, -0.5, 0.5) * 1.5) * roty(-clamp(mouse.x, -0.5, 0.5) * 1.5);\\n // eye = vec3(0.0, 0.0, 3.0);\\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n mat4 pMatrix = perspectiveMatrix(60.0 * degree_to_rad, resolution.x / resolution.y);\\n vec4 viewPos = (viewMat * vec4(p, 1.0));\\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\\n\\n gl_Position = (pMatrix * viewPos) * 100.2;\\n gl_PointSize = 2.0;\\n\\n v_color = color_phong(viewPos.xyz, eye, viewNorm, 0.5 * (viewNorm + 1.) / 2.);\\n }\"}", + "settings": { + "num": 60750, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.043137254901960784, + 0.0392156862745098, + 0.03529411764705882, + 1 + ], + "shader": " //#define vertexId float(gl_InstanceID+gl_VertexID)\n\n\n // default number of particles 15*15*15*6*3=60750 15 is cube size\n\n const float size=1.; \n\n //out vec4 v_color;\n\n const float PI = 3.1415926535898;\n\n const float VertX = 15.0;\n const float VertY = 15.0;\n\n const float tscale = 0.2;\n const vec3 obj_pos = vec3(-1.5);\n\n mat3 rotx(float a){float s = sin(a);float c = cos(a);return mat3(vec3(1.0, 0.0, 0.0), vec3(0.0, c, s), vec3(0.0, -s, c)); }\n mat3 roty(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, 0.0, s), vec3(0.0, 1.0, 0.0), vec3(-s, 0.0, c));}\n mat3 rotz(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0 ));}\n\n\n const float degree_to_rad = PI / 180.0;\n\n mat4 perspectiveMatrix(float fovYInRad, float aspectRatio)\n {\n float yScale = 1.0 / tan(fovYInRad / 2.0);\n float xScale = yScale / aspectRatio;\n float zf = 100.0;\n float zn = 0.3;\n\n float z1 = zf / (zf - zn);\n float z2 = -zn * zf / (zf - zn);\n\n mat4 result = mat4(xScale, 0.0, 0.0, 0.0, 0.0, yScale, 0.0, 0.0, 0.0, 0.0, -z1, -1., 0.0, 0.0, z2, 0.0);\n\n return result;\n }\n\n mat4 lookat(vec3 eye, vec3 look, vec3 up)\n {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\n }\n\n vec3 voxelPosToWorld(vec3 vp)\n {\n return vp * (tscale / (size)) + obj_pos;\n }\n\n float sphereSDF(vec3 p, float r)\n {\n return length(p) - r;\n }\n\n float sdBox( vec3 p, vec3 b )\n {\n vec3 q = abs(p) - b;\n return length(max(q,0.0)) + min(max(q.x,max(q.y,q.z)),0.0);\n }\n\n float sdfUnion( const float a, const float b )\n {\n return min(a, b);\n }\n\n float sdfDifference( const float a, const float b)\n {\n return max(a, -b);\n }\n\n float sdfIntersection( const float a, const float b )\n {\n return max(a, b);\n }\n\n float scene(vec3 p)\n {\n float d = 0.0;\n d = sdfDifference(sphereSDF(p + vec3(0., 0.3, 0.), .8),\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\n d = sdfDifference(sdBox(p + vec3(0., 0.3, 0.), vec3(.8)),\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\n\n return d;\n }\n\n vec3 sceneNormal(vec3 p)\n {\n vec3 EPS = vec3(0.01, 0.0, 0.0);\n vec3 n;\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\n return normalize(n);\n }\n\n vec3 vertexSmooth(vec3 ip)\n {\n vec3 p = ip;\n vec3 n = sceneNormal(p);\n for (int i = 0; i < 8; i++)\n {\n float d = scene(p);\n p -= n * d;\n if (abs(d) < 0.01)\n {\n break;\n }\n }\n return p;\n }\n\n vec3 phongContribForLight(vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 lightPos, vec3 lightIntensity, vec3 N)\n {\n vec3 L = normalize(lightPos - p);\n vec3 V = normalize(eye - p);\n vec3 R = normalize(reflect(-L, N));\n\n float dotLN = dot(L, N);\n float dotRV = dot(R, V);\n\n if (dotLN < 0.0)\n {\n return vec3(0.0, 0.0, 0.0);\n }\n\n if (dotRV < 0.0)\n {\n return lightIntensity * (k_d * dotLN);\n }\n return lightIntensity * (k_d * dotLN + k_s * pow(dotRV, alpha));\n }\n\n vec3 phongIllumination(vec3 k_a, vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 norm)\n {\n const vec3 ambientLight = 0.5 * vec3(1.0, 1.0, 1.0);\n vec3 color = ambientLight * k_a;\n\n vec3 light1Pos = normalize(vec3(mouse.x, mouse.y, .20));\n vec3 light1Intensity = 2. * vec3(0.4, 0.4, 0.4);\n\n color += phongContribForLight(k_d, k_s, alpha, p, eye, light1Pos, light1Intensity, norm);\n\n return color;\n }\n\n vec4 color_phong(vec3 p, vec3 ro, vec3 n, vec3 col)\n {\n vec3 K_a = col;\n vec3 K_d = K_a;\n vec3 K_s = vec3(1.0, 1.0, 1.0);\n float shininess = 12.0;\n\n col = phongIllumination(K_a, K_d, K_s, shininess, p, ro, n);\n return vec4(col, 1.);\n }\n\n void main()\n {\n // vertex index in quad face, two triangles\n float id_Vert = mod(vertexId, 6.0);\n // face index\n float id_Face = floor(vertexId / 6.0);\n // corner face index\n float id_Face_corner = mod(id_Face, 3.0);\n // corner edge index\n float id_Edge = mod(id_Face, 3.0);\n // corner index 1 corner is 3 faces is 3*6 verts\n float id_Corner = floor(vertexId / 18.0);\n // corner position\n vec3 cornerP;\n float tVertX = VertX * size;\n float tVertY = VertY * size;\n cornerP.x = mod(id_Corner, tVertX);\n cornerP.y = mod(floor(id_Corner / tVertX), tVertY);\n cornerP.z = mod(floor(id_Corner / (tVertX * tVertY)), tVertY);\n\n vec3 faceNorm;\n vec3 faceTan;\n vec3 faceaTan;\n if (id_Edge == 0.0)\n {\n faceNorm = vec3(1.0, 0.0, 0.0);\n faceTan = vec3(0.0, 0.0, -1.0);\n faceaTan = vec3(0.0, 1.0, 0.0);\n }\n else if (id_Edge == 1.0)\n {\n faceNorm = vec3(0.0, 1.0, 0.0);\n faceTan = vec3(1.0, 0.0, 0.0);\n faceaTan = vec3(0.0, 0.0, -1.0);\n }\n else\n {\n faceNorm = vec3(0.0, 0.0, 1.0);\n faceTan = vec3(1.0, 0.0, 0.0);\n faceaTan = vec3(0.0, 1.0, 0.0);\n }\n vec3 aPos = cornerP + faceNorm;\n\n // sampling points\n vec3 p0 = voxelPosToWorld(cornerP);\n vec3 p1 = voxelPosToWorld(aPos);\n\n // field value\n float d0 = scene(p0);\n float d1 = scene(p1);\n\n vec3 p;\n vec3 vertNorm;\n\n if (d0 * d1 > 0.0)\n {\n // no face\n p = p0;\n vertNorm = vec3(1.0, 1.0, 1.0);\n }\n else\n {\n // have a face\n if (d1 < d0)\n {\n // 0->1 is standard normal.\n // otherwise flip triangle\n if (id_Vert == 0.0)\n {\n id_Vert = 2.0;\n }\n else if (id_Vert == 2.0)\n {\n id_Vert = 0.0;\n }\n else if (id_Vert == 3.0)\n {\n id_Vert = 5.0;\n }\n else if (id_Vert == 5.0)\n {\n id_Vert = 3.0;\n }\n faceNorm *= -1.0;\n }\n\n /*\n face\n 2 4-5\n |\\ \\|\n 0-1 3\n */\n float faceSize = mix(0.45, 0.5, clamp(cos(time * .75) * 4.0 + 0.5, 0.0, 1.0));\n vec3 edgeMidP = (cornerP + aPos) * 0.5;\n vec3 faceVertP;\n if (id_Vert == 0.0)\n {\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * -faceSize;\n }\n else if (id_Vert == 1.0)\n {\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\n }\n else if (id_Vert == 2.0)\n {\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\n }\n else if (id_Vert == 3.0)\n {\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\n }\n else if (id_Vert == 4.0)\n {\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\n }\n else if (id_Vert == 5.0)\n {\n faceVertP = edgeMidP + faceTan * 0.5 + faceaTan * 0.5;\n }\n p = voxelPosToWorld(faceVertP);\n\n // smoothing\n vec3 sp = vertexSmooth(p);\n vertNorm = sceneNormal(p);\n\n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\n vmix = 1.;\n p = mix(p, sp, vmix);\n vertNorm = mix(faceNorm, vertNorm, vmix);\n }\n\n vec3 eye = vec3(0.0, 0.0, 3.5) * rotx(clamp(mouse.y, -0.5, 0.5) * 1.5) * roty(-clamp(mouse.x, -0.5, 0.5) * 1.5);\n // eye = vec3(0.0, 0.0, 3.0);\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n mat4 pMatrix = perspectiveMatrix(60.0 * degree_to_rad, resolution.x / resolution.y);\n vec4 viewPos = (viewMat * vec4(p, 1.0));\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\n\n gl_Position = (pMatrix * viewPos) * 100.2;\n gl_PointSize = 2.0;\n\n v_color = color_phong(viewPos.xyz, eye, viewNorm, 0.5 * (viewNorm + 1.) / 2.);\n }" + }, "screenshotURL": "data/images/images-h8yoih8lvio846bad-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rpZQsvErnMxXynuRd/art.json b/art/rpZQsvErnMxXynuRd/art.json index 32468067..8747dd4b 100644 --- a/art/rpZQsvErnMxXynuRd/art.json +++ b/art/rpZQsvErnMxXynuRd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "taejukwon-digipen", "avatarUrl": "https://avatars.githubusercontent.com/taejuKwon-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across -1.);\\n float v = y / (across -1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/600.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across -1.);\n float v = y / (across -1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/600.0;\n \n v_color = vec4(1,0,0,1);\n \n}\n" + }, "screenshotURL": "data/images/images-a2m8xili6i396g91q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rpeFEbrt3ozGdCvBQ/art.json b/art/rpeFEbrt3ozGdCvBQ/art.json index aefe1819..64d3de57 100644 --- a/art/rpeFEbrt3ozGdCvBQ/art.json +++ b/art/rpeFEbrt3ozGdCvBQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46282.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\n// \\\"Seascape\\\" by Alexander Alekseev aka TDM - 2014\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n\\nconst int NUM_STEPS = 16;\\nconst float PI\\t \\t= 3.1415;\\nconst float EPSILON\\t= 1e-3;\\nfloat EPSILON_NRM\\t= 0.;\\n\\n// sea\\nconst int ITER_GEOMETRY = 3;\\nconst int ITER_FRAGMENT = 2;\\nconst float SEA_HEIGHT = 0.6;\\nconst float SEA_CHOPPY = 4.0;\\nconst float SEA_SPEED = 0.8;\\nconst float SEA_FREQ = 0.16;\\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\\nfloat SEA_TIME = 0.;\\nmat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\\n\\n// math\\nmat3 fromEuler(vec3 ang) {\\n\\tvec2 a1 = vec2(sin(ang.x),cos(ang.x));\\n vec2 a2 = vec2(sin(ang.y),cos(ang.y));\\n vec2 a3 = vec2(sin(ang.z),cos(ang.z));\\n mat3 m;\\n m[0] = vec3(a1.y*a3.y+a1.x*a2.x*a3.x,a1.y*a2.x*a3.x+a3.y*a1.x,-a2.y*a3.x);\\n\\tm[1] = vec3(-a2.y*a1.x,a1.y*a2.y,a2.x);\\n\\tm[2] = vec3(a3.y*a1.x*a2.x+a1.y*a3.x,a1.x*a3.x-a1.y*a3.y*a2.x,a2.y*a3.y);\\n\\treturn m;\\n}\\nfloat hash( vec2 p ) {\\n\\tfloat h = dot(p,vec2(127.1,311.7));\\t\\n return fract(sin(h)*43758.5453123);\\n}\\nfloat noise( in vec2 p ) {\\n vec2 i = floor( p );\\n vec2 f = fract( p );\\t\\n\\tvec2 u = f*f*(3.0-2.0*f);\\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \\n hash( i + vec2(1.0,0.0) ), u.x),\\n mix( hash( i + vec2(0.0,1.0) ), \\n hash( i + vec2(1.0,1.0) ), u.x), u.y);\\n}\\n\\n// lighting\\nfloat diffuse(vec3 n,vec3 l,float p) {\\n return pow(dot(n,l) * 0.4 + 0.6,p);\\n}\\nfloat specular(vec3 n,vec3 l,vec3 e,float s) { \\n float nrm = (s + 8.0) / (3.1415 * 8.0);\\n return pow(max(dot(reflect(e,n),l),0.0),s) * nrm;\\n}\\n\\n// sky\\nvec3 getSkyColor(vec3 e) {\\n e.y = max(e.y,0.0);\\n vec3 ret;\\n ret.x = pow(1.0-e.y,2.0);\\n ret.y = 1.0-e.y;\\n ret.z = 0.6+(1.0-e.y)*0.4;\\n return ret;\\n}\\n\\n// sea\\nfloat sea_octave(vec2 uv, float choppy) {\\n uv += noise(uv); \\n vec2 wv = 1.0-abs(sin(uv));\\n vec2 swv = abs(cos(uv)); \\n wv = mix(wv,swv,wv);\\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\\n}\\n\\nfloat map(vec3 p) {\\n float freq = SEA_FREQ;\\n float amp = SEA_HEIGHT;\\n float choppy = SEA_CHOPPY;\\n vec2 uv = p.xz; uv.x *= 0.75;\\n \\n float d, h = 0.0; \\n for(int i = 0; i < ITER_GEOMETRY; i++) { \\n \\td = sea_octave((uv+SEA_TIME)*freq,choppy);\\n \\td += sea_octave((uv-SEA_TIME)*freq,choppy);\\n h += d * amp; \\n \\tuv *= octave_m; freq *= 1.9; amp *= 0.22;\\n choppy = mix(choppy,1.0,0.2);\\n }\\n return p.y - h;\\n}\\n\\nfloat map_detailed(vec3 p) {\\n float freq = SEA_FREQ;\\n float amp = SEA_HEIGHT;\\n float choppy = SEA_CHOPPY;\\n vec2 uv = p.xz; uv.x *= 0.75;\\n \\n float d, h = 0.0; \\n for(int i = 0; i < ITER_FRAGMENT; i++) { \\n \\td = sea_octave((uv+SEA_TIME)*freq,choppy);\\n \\td += sea_octave((uv-SEA_TIME)*freq,choppy);\\n h += d * amp; \\n \\tuv *= octave_m; freq *= 1.9; amp *= 0.22;\\n choppy = mix(choppy,1.0,0.2);\\n }\\n return p.y - h;\\n}\\n\\nvec3 getSeaColor(vec3 p, vec3 n, vec3 l, vec3 eye, vec3 dist) { \\n float fresnel = 1.0 - max(dot(n,-eye),0.0);\\n fresnel = pow(fresnel,3.0) * 0.65;\\n \\n vec3 reflected = getSkyColor(reflect(eye,n)); \\n vec3 refracted = SEA_BASE + diffuse(n,l,80.0) * SEA_WATER_COLOR * 0.12; \\n \\n vec3 color = mix(refracted,reflected,fresnel);\\n \\n float atten = max(1.0 - dot(dist,dist) * 0.001, 0.0);\\n color += SEA_WATER_COLOR * (p.y - SEA_HEIGHT) * 0.18 * atten;\\n \\n color += vec3(specular(n,l,eye,60.0));\\n \\n return color;\\n}\\n\\n// tracing\\nvec3 getNormal(vec3 p, float eps) {\\n vec3 n;\\n n.y = map_detailed(p); \\n n.x = map_detailed(vec3(p.x+eps,p.y,p.z)) - n.y;\\n n.z = map_detailed(vec3(p.x,p.y,p.z+eps)) - n.y;\\n n.y = eps;\\n \\n return normalize(n);\\n}\\n\\nfloat heightMapTracing(vec3 ori, vec3 dir, out vec3 p) { \\n float tm = 0.0;\\n float tx = 1000.0; \\n float hx = map(ori + dir * tx);\\n if(hx > 0.0) return tx; \\n float hm = map(ori + dir * tm); \\n float tmid = 0.0;\\n for(int i = 0; i < NUM_STEPS; i++) {\\n tmid = mix(tm,tx, hm/(hm-hx)); \\n p = ori + dir * tmid; \\n \\tfloat hmid = map(p);\\n\\t\\tif(hmid < 0.0) {\\n \\ttx = tmid;\\n hx = hmid;\\n } else {\\n tm = tmid;\\n hm = hmid;\\n }\\n }\\n\\n}\\n\\n// main\\nvoid main( void ) {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n\\tEPSILON_NRM = 0.1 / vertexResolution.x;\\n\\tSEA_TIME = time * SEA_SPEED;\\n\\t\\n\\tvec2 uv = simFragCoord.xy / vertexResolution.xy;\\n uv = uv * 2.0 - 1.0;\\n uv.x *= vertexResolution.x / vertexResolution.y; \\n float time = time * 0.3 + mouse.x*0.01;\\n \\n // ray\\n vec3 ang = vec3(sin(time*3.0)*0.1,sin(time)*0.2+0.3,time); \\n vec3 ori = vec3(0.0,3.5,time*5.0);\\n vec3 dir = normalize(vec3(uv.xy,-2.0)); dir.z += length(uv) * 0.15;\\n dir = normalize(dir) * fromEuler(ang);\\n \\n // tracing\\n vec3 p;\\n heightMapTracing(ori,dir,p);\\n vec3 dist = p - ori;\\n vec3 n = getNormal(p, dot(dist,dist) * EPSILON_NRM);\\n vec3 light = normalize(vec3(0.0,1.0,0.8)); \\n \\n // color\\n vec3 color = mix(\\n getSkyColor(dir),\\n getSeaColor(p,n,light,dir,dist),\\n \\tpow(smoothstep(0.0,-0.05,dir.y),0.3));\\n \\n // post\\n\\tv_color = vec4(pow(color,vec3(0.75)), 1.0);\\n}\\n\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46282.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n#ifdef GL_ES\n//precision mediump float;\n#endif\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\n// \"Seascape\" by Alexander Alekseev aka TDM - 2014\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n\nconst int NUM_STEPS = 16;\nconst float PI\t \t= 3.1415;\nconst float EPSILON\t= 1e-3;\nfloat EPSILON_NRM\t= 0.;\n\n// sea\nconst int ITER_GEOMETRY = 3;\nconst int ITER_FRAGMENT = 2;\nconst float SEA_HEIGHT = 0.6;\nconst float SEA_CHOPPY = 4.0;\nconst float SEA_SPEED = 0.8;\nconst float SEA_FREQ = 0.16;\nconst vec3 SEA_BASE = vec3(0.1,0.19,0.22);\nconst vec3 SEA_WATER_COLOR = vec3(0.8,0.9,0.6);\nfloat SEA_TIME = 0.;\nmat2 octave_m = mat2(1.6,1.2,-1.2,1.6);\n\n// math\nmat3 fromEuler(vec3 ang) {\n\tvec2 a1 = vec2(sin(ang.x),cos(ang.x));\n vec2 a2 = vec2(sin(ang.y),cos(ang.y));\n vec2 a3 = vec2(sin(ang.z),cos(ang.z));\n mat3 m;\n m[0] = vec3(a1.y*a3.y+a1.x*a2.x*a3.x,a1.y*a2.x*a3.x+a3.y*a1.x,-a2.y*a3.x);\n\tm[1] = vec3(-a2.y*a1.x,a1.y*a2.y,a2.x);\n\tm[2] = vec3(a3.y*a1.x*a2.x+a1.y*a3.x,a1.x*a3.x-a1.y*a3.y*a2.x,a2.y*a3.y);\n\treturn m;\n}\nfloat hash( vec2 p ) {\n\tfloat h = dot(p,vec2(127.1,311.7));\t\n return fract(sin(h)*43758.5453123);\n}\nfloat noise( in vec2 p ) {\n vec2 i = floor( p );\n vec2 f = fract( p );\t\n\tvec2 u = f*f*(3.0-2.0*f);\n return -1.0+2.0*mix( mix( hash( i + vec2(0.0,0.0) ), \n hash( i + vec2(1.0,0.0) ), u.x),\n mix( hash( i + vec2(0.0,1.0) ), \n hash( i + vec2(1.0,1.0) ), u.x), u.y);\n}\n\n// lighting\nfloat diffuse(vec3 n,vec3 l,float p) {\n return pow(dot(n,l) * 0.4 + 0.6,p);\n}\nfloat specular(vec3 n,vec3 l,vec3 e,float s) { \n float nrm = (s + 8.0) / (3.1415 * 8.0);\n return pow(max(dot(reflect(e,n),l),0.0),s) * nrm;\n}\n\n// sky\nvec3 getSkyColor(vec3 e) {\n e.y = max(e.y,0.0);\n vec3 ret;\n ret.x = pow(1.0-e.y,2.0);\n ret.y = 1.0-e.y;\n ret.z = 0.6+(1.0-e.y)*0.4;\n return ret;\n}\n\n// sea\nfloat sea_octave(vec2 uv, float choppy) {\n uv += noise(uv); \n vec2 wv = 1.0-abs(sin(uv));\n vec2 swv = abs(cos(uv)); \n wv = mix(wv,swv,wv);\n return pow(1.0-pow(wv.x * wv.y,0.65),choppy);\n}\n\nfloat map(vec3 p) {\n float freq = SEA_FREQ;\n float amp = SEA_HEIGHT;\n float choppy = SEA_CHOPPY;\n vec2 uv = p.xz; uv.x *= 0.75;\n \n float d, h = 0.0; \n for(int i = 0; i < ITER_GEOMETRY; i++) { \n \td = sea_octave((uv+SEA_TIME)*freq,choppy);\n \td += sea_octave((uv-SEA_TIME)*freq,choppy);\n h += d * amp; \n \tuv *= octave_m; freq *= 1.9; amp *= 0.22;\n choppy = mix(choppy,1.0,0.2);\n }\n return p.y - h;\n}\n\nfloat map_detailed(vec3 p) {\n float freq = SEA_FREQ;\n float amp = SEA_HEIGHT;\n float choppy = SEA_CHOPPY;\n vec2 uv = p.xz; uv.x *= 0.75;\n \n float d, h = 0.0; \n for(int i = 0; i < ITER_FRAGMENT; i++) { \n \td = sea_octave((uv+SEA_TIME)*freq,choppy);\n \td += sea_octave((uv-SEA_TIME)*freq,choppy);\n h += d * amp; \n \tuv *= octave_m; freq *= 1.9; amp *= 0.22;\n choppy = mix(choppy,1.0,0.2);\n }\n return p.y - h;\n}\n\nvec3 getSeaColor(vec3 p, vec3 n, vec3 l, vec3 eye, vec3 dist) { \n float fresnel = 1.0 - max(dot(n,-eye),0.0);\n fresnel = pow(fresnel,3.0) * 0.65;\n \n vec3 reflected = getSkyColor(reflect(eye,n)); \n vec3 refracted = SEA_BASE + diffuse(n,l,80.0) * SEA_WATER_COLOR * 0.12; \n \n vec3 color = mix(refracted,reflected,fresnel);\n \n float atten = max(1.0 - dot(dist,dist) * 0.001, 0.0);\n color += SEA_WATER_COLOR * (p.y - SEA_HEIGHT) * 0.18 * atten;\n \n color += vec3(specular(n,l,eye,60.0));\n \n return color;\n}\n\n// tracing\nvec3 getNormal(vec3 p, float eps) {\n vec3 n;\n n.y = map_detailed(p); \n n.x = map_detailed(vec3(p.x+eps,p.y,p.z)) - n.y;\n n.z = map_detailed(vec3(p.x,p.y,p.z+eps)) - n.y;\n n.y = eps;\n \n return normalize(n);\n}\n\nfloat heightMapTracing(vec3 ori, vec3 dir, out vec3 p) { \n float tm = 0.0;\n float tx = 1000.0; \n float hx = map(ori + dir * tx);\n if(hx > 0.0) return tx; \n float hm = map(ori + dir * tm); \n float tmid = 0.0;\n for(int i = 0; i < NUM_STEPS; i++) {\n tmid = mix(tm,tx, hm/(hm-hx)); \n p = ori + dir * tmid; \n \tfloat hmid = map(p);\n\t\tif(hmid < 0.0) {\n \ttx = tmid;\n hx = hmid;\n } else {\n tm = tmid;\n hm = hmid;\n }\n }\n\n}\n\n// main\nvoid main( void ) {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n\tEPSILON_NRM = 0.1 / vertexResolution.x;\n\tSEA_TIME = time * SEA_SPEED;\n\t\n\tvec2 uv = simFragCoord.xy / vertexResolution.xy;\n uv = uv * 2.0 - 1.0;\n uv.x *= vertexResolution.x / vertexResolution.y; \n float time = time * 0.3 + mouse.x*0.01;\n \n // ray\n vec3 ang = vec3(sin(time*3.0)*0.1,sin(time)*0.2+0.3,time); \n vec3 ori = vec3(0.0,3.5,time*5.0);\n vec3 dir = normalize(vec3(uv.xy,-2.0)); dir.z += length(uv) * 0.15;\n dir = normalize(dir) * fromEuler(ang);\n \n // tracing\n vec3 p;\n heightMapTracing(ori,dir,p);\n vec3 dist = p - ori;\n vec3 n = getNormal(p, dot(dist,dist) * EPSILON_NRM);\n vec3 light = normalize(vec3(0.0,1.0,0.8)); \n \n // color\n vec3 color = mix(\n getSkyColor(dir),\n getSeaColor(p,n,light,dir,dist),\n \tpow(smoothstep(0.0,-0.05,dir.y),0.3));\n \n // post\n\tv_color = vec4(pow(color,vec3(0.75)), 1.0);\n}\n" + }, "screenshotURL": "data/images/images-wjicgqrsxi0olqpjv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rprQ8uGr5rvgeTCMd/art.json b/art/rprQ8uGr5rvgeTCMd/art.json index 7a1def8a..a3490700 100644 --- a/art/rprQ8uGr5rvgeTCMd/art.json +++ b/art/rprQ8uGr5rvgeTCMd/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "rmccampbell7", "avatarUrl": "https://secure.gravatar.com/avatar/06a15f2260899be5cfa7484a476adf34?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const float TAU = radians(360.);\\nconst float NLON = 20.;\\nconst float NLAT = 10.;\\nconst float NPOINTS = NLON*(NLAT+1.);\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 rotx(vec3 v, float theta) {\\n float c = cos(theta), s = sin(theta);\\n return vec3(v.x, c*v.y-s*v.z, s*v.y+c*v.z);\\n}\\n\\nvec3 roty(vec3 v, float theta) {\\n float c = cos(theta), s = sin(theta);\\n return vec3(c*v.x+s*v.z, v.y, -s*v.x+c*v.z);\\n}\\n\\nvoid main() {\\n float id = mod(vertexId, NPOINTS);\\n float u = fract(id / NLON);\\n float v = floor(id / NLON) / NLAT;\\n float theta = TAU*u;\\n float phi = .5*TAU*v;\\n float x = cos(theta)*sin(phi);\\n float z = sin(theta)*sin(phi);\\n float y = -cos(phi);\\n\\n vec3 pos = roty(rotx(vec3(x, y, z), .95*TAU), time) * .8;\\n float aspect = resolution.y / resolution.x;\\n gl_Position = vec4(pos.x*aspect, pos.y, pos.z, 1);\\n gl_PointSize = 10.;\\n\\n v_color = vec4(hsv2rgb(vec3(fract(u+v), 1, 1)), 1);\\n}\\n\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const float TAU = radians(360.);\nconst float NLON = 20.;\nconst float NLAT = 10.;\nconst float NPOINTS = NLON*(NLAT+1.);\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 rotx(vec3 v, float theta) {\n float c = cos(theta), s = sin(theta);\n return vec3(v.x, c*v.y-s*v.z, s*v.y+c*v.z);\n}\n\nvec3 roty(vec3 v, float theta) {\n float c = cos(theta), s = sin(theta);\n return vec3(c*v.x+s*v.z, v.y, -s*v.x+c*v.z);\n}\n\nvoid main() {\n float id = mod(vertexId, NPOINTS);\n float u = fract(id / NLON);\n float v = floor(id / NLON) / NLAT;\n float theta = TAU*u;\n float phi = .5*TAU*v;\n float x = cos(theta)*sin(phi);\n float z = sin(theta)*sin(phi);\n float y = -cos(phi);\n\n vec3 pos = roty(rotx(vec3(x, y, z), .95*TAU), time) * .8;\n float aspect = resolution.y / resolution.x;\n gl_Position = vec4(pos.x*aspect, pos.y, pos.z, 1);\n gl_PointSize = 10.;\n\n v_color = vec4(hsv2rgb(vec3(fract(u+v), 1, 1)), 1);\n}\n" + }, "screenshotURL": "data/images/images-ev8tke6yqm35y9bo5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rpsbSKo8heXFgATpg/art.json b/art/rpsbSKo8heXFgATpg/art.json index ec3e6d3a..247234d2 100644 --- a/art/rpsbSKo8heXFgATpg/art.json +++ b/art/rpsbSKo8heXFgATpg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":8196,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() { \\n gl_PointSize = 1.0;\\n \\n v_color = vec4(\\n abs(sin(vertexId * 0.1 - time * 8.0)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\\n 1.0);\\n \\n gl_Position.x = sin(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\\n gl_Position.y = cos(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\\n gl_Position.z = 0.0;\\n gl_Position[3] = 1.0;\\n}\"}", + "settings": { + "num": 8196, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() { \n gl_PointSize = 1.0;\n \n v_color = vec4(\n abs(sin(vertexId * 0.1 - time * 8.0)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 2.09)),\n abs(sin(vertexId * 0.1 - time * 8.0 + 4.18879020479)),\n 1.0);\n \n gl_Position.x = sin(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\n gl_Position.y = cos(time * 2.0 - vertexId / 2.0) * vertexId / 64.0 / 64.0;\n gl_Position.z = 0.0;\n gl_Position[3] = 1.0;\n}" + }, "screenshotURL": "data/images/images-klv0dnomdvgrld4uw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rr7LMKBcPb7iHAgAT/art.json b/art/rr7LMKBcPb7iHAgAT/art.json index 14711936..8570a84b 100644 --- a/art/rr7LMKBcPb7iHAgAT/art.json +++ b/art/rr7LMKBcPb7iHAgAT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*0.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.1)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3, i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+2.5)-3.5;\\n \\n float l = length(posf)*2.4;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.5,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*6.20;\\n float i = vertexId+sin(vertexId)*100.7;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.8; f++) {\\n\\t ofs += push(t+f*9.05,i,ofs,2.10-exp(-f*1.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(2.8,3.6,-4.6,5.8);\\n pos.xz *= mat2(6.8,7.6,-8.6,9.8);\\n \\n pos *= 1.10;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*0.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.1)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3, i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+2.5)-3.5;\n \n float l = length(posf)*2.4;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.5,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*6.20;\n float i = vertexId+sin(vertexId)*100.7;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.8; f++) {\n\t ofs += push(t+f*9.05,i,ofs,2.10-exp(-f*1.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(2.8,3.6,-4.6,5.8);\n pos.xz *= mat2(6.8,7.6,-8.6,9.8);\n \n pos *= 1.10;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-08vn41lpndi0opfyw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rrbek22fBWSHNDxAE/art.json b/art/rrbek22fBWSHNDxAE/art.json index 34ff215e..63a6e328 100644 --- a/art/rrbek22fBWSHNDxAE/art.json +++ b/art/rrbek22fBWSHNDxAE/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "mauricio", "avatarUrl": "https://lh6.googleusercontent.com/-b9uQLeas5E4/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdVYh3bL30qL5Loro9AUsZOKbJn4Q/mo/photo.jpg", - "settings": "{\"num\":12593,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n float u = x / (width - 1.0);\\n float v = y / (width -1.0);\\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n float ux = u * 2.0 -1.0 + xOffset;\\n float uy = v* 2.0 -1.0 + yOffset;\\n vec2 xy = vec2(ux, uy) * 0.6;\\n \\n gl_Position = vec4(xy, 0.0, 1.0); //posicion del color\\n v_color = vec4(1.0, 0.0, 1.0, 1.0); //color \\n gl_PointSize = 10.0;\\n \\n}\"}", + "settings": { + "num": 12593, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n float u = x / (width - 1.0);\n float v = y / (width -1.0);\n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n float ux = u * 2.0 -1.0 + xOffset;\n float uy = v* 2.0 -1.0 + yOffset;\n vec2 xy = vec2(ux, uy) * 0.6;\n \n gl_Position = vec4(xy, 0.0, 1.0); //posicion del color\n v_color = vec4(1.0, 0.0, 1.0, 1.0); //color \n gl_PointSize = 10.0;\n \n}" + }, "screenshotURL": "data/images/images-2g2qxotz3pql8c1ag-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rsQG6eXcgMiDznHzF/art.json b/art/rsQG6eXcgMiDznHzF/art.json index 24cec9c6..aba7584a 100644 --- a/art/rsQG6eXcgMiDznHzF/art.json +++ b/art/rsQG6eXcgMiDznHzF/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "duhochoi", "avatarUrl": "https://secure.gravatar.com/avatar/3a2a5d4b2ecd66c69241bc6b3e1e34e6?default=retro&size=200", - "settings": "{\"num\":60891,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Duho Choi\\n// Assignment : Exercise - Vertexshaderart : Motion\\n// Course : CS250\\n// Term : Spring 2023\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + x * 0.2) * sin(time) * 0.15;\\n \\tfloat yoff = sin(time + y * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 3.;\\n \\n \\tgl_PointSize = 15. + soff;\\n \\tgl_PointSize *= 20. / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tv_color = vec4(1, sin(time) + 0.5, sin(x), 1);\\n}\\n\"}", + "settings": { + "num": 60891, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Duho Choi\n// Assignment : Exercise - Vertexshaderart : Motion\n// Course : CS250\n// Term : Spring 2023\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + x * 0.2) * sin(time) * 0.15;\n \tfloat yoff = sin(time + y * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 3.;\n \n \tgl_PointSize = 15. + soff;\n \tgl_PointSize *= 20. / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n \tv_color = vec4(1, sin(time) + 0.5, sin(x), 1);\n}\n" + }, "screenshotURL": "data/images/images-u5bpfhzek7qra5u6v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rsfLpHMoLXeSK4ybu/art.json b/art/rsfLpHMoLXeSK4ybu/art.json index 20274c03..2f5b470a 100644 --- a/art/rsfLpHMoLXeSK4ybu/art.json +++ b/art/rsfLpHMoLXeSK4ybu/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":128,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvoid main() {\\n float start = mod(vertexId, 2.0);\\n float x = -1.0 + 2.0 * mod(floor(vertexId / 2.0), 2.0);\\n float y = -1.0 + 2.0 * mod(floor(vertexId / 4.0), 2.0);\\n float z = -1.0 + 2.0 * mod(floor(vertexId / 8.0), 2.0);\\n float w = -1.0 + 2.0 * mod(floor(vertexId / 16.0), 2.0);\\n float idx = mod(floor(vertexId / 32.0), 4.0);\\n x += (idx == .0 && start == 1.0 && x < 0.) ? 2. : 0.;\\n y += (idx == 1.0 && start == 1.0 && y < 0.) ? 2. : 0.;\\n z += (idx == 2.0 && start == 1.0 && z < 0.) ? 2. : 0.;\\n w += (idx == 3.0 && start == 1.0 && w < 0.) ? 2. : 0.;\\n vec4 xyzw = vec4(x, y, z, w);\\n float a = cos(0.08*time);\\n float k = sin(0.08*time);\\n float b = k * mouse.x;\\n float c = k * mouse.y;\\n float d = k * sqrt(1. - dot(mouse, mouse));\\n mat4 rot = mat4(a, -b, -c, -d,\\n b, a, -d, c,\\n c, d, a, -b,\\n d, -c, b, a);\\n xyzw = rot * xyzw;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(.3 * aspect * xyzw.xy, 0., 1.);\\n v_color = .25 * (3. + xyzw.z) * vec4(.5, .5 * (1.+xyzw.w), .5, 0.5);\\n}\"}", + "settings": { + "num": 128, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvoid main() {\n float start = mod(vertexId, 2.0);\n float x = -1.0 + 2.0 * mod(floor(vertexId / 2.0), 2.0);\n float y = -1.0 + 2.0 * mod(floor(vertexId / 4.0), 2.0);\n float z = -1.0 + 2.0 * mod(floor(vertexId / 8.0), 2.0);\n float w = -1.0 + 2.0 * mod(floor(vertexId / 16.0), 2.0);\n float idx = mod(floor(vertexId / 32.0), 4.0);\n x += (idx == .0 && start == 1.0 && x < 0.) ? 2. : 0.;\n y += (idx == 1.0 && start == 1.0 && y < 0.) ? 2. : 0.;\n z += (idx == 2.0 && start == 1.0 && z < 0.) ? 2. : 0.;\n w += (idx == 3.0 && start == 1.0 && w < 0.) ? 2. : 0.;\n vec4 xyzw = vec4(x, y, z, w);\n float a = cos(0.08*time);\n float k = sin(0.08*time);\n float b = k * mouse.x;\n float c = k * mouse.y;\n float d = k * sqrt(1. - dot(mouse, mouse));\n mat4 rot = mat4(a, -b, -c, -d,\n b, a, -d, c,\n c, d, a, -b,\n d, -c, b, a);\n xyzw = rot * xyzw;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(.3 * aspect * xyzw.xy, 0., 1.);\n v_color = .25 * (3. + xyzw.z) * vec4(.5, .5 * (1.+xyzw.w), .5, 0.5);\n}" + }, "screenshotURL": "data/images/images-ku8yibf3fp4zzjvug-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rskYzcp7KQd6MLz3F/art.json b/art/rskYzcp7KQd6MLz3F/art.json index f5afb921..612a741a 100644 --- a/art/rskYzcp7KQd6MLz3F/art.json +++ b/art/rskYzcp7KQd6MLz3F/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "gninnam", "avatarUrl": "https://secure.gravatar.com/avatar/7d3e3f2854cb9a5f58af502a80c9c450?default=retro&size=200", - "settings": "{\"num\":6272,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nfloat select(float v, float t) {\\n return step(t * 0.9, v) * step(v, t * 1.1);\\n}\\n\\nvoid main() {\\n float GRID_YOFF = 1./40.;\\n float GRID_DOWN = 17.;\\n float GRID_ACROSS = 64.0;\\n float NUM_PER_DOWN = GRID_DOWN * 2.;\\n float NUM_PER_ACROSS = GRID_ACROSS * 2.;\\n float NUM_PER_GRID = NUM_PER_DOWN + NUM_PER_ACROSS;\\n float NUM_GRIDS = 4.;\\n float NUM_GRID_TOTAL = NUM_PER_GRID * NUM_GRIDS;\\n float NUM_POINTS = (vertexCount - NUM_GRID_TOTAL) / 4.;\\n float NUM_SEGMENTS = NUM_POINTS / 2.;\\n \\n \\n float id = vertexId - NUM_GRID_TOTAL;\\n \\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(id, NUM_POINTS) / 2.0) + mod(id, 2.0);\\n // line count\\n float grid = floor(id / NUM_POINTS);\\n\\n float u = point / (NUM_SEGMENTS - 1.); // 0 <-> 1 across line\\n float v = grid / NUM_GRIDS; // 0 <-> 1 by line\\n\\n float snd0 = texture2D(sound, vec2(u * 1., 0)).a;\\n float snd1 = texture2D(sound, vec2(u * 0.5, 0)).a;\\n float snd2 = texture2D(sound, vec2(u * 0.25, 0)).a;\\n float snd3 = texture2D(sound, vec2(u * 0.125, 0)).a;\\n \\n float s = \\n snd0 * select(grid, 0.) + \\n snd1 * select(grid, 1.) +\\n snd2 * select(grid, 2.) + \\n snd3 * select(grid, 3.) +\\n 0.;\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x,\\n s * 0.4 + y + GRID_YOFF);\\n gl_Position = vec4(xy, 0, 1);\\n \\n float hue = grid * 0.25;\\n float sat = 1.0;\\n float val = 1.0;\\n \\n if (id < 0.0) {\\n if (vertexId < NUM_PER_DOWN * NUM_GRIDS) {\\n float hgx = mod(vertexId, 2.0);\\n float hgy = mod(floor(vertexId / 2.), GRID_DOWN);\\n float hgId = floor(vertexId / NUM_PER_DOWN);\\n gl_Position = vec4(\\n hgx * 2. - 1.,\\n hgy / (GRID_DOWN - 1.) * 0.4 + \\n (hgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\\n 0.1,\\n 1);\\n \\n hue = hgId * 0.25;\\n sat = 0.5;\\n val = 0.3;\\n } else {\\n float vid = vertexId - NUM_PER_DOWN * NUM_GRIDS;\\n float vgy = mod(vid, 2.0);\\n float vgx = mod(floor(vid / 2.), GRID_ACROSS);\\n float vgId = floor(vid / NUM_PER_ACROSS);\\n gl_Position = vec4(\\n ((vgx / GRID_ACROSS) * 2. - 1.) * pow(2., vgId),\\n vgy * 0.4 + \\n (vgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\\n 0.1,\\n 1);\\n \\n hue = vgId * 0.25;\\n sat = 0.5;\\n val = 0.3;\\n \\n }\\n }\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 6272, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nfloat select(float v, float t) {\n return step(t * 0.9, v) * step(v, t * 1.1);\n}\n\nvoid main() {\n float GRID_YOFF = 1./40.;\n float GRID_DOWN = 17.;\n float GRID_ACROSS = 64.0;\n float NUM_PER_DOWN = GRID_DOWN * 2.;\n float NUM_PER_ACROSS = GRID_ACROSS * 2.;\n float NUM_PER_GRID = NUM_PER_DOWN + NUM_PER_ACROSS;\n float NUM_GRIDS = 4.;\n float NUM_GRID_TOTAL = NUM_PER_GRID * NUM_GRIDS;\n float NUM_POINTS = (vertexCount - NUM_GRID_TOTAL) / 4.;\n float NUM_SEGMENTS = NUM_POINTS / 2.;\n \n \n float id = vertexId - NUM_GRID_TOTAL;\n \n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(id, NUM_POINTS) / 2.0) + mod(id, 2.0);\n // line count\n float grid = floor(id / NUM_POINTS);\n\n float u = point / (NUM_SEGMENTS - 1.); // 0 <-> 1 across line\n float v = grid / NUM_GRIDS; // 0 <-> 1 by line\n\n float snd0 = texture2D(sound, vec2(u * 1., 0)).a;\n float snd1 = texture2D(sound, vec2(u * 0.5, 0)).a;\n float snd2 = texture2D(sound, vec2(u * 0.25, 0)).a;\n float snd3 = texture2D(sound, vec2(u * 0.125, 0)).a;\n \n float s = \n snd0 * select(grid, 0.) + \n snd1 * select(grid, 1.) +\n snd2 * select(grid, 2.) + \n snd3 * select(grid, 3.) +\n 0.;\n \n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x,\n s * 0.4 + y + GRID_YOFF);\n gl_Position = vec4(xy, 0, 1);\n \n float hue = grid * 0.25;\n float sat = 1.0;\n float val = 1.0;\n \n if (id < 0.0) {\n if (vertexId < NUM_PER_DOWN * NUM_GRIDS) {\n float hgx = mod(vertexId, 2.0);\n float hgy = mod(floor(vertexId / 2.), GRID_DOWN);\n float hgId = floor(vertexId / NUM_PER_DOWN);\n gl_Position = vec4(\n hgx * 2. - 1.,\n hgy / (GRID_DOWN - 1.) * 0.4 + \n (hgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\n 0.1,\n 1);\n \n hue = hgId * 0.25;\n sat = 0.5;\n val = 0.3;\n } else {\n float vid = vertexId - NUM_PER_DOWN * NUM_GRIDS;\n float vgy = mod(vid, 2.0);\n float vgx = mod(floor(vid / 2.), GRID_ACROSS);\n float vgId = floor(vid / NUM_PER_ACROSS);\n gl_Position = vec4(\n ((vgx / GRID_ACROSS) * 2. - 1.) * pow(2., vgId),\n vgy * 0.4 + \n (vgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\n 0.1,\n 1);\n \n hue = vgId * 0.25;\n sat = 0.5;\n val = 0.3;\n \n }\n }\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-9pwuiycdvsmhnpi3o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ruRxM7a7ngW6o8SPY/art.json b/art/ruRxM7a7ngW6o8SPY/art.json index 6ea769f6..7cf0d103 100644 --- a/art/ruRxM7a7ngW6o8SPY/art.json +++ b/art/ruRxM7a7ngW6o8SPY/art.json @@ -27,7 +27,19 @@ "name": "balls", "private": false, "username": "gman", - "settings": "{\"num\":38300,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/techno-musictv/minimal-techno-remix-1-click\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid sphere(float v, float time, out vec3 pos, out vec3 color) {\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 8.);\\n v = (v-a1)/8.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/8.*2.*PI;\\n float a2n = (a2+.5)/8.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/8.*2.*PI;\\n a2 = a2/8.*2.*PI;\\n \\n pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n color = vec3(1,1,1) * (dot(normalize(vec3(0.3, 0.5, 0.3)), norm) * 0.5 + 0.5);\\n}\\n\\nvoid main() {\\n vec3 pos;\\n vec3 light;\\n\\n float count = floor(vertexId / 384.0);\\n float col = mod(count, 10.);\\n float row = floor(count / 10.);\\n float u = col / 9.;\\n float v = row / 9.;\\n float vs = v * 2. - 1.;\\n float us = u * 2. - 1.;\\n float s = \\n texture2D(sound, vec2(0.05, abs(us) * 0.05)).a +\\n texture2D(sound, vec2(0.10, abs(us) * 0.05)).a + \\n texture2D(sound, vec2(0.15, abs(us) * 0.05)).a;\\n float s2 = \\n texture2D(sound, vec2(0.025, abs(vs) * 0.05)).a +\\n texture2D(sound, vec2(0.120, abs(vs) * 0.05)).a + \\n texture2D(sound, vec2(0.125, abs(vs) * 0.05)).a;\\n sphere(mod(vertexId, 384.0), time + pow(s * 2. - 1.,s), pos, light);\\n \\n vec3 p = vec3((col + mod(row, 2.) * 0.5) / 9. * 2. - 1., (row + mod(col, 2.) * 0.0) / 9. * 2. - 1., 0.);\\n float a = atan(vs, us);// + time;\\n vec3 cs = vec3(1, 1, 1);\\n \\n gl_Position = vec4(p * cs + vec3(pos.x*resolution.y/resolution.x,pos.y, -pos.z*.5+.5) * (0.1 + 0.1 * pow(s * 0.7, 2.0)), 1); \\n\\n v_color = vec4(vec3(light) * pow(s2 * 0.7, 3.0), 1);\\n}\"}", + "settings": { + "num": 38300, + "mode": "LINES", + "sound": "https://soundcloud.com/techno-musictv/minimal-techno-remix-1-click", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid sphere(float v, float time, out vec3 pos, out vec3 color) {\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 8.);\n v = (v-a1)/8.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/8.*2.*PI;\n float a2n = (a2+.5)/8.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/8.*2.*PI;\n a2 = a2/8.*2.*PI;\n \n pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n color = vec3(1,1,1) * (dot(normalize(vec3(0.3, 0.5, 0.3)), norm) * 0.5 + 0.5);\n}\n\nvoid main() {\n vec3 pos;\n vec3 light;\n\n float count = floor(vertexId / 384.0);\n float col = mod(count, 10.);\n float row = floor(count / 10.);\n float u = col / 9.;\n float v = row / 9.;\n float vs = v * 2. - 1.;\n float us = u * 2. - 1.;\n float s = \n texture2D(sound, vec2(0.05, abs(us) * 0.05)).a +\n texture2D(sound, vec2(0.10, abs(us) * 0.05)).a + \n texture2D(sound, vec2(0.15, abs(us) * 0.05)).a;\n float s2 = \n texture2D(sound, vec2(0.025, abs(vs) * 0.05)).a +\n texture2D(sound, vec2(0.120, abs(vs) * 0.05)).a + \n texture2D(sound, vec2(0.125, abs(vs) * 0.05)).a;\n sphere(mod(vertexId, 384.0), time + pow(s * 2. - 1.,s), pos, light);\n \n vec3 p = vec3((col + mod(row, 2.) * 0.5) / 9. * 2. - 1., (row + mod(col, 2.) * 0.0) / 9. * 2. - 1., 0.);\n float a = atan(vs, us);// + time;\n vec3 cs = vec3(1, 1, 1);\n \n gl_Position = vec4(p * cs + vec3(pos.x*resolution.y/resolution.x,pos.y, -pos.z*.5+.5) * (0.1 + 0.1 * pow(s * 0.7, 2.0)), 1); \n\n v_color = vec4(vec3(light) * pow(s2 * 0.7, 3.0), 1);\n}" + }, "screenshotURL": "data/images/images-i6gmagfend2kt7ldd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rvBrwrSM6wfvD97BZ/art.json b/art/rvBrwrSM6wfvD97BZ/art.json index c66b466d..ab0d6220 100644 --- a/art/rvBrwrSM6wfvD97BZ/art.json +++ b/art/rvBrwrSM6wfvD97BZ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "dnmtn", "avatarUrl": "https://secure.gravatar.com/avatar/a118b79de569bc655138fbe150558114?default=retro&size=200", - "settings": "{\"num\":21380,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>8.\\n#define parameter1 3.//KParameter1 1.>>8.\\n#define parameter2 3.//KParameter2 0.>>40.\\n#define parameter3 20.//KParameter3 5>>100.\\n#define parameter4 0.2//KParameter4 0.01>>0.05\\n#define parameter5 360.//KParameter5 5.>>50.\\n#define parameter6 15.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 1.>>5.\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\\n{\\n vec3 u = _triangleVertices0 - _triangleVertices1;\\n vec3 v = _triangleVertices1 - _triangleVertices2;\\n return cross(v, u);\\n}\\n\\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\\n{\\n float localVid = mod(_vId,_vtn);\\n \\n if(localVid< 1.)\\n {\\n \\n _v = _vt[0];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n \\n }\\n else\\n if(localVid< 2.)\\n {\\n _v = _vt[1];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 3.)\\n {\\n _v = _vt[2];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 4.)\\n {\\n _v = _vt[3];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 5.)\\n {\\n _v = _vt[4];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 6.)\\n {\\n _v = _vt[5];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 7.)\\n {\\n _v = _vt[6];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 8.)\\n {\\n _v = _vt[7];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 9.)\\n {\\n _v = _vt[8];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 10.)\\n {\\n _v = _vt[9];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 11.)\\n {\\n _v = _vt[10];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 12.)\\n {\\n _v = _vt[11];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n \\n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\\n \\n _v = rotY(_v,_rot.y);\\n _n = rotY(_n,_rot.y);\\n \\n\\n _v = rotX(_v,_rot.x);\\n _n = rotX(_n,_rot.x);\\n \\n _v = rotZ(_v,_rot.z);\\n _n = rotZ(_n,_rot.z);\\n \\n _v += _pos;\\n //_n += _pos;\\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\\n specular = max(0.0, pow(NDoth, _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n \\n //KVsa\\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n //KVsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops = floor(parameter1);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n\\n \\n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops2 = floor(1.);\\n float subLoopLength2 = 1./numberOfSubLoops2;\\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n vec3 _n = vec3(0.,0.,0.);\\n \\n vec3 shapeVertices[12];\\n float shapeSize = 12.;\\n \\n \\n \\n \\n float maxShapeCount = floor(vertexCount/shapeSize);\\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\\n float shapeId = floor(finalVertexId/shapeSize);\\n float relShapeId = shapeId/maxShapeCount;\\n float scale = parameter4;\\n \\n \\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\\n float localShapeId = mod(shapeId,numberOfShape);\\n float localRelShapeId = localShapeId/numberOfShape;\\n \\n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\\n \\n \\n float radius = 0.1+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\\n \\n \\n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\\n \\n \\n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\\n float factor1 = 1.;\\n \\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\\n shapeVertices[1] = vec3(0.5,0.,-0.5);\\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\\n shapeVertices[3] = vec3(0.5,0.,-0.5);\\n shapeVertices[4] = vec3(0.5,0.,0.5);\\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\\n shapeVertices[6] =vec3(0.5,0.,0.5);\\n shapeVertices[7] =vec3(-0.5,0.,0.5);\\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\\n shapeVertices[9] =vec3(-0.5,0.,0.5);\\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\\n \\n vec3 shapeColors[4];\\n \\n shapeColors[0] = vec3(1.,0.,0.);\\n shapeColors[1] = vec3(0.,1.,1.);\\n shapeColors[2] = vec3(1.,0.,0.);\\n shapeColors[3] = vec3(1.,1.,0.);\\n \\n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\\n \\n //create the big circle\\n float masterCircleRadius = 0.4;\\n float numberOfCirclesInMasterCircle = floor(parameter5);\\n float vertexPerSmallCircle = numberOfShape*shapeSize;\\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\\n \\n _v.y-=masterCircleRadius;\\n \\n _v = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\\n _n = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\\n _v.z-=0.58;\\n \\n vec3 eye = vec3(0., 0., -1.);\\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\\n\\n vec3 p = lookAt(_v, eye, vec3(0.,1.7,0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n \\n _v.x*=resolution.y/resolution.x;\\n\\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 21380, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>8.\n#define parameter1 3.//KParameter1 1.>>8.\n#define parameter2 3.//KParameter2 0.>>40.\n#define parameter3 20.//KParameter3 5>>100.\n#define parameter4 0.2//KParameter4 0.01>>0.05\n#define parameter5 360.//KParameter5 5.>>50.\n#define parameter6 15.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 1.>>5.\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\n{\n vec3 u = _triangleVertices0 - _triangleVertices1;\n vec3 v = _triangleVertices1 - _triangleVertices2;\n return cross(v, u);\n}\n\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\n{\n float localVid = mod(_vId,_vtn);\n \n if(localVid< 1.)\n {\n \n _v = _vt[0];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n \n }\n else\n if(localVid< 2.)\n {\n _v = _vt[1];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 3.)\n {\n _v = _vt[2];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 4.)\n {\n _v = _vt[3];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 5.)\n {\n _v = _vt[4];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 6.)\n {\n _v = _vt[5];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 7.)\n {\n _v = _vt[6];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 8.)\n {\n _v = _vt[7];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 9.)\n {\n _v = _vt[8];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 10.)\n {\n _v = _vt[9];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 11.)\n {\n _v = _vt[10];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 12.)\n {\n _v = _vt[11];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n \n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\n \n _v = rotY(_v,_rot.y);\n _n = rotY(_n,_rot.y);\n \n\n _v = rotX(_v,_rot.x);\n _n = rotX(_n,_rot.x);\n \n _v = rotZ(_v,_rot.z);\n _n = rotZ(_n,_rot.z);\n \n _v += _pos;\n //_n += _pos;\n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\n specular = max(0.0, pow(NDoth, _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n \n vec3 color = vec3(1.);\n \n //KVsa\n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n //KVsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops = floor(parameter1);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n\n \n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops2 = floor(1.);\n float subLoopLength2 = 1./numberOfSubLoops2;\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\n \n vec3 _v = vec3(0.,0.,0.);\n vec3 _n = vec3(0.,0.,0.);\n \n vec3 shapeVertices[12];\n float shapeSize = 12.;\n \n \n \n \n float maxShapeCount = floor(vertexCount/shapeSize);\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\n float shapeId = floor(finalVertexId/shapeSize);\n float relShapeId = shapeId/maxShapeCount;\n float scale = parameter4;\n \n \n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\n float localShapeId = mod(shapeId,numberOfShape);\n float localRelShapeId = localShapeId/numberOfShape;\n \n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\n \n \n float radius = 0.1+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\n \n \n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\n \n \n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\n float factor1 = 1.;\n \n shapeVertices[0] = vec3(-0.5,0.,-0.5);\n shapeVertices[1] = vec3(0.5,0.,-0.5);\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\n shapeVertices[3] = vec3(0.5,0.,-0.5);\n shapeVertices[4] = vec3(0.5,0.,0.5);\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\n shapeVertices[6] =vec3(0.5,0.,0.5);\n shapeVertices[7] =vec3(-0.5,0.,0.5);\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\n shapeVertices[9] =vec3(-0.5,0.,0.5);\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\n \n vec3 shapeColors[4];\n \n shapeColors[0] = vec3(1.,0.,0.);\n shapeColors[1] = vec3(0.,1.,1.);\n shapeColors[2] = vec3(1.,0.,0.);\n shapeColors[3] = vec3(1.,1.,0.);\n \n vec3 rot = vec3(PI/2.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\n \n //create the big circle\n float masterCircleRadius = 0.4;\n float numberOfCirclesInMasterCircle = floor(parameter5);\n float vertexPerSmallCircle = numberOfShape*shapeSize;\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\n \n _v.y-=masterCircleRadius;\n \n _v = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\n _n = rotX(_v,-(relMasterCircleId*2.*PI+time*parameter7));\n _v.z-=0.58;\n \n vec3 eye = vec3(0., 0., -1.);\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\n\n vec3 p = lookAt(_v, eye, vec3(0.,1.7,0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n \n _v.x*=resolution.y/resolution.x;\n\n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-gompxsnm60lrr4mpk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rvrqPiwbYYrRPNC6i/art.json b/art/rvrqPiwbYYrRPNC6i/art.json index b1fd6f3c..3a917348 100644 --- a/art/rvrqPiwbYYrRPNC6i/art.json +++ b/art/rvrqPiwbYYrRPNC6i/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "xi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GhDJubRRp-SM2AciN7fDuusjZXt4-We-Q9ZOwXU", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.0196078431372549,0.2784313725490196,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y*0.2) * 0.1;\\n float yoff = sin(time + x*0.2) * 0.1;\\n \\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x/600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.0196078431372549, + 0.2784313725490196, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y*0.2) * 0.1;\n float yoff = sin(time + x*0.2) * 0.1;\n \n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x/600.;\n \n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-ufkgug8ufwkzvbnnr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/rvw679Z5He2rieYqy/art.json b/art/rvw679Z5He2rieYqy/art.json index e8b8ab8f..5549f84d 100644 --- a/art/rvw679Z5He2rieYqy/art.json +++ b/art/rvw679Z5He2rieYqy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/droplexofficial/droplex-corner-wealth-power-original-mix\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\\n \\n float sp = time * .2 + vertexId;\\n vec3 eye = vec3(0, 0, 1000);\\n vec3 target = vec3(0);\\n vec3 up = vec3(sin(sp), cos(sp), 0.);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec4 color;\\n \\n vec3 cpos = vec3(0);\\n vec3 cnormal = vec3(0,0,1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / 1.);\\n \\n float tm = time * 0.1;\\n \\n const float dim = 1.0;\\n vec3 t = normalize(vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n .5) * 2. - 1.);\\n \\n vec3 tp = t * hash(cubeId * 0.413 + time);\\n \\n \\n float sf = hash(cubeId * 0.379);\\n float s = texture2D(sound, vec2(\\n mix(0.05, 0.3, sf),\\n length(tp) * .2)).a;\\n\\n float pump = step(0.6, s);\\n \\n \\n \\n mat4 mat = trans(tp * dim * .5 + tp * pow(s, 5.) * 2.);\\n \\n vec3 pos = (mat * vec4(cpos, 1)).xyz; \\n \\n color = vec4(.5);\\n \\n \\n \\n float hue = time * 0.1 + mix(0.0, 0.2, sf);\\n float sat = 1.;\\n float val = 1.;\\n vec3 pcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n color = mix(color, vec4(pcolor, 1), pump);\\n \\n// color = mix(color, vec4(0), abs(sin(time + atan(pos.x, pos.y))));\\n \\n color.rgb *= color.a;\\n vec2 shit = normalize(tp.xy);\\n float ang = atan(shit.y, shit.x);\\n \\n // color.rgb = hsv2rgb(vec3(ang, 1, 1));\\n \\n gl_PointSize = mix(0.5, (1. - length(tp)) * 2., pump);\\n \\n // gl_PointSize = 4.;\\n\\n float aspect = resolution.x / resolution.y;\\n \\n mat4 lmat = scale(vec3(1, aspect, 1) * .75);\\n lmat *= rotZ(vertexId + time);\\n gl_Position = lmat * vec4(pos, 1);\\n v_color = color;\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/droplexofficial/droplex-corner-wealth-power-original-mix", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 4000.0);\n \n float sp = time * .2 + vertexId;\n vec3 eye = vec3(0, 0, 1000);\n vec3 target = vec3(0);\n vec3 up = vec3(sin(sp), cos(sp), 0.);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec4 color;\n \n vec3 cpos = vec3(0);\n vec3 cnormal = vec3(0,0,1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / 1.);\n \n float tm = time * 0.1;\n \n const float dim = 1.0;\n vec3 t = normalize(vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n .5) * 2. - 1.);\n \n vec3 tp = t * hash(cubeId * 0.413 + time);\n \n \n float sf = hash(cubeId * 0.379);\n float s = texture2D(sound, vec2(\n mix(0.05, 0.3, sf),\n length(tp) * .2)).a;\n\n float pump = step(0.6, s);\n \n \n \n mat4 mat = trans(tp * dim * .5 + tp * pow(s, 5.) * 2.);\n \n vec3 pos = (mat * vec4(cpos, 1)).xyz; \n \n color = vec4(.5);\n \n \n \n float hue = time * 0.1 + mix(0.0, 0.2, sf);\n float sat = 1.;\n float val = 1.;\n vec3 pcolor = hsv2rgb(vec3(hue, sat, val));\n \n color = mix(color, vec4(pcolor, 1), pump);\n \n// color = mix(color, vec4(0), abs(sin(time + atan(pos.x, pos.y))));\n \n color.rgb *= color.a;\n vec2 shit = normalize(tp.xy);\n float ang = atan(shit.y, shit.x);\n \n // color.rgb = hsv2rgb(vec3(ang, 1, 1));\n \n gl_PointSize = mix(0.5, (1. - length(tp)) * 2., pump);\n \n // gl_PointSize = 4.;\n\n float aspect = resolution.x / resolution.y;\n \n mat4 lmat = scale(vec3(1, aspect, 1) * .75);\n lmat *= rotZ(vertexId + time);\n gl_Position = lmat * vec4(pos, 1);\n v_color = color;\n \n}\n" + }, "screenshotURL": "data/images/images-iktrwnrgs7kd45dyk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ryGyoqT2E3N7mdJrC/art.json b/art/ryGyoqT2E3N7mdJrC/art.json index 7234ed9e..1d8a3632 100644 --- a/art/ryGyoqT2E3N7mdJrC/art.json +++ b/art/ryGyoqT2E3N7mdJrC/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":6272,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/richarddevine/ts83\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* ⏆ */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nfloat select(float v, float t) {\\n return step(t * 0.9, v) * step(v, t * 1.1);\\n}\\n\\nvoid main() {\\n float GRID_YOFF = 1./40.;\\n float GRID_DOWN = 17.;\\n float GRID_ACROSS = 64.0;\\n float NUM_PER_DOWN = GRID_DOWN * 2.;\\n float NUM_PER_ACROSS = GRID_ACROSS * 2.;\\n float NUM_PER_GRID = NUM_PER_DOWN + NUM_PER_ACROSS;\\n float NUM_GRIDS = 4.;\\n float NUM_GRID_TOTAL = NUM_PER_GRID * NUM_GRIDS;\\n float NUM_POINTS = (vertexCount - NUM_GRID_TOTAL) / 4.;\\n float NUM_SEGMENTS = NUM_POINTS / 2.;\\n \\n \\n float id = vertexId - NUM_GRID_TOTAL;\\n \\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(id, NUM_POINTS) / 2.0) + mod(id, 2.0);\\n // line count\\n float grid = floor(id / NUM_POINTS);\\n\\n float u = point / (NUM_SEGMENTS - 1.); // 0 <-> 1 across line\\n float v = grid / NUM_GRIDS; // 0 <-> 1 by line\\n\\n float snd0 = texture2D(sound, vec2(u * 1., 0)).a;\\n float snd1 = texture2D(sound, vec2(u * 0.5, 0)).a;\\n float snd2 = texture2D(sound, vec2(u * 0.25, 0)).a;\\n float snd3 = texture2D(sound, vec2(u * 0.125, 0)).a;\\n \\n float s = \\n snd0 * select(grid, 0.) + \\n snd1 * select(grid, 1.) +\\n snd2 * select(grid, 2.) + \\n snd3 * select(grid, 3.) +\\n 0.;\\n \\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x,\\n s * 0.4 + y + GRID_YOFF);\\n gl_Position = vec4(xy, 0, 1);\\n \\n float hue = 1.0;//grid * 0.25;\\n float sat = 1.0;\\n float val = 1.0;\\n \\n if (id < 0.0) {\\n if (vertexId < NUM_PER_DOWN * NUM_GRIDS) {\\n float hgx = mod(vertexId, 2.0);\\n float hgy = mod(floor(vertexId / 2.), GRID_DOWN);\\n float hgId = floor(vertexId / NUM_PER_DOWN);\\n gl_Position = vec4(\\n hgx * 2. - 1.,\\n hgy / (GRID_DOWN - 1.) * 0.4 + \\n (hgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\\n 0.1,\\n 1);\\n \\n hue = 1.0;//hgId * 0.25;\\n sat = 0.0;\\n val = 0.3;\\n } else {\\n float vid = vertexId - NUM_PER_DOWN * NUM_GRIDS;\\n float vgy = mod(vid, 2.0);\\n float vgx = mod(floor(vid / 2.), GRID_ACROSS);\\n float vgId = floor(vid / NUM_PER_ACROSS);\\n gl_Position = vec4(\\n ((vgx / GRID_ACROSS) * 2. - 1.) * pow(2., vgId),\\n vgy * 0.4 + \\n (vgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\\n 0.1,\\n 1);\\n \\n hue = vgId * 0.25;\\n sat = 0.5;\\n val = 0.3;\\n \\n }\\n }\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 6272, + "mode": "LINES", + "sound": "https://soundcloud.com/richarddevine/ts83", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* ⏆ */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nfloat select(float v, float t) {\n return step(t * 0.9, v) * step(v, t * 1.1);\n}\n\nvoid main() {\n float GRID_YOFF = 1./40.;\n float GRID_DOWN = 17.;\n float GRID_ACROSS = 64.0;\n float NUM_PER_DOWN = GRID_DOWN * 2.;\n float NUM_PER_ACROSS = GRID_ACROSS * 2.;\n float NUM_PER_GRID = NUM_PER_DOWN + NUM_PER_ACROSS;\n float NUM_GRIDS = 4.;\n float NUM_GRID_TOTAL = NUM_PER_GRID * NUM_GRIDS;\n float NUM_POINTS = (vertexCount - NUM_GRID_TOTAL) / 4.;\n float NUM_SEGMENTS = NUM_POINTS / 2.;\n \n \n float id = vertexId - NUM_GRID_TOTAL;\n \n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(id, NUM_POINTS) / 2.0) + mod(id, 2.0);\n // line count\n float grid = floor(id / NUM_POINTS);\n\n float u = point / (NUM_SEGMENTS - 1.); // 0 <-> 1 across line\n float v = grid / NUM_GRIDS; // 0 <-> 1 by line\n\n float snd0 = texture2D(sound, vec2(u * 1., 0)).a;\n float snd1 = texture2D(sound, vec2(u * 0.5, 0)).a;\n float snd2 = texture2D(sound, vec2(u * 0.25, 0)).a;\n float snd3 = texture2D(sound, vec2(u * 0.125, 0)).a;\n \n float s = \n snd0 * select(grid, 0.) + \n snd1 * select(grid, 1.) +\n snd2 * select(grid, 2.) + \n snd3 * select(grid, 3.) +\n 0.;\n \n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x,\n s * 0.4 + y + GRID_YOFF);\n gl_Position = vec4(xy, 0, 1);\n \n float hue = 1.0;//grid * 0.25;\n float sat = 1.0;\n float val = 1.0;\n \n if (id < 0.0) {\n if (vertexId < NUM_PER_DOWN * NUM_GRIDS) {\n float hgx = mod(vertexId, 2.0);\n float hgy = mod(floor(vertexId / 2.), GRID_DOWN);\n float hgId = floor(vertexId / NUM_PER_DOWN);\n gl_Position = vec4(\n hgx * 2. - 1.,\n hgy / (GRID_DOWN - 1.) * 0.4 + \n (hgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\n 0.1,\n 1);\n \n hue = 1.0;//hgId * 0.25;\n sat = 0.0;\n val = 0.3;\n } else {\n float vid = vertexId - NUM_PER_DOWN * NUM_GRIDS;\n float vgy = mod(vid, 2.0);\n float vgx = mod(floor(vid / 2.), GRID_ACROSS);\n float vgId = floor(vid / NUM_PER_ACROSS);\n gl_Position = vec4(\n ((vgx / GRID_ACROSS) * 2. - 1.) * pow(2., vgId),\n vgy * 0.4 + \n (vgId / NUM_GRIDS * 2. - 1.) + GRID_YOFF,\n 0.1,\n 1);\n \n hue = vgId * 0.25;\n sat = 0.5;\n val = 0.3;\n \n }\n }\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ucoa0uvtbwv94ow6b-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rybGugSztRdCtGYet/art.json b/art/rybGugSztRdCtGYet/art.json index 1c64fe21..dfb2935b 100644 --- a/art/rybGugSztRdCtGYet/art.json +++ b/art/rybGugSztRdCtGYet/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "geonhwisim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/geonhwisim-digipen?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/taeoxo/gta-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8509803921568627,0.6274509803921569,0.9333333333333333,1],\"shader\":\"// Name: Geonhwi Sim\\n// Assignment Name: Audio Reactive\\n// Course Name: CS250\\n// Term: Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(9.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 5. / 0.2;\\n float sv = abs(v - 0.5) * 3.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 4.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 800.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.5 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/taeoxo/gta-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8509803921568627, + 0.6274509803921569, + 0.9333333333333333, + 1 + ], + "shader": "// Name: Geonhwi Sim\n// Assignment Name: Audio Reactive\n// Course Name: CS250\n// Term: Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(9.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 5. / 0.2;\n float sv = abs(v - 0.5) * 3.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 4.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 800.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.5 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-96mltree65saj1wkk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/rzriAAzqrAiYpiyWX/art.json b/art/rzriAAzqrAiYpiyWX/art.json index 3d127272..91b5457e 100644 --- a/art/rzriAAzqrAiYpiyWX/art.json +++ b/art/rzriAAzqrAiYpiyWX/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/madoxnetwork/vegas?in=jim-ekstroem/sets/club-mix-2022-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Circles from Triangles\\n// CS250 \\n// Spring/2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\nvec2 getCirclePoint(float id, float numCircleSegments){\\n float ux = floor(id/6.) + mod(id,2.);\\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\\n \\n float angle = ux/numCircleSegments * PI*2.;\\n float c =cos(angle);\\n float s =sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n\\treturn vec2(x,y);\\n}\\n\\n\\n\\nvoid main() {\\n \\n \\n float numCircleSegments = float(int((sin(time)*0.5 + 0.5)*10.)/2)*2. + 3.;\\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 12.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount/numPointsPerCircle);\\n \\n float sliceId = floor(vertexId/6.);\\n float oddSlice = mod(sliceId,2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down); \\n \\n float x = mod(circleId,across);\\n float y = floor(circleId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a*(sin(time)*0.1 + 1.2)*1.;\\n \\n //vec2 xy = circleXY*0.1*sc + vec2(ux, vy) * 1.3;\\n \\n float aspect = resolution.x/resolution.y;\\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\\n sc*=20./across;\\n \\n vec4 pos = vec4(circleXY,sin(x)*snd*10.,1);\\n mat4 mat = ident();\\n mat*= scale(vec3(1,aspect,1));\\n mat*= rotZ(time*0.5 + snd*0.8);\\n mat *= trans(vec3(ux,vy,0) *1.5);\\n mat*= rotZ(snd*20.*sign(ux));\\n mat*= uniformScale(0.01*sc);\\n \\n gl_Position = mat*pos;\\n \\n float soff = 0.;//sin(time + x * y * .02) * 5.; \\n\\n float pump = step(0.8, snd);\\n float hue = u * .1 * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;//mix(0., 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue +pump* oddSlice*0.5 + pump*0.33 + snd;\\n val += oddSlice*pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n //background = vec4(0.);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/madoxnetwork/vegas?in=jim-ekstroem/sets/club-mix-2022-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Circles from Triangles\n// CS250 \n// Spring/2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\nvec2 getCirclePoint(float id, float numCircleSegments){\n float ux = floor(id/6.) + mod(id,2.);\n float vy = mod(floor(id/2.) + floor(id/3.),2.);\n \n float angle = ux/numCircleSegments * PI*2.;\n float c =cos(angle);\n float s =sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n\treturn vec2(x,y);\n}\n\n\n\nvoid main() {\n \n \n float numCircleSegments = float(int((sin(time)*0.5 + 0.5)*10.)/2)*2. + 3.;\n vec2 circleXY = getCirclePoint(vertexId,numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 12.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount/numPointsPerCircle);\n \n float sliceId = floor(vertexId/6.);\n float oddSlice = mod(sliceId,2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down); \n \n float x = mod(circleId,across);\n float y = floor(circleId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a*(sin(time)*0.1 + 1.2)*1.;\n \n //vec2 xy = circleXY*0.1*sc + vec2(ux, vy) * 1.3;\n \n float aspect = resolution.x/resolution.y;\n float sc = pow(snd + 0.2,5.)*mix(1.,1.1,oddSlice);\n sc*=20./across;\n \n vec4 pos = vec4(circleXY,sin(x)*snd*10.,1);\n mat4 mat = ident();\n mat*= scale(vec3(1,aspect,1));\n mat*= rotZ(time*0.5 + snd*0.8);\n mat *= trans(vec3(ux,vy,0) *1.5);\n mat*= rotZ(snd*20.*sign(ux));\n mat*= uniformScale(0.01*sc);\n \n gl_Position = mat*pos;\n \n float soff = 0.;//sin(time + x * y * .02) * 5.; \n\n float pump = step(0.8, snd);\n float hue = u * .1 * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;//mix(0., 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue +pump* oddSlice*0.5 + pump*0.33 + snd;\n val += oddSlice*pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n //background = vec4(0.);\n}\n" + }, "screenshotURL": "data/images/images-pul7q4h4trzttl9ht-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/s3bsdzjr5aaq7n4NR/art.json b/art/s3bsdzjr5aaq7n4NR/art.json index 904e3879..b05b56c4 100644 --- a/art/s3bsdzjr5aaq7n4NR/art.json +++ b/art/s3bsdzjr5aaq7n4NR/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "julio", "avatarUrl": "https://lh4.googleusercontent.com/-_qIuSe0i5BM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3re8EYbgzIrdnuAsoVZKmC72bCiiKQ/mo/photo.jpg", - "settings": "{\"num\":27186,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float pointsPerCircle = 42.0;\\n float circleAngle = 20.0;\\n float circlesPerRow = 25.0;\\n float pointsPerRow = pointsPerCircle * circlesPerRow;\\n \\n float vertexIdX = floor(mod(vertexId , pointsPerRow) / pointsPerCircle) * 1.3;\\n float vertexIdY = floor(vertexId / pointsPerRow) * 1.3;\\n \\n float xCircle = floor(vertexId / 2.0);\\n float yCircle = mod(vertexId + 1.0, 2.0);\\n \\n // Radianes de 360 da 2pi\\n float angle = xCircle / circleAngle * radians(360.0);\\n float radius = 1.7 - yCircle;\\n \\n // Movimiento\\n float xOffset = cos(time + vertexIdY * 0.2) * 0.4;\\n float yOffset = cos(time + vertexIdX * 0.2 ) * 0.8;\\n \\n // Se asignan a 4 cuadrantes\\n float uCircle = radius * cos(angle) * 0.3;\\n float vCircle = radius * sin(angle) * 0.3;\\n float uxCircle = uCircle - (circlesPerRow / 2.0) + xOffset;\\n float vyCircle = vCircle - (circlesPerRow / 2.0) + yOffset;\\n \\n vec2 xy = vec2(uxCircle + vertexIdX, vyCircle + vertexIdY) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n v_color = vec4(0.0, 0.7, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 27186, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float pointsPerCircle = 42.0;\n float circleAngle = 20.0;\n float circlesPerRow = 25.0;\n float pointsPerRow = pointsPerCircle * circlesPerRow;\n \n float vertexIdX = floor(mod(vertexId , pointsPerRow) / pointsPerCircle) * 1.3;\n float vertexIdY = floor(vertexId / pointsPerRow) * 1.3;\n \n float xCircle = floor(vertexId / 2.0);\n float yCircle = mod(vertexId + 1.0, 2.0);\n \n // Radianes de 360 da 2pi\n float angle = xCircle / circleAngle * radians(360.0);\n float radius = 1.7 - yCircle;\n \n // Movimiento\n float xOffset = cos(time + vertexIdY * 0.2) * 0.4;\n float yOffset = cos(time + vertexIdX * 0.2 ) * 0.8;\n \n // Se asignan a 4 cuadrantes\n float uCircle = radius * cos(angle) * 0.3;\n float vCircle = radius * sin(angle) * 0.3;\n float uxCircle = uCircle - (circlesPerRow / 2.0) + xOffset;\n float vyCircle = vCircle - (circlesPerRow / 2.0) + yOffset;\n \n vec2 xy = vec2(uxCircle + vertexIdX, vyCircle + vertexIdY) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 1.0;\n v_color = vec4(0.0, 0.7, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-96qi85he4jpb48jb9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/s4PDZP2QnF2WpRZqM/art.json b/art/s4PDZP2QnF2WpRZqM/art.json index 727f3c10..02dee9ef 100644 --- a/art/s4PDZP2QnF2WpRZqM/art.json +++ b/art/s4PDZP2QnF2WpRZqM/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.13725490196078433,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.1) * 0.1;\\n float yoff = sin(time + x * 0.1) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.13725490196078433, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.1) * 0.1;\n float yoff = sin(time + x * 0.1) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-kxrlwty2x206ms12p-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/s5Zxb4iQj8xZjfB5c/art.json b/art/s5Zxb4iQj8xZjfB5c/art.json index 07337a3c..69174b63 100644 --- a/art/s5Zxb4iQj8xZjfB5c/art.json +++ b/art/s5Zxb4iQj8xZjfB5c/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 p = position;//(-resolution + 2.0*uv.xy)/resolution.y;\\n\\tvec2 finalResolution = vec2(across, down);\\n // vec2 p = vec2(x,y);\\n \\n vec2 surfacePosition =vec2(0.);\\n \\n\\tvec2 uv1= (p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t \\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;//gl_FragColor = vec4(col, 1);\\n\\t\\n\\t//gl_FragColor = vec4(vec3(pattern), 1.0);\\n \\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n //camera\\n float r = .9;\\n float tm = time * 0.05;\\n float tm2 = time * 0.05;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 2.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x*v_color.y*v_color.z)/20.;\\n \\n vec4 finalPos = vec4(ux, vy, depth, 1.);\\n \\n gl_Position = mat*finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 p = position;//(-resolution + 2.0*uv.xy)/resolution.y;\n\tvec2 finalResolution = vec2(across, down);\n // vec2 p = vec2(x,y);\n \n vec2 surfacePosition =vec2(0.);\n \n\tvec2 uv1= (p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t \n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;//gl_FragColor = vec4(col, 1);\n\t\n\t//gl_FragColor = vec4(vec3(pattern), 1.0);\n \n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n //camera\n float r = .9;\n float tm = time * 0.05;\n float tm2 = time * 0.05;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 2.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x*v_color.y*v_color.z)/20.;\n \n vec4 finalPos = vec4(ux, vy, depth, 1.);\n \n gl_Position = mat*finalPos;\n}" + }, "screenshotURL": "data/images/images-n5gdk8jx6rbpegbt0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/s5eywpAoRQGmsD8Dq/art.json b/art/s5eywpAoRQGmsD8Dq/art.json index e4d45e23..2aaec296 100644 --- a/art/s5eywpAoRQGmsD8Dq/art.json +++ b/art/s5eywpAoRQGmsD8Dq/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "yejin-shin", "avatarUrl": "https://avatars.githubusercontent.com/yejin-shin?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-9014704/baby-hotline-extended-jack-stauber\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7254901960784313,0.8392156862745098,0.8941176470588236,1],\"shader\":\"//Name : Yejin Shin\\n//Assignment : Vertexshaderart - Motion\\n//Course : CS250\\n//Spring, 2023\\n\\n\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n\\tfloat across = floor(vertexCount / down);\\n\\n\\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId/ across);\\n\\n\\tfloat u = x / (across - 1.);\\n\\tfloat v = y / (across - 1.);\\n\\n\\tfloat xoff = cos(time + y * 0.3) * 0.5;\\n\\tfloat yoff = cos(time + y * 0.3) * 0.2;\\n\\n\\tfloat ux = u * 2. -1. + xoff;\\n\\tfloat vy = v * 2. -1. + yoff;\\n\\n\\tvec2 xy = vec2(ux, vy) * 1.3;\\n\\t\\n \\tgl_Position = vec4(xy, 0, 1);\\n\\n\\t\\n\\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n\\n\\tgl_PointSize = 25.0 * soff;\\n\\tgl_PointSize *= 20. / across;\\n\\tgl_PointSize *= resolution.x / 600.;\\n\\n\\tv_color = vec4(0.178, 0.221, 0.239, 0.5);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-9014704/baby-hotline-extended-jack-stauber", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7254901960784313, + 0.8392156862745098, + 0.8941176470588236, + 1 + ], + "shader": "//Name : Yejin Shin\n//Assignment : Vertexshaderart - Motion\n//Course : CS250\n//Spring, 2023\n\n\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n\tfloat across = floor(vertexCount / down);\n\n\tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId/ across);\n\n\tfloat u = x / (across - 1.);\n\tfloat v = y / (across - 1.);\n\n\tfloat xoff = cos(time + y * 0.3) * 0.5;\n\tfloat yoff = cos(time + y * 0.3) * 0.2;\n\n\tfloat ux = u * 2. -1. + xoff;\n\tfloat vy = v * 2. -1. + yoff;\n\n\tvec2 xy = vec2(ux, vy) * 1.3;\n\t\n \tgl_Position = vec4(xy, 0, 1);\n\n\t\n\tfloat soff = sin(time + x * y * 0.02) * 5.;\n\n\tgl_PointSize = 25.0 * soff;\n\tgl_PointSize *= 20. / across;\n\tgl_PointSize *= resolution.x / 600.;\n\n\tv_color = vec4(0.178, 0.221, 0.239, 0.5);\n}" + }, "screenshotURL": "data/images/images-dtyeph272ulndv87z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/s62zTw9wPkh2irNpz/art.json b/art/s62zTw9wPkh2irNpz/art.json index 2f53a5e9..026dba37 100644 --- a/art/s62zTw9wPkh2irNpz/art.json +++ b/art/s62zTw9wPkh2irNpz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3176470588235294,0.03529411764705882,0.21176470588235294,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 5.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 18.0;\\n float braids = 20.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3176470588235294, + 0.03529411764705882, + 0.21176470588235294, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 5.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 18.0;\n float braids = 20.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-wgdyzlw6vz0q335i8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/s7zehgnGsLh5aHkM8/art.json b/art/s7zehgnGsLh5aHkM8/art.json index bc03488c..84bc9822 100644 --- a/art/s7zehgnGsLh5aHkM8/art.json +++ b/art/s7zehgnGsLh5aHkM8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/vlokken-rorschach-drumcomplex-remix-complexed-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nYea I know I need to sort it but I'm lazy :P\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getQuadPoint(const float inId, out vec3 pos) {\\n float id = mod(inId, 6.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n pos = vec3(ux, 0, vy);\\n}\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float quadsPerAxis = floor(numQuads / 3.);\\n float unitsPer = floor(pow(quadsPerAxis, 1. / 3.));\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, unitsPer);\\n float qy = mod(floor(quadId / unitsPer), unitsPer);\\n float qz = mod(floor(quadId / unitsPer / unitsPer), unitsPer);\\n \\n float axisId = floor(quadId / quadsPerAxis);\\n \\n vec3 pos;\\n getQuadPoint(vertexId, pos);\\n \\n float qu = qx / (unitsPer - 1.);\\n float qv = qy / (unitsPer - 1.);\\n float qw = qz / (unitsPer - 1.);\\n \\n float qa = qu * 2. - 1.;\\n float qb = qv * 2. - 1.;\\n float qc = qw * 2. - 1.;\\n \\n float v = length(vec3(qa, qb, qc)) * .2;\\n float s = texture2D(sound, vec2(qb * 0.2, v)).a;\\n \\n float r = unitsPer * 1.3;\\n float ctime = time * 0.1;\\n vec3 eye = vec3(sin(ctime) * r, r + sin(ctime * 0.717) * r * 0.5, r);\\n vec3 target = vec3(0); //vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(40. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n\\n mat *= rotZ(axisId * PI * 0.5);\\n mat *= rotY(step(1.5, axisId) * PI * 0.5);\\n mat *= trans(vec3(qx, qy, qz) - vec3(unitsPer, unitsPer, unitsPer) * 0.5);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * 0.1 + v + s * .2;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(s, 6.));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/vlokken-rorschach-drumcomplex-remix-complexed-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nYea I know I need to sort it but I'm lazy :P\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getQuadPoint(const float inId, out vec3 pos) {\n float id = mod(inId, 6.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n pos = vec3(ux, 0, vy);\n}\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float quadsPerAxis = floor(numQuads / 3.);\n float unitsPer = floor(pow(quadsPerAxis, 1. / 3.));\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, unitsPer);\n float qy = mod(floor(quadId / unitsPer), unitsPer);\n float qz = mod(floor(quadId / unitsPer / unitsPer), unitsPer);\n \n float axisId = floor(quadId / quadsPerAxis);\n \n vec3 pos;\n getQuadPoint(vertexId, pos);\n \n float qu = qx / (unitsPer - 1.);\n float qv = qy / (unitsPer - 1.);\n float qw = qz / (unitsPer - 1.);\n \n float qa = qu * 2. - 1.;\n float qb = qv * 2. - 1.;\n float qc = qw * 2. - 1.;\n \n float v = length(vec3(qa, qb, qc)) * .2;\n float s = texture2D(sound, vec2(qb * 0.2, v)).a;\n \n float r = unitsPer * 1.3;\n float ctime = time * 0.1;\n vec3 eye = vec3(sin(ctime) * r, r + sin(ctime * 0.717) * r * 0.5, r);\n vec3 target = vec3(0); //vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(40. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n\n mat *= rotZ(axisId * PI * 0.5);\n mat *= rotY(step(1.5, axisId) * PI * 0.5);\n mat *= trans(vec3(qx, qy, qz) - vec3(unitsPer, unitsPer, unitsPer) * 0.5);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * 0.1 + v + s * .2;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), pow(s, 6.));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-5haeru13b75d6vkpy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/s8eghqEX2KWmXy2BZ/art.json b/art/s8eghqEX2KWmXy2BZ/art.json index 8dd8f466..9fb3fe82 100644 --- a/art/s8eghqEX2KWmXy2BZ/art.json +++ b/art/s8eghqEX2KWmXy2BZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jorenvo", "avatarUrl": "https://avatars.githubusercontent.com/jorenvo?s=200", - "settings": "{\"num\":2585,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/rattpack-radio/logic-stewie-griffin\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// from https://www.laurivan.com/rgb-to-hsv-to-rgb-for-shaders/\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat norm_sin(float x) {\\n \\treturn (sin(x) + 1.) / 2.;\\n}\\n\\nvoid main() {\\n float size = floor(sqrt(vertexCount));\\n vec2 c = vec2(mod(vertexId, size),\\n floor(vertexId / size));\\n \\n float xoff = sin(time + c.y * 0.3) * .1;\\n float yoff = sin(time + c.x * 0.2) * .1;\\n \\n const int amt_samples = 8;\\n float avg_volume = 0.;\\n for(int i = 0; i < amt_samples; i++) { \\n \\tavg_volume += texture2D(volume, vec2(i, 0)).a; \\n }\\n avg_volume /= float(amt_samples);\\n \\n float m = 100.;\\n float soff = pow(avg_volume * m, 4.) / pow(m, 4.) * 42.;//avg_volume * 42.;\\n\\n vec3 color = vec3(norm_sin(time + c.x / .1 + c.y / .1), 1, 1);\\n \\n // divide by the maximum to normalize to [0, 1]\\n float normalizer_x = size - 1.0;\\n float normalizer_y = floor((vertexCount - 1.0) / size);\\n c /= vec2(normalizer_x, normalizer_y);\\n \\n // go from [0,1] -> [0,2]\\n c *= 2.0;\\n \\n // go from [0,2] -> [-1, 1]\\n c -= 1.0;\\n \\n c += vec2(xoff, yoff);\\n \\n c *= 1.2;\\n \\n gl_Position = vec4(c, 0, 1);\\n \\n float point_size_scale = 16.0 / size;\\n gl_PointSize = 2. + soff;\\n gl_PointSize *= point_size_scale;\\n v_color = vec4(hsv2rgb(color), 1);\\n}\"}", + "settings": { + "num": 2585, + "mode": "POINTS", + "sound": "https://soundcloud.com/rattpack-radio/logic-stewie-griffin", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// from https://www.laurivan.com/rgb-to-hsv-to-rgb-for-shaders/\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat norm_sin(float x) {\n \treturn (sin(x) + 1.) / 2.;\n}\n\nvoid main() {\n float size = floor(sqrt(vertexCount));\n vec2 c = vec2(mod(vertexId, size),\n floor(vertexId / size));\n \n float xoff = sin(time + c.y * 0.3) * .1;\n float yoff = sin(time + c.x * 0.2) * .1;\n \n const int amt_samples = 8;\n float avg_volume = 0.;\n for(int i = 0; i < amt_samples; i++) { \n \tavg_volume += texture2D(volume, vec2(i, 0)).a; \n }\n avg_volume /= float(amt_samples);\n \n float m = 100.;\n float soff = pow(avg_volume * m, 4.) / pow(m, 4.) * 42.;//avg_volume * 42.;\n\n vec3 color = vec3(norm_sin(time + c.x / .1 + c.y / .1), 1, 1);\n \n // divide by the maximum to normalize to [0, 1]\n float normalizer_x = size - 1.0;\n float normalizer_y = floor((vertexCount - 1.0) / size);\n c /= vec2(normalizer_x, normalizer_y);\n \n // go from [0,1] -> [0,2]\n c *= 2.0;\n \n // go from [0,2] -> [-1, 1]\n c -= 1.0;\n \n c += vec2(xoff, yoff);\n \n c *= 1.2;\n \n gl_Position = vec4(c, 0, 1);\n \n float point_size_scale = 16.0 / size;\n gl_PointSize = 2. + soff;\n gl_PointSize *= point_size_scale;\n v_color = vec4(hsv2rgb(color), 1);\n}" + }, "screenshotURL": "data/images/images-am5gl9h4hy5y9t81t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/s8fhTKeFZujEYyKJi/art.json b/art/s8fhTKeFZujEYyKJi/art.json index 63bc26e4..8764d60d 100644 --- a/art/s8fhTKeFZujEYyKJi/art.json +++ b/art/s8fhTKeFZujEYyKJi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":2,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec2 field(vec2 pos) {\\n // just for easier readability\\n float x = pos.x;\\n float y = pos.y;\\n \\n // vector field mapping\\n return vec2(\\n\\n -y,\\n x\\n );\\n}\\n\\nvoid main() {\\n // mouse position is the droplets position in this example\\n gl_Position = vec4(mouse.x, mouse.y, 0,1);\\n \\n // apply vector field to the next point\\n // to demonstrate effect of vector field\\n if (vertexId == 1.) {\\n vec2 d = field(mouse.xy);\\n d = normalize(d);\\n gl_Position += vec4(d.x, d.y, 0,1);\\n }\\n \\n gl_PointSize = vertexId * 4.;\\n v_color = vec4(1.0 - vertexId,1,1,1);\\n}\"}", + "settings": { + "num": 2, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec2 field(vec2 pos) {\n // just for easier readability\n float x = pos.x;\n float y = pos.y;\n \n // vector field mapping\n return vec2(\n\n -y,\n x\n );\n}\n\nvoid main() {\n // mouse position is the droplets position in this example\n gl_Position = vec4(mouse.x, mouse.y, 0,1);\n \n // apply vector field to the next point\n // to demonstrate effect of vector field\n if (vertexId == 1.) {\n vec2 d = field(mouse.xy);\n d = normalize(d);\n gl_Position += vec4(d.x, d.y, 0,1);\n }\n \n gl_PointSize = vertexId * 4.;\n v_color = vec4(1.0 - vertexId,1,1,1);\n}" + }, "screenshotURL": "data/images/images-lsegf533xf05n5bgu-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/s9xXnsxy4wkR3kkSc/art.json b/art/s9xXnsxy4wkR3kkSc/art.json index 722d456d..c7ecfb6d 100644 --- a/art/s9xXnsxy4wkR3kkSc/art.json +++ b/art/s9xXnsxy4wkR3kkSc/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":99840,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/satoshiimano/fizzy-life-satoshiimano\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.14901960784313725,0.011764705882352941,1],\"shader\":\"/*\\n\\n \\n _ _ _ _ \\n _ _ ___ ___| |_ ___ _ _ ___| |_ ___ _| |___ ___ ___ ___| |_ \\n| | | -_| _| _| -_|_'_|_ -| | .'| . | -_| _| .'| _| _|\\n \\\\_/|___|_| |_| |___|_,_|___|_|_|__,|___|___|_| |__,|_| |_| \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat hashp(float p) {\\n return m1p1(hash(p));\\n}\\n\\n\\n#define SEGS 16.\\nvoid main() {\\n float pointsPerSphere = SEGS * (SEGS * 0.5) * 6.;\\n float pointsPerPair = pointsPerSphere * 2.;\\n float sphereId = floor(vertexId / pointsPerSphere);\\n float pairId = floor(vertexId / pointsPerPair);\\n float numPairs = floor(vertexCount / pointsPerPair);\\n float su = pairId / numPairs;\\n \\n float v = mod(vertexId, pointsPerSphere);\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, SEGS);\\n v = (v-a1)/SEGS;\\n float a2 = v-(SEGS / 4.);\\n \\n float a1n = (a1+.5)/SEGS*2.*PI;\\n float a2n = (a2+.5)/SEGS*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/SEGS*2.*PI;\\n a2 = a2/SEGS*2.*PI;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n\\n /*\\n float t = time * 0.1;\\n pos.xz *= mat2(cos(t),sin(t),-sin(t),cos(t));\\n pos.yz *= mat2(cos(t),sin(t),-sin(t),cos(t));\\n norm.xz *= mat2(cos(t),sin(t),-sin(t),cos(t));\\n norm.yz *= mat2(cos(t),sin(t),-sin(t),cos(t));\\n */\\n \\n float light = 0.5 + 0.5 * dot(norm, normalize(vec3(1.1, 2.0, -2.0)));\\n float snd0 = texture2D(sound, vec2(su * 0.2, 0.0)).a;\\n /*\\n #define NUM_SAMPLES 8\\n float csnd = 0.;\\n for (int i = 0; i < NUM_SAMPLES; ++i) {\\n csnd += texture2D(sound, vec2(0.05, float(i) / float(NUM_SAMPLES) * 0.1)).a;\\n }\\n csnd /= float(NUM_SAMPLES);\\n */\\n float csnd = 0.;\\n float cangle = time * m1p1(hash(pairId)) * 2. + csnd * PI * 2.;\\n float c = cos(cangle);\\n float s = sin(cangle);\\n float r = 2.;\\n vec3 cameraPos = vec3(c * r, 1.* sin(time * 0.57), s * r);\\n vec3 cameraTarget = vec3(0, 0, 0);\\n vec3 cameraUp = vec3(0, 1, 0);\\n float back = 1. - mod(sphereId, 2.);\\n vec3 center = vec3(hashp(pairId * 0.43), hashp(pairId * 1.39), hashp(pairId * 2.11));\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 cam = lookAt(cameraPos, cameraTarget, cameraUp);\\n mat4 m = persp(radians(45.), aspect, 0.1, 100.);\\n m *= inverse(cam);\\n m *= trans(center);\\n m *= uniformScale(mix(0.25, 0.6, hash(pairId * 0.37)) * pow(snd0, 2.)) ;\\n \\n vec4 cp = m * vec4(pos, 1);\\n \\n vec4 cn = m * vec4(center, 1);\\n vec2 cclip = (cn / cn.w).xy;\\n vec2 eclip = (cp / cp.w).xy;\\n vec2 dir = normalize(eclip - cclip) / vec2(aspect, 1) * back;\\n \\n gl_Position = vec4(eclip + dir * 0.04, back * 0.1, 1);\\n \\n \\n float hue = mix(0.55, 0.65, hash(pairId));\\n float sat = mix(0.4, 0.7, hash(pairId * 6.131));\\n float val = light;\\n v_color = vec4(\\n mix(vec3(1), vec3(0), step(0.5, back)), 1);\\n}\"}", + "settings": { + "num": 99840, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/satoshiimano/fizzy-life-satoshiimano", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.14901960784313725, + 0.011764705882352941, + 1 + ], + "shader": "/*\n\n \n _ _ _ _ \n _ _ ___ ___| |_ ___ _ _ ___| |_ ___ _| |___ ___ ___ ___| |_ \n| | | -_| _| _| -_|_'_|_ -| | .'| . | -_| _| .'| _| _|\n \\_/|___|_| |_| |___|_,_|___|_|_|__,|___|___|_| |__,|_| |_| \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat hashp(float p) {\n return m1p1(hash(p));\n}\n\n\n#define SEGS 16.\nvoid main() {\n float pointsPerSphere = SEGS * (SEGS * 0.5) * 6.;\n float pointsPerPair = pointsPerSphere * 2.;\n float sphereId = floor(vertexId / pointsPerSphere);\n float pairId = floor(vertexId / pointsPerPair);\n float numPairs = floor(vertexCount / pointsPerPair);\n float su = pairId / numPairs;\n \n float v = mod(vertexId, pointsPerSphere);\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, SEGS);\n v = (v-a1)/SEGS;\n float a2 = v-(SEGS / 4.);\n \n float a1n = (a1+.5)/SEGS*2.*PI;\n float a2n = (a2+.5)/SEGS*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/SEGS*2.*PI;\n a2 = a2/SEGS*2.*PI;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n\n /*\n float t = time * 0.1;\n pos.xz *= mat2(cos(t),sin(t),-sin(t),cos(t));\n pos.yz *= mat2(cos(t),sin(t),-sin(t),cos(t));\n norm.xz *= mat2(cos(t),sin(t),-sin(t),cos(t));\n norm.yz *= mat2(cos(t),sin(t),-sin(t),cos(t));\n */\n \n float light = 0.5 + 0.5 * dot(norm, normalize(vec3(1.1, 2.0, -2.0)));\n float snd0 = texture2D(sound, vec2(su * 0.2, 0.0)).a;\n /*\n #define NUM_SAMPLES 8\n float csnd = 0.;\n for (int i = 0; i < NUM_SAMPLES; ++i) {\n csnd += texture2D(sound, vec2(0.05, float(i) / float(NUM_SAMPLES) * 0.1)).a;\n }\n csnd /= float(NUM_SAMPLES);\n */\n float csnd = 0.;\n float cangle = time * m1p1(hash(pairId)) * 2. + csnd * PI * 2.;\n float c = cos(cangle);\n float s = sin(cangle);\n float r = 2.;\n vec3 cameraPos = vec3(c * r, 1.* sin(time * 0.57), s * r);\n vec3 cameraTarget = vec3(0, 0, 0);\n vec3 cameraUp = vec3(0, 1, 0);\n float back = 1. - mod(sphereId, 2.);\n vec3 center = vec3(hashp(pairId * 0.43), hashp(pairId * 1.39), hashp(pairId * 2.11));\n \n float aspect = resolution.x / resolution.y;\n mat4 cam = lookAt(cameraPos, cameraTarget, cameraUp);\n mat4 m = persp(radians(45.), aspect, 0.1, 100.);\n m *= inverse(cam);\n m *= trans(center);\n m *= uniformScale(mix(0.25, 0.6, hash(pairId * 0.37)) * pow(snd0, 2.)) ;\n \n vec4 cp = m * vec4(pos, 1);\n \n vec4 cn = m * vec4(center, 1);\n vec2 cclip = (cn / cn.w).xy;\n vec2 eclip = (cp / cp.w).xy;\n vec2 dir = normalize(eclip - cclip) / vec2(aspect, 1) * back;\n \n gl_Position = vec4(eclip + dir * 0.04, back * 0.1, 1);\n \n \n float hue = mix(0.55, 0.65, hash(pairId));\n float sat = mix(0.4, 0.7, hash(pairId * 6.131));\n float val = light;\n v_color = vec4(\n mix(vec3(1), vec3(0), step(0.5, back)), 1);\n}" + }, "screenshotURL": "data/images/images-wf3ynpo84zmn6hf0r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sA2GkcNB7H2biaXxg/art.json b/art/sA2GkcNB7H2biaXxg/art.json index d59c3081..d0ff0756 100644 --- a/art/sA2GkcNB7H2biaXxg/art.json +++ b/art/sA2GkcNB7H2biaXxg/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":85391,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/gscottcorey/sets/amphibian?si=41cf35a9260c4e2db7672d59451e9277\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.93) +\\n sin(t*0.311+i) +\\n sin(t*0.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*0.4+i*1.393-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.653-2.1) +\\n sin(t*0.311+i*1.1-2.1) +\\n sin(t*0.4+i*1.23+9.1) +\\n sin(t*0.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*1900.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .07;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-89))*.3+.7,1);\\n}\"}", + "settings": { + "num": 85391, + "mode": "POINTS", + "sound": "https://soundcloud.com/gscottcorey/sets/amphibian?si=41cf35a9260c4e2db7672d59451e9277", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.93) +\n sin(t*0.311+i) +\n sin(t*0.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*0.4+i*1.393-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.653-2.1) +\n sin(t*0.311+i*1.1-2.1) +\n sin(t*0.4+i*1.23+9.1) +\n sin(t*0.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*1900.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .07;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-89))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-io3g46f2mpkzk58ao-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sBRAzLRKmk8gYkZgz/art.json b/art/sBRAzLRKmk8gYkZgz/art.json index 6511b77d..4d5afd76 100644 --- a/art/sBRAzLRKmk8gYkZgz/art.json +++ b/art/sBRAzLRKmk8gYkZgz/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "jimhanks", "avatarUrl": "https://secure.gravatar.com/avatar/2bf167068c2de88c2a8119b5403a900b?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I will polygonize this in my next code\\n\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n float spd = 0.3;\\n float tm = time * spd;\\n c = sin(sin(pos.x) + sin(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\\n gl_PointSize = 24.0;\\n\\n \\n v_color = vec4(0.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I will polygonize this in my next code\n\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n float spd = 0.3;\n float tm = time * spd;\n c = sin(sin(pos.x) + sin(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px+0.5, py) * 4.0)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y + c * 0.15) / py, 0.0, 1);\n gl_PointSize = 24.0;\n\n \n v_color = vec4(0.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-52i6jl5th21rr1fb2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sBgC7apPnFmiA6GQ8/art.json b/art/sBgC7apPnFmiA6GQ8/art.json index cca7b311..5dc50fd4 100644 --- a/art/sBgC7apPnFmiA6GQ8/art.json +++ b/art/sBgC7apPnFmiA6GQ8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":15000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=40000\\n//KBackGroundColor=vec3(0.,0.,0.);\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>30.\\n#define parameter1 1.1//KParameter1 0.>>1.\\n#define parameter2 0.1//KParameter2 0.>>1.\\n#define parameter3 0.5//KParameter3 0.>>0.5\\n#define parameter4 0.//KParameter4 0.>>1.\\n#define parameter5 0.//KParameter5 0.>>1.\\n#define parameter6 0.//KParameter6 0.>>1.\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nvoid main() {\\n \\n float symCount = 6.;\\n float shapeVertexCount = vertexCount/symCount;\\n \\n float fVertexId = mod(vertexId,shapeVertexCount);\\n \\n float point = mod(floor(fVertexId / 2.0) + mod(fVertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(fVertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n \\n float shapeId = floor(vertexId/shapeVertexCount);\\n \\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //rotation for the shape\\n \\n mat4 rotz = rotZ(2.*PI/symCount);\\n gl_Position.x += shapeId/symCount*2.5 - 1.;\\n \\n \\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(0, b, b, 1);\\n}\"}", + "settings": { + "num": 15000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\n\n//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=40000\n//KBackGroundColor=vec3(0.,0.,0.);\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>30.\n#define parameter1 1.1//KParameter1 0.>>1.\n#define parameter2 0.1//KParameter2 0.>>1.\n#define parameter3 0.5//KParameter3 0.>>0.5\n#define parameter4 0.//KParameter4 0.>>1.\n#define parameter5 0.//KParameter5 0.>>1.\n#define parameter6 0.//KParameter6 0.>>1.\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nvoid main() {\n \n float symCount = 6.;\n float shapeVertexCount = vertexCount/symCount;\n \n float fVertexId = mod(vertexId,shapeVertexCount);\n \n float point = mod(floor(fVertexId / 2.0) + mod(fVertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(fVertexId / NUM_POINTS);\n float offset = count * sin(time * 0.001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \n vec2 xy = vec2(\n oC + c,\n oS + s);\n \n float shapeId = floor(vertexId/shapeVertexCount);\n \n gl_Position = vec4(xy * aspect, 0, 1);\n\n //rotation for the shape\n \n mat4 rotz = rotZ(2.*PI/symCount);\n gl_Position.x += shapeId/symCount*2.5 - 1.;\n \n \n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(0, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-du7dpk8rydqkoo9cj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sCPDNvuYTdioSKHL7/art.json b/art/sCPDNvuYTdioSKHL7/art.json index 42747043..6f862081 100644 --- a/art/sCPDNvuYTdioSKHL7/art.json +++ b/art/sCPDNvuYTdioSKHL7/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":4486,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"vec2 getCirclePoint(float id, float segments)\\n{\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n \\n float angle = ux / segments * radians(180.0) * 2.0;\\n float radius = vy + 1.0;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n return vec2(x, y);\\n}\\n\\nvoid main()\\n{\\n float numSegments = 20.0;\\n float pointsPerCircle = numSegments * 6.0;\\n float circleId = floor(vertexId / pointsPerCircle);\\n float circleCount = floor(vertexCount / pointsPerCircle);\\n \\n float width = floor(sqrt(circleCount));\\n \\n float x = mod(circleId, width); // [0, width - 1]\\n float y = floor(circleId / width); // [0, 00]\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = cos(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1 + vec2(ux, vy);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 4486, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "vec2 getCirclePoint(float id, float segments)\n{\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n \n float angle = ux / segments * radians(180.0) * 2.0;\n float radius = vy + 1.0;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n return vec2(x, y);\n}\n\nvoid main()\n{\n float numSegments = 20.0;\n float pointsPerCircle = numSegments * 6.0;\n float circleId = floor(vertexId / pointsPerCircle);\n float circleCount = floor(vertexCount / pointsPerCircle);\n \n float width = floor(sqrt(circleCount));\n \n float x = mod(circleId, width); // [0, width - 1]\n float y = floor(circleId / width); // [0, 00]\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = cos(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n vec2 xy = getCirclePoint(vertexId, numSegments) * 0.1 + vec2(ux, vy);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-nj471udiz713u6twm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sEDKEFtcGxZoxbis8/art.json b/art/sEDKEFtcGxZoxbis8/art.json index 6b41b70e..69ee663d 100644 --- a/art/sEDKEFtcGxZoxbis8/art.json +++ b/art/sEDKEFtcGxZoxbis8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Kdrawmode=GL_TRIANGLES\\n\\nvec3 gSunColor = vec3(1.0, 0.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(-2.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -20.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\\n // \\tvec3 vCameraUp = vec3( 0, 0, 1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Kdrawmode=GL_TRIANGLES\n\nvec3 gSunColor = vec3(1.0, 0.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(-2.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -20.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( sin(ca), 0, cos(ca) );\n // \tvec3 vCameraUp = vec3( 0, 0, 1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-jqv31s11csws8yo8t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sESZsypGtXcTsaupL/art.json b/art/sESZsypGtXcTsaupL/art.json index 0e7595d2..15e67908 100644 --- a/art/sESZsypGtXcTsaupL/art.json +++ b/art/sESZsypGtXcTsaupL/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sunwoo.lee", "avatarUrl": "https://secure.gravatar.com/avatar/847e0aa72622f450daec2296ed8fe915?default=retro&size=200", - "settings": "{\"num\":30000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thomashayden/genie\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// // Name: sunwoo.lee\\n// // Assignment name: Audio Reactive\\n// // Course name: CS250\\n// // Term: 2022 Spring\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux,vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su,sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(mix(0.25, 0.125, au), av * 0.5)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd+0.3, 2.5) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.6,snd);\\n float hue = u * 0.1 + pump * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\\n float sat = mix(0.0, 1.0, pump); //1.0 - av;\\n float val = mix(0.1, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 30000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thomashayden/genie", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// // Name: sunwoo.lee\n// // Assignment name: Audio Reactive\n// // Course name: CS250\n// // Term: 2022 Spring\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux,vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su,sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(mix(0.25, 0.125, au), av * 0.5)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd+0.3, 2.5) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.6,snd);\n float hue = u * 0.1 + pump * 0.2 + time * 0.1;//sin(time + v*20.0) * 0.05;\n float sat = mix(0.0, 1.0, pump); //1.0 - av;\n float val = mix(0.1, pow(snd+0.2 ,5.), pump);//sin(time + v*u*20.0)*0.5+0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-c3pk1ep2tt8aeict7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sEkj67PRA2wdoH6n2/art.json b/art/sEkj67PRA2wdoH6n2/art.json index 27717e35..b72ef0bf 100644 --- a/art/sEkj67PRA2wdoH6n2/art.json +++ b/art/sEkj67PRA2wdoH6n2/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "adrian", "avatarUrl": "https://lh4.googleusercontent.com/-CON_gtaPLEk/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckwQ_DJdsWRL_4u4UUPfQOEug7jtA/photo.jpg", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2549019607843137,0.2627450980392157,0.4627450980392157,1],\"shader\":\"\\nvoid main() {\\n \\n float across = 10.0;\\n \\n // vertexId = 0, 1, 2, 3, 4, ..., 10, 11, 12, ...\\n \\n // float x = vertexId / 10.0;\\n // x = 0.0, 0.1, 0.2, 0.3, 0.4, ..., 1.0, 1.1, 1.2, ...\\n \\n // float x = mod(vertexId, 10.0);\\n // x = 0, 1, 2, 3, 4, ..., 0, 1, 2, ...\\n \\n // float y = floor(vertexId / 10.0);\\n // when vertexId is in [0,9], y = 0;\\n // when vertexId is in [10, 19], y = 1;\\n // when vertexId is in [20, 29], y = 2;\\n // ...\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n // u = 0.0, 0.1, 0.2, 0.3, 0.4, ... 0.0, 0.1, 0.2, ...\\n float u = x / across;\\n float v = y / across;\\n \\n // move u and v to center \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2549019607843137, + 0.2627450980392157, + 0.4627450980392157, + 1 + ], + "shader": "\nvoid main() {\n \n float across = 10.0;\n \n // vertexId = 0, 1, 2, 3, 4, ..., 10, 11, 12, ...\n \n // float x = vertexId / 10.0;\n // x = 0.0, 0.1, 0.2, 0.3, 0.4, ..., 1.0, 1.1, 1.2, ...\n \n // float x = mod(vertexId, 10.0);\n // x = 0, 1, 2, 3, 4, ..., 0, 1, 2, ...\n \n // float y = floor(vertexId / 10.0);\n // when vertexId is in [0,9], y = 0;\n // when vertexId is in [10, 19], y = 1;\n // when vertexId is in [20, 29], y = 2;\n // ...\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n // u = 0.0, 0.1, 0.2, 0.3, 0.4, ... 0.0, 0.1, 0.2, ...\n float u = x / across;\n float v = y / across;\n \n // move u and v to center \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n \n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-bsd7pb131qhbcoa5z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sEwzQPsXsfiFvkjuQ/art.json b/art/sEwzQPsXsfiFvkjuQ/art.json index 976f6d62..865f86be 100644 --- a/art/sEwzQPsXsfiFvkjuQ/art.json +++ b/art/sEwzQPsXsfiFvkjuQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/okokko/harpoons-and-frittatas\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 16.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * 4.), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * 4.), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * 1.4;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n// normal.xz *= rotateX;\\n// normal.yz *= rotateY;\\n \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -1.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/okokko/harpoons-and-frittatas", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 16.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * 4.), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * 4.), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * 1.4;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx), -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my), -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz), -sin(mz), sin(mz), cos(mz));\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n// normal.xz *= rotateX;\n// normal.yz *= rotateY;\n \n\n \n float screenZ = -0.;\n float eyeZ = -1.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}\n" + }, "screenshotURL": "data/images/images-uirq4fkgq9n8chsew-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sFMa3xreof2dhgyS2/art.json b/art/sFMa3xreof2dhgyS2/art.json index adf196c2..83c58c0b 100644 --- a/art/sFMa3xreof2dhgyS2/art.json +++ b/art/sFMa3xreof2dhgyS2/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/guigoo-official/acido\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"const int maxIter = 50;\\nfloat df(vec3 p, float power) {\\n vec3 z = p;\\n float r = 0.0;\\n float dr = 1.0;\\n for(int i = 0; i < maxIter; i++) {\\n r = length(z);\\n if(r > 100.0) break;\\n \\n float theta = acos(z.z/r);\\n float phi = atan(z.y, z.x);\\n \\n dr = power*pow(r, power-1.0)*dr + 1.0;\\n \\n r = pow(r, power);\\n theta *= power;\\n phi *= power;\\n \\n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\\n z += p;\\n }\\n return 0.5*log(r)*r/dr;\\n}\\n\\n\\nstruct Ray {\\n bool hit;\\n vec3 hitPos;\\n float t;\\n int steps;\\n};\\nconst int maxSteps = 50;\\nRay trace(vec3 camPos, vec3 rayDir) {\\n vec3 p = vec3(0);\\n float t = 0.0; \\n int steps = 0;\\n bool hit = false;\\n for(int i = 0; i < maxSteps; i++) {\\n p = camPos + t*rayDir;\\n float d = df(p, 8.0*abs(sin(0.5*time)) + 1.0);\\n if(d < 0.001) {\\n hit = true;\\n steps = i;\\n break;\\n }\\n t += d*0.9;\\n }\\n return Ray(hit, p, t, steps);\\n}\\n\\n\\nvec3 shading(Ray tr) {\\n if(tr.hit) {\\n \\treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\\n }\\n else {\\n return vec3(0);\\n }\\n}\\n\\n\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n //we want to keep the resolution.xresolution.y ratio\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //deduce from finalMaxVertexCount the number of possible lines with the given across\\n float down = floor(finalMaxVertexCount / across);\\n \\n //Now we have the across and down number of elements, we can now calculate the final number of vertices\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n\\n \\n //vec2 fragCoord = vec2(ux,vy);\\n \\n //apply fragment logic\\n\\n\\t//vec2 fragCoord = vec2(ux,vy);\\n \\n\\tvec2 iResolution = vec2(across, down);\\n float iTime = time;\\n \\n\\t//vec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\\n \\n vec2 uv = vec2(u,v);\\n \\n //vec3 camPos = vec3(-2, 0, 0);\\n vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\\n vec3 camFront = normalize(-camPos);\\n vec3 camUp = vec3(0, 1, 0);\\n vec3 camRight = cross(camFront, camUp);\\n float focus = 1.0;\\n \\n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\\n Ray tr = trace(camPos, rayDir);\\n \\n\\t//fragColor = vec4(shading(tr), 1.0);\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(shading(tr), 1.0);\\n \\n //v_color = vec4(1.,1.,1.,1.);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/guigoo-official/acido", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "const int maxIter = 50;\nfloat df(vec3 p, float power) {\n vec3 z = p;\n float r = 0.0;\n float dr = 1.0;\n for(int i = 0; i < maxIter; i++) {\n r = length(z);\n if(r > 100.0) break;\n \n float theta = acos(z.z/r);\n float phi = atan(z.y, z.x);\n \n dr = power*pow(r, power-1.0)*dr + 1.0;\n \n r = pow(r, power);\n theta *= power;\n phi *= power;\n \n z = r*vec3(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));\n z += p;\n }\n return 0.5*log(r)*r/dr;\n}\n\n\nstruct Ray {\n bool hit;\n vec3 hitPos;\n float t;\n int steps;\n};\nconst int maxSteps = 50;\nRay trace(vec3 camPos, vec3 rayDir) {\n vec3 p = vec3(0);\n float t = 0.0; \n int steps = 0;\n bool hit = false;\n for(int i = 0; i < maxSteps; i++) {\n p = camPos + t*rayDir;\n float d = df(p, 8.0*abs(sin(0.5*time)) + 1.0);\n if(d < 0.001) {\n hit = true;\n steps = i;\n break;\n }\n t += d*0.9;\n }\n return Ray(hit, p, t, steps);\n}\n\n\nvec3 shading(Ray tr) {\n if(tr.hit) {\n \treturn vec3(pow(1.0 - float(tr.steps)/float(maxSteps), 0.7));\n }\n else {\n return vec3(0);\n }\n}\n\n\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n //we want to keep the resolution.xresolution.y ratio\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //deduce from finalMaxVertexCount the number of possible lines with the given across\n float down = floor(finalMaxVertexCount / across);\n \n //Now we have the across and down number of elements, we can now calculate the final number of vertices\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n\n \n //vec2 fragCoord = vec2(ux,vy);\n \n //apply fragment logic\n\n\t//vec2 fragCoord = vec2(ux,vy);\n \n\tvec2 iResolution = vec2(across, down);\n float iTime = time;\n \n\t//vec2 uv = (2.0*fragCoord.xy - iResolution.xy) / iResolution.y;\n \n vec2 uv = vec2(u,v);\n \n //vec3 camPos = vec3(-2, 0, 0);\n vec3 camPos = 2.0*vec3(cos(iTime), 0, sin(iTime));\n vec3 camFront = normalize(-camPos);\n vec3 camUp = vec3(0, 1, 0);\n vec3 camRight = cross(camFront, camUp);\n float focus = 1.0;\n \n vec3 rayDir = normalize(uv.x*camRight + uv.y*camUp + focus*camFront);\n Ray tr = trace(camPos, rayDir);\n \n\t//fragColor = vec4(shading(tr), 1.0);\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(shading(tr), 1.0);\n \n //v_color = vec4(1.,1.,1.,1.);\n}" + }, "screenshotURL": "data/images/images-kfpwimt38qwaygkkh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sFwDFQhDYuAh6a6r8/art.json b/art/sFwDFQhDYuAh6a6r8/art.json index e6869fcd..e63d62b7 100644 --- a/art/sFwDFQhDYuAh6a6r8/art.json +++ b/art/sFwDFQhDYuAh6a6r8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":33967,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n\\n#define KP0 222.//KParameter0 0.>>1000.\\n#define KP1 56.//KParameter1 0.0>>22.\\n#define K2 9.0//KParameter2 6.0>>10.\\n#define KP3 -0.01//KParameter3 -8.000>>0.5\\n#define KP4 6.2//KParameter4 0.000>>15.\\n#define KP5 553.0//KParameter5 30.000>>90000.0\\n\\n\\n\\n#define PI radians(180. -KP1)\\nfloat VertexCount = (1000. * K2) ;\\n \\n float KP2 = (K2 + mouse.y);\\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 29.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(y-x -x,.5*y+y, z*3.); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 1.125;\\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.52) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n ,1.15)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect );\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n \\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 33967, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n\n#define KP0 222.//KParameter0 0.>>1000.\n#define KP1 56.//KParameter1 0.0>>22.\n#define K2 9.0//KParameter2 6.0>>10.\n#define KP3 -0.01//KParameter3 -8.000>>0.5\n#define KP4 6.2//KParameter4 0.000>>15.\n#define KP5 553.0//KParameter5 30.000>>90000.0\n\n\n\n#define PI radians(180. -KP1)\nfloat VertexCount = (1000. * K2) ;\n \n float KP2 = (K2 + mouse.y);\nfloat K1 = KP0 * mouse.x *(KP0 * mouse.y)+(KP1 * mouse.x);\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0 *KP3);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 29.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(y-x -x,.5*y+y, z*3.); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 1.125;\n vec3 p = vec3(cos(a), 0.0707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.52) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n ,1.15)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 111.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect );\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n \n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 1.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-dycy6r5tylaz6au0h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sHdHwHQ9GTSaJ9j99/art.json b/art/sHdHwHQ9GTSaJ9j99/art.json index 323406e7..80ea02b4 100644 --- a/art/sHdHwHQ9GTSaJ9j99/art.json +++ b/art/sHdHwHQ9GTSaJ9j99/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":90000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ken-ishii-70drums/sulfurex-point-break-ken-ishii\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.23137254901960785,0.7490196078431373,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\\n 0);\\n}\\n\\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\\n \\n float id = pointId;\\n float ux = mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n \\n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \\n uv = vec2(ux, vy);\\n}\\n\\n#define POINTS_PER_LINE 1800.\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float quadCount = POINTS_PER_LINE / 6.; \\n float pointId = mod(vertexId, 6.);\\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\\n vec3 pos;\\n vec2 uv;\\n \\n float snd0 = texture2D(sound, vec2(0.13 + lineId * 0.005, quadId / quadCount * 0.01)).a;\\n float snd1 = texture2D(sound, vec2(0.14 + lineId * 0.005, quadId / quadCount * 0.01)).a;\\n \\n getQuadPoint(quadId * 0.02 + time * 1.1 * (lineId + 1.), pointId, pow(snd0, 7.0) * 0.5, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \\n \\n vec3 aspect = vec3(resolution.y / resolution.x * 2., 2, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_Position.z = -m1p1(quadId / quadCount);\\n gl_Position.x += m1p1(lineId / 50.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 4.;\\n\\n float hue = mix(0.95, 1.0, fract(lineId / 5.3));\\n float sat = 1.;\\n float val = step(0.5, snd1);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 90000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ken-ishii-70drums/sulfurex-point-break-ken-ishii", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.23137254901960785, + 0.7490196078431373, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + cos(a1 * 1.73)) / 3.,\n 0);\n}\n\nvoid getQuadPoint(const float quadId, const float pointId, float thickness, vec2 seed, out vec3 pos, out vec2 uv) {\n vec3 p0 = getCenterPoint(quadId + 0.0, seed);\n vec3 p1 = getCenterPoint(quadId + 0.1, seed);\n vec3 p2 = getCenterPoint(quadId + 0.2, seed);\n vec3 p3 = getCenterPoint(quadId + 0.3, seed);\n vec3 perp0 = normalize(p2 - p0).yxz * vec3(-1, 1, 0) * thickness;\n vec3 perp1 = normalize(p3 - p1).yxz * vec3(-1, 1, 0) * thickness;\n \n float id = pointId;\n float ux = mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n \n pos = vec3(mix(p1, p2, vy) + mix(-1., 1., ux) * mix(perp0, perp1, vy)); \n uv = vec2(ux, vy);\n}\n\n#define POINTS_PER_LINE 1800.\n#define QUADS_PER_LINE (POINTS_PER_LINE / 6.)\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float quadCount = POINTS_PER_LINE / 6.; \n float pointId = mod(vertexId, 6.);\n float quadId = floor(mod(vertexId, POINTS_PER_LINE) / 6.);\n vec3 pos;\n vec2 uv;\n \n float snd0 = texture2D(sound, vec2(0.13 + lineId * 0.005, quadId / quadCount * 0.01)).a;\n float snd1 = texture2D(sound, vec2(0.14 + lineId * 0.005, quadId / quadCount * 0.01)).a;\n \n getQuadPoint(quadId * 0.02 + time * 1.1 * (lineId + 1.), pointId, pow(snd0, 7.0) * 0.5, vec2(pow(snd0, 2.), pow(snd1, 2.0)), pos, uv); \n \n vec3 aspect = vec3(resolution.y / resolution.x * 2., 2, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_Position.z = -m1p1(quadId / quadCount);\n gl_Position.x += m1p1(lineId / 50.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 4.;\n\n float hue = mix(0.95, 1.0, fract(lineId / 5.3));\n float sat = 1.;\n float val = step(0.5, snd1);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), quadId / quadCount);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-4xkxk1n631eieg75l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sK7LiRcHNuXupG5ax/art.json b/art/sK7LiRcHNuXupG5ax/art.json index a37c9129..5e3595b8 100644 --- a/art/sK7LiRcHNuXupG5ax/art.json +++ b/art/sK7LiRcHNuXupG5ax/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6127,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.27058823529411763,0.050980392156862744,0.34901960784313724,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 1.0)\\n#define STEP 1.93\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\\nfloat snd = texture2D(sound,vec2(0.,1.)).a;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * .6- mouse.y) + 11.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.0014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.0025, .9);\\n float innerRadius = pow(count * 0.0005, .2);\\n float oC = cos(orbitAngle + count * 0.003) * innerRadius*mouse.y*sin(time);\\n float oS = sin(orbitAngle + count * 0.01) * innerRadius-mouse.x+sin(time);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC -1.+ c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\\n\\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 1.3 + 0.17, 1.8);\\n b = 0.20;mix(-.3, mouse.x/0.9/T, b)/-T;\\n v_color = vec4(c, c, cos(T*5./b)+b/c-b, .489);\\n}\\n\"}", + "settings": { + "num": 6127, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.27058823529411763, + 0.050980392156862744, + 0.34901960784313724, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 1.0)\n#define STEP 1.93\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\nfloat snd = texture2D(sound,vec2(0.,1.)).a;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * .6- mouse.y) + 11.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.0014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.0025, .9);\n float innerRadius = pow(count * 0.0005, .2);\n float oC = cos(orbitAngle + count * 0.003) * innerRadius*mouse.y*sin(time);\n float oS = sin(orbitAngle + count * 0.01) * innerRadius-mouse.x+sin(time);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC -1.+ c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\n\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 1.3 + 0.17, 1.8);\n b = 0.20;mix(-.3, mouse.x/0.9/T, b)/-T;\n v_color = vec4(c, c, cos(T*5./b)+b/c-b, .489);\n}\n" + }, "screenshotURL": "data/images/images-34zoofwmawlxo2ax2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sP9meYNADjKewXyNN/art.json b/art/sP9meYNADjKewXyNN/art.json index ae8f4f0f..a48154d5 100644 --- a/art/sP9meYNADjKewXyNN/art.json +++ b/art/sP9meYNADjKewXyNN/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float u = floor(vertexId / 6.) + mod(vertexId, 2.);\\n float v = mod(floor(vertexId / 3.) +\\n floor(vertexId / 2.), 2.);\\n \\n float segmentsPerCircle = 6.;\\n float angle = u / segmentsPerCircle * PI * 2.;\\n float s = sin(angle);\\n float c = cos(angle);\\n float radius = v;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n vec2 xy = vec2(x, y);\\n vec4 pos = vec4(xy, 0, 1);\\n \\n mat4 mvp = mat4(\\n resolution.y / resolution.x, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n mvp *= scale(0.25);\\n \\n gl_Position = mvp * pos;\\n v_color = vec4(0, 0, 1, 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float u = floor(vertexId / 6.) + mod(vertexId, 2.);\n float v = mod(floor(vertexId / 3.) +\n floor(vertexId / 2.), 2.);\n \n float segmentsPerCircle = 6.;\n float angle = u / segmentsPerCircle * PI * 2.;\n float s = sin(angle);\n float c = cos(angle);\n float radius = v;\n \n float x = c * radius;\n float y = s * radius;\n \n vec2 xy = vec2(x, y);\n vec4 pos = vec4(xy, 0, 1);\n \n mat4 mvp = mat4(\n resolution.y / resolution.x, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n mvp *= scale(0.25);\n \n gl_Position = mvp * pos;\n v_color = vec4(0, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-mflebhnqxoc5wme4c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sPftu8weSr8Ej2krv/art.json b/art/sPftu8weSr8Ej2krv/art.json index 71c1b2ae..0a48e6a0 100644 --- a/art/sPftu8weSr8Ej2krv/art.json +++ b/art/sPftu8weSr8Ej2krv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 4.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 4.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ptfoyfp5ejm55ipi3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sQ6ahpp85mA5CcSNJ/art.json b/art/sQ6ahpp85mA5CcSNJ/art.json index 349a63a1..ad5e0c8e 100644 --- a/art/sQ6ahpp85mA5CcSNJ/art.json +++ b/art/sQ6ahpp85mA5CcSNJ/art.json @@ -35,7 +35,19 @@ "unlisted": false, "username": "archer", "avatarUrl": "https://lh5.googleusercontent.com/-yNdyToHV35U/AAAAAAAAAAI/AAAAAAAABxw/qQAHdzq4gr8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define MAX_RAY_STEPS 50\\n#define MIN_DISTANCE 0.001\\n#define MENGER_LAYERS 3\\n#define FOV 4.0 / 3.0\\n\\nvec3 hsv2rgb(vec3 c) { // Change HSV to RGB\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat distanceEstimator(vec3 pos) { // Distance estimator for Menger Sponge\\n // Loop the Menger Sponge\\n float x = 2.0 / 3.0 - mod(abs(pos.x) + 2.0 / 3.0, 4.0 / 3.0);\\n float y = 2.0 / 3.0 - mod(abs(pos.y) + 2.0 / 3.0, 4.0 / 3.0);\\n float z = 2.0 / 3.0 - mod(abs(pos.z) + 2.0 / 3.0, 4.0 / 3.0);\\n \\n // Center it by changing position and scale\\n\\tx = x * 0.5 + 0.5;\\n y = y * 0.5 + 0.5;\\n z = z * 0.5 + 0.5;\\n\\n\\tfloat xx = abs(x - 0.5) - 0.5;\\n float yy = abs(y - 0.5) - 0.5;\\n float zz = abs(z - 0.5) - 0.5;\\n \\n\\tfloat d1 = max(xx,max(yy,zz)); // Distance to a box\\n\\tfloat d = d1; // Current computed distance\\n\\tfloat p = 1.0;\\n \\n for (int i=1; i <= MENGER_LAYERS; i++) {\\n\\t\\tfloat xa = mod(3.0 * x * p, 3.0);\\n\\t\\tfloat ya = mod(3.0 * y * p, 3.0);\\n\\t\\tfloat za = mod(3.0 * z * p, 3.0);\\n\\t\\tp *= 3.0;\\n\\t\\t\\n\\t\\txx = 0.5 - abs(xa - 1.5);\\n yy = 0.5 - abs(ya - 1.5);\\n zz = 0.5 - abs(za - 1.5);\\n \\n // Distance inside the 3 axis-aligned square tubes\\n\\t\\td1 = min(max(xx, zz), min(max(xx, yy), max(yy, zz))) / p;\\n\\t\\t\\n \\t// Intersection\\n\\t\\td = max(d, d1);\\n }\\n \\n\\treturn d * 2.0;\\n}\\n\\nfloat trace(vec3 from, vec3 direction) { // \\n\\tfloat totalDistance = 0.0;\\n\\tint steps;\\n\\tfor (int i=0; i < MAX_RAY_STEPS; i++) {\\n steps++;\\n\\t\\tvec3 p = from + totalDistance * direction;\\n\\t\\tfloat distance = distanceEstimator(p);\\n\\t\\ttotalDistance += distance;\\n\\t\\tif (distance < MIN_DISTANCE) break;\\n\\t}\\n\\treturn 1.0 - float(steps) / float(MAX_RAY_STEPS);\\n}\\n\\nvoid main() {\\n \\n float pixelDensity = floor(sqrt(vertexCount));\\n gl_PointSize = max(resolution.x, resolution.y) / pixelDensity;\\n \\n // Convert vertices to screenspace pixels\\n float sx = (mod(vertexId, pixelDensity) / pixelDensity) * 2.0 - 1.0;\\n float sy = (ceil(vertexId / pixelDensity) / pixelDensity) * 2.0 - 1.0;\\n \\n gl_Position = vec4(sx, sy, 0.0, 1.0);\\n \\n // Convert screenspace pixels to worldspace pixels\\n float trueX = sx * resolution.x / 500.0;\\n float trueY = sy * resolution.y / 500.0;\\n \\n // Get rotation\\n float rotation = -mouse.x + PI / 2.0;\\n \\n // Get camera position and direction per pixel\\n vec3 camera = vec3(0.0, mod(time, FOV), 0.0);\\n vec3 direction = normalize(vec3(FOV * cos(rotation) + trueX * sin(rotation), FOV * sin(rotation) + trueX * -cos(rotation), trueY));\\n \\n // Get pixel value and set vertex color\\n float pixelVal = trace(camera, direction);\\n vec3 pixelColor = hsv2rgb(vec3(pixelVal * 3.0, 0.3, pixelVal * 0.3 + 0.7));\\n \\n v_color = vec4(pixelColor, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define MAX_RAY_STEPS 50\n#define MIN_DISTANCE 0.001\n#define MENGER_LAYERS 3\n#define FOV 4.0 / 3.0\n\nvec3 hsv2rgb(vec3 c) { // Change HSV to RGB\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat distanceEstimator(vec3 pos) { // Distance estimator for Menger Sponge\n // Loop the Menger Sponge\n float x = 2.0 / 3.0 - mod(abs(pos.x) + 2.0 / 3.0, 4.0 / 3.0);\n float y = 2.0 / 3.0 - mod(abs(pos.y) + 2.0 / 3.0, 4.0 / 3.0);\n float z = 2.0 / 3.0 - mod(abs(pos.z) + 2.0 / 3.0, 4.0 / 3.0);\n \n // Center it by changing position and scale\n\tx = x * 0.5 + 0.5;\n y = y * 0.5 + 0.5;\n z = z * 0.5 + 0.5;\n\n\tfloat xx = abs(x - 0.5) - 0.5;\n float yy = abs(y - 0.5) - 0.5;\n float zz = abs(z - 0.5) - 0.5;\n \n\tfloat d1 = max(xx,max(yy,zz)); // Distance to a box\n\tfloat d = d1; // Current computed distance\n\tfloat p = 1.0;\n \n for (int i=1; i <= MENGER_LAYERS; i++) {\n\t\tfloat xa = mod(3.0 * x * p, 3.0);\n\t\tfloat ya = mod(3.0 * y * p, 3.0);\n\t\tfloat za = mod(3.0 * z * p, 3.0);\n\t\tp *= 3.0;\n\t\t\n\t\txx = 0.5 - abs(xa - 1.5);\n yy = 0.5 - abs(ya - 1.5);\n zz = 0.5 - abs(za - 1.5);\n \n // Distance inside the 3 axis-aligned square tubes\n\t\td1 = min(max(xx, zz), min(max(xx, yy), max(yy, zz))) / p;\n\t\t\n \t// Intersection\n\t\td = max(d, d1);\n }\n \n\treturn d * 2.0;\n}\n\nfloat trace(vec3 from, vec3 direction) { // \n\tfloat totalDistance = 0.0;\n\tint steps;\n\tfor (int i=0; i < MAX_RAY_STEPS; i++) {\n steps++;\n\t\tvec3 p = from + totalDistance * direction;\n\t\tfloat distance = distanceEstimator(p);\n\t\ttotalDistance += distance;\n\t\tif (distance < MIN_DISTANCE) break;\n\t}\n\treturn 1.0 - float(steps) / float(MAX_RAY_STEPS);\n}\n\nvoid main() {\n \n float pixelDensity = floor(sqrt(vertexCount));\n gl_PointSize = max(resolution.x, resolution.y) / pixelDensity;\n \n // Convert vertices to screenspace pixels\n float sx = (mod(vertexId, pixelDensity) / pixelDensity) * 2.0 - 1.0;\n float sy = (ceil(vertexId / pixelDensity) / pixelDensity) * 2.0 - 1.0;\n \n gl_Position = vec4(sx, sy, 0.0, 1.0);\n \n // Convert screenspace pixels to worldspace pixels\n float trueX = sx * resolution.x / 500.0;\n float trueY = sy * resolution.y / 500.0;\n \n // Get rotation\n float rotation = -mouse.x + PI / 2.0;\n \n // Get camera position and direction per pixel\n vec3 camera = vec3(0.0, mod(time, FOV), 0.0);\n vec3 direction = normalize(vec3(FOV * cos(rotation) + trueX * sin(rotation), FOV * sin(rotation) + trueX * -cos(rotation), trueY));\n \n // Get pixel value and set vertex color\n float pixelVal = trace(camera, direction);\n vec3 pixelColor = hsv2rgb(vec3(pixelVal * 3.0, 0.3, pixelVal * 0.3 + 0.7));\n \n v_color = vec4(pixelColor, 1.0);\n}" + }, "screenshotURL": "data/images/images-w0vu21lgu06bm774x-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sS597q4aY9wEpneFz/art.json b/art/sS597q4aY9wEpneFz/art.json index 10e3d6e9..5d989ace 100644 --- a/art/sS597q4aY9wEpneFz/art.json +++ b/art/sS597q4aY9wEpneFz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "galousis", "avatarUrl": "https://avatars.githubusercontent.com/galousis?s=200", - "settings": "{\"num\":80000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/pridon/here-be-dragons\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n___________________1111111111111__________________\\n______________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_____________\\n___________1¶¶¶¶¶¶111111111111111¶¶¶¶¶¶1__________\\n_________1¶¶¶11111111111111111111111¶1¶¶¶1________\\n_______1¶¶¶¶1111111111111111111111111111¶¶¶1______\\n______1¶¶1¶1111111111¶¶¶¶¶¶¶¶1111111111111¶¶1_____\\n_____¶¶¶11111111¶¶¶¶¶¶¶¶1_¶¶¶¶¶¶¶¶111111111¶¶¶____\\n____¶¶¶1111111¶¶¶¶¶¶¶¶1_____¶¶¶¶¶¶¶¶11111111¶¶¶___\\n___1¶¶111111¶¶¶¶¶¶¶¶1_________¶¶¶¶¶¶¶¶1111111¶¶1__\\n___¶¶11111¶¶¶¶¶¶¶¶1____________1¶¶¶¶¶¶¶¶111111¶¶1_\\n__¶¶11111¶¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶¶1¶¶¶¶¶¶¶¶111111¶¶_\\n__¶¶1111¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶_____1¶¶¶¶¶¶¶¶11111¶¶_\\n__¶¶1111¶¶¶¶¶¶¶1________¶¶________¶¶¶¶¶¶1¶¶1111¶¶_\\n__¶1111¶¶¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\\n__¶¶111¶1¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\\n__¶1111¶¶1¶¶¶¶¶¶________¶¶¶_______1¶¶¶¶¶11¶11111¶_\\n__¶¶111¶¶1¶¶¶¶¶¶1_____¶¶¶_¶¶______¶¶¶¶¶¶1¶¶1111¶¶_\\n__1¶¶111¶11¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶¶¶¶¶11¶1111¶¶1_\\n___¶¶¶11¶¶11¶¶¶¶¶¶¶1___________¶¶¶¶¶¶¶11¶¶111¶¶¶__\\n___1¶¶111¶¶111¶¶¶¶¶¶¶________1¶¶¶¶¶¶111¶¶1111¶¶1__\\n____1¶¶1111¶¶111¶¶¶¶¶¶¶1___¶¶¶¶¶¶¶111¶¶¶1111¶¶1___\\n_____1¶¶¶111¶¶¶11111¶¶¶¶¶¶¶¶¶¶11111¶¶¶11111¶¶1____\\n______1¶¶¶1111¶¶¶¶¶1111¶¶¶11111¶¶¶¶¶11111¶¶¶1_____\\n________1¶¶111111¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1111111¶¶1_______\\n__________¶¶1111111111¶¶¶¶1111111111111¶1_________\\n__________¶¶¶11111111¶¶11¶¶11111111111¶¶¶_________\\n________1¶¶11¶1¶¶111111111¶111111¶¶¶¶¶11¶¶________\\n_______1¶¶111111¶¶¶¶¶1¶1¶¶¶¶¶¶¶¶¶¶1111111¶¶_______\\n_______¶¶¶11111111111111¶¶11¶1111111111111¶¶______\\n______1¶1111¶11111111111¶¶11111111111111111¶1_____\\n______¶¶111¶111111111111¶¶1111111111111¶111¶¶_____\\n_____1¶111¶¶111111111111¶¶1111111111111¶1111¶1____\\n_____¶¶¶¶¶¶¶111111111111¶¶1111111111111¶¶¶¶¶¶¶____\\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\\n____1¶¶¶¶¶¶1111111111111¶¶11111111111111¶¶¶¶¶¶1___\\n______1111¶1111111111111¶¶11111111111111¶1111_____\\n__________¶¶¶11111111111¶¶111111111111¶¶¶_________\\n__________¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶_________\\n________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_______\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n// based & influenced by this https://github.com/KessonDalef/Shaders/blob/master/Vertex/spherepointcloud.vert\\n\\n/*{\\n \\\"pixelRatio\\\": 1,\\n \\\"vertexCount\\\": 80000,\\n \\\"vertexMode\\\": \\\"POINTS\\\",\\n}*/\\n\\n#define DOTS_PER 80000.\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nprecision mediump float;\\n/*\\nattribute float vertexId;\\nuniform float vertexCount;\\nuniform float time;\\nuniform vec2 resolution;\\nvarying vec4 v_color;\\n*/\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n// 2D Random\\nfloat random (in vec2 st) {\\n return fract(sin(dot(st.xy,\\n vec2(12.9898,78.233)))\\n * 43758.5453123);\\n}\\n\\n// Based on Morgan McGuire @morgan3d\\n// https://www.shadertoy.com/view/4dS3Wd\\nfloat noise (in vec2 st) {\\n vec2 i = floor(st);\\n vec2 f = fract(st);\\n\\n // Four corners in 2D of a tile\\n float a = random(i);\\n float b = random(i + vec2(1.0, 0.0));\\n float c = random(i + vec2(0.0, 1.0));\\n float d = random(i + vec2(1.0, 1.0));\\n\\n // Cubic Hermine Curve. Same as SmoothStep()\\n vec2 u = f*f*(3.-2.0*f);\\n u = smoothstep(0.,1.,f);\\n\\n // Mix 4 coorners percentages\\n return mix(a, b, u.x) +\\n (c - a)* u.y * (1.0 - u.x) +\\n (d - b) * u.x * u.y;\\n}\\n\\nmat4 rotateX(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateY(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotateZ(float angle) {\\n float s = sin(angle);\\n float c = cos(angle);\\n\\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nfloat easeInOutSine(float x) \\n{\\n return -(cos(PI * x) - 1.) * 0.5;\\n}\\n\\nvec4 Slerp(vec4 p0, vec4 p1, float t)\\n{\\n float dotp = dot(normalize(p0), normalize(p1));\\n if ((dotp > 0.9999) || (dotp<-0.9999))\\n {\\n if (t<=0.5)\\n return p0;\\n return p1;\\n }\\n float theta = acos(dotp * PI/180.0);\\n vec4 P = (\\n (\\n p0*sin((1.-t)*theta) + p1*sin(t*theta)\\n ) / sin(theta)\\n );\\n P.w = 1.;\\n return P;\\n}\\n\\nvec3 posf2(float t, float i, float snd) \\n{\\n \\n \\n\\treturn vec3(\\n cos(t*.4+i*1.53) +\\n sin(t*4.84+i*.6)\\n //noise(vec2(t*.5*snd, i))\\n ,\\n cos(t*1.4+i*1.353-2.1) +\\n sin(t*4.84+i*.476-2.1) \\n //noise(vec2(t, i))\\n ,\\n sin(t*1.84+i*.36+2.1)// +\\n\\t)*.1;\\n}\\n\\nvec3 posf0(float t, float fsndweight, float snd) {\\n //return posf2(t,-1.)*0.9;\\n return posf2(t,-1.,snd)*fsndweight;\\n}\\n\\nvec3 posf(float t, float i, float fsndweight, float snd) \\n{\\n //float fsndweightf = mix(4.4, 4.49, pow(fsndweight, 2.0));\\n return posf2(t*.045,i,snd) + posf0(t,fsndweight,snd);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd, float lenghtweight, float snd) {\\n //vec3 pos = posf(t,i,.49)+ofs;\\n vec3 pos = posf(t,i, mix(.45, 4.5, pow(snd, 1.0)), snd) + ofs;\\n\\n vec3 posf = fract(pos+.5)-.5;\\n\\n float l = length(posf)*lenghtweight; //1.5\\n //return (- posf + posf/l)*(1.-smoothstep(lerpEnd,3.,l));\\n //return (posf/l)*(1.-smoothstep(lerpEnd,2.9,l));\\n return (posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// YUV to RGB matrix\\nmat3 yuv2rgb = mat3(1.0, 0.0, 1.13983,\\n 1.0, -0.39465, -0.58060,\\n 1.0, 2.03211, 0.0);\\n\\n// RGB to YUV matrix\\nmat3 rgb2yuv = mat3(0.2126, 0.7152, 0.0722,\\n -0.09991, -0.33609, 0.43600,\\n 0.615, -0.5586, -0.05639);\\n\\n#define OCTAVES 12\\nfloat fbm (in vec2 st) {\\n // Initial values\\n float value = 0.0;\\n float amplitude = .5;\\n float frequency = 0.;\\n //\\n // Loop of octaves\\n for (int i = 0; i < OCTAVES; i++) {\\n value += amplitude * noise(st);\\n st *= 2.;\\n amplitude *= .5;\\n }\\n return value;\\n}\\n\\nfloat fbm2 ( in vec2 _st) {\\n float v = 0.0;\\n float a = 0.5;\\n vec2 shift = vec2(100.0);\\n // Rotate to reduce axial bias\\n mat2 rot = mat2(cos(0.5), sin(0.5),\\n -sin(0.5), cos(0.50));\\n for (int i = 0; i < OCTAVES; ++i) {\\n v += a * noise(_st);\\n _st = rot * _st * 2.0 + shift;\\n a *= 0.5;\\n }\\n return v;\\n}\\n\\nvoid main(void)\\n{\\n\\n float t = time*.6;\\n float i = vertexId+sin(vertexId)*100.;\\n \\n float v = vertexId / vertexCount;\\n float invV = 1.0 - v;\\n float thingId = floor(vertexId / DOTS_PER);\\n float numThings = floor(vertexCount / DOTS_PER);\\n float thingV = thingId / numThings;\\n \\n float snd = texture2D(sound, vec2(thingV * 0.5 + 0.01, mod(thingV * 4., 4.) * 6. / 24.)).a*mix(.5, .9, .8);\\n \\n vec3 pos = posf(t,i, mix(1.45, 4.5, pow(snd, 1.)), snd);\\n \\n vec3 ofs = vec3(0);\\n \\n for (float f = -10.; f < 0.; f++) {\\n\\t //ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\\n ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\\n }\\n ofs += push(t,i,ofs,.999,mix(1.45, 1.5, pow(snd, 2.)),snd);\\n\\n //pos -= posf0(t);\\n pos -= posf0(t,.49, snd);\\n \\n pos += ofs;\\n\\n vec3 oscillationV = posf0(t*.1,0.25, 10.001);\\n\\t\\n oscillationV = vec3(\\n oscillationV.x, \\n dot(normalize( cross(pos,vec3(1.0,0.0,0.0)) ),oscillationV), \\n dot(pos,oscillationV)\\n );\\n\\n float offset = .5 + .5*sin( 1.0 + 6.0*pow(.5-.5*oscillationV.x,1.) );\\n float dist = length( oscillationV*vec3(5.,.0,.0) ) - .80 - offset;\\n \\n dist += 8.*sin(1.*oscillationV.z);\\n dist += sin(10.0*oscillationV.x) * sin(500.*oscillationV.y) * sin(10.*oscillationV.z) * clamp(2.0*oscillationV.y+0.5,0.0,1.0);\\n //dist *= clamp(2.0*oscillationV.y+0.5,0.0,1.0);\\n \\n //vec4 sphericalInt = Slerp(vec4(pos, 1.), vec4(vec3(ofs), 1.), time*pow(snd, 2.));\\n \\n pos.yz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\\n pos.xz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\\n \\n //pos.yz *= mat2(.8,.6,-.6,.8);\\n //pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n //sphericalInt.yz *= mat2(.8,.6,-.6,.8);\\n //sphericalInt.xz *= mat2(.8,.6,-.6,.8);\\n\\n pos.x *= resolution.y/resolution.x;\\n pos.z *= resolution.y/resolution.x;\\n\\n mat4 rotation = rotateY(time*0.15);\\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\\n\\n pos.z += .9;\\n\\n //rot *= .95;\\n rot *= .5;\\n\\n gl_Position = vec4(rot.xyz, 0.55);\\n gl_PointSize = .3;\\n\\n float hue = 1.6 + v;// + v * time * 0.;\\n hue = mix(hue, 50., mod(floor(t * 4.0), 1.4));\\n hue = mix(hue, 0.5, step(0.95, snd*0.95));\\n \\n float clipZ = m1p1(gl_Position.z / gl_Position.w);\\n float invClipZ = 1. - clipZ;\\n float val = invClipZ * 150.;\\n \\n \\n \\n \\n //v_color = vec4(hsv2rgb(vec3(hue*2., hue*22., val)),mix(1., 2.5, pow(snd, 4.)));\\n v_color = vec4(yuv2rgb * vec3(0.5, pos.x, pos.y),mix(1., 2.5, pow(snd, 4.)));\\n v_color = vec4(\\n v_color.rbg * v_color.g, \\n v_color.a\\n );\\n v_color += fbm(pos.xy*50.0);\\n \\n //v_color += vec4(.7, 0.6, 1.0, 0.6);\\n}\\n\"}", + "settings": { + "num": 80000, + "mode": "POINTS", + "sound": "https://soundcloud.com/pridon/here-be-dragons", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n___________________1111111111111__________________\n______________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_____________\n___________1¶¶¶¶¶¶111111111111111¶¶¶¶¶¶1__________\n_________1¶¶¶11111111111111111111111¶1¶¶¶1________\n_______1¶¶¶¶1111111111111111111111111111¶¶¶1______\n______1¶¶1¶1111111111¶¶¶¶¶¶¶¶1111111111111¶¶1_____\n_____¶¶¶11111111¶¶¶¶¶¶¶¶1_¶¶¶¶¶¶¶¶111111111¶¶¶____\n____¶¶¶1111111¶¶¶¶¶¶¶¶1_____¶¶¶¶¶¶¶¶11111111¶¶¶___\n___1¶¶111111¶¶¶¶¶¶¶¶1_________¶¶¶¶¶¶¶¶1111111¶¶1__\n___¶¶11111¶¶¶¶¶¶¶¶1____________1¶¶¶¶¶¶¶¶111111¶¶1_\n__¶¶11111¶¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶¶1¶¶¶¶¶¶¶¶111111¶¶_\n__¶¶1111¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶_____1¶¶¶¶¶¶¶¶11111¶¶_\n__¶¶1111¶¶¶¶¶¶¶1________¶¶________¶¶¶¶¶¶1¶¶1111¶¶_\n__¶1111¶¶¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\n__¶¶111¶1¶¶¶¶¶¶_______¶¶_¶_¶¶______¶¶¶¶¶¶1¶11111¶_\n__¶1111¶¶1¶¶¶¶¶¶________¶¶¶_______1¶¶¶¶¶11¶11111¶_\n__¶¶111¶¶1¶¶¶¶¶¶1_____¶¶¶_¶¶______¶¶¶¶¶¶1¶¶1111¶¶_\n__1¶¶111¶11¶¶¶¶¶¶¶¶¶¶¶¶_____¶¶¶¶_¶¶¶¶¶¶11¶1111¶¶1_\n___¶¶¶11¶¶11¶¶¶¶¶¶¶1___________¶¶¶¶¶¶¶11¶¶111¶¶¶__\n___1¶¶111¶¶111¶¶¶¶¶¶¶________1¶¶¶¶¶¶111¶¶1111¶¶1__\n____1¶¶1111¶¶111¶¶¶¶¶¶¶1___¶¶¶¶¶¶¶111¶¶¶1111¶¶1___\n_____1¶¶¶111¶¶¶11111¶¶¶¶¶¶¶¶¶¶11111¶¶¶11111¶¶1____\n______1¶¶¶1111¶¶¶¶¶1111¶¶¶11111¶¶¶¶¶11111¶¶¶1_____\n________1¶¶111111¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1111111¶¶1_______\n__________¶¶1111111111¶¶¶¶1111111111111¶1_________\n__________¶¶¶11111111¶¶11¶¶11111111111¶¶¶_________\n________1¶¶11¶1¶¶111111111¶111111¶¶¶¶¶11¶¶________\n_______1¶¶111111¶¶¶¶¶1¶1¶¶¶¶¶¶¶¶¶¶1111111¶¶_______\n_______¶¶¶11111111111111¶¶11¶1111111111111¶¶______\n______1¶1111¶11111111111¶¶11111111111111111¶1_____\n______¶¶111¶111111111111¶¶1111111111111¶111¶¶_____\n_____1¶111¶¶111111111111¶¶1111111111111¶1111¶1____\n_____¶¶¶¶¶¶¶111111111111¶¶1111111111111¶¶¶¶¶¶¶____\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\n____¶¶¶¶¶¶¶¶¶11111111111¶¶111111111111¶¶¶¶¶¶¶¶¶___\n____1¶¶¶¶¶¶1111111111111¶¶11111111111111¶¶¶¶¶¶1___\n______1111¶1111111111111¶¶11111111111111¶1111_____\n__________¶¶¶11111111111¶¶111111111111¶¶¶_________\n__________¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶_________\n________1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶¶1_______\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// based & influenced by this https://github.com/KessonDalef/Shaders/blob/master/Vertex/spherepointcloud.vert\n\n/*{\n \"pixelRatio\": 1,\n \"vertexCount\": 80000,\n \"vertexMode\": \"POINTS\",\n}*/\n\n#define DOTS_PER 80000.\n#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nprecision mediump float;\n/*\nattribute float vertexId;\nuniform float vertexCount;\nuniform float time;\nuniform vec2 resolution;\nvarying vec4 v_color;\n*/\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n// 2D Random\nfloat random (in vec2 st) {\n return fract(sin(dot(st.xy,\n vec2(12.9898,78.233)))\n * 43758.5453123);\n}\n\n// Based on Morgan McGuire @morgan3d\n// https://www.shadertoy.com/view/4dS3Wd\nfloat noise (in vec2 st) {\n vec2 i = floor(st);\n vec2 f = fract(st);\n\n // Four corners in 2D of a tile\n float a = random(i);\n float b = random(i + vec2(1.0, 0.0));\n float c = random(i + vec2(0.0, 1.0));\n float d = random(i + vec2(1.0, 1.0));\n\n // Cubic Hermine Curve. Same as SmoothStep()\n vec2 u = f*f*(3.-2.0*f);\n u = smoothstep(0.,1.,f);\n\n // Mix 4 coorners percentages\n return mix(a, b, u.x) +\n (c - a)* u.y * (1.0 - u.x) +\n (d - b) * u.x * u.y;\n}\n\nmat4 rotateX(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateY(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotateZ(float angle) {\n float s = sin(angle);\n float c = cos(angle);\n\n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nfloat easeInOutSine(float x) \n{\n return -(cos(PI * x) - 1.) * 0.5;\n}\n\nvec4 Slerp(vec4 p0, vec4 p1, float t)\n{\n float dotp = dot(normalize(p0), normalize(p1));\n if ((dotp > 0.9999) || (dotp<-0.9999))\n {\n if (t<=0.5)\n return p0;\n return p1;\n }\n float theta = acos(dotp * PI/180.0);\n vec4 P = (\n (\n p0*sin((1.-t)*theta) + p1*sin(t*theta)\n ) / sin(theta)\n );\n P.w = 1.;\n return P;\n}\n\nvec3 posf2(float t, float i, float snd) \n{\n \n \n\treturn vec3(\n cos(t*.4+i*1.53) +\n sin(t*4.84+i*.6)\n //noise(vec2(t*.5*snd, i))\n ,\n cos(t*1.4+i*1.353-2.1) +\n sin(t*4.84+i*.476-2.1) \n //noise(vec2(t, i))\n ,\n sin(t*1.84+i*.36+2.1)// +\n\t)*.1;\n}\n\nvec3 posf0(float t, float fsndweight, float snd) {\n //return posf2(t,-1.)*0.9;\n return posf2(t,-1.,snd)*fsndweight;\n}\n\nvec3 posf(float t, float i, float fsndweight, float snd) \n{\n //float fsndweightf = mix(4.4, 4.49, pow(fsndweight, 2.0));\n return posf2(t*.045,i,snd) + posf0(t,fsndweight,snd);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd, float lenghtweight, float snd) {\n //vec3 pos = posf(t,i,.49)+ofs;\n vec3 pos = posf(t,i, mix(.45, 4.5, pow(snd, 1.0)), snd) + ofs;\n\n vec3 posf = fract(pos+.5)-.5;\n\n float l = length(posf)*lenghtweight; //1.5\n //return (- posf + posf/l)*(1.-smoothstep(lerpEnd,3.,l));\n //return (posf/l)*(1.-smoothstep(lerpEnd,2.9,l));\n return (posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\n// YUV to RGB matrix\nmat3 yuv2rgb = mat3(1.0, 0.0, 1.13983,\n 1.0, -0.39465, -0.58060,\n 1.0, 2.03211, 0.0);\n\n// RGB to YUV matrix\nmat3 rgb2yuv = mat3(0.2126, 0.7152, 0.0722,\n -0.09991, -0.33609, 0.43600,\n 0.615, -0.5586, -0.05639);\n\n#define OCTAVES 12\nfloat fbm (in vec2 st) {\n // Initial values\n float value = 0.0;\n float amplitude = .5;\n float frequency = 0.;\n //\n // Loop of octaves\n for (int i = 0; i < OCTAVES; i++) {\n value += amplitude * noise(st);\n st *= 2.;\n amplitude *= .5;\n }\n return value;\n}\n\nfloat fbm2 ( in vec2 _st) {\n float v = 0.0;\n float a = 0.5;\n vec2 shift = vec2(100.0);\n // Rotate to reduce axial bias\n mat2 rot = mat2(cos(0.5), sin(0.5),\n -sin(0.5), cos(0.50));\n for (int i = 0; i < OCTAVES; ++i) {\n v += a * noise(_st);\n _st = rot * _st * 2.0 + shift;\n a *= 0.5;\n }\n return v;\n}\n\nvoid main(void)\n{\n\n float t = time*.6;\n float i = vertexId+sin(vertexId)*100.;\n \n float v = vertexId / vertexCount;\n float invV = 1.0 - v;\n float thingId = floor(vertexId / DOTS_PER);\n float numThings = floor(vertexCount / DOTS_PER);\n float thingV = thingId / numThings;\n \n float snd = texture2D(sound, vec2(thingV * 0.5 + 0.01, mod(thingV * 4., 4.) * 6. / 24.)).a*mix(.5, .9, .8);\n \n vec3 pos = posf(t,i, mix(1.45, 4.5, pow(snd, 1.)), snd);\n \n vec3 ofs = vec3(0);\n \n for (float f = -10.; f < 0.; f++) {\n\t //ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\n ofs += push(t+f*.03,i,ofs,2.-exp(-f*.1),mix(1.45, 1.5, pow(snd, 1.)),snd);\n }\n ofs += push(t,i,ofs,.999,mix(1.45, 1.5, pow(snd, 2.)),snd);\n\n //pos -= posf0(t);\n pos -= posf0(t,.49, snd);\n \n pos += ofs;\n\n vec3 oscillationV = posf0(t*.1,0.25, 10.001);\n\t\n oscillationV = vec3(\n oscillationV.x, \n dot(normalize( cross(pos,vec3(1.0,0.0,0.0)) ),oscillationV), \n dot(pos,oscillationV)\n );\n\n float offset = .5 + .5*sin( 1.0 + 6.0*pow(.5-.5*oscillationV.x,1.) );\n float dist = length( oscillationV*vec3(5.,.0,.0) ) - .80 - offset;\n \n dist += 8.*sin(1.*oscillationV.z);\n dist += sin(10.0*oscillationV.x) * sin(500.*oscillationV.y) * sin(10.*oscillationV.z) * clamp(2.0*oscillationV.y+0.5,0.0,1.0);\n //dist *= clamp(2.0*oscillationV.y+0.5,0.0,1.0);\n \n //vec4 sphericalInt = Slerp(vec4(pos, 1.), vec4(vec3(ofs), 1.), time*pow(snd, 2.));\n \n pos.yz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\n pos.xz *= mat2(dist*0.8,dist*.6,-dist*.6,dist*0.8);\n \n //pos.yz *= mat2(.8,.6,-.6,.8);\n //pos.xz *= mat2(.8,.6,-.6,.8);\n \n //sphericalInt.yz *= mat2(.8,.6,-.6,.8);\n //sphericalInt.xz *= mat2(.8,.6,-.6,.8);\n\n pos.x *= resolution.y/resolution.x;\n pos.z *= resolution.y/resolution.x;\n\n mat4 rotation = rotateY(time*0.15);\n vec4 rot = vec4(pos.xyz, 1.0) * rotation;\n\n pos.z += .9;\n\n //rot *= .95;\n rot *= .5;\n\n gl_Position = vec4(rot.xyz, 0.55);\n gl_PointSize = .3;\n\n float hue = 1.6 + v;// + v * time * 0.;\n hue = mix(hue, 50., mod(floor(t * 4.0), 1.4));\n hue = mix(hue, 0.5, step(0.95, snd*0.95));\n \n float clipZ = m1p1(gl_Position.z / gl_Position.w);\n float invClipZ = 1. - clipZ;\n float val = invClipZ * 150.;\n \n \n \n \n //v_color = vec4(hsv2rgb(vec3(hue*2., hue*22., val)),mix(1., 2.5, pow(snd, 4.)));\n v_color = vec4(yuv2rgb * vec3(0.5, pos.x, pos.y),mix(1., 2.5, pow(snd, 4.)));\n v_color = vec4(\n v_color.rbg * v_color.g, \n v_color.a\n );\n v_color += fbm(pos.xy*50.0);\n \n //v_color += vec4(.7, 0.6, 1.0, 0.6);\n}\n" + }, "screenshotURL": "data/images/images-w0kskivlej25q9evu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sSEcdoNo3EcbnYphW/art.json b/art/sSEcdoNo3EcbnYphW/art.json index 0bf42379..1ae54182 100644 --- a/art/sSEcdoNo3EcbnYphW/art.json +++ b/art/sSEcdoNo3EcbnYphW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 50\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float sizeFactor = 1./20.;\\n float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n //cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n cubep*= sizeFactor;\\n \\n //LOGISTIC\\n \\n //vec2 p = vec2(fragCoord.x / iResolution.x, fragCoord.y / iResolution.y);\\n \\n float fac = sin(time*1.57)+sin(time*0.13)+sin(time*0.8);\\n vec2 vp = vec2(shapeRelId,shapeRelId);\\n float z = fract(time+shapeRelId+fac);//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n int acc = 0;\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + vp.x * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n //acc += (z > p.y && z <= p.y + 1. / iResolution.y) ? 1 : 0;\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n float g = 25. * float(acc) / iters;\\n\\n cubep.x+= z*10.;\\n \\n cubep.z+= shapeRelId*10.;\\n cubep.z+= snd*10.;\\n //fragColor = vec4(g, g /3., g / 8.,1.);\\n\\n\\n //END LOGISTIC\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n vec3 eye = vec3(0., 4., -4.2);\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n \\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(3.0, 0., 2.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 50\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float sizeFactor = 1./20.;\n float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n //cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n cubep*= sizeFactor;\n \n //LOGISTIC\n \n //vec2 p = vec2(fragCoord.x / iResolution.x, fragCoord.y / iResolution.y);\n \n float fac = sin(time*1.57)+sin(time*0.13)+sin(time*0.8);\n vec2 vp = vec2(shapeRelId,shapeRelId);\n float z = fract(time+shapeRelId+fac);//sin(shapeRelId+fract(time/100.));//fract(0.02);\n int acc = 0;\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + vp.x * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n //acc += (z > p.y && z <= p.y + 1. / iResolution.y) ? 1 : 0;\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n float g = 25. * float(acc) / iters;\n\n cubep.x+= z*10.;\n \n cubep.z+= shapeRelId*10.;\n cubep.z+= snd*10.;\n //fragColor = vec4(g, g /3., g / 8.,1.);\n\n\n //END LOGISTIC\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n vec3 eye = vec3(0., 4., -4.2);\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n \n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(3.0, 0., 2.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-evl4drgi5yctmou2j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sSXAMvBdzGHTManZw/art.json b/art/sSXAMvBdzGHTManZw/art.json index 58c9f81b..31a2f2c7 100644 --- a/art/sSXAMvBdzGHTManZw/art.json +++ b/art/sSXAMvBdzGHTManZw/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":72773,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(2.4, 1.2, 1.4) * 10.1-mouse.x; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\\n\\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * 3.;\\nfloat gExposure = 0.2;\\nfloat gCubeColorRandom = .5;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 3.6;\\nfloat gFloorHeight = -43.0*mouse.x;\\nfloat g_cameraFar = 105.0 *mouse.y;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 30.0, 80.3, -50.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 1.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 5.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = (v2- mouse.y);\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3, mouse.x;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\\n}\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 1.25 + .6;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 1, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 2.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.25);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\\n float z = vP * down * 11.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 10.);\\n mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \\n pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 0.78;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\\n float ca = 0.01;\\n \\n // get sick!\\n ca = time * 0.7;\\n \\tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 72773, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(2.4, 1.2, 1.4) * 10.1-mouse.x; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\n\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * 3.;\nfloat gExposure = 0.2;\nfloat gCubeColorRandom = .5;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 3.6;\nfloat gFloorHeight = -43.0*mouse.x;\nfloat g_cameraFar = 105.0 *mouse.y;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 30.0, 80.3, -50.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 1.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 5.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = (v2- mouse.y);\n }\n \telse\n {\n\t \tvWorldPos = v3, mouse.x;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\n}\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 1.25 + .6;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 1, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 2.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.25);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3(-0.92, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\n float z = vP * down * 11.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 10.);\n mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \n pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 1.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 0.78;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0.2, -0.2, 0.8 );\n \tvec3 vCameraPos = vec3(sin(time * 0.51) * 50., 1, cos(time * 0.1) * 50.0);\n float ca = 0.01;\n \n // get sick!\n ca = time * 0.7;\n \tvec3 vCameraUp = vec3( 0, 0.05, 0.1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.01, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-3hv0djwk0bu73xcwb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sTNYDvmznSEKDDQtK/art.json b/art/sTNYDvmznSEKDDQtK/art.json index 9992680a..02f9bd3d 100644 --- a/art/sTNYDvmznSEKDDQtK/art.json +++ b/art/sTNYDvmznSEKDDQtK/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "donga.choi", "avatarUrl": "https://secure.gravatar.com/avatar/edffcb435255bbb6bef5ad8a6333dda8?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Dong-A Choi\\n//CS250\\n//Motion exercise\\n//2022 spring\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time+x*y*0.02) * 5.;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Dong-A Choi\n//CS250\n//Motion exercise\n//2022 spring\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time+x*y*0.02) * 5.;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n \n}" + }, "screenshotURL": "data/images/images-fiud3f26k6opd7xm0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sYBECGM9gRBccnwPb/art.json b/art/sYBECGM9gRBccnwPb/art.json index 308f1e41..47c80b45 100644 --- a/art/sYBECGM9gRBccnwPb/art.json +++ b/art/sYBECGM9gRBccnwPb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6235294117647059,0.6235294117647059,0.6235294117647059,1],\"shader\":\"void main()\\n{\\n\\tgl_PointSize = 10.0;\\n \\n \\tvec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\\n \\n \\tgl_Position = vec4(xy, 0.0, 1.0);\\n \\tv_color = vec4(0.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6235294117647059, + 0.6235294117647059, + 0.6235294117647059, + 1 + ], + "shader": "void main()\n{\n\tgl_PointSize = 10.0;\n \n \tvec2 xy = vec2(vertexId / 3.0, vertexId / 3.0);\n \n \tgl_Position = vec4(xy, 0.0, 1.0);\n \tv_color = vec4(0.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-rcrkuggsqkoe1a5gt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sYdAq9WutD8TN6uxp/art.json b/art/sYdAq9WutD8TN6uxp/art.json index eafebe62..90319027 100644 --- a/art/sYdAq9WutD8TN6uxp/art.json +++ b/art/sYdAq9WutD8TN6uxp/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-vucna6khkfe36l2eh-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sbPQY2SPAe2cbSP3K/art.json b/art/sbPQY2SPAe2cbSP3K/art.json index 8a92970f..0a55611e 100644 --- a/art/sbPQY2SPAe2cbSP3K/art.json +++ b/art/sbPQY2SPAe2cbSP3K/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minkicho", "avatarUrl": "https://secure.gravatar.com/avatar/d60bba6d40dad392ba0244fbcca8d579?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.11372549019607843,0.10196078431372549,1,1],\"shader\":\"// Minki Cho\\n// Circles from Triangles\\n// CS250 Spring 2022\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) \\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.11372549019607843, + 0.10196078431372549, + 1, + 1 + ], + "shader": "// Minki Cho\n// Circles from Triangles\n// CS250 Spring 2022\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) \n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-laubep6azpejdw1q0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sc6jikXkGhP7hihWb/art.json b/art/sc6jikXkGhP7hihWb/art.json index bf678afe..cd577a6c 100644 --- a/art/sc6jikXkGhP7hihWb/art.json +++ b/art/sc6jikXkGhP7hihWb/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6757,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/hugdealer/every-freakin-night-dj-0-0001-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, s, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, (sin(time * 3.)));\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nvoid main() {\\n float deep = floor(pow(vertexCount, 0.33333));\\n float down = floor(deep);\\n float across = floor(vertexCount / down / deep);\\n \\n float cx = mod(vertexId, across);\\n float cy = mod(floor(vertexId / across), down);\\n float cz = floor(vertexId / across / down);\\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.21;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n float rad = 4.;\\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, ce, cd) * 2.);\\n \\n vec3 pos = vec3(0);\\n \\n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\\n \\n gl_Position = mat * vec4(pos, 1);\\n \\n float sz = 1. - abs((gl_Position.z / gl_Position.w * .2+ .15));\\n gl_PointSize =pow(sz*2., s\\n ) * resolution.y / 476. * s* 302.;\\n \\n \\n\\n float hue = sz * 2. + s * 0.953;\\n float sat = 1.;\\n float val = s*2.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n \\n\"}", + "settings": { + "num": 6757, + "mode": "POINTS", + "sound": "https://soundcloud.com/hugdealer/every-freakin-night-dj-0-0001-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.20, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, s, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, (sin(time * 3.)));\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nvoid main() {\n float deep = floor(pow(vertexCount, 0.33333));\n float down = floor(deep);\n float across = floor(vertexCount / down / deep);\n \n float cx = mod(vertexId, across);\n float cy = mod(floor(vertexId / across), down);\n float cz = floor(vertexId / across / down);\n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.21;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n float rad = 4.;\n vec3 eye = vec3(cos(tm) * rad, sin(tm * 0.9) * rad * 1.1, sin(tm) * rad);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, ce, cd) * 2.);\n \n vec3 pos = vec3(0);\n \n float s = texture2D(sound, vec2(hash(vertexId / vertexCount), 4.)).a;\n \n gl_Position = mat * vec4(pos, 1);\n \n float sz = 1. - abs((gl_Position.z / gl_Position.w * .2+ .15));\n gl_PointSize =pow(sz*2., s\n ) * resolution.y / 476. * s* 302.;\n \n \n\n float hue = sz * 2. + s * 0.953;\n float sat = 1.;\n float val = s*2.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n \n" + }, "screenshotURL": "data/images/images-fu3w8o71hsua28djt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sdooECpbs5tTTw7AW/art.json b/art/sdooECpbs5tTTw7AW/art.json index 19da1b6d..25b1e218 100644 --- a/art/sdooECpbs5tTTw7AW/art.json +++ b/art/sdooECpbs5tTTw7AW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 1.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 18.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n //xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n lineId+=mod(time*10.,1.);\\n lineId/=numberOfElement;\\n\\n cubep*=0.04;// min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n \\n vec3 circleCenter = vec3(0.,0.,0.);\\n //circleCenter.x -= 5.;\\n \\n cubep.x += cos(lineId*2.*PI);//circleCenter.x;\\n cubep.z += sin(lineId*2.*PI);\\n //cubep = rot(circleCenter,PI/10.);\\n //cubep.x -= circleCenter.x;\\n \\n cubep.x += cos(xPos*2.*PI);\\n cubep.y += sin(xPos*2.*PI);\\n \\n\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n //cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0.2, 10., .2);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 0., -1.);\\n //cubep += distance(cubep, eye)/7.;\\n \\n //cubep.x += 0.2;\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 1.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 18.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n //xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n lineId+=mod(time*10.,1.);\n lineId/=numberOfElement;\n\n cubep*=0.04;// min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y+sndFactor*snd, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n \n vec3 circleCenter = vec3(0.,0.,0.);\n //circleCenter.x -= 5.;\n \n cubep.x += cos(lineId*2.*PI);//circleCenter.x;\n cubep.z += sin(lineId*2.*PI);\n //cubep = rot(circleCenter,PI/10.);\n //cubep.x -= circleCenter.x;\n \n cubep.x += cos(xPos*2.*PI);\n cubep.y += sin(xPos*2.*PI);\n \n\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n //cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0.2, 10., .2);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 0., -1.);\n //cubep += distance(cubep, eye)/7.;\n \n //cubep.x += 0.2;\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-fxnpktsolu1ja6ool-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/seEL2RtaERajKZKbT/art.json b/art/seEL2RtaERajKZKbT/art.json index b89d9482..d4b003ac 100644 --- a/art/seEL2RtaERajKZKbT/art.json +++ b/art/seEL2RtaERajKZKbT/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n#define timeFactor 0.05//KParameter 0.>>1.\\n#define PointSizeValue 2.//KParameter 1.>>4.\\n#define colorFactorR 0.//KParameter 0.>>1.\\n#define colorFactorG 0.//KParameter 0.>>1.\\n#define colorFactorB 0.//KParameter 0.>>1.\\n\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n \\n float localVertexId = floor( mod(vertexId,vertexCount/2.) );\\n \\n // more or less random movement\\n float t = time*timeFactor;\\n float i = localVertexId+sin(localVertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(colorFactorR,colorFactorG,colorFactorB);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n if(vertexId>=(vertexCount/2.))\\n {\\n gl_Position.x = -gl_Position.x;\\n }\\n \\n gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n#define timeFactor 0.05//KParameter 0.>>1.\n#define PointSizeValue 2.//KParameter 1.>>4.\n#define colorFactorR 0.//KParameter 0.>>1.\n#define colorFactorG 0.//KParameter 0.>>1.\n#define colorFactorB 0.//KParameter 0.>>1.\n\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n \n float localVertexId = floor( mod(vertexId,vertexCount/2.) );\n \n // more or less random movement\n float t = time*timeFactor;\n float i = localVertexId+sin(localVertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(colorFactorR,colorFactorG,colorFactorB);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n if(vertexId>=(vertexCount/2.))\n {\n gl_Position.x = -gl_Position.x;\n }\n \n gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,0.2);\n}" + }, "screenshotURL": "data/images/images-verli37dsbcrqwktg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sfTopMcw7ctmNhjJL/art.json b/art/sfTopMcw7ctmNhjJL/art.json index ea7ec9db..e467761f 100644 --- a/art/sfTopMcw7ctmNhjJL/art.json +++ b/art/sfTopMcw7ctmNhjJL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "ilyadorosh", "avatarUrl": "https://avatars.githubusercontent.com/ilyadorosh?s=200", - "settings": "{\"num\":10000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\nvec3 inv(vec3 a){return 1.-a;}\\n\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n \\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n\\n float a = pos.x;\\n a = fract(sin(dot(floor(pos.xy*8.0+time*2.0),vec2(5.34,6.57)))*37.536);\\n //a=2.*a-1.;\\n vec3 color = vec3(a, -a, abs(a));\\n color = inv(color); \\n \\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n\\n v_color = vec4(color, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\nvec3 inv(vec3 a){return 1.-a;}\n\n\nvoid main() {\n float localTime = time + 20.0;\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n \n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n\n float a = pos.x;\n a = fract(sin(dot(floor(pos.xy*8.0+time*2.0),vec2(5.34,6.57)))*37.536);\n //a=2.*a-1.;\n vec3 color = vec3(a, -a, abs(a));\n color = inv(color); \n \n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n\n v_color = vec4(color, 1);\n}" + }, "screenshotURL": "data/images/images-fmf4u4b08aqjtuiac-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sfhL5D5YFCpH6NjJE/art.json b/art/sfhL5D5YFCpH6NjJE/art.json index ee983307..80ba09d1 100644 --- a/art/sfhL5D5YFCpH6NjJE/art.json +++ b/art/sfhL5D5YFCpH6NjJE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":26109,\"mode\":\"TRIANGLES\",\"sound\":\"feedback\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define parameter0 1.//KParameter 0.>>6.\\n#define P2 3.//KParameter 0.>>10.\\n#define P3 3.//KParameter 0.>>3.\\n#define P6 3.//KParameter 0.1>>10.\\n#define P5 1.//KParameter 0.>>3.\\n//KVerticesNumber=2000\\n\\n\\n//KDrawmode=GL_TRIANGLE\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mouse.x,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 1000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 6. *fract(mouse.x-mouse.y)));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + mouse.y * r;\\n float y = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.02 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos,sin(1.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *1.001;\\n float sat = 0.;\\n float val = vertexCount/(vertexId * 21.)*0.6;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 26109, + "mode": "TRIANGLES", + "sound": "feedback", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define parameter0 1.//KParameter 0.>>6.\n#define P2 3.//KParameter 0.>>10.\n#define P3 3.//KParameter 0.>>3.\n#define P6 3.//KParameter 0.1>>10.\n#define P5 1.//KParameter 0.>>3.\n//KVerticesNumber=2000\n\n\n//KDrawmode=GL_TRIANGLE\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mouse.x,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 1000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 6. *fract(mouse.x-mouse.y)));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + mouse.y * r;\n float y = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.02 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 10.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos,sin(1.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *1.001;\n float sat = 0.;\n float val = vertexCount/(vertexId * 21.)*0.6;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-ttevduz05ve66tpij-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sfkanHudyxsBjm2BE/art.json b/art/sfkanHudyxsBjm2BE/art.json index 5d305cc5..d36567c8 100644 --- a/art/sfkanHudyxsBjm2BE/art.json +++ b/art/sfkanHudyxsBjm2BE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":95256,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/peterjosephberkman/ifl\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 1, 1, 1,\\n 1, c, s, 0,\\n 0, -s, c, 1,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 1,\\n 1, 0, 0, 1,\\n s, 0, c, 1,\\n 1, 0, 1, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 1, \\n s, c, 0, 0,\\n 0, 0, 0, 0,\\n 1, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 1, 1, 0,\\n 0, 1, 0, 1,\\n 1, 0, 1, 1,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 1,\\n 0, s[0], 1, 0,\\n 0, 1, s[0], 0,\\n 1, 0, 0, 0);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 1, 1, 0,\\n 1, s, 0, 1,\\n 1, 0, s, 1,\\n 0, 1, 1, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 2, 2, 2,\\n 2, f, 1, 1,\\n 1, 2, (zNear + zFar) * rangeInv, -1,\\n 0, 2, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[3][3], m[3][3], m[3][3], \\n m[2][2], m[2][2], m[2][2], \\n m[0][2], m[1][2], m[2][1]);\\n vec3 t = -i * m[0].xyz;\\n \\n return mat4(\\n i[2], t[0], \\n i[1], t[1],\\n i[0], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 3,\\n yAxis, 2,\\n zAxis, 1,\\n eye, 0);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -3,\\n yAxis, -1,\\n zAxis, -2,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float su = abs(atan(ca, cb)) / PI;\\n float sv = length(vec2(ca, cb));\\n sv = mod(faceId, 2.) < 0.5 ? sv : 1. - sv; \\n float s = texture2D(sound, vec2(mix(0.05, 0.1, su) + faceId * 0.1, (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, mix(1.4, 2., faceId / 6.), s);\\n \\n float tm = time * 0.3;\\n float r = mix(20., 50., step(7., mod(time, 14.)));\\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip * 1.05, cb) * down * 1.);\\n mat *= uniformScale(1.);//mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2.2, s) + faceId * 0.15;\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0., 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), val);\\n gl_Position.z = mix(10000., gl_Position.z, val);\\n}\\n\\n\"}", + "settings": { + "num": 95256, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/peterjosephberkman/ifl", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 1, 1, 1,\n 1, c, s, 0,\n 0, -s, c, 1,\n 0, 0, 0, 0); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 1,\n 1, 0, 0, 1,\n s, 0, c, 1,\n 1, 0, 1, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 1, \n s, c, 0, 0,\n 0, 0, 0, 0,\n 1, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 1, 1, 0,\n 0, 1, 0, 1,\n 1, 0, 1, 1,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 1,\n 0, s[0], 1, 0,\n 0, 1, s[0], 0,\n 1, 0, 0, 0);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 1, 1, 0,\n 1, s, 0, 1,\n 1, 0, s, 1,\n 0, 1, 1, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 2, 2, 2,\n 2, f, 1, 1,\n 1, 2, (zNear + zFar) * rangeInv, -1,\n 0, 2, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[3][3], m[3][3], m[3][3], \n m[2][2], m[2][2], m[2][2], \n m[0][2], m[1][2], m[2][1]);\n vec3 t = -i * m[0].xyz;\n \n return mat4(\n i[2], t[0], \n i[1], t[1],\n i[0], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 3,\n yAxis, 2,\n zAxis, 1,\n eye, 0);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -3,\n yAxis, -1,\n zAxis, -2,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float su = abs(atan(ca, cb)) / PI;\n float sv = length(vec2(ca, cb));\n sv = mod(faceId, 2.) < 0.5 ? sv : 1. - sv; \n float s = texture2D(sound, vec2(mix(0.05, 0.1, su) + faceId * 0.1, (sv) / 2. * .2)).a;\n \n s = mix(0.0, mix(1.4, 2., faceId / 6.), s);\n \n float tm = time * 0.3;\n float r = mix(20., 50., step(7., mod(time, 14.)));\n mat4 mat = persp(radians(90.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip * 1.05, cb) * down * 1.);\n mat *= uniformScale(1.);//mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2.2, s) + faceId * 0.15;\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0., 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), val);\n gl_Position.z = mix(10000., gl_Position.z, val);\n}\n\n" + }, "screenshotURL": "data/images/images-9pep6scyyp43uyhu0-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sgg5X7iFw5d2SLzwX/art.json b/art/sgg5X7iFw5d2SLzwX/art.json index 0ee6bb4c..edb00bba 100644 --- a/art/sgg5X7iFw5d2SLzwX/art.json +++ b/art/sgg5X7iFw5d2SLzwX/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// very long playlist:\\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\\n\\n// lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main () {\\n \\n float freq = vertexId / vertexCount;\\n float s = texture2D(sound, vec2(freq, 0.0)).a - 0.5;\\n float v = texture2D(volume, vec2(0, 0.0)).a - 0.5;\\n float f = texture2D(floatSound, vec2(freq, 0.0)).a * 0.01 + 0.5;\\n \\n float id = mod(vertexId, 3.0);\\n float y0 = mix(s, v, step(0.5, id));\\n float y = mix(y0, f, step(1.5, id));\\n \\n float x = freq * 2.0 - 1.0;\\n \\n vec3 hsv = vec3(vertexId / 3.0, 1.0, 1.0);\\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n\\n gl_PointSize = 5.0;\\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// very long playlist:\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\n\n// lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main () {\n \n float freq = vertexId / vertexCount;\n float s = texture2D(sound, vec2(freq, 0.0)).a - 0.5;\n float v = texture2D(volume, vec2(0, 0.0)).a - 0.5;\n float f = texture2D(floatSound, vec2(freq, 0.0)).a * 0.01 + 0.5;\n \n float id = mod(vertexId, 3.0);\n float y0 = mix(s, v, step(0.5, id));\n float y = mix(y0, f, step(1.5, id));\n \n float x = freq * 2.0 - 1.0;\n \n vec3 hsv = vec3(vertexId / 3.0, 1.0, 1.0);\n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n\n gl_PointSize = 5.0;\n\n}" + }, "screenshotURL": "data/images/images-8yl1wdtntsatb0vqo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sh2fiodFgyJZRA5kn/art.json b/art/sh2fiodFgyJZRA5kn/art.json index 3a432cbc..b7f4ad6f 100644 --- a/art/sh2fiodFgyJZRA5kn/art.json +++ b/art/sh2fiodFgyJZRA5kn/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":17729,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Colors\\n//cs250\\n//spring2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 17729, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Colors\n//cs250\n//spring2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-6302wfdqcl7l7ckh6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/shSEhMvvTzScwX6xx/art.json b/art/shSEhMvvTzScwX6xx/art.json index d69ddc38..6c184411 100644 --- a/art/shSEhMvvTzScwX6xx/art.json +++ b/art/shSEhMvvTzScwX6xx/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "phi16", "avatarUrl": "https://lh6.googleusercontent.com/-EMFaalZS9Rg/AAAAAAAAAAI/AAAAAAAAAjg/SGZ_70U2Idc/photo.jpg", - "settings": "{\"num\":80000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rand(vec2 co) {\\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\\n}\\n\\nfloat noise(vec2 r) {\\n\\tvec2 p = floor(r);\\n vec2 f = fract(r);\\n f = smoothstep(0.,1.,f);\\n vec2 e = vec2(0,1);\\n float p00 = rand(p+e.xx);\\n float p01 = rand(p+e.xy);\\n float p10 = rand(p+e.yx);\\n float p11 = rand(p+e.yy);\\n\\treturn mix(\\n mix(p00,p01,f.y),\\n mix(p10,p11,f.y),\\n f.x) - 0.5;\\n}\\n\\nfloat ot(vec2 r) {\\n\\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\\n return v * 0.5 + 0.5;\\n}\\n\\nvoid shift(inout vec3 p) {\\n\\tp.y += pow(ot(p.xz),1.2)*0.5;\\n}\\n\\nvoid main() {\\n vec3 pos, color;\\n float alpha = 1.0;\\n vec2 div;\\n int i = int(mod(vertexId,6.));\\n if(i==0) {\\n div = vec2(-1,-1);\\n } else if(i==1) {\\n div = vec2(-1,1);\\n } else if(i==2) {\\n div = vec2(1,-1);\\n } else if(i==3) {\\n div = vec2(1,-1);\\n } else if(i==4) {\\n div = vec2(-1,1);\\n } else if(i==5) {\\n div = vec2(1,1);\\n }\\n if(vertexId < 6.) {\\n pos = vec3(0,0,100.);\\n pos.xy += div * 1000.;\\n color = vec3(0.03);\\n } else if(vertexId < 12.) {\\n pos = vec3(0,0.2,0);\\n pos.xz += div * 100.;\\n color = vec3(0,0,0.2);\\n } else if(vertexId < 4812.) {\\n float vid = vertexId-6.;\\n float unitIx = floor(vid/6.);\\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\\n p.x -= 20.5;\\n p *= 0.5;\\n vec2 origP = p;\\n \\n p += div * 0.25;\\n\\tpos = vec3(p.x,0,p.y);\\n shift(pos);\\n \\n color = vec3(0.1,0.1,0.3);\\n color *= noise(pos.xz) * 0.5 + 0.5;\\n \\n vec3 u = pos - vec3(1,1.5,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - abs(u.y*0.2);\\n \\n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\\n } else if(vertexId < 15000.) {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float per = time*3. + rand(vec2(unitIx,3));\\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\\n float th = rand(vec2(seed,0))*3.1415926535*2.;\\n th += rand(vec2(seed,1));\\n float rad = rand(vec2(seed,2))*10. + 0.2;\\n pos = vec3(cos(th),0,sin(th)) * rad;\\n float ww = rand(vec2(seed,4))*0.02;\\n float ww2 = rand(vec2(seed,6))*0.5;\\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\\n pos.y += 3.0;\\n pos.z -= 1.0;\\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\\n \\tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\\n } else {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float v = rand(vec2(unitIx,9.))*2.-1.;\\n float per = time * 0.02 * v;\\n float au = time*0.05 + rand(vec2(unitIx,10.));\\n pos = vec3(\\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\\n rand(vec2(unitIx,2.)) * 2.,\\n rand(vec2(unitIx,3.)) * 2. - 1.\\n );\\n pos.x += sin(au*3.1415926535*2.)*0.1;\\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\\n vec3 ddiv = vec3(div,0.);\\n float ra = time*(1. + rand(vec2(unitIx,8.)));\\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n ra *= 2.;\\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n float size = rand(vec2(unitIx,5.))+0.5;\\n pos += ddiv*0.01*size;\\n \\n vec3 u = pos - vec3(1,1.8,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - u.y*0.05;\\n \\n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\\n \\talpha = 0.;\\n }\\n vec3 cam = vec3(0.,1.,0.);\\n pos -= cam;\\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\\n\\n float near = 0.001;\\n float far = 1000.;\\n float fovy = 3.1415926535 * 0.4;\\n float aspect = resolution.x / resolution.y;\\n float f = 1. / tan(fovy / 2.);\\n mat4 P = mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0,0,-2./(far-near),1,\\n 0,0,-(far+near)/(far-near),1\\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\\n // 0, 0, -1, 0\\n );\\n gl_Position = P * vec4(pos,1.);\\n v_color = vec4(color,alpha);\\n}\"}", + "settings": { + "num": 80000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rand(vec2 co) {\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\n}\n\nfloat noise(vec2 r) {\n\tvec2 p = floor(r);\n vec2 f = fract(r);\n f = smoothstep(0.,1.,f);\n vec2 e = vec2(0,1);\n float p00 = rand(p+e.xx);\n float p01 = rand(p+e.xy);\n float p10 = rand(p+e.yx);\n float p11 = rand(p+e.yy);\n\treturn mix(\n mix(p00,p01,f.y),\n mix(p10,p11,f.y),\n f.x) - 0.5;\n}\n\nfloat ot(vec2 r) {\n\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\n return v * 0.5 + 0.5;\n}\n\nvoid shift(inout vec3 p) {\n\tp.y += pow(ot(p.xz),1.2)*0.5;\n}\n\nvoid main() {\n vec3 pos, color;\n float alpha = 1.0;\n vec2 div;\n int i = int(mod(vertexId,6.));\n if(i==0) {\n div = vec2(-1,-1);\n } else if(i==1) {\n div = vec2(-1,1);\n } else if(i==2) {\n div = vec2(1,-1);\n } else if(i==3) {\n div = vec2(1,-1);\n } else if(i==4) {\n div = vec2(-1,1);\n } else if(i==5) {\n div = vec2(1,1);\n }\n if(vertexId < 6.) {\n pos = vec3(0,0,100.);\n pos.xy += div * 1000.;\n color = vec3(0.03);\n } else if(vertexId < 12.) {\n pos = vec3(0,0.2,0);\n pos.xz += div * 100.;\n color = vec3(0,0,0.2);\n } else if(vertexId < 4812.) {\n float vid = vertexId-6.;\n float unitIx = floor(vid/6.);\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\n p.x -= 20.5;\n p *= 0.5;\n vec2 origP = p;\n \n p += div * 0.25;\n\tpos = vec3(p.x,0,p.y);\n shift(pos);\n \n color = vec3(0.1,0.1,0.3);\n color *= noise(pos.xz) * 0.5 + 0.5;\n \n vec3 u = pos - vec3(1,1.5,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - abs(u.y*0.2);\n \n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\n } else if(vertexId < 15000.) {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float per = time*3. + rand(vec2(unitIx,3));\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\n float th = rand(vec2(seed,0))*3.1415926535*2.;\n th += rand(vec2(seed,1));\n float rad = rand(vec2(seed,2))*10. + 0.2;\n pos = vec3(cos(th),0,sin(th)) * rad;\n float ww = rand(vec2(seed,4))*0.02;\n float ww2 = rand(vec2(seed,6))*0.5;\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\n pos.y += 3.0;\n pos.z -= 1.0;\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\n \tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\n } else {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float v = rand(vec2(unitIx,9.))*2.-1.;\n float per = time * 0.02 * v;\n float au = time*0.05 + rand(vec2(unitIx,10.));\n pos = vec3(\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\n rand(vec2(unitIx,2.)) * 2.,\n rand(vec2(unitIx,3.)) * 2. - 1.\n );\n pos.x += sin(au*3.1415926535*2.)*0.1;\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\n vec3 ddiv = vec3(div,0.);\n float ra = time*(1. + rand(vec2(unitIx,8.)));\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n ra *= 2.;\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n float size = rand(vec2(unitIx,5.))+0.5;\n pos += ddiv*0.01*size;\n \n vec3 u = pos - vec3(1,1.8,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - u.y*0.05;\n \n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\n \talpha = 0.;\n }\n vec3 cam = vec3(0.,1.,0.);\n pos -= cam;\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\n\n float near = 0.001;\n float far = 1000.;\n float fovy = 3.1415926535 * 0.4;\n float aspect = resolution.x / resolution.y;\n float f = 1. / tan(fovy / 2.);\n mat4 P = mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0,0,-2./(far-near),1,\n 0,0,-(far+near)/(far-near),1\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\n // 0, 0, -1, 0\n );\n gl_Position = P * vec4(pos,1.);\n v_color = vec4(color,alpha);\n}" + }, "screenshotURL": "data/images/images-ws2fs02k30i3sltt1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/siFxTFYwYALqTSCib/art.json b/art/siFxTFYwYALqTSCib/art.json index c2599ef9..c3369cb0 100644 --- a/art/siFxTFYwYALqTSCib/art.json +++ b/art/siFxTFYwYALqTSCib/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "robsouthgate4", "avatarUrl": "https://avatars.githubusercontent.com/robsouthgate4?s=200", - "settings": "{\"num\":500,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across); \\n float y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across -1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.5;\\n \\n\\tgl_Position = vec4(xy,0,1);\\n gl_PointSize = 10.;\\n \\tgl_PointSize *= 20. / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\tv_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 500, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \tfloat down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across); \n float y = floor(vertexId / across);\n \n \tfloat u = x / (across -1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.5;\n \n\tgl_Position = vec4(xy,0,1);\n gl_PointSize = 10.;\n \tgl_PointSize *= 20. / across;\n \tgl_PointSize *= resolution.x / 600.;\n \tv_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-qryic8vculpgtppbz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/siiR5CkBzKcRp6keX/art.json b/art/siiR5CkBzKcRp6keX/art.json index a3207f45..1cc3ceff 100644 --- a/art/siiR5CkBzKcRp6keX/art.json +++ b/art/siiR5CkBzKcRp6keX/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":95256,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n // mat *= uniformScale(1.);\\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0.2, 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n//test why\\n\"}", + "settings": { + "num": 95256, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/egroove/premiere-vonda7-tel-aviv-second-state-audio", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n // mat *= uniformScale(1.);\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0.2, 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n//test why\n" + }, "screenshotURL": "data/images/images-adqxsznmpse4p3oxk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/snE4Fu2qG9PmDKDgc/art.json b/art/snE4Fu2qG9PmDKDgc/art.json index 7b897ca5..21429b5d 100644 --- a/art/snE4Fu2qG9PmDKDgc/art.json +++ b/art/snE4Fu2qG9PmDKDgc/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":81691,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define KP0 mouse.x\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 1800.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\\nvoid main() {\\n float quadCount = POINTS_PER_LINE / 2.; \\n float v = vertexId / vertexCount;\\n float invV = 1. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = sin(vertexId* 2.) / 1200.;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.006, 0.61, spread), mix(0.25, 1., v))).a;\\n \\n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * .11 + vertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\\n time-sin(snd1*KP0);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 5.4)).xyz, 0.82);\\n gl_Position.z = -m1p1(v);\\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\\n gl_PointSize = 2.;\\n\\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\\n float sat = 0.2 + pow(snd0 + 0.2, 1.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), .2);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 81691, + "mode": "LINES", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n#define KP0 mouse.x\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 1800.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\nvoid main() {\n float quadCount = POINTS_PER_LINE / 2.; \n float v = vertexId / vertexCount;\n float invV = 1. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = sin(vertexId* 2.) / 1200.;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.006, 0.61, spread), mix(0.25, 1., v))).a;\n \n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 10.3 + vertexId * 0.01), goop(time * .11 + vertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\n time-sin(snd1*KP0);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 5.4)).xyz, 0.82);\n gl_Position.z = -m1p1(v);\n // gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 0.1;\n gl_PointSize = 2.;\n\n float hue = mix(0.85, 0.95, pow(snd0, 5.));\n float sat = 0.2 + pow(snd0 + 0.2, 1.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), .2);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-rghgsub1scakacdfl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/snffEbJSrbtrEQvka/art.json b/art/snffEbJSrbtrEQvka/art.json index 17072ac5..80ddce6c 100644 --- a/art/snffEbJSrbtrEQvka/art.json +++ b/art/snffEbJSrbtrEQvka/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//#ifdef GL_ES\\n//precision mediump float;\\n//#endif \\n\\n//#extension GL_OES_standard_derivatives : enable\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\nvec3 mod289(vec3 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\\nvec2 mod289(vec2 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\\nvec3 permute(vec3 x) { return mod289(((x*34.0)+1.0)*x); }\\n\\nfloat snoise(vec2 v) {\\n const vec4 C = vec4(0.211324865405187, // (3.0-sqrt(3.0))/6.0\\n 0.366025403784439, // 0.5*(sqrt(3.0)-1.0)\\n -0.577350269189626, // -1.0 + 2.0 * C.x\\n 0.024390243902439); // 1.0 / 41.0\\n vec2 i = floor(v + dot(v, C.yy) );\\n vec2 x0 = v - i + dot(i, C.xx);\\n vec2 i1;\\n i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);\\n vec4 x12 = x0.xyxy + C.xxzz;\\n x12.xy -= i1;\\n i = mod289(i); // Avoid truncation effects in permutation\\n vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))\\n + i.x + vec3(0.0, i1.x, 1.0 ));\\n\\n vec3 m = max(0.5 - vec3(dot(x0,x0), dot(x12.xy,x12.xy), dot(x12.zw,x12.zw)), 0.0);\\n m = m*m ;\\n m = m*m ;\\n vec3 x = 2.0 * fract(p * C.www) - 1.0;\\n vec3 h = abs(x) - 0.5;\\n vec3 ox = floor(x + 0.5);\\n vec3 a0 = x - ox;\\n m *= 1.79284291400159 - 0.85373472095314 * ( a0*a0 + h*h );\\n vec3 g;\\n g.x = a0.x * x0.x + h.x * x0.y;\\n g.yz = a0.yz * x12.xz + h.yz * x12.yw;\\n return 130.0 * dot(m, g);\\n}\\n\\nvoid main() {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n vec2 st = simFragCoord.xy/vertexResolution.xy;\\n st.x *= vertexResolution.x/vertexResolution.y;\\n vec3 color = vec3(0.0);\\n vec2 pos = vec2(st*3.);\\n\\n float DF = 0.0;\\n\\n // Add a random position\\n float a = 0.0;\\n vec2 vel = vec2(time*.1);\\n DF += snoise(pos+vel)*.25+.25;\\n\\n // Add a random position\\n a = snoise(pos*vec2(cos(time*0.15),sin(time*0.1))*0.1)*3.1415;\\n vel = vec2(cos(a),sin(a));\\n DF += snoise(pos+vel)*.5+.5;\\n\\n color = vec3( smoothstep(.7,.75,fract(DF)) );\\n\\n v_color = vec4(1.0-color,1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//#ifdef GL_ES\n//precision mediump float;\n//#endif \n\n//#extension GL_OES_standard_derivatives : enable\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\nvec3 mod289(vec3 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\nvec2 mod289(vec2 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\nvec3 permute(vec3 x) { return mod289(((x*34.0)+1.0)*x); }\n\nfloat snoise(vec2 v) {\n const vec4 C = vec4(0.211324865405187, // (3.0-sqrt(3.0))/6.0\n 0.366025403784439, // 0.5*(sqrt(3.0)-1.0)\n -0.577350269189626, // -1.0 + 2.0 * C.x\n 0.024390243902439); // 1.0 / 41.0\n vec2 i = floor(v + dot(v, C.yy) );\n vec2 x0 = v - i + dot(i, C.xx);\n vec2 i1;\n i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);\n vec4 x12 = x0.xyxy + C.xxzz;\n x12.xy -= i1;\n i = mod289(i); // Avoid truncation effects in permutation\n vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))\n + i.x + vec3(0.0, i1.x, 1.0 ));\n\n vec3 m = max(0.5 - vec3(dot(x0,x0), dot(x12.xy,x12.xy), dot(x12.zw,x12.zw)), 0.0);\n m = m*m ;\n m = m*m ;\n vec3 x = 2.0 * fract(p * C.www) - 1.0;\n vec3 h = abs(x) - 0.5;\n vec3 ox = floor(x + 0.5);\n vec3 a0 = x - ox;\n m *= 1.79284291400159 - 0.85373472095314 * ( a0*a0 + h*h );\n vec3 g;\n g.x = a0.x * x0.x + h.x * x0.y;\n g.yz = a0.yz * x12.xz + h.yz * x12.yw;\n return 130.0 * dot(m, g);\n}\n\nvoid main() {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n vec2 st = simFragCoord.xy/vertexResolution.xy;\n st.x *= vertexResolution.x/vertexResolution.y;\n vec3 color = vec3(0.0);\n vec2 pos = vec2(st*3.);\n\n float DF = 0.0;\n\n // Add a random position\n float a = 0.0;\n vec2 vel = vec2(time*.1);\n DF += snoise(pos+vel)*.25+.25;\n\n // Add a random position\n a = snoise(pos*vec2(cos(time*0.15),sin(time*0.1))*0.1)*3.1415;\n vel = vec2(cos(a),sin(a));\n DF += snoise(pos+vel)*.5+.5;\n\n color = vec3( smoothstep(.7,.75,fract(DF)) );\n\n v_color = vec4(1.0-color,1.0);\n}" + }, "screenshotURL": "data/images/images-8yms5dy2ad8oznpj9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/soQPRE79HZt8hAGAh/art.json b/art/soQPRE79HZt8hAGAh/art.json index 3736a837..cd36cf9d 100644 --- a/art/soQPRE79HZt8hAGAh/art.json +++ b/art/soQPRE79HZt8hAGAh/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "ארד", "avatarUrl": "https://lh4.googleusercontent.com/-8413R_UAuFI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdV_Fow1wVvKUVUEHJI563QumRktQ/photo.jpg", - "settings": "{\"num\":81,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.5019607843137255,0,1],\"shader\":\"#define TOP_WIDTH 0.4\\n#define BOTTOM_WIDTH 0.1\\n#define HEIGHT 0.5\\n\\nvoid main(){\\n float columnCount = vertexCount / 2.0;\\n \\n float ux = (floor(vertexId / 2.0) / (columnCount - 1.0) * (TOP_WIDTH - BOTTOM_WIDTH)) + BOTTOM_WIDTH;\\n \\n float x = (mod(vertexId, 2.0) * 2.0 - 1.0) * ux;\\n float y = sqrt(floor(vertexId / 2.0) / (columnCount - 1.0)) * HEIGHT;\\n \\n gl_PointSize = 10.0;\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n \\n float baseColor = mod(vertexId, vertexCount) / vertexCount;\\n v_color = vec4(baseColor, 1.0 - baseColor, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 81, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.5019607843137255, + 0, + 1 + ], + "shader": "#define TOP_WIDTH 0.4\n#define BOTTOM_WIDTH 0.1\n#define HEIGHT 0.5\n\nvoid main(){\n float columnCount = vertexCount / 2.0;\n \n float ux = (floor(vertexId / 2.0) / (columnCount - 1.0) * (TOP_WIDTH - BOTTOM_WIDTH)) + BOTTOM_WIDTH;\n \n float x = (mod(vertexId, 2.0) * 2.0 - 1.0) * ux;\n float y = sqrt(floor(vertexId / 2.0) / (columnCount - 1.0)) * HEIGHT;\n \n gl_PointSize = 10.0;\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n \n float baseColor = mod(vertexId, vertexCount) / vertexCount;\n v_color = vec4(baseColor, 1.0 - baseColor, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-dc8cnx2q7gt9gydjl-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sofn3Bs4vuERfBH8b/art.json b/art/sofn3Bs4vuERfBH8b/art.json index 7e3a2a2d..3d6a5372 100644 --- a/art/sofn3Bs4vuERfBH8b/art.json +++ b/art/sofn3Bs4vuERfBH8b/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "ray7551", "avatarUrl": "https://avatars.githubusercontent.com/ray7551?s=200", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\nconst float a = 1.641, b = 1.902, c = 0.316, d= 1.525;\\nvoid stepPos() {\\n}\\n\\nvoid main() {\\n float t = vertexId / vertexCount;\\n float t1 = mod(vertexId, 4.);\\n //gl_Position.x = sin(a * prevPos.z) * t1- cos(b * prevPos.x) * t1;\\n //gl_Position.y = sin(c * prevPos.x) * t1- cos(d * prevPos.z) * t1;\\n gl_Position.z = 0.;//sin(c * prevPos.x) * t1- cos(d * prevPos.z) * t1;\\n //t * (sin(t * 10. ) + sin(t1 * 10.));//prevPos.z;\\n \\n if(vertexId == 1.) {\\n gl_Position.xyz = vec3(0., 0., 0.);\\n }\\n //gl_Position.w = prevPos.z;\\n\\n float hue = (time * 0.01 + vertexId * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\nconst float a = 1.641, b = 1.902, c = 0.316, d= 1.525;\nvoid stepPos() {\n}\n\nvoid main() {\n float t = vertexId / vertexCount;\n float t1 = mod(vertexId, 4.);\n //gl_Position.x = sin(a * prevPos.z) * t1- cos(b * prevPos.x) * t1;\n //gl_Position.y = sin(c * prevPos.x) * t1- cos(d * prevPos.z) * t1;\n gl_Position.z = 0.;//sin(c * prevPos.x) * t1- cos(d * prevPos.z) * t1;\n //t * (sin(t * 10. ) + sin(t1 * 10.));//prevPos.z;\n \n if(vertexId == 1.) {\n gl_Position.xyz = vec3(0., 0., 0.);\n }\n //gl_Position.w = prevPos.z;\n\n float hue = (time * 0.01 + vertexId * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-js76i65jpioebwo6u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/sph6PXJZqMbGaLSkY/art.json b/art/sph6PXJZqMbGaLSkY/art.json index be2b5cbf..efc70bdd 100644 --- a/art/sph6PXJZqMbGaLSkY/art.json +++ b/art/sph6PXJZqMbGaLSkY/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "brendon", "avatarUrl": "https://lh6.googleusercontent.com/-gsD8A6mNaf8/AAAAAAAAAAI/AAAAAAAAA8Q/XILS5Uddduw/photo.jpg", - "settings": "{\"num\":2000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n float n = vertexId / vertexCount;\\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \\n float angle = n * 6.28;\\n \\n float avx = 0.5;\\n float axy = 0.5;\\n \\n float dx = cos(angle * time * avx) * vertexId / 1000.0;\\n float dy = sin(angle * time * axy) * vertexId / 1000.0;\\n \\n gl_Position = vec4(dx, dy, 0.0, 1);\\n gl_PointSize = vertexId / 0.0;\\n v_color = vec4(snd.a, n, cos(time * n), 1.0);\\n}\"}", + "settings": { + "num": 2000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aeon-audio-studio/vitalism-gradus-full-production", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n float n = vertexId / vertexCount;\n vec4 snd = texture2D(sound, vec2(0.0, 0.0)); \n float angle = n * 6.28;\n \n float avx = 0.5;\n float axy = 0.5;\n \n float dx = cos(angle * time * avx) * vertexId / 1000.0;\n float dy = sin(angle * time * axy) * vertexId / 1000.0;\n \n gl_Position = vec4(dx, dy, 0.0, 1);\n gl_PointSize = vertexId / 0.0;\n v_color = vec4(snd.a, n, cos(time * n), 1.0);\n}" + }, "screenshotURL": "data/images/images-5dhm2uki4mm72wt5r-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sr2hRa3R2XYEKwJyC/art.json b/art/sr2hRa3R2XYEKwJyC/art.json index ae63d3bd..bb683331 100644 --- a/art/sr2hRa3R2XYEKwJyC/art.json +++ b/art/sr2hRa3R2XYEKwJyC/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9439,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP \\n\\n\\n#define K0 7.//KParameter0 0.>>1000.\\n#define K1 11.//KParameter1 0.0>>22.\\n#define KP2 1.//KParameter2 0.0>>10.\\n#define KP3 0.//KParameter3 0.000>>0.5\\n#define KP4 0.//KParameter4 0.000>>5.\\n#define KP5 (100.0*(1.0+mouse.x))//KParameter5 30.000>>90000.0\\n\\n\\n#define PI radians(180.)\\n\\n #define KP1 (K0 * mouse.x)\\n#define KP0 (K1 * mouse.y)\\n\\n#define vertexCount(KP5)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = tan(angleInRadians);\\n \\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 0,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 9.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.6;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., 1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.125;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 6)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 3.);\\n float side = mix(-1., 1., step(1.5, mod(circleId, 0.2)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(0.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.25,\\n gy - (gDown - 1.) / 2.,\\n 0.5) * cos(0.17 + KP1);\\n \\n float gs = gx / (gAcross-KP3 );\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (1.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.7;\\n float end = 2./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1.1);\\n gl_PointSize = 4.;\\n\\n float hue = 2. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 9439, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP \n\n\n#define K0 7.//KParameter0 0.>>1000.\n#define K1 11.//KParameter1 0.0>>22.\n#define KP2 1.//KParameter2 0.0>>10.\n#define KP3 0.//KParameter3 0.000>>0.5\n#define KP4 0.//KParameter4 0.000>>5.\n#define KP5 (100.0*(1.0+mouse.x))//KParameter5 30.000>>90000.0\n\n\n#define PI radians(180.)\n\n #define KP1 (K0 * mouse.x)\n#define KP0 (K1 * mouse.y)\n\n#define vertexCount(KP5)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.0));\n vec4 K = vec4(1.0, 2.0 / KP1 *3.0, 1.0 / (0.0-KP3), 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.yxz);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = tan(angleInRadians);\n \n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 0,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye),2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(1.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 9.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.)* 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.2;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.6;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., 1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.125;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 6)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 3.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 5.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 3.);\n float side = mix(-1., 1., step(1.5, mod(circleId, 0.2)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(0.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. * mod(gy, 2.) * 0.25,\n gy - (gDown - 1.) / 2.,\n 0.5) * cos(0.17 + KP1);\n \n float gs = gx / (gAcross-KP3 );\n float gt = (gy / gDown);\n\n float tm = time - cgv * (1.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 1.5, gs*3.), gt * (11.5 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.7;\n float end = 2./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0,1); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * -.2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.100 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 0.1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1.1);\n gl_PointSize = 4.;\n\n float hue = 2. + cgId * 0.4;\n float sat = 1. - step(pow(s, 1.), abs(gt * 12. - 1.3) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (0.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-n0tsrgasjjq1sqt3s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/srEzQEq8iaczPwERC/art.json b/art/srEzQEq8iaczPwERC/art.json index b74548ef..9bef6409 100644 --- a/art/srEzQEq8iaczPwERC/art.json +++ b/art/srEzQEq8iaczPwERC/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/dj-wonkar/easy-funk-edit\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define ACROSS 8.\\n#define DOWN 10.\\n#define PER_AREA ((ACROSS - 0.61) * (DOWN + 12.) *1.1)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz,.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0,1.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx-0.1, 0.14,0.5), c.y);\\n}\\n\\nvec4 area(float vertexId, float areaId) {\\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 1.)) * 2., 5.);\\n float thingId = floor(vertexId - 1.);\\n float col = mod(thingId, ACROSS +0.5);\\n float row = floor(thingId / (ACROSS - 10.5));\\n float u = col / ACROSS;\\n float v = row / DOWN;\\n float x = u * 2. - 1.;\\n float y = v * 1. - 1.;\\n \\n float d = length(vec2(x, y) *2.);\\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / 11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\\n float sv = d * 0.1;\\n float snd = texture2D(sound, vec2(su * 0.25 / 8. * areaId, sv)).a;\\n \\n float r = 0.4 + pow(snd, 8.) * -3.15;\\n float a = pointId / 5. * PI * (2. + thingId * 0.005 + time) / 12.;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = cs * y - r;\\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\\n \\n float hue = (time * 0.01) * areaId / 2.;\\n \\n return vec4(\\n vec2(x * snd, y * snd) - 0.1 / xy / aspect,\\n snd,\\n hue) * 2.5 ;\\n}\\n\\nvoid main() {\\n gl_PointSize =1.0;\\n\\n float areaId = floor(vertexId / PER_AREA);\\n float aCol = mod(areaId,2.);\\n float aRow = floor(areaId / 3.)/3.2;\\n float ax = (aCol - 0.01) - (0.4 / 2.) /12.2;\\n float ay = (aRow - 0.5) / 2. * 1.8 * .21;\\n float avId = mod(vertexId, PER_AREA)*112.01; \\n \\n vec4 a = area(avId, areaId);\\n \\n gl_Position = vec4(a.xy *- vec2(1.125, -0.4) * vec2(ax, ay), 0.01, 2);\\n float snd = a.z;\\n float hue = a.w;\\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/dj-wonkar/easy-funk-edit", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define ACROSS 8.\n#define DOWN 10.\n#define PER_AREA ((ACROSS - 0.61) * (DOWN + 12.) *1.1)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz,.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0,1.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx-0.1, 0.14,0.5), c.y);\n}\n\nvec4 area(float vertexId, float areaId) {\n // 0, 2, 2, 4, 4, 1, 3, 3, 0\n float pointId = mod((floor(vertexId / 2.) + mod(vertexId, 1.)) * 2., 5.);\n float thingId = floor(vertexId - 1.);\n float col = mod(thingId, ACROSS +0.5);\n float row = floor(thingId / (ACROSS - 10.5));\n float u = col / ACROSS;\n float v = row / DOWN;\n float x = u * 2. - 1.;\n float y = v * 1. - 1.;\n \n float d = length(vec2(x, y) *2.);\n float su = mod(PI * 2.5 + atan(y ,x) + areaId / 11.3 * PI + 2. + time, PI * 2.) / (PI * 2.);\n float sv = d * 0.1;\n float snd = texture2D(sound, vec2(su * 0.25 / 8. * areaId, sv)).a;\n \n float r = 0.4 + pow(snd, 8.) * -3.15;\n float a = pointId / 5. * PI * (2. + thingId * 0.005 + time) / 12.;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = cs * y - r;\n vec2 aspect = vec2(snd, resolution.x / resolution.y);\n \n float hue = (time * 0.01) * areaId / 2.;\n \n return vec4(\n vec2(x * snd, y * snd) - 0.1 / xy / aspect,\n snd,\n hue) * 2.5 ;\n}\n\nvoid main() {\n gl_PointSize =1.0;\n\n float areaId = floor(vertexId / PER_AREA);\n float aCol = mod(areaId,2.);\n float aRow = floor(areaId / 3.)/3.2;\n float ax = (aCol - 0.01) - (0.4 / 2.) /12.2;\n float ay = (aRow - 0.5) / 2. * 1.8 * .21;\n float avId = mod(vertexId, PER_AREA)*112.01; \n \n vec4 a = area(avId, areaId);\n \n gl_Position = vec4(a.xy *- vec2(1.125, -0.4) * vec2(ax, ay), 0.01, 2);\n float snd = a.z;\n float hue = a.w;\n v_color = vec4(mix(hsv2rgb(vec3(hue, 2.-snd, snd)), vec3(snd *1.15,1,0.5), 0.0), 1.0);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-3pjwimidgtt953622-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ssKvHBoYZGXuj88en/art.json b/art/ssKvHBoYZGXuj88en/art.json index 7bd37364..69d4983f 100644 --- a/art/ssKvHBoYZGXuj88en/art.json +++ b/art/ssKvHBoYZGXuj88en/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1156,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8901960784313725,0.40784313725490196,0.00784313725490196,1],\"shader\":\"void main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float ac = floor(vertexCount / down);\\n \\n float x = mod(vertexId, ac);\\n float y = floor(vertexId / ac);\\n \\n float u = x / (ac - 1.);\\n float v = y / (ac - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 25.5 * snd + 2.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1156, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8901960784313725, + 0.40784313725490196, + 0.00784313725490196, + 1 + ], + "shader": "void main()\n{\n float down = floor(sqrt(vertexCount));\n float ac = floor(vertexCount / down);\n \n float x = mod(vertexId, ac);\n float y = floor(vertexId / ac);\n \n float u = x / (ac - 1.);\n float v = y / (ac - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float snd = pow(texture2D(sound, vec2(u * 0.01, v * 0.01)).a, 4.);\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 25.5 * snd + 2.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-t4hn0ycil9ufaiq9s-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ssKwqvCp3dNhRbnLa/art.json b/art/ssKwqvCp3dNhRbnLa/art.json index d44721c5..f0d9141b 100644 --- a/art/ssKwqvCp3dNhRbnLa/art.json +++ b/art/ssKwqvCp3dNhRbnLa/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":22123,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/whippedcreammusic/popn11yuihuihyuihh\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.1, 2.2, 0.4) * 1.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 2.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 0.1 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(2.1, 1.2, 0.0)*3.;\\nfloat gExposure = 15.3;\\n\\nfloat gCubeColorRandom =3.8;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 2.8;\\nfloat gFloorHeight = -0.5;\\nfloat g_cameraFar = 1000.0;\\n#define PI radians( 185.0 -(mouse.y *5. -4.) )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 110.3, 10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 14.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-3., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 2.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 0.2)).xyz;\\n \\tv3 = (mat * vec4(v3, 0.5)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 1.,0.3,0.4 );\\n\\n outSceneVertex.fAlpha = 0.6; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 12.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, mouse.y * 3.0, 2.0*mouse.x);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, -0.2,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, -0.6, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n c, 0, 1, 0,\\n 0, s, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 0, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 172, 2 -mouse.x);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 2);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][2], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 - a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 + a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, -up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, -1,\\n zAxis, 0.11,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 3. - 0.5;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.5);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * (2. /mouse.y));\\n}\\n\\nconst float perBlock = 6.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 3.5));\\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.;\\n float z = vP * down * 1.4 + bzId * 0.;\\n vCubeOrigin.z += z-snd*5.; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 2, cos(time * 1.1) * 50.0);\\n float ca = 0.;\\n \\n // get sick!\\n ca = time * 0.1;\\n \\tvec3 vCameraUp = vec3( 0, 1, 0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(0.37) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.4), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 22123, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/whippedcreammusic/popn11yuihuihyuihh", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.1, 2.2, 0.4) * 1.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 2.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 0.1 ) * 1.5;\n\nvec3 gCubeColor = vec3(2.1, 1.2, 0.0)*3.;\nfloat gExposure = 15.3;\n\nfloat gCubeColorRandom =3.8;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 2.8;\nfloat gFloorHeight = -0.5;\nfloat g_cameraFar = 1000.0;\n#define PI radians( 185.0 -(mouse.y *5. -4.) )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 110.3, 10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, fract( 1.1 / vViewDir.y *8. ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 4.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 14.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-3., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 2.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 0.2)).xyz;\n \tv3 = (mat * vec4(v3, 0.5)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 + v1 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.001, 1.0, pow( 1.0 - NdotL, 8.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 1.,0.3,0.4 );\n\n outSceneVertex.fAlpha = 0.6; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.6, 0.5 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 12.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, mouse.y * 3.0, 2.0*mouse.x);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 0.6), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, -0.2,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, -0.6, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n c, 0, 1, 0,\n 0, s, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 0, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 172, 2 -mouse.x);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 2);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][2], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 - a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 + a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, -up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, -1,\n zAxis, 0.11,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), -1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 3. - 0.5;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.5);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * (2. /mouse.y));\n}\n\nconst float perBlock = 6.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 3.5));\n float snd = texture2D(sound, vec2(mix(0.01, 0.199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.;\n float z = vP * down * 1.4 + bzId * 0.;\n vCubeOrigin.z += z-snd*5.; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0., 0.0 );\n \tvec3 vCameraPos = vec3(sin(time * 0.1) * 50., 2, cos(time * 1.1) * 50.0);\n float ca = 0.;\n \n // get sick!\n ca = time * 0.1;\n \tvec3 vCameraUp = vec3( 0, 1, 0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(0.37) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.4), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-6ppzou4gx2du095ud-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/strzQyhv3SnhYWLrs/art.json b/art/strzQyhv3SnhYWLrs/art.json index 06b58138..baa4427f 100644 --- a/art/strzQyhv3SnhYWLrs/art.json +++ b/art/strzQyhv3SnhYWLrs/art.json @@ -20,7 +20,19 @@ }, "private": false, "username": "-anon-", - "settings": "{\"num\":3000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n //float osc = sin(4.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.03)).a,7.0);\\n float x = (u*60.0)-1.0;\\n float y = ((v+vold)*0.5);//*osc;\\n gl_PointSize = 20.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n //float osc = sin(4.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.03)).a,7.0);\n float x = (u*60.0)-1.0;\n float y = ((v+vold)*0.5);//*osc;\n gl_PointSize = 20.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n v_color = vec4(lum*0.6,lum*0.6,lum*1.0,v);\n}" + }, "screenshotURL": "data/images/images-j4dujddvhfkve6gva-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/suJcf7jB43TcT8x5X/art.json b/art/suJcf7jB43TcT8x5X/art.json index 54d0eab5..92d8a50b 100644 --- a/art/suJcf7jB43TcT8x5X/art.json +++ b/art/suJcf7jB43TcT8x5X/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":272,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 * 3.0, 0.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx * K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 272, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 * 3.0, 0.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx * K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-n01wh3zklbx8wxva2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/svRerLfafn3PP5Jif/art.json b/art/svRerLfafn3PP5Jif/art.json index b68d7480..28c72f45 100644 --- a/art/svRerLfafn3PP5Jif/art.json +++ b/art/svRerLfafn3PP5Jif/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seb0fh", "avatarUrl": "https://secure.gravatar.com/avatar/952c6ff0f2b9ef4d12f4664071f72153?default=retro&size=200", - "settings": "{\"num\":1838,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sebchevrel/ninetyseven\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n\\nvoid main()\\n{ \\n float numTurns = vertexCount/128.0;\\n float u = floor(vertexId/2.0) / (vertexCount/2.0);\\n float v = mod(vertexId,2.0);\\n \\n float snd = texture2D(volume, vec2(0.0,u*0.25)).a;\\n float snd2 = texture2D(volume, vec2(0.0,u*0.0625)).a;\\n \\n float lon = u * PI*2.0*numTurns; \\n float lat = u * PI - PI*0.5 + v*PI/numTurns*(snd*0.9+0.1);\\n \\n float h = sin(lat);\\n float rad = sqrt(1.0 - h * h) + snd2*0.5;\\n\\n vec3 nor = vec3(cos(lon)*rad, h , sin(lon)*rad);\\n \\n \\n \\n mat4 VP = persp(PI*0.25, resolution.x/resolution.y, 0.1, 10000.0) * cameraLookAt(vec3(0.0,1.0,5.0),vec3(0.0),vec3(0.0,1.0,0.0));\\n \\n gl_Position = VP * vec4(nor,1.0);\\n v_color = vec4(nor*0.5 + 0.5,1.0);\\n \\n}\"}", + "settings": { + "num": 1838, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sebchevrel/ninetyseven", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n\nvoid main()\n{ \n float numTurns = vertexCount/128.0;\n float u = floor(vertexId/2.0) / (vertexCount/2.0);\n float v = mod(vertexId,2.0);\n \n float snd = texture2D(volume, vec2(0.0,u*0.25)).a;\n float snd2 = texture2D(volume, vec2(0.0,u*0.0625)).a;\n \n float lon = u * PI*2.0*numTurns; \n float lat = u * PI - PI*0.5 + v*PI/numTurns*(snd*0.9+0.1);\n \n float h = sin(lat);\n float rad = sqrt(1.0 - h * h) + snd2*0.5;\n\n vec3 nor = vec3(cos(lon)*rad, h , sin(lon)*rad);\n \n \n \n mat4 VP = persp(PI*0.25, resolution.x/resolution.y, 0.1, 10000.0) * cameraLookAt(vec3(0.0,1.0,5.0),vec3(0.0),vec3(0.0,1.0,0.0));\n \n gl_Position = VP * vec4(nor,1.0);\n v_color = vec4(nor*0.5 + 0.5,1.0);\n \n}" + }, "screenshotURL": "data/images/images-jvy1otr1kog86tcd8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/swrTgKcxx4aJDe6hD/art.json b/art/swrTgKcxx4aJDe6hD/art.json index 152a933f..1aa8a036 100644 --- a/art/swrTgKcxx4aJDe6hD/art.json +++ b/art/swrTgKcxx4aJDe6hD/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/thomas-schumacher/thomas-schumacher-do-real\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nVertexShaderArt Boilerplate Library\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 3.;\\n float maxEdge = 16.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 4.5) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, fract(gv * 4.)), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 loc = fibonacciSphere(numGroups, groupId);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, 0.);\\n \\n mat4 wmat = rotY(time * .17);\\n wmat *= rotX(time * .13);\\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\\n wmat *= uniformScale(mix(0.6, 1., mv));\\n wmat *= rotZ(groupId * PI / 3.);\\n \\n \\n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = fract(gv * 4.) * .1 + time * .1 + groupId * 0.5;\\n float sat = .5;//step(pow(s, 3.), gt);\\n float val = mix(.5, 1., mod(groupId, 2.));\\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = dot(litDir, nrm) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/thomas-schumacher/thomas-schumacher-do-real", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nVertexShaderArt Boilerplate Library\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 3.;\n float maxEdge = 16.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 4.5) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, fract(gv * 4.)), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 loc = fibonacciSphere(numGroups, groupId);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, 0.);\n \n mat4 wmat = rotY(time * .17);\n wmat *= rotX(time * .13);\n wmat *= lookAt(loc * mix(15., 19.5, sv), vec3(0), up);\n wmat *= uniformScale(mix(0.6, 1., mv));\n wmat *= rotZ(groupId * PI / 3.);\n \n \n gl_Position = pmat * vmat * wmat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = fract(gv * 4.) * .1 + time * .1 + groupId * 0.5;\n float sat = .5;//step(pow(s, 3.), gt);\n float val = mix(.5, 1., mod(groupId, 2.));\n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = dot(litDir, nrm) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-qokrb55r4031kv29j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/sxuyK3fxSLJbouBDN/art.json b/art/sxuyK3fxSLJbouBDN/art.json index ef43bdc0..7676e83a 100644 --- a/art/sxuyK3fxSLJbouBDN/art.json +++ b/art/sxuyK3fxSLJbouBDN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":3096,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/darth-vader-the-deep-side-feature025\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\nJust a challenge to put both lines and dots in the same piece\\n\\nNote: I should really not be using my cirlce funciton which\\nis generating a square from 24 vertices instead of 6 but \\nI'm lazy and maybe using the circle funciton will generate\\nsome different results later.\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1.41421356237, vy);\\n float a = mix(start, end, u) * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#if 1\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float line = mod(circleId, 2.); // 1 if line, 0 if point\\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = line * .1;\\n \\n \\n float g0 = (groupId ) / numGroups;\\n float g1 = (groupId + 1.) / numGroups;\\n \\n float s0 = texture2D(sound, vec2(mix(.1, .5, g0), 0)).a;\\n float s1 = texture2D(sound, vec2(mix(.1, .5, g1), 0)).a;\\n \\n #if 0\\n float t = time * 0.1;\\n s0 = sin(t + g0 * 20.) * .5;\\n s1 = sin(t + g1 * 20.) * .5;\\n #endif\\n \\n vec2 p0 = vec2(t2m1(g0) * .9, s0 - .5);\\n vec2 p1 = vec2(t2m1(g1) * .9, s1 - .5);\\n vec2 dif = p1 - p0;\\n \\n float aspect = resolution.x / resolution.y;\\n mat4 mat = scale(vec3(1, aspect, 1));\\n \\n const float dotSize = .005;\\n const float lineWidth = .001;\\n \\n mat *= trans(vec3(p0, 0));\\n mat *= rotZ(atan(dif.x, dif.y) * line);\\n mat *= scale(mix(vec3(dotSize, dotSize, 1), vec3(lineWidth, length(dif) * .5, 1), line));\\n mat *= trans(vec3(0, line * 1.0, 0));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * .1 + gv * .2;\\n float sat = 1. - line;\\n float val = 1. - line * .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 3096, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/darth-vader-the-deep-side-feature025", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\nJust a challenge to put both lines and dots in the same piece\n\nNote: I should really not be using my cirlce funciton which\nis generating a square from 24 vertices instead of 6 but \nI'm lazy and maybe using the circle funciton will generate\nsome different results later.\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1.41421356237, vy);\n float a = mix(start, end, u) * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#if 1\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float line = mod(circleId, 2.); // 1 if line, 0 if point\n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = line * .1;\n \n \n float g0 = (groupId ) / numGroups;\n float g1 = (groupId + 1.) / numGroups;\n \n float s0 = texture2D(sound, vec2(mix(.1, .5, g0), 0)).a;\n float s1 = texture2D(sound, vec2(mix(.1, .5, g1), 0)).a;\n \n #if 0\n float t = time * 0.1;\n s0 = sin(t + g0 * 20.) * .5;\n s1 = sin(t + g1 * 20.) * .5;\n #endif\n \n vec2 p0 = vec2(t2m1(g0) * .9, s0 - .5);\n vec2 p1 = vec2(t2m1(g1) * .9, s1 - .5);\n vec2 dif = p1 - p0;\n \n float aspect = resolution.x / resolution.y;\n mat4 mat = scale(vec3(1, aspect, 1));\n \n const float dotSize = .005;\n const float lineWidth = .001;\n \n mat *= trans(vec3(p0, 0));\n mat *= rotZ(atan(dif.x, dif.y) * line);\n mat *= scale(mix(vec3(dotSize, dotSize, 1), vec3(lineWidth, length(dif) * .5, 1), line));\n mat *= trans(vec3(0, line * 1.0, 0));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * .1 + gv * .2;\n float sat = 1. - line;\n float val = 1. - line * .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-9pymiz6eysskllya2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/t6BweGrbMSz3TPJen/art.json b/art/t6BweGrbMSz3TPJen/art.json index 4844567f..b16beab7 100644 --- a/art/t6BweGrbMSz3TPJen/art.json +++ b/art/t6BweGrbMSz3TPJen/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Rotation speed\\nconst float Speed = 0.6;\\n\\n//Rotation Matrix\\nmat2 Rotate2D (float x) {\\n float a=sin(x), b=cos(x);\\n return mat2(b, -a, a, b);\\n}\\n\\nvoid main() {\\n vec2 pos = vec2(vertexId/vertexCount*1.5, Speed*sin(time)*0.5) * Rotate2D(Speed*time+vertexId);\\n vec3 clr = vec3(pos.x, pos.y, -pos.x);\\n \\n gl_PointSize = abs(pos.x)+abs(pos.y)*15.0;\\n gl_Position = vec4(pos, 0.0, 1.0);\\n v_color = vec4(clr, 1.0)+0.3;\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Rotation speed\nconst float Speed = 0.6;\n\n//Rotation Matrix\nmat2 Rotate2D (float x) {\n float a=sin(x), b=cos(x);\n return mat2(b, -a, a, b);\n}\n\nvoid main() {\n vec2 pos = vec2(vertexId/vertexCount*1.5, Speed*sin(time)*0.5) * Rotate2D(Speed*time+vertexId);\n vec3 clr = vec3(pos.x, pos.y, -pos.x);\n \n gl_PointSize = abs(pos.x)+abs(pos.y)*15.0;\n gl_Position = vec4(pos, 0.0, 1.0);\n v_color = vec4(clr, 1.0)+0.3;\n}" + }, "screenshotURL": "data/images/images-mh4woavdwdkp2ris5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/t9afzWHetyWR3bZSB/art.json b/art/t9afzWHetyWR3bZSB/art.json index 4f19e4e2..acc8ba58 100644 --- a/art/t9afzWHetyWR3bZSB/art.json +++ b/art/t9afzWHetyWR3bZSB/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres", "private": false, "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.45,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .5;\\n \\n pos.xy *= .5/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.5,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.45,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .5;\n \n pos.xy *= .5/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.5,1);\n}" + }, "screenshotURL": "data/images/images-fgqh8smjxsftw86md-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tBY967FHBHEfJkSwk/art.json b/art/tBY967FHBHEfJkSwk/art.json index 0edab9d1..60018d8d 100644 --- a/art/tBY967FHBHEfJkSwk/art.json +++ b/art/tBY967FHBHEfJkSwk/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "paul-jan", "avatarUrl": "https://secure.gravatar.com/avatar/40d0673cb04e3c59ed5f9086f215bb8d?default=retro&size=200", - "settings": "{\"num\":4000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5019607843137255,0.7843137254901961,0.5019607843137255,1],\"shader\":\"void main() {\\n float across = floor(sqrt(vertexCount));\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = 2.0 * u - 1.0;\\n float uy = 2.0 * v - 1.0;\\n \\n gl_Position = vec4(ux, uy, 0, 1);\\n gl_PointSize = 10.0 * 20.0 / across;\\n v_color = vec4(0.5, 1, 0.5, 1);\\n}\"}", + "settings": { + "num": 4000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5019607843137255, + 0.7843137254901961, + 0.5019607843137255, + 1 + ], + "shader": "void main() {\n float across = floor(sqrt(vertexCount));\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = 2.0 * u - 1.0;\n float uy = 2.0 * v - 1.0;\n \n gl_Position = vec4(ux, uy, 0, 1);\n gl_PointSize = 10.0 * 20.0 / across;\n v_color = vec4(0.5, 1, 0.5, 1);\n}" + }, "screenshotURL": "data/images/images-7eds5hm7pbhwc9eap-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tBoefnyLiLiAapP2L/art.json b/art/tBoefnyLiLiAapP2L/art.json index 27b14aea..4ab1d318 100644 --- a/art/tBoefnyLiLiAapP2L/art.json +++ b/art/tBoefnyLiLiAapP2L/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "spotline", - "settings": "{\"num\":1292,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/rainflash\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat rand(float seed)\\n{\\n return mod(1.0/seed * 123456.789456,1.0);\\n}\\n\\nfloat OneToScreen(float coor)\\n{\\n return coor * 2.0 - 1.0;\\n}\\n\\nvoid main() \\n{\\n \\tfloat random1 = rand(vertexId);\\n \\tfloat random2 = rand(vertexId+1000.0);\\n \\tfloat random3 = rand(vertexId+2000.0);\\n \\tfloat randomspeed = random1*5.0+0.1;\\n\\tfloat x = OneToScreen(mod(random1+time*randomspeed,1.0));\\n \\tfloat y = OneToScreen(random2);\\n \\tgl_PointSize = pow(random3,10.0)*4.0;\\n gl_Position = vec4(x,y,0,1);\\n \\tv_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 1292, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/rainflash", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat rand(float seed)\n{\n return mod(1.0/seed * 123456.789456,1.0);\n}\n\nfloat OneToScreen(float coor)\n{\n return coor * 2.0 - 1.0;\n}\n\nvoid main() \n{\n \tfloat random1 = rand(vertexId);\n \tfloat random2 = rand(vertexId+1000.0);\n \tfloat random3 = rand(vertexId+2000.0);\n \tfloat randomspeed = random1*5.0+0.1;\n\tfloat x = OneToScreen(mod(random1+time*randomspeed,1.0));\n \tfloat y = OneToScreen(random2);\n \tgl_PointSize = pow(random3,10.0)*4.0;\n gl_Position = vec4(x,y,0,1);\n \tv_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-p697w1vuschbersk4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tDL9nRCoBMvh9R7Zh/art.json b/art/tDL9nRCoBMvh9R7Zh/art.json index 1e44ce9d..f9f871bd 100644 --- a/art/tDL9nRCoBMvh9R7Zh/art.json +++ b/art/tDL9nRCoBMvh9R7Zh/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/rtype187/john-wayne\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.41568627450980394,0.18823529411764706,0.5372549019607843,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=TRIANGLES\\n\\n#define P1 1.//KParameter 0.>>4.\\n#define P2 2.//KParameter 0.>>11.\\n#define P3 1.//KParameter 0.1>>1.\\n\\n\\n\\n//KVerticesNumber=1000000\\n\\n#define PI radians(120.0)\\n\\n \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1.*P3); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * P2 - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time *.1+P3;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,-1.5);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5*P3);\\n mat *= rotZ(ud * PI * 0.15);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n mat == uniformScale(1.);\\n mat *= uniformScale(mix(1.1, 1., 1.1 - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.8, 0.4*P1, -1));\\n\\n float hue = mix(1.8, 2.4*su, s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 1.));\\n float sat = mix(1.0, 1.-s, step(0.95, s));\\n float val = mix(0.2, 1., step(0.19, su));\\n vec3 color = hsv2rgb(vec3(hue*0.27*P1, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 1.5);\\n v_color = vec4(color * pinch(lt, 3.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/rtype187/john-wayne", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.41568627450980394, + 0.18823529411764706, + 0.5372549019607843, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=TRIANGLES\n\n#define P1 1.//KParameter 0.>>4.\n#define P2 2.//KParameter 0.>>11.\n#define P3 1.//KParameter 0.1>>1.\n\n\n\n//KVerticesNumber=1000000\n\n#define PI radians(120.0)\n\n \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1.*P3); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * P2 - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(mouse.y +time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.83- mouse.x, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time *.1+P3;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,-1.5);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5*P3);\n mat *= rotZ(ud * PI * 0.15);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n mat == uniformScale(1.);\n mat *= uniformScale(mix(1.1, 1., 1.1 - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.8, 0.4*P1, -1));\n\n float hue = mix(1.8, 2.4*su, s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 1.));\n float sat = mix(1.0, 1.-s, step(0.95, s));\n float val = mix(0.2, 1., step(0.19, su));\n vec3 color = hsv2rgb(vec3(hue*0.27*P1, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 1.5);\n v_color = vec4(color * pinch(lt, 3.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-qlw8jqai18f2k15y1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tDPKDjEBxPf4GXgvv/art.json b/art/tDPKDjEBxPf4GXgvv/art.json index ee46eeec..1f756f3a 100644 --- a/art/tDPKDjEBxPf4GXgvv/art.json +++ b/art/tDPKDjEBxPf4GXgvv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = 1.;\\n float sat = 1.;\\n float val = 1.;\\n\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = 1.;\n float sat = 1.;\n float val = 1.;\n\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-mjfno8utejh66oj8m-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tDZd2w9DsKbz3CHm2/art.json b/art/tDZd2w9DsKbz3CHm2/art.json index dacad616..02dc3648 100644 --- a/art/tDZd2w9DsKbz3CHm2/art.json +++ b/art/tDZd2w9DsKbz3CHm2/art.json @@ -26,7 +26,19 @@ "name": "test", "private": true, "username": "fred1024", - "settings": "{\"num\":1959,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/klauslunde/let-it-go?in=fred-heintz/sets/fred\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = 0.0 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 1959, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/klauslunde/let-it-go?in=fred-heintz/sets/fred", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = 0.0 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + localTime * count * 0.01) * sin(orbitAngle);\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-i7r8iehln6uw7uwh2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tEAGWWrJv76hQhmjy/art.json b/art/tEAGWWrJv76hQhmjy/art.json index d4917f74..a0dc7edc 100644 --- a/art/tEAGWWrJv76hQhmjy/art.json +++ b/art/tEAGWWrJv76hQhmjy/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":581,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - make a grid\\n// spring 2022\\n\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n \\n\\tgl_Position = vec4(ux / 1.5 * cos(time), vy / 1.5 * sin(time), 0, 1);\\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= (40. / across) * vy * ux * abs(1. + cos(time * 2.));\\n //gl_PointSize *= resolution.x / 600.;\\n \\n float count = floor(vertexId / NUM_POINTS);\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue + time, 1, 1)), 1); \\n}\\n\\n\"}", + "settings": { + "num": 581, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - make a grid\n// spring 2022\n\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n \n\tgl_Position = vec4(ux / 1.5 * cos(time), vy / 1.5 * sin(time), 0, 1);\n gl_PointSize = 10.0;\n \n gl_PointSize *= (40. / across) * vy * ux * abs(1. + cos(time * 2.));\n //gl_PointSize *= resolution.x / 600.;\n \n float count = floor(vertexId / NUM_POINTS);\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue + time, 1, 1)), 1); \n}\n\n" + }, "screenshotURL": "data/images/images-5jv64db87fzhbhp3s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tEPdh34hM3fNGFFsg/art.json b/art/tEPdh34hM3fNGFFsg/art.json index ec1d87a0..555711a9 100644 --- a/art/tEPdh34hM3fNGFFsg/art.json +++ b/art/tEPdh34hM3fNGFFsg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .05; p = mod(p/7., 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n\\tc = rotate(c, max(-10.0, 2.3* time/2000.*sin( centerDistance + snd*time/5000.*sin(centerDistance))));\\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n \\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(pattern(3.*c));;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\nfloat pattern(vec2 p){p.x -= .866; p.x -= p.y * .05; p = mod(p/7., 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n\tc = rotate(c, max(-10.0, 2.3* time/2000.*sin( centerDistance + snd*time/5000.*sin(centerDistance))));\n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n \n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(pattern(3.*c));;\n \n\n}" + }, "screenshotURL": "data/images/images-r6g52ty6inwb7vge7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tF4ynbNrnHawnus9p/art.json b/art/tF4ynbNrnHawnus9p/art.json index ee9e9a4b..d6a4b496 100644 --- a/art/tF4ynbNrnHawnus9p/art.json +++ b/art/tF4ynbNrnHawnus9p/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"void main() {\\n\\tgl_PointSize = 10.0;\\n \\tgl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "void main() {\n\tgl_PointSize = 10.0;\n \tgl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-zodq1oypukyv9x70e-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tGCcoCiv9fi2S5rub/art.json b/art/tGCcoCiv9fi2S5rub/art.json index d9491845..97816bda 100644 --- a/art/tGCcoCiv9fi2S5rub/art.json +++ b/art/tGCcoCiv9fi2S5rub/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" #define ITERS 10\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define lineNumber 1.//KParameter0 1.>>10.\\n#define speedFactor 1.//KParameter1 1.>>5.\\n#define sndFactor 3.//KParameter7 0.>>5.\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n\\n\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n //gl_PointSize = 0.1;\\n float sizeFactor = 1./400.;\\n //float patternSize = sizeFactor*3.;\\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = lineNumber;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n xPos = xPos*2.-1.;\\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n vec4 cbNi;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\\n \\n \\n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\\n \\n \\n //LOGISTIC\\n \\n vec2 vp = vec2(0.,0.);\\n float z = fract(0.02+snd*snd);//sin(shapeRelId+fract(time/100.));//fract(0.02);\\n\\n float trig = (cos(2. * PI * z) + 1.) / 2.;\\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\\n \\n for (int i = 0; i < ITERS; i++) {\\n z = a * z * (1.-z);\\n }\\n float iters = float(ITERS);\\n \\n\\n cubep.y+= z;\\n cubep.x+= shapeRelId;\\n //END LOGISTIC\\n \\n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n //vec3 eye = vec3(0.5, 0.5, 1.5);\\n vec3 eye = vec3(0.5+sin(time/1.3)/4., 0.5+sin(time/1.)/4., cos(time/5.));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(color, 1.0);\\n //v_color.x = acc/10.;\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " #define ITERS 10\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define lineNumber 1.//KParameter0 1.>>10.\n#define speedFactor 1.//KParameter1 1.>>5.\n#define sndFactor 3.//KParameter7 0.>>5.\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n\n\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n //gl_PointSize = 0.1;\n float sizeFactor = 1./400.;\n //float patternSize = sizeFactor*3.;\n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = lineNumber;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n xPos = xPos*2.-1.;\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n vec4 cbNi;\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);;\n \n \n cubep*= min(lineId/10., 1.0)*sizeFactor;//resize\n \n \n //LOGISTIC\n \n vec2 vp = vec2(0.,0.);\n float z = fract(0.02+snd*snd);//sin(shapeRelId+fract(time/100.));//fract(0.02);\n\n float trig = (cos(2. * PI * z) + 1.) / 2.;\n float a = mix(1., 3.75, trig) + shapeRelId * mix(3., 0.25, trig);\n \n for (int i = 0; i < ITERS; i++) {\n z = a * z * (1.-z);\n }\n float iters = float(ITERS);\n \n\n cubep.y+= z;\n cubep.x+= shapeRelId;\n //END LOGISTIC\n \n //cubep = vec3(cubep.x+xPos, cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n //vec3 eye = vec3(0.5, 0.5, 1.5);\n vec3 eye = vec3(0.5+sin(time/1.3)/4., 0.5+sin(time/1.)/4., cos(time/5.));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n //vec3 eye = vec3(0., 1., 0.5);//29./2.*abs(cos(time/5.))\n vec3 color = shade(eye, cubep, cbNi.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n vec3 p = lookAt(cubep, eye, vec3(0.5, 0.5, 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 2.;\n \n v_color = vec4(color, 1.0);\n //v_color.x = acc/10.;\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-r19lz2ge9cchfmkf6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tGQbaSaJuQ5gAAcEk/art.json b/art/tGQbaSaJuQ5gAAcEk/art.json index 8957a3e8..47ef012c 100644 --- a/art/tGQbaSaJuQ5gAAcEk/art.json +++ b/art/tGQbaSaJuQ5gAAcEk/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":4000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ciccio-and-the-curran/clang\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define T radians(360.)\\n#define f float\\nf h(f p) {\\n vec2 p2 = fract(vec2(p*5.3983, p*5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n return fract(p2.x*p2.y*95.4337);\\n}\\nvec3 h3(f s) { return vec3(h(s),h(s*.731),h(s*1.319))*2.-1.; }\\nvec2 r(vec2 p,f a) { return vec2(p.x*cos(a)-p.y*sin(a), p.x*sin(a)+p.y*cos(a)); }\\nvec3 fk(f s,f x,f ff) {\\n vec3 p = vec3(r(vec2(ff*.5,0.),T*h(s*.311)),1);\\n p.xz = r(p.xz,T*floor(h(s*.731)*3.)/3.);\\n p.yz = r(p.yz,T*floor(h(s)*x)/x);\\n return p;\\n}\\nvec3 c(f s, f b) {\\n f a = h(s*0.911)*3.;\\n vec3 p = h3(s), A = vec3(1.-step(.5,a));\\n A.y = 1.-step(1.5,a)-A.x;\\n A.z = 1.-step(2.5,a)-A.x-A.y;\\n p = mix(step(0.,p)*2.-1.,p,mix(1.-A,A,b));\\n return p;\\n}\\nvec3 o(f t, f s) {\\n t = floor(mod(t, 7.));\\n if (t == 0.||t == 3.) return c(s,step(1.,t));\\n if (t == 1.||t == 4.) return normalize(h3(s))*mix(1.,h(s*2.117),step(2.,t));\\n if (t == 2.) return fk(s,3.,h(s*2.117));\\n if (t == 5.) return h3(s);\\n return fk(s,4.,1.);\\n}\\nvoid main() {\\n f r = 6.,m = 1./r,t=time,a=t*.2,b=fract(time),\\n u=step(.5,b),w=1.-2.*u,v=vertexId/vertexCount,s=v*4.+t*.01;\\n vec3 p = mix(o(t,s),o(t+1.,s),w*pow(2.,((40.*b)-20.)*w)*.5+u),e=vec3(cos(a)*r,sin(t)*2.,sin(a)*r);\\n f d = length(e), l=1./d,z=d-dot(p,e)*l;\\n gl_Position=vec4((p.x*e.z - p.z*e.x)*m*2.*resolution.y/resolution.x,(p.y*r-dot(p.xz,e.xz)*e.y*m)*l*2.,z-2.,z);\\n v_color = vec4(abs(p.x),p.y*cos(t*3.),abs(p.z),1);\\n gl_PointSize = 18./z;\\n}\"}", + "settings": { + "num": 4000, + "mode": "POINTS", + "sound": "https://soundcloud.com/ciccio-and-the-curran/clang", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define T radians(360.)\n#define f float\nf h(f p) {\n vec2 p2 = fract(vec2(p*5.3983, p*5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n return fract(p2.x*p2.y*95.4337);\n}\nvec3 h3(f s) { return vec3(h(s),h(s*.731),h(s*1.319))*2.-1.; }\nvec2 r(vec2 p,f a) { return vec2(p.x*cos(a)-p.y*sin(a), p.x*sin(a)+p.y*cos(a)); }\nvec3 fk(f s,f x,f ff) {\n vec3 p = vec3(r(vec2(ff*.5,0.),T*h(s*.311)),1);\n p.xz = r(p.xz,T*floor(h(s*.731)*3.)/3.);\n p.yz = r(p.yz,T*floor(h(s)*x)/x);\n return p;\n}\nvec3 c(f s, f b) {\n f a = h(s*0.911)*3.;\n vec3 p = h3(s), A = vec3(1.-step(.5,a));\n A.y = 1.-step(1.5,a)-A.x;\n A.z = 1.-step(2.5,a)-A.x-A.y;\n p = mix(step(0.,p)*2.-1.,p,mix(1.-A,A,b));\n return p;\n}\nvec3 o(f t, f s) {\n t = floor(mod(t, 7.));\n if (t == 0.||t == 3.) return c(s,step(1.,t));\n if (t == 1.||t == 4.) return normalize(h3(s))*mix(1.,h(s*2.117),step(2.,t));\n if (t == 2.) return fk(s,3.,h(s*2.117));\n if (t == 5.) return h3(s);\n return fk(s,4.,1.);\n}\nvoid main() {\n f r = 6.,m = 1./r,t=time,a=t*.2,b=fract(time),\n u=step(.5,b),w=1.-2.*u,v=vertexId/vertexCount,s=v*4.+t*.01;\n vec3 p = mix(o(t,s),o(t+1.,s),w*pow(2.,((40.*b)-20.)*w)*.5+u),e=vec3(cos(a)*r,sin(t)*2.,sin(a)*r);\n f d = length(e), l=1./d,z=d-dot(p,e)*l;\n gl_Position=vec4((p.x*e.z - p.z*e.x)*m*2.*resolution.y/resolution.x,(p.y*r-dot(p.xz,e.xz)*e.y*m)*l*2.,z-2.,z);\n v_color = vec4(abs(p.x),p.y*cos(t*3.),abs(p.z),1);\n gl_PointSize = 18./z;\n}" + }, "screenshotURL": "data/images/images-7tmaebgbnxpysec6z-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tJ9XYE3zGtX8Lp2fm/art.json b/art/tJ9XYE3zGtX8Lp2fm/art.json index 8b6190d7..c03e9ec7 100644 --- a/art/tJ9XYE3zGtX8Lp2fm/art.json +++ b/art/tJ9XYE3zGtX8Lp2fm/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/tiptop-audio-records/9-richard-devine-cr-hex-mutant\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾RDVINEZZ */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n#define BPM \\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = 21.;\\n float across = 21.;\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across), down);\\n float faceId = floor(cubeId / across / down);\\n \\n float sideId = mod(faceId, 3.);\\n float flip = mix(1., -1., step(2.5, faceId));\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cb = cv * 2. - 1.;\\n\\n float sv = length(vec2(ca, cb));\\n float su = abs(mod(atan(ca, cb) + floor(time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), (sv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 20.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n \\n mat *= trans(vec3(ca, flip, cb) * down * 1.);\\n // mat *= uniformScale(1.);\\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\\n float sat = mix(.0, 1., step(0.95, s));\\n float val = mix(0.2, 1., step(0.99, s));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * pinch(lt, 2.), 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/tiptop-audio-records/9-richard-devine-cr-hex-mutant", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾RDVINEZZ */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n#define BPM \n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = 21.;\n float across = 21.;\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across), down);\n float faceId = floor(cubeId / across / down);\n \n float sideId = mod(faceId, 3.);\n float flip = mix(1., -1., step(2.5, faceId));\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cb = cv * 2. - 1.;\n\n float sv = length(vec2(ca, cb));\n float su = abs(mod(atan(ca, cb) + floor(time / 1. - sv + faceId / 6.) * PI * .25, PI * 2.) - PI) / PI;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), (sv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 20.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n \n mat *= trans(vec3(ca, flip, cb) * down * 1.);\n // mat *= uniformScale(1.);\n mat *= uniformScale(mix(-0., 1., 1. - pow(s, 3.)));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = mix(1.8, 2., s) + mix(0.6, 0.95, mod(floor(time * 4. + faceId / 6. - sv), 2.));\n float sat = mix(.0, 1., step(0.95, s));\n float val = mix(0.2, 1., step(0.99, s));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * pinch(lt, 2.), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-cbpswjnvtko2ghkim-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tL9Q5Bx3AuuRT4JTx/art.json b/art/tL9Q5Bx3AuuRT4JTx/art.json index 523d5d0c..d8b1dde6 100644 --- a/art/tL9Q5Bx3AuuRT4JTx/art.json +++ b/art/tL9Q5Bx3AuuRT4JTx/art.json @@ -20,7 +20,19 @@ }, "private": true, "username": "-anon-", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28\\n#define PI 3.145191\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nfloat hash11(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nfloat hash12(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nfloat SmoothNoise(in vec2 o) \\n{\\n\\tvec2 p = floor(o);\\n\\tvec2 f = fract(o);\\n\\t\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\n\\tfloat a = hash11(n+ 0.0);\\n\\tfloat b = hash11(n+ 1.0);\\n\\tfloat c = hash11(n+ 57.0);\\n\\tfloat d = hash11(n+ 58.0);\\n\\t\\n\\tvec2 f2 = f * f;\\n\\tvec2 f3 = f2 * f;\\n\\t\\n\\tvec2 t = 3.0 * f2 - 2.0 * f3;\\n\\t\\n\\tfloat u = t.x;\\n\\tfloat v = t.y;\\n\\n\\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\\n \\n return res;\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float n = vertexId / vertexCount;\\n float z = vertexId / 2000.;\\n \\n float m = pow (n, 1.12);\\n float k = 1. - m;\\n \\n vec2 p;\\n\\n p = vec2(k * z * 0.7 * cos(0.7 * PI + time) * cos(time), k * z * 0.3 * sin(time));\\n \\n vec2 d = 0.3*vec2(z * cos(vertexId * TAU * 0.0051), z * sin(vertexId * TAU * 0.0051));\\n p += d + d * 0.1 * SmoothNoise(d + vec2(time, time) + hash12(d) * 0.4);\\n \\n p.xy *= resolution.yy / resolution.xy; \\n\\n gl_Position = vec4(p, 0., 1.);\\n \\n vec3 c = hsv2rgb(vec3(10. / 360. * time,mix(.6, 1., m), m));\\n \\n v_color = vec4(c,1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28\n#define PI 3.145191\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nfloat hash11(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nfloat hash12(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nfloat SmoothNoise(in vec2 o) \n{\n\tvec2 p = floor(o);\n\tvec2 f = fract(o);\n\t\t\n\tfloat n = p.x + p.y*57.0;\n\n\tfloat a = hash11(n+ 0.0);\n\tfloat b = hash11(n+ 1.0);\n\tfloat c = hash11(n+ 57.0);\n\tfloat d = hash11(n+ 58.0);\n\t\n\tvec2 f2 = f * f;\n\tvec2 f3 = f2 * f;\n\t\n\tvec2 t = 3.0 * f2 - 2.0 * f3;\n\t\n\tfloat u = t.x;\n\tfloat v = t.y;\n\n\tfloat res = a + (b-a)*u +(c-a)*v + (a-b+d-c)*u*v;\n \n return res;\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float n = vertexId / vertexCount;\n float z = vertexId / 2000.;\n \n float m = pow (n, 1.12);\n float k = 1. - m;\n \n vec2 p;\n\n p = vec2(k * z * 0.7 * cos(0.7 * PI + time) * cos(time), k * z * 0.3 * sin(time));\n \n vec2 d = 0.3*vec2(z * cos(vertexId * TAU * 0.0051), z * sin(vertexId * TAU * 0.0051));\n p += d + d * 0.1 * SmoothNoise(d + vec2(time, time) + hash12(d) * 0.4);\n \n p.xy *= resolution.yy / resolution.xy; \n\n gl_Position = vec4(p, 0., 1.);\n \n vec3 c = hsv2rgb(vec3(10. / 360. * time,mix(.6, 1., m), m));\n \n v_color = vec4(c,1);\n}" + }, "screenshotURL": "data/images/images-t6fqmj37b5m45kool-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tMLi8Jfi7Db6YYosv/art.json b/art/tMLi8Jfi7Db6YYosv/art.json index 49df6a8c..e5704079 100644 --- a/art/tMLi8Jfi7Db6YYosv/art.json +++ b/art/tMLi8Jfi7Db6YYosv/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "8bitrick", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/queroxmusic/querox-phaxe-tripical-moon\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI 3.14159\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) { return v * 2. - 1.; }\\n\\nvoid main()\\n{\\n float ROWS = 3.;\\n float cur_time = mod(time, 4.);\\n float verts_per_row = vertexCount / ROWS;\\n float vert_per = vertexId / (vertexCount - 1.);\\n float row = floor(vertexId / verts_per_row);\\n float row_per = row / (ROWS-1.);\\n //float freq = vert_per * 0.8 + 0.1;\\n float hash_row = hash(hash(row_per)+0.10);\\n vec2 center = vec2(m1p1(hash_row), m1p1(hash(hash_row)))* 0.5;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n \\n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\\n float x = vertex_per;\\n //float y = texture2D(sound,vec2(vertex_per*0.90+0.1,0.)).a;// + (row_per) - 1. + hash(row_per);\\n \\n //vec2 vel = vec2(m1p1(hash(vert_per))*0.25 * amp, amp);\\n float hash_vert = hash(vert_per);\\n float angle = hash(hash_vert) * PI * 2.;\\n //float radius = hash_vert;\\n //float radius = (-exp2(-hash_vert)+1.) * 2.;\\n float radius = (-pow(hash_vert-1.,2.)+1.);\\n \\n float freq = radius * 0.6 + 0.1;\\n float amp = texture2D(sound,vec2(freq, 0.)).a;// + (row_per) - 1. + hash(row_per);\\n \\n //float angle = hash(hash_vert) * PI * 0.333 + (PI * 0.333);\\n vec2 offset = vec2(cos(angle), sin(angle)) * (radius + amp * 0.4);\\n //vec2 offset = vec2(cos(angle), sin(angle)) * hash_vert*hash_vert*(3.-2.*hash_vert);\\n //vec2 xy = (center + offset * vec2(cos(time*offset.x), 1.) * 0.25) * aspect;\\n vec2 xy = (center + offset * vec2(cos(time*offset.x), 1.) * 0.25) * aspect;\\n \\n gl_PointSize = 5.0;\\n gl_Position = vec4(xy,0,1);\\n v_color = vec4(1.0);\\n// v_color = mix(vec4(hsv2rgb(vec3(y*0.21, 1.-y, 1.)), 1.-row_per), background, row_per - 0.2);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/queroxmusic/querox-phaxe-tripical-moon", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI 3.14159\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) { return v * 2. - 1.; }\n\nvoid main()\n{\n float ROWS = 3.;\n float cur_time = mod(time, 4.);\n float verts_per_row = vertexCount / ROWS;\n float vert_per = vertexId / (vertexCount - 1.);\n float row = floor(vertexId / verts_per_row);\n float row_per = row / (ROWS-1.);\n //float freq = vert_per * 0.8 + 0.1;\n float hash_row = hash(hash(row_per)+0.10);\n vec2 center = vec2(m1p1(hash_row), m1p1(hash(hash_row)))* 0.5;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n \n float vertex_per = mod(vertexId, verts_per_row) / verts_per_row;\n float x = vertex_per;\n //float y = texture2D(sound,vec2(vertex_per*0.90+0.1,0.)).a;// + (row_per) - 1. + hash(row_per);\n \n //vec2 vel = vec2(m1p1(hash(vert_per))*0.25 * amp, amp);\n float hash_vert = hash(vert_per);\n float angle = hash(hash_vert) * PI * 2.;\n //float radius = hash_vert;\n //float radius = (-exp2(-hash_vert)+1.) * 2.;\n float radius = (-pow(hash_vert-1.,2.)+1.);\n \n float freq = radius * 0.6 + 0.1;\n float amp = texture2D(sound,vec2(freq, 0.)).a;// + (row_per) - 1. + hash(row_per);\n \n //float angle = hash(hash_vert) * PI * 0.333 + (PI * 0.333);\n vec2 offset = vec2(cos(angle), sin(angle)) * (radius + amp * 0.4);\n //vec2 offset = vec2(cos(angle), sin(angle)) * hash_vert*hash_vert*(3.-2.*hash_vert);\n //vec2 xy = (center + offset * vec2(cos(time*offset.x), 1.) * 0.25) * aspect;\n vec2 xy = (center + offset * vec2(cos(time*offset.x), 1.) * 0.25) * aspect;\n \n gl_PointSize = 5.0;\n gl_Position = vec4(xy,0,1);\n v_color = vec4(1.0);\n// v_color = mix(vec4(hsv2rgb(vec3(y*0.21, 1.-y, 1.)), 1.-row_per), background, row_per - 0.2);\n}\n" + }, "screenshotURL": "data/images/images-ig33262iqx9bhrayf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tQEPfhxxjYGjmL6LL/art.json b/art/tQEPfhxxjYGjmL6LL/art.json index 279498b6..c18604a5 100644 --- a/art/tQEPfhxxjYGjmL6LL/art.json +++ b/art/tQEPfhxxjYGjmL6LL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n#define Kp1 4.//0.1>>3.\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), Kp1\\n \\n -sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 ctr = vec2(0.5);\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 4.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 80. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown * snd; \\n gl_PointSize *= resolution.x /52./dot(s*Kp1,3.*cos(s+time))* xOff; \\n xy -= ctr;\\n xy *= rotate2D(snd * PI * 2.0 +s);\\n xy += ctr;\\n xy *= pow(xy, ctr + xy);\\n xy *= -3.;\\n //xy = fract(xy / 0.1);\\n vec4 pos = vec4(xy / yOff, -.25*s*xOff/sin(s*sin(time)) , 1.15-xOff);\\n pos *= rotY(PI * s);\\n gl_Position = pos;\\n xy -= vec2(0.5);\\n xy *= rotate2D(snd * -PI * 2.0);\\n xy += vec2(0.5);\\n xy *= mouse;\\n float hue = snd *s;\\n hue = smoothstep(xy.x, xy.y, s);\\n float sat = 1.0*cos(time*6.3*2.);\\n float val = invV;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val))+0.95*s, 1);\\n color *= rotY(PI * snd * s/2.);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n \\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n#define Kp1 4.//0.1>>3.\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), Kp1\n \n -sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n vec2 ctr = vec2(0.5);\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 4.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 80. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown * snd; \n gl_PointSize *= resolution.x /52./dot(s*Kp1,3.*cos(s+time))* xOff; \n xy -= ctr;\n xy *= rotate2D(snd * PI * 2.0 +s);\n xy += ctr;\n xy *= pow(xy, ctr + xy);\n xy *= -3.;\n //xy = fract(xy / 0.1);\n vec4 pos = vec4(xy / yOff, -.25*s*xOff/sin(s*sin(time)) , 1.15-xOff);\n pos *= rotY(PI * s);\n gl_Position = pos;\n xy -= vec2(0.5);\n xy *= rotate2D(snd * -PI * 2.0);\n xy += vec2(0.5);\n xy *= mouse;\n float hue = snd *s;\n hue = smoothstep(xy.x, xy.y, s);\n float sat = 1.0*cos(time*6.3*2.);\n float val = invV;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val))+0.95*s, 1);\n color *= rotY(PI * snd * s/2.);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n \n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-ovlffevkxqotbpz1h-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tRnGuB6MaPdZJMzmR/art.json b/art/tRnGuB6MaPdZJMzmR/art.json index bf163de6..6db01925 100644 --- a/art/tRnGuB6MaPdZJMzmR/art.json +++ b/art/tRnGuB6MaPdZJMzmR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongryul.park", "avatarUrl": "https://secure.gravatar.com/avatar/335c7306112b8357ec436839f7018115?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//\\tseongryul.park\\n//\\tCS250 spring 2023\\n//\\tColors\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main()\\n{\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount / down);\\n \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId/ across);\\n \\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = sin(time + x * 0.3) * 0.2;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n \\tgl_PointSize = 15.0 + soff;\\n \\tgl_PointSize *= 20.0 / across;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n \\tfloat hue = u * .1 + sin(time * 1.3 + v * 20.0) * 0.5 + 0.5;\\n \\tfloat sat = 1.0;\\n \\tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//\tseongryul.park\n//\tCS250 spring 2023\n//\tColors\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \n vec4 k = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + k.xyz) * 6.0 - k.www);\n return c.z * mix(k.xxx, clamp(p - k.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main()\n{\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount / down);\n \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId/ across);\n \n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = sin(time + x * 0.3) * 0.2;\n \n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n \tgl_PointSize = 15.0 + soff;\n \tgl_PointSize *= 20.0 / across;\n \tgl_PointSize *= resolution.x / 600.;\n \n \tfloat hue = u * .1 + sin(time * 1.3 + v * 20.0) * 0.5 + 0.5;\n \tfloat sat = 1.0;\n \tfloat val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \tv_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-pgrtrrdinhfbxsg2d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tSysk55tWkhrkkrEF/art.json b/art/tSysk55tWkhrkkrEF/art.json index 38344731..53ed95b6 100644 --- a/art/tSysk55tWkhrkkrEF/art.json +++ b/art/tSysk55tWkhrkkrEF/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "liaminjapan", "avatarUrl": "https://avatars.githubusercontent.com/LiamInJapan?s=200", - "settings": "{\"num\":57906,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.3411764705882353,0.22745098039215686,0.27450980392156865,1],\"shader\":\"vec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = .0;// sin(time + y * 0.2) * .05;\\n float yoff = .0;// sin(time + x * 0.3) * .05;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = 0.;/*sin(time + x * y * 0.02) * 5.;*/\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across; \\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * .2 + time * .1;// sin(time*1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1. ,pump);//mix(1., 0., av);\\n float val = mix(.1, pow(snd + 0.2, .5), pump);//sin(time*1.4 + v * u * 20.) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1)\\n}\"}", + "settings": { + "num": 57906, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.3411764705882353, + 0.22745098039215686, + 0.27450980392156865, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = .0;// sin(time + y * 0.2) * .05;\n float yoff = .0;// sin(time + x * 0.3) * .05;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).a;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = 0.;/*sin(time + x * y * 0.02) * 5.;*/\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across; \n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * .2 + time * .1;// sin(time*1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1. ,pump);//mix(1., 0., av);\n float val = mix(.1, pow(snd + 0.2, .5), pump);//sin(time*1.4 + v * u * 20.) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1)\n}" + }, "screenshotURL": "data/images/images-kxa5odb0lcxktg3bb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tTGjfG5qvuESdFcQR/art.json b/art/tTGjfG5qvuESdFcQR/art.json index c5558364..c5f043ca 100644 --- a/art/tTGjfG5qvuESdFcQR/art.json +++ b/art/tTGjfG5qvuESdFcQR/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(360.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 4.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(360.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 4.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-cwexgm561wag3gefb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tTWmqDWD9Y3Gijkoy/art.json b/art/tTWmqDWD9Y3Gijkoy/art.json index fa0d1b8b..d8a6e47d 100644 --- a/art/tTWmqDWD9Y3Gijkoy/art.json +++ b/art/tTWmqDWD9Y3Gijkoy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = (((i * offset) - 1.) + (offset / 2.) * 2.);\\n float r = sqrt(2. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = (((i * offset) - 1.) + (offset / 2.) * 2.);\n float r = sqrt(2. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-aa2d0cd4x87w5ao0c-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tTpdRDPwymLa9i5Mo/art.json b/art/tTpdRDPwymLa9i5Mo/art.json index 1c8247af..1d7dee56 100644 --- a/art/tTpdRDPwymLa9i5Mo/art.json +++ b/art/tTpdRDPwymLa9i5Mo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "yejin-shin", "avatarUrl": "https://avatars.githubusercontent.com/yejin-shin?s=200", - "settings": "{\"num\":16384,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bradangus/kda-popstars-ft-madison-beer-gi-dle-jaira-burns-official-music-video-league-of-legendsbigconvertercom\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat PI = 3.141592;\\n\\nvoid main() \\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux, vy) * 1.3;\\n\\n float su = abs(u - 0.5) * 0.87;\\n float sv = abs(v - 0.5) * 0.87;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.06, av * 0.28)).a;\\n\\n gl_Position = vec4(xy, 0, 1);\\n\\n gl_PointSize = pow(snd + 0.2, 5.) * 50.0;\\n gl_PointSize *= 10. / across;\\n gl_PointSize *= resolution.x / 350.;\\n\\n float pump = step(0.8, snd);\\t\\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\\n\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "POINTS", + "sound": "https://soundcloud.com/bradangus/kda-popstars-ft-madison-beer-gi-dle-jaira-burns-official-music-video-league-of-legendsbigconvertercom", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat PI = 3.141592;\n\nvoid main() \n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux, vy) * 1.3;\n\n float su = abs(u - 0.5) * 0.87;\n float sv = abs(v - 0.5) * 0.87;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.06, av * 0.28)).a;\n\n gl_Position = vec4(xy, 0, 1);\n\n gl_PointSize = pow(snd + 0.2, 5.) * 50.0;\n gl_PointSize *= 10. / across;\n gl_PointSize *= resolution.x / 350.;\n\n float pump = step(0.8, snd);\t\n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\n\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-39r82cvwwqzzr6894-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tW33RrL78zzouNP8o/art.json b/art/tW33RrL78zzouNP8o/art.json index 5dd86a2c..e68ee9e1 100644 --- a/art/tW33RrL78zzouNP8o/art.json +++ b/art/tW33RrL78zzouNP8o/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "sairu312", "avatarUrl": "https://avatars.githubusercontent.com/Sairu312?s=200", - "settings": "{\"num\":3281,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n//透視投影変換関数\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n//Y軸回りの回転関数\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n vec4 vertPos = rotY(time*mouse.x) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 3281, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n//透視投影変換関数\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n//Y軸回りの回転関数\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n vec4 vertPos = rotY(time*mouse.x) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-gd7opn07ez9d3wf4n-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tYmHG6XpcftYrE9DD/art.json b/art/tYmHG6XpcftYrE9DD/art.json index 02043f52..12751f1f 100644 --- a/art/tYmHG6XpcftYrE9DD/art.json +++ b/art/tYmHG6XpcftYrE9DD/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/proposal-records/jose-ayen-apsara-brooklyn-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n// vsa\\n\\n//asdf\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvoid main() {\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n float snd = texture2D(sound, vec2(abs(m1p1(a2n / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n float t = time * 0.05;\\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.3,1.))\\n \\t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.5,1.))\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.7,1.))\\n \\t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.4,1.));\\n\\n light *= mix(0.5, 2.0, snd);\\n //light *= mix(vec3(1,0,0), vec3(0,0,1), vertexId / 32./ 32. / 3.);\\n light *= mix(vec3(1), vec3(1,0,0), step(0.66, snd));\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n v_color = vec4(vec3(light), 1);\\n}//axcx\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/proposal-records/jose-ayen-apsara-brooklyn-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n// vsa\n\n//asdf\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvoid main() {\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n float snd = texture2D(sound, vec2(abs(m1p1(a2n / 2. / PI)) * 0.2 + 0.05, a2 / 2. / PI * 0.25)).a;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2)) * mix(0.4, 3.2, pow(snd, 6.));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n norm = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n float t = time * 0.05;\n light = pow(dot(normalize(vec3( .3, .4,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.3,1.))\n \t+ pow(dot(normalize(vec3( .1,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.5,1.))\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.3 + t,.0*1.7,1.))\n \t+ pow(dot(normalize(vec3( .7,-.2,-.5)),norm)*.5+.5,5.)*hsv2rgb(vec3(.8 + t,.0*1.4,1.));\n\n light *= mix(0.5, 2.0, snd);\n //light *= mix(vec3(1,0,0), vec3(0,0,1), vertexId / 32./ 32. / 3.);\n light *= mix(vec3(1), vec3(1,0,0), step(0.66, snd));\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n v_color = vec4(vec3(light), 1);\n}//axcx" + }, "screenshotURL": "data/images/images-f1xpywpsobuemkfks-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tZ878XpvmzGfjF3hG/art.json b/art/tZ878XpvmzGfjF3hG/art.json index 83712e43..914846b4 100644 --- a/art/tZ878XpvmzGfjF3hG/art.json +++ b/art/tZ878XpvmzGfjF3hG/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyojoonkim0020", "avatarUrl": "https://secure.gravatar.com/avatar/cefe773094bef8b88aa9bc719abe4874?default=retro&size=200", - "settings": "{\"num\":16988,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//hyojoon kim\\n//Colors\\n//cs250\\n//spring2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = abs(cos(time + y * 0.2)) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff*2.0;\\n float vy = v * 2. - 1.;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u ;\\n float sat = v;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 16988, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//hyojoon kim\n//Colors\n//cs250\n//spring2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = abs(cos(time + y * 0.2)) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff*2.0;\n float vy = v * 2. - 1.;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u ;\n float sat = v;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-ezughjgcf4ojqic8g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tZJWzLbyDQHTztNqY/art.json b/art/tZJWzLbyDQHTztNqY/art.json index be79cbba..596821ac 100644 --- a/art/tZJWzLbyDQHTztNqY/art.json +++ b/art/tZJWzLbyDQHTztNqY/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n//Step 1 >> comment all precision, extension, uniforms and varying\\n/*\\n#ifdef GL_ES\\nprecision mediump float;\\n#endif\\n \\n#extension GL_OES_standard_derivatives : enable\\n\\nuniform float time;\\nuniform vec2 mouse;\\nuniform vec2 resolution;\\nvarying vec2 surfacePosition;\\n*/\\n//#define BASE_ANGLE 0.\\n//#define ANGLE_DELTA 0.02\\n//#define XOFF .7\\n\\n#define BASE_ANGLE .3//KParameter 0.>>3.14\\n#define ANGLE_DELTA .02//KParameter 0.02>>10.\\n#define XOFF .7//KParameter 0.02>>.7\\n\\nmat2 mm2(in float a){float c = cos(a), s = sin(a);return mat2(c,-s,s,c);}\\n\\nfloat aspect = resolution.x/resolution.y;\\nfloat featureSize = 60./((resolution.x*aspect+resolution.y));\\n\\nfloat f(vec2 p)\\n{\\n\\tp.x = sin(p.x*25.+time*1.2)*sin(time+p.x*0.1)*3.;\\t\\n p += sin(p.x*1.5)*.1;\\n return smoothstep(-0.0,featureSize,abs(p.y));\\n}\\n\\n\\nvoid main( void ) {\\n\\n\\n //Step 2 >> replace gl_FragCoord\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\n \\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n //set vertices disposition\\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\n \\n float ux = sizeFactor*(u - 0.5);\\n float vy = sizeFactor*(v - 0.5);\\n \\n gl_PointSize = finalDesiredPointSize;\\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //create the surfacePosition\\n vec2 surfacePosition = vec2(ux,vy);\\n\\n /****************************************************************/\\n //Step 4 >> paste the old fragment code with following changes:\\n //replace gl_FragCoord by simFragCoord \\n //replace gl_FragColor by v_color\\n //replace iResolution by resolution\\n //replace resolution by vertexResolution\\n \\n\\tvec2 p = simFragCoord.xy / vertexResolution.xy*6.5-3.25;\\n\\tp.x *= aspect;\\n\\tp.y = abs(p.y);\\n\\t\\n\\tvec3 col = vec3(0);\\n\\tfor(float i=0.;i<26.;i++)\\n\\t{\\n\\t\\tvec3 col2 = (sin(vec3(3.3,2.5,2.2)+i*10.15)*0.5+10.54)*(1.-f(p));\\n\\t\\tcol = max(col,col2);\\n\\t\\t\\n p.x -= XOFF;\\n p.y -= sin(time*0.11+1.5)*1.5+1.5;\\n\\t\\tp*= mm2(i*ANGLE_DELTA+BASE_ANGLE);\\n\\t\\t\\n vec2 pa = vec2(abs(p.x-.9),abs(p.y));\\n vec2 pb = vec2(p.x,abs(p.y));\\n \\n p = mix(pa,pb,smoothstep(-.07,.07,sin(time*0.24)+.1));\\n\\t}\\n\\tv_color = vec4(col,1.0);\\n \\n /****************************************************************/\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n//Step 1 >> comment all precision, extension, uniforms and varying\n/*\n#ifdef GL_ES\nprecision mediump float;\n#endif\n \n#extension GL_OES_standard_derivatives : enable\n\nuniform float time;\nuniform vec2 mouse;\nuniform vec2 resolution;\nvarying vec2 surfacePosition;\n*/\n//#define BASE_ANGLE 0.\n//#define ANGLE_DELTA 0.02\n//#define XOFF .7\n\n#define BASE_ANGLE .3//KParameter 0.>>3.14\n#define ANGLE_DELTA .02//KParameter 0.02>>10.\n#define XOFF .7//KParameter 0.02>>.7\n\nmat2 mm2(in float a){float c = cos(a), s = sin(a);return mat2(c,-s,s,c);}\n\nfloat aspect = resolution.x/resolution.y;\nfloat featureSize = 60./((resolution.x*aspect+resolution.y));\n\nfloat f(vec2 p)\n{\n\tp.x = sin(p.x*25.+time*1.2)*sin(time+p.x*0.1)*3.;\t\n p += sin(p.x*1.5)*.1;\n return smoothstep(-0.0,featureSize,abs(p.y));\n}\n\n\nvoid main( void ) {\n\n\n //Step 2 >> replace gl_FragCoord\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n vec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\n \n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n //set vertices disposition\n float sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\n \n float ux = sizeFactor*(u - 0.5);\n float vy = sizeFactor*(v - 0.5);\n \n gl_PointSize = finalDesiredPointSize;\n gl_Position = vec4(ux, vy, 0., 1.);\n \n //create the surfacePosition\n vec2 surfacePosition = vec2(ux,vy);\n\n /****************************************************************/\n //Step 4 >> paste the old fragment code with following changes:\n //replace gl_FragCoord by simFragCoord \n //replace gl_FragColor by v_color\n //replace iResolution by resolution\n //replace resolution by vertexResolution\n \n\tvec2 p = simFragCoord.xy / vertexResolution.xy*6.5-3.25;\n\tp.x *= aspect;\n\tp.y = abs(p.y);\n\t\n\tvec3 col = vec3(0);\n\tfor(float i=0.;i<26.;i++)\n\t{\n\t\tvec3 col2 = (sin(vec3(3.3,2.5,2.2)+i*10.15)*0.5+10.54)*(1.-f(p));\n\t\tcol = max(col,col2);\n\t\t\n p.x -= XOFF;\n p.y -= sin(time*0.11+1.5)*1.5+1.5;\n\t\tp*= mm2(i*ANGLE_DELTA+BASE_ANGLE);\n\t\t\n vec2 pa = vec2(abs(p.x-.9),abs(p.y));\n vec2 pb = vec2(p.x,abs(p.y));\n \n p = mix(pa,pb,smoothstep(-.07,.07,sin(time*0.24)+.1));\n\t}\n\tv_color = vec4(col,1.0);\n \n /****************************************************************/\n \n}" + }, "screenshotURL": "data/images/images-4t8bbtusgndnhu5bm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tbgH6FuoT5pxxDgfv/art.json b/art/tbgH6FuoT5pxxDgfv/art.json index 16630350..3c18b8a6 100644 --- a/art/tbgH6FuoT5pxxDgfv/art.json +++ b/art/tbgH6FuoT5pxxDgfv/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":200,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) ;\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 200, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) ;\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-2kdyioq5u3lamkaog-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tbsksogaFbe66Nn5Q/art.json b/art/tbsksogaFbe66Nn5Q/art.json index 26da5528..eb5c651c 100644 --- a/art/tbsksogaFbe66Nn5Q/art.json +++ b/art/tbsksogaFbe66Nn5Q/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "dertrackererpro", "avatarUrl": "https://lh4.googleusercontent.com/-tzGrZLlkoQI/AAAAAAAAAAI/AAAAAAAAAWA/IcJA81i4FOw/photo.jpg", - "settings": "{\"num\":54,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n vec3 pos = vec3(cos(time+vertexId)*0.7, sin(time+vertexId), 0.0);\\n float color = 1.0;\\n gl_PointSize = 20.0;\\n gl_Position = vec4(pos, 1.0);\\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0)+0.5;\\n}\"}", + "settings": { + "num": 54, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n vec3 pos = vec3(cos(time+vertexId)*0.7, sin(time+vertexId), 0.0);\n float color = 1.0;\n gl_PointSize = 20.0;\n gl_Position = vec4(pos, 1.0);\n v_color = vec4(pos.x, pos.y, -pos.y, 1.0)+0.5;\n}" + }, "screenshotURL": "data/images/images-vu11v8abn6uhybwhz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tgnWFwxfEbt64aHfQ/art.json b/art/tgnWFwxfEbt64aHfQ/art.json index a8661a37..229de633 100644 --- a/art/tgnWFwxfEbt64aHfQ/art.json +++ b/art/tgnWFwxfEbt64aHfQ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.49411764705882355,0.8941176470588236,0.8509803921568627,1],\"shader\":\"// terrain\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.54030,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n float su = fract(p.x * 0.0125);\\n float sv = 1. - (p.y + 0.5) / soundRes.y;\\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\\n return pow(s, 1.) * 0.5;\\n //return sin(p.y * 4.);\\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\\n\\tfloat f;\\n p.y += time * 0.1;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\\n float outId = mix(id, 8. - id, step(2.5, id));\\n float ux = floor(outId / 6.) + mod(outId, 2.);\\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \\n vec3 p = vec3(ux, 0, vy) + off;\\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\\n return pos;\\n}\\n\\n#define POINTS_PER_QUAD 6.\\nvoid main() {\\n float quadPnt = mod(vertexId, 6.);\\n float quadId = floor(vertexId / POINTS_PER_QUAD);\\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\\n float across = floor(sqrt(numQuads) * 0.5);\\n float down = floor(numQuads / across);\\n \\n float qx = mod(quadId, across);\\n float qz = floor(quadId / across);\\n float qu = qx / across;\\n float qv = qz / down;\\n vec3 q = vec3(qx, -1, qz);\\n \\n float s = 8. / across;\\n \\n float nId = floor(quadPnt / 3.) * 3.;\\n vec3 n0 = getQuadPoint(nId + 0., s, q);\\n vec3 n1 = getQuadPoint(nId + 1., s, q);\\n vec3 n2 = getQuadPoint(nId + 2., s, q);\\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\\n vec3 lightDir = normalize(vec3(-1, 1, -2));\\n float l = abs(dot(n, lightDir));\\n \\n vec3 p = getQuadPoint(quadPnt, s, q);\\n \\n\\n float ct = time * 0.3;\\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\\n \\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\\n m *= trans(vec3(-across / 2. * s, 0, 0));\\n \\n gl_Position = m * vec4(p, 1);\\n \\n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\\n float val = mix(0.05, 1., l);\\n \\n float cback = 1. - pow(qv, 5.);\\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color = mix(v_color, background, 1. - cback * cacross);\\n v_color.rga *= v_color.a;\\n \\n v_color = vec4(255) - v_color;\\n \\n gl_PointSize = 10.0;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/shin-nishimura-apsara-eighteen-original-mix-plus-records-192kbps", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.49411764705882355, + 0.8941176470588236, + 0.8509803921568627, + 1 + ], + "shader": "// terrain\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.54030,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n float su = fract(p.x * 0.0125);\n float sv = 1. - (p.y + 0.5) / soundRes.y;\n float s = texture2D(sound, vec2(mix(0.002, 0.253, su), sv)).a;\n return pow(s, 1.) * 0.5;\n //return sin(p.y * 4.);\n //return sin(p.x * PI) * sin(p.y * PI) * 0.5;\n\tfloat f;\n p.y += time * 0.1;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f * 0.5;///(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 getQuadPoint(const float id, const float scale, const vec3 off) {\n float outId = mix(id, 8. - id, step(2.5, id));\n float ux = floor(outId / 6.) + mod(outId, 2.);\n float vy = mod(floor(outId / 2.) + floor(outId / 3.), 2.); \n vec3 p = vec3(ux, 0, vy) + off;\n vec3 pos = p * scale + vec3(0, fbm(p.xz) * 2., 0);\n return pos;\n}\n\n#define POINTS_PER_QUAD 6.\nvoid main() {\n float quadPnt = mod(vertexId, 6.);\n float quadId = floor(vertexId / POINTS_PER_QUAD);\n float numQuads = floor(vertexCount / POINTS_PER_QUAD);\n float across = floor(sqrt(numQuads) * 0.5);\n float down = floor(numQuads / across);\n \n float qx = mod(quadId, across);\n float qz = floor(quadId / across);\n float qu = qx / across;\n float qv = qz / down;\n vec3 q = vec3(qx, -1, qz);\n \n float s = 8. / across;\n \n float nId = floor(quadPnt / 3.) * 3.;\n vec3 n0 = getQuadPoint(nId + 0., s, q);\n vec3 n1 = getQuadPoint(nId + 1., s, q);\n vec3 n2 = getQuadPoint(nId + 2., s, q);\n vec3 n = (cross(normalize(n1 - n0), normalize(n2 - n1)));// * mix(vec3(1,1,1), vec3(-1,-1,-1), step(2.5, nId));\n vec3 lightDir = normalize(vec3(-1, 1, -2));\n float l = abs(dot(n, lightDir));\n \n vec3 p = getQuadPoint(quadPnt, s, q);\n \n\n float ct = time * 0.3;\n// vec3 cameraPos = vec3(mouse.x * 4., mix(5., 1., p1m1(mouse.y)), -3);\n vec3 cameraPos = vec3(sin(ct), 1., sin(ct) + 1.);\n vec3 cameraTarget = vec3(cameraPos.x, 0, 4. + sin(ct));\n vec3 cameraUp = normalize(vec3(sin(ct + 2.5) * 0.3, 1, 0));\n \n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 100.);\n m *= cameraLookAt(cameraPos, cameraTarget, cameraUp);\n m *= trans(vec3(-across / 2. * s, 0, 0));\n \n gl_Position = m * vec4(p, 1);\n \n float hue = 0.5 + sin(time * 0.01) * 0.1 + qu * 0. + p.y * -0.3;//1.;m1p1(n.z);\n float sat = pow(1. - p.y, 2.);//.3;abs(n.z);\n float val = mix(0.05, 1., l);\n \n float cback = 1. - pow(qv, 5.);\n float cacross = 1. - pow(abs((qu * 2. - 1.)), 5.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color = mix(v_color, background, 1. - cback * cacross);\n v_color.rga *= v_color.a;\n \n v_color = vec4(255) - v_color;\n \n gl_PointSize = 10.0;\n}" + }, "screenshotURL": "data/images/images-2t9b3pyfzxx84cj1w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tiY4qnEQ7wBnY5XdH/art.json b/art/tiY4qnEQ7wBnY5XdH/art.json index fc2b7880..a1bf3fbe 100644 --- a/art/tiY4qnEQ7wBnY5XdH/art.json +++ b/art/tiY4qnEQ7wBnY5XdH/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "julio", "avatarUrl": "https://lh4.googleusercontent.com/-_qIuSe0i5BM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3re8EYbgzIrdnuAsoVZKmC72bCiiKQ/mo/photo.jpg", - "settings": "{\"num\":347,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8156862745098039,0.8509803921568627,0.2,1],\"shader\":\"void main()\\n{\\n float width = 20.0;\\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n\\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n\\n float xOffset = sin(time + y * 0.1) * 0.5;\\n float yOffset = cos(time + x * 0.4) * 0.3;\\n\\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n\\n vec2 xy = vec2(ux, vy) * 0.5;\\n\\n gl_Position = vec4(ux, vy, sin(time), 1.0);\\n v_color = vec4(sin(time / vertexId), sin(time), cos(vertexId), sin(time));\\n gl_PointSize = 40.0;\\n}\"}", + "settings": { + "num": 347, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8156862745098039, + 0.8509803921568627, + 0.2, + 1 + ], + "shader": "void main()\n{\n float width = 20.0;\n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n\n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n\n float xOffset = sin(time + y * 0.1) * 0.5;\n float yOffset = cos(time + x * 0.4) * 0.3;\n\n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n\n vec2 xy = vec2(ux, vy) * 0.5;\n\n gl_Position = vec4(ux, vy, sin(time), 1.0);\n v_color = vec4(sin(time / vertexId), sin(time), cos(vertexId), sin(time));\n gl_PointSize = 40.0;\n}" + }, "screenshotURL": "data/images/images-0ivkzjc8coamzvy87-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tjBqEBhdzGA4XCiWr/art.json b/art/tjBqEBhdzGA4XCiWr/art.json index 8c560024..46319a84 100644 --- a/art/tjBqEBhdzGA4XCiWr/art.json +++ b/art/tjBqEBhdzGA4XCiWr/art.json @@ -28,7 +28,19 @@ "name": "cubes2", "private": false, "username": "matt", - "settings": "{\"num\":14400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rotr3(float x, float n) {\\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\\n}\\n\\nfloat mod2(float x) {\\n return mod(floor(x), 2.0);\\n}\\n\\nvec3 cubePos(float x) {\\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\\n}\\n\\nvoid main() {\\n float near = -1.0;\\n float aspectRatio = resolution.y / resolution.x;\\n float cubeIdx = floor(vertexId / 36.0);\\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\\n float faceDiv3 = floor(faceIdx / 3.0);\\n float faceMod3 = mod(faceIdx, 3.0);\\n float quadIdx = mod(vertexId, 6.0);\\n float baseIdx = faceIdx * 6.0;\\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\\n vec3 pos = cubePos(rotr3(vertIdx + faceDiv3 * 4.0, faceMod3));\\n pos -= 0.5;\\n pos *= 0.02;\\n \\n float gridX = (mod(cubeIdx, 20.0) - 10.0) / 20.0;\\n float gridY = floor(cubeIdx / 20.0 - 10.0) / 20.0;\\n float dist = length(vec2(gridX, gridY));\\n float ct = sin(time + gridX * 4.0) * sin(time + gridY * 4.0);\\n float ct1 = cos(time + gridX * 4.0) * cos(time + gridY * 4.0);\\n float s = sin(ct + time), c = cos(ct + time);\\n float s1 = sin(ct1 + time), c1 = cos(ct1 + time);\\n mat3 rotZ = mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0));\\n mat3 rotY = mat3(vec3(c1, 0.0, s1), vec3(0.0, 1.0, 0.0), vec3(-s1, 0.0, c1));\\n pos = pos * rotZ * rotY;\\n pos.x += gridX;\\n pos.y += gridY;\\n pos.y /= aspectRatio;\\n float zDist = pos.z - near;\\n gl_Position = vec4(pos, zDist);\\n\\n float colIdx = faceIdx + 1.0;\\n v_color = vec4(mod2(colIdx), mod2(colIdx / 2.0), mod2(colIdx / 4.0), 1.0);\\n}\"}", + "settings": { + "num": 14400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rotr3(float x, float n) {\n return floor(x / pow(2.0, n)) + mod(x * pow(2.0, 3.0 - n), 8.0);\n}\n\nfloat mod2(float x) {\n return mod(floor(x), 2.0);\n}\n\nvec3 cubePos(float x) {\n return vec3(mod2(x), mod2(x / 2.0), mod2(x / 4.0));\n}\n\nvoid main() {\n float near = -1.0;\n float aspectRatio = resolution.y / resolution.x;\n float cubeIdx = floor(vertexId / 36.0);\n float faceIdx = mod(floor(vertexId / 6.0), 6.0);\n float faceDiv3 = floor(faceIdx / 3.0);\n float faceMod3 = mod(faceIdx, 3.0);\n float quadIdx = mod(vertexId, 6.0);\n float baseIdx = faceIdx * 6.0;\n float vertIdx = abs(faceDiv3 == 0.0 ? quadIdx - 2.0 : 3.0 - quadIdx);\n vec3 pos = cubePos(rotr3(vertIdx + faceDiv3 * 4.0, faceMod3));\n pos -= 0.5;\n pos *= 0.02;\n \n float gridX = (mod(cubeIdx, 20.0) - 10.0) / 20.0;\n float gridY = floor(cubeIdx / 20.0 - 10.0) / 20.0;\n float dist = length(vec2(gridX, gridY));\n float ct = sin(time + gridX * 4.0) * sin(time + gridY * 4.0);\n float ct1 = cos(time + gridX * 4.0) * cos(time + gridY * 4.0);\n float s = sin(ct + time), c = cos(ct + time);\n float s1 = sin(ct1 + time), c1 = cos(ct1 + time);\n mat3 rotZ = mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0));\n mat3 rotY = mat3(vec3(c1, 0.0, s1), vec3(0.0, 1.0, 0.0), vec3(-s1, 0.0, c1));\n pos = pos * rotZ * rotY;\n pos.x += gridX;\n pos.y += gridY;\n pos.y /= aspectRatio;\n float zDist = pos.z - near;\n gl_Position = vec4(pos, zDist);\n\n float colIdx = faceIdx + 1.0;\n v_color = vec4(mod2(colIdx), mod2(colIdx / 2.0), mod2(colIdx / 4.0), 1.0);\n}" + }, "screenshotURL": "data/images/images-qyiuebc2yhez3fevp-thumbnail.jpg", "views": { "$numberInt": "517" diff --git a/art/tkkTQCvYJZZ7rzpLo/art.json b/art/tkkTQCvYJZZ7rzpLo/art.json index 08b8fe88..544243e0 100644 --- a/art/tkkTQCvYJZZ7rzpLo/art.json +++ b/art/tkkTQCvYJZZ7rzpLo/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n return inverse(lookAt(eye, target, up));\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\nfloat remap(float v, float inMin, float inMax, float outMin, float outMax) {\\n return (v - inMin) / (inMax - inMin) * (outMax - outMin) + outMin;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 loc = fibonacciSphere(vertexCount, pointId);\\n\\n float cv = pointId / vertexCount;\\n float su = fract(cv + -time);\\n \\n float tm = time * .0;\\n float r = 40.;\\n float fov = radians(100.0);\\n float aspect = resolution.x / resolution.y;\\n float zNear = 1.;\\n float zFar = 100.;\\n mat4 mat = persp(fov, aspect, zNear, zFar);\\n \\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotX(time * 0.37);\\n mat *= rotY(time * 0.21);\\n \\n gl_Position = mat * vec4(loc * 35., 1);\\n\\n // z goes from about 20 to 100\\n float alpha = remap(gl_Position.z, 20., 100., 1., 0.); \\n \\n v_color = vec4(1, 0, 0, alpha);\\n v_color.rgb *= v_color.a; \\n \\n gl_PointSize = 10.;\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n return inverse(lookAt(eye, target, up));\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\nfloat remap(float v, float inMin, float inMax, float outMin, float outMax) {\n return (v - inMin) / (inMax - inMin) * (outMax - outMin) + outMin;\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 loc = fibonacciSphere(vertexCount, pointId);\n\n float cv = pointId / vertexCount;\n float su = fract(cv + -time);\n \n float tm = time * .0;\n float r = 40.;\n float fov = radians(100.0);\n float aspect = resolution.x / resolution.y;\n float zNear = 1.;\n float zFar = 100.;\n mat4 mat = persp(fov, aspect, zNear, zFar);\n \n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotX(time * 0.37);\n mat *= rotY(time * 0.21);\n \n gl_Position = mat * vec4(loc * 35., 1);\n\n // z goes from about 20 to 100\n float alpha = remap(gl_Position.z, 20., 100., 1., 0.); \n \n v_color = vec4(1, 0, 0, alpha);\n v_color.rgb *= v_color.a; \n \n gl_PointSize = 10.;\n}\n" + }, "screenshotURL": "data/images/images-2fe3mlhd0f6x0v370-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tn7AoRaD9XwPucwsL/art.json b/art/tn7AoRaD9XwPucwsL/art.json index 16e599e9..7dc00255 100644 --- a/art/tn7AoRaD9XwPucwsL/art.json +++ b/art/tn7AoRaD9XwPucwsL/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=0635288f616b4caebe7a732ce5fde187&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Audio Reactive\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 1. + snd * 0.2 + time * .1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/rain-boi-581578131/yakuza-0-5-kiwami-baka-mitai?in=0huvqia5iuxj/sets/yakuza&si=0635288f616b4caebe7a732ce5fde187&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Audio Reactive\n//Course: CS250\n//Term: Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float pump = step(0.8, snd);\n float hue = u * 1. + snd * 0.2 + time * .1;//u * .1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-m9e1tceae85wupy05-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tneny66CTjxFbesnu/art.json b/art/tneny66CTjxFbesnu/art.json index 3f95b77b..1fed6ecf 100644 --- a/art/tneny66CTjxFbesnu/art.json +++ b/art/tneny66CTjxFbesnu/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":500,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main()\\n{\\n float deg = vertexId + (time / 2.);\\n vec3 pos = vec3(sin(deg), cos(deg), vertexId*16.);\\n \\n // Applied a sin wave to the tex2d sample as a smoothing operation\\n float fov = (sin(radians(texture2D(sound, vec2(.4, 0)).a) * 90.) + 0.1) / 256.;\\n \\n mat4 camera = mat4(\\n resolution.y / resolution.x, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, fov, fov,\\n 0, 0, 0, 1);\\n \\n gl_Position = camera * vec4(pos.xyz, 1);\\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\\n}\"}", + "settings": { + "num": 500, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/aivisura/love-like-you?in=aivisura/sets/steven-universe", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main()\n{\n float deg = vertexId + (time / 2.);\n vec3 pos = vec3(sin(deg), cos(deg), vertexId*16.);\n \n // Applied a sin wave to the tex2d sample as a smoothing operation\n float fov = (sin(radians(texture2D(sound, vec2(.4, 0)).a) * 90.) + 0.1) / 256.;\n \n mat4 camera = mat4(\n resolution.y / resolution.x, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, fov, fov,\n 0, 0, 0, 1);\n \n gl_Position = camera * vec4(pos.xyz, 1);\n v_color = vec4(1, (vertexId / vertexCount) / 2. + 0.5, 1, 1);\n}" + }, "screenshotURL": "data/images/images-jtsu7veo0ayn5mxxy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/tnmTYzZQNchp9ECC2/art.json b/art/tnmTYzZQNchp9ECC2/art.json index 5be53490..1b08faa4 100644 --- a/art/tnmTYzZQNchp9ECC2/art.json +++ b/art/tnmTYzZQNchp9ECC2/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":74675,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/rossylo/dontuthink\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* Lambmeow */ \\n\\n#define PI radians(180.)\\n\\nvec2 GetCirclePoint(float id, float NumCircleSegments) {\\n \\n \\n float ux= floor(id/6.) + mod(id,2.);\\n float vy = mod(floor(id/2.)+ floor(id/3.), 2.);\\n \\n float angle =ux/NumCircleSegments * PI * 2. ;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy +1.;\\n \\n \\n \\n float x = c * radius ; \\n float y = s * radius;\\n \\n return vec2(x,y);\\n \\n \\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main(){\\n float numCircleSeg = 20.;\\n vec2 cir = GetCirclePoint(vertexId,numCircleSeg);\\n float numPointsPerCircle = numCircleSeg * 6.;\\n float circleId = floor(vertexId/numPointsPerCircle);\\n float numCircles = floor(vertexCount/numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles/down);\\n \\n float x = mod(circleId,across);\\n float y = floor(circleId/across);\\n \\n float u = x/(across-1.);\\n float v = y/(across- 1.);\\n \\n float xoff = sin(time + y *.2);\\n float yoff = sin(time +x *.2);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x/resolution.y;\\n float snd = texture2D(sound, vec2(u,v/4.)).a;\\n float scale = pow(snd +.2,.5);\\n float soff = sin(time +x * y ) * .5 ;\\n \\n vec2 xy = cir * .3* vec2(ux,vy) * texture2D(sound,vec2(u,v)).a;\\n \\n gl_Position = vec4(xy,0,1) * vec4(1,aspect,1,1);\\n\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x/ 600.;\\n float h = (u +cos(time * -v))* sin(time * .3) + snd;\\n float s = 1.;\\n float val = v+.8;\\n v_color = vec4(hsv2rgb(vec3(h,s,val)),1);\\n}\"}", + "settings": { + "num": 74675, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/rossylo/dontuthink", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* Lambmeow */ \n\n#define PI radians(180.)\n\nvec2 GetCirclePoint(float id, float NumCircleSegments) {\n \n \n float ux= floor(id/6.) + mod(id,2.);\n float vy = mod(floor(id/2.)+ floor(id/3.), 2.);\n \n float angle =ux/NumCircleSegments * PI * 2. ;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy +1.;\n \n \n \n float x = c * radius ; \n float y = s * radius;\n \n return vec2(x,y);\n \n \n}\n\n\nvec3 hsv2rgb(vec3 c) {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main(){\n float numCircleSeg = 20.;\n vec2 cir = GetCirclePoint(vertexId,numCircleSeg);\n float numPointsPerCircle = numCircleSeg * 6.;\n float circleId = floor(vertexId/numPointsPerCircle);\n float numCircles = floor(vertexCount/numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles/down);\n \n float x = mod(circleId,across);\n float y = floor(circleId/across);\n \n float u = x/(across-1.);\n float v = y/(across- 1.);\n \n float xoff = sin(time + y *.2);\n float yoff = sin(time +x *.2);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x/resolution.y;\n float snd = texture2D(sound, vec2(u,v/4.)).a;\n float scale = pow(snd +.2,.5);\n float soff = sin(time +x * y ) * .5 ;\n \n vec2 xy = cir * .3* vec2(ux,vy) * texture2D(sound,vec2(u,v)).a;\n \n gl_Position = vec4(xy,0,1) * vec4(1,aspect,1,1);\n\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x/ 600.;\n float h = (u +cos(time * -v))* sin(time * .3) + snd;\n float s = 1.;\n float val = v+.8;\n v_color = vec4(hsv2rgb(vec3(h,s,val)),1);\n}" + }, "screenshotURL": "data/images/images-8hcihqg55uvaywg3v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/toqC3cLBCWT32vPb2/art.json b/art/toqC3cLBCWT32vPb2/art.json index 91d7d31e..3f294411 100644 --- a/art/toqC3cLBCWT32vPb2/art.json +++ b/art/toqC3cLBCWT32vPb2/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":25093,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/ziad-husni/skyguide-music\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 1.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nfloat easeInOutPow(float pos, float pw) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, pw);\\n }\\n return 0.5 * (pow((pos - 2.), pw) + 2.);\\n}\\n\\n\\nvoid main() {\\n vec3 pos = vec3(0, 0, 0);\\n //pos *= vec3(100, 100, 10);\\n \\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\\n float tm = time * -0.05;\\n float t2 = time * 0.05;\\n float t3 = time * 0.04;\\n float r = mix(10., 5., sin(t3) * .5 + .5);\\n vec3 eye = vec3(cos(tm) * r, sin(t2) * 2. + 3., sin(tm) * r);\\n vec3 target = vec3(0, sin(t2) * -2.5, 0);\\n vec3 up = vec3(0, 1, 0);\\n mat *= cameraLookAt(eye, target, up);\\n \\n vec3 n = normalize(\\n vec3(\\n hash(vertexId * 0.123), \\n hash(vertexId * 0.357), \\n hash(vertexId * 0.531)\\n ) * 2. - 1.\\n );\\n \\n if (vertexId < 5000.0) {\\n mat *= trans(n * 84.);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.25;;\\n v_color = vec4(hash(vertexId * 0.211));\\n } else {\\n float d = hash(vertexId * 0.713);// * (sin(vertexId * 1.5) * .5 + .5);\\n \\n float s = texture2D(sound, vec2(d * .1, 0)).a;\\n \\n mat *= rotY(time * mix(0.01, 0.3, (1. - d)) + sin(atan(n.x,n.z) * 20.));\\n mat *= scale(vec3(10, easeInOutPow((1. - d), 4.) * 5., 10));\\n mat *= trans(n * pow(d, 3.));\\n gl_Position = mat * vec4(pos, 1);\\n\\n vec4 f = mat * vec4(1,1,pos.z,1);\\n f = f / f.w;\\n\\n gl_PointSize = mix(1.5, 2.5, (1. - d)); //f.y * 0.5;\\n float hue = mix(0.4, 0.8, s);\\n float sat = 0.45;\\n float val = mix(1., 1., s);\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), pow(1.-d, 0.2));\\n } \\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 25093, + "mode": "POINTS", + "sound": "https://soundcloud.com/ziad-husni/skyguide-music", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 1.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nfloat easeInOutPow(float pos, float pw) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, pw);\n }\n return 0.5 * (pow((pos - 2.), pw) + 2.);\n}\n\n\nvoid main() {\n vec3 pos = vec3(0, 0, 0);\n //pos *= vec3(100, 100, 10);\n \n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.01, 100.0);\n float tm = time * -0.05;\n float t2 = time * 0.05;\n float t3 = time * 0.04;\n float r = mix(10., 5., sin(t3) * .5 + .5);\n vec3 eye = vec3(cos(tm) * r, sin(t2) * 2. + 3., sin(tm) * r);\n vec3 target = vec3(0, sin(t2) * -2.5, 0);\n vec3 up = vec3(0, 1, 0);\n mat *= cameraLookAt(eye, target, up);\n \n vec3 n = normalize(\n vec3(\n hash(vertexId * 0.123), \n hash(vertexId * 0.357), \n hash(vertexId * 0.531)\n ) * 2. - 1.\n );\n \n if (vertexId < 5000.0) {\n mat *= trans(n * 84.);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.25;;\n v_color = vec4(hash(vertexId * 0.211));\n } else {\n float d = hash(vertexId * 0.713);// * (sin(vertexId * 1.5) * .5 + .5);\n \n float s = texture2D(sound, vec2(d * .1, 0)).a;\n \n mat *= rotY(time * mix(0.01, 0.3, (1. - d)) + sin(atan(n.x,n.z) * 20.));\n mat *= scale(vec3(10, easeInOutPow((1. - d), 4.) * 5., 10));\n mat *= trans(n * pow(d, 3.));\n gl_Position = mat * vec4(pos, 1);\n\n vec4 f = mat * vec4(1,1,pos.z,1);\n f = f / f.w;\n\n gl_PointSize = mix(1.5, 2.5, (1. - d)); //f.y * 0.5;\n float hue = mix(0.4, 0.8, s);\n float sat = 0.45;\n float val = mix(1., 1., s);\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)), pow(1.-d, 0.2));\n } \n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-u7y4s1w0zqj15j3g5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/trsRykwiAHEtSA98a/art.json b/art/trsRykwiAHEtSA98a/art.json index 326277f9..6f0da067 100644 --- a/art/trsRykwiAHEtSA98a/art.json +++ b/art/trsRykwiAHEtSA98a/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":49311,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat getX(float t) {\\n return\\n 545./23.*sin(t + 37./22.) +\\n 35./26.*sin(2.*t + 121./53.) +\\n 65./24.*sin(3.*t + 53./30.) +\\n 11./39.*sin(4.*t + 61./25.) +\\n\\n 21./25.*sin(5.*t + 19./11.) +\\n 3./22.*sin(6.*t + 15./44.) +\\n 13./24.*sin(7.*t + 62./43.) +\\n \\n 4./19.*sin(8.*t + 31./38.) + \\n 15./32.*sin(9.*t + 36./23.) +\\n 3./22.*sin(10.*t + 46./29.) +\\n \\n 8./27.*sin(11.+t + 29./16.) +\\n 1./34.*sin(12.+t + 89./40.) +\\n //103760./29. +\\n \\n 0.;\\n}\\n\\nfloat getY(float t) {\\n return \\n -1./23.*sin(7./24.-10.*t) +\\n 482./21.*sin(t+8./5.) +\\n 61./50.*sin(2.*t+73./31.) +\\n \\n 45./17.*sin(3.*t+110./73.) +\\n 23./42.*sin(4.*t+107./48.) +\\n 13./14.*sin(5.*t+30./19.) +\\n \\n 10./33.*sin(1.)+\\n 20./59.*sin(7.*t+27./16.) +\\n 3./29.*sin(8.*t+131./39.) +\\n \\n 4./27.*sin(9.*t+17./18.) +\\n 7./36.*sin(11.*t+53./74.) +\\n 3./37.*sin(12.*t+9./8.) -\\n // 11131./37. +\\n \\n 0.;\\n}\\n \\n\\nvoid main() {\\n float t = vertexId / vertexCount * PI * 4. * 12.;\\n float x = getX(t);\\n float y = getY(t);\\n vec2 xy = vec2(x, y);\\n gl_Position = vec4(xy * 0.005, 0, 1);\\n gl_PointSize = 2.;\\n \\n v_color = vec4(1);\\n}\"}", + "settings": { + "num": 49311, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat getX(float t) {\n return\n 545./23.*sin(t + 37./22.) +\n 35./26.*sin(2.*t + 121./53.) +\n 65./24.*sin(3.*t + 53./30.) +\n 11./39.*sin(4.*t + 61./25.) +\n\n 21./25.*sin(5.*t + 19./11.) +\n 3./22.*sin(6.*t + 15./44.) +\n 13./24.*sin(7.*t + 62./43.) +\n \n 4./19.*sin(8.*t + 31./38.) + \n 15./32.*sin(9.*t + 36./23.) +\n 3./22.*sin(10.*t + 46./29.) +\n \n 8./27.*sin(11.+t + 29./16.) +\n 1./34.*sin(12.+t + 89./40.) +\n //103760./29. +\n \n 0.;\n}\n\nfloat getY(float t) {\n return \n -1./23.*sin(7./24.-10.*t) +\n 482./21.*sin(t+8./5.) +\n 61./50.*sin(2.*t+73./31.) +\n \n 45./17.*sin(3.*t+110./73.) +\n 23./42.*sin(4.*t+107./48.) +\n 13./14.*sin(5.*t+30./19.) +\n \n 10./33.*sin(1.)+\n 20./59.*sin(7.*t+27./16.) +\n 3./29.*sin(8.*t+131./39.) +\n \n 4./27.*sin(9.*t+17./18.) +\n 7./36.*sin(11.*t+53./74.) +\n 3./37.*sin(12.*t+9./8.) -\n // 11131./37. +\n \n 0.;\n}\n \n\nvoid main() {\n float t = vertexId / vertexCount * PI * 4. * 12.;\n float x = getX(t);\n float y = getY(t);\n vec2 xy = vec2(x, y);\n gl_Position = vec4(xy * 0.005, 0, 1);\n gl_PointSize = 2.;\n \n v_color = vec4(1);\n}" + }, "screenshotURL": "data/images/images-mceng9j354ieuiv68-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/trsmEtfPkaXKti9gH/art.json b/art/trsmEtfPkaXKti9gH/art.json index b0fc73a7..d92a293b 100644 --- a/art/trsmEtfPkaXKti9gH/art.json +++ b/art/trsmEtfPkaXKti9gH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "der", "avatarUrl": "https://secure.gravatar.com/avatar/3edd222097c4b36118a8d5f5ab65ddb6?default=retro&size=200", - "settings": "{\"num\":15606,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float dist(vec2 p1, vec2 p2) {\\n return sqrt(pow(p1.x - p2.x, 2.0) + pow(p1.y - p2.y, 2.0));\\n}\\n\\nvoid main() {\\n float across = floor(sqrt(vertexCount));\\n \\n float x = (mod(vertexId, across) / (across - 1.0) * 2.0 - 1.0) * 1.5;\\n float y = (floor(vertexId / across) / (across - 1.0) * 2.0 - 1.0) * 1.5;\\n \\n float distFromCenter = dist(vec2(x, y), vec2(0.0, 0.0));\\n float ang = atan(0.0 - y, 0.0 - x);\\n \\n float farthestDist = dist(vec2(1.0, 1.0), vec2(0.0, 0.0));\\n \\n float normX = cos(ang + time * (farthestDist - distFromCenter));\\n float normY = sin(ang + time * (farthestDist - distFromCenter));\\n \\n float xPos = normX * distFromCenter;\\n float yPos = normY * distFromCenter;\\n \\n gl_Position = vec4(xPos, yPos, 0.0, 1.0);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1.0, 1.0, 1.0, 1.0);\\n}\"}", + "settings": { + "num": 15606, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float dist(vec2 p1, vec2 p2) {\n return sqrt(pow(p1.x - p2.x, 2.0) + pow(p1.y - p2.y, 2.0));\n}\n\nvoid main() {\n float across = floor(sqrt(vertexCount));\n \n float x = (mod(vertexId, across) / (across - 1.0) * 2.0 - 1.0) * 1.5;\n float y = (floor(vertexId / across) / (across - 1.0) * 2.0 - 1.0) * 1.5;\n \n float distFromCenter = dist(vec2(x, y), vec2(0.0, 0.0));\n float ang = atan(0.0 - y, 0.0 - x);\n \n float farthestDist = dist(vec2(1.0, 1.0), vec2(0.0, 0.0));\n \n float normX = cos(ang + time * (farthestDist - distFromCenter));\n float normY = sin(ang + time * (farthestDist - distFromCenter));\n \n float xPos = normX * distFromCenter;\n float yPos = normY * distFromCenter;\n \n gl_Position = vec4(xPos, yPos, 0.0, 1.0);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1.0, 1.0, 1.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-ign6dm9bnsv1ygv8v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/tw3mJeCpEXQ6gMz2q/art.json b/art/tw3mJeCpEXQ6gMz2q/art.json index 55069609..acc4e58d 100644 --- a/art/tw3mJeCpEXQ6gMz2q/art.json +++ b/art/tw3mJeCpEXQ6gMz2q/art.json @@ -27,7 +27,19 @@ "name": "pointsprite plasma", "private": false, "username": "myownclone", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n \\n c = sin(pos.x) * cos(pos.y);; \\n \\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 10.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n \n c = sin(pos.x) * cos(pos.y);; \n \n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 10.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-bzox4m0o3l9cie99k-thumbnail.jpg", "views": { "$numberInt": "201" diff --git a/art/txxXeHf8AFDuZzxWD/art.json b/art/txxXeHf8AFDuZzxWD/art.json index 09b2c0b9..8d5952e0 100644 --- a/art/txxXeHf8AFDuZzxWD/art.json +++ b/art/txxXeHf8AFDuZzxWD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":21019,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n#define KP0 11. /time\\nvec3 gSunColor = vec3(1.0, 0.2, 1.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(-2.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 1.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -20.4 +KP0) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 3.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.15 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 12.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 6.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 1.0, 0.0 );\\n \\n float across = 48.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock)-2.0;\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 1.;\\n float z = vP * down * 1.4 + bzId * 0.2;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n //mat *= rotZ(p1m1(snd) * 10.);\\n //mat *= rotY(p1m1(snd) * 10.);\\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \\n st,//pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n// \\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.16, 1.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\\n float ca = 0.004;\\n \\n // get sick!\\n ca = time * 0.51;\\n \\tvec3 vCameraUp = vec3( sin(ca), time *0.3, cos(ca) );\\n // \\tvec3 vCameraUp = vec3( 0, 0, 1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount )-1.;\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, (.1), 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 0.5);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(0.7) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 0.5), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 21019, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/drumcode/pigdan-mexico-drumcode-dc157", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n#define KP0 11. /time\nvec3 gSunColor = vec3(1.0, 0.2, 1.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(-2.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 1.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -20.4 +KP0) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 3.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.15 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 12.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 6.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 1.0, 0.0 );\n \n float across = 48.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock)-2.0;\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 1.;\n float z = vP * down * 1.4 + bzId * 0.2;\n vCubeOrigin.z += z; \n float height = 1.;\n //vCubeOrigin.y += pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n //mat *= rotZ(p1m1(snd) * 10.);\n //mat *= rotY(p1m1(snd) * 10.);\n mat *= uniformScale(mix(0., 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.0) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.5, st), \n st,//pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n// \tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0, 0.16, 1.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3(0, 70. - sin(time * 0.1) * 30., sin(time * 0.13) * 50.0);\n float ca = 0.004;\n \n // get sick!\n ca = time * 0.51;\n \tvec3 vCameraUp = vec3( sin(ca), time *0.3, cos(ca) );\n // \tvec3 vCameraUp = vec3( 0, 0, 1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount )-1.;\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, (.1), 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 0.5);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(0.7) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 0.5), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-vr3awyne9z1klpayk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/u2cNzFGq9v9PnRyAM/art.json b/art/u2cNzFGq9v9PnRyAM/art.json index 1abf38fe..7fde7d4c 100644 --- a/art/u2cNzFGq9v9PnRyAM/art.json +++ b/art/u2cNzFGq9v9PnRyAM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "clydepashley", "avatarUrl": "https://avatars.githubusercontent.com/clydepashley?s=200", - "settings": "{\"num\":10000,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n cgv) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.05)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\\n mat *= trans(vec3(offset));\\n float gt = time + gv * PI * 50.;\\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\\n mat *= uniformScale(0.3 * cgv + snd * .1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float pump = step(0.65, snd);\\n float hue = 1. + cgId * 1. + pump * .7;\\n float sat = mod(cgId, 2.) + pump;\\n float val = 1. - mod(cgId + 1., 2.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 10000, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n cgv) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.05)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 1, 1) * 1.5);\n mat *= rotZ(time * 0.1 * mix(-1., 1., mod(groupId, 2.)));\n mat *= trans(vec3(offset));\n float gt = time + gv * PI * 50.;\n mat *= trans(vec3(sin(gt), cos(gt), 0) * .095 * (1. - cgv * .5));\n mat *= uniformScale(0.3 * cgv + snd * .1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float pump = step(0.65, snd);\n float hue = 1. + cgId * 1. + pump * .7;\n float sat = mod(cgId, 2.) + pump;\n float val = 1. - mod(cgId + 1., 2.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb = mix(v_color.rgb, vec3(1), pump);\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-yts4d10u87c1j53p5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/u4Ycc5AWRWWSk23Dt/art.json b/art/u4Ycc5AWRWWSk23Dt/art.json index e4485c6c..8e1a980c 100644 --- a/art/u4Ycc5AWRWWSk23Dt/art.json +++ b/art/u4Ycc5AWRWWSk23Dt/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "paul", "avatarUrl": "https://lh3.googleusercontent.com/-04n4H9P9k8s/AAAAAAAAAAI/AAAAAAAAACE/FJR_Kf7XPpQ/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\nfloat width = floor(sqrt(vertexCount));\\nfloat x = mod(vertexId,width);\\nfloat y = floor(vertexId/width);\\n\\nfloat u = x/(width - 1.0);\\nfloat v = y/(width - 1.0);\\n\\nfloat xOffset = cos(time + y * .2) *.1;\\nfloat yOffset = cos(time + x * .2) *.1;\\n\\nfloat ux = u*2.0 - 1.0 + xOffset;\\nfloat vy = v*2.0 - 1.0 + yOffset;\\n\\n//vertex id 0 1 2 3 4 ... 10 11 12 ... 20 21 22\\n//mod X 0 1 2 3 4 ... 0 1 2 ... 0 1 2\\n//floor Y 0 0 0 0 0 ... 1 1 1 ... 2 2 2\\n\\nvec2 xy = vec2(ux,vy)*1.2;\\n\\nfloat sizeOffSet = sin(time + x * y * .2)*5.;\\n\\ngl_Position = vec4(xy, 0.0, 1.0);\\ngl_PointSize = 15.0 + sizeOffSet;\\ngl_PointSize*= 32.0 / width;\\nv_color = vec4(256.0, 128.0, 0.0, 1.0);\\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\nfloat width = floor(sqrt(vertexCount));\nfloat x = mod(vertexId,width);\nfloat y = floor(vertexId/width);\n\nfloat u = x/(width - 1.0);\nfloat v = y/(width - 1.0);\n\nfloat xOffset = cos(time + y * .2) *.1;\nfloat yOffset = cos(time + x * .2) *.1;\n\nfloat ux = u*2.0 - 1.0 + xOffset;\nfloat vy = v*2.0 - 1.0 + yOffset;\n\n//vertex id 0 1 2 3 4 ... 10 11 12 ... 20 21 22\n//mod X 0 1 2 3 4 ... 0 1 2 ... 0 1 2\n//floor Y 0 0 0 0 0 ... 1 1 1 ... 2 2 2\n\nvec2 xy = vec2(ux,vy)*1.2;\n\nfloat sizeOffSet = sin(time + x * y * .2)*5.;\n\ngl_Position = vec4(xy, 0.0, 1.0);\ngl_PointSize = 15.0 + sizeOffSet;\ngl_PointSize*= 32.0 / width;\nv_color = vec4(256.0, 128.0, 0.0, 1.0);\n\n}" + }, "screenshotURL": "data/images/images-5ic2khxhjcsa8vmml-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/u9hvPc2WxibcTmT6F/art.json b/art/u9hvPc2WxibcTmT6F/art.json index f1b6f206..231d533c 100644 --- a/art/u9hvPc2WxibcTmT6F/art.json +++ b/art/u9hvPc2WxibcTmT6F/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/el-bee/little-bitchard-feat-xander-pills-owl-stretching-time\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 2.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd = texture2D(sound, vec2(mix(0.01, 0.14, su), gv * 0.05)).a;\\n \\n //snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n vec3 pos;\\n float inner = mix(0.0, 1. - pow(snd, 4.), cgId);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n float gDown = floor(sqrt(numGroups));\\n float gAcross = floor(numGroups / gDown);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + fract(time * 8.) + mod(gy, 2.) * 0.5,\\n (gy - (gDown - 1.) / 2.) * 0.8,\\n 0) * 0.1;\\n \\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(vec3(0.25,0,0));\\n mat *= rotZ(-time * 0.);\\n mat *= trans(offset);\\n float sp = pow(snd, 5.0);\\n\\n mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.05 + sliceId * 0.0);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = tm * 0.1 + mix(0., 0.2, abs(atan(offset.y, offset.x) / PI));//hash(groupId * 0.23));\\n float sat = 1. - pow(snd, 5.);\\n float val = mix(0.5, 1., step(0.8, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/el-bee/little-bitchard-feat-xander-pills-owl-stretching-time", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 2.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd = texture2D(sound, vec2(mix(0.01, 0.14, su), gv * 0.05)).a;\n \n //snd = pow(snd, mix(2., 0.5, su));\n \n \n vec3 pos;\n float inner = mix(0.0, 1. - pow(snd, 4.), cgId);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n float gDown = floor(sqrt(numGroups));\n float gAcross = floor(numGroups / gDown);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + fract(time * 8.) + mod(gy, 2.) * 0.5,\n (gy - (gDown - 1.) / 2.) * 0.8,\n 0) * 0.1;\n \n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(vec3(0.25,0,0));\n mat *= rotZ(-time * 0.);\n mat *= trans(offset);\n float sp = pow(snd, 5.0);\n\n mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.05 + sliceId * 0.0);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = tm * 0.1 + mix(0., 0.2, abs(atan(offset.y, offset.x) / PI));//hash(groupId * 0.23));\n float sat = 1. - pow(snd, 5.);\n float val = mix(0.5, 1., step(0.8, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-qtgkigrawla1fyuu4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uAHaEoLE9cg9b7WQL/art.json b/art/uAHaEoLE9cg9b7WQL/art.json index 99cca606..dba1cc7c 100644 --- a/art/uAHaEoLE9cg9b7WQL/art.json +++ b/art/uAHaEoLE9cg9b7WQL/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kim-kimsinho/epic-sax-guy\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= rotZ(snd * 10. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n float ca = time * -0.05;\\n float cd = 2.;\\n vec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n camera *= cameraLookAt(eye, target, up);\\n \\n gl_Position = camera * mat * pos;\\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.; //mix(0.5, 1., pump);\\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kim-kimsinho/epic-sax-guy", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n////////////////////////////////////////////////////////////\nvec2 getCirclePoint(float id, float numCircleSegments)\n{\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0));\n mat *= rotZ(snd * 10. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n float ca = time * -0.05;\n float cd = 2.;\n vec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n camera *= cameraLookAt(eye, target, up);\n \n gl_Position = camera * mat * pos;\n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.; //mix(0.5, 1., pump);\n float val = mix(.4, pow(snd + 0.2, 5.0), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-n2hiopd5pf2otlnt4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uB888bmYT66k3orcR/art.json b/art/uB888bmYT66k3orcR/art.json index 8a2f84be..6118e744 100644 --- a/art/uB888bmYT66k3orcR/art.json +++ b/art/uB888bmYT66k3orcR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangjin.lee", "avatarUrl": "https://secure.gravatar.com/avatar/43c092b75e622812b5ae9c173521d1e6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"//CS250\\n//Sangjin Lee\\n//2023 Spring\\n//Exercise - Vertexshaderart : Motion is due\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "//CS250\n//Sangjin Lee\n//2023 Spring\n//Exercise - Vertexshaderart : Motion is due\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-esv729f2yjlwcb2cs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uBNYQJxs6ta546Y5j/art.json b/art/uBNYQJxs6ta546Y5j/art.json index 0e1fd260..f4133930 100644 --- a/art/uBNYQJxs6ta546Y5j/art.json +++ b/art/uBNYQJxs6ta546Y5j/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3923,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float width = floor(sqrt(vertexCount-8.));\\n \\n float x = mod(vertexId*0.5, width);\\n float y = floor(vertexId / width/6.);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - .6);\\n \\n float xOffset = cos(time + y * 10.2) * 0.1;\\n float yOffset = cos(time + x * 1.3) * 0.3;\\n \\n float ux = u * 2.0 - 1.35 -sin(time)+ xOffset;\\n float vy = v * 5.0 / (time *0.3) + yOffset;\\n \\n //vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\\n \\n vec2 xy = vec2(ux, vy) * (2.2-sin(time/x-3.));\\n \\n gl_Position = vec4 (xy, 0.25, 1.0);\\n \\n float sizeOffset = sin(time + x * y * 0.712) * 17.0;\\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 3.0 / width/6.;\\n \\n v_color= vec4(0.5, .22, (x *sin(y-time*0.6)-y), 0.2);\\n}\"}", + "settings": { + "num": 3923, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float width = floor(sqrt(vertexCount-8.));\n \n float x = mod(vertexId*0.5, width);\n float y = floor(vertexId / width/6.);\n \n float u = x / (width - 1.0);\n float v = y / (width - .6);\n \n float xOffset = cos(time + y * 10.2) * 0.1;\n float yOffset = cos(time + x * 1.3) * 0.3;\n \n float ux = u * 2.0 - 1.35 -sin(time)+ xOffset;\n float vy = v * 5.0 / (time *0.3) + yOffset;\n \n //vertexId 0 1 2 ... 10 11 12 13 ... 20 21 22\n //mod 0 1 2 ... 0 1 2 3 ... 0 1 2 (residuo) X\n //floor 0 0 0 ... 1 1 1 1 ... 2 2 2 (divididos) Y\n \n vec2 xy = vec2(ux, vy) * (2.2-sin(time/x-3.));\n \n gl_Position = vec4 (xy, 0.25, 1.0);\n \n float sizeOffset = sin(time + x * y * 0.712) * 17.0;\n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 3.0 / width/6.;\n \n v_color= vec4(0.5, .22, (x *sin(y-time*0.6)-y), 0.2);\n}" + }, "screenshotURL": "data/images/images-vcpwm7spg7fbpz5om-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uD6PQ38TinznYz4vi/art.json b/art/uD6PQ38TinznYz4vi/art.json index 74df58f2..9cf8a4af 100644 --- a/art/uD6PQ38TinznYz4vi/art.json +++ b/art/uD6PQ38TinznYz4vi/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "mats", "avatarUrl": "https://lh3.googleusercontent.com/-oRuhWa2k-Mg/AAAAAAAAAAI/AAAAAAAABAM/VJyYs7ET7R4/photo.jpg", - "settings": "{\"num\":1914,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mickenilsson/ut-ni-on\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\nvoid main() {\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount/ down);\\n \\n\\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId / across );\\n\\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n\\n \\tfloat xoff = 0.; // sin(time + y * .2) * 0.1;\\n \\tfloat yoff = 0.; // sin(time + x * .3) * 0.2;\\n\\n \\t\\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n\\tvec2 xy = vec2(ux,vy) * 1.3;\\n \\n\\n float sv = abs(v - 0.5) * 2.;\\n \\tfloat su = abs(u - 0.5) * 2.;\\n \\tfloat au = abs(atan(su,sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n\\n\\tfloat snd = texture2D(sound, vec2(su * .125, sv * .25)).a;\\n \\t\\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = snd * 30. + soff;\\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n\\n \\tfloat pump= step(0.8, snd);\\n \\tfloat hue = u * .1 + snd * 0.2 + time; // u * .1 + sin(time + v * 20.) * 0.05;\\n \\tfloat sat = mix(0., 1., pump); // mix(1., -10., av);\\n \\tfloat val = pow(snd + 0.2, 5.); // 1.; // sin(time + v * u *20.0) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n \\n}\"}", + "settings": { + "num": 1914, + "mode": "POINTS", + "sound": "https://soundcloud.com/mickenilsson/ut-ni-on", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\nvoid main() {\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount/ down);\n \n\tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId / across );\n\n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n\n \tfloat xoff = 0.; // sin(time + y * .2) * 0.1;\n \tfloat yoff = 0.; // sin(time + x * .3) * 0.2;\n\n \t\n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n\tvec2 xy = vec2(ux,vy) * 1.3;\n \n\n float sv = abs(v - 0.5) * 2.;\n \tfloat su = abs(u - 0.5) * 2.;\n \tfloat au = abs(atan(su,sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n\n\tfloat snd = texture2D(sound, vec2(su * .125, sv * .25)).a;\n \t\n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = snd * 30. + soff;\n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n\n \tfloat pump= step(0.8, snd);\n \tfloat hue = u * .1 + snd * 0.2 + time; // u * .1 + sin(time + v * 20.) * 0.05;\n \tfloat sat = mix(0., 1., pump); // mix(1., -10., av);\n \tfloat val = pow(snd + 0.2, 5.); // 1.; // sin(time + v * u *20.0) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n \n}" + }, "screenshotURL": "data/images/images-k6j9i5il8guf3k4wi-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uDBqerAHTiHEjQMdR/art.json b/art/uDBqerAHTiHEjQMdR/art.json index 8891dcf2..ddee23bc 100644 --- a/art/uDBqerAHTiHEjQMdR/art.json +++ b/art/uDBqerAHTiHEjQMdR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/brianne-becker/charlie-brown-o-tannenbaum\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n _____, ____, ___, ___, __ _, \\n(-| | | (-|_, (-|_) (-|_) (-\\\\ | \\n _| | |_, _|__, _| \\\\_, _| \\\\_, \\\\| \\n( ( ( ( (__/ \\n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \\n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\\\_,(-(__`\\n \\\\___, _| |_, _| \\\\_, _|__, ____) _| _| | |_, _| ) ____)\\n ( ( ( ( ( ( ( ( \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float t = vertexId / vertexCount + fract(time * 8.) * -0.0025;\\n float sideId = mod(vertexId, 2.);\\n float twist = vertexCount / 200.0;\\n \\n t = cos(t * PI * .5);\\n\\n float m = t * PI * twist + sideId * PI;\\n float r = t * .75;\\n \\n m += mod(time / vertexCount, 1.);\\n\\n float x = r * cos(m);\\n float z = r * sin(m);\\n\\n float aspect = resolution.x / resolution.y;\\n gl_Position = vec4(\\n vec3(\\n x / aspect, \\n t * -2. + 1., \\n z) * 0.8,\\n 1);\\n gl_PointSize = 3.0;\\n v_color.rgb = mix(vec3(1,0,0), vec3(0,1,1), sideId); \\n v_color.a = mix(.5, 1., sin(m) * .5 * .5);\\n v_color.a = mix(.2, 1., step(0., -sin(m)));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/brianne-becker/charlie-brown-o-tannenbaum", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n _____, ____, ___, ___, __ _, \n(-| | | (-|_, (-|_) (-|_) (-\\ | \n _| | |_, _|__, _| \\_, _| \\_, \\| \n( ( ( ( (__/ \n ____ __ _, ___, ____, ____ ____, _____, ___, ____ \n (-/ ` (-|__| (-|_) (-| (-(__`(-| (-| | | (-|_\\_,(-(__`\n \\___, _| |_, _| \\_, _|__, ____) _| _| | |_, _| ) ____)\n ( ( ( ( ( ( ( ( \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvoid main() {\n float t = vertexId / vertexCount + fract(time * 8.) * -0.0025;\n float sideId = mod(vertexId, 2.);\n float twist = vertexCount / 200.0;\n \n t = cos(t * PI * .5);\n\n float m = t * PI * twist + sideId * PI;\n float r = t * .75;\n \n m += mod(time / vertexCount, 1.);\n\n float x = r * cos(m);\n float z = r * sin(m);\n\n float aspect = resolution.x / resolution.y;\n gl_Position = vec4(\n vec3(\n x / aspect, \n t * -2. + 1., \n z) * 0.8,\n 1);\n gl_PointSize = 3.0;\n v_color.rgb = mix(vec3(1,0,0), vec3(0,1,1), sideId); \n v_color.a = mix(.5, 1., sin(m) * .5 * .5);\n v_color.a = mix(.2, 1., step(0., -sin(m)));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-40kex9pv9s2ex3dvt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uDDkmQ76JPKLooXHk/art.json b/art/uDDkmQ76JPKLooXHk/art.json index e4207d34..0afc45ac 100644 --- a/art/uDDkmQ76JPKLooXHk/art.json +++ b/art/uDDkmQ76JPKLooXHk/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "markus", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GifvlNvBe-lLi3fzBlpXK1QVVIW7V5Nwqq8cssCjA", - "settings": "{\"num\":80944,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 24.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float circlesPerRow = 33.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow) * 2.;\\n float cy = floor(circleId / circlesPerRow) * 2.;\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n float sx = cx - circlesPerRow;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.0;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx, cy, 0, 0);\\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\\n \\n // scale\\n gl_Position *= scale(1. / 20.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 80944, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 24.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float circlesPerRow = 33.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow) * 2.;\n float cy = floor(circleId / circlesPerRow) * 2.;\n \n vec2 soundTexCoords = vec2(0, 0);\n float sx = cx - circlesPerRow;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * 0.215;\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.0;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx, cy, 0, 0);\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\n \n // scale\n gl_Position *= scale(1. / 20.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-x8k6q35meop75gfeh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uF8TFTKpj88nNiuD2/art.json b/art/uF8TFTKpj88nNiuD2/art.json index bed32960..fe8f6f30 100644 --- a/art/uF8TFTKpj88nNiuD2/art.json +++ b/art/uF8TFTKpj88nNiuD2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":80946,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 24.;\\n float vertsPerSegment = 6.;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\\n float circlesPerRow = 33.;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow) * 2.;\\n float cy = floor(circleId / circlesPerRow) * 2.;\\n \\n vec2 soundTexCoords = vec2(0, 0);\\n float sx = cx - circlesPerRow;\\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * (sin(time * 0.25) * 0.5 + 0.5);// * 0.215;\\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2., 1);\\n gl_Position += vec4(cx, cy, 0, 0);\\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\\n \\n // scale\\n gl_Position *= scale(1. / 16.);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\\n}\"}", + "settings": { + "num": 80946, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 24.;\n float vertsPerSegment = 6.;\n \n // set base vert pos\n float bx = mod(vertexId, 2.) + floor(vertexId / 6.);\n float by = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / segmentsPerCircle * vertsPerSegment;\n float circlesPerRow = 33.;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow) * 2.;\n float cy = floor(circleId / circlesPerRow) * 2.;\n \n vec2 soundTexCoords = vec2(0, 0);\n float sx = cx - circlesPerRow;\n soundTexCoords.x = abs(sx) / (abs(sx) + cy) * (sin(time * 0.25) * 0.5 + 0.5);// * 0.215;\n soundTexCoords.y = ((abs(sx) + cy) - 1.) / (circlesPerRow + circlesPerColumn) * 0.25;\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2., 1);\n gl_Position += vec4(cx, cy, 0, 0);\n gl_Position += vec4(-16., -8, 0, 0) * 2.;\n \n // scale\n gl_Position *= scale(1. / 16.);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n v_color = vec4(r * 2. - 0.5, 0, 1, 1);\n}" + }, "screenshotURL": "data/images/images-7g3698p9kq57vg1ud-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uFWQ38ziz2oKNfZZi/art.json b/art/uFWQ38ziz2oKNfZZi/art.json index aa631f71..a334338d 100644 --- a/art/uFWQ38ziz2oKNfZZi/art.json +++ b/art/uFWQ38ziz2oKNfZZi/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Motion\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = tan(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. -1. + xoff;\\n float vy = v * 2. -1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.2;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, sin(time), cos(time), 1);\\n \\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Motion\n//Course : CS250\n//Term : 2023 Fall\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = tan(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. -1. + xoff;\n float vy = v * 2. -1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.2;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, sin(time), cos(time), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-dkn5dlkuz06yp7b4v-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uGJhdfKrAj8tkovpA/art.json b/art/uGJhdfKrAj8tkovpA/art.json index 68006a81..f7ccf7f5 100644 --- a/art/uGJhdfKrAj8tkovpA/art.json +++ b/art/uGJhdfKrAj8tkovpA/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "aiekick", "avatarUrl": "https://secure.gravatar.com/avatar/9423fa0d99c42e44e2b7d18c6f88b041?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2014\\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\\n\\nvoid main() \\n{\\n\\tfloat astep = 3.14159 * 2.0 / 70.;\\n\\t\\n\\tfloat t = time * .3;\\n\\t\\n\\tfloat a = astep * float(vertexId) * t;\\n\\t\\t\\t\\n\\tvec2 d = a * vec2(cos(a), sin(a));\\n\\t\\n\\td /= 100.;\\n \\n \\td.x *= resolution.y/resolution.x;\\n\\t\\t\\n\\tgl_Position=vec4(d,0,1);\\n\\t\\n\\tv_color=vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2014\n// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n// Tuned via XShade (http://www.funparadigm.com/xshade/)\n\nvoid main() \n{\n\tfloat astep = 3.14159 * 2.0 / 70.;\n\t\n\tfloat t = time * .3;\n\t\n\tfloat a = astep * float(vertexId) * t;\n\t\t\t\n\tvec2 d = a * vec2(cos(a), sin(a));\n\t\n\td /= 100.;\n \n \td.x *= resolution.y/resolution.x;\n\t\t\n\tgl_Position=vec4(d,0,1);\n\t\n\tv_color=vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-wxu1z6zji5saekvh7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uHMnt4GHAXCSCeQyM/art.json b/art/uHMnt4GHAXCSCeQyM/art.json index 6677b382..635cde39 100644 --- a/art/uHMnt4GHAXCSCeQyM/art.json +++ b/art/uHMnt4GHAXCSCeQyM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "athega", "avatarUrl": "https://secure.gravatar.com/avatar/ac866057ea99c21292a071d08fadd152?default=retro&size=200", - "settings": "{\"num\":3072,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/laffethefox/laffe-the-fox-heaven-for-monsters\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Unmodified fork from \\\"disco ball\\\" by -anon-\\n// Added music\\n\\n#define PI 3.14159\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float v = vertexId;\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, 32.);\\n v = (v-a1)/32.;\\n float a2 = v-8.;\\n \\n float a1n = (a1+.5)/32.*2.*PI;\\n float a2n = (a2+.5)/32.*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/32.*2.*PI;\\n a2 = a2/32.*2.*PI;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n \\n \\n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\\n \\n vec3 light = vec3(0);\\n \\n for (int i = 0; i < 100; i++) {\\n float f=float(i);\\n light += pow(dot(normalize(vec3(sin(float(i)),sin(float(i)*1.3),cos(float(i)*1.43))),norm)*.5+.5,70.)*abs(vec3(sin(f*4.2),cos(f*2.5),cos(f*1.9)))*.4;\\n }\\n \\n \\n /*\\n \\n pow(dot(normalize(vec3(.3,.4,-.5)),norm)*.5+.5,50.)*vec3(.8,.3,.2)\\n \\t+ pow(dot(normalize(vec3(.1,-.2,-.5)),norm)*.5+.5,50.)*vec3(.2,.3,.8)\\n \\t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,50.)*vec3(.2,.7,.4)\\n \\t+ pow(dot(normalize(vec3(.7,-.2,-.5)),norm)*.5+.5,50.)*vec3(.7,.6,.1);\\n */\\n \\n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\\n \\n\\n v_color = vec4(vec3(light), 1);\\n}\"}", + "settings": { + "num": 3072, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/laffethefox/laffe-the-fox-heaven-for-monsters", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Unmodified fork from \"disco ball\" by -anon-\n// Added music\n\n#define PI 3.14159\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float v = vertexId;\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, 32.);\n v = (v-a1)/32.;\n float a2 = v-8.;\n \n float a1n = (a1+.5)/32.*2.*PI;\n float a2n = (a2+.5)/32.*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/32.*2.*PI;\n a2 = a2/32.*2.*PI;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n \n \n pos.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n pos.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.xz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n norm.yz *= mat2(cos(time),sin(time),-sin(time),cos(time));\n \n vec3 light = vec3(0);\n \n for (int i = 0; i < 100; i++) {\n float f=float(i);\n light += pow(dot(normalize(vec3(sin(float(i)),sin(float(i)*1.3),cos(float(i)*1.43))),norm)*.5+.5,70.)*abs(vec3(sin(f*4.2),cos(f*2.5),cos(f*1.9)))*.4;\n }\n \n \n /*\n \n pow(dot(normalize(vec3(.3,.4,-.5)),norm)*.5+.5,50.)*vec3(.8,.3,.2)\n \t+ pow(dot(normalize(vec3(.1,-.2,-.5)),norm)*.5+.5,50.)*vec3(.2,.3,.8)\n \t+ pow(dot(normalize(vec3(-.5,-.1,-.5)),norm)*.5+.5,50.)*vec3(.2,.7,.4)\n \t+ pow(dot(normalize(vec3(.7,-.2,-.5)),norm)*.5+.5,50.)*vec3(.7,.6,.1);\n */\n \n gl_Position = vec4(pos.x*resolution.y/resolution.x,pos.y, pos.z*.5+.5, 1);\n \n\n v_color = vec4(vec3(light), 1);\n}" + }, "screenshotURL": "data/images/images-5tq9t1g30u7jlidt7-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uKvQ258NCvBLd29xE/art.json b/art/uKvQ258NCvBLd29xE/art.json index 96cda4bd..fb87131a 100644 --- a/art/uKvQ258NCvBLd29xE/art.json +++ b/art/uKvQ258NCvBLd29xE/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "james2", "avatarUrl": "https://lh3.googleusercontent.com/a/AGNmyxa3JZWJm88yunQiCwAfn9zM-tkF1s8O-hJsYEynRw=s96-c", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < 6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n if (gl_Position.x < 0.) {\\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\\n v_color.rgb *= v_color.a; \\n if (v_color.a <= -.10) {\\n gl_Position.z = 10000.;\\n }\\n } else {\\n float hue = 0.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1); \\n }\\n}\\n\\n\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < 6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 2.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n if (gl_Position.x < 0.) {\n float hue = mix(0.9, 1.1, hash(cv)) + time * 0.1;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n v_color.a = mix(-.2, 0.2, pow(s, 5.));\n v_color.rgb *= v_color.a; \n if (v_color.a <= -.10) {\n gl_Position.z = 10000.;\n }\n } else {\n float hue = 0.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1); \n }\n}\n\n" + }, "screenshotURL": "data/images/images-411v75n6li62phndm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uNm4pd5oCSruRA832/art.json b/art/uNm4pd5oCSruRA832/art.json index 4d426daf..7b9f18fe 100644 --- a/art/uNm4pd5oCSruRA832/art.json +++ b/art/uNm4pd5oCSruRA832/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "kcha", "avatarUrl": "https://secure.gravatar.com/avatar/393683f94ba2c18293b67ab3d3eb6f10?default=retro&size=200", - "settings": "{\"num\":786,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2627450980392157,0.49019607843137253,0.9607843137254902,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across); // 0, 1, 2, ..., 9\\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\\n\"}", + "settings": { + "num": 786, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2627450980392157, + 0.49019607843137253, + 0.9607843137254902, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across); // 0, 1, 2, ..., 9\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}\n" + }, "screenshotURL": "data/images/images-p9ujy187654qfu21w-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uPZQYGHJDM4trFXcC/art.json b/art/uPZQYGHJDM4trFXcC/art.json index 5c8d17f1..0e8097aa 100644 --- a/art/uPZQYGHJDM4trFXcC/art.json +++ b/art/uPZQYGHJDM4trFXcC/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n#define PI radians(180.0)\\n\\nvec2 getCirclePoint(float id, float sumCircleSegments) {\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\\n // create a horizontal triangle strip\\n\\n float angle = ux / sumCircleSegments * PI * 2.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.0;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float sumCircleSegments = 12.0;\\n vec2 circleXY = getCirclePoint(vertexId, sumCircleSegments);\\n \\n float numPointsPerCircle = sumCircleSegments * 6.0;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.0);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n float su = abs(u - 0.5) * 1.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 4.0) / 9.0 + mix(1.0, 1.1, oddSlice) * 0.01;\\n \\n sc *= 15.0 / across;\\n \\n vec4 pos = vec4(circleXY, 0.0, 1.0);\\n mat4 mat = ident();\\n mat *= scale(vec3(1.0, aspect, 1.0));\\n mat *= rotZ(time * 0.05);\\n mat *= trans(vec3(ux, vy, 0.0) * 2.0);\\n mat *= rotZ(snd * 2.0 * sign(ux));\\n mat *= uniformScale(0.5 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * 0.1 + snd + sin(time * 0.1) + 0.0 * sliceId * 0.01; // sin(time * 1.2 + v * 5.0) * 0.1;\\n float sat = 1.0;mix(0.0, 1.0, pump);\\n float val = 1.0; mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\\n \\n hue = hue + pump * oddSlice * 0.8 + pump * 0.33;\\n val += oddSlice + pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ringanddorf/ring-dorf-fusion-festival-2018-bachstelzen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n#define PI radians(180.0)\n\nvec2 getCirclePoint(float id, float sumCircleSegments) {\n float ux = floor(id / 6.0) + mod(id, 2.0);\n float vy = mod(floor(id / 2.0) + floor(id / 3.0), 2.0);\n // create a horizontal triangle strip\n\n float angle = ux / sumCircleSegments * PI * 2.0;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.0;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float sumCircleSegments = 12.0;\n vec2 circleXY = getCirclePoint(vertexId, sumCircleSegments);\n \n float numPointsPerCircle = sumCircleSegments * 6.0;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.0);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.01;\n float yoff = 0.0; //sin(time * 1.1 + x * 0.3) * 0.02;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n float su = abs(u - 0.5) * 1.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * 0.25)).z;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 4.0) / 9.0 + mix(1.0, 1.1, oddSlice) * 0.01;\n \n sc *= 15.0 / across;\n \n vec4 pos = vec4(circleXY, 0.0, 1.0);\n mat4 mat = ident();\n mat *= scale(vec3(1.0, aspect, 1.0));\n mat *= rotZ(time * 0.05);\n mat *= trans(vec3(ux, vy, 0.0) * 2.0);\n mat *= rotZ(snd * 2.0 * sign(ux));\n mat *= uniformScale(0.5 * sc);\n \n gl_Position = mat * pos;\n \n float soff = snd; // sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd + 0.3, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * 0.1 + snd + sin(time * 0.1) + 0.0 * sliceId * 0.01; // sin(time * 1.2 + v * 5.0) * 0.1;\n float sat = 1.0;mix(0.0, 1.0, pump);\n float val = 1.0; mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time * 1. + v * u * 20.0) + 0.5;\n \n hue = hue + pump * oddSlice * 0.8 + pump * 0.33;\n val += oddSlice + pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-73g5vlgvpviyh8jcn-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uProMGMrzma2K7GiG/art.json b/art/uProMGMrzma2K7GiG/art.json index 7f665f31..d7216a1e 100644 --- a/art/uProMGMrzma2K7GiG/art.json +++ b/art/uProMGMrzma2K7GiG/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "pcornu", "avatarUrl": "https://secure.gravatar.com/avatar/929dd88fde273d17d765f2696eaa9a90?default=retro&size=200", - "settings": "{\"num\":3319,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n// e\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 3319, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n// e\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-csi5hkby00zeab1oj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uPu4TCDWfH27uwcgs/art.json b/art/uPu4TCDWfH27uwcgs/art.json index e2a21a9e..b862073e 100644 --- a/art/uPu4TCDWfH27uwcgs/art.json +++ b/art/uPu4TCDWfH27uwcgs/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":23390,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0784313725490196,0.06274509803921569,0.0784313725490196,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 1.>>3.\\n#define parameter1 3.//KParameter1 0.1>>3.\\n#define parameter2 4.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 3.//KParameter5 0.>>3.\\n#define parameter6 7.//KParameter6 0.>>11.\\n#define parameter7 5.//KParameter7 0.>>11.\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 2.2, 1.5)/cos(time*1.6)*parameter3);\\n vec4 K = vec4(2.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle/cos(time* 0.16 ));\\n float c =cos( angle *32.);\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, -1, 0, abs(parameter2*2.),\\n 1.-s, 0, 2, 0.4,\\n 0, 0, 0, 12); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = cos( angle * 33. );\\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\\n \\t\\n return mat4( \\n c,-s, 0.1, 0, \\n s, c, -1.5, (0.5-parameter7),\\n 0, 0, 1, parameter2,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 0, 0.,2., 0,\\n 0.33, -1, 0.5, 0.1,\\ntrans, 0, 1, 2.,\\n -0.3, 1.);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0.5, 0,\\n 0, 1, 0, 2,\\n 1, -1, 0, -0.9,\\n 0, -2, 0, 2.4);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 1,\\n 0, -0.1, 0.5, 2.5);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n -s, 0, 1.5, 0,\\n 0, 0.7+s, s-mouse.x, 1.31,\\n s-0.5, 1.3, 0, 1.-s,\\n 2, 0.5, 0.2, 1.2);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\\n\\treturn fract(p2.x / p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 1.6, v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 2. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = 0.15;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * \\t1.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 12.0);\\n float side = mix(1., 5.3, step(2., mod(circleId, 311.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * 2.1)));\\n float start = fract(hash(circleId * 23.33) + cos(time * .03 + circleId) *0.1 /mouse.x);\\n float end = start * 1.3/vertexCount;\\n start + hash(sideId + 2.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 1.8 *1.3)) * 0.5, uv.y * 120.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\\n ));\\n offset.x += goop(circleId + time - parameter2 + 0.103) * 0.4;\\n offset.y += goop(circleId * time * 0.13)-pos.x;\\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset+parameter3);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\\n}\"}", + "settings": { + "num": 23390, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/crystal-tech/sets/g-mothafuckin-jones", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0784313725490196, + 0.06274509803921569, + 0.0784313725490196, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 1.>>3.\n#define parameter1 3.//KParameter1 0.1>>3.\n#define parameter2 4.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 3.//KParameter5 0.>>3.\n#define parameter6 7.//KParameter6 0.>>11.\n#define parameter7 5.//KParameter7 0.>>11.\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 2.2, 1.5)/cos(time*1.6)*parameter3);\n vec4 K = vec4(2.0, 3.0 / -3.0, 2.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.35, 0.8)*parameter1, c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle/cos(time* 0.16 ));\n float c =cos( angle *32.);\n \t\n return mat4( \n c, 0, s, 0,\n 0, -1, 0, abs(parameter2*2.),\n 1.-s, 0, 2, 0.4,\n 0, 0, 0, 12); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = cos( angle * 33. );\n float c = fract(mix( time,angle *3.,s*parameter7)/ time*22.);\n \t\n return mat4( \n c,-s, 0.1, 0, \n s, c, -1.5, (0.5-parameter7),\n 0, 0, 1, parameter2,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 0, 0.,2., 0,\n 0.33, -1, 0.5, 0.1,\ntrans, 0, 1, 2.,\n -0.3, 1.);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0.5, 0,\n 0, 1, 0, 2,\n 1, -1, 0, -0.9,\n 0, -2, 0, 2.4);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 1,\n 0, -0.1, 0.5, 2.5);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n -s, 0, 1.5, 0,\n 0, 0.7+s, s-mouse.x, 1.31,\n s-0.5, 1.3, 0, 1.-s,\n 2, 0.5, 0.2, 1.2);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 6.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(261.5351, 14.3137));\n\treturn fract(p2.x / p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 1.6, v- 11.1;\n}\n\nfloat inv(float v) {\n return 2. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 24.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 65.);\n float vy = mod(floor(id / 4.) - floor(id / 1.3), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE /22.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 / PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = 0.15;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * \t1.7) + tan((t * 0.013) + parameter6 -t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 12.0);\n float side = mix(1., 5.3, step(2., mod(circleId, 311.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time * 2.1)));\n float start = fract(hash(circleId * 23.33) + cos(time * .03 + circleId) *0.1 /mouse.x);\n float end = start * 1.3/vertexCount;\n start + hash(sideId + 2.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 1.8 *1.3)) * 0.5, uv.y * 120.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId - 0.7)), m1p1(circleId * numCircles*0.2\n ));\n offset.x += goop(circleId + time - parameter2 + 0.103) * 0.4;\n offset.y += goop(circleId * time * 0.13)-pos.x;\n vec3 aspect = vec3(parameter4, resolution.x / resolution.y, 0.3);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset+parameter3);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, .15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(11.01 *snd , 1.9 *mouse.x*circleId-snd , fract(circleId * 11.79 + snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 5.51, snd*6.));\n v_color = vec4(v_color.rgb, v_color.r/ v_color.a);\n}" + }, "screenshotURL": "data/images/images-1nvrtkr53rrvptp6i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uPwKetxzwcL2PFZd6/art.json b/art/uPwKetxzwcL2PFZd6/art.json index 22e90d60..d941e844 100644 --- a/art/uPwKetxzwcL2PFZd6/art.json +++ b/art/uPwKetxzwcL2PFZd6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":45000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId + next) / (numSections - 1.);\\n float v = sv * 4. + base;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n #if 0\\n s = .5;\\n s2 = 0.5;\\n #endif\\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n //float width = mix(1., 2., pow(s2, .5));\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre * .4, 1)).xyz;\\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \\n \\n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n float pump = step(0.5, s2);\\n sat = mix(sat, 1., vert * pump);\\n val = mix(val, 1., vert * pump);\\n hue = mix(hue, hue + .15, vert * pump);\\n \\n //hue += sign(pre.x) * .25;\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\\n \\n //color.rgb = zaxis * .5 + .5; \\n color.a = 1. - pow(sv, 20.0);\\n color.rgb *= color.a;\\n}\\n\\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 30.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float sideV = sideSectionId / halfSectionsAcross;\\n \\n float lr = mod(vertexId, 2.);\\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n \\n float sv = (sectionId + next * .4) / (numSections - 1.);\\n float v = sv * .2 + base + .1;\\n \\n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 tzaxis = normalize(s1 - s0);\\n vec3 txaxis = normalize(cross(s0, s1));\\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\\n \\n const float height = .05;\\n const float period = 2.;\\n const float speed = 2.;\\n const float lPeriod = 0.5;\\n \\n float sx = (sideV + lr / halfSectionsAcross);\\n float bt = sx * period + time * speed + sv * lPeriod;\\n float bh = sin(bt) * height;\\n \\n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\\n float unit = 1. / halfSectionsAcross;\\n \\n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\\n \\n r0 += tzaxis * -.01;\\n \\n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\\n \\n vec3 sb0 = normalize(rb1 - rb0);\\n vec3 sb1 = normalize(rb2 - rb1);\\n \\n vec3 zaxis = normalize(sb1 - sb0);\\n vec3 xaxis = normalize(cross(sb0, sb1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(rb0 * expand, 1)); \\n\\n #if 0\\n s = 1.;\\n s2 = 1.;\\n #endif\\n \\n float su = (sideSectionId + lr) / halfSectionsAcross;\\n\\n float width = 1.; \\n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\\n vec3 nrm = vec3(0, 1, 0);\\n \\n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = 0.3;\\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n if (id < numTrackPoints) {\\n track(id, numTrackPoints, base, pos, color);\\n } else {\\n id -= numTrackPoints;\\n if (id < numFunkPoints) {\\n funk(id, numFunkPoints, base, pos, color);\\n } else {\\n id -= numFunkPoints;\\n sky(id, base, cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 45000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId + next) / (numSections - 1.);\n float v = sv * 4. + base;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n #if 0\n s = .5;\n s2 = 0.5;\n #endif\n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n //float width = mix(1., 2., pow(s2, .5));\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre * .4, 1)).xyz;\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \n \n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n float pump = step(0.5, s2);\n sat = mix(sat, 1., vert * pump);\n val = mix(val, 1., vert * pump);\n hue = mix(hue, hue + .15, vert * pump);\n \n //hue += sign(pre.x) * .25;\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\n \n //color.rgb = zaxis * .5 + .5; \n color.a = 1. - pow(sv, 20.0);\n color.rgb *= color.a;\n}\n\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 30.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float sideV = sideSectionId / halfSectionsAcross;\n \n float lr = mod(vertexId, 2.);\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n \n float sv = (sectionId + next * .4) / (numSections - 1.);\n float v = sv * .2 + base + .1;\n \n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 tzaxis = normalize(s1 - s0);\n vec3 txaxis = normalize(cross(s0, s1));\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\n \n const float height = .05;\n const float period = 2.;\n const float speed = 2.;\n const float lPeriod = 0.5;\n \n float sx = (sideV + lr / halfSectionsAcross);\n float bt = sx * period + time * speed + sv * lPeriod;\n float bh = sin(bt) * height;\n \n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\n float unit = 1. / halfSectionsAcross;\n \n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\n \n r0 += tzaxis * -.01;\n \n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\n \n vec3 sb0 = normalize(rb1 - rb0);\n vec3 sb1 = normalize(rb2 - rb1);\n \n vec3 zaxis = normalize(sb1 - sb0);\n vec3 xaxis = normalize(cross(sb0, sb1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(rb0 * expand, 1)); \n\n #if 0\n s = 1.;\n s2 = 1.;\n #endif\n \n float su = (sideSectionId + lr) / halfSectionsAcross;\n\n float width = 1.; \n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\n vec3 nrm = vec3(0, 1, 0);\n \n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\n float sat = 0.3;\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n if (id < numTrackPoints) {\n track(id, numTrackPoints, base, pos, color);\n } else {\n id -= numTrackPoints;\n if (id < numFunkPoints) {\n funk(id, numFunkPoints, base, pos, color);\n } else {\n id -= numFunkPoints;\n sky(id, base, cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-5nuxabtwsyxdzgvvw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uQ6SBCL37HsvsjWYy/art.json b/art/uQ6SBCL37HsvsjWYy/art.json index f5da37dc..5a7cf551 100644 --- a/art/uQ6SBCL37HsvsjWYy/art.json +++ b/art/uQ6SBCL37HsvsjWYy/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":400,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(((sin(vertexId * time)*8.0) / resolution.x) * count, ((cos(vertexId * time)*4.0) / resolution.y) * count);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + (count/10.0) * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\\n\"}", + "settings": { + "num": 400, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n\n float count = floor(vertexId / NUM_POINTS);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(((sin(vertexId * time)*8.0) / resolution.x) * count, ((cos(vertexId * time)*4.0) / resolution.y) * count);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + (count/10.0) * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}\n" + }, "screenshotURL": "data/images/images-itzj8smlszzcok3c5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uQAeKH3AvcwiJJ6AW/art.json b/art/uQAeKH3AvcwiJJ6AW/art.json index 736f6a03..59cec06f 100644 --- a/art/uQAeKH3AvcwiJJ6AW/art.json +++ b/art/uQAeKH3AvcwiJJ6AW/art.json @@ -31,7 +31,19 @@ "private": true, "unlisted": false, "username": "dzozef", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float SIDE = 40.; // how many nodes on one side\\nfloat CUBESIZE = 0.1;// one node size\\nfloat NSCALE = 0.1;\\nfloat TSCALE = 2.2;\\n\\nvoid rotateX(inout vec3 p, float a) {\\n\\tfloat c,s;vec3 q=p;\\n\\tc = cos(a); s = sin(a);\\n\\tp.y = c * q.y - s * q.z;\\n\\tp.z = s * q.y + c * q.z;\\n}\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// noise from iq (https://www.shadertoy.com/view/4sfGzS)\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\nfloat noise( in vec3 x )\\n{\\n vec3 p = floor(x);\\n vec3 f = fract(x);\\n f = f*f*(3.0-2.0*f);\\n\\t\\n float n = p.x + p.y*157.0 + 113.0*p.z;\\n return mix(mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n mix( hash(n+157.0), hash(n+158.0),f.x),f.y),\\n mix(mix( hash(n+113.0), hash(n+114.0),f.x),\\n mix( hash(n+270.0), hash(n+271.0),f.x),f.y),f.z);\\n}\\n\\nfloat noise4( in vec4 x )\\n{\\n\\treturn mix( noise( x.xyz ), noise( x.xyz + vec3(-2.1*sin(x.w*0.2),4.33*sin(x.w*0.43),2.3*sin(x.w*0.5)) ), 0.5 );\\n}\\n\\nvec3 GetPoint( float vertexid, out float color, out float psize )\\n{\\n\\tfloat node = vertexid;\\n\\tif (node > SIDE*SIDE*SIDE-1.) return vec3(0.0);\\n\\t// get the grid location\\n\\tfloat y = floor( node / (SIDE*SIDE) );\\n\\tfloat z = floor( mod( node, SIDE*SIDE ) / SIDE );\\n\\tfloat x = mod( mod( node, SIDE*SIDE ), SIDE );\\n\\t// first check if empty\\n \\tvec4 npos = vec4( x, y, z, time*TSCALE ) * NSCALE;// + vec3( time, time/2., time /3. ) * TSCALE;\\n\\tfloat n = noise4( npos );\\n \\tcolor = 0.0;\\n \\tpsize = 0.0;\\n\\tif (n < 0.7 || n > 0.78) return vec3(0.);\\n\\n \\tpsize = CUBESIZE * smoothstep( n, 0.7, 0.71 ) * 220.;\\n\\n\\tvec3 normal = normalize( vec3( n-noise4( npos+vec4(.01,.0,.0,.0) ), n-noise4( npos+vec4(.0,.01,.0,.0) ), n-noise4( npos+vec4(.0,.0,.01,.0) ) ) );\\n\\n \\tnormal = rotateY( normal, -mouse.x*1.2-0.2 );\\n\\trotateX( normal, mouse.y*1.2-0.2 );\\n \\t\\n \\tvec3 light = vec3( 0.0, 1., -1. );\\n \\tnormalize( light );\\n\\tcolor = abs( dot( normal, light ) )*0.5 + abs( dot( normal, -light ) )*0.1;\\n \\n \\tvec3 p = (vec3( x, y, z ) + vec3( -SIDE/2. ))* CUBESIZE;\\n\\tp = rotateY( p, -mouse.x*1.2-0.2 );\\n\\trotateX( p, mouse.y*1.2-0.2 );\\n\\n \\t//float vid = mod( vertexid, 24. );\\n\\t//float sideid = floor( vid / 4. );\\n\\tfloat vid = mod( vertexid, 6. );\\n\\tvec3 d = vec3( 0.0 );\\n \\tif (vid == 0. || vid == 3.)\\n {\\n \\td.x = -CUBESIZE;\\n \\td.y = -CUBESIZE;\\n }\\n \\tif (vid == 1.)\\n {\\n \\td.x = CUBESIZE;\\n \\td.y = -CUBESIZE;\\n }\\n \\tif (vid == 2. || vid == 4.)\\n {\\n \\td.x = CUBESIZE;\\n \\td.y = CUBESIZE;\\n }\\n \\tif (vid == 5.)\\n {\\n \\td.x = -CUBESIZE;\\n \\td.y = CUBESIZE;\\n }\\n\\treturn p;// + d*0.5*(n-0.7)/0.13;\\n}\\n\\nvoid main()\\n{\\n\\tfloat col = 1.0;\\n \\tfloat ps = 0.0;\\n\\tvec3 p = GetPoint( vertexId, col, ps );\\n\\tfloat origz = p.z;\\n\\tp += vec3( 0.0, 0, SIDE/7. );\\n\\tfloat fov = 1.1;\\n\\tgl_Position = vec4( p.xy*fov, 1.0/(-p.z-0.0), p.z ); \\n\\tgl_PointSize = ps;\\n\\tv_color = vec4(col,col,col,1.); //vec4(vec3(max( 0.0, origz)),1.);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float SIDE = 40.; // how many nodes on one side\nfloat CUBESIZE = 0.1;// one node size\nfloat NSCALE = 0.1;\nfloat TSCALE = 2.2;\n\nvoid rotateX(inout vec3 p, float a) {\n\tfloat c,s;vec3 q=p;\n\tc = cos(a); s = sin(a);\n\tp.y = c * q.y - s * q.z;\n\tp.z = s * q.y + c * q.z;\n}\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// noise from iq (https://www.shadertoy.com/view/4sfGzS)\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\nfloat noise( in vec3 x )\n{\n vec3 p = floor(x);\n vec3 f = fract(x);\n f = f*f*(3.0-2.0*f);\n\t\n float n = p.x + p.y*157.0 + 113.0*p.z;\n return mix(mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n mix( hash(n+157.0), hash(n+158.0),f.x),f.y),\n mix(mix( hash(n+113.0), hash(n+114.0),f.x),\n mix( hash(n+270.0), hash(n+271.0),f.x),f.y),f.z);\n}\n\nfloat noise4( in vec4 x )\n{\n\treturn mix( noise( x.xyz ), noise( x.xyz + vec3(-2.1*sin(x.w*0.2),4.33*sin(x.w*0.43),2.3*sin(x.w*0.5)) ), 0.5 );\n}\n\nvec3 GetPoint( float vertexid, out float color, out float psize )\n{\n\tfloat node = vertexid;\n\tif (node > SIDE*SIDE*SIDE-1.) return vec3(0.0);\n\t// get the grid location\n\tfloat y = floor( node / (SIDE*SIDE) );\n\tfloat z = floor( mod( node, SIDE*SIDE ) / SIDE );\n\tfloat x = mod( mod( node, SIDE*SIDE ), SIDE );\n\t// first check if empty\n \tvec4 npos = vec4( x, y, z, time*TSCALE ) * NSCALE;// + vec3( time, time/2., time /3. ) * TSCALE;\n\tfloat n = noise4( npos );\n \tcolor = 0.0;\n \tpsize = 0.0;\n\tif (n < 0.7 || n > 0.78) return vec3(0.);\n\n \tpsize = CUBESIZE * smoothstep( n, 0.7, 0.71 ) * 220.;\n\n\tvec3 normal = normalize( vec3( n-noise4( npos+vec4(.01,.0,.0,.0) ), n-noise4( npos+vec4(.0,.01,.0,.0) ), n-noise4( npos+vec4(.0,.0,.01,.0) ) ) );\n\n \tnormal = rotateY( normal, -mouse.x*1.2-0.2 );\n\trotateX( normal, mouse.y*1.2-0.2 );\n \t\n \tvec3 light = vec3( 0.0, 1., -1. );\n \tnormalize( light );\n\tcolor = abs( dot( normal, light ) )*0.5 + abs( dot( normal, -light ) )*0.1;\n \n \tvec3 p = (vec3( x, y, z ) + vec3( -SIDE/2. ))* CUBESIZE;\n\tp = rotateY( p, -mouse.x*1.2-0.2 );\n\trotateX( p, mouse.y*1.2-0.2 );\n\n \t//float vid = mod( vertexid, 24. );\n\t//float sideid = floor( vid / 4. );\n\tfloat vid = mod( vertexid, 6. );\n\tvec3 d = vec3( 0.0 );\n \tif (vid == 0. || vid == 3.)\n {\n \td.x = -CUBESIZE;\n \td.y = -CUBESIZE;\n }\n \tif (vid == 1.)\n {\n \td.x = CUBESIZE;\n \td.y = -CUBESIZE;\n }\n \tif (vid == 2. || vid == 4.)\n {\n \td.x = CUBESIZE;\n \td.y = CUBESIZE;\n }\n \tif (vid == 5.)\n {\n \td.x = -CUBESIZE;\n \td.y = CUBESIZE;\n }\n\treturn p;// + d*0.5*(n-0.7)/0.13;\n}\n\nvoid main()\n{\n\tfloat col = 1.0;\n \tfloat ps = 0.0;\n\tvec3 p = GetPoint( vertexId, col, ps );\n\tfloat origz = p.z;\n\tp += vec3( 0.0, 0, SIDE/7. );\n\tfloat fov = 1.1;\n\tgl_Position = vec4( p.xy*fov, 1.0/(-p.z-0.0), p.z ); \n\tgl_PointSize = ps;\n\tv_color = vec4(col,col,col,1.); //vec4(vec3(max( 0.0, origz)),1.);\n}" + }, "screenshotURL": "data/images/images-tsn7v6m0mey89w9ol-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uQNhYXZtikXJR6MBz/art.json b/art/uQNhYXZtikXJR6MBz/art.json index e54bb7a4..646d7ee5 100644 --- a/art/uQNhYXZtikXJR6MBz/art.json +++ b/art/uQNhYXZtikXJR6MBz/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 5.1)));\\n float start = fract(hash(circleId * inner/2.) + sin(time * 0.83 + circleId) * 1.1);\\n float end = start + 1.;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + tan(uv.x * 1.8 / 2.)) * 0.05, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 0);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n\\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\\n float sat = 2.9 / circleId;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 2. + PI * 0.1;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 13.27) + tan(t * 1.13+mouse.x) + cos(t* 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.3, 0.0, p1m1(sin(goop(circleId) + time * 5.1)));\n float start = fract(hash(circleId * inner/2.) + sin(time * 0.83 + circleId) * 1.1);\n float end = start + 1.;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + tan(uv.x * 1.8 / 2.)) * 0.05, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 0);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n\n float hue = mix(0.5-snd, 0.6+snd, fract(circleId * 2.79));\n float sat = 2.9 / circleId;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd + 0.1, 5.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-4jzzaz5i4ljrufpqc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uQkpXdAa4ABNPNthi/art.json b/art/uQkpXdAa4ABNPNthi/art.json index 4527d484..6761be0f 100644 --- a/art/uQkpXdAa4ABNPNthi/art.json +++ b/art/uQkpXdAa4ABNPNthi/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "test", "username": "spotline", - "settings": "{\"num\":5009,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/taiataia/ryoji-ikeda-data-vertex\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 5000.0\\n//#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n float u = (float(vertexId)/NUM_POINTS) * 2.0 - 1.0;\\n float v = 0.0;\\n float ucoor = log((abs(u)*1.5 + 1.0));\\n v+= floor(texture2D(sound,vec2(ucoor,0.0)).a * 15.0)/15.0;\\n float osc = 0.2*cos(1.*(1.1*time+3.0*(abs(u)+1.0)));\\n float osc2 = 0.1*cos(1.*(-1.5*time+5.0*(abs(u)+1.0)));\\n float x = u * 2.0;\\n float y = v -0.5 + 0.5*pow(x,2.0) + osc +osc2;\\n gl_PointSize = v*15.0 + 1.0;\\n gl_Position = vec4(x,y,0,1);\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 5009, + "mode": "POINTS", + "sound": "https://soundcloud.com/taiataia/ryoji-ikeda-data-vertex", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n//#define FIT_VERTICAL\n\n\nvoid main() \n{\n float u = (float(vertexId)/NUM_POINTS) * 2.0 - 1.0;\n float v = 0.0;\n float ucoor = log((abs(u)*1.5 + 1.0));\n v+= floor(texture2D(sound,vec2(ucoor,0.0)).a * 15.0)/15.0;\n float osc = 0.2*cos(1.*(1.1*time+3.0*(abs(u)+1.0)));\n float osc2 = 0.1*cos(1.*(-1.5*time+5.0*(abs(u)+1.0)));\n float x = u * 2.0;\n float y = v -0.5 + 0.5*pow(x,2.0) + osc +osc2;\n gl_PointSize = v*15.0 + 1.0;\n gl_Position = vec4(x,y,0,1);\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-n32ll286twu6hnngo-thumbnail.jpg", "views": { "$numberInt": "279" diff --git a/art/uQsrjwoCeqSersLA9/art.json b/art/uQsrjwoCeqSersLA9/art.json index e68123d7..bdf65c28 100644 --- a/art/uQsrjwoCeqSersLA9/art.json +++ b/art/uQsrjwoCeqSersLA9/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":488,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.08235294117647059,0.08235294117647059,1],\"shader\":\"#define MAX_STACK 8\\n\\n// Define asembly for our vm.\\n\\n#define NOP 0\\n\\n#define REX 1\\n#define REY 2\\n\\n#define SUM 3\\n#define MIS 4\\n\\n#define MUL 5\\n#define DIV 6\\n\\n#define SIN 7\\n#define COS 8\\n\\n#define LFC 9\\n\\n#define LNC 10\\n#define GCP 11\\n\\n// Varibales for programm and programms length.\\n\\n/*uniform */ int prog [256];\\n/*uniform */ int progLength;\\n\\n// Precalculated constants.\\n\\n/*uniform */ float consts [256];\\n\\nfloat getConsts(int id) {\\n for (int i=0; i<256; i++) {\\n if (i == id) return consts[i];\\n }\\n}\\n\\n\\n// Stack.\\nfloat stack [MAX_STACK];\\n\\nfloat getStack(int id) {\\n for (int i=0; i=progLength) \\n {\\n break;\\n }\\n \\n if(argFlag)\\n {\\n argFlag = false;\\n continue;\\n }\\n \\n \\tif (prog[pCt]==NOP)\\n {\\n \\t// Do nothing.\\n \\t} else if (prog[pCt]==REX)\\n {\\n \\tx = getStack(--stackPtr);\\n \\t} else if (prog[pCt]==REY)\\n {\\n \\ty = getStack(--stackPtr);\\n \\t} else\\n \\tif (prog[pCt]==SUM){\\n \\ta = getStack(--stackPtr);\\n b = getStack(--stackPtr);\\n setStack(stackPtr++, a+b); \\n \\t} else\\n \\tif (prog[pCt]==MIS){\\n \\ta = getStack(--stackPtr);\\n b = getStack(--stackPtr);\\n setStack(stackPtr++, a-b); \\n \\t} else\\n \\tif (prog[pCt]==MUL){\\n \\t\\ta = getStack(--stackPtr);\\n b = getStack(--stackPtr);\\n setStack(stackPtr++, a*b); \\n \\t} else\\n \\tif (prog[pCt]==DIV){\\n \\ta = getStack(--stackPtr);\\n b = getStack(--stackPtr);\\n setStack(stackPtr++, a/b); \\n \\t} else\\n \\tif (prog[pCt]==SIN){\\n \\tsetStack(stackPtr-1, sin(getStack(stackPtr-1))); \\n \\t} else \\n \\tif (prog[pCt]==COS){\\n \\tsetStack(stackPtr-1, cos(getStack(stackPtr-1))); \\n \\t} else\\n \\tif (prog[pCt]==LFC){\\n \\tsetStack(stackPtr++,getConsts(prog[pCt+1]));\\n \\targFlag = true;\\n \\t} else\\n \\tif (prog[pCt]==LNC){\\n \\tsetStack(stackPtr++,vertexCount );\\n \\t} else\\n \\tif (prog[pCt]==GCP){\\n \\tsetStack(stackPtr++,vertexId );\\n \\t}\\n \\n }\\n \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = 3.;\\n v_color = vec4(1, 1, 1, 1);\\n}\"}", + "settings": { + "num": 488, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.08235294117647059, + 0.08235294117647059, + 1 + ], + "shader": "#define MAX_STACK 8\n\n// Define asembly for our vm.\n\n#define NOP 0\n\n#define REX 1\n#define REY 2\n\n#define SUM 3\n#define MIS 4\n\n#define MUL 5\n#define DIV 6\n\n#define SIN 7\n#define COS 8\n\n#define LFC 9\n\n#define LNC 10\n#define GCP 11\n\n// Varibales for programm and programms length.\n\n/*uniform */ int prog [256];\n/*uniform */ int progLength;\n\n// Precalculated constants.\n\n/*uniform */ float consts [256];\n\nfloat getConsts(int id) {\n for (int i=0; i<256; i++) {\n if (i == id) return consts[i];\n }\n}\n\n\n// Stack.\nfloat stack [MAX_STACK];\n\nfloat getStack(int id) {\n for (int i=0; i=progLength) \n {\n break;\n }\n \n if(argFlag)\n {\n argFlag = false;\n continue;\n }\n \n \tif (prog[pCt]==NOP)\n {\n \t// Do nothing.\n \t} else if (prog[pCt]==REX)\n {\n \tx = getStack(--stackPtr);\n \t} else if (prog[pCt]==REY)\n {\n \ty = getStack(--stackPtr);\n \t} else\n \tif (prog[pCt]==SUM){\n \ta = getStack(--stackPtr);\n b = getStack(--stackPtr);\n setStack(stackPtr++, a+b); \n \t} else\n \tif (prog[pCt]==MIS){\n \ta = getStack(--stackPtr);\n b = getStack(--stackPtr);\n setStack(stackPtr++, a-b); \n \t} else\n \tif (prog[pCt]==MUL){\n \t\ta = getStack(--stackPtr);\n b = getStack(--stackPtr);\n setStack(stackPtr++, a*b); \n \t} else\n \tif (prog[pCt]==DIV){\n \ta = getStack(--stackPtr);\n b = getStack(--stackPtr);\n setStack(stackPtr++, a/b); \n \t} else\n \tif (prog[pCt]==SIN){\n \tsetStack(stackPtr-1, sin(getStack(stackPtr-1))); \n \t} else \n \tif (prog[pCt]==COS){\n \tsetStack(stackPtr-1, cos(getStack(stackPtr-1))); \n \t} else\n \tif (prog[pCt]==LFC){\n \tsetStack(stackPtr++,getConsts(prog[pCt+1]));\n \targFlag = true;\n \t} else\n \tif (prog[pCt]==LNC){\n \tsetStack(stackPtr++,vertexCount );\n \t} else\n \tif (prog[pCt]==GCP){\n \tsetStack(stackPtr++,vertexId );\n \t}\n \n }\n \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = 3.;\n v_color = vec4(1, 1, 1, 1);\n}" + }, "screenshotURL": "data/images/images-1yecq3mjrnnzlw2e2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uRPsmf73ZgmHdkDP5/art.json b/art/uRPsmf73ZgmHdkDP5/art.json index 285cce1b..e5ea325a 100644 --- a/art/uRPsmf73ZgmHdkDP5/art.json +++ b/art/uRPsmf73ZgmHdkDP5/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":4350,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 9.0)\\n#define STEP 5.0\\n#define pointSize 0.3\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.90, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 1.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 3.0) + mod(vertexId, 4.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.1) * mouse.x * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.1) * mouse.y * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect / (1.0-mouse) * 2.5, (point-oC) * pointSize, 0.9);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 0.0)*0.5;\\n}\"}", + "settings": { + "num": 4350, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 9.0)\n#define STEP 5.0\n#define pointSize 0.3\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.90, 1.0));\n vec4 K = vec4(1.0, 2.0 / 1.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 3.0) + mod(vertexId, 4.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.1) * mouse.x * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.1) * mouse.y * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect / (1.0-mouse) * 2.5, (point-oC) * pointSize, 0.9);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 0.0)*0.5;\n}" + }, "screenshotURL": "data/images/images-372ycfadsaw4i095t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uSaN2bccDvQp8857Q/art.json b/art/uSaN2bccDvQp8857Q/art.json index b6556748..4a1d4402 100644 --- a/art/uSaN2bccDvQp8857Q/art.json +++ b/art/uSaN2bccDvQp8857Q/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":16622,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define kp0 sin(time*0.60)//KParameter -5.>>5.\\n#define kp1 sin(time*0.10)//KParameter -6.>>5.\\n#define kp2 sin(1.-time*0.30)//KParameter -6.>>5.\\n#define kp3 sin(1.-time*0.930)//KParameter -6.>>5.\\n#define kp4 sin(-time*0.70)//KParameter -6.>>5.\\n#define kp5 sin(-time*.130)//KParameter -6.>>5.\\n//#define kp0 -5.//KParameter -5.>>5.\\n//#define kp1 1.//KParameter -6.>>5.\\n//KVerticesNumber=16622\\n\\n\\n\\n#define PI radians(180.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\\n\\n// https://en.wikipedia.org/wiki/Lorenz_system\\n\\n// exponential smooth min (k = 32);\\n// http://www.iquilezles.org/www/articles/smin/smin.htm\\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\\n{\\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\\n return -log( res )/k;\\n}\\n\\nvoid main()\\n{\\n\\tfloat sigma = 10.;\\n\\tfloat rho = 28.;\\n\\tfloat beta = 2.66;\\n\\tfloat speed = 0.0030;\\n \\tfloat transitionStrength = 1.3*kp5;\\n \\tvec3 colKernel0 = vec3(1,0,1.-kp3);\\n \\tvec3 colKernel1 = vec3(0,kp2,0);\\n \\tvec3 colTransition = vec3(kp0,kp4,1);\\n\\tconst float maxIterations = 30000.;\\n \\n\\tvec3 new = vec3(0);\\n\\tvec3 last = vec3(0);\\n\\t\\n\\tgl_Position = vec4(0);\\n\\tv_color = vec4(0,1,0,0);\\n\\t\\n\\tfloat vtId = vertexId;\\n\\t\\n\\tfor (float i=0.; i < maxIterations; i++)\\n\\t{\\n \\tif (i > vtId) break;\\n\\t\\tlast = new;\\n\\t\\tnew.x = sigma * (last.y - last.x);\\n\\t\\tnew.y = rho * last.x - last.y - last.x * last.z ;\\n\\t\\tnew.z = last.x * last.y - beta * last.z;\\n\\t\\tnew = new * speed + speed;\\n\\t\\tnew += last;\\n\\t}\\n\\t\\n \\t// eachs two points, same points, for avoid path interruptions in LINES mode\\n\\tif (mod(vertexId, 2.) < 1.);\\n\\t{\\n\\t\\tnew = last;\\n\\t\\tvtId++;\\n\\t}\\n\\t\\n\\t// kernel 0\\n\\tvec3 k0 = vec3(0);\\n\\tk0.x = -sqrt(beta * (rho - 1.));\\n\\tk0.y = -sqrt(beta * (rho - 1.));\\n\\tk0.z = rho - 1.;\\n\\tfloat dk0 = length(new-k0);\\n\\t\\t\\t\\n\\t// kernel 1\\n\\tvec3 k1 = vec3(0);\\n\\tk1.x = sqrt(beta * (rho - mouse.x));\\n\\tk1.y = sqrt(beta * (rho - 1.));\\n\\tk1.z = rho - 1.;\\n\\tfloat dk1 = length(new-k1);\\n\\t\\n\\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\\n\\t\\n\\tvec3 center = (k0 + k1) * 0.5;\\n\\tfloat diam = length(k0-center);\\n\\t\\n\\tfloat rk0 = dk0/(dk1*transitionStrength);;\\n\\tfloat rk1 = dk1/(dk0*transitionStrength);\\n\\t\\n \\tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\\n\\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\\n\\t\\n\\t\\n\\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\\n\\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\\n\\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\\n\\n\\tnew = new.xzy;\\n\\n\\tif (dk0 < dk1)\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\\n\\t}\\n\\telse\\n\\t{\\n\\t\\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\\n\\t}\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = .5 - kp1* 0.5;\\n\\tfloat ce = -1.5+ kp0* 3.+1.;\\n\\tfloat cd = 80.0;\\n\\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \\n\\tvec3 target = vec3(0, 1, 0);\\n\\tvec3 up = vec3(0, 0.6,1.);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n\\tcamera *= Trans(33.,47.,66.);\\n\\tgl_Position = camera * vec4(new + path,1);\\n}\\n\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n\\tfloat f = tan(PI * 0.5 - 0.5 * fov);\\n\\tfloat rangeInv = .2 / (zNear - zFar);\\n\\n\\treturn mat4(\\n\\t\\tf / aspect, 0, 0, 0,\\n\\t\\t0, f, 0, 0,\\n\\t\\t0, 0, (zNear + zFar) * rangeInv,\\n-1.,\\t\\t0, 0, zNear * zFar * rangeInv * 1.23, 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n\\tvec3 zAxis = normalize(eye - target);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, sin(mouse.y/8.),\\n\\t\\teye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n\\tfloat\\n\\t\\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n\\t\\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n\\t\\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n\\t\\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n\\t\\tb00 = a00 * a11 - a01 * a10,\\n\\t\\tb01 = a00 * a12 - a02 * a10,\\n\\t\\tb02 = a00 * a13 - a03 * a10,\\n\\t\\tb03 = a01 * a12 - a02 * a11,\\n\\t\\tb04 = a01 * a13 - a03 * a11,\\n\\t\\tb05 = a02 * a13 - a03 * a12,\\n\\t\\tb06 = a20 * a31 - a21 * a30,\\n\\t\\tb07 = a20 * a32 - a22 * a30,\\n\\t\\tb08 = a20 * a33 - a23 * a30,\\n\\t\\tb09 = a21 * a32 - a22 * a31,\\n\\t\\tb10 = a21 * a33 - a23 * a31,\\n\\t\\tb11 = a22 * a33 - a23 * a32,\\n\\n\\t\\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n\\treturn mat4(\\n\\t\\ta11 * b11 - a12 * b10 + a13 * b09,\\n\\t\\ta02 * b10 - a01 * b11 - a03 * b09,\\n\\t\\ta31 * b05 - a32 * b04 + a33 * b03,\\n\\t\\ta22 * b04 - a21 * b05 - a23 * b03,\\n\\t\\ta12 * b08 - a10 * b11 - a13 * b07,\\n\\t\\ta00 * b11 - a02 * b08 + a03 * b07,\\n\\t\\ta32 * b02 - a30 * b05 - a33 * b01,\\n\\t\\ta20 * b05 - a22 * b02 + a23 * b01,\\n\\t\\ta10 * b10 - a11 * b08 + a13 * b06,\\n\\t\\ta01 * b08 - a00 * b10 - a03 * b06,\\n\\t\\ta30 * b04 - a31 * b02 + a33 * b00,\\n\\t\\ta21 * b02 - a20 * b04 - a23 * b00,\\n\\t\\ta11 * b07 - a10 * b09 - a12 * b06,\\n\\t\\ta00 * b09 - a01 * b07 + a02 * b06,\\n\\t\\ta31 * b01 - a30 * b03 - a32 * b00,\\n\\t\\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,\\n \\n 2.)*0.3;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n#if 1\\n\\treturn inverse(lookAt(eye, target, up));\\n#else\\n\\tvec3 zAxis = normalize(target - eye*2.);\\n\\tvec3 xAxis = normalize(cross(up, zAxis));\\n\\tvec3 yAxis = cross(zAxis, xAxis);\\n\\n\\treturn mat4(\\n\\t\\txAxis, 0,\\n\\t\\tyAxis, 0,\\n\\t\\tzAxis, 1,\\n\\t\\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.45); \\n#endif\\n \\n\\t}\"}", + "settings": { + "num": 16622, + "mode": "LINES", + "sound": "https://soundcloud.com/hug-life/666gangstaz-get-out-of-my-fucking-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define kp0 sin(time*0.60)//KParameter -5.>>5.\n#define kp1 sin(time*0.10)//KParameter -6.>>5.\n#define kp2 sin(1.-time*0.30)//KParameter -6.>>5.\n#define kp3 sin(1.-time*0.930)//KParameter -6.>>5.\n#define kp4 sin(-time*0.70)//KParameter -6.>>5.\n#define kp5 sin(-time*.130)//KParameter -6.>>5.\n//#define kp0 -5.//KParameter -5.>>5.\n//#define kp1 1.//KParameter -6.>>5.\n//KVerticesNumber=16622\n\n\n\n#define PI radians(180.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),1.-sin(a),0.,sin(a),cos(-a),0.,0.,1.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0,0,0,0,1,0,0,0,0.4,1,0,x,y,z,1.);}\n\n// https://en.wikipedia.org/wiki/Lorenz_system\n\n// exponential smooth min (k = 32);\n// http://www.iquilezles.org/www/articles/smin/smin.htm\nvec3 sminExp( vec3 a, vec3 b, vec3 k )\n{\n vec3 res = exp( -k*(2.-b-a,b+kp2) ) + exp( -k*b+k*a );\n return -log( res )/k;\n}\n\nvoid main()\n{\n\tfloat sigma = 10.;\n\tfloat rho = 28.;\n\tfloat beta = 2.66;\n\tfloat speed = 0.0030;\n \tfloat transitionStrength = 1.3*kp5;\n \tvec3 colKernel0 = vec3(1,0,1.-kp3);\n \tvec3 colKernel1 = vec3(0,kp2,0);\n \tvec3 colTransition = vec3(kp0,kp4,1);\n\tconst float maxIterations = 30000.;\n \n\tvec3 new = vec3(0);\n\tvec3 last = vec3(0);\n\t\n\tgl_Position = vec4(0);\n\tv_color = vec4(0,1,0,0);\n\t\n\tfloat vtId = vertexId;\n\t\n\tfor (float i=0.; i < maxIterations; i++)\n\t{\n \tif (i > vtId) break;\n\t\tlast = new;\n\t\tnew.x = sigma * (last.y - last.x);\n\t\tnew.y = rho * last.x - last.y - last.x * last.z ;\n\t\tnew.z = last.x * last.y - beta * last.z;\n\t\tnew = new * speed + speed;\n\t\tnew += last;\n\t}\n\t\n \t// eachs two points, same points, for avoid path interruptions in LINES mode\n\tif (mod(vertexId, 2.) < 1.);\n\t{\n\t\tnew = last;\n\t\tvtId++;\n\t}\n\t\n\t// kernel 0\n\tvec3 k0 = vec3(0);\n\tk0.x = -sqrt(beta * (rho - 1.));\n\tk0.y = -sqrt(beta * (rho - 1.));\n\tk0.z = rho - 1.;\n\tfloat dk0 = length(new-k0);\n\t\t\t\n\t// kernel 1\n\tvec3 k1 = vec3(0);\n\tk1.x = sqrt(beta * (rho - mouse.x));\n\tk1.y = sqrt(beta * (rho - 1.));\n\tk1.z = rho - 1.;\n\tfloat dk1 = length(new-k1);\n\t\n\tfloat dk = sminExp(vec3(dk0), vec3(dk1), vec3(0.01)).x;\n\t\n\tvec3 center = (k0 + k1) * 0.5;\n\tfloat diam = length(k0-center);\n\t\n\tfloat rk0 = dk0/(dk1*transitionStrength);;\n\tfloat rk1 = dk1/(dk0*transitionStrength);\n\t\n \tfloat sk0 = -30. * texture2D(sound, vec2(0.02, (1.-rk0)*0.7)).x*.605;\n\tfloat sk1 = 30. * texture2D(sound, vec2(0.1, (1.-rk1)*0.6*(kp2*0.20-.04))).y*1.5;\n\t\n\t\n\tvec3 pathk0 = vec3(sk0 * rk0, 0., 0.);;\n\tvec3 pathk1 = vec3(sk1 * rk1, 0., 0.);\n\tvec3 path = sminExp(pathk0, pathk1, vec3(0.012));\n\n\tnew = new.xzy;\n\n\tif (dk0 < dk1)\n\t{\n\t\tv_color.rgb = mix(colKernel0,colTransition, vec3(rk0));\n\t}\n\telse\n\t{\n\t\tv_color.rgb = mix(colKernel1,colTransition, vec3(rk1));\n\t}\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = .5 - kp1* 0.5;\n\tfloat ce = -1.5+ kp0* 3.+1.;\n\tfloat cd = 80.0;\n\tvec3 eye = vec3(cos(ca), sin(ce), sin(ca)) * cd; \n\tvec3 target = vec3(0, 1, 0);\n\tvec3 up = vec3(0, 0.6,1.);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n\tcamera *= cameraLookAt(eye, target, up);\n\tcamera *= Trans(33.,47.,66.);\n\tgl_Position = camera * vec4(new + path,1);\n}\n\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n\tfloat f = tan(PI * 0.5 - 0.5 * fov);\n\tfloat rangeInv = .2 / (zNear - zFar);\n\n\treturn mat4(\n\t\tf / aspect, 0, 0, 0,\n\t\t0, f, 0, 0,\n\t\t0, 0, (zNear + zFar) * rangeInv,\n-1.,\t\t0, 0, zNear * zFar * rangeInv * 1.23, 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n\tvec3 zAxis = normalize(eye - target);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, sin(mouse.y/8.),\n\t\teye, 1);\n}\n\nmat4 inverse(mat4 m) {\n\tfloat\n\t\ta00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n\t\ta10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n\t\ta20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n\t\ta30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n\t\tb00 = a00 * a11 - a01 * a10,\n\t\tb01 = a00 * a12 - a02 * a10,\n\t\tb02 = a00 * a13 - a03 * a10,\n\t\tb03 = a01 * a12 - a02 * a11,\n\t\tb04 = a01 * a13 - a03 * a11,\n\t\tb05 = a02 * a13 - a03 * a12,\n\t\tb06 = a20 * a31 - a21 * a30,\n\t\tb07 = a20 * a32 - a22 * a30,\n\t\tb08 = a20 * a33 - a23 * a30,\n\t\tb09 = a21 * a32 - a22 * a31,\n\t\tb10 = a21 * a33 - a23 * a31,\n\t\tb11 = a22 * a33 - a23 * a32,\n\n\t\tdet = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n\treturn mat4(\n\t\ta11 * b11 - a12 * b10 + a13 * b09,\n\t\ta02 * b10 - a01 * b11 - a03 * b09,\n\t\ta31 * b05 - a32 * b04 + a33 * b03,\n\t\ta22 * b04 - a21 * b05 - a23 * b03,\n\t\ta12 * b08 - a10 * b11 - a13 * b07,\n\t\ta00 * b11 - a02 * b08 + a03 * b07,\n\t\ta32 * b02 - a30 * b05 - a33 * b01,\n\t\ta20 * b05 - a22 * b02 + a23 * b01,\n\t\ta10 * b10 - a11 * b08 + a13 * b06,\n\t\ta01 * b08 - a00 * b10 - a03 * b06,\n\t\ta30 * b04 - a31 * b02 + a33 * b00,\n\t\ta21 * b02 - a20 * b04 - a23 * b00,\n\t\ta11 * b07 - a10 * b09 - a12 * b06,\n\t\ta00 * b09 - a01 * b07 + a02 * b06,\n\t\ta31 * b01 - a30 * b03 - a32 * b00,\n\t\ta20 * b03 - a21 * b01 + a22 * b03) /-dot(det*-det,\n \n 2.)*0.3;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n#if 1\n\treturn inverse(lookAt(eye, target, up));\n#else\n\tvec3 zAxis = normalize(target - eye*2.);\n\tvec3 xAxis = normalize(cross(up, zAxis));\n\tvec3 yAxis = cross(zAxis, xAxis);\n\n\treturn mat4(\n\t\txAxis, 0,\n\t\tyAxis, 0,\n\t\tzAxis, 1,\n\t\t-dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1.45); \n#endif\n \n\t}" + }, "screenshotURL": "data/images/images-rql9vjr4uuxjh8qq9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uSaQNx4ahiXtBAcB2/art.json b/art/uSaQNx4ahiXtBAcB2/art.json index af2a7d03..8cdf7177 100644 --- a/art/uSaQNx4ahiXtBAcB2/art.json +++ b/art/uSaQNx4ahiXtBAcB2/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/didlybom/ryuichi-sakamoto-merry-christmas-mr-lawrence\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n if (vertexId < -6.) {\\n float id = vertexId;\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n\\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\\n v_color = vec4(1);\\n return;\\n \\n }\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float maxCubes = floor(vertexCount / 36./mouse.y);\\n float numCubes = maxCubes * mix(0.1, 1., t5p5(sin(time * .05)));\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float su = (cv);\\n //su = hash(cubeId / maxCubes);\\n float s1 = texture2D(sound, vec2(mix(.2, .0, su), 0. / soundRes.y)).a;\\n float s2 = texture2D(sound, vec2(mix(.2, .0, su), 1. / soundRes.x)).a;\\n float s3 = texture2D(sound, vec2(mix(1.2, .0, su), 2. / soundRes.y)).a;\\n float s4 = texture2D(sound, vec2(mix(.2,1.0, su), 3. / soundRes.y)).a;\\n \\n float s = mix(0.0, 0.25, s1 + s2 + s3 + s4);\\n \\n float tm = time * .1;\\n float r = 50.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(sc, sc, mix(0.5, s*3.61, pow(s,.0030))));\\n mat *= trans(vec3(0, 1, 1));\\n mat *= rotZ(s * PI * 2.);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n\\n float hue = .4 + s * .15;\\n float sat = .2 + s;\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * lt, 1);\\n v_color.a = s;\\n v_color.rgb *= v_color.a; \\n if (s < .2) {\\n gl_Position.z = 10000.;\\n }\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/didlybom/ryuichi-sakamoto-merry-christmas-mr-lawrence", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n if (vertexId < -6.) {\n float id = vertexId;\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n\n gl_Position = vec4(ux, mix(-1., 1., vy), 0.999, 1);\n v_color = vec4(1);\n return;\n \n }\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float maxCubes = floor(vertexCount / 36./mouse.y);\n float numCubes = maxCubes * mix(0.1, 1., t5p5(sin(time * .05)));\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float su = (cv);\n //su = hash(cubeId / maxCubes);\n float s1 = texture2D(sound, vec2(mix(.2, .0, su), 0. / soundRes.y)).a;\n float s2 = texture2D(sound, vec2(mix(.2, .0, su), 1. / soundRes.x)).a;\n float s3 = texture2D(sound, vec2(mix(1.2, .0, su), 2. / soundRes.y)).a;\n float s4 = texture2D(sound, vec2(mix(.2,1.0, su), 3. / soundRes.y)).a;\n \n float s = mix(0.0, 0.25, s1 + s2 + s3 + s4);\n \n float tm = time * .1;\n float r = 50.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm) * r * 0. + r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n float sc = mix(1.8, 20., pow(1. - numCubes / maxCubes, 10.));\n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(sc, sc, mix(0.5, s*3.61, pow(s,.0030))));\n mat *= trans(vec3(0, 1, 1));\n mat *= rotZ(s * PI * 2.);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n\n float hue = .4 + s * .15;\n float sat = .2 + s;\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * lt, 1);\n v_color.a = s;\n v_color.rgb *= v_color.a; \n if (s < .2) {\n gl_Position.z = 10000.;\n }\n}\n\n" + }, "screenshotURL": "data/images/images-mcc50qrpgu06iswg3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uTpabmasr6wBTbv3z/art.json b/art/uTpabmasr6wBTbv3z/art.json index fc23082d..2e308b1b 100644 --- a/art/uTpabmasr6wBTbv3z/art.json +++ b/art/uTpabmasr6wBTbv3z/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "phi16", "avatarUrl": "https://lh6.googleusercontent.com/-EMFaalZS9Rg/AAAAAAAAAAI/AAAAAAAAAjg/SGZ_70U2Idc/photo.jpg", - "settings": "{\"num\":80000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"float rand(vec2 co) {\\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\\n}\\n\\nfloat noise(vec2 r) {\\n\\tvec2 p = floor(r);\\n vec2 f = fract(r);\\n f = smoothstep(0.,1.,f);\\n vec2 e = vec2(0,1);\\n float p00 = rand(p+e.xx);\\n float p01 = rand(p+e.xy);\\n float p10 = rand(p+e.yx);\\n float p11 = rand(p+e.yy);\\n\\treturn mix(\\n mix(p00,p01,f.y),\\n mix(p10,p11,f.y),\\n f.x) - 0.5;\\n}\\n\\nfloat ot(vec2 r) {\\n\\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\\n return v * 0.5 + 0.5;\\n}\\n\\nvoid shift(inout vec3 p) {\\n\\tp.y += pow(ot(p.xz),1.2)*0.5;\\n}\\n\\nvoid main() {\\n vec3 pos, color;\\n float alpha = 1.0;\\n vec2 div;\\n int i = int(mod(vertexId,6.));\\n if(i==0) {\\n div = vec2(-1,-1);\\n } else if(i==1) {\\n div = vec2(-1,1);\\n } else if(i==2) {\\n div = vec2(1,-1);\\n } else if(i==3) {\\n div = vec2(1,-1);\\n } else if(i==4) {\\n div = vec2(-1,1);\\n } else if(i==5) {\\n div = vec2(1,1);\\n }\\n if(vertexId < 6.) {\\n pos = vec3(0,0,100.);\\n pos.xy += div * 1000.;\\n color = vec3(0.03);\\n } else if(vertexId < 12.) {\\n pos = vec3(0,0.2,0);\\n pos.xz += div * 100.;\\n color = vec3(0,0,0.2);\\n } else if(vertexId < 4812.) {\\n float vid = vertexId-6.;\\n float unitIx = floor(vid/6.);\\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\\n p.x -= 20.5;\\n p *= 0.5;\\n vec2 origP = p;\\n \\n p += div * 0.25;\\n\\tpos = vec3(p.x,0,p.y);\\n shift(pos);\\n \\n color = vec3(0.1,0.1,0.3);\\n color *= noise(pos.xz) * 0.5 + 0.5;\\n \\n vec3 u = pos - vec3(1,1.5,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - abs(u.y*0.2);\\n \\n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\\n } else if(vertexId < 15000.) {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float per = time*3. + rand(vec2(unitIx,3));\\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\\n float th = rand(vec2(seed,0))*3.1415926535*2.;\\n th += rand(vec2(seed,1));\\n float rad = rand(vec2(seed,2))*10. + 0.2;\\n pos = vec3(cos(th),0,sin(th)) * rad;\\n float ww = rand(vec2(seed,4))*0.02;\\n float ww2 = rand(vec2(seed,6))*0.5;\\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\\n pos.y += 3.0;\\n pos.z -= 1.0;\\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\\n \\tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\\n } else {\\n float vid = vertexId-4812.;\\n float unitIx = floor(vid/6.);\\n float v = rand(vec2(unitIx,9.))*2.-1.;\\n float per = time * 0.02 * v;\\n float au = time*0.05 + rand(vec2(unitIx,10.));\\n pos = vec3(\\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\\n rand(vec2(unitIx,2.)) * 2.,\\n rand(vec2(unitIx,3.)) * 2. - 1.\\n );\\n pos.x += sin(au*3.1415926535*2.)*0.1;\\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\\n vec3 ddiv = vec3(div,0.);\\n float ra = time*(1. + rand(vec2(unitIx,8.)));\\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n ra *= 2.;\\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\\n float size = rand(vec2(unitIx,5.))+0.5;\\n pos += ddiv*0.01*size;\\n \\n vec3 u = pos - vec3(1,1.8,1);\\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\\n float ll = length(u.xz) - u.y*0.05;\\n \\n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\\n \\talpha = 0.;\\n }\\n vec3 cam = vec3(0.,1.,0.);\\n pos -= cam;\\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\\n\\n float near = 0.001;\\n float far = 1000.;\\n float fovy = 3.1415926535 * 0.4;\\n float aspect = resolution.x / resolution.y;\\n float f = 1. / tan(fovy / 2.);\\n mat4 P = mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0,0,-2./(far-near),1,\\n 0,0,-(far+near)/(far-near),1\\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\\n // 0, 0, -1, 0\\n );\\n gl_Position = P * vec4(pos,1.);\\n v_color = vec4(color,alpha);\\n}\"}", + "settings": { + "num": 80000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "float rand(vec2 co) {\n return fract(sin(dot(co,vec2(95.92921,392.492))) * 93683.2319);\n}\n\nfloat noise(vec2 r) {\n\tvec2 p = floor(r);\n vec2 f = fract(r);\n f = smoothstep(0.,1.,f);\n vec2 e = vec2(0,1);\n float p00 = rand(p+e.xx);\n float p01 = rand(p+e.xy);\n float p10 = rand(p+e.yx);\n float p11 = rand(p+e.yy);\n\treturn mix(\n mix(p00,p01,f.y),\n mix(p10,p11,f.y),\n f.x) - 0.5;\n}\n\nfloat ot(vec2 r) {\n\tfloat v = noise(r) + noise(r*2.*mat2(1,-2,2,1)/sqrt(5.))/2. + noise(r*4.*mat2(-3,5,-5,-3)/sqrt(34.))/4.;\n return v * 0.5 + 0.5;\n}\n\nvoid shift(inout vec3 p) {\n\tp.y += pow(ot(p.xz),1.2)*0.5;\n}\n\nvoid main() {\n vec3 pos, color;\n float alpha = 1.0;\n vec2 div;\n int i = int(mod(vertexId,6.));\n if(i==0) {\n div = vec2(-1,-1);\n } else if(i==1) {\n div = vec2(-1,1);\n } else if(i==2) {\n div = vec2(1,-1);\n } else if(i==3) {\n div = vec2(1,-1);\n } else if(i==4) {\n div = vec2(-1,1);\n } else if(i==5) {\n div = vec2(1,1);\n }\n if(vertexId < 6.) {\n pos = vec3(0,0,100.);\n pos.xy += div * 1000.;\n color = vec3(0.03);\n } else if(vertexId < 12.) {\n pos = vec3(0,0.2,0);\n pos.xz += div * 100.;\n color = vec3(0,0,0.2);\n } else if(vertexId < 4812.) {\n float vid = vertexId-6.;\n float unitIx = floor(vid/6.);\n vec2 p = vec2(mod(unitIx,40.), floor(unitIx/40.));\n p.x -= 20.5;\n p *= 0.5;\n vec2 origP = p;\n \n p += div * 0.25;\n\tpos = vec3(p.x,0,p.y);\n shift(pos);\n \n color = vec3(0.1,0.1,0.3);\n color *= noise(pos.xz) * 0.5 + 0.5;\n \n vec3 u = pos - vec3(1,1.5,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - abs(u.y*0.2);\n \n color = mix(vec3(1,0.8,0.4),color,smoothstep(0.5,0.0,1. - ll));\n } else if(vertexId < 15000.) {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float per = time*3. + rand(vec2(unitIx,3));\n float seed = (unitIx + floor(per)*sqrt(2.)) * .2;\n float th = rand(vec2(seed,0))*3.1415926535*2.;\n th += rand(vec2(seed,1));\n float rad = rand(vec2(seed,2))*10. + 0.2;\n pos = vec3(cos(th),0,sin(th)) * rad;\n float ww = rand(vec2(seed,4))*0.02;\n float ww2 = rand(vec2(seed,6))*0.5;\n vec2 ddiv = mat2(1.,1.,-1.,1.)/sqrt(2.)*div;\n pos.xy += ddiv * vec2(0.02+ww,0.5*fract(per)+ww2);\n pos.y += 3.0;\n pos.z -= 1.0;\n pos.y -= (pow(fract(per),2.)+1.)*rad - rad;\n \tcolor = mix(vec3(0.3,0.4,1.0), vec3(1.), rand(vec2(seed,5)));\n color *= pow(rand(vec2(seed,6)),4.)*0.9+0.1;\n } else {\n float vid = vertexId-4812.;\n float unitIx = floor(vid/6.);\n float v = rand(vec2(unitIx,9.))*2.-1.;\n float per = time * 0.02 * v;\n float au = time*0.05 + rand(vec2(unitIx,10.));\n pos = vec3(\n fract(rand(vec2(unitIx,1.)) + per) * 10. - 5.,\n rand(vec2(unitIx,2.)) * 2.,\n rand(vec2(unitIx,3.)) * 2. - 1.\n );\n pos.x += sin(au*3.1415926535*2.)*0.1;\n pos.y += sin(au*0.9*3.1415926535*2.)*0.1;\n pos.z += sin(au*1.1*3.1415926535*2.)*0.1;\n vec3 ddiv = vec3(div,0.);\n float ra = time*(1. + rand(vec2(unitIx,8.)));\n ddiv.xy *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n ra *= 2.;\n ddiv.yz *= mat2(cos(ra),-sin(ra),sin(ra),cos(ra));\n float size = rand(vec2(unitIx,5.))+0.5;\n pos += ddiv*0.01*size;\n \n vec3 u = pos - vec3(1,1.8,1);\n u.xy *= mat2(2,-1,1,2)/sqrt(5.);\n float ll = length(u.xz) - u.y*0.05;\n \n color = mix(vec3(1,0.8,0.4),vec3(0.0),smoothstep(0.5,0.9,ll));\n \talpha = 0.;\n }\n vec3 cam = vec3(0.,1.,0.);\n pos -= cam;\n pos.yz *= mat2(5,-1,1,5)/sqrt(26.);\n\n float near = 0.001;\n float far = 1000.;\n float fovy = 3.1415926535 * 0.4;\n float aspect = resolution.x / resolution.y;\n float f = 1. / tan(fovy / 2.);\n mat4 P = mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0,0,-2./(far-near),1,\n 0,0,-(far+near)/(far-near),1\n // 0, 0, (far + near) / (near - far), (2. * far * near) / (near - far),\n // 0, 0, -1, 0\n );\n gl_Position = P * vec4(pos,1.);\n v_color = vec4(color,alpha);\n}" + }, "screenshotURL": "data/images/images-4p2shwyk0so0zghbo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uWGtoiQdrk49KSPoT/art.json b/art/uWGtoiQdrk49KSPoT/art.json index 7c88fd16..437732f9 100644 --- a/art/uWGtoiQdrk49KSPoT/art.json +++ b/art/uWGtoiQdrk49KSPoT/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nfloat pulse(float t) {\\n return pow(t, 2.);\\n}\\n\\nvoid main() {\\n float t = fract(time / 1.5);\\n float scale = 1. - \\n pulse(step(0.9, t) * (1. - t) * 10.0) * .1 -\\n pulse(step(0.7, t) * step(t, 0.8) * (0.8 - t) * 10.0) * .4;\\n \\n gl_PointSize = scale * 200.0;\\n gl_Position = vec4(0, 0, 0, 1);\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nfloat pulse(float t) {\n return pow(t, 2.);\n}\n\nvoid main() {\n float t = fract(time / 1.5);\n float scale = 1. - \n pulse(step(0.9, t) * (1. - t) * 10.0) * .1 -\n pulse(step(0.7, t) * step(t, 0.8) * (0.8 - t) * 10.0) * .4;\n \n gl_PointSize = scale * 200.0;\n gl_Position = vec4(0, 0, 0, 1);\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-wm1t78vrooq294oag-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uX4j5TjepFCvRZJ7X/art.json b/art/uX4j5TjepFCvRZJ7X/art.json index 78879986..55fb5907 100644 --- a/art/uX4j5TjepFCvRZJ7X/art.json +++ b/art/uX4j5TjepFCvRZJ7X/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":99940,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/didrec/ken-ishii-malfunction-10\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\nvoid main() {\\n float minEdge = 4.;\\n float maxEdge = 12.0;\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 1.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect) ;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n \\n float gs = gx / gAcross;\\n float gt = gy / gDown;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n // vec3 loc = fibonacciSphere(numGroups, groupId);\\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\\n float rd = 50.;\\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\\n float t = time;\\n vec3 target = vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\\n mat4 vmat = cameraLookAt(eye, target, up);\\n \\n \\n float sv = pow(s, .5);\\n \\n mat4 wmat = rotY(t * .17);\\n wmat *= rotX(t * .13);\\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\\n wmat *= uniformScale(mix(0., 1., pow(s +.1, 5.)));\\n wmat *= rotZ(groupId * PI / 3.);\\n\\n mat4 mvMat = vmat * wmat;\\n gl_Position = pmat * mvMat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n \\n\\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\\n float sat = .0;//step(pow(s, 3.), gt);\\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\\n \\n //if (mvMat[2][2] < 0.0) {\\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\\n gl_Position.z = 100.;\\n }\\n \\n \\n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\\n vec3 litDir = normalize(vec3(2,2,1));\\n float lt = 1.0;;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\\n \\n v_color.rgb *= v_color.a;\\n \\n float super = .0;step(0.99, s);\\n v_color = mix(v_color, vec4(1,0,0,1), super);\\n \\n}\\n\"}", + "settings": { + "num": 99940, + "mode": "POINTS", + "sound": "https://soundcloud.com/didrec/ken-ishii-malfunction-10", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\nvoid main() {\n float minEdge = 4.;\n float maxEdge = 12.0;\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(minEdge, maxEdge, sin(time * 7.) * .5 + .5));\n float mv = (NUM_EDGE_POINTS_PER_CIRCLE - minEdge) / (maxEdge - minEdge);\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 1.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect) ;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2.,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n \n float gs = gx / gAcross;\n float gt = gy / gDown;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.01, 0.5, hash(fract(gv * 4.))), 0.)).a * 1.3; \n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n // vec3 loc = fibonacciSphere(numGroups, groupId);\n vec3 loc = normalize(vec3(hash(groupId * 0.123), hash(groupId * .747), hash(groupId * .311)) * 2. - 1.);\n float rd = 50.;\n vec3 eye = vec3(0,0,rd);//sin(time * 0.19) * rd, sin(time * 0.21) * 0., cos(time * 0.19) * rd);\n float t = time;\n vec3 target = vec3(sin(t * .1) * 20., sin(t * 0.3) * 10., 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 pmat = persp(radians(45.), aspect, 1., 200.);\n mat4 vmat = cameraLookAt(eye, target, up);\n \n \n float sv = pow(s, .5);\n \n mat4 wmat = rotY(t * .17);\n wmat *= rotX(t * .13);\n wmat *= lookAt(loc * 19.5 + s * .1, vec3(0), up);\n wmat *= uniformScale(mix(0., 1., pow(s +.1, 5.)));\n wmat *= rotZ(groupId * PI / 3.);\n\n mat4 mvMat = vmat * wmat;\n gl_Position = pmat * mvMat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n \n\n float hue = fract(gv * 4.) * .1 + time * .1;// + groupId * 0.5;\n float sat = .0;//step(pow(s, 3.), gt);\n float val = 1.;pow(s * 1.25, 20.) + .3;// + mix(.0, 1., mod(groupId, 2.));\n \n //if (mvMat[2][2] < 0.0) {\n if (dot(normalize(mvMat[2].xyz), vec3(0, 0, 1)) < 0.3) {\n gl_Position.z = 100.;\n }\n \n \n vec3 nrm = normalize((wmat * vec4(0,0,1,0)).xyz);\n vec3 litDir = normalize(vec3(2,2,1));\n float lt = 1.0;;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)) * lt, 1);\n \n v_color.rgb *= v_color.a;\n \n float super = .0;step(0.99, s);\n v_color = mix(v_color, vec4(1,0,0,1), super);\n \n}\n" + }, "screenshotURL": "data/images/images-75wjvvmlefl787rgh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uXG7SrNumn9NcWxDE/art.json b/art/uXG7SrNumn9NcWxDE/art.json index d1698920..6c868a9f 100644 --- a/art/uXG7SrNumn9NcWxDE/art.json +++ b/art/uXG7SrNumn9NcWxDE/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/diskore/m4r\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.10980392156862745,0.11764705882352941,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/ \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 2.//KParameter0 1.>>3.\\n#define parameter1 0.6//KParameter1 0.1>>1.\\n#define parameter2 0.7//KParameter2 -1.>>3.\\n#define parameter3 .5//KParameter3 -1.5>>4.\\n#define parameter4 0.5//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 2.//KParameter6 0.>>2.\\n#define parameter7 2.6//KParameter7 -1.>>4.\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.7, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / parameter0 *3.0, 2.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle/parameter7 );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0.3, 1)*2.; \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 1.-parameter0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -1, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n -0.5, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(121.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 15.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v / 21. - v;}\\n\\nfloat p1m1(float v) {\\n return v * mod(4.1 *time, 2.0*parameter2) ;\\n}\\n\\nfloat inv(float v) {\\n return 1. + v - 2.;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, time);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE +1.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 2., level);\\n float a = mix(start, end, u) -PI - 1.16 / PI * 7.0* parameter3;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = 0.2;\\n pos = vec3(x, y+1., -5.* parameter4); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t - 1.7) + tan((t *= 1.13) - -t) + sin(t - 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles+ 4.;\\n vec3 pos;\\n float inner = mix(0.03, 11.1-parameter4, p1m1(sin(goop(circleId) * time / 3.1)));\\n float start = fract(hash(circleId * 7.033) - sin(time * .083 + circleId) *0.1- parameter4);\\n float end = start + 3.;//start + hash(sideId + 3.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/.8 - 0.3)*7.)* 0.05, uv.y * 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId +.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time + 0.103) - 1.4;\\n offset.y += goop(circleId + time - 1.13) * 1.31 *parameter4;\\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset- parameter1);\\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\\n gl_Position = vec4((mat * vec4(pos,.5)).xyz, 11.3 +parameter4 -(circleId + mouse.x));\\n gl_PointSize = 2. -parameter3;\\n\\n float hue = mix(0.01 *snd , 1.9 *parameter3/ circleId/snd , fract(circleId * 12.79 /snd));\\n float sat = 1. / snd;\\n float val = 0.9- snd ;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. /parameter2 - uv.y) * pow(snd * 2.51, snd-3. /parameter6));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/diskore/m4r", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.10980392156862745, + 0.11764705882352941, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/ \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 2.//KParameter0 1.>>3.\n#define parameter1 0.6//KParameter1 0.1>>1.\n#define parameter2 0.7//KParameter2 -1.>>3.\n#define parameter3 .5//KParameter3 -1.5>>4.\n#define parameter4 0.5//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 2.//KParameter6 0.>>2.\n#define parameter7 2.6//KParameter7 -1.>>4.\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.7, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / parameter0 *3.0, 2.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle/parameter7 );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0.3, 1)*2.; \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 1.-parameter0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -1, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n -0.5, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy + vec2(121.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 15.4337);\n}\n\nfloat m1p1(float v) {\n return v / 21. - v;}\n\nfloat p1m1(float v) {\n return v * mod(4.1 *time, 2.0*parameter2) ;\n}\n\nfloat inv(float v) {\n return 1. + v - 2.;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, time);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE +1.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE , - 2.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 2., level);\n float a = mix(start, end, u) -PI - 1.16 / PI * 7.0* parameter3;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = 0.2;\n pos = vec3(x, y+1., -5.* parameter4); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t - 1.7) + tan((t *= 1.13) - -t) + sin(t - 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles+ 4.;\n vec3 pos;\n float inner = mix(0.03, 11.1-parameter4, p1m1(sin(goop(circleId) * time / 3.1)));\n float start = fract(hash(circleId * 7.033) - sin(time * .083 + circleId) *0.1- parameter4);\n float end = start + 3.;//start + hash(sideId + 3.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x / uv.y/.8 - 0.3)*7.)* 0.05, uv.y * 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 1.5, m1p1(hash(circleId +.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time + 0.103) - 1.4;\n offset.y += goop(circleId + time - 1.13) * 1.31 *parameter4;\n vec3 aspect = vec3(2, resolution.x / resolution.y, 0.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset- parameter1);\n mat *= uniformScale(mix(0.1, 0.2, hash(circleId- 11.)));\n gl_Position = vec4((mat * vec4(pos,.5)).xyz, 11.3 +parameter4 -(circleId + mouse.x));\n gl_PointSize = 2. -parameter3;\n\n float hue = mix(0.01 *snd , 1.9 *parameter3/ circleId/snd , fract(circleId * 12.79 /snd));\n float sat = 1. / snd;\n float val = 0.9- snd ;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. /parameter2 - uv.y) * pow(snd * 2.51, snd-3. /parameter6));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a );\n}" + }, "screenshotURL": "data/images/images-aqidu92gs5uo8kba9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uXbjeauxDQaEZBKPg/art.json b/art/uXbjeauxDQaEZBKPg/art.json index 676e6b43..26f1d84d 100644 --- a/art/uXbjeauxDQaEZBKPg/art.json +++ b/art/uXbjeauxDQaEZBKPg/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hornet", "avatarUrl": "https://secure.gravatar.com/avatar/eb6c8d6cd2e064d55df92d041373e1c9?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n \\n \\n _ ._ _|_ _ _ |_ _. _| _ ._ _. ._ _|_ \\n \\\\/ (/_ | |_ (/_ >< _> | | (_| (_| (/_ | (_| | |_ \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians( 180. )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotX( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\n\\nfloat hash11(float p)\\n{\\n p = fract(p * .1031);\\n p *= p + 33.33;\\n p *= p + p;\\n return fract(p);\\n}\\n\\nfloat hash12_float(vec2 p)\\n{\\n #define HASHSCALE1 .1031\\n\\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract((p3.x + p3.y) * p3.z);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nvoid getShapePoint(const float numPointsPerFace, const float id, const mat4 wvp, out vec4 pos) {\\n float numPointsPerShape = pow(numPointsPerFace, 3.);\\n float numPointsPerWhat = numPointsPerFace * numPointsPerFace;\\n float aId = mod(id, numPointsPerFace);\\n float a = aId / numPointsPerFace;\\n float bId = mod(floor(id / numPointsPerFace), numPointsPerFace);\\n float b = bId / numPointsPerFace;\\n float cId = floor(id / numPointsPerWhat);\\n \\n float c = cId / numPointsPerFace;\\n \\n c += hash11( id );\\n \\n float a0 = a * PI * 2.;\\n float b0 = b * PI * 2.;\\n float c0 = c * PI * 2.;\\n \\n \\n \\n mat4 m = wvp;\\n m *= rotZ(c0);\\n m *= rotY(b0);\\n m *= rotY(a0);\\n pos = m * vec4(1,1,1,1);\\n}\\n\\n\\nvoid main() { \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.03456;\\n \\tfloat elevation = sin(animTime * 0.223);\\n \\tfloat fOrbitDistance = 30.;\\n \\n vec3 target = vec3(0, 0, 0);\\n vec3 eye = vec3(0, 0, 10);\\n \\t eye = vec3( sin(orbitAngle) * fOrbitDistance , sin(elevation * 1.11) * 10. , cos(orbitAngle)* fOrbitDistance ) ;\\n vec3 up = vec3(0,1,0);\\n \\n float numPointsPerFace = 4.;\\n float numPointsPerShape = pow(numPointsPerFace, 3.);\\n float shapeId = floor(vertexId / numPointsPerShape); \\n float shapeCount = floor(vertexCount / numPointsPerShape);\\n float shapeV = shapeId / shapeCount;\\n float invShapeV = 1. - shapeV;\\n \\n float size = floor(pow(shapeCount, 1./3.));\\n vec3 p = vec3(\\n mod(shapeId, size),\\n mod(floor(shapeId / size), size),\\n floor(floor(shapeId / size) / size));\\n vec3 pv = p / size;\\n pv = vec3(0,0,0);\\n \\n float snd = 0.;\\n \\n vec4 pos;\\n mat4 m = ident();\\n m *= persp(45., resolution.x / resolution.y, 0.1, 60.);\\n m *= cameraLookAt(eye, target, up);\\n\\n \\t//m *= rotY( 0.5+0.5*sin(time * 0.051 + shapeId * sin(time * 0.13) * 0.07) );\\n //m *= rotZ( 0.5+0.5*sin(time * 0.073 + shapeId * sin(time * 0.21) * 0.06));\\n\\n \\n \\tm *= rotY( sin(time * 0.051 + 0.125 * shapeId * 0.07 ) );\\n m *= rotZ( sin(time * 0.073 + shapeId * 0.06 ) );\\n \\n m *= uniformScale(10. * invShapeV);\\n getShapePoint(numPointsPerFace, vertexId, m, pos);\\n\\n gl_Position = pos;\\n gl_PointSize = 4.;\\n float z = p1m1(pos.z / pos.w);\\n \\n \\t// Final output color\\n //float hue = time * 0.01 + shapeV * 0.1;\\n //float sat = 1.;\\n //float val = 1.;\\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invShapeV + 0.1);\\n \\n \\tv_color = 0.25*vec4(0.7, 0.6, 0.5, 0.0);\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n \n \n _ ._ _|_ _ _ |_ _. _| _ ._ _. ._ _|_ \n \\/ (/_ | |_ (/_ >< _> | | (_| (_| (/_ | (_| | |_ \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians( 180. )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotX( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\n\nfloat hash11(float p)\n{\n p = fract(p * .1031);\n p *= p + 33.33;\n p *= p + p;\n return fract(p);\n}\n\nfloat hash12_float(vec2 p)\n{\n #define HASHSCALE1 .1031\n\tvec3 p3 = fract(vec3(p.xyx) * HASHSCALE1);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract((p3.x + p3.y) * p3.z);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nvoid getShapePoint(const float numPointsPerFace, const float id, const mat4 wvp, out vec4 pos) {\n float numPointsPerShape = pow(numPointsPerFace, 3.);\n float numPointsPerWhat = numPointsPerFace * numPointsPerFace;\n float aId = mod(id, numPointsPerFace);\n float a = aId / numPointsPerFace;\n float bId = mod(floor(id / numPointsPerFace), numPointsPerFace);\n float b = bId / numPointsPerFace;\n float cId = floor(id / numPointsPerWhat);\n \n float c = cId / numPointsPerFace;\n \n c += hash11( id );\n \n float a0 = a * PI * 2.;\n float b0 = b * PI * 2.;\n float c0 = c * PI * 2.;\n \n \n \n mat4 m = wvp;\n m *= rotZ(c0);\n m *= rotY(b0);\n m *= rotY(a0);\n pos = m * vec4(1,1,1,1);\n}\n\n\nvoid main() { \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.03456;\n \tfloat elevation = sin(animTime * 0.223);\n \tfloat fOrbitDistance = 30.;\n \n vec3 target = vec3(0, 0, 0);\n vec3 eye = vec3(0, 0, 10);\n \t eye = vec3( sin(orbitAngle) * fOrbitDistance , sin(elevation * 1.11) * 10. , cos(orbitAngle)* fOrbitDistance ) ;\n vec3 up = vec3(0,1,0);\n \n float numPointsPerFace = 4.;\n float numPointsPerShape = pow(numPointsPerFace, 3.);\n float shapeId = floor(vertexId / numPointsPerShape); \n float shapeCount = floor(vertexCount / numPointsPerShape);\n float shapeV = shapeId / shapeCount;\n float invShapeV = 1. - shapeV;\n \n float size = floor(pow(shapeCount, 1./3.));\n vec3 p = vec3(\n mod(shapeId, size),\n mod(floor(shapeId / size), size),\n floor(floor(shapeId / size) / size));\n vec3 pv = p / size;\n pv = vec3(0,0,0);\n \n float snd = 0.;\n \n vec4 pos;\n mat4 m = ident();\n m *= persp(45., resolution.x / resolution.y, 0.1, 60.);\n m *= cameraLookAt(eye, target, up);\n\n \t//m *= rotY( 0.5+0.5*sin(time * 0.051 + shapeId * sin(time * 0.13) * 0.07) );\n //m *= rotZ( 0.5+0.5*sin(time * 0.073 + shapeId * sin(time * 0.21) * 0.06));\n\n \n \tm *= rotY( sin(time * 0.051 + 0.125 * shapeId * 0.07 ) );\n m *= rotZ( sin(time * 0.073 + shapeId * 0.06 ) );\n \n m *= uniformScale(10. * invShapeV);\n getShapePoint(numPointsPerFace, vertexId, m, pos);\n\n gl_Position = pos;\n gl_PointSize = 4.;\n float z = p1m1(pos.z / pos.w);\n \n \t// Final output color\n //float hue = time * 0.01 + shapeV * 0.1;\n //float sat = 1.;\n //float val = 1.;\n //v_color = vec4(hsv2rgb(vec3(hue, sat, val)), invShapeV + 0.1);\n \n \tv_color = 0.25*vec4(0.7, 0.6, 0.5, 0.0);\n}\n" + }, "screenshotURL": "data/images/images-6uyv98z49slhu41rk-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uXzMte5jWZa5aMKgf/art.json b/art/uXzMte5jWZa5aMKgf/art.json index 2636f81e..26ad3b34 100644 --- a/art/uXzMte5jWZa5aMKgf/art.json +++ b/art/uXzMte5jWZa5aMKgf/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junsujang-digipen", "avatarUrl": "https://avatars.githubusercontent.com/junsujang-digipen?s=200", - "settings": "{\"num\":7407,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Junsu Jang\\n// Exercise - Vertexshaderart : Motion\\n// CS250 \\n// Spring/2022\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId/across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time+y*0.2)*0.1;\\n float yoff = sin(time+x*0.3)*0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\t\\n vec2 xy = vec2(ux,vy)*1.3;\\n \\n gl_Position = vec4(xy, 0., 1.);\\n \\n float soff = sin(time+x*y*0.02)*5.;\\n\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20./across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n //gl_PointSize = 10.;\\n vec2 pos = gl_Position.xy * resolution;\\n v_color = vec4(pos.x,pos.y,cos(pos.x),1.);\\n \\n}\"}", + "settings": { + "num": 7407, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Junsu Jang\n// Exercise - Vertexshaderart : Motion\n// CS250 \n// Spring/2022\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId/across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time+y*0.2)*0.1;\n float yoff = sin(time+x*0.3)*0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \t\n vec2 xy = vec2(ux,vy)*1.3;\n \n gl_Position = vec4(xy, 0., 1.);\n \n float soff = sin(time+x*y*0.02)*5.;\n\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20./across;\n gl_PointSize *= resolution.x / 600.;\n \n //gl_PointSize = 10.;\n vec2 pos = gl_Position.xy * resolution;\n v_color = vec4(pos.x,pos.y,cos(pos.x),1.);\n \n}" + }, "screenshotURL": "data/images/images-gv39rs2wopz7uhjut-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uYBa5uSws8jiReZXu/art.json b/art/uYBa5uSws8jiReZXu/art.json index 631278e7..31b67fcd 100644 --- a/art/uYBa5uSws8jiReZXu/art.json +++ b/art/uYBa5uSws8jiReZXu/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":73,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.06666666666666667,0.06666666666666667,1],\"shader\":\"#define PI radians(180.)\\n#define VERTICES_PER_TRI 3\\n#define MASK 16\\n#define MAX_TRIS 9\\n#define MAX_NORMALS 12\\n#define TOTAL_TRI 12\\n#define VERTS_PER_VEC4 4\\n\\n\\nvec4 triangles[MAX_TRIS];\\nvec3 normals[MAX_NORMALS];\\n \\nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\\nconst float znear = 0.001, zfar=1000.0;\\nconst float rangeInv = 1.0 / (znear-zfar);\\nconst vec4 model_o = vec4(0.0,2.0,7.5,0.0);\\nconst vec3 light = vec3(-11.8,111.2,11.0);\\n mat4 persp = mat4(\\n 1.0 / (resolution.x/resolution.y), 0, 0, 0,\\n 0, 1.0, 0, 0,\\n 0, 0, (znear + zfar) * rangeInv, -1,\\n 0, 0, znear * zfar * rangeInv * 2., 0);\\n\\nvec4 unpackVertex(float a){\\n vec4 r = vec4(a);\\n r.xyz/=masker.yxz;\\n return vec4(mod(r.xyz,masker.xxx), 1.0);\\n}\\n\\nvoid populate(){ \\n triangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \\n triangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \\n triangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \\n triangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \\n triangles[ 4]=vec4( 1326.0, 91.0, 47.0, 91.0); \\n triangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \\n triangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \\n triangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \\n triangles[ 8]=vec4( 4.0, 47.0, 1326.0, 4.0); \\n\\n normals[0]=vec3(0.,0.,-1.);\\n normals[1]=vec3(0.,0.,-1.);\\n normals[2]=vec3(0.,0.,-1.);\\n normals[3]=vec3(0.09,0.97,0.19);\\n normals[4]=vec3(0.27,0.85,0.43);\\n normals[5]=vec3(0.16,0.90,0.39);\\n normals[6]=vec3(0.51,0.84,0.10);\\n normals[7]=vec3(0.,0.80,0.58);\\n normals[8]=vec3(0.,-1.,0.);\\n normals[9]=vec3(0.,-1.,0.);\\n normals[10]=vec3(0.16,-0.98,0.);\\n normals[11]=vec3(0.15,-0.98,0.03);\\n}\\n\\nfloat getVertex(int target){\\n int h= ((target/VERTS_PER_VEC4));\\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\\n for(int i=0;i=TOTAL_TRI*VERTICES_PER_TRI ) {\\n //Mirror the model in x-axis\\n position.x=-position.x;\\n normal = (reflect(normal,-normals[0].zyx));\\n }\\n tnorm = normalize(transform*vec4(normal,1.0)).xyz;\\n\\n position *= transform; \\n v_color = vec4((dot(tnorm,light)/11.))*background*2.;\\n v_color.w = 1.;\\n position.z-= 20.0;\\n gl_Position =persp * position;\\n\\n}\"}", + "settings": { + "num": 73, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.06666666666666667, + 0.06666666666666667, + 1 + ], + "shader": "#define PI radians(180.)\n#define VERTICES_PER_TRI 3\n#define MASK 16\n#define MAX_TRIS 9\n#define MAX_NORMALS 12\n#define TOTAL_TRI 12\n#define VERTS_PER_VEC4 4\n\n\nvec4 triangles[MAX_TRIS];\nvec3 normals[MAX_NORMALS];\n \nconst vec3 masker = vec3(MASK,1.0,MASK*MASK);\nconst float znear = 0.001, zfar=1000.0;\nconst float rangeInv = 1.0 / (znear-zfar);\nconst vec4 model_o = vec4(0.0,2.0,7.5,0.0);\nconst vec3 light = vec3(-11.8,111.2,11.0);\n mat4 persp = mat4(\n 1.0 / (resolution.x/resolution.y), 0, 0, 0,\n 0, 1.0, 0, 0,\n 0, 0, (znear + zfar) * rangeInv, -1,\n 0, 0, znear * zfar * rangeInv * 2., 0);\n\nvec4 unpackVertex(float a){\n vec4 r = vec4(a);\n r.xyz/=masker.yxz;\n return vec4(mod(r.xyz,masker.xxx), 1.0);\n}\n\nvoid populate(){ \n triangles[ 0]=vec4( 0.0, 96.0, 4.0, 91.0); \n triangles[ 1]=vec4( 4.0, 96.0, 47.0, 4.0); \n triangles[ 2]=vec4( 91.0, 2112.0, 91.0, 96.0); \n triangles[ 3]=vec4( 3332.0, 91.0, 2112.0, 3332.0); \n triangles[ 4]=vec4( 1326.0, 91.0, 47.0, 91.0); \n triangles[ 5]=vec4( 1326.0, 2112.0, 3328.0, 3332.0); \n triangles[ 6]=vec4( 0.0, 4.0, 3328.0, 3328.0); \n triangles[ 7]=vec4( 4.0, 3332.0, 1326.0, 3332.0); \n triangles[ 8]=vec4( 4.0, 47.0, 1326.0, 4.0); \n\n normals[0]=vec3(0.,0.,-1.);\n normals[1]=vec3(0.,0.,-1.);\n normals[2]=vec3(0.,0.,-1.);\n normals[3]=vec3(0.09,0.97,0.19);\n normals[4]=vec3(0.27,0.85,0.43);\n normals[5]=vec3(0.16,0.90,0.39);\n normals[6]=vec3(0.51,0.84,0.10);\n normals[7]=vec3(0.,0.80,0.58);\n normals[8]=vec3(0.,-1.,0.);\n normals[9]=vec3(0.,-1.,0.);\n normals[10]=vec3(0.16,-0.98,0.);\n normals[11]=vec3(0.15,-0.98,0.03);\n}\n\nfloat getVertex(int target){\n int h= ((target/VERTS_PER_VEC4));\n int n = int(mod(float(target),float(VERTS_PER_VEC4)));\n for(int i=0;i=TOTAL_TRI*VERTICES_PER_TRI ) {\n //Mirror the model in x-axis\n position.x=-position.x;\n normal = (reflect(normal,-normals[0].zyx));\n }\n tnorm = normalize(transform*vec4(normal,1.0)).xyz;\n\n position *= transform; \n v_color = vec4((dot(tnorm,light)/11.))*background*2.;\n v_color.w = 1.;\n position.z-= 20.0;\n gl_Position =persp * position;\n\n}" + }, "screenshotURL": "data/images/images-kb0s8wmmdgcs37owr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uZ4ELyQ7j8J8X5xJg/art.json b/art/uZ4ELyQ7j8J8X5xJg/art.json index f0788e5d..09c56a20 100644 --- a/art/uZ4ELyQ7j8J8X5xJg/art.json +++ b/art/uZ4ELyQ7j8J8X5xJg/art.json @@ -26,7 +26,19 @@ "name": "julia point cloud", "private": false, "username": "kabuto", - "settings": "{\"num\":56478,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define MAXITER 1000\\n\\nvoid main() {\\n // more or less random start position\\n vec2 v = vec2(cos(vertexId*23.), cos(vertexId*545.))*3.;\\n\\n // collect ljapunov exponent (derivative) for colouring\\n float dv = 0.;\\n \\n float rnd = vertexId;\\n \\n // Follow a path just along the edge of the mandelbrot set's 2 biggest blobs\\n const float PI = 3.141592653589;\\n float t = fract(time*.06)*2.-1.;\\n t = pow(abs(t),0.7)*sign(t);\\n t = fract(t*.5+.6);\\n t = t*2.5*PI-0.5*PI;\\n vec2 ofs = t < 0.\\n ? vec2(-1,0)+vec2(cos(t*4.),sin(t*4.))*.25\\n : vec2(.25,0)-vec2(cos(t),-sin(t))*(1.+cos(t))*.5;\\n \\n //\\n vec2 norm = t < 0.\\n ? vec2(cos(t*4.),sin(t*4.))*sin(-t*2.)\\n : -vec2(cos(t*1.5),-sin(t*1.5))*sin(t);\\n ofs += norm*(sin(time*.3)+sin(time*.33413)+cos(time*.335)+cos(time*.4534)+1.)*.2;\\n \\n \\n for (int i = 0; i < MAXITER; i++) {\\n // random number update\\n rnd = sin(rnd*1337.+vertexId*.2+sin(time)+float(i));\\n \\n // inverse julia iteration step - subtract offset, then extract square root\\n\\tv -= ofs;\\n \\tv = vec2(sqrt((length(v) + v.x)*.5), sign(v.y)*sqrt((length(v) - v.x)*.5));\\n \\n // The complex square root is ambiguous, so both the value just computed and its inverse are valid.\\n // The most simple approach of just randomly picking a point does not work so well -\\n // it tends to collect points in certain spots (mostly tips of the fractal) while neglecting coves.\\n // Mathematically speaking, coves appear because the square root of near-zero values is computed\\n // and the square root tends to make a big difference around such values.\\n // At the same time point density is decreased too...\\n // To combat this we look ahead to the next step and prefer values that are closer to zero.\\n // This doesn't fix everything - for that we would have to look ahead further,\\n //but complexity would increase too much. So it might not really be feasible for this approach.\\n v *= sign(rnd-(length(v-ofs)-length(-v-ofs))*vertexId/vertexCount*1.3*(1.-exp((float(i-1)-float(MAXITER))*.5)));\\n \\n dv += log(length(v))+.2;\\n }\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v*aspect*.5, 1.-vertexId*.00001, 1);\\n\\n gl_PointSize = min(3.,sqrt(max(1.,-dv*.1)));\\n v_color = vec4(dv,dv*.005+1.,1,1)*.3/gl_PointSize;\\n}\"}", + "settings": { + "num": 56478, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define MAXITER 1000\n\nvoid main() {\n // more or less random start position\n vec2 v = vec2(cos(vertexId*23.), cos(vertexId*545.))*3.;\n\n // collect ljapunov exponent (derivative) for colouring\n float dv = 0.;\n \n float rnd = vertexId;\n \n // Follow a path just along the edge of the mandelbrot set's 2 biggest blobs\n const float PI = 3.141592653589;\n float t = fract(time*.06)*2.-1.;\n t = pow(abs(t),0.7)*sign(t);\n t = fract(t*.5+.6);\n t = t*2.5*PI-0.5*PI;\n vec2 ofs = t < 0.\n ? vec2(-1,0)+vec2(cos(t*4.),sin(t*4.))*.25\n : vec2(.25,0)-vec2(cos(t),-sin(t))*(1.+cos(t))*.5;\n \n //\n vec2 norm = t < 0.\n ? vec2(cos(t*4.),sin(t*4.))*sin(-t*2.)\n : -vec2(cos(t*1.5),-sin(t*1.5))*sin(t);\n ofs += norm*(sin(time*.3)+sin(time*.33413)+cos(time*.335)+cos(time*.4534)+1.)*.2;\n \n \n for (int i = 0; i < MAXITER; i++) {\n // random number update\n rnd = sin(rnd*1337.+vertexId*.2+sin(time)+float(i));\n \n // inverse julia iteration step - subtract offset, then extract square root\n\tv -= ofs;\n \tv = vec2(sqrt((length(v) + v.x)*.5), sign(v.y)*sqrt((length(v) - v.x)*.5));\n \n // The complex square root is ambiguous, so both the value just computed and its inverse are valid.\n // The most simple approach of just randomly picking a point does not work so well -\n // it tends to collect points in certain spots (mostly tips of the fractal) while neglecting coves.\n // Mathematically speaking, coves appear because the square root of near-zero values is computed\n // and the square root tends to make a big difference around such values.\n // At the same time point density is decreased too...\n // To combat this we look ahead to the next step and prefer values that are closer to zero.\n // This doesn't fix everything - for that we would have to look ahead further,\n //but complexity would increase too much. So it might not really be feasible for this approach.\n v *= sign(rnd-(length(v-ofs)-length(-v-ofs))*vertexId/vertexCount*1.3*(1.-exp((float(i-1)-float(MAXITER))*.5)));\n \n dv += log(length(v))+.2;\n }\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v*aspect*.5, 1.-vertexId*.00001, 1);\n\n gl_PointSize = min(3.,sqrt(max(1.,-dv*.1)));\n v_color = vec4(dv,dv*.005+1.,1,1)*.3/gl_PointSize;\n}" + }, "screenshotURL": "data/images/images-zmmvovl7lp9166ob0-thumbnail.jpg", "views": { "$numberInt": "960" diff --git a/art/uaxNZMjuMEduopGWR/art.json b/art/uaxNZMjuMEduopGWR/art.json index f33bfcb2..f0aa0dce 100644 --- a/art/uaxNZMjuMEduopGWR/art.json +++ b/art/uaxNZMjuMEduopGWR/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16005,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n vec3 p = vec3(sin(PI/80.*vertexId),cos(PI/80.*vertexId),0);\\n \\n mat2 rot = mat2(\\n cos(PI/80.*vertexId/40.),sin(PI/80.*vertexId/40.),\\n -sin(PI/80.*vertexId/40.),cos(PI/80.*vertexId/40.)\\n );\\n \\n p.xz = p.xz*rot;\\n vec3 op = p;\\n \\n p.xz = p.xz*mat2(cos(time),sin(time),-sin(time),cos(time));\\n p.xy = p.xy*mat2(cos(time*.5),sin(time*.5),-sin(time*.5),cos(time*.5));\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n p.xy*= aspect;\\n gl_Position = vec4(p/(p.z+2.)*.7, 1);\\n gl_PointSize = (1.-gl_Position.z)*10.;\\n\\n v_color = vec4((op*.5+.5)*max(dot(p,vec3(.5,1,-1)),0.),1);\\n}\"}", + "settings": { + "num": 16005, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n vec3 p = vec3(sin(PI/80.*vertexId),cos(PI/80.*vertexId),0);\n \n mat2 rot = mat2(\n cos(PI/80.*vertexId/40.),sin(PI/80.*vertexId/40.),\n -sin(PI/80.*vertexId/40.),cos(PI/80.*vertexId/40.)\n );\n \n p.xz = p.xz*rot;\n vec3 op = p;\n \n p.xz = p.xz*mat2(cos(time),sin(time),-sin(time),cos(time));\n p.xy = p.xy*mat2(cos(time*.5),sin(time*.5),-sin(time*.5),cos(time*.5));\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n p.xy*= aspect;\n gl_Position = vec4(p/(p.z+2.)*.7, 1);\n gl_PointSize = (1.-gl_Position.z)*10.;\n\n v_color = vec4((op*.5+.5)*max(dot(p,vec3(.5,1,-1)),0.),1);\n}" + }, "screenshotURL": "data/images/images-1lqxzmjvfocxm21ol-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ubXN9wpiu8DoS8vjW/art.json b/art/ubXN9wpiu8DoS8vjW/art.json index 0d8fabb0..fc46cb76 100644 --- a/art/ubXN9wpiu8DoS8vjW/art.json +++ b/art/ubXN9wpiu8DoS8vjW/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jonghyeon-lee-digipen", "avatarUrl": "https://avatars.githubusercontent.com/JongHyeon-Lee-Digipen?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"//Name: JongHyeon Lee\\n//Assignment: Motion\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n vec2 xy = vec2(ux, vy) * 1.3;\\n\\n gl_Position = vec4(xy, 0, 1);\\n\\n float soff = sin(time + x * y * 0.02) * 5.;\\n\\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n\\n // Calculate continuous changing color\\n float r = (sin(time * 0.5) + 1.0) * 0.5; // Red component\\n float g = (cos(time * 0.7) + 1.0) * 0.5; // Green component\\n float b = (sin(time * 0.9) + cos(time * 0.3) + 2.0) * 0.25; // Blue component\\n\\n v_color = vec4(r, g, b, 1.0);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "//Name: JongHyeon Lee\n//Assignment: Motion\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n vec2 xy = vec2(ux, vy) * 1.3;\n\n gl_Position = vec4(xy, 0, 1);\n\n float soff = sin(time + x * y * 0.02) * 5.;\n\n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n\n // Calculate continuous changing color\n float r = (sin(time * 0.5) + 1.0) * 0.5; // Red component\n float g = (cos(time * 0.7) + 1.0) * 0.5; // Green component\n float b = (sin(time * 0.9) + cos(time * 0.3) + 2.0) * 0.25; // Blue component\n\n v_color = vec4(r, g, b, 1.0);\n}" + }, "screenshotURL": "data/images/images-yi9l7mun72ywo063j-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ud8JyamidCEqTgz7R/art.json b/art/ud8JyamidCEqTgz7R/art.json index 8badde32..fc270c64 100644 --- a/art/ud8JyamidCEqTgz7R/art.json +++ b/art/ud8JyamidCEqTgz7R/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12972,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 11\\\\\\\\ 13\\\\\\\\ 15,(16,17) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(8,9)10 \\\\\\\\12 14\\n 1\\\\\\\\ 3\\\\\\\\ 5(6,7) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\n\\nvoid main(){\\n gl_PointSize=3.0;\\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\n v_color =vec4(1.0);\\n}\"}", + "settings": { + "num": 12972, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 11\\\\ 13\\\\ 15,(16,17) <---degen\n | \\\\ | \\\\|\ndegen-->(8,9)10 \\\\12 14\n 1\\\\ 3\\\\ 5(6,7) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \n\nvoid main(){\n gl_PointSize=3.0;\n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),0.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position.xy = (gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0));\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\n v_color =vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-8ofp47deymvwnlxsz-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ueTjuJf66xFbmgcBo/art.json b/art/ueTjuJf66xFbmgcBo/art.json index cfa6300e..726df50d 100644 --- a/art/ueTjuJf66xFbmgcBo/art.json +++ b/art/ueTjuJf66xFbmgcBo/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":44468,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aqueous/spl-back-at-it-aqueous-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define parameter0 8.//KParameter0 0.>>10.\\n#define parameter1 0.5//KParameter1 0.>>1.\\n#define parameter2 1.5//KParameter2 0.>>1.\\n#define parameter3 -0.3//KParameter3 -0.5>>1.\\n#define parameter4 2.//KParameter4 0.>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 0.//KParameter7 0.>>1.\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.03 * c.y) , 8.0 /(c.x * 4.0, 8.0, .01 * parameter7), .9 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www * 20.);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 7.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 0, 2, 0, 0,\\n 0, c, s, 0,\\n parameter3, -s, c, 2,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 1,-0.5, parameter5,\\n 0, 1, 0, 0,\\n s, 0, c, 1,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target + eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 +100.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 5.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 16.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .13),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv +.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1.5+ parameter3, sin(tm * 0.2) * .1 + 1., sin(tm) * 0.1);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,0.1,0.5);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.10, 0.1, pow(s + .12 *parameter2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 1)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 44468, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aqueous/spl-back-at-it-aqueous-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define parameter0 8.//KParameter0 0.>>10.\n#define parameter1 0.5//KParameter1 0.>>1.\n#define parameter2 1.5//KParameter2 0.>>1.\n#define parameter3 -0.3//KParameter3 -0.5>>1.\n#define parameter4 2.//KParameter4 0.>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 0.//KParameter7 0.>>1.\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.03 * c.y) , 8.0 /(c.x * 4.0, 8.0, .01 * parameter7), .9 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www * 20.);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 7.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 0, 2, 0, 0,\n 0, c, s, 0,\n parameter3, -s, c, 2,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 1,-0.5, parameter5,\n 0, 1, 0, 0,\n s, 0, c, 1,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target + eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, (eye - parameter6), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 15.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 +100.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 3. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 2.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 5.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 16.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .03 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .13),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv +.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1.5+ parameter3, sin(tm * 0.2) * .1 + 1., sin(tm) * 0.1);\n vec3 target = vec3(0);\n vec3 up = vec3(0,0.1,0.5);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.10, 0.1, pow(s + .12 *parameter2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 1)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-rg0mww76q1od7op8e-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uesEjk3MpYeCJCofM/art.json b/art/uesEjk3MpYeCJCofM/art.json index 94c48afd..3a6bfdf7 100644 --- a/art/uesEjk3MpYeCJCofM/art.json +++ b/art/uesEjk3MpYeCJCofM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "julien", "avatarUrl": "https://avatars.githubusercontent.com/julien?s=200", - "settings": "{\"num\":4278,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.00784313725490196,0.0196078431372549,0.21176470588235294,1],\"shader\":\"\\n\\nvec3 hsv2rgb(vec3 c) {\\n\\t\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n \\n}\\n\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.1) * 0.25;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.0; // x,y pos and scale;\\n\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 8.0;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\\n float saturation = 1.0;\\n float value = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1.0);\\n}\"}", + "settings": { + "num": 4278, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.00784313725490196, + 0.0196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "\n\nvec3 hsv2rgb(vec3 c) {\n\t\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n \n}\n\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.1) * 0.25;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.0; // x,y pos and scale;\n\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n \n float soff = sin(time * 1.2 + x * y * 0.02) * 8.0;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.0) * 0.05;\n float saturation = 1.0;\n float value = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-2tzixb39amtzvk6nb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/umxyfipbWA28PZZu5/art.json b/art/umxyfipbWA28PZZu5/art.json index 9f44e0f8..c73489f9 100644 --- a/art/umxyfipbWA28PZZu5/art.json +++ b/art/umxyfipbWA28PZZu5/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "nathan", "avatarUrl": "https://lh6.googleusercontent.com/-JT7xJ_JWLYc/AAAAAAAAAAI/AAAAAAAAAC4/7ddaOc6vFnQ/photo.jpg", - "settings": "{\"num\":1533,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.12549019607843137,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n }\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n\\n//START \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n\\n float u = x / (across - 1.);\\n float v = y / (across -1.);\\n\\n float xoff = 0. ;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0. ;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time * y * 0.02) * 5.;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n //float hue = u * .1 + sin(time + v * 20.);\\n float hue = u * 0.9; // hue = 0-1 (0.1, 0.2 etc. 0 and 1 are red, the others are colours)\\n float sat = 1.; // color to grey\\n float val = 1.;\\n //float val = sin(time + v * u * 20.0);\\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n \\n \\n}\"}", + "settings": { + "num": 1533, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.12549019607843137, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n\n//START \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n\n float u = x / (across - 1.);\n float v = y / (across -1.);\n\n float xoff = 0. ;//sin(time + y * 0.2) * 0.1;\n float yoff = 0. ;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time * y * 0.02) * 5.;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n //float hue = u * .1 + sin(time + v * 20.);\n float hue = u * 0.9; // hue = 0-1 (0.1, 0.2 etc. 0 and 1 are red, the others are colours)\n float sat = 1.; // color to grey\n float val = 1.;\n //float val = sin(time + v * u * 20.0);\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n \n \n}" + }, "screenshotURL": "data/images/images-upkr025e9wco19zd4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/upTN3YzTRee3FJs4P/art.json b/art/upTN3YzTRee3FJs4P/art.json index a7aad909..996fd411 100644 --- a/art/upTN3YzTRee3FJs4P/art.json +++ b/art/upTN3YzTRee3FJs4P/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "floppafilms google emails", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocIuaBwUR9c6Zno3BImNS0s8sMlZcGj0gBrDxanr22L0IECUEO0=s96-c", - "settings": "{\"num\":28423,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/user-458550313/whats-up\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\nV V SSSSSS A\\n V V S A A\\n V V S A A\\n V V S AAAAAAA\\n V SSSSS A A\\n\\nvsa is awesome\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\nvoid main() {\\n\\tvec3 cameraEyeVec = vec3(0,0,0);\\n \\tv_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 28423, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/user-458550313/whats-up", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\nV V SSSSSS A\n V V S A A\n V V S A A\n V V S AAAAAAA\n V SSSSS A A\n\nvsa is awesome\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\nvoid main() {\n\tvec3 cameraEyeVec = vec3(0,0,0);\n \tv_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-urvhu4k9quqf4b3gg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uqWtxuQpEkfxqWXCK/art.json b/art/uqWtxuQpEkfxqWXCK/art.json index 8fb4c741..25867e87 100644 --- a/art/uqWtxuQpEkfxqWXCK/art.json +++ b/art/uqWtxuQpEkfxqWXCK/art.json @@ -26,7 +26,19 @@ "name": "wired", "private": false, "username": "kabuto", - "settings": "{\"num\":50585,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"wired\\\" by kabuto\\n// drawing a smoothed 3d hilbert curve\\n\\n// if this runs too slowly try zooming in\\n// (ctrl + mousewheel up)\\n\\n#define PI 3.14159\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n sin(i*.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76),\\n sin(i*.79553+2.1) +\\n sin(i*1.1311+2.1) +\\n sin(i*1.353-2.1) +\\n sin(i*.476-2.1),\\n sin(i*.5553-2.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*.36+2.1)\\n\\t)*.2;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n cos(i*.9553)*.9553 +\\n cos(i) +\\n cos(i*1.53)*1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*1.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n cos(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*.2;\\n}\\n\\nvec3 hilbert(float s) {\\n\\t\\t vec3 p;\\n\\t\\t {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\t\\t p = vec3(xi,yi,zi);\\n\\t\\t }\\n\\tfloat n = 2.;\\n\\t\\t for (int i = 1; i < 7; i++) {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\n\\t \\n\\tif (xi > .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < .5) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*510.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(1.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = .5;\\n \\n vec3 colour = vec3(0.);\\n\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n \\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/1080.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,0.);\\n}\"}", + "settings": { + "num": 50585, + "mode": "POINTS", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"wired\" by kabuto\n// drawing a smoothed 3d hilbert curve\n\n// if this runs too slowly try zooming in\n// (ctrl + mousewheel up)\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76),\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476-2.1),\n sin(i*.5553-2.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*.36+2.1)\n\t)*.2;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n cos(i*.9553)*.9553 +\n cos(i) +\n cos(i*1.53)*1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*1.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n cos(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2.;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < .5) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*510.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(1.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = .5;\n \n vec3 colour = vec3(0.);\n\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n \n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/1080.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,0.);\n}" + }, "screenshotURL": "data/images/images-kx3hgkhqoxqwoqspq-thumbnail.jpg", "views": { "$numberInt": "3452" diff --git a/art/uqyvxTyC4ctpQRYNi/art.json b/art/uqyvxTyC4ctpQRYNi/art.json index b21bbe6f..f8fccd92 100644 --- a/art/uqyvxTyC4ctpQRYNi/art.json +++ b/art/uqyvxTyC4ctpQRYNi/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junkyo", "avatarUrl": "https://lh5.googleusercontent.com/-kvoS5qzQr_A/AAAAAAAAAAI/AAAAAAAAACQ/FspBlgMeblI/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n\\n gl_Position = vec4(0, 0, 0, 1);\\n \\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n\n gl_Position = vec4(0, 0, 0, 1);\n \n \n}" + }, "screenshotURL": "data/images/images-ej9mibe3572fcu8x1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ur9ypANXXdW8q9gmW/art.json b/art/ur9ypANXXdW8q9gmW/art.json index be7be8b1..a2b6dded 100644 --- a/art/ur9ypANXXdW8q9gmW/art.json +++ b/art/ur9ypANXXdW8q9gmW/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\"}", + "settings": { + "num": 1, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n gl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}" + }, "screenshotURL": "data/images/images-zghf35sd877zzpowh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/us5PXZuW9emkg2bD4/art.json b/art/us5PXZuW9emkg2bD4/art.json index fce7f5ff..355fa0d4 100644 --- a/art/us5PXZuW9emkg2bD4/art.json +++ b/art/us5PXZuW9emkg2bD4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nohell/the-juju-orchestra-take-four\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.3;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\\n vCubeOrigin.y += perBlock * + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.5 + quant(over, 3.) * 0.7;\\n float sat = step(0.75,s2);\\n float val = 1.;\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -0.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nohell/the-juju-orchestra-take-four", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * perBlock * 1.05;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\n vCubeOrigin.y += perBlock * + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.5 + quant(over, 3.) * 0.7;\n float sat = step(0.75,s2);\n float val = 1.;\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -0.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-k4zz6k7352awiblid-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/us7EwfYeHRHwZoEsZ/art.json b/art/us7EwfYeHRHwZoEsZ/art.json index 14fb799c..d7f1363b 100644 --- a/art/us7EwfYeHRHwZoEsZ/art.json +++ b/art/us7EwfYeHRHwZoEsZ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "clydepashley", "avatarUrl": "https://avatars.githubusercontent.com/clydepashley?s=200", - "settings": "{\"num\":849,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n float down = floor(sqrt (vertexCount));\\n float across = floor (vertexCount / down);\\n \\n //Create Grid\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n //Respace out\\n x = x / (across - 1.);\\n y = y / (across - 1.);\\n \\n //Move back around origin\\n x = x * 2. - 1.;\\n y = y * 2. - 1.;\\n \\n float sin_thing = sin(vertexId + time);\\n \\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = sin_thing * 10.;\\n v_color = vec4(sin_thing * 140., sin_thing * 2.,mod(sin_thing,1.),1);\\n //v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\\n}\"}", + "settings": { + "num": 849, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n float down = floor(sqrt (vertexCount));\n float across = floor (vertexCount / down);\n \n //Create Grid\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n //Respace out\n x = x / (across - 1.);\n y = y / (across - 1.);\n \n //Move back around origin\n x = x * 2. - 1.;\n y = y * 2. - 1.;\n \n float sin_thing = sin(vertexId + time);\n \n gl_Position = vec4(x,y,0,1);\n gl_PointSize = sin_thing * 10.;\n v_color = vec4(sin_thing * 140., sin_thing * 2.,mod(sin_thing,1.),1);\n //v_color = vec4(mod(sin_thing,2.), sin_thing * 2.,mod(sin_thing,1.),1);\n}" + }, "screenshotURL": "data/images/images-de3u8l7gh19tbiubs-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ut2hNmEtGzvzi7Rwj/art.json b/art/ut2hNmEtGzvzi7Rwj/art.json index 372ca4fd..95d5765f 100644 --- a/art/ut2hNmEtGzvzi7Rwj/art.json +++ b/art/ut2hNmEtGzvzi7Rwj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n\\t\\n}\"}", + "settings": { + "num": 20000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n\t\n}" + }, "screenshotURL": "data/images/images-i0w432s0q7axj84rm-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ut7msYoHpzuRZjDyc/art.json b/art/ut7msYoHpzuRZjDyc/art.json index 71858f13..b2a30aa2 100644 --- a/art/ut7msYoHpzuRZjDyc/art.json +++ b/art/ut7msYoHpzuRZjDyc/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":95496,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wbgldn/track-01\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 0.5>>2.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>12.\\n#define parameter3 1.//KParameter3 0.5>>-4.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 -1.>>1.\\n\\n\\n#define PI radians(180. * parameter2)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\\n vec4 K = vec4(1.0, 2.5 / 0.0, 1.0 / 3.0/parameter4, (parameter5 - 3.0 * parameter1));\\n vec3 p = abs(fract(c.xxx + K.xyz) * (6.0 / parameter6) - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians -parameter2);\\n \\t\\n return mat4( \\n 1, 0, 0, parameter2,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, parameter6, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians- parameter3);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, s,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, (2. - parameter4));\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1. / parameter3,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 6.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv + .3),\\n crv(cv + .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .3),\\n crv(cv2 + .6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.1)\\n ).a;\\n \\n float tm = time * 0.1 + parameter3 / 2.;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// mat *= trans(p2 * 2.);\\n mat *= p4;\\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\\n\\n float hue = gv * .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\"}", + "settings": { + "num": 95496, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wbgldn/track-01", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 0.5>>2.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>12.\n#define parameter3 1.//KParameter3 0.5>>-4.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 -1.>>1.\n\n\n#define PI radians(180. * parameter2)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, parameter7));\n vec4 K = vec4(1.0, 2.5 / 0.0, 1.0 / 3.0/parameter4, (parameter5 - 3.0 * parameter1));\n vec3 p = abs(fract(c.xxx + K.xyz) * (6.0 / parameter6) - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, parameter0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians -parameter2);\n \t\n return mat4( \n 1, 0, 0, parameter2,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, parameter6, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians- parameter3);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, s,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, (2. - parameter4));\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1. / parameter3,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 6.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu * 2. + gv * 30. + time * .05 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv + .3),\n crv(cv + .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .3),\n crv(cv2 + .6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.1)\n ).a;\n \n float tm = time * 0.1 + parameter3 / 2.;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 p4 = lookAt(p2 * 2., p3 * 2., up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// mat *= trans(p2 * 2.);\n mat *= p4;\n mat *= uniformScale(mix(0.0, 0.1, pow(s + .2, 10. -parameter6)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3 * parameter4, 0.4, -1));\n\n float hue = gv * .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n" + }, "screenshotURL": "data/images/images-8lf6fgfzzcxp6rk2w-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uuHumiKPEiAKNPkEA/art.json b/art/uuHumiKPEiAKNPkEA/art.json index cf9ff0e3..bf00bc58 100644 --- a/art/uuHumiKPEiAKNPkEA/art.json +++ b/art/uuHumiKPEiAKNPkEA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/7e-p/i-am-robot-and-proud-touch-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 1.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n //snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd = texture2D(sound, vec2(\\n mix(0.001, 0.021, abs(atan(offset.x, offset.y + sin(time + length(offset))) / PI)), \\n length(offset) * 0.1)).a;\\n \\n\\n vec3 pos;\\n float inner = mix(-2.0, 2.0, pow(snd,2.));//mix(0.0, 1. - pow(snd, 4.), cgId);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect * (0.4 + sin(time) * 0.0));\\n //mat *= rotZ(time * 0.1 * sign(offset.x));\\n mat *= trans(offset);\\n float sp = pow(snd, 5.0);\\n \\n mat *= rotZ(pow(snd, 0.5) * -6. * sign(offset.x));\\n mat *= uniformScale(0.1);// + -sin((time + 0.5) * 6.) * 0.01);\\n //mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.1 + sliceId * 0.0);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 0.6;//tm * 0.0 + mix(0., .02, length(offset));\\n float sat = 0.6;pow(snd, 5.);\\n float val = pow(snd, 5.);//step(0.90, snd); //0.;//mix(hash(groupId), 1.0, step(0.99, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/7e-p/i-am-robot-and-proud-touch-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 1.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n //snd = pow(snd, mix(2., 0.5, su));\n \n \n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd = texture2D(sound, vec2(\n mix(0.001, 0.021, abs(atan(offset.x, offset.y + sin(time + length(offset))) / PI)), \n length(offset) * 0.1)).a;\n \n\n vec3 pos;\n float inner = mix(-2.0, 2.0, pow(snd,2.));//mix(0.0, 1. - pow(snd, 4.), cgId);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect * (0.4 + sin(time) * 0.0));\n //mat *= rotZ(time * 0.1 * sign(offset.x));\n mat *= trans(offset);\n float sp = pow(snd, 5.0);\n \n mat *= rotZ(pow(snd, 0.5) * -6. * sign(offset.x));\n mat *= uniformScale(0.1);// + -sin((time + 0.5) * 6.) * 0.01);\n //mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.1 + sliceId * 0.0);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = 0.6;//tm * 0.0 + mix(0., .02, length(offset));\n float sat = 0.6;pow(snd, 5.);\n float val = pow(snd, 5.);//step(0.90, snd); //0.;//mix(hash(groupId), 1.0, step(0.99, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-esq7vkjrkb1apsw6g-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uvCsxPZo4fAnuhkrZ/art.json b/art/uvCsxPZo4fAnuhkrZ/art.json index cc23c7ab..b0de23fe 100644 --- a/art/uvCsxPZo4fAnuhkrZ/art.json +++ b/art/uvCsxPZo4fAnuhkrZ/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "이원용", "avatarUrl": "https://secure.gravatar.com/avatar/19bc9a19b7b6dda587101c7dc9b41c99?default=retro&size=200", - "settings": "{\"num\":19999,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/wubbixmusic/boss-fight\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n/*\\nName: Lee Wonyong\\nAssignment 03 / shader\\nclass: CS230\\nterm: 2019 spring\\n*/\\nvoid main() \\n{\\n float get_sound = texture2D(sound, vec2(mouse.x,mouse.y)).a;\\n // get the sound value and insert it\\n gl_Position = vec4(sin(get_sound)*mouse.x, cos(get_sound)*mouse.y,0 , abs(sin(get_sound*10.0)));\\n // position of points, x , y , z , depth\\n gl_PointSize = 100.0;\\n // size of points\\n v_color=vec4(abs(sin(get_sound)),abs(cos(get_sound)),abs(sin(get_sound)),1.0);\\n // set color of points red, green, blue, alpha\\n}\\n\\n\"}", + "settings": { + "num": 19999, + "mode": "POINTS", + "sound": "https://soundcloud.com/wubbixmusic/boss-fight", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n/*\nName: Lee Wonyong\nAssignment 03 / shader\nclass: CS230\nterm: 2019 spring\n*/\nvoid main() \n{\n float get_sound = texture2D(sound, vec2(mouse.x,mouse.y)).a;\n // get the sound value and insert it\n gl_Position = vec4(sin(get_sound)*mouse.x, cos(get_sound)*mouse.y,0 , abs(sin(get_sound*10.0)));\n // position of points, x , y , z , depth\n gl_PointSize = 100.0;\n // size of points\n v_color=vec4(abs(sin(get_sound)),abs(cos(get_sound)),abs(sin(get_sound)),1.0);\n // set color of points red, green, blue, alpha\n}\n\n" + }, "screenshotURL": "data/images/images-ziksc6uu99ezoo06l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uw8sFSNiZKdTFYyqd/art.json b/art/uw8sFSNiZKdTFYyqd/art.json index df2c2d97..be8d645c 100644 --- a/art/uw8sFSNiZKdTFYyqd/art.json +++ b/art/uw8sFSNiZKdTFYyqd/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":41000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.07058823529411765,0.011764705882352941,0.38823529411764707,1],\"shader\":\"// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\\n//KDrawmode=GL_TRIANGLE_STRIP\\n// Tuned via XShade (http://www.funparadigm.com/xshad\\n#define kp0 11.6//KParameter -22.>>22.\\n#define kp1 1.2//KParameter -2.>>2.\\n//KVerticesNumber=41000.\\n\\n////////////////////////////////////////////////////////////\\n#define PI radians(90.)\\nmat4 persp(float fov, float aspect, float zNear, float zFar);\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\\nmat4 inverse(mat4 m);\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\\n////////////////////////////////////////////////////////////\\n\\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\\nmat3 RotY(float a){return mat3(cos(a),0.3-mouse.x,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\\nmat4 Trans(float x, float y, float z){return mat4(1,0.5,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\\n\\n#define _2pi 6.2831853\\n#define _pi 3.1415926\\n#define _05pi 2.5707963\\n\\nvoid main()\\n{\\n \\tfloat t = time * 5.;\\n \\n \\tgl_PointSize = 8.;\\n\\n \\tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\\n\\tfloat hexSpace = 0.20* kp1;\\n \\tvec2 height = vec2(22.*kp1,0.6);\\n \\t\\n\\tfloat indexQuad = floor(vertexId / 12.);\\n\\tfloat indexCircle = floor(indexQuad / polySize);\\n\\t\\t\\n\\tfloat astep = -_2pi / polySize;\\n\\t\\n\\tfloat angleOffset = _05pi;\\n\\tfloat angle0 = indexQuad * astep + angleOffset;\\n\\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\\n\\t\\n\\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\\n\\t\\t\\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\\n \\tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\\n \\n \\tif (indexCircle > snd2 * 1000.) \\n {\\n \\tgl_Position = vec4(0,0,0,0);\\n \\treturn;\\n }\\n \\n\\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\\n\\t\\n\\tfloat hexTop = hexHeight * 0.5;\\n\\tfloat hexBottom = hexHeight * -0.5;\\n\\tfloat hexCenterOffset = height.y;\\n\\t\\n\\tfloat index = mod(vertexId, 12.);\\n\\t\\n\\tvec3 p = vec3(0);\\n\\t\\n\\t// triangle bas\\n\\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\\n\\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\\n\\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\\n\\t\\n\\t// triangle 1\\n\\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\\n\\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\t\\n\\t// triangle 2\\n\\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\\n\\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\\n\\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\\n\\t\\n\\t// triangle haut\\n\\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\\n\\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\\n\\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\\n\\t\\n \\t// normal\\n\\tvec3 n = vec3(0);\\n\\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\\n\\telse n = normalize(vec3(0,p.y,0));\\n\\t\\n\\tvec3 col = n;\\n\\t\\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\\n \\n\\tif (indexCircle > 0.)\\n\\t{\\n\\t\\tfloat side_length = ringCircle;\\n\\t\\t\\n\\t\\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\\n\\t\\t\\n\\t\\tfloat side_number = floor(circleOffset / side_length);\\n\\t\\tfloat side_offset = mod(circleOffset, side_length);\\n\\t\\t\\n\\t\\tfloat as = _2pi / polySize;\\n\\t\\t\\n\\t\\tfloat a = as * side_number;\\n\\t\\tvec2 hex0 = vec2(cos(a),sin(a));\\n\\t\\t\\n\\t\\ta = as * mod((side_number + 1.), polySize);\\n\\t\\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\\n\\n\\t\\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\\n\\t}\\n\\n\\tp.y -= 15.;\\n\\t\\n\\t///////////////////////////////////////////////////////////////////////////////////////\\n\\tfloat ca = t * -0.05;\\n\\tfloat cd = 40.;\\n\\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\\n\\tvec3 target = vec3(0, 0, 0);\\n\\tvec3 up = vec3(0, 1, 0);\\n \\n\\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \\n\\tcamera *= cameraLookAt(eye, target, up);\\n \\n\\tgl_Position = camera * vec4(p, 1);\\n\\t\\n \\tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\\n\\t\\n\\tv_color = vec4(clamp(col,0.,1.), 1);\\n}\\n\\t\\n////////////////////////////////////////////////////////////\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \\n #endif\\n \\n}\\n////////////////////////////////////////////////////////////\"}", + "settings": { + "num": 41000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.07058823529411765, + 0.011764705882352941, + 0.38823529411764707, + 1 + ], + "shader": "// Created by Stephane Cuillerdier - Aiekick/2017 (twitter:@aiekic// License Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License.\n//KDrawmode=GL_TRIANGLE_STRIP\n// Tuned via XShade (http://www.funparadigm.com/xshad\n#define kp0 11.6//KParameter -22.>>22.\n#define kp1 1.2//KParameter -2.>>2.\n//KVerticesNumber=41000.\n\n////////////////////////////////////////////////////////////\n#define PI radians(90.)\nmat4 persp(float fov, float aspect, float zNear, float zFar);\nmat4 lookAt(vec3 eye, vec3 target, vec3 up);\nmat4 inverse(mat4 m);\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up);\n////////////////////////////////////////////////////////////\n\nmat3 RotX(float a){return mat3(1.,0.,0.,0.,cos(a),-sin(a),0.,sin(a),cos(a));}\nmat3 RotY(float a){return mat3(cos(a),0.3-mouse.x,sin(a),0.,1.,0.,-sin(a),0.,cos(a));}\nmat3 RotZ(float a){return mat3(cos(a),-sin(a),0.,sin(a),cos(a),0.,0.,0.,1.);}\nmat4 Trans(float x, float y, float z){return mat4(1,0.5,0,0,0,1,0,0,0,0,1,0,x,y,z,1);}\n\n#define _2pi 6.2831853\n#define _pi 3.1415926\n#define _05pi 2.5707963\n\nvoid main()\n{\n \tfloat t = time * 5.;\n \n \tgl_PointSize = 8.;\n\n \tfloat polySize = clamp(floor(6. * (1.0-mouse.x)), 3., 6.);\n\tfloat hexSpace = 0.20* kp1;\n \tvec2 height = vec2(22.*kp1,0.6);\n \t\n\tfloat indexQuad = floor(vertexId / 12.);\n\tfloat indexCircle = floor(indexQuad / polySize);\n\t\t\n\tfloat astep = -_2pi / polySize;\n\t\n\tfloat angleOffset = _05pi;\n\tfloat angle0 = indexQuad * astep + angleOffset;\n\tfloat angle1 = (indexQuad + 3.+astep) * astep + angleOffset;\n\t\n\tfloat ringCircle = floor(sqrt((4. * indexCircle - 0.3) / 9.0) *1.5+kp0) - 1.0;;\n\t\t\n float snd = texture2D(sound, vec2(2.1, ringCircle * 0.21)*.21).a * 3.;\n \tfloat snd2 = texture2D(sound, vec2(.15, ringCircle * 0.4e1)*.01).a * 2.;\n \n \tif (indexCircle > snd2 * 1000.) \n {\n \tgl_Position = vec4(0,0,0,0);\n \treturn;\n }\n \n\tfloat hexHeight = 1.0 + height.x * (sin(snd)*0.5+0.5)*3.;\n\t\n\tfloat hexTop = hexHeight * 0.5;\n\tfloat hexBottom = hexHeight * -0.5;\n\tfloat hexCenterOffset = height.y;\n\t\n\tfloat index = mod(vertexId, 12.);\n\t\n\tvec3 p = vec3(0);\n\t\n\t// triangle bas\n\tif (index == 0.) p = vec3(cos(angle0), hexBottom, sin(angle0));\n\telse if (index == 1.) p = vec3(cos(angle1), hexBottom, sin(angle1));\n\telse if (index == 2.) p = vec3(0,hexBottom - hexCenterOffset,0);\n\t\n\t// triangle 1\n\telse if (index == 3.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 4.) p = vec3(cos(angle1) , hexBottom, sin(angle1));\n\telse if (index == 5.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\t\n\t// triangle 2\n\telse if (index == 6.) p = vec3(cos(angle0) , hexBottom, sin(angle0));\n\telse if (index == 7.) p = vec3(cos(angle1) , hexTop, sin(angle1));\n\telse if (index == 8.) p = vec3(cos(angle0) , hexTop, sin(angle0));\n\t\n\t// triangle haut\n\telse if (index == 9.) p = vec3(cos(angle0), hexTop, sin(angle0));\n\telse if (index == 10.) p = vec3(cos(angle1), hexTop, sin(angle1));\n\telse if (index == 11.) p = vec3(0,hexTop + hexCenterOffset,0);\n\t\n \t// normal\n\tvec3 n = vec3(0);\n\tif (index >= 3. && index <= 8.) n = normalize(vec3(p.x,0.,p.z));\n\telse n = normalize(vec3(0,p.y,0));\n\t\n\tvec3 col = n;\n\t\n // based on http://vincentwoo.com/2013/03/08/above-and-beyond-the-affirm-job-puzzle/\n \n\tif (indexCircle > 0.)\n\t{\n\t\tfloat side_length = ringCircle;\n\t\t\n\t\tfloat circleOffset = (3. * pow(ringCircle,2.) + 3. * ringCircle + 1.) - indexCircle;\n\t\t\n\t\tfloat side_number = floor(circleOffset / side_length);\n\t\tfloat side_offset = mod(circleOffset, side_length);\n\t\t\n\t\tfloat as = _2pi / polySize;\n\t\t\n\t\tfloat a = as * side_number;\n\t\tvec2 hex0 = vec2(cos(a),sin(a));\n\t\t\n\t\ta = as * mod((side_number + 1.), polySize);\n\t\tvec2 hex1 = vec2(cos(a),sin(a)) - hex0;\n\n\t\tp.xz += ((hex0 * ringCircle) + (hex1 * side_offset)) * (1.8 + hexSpace);\n\t}\n\n\tp.y -= 15.;\n\t\n\t///////////////////////////////////////////////////////////////////////////////////////\n\tfloat ca = t * -0.05;\n\tfloat cd = 40.;\n\tvec3 eye = vec3(sin(ca), 0.8, cos(ca)) * cd;\n\tvec3 target = vec3(0, 0, 0);\n\tvec3 up = vec3(0, 1, 0);\n \n\tmat4 camera = persp(45. * PI / 180., resolution.x / resolution.y, 0.1, 10000.); \n\tcamera *= cameraLookAt(eye, target, up);\n \n\tgl_Position = camera * vec4(p, 1);\n\t\n \tcol *= (p.y+3.) / mix(vec3(0.2,0.5,0.2)*2., vec3(0.2,0.8,0.5), snd);\n\t\n\tv_color = vec4(clamp(col,0.,1.), 1);\n}\n\t\n////////////////////////////////////////////////////////////\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis82., eye), -cross(yAxis, eye), -cross(zAxis, eye), 2.1); \n #endif\n \n}\n////////////////////////////////////////////////////////////" + }, "screenshotURL": "data/images/images-esm9snrln1tjjpmqj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uwSnj6nQHdjH7dR7F/art.json b/art/uwSnj6nQHdjH7dR7F/art.json index 6cce020e..989b9552 100644 --- a/art/uwSnj6nQHdjH7dR7F/art.json +++ b/art/uwSnj6nQHdjH7dR7F/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3100,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec2 createCircle(float id){\\n float ux = floor(id / 6.0) + mod(id, 2.0);\\n //float vy = mod(floor(id / 2.0) + floor (id /3.0), 2.0);\\n //float vy = floor(id/6.0) + mod(id, 3.0);\\n float vy = floor(id/6.0) + mod(id, 3.0);\\n if(mod(id, 6.0) >= 3.0){\\n \\t vy+=1.;\\n }\\n \\n \\n float angle = ux /2.0;\\n float radius = vy;\\n \\n float x = radius * cos(angle);\\n float y = radius * sin(angle);\\n \\n return vec2(x,y);\\n}\\n\\nvoid main() \\n{ \\n \\n vec2 xy = createCircle(vertexId) * 0.01;\\n \\n gl_Position= vec4(xy , 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n}\\n\"}", + "settings": { + "num": 3100, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec2 createCircle(float id){\n float ux = floor(id / 6.0) + mod(id, 2.0);\n //float vy = mod(floor(id / 2.0) + floor (id /3.0), 2.0);\n //float vy = floor(id/6.0) + mod(id, 3.0);\n float vy = floor(id/6.0) + mod(id, 3.0);\n if(mod(id, 6.0) >= 3.0){\n \t vy+=1.;\n }\n \n \n float angle = ux /2.0;\n float radius = vy;\n \n float x = radius * cos(angle);\n float y = radius * sin(angle);\n \n return vec2(x,y);\n}\n\nvoid main() \n{ \n \n vec2 xy = createCircle(vertexId) * 0.01;\n \n gl_Position= vec4(xy , 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;\n}\n" + }, "screenshotURL": "data/images/images-9odxn8ccocloodw7s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uxAPCSmSfNYuW8CJL/art.json b/art/uxAPCSmSfNYuW8CJL/art.json index 9cc48d30..fca79ec8 100644 --- a/art/uxAPCSmSfNYuW8CJL/art.json +++ b/art/uxAPCSmSfNYuW8CJL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5096,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 100.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\\n\"}", + "settings": { + "num": 5096, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 100.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}\n" + }, "screenshotURL": "data/images/images-3zkvifmf7av7w5w8a-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uxbBoD5jdLBmRbdtE/art.json b/art/uxbBoD5jdLBmRbdtE/art.json index 4bb94054..e7942ba5 100644 --- a/art/uxbBoD5jdLBmRbdtE/art.json +++ b/art/uxbBoD5jdLBmRbdtE/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "정학", "avatarUrl": "https://lh6.googleusercontent.com/-OMiZ3nksbAM/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rd4iIW6pXdqajwjPLfViARoXXTGxg/mo/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId - 7.);\\n float y = floor(vertexId - 7.);\\n \\n float u = x / 10.;\\n float v = y / 10.;\\n \\n float ux = mouse.x * u * 2.;\\n float vy = mouse.y * v * 2.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(cos(time) + 1., mouse.x, mouse.y, 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId - 7.);\n float y = floor(vertexId - 7.);\n \n float u = x / 10.;\n float v = y / 10.;\n \n float ux = mouse.x * u * 2.;\n float vy = mouse.y * v * 2.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(cos(time) + 1., mouse.x, mouse.y, 1);\n}" + }, "screenshotURL": "data/images/images-wtwrlwspxibh2wym2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/uxqp5gTZsNRKt9SRM/art.json b/art/uxqp5gTZsNRKt9SRM/art.json index 30929e6d..be5f3841 100644 --- a/art/uxqp5gTZsNRKt9SRM/art.json +++ b/art/uxqp5gTZsNRKt9SRM/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "eugene", "avatarUrl": "https://lh4.googleusercontent.com/-1W0Zx2V2YBo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuck7HOEHYTKOuOYfO3JNASLLHC1T0A/s96-c/photo.jpg", - "settings": "{\"num\":3030,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.06666666666666667,0.25882352941176473,1],\"shader\":\"void main() {\\n\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.2) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n\\n}\"}", + "settings": { + "num": 3030, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.06666666666666667, + 0.25882352941176473, + 1 + ], + "shader": "void main() {\n\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.2) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n\n}" + }, "screenshotURL": "data/images/images-ny2jtpo6oas5apobn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/uzebvE2bsmjwLjrKY/art.json b/art/uzebvE2bsmjwLjrKY/art.json index b8699d54..ad0917fc 100644 --- a/art/uzebvE2bsmjwLjrKY/art.json +++ b/art/uzebvE2bsmjwLjrKY/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"uniform mat4 modelview;\\nuniform mat4 transform;\\nuniform mat3 normalMatrix;\\n\\nuniform vec4 lightPosition;\\n\\nattribute vec4 vertex;\\nattribute vec4 color;\\nattribute vec3 normal;\\n\\nvarying vec4 vertColor;\\n\\nvoid main() {\\n gl_Position = transform * vertex;\\n vec3 ecPosition = vec3(modelview * vertex);\\n\\n vec3 ecNormal = normalize(normalMatrix * normal);\\n\\n vec3 direction = normalize(lightPosition.xyz - ecPosition);\\n float intensity = max(0.0, dot(direction, ecNormal));\\n vertColor = vec4(intensity, intensity, intensity, 1) * color;\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "uniform mat4 modelview;\nuniform mat4 transform;\nuniform mat3 normalMatrix;\n\nuniform vec4 lightPosition;\n\nattribute vec4 vertex;\nattribute vec4 color;\nattribute vec3 normal;\n\nvarying vec4 vertColor;\n\nvoid main() {\n gl_Position = transform * vertex;\n vec3 ecPosition = vec3(modelview * vertex);\n\n vec3 ecNormal = normalize(normalMatrix * normal);\n\n vec3 direction = normalize(lightPosition.xyz - ecPosition);\n float intensity = max(0.0, dot(direction, ecNormal));\n vertColor = vec4(intensity, intensity, intensity, 1) * color;\n}" + }, "screenshotURL": "data/images/images-15gwsc7qd60g0avm9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/v2n4RsmA4tBEGs7Zy/art.json b/art/v2n4RsmA4tBEGs7Zy/art.json index 8390e0c5..344f194a 100644 --- a/art/v2n4RsmA4tBEGs7Zy/art.json +++ b/art/v2n4RsmA4tBEGs7Zy/art.json @@ -27,7 +27,19 @@ "name": "Sound Pointscape", "private": true, "username": "P_Malin", - "settings": "{\"num\":57426,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/judahofficial/london-grammar-strong-judah-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Simple Fractal - @P_Malin\\n \\nvoid main() \\n{ \\n \\tvec2 vUV;\\n \\n\\tvec2 p;\\n \\n \\tp.x = mod(vertexId, 240.0);\\n \\tp.y = floor(vertexId / 240.0);\\n \\n \\tp = p * (1.0 / 240.0);\\n \\n\\tvUV.x = 0.5;\\n \\tvUV.y = 0.5;\\n \\n \\tvec2 vSoundUV = p.xy;\\n \\n \\tfloat h = texture2D( sound, vSoundUV).a;\\n \\tvUV.x = (p.x - p.y);\\n \\tvUV.y = (p.x + p.y + h * 0.5);\\n \\t//vUV *= 0.5;\\n \\n \\tvUV.y -= 1.0;\\n \\t//vUV = vUV * 2.0 - 1.0;\\n \\n\\tgl_Position = vec4( vUV.x, vUV.y, 0.0, 1.0 );\\n \\tgl_PointSize = 4.0;\\n \\n \\tv_color = vec4( h * h, 0.0, h * 0.5 + 0.5, 0.0 );\\n}\"}", + "settings": { + "num": 57426, + "mode": "POINTS", + "sound": "https://soundcloud.com/judahofficial/london-grammar-strong-judah-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Simple Fractal - @P_Malin\n \nvoid main() \n{ \n \tvec2 vUV;\n \n\tvec2 p;\n \n \tp.x = mod(vertexId, 240.0);\n \tp.y = floor(vertexId / 240.0);\n \n \tp = p * (1.0 / 240.0);\n \n\tvUV.x = 0.5;\n \tvUV.y = 0.5;\n \n \tvec2 vSoundUV = p.xy;\n \n \tfloat h = texture2D( sound, vSoundUV).a;\n \tvUV.x = (p.x - p.y);\n \tvUV.y = (p.x + p.y + h * 0.5);\n \t//vUV *= 0.5;\n \n \tvUV.y -= 1.0;\n \t//vUV = vUV * 2.0 - 1.0;\n \n\tgl_Position = vec4( vUV.x, vUV.y, 0.0, 1.0 );\n \tgl_PointSize = 4.0;\n \n \tv_color = vec4( h * h, 0.0, h * 0.5 + 0.5, 0.0 );\n}" + }, "screenshotURL": "data/images/images-rgdov3d337y85l06d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/v5YKKxvrTF6dp4WTo/art.json b/art/v5YKKxvrTF6dp4WTo/art.json index 5626868c..399cf6c8 100644 --- a/art/v5YKKxvrTF6dp4WTo/art.json +++ b/art/v5YKKxvrTF6dp4WTo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":3840,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/horrorshower/marylin-manson-this-is-the-new-shit-horror-shower-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7764705882352941,0.1411764705882353,0.33725490196078434,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() { \\n float units = 40.0;\\n float perSet = units * 6.0;\\n float numGroups = 4.0;\\n float numSets = floor(vertexCount / numGroups / perSet);\\n float perGroup = perSet * numSets;\\n \\n \\n float id = mod(vertexId, perSet);\\n float setId = floor(mod(vertexId, perGroup) / perSet);\\n \\n float vId = mod(vertexId, perSet);\\n float ux = floor(vId / 6.) + mod(vId, 2.);\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \\n \\n float gId = floor(vertexId / perGroup);\\n float gu = gId / numGroups;\\n \\n float u = ux / units;\\n \\n float sv = setId / (numSets - 1.);\\n \\n float s0 = texture2D(sound, vec2(mix(.05, .2, abs(u * 2. - 1.)), sv * .1 + gu * 0.02)).a;\\n float s1 = texture2D(sound, vec2(0.05, gu * 0.1)).a;\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(0, 0, mix(7., 5., pow(s1 + 0.1, 5.)));\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n vec3 pos = vec3(0, vy + pow(s0 + 0.2, 5.0) * 3., 0);\\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(u * PI * 2.);\\n float off = abs(mix(1., -1., fract(u * 2.))); //abs(cos(u * PI * 2.));\\n mat *= trans(vec3(0, mix(1., .5, off) * (1. - vy), 0));\\n\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 1.0;\\n\\n float top = step(0., gl_Position.y);\\n \\n float hue = u * .1 + mix(.85, 0.5, top);\\n float sat = .4;\\n float val = mix(0.5, 0., top);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color, 1. - gu);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 3840, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/horrorshower/marylin-manson-this-is-the-new-shit-horror-shower-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7764705882352941, + 0.1411764705882353, + 0.33725490196078434, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() { \n float units = 40.0;\n float perSet = units * 6.0;\n float numGroups = 4.0;\n float numSets = floor(vertexCount / numGroups / perSet);\n float perGroup = perSet * numSets;\n \n \n float id = mod(vertexId, perSet);\n float setId = floor(mod(vertexId, perGroup) / perSet);\n \n float vId = mod(vertexId, perSet);\n float ux = floor(vId / 6.) + mod(vId, 2.);\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \n \n float gId = floor(vertexId / perGroup);\n float gu = gId / numGroups;\n \n float u = ux / units;\n \n float sv = setId / (numSets - 1.);\n \n float s0 = texture2D(sound, vec2(mix(.05, .2, abs(u * 2. - 1.)), sv * .1 + gu * 0.02)).a;\n float s1 = texture2D(sound, vec2(0.05, gu * 0.1)).a;\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(0, 0, mix(7., 5., pow(s1 + 0.1, 5.)));\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n vec3 pos = vec3(0, vy + pow(s0 + 0.2, 5.0) * 3., 0);\n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(u * PI * 2.);\n float off = abs(mix(1., -1., fract(u * 2.))); //abs(cos(u * PI * 2.));\n mat *= trans(vec3(0, mix(1., .5, off) * (1. - vy), 0));\n\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 1.0;\n\n float top = step(0., gl_Position.y);\n \n float hue = u * .1 + mix(.85, 0.5, top);\n float sat = .4;\n float val = mix(0.5, 0., top);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color, 1. - gu);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-mogyvp5gi2g3wifz3-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/v5nH366PBWGH7qqG8/art.json b/art/v5nH366PBWGH7qqG8/art.json index 885a8315..5983336e 100644 --- a/art/v5nH366PBWGH7qqG8/art.json +++ b/art/v5nH366PBWGH7qqG8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * 0.;\\n float y = s * 0.;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * 0.;\n float y = s * 0.;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-9jh9okr2rknwuyjtw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/v8Q2uDoFCSfa5sQRC/art.json b/art/v8Q2uDoFCSfa5sQRC/art.json index 1f37b74a..2ec37c5f 100644 --- a/art/v8Q2uDoFCSfa5sQRC/art.json +++ b/art/v8Q2uDoFCSfa5sQRC/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "seongwon.jang", "avatarUrl": "https://secure.gravatar.com/avatar/fc6292437035d0a96160cdb27eb0a6dd?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux - sin(time + vy) + 0.5, vy + cos(time * ux + vy) - 0.5,cos(time + vy + ux), 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n\\n v_color = vec4(gl_Position.x, gl_Position.y, gl_Position.z, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux - sin(time + vy) + 0.5, vy + cos(time * ux + vy) - 0.5,cos(time + vy + ux), 1);\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n\n v_color = vec4(gl_Position.x, gl_Position.y, gl_Position.z, 1);\n}" + }, "screenshotURL": "data/images/images-wklrmxf75r1qqmtzn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/v8pJCRw47pMT9EDZk/art.json b/art/v8pJCRw47pMT9EDZk/art.json index 9b5d4686..da49ee84 100644 --- a/art/v8pJCRw47pMT9EDZk/art.json +++ b/art/v8pJCRw47pMT9EDZk/art.json @@ -26,7 +26,19 @@ "name": "Rainbow Grid", "private": true, "username": "baldand", - "settings": "{\"num\":10000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5058823529411764,0.4588235294117647,0.4588235294117647,1],\"shader\":\"void main() {\\n vec3 pos = vec3(sin(vertexId*(.1+.1*sin(time*.001))+time*.01),cos(vertexId*(.1+.1*sin(time*.0011))+time*.01),1.1);\\n gl_Position = vec4(pos.xy,1.0/pos.z,pos.z);\\n v_color = vec4(sin(vertexId+time),cos(vertexId+time),sin(vertexId*1.1+time),1.);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5058823529411764, + 0.4588235294117647, + 0.4588235294117647, + 1 + ], + "shader": "void main() {\n vec3 pos = vec3(sin(vertexId*(.1+.1*sin(time*.001))+time*.01),cos(vertexId*(.1+.1*sin(time*.0011))+time*.01),1.1);\n gl_Position = vec4(pos.xy,1.0/pos.z,pos.z);\n v_color = vec4(sin(vertexId+time),cos(vertexId+time),sin(vertexId*1.1+time),1.);\n}" + }, "screenshotURL": "data/images/images-yrmt3uastjimfjnlx-thumbnail.jpg", "views": { "$numberInt": "1" diff --git a/art/vBDBSAvnH4mCTZ4So/art.json b/art/vBDBSAvnH4mCTZ4So/art.json index 8923c3df..4c42dc59 100644 --- a/art/vBDBSAvnH4mCTZ4So/art.json +++ b/art/vBDBSAvnH4mCTZ4So/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), 2.-sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 ctr = vec2(0.5);\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 4.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 80. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown * snd; \\n gl_PointSize *= resolution.x / 40. * xOff; \\n xy -= ctr;\\n xy *= rotate2D(snd * PI * 2.0 +s);\\n xy += ctr;\\n xy *= pow(xy, ctr + xy);\\n xy *= -3.;\\n //xy = fract(xy / 0.1);\\n vec4 pos = vec4(xy / yOff, -.25*s*xOff/sin(s*sin(time)) , 1.15-xOff);\\n pos *= rotY(PI * s);\\n gl_Position = pos;\\n xy -= vec2(0.5);\\n xy *= rotate2D(-snd * -PI * 2.0);\\n xy += vec2(0.5);\\n xy *= mouse;\\n float hue = snd *-s;\\n hue = smoothstep(xy.x, xy.y, s);\\n float sat = 1.0;\\n float val = invV;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val))+0.95*s, 1);\\n color *= rotY(PI * snd * s/2.);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n \\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), 2.-sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n vec2 ctr = vec2(0.5);\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 4.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 80. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown * snd; \n gl_PointSize *= resolution.x / 40. * xOff; \n xy -= ctr;\n xy *= rotate2D(snd * PI * 2.0 +s);\n xy += ctr;\n xy *= pow(xy, ctr + xy);\n xy *= -3.;\n //xy = fract(xy / 0.1);\n vec4 pos = vec4(xy / yOff, -.25*s*xOff/sin(s*sin(time)) , 1.15-xOff);\n pos *= rotY(PI * s);\n gl_Position = pos;\n xy -= vec2(0.5);\n xy *= rotate2D(-snd * -PI * 2.0);\n xy += vec2(0.5);\n xy *= mouse;\n float hue = snd *-s;\n hue = smoothstep(xy.x, xy.y, s);\n float sat = 1.0;\n float val = invV;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val))+0.95*s, 1);\n color *= rotY(PI * snd * s/2.);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n \n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-ny7768vo3dmybxoap-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vEvaCS9R8ehpnLZPj/art.json b/art/vEvaCS9R8ehpnLZPj/art.json index b125c33c..b53dfdc8 100644 --- a/art/vEvaCS9R8ehpnLZPj/art.json +++ b/art/vEvaCS9R8ehpnLZPj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12332,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/diskore/m4r-2017-01-31\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n\\n#define KP0 3. *mouse.x//KParameter0 0.>>10.\\n#define KP1 3. *mouse.y//Kparameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>5.\\n#define KP3 0.//KParameter3 0.>>0.5\\n#define KP4 2.//KParameter4 0.>>2.0\\n#define KP5 2222.0//KParameter5 1000.>>180000.\\n//KVerticesNumber=KP5\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 8.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.005, 1.0 -KP4), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1) ; \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n -0.2, 0, 1, 0,\\n trans, 1.5);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, -0.5, 1, 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.2 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect + f, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.-KP0);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2. +mouse.x)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time * cgv * tan(1.2 - KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.2, 0.5 /cu, gs), gt * (0.00005 + KP3))).a; \\n float VC = vertexCount;\\n float (KP5 /mouse.y)*s2;\\n \\n vec3 pos;\\n float inner = sin(-1.3-KP2);\\n float start = 0.5- 0.0003 +s2;\\n float end = 2./tan(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv ,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,0.5,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, s2* .1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2.3, mod(circleId, 2.)) + gy * (0.0 +KP2) * cos(time * .1));\\n //[sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) - KP3 * 1. * sign(h)); \\n mat *= scale(vec3(0.8/KP0, sin(11.9 * s2)* 8.0, 1.5));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, KP3+ .5)*cos(s /s2);\\n gl_PointSize = 2.;\\n\\n float hue = 1. + cgId - 1.4;\\n float sat = 1.7 - step(pow(s2, mouse.y * 2.), abs(gt+ 2. * 11.) * .33);\\n float val = 0.8;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x/KP1, sat/s2*5., val)), (0.3 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 12332, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/diskore/m4r-2017-01-31", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n\n#define KP0 3. *mouse.x//KParameter0 0.>>10.\n#define KP1 3. *mouse.y//Kparameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>5.\n#define KP3 0.//KParameter3 0.>>0.5\n#define KP4 2.//KParameter4 0.>>2.0\n#define KP5 2222.0//KParameter5 1000.>>180000.\n//KVerticesNumber=KP5\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 8.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.005, 1.0 -KP4), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1) ; \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n -0.2, 0, 1, 0,\n trans, 1.5);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, -0.5, 1, 0,\n 0, 0, 0, 2);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.2 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect + f, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.-KP0);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2. +mouse.x)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time * cgv * tan(1.2 - KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.2, 0.5 /cu, gs), gt * (0.00005 + KP3))).a; \n float VC = vertexCount;\n float (KP5 /mouse.y)*s2;\n \n vec3 pos;\n float inner = sin(-1.3-KP2);\n float start = 0.5- 0.0003 +s2;\n float end = 2./tan(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv ,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, s-0.4, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,0.5,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, s2* .1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2.3, mod(circleId, 2.)) + gy * (0.0 +KP2) * cos(time * .1));\n //[sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) - KP3 * 1. * sign(h)); \n mat *= scale(vec3(0.8/KP0, sin(11.9 * s2)* 8.0, 1.5));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, KP3+ .5)*cos(s /s2);\n gl_PointSize = 2.;\n\n float hue = 1. + cgId - 1.4;\n float sat = 1.7 - step(pow(s2, mouse.y * 2.), abs(gt+ 2. * 11.) * .33);\n float val = 0.8;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x/KP1, sat/s2*5., val)), (0.3 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-aybrsdt9f6loildph-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vFe83XLQLWckPmxFd/art.json b/art/vFe83XLQLWckPmxFd/art.json index 7fee9d88..1882b3bc 100644 --- a/art/vFe83XLQLWckPmxFd/art.json +++ b/art/vFe83XLQLWckPmxFd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"/*\\n\\n-=O=-\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float xx = mod(vertexId, across);\\n float zz = floor(vertexId / across);\\n float u = xx / across;\\n float v = zz / down;\\n \\n vec3 pos = (vec3(u, 0.5, v) * 2.0 - 1.0) * 10.0;\\n vec3 normal = vec3(0,1,0);\\n \\n const float water_gravity = 0.8;\\n const float water_peakiness = 0.8;\\n \\n for (int octave = 0; octave < 5; ++octave) {\\n float water_wavelength = 1.0;// / float(octave + 1);\\n vec2 wave_dir = vec2(\\n hash(float(octave) * 0.237),\\n hash(float(octave) * 0.373));\\n float wave_x = dot(pos.xz, wave_dir);\\n \\n float a = wave_x;\\n float k = 2.0 * PI / water_wavelength;\\n float c = sqrt(water_gravity / k);\\n float b = water_peakiness - 1.0;\\n float t = time;\\n\\n float ang = k * (a + c * t); \\n float tmp = exp(k * b) / k;\\n float wave_dx = tmp * sin(ang);\\n float wave_dy = -tmp * cos(ang);\\n \\n pos.x += wave_dx;\\n pos.y += wave_dy * 1.;\\n \\n normal.x += wave_dx * -k;\\n normal.y -= wave_dy * -k;\\n }\\n \\n// float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 10., sin(tm * 0.9) * 1.5 + 2., sin(tm) * 10.5);\\n //vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n //vec3 up = vec3(sin(tm),cos(tm),0);\\n //vec3 eye = vec3(5, 10, 20);\\n vec3 target = vec3(0,0,0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 8.0;\\n vec3 n = normalize((mat * vec4(normalize(normal), 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = 0.66;\\n float sat = 6.;//step(0.6, snd);//pow(snd + 0.3, 5.);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n-=O=-\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float xx = mod(vertexId, across);\n float zz = floor(vertexId / across);\n float u = xx / across;\n float v = zz / down;\n \n vec3 pos = (vec3(u, 0.5, v) * 2.0 - 1.0) * 10.0;\n vec3 normal = vec3(0,1,0);\n \n const float water_gravity = 0.8;\n const float water_peakiness = 0.8;\n \n for (int octave = 0; octave < 5; ++octave) {\n float water_wavelength = 1.0;// / float(octave + 1);\n vec2 wave_dir = vec2(\n hash(float(octave) * 0.237),\n hash(float(octave) * 0.373));\n float wave_x = dot(pos.xz, wave_dir);\n \n float a = wave_x;\n float k = 2.0 * PI / water_wavelength;\n float c = sqrt(water_gravity / k);\n float b = water_peakiness - 1.0;\n float t = time;\n\n float ang = k * (a + c * t); \n float tmp = exp(k * b) / k;\n float wave_dx = tmp * sin(ang);\n float wave_dy = -tmp * cos(ang);\n \n pos.x += wave_dx;\n pos.y += wave_dy * 1.;\n \n normal.x += wave_dx * -k;\n normal.y -= wave_dy * -k;\n }\n \n// float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 10., sin(tm * 0.9) * 1.5 + 2., sin(tm) * 10.5);\n //vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n //vec3 up = vec3(sin(tm),cos(tm),0);\n //vec3 eye = vec3(5, 10, 20);\n vec3 target = vec3(0,0,0);\n vec3 up = vec3(0, 1, 0);\n \n mat *= cameraLookAt(eye, target, up);\n \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 8.0;\n vec3 n = normalize((mat * vec4(normalize(normal), 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = 0.66;\n float sat = 6.;//step(0.6, snd);//pow(snd + 0.3, 5.);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-erhzmw5woo4u61489-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vFkJ9f33FZrMwjHCH/art.json b/art/vFkJ9f33FZrMwjHCH/art.json index 382fddf4..8fa9f22a 100644 --- a/art/vFkJ9f33FZrMwjHCH/art.json +++ b/art/vFkJ9f33FZrMwjHCH/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n ___ ___ _______ ________ _________ _______ ___ ___ \\n|\\\\ \\\\ / /|\\\\ ___ \\\\ |\\\\ __ \\\\|\\\\___ ___|\\\\ ___ \\\\ |\\\\ \\\\ / /|\\n\\\\ \\\\ \\\\ / / \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_\\\\ \\\\ __/| \\\\ \\\\ \\\\/ / /\\n \\\\ \\\\ \\\\/ / / \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|/__ \\\\ \\\\ / / \\n \\\\ \\\\ / / \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ / \\\\/ \\n \\\\ \\\\__/ / \\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\\\ \\\\_______\\\\/ /\\\\ \\\\ \\n \\\\|__|/ \\\\|_______|\\\\|__|\\\\|__| \\\\|__| \\\\|_______/__/ /\\\\ __\\\\ \\n |__|/ \\\\|__| \\n \\n \\n ________ ___ ___ ________ ________ _______ ________ \\n|\\\\ ____\\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ ___ \\\\|\\\\ ___ \\\\ |\\\\ __ \\\\ \\n\\\\ \\\\ \\\\___|\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ __/|\\\\ \\\\ \\\\|\\\\ \\\\ \\n \\\\ \\\\_____ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\_|/_\\\\ \\\\ _ _\\\\ \\n \\\\|____|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\n ____\\\\_\\\\ \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\\\\\ _\\\\ \\n |\\\\_________\\\\|__|\\\\|__|\\\\|__|\\\\|__|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__| \\n \\\\|_________| \\n \\n \\n ________ ________ _________ \\n|\\\\ __ \\\\|\\\\ __ \\\\|\\\\___ ___\\\\ \\n\\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\|\\\\ \\\\|___ \\\\ \\\\_| \\n \\\\ \\\\ __ \\\\ \\\\ _ _\\\\ \\\\ \\\\ \\\\ \\n \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\\\\\ \\\\| \\\\ \\\\ \\\\ \\n \\\\ \\\\__\\\\ \\\\__\\\\ \\\\__\\\\\\\\ _\\\\ \\\\ \\\\__\\\\ \\n \\\\|__|\\\\|__|\\\\|__|\\\\|__| \\\\|__| \\n \\n \\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\nvec3 gSunColor = vec3(2.4, 1.2, 0.4) * 10.1; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\\n\\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * -3.;\\nfloat gExposure = 0.2;\\nfloat gCubeColorRandom = .85;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 3.6;\\nfloat gFloorHeight = -43.0*mouse.x;\\nfloat g_cameraFar = 99.0 /mouse.y;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 30.0, -10.3, -50.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.1;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.01;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 1.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 5.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = (v2- mouse.y);\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3, mouse.x;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\\n}\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 1.25 + 1.6;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983-(mouse.x/4.), p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337-mouse.y);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 1, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) *rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv - 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 1, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 2.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.25);\\n }\\n return easeInOutCubic(2. / t * 2.);\\n}\\n\\nconst float perBlock = 4.0 ;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3(-1.92, 3.0, -10.0 );\\n \\n float across = 78.;\\n float down = floor(numCubes / across);\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float uP = m1p1(u);\\n float vP = m1p1(v);\\n\\n float ll = length(vec2(uP, vP * 1.5));\\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\\n float z = vP * down * 11.4 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height = 1.;\\n vCubeOrigin.y += pow(sin(time + v * 2.), 1.3 * snd) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\\n vCubeOrigin *= 20.0;\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= rotZ(p1m1(snd) * 1.);\\n mat *= rotY(p1m1(snd) * 2.);\\n mat *= uniformScale(mix(0.1, 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\\n \\n \\tvec3 vRandCol;\\n\\n float st = step(0.9, snd);\\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \\n pow(snd, 0.), \\n 1));\\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 1.27) * sin(t * 0.1) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 0.78;\\n \\n//\\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\\n// \\tvec3 vCameraPos = vec3(-45.1, 20., -0.);\\n \\n \\tvec3 vCameraTarget = vec3( 0.2, -13.2, 0.8 );\\n \\tvec3 vCameraPos = vec3(sin(time * 0.51) * 85., 1, cos(time * 0.1) * 50.0);\\n float ca = 0.01;\\n \\n // get sick!\\n ca = time * 2.07;\\n \\tvec3 vCameraUp = vec3( -1, 0.05, 0.1 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget * vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol ;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(33.), resolution.x / resolution.y, 1.1, (mouse.x, 500.0 /mouse.y));\\n m *= cameraLookAt(vCameraPos-mouse.x, vCameraTarget-mouse.x, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos +((time -4.0),mouse.x), (2.4, 2.-mouse.y));\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\\n \\tvec3 vFinalColor = sqrt( vec3(.9) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/matt-sassari/matt-sassari-ant-brooks-3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(2.4, 1.2, 0.4) * 10.1; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 1.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 2.8, 0.3 ) * 2.5;\n\nvec3 gCubeColor = vec3(0.7, 0.6, 0.6) * -3.;\nfloat gExposure = 0.2;\nfloat gCubeColorRandom = .85;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 3.6;\nfloat gFloorHeight = -43.0*mouse.x;\nfloat g_cameraFar = 99.0 /mouse.y;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 30.0, -10.3, -50.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.1;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.01;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.1, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 1.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 5.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = (v2- mouse.y);\n }\n \telse\n {\n\t \tvWorldPos = v3, mouse.x;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.01, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.6, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, (0.6 ,time), pow( 1.0 - NdotL, 4.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 3.8 /time;\n}\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 1.25 + 1.6;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 0.4, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983-(mouse.x/4.), p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337-mouse.y);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.2, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 1, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1); \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) *rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv - 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[3][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 1, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 2.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.25);\n }\n return easeInOutCubic(2. / t * 2.);\n}\n\nconst float perBlock = 4.0 ;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3(-1.92, 3.0, -10.0 );\n \n float across = 78.;\n float down = floor(numCubes / across);\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float uP = m1p1(u);\n float vP = m1p1(v);\n\n float ll = length(vec2(uP, vP * 1.5));\n float snd = texture2D(sound, vec2(mix(0.001, 0.0199, uP), ll * 0.3)).a;\n //float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += uP * across * 1.2 + bxId * 0. ;\n float vSpace = numRows * 1.4 + numBlocks * 0.1;\n float z = vP * down * 11.4 + bzId * 0.;\n vCubeOrigin.z += z; \n float height = 1.;\n vCubeOrigin.y += pow(sin(time + v * 2.), 1.3 * snd) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 0.1);\n vCubeOrigin = vec3(hash(fCubeId), hash(fCubeId * 0.371), hash(fCubeId * 0.781)) * 2. - 1.;\n vCubeOrigin *= 20.0;\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= rotZ(p1m1(snd) * 1.);\n mat *= rotY(p1m1(snd) * 2.);\n mat *= uniformScale(mix(0.1, 3.0, pow(clamp(mix(-0.5, 1., snd), 0., 1.), 7.)));\n \n \tvec3 vRandCol;\n\n float st = step(0.9, snd);\n float h = 0. + floor(time * 0.5) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1;\n vCubeCol.rgb = hsv2rgb(vec3(mix(h, h + 0.4, st), \n pow(snd, 0.), \n 1));\n //vCubeCol.rgb = mix(vCubeCol.rgb, vec3(1,0,0), step(0.9, snd));\n vCubeCol.rgb = mix(vCubeCol.rgb, vec3(0,0.5,0), step(0.999, snd));\n vCubeCol.a = 0.;vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 1.27) * sin(t * 0.1) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 0.78;\n \n//\tvec3 vCameraTarget = vec3( 300, -400.6, 500.0 );\n// \tvec3 vCameraPos = vec3(-45.1, 20., -0.);\n \n \tvec3 vCameraTarget = vec3( 0.2, -13.2, 0.8 );\n \tvec3 vCameraPos = vec3(sin(time * 0.51) * 85., 1, cos(time * 0.1) * 50.0);\n float ca = 0.01;\n \n // get sick!\n ca = time * 2.07;\n \tvec3 vCameraUp = vec3( -1, 0.05, 0.1 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget * vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol ;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(33.), resolution.x / resolution.y, 1.1, (mouse.x, 500.0 /mouse.y));\n m *= cameraLookAt(vCameraPos-mouse.x, vCameraTarget-mouse.x, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos +((time -4.0),mouse.x), (2.4, 2.-mouse.y));\n \n \t// Final output color\n \tfloat fExposure = gExposure; min( gExposure, time * 3.31 );\n \tvec3 vFinalColor = sqrt( vec3(.9) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-rs4f0txtuaezf67ur-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vG8pMALDuaEu8S5oL/art.json b/art/vG8pMALDuaEu8S5oL/art.json index ebbba370..076dfe69 100644 --- a/art/vG8pMALDuaEu8S5oL/art.json +++ b/art/vG8pMALDuaEu8S5oL/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":28986,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/backseatlove\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define K0 5.0//KParameter0 0.>>10.\\n#define K1 3.0//KParameter1 0.0>>5.\\n#define KP2 2.0//KParameter2 0.0>>5.\\n#define KP3 0.00//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>2.0\\n#define KP0 (K0 *mouse.y)\\n#define KP1 (K1* mouse.x)\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2., quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 2.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 28986, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/backseatlove", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define K0 5.0//KParameter0 0.>>10.\n#define K1 3.0//KParameter1 0.0>>5.\n#define KP2 2.0//KParameter2 0.0>>5.\n#define KP3 0.00//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>2.0\n#define KP0 (K0 *mouse.y)\n#define KP1 (K1* mouse.x)\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2., quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 2.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-09wnpki6g5h780k5d-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vLxHHs7vSmLsud4hw/art.json b/art/vLxHHs7vSmLsud4hw/art.json index 4ba8cfc4..c7a0bccd 100644 --- a/art/vLxHHs7vSmLsud4hw/art.json +++ b/art/vLxHHs7vSmLsud4hw/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":27013,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n#define NUM_LINES_DOWN 64.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.5;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * NUM_LINES_DOWN) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).r;\\n\\n //\\n float x = u * 3.0 - 1.5;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 4.5) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.25, 0, 1);\\n\\n float hue = u;\\n float sat = invV + 1.2;\\n float val = invV;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 27013, + "mode": "LINES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n#define NUM_LINES_DOWN 64.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0) * STEP;\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / NUM_LINES_DOWN; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.5;\n // Match each line to a specific row in the sound texture\n float historyV = (v * NUM_LINES_DOWN) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).r;\n\n //\n float x = u * 3.0 - 1.5;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 4.5) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.25, 0, 1);\n\n float hue = u;\n float sat = invV + 1.2;\n float val = invV;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-frzk4yk01xlfyoide-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vMMTeTmGkJsRT7dg6/art.json b/art/vMMTeTmGkJsRT7dg6/art.json index 48e23d47..55354628 100644 --- a/art/vMMTeTmGkJsRT7dg6/art.json +++ b/art/vMMTeTmGkJsRT7dg6/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "w.chae", "avatarUrl": "https://secure.gravatar.com/avatar/e33886e1d2ddd9c8199ae2b5bbb15df9?default=retro&size=200", - "settings": "{\"num\":12000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ensisrecords/state-of-wenzel-regular-guy-original-mixensis-discovery?in=sc-playlists/sets/happy-hour\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Wonhyeong Chae\\n// Exercise Circles from triangles\\n// CS250 Spring 2022\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) { \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n\\n}\\n\\nvoid main() {\\n float numCircleSegments = 12.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\n float yoff = 0.;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.1);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 12000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ensisrecords/state-of-wenzel-regular-guy-original-mixensis-discovery?in=sc-playlists/sets/happy-hour", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Wonhyeong Chae\n// Exercise Circles from triangles\n// CS250 Spring 2022\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) { \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n\n}\n\nvoid main() {\n float numCircleSegments = 12.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\n float yoff = 0.;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) + mix(1., 1.1, oddSlice);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.1);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = mix(.4, pow(snd + 0.2, 5.), pump);\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-fwryavh3o6605723t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vNF92j6RWk3FEERkv/art.json b/art/vNF92j6RWk3FEERkv/art.json index 010010a9..c70235e4 100644 --- a/art/vNF92j6RWk3FEERkv/art.json +++ b/art/vNF92j6RWk3FEERkv/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.13725490196078433,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.1) + 0.1;\\n float yoff = sin(time + x * 0.1) + 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.13725490196078433, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.1) + 0.1;\n float yoff = sin(time + x * 0.1) + 0.1;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-tk7et6o86s4l30pn4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vQ7wEjJPEkssSR58B/art.json b/art/vQ7wEjJPEkssSR58B/art.json index 2cab389f..2ebacd59 100644 --- a/art/vQ7wEjJPEkssSR58B/art.json +++ b/art/vQ7wEjJPEkssSR58B/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main () {\\n \\n float scale = 0.5;\\n float tvar1 = 1.;\\n float tvar2 = 1.3;\\n \\n float timevar1 = (sin(time/tvar1) +1.)/2.;\\n float timevar2 = (sin(time/tvar2) +1.)/2.;\\n \\n float vc = vertexCount;\\n \\n float down = abs(sqrt(vc));\\n float across = floor(vc/down); \\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n float xoff = sin(time+timevar1);\\n float yoff = sin(time+timevar2);\\n x += xoff;\\n y += yoff;\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = (u - 0.5) * 2.;\\n float sv = (v - 0.5) * 2.;\\n \\n vec2 xy = vec2(su, sv);\\n xy *= scale;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n gl_PointSize = 10.;\\n gl_PointSize *= 20./down;\\n \\n \\n float hue = su*timevar1 / sv*timevar2;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main () {\n \n float scale = 0.5;\n float tvar1 = 1.;\n float tvar2 = 1.3;\n \n float timevar1 = (sin(time/tvar1) +1.)/2.;\n float timevar2 = (sin(time/tvar2) +1.)/2.;\n \n float vc = vertexCount;\n \n float down = abs(sqrt(vc));\n float across = floor(vc/down); \n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n float xoff = sin(time+timevar1);\n float yoff = sin(time+timevar2);\n x += xoff;\n y += yoff;\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = (u - 0.5) * 2.;\n float sv = (v - 0.5) * 2.;\n \n vec2 xy = vec2(su, sv);\n xy *= scale;\n \n gl_Position = vec4(xy, 0, 1);\n \n gl_PointSize = 10.;\n gl_PointSize *= 20./down;\n \n \n float hue = su*timevar1 / sv*timevar2;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0);\n \n}" + }, "screenshotURL": "data/images/images-fn5g7euhkau4mg28l-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vRKQmBo3cooJejSdP/art.json b/art/vRKQmBo3cooJejSdP/art.json index 2657cd71..7367c529 100644 --- a/art/vRKQmBo3cooJejSdP/art.json +++ b/art/vRKQmBo3cooJejSdP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minjae-yu", "avatarUrl": "https://avatars.githubusercontent.com/minjae-yu?s=200", - "settings": "{\"num\":1040,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : MINJAE YU\\n//Assignment : Audio Reactive\\n//Course : CS250\\n//Term : Spring 2023\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = sin(time);\\n float yoff = cos(time);\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;\\n gl_PointSize = pow(snd + 0.2, 5.0) * 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.5 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1040, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : MINJAE YU\n//Assignment : Audio Reactive\n//Course : CS250\n//Term : Spring 2023\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = sin(time);\n float yoff = cos(time);\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;\n gl_PointSize = pow(snd + 0.2, 5.0) * 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.5 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-eehf04nwx1si1ttfh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vRvb4kJdBxK7WSiSp/art.json b/art/vRvb4kJdBxK7WSiSp/art.json index c65e7439..ea6f4dc8 100644 --- a/art/vRvb4kJdBxK7WSiSp/art.json +++ b/art/vRvb4kJdBxK7WSiSp/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "highkingofgondor", "avatarUrl": "https://secure.gravatar.com/avatar/b1671a1b260e84a63ac485357c417c42?default=retro&size=200", - "settings": "{\"num\":1095,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main () {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 /across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(0, 1, 1, 1);\\n \\n}\"}", + "settings": { + "num": 1095, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main () {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 /across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(0, 1, 1, 1);\n \n}" + }, "screenshotURL": "data/images/images-0rbhrz860sri7tbk8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vSoYhoMHS2k2S8ueR/art.json b/art/vSoYhoMHS2k2S8ueR/art.json index 1733089c..4247429a 100644 --- a/art/vSoYhoMHS2k2S8ueR/art.json +++ b/art/vSoYhoMHS2k2S8ueR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "myunghyunkim0227", "avatarUrl": "https://avatars.githubusercontent.com/MyunghyunKim0227?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://on.soundcloud.com/KvgR5\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Myunghyun Kim\\n//Assignment: Exercise - Vertexshaderart : Making a Grid\\n//Course: CS250\\n//Term: Spring 2023\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float red = sin(time) * 4.;\\n float blue = sin(time) * 4.;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 300.;\\n \\n v_color = vec4(red, 0, blue, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://on.soundcloud.com/KvgR5", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Myunghyun Kim\n//Assignment: Exercise - Vertexshaderart : Making a Grid\n//Course: CS250\n//Term: Spring 2023\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float red = sin(time) * 4.;\n float blue = sin(time) * 4.;\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 300.;\n \n v_color = vec4(red, 0, blue, 1);\n}" + }, "screenshotURL": "data/images/images-5ufrcrfqcrl2s2h20-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vX6mGDTuwQmga2tvj/art.json b/art/vX6mGDTuwQmga2tvj/art.json index 101e3eac..ceb76fd3 100644 --- a/art/vX6mGDTuwQmga2tvj/art.json +++ b/art/vX6mGDTuwQmga2tvj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":20000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/victorruiz/robots\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n//KVerticesNumber=20000\\n\\n#define turning 1.4//KParameter0 1.4>>100.\\n#define rotateXcos 1.//KParameter1 1.>>5.\\n#define rotateYcos 1.//KParameter2 1.>>5.\\n#define rotateZcos 1.//KParameter3 1.>>5.\\n#define spikeFactor 4. //KParameter4 1.>>10.\\n#define spikeFactor2 4. //KParameter5 1.>>100.\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nstruct point {\\n vec3 position;\\n float a;\\n float b;\\n float rad;\\n float snd;\\n};\\n\\npoint getPoint(float i) {\\n\\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\\n pointsPerTurn -= mod(pointsPerTurn, 64.);\\n pointsPerTurn++;\\n float turns = vertexCount / pointsPerTurn;\\n \\n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\\n float b = 2. * PI * i * turns;\\n \\n\\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\\n a = clamp(a, 0., PI);\\n\\n \\n float spike = pow(cos(a * spikeFactor), 4.);\\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\\n if (middle) {\\n\\t spike *= pow(sin(b * spikeFactor2), 4.);\\n }\\n \\n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\\n\\n float rad = 0.35; \\n rad += spike * 0.35;\\n rad += snd * 0.2; \\n\\n \\n float x = sin(a);\\n float y = cos(a); \\n float z = sin(b) * x;\\n x *= cos(b);\\n \\n return point(vec3(x, y, z) * rad, a, b, rad, snd); \\t\\n}\\n\\nvoid main() {\\n \\n point p1 = getPoint(vertexId / vertexCount);\\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\\n \\n \\n float mx = sin(time - p1.rad) * turning;\\n// float mx = PI * -mouse.y;\\n float my = time - p1.rad;\\n// float my = PI * -mouse.x;\\n float mz = sin(time * 0.44 - p1.rad);\\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\\n\\n p1.position.yz *= rotateX;\\n p1.position.xz *= rotateY;\\n p1.position.xy *= rotateZ; \\n\\n \\n float screenZ = -0.;\\n float eyeZ = -4.5;\\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\\n p1.position.xy *= perspective;\\n \\n float aspect = resolution.x / resolution.y;\\n p1.position.x /= aspect;\\n \\n gl_Position = vec4(p1.position, 1);\\n \\n gl_PointSize = 2. - p1.position.z * 5.;\\n\\n\\n float h = fract(p1.b / (2. * PI));\\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\\n \\n if (p1.a < PI / 8.) {\\n \\ts = mix(s, 0., 1. - p1.a / (PI / 8.));\\n } else if (p1.a > PI * 7. / 8.) {\\n \\ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \\n }\\n float v = 0.4 - p1.position.z * 2.;\\n// float v = normal.z * 0.5 + 0.5; \\n \\n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/victorruiz/robots", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n//KVerticesNumber=20000\n\n#define turning 1.4//KParameter0 1.4>>100.\n#define rotateXcos 1.//KParameter1 1.>>5.\n#define rotateYcos 1.//KParameter2 1.>>5.\n#define rotateZcos 1.//KParameter3 1.>>5.\n#define spikeFactor 4. //KParameter4 1.>>10.\n#define spikeFactor2 4. //KParameter5 1.>>100.\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nstruct point {\n vec3 position;\n float a;\n float b;\n float rad;\n float snd;\n};\n\npoint getPoint(float i) {\n\n float pointsPerTurn = floor(sqrt(vertexCount) * 2.);\n pointsPerTurn -= mod(pointsPerTurn, 64.);\n pointsPerTurn++;\n float turns = vertexCount / pointsPerTurn;\n \n float a = (PI + PI / turns) * i; //(acos(1.0 - 2.0 * i) / PI);\n float b = 2. * PI * i * turns;\n \n\n a -= mod(vertexId, 2.) * PI / (turns - 1.);\n a = clamp(a, 0., PI);\n\n \n float spike = pow(cos(a * spikeFactor), 4.);\n bool middle = a > PI / 8. && a < PI * 7. / 8.;\n if (middle) {\n\t spike *= pow(sin(b * spikeFactor2), 4.);\n }\n \n float snd = pow(texture2D(sound, vec2(0.005, spike*0.025)).a, 4.);\n\n float rad = 0.35; \n rad += spike * 0.35;\n rad += snd * 0.2; \n\n \n float x = sin(a);\n float y = cos(a); \n float z = sin(b) * x;\n x *= cos(b);\n \n return point(vec3(x, y, z) * rad, a, b, rad, snd); \t\n}\n\nvoid main() {\n \n point p1 = getPoint(vertexId / vertexCount);\n// point p2 = getPoint((vertexId - 1.) / vertexCount);\n// point p3 = getPoint((vertexId - 2.) / vertexCount);\n// vec3 normal = normalize(cross(p2.position - p1.position, p3.position - p1.position));\n \n \n float mx = sin(time - p1.rad) * turning;\n// float mx = PI * -mouse.y;\n float my = time - p1.rad;\n// float my = PI * -mouse.x;\n float mz = sin(time * 0.44 - p1.rad);\n mat2 rotateX = mat2(cos(mx)*rotateXcos, -sin(mx), sin(mx), cos(mx));\n mat2 rotateY = mat2(cos(my)*rotateYcos, -sin(my), sin(my), cos(my));\n mat2 rotateZ = mat2(cos(mz)*rotateZcos, -sin(mz), sin(mz), cos(mz));\n\n p1.position.yz *= rotateX;\n p1.position.xz *= rotateY;\n p1.position.xy *= rotateZ; \n\n \n float screenZ = -0.;\n float eyeZ = -4.5;\n float perspective = (eyeZ - screenZ) / (p1.position.z - eyeZ);\n p1.position.xy *= perspective;\n \n float aspect = resolution.x / resolution.y;\n p1.position.x /= aspect;\n \n gl_Position = vec4(p1.position, 1);\n \n gl_PointSize = 2. - p1.position.z * 5.;\n\n\n float h = fract(p1.b / (2. * PI));\n float s = (p1.rad - 0.5 * p1.snd) * 3.;\n \n if (p1.a < PI / 8.) {\n \ts = mix(s, 0., 1. - p1.a / (PI / 8.));\n } else if (p1.a > PI * 7. / 8.) {\n \ts = mix(s, 0., 1. - (PI - p1.a) / (PI / 8.)); \n }\n float v = 0.4 - p1.position.z * 2.;\n// float v = normal.z * 0.5 + 0.5; \n \n v_color = vec4(hsv2rgb(vec3(h, s, v)), 1);\n}" + }, "screenshotURL": "data/images/images-1flpjy3ynqqpofr29-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vXFhLDE2hgAm9bXD8/art.json b/art/vXFhLDE2hgAm9bXD8/art.json index 26329ad8..c98a5cbf 100644 --- a/art/vXFhLDE2hgAm9bXD8/art.json +++ b/art/vXFhLDE2hgAm9bXD8/art.json @@ -11,7 +11,19 @@ "origId": "h6BvsMWiHpgwT5Nhh", "name": "pointsprite plasma", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.2 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px, py) * 4.0);\\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.2 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px, py) * 4.0);\n v_color = vec4(c, 2.0 * c, 3.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-jslty9hjtq8kykp1u-thumbnail.jpg", "views": { "$numberInt": "187" diff --git a/art/vY9ZdpP3WcoSgySqL/art.json b/art/vY9ZdpP3WcoSgySqL/art.json index 67459f94..6ae7eade 100644 --- a/art/vY9ZdpP3WcoSgySqL/art.json +++ b/art/vY9ZdpP3WcoSgySqL/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "seiji", "avatarUrl": "https://lh4.googleusercontent.com/-RS-S20_LZCc/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAdcRXz-a14kGVDL4kr6M38jRz17A/photo.jpg", - "settings": "{\"num\":59701,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nvoid main() {\\n\\n gl_PointSize = 10.0; \\n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\\n gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\\n v_color = vec4(1,vertexId,0.5,1);\\n}\"}", + "settings": { + "num": 59701, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nvoid main() {\n\n gl_PointSize = 10.0; \n // gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vec4(0.5,0.5,0.4,1.0);\n //gl_Position = vec4(sin(vertexId/(cos(time)*100.0))/1.2, cos(time)+ cos(vertexId/200.0)/1.5,0.0,1.0);\n gl_Position = vec4(sin(time/vertexId), sin(time*vertexId),0.5,1.0);\n //gl_Position = vec4(0.1, 0.1,0.2, 1.0);\n v_color = vec4(1,vertexId,0.5,1);\n}" + }, "screenshotURL": "data/images/images-ngvto3z3ttbmwpfks-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vZ4PBCfpqJPJ4eweJ/art.json b/art/vZ4PBCfpqJPJ4eweJ/art.json index 03a11bb3..7a4ac921 100644 --- a/art/vZ4PBCfpqJPJ4eweJ/art.json +++ b/art/vZ4PBCfpqJPJ4eweJ/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "nathan2", "avatarUrl": "https://lh3.googleusercontent.com/a-/AAuE7mD1UTwiIjcHi479UROSg1X6rOGjkm4OniwszUsteg", - "settings": "{\"num\":4616,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10980392156862745,0.16470588235294117,0.22745098039215686,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount/down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x*y*0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * 0.1 + sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = 1.0;\\n float val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 4616, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10980392156862745, + 0.16470588235294117, + 0.22745098039215686, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount/down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x*y*0.02) * 5.0;\n \n gl_PointSize = 10.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * 0.1 + sin(time * 1.3 + v * 20.) * 0.05;\n float sat = 1.0;\n float val = sin(time * 1.4 + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-ukesxa3t1qakkeb4j-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vZtNQowy822RZj6gP/art.json b/art/vZtNQowy822RZj6gP/art.json index 0161958d..67f228eb 100644 --- a/art/vZtNQowy822RZj6gP/art.json +++ b/art/vZtNQowy822RZj6gP/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_POINTS\\n//KVerticesNumber=100000\\n#define parameter0 5.//KParameter0 -15.>>20.\\n#define parameter1 5.//KParameter1 -15.>>20.\\n#define parameter2 2.//KParameter2 -1.>>5.\\n#define PI radians(180.)\\n\\nmat4 scale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n\\n 0, 0, 0, 1);\\n}\\n\\nvoid main() {\\n float segmentsPerCircle = 16.0;\\n float vertsPerSegment = 6.1;\\n \\n // set base vert pos\\n float bx = mod(vertexId, 2.2) + floor(vertexId / 6.4);\\n float by = mod(floor(vertexId / 2.3) + floor(vertexId / 3.5), 2.6);\\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\\n \\n // offset circles\\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\\n float circlesPerRow = 45.7;\\n float circlesPerColumn = floor(circleCount / circlesPerRow);\\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\\n float cx = mod(circleId, circlesPerRow);\\n float cy = floor(circleId / circlesPerRow);\\n \\n float sx = cx - circlesPerRow * 8.5;\\n float sy = cy - circlesPerColumn * 9.5; //cy - circlesPerColumn * 0.5;\\n vec2 soundTexCoords0 = vec2(10, 1);\\n float soundXTimeOffset = 2.3; //sin(time) * 0.015625;\\n float beatwave =\\n ( 1.4 - abs( sin( time ) ) - 1.5 ) * sign( sin( time * 6.5 ) );\\n float sampleRange = beatwave * 7.25 + 8.125;\\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 9.5) * sampleRange;\\n float maxRadius = sqrt(pow(circlesPerRow * 10.5, 2.10) + pow(circlesPerColumn * 0.5, 2.));\\n // lets pretend the max radius is actually a little longer.\\n maxRadius *= 1.5;\\n float historyDepth = 0.625;\\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\\n soundTexCoords0.y = currentRadius * historyDepth;\\n vec2 soundTexCoords1 = soundTexCoords0;\\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\\n float outgoingR = texture2D(sound, soundTexCoords0).a;\\n float r = outgoingR;\\n r = r * (1.2 + soundTexCoords0.x) + 0.1;\\n r = pow(r, 5.3);\\n float radius = by * r;\\n float x = cos(angle) * radius;\\n float y = sin(angle) * radius;\\n \\n gl_Position = vec4(x, y, -r / 2.4, 1);\\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\\n \\n // scale\\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\\n \\n // fix aspect\\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\\n gl_Position *= aspect;\\n \\n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.5) * 0.5 + 0.5);\\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\\n \\n gl_PointSize = 4.6 * r * parameter2;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/griffinmcelroy/wonderland-round-three?in=griffinmcelroy/sets/the-adventure-zone-ost", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_POINTS\n//KVerticesNumber=100000\n#define parameter0 5.//KParameter0 -15.>>20.\n#define parameter1 5.//KParameter1 -15.>>20.\n#define parameter2 2.//KParameter2 -1.>>5.\n#define PI radians(180.)\n\nmat4 scale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n\n 0, 0, 0, 1);\n}\n\nvoid main() {\n float segmentsPerCircle = 16.0;\n float vertsPerSegment = 6.1;\n \n // set base vert pos\n float bx = mod(vertexId, 2.2) + floor(vertexId / 6.4);\n float by = mod(floor(vertexId / 2.3) + floor(vertexId / 3.5), 2.6);\n float angle = mod(bx, segmentsPerCircle) / segmentsPerCircle * 2. * PI;\n \n // offset circles\n float circleCount = vertexCount / (segmentsPerCircle * vertsPerSegment);\n float circlesPerRow = 45.7;\n float circlesPerColumn = floor(circleCount / circlesPerRow);\n float circleId = floor(vertexId / (segmentsPerCircle * vertsPerSegment));\n float cx = mod(circleId, circlesPerRow);\n float cy = floor(circleId / circlesPerRow);\n \n float sx = cx - circlesPerRow * 8.5;\n float sy = cy - circlesPerColumn * 9.5; //cy - circlesPerColumn * 0.5;\n vec2 soundTexCoords0 = vec2(10, 1);\n float soundXTimeOffset = 2.3; //sin(time) * 0.015625;\n float beatwave =\n ( 1.4 - abs( sin( time ) ) - 1.5 ) * sign( sin( time * 6.5 ) );\n float sampleRange = beatwave * 7.25 + 8.125;\n soundTexCoords0.x = abs(atan(sx / sy)) / (PI * 9.5) * sampleRange;\n float maxRadius = sqrt(pow(circlesPerRow * 10.5, 2.10) + pow(circlesPerColumn * 0.5, 2.));\n // lets pretend the max radius is actually a little longer.\n maxRadius *= 1.5;\n float historyDepth = 0.625;\n float currentRadius = sqrt(pow(sx, 2.) + pow(sy, 2.)) / maxRadius;\n soundTexCoords0.y = currentRadius * historyDepth;\n vec2 soundTexCoords1 = soundTexCoords0;\n soundTexCoords1.y = historyDepth - soundTexCoords0.y + historyDepth;\n float outgoingR = texture2D(sound, soundTexCoords0).a;\n float r = outgoingR;\n r = r * (1.2 + soundTexCoords0.x) + 0.1;\n r = pow(r, 5.3);\n float radius = by * r;\n float x = cos(angle) * radius;\n float y = sin(angle) * radius;\n \n gl_Position = vec4(x, y, -r / 2.4, 1);\n gl_Position += vec4(cx - circlesPerRow * 0.5, cy - circlesPerColumn * 0.5, 0, 0);\n \n // scale\n gl_Position *= scale((1. - r) / (6. + parameter1) / x * y);\n \n // fix aspect\n vec4 aspect = vec4(resolution.y / resolution.x, 1, 1, 1);\n gl_Position *= aspect;\n \n float g = (sin((abs(sx) + abs(sy)) * 0.25 - time * 8.5) * 0.5 + 0.5);\n v_color = vec4(r * 2. - 0.5, g, 1, 1);\n \n gl_PointSize = 4.6 * r * parameter2;\n}" + }, "screenshotURL": "data/images/images-alpgrc6ll3b4pms99-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vbumqNjcawaLjdiM8/art.json b/art/vbumqNjcawaLjdiM8/art.json index cb50afb7..b5eab02e 100644 --- a/art/vbumqNjcawaLjdiM8/art.json +++ b/art/vbumqNjcawaLjdiM8/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":12004,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/plu-collective/circuitry\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Lesson 05\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegements) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / 20. * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n \\n return vec2(x, y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId,\\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float CircleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(CircleId, across);\\n float y = floor(CircleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .09, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.1 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 12004, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/plu-collective/circuitry", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Lesson 05\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegements) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / 20. * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n \n return vec2(x, y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId,\n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float CircleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(CircleId, across);\n float y = floor(CircleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .09, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.1 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-v475hvb2oujw62ogz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vcYrT69DDanvyFBTr/art.json b/art/vcYrT69DDanvyFBTr/art.json index 74101221..3dfd7650 100644 --- a/art/vcYrT69DDanvyFBTr/art.json +++ b/art/vcYrT69DDanvyFBTr/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Garden Fireworks - @P_Malin\\n// Playing with motion blurred hexagonal bokeh\\n\\n#define SHAKY_CAM\\n\\nfloat Cross( const in vec2 A, const in vec2 B )\\n{\\n return A.x * B.y - A.y * B.x;\\n}\\n\\nvoid GetTriInfo( const float vertexIndex, out vec2 triVertId, out float triId )\\n{\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( triVertexIndex < 0.5 ) \\ttriVertId = vec2( 0.0, 0.0 );\\n else if\\t( triVertexIndex < 1.5 )\\ttriVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\ttriVertId = vec2( 0.0, 1.0 );\\n\\n triId = floor( vertexIndex / 3.0 );\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nmat3 RotMatrixX( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( 1.0, 0.0, 0.0, \\n 0.0, c, s,\\n 0.0, -s, c ); \\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat Hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\nvec3 Hash3(float p)\\n{\\n vec3 p3 = fract(vec3(p) * MOD3);\\n p3 += dot(p3, p3.yzx + 19.19);\\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\\n}\\n\\nvec3 Hash32(vec2 p)\\n{\\n\\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\\n p3 += dot(p3, p3.yxz+19.19);\\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\\n}\\n\\n\\nvec3 Noise23( vec2 p )\\n{\\n\\tvec2 fl = floor(p);\\n\\n\\tvec3 h00 = Hash32( fl + vec2( 0.0, 0.0 ) );\\n\\tvec3 h10 = Hash32( fl + vec2( 1.0, 0.0 ) );\\n\\tvec3 h01 = Hash32( fl + vec2( 0.0, 1.0 ) );\\n\\tvec3 h11 = Hash32( fl + vec2( 1.0, 1.0 ) );\\n\\n\\tvec2 fr = p - fl;\\n\\t\\n\\tvec2 fr2 = fr * fr;\\n\\tvec2 fr3 = fr2 * fr;\\n\\t\\n\\tvec2 t1 = 3.0 * fr2 - 2.0 * fr3;\\t\\n\\tvec2 t0 = 1.0 - t1;\\n\\t\\n\\treturn h00 * t0.x * t0.y\\n\\t\\t + h10 * t1.x * t0.y\\n\\t\\t + h01 * t0.x * t1.y\\n\\t\\t + h11 * t1.x * t1.y;\\n}\\n\\nstruct CameraSettings\\n{\\n float fAperture;\\n float fFocalLength;\\n float fPlaneInFocus; \\n float fExposure;\\n};\\n\\nstruct CameraPosition\\n{\\n \\tvec3 vPosition;\\n \\tvec3 vTarget;\\n \\tvec3 vUp;\\n \\n \\tmat3 mRotation;\\n};\\n \\nstruct OutVertex\\n{\\n \\tvec2 vPos;\\n \\tvec3 vColor;\\n}; \\n \\n#define HEXAGON_OUTLINE_VERTEX_COUNT \\t6.0 * (6.0 + 2.0)\\n\\nvoid GetHexagonOutlineVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r0, const float r1, const vec3 col0, const vec3 col1, inout OutVertex vertex )\\n{\\n \\tfloat fAngleOffset = settings.fAperture * 0.5;\\n \\n \\tif ( fVertexIndex < 6.0 * 6.0 ) \\n {\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndex, vQuadVertId, fQuadId );\\n\\n float fIndex = fQuadId + vQuadVertId.x;\\n\\n float fAngle = fIndex * radians(360.0) / 6.0;\\n\\n float fRadius = mix( r0, r1, vQuadVertId.y);\\n\\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\\n\\n float fCurrIndex = fQuadId;\\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\\n\\n float fNextIndex = fQuadId + 1.0;\\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\\n\\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\\n {\\n vPos += vDir;\\n }\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n else\\n {\\n\\t float fVertexIndexB = fVertexIndex - 6.0 * 6.0;\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\\n \\n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\\n \\n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\\n \\n if ( fQuadId > 0.0 )\\n {\\n\\t\\tfEdgeAngle += radians( 180.0 );\\n }\\n \\n float fRadius = mix( r0, r1, vQuadVertId.y);\\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\\n vPos += vDir * vQuadVertId.x;\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n}\\n \\n#define HEXAGON_VERTEX_COUNT (6.0 * 3.0 + 6.0 * 2.0)\\nvoid GetHexagonVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r, const vec3 col0, const vec3 col1, inout OutVertex vertex )\\n{\\n \\tfloat fAngleOffset = settings.fAperture * 0.5;\\n \\n \\tif ( fVertexIndex < 6.0 * 3.0 ) \\n {\\n float fTriId;\\n\\n vec2 vTriVertId;\\n GetTriInfo( fVertexIndex, vTriVertId, fTriId );\\n\\n float fIndex = fTriId + vTriVertId.x;\\n\\n float fAngle = fIndex * radians(360.0) / 6.0;\\n\\n float fRadius = vTriVertId.y * r;\\n\\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\\n\\n float fCurrIndex = fTriId;\\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\\n\\n float fNextIndex = fTriId + 1.0;\\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\\n\\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\\n {\\n vPos += vDir;\\n }\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vTriVertId.y );\\n }\\n else\\n {\\n\\t float fVertexIndexB = fVertexIndex - 6.0 * 3.0;\\n float fQuadId;\\n\\n vec2 vQuadVertId;\\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\\n \\n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\\n \\n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\\n \\n if ( fQuadId > 0.0 )\\n {\\n\\t\\tfEdgeAngle += radians( 180.0 );\\n }\\n \\n float fRadius = vQuadVertId.y * r;\\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\\n vPos += vDir * vQuadVertId.x;\\n\\n vertex.vPos.xy = vOrigin + vPos;\\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\\n }\\n}\\n\\n\\n#define BOKEH_VERTEX_COUNT ( HEXAGON_VERTEX_COUNT + HEXAGON_OUTLINE_VERTEX_COUNT ) \\nvoid GetBokehVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float fSize, const float fCoC, const vec3 vCol, out OutVertex vertex )\\n{\\n \\tfloat fInnerSize = fSize + fCoC;\\n \\tfloat fGlowSize = 0.02;\\n \\tfloat fOuterSize = fInnerSize + fGlowSize;\\n \\n \\tif ( fVertexIndex < HEXAGON_VERTEX_COUNT )\\n {\\n \\t\\tGetHexagonVertex( settings, fVertexIndex, vOrigin, vDir, fInnerSize, vCol, vCol, vertex );\\n }\\n \\telse\\n {\\n\\t \\tvec3 vGlowCol = pow(vCol, vec3(0.5)) * 0.0001; \\n \\tif ( length( vGlowCol ) > 0.0000001 )\\n {\\n \\t\\t\\tGetHexagonOutlineVertex( settings, fVertexIndex - HEXAGON_VERTEX_COUNT, vOrigin, vDir, fInnerSize, fOuterSize, vGlowCol, vCol * 0.0, vertex );\\n }\\n else\\n {\\n \\tvertex.vPos.xy = vec2(0.0);\\n \\tvertex.vColor.rgb = vec3(0.0);\\n }\\n }\\n}\\n\\nfloat GetCoC( CameraSettings settings, float objectdistance )\\n{\\n // http://http.developer.nvidia.com/GPUGems/gpugems_ch23.html\\n\\n\\treturn abs(settings.fAperture * (settings.fFocalLength * (objectdistance - settings.fPlaneInFocus)) /\\n (objectdistance * (settings.fPlaneInFocus - settings.fFocalLength))); \\n}\\n\\n\\nvec3 GetViewPos( CameraSettings settings, CameraPosition cameraPos, vec3 vWorldPos )\\n{\\n \\treturn (vWorldPos - cameraPos.vPosition) * cameraPos.mRotation;\\n}\\n\\nvec2 GetScreenPos( CameraSettings settings, vec3 vViewPos )\\n{ \\n \\treturn vViewPos.xy * settings.fFocalLength * 5.0 / vViewPos.z;\\n}\\n\\nCameraSettings GetCameraSettings( CameraPosition cameraPosition )\\n{\\n \\tCameraSettings settings;\\n \\n \\tfloat aVal = sin(time * 0.25) * 0.5 + 0.5;\\n \\taVal = aVal * aVal;\\n \\tsettings.fAperture = aVal * 2.9 + 0.1;\\n \\tfloat fVal = sin(time * 0.123) * 0.5 + 0.5;\\n \\tsettings.fFocalLength = 0.2 + 0.2 * fVal;\\n \\tsettings.fPlaneInFocus = length(cameraPosition.vTarget - cameraPosition.vPosition);\\n \\n \\tfloat oldAVal = sin((time - 0.5) * 0.25) * 0.5 + 0.5;\\n \\toldAVal = oldAVal * oldAVal;\\n \\n\\tsettings.fExposure = 3.0 + oldAVal *3.0;\\n\\n \\treturn settings;\\n}\\n\\nstruct LightInfo\\n{\\n\\tvec3 vWorldPos;\\n \\tfloat fRadius;\\n \\tvec3 vColor;\\n};\\n \\n \\nvec2 SolveQuadratic( float a, float b, float c )\\n{\\n float d = sqrt( b * b - 4.0 * a * c );\\n vec2 dV = vec2( d, -d );\\n return (-b + dV) / (2.0 * a);\\n}\\n\\n\\nvec3 BounceParticle( vec3 vOrigin, vec3 vInitialVel, float fGravity, float fFloorHeight, float fTime )\\n{\\n \\tvec3 u = vInitialVel;\\n \\tvec3 a = vec3(0.0, fGravity, 0.0);\\n \\tvec3 vPos = vOrigin;\\n\\n \\tfloat t = fTime;\\n \\t \\t\\n \\tfor( int iBounce=0; iBounce < 3; iBounce++)\\n {\\n // When will we hit the ground?\\n vec2 q = SolveQuadratic( 0.5 * a.y, u.y, -fFloorHeight + vPos.y);\\n float tInt = max( q.x, q.y );\\n tInt -= 0.0001;\\n \\n\\n if ( t < tInt )\\n {\\n\\t vPos += u * t + 0.5 * a * t * t;\\n break;\\n }\\n else\\n { \\n // Calculate velocity at intersect time\\n vec3 v = u + a * tInt;\\n\\n // step to intersect time\\n vPos += u * tInt + 0.5 * a * tInt * tInt;\\n \\t u = v;\\n \\n // bounce\\n u.y = -u.y * 0.3;\\n u.xz *= 0.6;\\n\\n t -= tInt;\\n }\\n }\\n\\n \\treturn vPos;\\n}\\n\\nfloat fFloorHeight = 0.0;\\n\\nLightInfo Fountain( const in float fLightIndex, const in vec3 vPos, float fTime, vec3 vCol, float fSpread )\\n{\\n float fParticleLifetime = 1.5;\\n \\tLightInfo lightInfo;\\n \\n \\tfloat h = Hash( fLightIndex + 12.0 );\\n \\tvec3 h3 = Hash3( fLightIndex + 13.0 );\\n \\n \\tfloat fAngle = fLightIndex;\\n \\n \\tvec3 vInitialVel = (normalize(h3 * 2.0 - 1.0) * fSpread + vec3( 0.0, 10.0 - fSpread * 1.3, 0.0 )) * (0.4 + h * 0.4);\\n \\tvec3 vOrigin = vPos + vec3( 0.0, fFloorHeight + 0.1, 0.0 ) + vInitialVel * 0.1;\\n \\tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fTime );\\n\\n \\n \\tlightInfo.fRadius = 0.01; \\n// \\tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\\n \\tlightInfo.vColor = vCol;\\n \\tlightInfo.vColor *= clamp( 1.0 - fTime + fParticleLifetime - 1.0, 0.0, 1.0);\\n\\treturn lightInfo; \\n}\\n\\nLightInfo CatherineWheel( const in float fLightIndex, const in vec3 vPos, float fSequenceStart, float fSpawnTime, float fParticleT, vec3 vCol )\\n{\\n \\tfloat h = Hash( fLightIndex + 4.0 );\\n\\n\\t float fParticleLifetime = 0.3 + h *0.5;\\n \\tLightInfo lightInfo;\\n\\n \\tvec3 h3 = Hash3( fLightIndex + 12.0 );\\n \\tfloat t = fSpawnTime - fSequenceStart;\\n \\tif( t < 5.0 ) t = t * t;\\n \\telse t = t * 5.0 + 5.0 * 5.0;\\n \\t\\n \\tfloat fSpawnAngle = t * 5.0;\\n \\n \\tif ( h > 0.5 )\\n {\\n fSpawnAngle += radians( 180.0 );\\n }\\n \\n \\tmat3 m = RotMatrixZ(fSpawnAngle);\\n \\n \\tvec3 vInitialVel = vec3(-3.0, 0.0, 0.0 ) + h3 * 0.5;\\n \\tvInitialVel = vInitialVel * m;\\n \\tvec3 vOffset = vec3( 0.0, 0.03, 0.0 * m);\\n \\tvec3 vOrigin = vPos + vOffset + vInitialVel * 0.1;\\n \\tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fParticleT );\\n\\n \\n \\tlightInfo.fRadius = 0.01; \\n// \\tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\\n \\tlightInfo.vColor = vCol;\\n \\tlightInfo.vColor *= clamp( 1.0 - fParticleT + fParticleLifetime - 1.0, 0.0, 1.0);\\n\\treturn lightInfo; \\n}\\n\\n\\nstruct SequenceInfo\\n{\\n \\tfloat fSequenceSet;\\n \\tfloat fSequenceSetLength;\\n \\n \\tfloat fSequenceIndex;\\n \\tfloat fSequenceStartTime;\\n \\n \\tfloat fSequenceSeed;\\n \\tvec3 vSequenceHash;\\n \\n \\tvec3 vCol;\\n \\n \\tfloat fType;\\n \\tvec3 vPos;\\n \\tvec3 vTarget;\\n};\\n \\nSequenceInfo GetSequenceInfo( float fSetIndex, float fTime )\\n{\\n \\tSequenceInfo sequenceInfo;\\n\\n \\t\\tfloat fSequenceSetCount = 2.0;\\n \\tsequenceInfo.fSequenceSet = mod(fSetIndex, fSequenceSetCount);\\n\\n \\t\\tfloat sh = Hash( sequenceInfo.fSequenceSet );\\n \\t\\tfloat fSequenceSetLength = 10.0 + sh * 5.0;\\n \\n\\n \\t\\tsequenceInfo.fSequenceIndex = floor( fTime / fSequenceSetLength );\\n \\t\\tsequenceInfo.fSequenceStartTime = (sequenceInfo.fSequenceIndex * fSequenceSetLength);\\n \\n \\t\\tsequenceInfo.fSequenceSeed = sequenceInfo.fSequenceIndex + sequenceInfo.fSequenceSet * 12.3;\\n \\t\\tsequenceInfo.vSequenceHash = Hash3(sequenceInfo.fSequenceSeed);\\n\\n \\t\\tfloat ch = Hash( sequenceInfo.fSequenceSeed * 2.34 );\\n \\t\\tsequenceInfo.vCol = vec3(1.0, 0.4, 0.1);\\n \\n \\t\\tif( ch < 0.25 )\\n {\\n sequenceInfo.vCol = vec3(1.0, 0.08, 0.08);\\n }\\n \\t\\telse if( ch < 0.5 )\\n {\\n sequenceInfo.vCol = vec3(0.08, 0.08, 1.0);\\n }\\n \\t\\telse if( ch < 0.75 )\\n {\\n sequenceInfo.vCol = vec3(0.08, 1.0, 0.08 );\\n }\\n \\n \\n \\tif ( sequenceInfo.vSequenceHash.x < 0.7)\\n {\\n \\t\\t\\tsequenceInfo.vPos = vec3(0.0);\\n\\t \\t\\tsequenceInfo.vPos.xz = sequenceInfo.vSequenceHash.yz * 6.0 - 3.0;\\n\\t \\t\\tsequenceInfo.fType = 0.0;\\n \\tsequenceInfo.vTarget = sequenceInfo.vPos;\\n \\tsequenceInfo.vTarget.y = 1.5;\\n }\\n \\t\\telse\\n {\\n \\tsequenceInfo.vPos = vec3(0.0, 2.5, 7.0);\\n\\t \\t\\tsequenceInfo.vPos += (sequenceInfo.vSequenceHash.xyz * 2.0 - 1.0) * vec3(5.0, 1.5, 3.0);\\n\\t \\t\\tsequenceInfo.fType = 1.0;\\n \\tsequenceInfo.vTarget = sequenceInfo.vPos;\\n } \\n \\n \\treturn sequenceInfo;\\n}\\n\\nLightInfo GetFireworkSparkInfo( in float fLightIndex, float fTime, float fDeltaTime, vec3 h3 )\\n{ \\n\\t float fParticleLifetime = 1.5;\\n \\tfloat fParticleSpawnTime = (floor( (fTime / fParticleLifetime) + h3.x) - h3.x) * fParticleLifetime;\\n \\tfloat fParticleEndTime = fParticleSpawnTime + fParticleLifetime;\\n \\tfloat fParticleGlobalT = fTime - fParticleSpawnTime;\\n \\tfloat fParticleT = mod( fParticleGlobalT, fParticleLifetime ) + fDeltaTime;\\n \\n \\t\\tSequenceInfo sequenceInfo = GetSequenceInfo( fLightIndex, fParticleSpawnTime );\\n \\n \\tLightInfo lightInfo;\\n \\n \\t\\tif ( sequenceInfo.fType < 0.5)\\n {\\n \\tfloat fSpread = fract( sequenceInfo.vSequenceHash.z + sequenceInfo.vSequenceHash.y ) + 1.0;\\n\\t \\t\\tlightInfo = Fountain( fLightIndex, sequenceInfo.vPos, fParticleT, sequenceInfo.vCol, fSpread );\\n }\\n \\t\\telse\\n {\\n \\tlightInfo = CatherineWheel( fLightIndex, sequenceInfo.vPos, sequenceInfo.fSequenceStartTime, fParticleSpawnTime, fParticleT, sequenceInfo.vCol );\\n } \\n \\n return lightInfo; \\n}\\n\\nLightInfo GetLightInfo( const in float fLightIndex, float fTime, float fDeltaTime, CameraPosition cameraPos )\\n{\\n \\tLightInfo lightInfo;\\n\\n \\t//float h = Hash( fLightIndex );\\n \\tvec3 h3 = Hash3(fLightIndex);\\n\\n \\tfloat kHangingLightCount = 32.0;\\n \\tfloat kHangingLightMax = 0.0 + kHangingLightCount;\\n \\n \\tfloat kStarCount = 0.0;\\n \\tfloat kStarMax = kHangingLightMax + kStarCount;\\n \\t\\n \\tfloat kDirtCount = 16.0;\\n \\tfloat kDirtMax = kStarMax + kDirtCount;\\n\\n \\tfloat kStreetLightCount = 64.0;\\n \\tfloat kStreetLightMax = kDirtMax + kStreetLightCount;\\n \\n \\tfloat kGardenLightCount = 16.0;\\n \\tfloat kGardenLightMax = kStreetLightMax + kGardenLightCount;\\n\\n \\tif( fLightIndex < kHangingLightMax )\\n \\t{\\n \\t// hanging lights\\n \\tlightInfo.vWorldPos.x = ((fLightIndex / 10.0) * 2.0 - 1.0) * 3.0;\\n \\tlightInfo.vWorldPos.y = 2.0 + -abs( cos( fLightIndex * 0.4 ) * 0.8 ); \\n \\tlightInfo.vWorldPos.z = 20.0;\\n \\t\\tlightInfo.vColor = vec3(0.01) * 0.5;\\n \\tfloat fColIndex = mod(fLightIndex, 3.0);\\n \\tif ( fColIndex == 0.0 ) lightInfo.vColor.x = 1.0;\\n \\tif ( fColIndex == 1.0 ) lightInfo.vColor.y = 1.0;\\n \\tif ( fColIndex == 2.0 ) lightInfo.vColor.z = 1.0;\\n\\t lightInfo.vColor *= 0.05;\\n \\t\\t//lightInfo.vColor = normalize(vec3(sin(fLightIndex) * .5 + 0.5, sin(fLightIndex * 3.45) * .5 + 0.5, sin(fLightIndex * 4.56) * .5 + 0.5)) * 0.5;\\n \\n \\t\\tlightInfo.fRadius = 0.05;\\n\\t}\\n \\telse\\n \\tif( fLightIndex < kStarMax )\\n \\t{\\n // stars\\n \\tlightInfo.vWorldPos = normalize( h3 * 2.0 - 1.0 ) * 5000.0;\\n \\tlightInfo.vWorldPos.y = abs(lightInfo.vWorldPos.y);\\n \\t\\tlightInfo.vColor = vec3(0.01);\\n \\t\\tlightInfo.fRadius = 0.001;\\n }\\n \\telse\\n \\tif( fLightIndex < kDirtMax )\\n \\t{\\n // lens dirt\\n \\tlightInfo.vWorldPos.xy = (Hash3(fLightIndex).xy * 2.0 - 1.0);\\n \\tlightInfo.vWorldPos.xy = normalize(lightInfo.vWorldPos.xy) * pow( length(lightInfo.vWorldPos.xy), 0.3 ) * 0.35;\\n\\t lightInfo.vWorldPos.y *= resolution.y / resolution.x;\\n \\tlightInfo.vWorldPos.z = 0.3;\\n \\tvec3 vOffset = cameraPos.mRotation * lightInfo.vWorldPos;\\n \\tlightInfo.vWorldPos = vOffset + cameraPos.vPosition;\\n \\t\\tlightInfo.vColor = vec3(0.2, 0.18, 0.1) * abs( dot(normalize(vOffset), vec3(0.0, 0.0, 1.0)) ) * 1.0;\\n \\t\\tlightInfo.fRadius = 0.0001;\\n }\\n \\telse\\n // street lights\\n \\tif( fLightIndex < kStreetLightMax )\\n \\t{\\n \\tlightInfo.vWorldPos.xz = (h3.xy * 2.0 - 1.0) * 500.0;\\n \\tlightInfo.vWorldPos.y = 10.0; \\n \\t\\tlightInfo.vColor = vec3(1.0, 0.3, 0.01) * 0.5;\\n \\n \\t\\tlightInfo.fRadius = 0.2;\\n\\t}\\n \\telse if( fLightIndex < kGardenLightMax )\\n \\t{\\n \\tlightInfo.vWorldPos.y = 0.05 + h3.y * 0.5; \\n \\tvec2 vOffset = (h3.xz * 2.0 - 1.0);\\n \\tlightInfo.vWorldPos.xz = vOffset * 50.0 + normalize( vOffset ) * 10.0;\\n \\t\\tlightInfo.vColor = sin(h3 * 10.0 + vec3(0.1, 0.2, 0.3)) * 0.5 + 0.5;\\n \\tlightInfo.vColor = normalize(lightInfo.vColor);\\n\\t lightInfo.vColor *= 0.005;\\n \\n \\t\\tlightInfo.fRadius = 0.05;\\n\\t}\\n \\telse\\n {\\n \\tlightInfo = GetFireworkSparkInfo( fLightIndex, fTime, fDeltaTime, h3 );\\n }\\n \\n\\n \\treturn lightInfo;\\n}\\n\\n\\nvec3 GetCameraTarget( float fTime )\\n{\\n \\t//return vec3(0.0, 1.8, 0.0);\\n\\n \\tfloat fInterval = 8.0;\\n \\n \\tfloat t0 = floor(fTime / fInterval) * fInterval; \\n \\tfloat t1 = (floor(fTime / fInterval+ 1.0) ) * fInterval; \\n \\n \\tSequenceInfo inf0 = GetSequenceInfo( 0.0, t0 );\\n \\tSequenceInfo inf1 = GetSequenceInfo( 0.0, t1 );\\n \\n \\tfloat fBlend = (fTime - t0) / fInterval;\\n \\n \\tfBlend = smoothstep( 0.0, 1.0, fBlend);\\n \\n \\treturn mix( inf0.vTarget, inf1.vTarget, fBlend );\\n}\\n\\nCameraPosition GetCameraPosition( float fTime, vec2 vTouch )\\n{\\n \\tCameraPosition cameraPos;\\n \\n \\tif( (vTouch.y > 0.9) && (vTouch.x > -0.83) && (vTouch.x < -0.80) )\\n {\\t\\n \\tvTouch.xy = vec2(0.0);\\n }\\n \\n \\tcameraPos.vTarget = GetCameraTarget( fTime );\\n \\n \\tcameraPos.vPosition += cameraPos.vTarget;\\n \\t\\n \\tcameraPos.vPosition = vec3( sin(fTime * 0.2) * 5.0, 2.0, -6.0 + sin(fTime * 0.0567) * 3.0);\\n \\tcameraPos.vUp = vec3( 0.0, 1.0, 0.0 );\\n \\n \\tGetMatrixFromZY( normalize(cameraPos.vTarget - cameraPos.vPosition), cameraPos.vUp, cameraPos.mRotation );\\n \\n \\tvec3 vRot = vec3( vTouch.y * 0.5, vTouch.x * 0.5, 0.0 );\\n \\n#ifdef SHAKY_CAM\\n\\tvRot += Noise23( cameraPos.vPosition.xz * 4.0 ) * vec3( 0.05, 0.03, 0.01 ); //shaky cam\\n#endif\\n \\n \\tcameraPos.mRotation = cameraPos.mRotation * RotMatrixZ(vRot.z) * RotMatrixY(vRot.y) * RotMatrixX( vRot.x ) ; \\n \\n \\treturn cameraPos;\\n}\\n\\nvoid main() \\n{\\n float fVertexIndex = vertexId;\\n\\n vec4 touch1 = texture2D(touch, vec2(0.0, 0.0));\\n vec4 touch2 = texture2D(touch, vec2(0.0, 0.01)); \\n\\n\\tfloat fShutterSpeed = 1.0 / 60.0;\\n \\n CameraPosition cameraPos = GetCameraPosition( time, touch1.xy );\\n CameraPosition lastCameraPos = GetCameraPosition( time - fShutterSpeed, touch2.xy );\\n\\n CameraSettings cameraSettings = GetCameraSettings( cameraPos );\\n\\n OutVertex vertex;\\n\\n float fBokehIndex = floor( fVertexIndex / BOKEH_VERTEX_COUNT );\\n \\n LightInfo lightInfo = GetLightInfo( fBokehIndex, time, 0.0, cameraPos );\\n LightInfo prevLightInfo = GetLightInfo( fBokehIndex, time, -fShutterSpeed, lastCameraPos );\\n \\n vec3 vViewPos = GetViewPos( cameraSettings, cameraPos, lightInfo.vWorldPos );\\n vec3 vLastViewPos = GetViewPos( cameraSettings, lastCameraPos, prevLightInfo.vWorldPos );\\n\\n vec2 vScreenPos = GetScreenPos( cameraSettings, vViewPos );\\n vec2 vLastScreenPos = GetScreenPos( cameraSettings, vLastViewPos ); \\n\\n float fScreenSize = GetScreenPos( cameraSettings, vec3( lightInfo.fRadius, lightInfo.fRadius, vViewPos.z ) ).x;\\n \\n vec2 vOrigin = vScreenPos.xy;\\n vec2 vDir = vLastScreenPos.xy - vScreenPos.xy;\\n \\n float fCoC = GetCoC( cameraSettings, vViewPos.z );\\n\\n vec3 vCol = lightInfo.vColor;\\n\\n float fSize = fCoC + fScreenSize;\\n vCol *= fScreenSize * fScreenSize * 3.14 / (length( vDir ) * fSize + fSize * fSize * 3.14);\\n \\n float fBokehVertexIndex = mod( fVertexIndex, BOKEH_VERTEX_COUNT );\\n GetBokehVertex( cameraSettings, fBokehVertexIndex, vOrigin, vDir, fScreenSize, fCoC, vCol, vertex );\\n \\n vertex.vPos.y *= resolution.x / resolution.y;\\n \\n gl_Position = vec4(vertex.vPos.x, vertex.vPos.y, 1.0 / vertexId, 1);\\n float fFinalExposure = cameraSettings.fExposure / (cameraSettings.fAperture * cameraSettings.fAperture);\\n v_color.rgb = 1.0 - exp2( vertex.vColor * -fFinalExposure );\\n v_color.rgb = pow( v_color.rgb, vec3(1.0 / 2.2) );\\n v_color.a = 0.0;\\n \\n float fNearClip = 0.25;\\n if ( vViewPos.z <= fNearClip || vLastViewPos.z <= fNearClip)\\n {\\n gl_Position = vec4(0.0);\\n v_color = vec4(0.0);\\n }\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Garden Fireworks - @P_Malin\n// Playing with motion blurred hexagonal bokeh\n\n#define SHAKY_CAM\n\nfloat Cross( const in vec2 A, const in vec2 B )\n{\n return A.x * B.y - A.y * B.x;\n}\n\nvoid GetTriInfo( const float vertexIndex, out vec2 triVertId, out float triId )\n{\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( triVertexIndex < 0.5 ) \ttriVertId = vec2( 0.0, 0.0 );\n else if\t( triVertexIndex < 1.5 )\ttriVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\ttriVertId = vec2( 0.0, 1.0 );\n\n triId = floor( vertexIndex / 3.0 );\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nmat3 RotMatrixX( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( 1.0, 0.0, 0.0, \n 0.0, c, s,\n 0.0, -s, c ); \n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat Hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\nvec3 Hash3(float p)\n{\n vec3 p3 = fract(vec3(p) * MOD3);\n p3 += dot(p3, p3.yzx + 19.19);\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\n}\n\nvec3 Hash32(vec2 p)\n{\n\tvec3 p3 = fract(vec3(p.xyx) * MOD3);\n p3 += dot(p3, p3.yxz+19.19);\n return fract(vec3((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y, (p3.y+p3.z)*p3.x));\n}\n\n\nvec3 Noise23( vec2 p )\n{\n\tvec2 fl = floor(p);\n\n\tvec3 h00 = Hash32( fl + vec2( 0.0, 0.0 ) );\n\tvec3 h10 = Hash32( fl + vec2( 1.0, 0.0 ) );\n\tvec3 h01 = Hash32( fl + vec2( 0.0, 1.0 ) );\n\tvec3 h11 = Hash32( fl + vec2( 1.0, 1.0 ) );\n\n\tvec2 fr = p - fl;\n\t\n\tvec2 fr2 = fr * fr;\n\tvec2 fr3 = fr2 * fr;\n\t\n\tvec2 t1 = 3.0 * fr2 - 2.0 * fr3;\t\n\tvec2 t0 = 1.0 - t1;\n\t\n\treturn h00 * t0.x * t0.y\n\t\t + h10 * t1.x * t0.y\n\t\t + h01 * t0.x * t1.y\n\t\t + h11 * t1.x * t1.y;\n}\n\nstruct CameraSettings\n{\n float fAperture;\n float fFocalLength;\n float fPlaneInFocus; \n float fExposure;\n};\n\nstruct CameraPosition\n{\n \tvec3 vPosition;\n \tvec3 vTarget;\n \tvec3 vUp;\n \n \tmat3 mRotation;\n};\n \nstruct OutVertex\n{\n \tvec2 vPos;\n \tvec3 vColor;\n}; \n \n#define HEXAGON_OUTLINE_VERTEX_COUNT \t6.0 * (6.0 + 2.0)\n\nvoid GetHexagonOutlineVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r0, const float r1, const vec3 col0, const vec3 col1, inout OutVertex vertex )\n{\n \tfloat fAngleOffset = settings.fAperture * 0.5;\n \n \tif ( fVertexIndex < 6.0 * 6.0 ) \n {\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndex, vQuadVertId, fQuadId );\n\n float fIndex = fQuadId + vQuadVertId.x;\n\n float fAngle = fIndex * radians(360.0) / 6.0;\n\n float fRadius = mix( r0, r1, vQuadVertId.y);\n\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\n\n float fCurrIndex = fQuadId;\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\n\n float fNextIndex = fQuadId + 1.0;\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\n\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\n {\n vPos += vDir;\n }\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n else\n {\n\t float fVertexIndexB = fVertexIndex - 6.0 * 6.0;\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\n \n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\n \n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\n \n if ( fQuadId > 0.0 )\n {\n\t\tfEdgeAngle += radians( 180.0 );\n }\n \n float fRadius = mix( r0, r1, vQuadVertId.y);\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\n vPos += vDir * vQuadVertId.x;\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n}\n \n#define HEXAGON_VERTEX_COUNT (6.0 * 3.0 + 6.0 * 2.0)\nvoid GetHexagonVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float r, const vec3 col0, const vec3 col1, inout OutVertex vertex )\n{\n \tfloat fAngleOffset = settings.fAperture * 0.5;\n \n \tif ( fVertexIndex < 6.0 * 3.0 ) \n {\n float fTriId;\n\n vec2 vTriVertId;\n GetTriInfo( fVertexIndex, vTriVertId, fTriId );\n\n float fIndex = fTriId + vTriVertId.x;\n\n float fAngle = fIndex * radians(360.0) / 6.0;\n\n float fRadius = vTriVertId.y * r;\n\n vec2 vPos = vec2( sin( fAngle + fAngleOffset), cos( fAngle + fAngleOffset) ) * fRadius;\n\n float fCurrIndex = fTriId;\n float fCurrAngle = fCurrIndex * radians(360.0) / 6.0;\n vec2 vCurrPos = vec2( sin( fCurrAngle + fAngleOffset), cos( fCurrAngle + fAngleOffset) );\n\n float fNextIndex = fTriId + 1.0;\n float fNextAngle = fNextIndex * radians(360.0) / 6.0;\n vec2 vNextPos = vec2( sin( fNextAngle + fAngleOffset), cos( fNextAngle + fAngleOffset) );\n\n if ( Cross( vNextPos - vCurrPos, vDir ) >= 0.0 )\n {\n vPos += vDir;\n }\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vTriVertId.y );\n }\n else\n {\n\t float fVertexIndexB = fVertexIndex - 6.0 * 3.0;\n float fQuadId;\n\n vec2 vQuadVertId;\n GetQuadInfo( fVertexIndexB, vQuadVertId, fQuadId );\n \n float fEdgeAngle = atan( vDir.x, vDir.y )- fAngleOffset;\n \n fEdgeAngle = floor( fEdgeAngle * 6.0 / radians(360.0) - 1.0 ) * radians(360.0) / 6.0;\n \n if ( fQuadId > 0.0 )\n {\n\t\tfEdgeAngle += radians( 180.0 );\n }\n \n float fRadius = vQuadVertId.y * r;\n vec2 vPos = vec2( sin( fEdgeAngle + fAngleOffset), cos( fEdgeAngle + fAngleOffset) ) * fRadius;\n vPos += vDir * vQuadVertId.x;\n\n vertex.vPos.xy = vOrigin + vPos;\n vertex.vColor.rgb = mix( col0, col1, vQuadVertId.y );\n }\n}\n\n\n#define BOKEH_VERTEX_COUNT ( HEXAGON_VERTEX_COUNT + HEXAGON_OUTLINE_VERTEX_COUNT ) \nvoid GetBokehVertex( CameraSettings settings, const float fVertexIndex, const vec2 vOrigin, const vec2 vDir, const float fSize, const float fCoC, const vec3 vCol, out OutVertex vertex )\n{\n \tfloat fInnerSize = fSize + fCoC;\n \tfloat fGlowSize = 0.02;\n \tfloat fOuterSize = fInnerSize + fGlowSize;\n \n \tif ( fVertexIndex < HEXAGON_VERTEX_COUNT )\n {\n \t\tGetHexagonVertex( settings, fVertexIndex, vOrigin, vDir, fInnerSize, vCol, vCol, vertex );\n }\n \telse\n {\n\t \tvec3 vGlowCol = pow(vCol, vec3(0.5)) * 0.0001; \n \tif ( length( vGlowCol ) > 0.0000001 )\n {\n \t\t\tGetHexagonOutlineVertex( settings, fVertexIndex - HEXAGON_VERTEX_COUNT, vOrigin, vDir, fInnerSize, fOuterSize, vGlowCol, vCol * 0.0, vertex );\n }\n else\n {\n \tvertex.vPos.xy = vec2(0.0);\n \tvertex.vColor.rgb = vec3(0.0);\n }\n }\n}\n\nfloat GetCoC( CameraSettings settings, float objectdistance )\n{\n // http://http.developer.nvidia.com/GPUGems/gpugems_ch23.html\n\n\treturn abs(settings.fAperture * (settings.fFocalLength * (objectdistance - settings.fPlaneInFocus)) /\n (objectdistance * (settings.fPlaneInFocus - settings.fFocalLength))); \n}\n\n\nvec3 GetViewPos( CameraSettings settings, CameraPosition cameraPos, vec3 vWorldPos )\n{\n \treturn (vWorldPos - cameraPos.vPosition) * cameraPos.mRotation;\n}\n\nvec2 GetScreenPos( CameraSettings settings, vec3 vViewPos )\n{ \n \treturn vViewPos.xy * settings.fFocalLength * 5.0 / vViewPos.z;\n}\n\nCameraSettings GetCameraSettings( CameraPosition cameraPosition )\n{\n \tCameraSettings settings;\n \n \tfloat aVal = sin(time * 0.25) * 0.5 + 0.5;\n \taVal = aVal * aVal;\n \tsettings.fAperture = aVal * 2.9 + 0.1;\n \tfloat fVal = sin(time * 0.123) * 0.5 + 0.5;\n \tsettings.fFocalLength = 0.2 + 0.2 * fVal;\n \tsettings.fPlaneInFocus = length(cameraPosition.vTarget - cameraPosition.vPosition);\n \n \tfloat oldAVal = sin((time - 0.5) * 0.25) * 0.5 + 0.5;\n \toldAVal = oldAVal * oldAVal;\n \n\tsettings.fExposure = 3.0 + oldAVal *3.0;\n\n \treturn settings;\n}\n\nstruct LightInfo\n{\n\tvec3 vWorldPos;\n \tfloat fRadius;\n \tvec3 vColor;\n};\n \n \nvec2 SolveQuadratic( float a, float b, float c )\n{\n float d = sqrt( b * b - 4.0 * a * c );\n vec2 dV = vec2( d, -d );\n return (-b + dV) / (2.0 * a);\n}\n\n\nvec3 BounceParticle( vec3 vOrigin, vec3 vInitialVel, float fGravity, float fFloorHeight, float fTime )\n{\n \tvec3 u = vInitialVel;\n \tvec3 a = vec3(0.0, fGravity, 0.0);\n \tvec3 vPos = vOrigin;\n\n \tfloat t = fTime;\n \t \t\n \tfor( int iBounce=0; iBounce < 3; iBounce++)\n {\n // When will we hit the ground?\n vec2 q = SolveQuadratic( 0.5 * a.y, u.y, -fFloorHeight + vPos.y);\n float tInt = max( q.x, q.y );\n tInt -= 0.0001;\n \n\n if ( t < tInt )\n {\n\t vPos += u * t + 0.5 * a * t * t;\n break;\n }\n else\n { \n // Calculate velocity at intersect time\n vec3 v = u + a * tInt;\n\n // step to intersect time\n vPos += u * tInt + 0.5 * a * tInt * tInt;\n \t u = v;\n \n // bounce\n u.y = -u.y * 0.3;\n u.xz *= 0.6;\n\n t -= tInt;\n }\n }\n\n \treturn vPos;\n}\n\nfloat fFloorHeight = 0.0;\n\nLightInfo Fountain( const in float fLightIndex, const in vec3 vPos, float fTime, vec3 vCol, float fSpread )\n{\n float fParticleLifetime = 1.5;\n \tLightInfo lightInfo;\n \n \tfloat h = Hash( fLightIndex + 12.0 );\n \tvec3 h3 = Hash3( fLightIndex + 13.0 );\n \n \tfloat fAngle = fLightIndex;\n \n \tvec3 vInitialVel = (normalize(h3 * 2.0 - 1.0) * fSpread + vec3( 0.0, 10.0 - fSpread * 1.3, 0.0 )) * (0.4 + h * 0.4);\n \tvec3 vOrigin = vPos + vec3( 0.0, fFloorHeight + 0.1, 0.0 ) + vInitialVel * 0.1;\n \tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fTime );\n\n \n \tlightInfo.fRadius = 0.01; \n// \tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\n \tlightInfo.vColor = vCol;\n \tlightInfo.vColor *= clamp( 1.0 - fTime + fParticleLifetime - 1.0, 0.0, 1.0);\n\treturn lightInfo; \n}\n\nLightInfo CatherineWheel( const in float fLightIndex, const in vec3 vPos, float fSequenceStart, float fSpawnTime, float fParticleT, vec3 vCol )\n{\n \tfloat h = Hash( fLightIndex + 4.0 );\n\n\t float fParticleLifetime = 0.3 + h *0.5;\n \tLightInfo lightInfo;\n\n \tvec3 h3 = Hash3( fLightIndex + 12.0 );\n \tfloat t = fSpawnTime - fSequenceStart;\n \tif( t < 5.0 ) t = t * t;\n \telse t = t * 5.0 + 5.0 * 5.0;\n \t\n \tfloat fSpawnAngle = t * 5.0;\n \n \tif ( h > 0.5 )\n {\n fSpawnAngle += radians( 180.0 );\n }\n \n \tmat3 m = RotMatrixZ(fSpawnAngle);\n \n \tvec3 vInitialVel = vec3(-3.0, 0.0, 0.0 ) + h3 * 0.5;\n \tvInitialVel = vInitialVel * m;\n \tvec3 vOffset = vec3( 0.0, 0.03, 0.0 * m);\n \tvec3 vOrigin = vPos + vOffset + vInitialVel * 0.1;\n \tlightInfo.vWorldPos = BounceParticle( vOrigin, vInitialVel, -9.81, fFloorHeight, fParticleT );\n\n \n \tlightInfo.fRadius = 0.01; \n// \tlightInfo.vColor = vec3(1.0, 0.4, 0.1);\n \tlightInfo.vColor = vCol;\n \tlightInfo.vColor *= clamp( 1.0 - fParticleT + fParticleLifetime - 1.0, 0.0, 1.0);\n\treturn lightInfo; \n}\n\n\nstruct SequenceInfo\n{\n \tfloat fSequenceSet;\n \tfloat fSequenceSetLength;\n \n \tfloat fSequenceIndex;\n \tfloat fSequenceStartTime;\n \n \tfloat fSequenceSeed;\n \tvec3 vSequenceHash;\n \n \tvec3 vCol;\n \n \tfloat fType;\n \tvec3 vPos;\n \tvec3 vTarget;\n};\n \nSequenceInfo GetSequenceInfo( float fSetIndex, float fTime )\n{\n \tSequenceInfo sequenceInfo;\n\n \t\tfloat fSequenceSetCount = 2.0;\n \tsequenceInfo.fSequenceSet = mod(fSetIndex, fSequenceSetCount);\n\n \t\tfloat sh = Hash( sequenceInfo.fSequenceSet );\n \t\tfloat fSequenceSetLength = 10.0 + sh * 5.0;\n \n\n \t\tsequenceInfo.fSequenceIndex = floor( fTime / fSequenceSetLength );\n \t\tsequenceInfo.fSequenceStartTime = (sequenceInfo.fSequenceIndex * fSequenceSetLength);\n \n \t\tsequenceInfo.fSequenceSeed = sequenceInfo.fSequenceIndex + sequenceInfo.fSequenceSet * 12.3;\n \t\tsequenceInfo.vSequenceHash = Hash3(sequenceInfo.fSequenceSeed);\n\n \t\tfloat ch = Hash( sequenceInfo.fSequenceSeed * 2.34 );\n \t\tsequenceInfo.vCol = vec3(1.0, 0.4, 0.1);\n \n \t\tif( ch < 0.25 )\n {\n sequenceInfo.vCol = vec3(1.0, 0.08, 0.08);\n }\n \t\telse if( ch < 0.5 )\n {\n sequenceInfo.vCol = vec3(0.08, 0.08, 1.0);\n }\n \t\telse if( ch < 0.75 )\n {\n sequenceInfo.vCol = vec3(0.08, 1.0, 0.08 );\n }\n \n \n \tif ( sequenceInfo.vSequenceHash.x < 0.7)\n {\n \t\t\tsequenceInfo.vPos = vec3(0.0);\n\t \t\tsequenceInfo.vPos.xz = sequenceInfo.vSequenceHash.yz * 6.0 - 3.0;\n\t \t\tsequenceInfo.fType = 0.0;\n \tsequenceInfo.vTarget = sequenceInfo.vPos;\n \tsequenceInfo.vTarget.y = 1.5;\n }\n \t\telse\n {\n \tsequenceInfo.vPos = vec3(0.0, 2.5, 7.0);\n\t \t\tsequenceInfo.vPos += (sequenceInfo.vSequenceHash.xyz * 2.0 - 1.0) * vec3(5.0, 1.5, 3.0);\n\t \t\tsequenceInfo.fType = 1.0;\n \tsequenceInfo.vTarget = sequenceInfo.vPos;\n } \n \n \treturn sequenceInfo;\n}\n\nLightInfo GetFireworkSparkInfo( in float fLightIndex, float fTime, float fDeltaTime, vec3 h3 )\n{ \n\t float fParticleLifetime = 1.5;\n \tfloat fParticleSpawnTime = (floor( (fTime / fParticleLifetime) + h3.x) - h3.x) * fParticleLifetime;\n \tfloat fParticleEndTime = fParticleSpawnTime + fParticleLifetime;\n \tfloat fParticleGlobalT = fTime - fParticleSpawnTime;\n \tfloat fParticleT = mod( fParticleGlobalT, fParticleLifetime ) + fDeltaTime;\n \n \t\tSequenceInfo sequenceInfo = GetSequenceInfo( fLightIndex, fParticleSpawnTime );\n \n \tLightInfo lightInfo;\n \n \t\tif ( sequenceInfo.fType < 0.5)\n {\n \tfloat fSpread = fract( sequenceInfo.vSequenceHash.z + sequenceInfo.vSequenceHash.y ) + 1.0;\n\t \t\tlightInfo = Fountain( fLightIndex, sequenceInfo.vPos, fParticleT, sequenceInfo.vCol, fSpread );\n }\n \t\telse\n {\n \tlightInfo = CatherineWheel( fLightIndex, sequenceInfo.vPos, sequenceInfo.fSequenceStartTime, fParticleSpawnTime, fParticleT, sequenceInfo.vCol );\n } \n \n return lightInfo; \n}\n\nLightInfo GetLightInfo( const in float fLightIndex, float fTime, float fDeltaTime, CameraPosition cameraPos )\n{\n \tLightInfo lightInfo;\n\n \t//float h = Hash( fLightIndex );\n \tvec3 h3 = Hash3(fLightIndex);\n\n \tfloat kHangingLightCount = 32.0;\n \tfloat kHangingLightMax = 0.0 + kHangingLightCount;\n \n \tfloat kStarCount = 0.0;\n \tfloat kStarMax = kHangingLightMax + kStarCount;\n \t\n \tfloat kDirtCount = 16.0;\n \tfloat kDirtMax = kStarMax + kDirtCount;\n\n \tfloat kStreetLightCount = 64.0;\n \tfloat kStreetLightMax = kDirtMax + kStreetLightCount;\n \n \tfloat kGardenLightCount = 16.0;\n \tfloat kGardenLightMax = kStreetLightMax + kGardenLightCount;\n\n \tif( fLightIndex < kHangingLightMax )\n \t{\n \t// hanging lights\n \tlightInfo.vWorldPos.x = ((fLightIndex / 10.0) * 2.0 - 1.0) * 3.0;\n \tlightInfo.vWorldPos.y = 2.0 + -abs( cos( fLightIndex * 0.4 ) * 0.8 ); \n \tlightInfo.vWorldPos.z = 20.0;\n \t\tlightInfo.vColor = vec3(0.01) * 0.5;\n \tfloat fColIndex = mod(fLightIndex, 3.0);\n \tif ( fColIndex == 0.0 ) lightInfo.vColor.x = 1.0;\n \tif ( fColIndex == 1.0 ) lightInfo.vColor.y = 1.0;\n \tif ( fColIndex == 2.0 ) lightInfo.vColor.z = 1.0;\n\t lightInfo.vColor *= 0.05;\n \t\t//lightInfo.vColor = normalize(vec3(sin(fLightIndex) * .5 + 0.5, sin(fLightIndex * 3.45) * .5 + 0.5, sin(fLightIndex * 4.56) * .5 + 0.5)) * 0.5;\n \n \t\tlightInfo.fRadius = 0.05;\n\t}\n \telse\n \tif( fLightIndex < kStarMax )\n \t{\n // stars\n \tlightInfo.vWorldPos = normalize( h3 * 2.0 - 1.0 ) * 5000.0;\n \tlightInfo.vWorldPos.y = abs(lightInfo.vWorldPos.y);\n \t\tlightInfo.vColor = vec3(0.01);\n \t\tlightInfo.fRadius = 0.001;\n }\n \telse\n \tif( fLightIndex < kDirtMax )\n \t{\n // lens dirt\n \tlightInfo.vWorldPos.xy = (Hash3(fLightIndex).xy * 2.0 - 1.0);\n \tlightInfo.vWorldPos.xy = normalize(lightInfo.vWorldPos.xy) * pow( length(lightInfo.vWorldPos.xy), 0.3 ) * 0.35;\n\t lightInfo.vWorldPos.y *= resolution.y / resolution.x;\n \tlightInfo.vWorldPos.z = 0.3;\n \tvec3 vOffset = cameraPos.mRotation * lightInfo.vWorldPos;\n \tlightInfo.vWorldPos = vOffset + cameraPos.vPosition;\n \t\tlightInfo.vColor = vec3(0.2, 0.18, 0.1) * abs( dot(normalize(vOffset), vec3(0.0, 0.0, 1.0)) ) * 1.0;\n \t\tlightInfo.fRadius = 0.0001;\n }\n \telse\n // street lights\n \tif( fLightIndex < kStreetLightMax )\n \t{\n \tlightInfo.vWorldPos.xz = (h3.xy * 2.0 - 1.0) * 500.0;\n \tlightInfo.vWorldPos.y = 10.0; \n \t\tlightInfo.vColor = vec3(1.0, 0.3, 0.01) * 0.5;\n \n \t\tlightInfo.fRadius = 0.2;\n\t}\n \telse if( fLightIndex < kGardenLightMax )\n \t{\n \tlightInfo.vWorldPos.y = 0.05 + h3.y * 0.5; \n \tvec2 vOffset = (h3.xz * 2.0 - 1.0);\n \tlightInfo.vWorldPos.xz = vOffset * 50.0 + normalize( vOffset ) * 10.0;\n \t\tlightInfo.vColor = sin(h3 * 10.0 + vec3(0.1, 0.2, 0.3)) * 0.5 + 0.5;\n \tlightInfo.vColor = normalize(lightInfo.vColor);\n\t lightInfo.vColor *= 0.005;\n \n \t\tlightInfo.fRadius = 0.05;\n\t}\n \telse\n {\n \tlightInfo = GetFireworkSparkInfo( fLightIndex, fTime, fDeltaTime, h3 );\n }\n \n\n \treturn lightInfo;\n}\n\n\nvec3 GetCameraTarget( float fTime )\n{\n \t//return vec3(0.0, 1.8, 0.0);\n\n \tfloat fInterval = 8.0;\n \n \tfloat t0 = floor(fTime / fInterval) * fInterval; \n \tfloat t1 = (floor(fTime / fInterval+ 1.0) ) * fInterval; \n \n \tSequenceInfo inf0 = GetSequenceInfo( 0.0, t0 );\n \tSequenceInfo inf1 = GetSequenceInfo( 0.0, t1 );\n \n \tfloat fBlend = (fTime - t0) / fInterval;\n \n \tfBlend = smoothstep( 0.0, 1.0, fBlend);\n \n \treturn mix( inf0.vTarget, inf1.vTarget, fBlend );\n}\n\nCameraPosition GetCameraPosition( float fTime, vec2 vTouch )\n{\n \tCameraPosition cameraPos;\n \n \tif( (vTouch.y > 0.9) && (vTouch.x > -0.83) && (vTouch.x < -0.80) )\n {\t\n \tvTouch.xy = vec2(0.0);\n }\n \n \tcameraPos.vTarget = GetCameraTarget( fTime );\n \n \tcameraPos.vPosition += cameraPos.vTarget;\n \t\n \tcameraPos.vPosition = vec3( sin(fTime * 0.2) * 5.0, 2.0, -6.0 + sin(fTime * 0.0567) * 3.0);\n \tcameraPos.vUp = vec3( 0.0, 1.0, 0.0 );\n \n \tGetMatrixFromZY( normalize(cameraPos.vTarget - cameraPos.vPosition), cameraPos.vUp, cameraPos.mRotation );\n \n \tvec3 vRot = vec3( vTouch.y * 0.5, vTouch.x * 0.5, 0.0 );\n \n#ifdef SHAKY_CAM\n\tvRot += Noise23( cameraPos.vPosition.xz * 4.0 ) * vec3( 0.05, 0.03, 0.01 ); //shaky cam\n#endif\n \n \tcameraPos.mRotation = cameraPos.mRotation * RotMatrixZ(vRot.z) * RotMatrixY(vRot.y) * RotMatrixX( vRot.x ) ; \n \n \treturn cameraPos;\n}\n\nvoid main() \n{\n float fVertexIndex = vertexId;\n\n vec4 touch1 = texture2D(touch, vec2(0.0, 0.0));\n vec4 touch2 = texture2D(touch, vec2(0.0, 0.01)); \n\n\tfloat fShutterSpeed = 1.0 / 60.0;\n \n CameraPosition cameraPos = GetCameraPosition( time, touch1.xy );\n CameraPosition lastCameraPos = GetCameraPosition( time - fShutterSpeed, touch2.xy );\n\n CameraSettings cameraSettings = GetCameraSettings( cameraPos );\n\n OutVertex vertex;\n\n float fBokehIndex = floor( fVertexIndex / BOKEH_VERTEX_COUNT );\n \n LightInfo lightInfo = GetLightInfo( fBokehIndex, time, 0.0, cameraPos );\n LightInfo prevLightInfo = GetLightInfo( fBokehIndex, time, -fShutterSpeed, lastCameraPos );\n \n vec3 vViewPos = GetViewPos( cameraSettings, cameraPos, lightInfo.vWorldPos );\n vec3 vLastViewPos = GetViewPos( cameraSettings, lastCameraPos, prevLightInfo.vWorldPos );\n\n vec2 vScreenPos = GetScreenPos( cameraSettings, vViewPos );\n vec2 vLastScreenPos = GetScreenPos( cameraSettings, vLastViewPos ); \n\n float fScreenSize = GetScreenPos( cameraSettings, vec3( lightInfo.fRadius, lightInfo.fRadius, vViewPos.z ) ).x;\n \n vec2 vOrigin = vScreenPos.xy;\n vec2 vDir = vLastScreenPos.xy - vScreenPos.xy;\n \n float fCoC = GetCoC( cameraSettings, vViewPos.z );\n\n vec3 vCol = lightInfo.vColor;\n\n float fSize = fCoC + fScreenSize;\n vCol *= fScreenSize * fScreenSize * 3.14 / (length( vDir ) * fSize + fSize * fSize * 3.14);\n \n float fBokehVertexIndex = mod( fVertexIndex, BOKEH_VERTEX_COUNT );\n GetBokehVertex( cameraSettings, fBokehVertexIndex, vOrigin, vDir, fScreenSize, fCoC, vCol, vertex );\n \n vertex.vPos.y *= resolution.x / resolution.y;\n \n gl_Position = vec4(vertex.vPos.x, vertex.vPos.y, 1.0 / vertexId, 1);\n float fFinalExposure = cameraSettings.fExposure / (cameraSettings.fAperture * cameraSettings.fAperture);\n v_color.rgb = 1.0 - exp2( vertex.vColor * -fFinalExposure );\n v_color.rgb = pow( v_color.rgb, vec3(1.0 / 2.2) );\n v_color.a = 0.0;\n \n float fNearClip = 0.25;\n if ( vViewPos.z <= fNearClip || vLastViewPos.z <= fNearClip)\n {\n gl_Position = vec4(0.0);\n v_color = vec4(0.0);\n }\n \n}" + }, "screenshotURL": "data/images/images-epsepn196c6cvr6te-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vd4wAi9P33ezAYGis/art.json b/art/vd4wAi9P33ezAYGis/art.json index e2c68711..557cf4de 100644 --- a/art/vd4wAi9P33ezAYGis/art.json +++ b/art/vd4wAi9P33ezAYGis/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":4,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nOverdraw with blending test\\n\\nThis vertex shader just draws full canvas size planes\\n\\nTurn on the Chrome Devtools FPS Meter\\n(Console tab -> Press ESC -> bottom left ⋮ icon -> Rendering)\\nIncrease the count above (the number to the right of the slider)\\n**SLOWLY** Try 50, then 100, then 150, then 200. If you put\\na large number like 10000 the browser may kill WebGL since\\nthe draw took too long.\\n\\nOn my 2014 Macbook Pro I get to about 100 with the window\\nfullscreen. That's only 100/6 or 16 screens of pixels\\neven though the fragment shader is just\\n\\n varying vec4 v_color\\n void main() {\\n gl_FragColor = v_color;\\n }\\n\\nNote this page uses CSS pixels so on an HD-DPI display\\nit's probably only drawing 1/4th the pixels relative\\nto the actual screen resolution.\\n\\nThings to consider\\n\\n* The browser is composting the WebGL canvas on the page\\n so that's one fullscreen of pixels of rendering\\n\\n* This text (the code editor) is another 1/2 or fullscreen\\n of pixels being rendered and compositied on the page.\\n\\n* Vertexshaderart.com has blending enabled. Blending is slower\\n than not blending.\\n\\n* Changing DRAW_BACK_TO_FRONT to 0 I can set count to 350\\n which is 58 screens of pixels or 3.6x faster because of\\n early depth test rejection. This is of course a simple\\n fragment shader. For a complex fragment shader the\\n difference would be far higher.\\n\\n*/\\n\\n#define DRAW_BACK_TO_FRONT 1\\n\\nvoid main() {\\n float id = vertexId;\\n float x = mod(id, 2.);\\n float y = mod(floor(id / 2.) + floor(id / 3.), 2.); \\n float planeId = floor(id / 6.);\\n float numPlanes = floor(vertexCount / 6.);\\n float z = planeId / numPlanes;\\n\\n #if DRAW_BACK_TO_FRONT\\n z = 1. - z;\\n #endif\\n \\n gl_Position = vec4(vec3(x, y, z) * 2. - 1., 1);\\n\\n v_color = vec4(0.01, 0.02, 0.03, 0.01);\\n}\"}", + "settings": { + "num": 4, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nOverdraw with blending test\n\nThis vertex shader just draws full canvas size planes\n\nTurn on the Chrome Devtools FPS Meter\n(Console tab -> Press ESC -> bottom left ⋮ icon -> Rendering)\nIncrease the count above (the number to the right of the slider)\n**SLOWLY** Try 50, then 100, then 150, then 200. If you put\na large number like 10000 the browser may kill WebGL since\nthe draw took too long.\n\nOn my 2014 Macbook Pro I get to about 100 with the window\nfullscreen. That's only 100/6 or 16 screens of pixels\neven though the fragment shader is just\n\n varying vec4 v_color\n void main() {\n gl_FragColor = v_color;\n }\n\nNote this page uses CSS pixels so on an HD-DPI display\nit's probably only drawing 1/4th the pixels relative\nto the actual screen resolution.\n\nThings to consider\n\n* The browser is composting the WebGL canvas on the page\n so that's one fullscreen of pixels of rendering\n\n* This text (the code editor) is another 1/2 or fullscreen\n of pixels being rendered and compositied on the page.\n\n* Vertexshaderart.com has blending enabled. Blending is slower\n than not blending.\n\n* Changing DRAW_BACK_TO_FRONT to 0 I can set count to 350\n which is 58 screens of pixels or 3.6x faster because of\n early depth test rejection. This is of course a simple\n fragment shader. For a complex fragment shader the\n difference would be far higher.\n\n*/\n\n#define DRAW_BACK_TO_FRONT 1\n\nvoid main() {\n float id = vertexId;\n float x = mod(id, 2.);\n float y = mod(floor(id / 2.) + floor(id / 3.), 2.); \n float planeId = floor(id / 6.);\n float numPlanes = floor(vertexCount / 6.);\n float z = planeId / numPlanes;\n\n #if DRAW_BACK_TO_FRONT\n z = 1. - z;\n #endif\n \n gl_Position = vec4(vec3(x, y, z) * 2. - 1., 1);\n\n v_color = vec4(0.01, 0.02, 0.03, 0.01);\n}" + }, "screenshotURL": "data/images/images-05k5j8cqbq2u0qhx0-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ve3x7fM9K77dHgwux/art.json b/art/ve3x7fM9K77dHgwux/art.json index e1e0e71b..f8be4092 100644 --- a/art/ve3x7fM9K77dHgwux/art.json +++ b/art/ve3x7fM9K77dHgwux/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "morimea", "avatarUrl": "https://secure.gravatar.com/avatar/8ff4b4cacdf52d8d31a020cd244c5269?default=retro&size=200", - "settings": "{\"num\":60750,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0392156862745098,0.0392156862745098,0.0392156862745098,1],\"shader\":\" //#define vertexId float(gl_InstanceID+gl_VertexID)\\n\\n\\n // default number of particles 15*15*15*6*3=60750 15 is cube size\\n\\n const float size=1.; \\n\\n //out vec4 v_color;\\n\\n const float PI = 3.1415926535898;\\n\\n const float VertX = 15.0;\\n const float VertY = 15.0;\\n\\n const float tscale = 0.2;\\n const vec3 obj_pos = vec3(-1.5);\\n\\n mat3 rotx(float a){float s = sin(a);float c = cos(a);return mat3(vec3(1.0, 0.0, 0.0), vec3(0.0, c, s), vec3(0.0, -s, c)); }\\n mat3 roty(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, 0.0, s), vec3(0.0, 1.0, 0.0), vec3(-s, 0.0, c));}\\n mat3 rotz(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0 ));}\\n\\n\\n const float degree_to_rad = PI / 180.0;\\n\\n mat4 perspectiveMatrix(float fovYInRad, float aspectRatio)\\n {\\n float yScale = 1.0 / tan(fovYInRad / 2.0);\\n float xScale = yScale / aspectRatio;\\n float zf = 100.0;\\n float zn = 0.3;\\n\\n float z1 = zf / (zf - zn);\\n float z2 = -zn * zf / (zf - zn);\\n\\n mat4 result = mat4(xScale, 0.0, 0.0, 0.0, 0.0, yScale, 0.0, 0.0, 0.0, 0.0, -z1, -1., 0.0, 0.0, z2, 0.0);\\n\\n return result;\\n }\\n\\n mat4 lookat(vec3 eye, vec3 look, vec3 up)\\n {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *\\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\\n }\\n\\n vec3 voxelPosToWorld(vec3 vp)\\n {\\n return vp * (tscale / (size)) + obj_pos;\\n }\\n\\n float sphereSDF(vec3 p, float r)\\n {\\n return length(p) - r;\\n }\\n\\n float sdBox( vec3 p, vec3 b )\\n {\\n vec3 q = abs(p) - b;\\n return length(max(q,0.0)) + min(max(q.x,max(q.y,q.z)),0.0);\\n }\\n\\n float sdfUnion( const float a, const float b )\\n {\\n return min(a, b);\\n }\\n\\n float sdfDifference( const float a, const float b)\\n {\\n return max(a, -b);\\n }\\n\\n float sdfIntersection( const float a, const float b )\\n {\\n return max(a, b);\\n }\\n\\n float scene(vec3 p)\\n {\\n float d = 0.0;\\n d = sdfDifference(sphereSDF(p + vec3(0., 0.3, 0.), .8),\\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\\n d = sdfDifference(sdBox(p + vec3(0., 0.3, 0.), vec3(.8)),\\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\\n\\n return d;\\n }\\n\\n vec3 sceneNormal(vec3 p)\\n {\\n vec3 EPS = vec3(0.05, 0.0, 0.0);\\n vec3 n;\\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\\n return normalize(n);\\n }\\n\\n vec3 vertexSmooth(vec3 ip)\\n {\\n vec3 p = ip;\\n vec3 n = sceneNormal(p);\\n for (int i = 0; i < 8; i++)\\n {\\n float d = scene(p);\\n p -= n * d;\\n if (abs(d) < 0.01)\\n {\\n break;\\n }\\n }\\n return p;\\n }\\n\\n vec3 phongContribForLight(vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 lightPos, vec3 lightIntensity, vec3 N)\\n {\\n vec3 L = normalize(lightPos - p);\\n vec3 V = normalize(eye - p);\\n vec3 R = normalize(reflect(-L, N));\\n\\n float dotLN = dot(L, N);\\n float dotRV = dot(R, V);\\n\\n if (dotLN < 0.0)\\n {\\n return vec3(0.0, 0.0, 0.0);\\n }\\n\\n if (dotRV < 0.0)\\n {\\n return lightIntensity * (k_d * dotLN);\\n }\\n return lightIntensity * (k_d * dotLN + k_s * pow(dotRV, alpha));\\n }\\n\\n vec3 phongIllumination(vec3 k_a, vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 norm)\\n {\\n const vec3 ambientLight = 0.5 * vec3(1.0, 1.0, 1.0);\\n vec3 color = ambientLight * k_a;\\n\\n vec3 light1Pos = normalize(vec3(mouse.x, mouse.y, .20));\\n vec3 light1Intensity = 2. * vec3(0.4, 0.4, 0.4);\\n\\n color += phongContribForLight(k_d, k_s, alpha, p, eye, light1Pos, light1Intensity, norm);\\n\\n return color;\\n }\\n\\n vec4 color_phong(vec3 p, vec3 ro, vec3 n, vec3 col)\\n {\\n vec3 K_a = col;\\n vec3 K_d = K_a;\\n vec3 K_s = vec3(1.0, 1.0, 1.0);\\n float shininess = 12.0;\\n\\n col = phongIllumination(K_a, K_d, K_s, shininess, p, ro, n);\\n return vec4(col, 1.);\\n }\\n\\n void main()\\n {\\n // vertex index in quad face, two triangles\\n float id_Vert = mod(vertexId, 6.0);\\n // face index\\n float id_Face = floor(vertexId / 6.0);\\n // corner face index\\n float id_Face_corner = mod(id_Face, 3.0);\\n // corner edge index\\n float id_Edge = mod(id_Face, 3.0);\\n // corner index 1 corner is 3 faces is 3*6 verts\\n float id_Corner = floor(vertexId / 18.0);\\n // corner position\\n vec3 cornerP;\\n float tVertX = VertX * size;\\n float tVertY = VertY * size;\\n cornerP.x = mod(id_Corner, tVertX);\\n cornerP.y = mod(floor(id_Corner / tVertX), tVertY);\\n cornerP.z = mod(floor(id_Corner / (tVertX * tVertY)), tVertY);\\n\\n vec3 faceNorm;\\n vec3 faceTan;\\n vec3 faceaTan;\\n if (id_Edge == 0.0)\\n {\\n faceNorm = vec3(1.0, 0.0, 0.0);\\n faceTan = vec3(0.0, 0.0, -1.0);\\n faceaTan = vec3(0.0, 1.0, 0.0);\\n }\\n else if (id_Edge == 1.0)\\n {\\n faceNorm = vec3(0.0, 1.0, 0.0);\\n faceTan = vec3(1.0, 0.0, 0.0);\\n faceaTan = vec3(0.0, 0.0, -1.0);\\n }\\n else\\n {\\n faceNorm = vec3(0.0, 0.0, 1.0);\\n faceTan = vec3(1.0, 0.0, 0.0);\\n faceaTan = vec3(0.0, 1.0, 0.0);\\n }\\n vec3 aPos = cornerP + faceNorm;\\n\\n // sampling points\\n vec3 p0 = voxelPosToWorld(cornerP);\\n vec3 p1 = voxelPosToWorld(aPos);\\n\\n // field value\\n float d0 = scene(p0);\\n float d1 = scene(p1);\\n\\n vec3 p;\\n vec3 vertNorm;\\n\\n if (d0 * d1 > 0.0)\\n {\\n // no face\\n p = p0;\\n vertNorm = vec3(1.0, 1.0, 1.0);\\n }\\n else\\n {\\n // have a face\\n if (d1 < d0)\\n {\\n // 0->1 is standard normal.\\n // otherwise flip triangle\\n if (id_Vert == 0.0)\\n {\\n id_Vert = 2.0;\\n }\\n else if (id_Vert == 2.0)\\n {\\n id_Vert = 0.0;\\n }\\n else if (id_Vert == 3.0)\\n {\\n id_Vert = 5.0;\\n }\\n else if (id_Vert == 5.0)\\n {\\n id_Vert = 3.0;\\n }\\n faceNorm *= -1.0;\\n }\\n\\n /*\\n face\\n 2 4-5\\n |\\\\ \\\\|\\n 0-1 3\\n */\\n float faceSize = mix(0.45, 0.5, clamp(cos(time * .75) * 4.0 + 0.5, 0.0, 1.0));\\n vec3 edgeMidP = (cornerP + aPos) * 0.5;\\n vec3 faceVertP;\\n if (id_Vert == 0.0)\\n {\\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * -faceSize;\\n }\\n else if (id_Vert == 1.0)\\n {\\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\\n }\\n else if (id_Vert == 2.0)\\n {\\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\\n }\\n else if (id_Vert == 3.0)\\n {\\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\\n }\\n else if (id_Vert == 4.0)\\n {\\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\\n }\\n else if (id_Vert == 5.0)\\n {\\n faceVertP = edgeMidP + faceTan * 0.5 + faceaTan * 0.5;\\n }\\n p = voxelPosToWorld(faceVertP);\\n\\n // smoothing\\n vec3 sp = vertexSmooth(p);\\n vertNorm = sceneNormal(p);\\n\\n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\\n vmix = 1.;\\n p = mix(p, sp, vmix);\\n vertNorm = mix(faceNorm, vertNorm, vmix);\\n }\\n\\n vec3 eye = vec3(0.0, 0.0, 3.5) * rotx(clamp(mouse.y, -0.5, 0.5) * 1.5) * roty(-clamp(mouse.x, -0.5, 0.5) * 1.5);\\n // eye = vec3(0.0, 0.0, 3.0);\\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\\n mat4 pMatrix = perspectiveMatrix(60.0 * degree_to_rad, resolution.x / resolution.y);\\n vec4 viewPos = (viewMat * vec4(p, 1.0));\\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\\n\\n gl_Position = (pMatrix * viewPos) * 100.2;\\n gl_PointSize = 2.0;\\n\\n v_color = color_phong(viewPos.xyz, eye, viewNorm, 0.5 * (viewNorm + 1.) / 2.);\\n }\"}", + "settings": { + "num": 60750, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0392156862745098, + 0.0392156862745098, + 0.0392156862745098, + 1 + ], + "shader": " //#define vertexId float(gl_InstanceID+gl_VertexID)\n\n\n // default number of particles 15*15*15*6*3=60750 15 is cube size\n\n const float size=1.; \n\n //out vec4 v_color;\n\n const float PI = 3.1415926535898;\n\n const float VertX = 15.0;\n const float VertY = 15.0;\n\n const float tscale = 0.2;\n const vec3 obj_pos = vec3(-1.5);\n\n mat3 rotx(float a){float s = sin(a);float c = cos(a);return mat3(vec3(1.0, 0.0, 0.0), vec3(0.0, c, s), vec3(0.0, -s, c)); }\n mat3 roty(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, 0.0, s), vec3(0.0, 1.0, 0.0), vec3(-s, 0.0, c));}\n mat3 rotz(float a){float s = sin(a);float c = cos(a);return mat3(vec3(c, s, 0.0), vec3(-s, c, 0.0), vec3(0.0, 0.0, 1.0 ));}\n\n\n const float degree_to_rad = PI / 180.0;\n\n mat4 perspectiveMatrix(float fovYInRad, float aspectRatio)\n {\n float yScale = 1.0 / tan(fovYInRad / 2.0);\n float xScale = yScale / aspectRatio;\n float zf = 100.0;\n float zn = 0.3;\n\n float z1 = zf / (zf - zn);\n float z2 = -zn * zf / (zf - zn);\n\n mat4 result = mat4(xScale, 0.0, 0.0, 0.0, 0.0, yScale, 0.0, 0.0, 0.0, 0.0, -z1, -1., 0.0, 0.0, z2, 0.0);\n\n return result;\n }\n\n mat4 lookat(vec3 eye, vec3 look, vec3 up)\n {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n return mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0);\n }\n\n vec3 voxelPosToWorld(vec3 vp)\n {\n return vp * (tscale / (size)) + obj_pos;\n }\n\n float sphereSDF(vec3 p, float r)\n {\n return length(p) - r;\n }\n\n float sdBox( vec3 p, vec3 b )\n {\n vec3 q = abs(p) - b;\n return length(max(q,0.0)) + min(max(q.x,max(q.y,q.z)),0.0);\n }\n\n float sdfUnion( const float a, const float b )\n {\n return min(a, b);\n }\n\n float sdfDifference( const float a, const float b)\n {\n return max(a, -b);\n }\n\n float sdfIntersection( const float a, const float b )\n {\n return max(a, b);\n }\n\n float scene(vec3 p)\n {\n float d = 0.0;\n d = sdfDifference(sphereSDF(p + vec3(0., 0.3, 0.), .8),\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\n d = sdfDifference(sdBox(p + vec3(0., 0.3, 0.), vec3(.8)),\n sphereSDF(p + vec3(0., -0.6 + 0.6 * sin(time), 0.), .7));\n\n return d;\n }\n\n vec3 sceneNormal(vec3 p)\n {\n vec3 EPS = vec3(0.05, 0.0, 0.0);\n vec3 n;\n n.x = scene(p + EPS.xyz) - scene(p - EPS.xyz);\n n.y = scene(p + EPS.zxy) - scene(p - EPS.zxy);\n n.z = scene(p + EPS.yzx) - scene(p - EPS.yzx);\n return normalize(n);\n }\n\n vec3 vertexSmooth(vec3 ip)\n {\n vec3 p = ip;\n vec3 n = sceneNormal(p);\n for (int i = 0; i < 8; i++)\n {\n float d = scene(p);\n p -= n * d;\n if (abs(d) < 0.01)\n {\n break;\n }\n }\n return p;\n }\n\n vec3 phongContribForLight(vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 lightPos, vec3 lightIntensity, vec3 N)\n {\n vec3 L = normalize(lightPos - p);\n vec3 V = normalize(eye - p);\n vec3 R = normalize(reflect(-L, N));\n\n float dotLN = dot(L, N);\n float dotRV = dot(R, V);\n\n if (dotLN < 0.0)\n {\n return vec3(0.0, 0.0, 0.0);\n }\n\n if (dotRV < 0.0)\n {\n return lightIntensity * (k_d * dotLN);\n }\n return lightIntensity * (k_d * dotLN + k_s * pow(dotRV, alpha));\n }\n\n vec3 phongIllumination(vec3 k_a, vec3 k_d, vec3 k_s, float alpha, vec3 p, vec3 eye, vec3 norm)\n {\n const vec3 ambientLight = 0.5 * vec3(1.0, 1.0, 1.0);\n vec3 color = ambientLight * k_a;\n\n vec3 light1Pos = normalize(vec3(mouse.x, mouse.y, .20));\n vec3 light1Intensity = 2. * vec3(0.4, 0.4, 0.4);\n\n color += phongContribForLight(k_d, k_s, alpha, p, eye, light1Pos, light1Intensity, norm);\n\n return color;\n }\n\n vec4 color_phong(vec3 p, vec3 ro, vec3 n, vec3 col)\n {\n vec3 K_a = col;\n vec3 K_d = K_a;\n vec3 K_s = vec3(1.0, 1.0, 1.0);\n float shininess = 12.0;\n\n col = phongIllumination(K_a, K_d, K_s, shininess, p, ro, n);\n return vec4(col, 1.);\n }\n\n void main()\n {\n // vertex index in quad face, two triangles\n float id_Vert = mod(vertexId, 6.0);\n // face index\n float id_Face = floor(vertexId / 6.0);\n // corner face index\n float id_Face_corner = mod(id_Face, 3.0);\n // corner edge index\n float id_Edge = mod(id_Face, 3.0);\n // corner index 1 corner is 3 faces is 3*6 verts\n float id_Corner = floor(vertexId / 18.0);\n // corner position\n vec3 cornerP;\n float tVertX = VertX * size;\n float tVertY = VertY * size;\n cornerP.x = mod(id_Corner, tVertX);\n cornerP.y = mod(floor(id_Corner / tVertX), tVertY);\n cornerP.z = mod(floor(id_Corner / (tVertX * tVertY)), tVertY);\n\n vec3 faceNorm;\n vec3 faceTan;\n vec3 faceaTan;\n if (id_Edge == 0.0)\n {\n faceNorm = vec3(1.0, 0.0, 0.0);\n faceTan = vec3(0.0, 0.0, -1.0);\n faceaTan = vec3(0.0, 1.0, 0.0);\n }\n else if (id_Edge == 1.0)\n {\n faceNorm = vec3(0.0, 1.0, 0.0);\n faceTan = vec3(1.0, 0.0, 0.0);\n faceaTan = vec3(0.0, 0.0, -1.0);\n }\n else\n {\n faceNorm = vec3(0.0, 0.0, 1.0);\n faceTan = vec3(1.0, 0.0, 0.0);\n faceaTan = vec3(0.0, 1.0, 0.0);\n }\n vec3 aPos = cornerP + faceNorm;\n\n // sampling points\n vec3 p0 = voxelPosToWorld(cornerP);\n vec3 p1 = voxelPosToWorld(aPos);\n\n // field value\n float d0 = scene(p0);\n float d1 = scene(p1);\n\n vec3 p;\n vec3 vertNorm;\n\n if (d0 * d1 > 0.0)\n {\n // no face\n p = p0;\n vertNorm = vec3(1.0, 1.0, 1.0);\n }\n else\n {\n // have a face\n if (d1 < d0)\n {\n // 0->1 is standard normal.\n // otherwise flip triangle\n if (id_Vert == 0.0)\n {\n id_Vert = 2.0;\n }\n else if (id_Vert == 2.0)\n {\n id_Vert = 0.0;\n }\n else if (id_Vert == 3.0)\n {\n id_Vert = 5.0;\n }\n else if (id_Vert == 5.0)\n {\n id_Vert = 3.0;\n }\n faceNorm *= -1.0;\n }\n\n /*\n face\n 2 4-5\n |\\ \\|\n 0-1 3\n */\n float faceSize = mix(0.45, 0.5, clamp(cos(time * .75) * 4.0 + 0.5, 0.0, 1.0));\n vec3 edgeMidP = (cornerP + aPos) * 0.5;\n vec3 faceVertP;\n if (id_Vert == 0.0)\n {\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * -faceSize;\n }\n else if (id_Vert == 1.0)\n {\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\n }\n else if (id_Vert == 2.0)\n {\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\n }\n else if (id_Vert == 3.0)\n {\n faceVertP = edgeMidP + faceTan * faceSize + faceaTan * -faceSize;\n }\n else if (id_Vert == 4.0)\n {\n faceVertP = edgeMidP + faceTan * -faceSize + faceaTan * faceSize;\n }\n else if (id_Vert == 5.0)\n {\n faceVertP = edgeMidP + faceTan * 0.5 + faceaTan * 0.5;\n }\n p = voxelPosToWorld(faceVertP);\n\n // smoothing\n vec3 sp = vertexSmooth(p);\n vertNorm = sceneNormal(p);\n\n float vmix = clamp(sin(time * 0.35) * 2.0 + 0.5, 0.0, 1.0);\n vmix = 1.;\n p = mix(p, sp, vmix);\n vertNorm = mix(faceNorm, vertNorm, vmix);\n }\n\n vec3 eye = vec3(0.0, 0.0, 3.5) * rotx(clamp(mouse.y, -0.5, 0.5) * 1.5) * roty(-clamp(mouse.x, -0.5, 0.5) * 1.5);\n // eye = vec3(0.0, 0.0, 3.0);\n mat4 viewMat = lookat(eye, vec3(0.0), vec3(0.0, 1.0, 0.0));\n mat4 pMatrix = perspectiveMatrix(60.0 * degree_to_rad, resolution.x / resolution.y);\n vec4 viewPos = (viewMat * vec4(p, 1.0));\n vec3 viewNorm = normalize((viewMat * vec4(vertNorm, 0.0)).xyz);\n\n gl_Position = (pMatrix * viewPos) * 100.2;\n gl_PointSize = 2.0;\n\n v_color = color_phong(viewPos.xyz, eye, viewNorm, 0.5 * (viewNorm + 1.) / 2.);\n }" + }, "screenshotURL": "data/images/images-gm1xerjvhglsk9ey2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vhbgo3kHochQMeb2i/art.json b/art/vhbgo3kHochQMeb2i/art.json index 1c1a5822..45cce7a6 100644 --- a/art/vhbgo3kHochQMeb2i/art.json +++ b/art/vhbgo3kHochQMeb2i/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "alejandrocamara", "avatarUrl": "https://avatars.githubusercontent.com/AlejandroCamara?s=200", - "settings": "{\"num\":4200,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define CIRCLE_SEGMENTS 20.0\\n#define PRIMITIVE_COUNT 42.0\\n#define TWO_PI radians(360.0)\\n\\nvoid main() {\\n \\n \\tfloat normalized_id = mod(vertexId, PRIMITIVE_COUNT);\\n \\n \\tfloat circle_x = floor(normalized_id / 2.0);\\n float circle_y = mod(normalized_id + 1.0, 2.0);\\n\\n float angle = circle_x / CIRCLE_SEGMENTS * radians(360.0);\\n float radius = 2.0 - circle_y;\\n\\n float circle_u = radius * cos(angle);\\n float circle_v = radius * sin(angle);\\n\\n vec2 circle_xy = vec2(circle_u, circle_v) * 0.05;\\n \\n \\t// Distancia entre los puntos\\n \\t// y numero de puntos por fila\\n \\tfloat width = 10.0;\\n \\n \\t\\n \\t// Ubicacion de los circulos\\n \\tfloat x = mod(floor(vertexId / PRIMITIVE_COUNT), width);\\t// Columna\\n \\tfloat y = floor(((vertexId / (PRIMITIVE_COUNT) )/ width));\\t// Fila\\n \\n \\t// Escala de los puntos para que quepan en la pantalla\\n \\tfloat u = x / (width - .50);\\n \\tfloat v = y / (width - .50);\\n \\n \\n \\t// Movimiento en onda\\n \\tfloat xOffset = sin(time + y * 0.2) * 0.1;\\n \\tfloat yOffset = cos(time + x * 0.3) * 0.2;\\n \\n \\t//float xOffset = 0.0;\\n \\t//float yOffset = 0.0;\\n \\n \\t// Coordenadas finales\\n \\tfloat ux = u * 2.0 - 1.0 + xOffset;\\n \\tfloat vy = v * 2.0 - 1.0 + yOffset;\\n \\t\\n \\tvec2 xy = vec2(ux, vy) * 1.2;\\n \\n \\t// xy = vec2(x, y) / 5.0;\\n \\n\\tgl_Position = vec4(circle_xy + xy, 0.0, 1.0);\\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n \\tgl_PointSize = 5.0;\\n}\"}", + "settings": { + "num": 4200, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define CIRCLE_SEGMENTS 20.0\n#define PRIMITIVE_COUNT 42.0\n#define TWO_PI radians(360.0)\n\nvoid main() {\n \n \tfloat normalized_id = mod(vertexId, PRIMITIVE_COUNT);\n \n \tfloat circle_x = floor(normalized_id / 2.0);\n float circle_y = mod(normalized_id + 1.0, 2.0);\n\n float angle = circle_x / CIRCLE_SEGMENTS * radians(360.0);\n float radius = 2.0 - circle_y;\n\n float circle_u = radius * cos(angle);\n float circle_v = radius * sin(angle);\n\n vec2 circle_xy = vec2(circle_u, circle_v) * 0.05;\n \n \t// Distancia entre los puntos\n \t// y numero de puntos por fila\n \tfloat width = 10.0;\n \n \t\n \t// Ubicacion de los circulos\n \tfloat x = mod(floor(vertexId / PRIMITIVE_COUNT), width);\t// Columna\n \tfloat y = floor(((vertexId / (PRIMITIVE_COUNT) )/ width));\t// Fila\n \n \t// Escala de los puntos para que quepan en la pantalla\n \tfloat u = x / (width - .50);\n \tfloat v = y / (width - .50);\n \n \n \t// Movimiento en onda\n \tfloat xOffset = sin(time + y * 0.2) * 0.1;\n \tfloat yOffset = cos(time + x * 0.3) * 0.2;\n \n \t//float xOffset = 0.0;\n \t//float yOffset = 0.0;\n \n \t// Coordenadas finales\n \tfloat ux = u * 2.0 - 1.0 + xOffset;\n \tfloat vy = v * 2.0 - 1.0 + yOffset;\n \t\n \tvec2 xy = vec2(ux, vy) * 1.2;\n \n \t// xy = vec2(x, y) / 5.0;\n \n\tgl_Position = vec4(circle_xy + xy, 0.0, 1.0);\n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n \tgl_PointSize = 5.0;\n}" + }, "screenshotURL": "data/images/images-s1qm4gmzq09mt4tvt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vhkrDTrknFZgdQvw5/art.json b/art/vhkrDTrknFZgdQvw5/art.json index 726a1718..f41dc201 100644 --- a/art/vhkrDTrknFZgdQvw5/art.json +++ b/art/vhkrDTrknFZgdQvw5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":72761,\"mode\":\"TRIANGLES\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2,0.2,0.2,1],\"shader\":\"/*\\n\\n\\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \\n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \\n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n}\\n\\n\\nvoid GenerateCubeVertex( \\n const float fCubeId, \\n const float vertexIndex, \\n const vec4 vCubeCol, \\n const vec3 vCameraPos, \\n out vec3 outSceneVertex )\\n{ \\n GetCubeVertex( vertexIndex, outSceneVertex);\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\n\\nvoid GetCubePosition(\\n float fVertexId, \\n float fCubeId, \\n out mat4 mat, \\n out vec4 vCubeCol)\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n float posId = floor(fCubeId / 2.);\\n float across = 32.;\\n float down = 40.;\\n float u2 = mod(posId, across);\\n float v2 = floor(posId / across);\\n float u = u2 / across;\\n float v = v2 / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n \\n float uBlock = floor(u2 / 4.);\\n float vBlock = floor(v2 / 4.);\\n\\n float uu = abs(m1p1(u));\\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\\n float glow = mod(fCubeId, 2.);\\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\\n float t = p1m1(sin(tm));\\n float st = p1m1(sin(tm + -0.6));\\n float tt = 1. - t;\\n float fScale = st * mix(1., 1.02, glow);\\n \\n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \\n float axisId = floor(fVertexId / 12.);\\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(\\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \\n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\\n \\n vCubeCol.xyz = vec3(0,0,0);\\n}\\n\\n\\nvoid main()\\n{ \\n float cameraTime = time * 0.1;\\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\\n vec3 vCameraTarget = vec3(0);\\n \\tvec3 vCameraUp = vec3(0.0, 1, 0);\\n \\n \\tfloat vertexIndex = vertexId;\\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n mat4 mCube;\\n vec4 vCubeCol;\\n vec3 vCubePos;\\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\\n\\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\\n\\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\\n \\n \\n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n mat *= mCube;\\n \\n gl_Position = mat * vec4(vCubePos, 1);\\n\\n \\n float glow = mod(fCubeId, 2.);\\n \\n vec4 color = vec4(0,1,0,0.9);\\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\\n \\tvec4 vFinalColor = mix(vec4(1. - pow(snd, 25.0),1,1,1), color, glow);\\n \\n \\n \\tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a)*-1.+1.;\\n gl_PointSize = 2.;\\n}\"}", + "settings": { + "num": 72761, + "mode": "TRIANGLES", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2, + 0.2, + 0.2, + 1 + ], + "shader": "/*\n\n\n## ## ######## ######## ######## ######## ## ## ###### ## ## ### ######## ######## ######## ### ######## ######## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n## ## ###### ######## ## ###### ### ###### ######### ## ## ## ## ###### ######## ## ## ######## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ######### ## ## ## ## ## ######### ## ## ## \n ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## \n ### ######## ## ## ## ######## ## ## ###### ## ## ## ## ######## ######## ## ## ## ## ## ## ## \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define PI radians( 180.0 )\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, out vec3 vWorldPos )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n}\n\n\nvoid GenerateCubeVertex( \n const float fCubeId, \n const float vertexIndex, \n const vec4 vCubeCol, \n const vec3 vCameraPos, \n out vec3 outSceneVertex )\n{ \n GetCubeVertex( vertexIndex, outSceneVertex);\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\n\nvoid GetCubePosition(\n float fVertexId, \n float fCubeId, \n out mat4 mat, \n out vec4 vCubeCol)\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n float posId = floor(fCubeId / 2.);\n float across = 32.;\n float down = 40.;\n float u2 = mod(posId, across);\n float v2 = floor(posId / across);\n float u = u2 / across;\n float v = v2 / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n \n float uBlock = floor(u2 / 4.);\n float vBlock = floor(v2 / 4.);\n\n float uu = abs(m1p1(u));\n float ur = uu; //cos(PI * -0.25) * u + sin(PI * -0.25) * v;\n float vr = v; //sin(PI * -0.25) * v - cos(PI * -0.25) * u;\n float glow = mod(fCubeId, 2.);\n float tm = time * 0.9 + hash(posId * 0.797) * PI * 2.;\n float t = p1m1(sin(tm));\n float st = p1m1(sin(tm + -0.6));\n float tt = 1. - t;\n float fScale = st * mix(1., 1.02, glow);\n \n vCubeOrigin.x = m1p1(hash(posId)) * 2. * tt;\n vCubeOrigin.y = m1p1(hash(posId * 0.123)) * 2. * tt;\n vCubeOrigin.z = m1p1(hash(posId * 0.347)) * 2. * tt; \n float axisId = floor(fVertexId / 12.);\n vec3 glowOff = vec3(0.97, 0.97, 0.97);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(\n fScale * mix(1., glowOff.x, glow * at(axisId, 1.)), \n fScale * mix(1., glowOff.y, glow * at(axisId, 2.)),\n fScale * mix(1., glowOff.z, glow * at(axisId, 0.))));\n \n vCubeCol.xyz = vec3(0,0,0);\n}\n\n\nvoid main()\n{ \n float cameraTime = time * 0.1;\n vec3 vCameraPos = vec3(sin(time * 0.137) * 5., sin(time * 0.1) * 3., cos(time * 0.137) * 5.);\n vec3 vCameraTarget = vec3(0);\n \tvec3 vCameraUp = vec3(0.0, 1, 0);\n \n \tfloat vertexIndex = vertexId;\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n mat4 mCube;\n vec4 vCubeCol;\n vec3 vCubePos;\n float snd = texture2D(sound, vec2(hash(fCubeId) * 0.125, 0)).a;\n\n GetCubePosition( fCubeVertex, fCubeId, mCube, vCubeCol);\n\n GenerateCubeVertex( fCubeId, fCubeVertex, vCubeCol, vCameraPos, vCubePos );\n \n \n mat4 mat = persp(radians(65.), resolution.x / resolution.y, 0.1, 1000.);\n mat *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n mat *= mCube;\n \n gl_Position = mat * vec4(vCubePos, 1);\n\n \n float glow = mod(fCubeId, 2.);\n \n vec4 color = vec4(0,1,0,0.9);\n color = vec4(0,0,0,1); //hsv2rgb(vec3(mix(0.6, 0.7, hash(fCubeId)), 1.3, 0.)), 1);\n \tvec4 vFinalColor = mix(vec4(1. - pow(snd, 25.0),1,1,1), color, glow);\n \n \n \tv_color = vec4(vFinalColor.xyz * vFinalColor.a, vFinalColor.a)*-1.+1.;\n gl_PointSize = 2.;\n}" + }, "screenshotURL": "data/images/images-2nna6cjnhqfptxl1p-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vhrfGAjQ76HJwApnJ/art.json b/art/vhrfGAjQ76HJwApnJ/art.json index 7c659289..cba0aa02 100644 --- a/art/vhrfGAjQ76HJwApnJ/art.json +++ b/art/vhrfGAjQ76HJwApnJ/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "jeminshin2", "avatarUrl": "https://avatars.githubusercontent.com/JeminShin2?s=200", - "settings": "{\"num\":3000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : jemin.Shin\\n//Exerciese : Circles from Triangles\\n//Course CS250\\n//Date : 2023 Spring\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(time + abs(ca) * 5.);\\n mat *= rotZ(time + abs(cd) * 6.);\\n mat *= uniformScale(0.03);\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = abs(ca * cd) * 2.;\\n float sat = mix(1., 0., abs(ca));\\n float val = mix(1., 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 1.0 + 0.5), 1);\\n}\\n#endif\\n\\n#if 0\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 2.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = 1.0; texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n mat *= rotZ(gx / gAcross * PI * 2.);\\n mat *= rotY(PI * 0.5);\\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\\n mat *= uniformScale(0.05);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.1;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 3000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : jemin.Shin\n//Exerciese : Circles from Triangles\n//Course CS250\n//Date : 2023 Spring\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 0.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(time + abs(ca) * 5.);\n mat *= rotZ(time + abs(cd) * 6.);\n mat *= uniformScale(0.03);\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = abs(ca * cd) * 2.;\n float sat = mix(1., 0., abs(ca));\n float val = mix(1., 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 1.0 + 0.5), 1);\n}\n#endif\n\n#if 0\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 2.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd2 = 1.0; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = 1.0; texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= rotZ(time * 0.01 * gy * 0. + PI * 0.5);\n mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n mat *= rotZ(gx / gAcross * PI * 2.);\n mat *= rotY(PI * 0.5);\n mat *= trans(vec3(0, 0, 1. - (1. - gy / gDown) * .4));\n mat *= uniformScale(0.05);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.1;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-w1ggu41s54iybywgk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/viP5QEyt8HBLNEEbD/art.json b/art/viP5QEyt8HBLNEEbD/art.json index 1e2cff61..3cae4d59 100644 --- a/art/viP5QEyt8HBLNEEbD/art.json +++ b/art/viP5QEyt8HBLNEEbD/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "cjensen93", "avatarUrl": "https://secure.gravatar.com/avatar/0df4239ac208a0c9696c1edd2e895cee?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/100gecs/ringtone-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.06666666666666667,0.058823529411764705,0.4117647058823529,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n\\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n \\tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n \\tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n \\treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n\\n}\\n\\n\\nvoid main(){\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\\n\\n float ux = u * 2.0 - 1.0 + xOff;\\n float uy = v * 2.0 - 1.0 + yOff;\\n \\n \\n vec2 xy = vec2(ux, uy) * 1.3;\\n \\n float sound = texture2D(sound, vec2(u * 0.125,0.0)).a;\\n\\n \\n gl_Position = vec4(xy,0.0,1.0);\\n \\n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = sound * 30.0 + sOff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = 1.0;//u * 0.1 + sin(time + v * 20.0) * 0.05;\\n float sat = 1.0;\\n float value = pow(sound, 4.0);//sin(time + v * u * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/100gecs/ringtone-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.06666666666666667, + 0.058823529411764705, + 0.4117647058823529, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n\tc = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n \tvec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n \tvec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n \treturn c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n\n}\n\n\nvoid main(){\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOff = 0.;//sin(time + y * 0.2) * 0.1;\n float yOff = 0.;//sin(time + x * 0.3) * 0.2;\n\n float ux = u * 2.0 - 1.0 + xOff;\n float uy = v * 2.0 - 1.0 + yOff;\n \n \n vec2 xy = vec2(ux, uy) * 1.3;\n \n float sound = texture2D(sound, vec2(u * 0.125,0.0)).a;\n\n \n gl_Position = vec4(xy,0.0,1.0);\n \n float sOff =0.;// sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = sound * 30.0 + sOff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = 1.0;//u * 0.1 + sin(time + v * 20.0) * 0.05;\n float sat = 1.0;\n float value = pow(sound, 4.0);//sin(time + v * u * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, value)), 1.0);\n}" + }, "screenshotURL": "data/images/images-eg9xchpu95muigbrt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vixRSiPMAiZ6AmgNA/art.json b/art/vixRSiPMAiZ6AmgNA/art.json index 00c09245..ec1d215f 100644 --- a/art/vixRSiPMAiZ6AmgNA/art.json +++ b/art/vixRSiPMAiZ6AmgNA/art.json @@ -27,7 +27,19 @@ "name": "Simple Fractal", "private": false, "username": "P_Malin", - "settings": "{\"num\":65536,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Simple Fractal - @P_Malin\\n \\nvoid main() \\n{ \\n \\tfloat fRotation = time * 0.5;\\n \\tvec2 vTranslation = vec2( 0.2, 0.2 );\\n \\tfloat fScale = 0.6;\\n\\n \\tfloat fSinRot = sin(fRotation);\\n \\tfloat fCosRot = cos(fRotation);\\n\\n \\tmat3 m = mat3( fCosRot * fScale, fSinRot * fScale, vTranslation.x, -fSinRot * fScale, fCosRot * fScale, vTranslation.y, 0.0, 0.0, 1.0 );\\n \\n \\tvec2 vPos = vec2( 0.0 );\\n \\tvec2 vMin = vec2( 100.0 ); \\t\\n \\tfloat fPassId = vertexId;\\n \\n \\tfor ( int i=0; i<8; i++ )\\n { \\n \\tvPos = (vec3(vPos, 1.0) * m).xy;\\n\\n \\tfPassId = fPassId / 4.0;\\n \\n \\tif ( fract( fPassId * 2.0 ) < 0.5 ) vPos.x = -vPos.x;\\n \\tif ( fract( fPassId ) < 0.5 ) vPos.y = -vPos.y;\\n \\tfPassId = floor( fPassId );\\n \\n \\tvMin = min( vMin, abs( vPos ) );\\n }\\n \\n \\tgl_PointSize = 6.0;\\n \\tgl_Position = vec4(vPos * vec2( 1.0, resolution.x / resolution.y) , 1.0/vertexId, 1);\\n\\n \\tvec3 vColor;\\n \\tvColor.x = sin( vMin.x * 10.0 + time * 1.234 ) * 0.5 + 0.5;\\n \\tvColor.y = sin( vMin.y * 10.0 + time * 2.345 ) * 0.5 + 0.5;\\n \\tvColor.z = sin( (vMin.x + vMin.y) * 5.0 + time * 3.456 ) * 0.5 + 0.5;\\n \\n \\tvColor = normalize(vColor);\\n \\n \\tvColor = 1.0 - exp2( vColor * -length( vMin ) * 3.0 );\\n \\tv_color = vec4( vColor, 0.0 );\\n}\"}", + "settings": { + "num": 65536, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Simple Fractal - @P_Malin\n \nvoid main() \n{ \n \tfloat fRotation = time * 0.5;\n \tvec2 vTranslation = vec2( 0.2, 0.2 );\n \tfloat fScale = 0.6;\n\n \tfloat fSinRot = sin(fRotation);\n \tfloat fCosRot = cos(fRotation);\n\n \tmat3 m = mat3( fCosRot * fScale, fSinRot * fScale, vTranslation.x, -fSinRot * fScale, fCosRot * fScale, vTranslation.y, 0.0, 0.0, 1.0 );\n \n \tvec2 vPos = vec2( 0.0 );\n \tvec2 vMin = vec2( 100.0 ); \t\n \tfloat fPassId = vertexId;\n \n \tfor ( int i=0; i<8; i++ )\n { \n \tvPos = (vec3(vPos, 1.0) * m).xy;\n\n \tfPassId = fPassId / 4.0;\n \n \tif ( fract( fPassId * 2.0 ) < 0.5 ) vPos.x = -vPos.x;\n \tif ( fract( fPassId ) < 0.5 ) vPos.y = -vPos.y;\n \tfPassId = floor( fPassId );\n \n \tvMin = min( vMin, abs( vPos ) );\n }\n \n \tgl_PointSize = 6.0;\n \tgl_Position = vec4(vPos * vec2( 1.0, resolution.x / resolution.y) , 1.0/vertexId, 1);\n\n \tvec3 vColor;\n \tvColor.x = sin( vMin.x * 10.0 + time * 1.234 ) * 0.5 + 0.5;\n \tvColor.y = sin( vMin.y * 10.0 + time * 2.345 ) * 0.5 + 0.5;\n \tvColor.z = sin( (vMin.x + vMin.y) * 5.0 + time * 3.456 ) * 0.5 + 0.5;\n \n \tvColor = normalize(vColor);\n \n \tvColor = 1.0 - exp2( vColor * -length( vMin ) * 3.0 );\n \tv_color = vec4( vColor, 0.0 );\n}" + }, "screenshotURL": "data/images/images-qx88yqxi4r69da57f-thumbnail.jpg", "views": { "$numberInt": "530" diff --git a/art/vmttH6ixNxK3G3sTG/art.json b/art/vmttH6ixNxK3G3sTG/art.json index c9cdf62f..a1cc970f 100644 --- a/art/vmttH6ixNxK3G3sTG/art.json +++ b/art/vmttH6ixNxK3G3sTG/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5725490196078431,0.2549019607843137,0.7450980392156863,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n#define width 256.0\\n#define height 384.0\\n\\nfloat plasma(vec2 pos, float w, float h)\\n{\\n float c = 0.0;\\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\\n float newRe = 1.5 * (pos.x - w / 2.0) / (0.5 * w);\\n float newIm = (pos.y - h / 2.0) / (0.5 * h);\\n float oldRe;\\n float oldIm;\\n float j = 0.0;\\n for(int i = 0; i < 128; i++)\\n {\\n j+=1.0;\\n oldRe = newRe;\\n oldIm = newIm;\\n newRe = oldRe * oldRe - oldIm * oldIm + 0.4;\\n newIm = 2.0 * oldRe * oldIm + sin(time/1.0);\\n if((newRe * newRe + newIm * newIm) > 4.0) break;\\n }\\n return j/64.0;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\\n \\n gl_Position = vec4(px, py, 0, 1);\\n gl_PointSize = 8.0;\\n\\n float c = plasma(vec2(px+0.5, py+0.5)*100.0,px+w/2.0,py+h/2.0);\\n v_color = vec4(c, 4.0 * c, 1.0 * c, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5725490196078431, + 0.2549019607843137, + 0.7450980392156863, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n#define width 256.0\n#define height 384.0\n\nfloat plasma(vec2 pos, float w, float h)\n{\n float c = 0.0;\n c = sin(sin(pos.x) + sin(1.4 * pos.y) + sin(3.0 * pos.x + pos.y + 3.0 * time) + sin(pos.x + sin(pos.y + 2.0 * time))) + (sin(pos.x * pos.y - 3.0 * time) * 0.5 + 0.25);\n float newRe = 1.5 * (pos.x - w / 2.0) / (0.5 * w);\n float newIm = (pos.y - h / 2.0) / (0.5 * h);\n float oldRe;\n float oldIm;\n float j = 0.0;\n for(int i = 0; i < 128; i++)\n {\n j+=1.0;\n oldRe = newRe;\n oldIm = newIm;\n newRe = oldRe * oldRe - oldIm * oldIm + 0.4;\n newIm = 2.0 * oldRe * oldIm + sin(time/1.0);\n if((newRe * newRe + newIm * newIm) > 4.0) break;\n }\n return j/64.0;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 2.0);\n \n gl_Position = vec4(px, py, 0, 1);\n gl_PointSize = 8.0;\n\n float c = plasma(vec2(px+0.5, py+0.5)*100.0,px+w/2.0,py+h/2.0);\n v_color = vec4(c, 4.0 * c, 1.0 * c, 1);\n}" + }, "screenshotURL": "data/images/images-so5wax3s8iqnb8gru-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vn7aCRpFmjs6n8XNG/art.json b/art/vn7aCRpFmjs6n8XNG/art.json index 302b50b8..e725d15e 100644 --- a/art/vn7aCRpFmjs6n8XNG/art.json +++ b/art/vn7aCRpFmjs6n8XNG/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":35908,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/plu-collective/circuitry\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Lesson 05a\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n \\n return vec2(x, y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, \\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.0);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 3.1, oddSlice);\\n \\n sc *= 20. / across;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time * 0.15);\\n mat *= trans(vec3(ux, vy, 0) * 1.4);\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = 1.;//mix(0.5, 1., pump);\\n float val = 1.;mix(.4, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 1. / 3.;\\n val += oddSlice * pump;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 35908, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/plu-collective/circuitry", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Lesson 05a\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n \n return vec2(x, y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId, \n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.0);\n float oddSlice = mod(sliceId, 2.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 3.1, oddSlice);\n \n sc *= 20. / across;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time * 0.15);\n mat *= trans(vec3(ux, vy, 0) * 1.4);\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = 1.;//mix(0.5, 1., pump);\n float val = 1.;mix(.4, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 1. / 3.;\n val += oddSlice * pump;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-ux591q98n3p42ecd1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vncmkDKkFydMJjG86/art.json b/art/vncmkDKkFydMJjG86/art.json index e9f9da8a..e6c479c3 100644 --- a/art/vncmkDKkFydMJjG86/art.json +++ b/art/vncmkDKkFydMJjG86/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "bohushvitali", "avatarUrl": "https://avatars.githubusercontent.com/bohushvitali?s=200", - "settings": "{\"num\":14224,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.1;\\n float yoff = sin(time + x * 0.2) * 0.3;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,1,0,1);\\n \\n \\n \\n}\"}", + "settings": { + "num": 14224, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.1;\n float yoff = sin(time + x * 0.2) * 0.3;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n gl_Position = vec4(ux, vy, 0, 1);\n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,1,0,1);\n \n \n \n}" + }, "screenshotURL": "data/images/images-o25fumyct77qq6u6t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vqBN6kLpxjBHGRvz8/art.json b/art/vqBN6kLpxjBHGRvz8/art.json index e1a8932a..409812dc 100644 --- a/art/vqBN6kLpxjBHGRvz8/art.json +++ b/art/vqBN6kLpxjBHGRvz8/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//[commercial] \\n\\n//Another K Machine exposed shader\\n//See it in action in the K Machine v2 on https://vimeo.com/217012333\\n//the 'K beginning' comments allows the K Machine to recognize \\n//and build adapted events controllers\\n//This shader can be copied in a text file with .glsl extension and\\n//uploaded to the K Machine. \\n//For more instructions for K Machine compliance see the doc on\\n//http://kolargon.com/KMachineV2Doc/KMachineV2Documentation.html\\n//More about the K Machine v2\\n//http://kolargones.net/wpkolargon/2017/05/05/k-machine-v-2-0/\\n//Note the part between 'for vsa' and 'end for vsa' could be skipped\\n//as the K Machine has it's own relLoopProgress float parameter\\n//corresponding to the progression in the selected loop\\n\\n//[/commercial]\\n\\n//KDrawmode=GL_TRIANGLES\\n#define parameter0 1.//KParameter0 1.>>8.\\n#define parameter1 -0.2//KParameter1 -1.>>1.\\n#define parameter2 -1.//KParameter2 -1.>>1.\\n#define parameter3 0.//KParameter3 0.>>12.\\n#define parameter4 2.//KParameter4 0.>>2.\\n#define parameter5 1.//KParameter5 0.1>>1.5\\n#define parameter6 0.3//KParameter6 0.>>1.\\n#define parameter7 0.//KParameter7 0.>>10.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n#define SYMMETRY_H 0\\n#define SYMMETRY_V 0\\n#define COLOR_MODE 0\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\\n{\\n \\n \\n \\n \\n vec4 result = vec4(0., 0.,-1., 1.);\\n \\n \\n float localVertexId = _vertexId - _startVertexId;\\n \\n if(localVertexId<1.)\\n {\\n result.xy = _letter[0].xy;\\n }\\n else\\n \\n if(localVertexId<2.)\\n {\\n result.xy = _letter[1].xy;\\n }\\n \\n else\\n if(localVertexId<3.)\\n {\\n result.xy = _letter[2].xy;\\n }\\n else //2nd triangle\\n if(localVertexId<4.)\\n {\\n result.xy = _letter[3].xy;\\n }\\n else\\n if(localVertexId<5.)\\n {\\n result.xy = _letter[4].xy;\\n }\\n else\\n if(localVertexId<6.)\\n {\\n result.xy = _letter[5].xy;\\n }\\n else\\n if(localVertexId<7.)//3 eme triangle\\n {\\n result.xy = _letter[6].xy;\\n }\\n else\\n if(localVertexId<8.)\\n {\\n result.xy = _letter[7].xy;\\n }\\n else\\n if(localVertexId<9.)\\n {\\n result.xy = _letter[8].xy;\\n \\n }\\n \\n else\\n if(localVertexId<10.)//4eme triangle\\n {\\n result.xy = _letter[9].xy;\\n \\n }\\n else\\n if(localVertexId<11.)\\n {\\n result.xy = _letter[10].xy;\\n \\n }\\n \\n else\\n if(localVertexId<12.)\\n {\\n result.xy = _letter[11].xy;\\n \\n }\\n else\\n if(localVertexId<13.)\\n {\\n result.xy = _letter[12].xy;\\n \\n }\\n else\\n if(localVertexId<14.)\\n {\\n result.xy = _letter[13].xy;\\n \\n }\\n else\\n if(localVertexId<15.)\\n {\\n result.xy = _letter[14].xy;\\n \\n }\\n else\\n if(localVertexId<16.)\\n {\\n result.xy = _letter[15].xy;\\n \\n }\\n else\\n if(localVertexId<17.)\\n {\\n result.xy = _letter[16].xy;\\n \\n }\\n else\\n if(localVertexId<18.)\\n {\\n result.xy = _letter[17].xy;\\n \\n }\\n result.xy+=_pos;\\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\\n result.xyz =rotZ(result.xyz, _rotation);\\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\\n result *= uniformScale(_scale);\\n \\n \\n return result.xyz;\\n}\\n\\n\\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\\n{\\n vec2 finalPos = _pos;\\n \\n \\n vec2 additionalPos = vec2(0.,0.);\\n \\n float transfoMode = floor(parameter3);\\n \\n \\n //additionalPos.x = _relLetterTimeProgress*0.5;\\n if(transfoMode<1.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n else\\n if(transfoMode<2.)\\n {\\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<3.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<4.)\\n {\\n additionalPos = -finalPos;\\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\\n \\n additionalPos.x+= m.x;\\n additionalPos.y+= m.y;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<5.)\\n {\\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<6.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<7.)\\n {\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\\n finalPos+= additionalPos;\\n }\\n \\n }\\n else\\n if(transfoMode<8.)\\n {\\n additionalPos = -finalPos;\\n if(_selectedShape == _shapeId)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n if(transfoMode<9.)\\n {\\n additionalPos = -finalPos;\\n \\n if(mod(_shapeId,2.)<1.)\\n {\\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\\n \\n }\\n finalPos+= additionalPos;\\n }\\n else\\n \\n if(transfoMode<10.)\\n {\\n //if(_selectedShape == _shapeId)\\n {\\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\\n additionalPos.y = m.x*parameter6*2.;\\n finalPos+= additionalPos;\\n }\\n }\\n \\n else\\n \\n if(transfoMode<11.)\\n {\\n additionalPos = -finalPos;\\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\\n finalPos+= additionalPos;\\n }\\n \\n return finalPos;\\n}\\n\\n\\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\\n{\\n float finalRot = _rotation;\\n \\n float additionalRotation = 0.;\\n \\n float transfoMode = floor(parameter3);\\n \\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n else\\n if(transfoMode<1.)\\n {\\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\\n \\n }\\n }\\n \\n \\n finalRot+= additionalRotation;\\n \\n /*\\n float additionalRotation = 0.;\\n \\n if(selectedLetterIndex == shapeId)\\n {\\n additionalRotation = 2.*PI*relLetterTimeProgress;\\n }\\n \\n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\\n */\\n \\n return finalRot;\\n}\\n\\n\\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\\n{\\n vec2 finalCenter = _center;\\n \\n \\n /*\\n vec2 additionalCenter = vec2(0.,0.);\\n \\n \\n if(_selectedShape == _shapeId)\\n {\\n additionalCenter.x = _relLetterTimeProgress*0.5;\\n additionalCenter.y = _relLetterTimeProgress*0.5;\\n }\\n \\n finalCenter+= additionalCenter;\\n */\\n \\n return finalCenter;\\n}\\n\\n#define elementPerShapeLetterK 18.\\n\\n#define defaultRotationForShapeLetterK 0.13\\n#define defaultRotationForShapeLetterM - 0.09\\n#define defaultRotationForShapeLetterN 0.04\\n#define defaultRotationForShapeLetterA 0.1\\n#define defaultRotationForShapeLetterC - 0.05\\n#define defaultRotationForShapeLetterE - 0.03\\n#define defaultRotationForShapeLetterH 0.04\\n#define defaultRotationForShapeLetterI - 0.02\\n\\n\\n#define shapeNumber 8.\\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\\n\\nvoid main() {\\n \\n \\n vec3 color = vec3(1.);\\n \\n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\\n float _junctionY = 0.5 +parameter4*sndFactor/10.;\\n \\n float _barWidth = 0.2 ;// + parameter4*sndFactor/100.;\\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\\n \\n float shapeId = 0.;\\n \\n vec2 letterK[18];\\n letterK[0] = vec2(0.,0.);\\n letterK[1] = vec2(0.,1.);\\n letterK[2] = vec2(_barWidth,1.);\\n letterK[3] = vec2(0.,0.0);\\n letterK[4] = vec2(_barWidth,1.);\\n letterK[5] = vec2(_barWidth,0.);\\n letterK[6] = vec2(_barWidth,_junctionY);\\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\\n letterK[8] = vec2(_secondVertY,1.);\\n letterK[9] = vec2(_barWidth,_junctionY);\\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\\n letterK[11] = vec2(_secondVertY,0.);\\n letterK[12] = vec2(_secondVertY,0.);\\n letterK[13] = vec2(_secondVertY,0.);\\n letterK[14] = vec2(_secondVertY,0.);\\n letterK[15] = vec2(_secondVertY,0.);\\n letterK[16] = vec2(_secondVertY,0.);\\n letterK[17] = vec2(_secondVertY,0.);\\n \\n vec2 letterM[18];\\n letterM[0] = vec2(0.,0.);\\n letterM[1] = vec2(0.,1.);\\n letterM[2] = vec2(_barWidth,1.);\\n letterM[3] = vec2(0.,0.0);\\n letterM[4] = vec2(_barWidth,1.);\\n letterM[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterM[7] = vec2(_barWidth,1.);\\n letterM[8] = vec2(_barWidth*2.,_junctionY);\\n letterM[9] = vec2(_barWidth*2.,_junctionY);\\n letterM[10] = vec2((_barWidth*3.),1.);\\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\\n letterM[12] = vec2(_barWidth*3.,1.);\\n letterM[13] = vec2(_barWidth*4.,1.);\\n letterM[14] = vec2(_barWidth*3.,0.);\\n letterM[15] = vec2(_barWidth*3.,0.);\\n letterM[16] = vec2(_barWidth*4.,1.);\\n letterM[17] = vec2(_barWidth*4.,0.);\\n \\n \\n vec2 letterN[18];\\n letterN[0] = vec2(0.,0.);\\n letterN[1] = vec2(0.,1.);\\n letterN[2] = vec2(_barWidth,1.);\\n letterN[3] = vec2(0.,0.0);\\n letterN[4] = vec2(_barWidth,1.);\\n letterN[5] = vec2(_barWidth,0.);\\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\\n letterN[7] = vec2(_barWidth,1.);\\n letterN[8] = vec2(_barWidth*2.,_junctionY);\\n letterN[9] = vec2(_barWidth*2.,1.);\\n letterN[10] = vec2(_barWidth*3.,1.);\\n letterN[11] = vec2(_barWidth*2.,0.);\\n \\n letterN[12] = vec2(_barWidth*2.,0.);\\n letterN[13] = vec2(_barWidth*3.,1.);\\n letterN[14] = vec2(_barWidth*3.,0.);\\n letterN[15] = vec2(_barWidth*3.,0.);\\n \\n letterN[16] = vec2(_barWidth*3.,0.);\\n letterN[17] = vec2(_barWidth*3.,0.);\\n \\n \\n vec2 letterA[18];\\n letterA[0] = vec2(0.,0.);\\n letterA[1] = vec2(_barWidth,0.);\\n letterA[2] = vec2(_barWidth*2.,1.);\\n letterA[3] = vec2(_barWidth*4.,0.0);\\n letterA[4] = vec2(_barWidth*2.,1.);\\n letterA[5] = vec2(_barWidth*3.,0.);\\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\\n letterA[8] = vec2(_barWidth*3.,_junctionY);\\n letterA[9] = vec2(_barWidth*3.,_junctionY);\\n letterA[10] = vec2(_barWidth*3.,_junctionY);\\n letterA[11] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[12] = vec2(_barWidth*3.,_junctionY);\\n letterA[13] = vec2(_barWidth*3.,_junctionY);\\n letterA[14] = vec2(_barWidth*3.,_junctionY);\\n letterA[15] = vec2(_barWidth*3.,_junctionY);\\n \\n letterA[16] = vec2(_barWidth*3.,_junctionY);\\n letterA[17] = vec2(_barWidth*3.,_junctionY);\\n \\n \\n vec2 letterE[18];\\n letterE[0] = vec2(0.,0.);\\n letterE[1] = vec2(0.,1.);\\n letterE[2] = vec2(_barWidth,1.);\\n letterE[3] = vec2(0.,0.0);\\n letterE[4] = vec2(_barWidth,1.);\\n letterE[5] = vec2(_barWidth,0.);\\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\\n letterE[7] = vec2(_barWidth,1.);\\n letterE[8] = vec2(_barWidth*3.,1.);\\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\\n letterE[10] = vec2(_barWidth,0.);\\n letterE[11] = vec2(_barWidth*3.,0.);\\n letterE[12] = vec2(_barWidth,_junctionY);\\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\\n \\n \\n vec2 letterC[18];\\n letterC[0] = vec2(0.,0.);\\n letterC[1] = vec2(0.,1.);\\n letterC[2] = vec2(_barWidth,1.);\\n letterC[3] = vec2(0.,0.0);\\n letterC[4] = vec2(_barWidth,1.);\\n letterC[5] = vec2(_barWidth,0.);\\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\\n letterC[7] = vec2(_barWidth,1.);\\n letterC[8] = vec2(_barWidth*3.,1.);\\n letterC[9] = vec2(_barWidth,0.);\\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\\n letterC[11] = vec2(_barWidth*3.,0.);\\n letterC[12] = vec2(_barWidth*3.,0.);\\n letterC[13] = vec2(_barWidth*3.,0.);\\n letterC[14] = vec2(_barWidth*3.,0.);\\n letterC[15] = vec2(_barWidth*3.,0.);\\n letterC[16] = vec2(_barWidth*3.,0.);\\n letterC[17] = vec2(_barWidth*3.,0.);\\n \\n vec2 letterH[18];\\n letterH[0] = vec2(0.,0.);\\n letterH[1] = vec2(0.,1.);\\n letterH[2] = vec2(_barWidth,1.);\\n letterH[3] = vec2(0.,0.0);\\n letterH[4] = vec2(_barWidth,1.);\\n letterH[5] = vec2(_barWidth,0.);\\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\\n letterH[8] = vec2(_barWidth*2.,_junctionY);\\n letterH[9] = vec2(_barWidth*2.,_junctionY);\\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\\n letterH[12] = vec2(_barWidth*3.,1.);\\n letterH[13] = vec2(_barWidth*4.,1.);\\n letterH[14] = vec2(_barWidth*3.,0.);\\n letterH[15] = vec2(_barWidth*3.,0.);\\n letterH[16] = vec2(_barWidth*4.,1.);\\n letterH[17] = vec2(_barWidth*4.,0.);\\n \\n vec2 letterI[18];\\n letterI[0] = vec2(0.,0.);\\n letterI[1] = vec2(0.,_junctionY+_barWidth);\\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[3] = vec2(0.,0.0);\\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\\n letterI[6] = vec2(0.,1.-_barWidth);\\n letterI[7] = vec2(0.,1.);\\n letterI[8] = vec2(_barWidth,1.-_barWidth);\\n letterI[9] = vec2(_barWidth,1.-_barWidth);\\n letterI[10] = vec2(0.,1.);\\n letterI[11] = vec2(_barWidth,1.);\\n letterI[12] = vec2(_barWidth,1.);\\n letterI[13] = vec2(_barWidth,1.);\\n letterI[14] = vec2(_barWidth,1.);\\n letterI[15] = vec2(_barWidth,1.);\\n letterI[16] = vec2(_barWidth,1.);\\n letterI[17] = vec2(_barWidth,1.);\\n \\n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\\n \\n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\\n \\n finalVertexId = min(maxNumberOfVertices,vertexId);\\n \\n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\\n \\n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\\n //float relMetaShapeId = metaShapeId/256.;\\n \\n float masterScale = parameter5;//parameter6;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n \\n vec2 letterPos = vec2(0.,0.);\\n \\n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\\n \\n float scaleK = 0.4*masterScale;\\n float scale = 0.2*masterScale;\\n float startPosK = parameter2;\\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\\n \\n vec2 shapeCenter = vec2(0.,0.5);\\n \\n //for vsa\\n \\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n \\n //end for vsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n \\n float numberOfSubLoops = floor(parameter0);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n \\n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\\n \\n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\\n \\n /////////////////////////\\n \\n float rotation = PI/3.*time*shapeId;\\n \\n if(finalVertexId0\\n else\\n if(vertexId0\\n else\\n if(vertexId0 && SYMMETRY_H >0\\n else\\n if(vertexId>8.\n#define parameter1 -0.2//KParameter1 -1.>>1.\n#define parameter2 -1.//KParameter2 -1.>>1.\n#define parameter3 0.//KParameter3 0.>>12.\n#define parameter4 2.//KParameter4 0.>>2.\n#define parameter5 1.//KParameter5 0.1>>1.5\n#define parameter6 0.3//KParameter6 0.>>1.\n#define parameter7 0.//KParameter7 0.>>10.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n#define SYMMETRY_H 0\n#define SYMMETRY_V 0\n#define COLOR_MODE 0\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec3 getShapeVectorForLetter(float _vertexId, float _startVertexId, float _junctionY, float _secondVertY, float _barWidth, vec2 _pos, float _scale, float _rotation, vec2 _letter[18])\n{\n \n \n \n \n vec4 result = vec4(0., 0.,-1., 1.);\n \n \n float localVertexId = _vertexId - _startVertexId;\n \n if(localVertexId<1.)\n {\n result.xy = _letter[0].xy;\n }\n else\n \n if(localVertexId<2.)\n {\n result.xy = _letter[1].xy;\n }\n \n else\n if(localVertexId<3.)\n {\n result.xy = _letter[2].xy;\n }\n else //2nd triangle\n if(localVertexId<4.)\n {\n result.xy = _letter[3].xy;\n }\n else\n if(localVertexId<5.)\n {\n result.xy = _letter[4].xy;\n }\n else\n if(localVertexId<6.)\n {\n result.xy = _letter[5].xy;\n }\n else\n if(localVertexId<7.)//3 eme triangle\n {\n result.xy = _letter[6].xy;\n }\n else\n if(localVertexId<8.)\n {\n result.xy = _letter[7].xy;\n }\n else\n if(localVertexId<9.)\n {\n result.xy = _letter[8].xy;\n \n }\n \n else\n if(localVertexId<10.)//4eme triangle\n {\n result.xy = _letter[9].xy;\n \n }\n else\n if(localVertexId<11.)\n {\n result.xy = _letter[10].xy;\n \n }\n \n else\n if(localVertexId<12.)\n {\n result.xy = _letter[11].xy;\n \n }\n else\n if(localVertexId<13.)\n {\n result.xy = _letter[12].xy;\n \n }\n else\n if(localVertexId<14.)\n {\n result.xy = _letter[13].xy;\n \n }\n else\n if(localVertexId<15.)\n {\n result.xy = _letter[14].xy;\n \n }\n else\n if(localVertexId<16.)\n {\n result.xy = _letter[15].xy;\n \n }\n else\n if(localVertexId<17.)\n {\n result.xy = _letter[16].xy;\n \n }\n else\n if(localVertexId<18.)\n {\n result.xy = _letter[17].xy;\n \n }\n result.xy+=_pos;\n result.xy-=vec2(_barWidth*2.,0.5)+_pos;\n result.xyz =rotZ(result.xyz, _rotation);\n result.xy+=vec2(_barWidth*2.,0.5)+_pos;\n result *= uniformScale(_scale);\n \n \n return result.xyz;\n}\n\n\nvec2 getPosFromShapeId(const float _shapeId, const float _selectedShape, const float _relLoopProgress, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _pos)\n{\n vec2 finalPos = _pos;\n \n \n vec2 additionalPos = vec2(0.,0.);\n \n float transfoMode = floor(parameter3);\n \n \n //additionalPos.x = _relLetterTimeProgress*0.5;\n if(transfoMode<1.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n else\n if(transfoMode<2.)\n {\n additionalPos.y = sin(_relLetterTimeProgress*PI)*parameter6;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<3.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= parameter6*cos( (_shapeId/8.)*2.*PI );\n additionalPos.y+= parameter6*sin( (_shapeId/8.)*2.*PI );\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<4.)\n {\n additionalPos = -finalPos;\n vec4 m = texture2D(touch, vec2(0., (0.2+0.2*parameter6/10.)*(_shapeId/8.) ));\n \n additionalPos.x+= m.x;\n additionalPos.y+= m.y;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<5.)\n {\n additionalPos.y+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<6.)\n {\n additionalPos = -finalPos;\n additionalPos.y+= ((1.-_shapeId/8.)-0.5)*1.5;\n additionalPos.x+= (parameter6/10.)*1.5*cos( _shapeId+(2.*PI *time));;\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<7.)\n {\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*cos( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*sin( _relLetterTimeProgress*2.*PI*(_shapeId/8.) );\n finalPos+= additionalPos;\n }\n \n }\n else\n if(transfoMode<8.)\n {\n additionalPos = -finalPos;\n if(_selectedShape == _shapeId)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n if(transfoMode<9.)\n {\n additionalPos = -finalPos;\n \n if(mod(_shapeId,2.)<1.)\n {\n additionalPos.x+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*cos( 2.*PI*(_shapeId/8.) );\n additionalPos.y+= parameter6*5.*(1.-_relLetterTimeProgress)/2.*sin( 2.*PI*(_shapeId/8.) );\n \n }\n finalPos+= additionalPos;\n }\n else\n \n if(transfoMode<10.)\n {\n //if(_selectedShape == _shapeId)\n {\n vec4 m = texture2D(sound, vec2((_shapeId/8.-0.25), 0. ));\n additionalPos.y = m.x*parameter6*2.;\n finalPos+= additionalPos;\n }\n }\n \n else\n \n if(transfoMode<11.)\n {\n additionalPos = -finalPos;\n additionalPos.x+= sin(_relLoopProgress*PI)*parameter6*cos( (_shapeId/8.)*2.*PI+time );\n additionalPos.y+= sin(_relLoopProgress*PI)*parameter6*sin( (_shapeId/8.)*2.*PI+time);\n finalPos+= additionalPos;\n }\n \n return finalPos;\n}\n\n\nfloat getRotationFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const float _rotation)\n{\n float finalRot = _rotation;\n \n float additionalRotation = 0.;\n \n float transfoMode = floor(parameter3);\n \n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = floor(parameter6+1.)*2.*PI*_relLetterTimeProgress;\n \n }\n }\n else\n if(transfoMode<1.)\n {\n \n if(_selectedShape == _shapeId)\n {\n additionalRotation = 2.*2.*PI*_relLetterTimeProgress;\n \n }\n }\n \n \n finalRot+= additionalRotation;\n \n /*\n float additionalRotation = 0.;\n \n if(selectedLetterIndex == shapeId)\n {\n additionalRotation = 2.*PI*relLetterTimeProgress;\n }\n \n rotation = PI/2. + defaultRotationForShapeLetterK+additionalRotation;//0.13;//PI/3.*time*shapeId;\n */\n \n return finalRot;\n}\n\n\nvec2 getCenterFromShapeId(const float _shapeId, const float _selectedShape, const float _percentProgress, const float _relLetterTimeProgress, const vec2 _center, const vec2 _pos, const float _letterWidth)\n{\n vec2 finalCenter = _center;\n \n \n /*\n vec2 additionalCenter = vec2(0.,0.);\n \n \n if(_selectedShape == _shapeId)\n {\n additionalCenter.x = _relLetterTimeProgress*0.5;\n additionalCenter.y = _relLetterTimeProgress*0.5;\n }\n \n finalCenter+= additionalCenter;\n */\n \n return finalCenter;\n}\n\n#define elementPerShapeLetterK 18.\n\n#define defaultRotationForShapeLetterK 0.13\n#define defaultRotationForShapeLetterM - 0.09\n#define defaultRotationForShapeLetterN 0.04\n#define defaultRotationForShapeLetterA 0.1\n#define defaultRotationForShapeLetterC - 0.05\n#define defaultRotationForShapeLetterE - 0.03\n#define defaultRotationForShapeLetterH 0.04\n#define defaultRotationForShapeLetterI - 0.02\n\n\n#define shapeNumber 8.\n#define numberOfVerticesForWord elementPerShapeLetterK*shapeNumber\n\nvoid main() {\n \n \n vec3 color = vec3(1.);\n \n float sndFactor = texture2D(sound, vec2(0.01, 0.)).r;\n float _junctionY = 0.5 +parameter4*sndFactor/10.;\n \n float _barWidth = 0.2 ;// + parameter4*sndFactor/100.;\n float _secondVertY = 2.4*_barWidth + parameter4*sndFactor/10.;\n \n float shapeId = 0.;\n \n vec2 letterK[18];\n letterK[0] = vec2(0.,0.);\n letterK[1] = vec2(0.,1.);\n letterK[2] = vec2(_barWidth,1.);\n letterK[3] = vec2(0.,0.0);\n letterK[4] = vec2(_barWidth,1.);\n letterK[5] = vec2(_barWidth,0.);\n letterK[6] = vec2(_barWidth,_junctionY);\n letterK[7] = vec2((_secondVertY+_barWidth),1.);\n letterK[8] = vec2(_secondVertY,1.);\n letterK[9] = vec2(_barWidth,_junctionY);\n letterK[10] = vec2((_secondVertY+_barWidth),0.);\n letterK[11] = vec2(_secondVertY,0.);\n letterK[12] = vec2(_secondVertY,0.);\n letterK[13] = vec2(_secondVertY,0.);\n letterK[14] = vec2(_secondVertY,0.);\n letterK[15] = vec2(_secondVertY,0.);\n letterK[16] = vec2(_secondVertY,0.);\n letterK[17] = vec2(_secondVertY,0.);\n \n vec2 letterM[18];\n letterM[0] = vec2(0.,0.);\n letterM[1] = vec2(0.,1.);\n letterM[2] = vec2(_barWidth,1.);\n letterM[3] = vec2(0.,0.0);\n letterM[4] = vec2(_barWidth,1.);\n letterM[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterM[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterM[7] = vec2(_barWidth,1.);\n letterM[8] = vec2(_barWidth*2.,_junctionY);\n letterM[9] = vec2(_barWidth*2.,_junctionY);\n letterM[10] = vec2((_barWidth*3.),1.);\n letterM[11] = vec2(_barWidth*3.,_junctionY+_barWidth);\n letterM[12] = vec2(_barWidth*3.,1.);\n letterM[13] = vec2(_barWidth*4.,1.);\n letterM[14] = vec2(_barWidth*3.,0.);\n letterM[15] = vec2(_barWidth*3.,0.);\n letterM[16] = vec2(_barWidth*4.,1.);\n letterM[17] = vec2(_barWidth*4.,0.);\n \n \n vec2 letterN[18];\n letterN[0] = vec2(0.,0.);\n letterN[1] = vec2(0.,1.);\n letterN[2] = vec2(_barWidth,1.);\n letterN[3] = vec2(0.,0.0);\n letterN[4] = vec2(_barWidth,1.);\n letterN[5] = vec2(_barWidth,0.);\n letterN[6] = vec2(_barWidth,_junctionY+_barWidth);\n letterN[7] = vec2(_barWidth,1.);\n letterN[8] = vec2(_barWidth*2.,_junctionY);\n letterN[9] = vec2(_barWidth*2.,1.);\n letterN[10] = vec2(_barWidth*3.,1.);\n letterN[11] = vec2(_barWidth*2.,0.);\n \n letterN[12] = vec2(_barWidth*2.,0.);\n letterN[13] = vec2(_barWidth*3.,1.);\n letterN[14] = vec2(_barWidth*3.,0.);\n letterN[15] = vec2(_barWidth*3.,0.);\n \n letterN[16] = vec2(_barWidth*3.,0.);\n letterN[17] = vec2(_barWidth*3.,0.);\n \n \n vec2 letterA[18];\n letterA[0] = vec2(0.,0.);\n letterA[1] = vec2(_barWidth,0.);\n letterA[2] = vec2(_barWidth*2.,1.);\n letterA[3] = vec2(_barWidth*4.,0.0);\n letterA[4] = vec2(_barWidth*2.,1.);\n letterA[5] = vec2(_barWidth*3.,0.);\n letterA[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterA[7] = vec2(_barWidth*1.5,_junctionY+_barWidth/2.);\n letterA[8] = vec2(_barWidth*3.,_junctionY);\n letterA[9] = vec2(_barWidth*3.,_junctionY);\n letterA[10] = vec2(_barWidth*3.,_junctionY);\n letterA[11] = vec2(_barWidth*3.,_junctionY);\n \n letterA[12] = vec2(_barWidth*3.,_junctionY);\n letterA[13] = vec2(_barWidth*3.,_junctionY);\n letterA[14] = vec2(_barWidth*3.,_junctionY);\n letterA[15] = vec2(_barWidth*3.,_junctionY);\n \n letterA[16] = vec2(_barWidth*3.,_junctionY);\n letterA[17] = vec2(_barWidth*3.,_junctionY);\n \n \n vec2 letterE[18];\n letterE[0] = vec2(0.,0.);\n letterE[1] = vec2(0.,1.);\n letterE[2] = vec2(_barWidth,1.);\n letterE[3] = vec2(0.,0.0);\n letterE[4] = vec2(_barWidth,1.);\n letterE[5] = vec2(_barWidth,0.);\n letterE[6] = vec2(_barWidth,_junctionY+_barWidth*1.5);\n letterE[7] = vec2(_barWidth,1.);\n letterE[8] = vec2(_barWidth*3.,1.);\n letterE[9] = vec2(_barWidth,_junctionY-_barWidth*1.5);\n letterE[10] = vec2(_barWidth,0.);\n letterE[11] = vec2(_barWidth*3.,0.);\n letterE[12] = vec2(_barWidth,_junctionY);\n letterE[13] = vec2(_barWidth*2.5,_junctionY+_barWidth/2.);\n letterE[14] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[15] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[16] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n letterE[17] = vec2(_barWidth*2.5,_junctionY-_barWidth/2.);\n \n \n vec2 letterC[18];\n letterC[0] = vec2(0.,0.);\n letterC[1] = vec2(0.,1.);\n letterC[2] = vec2(_barWidth,1.);\n letterC[3] = vec2(0.,0.0);\n letterC[4] = vec2(_barWidth,1.);\n letterC[5] = vec2(_barWidth,0.);\n letterC[6] = vec2(_barWidth,0.5+_barWidth*1.5);\n letterC[7] = vec2(_barWidth,1.);\n letterC[8] = vec2(_barWidth*3.,1.);\n letterC[9] = vec2(_barWidth,0.);\n letterC[10] = vec2(_barWidth,0.5-_barWidth*1.5);\n letterC[11] = vec2(_barWidth*3.,0.);\n letterC[12] = vec2(_barWidth*3.,0.);\n letterC[13] = vec2(_barWidth*3.,0.);\n letterC[14] = vec2(_barWidth*3.,0.);\n letterC[15] = vec2(_barWidth*3.,0.);\n letterC[16] = vec2(_barWidth*3.,0.);\n letterC[17] = vec2(_barWidth*3.,0.);\n \n vec2 letterH[18];\n letterH[0] = vec2(0.,0.);\n letterH[1] = vec2(0.,1.);\n letterH[2] = vec2(_barWidth,1.);\n letterH[3] = vec2(0.,0.0);\n letterH[4] = vec2(_barWidth,1.);\n letterH[5] = vec2(_barWidth,0.);\n letterH[6] = vec2(_barWidth,_junctionY-_barWidth/2.);\n letterH[7] = vec2(_barWidth,_junctionY+_barWidth/2.);\n letterH[8] = vec2(_barWidth*2.,_junctionY);\n letterH[9] = vec2(_barWidth*2.,_junctionY);\n letterH[10] = vec2((_barWidth*3.),_junctionY+_barWidth/2.);\n letterH[11] = vec2(_barWidth*3.,_junctionY-_barWidth/2.);\n letterH[12] = vec2(_barWidth*3.,1.);\n letterH[13] = vec2(_barWidth*4.,1.);\n letterH[14] = vec2(_barWidth*3.,0.);\n letterH[15] = vec2(_barWidth*3.,0.);\n letterH[16] = vec2(_barWidth*4.,1.);\n letterH[17] = vec2(_barWidth*4.,0.);\n \n vec2 letterI[18];\n letterI[0] = vec2(0.,0.);\n letterI[1] = vec2(0.,_junctionY+_barWidth);\n letterI[2] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[3] = vec2(0.,0.0);\n letterI[4] = vec2(_barWidth,_junctionY+_barWidth);\n letterI[5] = vec2(_barWidth,0.);//PROBLEM !!\n letterI[6] = vec2(0.,1.-_barWidth);\n letterI[7] = vec2(0.,1.);\n letterI[8] = vec2(_barWidth,1.-_barWidth);\n letterI[9] = vec2(_barWidth,1.-_barWidth);\n letterI[10] = vec2(0.,1.);\n letterI[11] = vec2(_barWidth,1.);\n letterI[12] = vec2(_barWidth,1.);\n letterI[13] = vec2(_barWidth,1.);\n letterI[14] = vec2(_barWidth,1.);\n letterI[15] = vec2(_barWidth,1.);\n letterI[16] = vec2(_barWidth,1.);\n letterI[17] = vec2(_barWidth,1.);\n \n float acceptedNumberOfWords = floor(vertexCount/float(numberOfVerticesForWord));\n float maxNumberOfVertices = acceptedNumberOfWords*numberOfVerticesForWord;//\n \n float finalVertexId = vertexId;//mod(vertexId,numberOfVerticesForWord);//min(maxNumberOfVertices,vertexId);\n //finalVertexId = min(finalVertexId,maxNumberOfVertices);// mod(finalVertexId, numberOfVerticesForWord);\n \n finalVertexId = min(maxNumberOfVertices,vertexId);\n \n finalVertexId = mod(finalVertexId,float(numberOfVerticesForWord));\n \n //float metaShapeId = floor(vertexId/float(256.));//floor(finalVertexId/numberOfVerticesForWord);\n //float relMetaShapeId = metaShapeId/256.;\n \n float masterScale = parameter5;//parameter6;\n \n vec3 _v = vec3(0.,0.,0.);\n \n vec2 letterPos = vec2(0.,0.);\n \n float marginBetweenLetters = 3.*_barWidth+parameter4*sndFactor/10.;\n \n float scaleK = 0.4*masterScale;\n float scale = 0.2*masterScale;\n float startPosK = parameter2;\n float startPosM = startPosK + marginBetweenLetters*scaleK;//+(2.*marginBetweenLetters);\n \n vec2 shapeCenter = vec2(0.,0.5);\n \n //for vsa\n \n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n \n //end for vsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n \n float numberOfSubLoops = floor(parameter0);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n \n float letterTimeProgress = mod(finalRelLoopProgress,(1./shapeNumber));\n float relLetterTimeProgress = letterTimeProgress/(1./shapeNumber);\n \n float selectedLetterIndex = floor(shapeNumber*finalRelLoopProgress);\n \n /////////////////////////\n \n float rotation = PI/3.*time*shapeId;\n \n if(finalVertexId0\n else\n if(vertexId0\n else\n if(vertexId0 && SYMMETRY_H >0\n else\n if(vertexId 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat quant(float v, float q) {\\n return min(q, floor(v * q) / (q - 1.));\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nconst float perBlock = 8.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 48.;\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across - .1);\\n float v = vId / down;\\n float bx = mod(uId, perBlock);\\n float bu = bx / (perBlock - 1.);\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numCols = floor(across / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(bu) * across * 1.1; - bxId * perBlock * 2.1;\\n float vSpace = numRows * 2.05 + numBlocks * 2.;\\n float z = v * down * 2.05 + bzId * 2.;\\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\\n vCubeOrigin.y += 10. + height;;\\n \\n mat = ident();\\n mat *= rotZ(bxId / numCols * PI * 2.);\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \\n \\n float over = (s2 - 0.75) / 0.25;\\n float hue = 0.5 + quant(over, 3.) * 0.7;\\n float sat = step(0.75,s2);\\n float val = 1.;\\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov = 1.8;\\n \\n \\tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\\n \\tvec3 vCameraPos = vec3(0.1, 0., -0.);\\n float ca = 0.;\\n \\n // get sick!\\n //ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nohell/the-juju-orchestra-take-four", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n ___ ___ _______ ________ _________ _______ ___ ___ \n|\\ \\ / /|\\ ___ \\ |\\ __ \\|\\___ ___|\\ ___ \\ |\\ \\ / /|\n\\ \\ \\ / / \\ \\ __/|\\ \\ \\|\\ \\|___ \\ \\_\\ \\ __/| \\ \\ \\/ / /\n \\ \\ \\/ / / \\ \\ \\_|/_\\ \\ _ _\\ \\ \\ \\ \\ \\ \\_|/__ \\ \\ / / \n \\ \\ / / \\ \\ \\_|\\ \\ \\ \\\\ \\| \\ \\ \\ \\ \\ \\_|\\ \\ / \\/ \n \\ \\__/ / \\ \\_______\\ \\__\\\\ _\\ \\ \\__\\ \\ \\_______\\/ /\\ \\ \n \\|__|/ \\|_______|\\|__|\\|__| \\|__| \\|_______/__/ /\\ __\\ \n |__|/ \\|__| \n \n \n ________ ___ ___ ________ ________ _______ ________ \n|\\ ____\\|\\ \\|\\ \\|\\ __ \\|\\ ___ \\|\\ ___ \\ |\\ __ \\ \n\\ \\ \\___|\\ \\ \\\\\\ \\ \\ \\|\\ \\ \\ \\_|\\ \\ \\ __/|\\ \\ \\|\\ \\ \n \\ \\_____ \\ \\ __ \\ \\ __ \\ \\ \\ \\\\ \\ \\ \\_|/_\\ \\ _ _\\ \n \\|____|\\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\_\\\\ \\ \\ \\_|\\ \\ \\ \\\\ \\| \n ____\\_\\ \\ \\__\\ \\__\\ \\__\\ \\__\\ \\_______\\ \\_______\\ \\__\\\\ _\\ \n |\\_________\\|__|\\|__|\\|__|\\|__|\\|_______|\\|_______|\\|__|\\|__| \n \\|_________| \n \n \n ________ ________ _________ \n|\\ __ \\|\\ __ \\|\\___ ___\\ \n\\ \\ \\|\\ \\ \\ \\|\\ \\|___ \\ \\_| \n \\ \\ __ \\ \\ _ _\\ \\ \\ \\ \n \\ \\ \\ \\ \\ \\ \\\\ \\| \\ \\ \\ \n \\ \\__\\ \\__\\ \\__\\\\ _\\ \\ \\__\\ \n \\|__|\\|__|\\|__|\\|__| \\|__| \n \n \n \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\nvec3 gSunColor = vec3(1.0, 1.2, 1.4) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.3;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat quant(float v, float q) {\n return min(q, floor(v * q) / (q - 1.));\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nconst float perBlock = 8.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 48.;\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across - .1);\n float v = vId / down;\n float bx = mod(uId, perBlock);\n float bu = bx / (perBlock - 1.);\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numCols = floor(across / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.1)).a;\n float s2 = texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(bu) * across * 1.1; - bxId * perBlock * 2.1;\n float vSpace = numRows * 2.05 + numBlocks * 2.;\n float z = v * down * 2.05 + bzId * 2.;\n vCubeOrigin.z += fract(-time * 0.2 + z / vSpace) * vSpace;\n float height = mix(0.1, 0.5, hash(fCubeId)) + smoothstep(0.75, 1., s2) * 1.;\n vCubeOrigin.y += 10. + height;;\n \n mat = ident();\n mat *= rotZ(bxId / numCols * PI * 2.);\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = vec3(1);//mix(vec3(0.5), vec3(1,1,1), pow(s2, 40.0)); \n \n float over = (s2 - 0.75) / 0.25;\n float hue = 0.5 + quant(over, 3.) * 0.7;\n float sat = step(0.75,s2);\n float val = 1.;\n vCubeCol.rgb = hsv2rgb(vec3(hue, sat, val));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov = 1.8;\n \n \tvec3 vCameraTarget = vec3( 0, 0.0, 1.0 );\n \tvec3 vCameraPos = vec3(0.1, 0., -0.);\n float ca = 0.;\n \n // get sick!\n //ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(45.), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-of8l530j8a5twvpa2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vtq5MvbFuTd4SDKpR/art.json b/art/vtq5MvbFuTd4SDKpR/art.json index 119701ff..1d2247fe 100644 --- a/art/vtq5MvbFuTd4SDKpR/art.json +++ b/art/vtq5MvbFuTd4SDKpR/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\n#define DEBUG 1\\n#define TAU 6.28318530718\\n\\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\\n{\\n vec2 finalRes = vec2(1.,1.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n _maxvertexCount = floor(vertexCount*ratioXforY);\\n \\n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\\n \\n return vec2(finalRes.x,finalRes.x/ratioXforY);\\n}\\n \\nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\\n\\nvoid main ()\\n{\\n \\n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\\n \\n float ratioXforY = resolution.x/resolution.y;\\n \\n float finalVertexCount = floor(vertexCount*ratioXforY);\\n \\n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\\n \\n //float numAcrossDown = floor(sqrt(finalVertexCount));\\n \\n //float ratio = resolution.y/numAcrossDown;\\n \\n //float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, finalVertexCount);\\n \\n float x = mod(finalVertexId, finalResolution.x);\\n float y = floor(finalVertexId / finalResolution.y);\\n \\n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\\n float v = (y / finalResolution.y);\\n \\n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x)/2.;\\n \\n float vy = ( v * 2.0 - 1.0)* (finalResolution.y/resolution.y)/2.;\\n \\n float snd = texture2D(sound, vec2(0., u)).a;\\n \\n \\n //apply fragment logic\\n\\n vec2 surfacePosition = vec2(0.,0.);\\n \\n\\n\\tvec2 p = vec2(x,y);\\n \\n \\n\\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \\n\\tuv1 += surfacePosition;\\n\\tfloat dp = dot(uv1,uv1);\\n\\tuv1 /= 1.-dp*dp;\\n \\n\\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\\n\\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\\n\\t\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\\n\\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\\n \\n\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\n#define DEBUG 1\n#define TAU 6.28318530718\n\nvec2 getBestXYResolutionForVertexCountToGetPixelResolution(const float _desiredPixelSize, float _maxvertexCount)\n{\n vec2 finalRes = vec2(1.,1.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n _maxvertexCount = floor(vertexCount*ratioXforY);\n \n finalRes.x = sqrt(ratioXforY * _maxvertexCount);\n \n return vec2(finalRes.x,finalRes.x/ratioXforY);\n}\n \nfloat pattern(vec2 p){p.x*=.866;p.x-=p.y*.5;p=mod(p,1.);return p.x+p.y<1.?0.:1.;}\n\nvoid main ()\n{\n \n //float finalVertexCount = vertexCount;//max((0.5*snd)*vertexCount,5000.);\n \n float ratioXforY = resolution.x/resolution.y;\n \n float finalVertexCount = floor(vertexCount*ratioXforY);\n \n vec2 finalResolution = vec2(sqrt(ratioXforY * finalVertexCount), sqrt(ratioXforY * finalVertexCount)/ratioXforY);\n \n //float numAcrossDown = floor(sqrt(finalVertexCount));\n \n //float ratio = resolution.y/numAcrossDown;\n \n //float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, finalVertexCount);\n \n float x = mod(finalVertexId, finalResolution.x);\n float y = floor(finalVertexId / finalResolution.y);\n \n float u = (x / finalResolution.x);// * (resolution.y/resolution.x);\n float v = (y / finalResolution.y);\n \n float ux = ( u * 2.0 - 1.0) * (finalResolution.x/resolution.x)/2.;\n \n float vy = ( v * 2.0 - 1.0)* (finalResolution.y/resolution.y)/2.;\n \n float snd = texture2D(sound, vec2(0., u)).a;\n \n \n //apply fragment logic\n\n vec2 surfacePosition = vec2(0.,0.);\n \n\n\tvec2 p = vec2(x,y);\n \n \n\tvec2 uv1=(p.xy*2.-finalResolution.xy)/min(finalResolution.x,finalResolution.y); \n\tuv1 += surfacePosition;\n\tfloat dp = dot(uv1,uv1);\n\tuv1 /= 1.-dp*dp;\n \n\tfloat a=0.,d=dot(uv1,uv1),s=0.,t=fract(time*.3),v1=0.;\n\tfor(int i=0;i<8;i++){s=fract(t+a);v+=pattern(uv1*(pow(2.,(1.-s)*8.))*.5)*sin(fract(t+a)*3.14);a+=.125;}\n\t\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = (resolution.y/finalResolution.y)*2.-1.;\n\n v_color = vec4(mix(vec3(.7,.8,1),vec3(.8,.8,.9),d)*v*.25,1);;\n \n\n}" + }, "screenshotURL": "data/images/images-pngiqrvufv7797bx9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vwQgfZcfrdKFAJLd2/art.json b/art/vwQgfZcfrdKFAJLd2/art.json index be292277..51171448 100644 --- a/art/vwQgfZcfrdKFAJLd2/art.json +++ b/art/vwQgfZcfrdKFAJLd2/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "jluethi", "avatarUrl": "https://secure.gravatar.com/avatar/21e93db3614e6e91a28d7f82b4e44433?default=retro&size=200", - "settings": "{\"num\":1100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.14901960784313725,0.12941176470588237,0.27058823529411763,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across) ;\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.3;\\n \\n float ux = u * 2. -1. +xoff;\\n float vy = v * 2. -1. +yoff;\\n \\n vec2 xy =vec2(ux, vy)* 1.3;\\n \\n float soff = sin(time + x * y * 0.02) * 25.;\\n \\n \\ngl_Position = vec4(xy,0,1);\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.14901960784313725, + 0.12941176470588237, + 0.27058823529411763, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across) ;\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.3;\n \n float ux = u * 2. -1. +xoff;\n float vy = v * 2. -1. +yoff;\n \n vec2 xy =vec2(ux, vy)* 1.3;\n \n float soff = sin(time + x * y * 0.02) * 25.;\n \n \ngl_Position = vec4(xy,0,1);\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-b01ex6y9mxhho3r4c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/vwbP4QH64Pn3EXf3w/art.json b/art/vwbP4QH64Pn3EXf3w/art.json index b70b69c9..e716ba2e 100644 --- a/art/vwbP4QH64Pn3EXf3w/art.json +++ b/art/vwbP4QH64Pn3EXf3w/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sendi", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GiA4oVEHO7tNcUpxHud7p60dl8Gb-TqVLeqG_Q1=s96-c", - "settings": "{\"num\":23736,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hema_singer/o-sajna-live-movie-parakh\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.25098039215686274,0.24705882352941178,0.09019607843137255,1],\"shader\":\"/*\\n\\n _ \\n | | \\n __ _____ _ __| |_ _____ __ \\n \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / \\n \\\\ V / __/ | | || __/> < \\n \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\ \\n | | | | \\n ___| |__ __ _ __| | ___ _ __ \\n / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__|\\n \\\\__ \\\\ | | | (_| | (_| | __/ | \\n |___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\n | | \\n __ _ _ __| |_ \\n / _` | '__| __| \\n | (_| | | | |_ \\n \\\\__,_|_| \\\\__| \\n \\n \\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[3][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_PARTS_PER_PETAL 20.\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 4.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float circleId, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 5.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n snd = 0.;//texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\\n \\n \\n float z = mix(inner, 1., level);\\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. + sin(time * 1. + (circleId + z) * 0.1) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n pos = vec3(x, y, z); \\n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\\n}\\n\\nfloat goop(float t) {\\n return (sin(t) + sin(t * 0.27) + sin(t * 1.53) + sin(t * 1.73)) / 4.;\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float petalId = floor(circleId / NUM_PARTS_PER_PETAL);\\n circleId = mod(circleId, NUM_PARTS_PER_PETAL);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n// float sideId = floor(circleId / 2.);\\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE / 12.);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = 0.0;\\n float start = 0.;//time * -0.1;\\n float end = start + 1.;\\n float snd;\\n vec3 uvf;\\n getCirclePoint(pointId, circleId, inner, start, end, pos, uvf, snd); \\n \\n vec3 offset = vec3(0);\\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\\n //offset.x += goop(circleId + time * 0.3) * 0.4;\\n //offset.y += goop(circleId + time * 0.13) * 0.1;\\n offset.z += circleId * 2.6;\\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n float edgeId = circleId + pos.z * 0.76;\\n \\n float ss = texture2D(sound, vec2(0.053, edgeId / numCircles * 1.)).a;\\n \\n vec3 camera = vec3(0, 50., -0.01);\\n vec3 target = vec3(0, 0, 0);\\n vec3 up = vec3(0, 1, 0);\\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65. * resolution.y / resolution.x), resolution.x / resolution.y, 0.1, 100.);\\n mat *= rotZ(sin(time * 0.1));\\n mat *= cameraLookAt(camera, target, up);\\n mat *= rotY(petalId / 12. * PI * 2. + sin(time * 0.4 + 3. + edgeId * mix(0.1, 0.5, p1m1(sin(time * 0.1)))) * 0.3);\\n mat *= trans(offset);\\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\\n float sc = mix(0.5, 5., mix(1., 2., pow(edgeId / numCircles, 10.))\\n * (pow(ss + 0.2, 5.0) + pow(goop((time * 0.1 + 38. + edgeId) * 0.1), 3.)));\\n mat *= scale(vec3(sc, sc, 2.));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n float hue = mix(0.0, 0.5, mod(uvf.z, 2.)) + time * 0.1;\\n float sat = 1.; mod(uvf.z, 2.);\\n float val = mix(0.5, 1., fract((edgeId)* 0.25 - time));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), );\\n}\"}", + "settings": { + "num": 23736, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hema_singer/o-sajna-live-movie-parakh", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.25098039215686274, + 0.24705882352941178, + 0.09019607843137255, + 1 + ], + "shader": "/*\n\n _ \n | | \n __ _____ _ __| |_ _____ __ \n \\ \\ / / _ \\ '__| __/ _ \\ \\/ / \n \\ V / __/ | | || __/> < \n \\_/ \\___|_| \\__\\___/_/\\_\\ \n | | | | \n ___| |__ __ _ __| | ___ _ __ \n / __| '_ \\ / _` |/ _` |/ _ \\ '__|\n \\__ \\ | | | (_| | (_| | __/ | \n |___/_| |_|\\__,_|\\__,_|\\___|_| \n | | \n __ _ _ __| |_ \n / _` | '__| __| \n | (_| | | | |_ \n \\__,_|_| \\__| \n \n \n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[3][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_PARTS_PER_PETAL 20.\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 4.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float circleId, const float inner, const float start, const float end, out vec3 pos, out vec3 uvf, out float snd) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 5.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n snd = 0.;//texture2D(sound, vec2((0.02 + abs(u * 2. - 1.)) * 0.20, ringV * 0.25)).a;\n \n \n float z = mix(inner, 1., level);\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2. * 20. + sin(time * 1. + (circleId + z) * 0.1) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n pos = vec3(x, y, z); \n uvf = vec3(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.));\n}\n\nfloat goop(float t) {\n return (sin(t) + sin(t * 0.27) + sin(t * 1.53) + sin(t * 1.73)) / 4.;\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float petalId = floor(circleId / NUM_PARTS_PER_PETAL);\n circleId = mod(circleId, NUM_PARTS_PER_PETAL);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n// float sideId = floor(circleId / 2.);\n// float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE / 12.);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = 0.0;\n float start = 0.;//time * -0.1;\n float end = start + 1.;\n float snd;\n vec3 uvf;\n getCirclePoint(pointId, circleId, inner, start, end, pos, uvf, snd); \n \n vec3 offset = vec3(0);\n //offset += vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId * 0.37)), -m1p1(circleId / numCircles));\n //offset.x += goop(circleId + time * 0.3) * 0.4;\n //offset.y += goop(circleId + time * 0.13) * 0.1;\n offset.z += circleId * 2.6;\n// vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n float edgeId = circleId + pos.z * 0.76;\n \n float ss = texture2D(sound, vec2(0.053, edgeId / numCircles * 1.)).a;\n \n vec3 camera = vec3(0, 50., -0.01);\n vec3 target = vec3(0, 0, 0);\n vec3 up = vec3(0, 1, 0);\n \n mat4 mat = ident(); \n mat *= persp(radians(65. * resolution.y / resolution.x), resolution.x / resolution.y, 0.1, 100.);\n mat *= rotZ(sin(time * 0.1));\n mat *= cameraLookAt(camera, target, up);\n mat *= rotY(petalId / 12. * PI * 2. + sin(time * 0.4 + 3. + edgeId * mix(0.1, 0.5, p1m1(sin(time * 0.1)))) * 0.3);\n mat *= trans(offset);\n// mat *= uniformScale(mix(0.1, 0.4, hash(circleId) * exp(snd)));\n float sc = mix(0.5, 5., mix(1., 2., pow(edgeId / numCircles, 10.))\n * (pow(ss + 0.2, 5.0) + pow(goop((time * 0.1 + 38. + edgeId) * 0.1), 3.)));\n mat *= scale(vec3(sc, sc, 2.));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n float hue = mix(0.0, 0.5, mod(uvf.z, 2.)) + time * 0.1;\n float sat = 1.; mod(uvf.z, 2.);\n float val = mix(0.5, 1., fract((edgeId)* 0.25 - time));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n// v_color = mix(v_color.rgba, vec4(1,1,1,1), );\n}" + }, "screenshotURL": "data/images/images-rq9og4cvamf3wpdao-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vycmMsgS7e6fHw5tD/art.json b/art/vycmMsgS7e6fHw5tD/art.json index c7751dbe..98b2ffe7 100644 --- a/art/vycmMsgS7e6fHw5tD/art.json +++ b/art/vycmMsgS7e6fHw5tD/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":7200,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/apollyonpsy/loose-connection-vs-apollyon\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//In progres. Based on gman's https://www.vertexshaderart.com/art/uPwKetxzwcL2PFZd6 \\n//Should be 'K Machine' compliant. Not tested yet.\\n\\n#define PI radians(180.0)\\n \\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n#define numberOfShapesPerGroup 5.0\\n#define fakeVerticeNumber 72000.\\n\\nconst float dim = 120.;\\nconst float off = 0.1;\\nconst vec3 vAlb = vec3(0.5);\\n\\n/////////////////////////////\\n//K Machine parameters\\n/////////////////////////////\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n\\n\\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\\n#define SizeFactorX 100.1 //KParameter 1.>>10.\\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\\n\\n\\nmat4 rotZ(float _radAngle) {\\n float s = sin(_radAngle);\\n float c = cos(_radAngle);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 scale(vec3 _s) {\\n return mat4(\\n _s[0], 0, 0, 0,\\n 0, _s[1], 0, 0,\\n 0, 0, _s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\\n float f = tan(PI * 0.5 - 0.5 * _fov);\\n float rInv = 1.0 / (_zNear - _zFar);\\n\\n return mat4(\\n f / _aspect, 0., 0., 0.,\\n 0., f, 0., 0.,\\n 0., 0., (_zNear + _zFar) * rInv, -1.,\\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\\n}\\n\\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\\n vec3 zAx = normalize(_eye - _targ);\\n vec3 xAx = normalize(cross(_up, zAx));\\n vec3 yAx = cross(zAx, xAx);\\n\\n return mat4(\\n xAx, 0.,\\n yAx, 0.,\\n zAx, 0.,\\n _eye, 1.);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\n\\nvec3 getTrajPoint(const float _id) {\\n return vec3(\\n sin(_id * 0.99),\\n sin(_id * 2.43),\\n sin(_id * 1.57));\\n}\\n \\nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\\n{\\n \\n float pg = _rel + _delta;\\n \\n vec3 r0 = getTrajPoint(pg + off * 0.);\\n vec3 r1 = getTrajPoint(pg + off * 1.);\\n vec3 r2 = getTrajPoint(pg + off * 2.);\\n \\n _pos = mat3(\\n getTrajPoint(pg + off * 0.),\\n getTrajPoint(pg + off * 1.),\\n getTrajPoint(pg + off * 2.));\\n \\n vec3 s0 = normalize(_pos[1] - _pos[0]);\\n vec3 s1 = normalize(_pos[2] - _pos[1]);\\n \\n vec4 zaxis = vec4(normalize(s1 - s0),1.);\\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\\n \\n _axis = mat3(\\n xaxis,\\n yaxis,\\n zaxis);\\n\\n\\n}\\n\\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\\n \\n \\n float prog = (_shapeId / _shapeCount)+_timeB;\\n \\n mat3 axis, mPos;\\n\\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\\n\\n //pos mtx\\n _wmat = mat4(\\n vec4(axis[0], 0),\\n vec4(axis[1], 0),\\n vec4(axis[2], 0),\\n vec4(mPos[0] * dim, 1)); \\n \\n //orient mtx\\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\\n vec3 target = mPos[1] * dim + axis[2];\\n vec3 up = axis[1];\\n \\n mat4 cmat = lookAt(eye, target, up);\\n _emat = inverse(cmat);\\n \\n \\n}\\n\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\nmat4 rotMatx(vec3 _axis, float _angle)\\n{\\n _axis = normalize(_axis);\\n float s = sin(_angle);\\n float c = cos(_angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * _axis.x * _axis.x + c, oc * _axis.x * _axis.y - _axis.z * s, oc * _axis.z * _axis.x + _axis.y * s, 0.0,\\n oc * _axis.x * _axis.y + _axis.z * s, oc * _axis.y * _axis.y + c, oc * _axis.y * _axis.z - _axis.x * s, 0.0,\\n oc * _axis.z * _axis.x - _axis.y * s, oc * _axis.y * _axis.z + _axis.x * s, oc * _axis.z * _axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\nvoid addPtLight( vec3 vLightPos, vec3 vLightColor, in vec3 _pos, in vec3 _norm, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - _pos);\\n vec3 vViewDir = normalize(-_pos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, _norm ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid addDirLight( vec3 _vLDir, vec3 _vLColor, in vec3 _pos, in vec3 _norm, inout vec3 _vDiff, inout vec3 _vSpec )\\n{\\n vec3 vViewDir = normalize(-_pos);\\n \\n float NdotL = max( 0.0, dot( _vLDir, _norm ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + _vLDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\\n \\n _vDiff += NdotL * _vLColor;\\n\\n float fPower = 80.0;\\n _vSpec += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * _vLColor;\\n}\\n\\nvec3 lightget(const vec3 vAlbedo, const vec3 _pos, const vec3 _eyePos, const vec3 _norm )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n vec3 vAmbient = vec3(1., 1., 1.);\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n\\n addPtLight( vec3(3.0, 2.0, 30.0), vec3( 0.2, 0.2,0.2),_pos, _norm, vDiffuseLight, vSpecLight );\\n \\n addDirLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, _pos, _norm, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(-_eyePos);\\n \\n float fNdotD = clamp(dot(_norm, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\n\\nvec3 lightPost( vec3 _vColor )\\n{\\n float exposure = 1.0;\\n _vColor = vec3(1.0) - exp2( _vColor * -exposure );\\n\\n _vColor = pow( _vColor, vec3(1.0 / 2.2) );\\n\\n return _vColor;\\n}\\n\\n//#define EYE_STATIC true\\n//#define STOP_TRAJ true\\n#define DYN_GROUPID true\\n#define SOUND_REACT true\\n\\nvoid main() {\\n \\n float finalVertexId = mod(vertexId,fakeVerticeNumber);\\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\\n //shape\\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\\n float shapeId = floor(finalVertexId / kShapeVertexCount);\\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\\n float shapeRelId = shapeId/shapeCount;\\n \\n //group\\n float groupId = floor(shapeId/numberOfShapesPerGroup);\\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\\n float relGroupId = groupId/groupCount;\\n \\n #ifdef SOUND_REACT\\n float snd = 2.*texture2D(sound, vec2(0., (1.-relGroupId))).a;\\n #else\\n float snd = 1.;\\n #endif\\n \\n \\n #ifdef STOP_TRAJ\\n float timeB = 14.;\\n #else\\n float timeB = time * tubeSpeedFactor;\\n #endif\\n \\n\\n \\n //Static eye\\n #ifdef EYE_STATIC\\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\\n vec3 up = vec3(0.5, 0.5, 1.5);\\n #else\\n //Following eye\\n mat3 axis, sPos;// = getAxisMat(0., timeB);\\n getPosAndAxisMat(0., timeB, axis, sPos);\\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\\n vec3 target = sPos[2] * dim + axis[2];\\n vec3 up = axis[1];\\n #endif\\n \\n \\n //rotation around eye z axis\\n //mat4 rotMat = rotationMatrix(zaxis, time*PI);\\n //xaxis = (rotMat*vec4(xaxis,1.)).xyz;\\n //yaxis = (rotMat*vec4(yaxis,1.)).xyz;\\n \\n //\\n\\n \\n mat4 vmat = inverse(lookAt(eye, target, up));\\n \\n\\n vec4 cNorm;\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\\n \\n \\n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\\n \\n cubep = (scaleMat*vec4(cubep,1.)).xyz;\\n \\n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\\n cubep = (zrot*vec4(cubep,1.)).xyz;\\n \\n cNorm *= zrot;\\n //create the circle group\\n float radius =100.*radiusSizeFactor;\\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\\n //cubep.z = mod(time*2.,3.);\\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\\n \\n vec3 pos;\\n \\n //shapeId = mod(shapeId+time, shapeCount);\\n\\n mat4 posmat, rotmat;\\n\\n #ifdef DYN_GROUPID\\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\\n #else\\n getTrajMat(groupId, groupCount, timeB, posmat, rotmat);\\n #endif\\n \\n //shape orientation\\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\\n cNorm *= rotmat;\\n \\n //shape position\\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\\n \\n //vec3 finalColor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\\n \\n //vec3 LightSurface(const vec3 vAlbedo, const vec3 _eyePos, const vec3 _norm )\\n vec3 finalColor = lightget(vAlb, cubep, eye, cNorm.xyz);\\n lightPost(finalColor);\\n \\n gl_PointSize = 2.;\\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n gl_Position = pmat * vmat * vec4(cubep, 1);\\n \\n v_color = vec4(finalColor,1.);\\n}\\n\"}", + "settings": { + "num": 7200, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/apollyonpsy/loose-connection-vs-apollyon", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//In progres. Based on gman's https://www.vertexshaderart.com/art/uPwKetxzwcL2PFZd6 \n//Should be 'K Machine' compliant. Not tested yet.\n\n#define PI radians(180.0)\n \n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n#define numberOfShapesPerGroup 5.0\n#define fakeVerticeNumber 72000.\n\nconst float dim = 120.;\nconst float off = 0.1;\nconst vec3 vAlb = vec3(0.5);\n\n/////////////////////////////\n//K Machine parameters\n/////////////////////////////\n\n//KDrawmode=GL_TRIANGLE_STRIP\n\n\n#define tubeSpeedFactor 0.9 //KParameter 0.>>4.\n#define cudeSpeedFactor 80. //KParameter 0.>>150.\n#define SizeFactorX 100.1 //KParameter 1.>>10.\n#define radiusSizeFactor 0.1 //KParameter 0.05>>0.2\n#define cubeSizeFactor 1. //KParameter 0.5>>40.\n#define cubeScaleFactorY 1. //KParameter 0.5>>40.\n#define cubeScaleFactorZ 1. //KParameter 0.5>>40.\n\n\nmat4 rotZ(float _radAngle) {\n float s = sin(_radAngle);\n float c = cos(_radAngle);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 scale(vec3 _s) {\n return mat4(\n _s[0], 0, 0, 0,\n 0, _s[1], 0, 0,\n 0, 0, _s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float _fov, float _aspect, float _zNear, float _zFar) {\n float f = tan(PI * 0.5 - 0.5 * _fov);\n float rInv = 1.0 / (_zNear - _zFar);\n\n return mat4(\n f / _aspect, 0., 0., 0.,\n 0., f, 0., 0.,\n 0., 0., (_zNear + _zFar) * rInv, -1.,\n 0., 0., _zNear * _zFar * rInv * 2., 0.);\n}\n\nmat4 lookAt(vec3 _eye, vec3 _targ, vec3 _up) {\n vec3 zAx = normalize(_eye - _targ);\n vec3 xAx = normalize(cross(_up, zAx));\n vec3 yAx = cross(zAx, xAx);\n\n return mat4(\n xAx, 0.,\n yAx, 0.,\n zAx, 0.,\n _eye, 1.);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\n\nvec3 getTrajPoint(const float _id) {\n return vec3(\n sin(_id * 0.99),\n sin(_id * 2.43),\n sin(_id * 1.57));\n}\n \nvoid getPosAndAxisMat(const float _rel, const float _delta, out mat3 _axis, out mat3 _pos)\n{\n \n float pg = _rel + _delta;\n \n vec3 r0 = getTrajPoint(pg + off * 0.);\n vec3 r1 = getTrajPoint(pg + off * 1.);\n vec3 r2 = getTrajPoint(pg + off * 2.);\n \n _pos = mat3(\n getTrajPoint(pg + off * 0.),\n getTrajPoint(pg + off * 1.),\n getTrajPoint(pg + off * 2.));\n \n vec3 s0 = normalize(_pos[1] - _pos[0]);\n vec3 s1 = normalize(_pos[2] - _pos[1]);\n \n vec4 zaxis = vec4(normalize(s1 - s0),1.);\n vec4 xaxis = vec4(normalize(cross(s0, s1)),1.);\n vec4 yaxis = vec4(normalize(cross(zaxis.xyz, xaxis.xyz)),1.);\n \n _axis = mat3(\n xaxis,\n yaxis,\n zaxis);\n\n\n}\n\nvoid getTrajMat(float _shapeId, float _shapeCount, float _timeB, out mat4 _wmat, out mat4 _emat) {\n \n \n float prog = (_shapeId / _shapeCount)+_timeB;\n \n mat3 axis, mPos;\n\n getPosAndAxisMat((_shapeId / _shapeCount), _timeB, axis, mPos);\n\n //pos mtx\n _wmat = mat4(\n vec4(axis[0], 0),\n vec4(axis[1], 0),\n vec4(axis[2], 0),\n vec4(mPos[0] * dim, 1)); \n \n //orient mtx\n vec3 eye = mPos[0] * dim + axis[2] * 1.;\n vec3 target = mPos[1] * dim + axis[2];\n vec3 up = axis[1];\n \n mat4 cmat = lookAt(eye, target, up);\n _emat = inverse(cmat);\n \n \n}\n\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\nmat4 rotMatx(vec3 _axis, float _angle)\n{\n _axis = normalize(_axis);\n float s = sin(_angle);\n float c = cos(_angle);\n float oc = 1.0 - c;\n \n return mat4(oc * _axis.x * _axis.x + c, oc * _axis.x * _axis.y - _axis.z * s, oc * _axis.z * _axis.x + _axis.y * s, 0.0,\n oc * _axis.x * _axis.y + _axis.z * s, oc * _axis.y * _axis.y + c, oc * _axis.y * _axis.z - _axis.x * s, 0.0,\n oc * _axis.z * _axis.x - _axis.y * s, oc * _axis.y * _axis.z + _axis.x * s, oc * _axis.z * _axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\nvoid addPtLight( vec3 vLightPos, vec3 vLightColor, in vec3 _pos, in vec3 _norm, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - _pos);\n vec3 vViewDir = normalize(-_pos);\n \n float NdotL = max( 0.0, dot( vLightDir, _norm ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid addDirLight( vec3 _vLDir, vec3 _vLColor, in vec3 _pos, in vec3 _norm, inout vec3 _vDiff, inout vec3 _vSpec )\n{\n vec3 vViewDir = normalize(-_pos);\n \n float NdotL = max( 0.0, dot( _vLDir, _norm ) );\n \n vec3 vHalfAngle = normalize( vViewDir + _vLDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, _norm ) );\n \n _vDiff += NdotL * _vLColor;\n\n float fPower = 80.0;\n _vSpec += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * _vLColor;\n}\n\nvec3 lightget(const vec3 vAlbedo, const vec3 _pos, const vec3 _eyePos, const vec3 _norm )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n vec3 vAmbient = vec3(1., 1., 1.);\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n\n addPtLight( vec3(3.0, 2.0, 30.0), vec3( 0.2, 0.2,0.2),_pos, _norm, vDiffuseLight, vSpecLight );\n \n addDirLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, _pos, _norm, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(-_eyePos);\n \n float fNdotD = clamp(dot(_norm, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\n\nvec3 lightPost( vec3 _vColor )\n{\n float exposure = 1.0;\n _vColor = vec3(1.0) - exp2( _vColor * -exposure );\n\n _vColor = pow( _vColor, vec3(1.0 / 2.2) );\n\n return _vColor;\n}\n\n//#define EYE_STATIC true\n//#define STOP_TRAJ true\n#define DYN_GROUPID true\n#define SOUND_REACT true\n\nvoid main() {\n \n float finalVertexId = mod(vertexId,fakeVerticeNumber);\n float finalVertexCount = min(vertexCount,fakeVerticeNumber);\n //shape\n float shapeCount = floor(finalVertexCount / kShapeVertexCount);\n float shapeId = floor(finalVertexId / kShapeVertexCount);\n float shapeVertexId = mod(finalVertexId, kShapeVertexCount);\n float shapeRelId = shapeId/shapeCount;\n \n //group\n float groupId = floor(shapeId/numberOfShapesPerGroup);\n float groupCount = floor(shapeCount/numberOfShapesPerGroup);\n float shapeIdInGroup = mod(shapeId,numberOfShapesPerGroup);\n float relShapeGroupId = shapeIdInGroup/numberOfShapesPerGroup;\n float relGroupId = groupId/groupCount;\n \n #ifdef SOUND_REACT\n float snd = 2.*texture2D(sound, vec2(0., (1.-relGroupId))).a;\n #else\n float snd = 1.;\n #endif\n \n \n #ifdef STOP_TRAJ\n float timeB = 14.;\n #else\n float timeB = time * tubeSpeedFactor;\n #endif\n \n\n \n //Static eye\n #ifdef EYE_STATIC\n vec3 eye = vec3(0.5, 0.5, 2.5)*dim;\n vec3 target = vec3(0.5, 0.5, 0.)*dim;\n vec3 up = vec3(0.5, 0.5, 1.5);\n #else\n //Following eye\n mat3 axis, sPos;// = getAxisMat(0., timeB);\n getPosAndAxisMat(0., timeB, axis, sPos);\n vec3 eye = sPos[0] * dim + axis[0].xyz * 1.;\n vec3 target = sPos[2] * dim + axis[2];\n vec3 up = axis[1];\n #endif\n \n \n //rotation around eye z axis\n //mat4 rotMat = rotationMatrix(zaxis, time*PI);\n //xaxis = (rotMat*vec4(xaxis,1.)).xyz;\n //yaxis = (rotMat*vec4(yaxis,1.)).xyz;\n \n //\n\n \n mat4 vmat = inverse(lookAt(eye, target, up));\n \n\n vec4 cNorm;\n \n vec3 cubep = shapeVertex(shapeVertexId, cNorm);;\n \n \n mat4 scaleMat = scale(vec3(cubeSizeFactor,cubeScaleFactorY*cubeSizeFactor*snd,cubeScaleFactorZ*cubeSizeFactor));\n \n cubep = (scaleMat*vec4(cubep,1.)).xyz;\n \n mat4 zrot = rotZ(relShapeGroupId*2.*PI);//shape orientation\n cubep = (zrot*vec4(cubep,1.)).xyz;\n \n cNorm *= zrot;\n //create the circle group\n float radius =100.*radiusSizeFactor;\n cubep.x+= radius*sin(2.*PI*relShapeGroupId);\n cubep.y+= radius*cos(2.*PI*relShapeGroupId);\n //cubep.z = mod(time*2.,3.);\n //cubep = vec3(cubep.x , cubep.y+sndFactor*snd, cubep.z+lineId*patternSize +mod(time*speedFactor,patternSize));//position\n \n vec3 pos;\n \n //shapeId = mod(shapeId+time, shapeCount);\n\n mat4 posmat, rotmat;\n\n #ifdef DYN_GROUPID\n getTrajMat(mod(groupId-time*cudeSpeedFactor,groupCount), groupCount, timeB, posmat, rotmat);\n #else\n getTrajMat(groupId, groupCount, timeB, posmat, rotmat);\n #endif\n \n //shape orientation\n cubep = (vec4(cubep.xyz,1.)*rotmat).xyz;\n cNorm *= rotmat;\n \n //shape position\n cubep+= (posmat * vec4(0.,0.,0., 1)).xyz;\n \n //vec3 finalColor = shade(eye, cubep, cNorm.xyz, vec3(1.), 0.6, vec2(64.0, .8));\n \n //vec3 LightSurface(const vec3 vAlbedo, const vec3 _eyePos, const vec3 _norm )\n vec3 finalColor = lightget(vAlb, cubep, eye, cNorm.xyz);\n lightPost(finalColor);\n \n gl_PointSize = 2.;\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n gl_Position = pmat * vmat * vec4(cubep, 1);\n \n v_color = vec4(finalColor,1.);\n}\n" + }, "screenshotURL": "data/images/images-5xbqcf58pynac2ssy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/vyzW6DRZFHK4tEbft/art.json b/art/vyzW6DRZFHK4tEbft/art.json index a7b04a94..92c58f97 100644 --- a/art/vyzW6DRZFHK4tEbft/art.json +++ b/art/vyzW6DRZFHK4tEbft/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "lambmeow", "avatarUrl": "https://i1.sndcdn.com/avatars-000201943208-mgxm4x-large.jpg", - "settings": "{\"num\":94,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nfloat rand(float p){\\n \\treturn fract(sin(p*10000./time));\\n}\\n\\nfloat noise(vec2 p)\\n{\\n return rand((p.x + p.y) * 1000.00);\\n}\\n\\nvoid main() {\\n vec2 uv = vec2(tan(time+ vertexId + time),tan(time + vertexId));\\n gl_Position = vec4(uv,0,1);\\n gl_PointSize = 100.;\\n v_color = vec4(1);\\n v_color.a*= noise(uv *time); \\n vec3 gle = vec3(rand(vertexId),rand(sin(time)),rand(uv.x));\\n v_color.rgb *= gle;\\n}\"}", + "settings": { + "num": 94, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nfloat rand(float p){\n \treturn fract(sin(p*10000./time));\n}\n\nfloat noise(vec2 p)\n{\n return rand((p.x + p.y) * 1000.00);\n}\n\nvoid main() {\n vec2 uv = vec2(tan(time+ vertexId + time),tan(time + vertexId));\n gl_Position = vec4(uv,0,1);\n gl_PointSize = 100.;\n v_color = vec4(1);\n v_color.a*= noise(uv *time); \n vec3 gle = vec3(rand(vertexId),rand(sin(time)),rand(uv.x));\n v_color.rgb *= gle;\n}" + }, "screenshotURL": "data/images/images-60doqjdxd6io12tco-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/w2wizFHHNsMCjuyvJ/art.json b/art/w2wizFHHNsMCjuyvJ/art.json index 716fe66f..7a4d115c 100644 --- a/art/w2wizFHHNsMCjuyvJ/art.json +++ b/art/w2wizFHHNsMCjuyvJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.01568627450980392,0.023529411764705882,0.058823529411764705,1],\"shader\":\"// ==========================================\\n// ^\\n// |\\n// +-- click \\\"hide\\\" then MOVE YOUR MOUSE!!!!\\n// ==========================================\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>1.\\n#define kpx 0.160//KParameter 1.>>8.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n//KverticesNumber=233333\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float u = 0.0;\\n float v = fract(vertexId / 624.0);\\n float age = floor(vertexId / 640.0) / 240.0;\\n float invAge = 1.0 - age;\\n vec4 touch = texture2D(touch, vec2(u, v));\\n float snd = texture2D(sound, vec2(v, age) * vec2(0.125, 0.25)).a;\\n float t = time - touch.w;\\n \\n float a = mod(vertexId, 6.0) / 2.0 * PI * 2.0 + t * 222.0;\\n vec2 cs = vec2(cos(a), sin(a));\\n vec2 xy = vec2(touch.xy) + (cs * age * snd + 0.2 *asin(kpx/3. )- 0.21) * 0.1;\\n gl_Position = vec4(xy * (1.50 + (age - t) *2.0) , age, 1);\\n\\n float hue = mix(age + 0.6*kpx + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\\n vec3 color = hsv2rgb(vec3(hue, invAge, snd * touch.z));\\n v_color = vec4(mix(color, background.rgb, age)-sin(color*.18) * invAge, invAge);\\n gl_PointSize = mix(20.0, 1.0, age);\\n\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nitrofun/nitro-fun-rob-gasser-ecstasy", + "lineSize": "CSS", + "backgroundColor": [ + 0.01568627450980392, + 0.023529411764705882, + 0.058823529411764705, + 1 + ], + "shader": "// ==========================================\n// ^\n// |\n// +-- click \"hide\" then MOVE YOUR MOUSE!!!!\n// ==========================================\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>1.\n#define kpx 0.160//KParameter 1.>>8.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n//KverticesNumber=233333\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float u = 0.0;\n float v = fract(vertexId / 624.0);\n float age = floor(vertexId / 640.0) / 240.0;\n float invAge = 1.0 - age;\n vec4 touch = texture2D(touch, vec2(u, v));\n float snd = texture2D(sound, vec2(v, age) * vec2(0.125, 0.25)).a;\n float t = time - touch.w;\n \n float a = mod(vertexId, 6.0) / 2.0 * PI * 2.0 + t * 222.0;\n vec2 cs = vec2(cos(a), sin(a));\n vec2 xy = vec2(touch.xy) + (cs * age * snd + 0.2 *asin(kpx/3. )- 0.21) * 0.1;\n gl_Position = vec4(xy * (1.50 + (age - t) *2.0) , age, 1);\n\n float hue = mix(age + 0.6*kpx + sin(v * PI * 2.0) * 0.9, 0.0, touch.z);\n vec3 color = hsv2rgb(vec3(hue, invAge, snd * touch.z));\n v_color = vec4(mix(color, background.rgb, age)-sin(color*.18) * invAge, invAge);\n gl_PointSize = mix(20.0, 1.0, age);\n\n}\n\n" + }, "screenshotURL": "data/images/images-z3rh4fp54ouln35vb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/w39M6FR7PCQctz5bN/art.json b/art/w39M6FR7PCQctz5bN/art.json index 34a1a80c..183909e2 100644 --- a/art/w39M6FR7PCQctz5bN/art.json +++ b/art/w39M6FR7PCQctz5bN/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/bagagee/bassattack-episode-01-by\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = mix(0.5, 1.0, vy);\\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 4.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 6.);\\n float oddSlice = mod(sliceId, 2.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 20;\\n float snd = 0.;\\n float totalSnd = 0.;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 11);\\n float spx = hash(spf * 7.123);\\n float spy = hash(spf * 0.317);\\n float sps = hash(spf * 3.411);\\n \\n float sds = distance(vec2(u, v), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\\n mix(0.95, 1.7, sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n\\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.2 * sc * 20. / across);\\n //mat *= rotZ(snd * 10. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n \\n float pump = step(0.7, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/bagagee/bassattack-episode-01-by", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = mix(0.5, 1.0, vy);\n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float numCircleSegments = 4.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 6.);\n float oddSlice = mod(sliceId, 2.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 20;\n float snd = 0.;\n float totalSnd = 0.;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 11);\n float spx = hash(spf * 7.123);\n float spy = hash(spf * 0.317);\n float sps = hash(spf * 3.411);\n \n float sds = distance(vec2(u, v), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 1.), 3.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.151, sps), sds * .9)).a *\n mix(0.95, 1.7, sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, 1., 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n\n float sc = pow(snd, 5.0) * 2. + oddSlice * 0.;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.2 * sc * 20. / across);\n //mat *= rotZ(snd * 10. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n \n float pump = step(0.7, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 0.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-txzps8fu72q7yb8ri-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/w3EKusJyt77LiLh5E/art.json b/art/w3EKusJyt77LiLh5E/art.json index fc42b608..1326d12e 100644 --- a/art/w3EKusJyt77LiLh5E/art.json +++ b/art/w3EKusJyt77LiLh5E/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":23,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n float n = 20.0;\\n float angle = (x/n)*radians(360.0);\\n float circleWidth = 1.0;\\n float radio = 2.0 - y*circleWidth;\\n \\n float ux = radio*cos(angle);\\n float uy = radio*sin(angle);\\n vec2 xy = vec2(ux, uy) * 0.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(0.2, 0.4, 0.6, 1.0);\\n gl_PointSize = 1.0;\\n \\n // E2\\n /*\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId + 1.0, 2.0);\\n \\n vec2 xy = vec2(x, y) * 0.1;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 1.0;\\n */\\n \\n // E1\\n /*float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.1;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 10.0;*/\\n}\\n\\n\\n\"}", + "settings": { + "num": 23, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n float n = 20.0;\n float angle = (x/n)*radians(360.0);\n float circleWidth = 1.0;\n float radio = 2.0 - y*circleWidth;\n \n float ux = radio*cos(angle);\n float uy = radio*sin(angle);\n vec2 xy = vec2(ux, uy) * 0.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(0.2, 0.4, 0.6, 1.0);\n gl_PointSize = 1.0;\n \n // E2\n /*\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId + 1.0, 2.0);\n \n vec2 xy = vec2(x, y) * 0.1;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 1.0;\n */\n \n // E1\n /*float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.1;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 10.0;*/\n}\n\n\n" + }, "screenshotURL": "data/images/images-huw8dj51o2tnuxr9b-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/w5XY5hp6r86GpTyLE/art.json b/art/w5XY5hp6r86GpTyLE/art.json index 9df76e0d..1e2c732a 100644 --- a/art/w5XY5hp6r86GpTyLE/art.json +++ b/art/w5XY5hp6r86GpTyLE/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "윤수", "avatarUrl": "https://lh5.googleusercontent.com/-uoLq7WqJDyE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rePSz3yuG_mKNfPWq5PvUl80AL7Hw/mo/photo.jpg", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*------------------------------------------------------------------------\\nAuthor\\t\\t\\t\\t\\t : yoonsoo.kwon \\nAssignment Name/Number : Shader/3 (Extra Credit)\\nCourse Name\\t\\t\\t\\t: CS230\\nTerm\\t\\t\\t\\t\\t: Spring 2019\\n------------------------------------------------------------------------*/\\n\\nvoid main()\\n{\\n float value = vertexId/10.;\\n \\n gl_Position = vec4(mouse.x*value , mouse.y*value , 0,1);\\n gl_PointSize = abs(sin(time+value))*50.;\\n \\n v_color = vec4(sin(time), cos(time), tan(time), 1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*------------------------------------------------------------------------\nAuthor\t\t\t\t\t : yoonsoo.kwon \nAssignment Name/Number : Shader/3 (Extra Credit)\nCourse Name\t\t\t\t: CS230\nTerm\t\t\t\t\t: Spring 2019\n------------------------------------------------------------------------*/\n\nvoid main()\n{\n float value = vertexId/10.;\n \n gl_Position = vec4(mouse.x*value , mouse.y*value , 0,1);\n gl_PointSize = abs(sin(time+value))*50.;\n \n v_color = vec4(sin(time), cos(time), tan(time), 1);\n}" + }, "screenshotURL": "data/images/images-7w2chea2az5wzn4zb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/w5qTDiEqtC8Tri6tv/art.json b/art/w5qTDiEqtC8Tri6tv/art.json index d02bc147..7aa305a5 100644 --- a/art/w5qTDiEqtC8Tri6tv/art.json +++ b/art/w5qTDiEqtC8Tri6tv/art.json @@ -20,7 +20,19 @@ }, "private": false, "username": "-anon-", - "settings": "{\"num\":37863,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/kemono/hawaiian-hula-blues\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.1568627450980392,0.9372549019607843,0.34901960784313724,1],\"shader\":\"// ,---. ,---. .-''-. .-------. ,---------. .-''-. _____ __ .-'''-. .---. .---. ____ ______ .-''-. .-------. ____ .-------. ,---------. \\n// | / | | .'_ _ \\\\ | _ _ \\\\\\\\ \\\\ .'_ _ \\\\ \\\\ _\\\\ / / / _ \\\\| | |_ _| .' __ `. | _ `''. .'_ _ \\\\ | _ _ \\\\ .' __ `. | _ _ \\\\\\\\ \\\\ \\n// | | | .'/ ( ` ) '| ( ' ) | `--. ,---'/ ( ` ) ' .-./ ). / ' (`' )/`--'| | ( ' ) / ' \\\\ \\\\| _ | ) _ \\\\ / ( ` ) '| ( ' ) | / ' \\\\ \\\\| ( ' ) | `--. ,---' \\n// | | _ | |. (_ o _) ||(_ o _) / | \\\\ . (_ o _) | \\\\ '_ .') .' (_ o _). | '-(_{;}_)|___| / ||( ''_' ) |. (_ o _) ||(_ o _) / |___| / ||(_ o _) / | \\\\ \\n// | _( )_ || (_,_)___|| (_,_).' __ :_ _: | (_,_)___|(_ (_) _) ' (_,_). '. | (_,_) _.-` || . (_) `. || (_,_)___|| (_,_).' __ _.-` || (_,_).' __ :_ _: \\n// \\\\ (_ o._) /' \\\\ .---.| |\\\\ \\\\ | | (_I_) ' \\\\ .---. / \\\\ \\\\ .---. \\\\ :| _ _--. | .' _ ||(_ ._) '' \\\\ .---.| |\\\\ \\\\ | |.' _ || |\\\\ \\\\ | | (_I_) \\n// \\\\ (_,_) / \\\\ `-' /| | \\\\ `' /(_(=)_) \\\\ `-' / `-'`-' \\\\\\\\ `-' ||( ' ) | | | _( )_ || (_.\\\\.' / \\\\ `-' /| | \\\\ `' /| _( )_ || | \\\\ `' /(_(=)_) \\n// \\\\ / \\\\ / | | \\\\ / (_I_) \\\\ / / / \\\\ \\\\\\\\ / (_{;}_)| | \\\\ (_ o _) /| .' \\\\ / | | \\\\ / \\\\ (_ o _) /| | \\\\ / (_I_) \\n// `---` `'-..-' ''-' `'-' '---' `'-..-' '--' '----'`-...-' '(_,_) '---' '.(_,_).' '-----'` `'-..-' ''-' `'-' '.(_,_).' ''-' `'-' '---' \\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_PETAL 19.\\n#define NUM_POINTS_PER_PETAL ((NUM_EDGE_POINTS_PER_PETAL - 1.) * 3.) \\nvoid getPetalPoint(const float flowerId, const float id, out vec3 pos, out float center) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n center = step(0.5, mod(id, 3.));\\n float u = outId / (NUM_EDGE_POINTS_PER_PETAL - 1.);\\n float a = u * PI * 2.;\\n float s = sin(a);\\n float c = cos(a);\\n float x = s * 0.3;\\n float y = c - 1.;\\n float z = u;\\n pos = vec3(x, y, z) * center + vec3(0, mix(-2.0, 1.0, hash(flowerId * 0.33)) * inv(center), 0);\\n \\n}\\n\\n#define NUM_PETALS_PER_FLOWER 16.\\n#define NUM_POINTS_PER_FLOWER (NUM_POINTS_PER_PETAL * NUM_PETALS_PER_FLOWER)\\nvoid getFlowerPoint(const float flowerId, const float id, out vec3 pos, out float center) {\\n float petalId = floor(id / NUM_POINTS_PER_PETAL);\\n float pointId = mod(id, NUM_POINTS_PER_PETAL);\\n vec3 petalPos;\\n getPetalPoint(flowerId, pointId, petalPos, center);\\n mat4 mat = rotZ(petalId / NUM_PETALS_PER_FLOWER * PI * 2.);\\n pos = (mat * vec4(petalPos, 1)).xyz;\\n}\\n\\nvoid main() {\\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 0.0001);\\n float id = vertexId;\\n float numFlowers = floor(vertexCount / NUM_POINTS_PER_FLOWER);\\n float flowerId = floor(vertexId / NUM_POINTS_PER_FLOWER);// + floor(time * 100.);\\n float sOff = 0.0;\\n float sSpread = 0.01;\\n const int numSamples = 5;\\n float snd = 0.;\\n for (int i = 0; i < numSamples; ++i) {\\n vec2 uv = vec2(flowerId / numFlowers * 0.25, sOff + sSpread * float(i));\\n snd += texture2D(sound, uv).a * float(numSamples - i);\\n }\\n snd /= float(numSamples * (numSamples + 1)) / 2.5;\\n vec3 offset = vec3(m1p1(hash(flowerId)) / aspect.x, m1p1(hash(flowerId * 1.37)), -m1p1(flowerId / 10.));\\n vec3 pos;\\n float center;\\n getFlowerPoint(flowerId, id, pos, center);\\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= rotZ(time * mix(-1., 1., hash(flowerId * 1.54)));\\n mat *= uniformScale(mix(0.1, 0.2, hash(flowerId)) + pow(snd, 5.0) * 0.1);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n \\n\\n float hue = mix(-0.2, 0.2, fract(time * 0.1 + flowerId * 0.13 + center * 0.1));\\n float sat = mix(.4, .7, hash(flowerId * 0.7));\\n float val = mix(mix(0.5, 1.0, hash(flowerId * 0.27)), 0.0, center * inv(hash(flowerId * 0.73)));\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.0 + pow(snd + 0.3, 5.0));\\n v_color = vec4(v_color.xyz * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 37863, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/kemono/hawaiian-hula-blues", + "lineSize": "CSS", + "backgroundColor": [ + 0.1568627450980392, + 0.9372549019607843, + 0.34901960784313724, + 1 + ], + "shader": "// ,---. ,---. .-''-. .-------. ,---------. .-''-. _____ __ .-'''-. .---. .---. ____ ______ .-''-. .-------. ____ .-------. ,---------. \n// | / | | .'_ _ \\ | _ _ \\\\ \\ .'_ _ \\ \\ _\\ / / / _ \\| | |_ _| .' __ `. | _ `''. .'_ _ \\ | _ _ \\ .' __ `. | _ _ \\\\ \\ \n// | | | .'/ ( ` ) '| ( ' ) | `--. ,---'/ ( ` ) ' .-./ ). / ' (`' )/`--'| | ( ' ) / ' \\ \\| _ | ) _ \\ / ( ` ) '| ( ' ) | / ' \\ \\| ( ' ) | `--. ,---' \n// | | _ | |. (_ o _) ||(_ o _) / | \\ . (_ o _) | \\ '_ .') .' (_ o _). | '-(_{;}_)|___| / ||( ''_' ) |. (_ o _) ||(_ o _) / |___| / ||(_ o _) / | \\ \n// | _( )_ || (_,_)___|| (_,_).' __ :_ _: | (_,_)___|(_ (_) _) ' (_,_). '. | (_,_) _.-` || . (_) `. || (_,_)___|| (_,_).' __ _.-` || (_,_).' __ :_ _: \n// \\ (_ o._) /' \\ .---.| |\\ \\ | | (_I_) ' \\ .---. / \\ \\ .---. \\ :| _ _--. | .' _ ||(_ ._) '' \\ .---.| |\\ \\ | |.' _ || |\\ \\ | | (_I_) \n// \\ (_,_) / \\ `-' /| | \\ `' /(_(=)_) \\ `-' / `-'`-' \\\\ `-' ||( ' ) | | | _( )_ || (_.\\.' / \\ `-' /| | \\ `' /| _( )_ || | \\ `' /(_(=)_) \n// \\ / \\ / | | \\ / (_I_) \\ / / / \\ \\\\ / (_{;}_)| | \\ (_ o _) /| .' \\ / | | \\ / \\ (_ o _) /| | \\ / (_I_) \n// `---` `'-..-' ''-' `'-' '---' `'-..-' '--' '----'`-...-' '(_,_) '---' '.(_,_).' '-----'` `'-..-' ''-' `'-' '.(_,_).' ''-' `'-' '---' \n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_PETAL 19.\n#define NUM_POINTS_PER_PETAL ((NUM_EDGE_POINTS_PER_PETAL - 1.) * 3.) \nvoid getPetalPoint(const float flowerId, const float id, out vec3 pos, out float center) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n center = step(0.5, mod(id, 3.));\n float u = outId / (NUM_EDGE_POINTS_PER_PETAL - 1.);\n float a = u * PI * 2.;\n float s = sin(a);\n float c = cos(a);\n float x = s * 0.3;\n float y = c - 1.;\n float z = u;\n pos = vec3(x, y, z) * center + vec3(0, mix(-2.0, 1.0, hash(flowerId * 0.33)) * inv(center), 0);\n \n}\n\n#define NUM_PETALS_PER_FLOWER 16.\n#define NUM_POINTS_PER_FLOWER (NUM_POINTS_PER_PETAL * NUM_PETALS_PER_FLOWER)\nvoid getFlowerPoint(const float flowerId, const float id, out vec3 pos, out float center) {\n float petalId = floor(id / NUM_POINTS_PER_PETAL);\n float pointId = mod(id, NUM_POINTS_PER_PETAL);\n vec3 petalPos;\n getPetalPoint(flowerId, pointId, petalPos, center);\n mat4 mat = rotZ(petalId / NUM_PETALS_PER_FLOWER * PI * 2.);\n pos = (mat * vec4(petalPos, 1)).xyz;\n}\n\nvoid main() {\n vec3 aspect = vec3(resolution.y / resolution.x, 1, 0.0001);\n float id = vertexId;\n float numFlowers = floor(vertexCount / NUM_POINTS_PER_FLOWER);\n float flowerId = floor(vertexId / NUM_POINTS_PER_FLOWER);// + floor(time * 100.);\n float sOff = 0.0;\n float sSpread = 0.01;\n const int numSamples = 5;\n float snd = 0.;\n for (int i = 0; i < numSamples; ++i) {\n vec2 uv = vec2(flowerId / numFlowers * 0.25, sOff + sSpread * float(i));\n snd += texture2D(sound, uv).a * float(numSamples - i);\n }\n snd /= float(numSamples * (numSamples + 1)) / 2.5;\n vec3 offset = vec3(m1p1(hash(flowerId)) / aspect.x, m1p1(hash(flowerId * 1.37)), -m1p1(flowerId / 10.));\n vec3 pos;\n float center;\n getFlowerPoint(flowerId, id, pos, center);\n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= rotZ(time * mix(-1., 1., hash(flowerId * 1.54)));\n mat *= uniformScale(mix(0.1, 0.2, hash(flowerId)) + pow(snd, 5.0) * 0.1);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n \n\n float hue = mix(-0.2, 0.2, fract(time * 0.1 + flowerId * 0.13 + center * 0.1));\n float sat = mix(.4, .7, hash(flowerId * 0.7));\n float val = mix(mix(0.5, 1.0, hash(flowerId * 0.27)), 0.0, center * inv(hash(flowerId * 0.73)));\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.0 + pow(snd + 0.3, 5.0));\n v_color = vec4(v_color.xyz * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-js9skd9fqg6rbavbw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/w9fNQs5qa7s4CmEvg/art.json b/art/w9fNQs5qa7s4CmEvg/art.json index c419deaa..ef1e48b0 100644 --- a/art/w9fNQs5qa7s4CmEvg/art.json +++ b/art/w9fNQs5qa7s4CmEvg/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 15.0\\n\\n//\\tClassic Perlin 3D Noise \\n//\\tby Stefan Gustavson\\n//\\nvec4 permute(vec4 x){return mod(((x*6.0)+1.0)*x, 289.0);}\\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\\n\\nfloat cnoise(vec3 P){\\n vec3 Pi0 = floor(P); // Integer part for indexing\\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\\n Pi0 = mod(Pi0, 289.0);\\n Pi1 = mod(Pi1, 289.0);\\n vec3 Pf0 = fract(P); // Fractional part for interpolation\\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\\n vec4 iz0 = Pi0.zzzz;\\n vec4 iz1 = Pi1.zzzz;\\n\\n vec4 ixy = permute(permute(ix) + iy);\\n vec4 ixy0 = permute(ixy + iz0);\\n vec4 ixy1 = permute(ixy + iz1);\\n\\n vec4 gx0 = ixy0 / 7.0;\\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\\n gx0 = fract(gx0);\\n vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\\n vec4 sz0 = step(gz0, vec4(0.0));\\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\\n\\n vec4 gx1 = ixy1 / 7.0;\\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\\n gx1 = fract(gx1);\\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\\n vec4 sz1 = step(gz1, vec4(0.0));\\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\\n\\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\\n\\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\\n g000 *= norm0.x;\\n g010 *= norm0.y;\\n g100 *= norm0.z;\\n g110 *= norm0.w;\\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\\n g001 *= norm1.x;\\n g011 *= norm1.y;\\n g101 *= norm1.z;\\n g111 *= norm1.w;\\n\\n float n000 = dot(g000, Pf0);\\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\\n float n111 = dot(g111, Pf1);\\n\\n vec3 fade_xyz = fade(Pf0);\\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \\n return 2.2 * n_xyz;\\n}\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angle) {\\nfloat Snd =texture2D(sound,vec2(0)).a;\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, Snd, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount));\\n \\tfloat cols = floor(vertexCount / rows);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n\\n\\tfloat a = atan(x, y);\\n \\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\\n \\tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\\n \\tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\\n float Snd =texture2D(sound,vec2(0)).a;\\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n vec4 pos = vec4(ux, vy, 0, 1);\\n \\tvec3 n = vec3(cnoise(pos.xyz*.51));\\n \\t//pos.x += n.x*1.9762*sin(n.x+time);\\n \\t//pos.y += n.y*.62;\\n \\t//pos.z += n.z*.9762;\\n \\t//pos*=rotY(PI*time*.125);\\n \\t//pos*=rotX(PI*time*.0125);\\n\\tgl_Position = pos;\\n \\tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \\n \\n float S =texture2D(volume,vec2(0)).a;\\n// 72.0 /Snd+cols; \\n \\tgl_PointSize *= resolution.x / 333.-S; \\n float hue = s;\\n hue = smoothstep(x, y-S, xOff);\\n float sat = v * xOff;\\n float val = u;\\n \\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n color *= rotY(-PI * soff);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n\\n v_color = finalColor;\\n }\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 15.0\n\n//\tClassic Perlin 3D Noise \n//\tby Stefan Gustavson\n//\nvec4 permute(vec4 x){return mod(((x*6.0)+1.0)*x, 289.0);}\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159 - 0.85373472095314 * r;}\nvec3 fade(vec3 t) {return t*t*t*(t*(t*6.0-15.0)+10.0);}\n\nfloat cnoise(vec3 P){\n vec3 Pi0 = floor(P); // Integer part for indexing\n vec3 Pi1 = Pi0 + vec3(1.0); // Integer part + 1\n Pi0 = mod(Pi0, 289.0);\n Pi1 = mod(Pi1, 289.0);\n vec3 Pf0 = fract(P); // Fractional part for interpolation\n vec3 Pf1 = Pf0 - vec3(1.0); // Fractional part - 1.0\n vec4 ix = vec4(Pi0.x, Pi1.x, Pi0.x, Pi1.x);\n vec4 iy = vec4(Pi0.yy, Pi1.yy);\n vec4 iz0 = Pi0.zzzz;\n vec4 iz1 = Pi1.zzzz;\n\n vec4 ixy = permute(permute(ix) + iy);\n vec4 ixy0 = permute(ixy + iz0);\n vec4 ixy1 = permute(ixy + iz1);\n\n vec4 gx0 = ixy0 / 7.0;\n vec4 gy0 = fract(floor(gx0) / 7.0) - 0.5;\n gx0 = fract(gx0);\n vec4 gz0 = vec4(0.5) - abs(gx0) - abs(gy0);\n vec4 sz0 = step(gz0, vec4(0.0));\n gx0 -= sz0 * (step(0.0, gx0) - 0.5);\n gy0 -= sz0 * (step(0.0, gy0) - 0.5);\n\n vec4 gx1 = ixy1 / 7.0;\n vec4 gy1 = fract(floor(gx1) / 7.0) - 0.5;\n gx1 = fract(gx1);\n vec4 gz1 = vec4(0.5) - abs(gx1) - abs(gy1);\n vec4 sz1 = step(gz1, vec4(0.0));\n gx1 -= sz1 * (step(0.0, gx1) - 0.5);\n gy1 -= sz1 * (step(0.0, gy1) - 0.5);\n\n vec3 g000 = vec3(gx0.x,gy0.x,gz0.x);\n vec3 g100 = vec3(gx0.y,gy0.y,gz0.y);\n vec3 g010 = vec3(gx0.z,gy0.z,gz0.z);\n vec3 g110 = vec3(gx0.w,gy0.w,gz0.w);\n vec3 g001 = vec3(gx1.x,gy1.x,gz1.x);\n vec3 g101 = vec3(gx1.y,gy1.y,gz1.y);\n vec3 g011 = vec3(gx1.z,gy1.z,gz1.z);\n vec3 g111 = vec3(gx1.w,gy1.w,gz1.w);\n\n vec4 norm0 = taylorInvSqrt(vec4(dot(g000, g000), dot(g010, g010), dot(g100, g100), dot(g110, g110)));\n g000 *= norm0.x;\n g010 *= norm0.y;\n g100 *= norm0.z;\n g110 *= norm0.w;\n vec4 norm1 = taylorInvSqrt(vec4(dot(g001, g001), dot(g011, g011), dot(g101, g101), dot(g111, g111)));\n g001 *= norm1.x;\n g011 *= norm1.y;\n g101 *= norm1.z;\n g111 *= norm1.w;\n\n float n000 = dot(g000, Pf0);\n float n100 = dot(g100, vec3(Pf1.x, Pf0.yz));\n float n010 = dot(g010, vec3(Pf0.x, Pf1.y, Pf0.z));\n float n110 = dot(g110, vec3(Pf1.xy, Pf0.z));\n float n001 = dot(g001, vec3(Pf0.xy, Pf1.z));\n float n101 = dot(g101, vec3(Pf1.x, Pf0.y, Pf1.z));\n float n011 = dot(g011, vec3(Pf0.x, Pf1.yz));\n float n111 = dot(g111, Pf1);\n\n vec3 fade_xyz = fade(Pf0);\n vec4 n_z = mix(vec4(n000, n100, n010, n110), vec4(n001, n101, n011, n111), fade_xyz.z);\n vec2 n_yz = mix(n_z.xy, n_z.zw, fade_xyz.y);\n float n_xyz = mix(n_yz.x, n_yz.y, fade_xyz.x); \n return 2.2 * n_xyz;\n}\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angle) {\nfloat Snd =texture2D(sound,vec2(0)).a;\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, Snd, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount));\n \tfloat cols = floor(vertexCount / rows);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n\n\tfloat a = atan(x, y);\n \n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(PI * time * .125 + y * 0.015) * 0.5;\n \tfloat yOff = cos(PI* time + x *.002* y * 0.333) * xOff;\n \tfloat soff = cos(PI* time * .25 + x * y * 0.0005) * 0.25;\n float Snd =texture2D(sound,vec2(0)).a;\n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n vec4 pos = vec4(ux, vy, 0, 1);\n \tvec3 n = vec3(cnoise(pos.xyz*.51));\n \t//pos.x += n.x*1.9762*sin(n.x+time);\n \t//pos.y += n.y*.62;\n \t//pos.z += n.z*.9762;\n \t//pos*=rotY(PI*time*.125);\n \t//pos*=rotX(PI*time*.0125);\n\tgl_Position = pos;\n \tgl_PointSize = 5.0-pos.z;// - soff*sin(time*.001); \n \n float S =texture2D(volume,vec2(0)).a;\n// 72.0 /Snd+cols; \n \tgl_PointSize *= resolution.x / 333.-S; \n float hue = s;\n hue = smoothstep(x, y-S, xOff);\n float sat = v * xOff;\n float val = u;\n \n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n color *= rotY(-PI * soff);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n\n v_color = finalColor;\n }" + }, "screenshotURL": "data/images/images-36aub785g7fz54v0t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wAHW2jvdnk46gwycK/art.json b/art/wAHW2jvdnk46gwycK/art.json index 511fb0d1..b5f74bbe 100644 --- a/art/wAHW2jvdnk46gwycK/art.json +++ b/art/wAHW2jvdnk46gwycK/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0,0.13725490196078433,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; // sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.0; // sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 20.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time + v * 20.0);\\n float sat = v;\\n float val = v;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0, + 0.13725490196078433, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; // sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.0; // sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 20.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time + v * 20.0);\n float sat = v;\n float val = v;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-z64r90hp5xeh8l99o-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wCMaWve5ErdStTm5C/art.json b/art/wCMaWve5ErdStTm5C/art.json index 314821dc..cb5f5667 100644 --- a/art/wCMaWve5ErdStTm5C/art.json +++ b/art/wCMaWve5ErdStTm5C/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//vertex shader:\\nvoid main() {\\n \\n int vertID = int(vertexId);\\n \\n float left = -0.025;\\n float rightTop = 0.5;\\n float rightBottom = 0.0125;\\n \\n //Triangle 0\\n if (vertID == 0) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 1) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n else if (vertID == 2) {\\n \\tgl_Position = vec4(rightBottom, -0.3, 0, 1); \\n v_color = vec4(1, 1, 1, 1);\\n }\\n \\n //Triangle 1\\n else if (vertID == 3) {\\n \\tgl_Position = vec4(left, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 4) {\\n \\tgl_Position = vec4(rightTop, 0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n else if (vertID == 5) {\\n \\tgl_Position = vec4(left, -0.3, 0, 1); \\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n \\n \\n \\n if (vertID == 1 || vertID == 2 || vertID == 4) { \\n \\tv_color = vec4(1, 1, 1, 1);\\n }\\n else {\\n v_color = vec4(1, 0, 0, 1);\\n }\\n \\n \\n \\n}\\n\"}", + "settings": { + "num": 6, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//vertex shader:\nvoid main() {\n \n int vertID = int(vertexId);\n \n float left = -0.025;\n float rightTop = 0.5;\n float rightBottom = 0.0125;\n \n //Triangle 0\n if (vertID == 0) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 1) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n else if (vertID == 2) {\n \tgl_Position = vec4(rightBottom, -0.3, 0, 1); \n v_color = vec4(1, 1, 1, 1);\n }\n \n //Triangle 1\n else if (vertID == 3) {\n \tgl_Position = vec4(left, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 4) {\n \tgl_Position = vec4(rightTop, 0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n else if (vertID == 5) {\n \tgl_Position = vec4(left, -0.3, 0, 1); \n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n \n \n \n if (vertID == 1 || vertID == 2 || vertID == 4) { \n \tv_color = vec4(1, 1, 1, 1);\n }\n else {\n v_color = vec4(1, 0, 0, 1);\n }\n \n \n \n}\n" + }, "screenshotURL": "data/images/images-wl6vjqljppr9wlmt5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wFYATkgtzx3PKBDcw/art.json b/art/wFYATkgtzx3PKBDcw/art.json index 32a9ac3d..4478650b 100644 --- a/art/wFYATkgtzx3PKBDcw/art.json +++ b/art/wFYATkgtzx3PKBDcw/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gregoireciles", "avatarUrl": "https://avatars.githubusercontent.com/GregoireCiles?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.011764705882352941,0,0.1803921568627451,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float uy = v * 2.0 - 1.0;\\n \\n gl_Position = vec4(ux, uy, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.011764705882352941, + 0, + 0.1803921568627451, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float uy = v * 2.0 - 1.0;\n \n gl_Position = vec4(ux, uy, 0.0, 1.0);\n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-3gxm2ju2gkh5tklqb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wFdw32QXQhDAXDLmi/art.json b/art/wFdw32QXQhDAXDLmi/art.json index b2d06a05..6ef52a58 100644 --- a/art/wFdw32QXQhDAXDLmi/art.json +++ b/art/wFdw32QXQhDAXDLmi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":25957,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/electricmantis/daybreak\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.058823529411764705,0.058823529411764705,0.058823529411764705,1],\"shader\":\"// chrillo\\n\\n#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n\\nvoid main () {\\n float i = hash(vertexId);\\n float f = hash(i);\\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\\n snd = pow(snd, 2.);\\n \\n float ang = vertexId / 1000.;\\n float perspective = .5 * (1. - mouse.y);\\n float t = time * (f + .5) - mouse.x;\\n float x = i * sin(ang + t) * .8;\\n float y = i * cos(ang + t);\\n y += .1 * snd * (1. - y);\\n y *= perspective;\\n \\n float vis = snd / (y + 1.);\\n \\n gl_Position = vec4(x, y, 0., 1.);\\n gl_PointSize = 5. * vis;\\n \\n v_color = vec4(\\n snd * .7 * (2. - f),\\n snd * .8 * cos(f * PI),\\n snd * 2.,\\n vis);\\n}\"}", + "settings": { + "num": 25957, + "mode": "POINTS", + "sound": "https://soundcloud.com/electricmantis/daybreak", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.058823529411764705, + 0.058823529411764705, + 0.058823529411764705, + 1 + ], + "shader": "// chrillo\n\n#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n\nvoid main () {\n float i = hash(vertexId);\n float f = hash(i);\n float snd = texture2D(sound, vec2(f, i)).a * cos(i);\n snd = pow(snd, 2.);\n \n float ang = vertexId / 1000.;\n float perspective = .5 * (1. - mouse.y);\n float t = time * (f + .5) - mouse.x;\n float x = i * sin(ang + t) * .8;\n float y = i * cos(ang + t);\n y += .1 * snd * (1. - y);\n y *= perspective;\n \n float vis = snd / (y + 1.);\n \n gl_Position = vec4(x, y, 0., 1.);\n gl_PointSize = 5. * vis;\n \n v_color = vec4(\n snd * .7 * (2. - f),\n snd * .8 * cos(f * PI),\n snd * 2.,\n vis);\n}" + }, "screenshotURL": "data/images/images-1xhkzzq9gmxbok4ae-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wFtvqKAQ3wB8Hho3p/art.json b/art/wFtvqKAQ3wB8Hho3p/art.json index e61249fd..c7ec3f61 100644 --- a/art/wFtvqKAQ3wB8Hho3p/art.json +++ b/art/wFtvqKAQ3wB8Hho3p/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/siesta8bit/siesta8bit-compilation-album-preview-low-bit\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n\\nvoid getCirclePoint(float id, out vec3 pos) {\\n /*\\n\\n 0-1 3\\n |/ /|\\n 2 4-5\\n\\n */\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float angle = ux / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;\\n pos.x = cos(angle);\\n pos.y = vy;\\n pos.z = sin(angle);\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float ringOff = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float ringId = circleId + ringOff;\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n\\n float ru0 = (ringId - 1.) / numCircles;\\n float ru1 = (ringId ) / numCircles;\\n float ru2 = (ringId + 1.) / numCircles;\\n\\n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, ru0), ru0 * 0.25)).a;\\n float s1 = texture2D(sound, vec2(mix(0.1, 0.5, ru1), ru1 * 0.25)).a;\\n float s2 = texture2D(sound, vec2(mix(0.1, 0.5, ru2), ru2 * 0.25)).a;\\n \\n float cu = circleId / numCircles;\\n vec3 pos;\\n getCirclePoint(pointId, pos); \\n \\n mat4 mat = ident(); \\n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n \\n float camRadius = 3.0;\\n float camTime = time * 0.1;\\n vec3 eye = vec3(cos(camTime) * camRadius, sin(camTime * 0.93) * camRadius, sin(camTime * 0.9) * camRadius);\\n vec3 up = vec3(sin(camTime), cos(camTime), 0);\\n vec3 target = vec3(0, 0,0);\\n\\n \\n mat *= cameraLookAt(eye, target, up); \\n float sc = mix(0.2, 2.0, pow(s1, 2.));\\n sc *= 1. - pow(1. - sin(ru1 * PI), 5.);\\n mat *= scale(vec3(sc, 4.0 / numCircles, sc));\\n //mat *= rotX(PI * 0.5);\\n mat *= trans(vec3(0, circleId - numCircles * 0.4, 0));\\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n \\n\\n float pop = step(0.6, s1);\\n \\n float hue = time * .1 + ru1 * 0.1;\\n float sat = 0.6;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n vec3 nrm = normalize(vec3(pos.x, s1 - s2 - s0, pos.z));\\n float l1 = clamp(dot(nrm, normalize(vec3(1,2,3))), 0.0, 1.0);\\n float l2 = clamp(dot(nrm, normalize(vec3(-2,4,-3))), 0.0, 1.0);\\n \\n v_color.rgb *= mix(0.3, 2., clamp(l1 + l2, 0.0, 1.0));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n\\n vec4 p_color = vec4(hsv2rgb(vec3(hue + 0.5 + cu * 0.1, mix(0.7, 1., mod(time * 60.0, 2.0)), 1)), 1);\\n \\n v_color = mix(v_color, p_color, step(0.6, s1));\\n v_color = mix(v_color, vec4(1,1,1,1), step(0.8, s1));\\n} \\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/siesta8bit/siesta8bit-compilation-album-preview-low-bit", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n\nvoid getCirclePoint(float id, out vec3 pos) {\n /*\n\n 0-1 3\n |/ /|\n 2 4-5\n\n */\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float angle = ux / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;\n pos.x = cos(angle);\n pos.y = vy;\n pos.z = sin(angle);\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float ringOff = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float ringId = circleId + ringOff;\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n\n float ru0 = (ringId - 1.) / numCircles;\n float ru1 = (ringId ) / numCircles;\n float ru2 = (ringId + 1.) / numCircles;\n\n float s0 = texture2D(sound, vec2(mix(0.1, 0.5, ru0), ru0 * 0.25)).a;\n float s1 = texture2D(sound, vec2(mix(0.1, 0.5, ru1), ru1 * 0.25)).a;\n float s2 = texture2D(sound, vec2(mix(0.1, 0.5, ru2), ru2 * 0.25)).a;\n \n float cu = circleId / numCircles;\n vec3 pos;\n getCirclePoint(pointId, pos); \n \n mat4 mat = ident(); \n mat *= persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n \n float camRadius = 3.0;\n float camTime = time * 0.1;\n vec3 eye = vec3(cos(camTime) * camRadius, sin(camTime * 0.93) * camRadius, sin(camTime * 0.9) * camRadius);\n vec3 up = vec3(sin(camTime), cos(camTime), 0);\n vec3 target = vec3(0, 0,0);\n\n \n mat *= cameraLookAt(eye, target, up); \n float sc = mix(0.2, 2.0, pow(s1, 2.));\n sc *= 1. - pow(1. - sin(ru1 * PI), 5.);\n mat *= scale(vec3(sc, 4.0 / numCircles, sc));\n //mat *= rotX(PI * 0.5);\n mat *= trans(vec3(0, circleId - numCircles * 0.4, 0));\n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n \n\n float pop = step(0.6, s1);\n \n float hue = time * .1 + ru1 * 0.1;\n float sat = 0.6;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n vec3 nrm = normalize(vec3(pos.x, s1 - s2 - s0, pos.z));\n float l1 = clamp(dot(nrm, normalize(vec3(1,2,3))), 0.0, 1.0);\n float l2 = clamp(dot(nrm, normalize(vec3(-2,4,-3))), 0.0, 1.0);\n \n v_color.rgb *= mix(0.3, 2., clamp(l1 + l2, 0.0, 1.0));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n\n vec4 p_color = vec4(hsv2rgb(vec3(hue + 0.5 + cu * 0.1, mix(0.7, 1., mod(time * 60.0, 2.0)), 1)), 1);\n \n v_color = mix(v_color, p_color, step(0.6, s1));\n v_color = mix(v_color, vec4(1,1,1,1), step(0.8, s1));\n} \n\n" + }, "screenshotURL": "data/images/images-yheobgbtjk9ttasx6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wFxoEvW6hYYYYfiKt/art.json b/art/wFxoEvW6hYYYYfiKt/art.json index ed631ef9..080b067d 100644 --- a/art/wFxoEvW6hYYYYfiKt/art.json +++ b/art/wFxoEvW6hYYYYfiKt/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "staeter", "avatarUrl": "https://avatars.githubusercontent.com/staeter?s=200", - "settings": "{\"num\":2111,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// complex numbers\\n// vec2(real part, complex part)\\nvec2 cProd(vec2 a, vec2 b) {\\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\\n}\\nfloat cModSqrd(vec2 a) {\\n return (a.x*a.x + a.y*a.y);\\n}\\nint mandelbrot(float x, float y) {\\n int n = 0;\\n vec2 z = vec2(0,0);\\n vec2 c = vec2(x,y);\\n \\n // no loops in glsl so jsut repeat 100 times\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\\n \\n return n;\\n}\\nfloat clamped_mandelbrot(float x, float y) {\\n return float(mandelbrot(x,y))/25.;\\n}\\n\\nvoid main() {\\n float resArea = resolution.x * resolution.y;\\n float areaPerVertex = resArea/vertexCount;\\n float vertLen = sqrt(areaPerVertex);\\n float vertAcrossX = floor(resolution.x/vertLen);\\n float vertAcrossY = floor(resolution.y/vertLen);\\n \\n float u = (mod(vertexId, vertAcrossX)-.5)/(vertAcrossX-1.);\\n u = (u - 0.5) * 2.;\\n float v = (floor(vertexId / vertAcrossX)-.5)/(vertAcrossY-1.);\\n v = (v - 0.5) * 2.;\\n \\n float x = u * resolution.x / resolution.y;\\n float y = v * resolution.x / resolution.x;\\n vec2 m = vec2(mouse.x/resolution.y, mouse.y/resolution.x);\\n \\n gl_Position = vec4(u, v, 0, 1);\\n gl_PointSize = vertLen*1.05;\\n \\n float fractal = clamped_mandelbrot(x, y);\\n v_color = vec4(hsv2rgb(vec3(1.-fractal, 1., 1.-fractal)), 1.);\\n}\"}", + "settings": { + "num": 2111, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// complex numbers\n// vec2(real part, complex part)\nvec2 cProd(vec2 a, vec2 b) {\n return vec2(a.x*b.x - a.y*b.y, a.x*b.y + a.y*b.x);\n}\nfloat cModSqrd(vec2 a) {\n return (a.x*a.x + a.y*a.y);\n}\nint mandelbrot(float x, float y) {\n int n = 0;\n vec2 z = vec2(0,0);\n vec2 c = vec2(x,y);\n \n // no loops in glsl so jsut repeat 100 times\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n z = cProd(z,z) + c; n++; if(abs(cModSqrd(z))>4.) return n;\n \n return n;\n}\nfloat clamped_mandelbrot(float x, float y) {\n return float(mandelbrot(x,y))/25.;\n}\n\nvoid main() {\n float resArea = resolution.x * resolution.y;\n float areaPerVertex = resArea/vertexCount;\n float vertLen = sqrt(areaPerVertex);\n float vertAcrossX = floor(resolution.x/vertLen);\n float vertAcrossY = floor(resolution.y/vertLen);\n \n float u = (mod(vertexId, vertAcrossX)-.5)/(vertAcrossX-1.);\n u = (u - 0.5) * 2.;\n float v = (floor(vertexId / vertAcrossX)-.5)/(vertAcrossY-1.);\n v = (v - 0.5) * 2.;\n \n float x = u * resolution.x / resolution.y;\n float y = v * resolution.x / resolution.x;\n vec2 m = vec2(mouse.x/resolution.y, mouse.y/resolution.x);\n \n gl_Position = vec4(u, v, 0, 1);\n gl_PointSize = vertLen*1.05;\n \n float fractal = clamped_mandelbrot(x, y);\n v_color = vec4(hsv2rgb(vec3(1.-fractal, 1., 1.-fractal)), 1.);\n}" + }, "screenshotURL": "data/images/images-xoxz5ygjpco8ie76z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wGQZbn4NqJiMq8Rvv/art.json b/art/wGQZbn4NqJiMq8Rvv/art.json index f1dd194c..37ab65f8 100644 --- a/art/wGQZbn4NqJiMq8Rvv/art.json +++ b/art/wGQZbn4NqJiMq8Rvv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hugo-w", "avatarUrl": "https://avatars.githubusercontent.com/Hugo-W?s=200", - "settings": "{\"num\":16384,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n\\n float x = u * 2.0 - 1.0;\\n float y = v * 2.0 - 1.0;\\n vec2 xy = vec2(\\n x * mix(0.5, 1.0, invV),\\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\\n gl_Position = vec4(xy * 0.5, 0, 1);\\n\\n float hue = u;\\n float sat = invV;\\n float val = invV;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\\n}\"}", + "settings": { + "num": 16384, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n\n float x = u * 2.0 - 1.0;\n float y = v * 2.0 - 1.0;\n vec2 xy = vec2(\n x * mix(0.5, 1.0, invV),\n y + pow(snd, 5.0) * 1.0) / (v + 0.5);\n gl_Position = vec4(xy * 0.5, 0, 1);\n\n float hue = u;\n float sat = invV;\n float val = invV;\n v_color = mix(vec4(hsv2rgb(vec3(hue, sat, val)), 1), background, v * v);\n}" + }, "screenshotURL": "data/images/images-35d6dzsosl1wle0bj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wGx3PFi6cT8Dydevv/art.json b/art/wGx3PFi6cT8Dydevv/art.json index a6f15e4b..9fb06898 100644 --- a/art/wGx3PFi6cT8Dydevv/art.json +++ b/art/wGx3PFi6cT8Dydevv/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":999,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){gl_Position=vec4(vertexId/vertexCount*2.1-1.,sin(vertexId*mod(vertexId,9.2)+time),0,1);v_color=vec4(4,1,5,1)}\"}", + "settings": { + "num": 999, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){gl_Position=vec4(vertexId/vertexCount*2.1-1.,sin(vertexId*mod(vertexId,9.2)+time),0,1);v_color=vec4(4,1,5,1)}" + }, "screenshotURL": "data/images/images-f351mglyixm8vpy58-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wHYadcJcCHsjn3cvr/art.json b/art/wHYadcJcCHsjn3cvr/art.json index f4b4d3dd..75423222 100644 --- a/art/wHYadcJcCHsjn3cvr/art.json +++ b/art/wHYadcJcCHsjn3cvr/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,1,1,1],\"shader\":\"void main() {\\n\\tgl_PointSize = 10.0;\\n \\tgl_Position = vec4(0.0, 0.0, 0.0, 1.0);\\n \\tv_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 3, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 1, + 1, + 1 + ], + "shader": "void main() {\n\tgl_PointSize = 10.0;\n \tgl_Position = vec4(0.0, 0.0, 0.0, 1.0);\n \tv_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-768cr750wf8j84seq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wHiihz6NHxZhtHDon/art.json b/art/wHiihz6NHxZhtHDon/art.json index 59702104..768d52bb 100644 --- a/art/wHiihz6NHxZhtHDon/art.json +++ b/art/wHiihz6NHxZhtHDon/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "oriam", "avatarUrl": "https://secure.gravatar.com/avatar/c1ddb12d07628010aa44539d8cedfb07?default=retro&size=200", - "settings": "{\"num\":42,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,0.5019607843137255,1],\"shader\":\"void main()\\n{\\n float x = floor(vertexId / 2.0);\\n float y = mod(vertexId, 2.0);\\n \\n float angle = x / 20.0 * radians(360.0);\\n float radius = y + 1.0;\\n \\n float u = radius * cos(angle) * 0.4;\\n float v = radius * sin(angle) * 0.4;\\n \\n vec2 xy = vec2(u, v);\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 42, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 0.5019607843137255, + 1 + ], + "shader": "void main()\n{\n float x = floor(vertexId / 2.0);\n float y = mod(vertexId, 2.0);\n \n float angle = x / 20.0 * radians(360.0);\n float radius = y + 1.0;\n \n float u = radius * cos(angle) * 0.4;\n float v = radius * sin(angle) * 0.4;\n \n vec2 xy = vec2(u, v);\n \n gl_Position = vec4(xy, 0.0, 1.0);\n gl_PointSize = 20.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-90ie65vyz2cf9txdr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wJ3ERkQqdQYSY6bnL/art.json b/art/wJ3ERkQqdQYSY6bnL/art.json index c1bb7bad..a2947cef 100644 --- a/art/wJ3ERkQqdQYSY6bnL/art.json +++ b/art/wJ3ERkQqdQYSY6bnL/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/t0kisaki/u-got-that-halogen\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2196078431372549,0.2196078431372549,0.21176470588235294,1],\"shader\":\"/*\\n\\n-=O=-\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22- time* a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis-2.));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.9;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, z-y, x); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes)) * 2.;\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\\n cpos = normalize(cpos) * hash(cubeId * 0.913);\\n \\n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\\n\\n \\n float tm = time * 0.25;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\\n vec3 up = vec3(sin(tm),cos(tm),0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n// mat *= trans(cpos);\\n mat *= lookAt(cpos, vec3(0), up);\\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n \\n\\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\\n float val = 1.;\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\\n v_color = vec4(color * mix(-10., 10., lit), 1);\\n v_color.rgb *= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/t0kisaki/u-got-that-halogen", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2196078431372549, + 0.2196078431372549, + 0.21176470588235294, + 1 + ], + "shader": "/*\n\n-=O=-\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22- time* a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis-2.));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.9;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, z-y, x); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes)) * 2.;\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n vec3 cpos = vec3(hash(cubeId * 0.113), hash(cubeId * 0.567), hash(cubeId * 0.713)) * 2.0 - 1.0;\n cpos = normalize(cpos) * hash(cubeId * 0.913);\n \n float snd = texture2D(sound, vec2(mix(0.1, 0.25, hash(cubeId)), length(cpos) * .05)).a;\n\n \n float tm = time * 0.25;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 2., sin(tm * 0.9) * 1.5, sin(tm) * 1.5);\n vec3 target = vec3(-eye.x, sin(tm * 0.9) * -1.5, -eye.z) * 5.5;\n vec3 up = vec3(sin(tm),cos(tm),0);\n \n mat *= cameraLookAt(eye, target, up);\n// mat *= trans(cpos);\n mat *= lookAt(cpos, vec3(0), up);\n mat *= uniformScale(clamp(mix(-0.1, 0.6, pow(snd, 3.)), 0.0, 1.0));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n \n\n float hue = mix(sin(time * 3.) * .1, time * 3. + .5, step(0.6, snd));//abs(ca * cd) * 2.;\n float sat = 1.;//step(0.6, snd);//pow(snd + 0.3, 5.);\n float val = 1.;\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lit = (dot(n, lightDir) * 0.5 + 0.5);\n v_color = vec4(color * mix(-10., 10., lit), 1);\n v_color.rgb *= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-nr4yuaag43ztnf3gf-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wJR8MkZGLQe3TZGZD/art.json b/art/wJR8MkZGLQe3TZGZD/art.json index fdb801d0..64e04a2f 100644 --- a/art/wJR8MkZGLQe3TZGZD/art.json +++ b/art/wJR8MkZGLQe3TZGZD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6255,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/montagerock/cult-of-follow-leave-it-all-behind\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n vec4 soundPoint = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0)));\\n float snd = soundPoint.a;\\n\\n float c = sin(count)*1.1 - point * 0.01;\\n float s = -0.4 + (snd * 0.8) - point * 0.01 * cos(count) * 0.1;\\n \\n vec2 size = vec2(resolution.x, resolution.y);\\n vec2 xy = vec2(c, s);\\n gl_Position = vec4(xy, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n //v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n v_color = (soundPoint.r < 0.1) \\n ? vec4(0)\\n : vec4(soundPoint.r * 0.7, soundPoint.g * 0.4 + 0.6, soundPoint.b * 0.8, 1);\\n float pointSize = (count > 20.0) ? 10.0 : 30.0;\\n gl_PointSize = soundPoint.r * (soundPoint.a + 0.2) * pointSize - 1.0;\\n}\"}", + "settings": { + "num": 6255, + "mode": "POINTS", + "sound": "https://soundcloud.com/montagerock/cult-of-follow-leave-it-all-behind", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n vec4 soundPoint = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0)));\n float snd = soundPoint.a;\n\n float c = sin(count)*1.1 - point * 0.01;\n float s = -0.4 + (snd * 0.8) - point * 0.01 * cos(count) * 0.1;\n \n vec2 size = vec2(resolution.x, resolution.y);\n vec2 xy = vec2(c, s);\n gl_Position = vec4(xy, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n //v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n v_color = (soundPoint.r < 0.1) \n ? vec4(0)\n : vec4(soundPoint.r * 0.7, soundPoint.g * 0.4 + 0.6, soundPoint.b * 0.8, 1);\n float pointSize = (count > 20.0) ? 10.0 : 30.0;\n gl_PointSize = soundPoint.r * (soundPoint.a + 0.2) * pointSize - 1.0;\n}" + }, "screenshotURL": "data/images/images-zru4mzt8800b6ygij-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wJtgtpePx8uemptoj/art.json b/art/wJtgtpePx8uemptoj/art.json index 11ebd298..2adc703e 100644 --- a/art/wJtgtpePx8uemptoj/art.json +++ b/art/wJtgtpePx8uemptoj/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "sergioerick", "avatarUrl": "https://lh6.googleusercontent.com/-6mWCYE7e8JE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcnyCK5B6N4hdhN62pAcPOwiFeA5g/mo/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n\\tfloat pointsDraw = 70.0;\\n\\tfloat radius = 0.8;\\n\\n\\tfloat xCircle = mod(vertexId, pointsDraw);\\n\\tfloat yCircle = floor(vertexId / pointsDraw);\\n\\n\\tfloat angleT = xCircle / pointsDraw * radians(360.0);\\n\\tfloat angleP = yCircle / pointsDraw * radians(360.0);\\n\\n\\tfloat x = radius * sin(angleT) * cos(angleP);\\n\\tfloat y = radius * sin(angleT) * sin(angleP);\\n\\tfloat z = radius * cos(angleT);\\n\\n\\tvec3 xyz = vec3(x, y, z)* 0.8;\\n\\n\\tmat3 rx = mat3(cos(time), 0, sin(time), \\n 0, 1, 0,\\n -sin(time), 0, cos(time));\\n\\tmat3 ry = mat3(1, 0, 0, \\n\\t\\t\\t\\t\\t0, cos(time), -sin(time),\\n\\t\\t\\t\\t\\t0, sin(time), cos(time));\\n \\n\\txyz = rx * xyz;\\n\\txyz = ry * xyz;\\n\\n\\tgl_Position = vec4(xyz, 1.0);\\n\\tgl_PointSize = 2.0;\\n\\tv_color = vec4(0.0,0.0,1.0,1.0);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n\tfloat pointsDraw = 70.0;\n\tfloat radius = 0.8;\n\n\tfloat xCircle = mod(vertexId, pointsDraw);\n\tfloat yCircle = floor(vertexId / pointsDraw);\n\n\tfloat angleT = xCircle / pointsDraw * radians(360.0);\n\tfloat angleP = yCircle / pointsDraw * radians(360.0);\n\n\tfloat x = radius * sin(angleT) * cos(angleP);\n\tfloat y = radius * sin(angleT) * sin(angleP);\n\tfloat z = radius * cos(angleT);\n\n\tvec3 xyz = vec3(x, y, z)* 0.8;\n\n\tmat3 rx = mat3(cos(time), 0, sin(time), \n 0, 1, 0,\n -sin(time), 0, cos(time));\n\tmat3 ry = mat3(1, 0, 0, \n\t\t\t\t\t0, cos(time), -sin(time),\n\t\t\t\t\t0, sin(time), cos(time));\n \n\txyz = rx * xyz;\n\txyz = ry * xyz;\n\n\tgl_Position = vec4(xyz, 1.0);\n\tgl_PointSize = 2.0;\n\tv_color = vec4(0.0,0.0,1.0,1.0);\n}" + }, "screenshotURL": "data/images/images-7vznoqhla5lmgoaeh-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wJuenftt4G6XBy8x7/art.json b/art/wJuenftt4G6XBy8x7/art.json index 97bae2ca..a9b48758 100644 --- a/art/wJuenftt4G6XBy8x7/art.json +++ b/art/wJuenftt4G6XBy8x7/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":15238,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 4.);\\n float quadId = floor(vertexId / 4.);\\n float down = floor(sqrt(numQuads));\\n float across = floor(numQuads / down);\\n \\n float gx = mod(quadId, across);\\n float gy = floor(quadId / across);\\n \\n float vId = mod(vertexId, 4.);\\n \\n float x = gx + mod(vId, 2.) - step(3., vId);\\n float y = gy + step(3., vId);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\\n gl_Position = vec4(xy * aspect * 1.1, 0, 1);\\n\\n v_color = vec4(vec3(0), 1);\\n}\"}", + "settings": { + "num": 15238, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n float numQuads = floor(vertexCount / 4.);\n float quadId = floor(vertexId / 4.);\n float down = floor(sqrt(numQuads));\n float across = floor(numQuads / down);\n \n float gx = mod(quadId, across);\n float gy = floor(quadId / across);\n \n float vId = mod(vertexId, 4.);\n \n float x = gx + mod(vId, 2.) - step(3., vId);\n float y = gy + step(3., vId);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(x, y) / vec2(across, down) * 2. - 1.;\n gl_Position = vec4(xy * aspect * 1.1, 0, 1);\n\n v_color = vec4(vec3(0), 1);\n}" + }, "screenshotURL": "data/images/images-xvdzwmh2ntvshhvxi-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wKpLsESkrBXCiRJad/art.json b/art/wKpLsESkrBXCiRJad/art.json index d86c1b83..c345cf5c 100644 --- a/art/wKpLsESkrBXCiRJad/art.json +++ b/art/wKpLsESkrBXCiRJad/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "eugene", "avatarUrl": "https://lh4.googleusercontent.com/-1W0Zx2V2YBo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuck7HOEHYTKOuOYfO3JNASLLHC1T0A/s96-c/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/futureisnow/fine-china\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.06666666666666667,0.25882352941176473,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; // sin(time + x * 0.2) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float snd = texture2D(sound, vec2(su * 0.05, sv * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; // sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = 1.; // u * .1 + sin(time + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = pow(snd + 0.2, 5.); // sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/futureisnow/fine-china", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.06666666666666667, + 0.25882352941176473, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.; // sin(time + x * 0.2) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float snd = texture2D(sound, vec2(su * 0.05, sv * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; // sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd + 0.2, 5.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = 1.; // u * .1 + sin(time + v * 20.) * 0.05;\n float sat = 1.;\n float val = pow(snd + 0.2, 5.); // sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n\n}" + }, "screenshotURL": "data/images/images-twe8dd70x1hxu4dra-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wMRQSfRMurn9etwdS/art.json b/art/wMRQSfRMurn9etwdS/art.json index 0d4302fe..35a59c5e 100644 --- a/art/wMRQSfRMurn9etwdS/art.json +++ b/art/wMRQSfRMurn9etwdS/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Exercise - VertexShaderart : Motion\\n// Course : CS250\\n// Term & Year : 2023 Spring\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Exercise - VertexShaderart : Motion\n// Course : CS250\n// Term & Year : 2023 Spring\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-t711ccnsjw00j0aaj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wP2mJ5GtGxM69FK8H/art.json b/art/wP2mJ5GtGxM69FK8H/art.json index 1f3e994b..51a63859 100644 --- a/art/wP2mJ5GtGxM69FK8H/art.json +++ b/art/wP2mJ5GtGxM69FK8H/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":21520,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define parameter0 fract(0.6 +mouse.y)\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 2.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) + mouse.y * r;\\n float y = sin(qu * PI * 12.) * r;\\n \\n vec3 pos = vec3(x, y, cos(qv * PI));\\n \\n float tm = time * 1.2 +mouse.x * qv;\\n float rd = 3.;\\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = quadId * .3333333;\\n float sat = 1.;\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 21520, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define parameter0 fract(0.6 +mouse.y)\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 2.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) + mouse.y * r;\n float y = sin(qu * PI * 12.) * r;\n \n vec3 pos = vec3(x, y, cos(qv * PI));\n \n float tm = time * 1.2 +mouse.x * qv;\n float rd = 3.;\n mat4 mat = persp(PI * .525*parameter0, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * (-mouse.x *3.0) + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = quadId * .3333333;\n float sat = 1.;\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-w3qmszzue6gzmselp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wP4tHTACwohNdomhd/art.json b/art/wP4tHTACwohNdomhd/art.json index 2ceb59bb..bd7fc9c3 100644 --- a/art/wP4tHTACwohNdomhd/art.json +++ b/art/wP4tHTACwohNdomhd/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "moon-jong", "avatarUrl": "https://avatars.githubusercontent.com/moon-jong?s=200", - "settings": "{\"num\":1606,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.050980392156862744,0.047058823529411764,0.047058823529411764,1],\"shader\":\"void main() {\\n \\n \\tfloat down = floor(sqrt(vertexCount));\\n\\tfloat across = floor(vertexCount / down); \\n \\tfloat x = mod(vertexId, across);\\n \\tfloat y = floor(vertexId / across);\\n \\t\\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n \\n \\tfloat xoff = sin(time + y * 0.2) * 0.1;\\n \\tfloat yoff = cos(time + x * 0.3) * 0.2;\\n \\tfloat soff = sin(time + x) * 5.;\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n \\tvec2 xy = vec2(ux, vy) * 1.3;\\n \\n\\tgl_Position = vec4(xy, 0, 1);\\n \\tgl_PointSize = 15.0 + soff;\\n\\tgl_PointSize *= 20.0 / across;\\n \\n \\t\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\n\\tv_color = vec4(xoff * 10., yoff * 10., soff * 10., 1);\\n \\n\\n}\"}", + "settings": { + "num": 1606, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.050980392156862744, + 0.047058823529411764, + 0.047058823529411764, + 1 + ], + "shader": "void main() {\n \n \tfloat down = floor(sqrt(vertexCount));\n\tfloat across = floor(vertexCount / down); \n \tfloat x = mod(vertexId, across);\n \tfloat y = floor(vertexId / across);\n \t\n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n \n \tfloat xoff = sin(time + y * 0.2) * 0.1;\n \tfloat yoff = cos(time + x * 0.3) * 0.2;\n \tfloat soff = sin(time + x) * 5.;\n \n \tfloat ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n \tvec2 xy = vec2(ux, vy) * 1.3;\n \n\tgl_Position = vec4(xy, 0, 1);\n \tgl_PointSize = 15.0 + soff;\n\tgl_PointSize *= 20.0 / across;\n \n \t\n \tgl_PointSize *= resolution.x / 600.;\n \n\tv_color = vec4(xoff * 10., yoff * 10., soff * 10., 1);\n \n\n}" + }, "screenshotURL": "data/images/images-sr3e9j8owmsqtjf6w-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wT4peJdYTS3FSeH9P/art.json b/art/wT4peJdYTS3FSeH9P/art.json index 69175856..b4460bed 100644 --- a/art/wT4peJdYTS3FSeH9P/art.json +++ b/art/wT4peJdYTS3FSeH9P/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":97883,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/muhammed-aslam-pk/tum_tum-video_song-enemy-tamil\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.06274509803921569,0.07450980392156863,0.043137254901960784,1],\"shader\":\"/*\\n\\n __ __ ______ ______ ______ ______ __ __ ______ __ __ ______ _____ ______ ______ ______ ______ ______ \\n/\\\\ \\\\ / / /\\\\ ___\\\\ /\\\\ == \\\\ /\\\\__ _\\\\ /\\\\ ___\\\\ /\\\\_\\\\_\\\\_\\\\ /\\\\ ___\\\\ /\\\\ \\\\_\\\\ \\\\ /\\\\ __ \\\\ /\\\\ __-. /\\\\ ___\\\\ /\\\\ == \\\\ /\\\\ __ \\\\ /\\\\ == \\\\ /\\\\__ _\\\\ \\n\\\\ \\\\ \\\\'/ \\\\ \\\\ __\\\\ \\\\ \\\\ __< \\\\/_/\\\\ \\\\/ \\\\ \\\\ __\\\\ \\\\/_/\\\\_\\\\/_ \\\\ \\\\___ \\\\ \\\\ \\\\ __ \\\\ \\\\ \\\\ __ \\\\ \\\\ \\\\ \\\\/\\\\ \\\\ \\\\ \\\\ __\\\\ \\\\ \\\\ __< \\\\ \\\\ __ \\\\ \\\\ \\\\ __< \\\\/_/\\\\ \\\\/ \\n \\\\ \\\\__| \\\\ \\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\ \\\\_____\\\\ /\\\\_\\\\/\\\\_\\\\ \\\\/\\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\____- \\\\ \\\\_____\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\\\_\\\\ \\\\ \\\\_\\\\ \\n \\\\/_/ \\\\/_____/ \\\\/_/ /_/ \\\\/_/ \\\\/_____/ \\\\/_/\\\\/_/ \\\\/_____/ \\\\/_/\\\\/_/ \\\\/_/\\\\/_/ \\\\/____/ \\\\/_____/ \\\\/_/ /_/ \\\\/_/\\\\/_/ \\\\/_/ /_/ \\\\/_/ \\n \\n\\n\\n\\n*/\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nvoid main() {\\n float size = floor(pow(vertexCount, 1./3.));\\n float div = size - 1.;\\n vec3 p = vec3(\\n mod(vertexId, size),\\n mod(floor(vertexId / size), size),\\n floor(floor(vertexId / size) / size));\\n \\n vec3 snd = vec3(\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.1) * 0.25, 0.0)).a,\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.3) * 0.25, 0.0)).a,\\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.5) * 0.25, 0.0)).a);\\n \\n float a = time * 0.01;\\n float r = 1.0;\\n float c = cos(a) * r;\\n float s = sin(a) * r;\\n float y = sin(time * 0.011);\\n \\n vec3 target = vec3(0,0,0);\\n vec3 up = vec3(0,1,0);\\n vec3 eye = vec3(c, y, s);\\n \\n \\n mat4 m = ident();\\n m *= persp(radians(45.), resolution.x / resolution.y, 0.1, 2.);\\n m *= cameraLookAt(eye, target, up);\\n m *= trans(vec3(-1, -1, -1));\\n m *= uniformScale(2. / div);\\n \\n vec3 sp = vec3(pow(snd.r, 6.0), pow(snd.b, 9.0), pow(snd.g, 8.0)) ;\\n gl_Position = m * vec4(p + sp * .5, 1);\\n\\n float z = gl_Position.z * 0.5 + 0.5;\\n float sm = max(max(sp.x, sp.y), sp.z);\\n float hue = 1.;//(time * 0.01 + count * 1.001);\\n v_color = vec4(mix(p / div * vec3(0,1,1) * z, vec3(1,0,0), step(0.7, sm)), mix(0.8,1.5, mod(floor(vertexId * 0.33 + time * 30.0), 2.)));\\n v_color.r -= snd.b;\\n v_color.g += snd.g;\\n v_color.b /= snd.r;\\n \\n v_color = vec4(hsv2rgb(v_color.rbg), v_color.b * 1.2);\\n gl_PointSize = mix(10.0, 0.0, z) + step(0.7, sm) * 2.;\\n}\"}", + "settings": { + "num": 97883, + "mode": "POINTS", + "sound": "https://soundcloud.com/muhammed-aslam-pk/tum_tum-video_song-enemy-tamil", + "lineSize": "CSS", + "backgroundColor": [ + 0.06274509803921569, + 0.07450980392156863, + 0.043137254901960784, + 1 + ], + "shader": "/*\n\n __ __ ______ ______ ______ ______ __ __ ______ __ __ ______ _____ ______ ______ ______ ______ ______ \n/\\ \\ / / /\\ ___\\ /\\ == \\ /\\__ _\\ /\\ ___\\ /\\_\\_\\_\\ /\\ ___\\ /\\ \\_\\ \\ /\\ __ \\ /\\ __-. /\\ ___\\ /\\ == \\ /\\ __ \\ /\\ == \\ /\\__ _\\ \n\\ \\ \\'/ \\ \\ __\\ \\ \\ __< \\/_/\\ \\/ \\ \\ __\\ \\/_/\\_\\/_ \\ \\___ \\ \\ \\ __ \\ \\ \\ __ \\ \\ \\ \\/\\ \\ \\ \\ __\\ \\ \\ __< \\ \\ __ \\ \\ \\ __< \\/_/\\ \\/ \n \\ \\__| \\ \\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\ \\_____\\ /\\_\\/\\_\\ \\/\\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\____- \\ \\_____\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\_\\ \\_\\ \\ \\_\\ \n \\/_/ \\/_____/ \\/_/ /_/ \\/_/ \\/_____/ \\/_/\\/_/ \\/_____/ \\/_/\\/_/ \\/_/\\/_/ \\/____/ \\/_____/ \\/_/ /_/ \\/_/\\/_/ \\/_/ /_/ \\/_/ \n \n\n\n\n*/\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nvoid main() {\n float size = floor(pow(vertexCount, 1./3.));\n float div = size - 1.;\n vec3 p = vec3(\n mod(vertexId, size),\n mod(floor(vertexId / size), size),\n floor(floor(vertexId / size) / size));\n \n vec3 snd = vec3(\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.1) * 0.25, 0.0)).a,\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.3) * 0.25, 0.0)).a,\n texture2D(sound, vec2(hash(vertexId / vertexCount / 3. + 0.5) * 0.25, 0.0)).a);\n \n float a = time * 0.01;\n float r = 1.0;\n float c = cos(a) * r;\n float s = sin(a) * r;\n float y = sin(time * 0.011);\n \n vec3 target = vec3(0,0,0);\n vec3 up = vec3(0,1,0);\n vec3 eye = vec3(c, y, s);\n \n \n mat4 m = ident();\n m *= persp(radians(45.), resolution.x / resolution.y, 0.1, 2.);\n m *= cameraLookAt(eye, target, up);\n m *= trans(vec3(-1, -1, -1));\n m *= uniformScale(2. / div);\n \n vec3 sp = vec3(pow(snd.r, 6.0), pow(snd.b, 9.0), pow(snd.g, 8.0)) ;\n gl_Position = m * vec4(p + sp * .5, 1);\n\n float z = gl_Position.z * 0.5 + 0.5;\n float sm = max(max(sp.x, sp.y), sp.z);\n float hue = 1.;//(time * 0.01 + count * 1.001);\n v_color = vec4(mix(p / div * vec3(0,1,1) * z, vec3(1,0,0), step(0.7, sm)), mix(0.8,1.5, mod(floor(vertexId * 0.33 + time * 30.0), 2.)));\n v_color.r -= snd.b;\n v_color.g += snd.g;\n v_color.b /= snd.r;\n \n v_color = vec4(hsv2rgb(v_color.rbg), v_color.b * 1.2);\n gl_PointSize = mix(10.0, 0.0, z) + step(0.7, sm) * 2.;\n}" + }, "screenshotURL": "data/images/images-448bs19ckhrm2c6cu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wTPZJYcFz58zagJqM/art.json b/art/wTPZJYcFz58zagJqM/art.json index 6dafd821..1ef7ff73 100644 --- a/art/wTPZJYcFz58zagJqM/art.json +++ b/art/wTPZJYcFz58zagJqM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "liaminjapan", "avatarUrl": "https://avatars.githubusercontent.com/LiamInJapan?s=200", - "settings": "{\"num\":3046,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.12549019607843137,0,0.3411764705882353,1],\"shader\":\"void main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time + x * 0.3) * .1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time + x * y * 0.02) * 15.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across; \\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 3046, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.12549019607843137, + 0, + 0.3411764705882353, + 1 + ], + "shader": "void main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time + x * 0.3) * .1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time + x * y * 0.02) * 15.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across; \n gl_PointSize *= resolution.x / 600.;\n \n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-4nyboxwrodr1ku02g-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wTaKE9X796qNFqgEM/art.json b/art/wTaKE9X796qNFqgEM/art.json index ccf6570f..ad091746 100644 --- a/art/wTaKE9X796qNFqgEM/art.json +++ b/art/wTaKE9X796qNFqgEM/art.json @@ -22,7 +22,19 @@ "origId": null, "name": "neurovelho", "username": "visy", - "settings": "{\"num\":10000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/liquidheasy/neuron\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float NUM_SEGMENTS = 4.0+time*0.001;\\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\\n float STEP = time*0.0001;\\n if (STEP > 0.03) STEP = 0.03;\\n float localTime = time*0.1 + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * localTime*0.0001) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(1.0-b, 1.0-c*10.0, 1.0-s*10.0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/liquidheasy/neuron", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n//#define FIT_VERTICAL\n\nvoid main() {\n float NUM_SEGMENTS = 4.0+time*0.001;\n float NUM_POINTS = (NUM_SEGMENTS * 2.0);\n float STEP = time*0.0001;\n if (STEP > 0.03) STEP = 0.03;\n float localTime = time*0.1 + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * localTime*0.0001) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001+0.3*cos(time*0.1+c)) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001+0.3*sin(time*0.1+orbitAngle)) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(1.0-b, 1.0-c*10.0, 1.0-s*10.0, 1);\n}" + }, "screenshotDataId": "NujseYpQTMRhrFdox", "views": { "$numberInt": "3270" diff --git a/art/wXoyv2xNDqkKWzsJE/art.json b/art/wXoyv2xNDqkKWzsJE/art.json index 2777d946..3e6bae2f 100644 --- a/art/wXoyv2xNDqkKWzsJE/art.json +++ b/art/wXoyv2xNDqkKWzsJE/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":12590,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/* 👾 */\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat pinch(float v, float p) {\\n if (v < 0.5) {\\n return pow(v * 2., p) * .5;\\n } \\n return 1. - pow(1. - (v - 0.5) * 2., p);\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(4. - pow(y ,2.) * 4.);\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n\\n vec3 loc = fibonacciSphere(numCubes, cubeId);\\n\\n float cv = cubeId / numCubes;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\\n \\n s = mix(0.0, 2.0, s);\\n \\n float tm = time * 0.1;\\n float r = 70.;\\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= lookAt(loc * 45., vec3(0), up);\\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\\n mat *= trans(vec3(0, 0, 1));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n float hue = 1.;\\n float sat = mix(.0, 1., pow(s, 5.));\\n float val = mix(0.9, 1., pow(s, 5.));\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\\n //v_color = vec4(color * pinch(lt, 2.), 1);\\n v_color = vec4(color * lt, 1);\\n}\\n\\n\"}", + "settings": { + "num": 12590, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcode/adam-beyer-vs-dense-pika-going-down-drumcode-dc166", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/* 👾 */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat pinch(float v, float p) {\n if (v < 0.5) {\n return pow(v * 2., p) * .5;\n } \n return 1. - pow(1. - (v - 0.5) * 2., p);\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(4. - pow(y ,2.) * 4.);\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n\n vec3 loc = fibonacciSphere(numCubes, cubeId);\n\n float cv = cubeId / numCubes;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, hash(cv)), hash(cv) / 2. * .2)).a;\n \n s = mix(0.0, 2.0, s);\n \n float tm = time * 0.1;\n float r = 70.;\n mat4 mat = persp(radians(100.0), resolution.x / resolution.y, 1., 200.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.9) * r * 0.6, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= lookAt(loc * 45., vec3(0), up);\n mat *= scale(vec3(.8, .8, mix(1., 3.5, pow(s, 5.))));\n mat *= trans(vec3(0, 0, 1));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n float hue = 1.;\n float sat = mix(.0, 1., pow(s, 5.));\n float val = mix(0.9, 1., pow(s, 5.));\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n float lt = (dot(n, lightDir) * 0.5 + 0.5);\n //v_color = vec4(color * pinch(lt, 2.), 1);\n v_color = vec4(color * lt, 1);\n}\n\n" + }, "screenshotURL": "data/images/images-xmfyffsismoc1qbez-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wYJg4JdkufCDkxugR/art.json b/art/wYJg4JdkufCDkxugR/art.json index 7524beaa..d9d4cbba 100644 --- a/art/wYJg4JdkufCDkxugR/art.json +++ b/art/wYJg4JdkufCDkxugR/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mattsonic", "avatarUrl": "https://secure.gravatar.com/avatar/4b4ea9969843f3808dccbabf78ea4289?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1568627450980392,0.15294117647058825,0.2627450980392157,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 15.; \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1568627450980392, + 0.15294117647058825, + 0.2627450980392157, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 15.; \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-crm43uheb50wo39mn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wZu7HgdEpJmXy93Jm/art.json b/art/wZu7HgdEpJmXy93Jm/art.json index c89516a8..bae5458b 100644 --- a/art/wZu7HgdEpJmXy93Jm/art.json +++ b/art/wZu7HgdEpJmXy93Jm/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/apollyonpsy/loose-connection-vs-apollyon\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st){\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n} \\n\\nfloat noise(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b, float fact) {\\n\\tfloat scale = 10.0*fact;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n///float pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n vec2 vertexResolution = vec2(0.);\\n \\n //first the number of elements in a line\\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n\\n //then the number of possible lines with the given vertexCount\\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, vertexResolution.x);\\n float y = floor(finalVertexId / vertexResolution.x);\\n \\n float u = (x /vertexResolution.x);\\n float v = (y /vertexResolution.y);\\n \\n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\\n \\n if(u>0.5)\\n u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0.1, udnd)).a;\\n \\n //apply fragment logic\\n\\n\\tvec2 position = vec2(x,y);\\n \\n\\tvec2 uv\\t\\t\\t= vec2(u,v);//position.xy/resolution.xy;\\n /*\\n\\tvec2 aspect\\t\\t= resolution/min(resolution.x, resolution.y);\\n\\tvec2 p \\t\\t= (uv -.5) * aspect;\\n\\tvec2 c\\t\\t\\t= p/dot(p,p);\\n\\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\\n \\n \\n\\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\\n */\\n vec2 st = uv;\\n\\tst.x *= resolution.x / resolution.y;\\n\\n\\tvec2 pos = st.yx* vec2(10.0, 3.0);\\n\\t\\n\\tfloat pattern = pos.x;\\n\\t\\n float timeFact = 5.;\\n\\tpos += rotate2d((noise(pos + timeFact*time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - timeFact*time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(timeFact*time) * 0.2) * 2.0 - 1.0);\\n\\t\\n\\tpattern = lines(pos, 0.5, snd);\\n\\t\\n\\t//gl_FragColor = vec4(vec3(pattern), 1.0);\\n \\n\\t//gl_FragColor = vec4(pattern(3.*c));\\n\\t\\n //camera\\n float r = 2.5;\\n float tm = time * 0.5;\\n float tm2 = time * 0.13;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = finalDesiredPointSize;\\n\\n v_color = vec4(vec3(pattern), 1.0);\\n \\n vec4 finalPos = vec4(ux, vy+snd/2.-0.2, 0., 1.);\\n \\n gl_Position = finalPos;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/apollyonpsy/loose-connection-vs-apollyon", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\n//functions for the shader\nfloat random(in vec2 st){\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n} \n\nfloat noise(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b, float fact) {\n\tfloat scale = 10.0*fact;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n///float pattern(vec2 p){p.x -= .866; p.x -= p.y * .005; p = mod(p, 1.); return p.x + p.y < 1.0 ? 0.3: 1.;}\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n vec2 vertexResolution = vec2(0.);\n \n //first the number of elements in a line\n vertexResolution.x = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n\n //then the number of possible lines with the given vertexCount\n vertexResolution.y = floor(finalMaxVertexCount / vertexResolution.x);\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, vertexResolution.x);\n float y = floor(finalVertexId / vertexResolution.x);\n \n float u = (x /vertexResolution.x);\n float v = (y /vertexResolution.y);\n \n float u0 = (u * (vertexResolution.x*finalDesiredPointSize/resolution.x));\n float v0 = (v * (vertexResolution.x*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(vertexResolution.x*finalDesiredPointSize/resolution.x);;\n \n if(u>0.5)\n u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0.1, udnd)).a;\n \n //apply fragment logic\n\n\tvec2 position = vec2(x,y);\n \n\tvec2 uv\t\t\t= vec2(u,v);//position.xy/resolution.xy;\n /*\n\tvec2 aspect\t\t= resolution/min(resolution.x, resolution.y);\n\tvec2 p \t\t= (uv -.5) * aspect;\n\tvec2 c\t\t\t= p/dot(p,p);\n\tfloat centerDistance = distance(c, snd*6.*vec2(0.5)) / 6.0;\n \n \n\tc = rotate(c, max(-10.0, 2.3*sin(time + centerDistance + sin(time + centerDistance))));\n */\n vec2 st = uv;\n\tst.x *= resolution.x / resolution.y;\n\n\tvec2 pos = st.yx* vec2(10.0, 3.0);\n\t\n\tfloat pattern = pos.x;\n\t\n float timeFact = 5.;\n\tpos += rotate2d((noise(pos + timeFact*time) * 2.0 - 1.0) * 3.1415) * vec2(noise(pos - timeFact*time * 0.2) * 2.0 - 1.0, noise(pos + vec2(100.0) - vec2(timeFact*time) * 0.2) * 2.0 - 1.0);\n\t\n\tpattern = lines(pos, 0.5, snd);\n\t\n\t//gl_FragColor = vec4(vec3(pattern), 1.0);\n \n\t//gl_FragColor = vec4(pattern(3.*c));\n\t\n //camera\n float r = 2.5;\n float tm = time * 0.5;\n float tm2 = time * 0.13;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = finalDesiredPointSize;\n\n v_color = vec4(vec3(pattern), 1.0);\n \n vec4 finalPos = vec4(ux, vy+snd/2.-0.2, 0., 1.);\n \n gl_Position = finalPos;\n}" + }, "screenshotURL": "data/images/images-t715dm873qwcxfb3y-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wdRcgmKhw55neWGbT/art.json b/art/wdRcgmKhw55neWGbT/art.json index 540f2ee9..723aea3e 100644 --- a/art/wdRcgmKhw55neWGbT/art.json +++ b/art/wdRcgmKhw55neWGbT/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "PLU Collective", "avatarUrl": "https://lh3.googleusercontent.com/-zoLHh8QcDvA/AAAAAAAAAAI/AAAAAAAAAMY/JF7a2zyY1xc/photo.jpg", - "settings": "{\"num\":12004,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/plu-collective/circuitry\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.03137254901960784,0.043137254901960784,0.1450980392156863,1],\"shader\":\"//Lesson 05a\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n \\n return vec2(x, y);\\n\\n}\\n\\n\\nvoid main() {\\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, \\n numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= trans(vec3(ux, vy, 0));\\n mat *= uniformScale(0.1 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1;\\n float sat = mix(0., 1., pump);\\n float val = 1.;mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\\n\"}", + "settings": { + "num": 12004, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/plu-collective/circuitry", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.03137254901960784, + 0.043137254901960784, + 0.1450980392156863, + 1 + ], + "shader": "//Lesson 05a\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n \n return vec2(x, y);\n\n}\n\n\nvoid main() {\n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId, \n numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= trans(vec3(ux, vy, 0));\n mat *= uniformScale(0.1 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1;\n float sat = mix(0., 1., pump);\n float val = 1.;mix(.1, pow(snd + 0.2, 5.), pump);//sin(time + v * u * 20.) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}\n" + }, "screenshotURL": "data/images/images-i2pxmunkilw1ci2wd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wfSM5cyoAJHAg6od5/art.json b/art/wfSM5cyoAJHAg6od5/art.json index e25dccab..d9253a34 100644 --- a/art/wfSM5cyoAJHAg6od5/art.json +++ b/art/wfSM5cyoAJHAg6od5/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":23936,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define radiusParam0 0.10//KParameter 0.03>>0.3\\n#define radiusParam1 0.82//KParameter 0.>>1.\\n#define angleParam0 0.02//KParameter 0.>>1.\\n#define sndFactor 0.8//KParameter 0.>>1.\\n#define PointSizeFactor 0.18//KParameter 0.>>1.\\n#define kpx -5.0//KParameter 0.>>4.\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\n//KverticesNumber=233333\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\n\\n#define elementPerTriangleShape 3.\\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\\n{\\n vec3 result = vec3(0., 0.,-1.);\\n \\n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\\n result = rotZ(result,_angle);\\n result.xy+=_center.xy;\\n return result;\\n}\\n\\n\\nvoid main() {\\n \\n //fix a maximum vertexId\\n float localVertexId = vertexId;\\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\\n \\n float relVertexId = vertexId/vertexCount-kpx;\\n \\n maxShapeCount = floor(maxShapeCount/2.);\\n \\n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\\n \\n if(localVertexId>=maxVerticesNumber)\\n localVertexId = maxVerticesNumber-1.5;\\n \\n float shapeId = floor(localVertexId / elementPerTriangleShape);\\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\\n float relShapeId = shapeId/maxShapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n \\n vec2 center=vec2(0., 0.);\\n \\n if(localVertexId>=(maxVerticesNumber/2.))\\n {\\n localVertexId = localVertexId - (maxVerticesNumber/2.);\\n }\\n \\n float localShapeId = floor(localVertexId/elementPerTriangleShape);\\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\\n \\n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\\n float snd = texture2D(sound, vec2(localRelShapeId,0.4) ).a* sndFactor;\\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\\n \\n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\\n ;\\n \\n \\n shapep.x/=aspect;\\n vec4 m = texture2D(touch, vec2(0., localShapeId /(maxShapeCount/2.)));\\n \\n shapep += vec3( m.xy, shapep.z+2.);\\n \\n if(shapeId>maxShapeCount/2.)\\n {\\n shapep.x = -shapep.x;\\n }\\n\\n \\n \\n \\n gl_Position = vec4(shapep,1.);\\n gl_PointSize = 3.*PointSizeFactor;\\n \\n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\\n \\n}\\n\"}", + "settings": { + "num": 23936, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_TRIANGLES\n\n\n#define radiusParam0 0.10//KParameter 0.03>>0.3\n#define radiusParam1 0.82//KParameter 0.>>1.\n#define angleParam0 0.02//KParameter 0.>>1.\n#define sndFactor 0.8//KParameter 0.>>1.\n#define PointSizeFactor 0.18//KParameter 0.>>1.\n#define kpx -5.0//KParameter 0.>>4.\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\n//KverticesNumber=233333\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\n\n#define elementPerTriangleShape 3.\nvec3 getTriangle(float _vertexId, vec2 _center, float _radius, float _angle)\n{\n vec3 result = vec3(0., 0.,-1.);\n \n float localAngle = _vertexId*2.*PI/elementPerTriangleShape;\n result.xy = _radius*vec2(cos(localAngle),sin(localAngle));\n result = rotZ(result,_angle);\n result.xy+=_center.xy;\n return result;\n}\n\n\nvoid main() {\n \n //fix a maximum vertexId\n float localVertexId = vertexId;\n float maxShapeCount = floor(vertexCount / elementPerTriangleShape);\n \n float relVertexId = vertexId/vertexCount-kpx;\n \n maxShapeCount = floor(maxShapeCount/2.);\n \n float maxVerticesNumber = maxShapeCount*elementPerTriangleShape;\n \n if(localVertexId>=maxVerticesNumber)\n localVertexId = maxVerticesNumber-1.5;\n \n float shapeId = floor(localVertexId / elementPerTriangleShape);\n float shapeVertexId = mod(localVertexId, elementPerTriangleShape);\n float relShapeId = shapeId/maxShapeCount;\n \n float aspect = resolution.x / resolution.y;\n \n vec2 center=vec2(0., 0.);\n \n if(localVertexId>=(maxVerticesNumber/2.))\n {\n localVertexId = localVertexId - (maxVerticesNumber/2.);\n }\n \n float localShapeId = floor(localVertexId/elementPerTriangleShape);\n float localRelShapeId =localShapeId/(maxShapeCount/2.);\n \n //float snd = texture2D(soundBuffer, vec2(localRelShapeId,0.) ).a* sndFactor;\n float snd = texture2D(sound, vec2(localRelShapeId,0.4) ).a* sndFactor;\n float radius = (1.- localRelShapeId)*radiusParam0+(radiusParam1/10.*cos(1.*2.*PI+localShapeId) );\n float angle = 2.*PI*time+angleParam0*50.*shapeId/500.+snd;\n \n vec3 shapep = getTriangle(localVertexId, center, radius, angle)\n ;\n \n \n shapep.x/=aspect;\n vec4 m = texture2D(touch, vec2(0., localShapeId /(maxShapeCount/2.)));\n \n shapep += vec3( m.xy, shapep.z+2.);\n \n if(shapeId>maxShapeCount/2.)\n {\n shapep.x = -shapep.x;\n }\n\n \n \n \n gl_Position = vec4(shapep,1.);\n gl_PointSize = 3.*PointSizeFactor;\n \n v_color = vec4(vec3(-m.y*3.5,mod(-m.x,shapeId/2.3),.5), 1.0);\n \n}\n" + }, "screenshotURL": "data/images/images-xq0u7j2ngl175rkqt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wftsxawoj5iw32a8D/art.json b/art/wftsxawoj5iw32a8D/art.json index b1880551..27e6a053 100644 --- a/art/wftsxawoj5iw32a8D/art.json +++ b/art/wftsxawoj5iw32a8D/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "도영", "avatarUrl": "https://lh4.googleusercontent.com/-U1yoYVQNRaI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdPOWnx_PVuWVFfdWUFWnYSBIUGSQ/mo/photo.jpg", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() \\n{\\n \\tfloat value = vertexId*10.0;\\n \\n\\tfloat x =mouse.x;\\n\\tfloat y = mouse.y;\\n \\n \\tfloat snd = texture2D(sound, vec2(0, 0)).a;\\n \\tgl_Position = vec4(cos(value), sin(value), 0, abs(snd*2.0));\\n \\n \\tgl_PointSize = 50.0;\\n \\n \\tv_color = vec4(cos(x), sin(y), tan(x*y), 1);\\n}\\n\\n \"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() \n{\n \tfloat value = vertexId*10.0;\n \n\tfloat x =mouse.x;\n\tfloat y = mouse.y;\n \n \tfloat snd = texture2D(sound, vec2(0, 0)).a;\n \tgl_Position = vec4(cos(value), sin(value), 0, abs(snd*2.0));\n \n \tgl_PointSize = 50.0;\n \n \tv_color = vec4(cos(x), sin(y), tan(x*y), 1);\n}\n\n " + }, "screenshotURL": "data/images/images-7a3rvxg6g6z8v1ngn-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/whWhE5dshEugnAaBD/art.json b/art/whWhE5dshEugnAaBD/art.json index e26997be..31c9cdf2 100644 --- a/art/whWhE5dshEugnAaBD/art.json +++ b/art/whWhE5dshEugnAaBD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":122,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/theeverlybrothers/all-i-have-to-do-is-dream-1?in=psydmr/sets/music-from-the-50s-60s-2&si=65a228ebf9714da083894a4300ad116c&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_POINTS 500.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(200.0*time+u*250.0);\\n v+= 15.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,1.0);\\n float x = (u*10.0)-1.0;\\n float y = 0.0;//((v + vold)*0.5);//*osc;\\n gl_PointSize = 300.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *3.0 - 0.7)/10.0;\\n //float lum = floor(v *30.0 + 0.9)/5.0;\\n //v_color = vec4(lum*0.5,0.0,0.0,v);\\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\\n /*vec2 soundTexCoords = vec2(0, 0);\\n float r = texture2D(sound, soundTexCoords).a;\\n r = r * 1.3;\\n r = pow(r, 4.);\\n*/\\n v_color = vec4(v*lum*0.2,lum*0.2,lum*1.0,1);\\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\\n\\n\\n \\n}\"}", + "settings": { + "num": 122, + "mode": "POINTS", + "sound": "https://soundcloud.com/theeverlybrothers/all-i-have-to-do-is-dream-1?in=psydmr/sets/music-from-the-50s-60s-2&si=65a228ebf9714da083894a4300ad116c&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_POINTS 500.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(200.0*time+u*250.0);\n v+= 15.0*pow(texture2D(sound,vec2(u,0.0)).a,5.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.81)).a,1.0);\n float x = (u*10.0)-1.0;\n float y = 0.0;//((v + vold)*0.5);//*osc;\n gl_PointSize = 300.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *3.0 - 0.7)/10.0;\n //float lum = floor(v *30.0 + 0.9)/5.0;\n //v_color = vec4(lum*0.5,0.0,0.0,v);\n //v_color = vec4(lum*0.6,lum*0.5,lum*1.0,v);\n /*vec2 soundTexCoords = vec2(0, 0);\n float r = texture2D(sound, soundTexCoords).a;\n r = r * 1.3;\n r = pow(r, 4.);\n*/\n v_color = vec4(v*lum*0.2,lum*0.2,lum*1.0,1);\n //v_color = vec4(v * 2. - 0.1, 0, 1, 1);\n\n\n \n}" + }, "screenshotURL": "data/images/images-marber1fnt48zptmm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wjw5e9cStNy6XAxH4/art.json b/art/wjw5e9cStNy6XAxH4/art.json index 300641cb..069d0bec 100644 --- a/art/wjw5e9cStNy6XAxH4/art.json +++ b/art/wjw5e9cStNy6XAxH4/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "visa-valtteri", "avatarUrl": "https://lh4.googleusercontent.com/-LZnRtqD3Cf4/AAAAAAAAAAI/AAAAAAAAEyw/CB7DLj_ThQA/photo.jpg", - "settings": "{\"num\":84134,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/maniacs-of-noise/jeroen-tel-cybernoid-preview-21-feb-2016\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.592156862745098,0.592156862745098,0.592156862745098,1],\"shader\":\"vec3 gSunColor = vec3(1.0, 1.2, 1.4) *7.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 0.2;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\\n}\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\nconst float g_cubeFaces = 6.0;\\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\\nconst float g_cubeVertexCount =\\t( g_cubeVerticesPerFace * g_cubeFaces );\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n \\tfloat f = fVertexIndex / 8.0;\\n\\treturn vec3(\\n mix(-1., 1., step(0.5, fract(f * 4.))),\\n mix(-1., 1., step(0.5, fract(f * 2.))), \\n mix(-1., 1., step(0.5, fract(f)))); \\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -2.2+cos(time*0.)*1.2,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat easeInOutCubic(float pos) {\\n if (pos < 0.5) {\\n return 0.5 * pow(pos / 0.5, 3.);\\n }\\n pos -= 0.5;\\n pos /= 0.5;\\n pos = 1. - pos;\\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\\n}\\n\\nfloat inOut(float v) {\\n float t = fract(v);\\n if (t < 0.5) {\\n return easeInOutCubic(t / 0.5);\\n }\\n return easeInOutCubic(2. - t * 2.);\\n}\\n\\nconst float perBlock = 4.;\\n\\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n \\n float across = 8.+abs(cos(time*0.2)*30.);\\n float down = 32.;\\n float uId = mod(fCubeId, across);\\n float vId = floor(fCubeId / across);\\n float u = uId / (across);\\n float v = vId / down;\\n float bxId = floor(uId / perBlock);\\n float bzId = floor(vId / perBlock);\\n float numRows = floor(numCubes / across);\\n float numBlocks = floor(numRows / perBlock);\\n\\n float a = atan(u - 0.5, v - .5);\\n float r = length(vec2(u - 0.5, v - .5));\\n float snd = texture2D(sound, vec2(mix(0.0, 0.0135, abs(a / PI)), r * 0.3)).a;\\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\\n \\n vCubeOrigin.x += m1p1(u) * across * 1.0 + bxId * 0. ;\\n float vSpace = numRows * 2.0 + numBlocks * 0.;\\n float z = v * down * 2.0 + bzId * 0.;\\n vCubeOrigin.z += z; \\n float height =sin(snd*z*time*0.001+time)*5.1 + pow(snd, 5.) * 7.0*snd+cos(time);\\n vCubeOrigin.y += height;pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 00.1);\\n \\n mat = ident();\\n mat *= trans(vCubeOrigin);\\n mat *= scale(vec3(1, height, 1));\\n \\n \\tvec3 vRandCol;\\n\\n \\n vCubeCol.rgb = mix(\\n hsv2rgb(vec3(time * 0.1,0.7,0.8)), hsv2rgb(vec3(time * 0.1 + 0.5,1,1)), smoothstep(0.50,1., snd));\\n // hsv2rgb(vec3(\\n // mix(1., 1.5, pow(snd, 5.)) + fract(time * 0.1), // + 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1, \\n // 0.5 + snd * 0.5, \\n // 1));\\n vCubeCol.a = vCubeOrigin.z / vSpace;\\n}\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tfloat fov =1.8;\\n \\n \\tvec3 vCameraTarget = vec3( sin(time) * 700., -600.6 + cos(time) * 100., 1000.0 );\\n \\tvec3 vCameraPos = vec3(sin(time) * -45.1, 40., -10.);\\n float ca = 0.;\\n \\n // get sick!\\n // ca = time + sin(time) * 2.;\\n \\tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\\n \\n mat4 mCube;\\n vec4 vCubeCol;\\n\\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\\n\\n mat4 m = persp(radians(time), resolution.x / resolution.y, 0.1, 1000.);\\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\\n \\n \\t// Final output color\\n \\tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\\n \\n}\"}", + "settings": { + "num": 84134, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/maniacs-of-noise/jeroen-tel-cybernoid-preview-21-feb-2016", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.592156862745098, + 0.592156862745098, + 0.592156862745098, + 1 + ], + "shader": "vec3 gSunColor = vec3(1.0, 1.2, 1.4) *7.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 0.2;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 20.0, 40.3, -10.4 ) );\n}\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\nconst float g_cubeFaces = 6.0;\nconst float g_cubeVerticesPerFace = ( 2.0 * 3.0 );\nconst float g_cubeVertexCount =\t( g_cubeVerticesPerFace * g_cubeFaces );\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n \tfloat f = fVertexIndex / 8.0;\n\treturn vec3(\n mix(-1., 1., step(0.5, fract(f * 4.))),\n mix(-1., 1., step(0.5, fract(f * 2.))), \n mix(-1., 1., step(0.5, fract(f)))); \n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -2.2+cos(time*0.)*1.2,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat easeInOutCubic(float pos) {\n if (pos < 0.5) {\n return 0.5 * pow(pos / 0.5, 3.);\n }\n pos -= 0.5;\n pos /= 0.5;\n pos = 1. - pos;\n return (1. - pow(pos, 3.)) * 0.5 + 0.5;\n}\n\nfloat inOut(float v) {\n float t = fract(v);\n if (t < 0.5) {\n return easeInOutCubic(t / 0.5);\n }\n return easeInOutCubic(2. - t * 2.);\n}\n\nconst float perBlock = 4.;\n\nvoid GetCubePosition( float fCubeId, float numCubes, out mat4 mat, out vec4 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n \n float across = 8.+abs(cos(time*0.2)*30.);\n float down = 32.;\n float uId = mod(fCubeId, across);\n float vId = floor(fCubeId / across);\n float u = uId / (across);\n float v = vId / down;\n float bxId = floor(uId / perBlock);\n float bzId = floor(vId / perBlock);\n float numRows = floor(numCubes / across);\n float numBlocks = floor(numRows / perBlock);\n\n float a = atan(u - 0.5, v - .5);\n float r = length(vec2(u - 0.5, v - .5));\n float snd = texture2D(sound, vec2(mix(0.0, 0.0135, abs(a / PI)), r * 0.3)).a;\n float s2 = 0.;texture2D(sound, vec2(mix(0.02, 0.04, hash(u + v + 2.34)), hash(v) * 0.05)).a;\n \n vCubeOrigin.x += m1p1(u) * across * 1.0 + bxId * 0. ;\n float vSpace = numRows * 2.0 + numBlocks * 0.;\n float z = v * down * 2.0 + bzId * 0.;\n vCubeOrigin.z += z; \n float height =sin(snd*z*time*0.001+time)*5.1 + pow(snd, 5.) * 7.0*snd+cos(time);\n vCubeOrigin.y += height;pow(sin(time + v * 9.), 1.) * pow(cos(time + u * 8.17), 1.) * 4. * inOut(time * 00.1);\n \n mat = ident();\n mat *= trans(vCubeOrigin);\n mat *= scale(vec3(1, height, 1));\n \n \tvec3 vRandCol;\n\n \n vCubeCol.rgb = mix(\n hsv2rgb(vec3(time * 0.1,0.7,0.8)), hsv2rgb(vec3(time * 0.1 + 0.5,1,1)), smoothstep(0.50,1., snd));\n // hsv2rgb(vec3(\n // mix(1., 1.5, pow(snd, 5.)) + fract(time * 0.1), // + 0.2 + floor(time * 0.1) * 0.1 + easeInOutCubic(fract(time * 0.1)) * 0.1, \n // 0.5 + snd * 0.5, \n // 1));\n vCubeCol.a = vCubeOrigin.z / vSpace;\n}\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 0.73);\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tfloat fov =1.8;\n \n \tvec3 vCameraTarget = vec3( sin(time) * 700., -600.6 + cos(time) * 100., 1000.0 );\n \tvec3 vCameraPos = vec3(sin(time) * -45.1, 40., -10.);\n float ca = 0.;\n \n // get sick!\n // ca = time + sin(time) * 2.;\n \tvec3 vCameraUp = vec3( sin(ca), cos(ca), 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n float fNumCubes = floor( vertexCount / g_cubeVertexCount );\n \n mat4 mCube;\n vec4 vCubeCol;\n\n GetCubePosition( fCubeId, fNumCubes, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol.xyz, vCameraPos, sceneVertex );\n\n mat4 m = persp(radians(time), resolution.x / resolution.y, 0.1, 1000.);\n m *= cameraLookAt(vCameraPos, vCameraTarget, vCameraUp);\n gl_Position = m * vec4(sceneVertex.vWorldPos, 1);\n \n \t// Final output color\n \tfloat fExposure = gExposure;// min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = mix(vec4(vFinalColor, 1), background, vCubeCol.a);\n \n}" + }, "screenshotURL": "data/images/images-df9eewy527rs9g2ik-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wm8Y738CbMGQQkW63/art.json b/art/wm8Y738CbMGQQkW63/art.json index 54d12fdf..3623076d 100644 --- a/art/wm8Y738CbMGQQkW63/art.json +++ b/art/wm8Y738CbMGQQkW63/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "danielskantze", "avatarUrl": "https://avatars.githubusercontent.com/danielskantze?s=200", - "settings": "{\"num\":100,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float p = vertexId / vertexCount;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n float size = min(resolution.x, resolution.y);\\n float inset = 0.8;\\n \\n float laps = 10.0;\\n \\n vec2 pos = vec2(inset * sin(laps * PI * p * 2.0), inset * cos(laps * PI * p * 2.0));\\n \\n pos = pos * aspect;\\n // gl_Position = vec4(pos * aspect + mouse * 0.1, 0, 1);\\n gl_Position = vec4(pos.x, p, pos.y, 1);\\n\\n float hue = (time * 0.01 + p * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 100, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float p = vertexId / vertexCount;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n float size = min(resolution.x, resolution.y);\n float inset = 0.8;\n \n float laps = 10.0;\n \n vec2 pos = vec2(inset * sin(laps * PI * p * 2.0), inset * cos(laps * PI * p * 2.0));\n \n pos = pos * aspect;\n // gl_Position = vec4(pos * aspect + mouse * 0.1, 0, 1);\n gl_Position = vec4(pos.x, p, pos.y, 1);\n\n float hue = (time * 0.01 + p * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-rp9salr445ckgyt7l-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wmrGHPZAroXn6EtZz/art.json b/art/wmrGHPZAroXn6EtZz/art.json index 66a1b3a6..6b3448c3 100644 --- a/art/wmrGHPZAroXn6EtZz/art.json +++ b/art/wmrGHPZAroXn6EtZz/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "prickley", "username": "gman", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n//#define FIT_VERTICAL\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n//#define FIT_VERTICAL\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n //float b = mix(0.0, 0.7, step(0.5, mod(count + localTime * 1.0, 6.0) / 2.0));\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotDataId": "TNJTEJo42ATm7SLyG", "views": { "$numberInt": "451" diff --git a/art/wnJ3yTrs7ZQXEmwRM/art.json b/art/wnJ3yTrs7ZQXEmwRM/art.json index 56ed1097..2346f9ef 100644 --- a/art/wnJ3yTrs7ZQXEmwRM/art.json +++ b/art/wnJ3yTrs7ZQXEmwRM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvoid main() {\\n\\n float stripId = mod(vertexId, 2.0);\\n float norId = vertexId / vertexCount;\\n \\n float x = norId - 0.5;\\n float y = stripId - 0.5;\\n \\n float ar = resolution.x / resolution.y;\\n \\n y += sin(x * 50.0) * sin(time); \\n y *= cos(time);\\n \\n vec2 p = vec2(x * ar, y);\\n p.y -= abs(norId - 0.5) * 2.0;\\n \\n gl_Position = vec4(p.x, p.y, 0, 1);\\n\\n v_color = vec4(1,1,1,1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvoid main() {\n\n float stripId = mod(vertexId, 2.0);\n float norId = vertexId / vertexCount;\n \n float x = norId - 0.5;\n float y = stripId - 0.5;\n \n float ar = resolution.x / resolution.y;\n \n y += sin(x * 50.0) * sin(time); \n y *= cos(time);\n \n vec2 p = vec2(x * ar, y);\n p.y -= abs(norId - 0.5) * 2.0;\n \n gl_Position = vec4(p.x, p.y, 0, 1);\n\n v_color = vec4(1,1,1,1);\n}" + }, "screenshotURL": "data/images/images-whitf9c4w3fcztyod-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wrMBc6LyKbu6PqxgL/art.json b/art/wrMBc6LyKbu6PqxgL/art.json index 3bf9b3c8..96a020e2 100644 --- a/art/wrMBc6LyKbu6PqxgL/art.json +++ b/art/wrMBc6LyKbu6PqxgL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "hyunjin-kim-dp", "avatarUrl": "https://avatars.githubusercontent.com/Hyunjin-Kim-DP?s=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// hyunjin Kim\\n// cs250 exercise - Audio Reactive\\n// spring 2022\\n\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a / 15.; \\n \\n float down = point * sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across * snd);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n\\n gl_PointSize = 15.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = (0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue + (snd * 7.), 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// hyunjin Kim\n// cs250 exercise - Audio Reactive\n// spring 2022\n\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a / 15.; \n \n float down = point * sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across * snd);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n\n gl_PointSize = 15.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = (0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue + (snd * 7.), 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-rwj10l45dpo2ojncj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wrTE6KKesztAX6apx/art.json b/art/wrTE6KKesztAX6apx/art.json index 41459c39..12fb87fe 100644 --- a/art/wrTE6KKesztAX6apx/art.json +++ b/art/wrTE6KKesztAX6apx/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "junkyo", "avatarUrl": "https://lh5.googleusercontent.com/-kvoS5qzQr_A/AAAAAAAAAAI/AAAAAAAAACQ/FspBlgMeblI/photo.jpg", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08627450980392157,0.043137254901960784,0.10588235294117647,1],\"shader\":\"void main(){\\n\\n \\n float across = 10.;\\n \\n float x = mod(vertexId,across); \\n float y = floor(vertexId / across); \\n \\n float u = x / across;\\n float v = y / across;\\n \\n gl_Position = vec4(u, v, 0, 1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08627450980392157, + 0.043137254901960784, + 0.10588235294117647, + 1 + ], + "shader": "void main(){\n\n \n float across = 10.;\n \n float x = mod(vertexId,across); \n float y = floor(vertexId / across); \n \n float u = x / across;\n float v = y / across;\n \n gl_Position = vec4(u, v, 0, 1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-jw0i60oj7iccbs2ni-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wt7dgJfnc9ut9a8tk/art.json b/art/wt7dgJfnc9ut9a8tk/art.json index b33a1c9c..7809dd63 100644 --- a/art/wt7dgJfnc9ut9a8tk/art.json +++ b/art/wt7dgJfnc9ut9a8tk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n float v=vertexId/30.0;\\n int num=int(mouse.x*10.0+10.0);\\n int den=int(exp(mouse.y*3.0+3.0));\\n float frac=1.0-float(num)/float(den);\\n vec2 xy=vec2(sin(v),cos(v)*sin(v*frac))/2.0;\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n v_color = vec4(0,0,0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n float v=vertexId/30.0;\n int num=int(mouse.x*10.0+10.0);\n int den=int(exp(mouse.y*3.0+3.0));\n float frac=1.0-float(num)/float(den);\n vec2 xy=vec2(sin(v),cos(v)*sin(v*frac))/2.0;\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(xy * aspect, 0, 1);\n v_color = vec4(0,0,0, 1);\n}" + }, "screenshotURL": "data/images/images-fd3u5k3lbarswitfj-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wuFdtxFYcP6TczAW2/art.json b/art/wuFdtxFYcP6TczAW2/art.json index 4f6b734f..0f83407b 100644 --- a/art/wuFdtxFYcP6TczAW2/art.json +++ b/art/wuFdtxFYcP6TczAW2/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n//for the K Machine\\n#define parameter0 0.//KParameter0 0.>>8.\\n#define parameter1 3.//KParameter1 1.>>8.\\n#define parameter2 3.//KParameter2 0.>>40.\\n#define parameter3 30.//KParameter3 5>>100.\\n#define parameter4 0.02//KParameter4 0.01>>0.05\\n#define parameter5 30.//KParameter5 5.>>50.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 1.>>5.\\n\\n\\n#define HPI 1.570796326795\\n#define PI 3.1415926535898\\n\\nvec3 hashv3(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\nmat4 uniformScale(float _s) {\\n return mat4(\\n _s, 0, 0, 0,\\n 0, _s, 0, 0,\\n 0, 0, _s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\\n{\\n vec3 u = _triangleVertices0 - _triangleVertices1;\\n vec3 v = _triangleVertices1 - _triangleVertices2;\\n return cross(v, u);\\n}\\n\\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\\n{\\n float localVid = mod(_vId,_vtn);\\n \\n if(localVid< 1.)\\n {\\n \\n _v = _vt[0];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n \\n }\\n else\\n if(localVid< 2.)\\n {\\n _v = _vt[1];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 3.)\\n {\\n _v = _vt[2];\\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\\n _color = _cl[0];\\n }\\n else\\n if(localVid< 4.)\\n {\\n _v = _vt[3];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 5.)\\n {\\n _v = _vt[4];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 6.)\\n {\\n _v = _vt[5];\\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\\n _color = _cl[1];\\n }\\n else\\n if(localVid< 7.)\\n {\\n _v = _vt[6];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 8.)\\n {\\n _v = _vt[7];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 9.)\\n {\\n _v = _vt[8];\\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\\n _color = _cl[2];\\n }\\n else\\n if(localVid< 10.)\\n {\\n _v = _vt[9];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 11.)\\n {\\n _v = _vt[10];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n else\\n if(localVid< 12.)\\n {\\n _v = _vt[11];\\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\\n _color = _cl[3];\\n }\\n \\n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\\n \\n _v = rotY(_v,_rot.y);\\n _n = rotY(_n,_rot.y);\\n \\n\\n _v = rotX(_v,_rot.x);\\n _n = rotX(_n,_rot.x);\\n \\n _v = rotZ(_v,_rot.z);\\n _n = rotZ(_n,_rot.z);\\n \\n _v += _pos;\\n //_n += _pos;\\n}\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\\n specular = max(0.0, pow(NDoth, _spec.x));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n\\nvoid main() {\\n \\n vec3 color = vec3(1.);\\n \\n //KVsa\\n float loopDurationMs = 4000.;\\n float timeProgress = mod(time*1000.,loopDurationMs);\\n float relLoopProgress = timeProgress/loopDurationMs;\\n //KVsa\\n \\n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops = floor(parameter1);\\n float subLoopLength = 1./numberOfSubLoops;\\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\\n\\n \\n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\\n float numberOfSubLoops2 = floor(1.);\\n float subLoopLength2 = 1./numberOfSubLoops2;\\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\\n \\n vec3 _v = vec3(0.,0.,0.);\\n vec3 _n = vec3(0.,0.,0.);\\n \\n vec3 shapeVertices[12];\\n float shapeSize = 12.;\\n \\n \\n \\n \\n float maxShapeCount = floor(vertexCount/shapeSize);\\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\\n float shapeId = floor(finalVertexId/shapeSize);\\n float relShapeId = shapeId/maxShapeCount;\\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\\n \\n //create the big circle\\n float masterCircleRadius = 0.8;\\n float numberOfCirclesInMasterCircle = floor(parameter5);\\n float vertexPerSmallCircle = numberOfShape*shapeSize;\\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\\n \\n float scale = parameter4;\\n \\n \\n \\n float localShapeId = mod(shapeId,numberOfShape);\\n float localRelShapeId = localShapeId/numberOfShape;\\n \\n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\\n \\n \\n float radius = 0.3;//+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\\n \\n \\n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\\n \\n \\n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\\n float sndFactor = texture2D(sound, vec2(relMasterCircleId, 0.)).a ;\\n float factor1 = 1.+sndFactor*20.;\\n \\n shapeVertices[0] = vec3(-0.5,0.,-0.5);\\n shapeVertices[1] = vec3(0.5,0.,-0.5);\\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\\n shapeVertices[3] = vec3(0.5,0.,-0.5);\\n shapeVertices[4] = vec3(0.5,0.,0.5);\\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\\n shapeVertices[6] =vec3(0.5,0.,0.5);\\n shapeVertices[7] =vec3(-0.5,0.,0.5);\\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\\n shapeVertices[9] =vec3(-0.5,0.,0.5);\\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\\n \\n vec3 shapeColors[4];\\n \\n shapeColors[0] = vec3(1.,1.,0.);\\n shapeColors[1] = vec3(0.,0.,1.);\\n shapeColors[2] = vec3(0.,1.,1.);\\n shapeColors[3] = vec3(1.,0.,1.);\\n \\n vec3 rot = vec3(PI/2.*sndFactor*10.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\\n \\n \\n \\n //_v.y-=masterCircleRadius;\\n \\n _v = rotX(_v,-(relMasterCircleId*2.*PI));//+time*10.));\\n _n = rotX(_v,-(relMasterCircleId*2.*PI));\\n /// _v.z-=0.58;\\n \\n vec3 eye = vec3(cos(time), 0., -0.5);\\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\\n\\n vec3 p = lookAt(_v, eye, vec3(0.,0.,0.0), vec3(0.0, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n \\n _v.x*=resolution.y/resolution.x;\\n\\n gl_PointSize = 10.;\\n v_color = vec4(color, 1.);\\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/drumcomplex/torsten-kanzler-overdog-drumcomplex-remix-tkr", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n//for the K Machine\n#define parameter0 0.//KParameter0 0.>>8.\n#define parameter1 3.//KParameter1 1.>>8.\n#define parameter2 3.//KParameter2 0.>>40.\n#define parameter3 30.//KParameter3 5>>100.\n#define parameter4 0.02//KParameter4 0.01>>0.05\n#define parameter5 30.//KParameter5 5.>>50.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 1.>>5.\n\n\n#define HPI 1.570796326795\n#define PI 3.1415926535898\n\nvec3 hashv3(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\nmat4 uniformScale(float _s) {\n return mat4(\n _s, 0, 0, 0,\n 0, _s, 0, 0,\n 0, 0, _s, 0,\n 0, 0, 0, 1);\n}\n\nvec3 NormalFromTriangleVertices(vec3 _triangleVertices0, vec3 _triangleVertices1, vec3 _triangleVertices2)\n{\n vec3 u = _triangleVertices0 - _triangleVertices1;\n vec3 v = _triangleVertices1 - _triangleVertices2;\n return cross(v, u);\n}\n\nvoid drawShapeFromVerticesList(const vec3 _vt[12],const vec3 _cl[4], const float _vtn, const float _vId, const vec3 _pos, const vec3 _rot, out vec3 _n, out vec3 _v, out vec3 _color, float _scale)\n{\n float localVid = mod(_vId,_vtn);\n \n if(localVid< 1.)\n {\n \n _v = _vt[0];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n \n }\n else\n if(localVid< 2.)\n {\n _v = _vt[1];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 3.)\n {\n _v = _vt[2];\n _n = NormalFromTriangleVertices(_vt[0], _vt[1],_vt[2]);\n _color = _cl[0];\n }\n else\n if(localVid< 4.)\n {\n _v = _vt[3];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 5.)\n {\n _v = _vt[4];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 6.)\n {\n _v = _vt[5];\n _n = NormalFromTriangleVertices(_vt[3], _vt[4],_vt[5]);\n _color = _cl[1];\n }\n else\n if(localVid< 7.)\n {\n _v = _vt[6];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 8.)\n {\n _v = _vt[7];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 9.)\n {\n _v = _vt[8];\n _n = NormalFromTriangleVertices(_vt[6], _vt[7],_vt[8]);\n _color = _cl[2];\n }\n else\n if(localVid< 10.)\n {\n _v = _vt[9];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 11.)\n {\n _v = _vt[10];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n else\n if(localVid< 12.)\n {\n _v = _vt[11];\n _n = NormalFromTriangleVertices(_vt[9], _vt[10],_vt[11]);\n _color = _cl[3];\n }\n \n _v = (vec4(_v,1.)*uniformScale(_scale)).xyz;\n //_n = (vec4(_n,1.)*uniformScale(_scale)).xyz;\n \n _v = rotY(_v,_rot.y);\n _n = rotY(_n,_rot.y);\n \n\n _v = rotX(_v,_rot.x);\n _n = rotX(_n,_rot.x);\n \n _v = rotZ(_v,_rot.z);\n _n = rotZ(_n,_rot.z);\n \n _v += _pos;\n //_n += _pos;\n}\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n float NDotLit = clamp(dot(_n, lit), 0.0, 1.0);\n float diffuse = max(0.0, NDotLit) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n float NDoth = clamp(dot(_n, h), 0.0, 1.0);\n specular = max(0.0, pow(NDoth, _spec.x));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n\nvoid main() {\n \n vec3 color = vec3(1.);\n \n //KVsa\n float loopDurationMs = 4000.;\n float timeProgress = mod(time*1000.,loopDurationMs);\n float relLoopProgress = timeProgress/loopDurationMs;\n //KVsa\n \n float finalRelLoopProgress = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops = floor(parameter1);\n float subLoopLength = 1./numberOfSubLoops;\n finalRelLoopProgress = mod(relLoopProgress,subLoopLength)/subLoopLength;\n\n \n float finalRelLoopProgress2 = relLoopProgress;//mod(relLoopProgress,(1./factor));\n float numberOfSubLoops2 = floor(1.);\n float subLoopLength2 = 1./numberOfSubLoops2;\n finalRelLoopProgress2 = mod(relLoopProgress,subLoopLength2)/subLoopLength2;\n \n vec3 _v = vec3(0.,0.,0.);\n vec3 _n = vec3(0.,0.,0.);\n \n vec3 shapeVertices[12];\n float shapeSize = 12.;\n \n \n \n \n float maxShapeCount = floor(vertexCount/shapeSize);\n float finalVertexId = min(vertexId,maxShapeCount*shapeSize);\n float shapeId = floor(finalVertexId/shapeSize);\n float relShapeId = shapeId/maxShapeCount;\n float numberOfShape = floor(parameter3);//floor(0.03*((vertexCount/shapeSize)/5.));\n \n //create the big circle\n float masterCircleRadius = 0.8;\n float numberOfCirclesInMasterCircle = floor(parameter5);\n float vertexPerSmallCircle = numberOfShape*shapeSize;\n float masterCircleId = floor(finalVertexId/vertexPerSmallCircle);\n float relMasterCircleId = masterCircleId/numberOfCirclesInMasterCircle;\n \n float scale = parameter4;\n \n \n \n float localShapeId = mod(shapeId,numberOfShape);\n float localRelShapeId = localShapeId/numberOfShape;\n \n float sf = 0.;//texture2D(sound, vec2(0.23, localRelShapeId)).a ;\n \n \n float radius = 0.3;//+sf*0.09;//+0.1*floor(shapeId/numberOfShape);\n \n \n vec3 shapePos = vec3(radius*cos(2.*PI*localRelShapeId),radius*sin(2.*PI*localRelShapeId),0.);\n \n \n float factor = parameter0*abs(cos(PI*finalRelLoopProgress+floor(shapeId/numberOfShape)));\n float sndFactor = texture2D(sound, vec2(relMasterCircleId, 0.)).a ;\n float factor1 = 1.+sndFactor*20.;\n \n shapeVertices[0] = vec3(-0.5,0.,-0.5);\n shapeVertices[1] = vec3(0.5,0.,-0.5);\n shapeVertices[2] = vec3(0.,factor1,0.-factor);\n shapeVertices[3] = vec3(0.5,0.,-0.5);\n shapeVertices[4] = vec3(0.5,0.,0.5);\n shapeVertices[5] = vec3(0.+factor,factor1,0.);\n shapeVertices[6] =vec3(0.5,0.,0.5);\n shapeVertices[7] =vec3(-0.5,0.,0.5);\n shapeVertices[8] =vec3(0.,factor1,0.+factor);\n shapeVertices[9] =vec3(-0.5,0.,0.5);\n shapeVertices[10] =vec3(-0.5,0.,-0.5);\n shapeVertices[11] =vec3(0.-factor,factor1,0.);\n \n vec3 shapeColors[4];\n \n shapeColors[0] = vec3(1.,1.,0.);\n shapeColors[1] = vec3(0.,0.,1.);\n shapeColors[2] = vec3(0.,1.,1.);\n shapeColors[3] = vec3(1.,0.,1.);\n \n vec3 rot = vec3(PI/2.*sndFactor*10.,0.,(time*2.*PI/10.)*parameter2+ (localRelShapeId*PI*2.));\n drawShapeFromVerticesList(shapeVertices, shapeColors, shapeSize, finalVertexId, shapePos, rot, _n, _v, color, scale);\n \n \n \n //_v.y-=masterCircleRadius;\n \n _v = rotX(_v,-(relMasterCircleId*2.*PI));//+time*10.));\n _n = rotX(_v,-(relMasterCircleId*2.*PI));\n /// _v.z-=0.58;\n \n vec3 eye = vec3(cos(time), 0., -0.5);\n color = shade(eye, _v, _n, color, 0.8, vec2(64.0, 3.8));\n\n vec3 p = lookAt(_v, eye, vec3(0.,0.,0.0), vec3(0.0, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n \n _v.x*=resolution.y/resolution.x;\n\n gl_PointSize = 10.;\n v_color = vec4(color, 1.);\n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-c705vuzt7odcujhwb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wvtQDvQbMrdANuDHh/art.json b/art/wvtQDvQbMrdANuDHh/art.json index 5c2edb8d..8cc6216e 100644 --- a/art/wvtQDvQbMrdANuDHh/art.json +++ b/art/wvtQDvQbMrdANuDHh/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":1769,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/dan-hekate-1/mercury-in-stasis\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.08235294117647059,0.08235294117647059,1],\"shader\":\"\\n#define parameter0 0.//KParameter 0.>>6.\\n#define P2 -3.//KParameter -5.>>10.\\n#define P3 0.1//KParameter 0.1>>3.\\n#define P6 9.//KParameter 0.1>>10.\\n#define P5 0.2//KParameter -1.>>1.\\n#define P4 0.5//KParameter 0.0>>1.\\n#define mx .1//KParameter -1.0>>1.0\\n#define my .72//KParameter -1.0>>1.0\\n//KVerticesNumber=1580\\n\\n\\n//KDrawmode=GL_TRIANGLE_FAN\\n\\n#define PI radians(120.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, .20 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, s, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c-1., 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0],\\n m[0][1], m[1][1], m[2][1],\\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0],\\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0],\\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, mx,\\n zAxis,1.5,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.5); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\nvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\nreturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 8.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.9 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION)\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\nfloat vertexCount = 10000. * P5;\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * s * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.2); \\n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor((vertexCount / 22. +P5));\\n float halfAround = floor(sqrt(numQuads));\\n float around = halfAround * 1.25;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 12.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / down*3.);\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6);\\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * P6) + my * r;\\n float y = sin(qu * PI * 4.) * r;\\n \\n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\\n \\n float tm = time * 1.02 +mx* qv;\\n float rd = 3.;\\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mx *3.0) + 2.0, sin(tm) * rd);\\n vec3 target = vec3(P3);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\\n gl_PointSize = 1. ;\\n \\n float hue = quadId *.01;\\n float sat = P4;\\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 1769, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/dan-hekate-1/mercury-in-stasis", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.08235294117647059, + 0.08235294117647059, + 1 + ], + "shader": "\n#define parameter0 0.//KParameter 0.>>6.\n#define P2 -3.//KParameter -5.>>10.\n#define P3 0.1//KParameter 0.1>>3.\n#define P6 9.//KParameter 0.1>>10.\n#define P5 0.2//KParameter -1.>>1.\n#define P4 0.5//KParameter 0.0>>1.\n#define mx .1//KParameter -1.0>>1.0\n#define my .72//KParameter -1.0>>1.0\n//KVerticesNumber=1580\n\n\n//KDrawmode=GL_TRIANGLE_FAN\n\n#define PI radians(120.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, .20 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, s, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c-1., 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 1, zNear * zFar * rangeInv * 1.5, 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0],\n m[0][1], m[1][1], m[2][1],\n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0],\n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0],\n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, mx,\n zAxis,1.5,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 0.5); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\nvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\nreturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 8.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.9 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION)\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\nfloat vertexCount = 10000. * P5;\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 4.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1 *P4);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 0.2, level) /vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * s * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.2); \n uvf = vec4(floor(edgeId / 12.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 8.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor((vertexCount / 22. +P5));\n float halfAround = floor(sqrt(numQuads));\n float around = halfAround * 1.25;\n float down = numQuads / around;\n float quadId = floor(vertexId / 12.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / down*3.);\n \n float edgeId = mod(vertexId, 6.);\n float ux = floor(vertexId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(vertexId / 2.) + floor(vertexId *2. ), 0.6);\n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * P6) + my * r;\n float y = sin(qu * PI * 4.) * r;\n \n vec3 pos = vec3(x, 1.-y, cos(qx * PI));\n \n float tm = time * 1.02 +mx* qv;\n float rd = 3.;\n mat4 mat = persp(PI - 1.525+parameter0, resolution.x / resolution.y, 1.2, 22.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) / (-mx *3.0) + 2.0, sin(tm) * rd);\n vec3 target = vec3(P3);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n gl_Position = mat * vec4(pos-1.,sin(.5+P5));\n gl_PointSize = 1. ;\n \n float hue = quadId *.01;\n float sat = P4;\n float val = vertexCount/(vertexId* 1.1 *qx)*0.126;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 2.);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-a05svjj3hd0hwzvh1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wxCaDvySLwp6dYRto/art.json b/art/wxCaDvySLwp6dYRto/art.json index 1e32114b..44c15d21 100644 --- a/art/wxCaDvySLwp6dYRto/art.json +++ b/art/wxCaDvySLwp6dYRto/art.json @@ -30,7 +30,19 @@ }, "private": true, "username": "gman", - "settings": "{\"num\":772,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n// Based on code by Nik\\n// http://codepen.io/nikrowell/pen/BNdaKV\\n\\n#define SETTINGS_FRICTION 0.5\\n#define SETTINGS_TRAILS 20.\\n#define SETTINGS_SIZE 50.\\n#define SETTINGS_DAMPENING 0.25\\n#define SETTINGS_TENSION 0.98\\n#define SETTINGS_POINTS_PER_NODE 20.\\n\\t\\n#define SETTINGS_POINTS_PER_TENDRIL (SETTINGS_SIZE * SETTINGS_POINTS_PER_NODE * 2.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nvec2 getPoint(float pointId) {\\n return vec2(m1p1(hash(pointId)), m1p1(hash(pointId + 0.37))) * 0.5;\\n}\\n\\n\\nvoid main() {\\n float pointId = mod(floor(vertexId / 2.), SETTINGS_POINTS_PER_TENDRIL) + mod(vertexId, 2.);\\n float cPointId = floor(pointId / SETTINGS_POINTS_PER_NODE);\\n float innerId = mod(pointId, SETTINGS_POINTS_PER_NODE);\\n float tendrilId = floor(vertexId / SETTINGS_POINTS_PER_TENDRIL);\\n \\n vec2 cp0 = getPoint(cPointId);\\n vec2 cp1 = getPoint(cPointId + 1.);\\n vec2 cp2 = getPoint(cPointId + 2.);\\n \\n float t = innerId / SETTINGS_POINTS_PER_NODE;\\n float invT = 1. - t;\\n // B(t) = (1 - t)[(1 - t)p0 + tP1] + t[(1 - t)P1 + tP2]\\n // B(t) = (1 - t)^2p0 + 2(1-t)tp1 + t^2p2;\\n //vec2 p = mix(mix(cp0, cp1, v), mix(cp1, cp2, v), v);\\n //vec2 p = invT * (invT * cp0 + t * cp1) + t * (invT * cp1 + cp2);\\n vec2 p = pow(invT, 2.) * cp0 + 2. * invT * t * cp1 + pow(t, 2.) * cp2; \\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(p * aspect, 0, 1);\\n\\n float hue = (time * 0.01);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n gl_PointSize = 4.;\\n}\\n\\n/* \\nMath.round(hue.update()) + ',90%,50%,0.25)';\\n\\t\\tctx.lineWidth = 1;\\n\\t\\t\\n\\t\\tfor(var i = 0, tendril; i < settings.trails; i++) {\\n\\t\\t\\ttendril = tendrils[i];\\n\\t\\t\\ttendril.update();\\n\\t\\t\\ttendril.draw();\\n\\t\\t}\\n\\n\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tthis.spring = options.spring + (Math.random() * 0.1) - 0.05; \\n\\t\\t\\t\\tthis.friction = settings.friction + (Math.random() * 0.01) - 0.005;\\n\\t\\t\\t\\tthis.nodes = [];\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tfor(var i = 0, node; i < settings.size; i++) {\\n\\t\\t\\t\\n\\t\\t\\t\\t\\tnode = new Node();\\n\\t\\t\\t\\t\\tnode.x = target.x;\\n\\t\\t\\t\\t\\tnode.y = target.y;\\n\\t\\t\\t\\n\\t\\t\\t\\t\\tthis.nodes.push(node);\\n\\t\\t\\t\\t}\\t\\n\\t\\t\\t},\\n\\t\\t\\t\\n\\t\\t\\tupdate: function() {\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tvar spring = this.spring,\\n\\t\\t\\t\\t\\tnode = this.nodes[0];\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tnode.vx += (target.x - node.x) * spring;\\n\\t\\t\\t\\tnode.vy += (target.y - node.y) * spring;\\n\\t\\t\\t\\t\\t\\n\\t\\t\\t\\tfor(var prev, i = 0, n = this.nodes.length; i < n; i++) {\\n\\t\\n\\t\\t\\t\\t\\tnode = this.nodes[i];\\n\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\tif(i > 0) {\\n\\t\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\t\\tprev = this.nodes[i - 1];\\n\\t\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\t\\tnode.vx += (prev.x - node.x) * spring;\\n\\t\\t\\t\\t\\t\\tnode.vy += (prev.y - node.y) * spring;\\n\\t\\t\\t\\t\\t\\tnode.vx += prev.vx * settings.dampening;\\n\\t\\t\\t\\t\\t\\tnode.vy += prev.vy * settings.dampening;\\n\\t\\t\\t\\t\\t}\\n\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\tnode.vx *= this.friction;\\n\\t\\t\\t\\t\\tnode.vy *= this.friction;\\n\\t\\t\\t\\t\\tnode.x += node.vx;\\n\\t\\t\\t\\t\\tnode.y += node.vy;\\n\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\tspring *= settings.tension;\\n\\t\\t\\t\\t}\\n\\t\\t\\t},\\n\\t\\n\\t\\t\\tdraw: function() {\\n\\t\\t\\t\\n\\t\\t\\t\\tvar x = this.nodes[0].x, \\n\\t\\t\\t\\t\\ty = this.nodes[0].y,\\n\\t\\t\\t\\t\\ta, b;\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tctx.beginPath();\\n\\t\\t\\t\\tctx.moveTo(x, y);\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tfor(var i = 1, n = this.nodes.length - 2; i < n; i++) {\\n\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\ta = this.nodes[i];\\n\\t\\t\\t\\t\\tb = this.nodes[i + 1];\\n\\t\\t\\t\\t\\tx = (a.x + b.x) * 0.5;\\n\\t\\t\\t\\t\\ty = (a.y + b.y) * 0.5;\\n\\t\\t\\t\\t\\t\\n\\t\\t\\t\\t\\tctx.quadraticCurveTo(a.x, a.y, x, y);\\n\\t\\t\\t\\t}\\n\\t\\t\\t\\t\\n\\t\\t\\t\\ta = this.nodes[i];\\n\\t\\t\\t\\tb = this.nodes[i + 1];\\n\\t\\t\\t\\t\\n\\t\\t\\t\\tctx.quadraticCurveTo(a.x, a.y, b.x, b.y);\\n\\t\\t\\t\\tctx.stroke();\\n\\t\\t\\t\\tctx.closePath();\\n\\t\\t\\t}\\n\\t\\t};\\n\\t\\n\\t\\n*/\\n\\n\\n\"}", + "settings": { + "num": 772, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n// Based on code by Nik\n// http://codepen.io/nikrowell/pen/BNdaKV\n\n#define SETTINGS_FRICTION 0.5\n#define SETTINGS_TRAILS 20.\n#define SETTINGS_SIZE 50.\n#define SETTINGS_DAMPENING 0.25\n#define SETTINGS_TENSION 0.98\n#define SETTINGS_POINTS_PER_NODE 20.\n\t\n#define SETTINGS_POINTS_PER_TENDRIL (SETTINGS_SIZE * SETTINGS_POINTS_PER_NODE * 2.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nvec2 getPoint(float pointId) {\n return vec2(m1p1(hash(pointId)), m1p1(hash(pointId + 0.37))) * 0.5;\n}\n\n\nvoid main() {\n float pointId = mod(floor(vertexId / 2.), SETTINGS_POINTS_PER_TENDRIL) + mod(vertexId, 2.);\n float cPointId = floor(pointId / SETTINGS_POINTS_PER_NODE);\n float innerId = mod(pointId, SETTINGS_POINTS_PER_NODE);\n float tendrilId = floor(vertexId / SETTINGS_POINTS_PER_TENDRIL);\n \n vec2 cp0 = getPoint(cPointId);\n vec2 cp1 = getPoint(cPointId + 1.);\n vec2 cp2 = getPoint(cPointId + 2.);\n \n float t = innerId / SETTINGS_POINTS_PER_NODE;\n float invT = 1. - t;\n // B(t) = (1 - t)[(1 - t)p0 + tP1] + t[(1 - t)P1 + tP2]\n // B(t) = (1 - t)^2p0 + 2(1-t)tp1 + t^2p2;\n //vec2 p = mix(mix(cp0, cp1, v), mix(cp1, cp2, v), v);\n //vec2 p = invT * (invT * cp0 + t * cp1) + t * (invT * cp1 + cp2);\n vec2 p = pow(invT, 2.) * cp0 + 2. * invT * t * cp1 + pow(t, 2.) * cp2; \n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(p * aspect, 0, 1);\n\n float hue = (time * 0.01);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n gl_PointSize = 4.;\n}\n\n/* \nMath.round(hue.update()) + ',90%,50%,0.25)';\n\t\tctx.lineWidth = 1;\n\t\t\n\t\tfor(var i = 0, tendril; i < settings.trails; i++) {\n\t\t\ttendril = tendrils[i];\n\t\t\ttendril.update();\n\t\t\ttendril.draw();\n\t\t}\n\n\n\t\t\t\t\n\t\t\t\tthis.spring = options.spring + (Math.random() * 0.1) - 0.05; \n\t\t\t\tthis.friction = settings.friction + (Math.random() * 0.01) - 0.005;\n\t\t\t\tthis.nodes = [];\n\t\t\t\t\n\t\t\t\tfor(var i = 0, node; i < settings.size; i++) {\n\t\t\t\n\t\t\t\t\tnode = new Node();\n\t\t\t\t\tnode.x = target.x;\n\t\t\t\t\tnode.y = target.y;\n\t\t\t\n\t\t\t\t\tthis.nodes.push(node);\n\t\t\t\t}\t\n\t\t\t},\n\t\t\t\n\t\t\tupdate: function() {\n\t\t\t\t\n\t\t\t\tvar spring = this.spring,\n\t\t\t\t\tnode = this.nodes[0];\n\t\t\t\t\n\t\t\t\tnode.vx += (target.x - node.x) * spring;\n\t\t\t\tnode.vy += (target.y - node.y) * spring;\n\t\t\t\t\t\n\t\t\t\tfor(var prev, i = 0, n = this.nodes.length; i < n; i++) {\n\t\n\t\t\t\t\tnode = this.nodes[i];\n\t\t\t\t\t\n\t\t\t\t\tif(i > 0) {\n\t\t\t\t\t\t\n\t\t\t\t\t\tprev = this.nodes[i - 1];\n\t\t\t\t\t\t\n\t\t\t\t\t\tnode.vx += (prev.x - node.x) * spring;\n\t\t\t\t\t\tnode.vy += (prev.y - node.y) * spring;\n\t\t\t\t\t\tnode.vx += prev.vx * settings.dampening;\n\t\t\t\t\t\tnode.vy += prev.vy * settings.dampening;\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tnode.vx *= this.friction;\n\t\t\t\t\tnode.vy *= this.friction;\n\t\t\t\t\tnode.x += node.vx;\n\t\t\t\t\tnode.y += node.vy;\n\t\t\t\t\t\n\t\t\t\t\tspring *= settings.tension;\n\t\t\t\t}\n\t\t\t},\n\t\n\t\t\tdraw: function() {\n\t\t\t\n\t\t\t\tvar x = this.nodes[0].x, \n\t\t\t\t\ty = this.nodes[0].y,\n\t\t\t\t\ta, b;\n\t\t\t\t\n\t\t\t\tctx.beginPath();\n\t\t\t\tctx.moveTo(x, y);\n\t\t\t\t\n\t\t\t\tfor(var i = 1, n = this.nodes.length - 2; i < n; i++) {\n\t\t\t\t\t\n\t\t\t\t\ta = this.nodes[i];\n\t\t\t\t\tb = this.nodes[i + 1];\n\t\t\t\t\tx = (a.x + b.x) * 0.5;\n\t\t\t\t\ty = (a.y + b.y) * 0.5;\n\t\t\t\t\t\n\t\t\t\t\tctx.quadraticCurveTo(a.x, a.y, x, y);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\ta = this.nodes[i];\n\t\t\t\tb = this.nodes[i + 1];\n\t\t\t\t\n\t\t\t\tctx.quadraticCurveTo(a.x, a.y, b.x, b.y);\n\t\t\t\tctx.stroke();\n\t\t\t\tctx.closePath();\n\t\t\t}\n\t\t};\n\t\n\t\n*/\n\n\n" + }, "screenshotURL": "data/images/images-pyuemm0rqvtg1uvbc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/wxPvS64A9HG62L8za/art.json b/art/wxPvS64A9HG62L8za/art.json index 3a8a3898..0eccf2c2 100644 --- a/art/wxPvS64A9HG62L8za/art.json +++ b/art/wxPvS64A9HG62L8za/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/7t2names/the-power-tareq-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 28.0\\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\\n#define PI 3.14159265359\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate2D(float _a) {\\n\\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\\n}\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nvoid main() {\\n float numLinesDown = floor(vertexCount / NUM_POINTS);\\n // produces 0,1, 1,2, 2,3, ...\\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\\n // line count\\n float count = floor(vertexId / NUM_POINTS);\\n vec2 ctr = vec2(0.5);\\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\\n float v = count / numLinesDown; // 0 <-> 1 by line\\n float invV = 1.0 - v;\\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\\n // Only use the left most 1/4th of the sound texture\\n // because there's no action on the right\\n float historyX = u * 0.25;\\n // Match each line to a specific row in the sound texture\\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\\n float xOff = sin(PI * count + x * 0.35) * 2.0;\\n float yOff = cos(PI * count + y * 0.005) * 4.0;\\n vec2 xy = vec2(\\n x * mix(yOff, s * snd, invV),\\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\\n gl_PointSize = snd * 80. - xOff - yOff; \\n gl_PointSize *= 20.0 / numLinesDown * snd; \\n gl_PointSize *= resolution.x / 30. * xOff; \\n xy -= ctr;\\n xy *= rotate2D(snd * PI * 2.0 +s);\\n xy += ctr;\\n xy *= pow(xy, ctr + xy);\\n xy *= -3.;\\n //xy = fract(xy / 0.1);\\n gl_Position = vec4(xy / yOff, xOff , 1.-xOff);\\n xy -= vec2(0.5);\\n xy *= rotate2D(-snd * -PI * 2.0);\\n xy += vec2(0.5);\\n xy *= mouse;\\n float hue = snd -s;\\n float sat = 1.0;\\n float val = invV;\\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n //color *= rotY(PI * snd * s);\\n //background += 0.1;\\n vec4 finalColor = mix(color, background, s);\\n \\n v_color = finalColor;\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/7t2names/the-power-tareq-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 28.0\n#define NUM_POINTS (NUM_SEGMENTS * 4.0)\n#define PI 3.14159265359\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate2D(float _a) {\n\treturn mat2(cos(_a), sin(_a), -sin(_a), cos(_a));\n}\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nvoid main() {\n float numLinesDown = floor(vertexCount / NUM_POINTS);\n // produces 0,1, 1,2, 2,3, ...\n float point = floor(mod(vertexId, NUM_POINTS) / 2.0) + mod(vertexId, 2.0);\n // line count\n float count = floor(vertexId / NUM_POINTS);\n vec2 ctr = vec2(0.5);\n float u = point / NUM_SEGMENTS; // 0 <-> 1 across line\n float v = count / numLinesDown; // 0 <-> 1 by line\n float invV = 1.0 - v;\n float s = sin(time * 0.25/2.0)/2.0 +0.25;\n // Only use the left most 1/4th of the sound texture\n // because there's no action on the right\n float historyX = u * 0.25;\n // Match each line to a specific row in the sound texture\n float historyV = (v * numLinesDown + 0.5) / soundRes.y;\n float snd = texture2D(sound, vec2(historyX, historyV)).a;\n float x = abs(u * fract(time / PI * 0.25) - 1.0 * snd);\n float y = abs(v * fract(time * PI * .25) - 1.0 * snd * s);\n float xOff = sin(PI * count + x * 0.35) * 2.0;\n float yOff = cos(PI * count + y * 0.005) * 4.0;\n vec2 xy = vec2(\n x * mix(yOff, s * snd, invV),\n y + mod(snd * 2.0, 5.0 * xOff) * 1.0) / (v + xOff);\n gl_PointSize = snd * 80. - xOff - yOff; \n gl_PointSize *= 20.0 / numLinesDown * snd; \n gl_PointSize *= resolution.x / 30. * xOff; \n xy -= ctr;\n xy *= rotate2D(snd * PI * 2.0 +s);\n xy += ctr;\n xy *= pow(xy, ctr + xy);\n xy *= -3.;\n //xy = fract(xy / 0.1);\n gl_Position = vec4(xy / yOff, xOff , 1.-xOff);\n xy -= vec2(0.5);\n xy *= rotate2D(-snd * -PI * 2.0);\n xy += vec2(0.5);\n xy *= mouse;\n float hue = snd -s;\n float sat = 1.0;\n float val = invV;\n vec4 color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n //color *= rotY(PI * snd * s);\n //background += 0.1;\n vec4 finalColor = mix(color, background, s);\n \n v_color = finalColor;\n}" + }, "screenshotURL": "data/images/images-fp7o5ypxf3ibqk8mj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wyoNwyHa6hTbkGCKW/art.json b/art/wyoNwyHa6hTbkGCKW/art.json index 23d8d29b..1ff6006b 100644 --- a/art/wyoNwyHa6hTbkGCKW/art.json +++ b/art/wyoNwyHa6hTbkGCKW/art.json @@ -17,7 +17,19 @@ "name": "point cloud vs spheres", "private": false, "username": "-anon-", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.45,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.45,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n}" + }, "screenshotURL": "data/images/images-wp7spqlf2jnoox7yz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/wzJiTNRsg9cApqfB9/art.json b/art/wzJiTNRsg9cApqfB9/art.json index fe0689e6..f33174d2 100644 --- a/art/wzJiTNRsg9cApqfB9/art.json +++ b/art/wzJiTNRsg9cApqfB9/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/lapixmusic/fugene2crossfade\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define ITERS 40\\n#define M_PI 3.1415926535897932384626433832795\\n\\nvoid main ()\\n{\\n /*\\n float ratio = resolution.x/resolution.y;\\n float numAcrossDown = floor(sqrt(vertexCount));\\n \\n float maxVertexCount = numAcrossDown* numAcrossDown;\\n \\n float finalVertexId = mod(vertexId, maxVertexCount);\\n \\n float x = mod(finalVertexId, numAcrossDown);\\n float y = floor(finalVertexId / numAcrossDown);\\n \\n float u = x / numAcrossDown;\\n float v = (y / numAcrossDown)*ratio;\\n \\n float ux = ( (u ) * 2.0 - 1.0) *resolution.y/resolution.x;\\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n */\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\\n \\n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n \\n //x = number of elements in a line as x value for local resolution\\n //y = number of possible lines with the given vertexCount\\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\\n \\n //and adjust finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Calculate the position of the elements based on their finalVertexId\\n //simfragCoord <=> gl_FragCoord in the vertex shader\\n \\n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\\n \\n //Step 3 >> calculate vertice positions\\n //relative coordinate of the vertex (cordinates in 0..1 referential)\\n float u = (simfragCoord.x /vertexResolution.x);\\n float v = (simfragCoord.y /vertexResolution.y);\\n \\n //calculate coordinates in -1.>>1.0 space\\n float sizeFactor = 1.;\\n float fact = 2.*sizeFactor;\\n float ux = fact*(u - 0.5);\\n float vy = fact*(v - 0.5);\\n \\n gl_Position = vec4(ux, vy, 0., 1.);\\n \\n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\\n \\n \\n //logistic\\n \\n\\n float snd = texture2D(sound, vec2(0.1, ux)).a;\\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\\n \\n \\n vec2 p = vec2(ux , vy);\\n //float z = fract(0.86);\\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\\n int a = 0;\\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\\n \\n\\n if(p.x>0.)p.x = -p.x;\\n \\n if(p.y<0.)p.y = -p.y;\\n \\n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\\n \\n \\n for (int i = 0; i < ITERS; i++) {\\n a += (z > p.y && z <= p.y + 1. / vertexResolution.y) ? 1 : 0;\\n z = coeff * z * (1.-z);\\n };\\n \\n float iters = float(ITERS);\\n \\n float g = 25. * float(a) / iters;\\n\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n //gl_PointSize = (resolution.y/vertexResolution.y) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\\n\\n v_color = vec4(g, g/8., g / 3.,1.);\\n \\n \\n \\n\\n //v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/lapixmusic/fugene2crossfade", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define ITERS 40\n#define M_PI 3.1415926535897932384626433832795\n\nvoid main ()\n{\n /*\n float ratio = resolution.x/resolution.y;\n float numAcrossDown = floor(sqrt(vertexCount));\n \n float maxVertexCount = numAcrossDown* numAcrossDown;\n \n float finalVertexId = mod(vertexId, maxVertexCount);\n \n float x = mod(finalVertexId, numAcrossDown);\n float y = floor(finalVertexId / numAcrossDown);\n \n float u = x / numAcrossDown;\n float v = (y / numAcrossDown)*ratio;\n \n float ux = ( (u ) * 2.0 - 1.0) *resolution.y/resolution.x;\n float vy = ( (v*resolution.y/resolution.x) * 2.0 - 1.0);//*resolution.y/resolution.x;\n \n gl_Position = vec4(ux, vy, 0, 1);\n */\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = pow(maxFinalSquareSideSize,2.);\n \n float maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n \n //x = number of elements in a line as x value for local resolution\n //y = number of possible lines with the given vertexCount\n vec2 vertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\n \n //we can now calculate the final number of elements\n float finalVertexCount = vertexResolution.x*vertexResolution.y;\n \n //and adjust finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Calculate the position of the elements based on their finalVertexId\n //simfragCoord <=> gl_FragCoord in the vertex shader\n \n vec2 simfragCoord = vec2(mod(finalVertexId, vertexResolution.x),floor(finalVertexId / vertexResolution.x));\n \n //Step 3 >> calculate vertice positions\n //relative coordinate of the vertex (cordinates in 0..1 referential)\n float u = (simfragCoord.x /vertexResolution.x);\n float v = (simfragCoord.y /vertexResolution.y);\n \n //calculate coordinates in -1.>>1.0 space\n float sizeFactor = 1.;\n float fact = 2.*sizeFactor;\n float ux = fact*(u - 0.5);\n float vy = fact*(v - 0.5);\n \n gl_Position = vec4(ux, vy, 0., 1.);\n \n //gl_PointSize = ((resolution.y/numAcrossDown)*2.-1.) * 0.97;\n \n \n //logistic\n \n\n float snd = texture2D(sound, vec2(0.1, ux)).a;\n float snd2 = texture2D(sound, vec2(0.1, 0.3)).a;\n //float snd3 = texture2D(sound, vec2(0.1, 0.5)).a;\n \n \n vec2 p = vec2(ux , vy);\n //float z = fract(0.86);\n float z = fract(0.9*snd*2.+cos(1./2.)/40.);\n int a = 0;\n float trig = (cos(2. * M_PI * z) + 1.) / 2.;\n \n\n if(p.x>0.)p.x = -p.x;\n \n if(p.y<0.)p.y = -p.y;\n \n float coeff = mix(1., 3.75, trig) + p.x * mix(3., 0.25, trig);\n \n \n for (int i = 0; i < ITERS; i++) {\n a += (z > p.y && z <= p.y + 1. / vertexResolution.y) ? 1 : 0;\n z = coeff * z * (1.-z);\n };\n \n float iters = float(ITERS);\n \n float g = 25. * float(a) / iters;\n\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n //gl_PointSize = (resolution.y/vertexResolution.y) * 1.;//(resolution.y/numAcrossDown)*2.-1.;\n gl_PointSize = 2.*resolution.y/vertexResolution.y;\n\n v_color = vec4(g, g/8., g / 3.,1.);\n \n \n \n\n //v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-kknpejgr0p0i2neqq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/x3EiTmLXs7z5qb9Mm/art.json b/art/x3EiTmLXs7z5qb9Mm/art.json index 85408309..e6dde307 100644 --- a/art/x3EiTmLXs7z5qb9Mm/art.json +++ b/art/x3EiTmLXs7z5qb9Mm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":18172,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define TAU 6.28318530718\\n#define DEG2RAD 0.0174532925199433\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.1, 1.0), c.y);\\n} \\nvec4 cross(vec4 U, vec4 V, vec4 W)\\n{\\n float A, B, C, D, E, F; // Intermediate Values\\n // Calculate intermediate values.\\n A = (V[0] * W[1]) - (V[1] * W[0]);\\n B = (V[0] * W[2]) - (V[2] * W[0]);\\n C = (V[0] * W[3]) - (V[3] * W[0]);\\n D = (V[1] * W[2]) - (V[2] * W[1]);\\n E = (V[1] * W[3]) - (V[3] * W[1]);\\n F = (V[2] * W[3]) - (V[3] * W[2]);\\n // Calculate the result-vector components.\\n return vec4(\\n (U[1] * F) - (U[2] * E) + (U[3] * D),\\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\\n (U[0] * E) - (U[1] * C) + (U[3] * A),\\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\\n );\\n}\\nmat4 rot4xy(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, s, 0, 0,\\n -s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4yz(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle- 1. );\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4zx(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, -s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1);\\n}\\nmat4 rot4xw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n c, 0, 0, s,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n -s, 0, 0, c);\\n}\\nmat4 rot4yw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, 0, -s,\\n 0, 0, 1, 0,\\n 0, s, 0, c);\\n}\\nmat4 rot4zw(float angle)\\n{\\n float s = sin(angle);\\n float c = cos(angle);\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, c, -s,\\n 0, 0, s, c);\\n}\\n// from world to eye space.\\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\\n{\\n vec4 d = normalize(to-from);\\n vec4 a = normalize(cross(up, over, d));\\n vec4 b = normalize(cross(up, d, a));\\n vec4 c = cross(d, a, b);\\n transform = mat4(a, b, c, d);\\n}\\n// from 4d to 3d space.\\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\\n{\\n float S,T; // Divisor Values\\n vec4 V; // Scratch Vector\\n if (false /*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true /*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[3]);\\n return vec3(\\n S * dot (V, transform[0]),\\n S * dot (V, transform[1]),\\n S * dot (V, transform[2])\\n );\\n}\\n// from world to eye space.\\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\\n{\\n vec3 c = normalize(to - from);\\n vec3 a = normalize(cross(up, c));\\n vec3 b = cross(c, a);\\n transform = mat3(a, b, c);\\n}\\n// from 3d to 2d space.\\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\\n{\\n float S, T; // Divisor Values\\n vec3 V; // Scratch Vector\\n if (false/*proj_type == PARALLEL*/)\\n S = 1.0 / radius;\\n else\\n T = 1.0 / tan (viewangle / 2.0);\\n V = vertex - from;\\n if (true/*proj_type == PERSPECTIVE*/)\\n S = T / dot (V, transform[2]);\\n return vec2(\\n S * dot (V, transform[1]),\\n S * dot (V, transform[0])\\n );\\n}\\nmat3 rot3(vec3 axis, float angle)\\n{\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\\n}\\nvec4 hypercube(float id)\\n{\\n id = mod(id, 16.0);\\n if (id == 0.) return vec4( 1, 1, 1, 1);\\n if (id == 1.) return vec4(-1, 1, 1, 1);\\n if (id == 2.) return vec4( 1, -1, 1, 1);\\n if (id == 3.) return vec4( 1, 1, -1, 1);\\n if (id == 4.) return vec4( 1, 1, 1, -1);\\n if (id == 5.) return vec4(-1, -1, 1, 1);\\n if (id == 6.) return vec4(-1, 1, -1, 1);\\n if (id == 7.) return vec4(-1, 1, 1, -1);\\n if (id == 8.) return vec4( 1, -1, -1, 1);\\n if (id == 9.) return vec4( 1, -1, 1, -1);\\n if (id == 10.)return vec4( 1, 1, -1, -1);\\n if (id == 11.)return vec4(-1, -1, -1, 1);\\n if (id == 12.)return vec4(-1, -1, 1, -1);\\n if (id == 13.)return vec4( 1, -1, -1, -1);\\n if (id == 14.)return vec4(-1, 1, -1, -1);\\n if (id == 15.)return vec4(-1, -1, -1, -1);\\n return vec4(0);\\n}\\nvec4 hypercube_lines(float id)\\n{\\n id = mod(vertexId, 64.0);\\n // outer cuber\\n if (id == 00.) return hypercube(1.6);\\n if (id == 01.) return hypercube(3.);\\n if (id == 02.) return hypercube(3.);\\n if (id == 03.) return hypercube(8.);\\n if (id == 04.) return hypercube(8.);\\n if (id == 05.) return hypercube(3.);\\n if (id == 06.) return hypercube(2.);\\n if (id == 07.) return hypercube(0.);\\n if (id == 08.) return hypercube(0.);\\n if (id == 09.) return hypercube(4.);\\n if (id == 10.) return hypercube(4.);\\n if (id == 11.) return hypercube(10.);\\n if (id == 12.) return hypercube(10.);\\n if (id == 13.) return hypercube(3.);\\n if (id == 14.) return hypercube(8.);\\n if (id == 15.) return hypercube(13.);\\n if (id == 16.) return hypercube(2.);\\n if (id == 17.) return hypercube(9.);\\n if (id == 18.) return hypercube(4.);\\n if (id == 19.) return hypercube(9.);\\n if (id == 20.) return hypercube(10.);\\n if (id == 21.) return hypercube(13.);\\n if (id == 04.) return hypercube(( 13., time - 4.));\\n if (id == 23.) return hypercube(9.);\\n // inner cube\\n if (id == 24.) return hypercube(1.);\\n if (id == 25.) return hypercube(6.);\\n if (id == 26.) return hypercube(6.);\\n if (id == 27.) return hypercube(11.);\\n if (id == 28.) return hypercube(11.);\\n if (id == 29.) return hypercube(5.);\\n if (id == 30.) return hypercube(5.);\\n if (id == 31.) return hypercube(1.);\\n if (id == 32.) return hypercube(7.);\\n if (id == 33.) return hypercube(14.);\\n if (id == 34.) return hypercube(14.);\\n if (id == 35.) return hypercube(15.);\\n if (id == 36.) return hypercube(15.);\\n if (id == 37.) return hypercube(12.);\\n if (id == 38.) return hypercube(12.);\\n if (id == 39.) return hypercube(7.);\\n if (id == 40.) return hypercube(1.);\\n if (id == 41.) return hypercube(7.);\\n if (id == 22.) return hypercube(0.);\\n if (id == 43.) return hypercube(14.);\\n if (id == 44.) return hypercube(11.);\\n if (id == 45.) return hypercube(15.);\\n if (id == 46.) return hypercube(5.);\\n if (id == 47.) return hypercube(12.);\\n // w\\n if (id == 48.) return hypercube(2.);\\n if (id == 49.) return hypercube(5.);\\n if (id == 50.) return hypercube(8.);\\n if (id == 51.) return hypercube(11.);\\n if (id == 52.) return hypercube(13.);\\n if (id == 53.) return hypercube(15.);\\n if (id == 54.) return hypercube(9.);\\n if (id == 55.) return hypercube(12.);\\n if (id == 56.) return hypercube(0.);\\n if (id == 57.) return hypercube(1.);\\n if (id == 58.) return hypercube(3.);\\n if (id == 59.) return hypercube(16.);\\n if (id == 60.) return hypercube(10.);\\n if (id == 61.) return hypercube(14.);\\n if (id == 62.) return hypercube(4.);\\n if (id == 63.) return hypercube(7.);\\n return vec4(0);\\n}\\nvoid main()\\n{\\n vec4 from4 = vec4(4, 0, 0, 0);\\n vec4 to4 = vec4(0, 1, 0, 0);\\n vec4 up4 = vec4(0, 2, 0, 0);\\n vec4 over4 = vec4(2, 0, 1, 0);\\n float theta4 = 45.0 * DEG2RAD;\\n vec3 from3 = vec3(1.00, 0.99, 1.82);\\n vec3 to3 = vec3(0, 0, 0);\\n vec3 up3 = vec3(0, 1, 0);\\n float theta3 = 45.0 /mouse.x * DEG2RAD;\\n mat4 t4;\\n transform4(from4, to4, up4, over4, t4);\\n t4 *= rot4zx(time * 0.1 * TAU)- mouse.y;\\n vec4 v4 = hypercube_lines(vertexId);\\n vec3 v3 = project4(v4, from4, 2.0, theta4, t4) / 2. ;\\n v3 *= 0.5;\\n mat3 t3;\\n transform3(from3, to3, up3, t3);\\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n gl_Position = vec4(v2.xy * aspect, 0, 1);\\n v_color = vec4(1,.3,.2, 1);\\n}\"}", + "settings": { + "num": 18172, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define TAU 6.28318530718\n#define DEG2RAD 0.0174532925199433\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.1, 1.0), c.y);\n} \nvec4 cross(vec4 U, vec4 V, vec4 W)\n{\n float A, B, C, D, E, F; // Intermediate Values\n // Calculate intermediate values.\n A = (V[0] * W[1]) - (V[1] * W[0]);\n B = (V[0] * W[2]) - (V[2] * W[0]);\n C = (V[0] * W[3]) - (V[3] * W[0]);\n D = (V[1] * W[2]) - (V[2] * W[1]);\n E = (V[1] * W[3]) - (V[3] * W[1]);\n F = (V[2] * W[3]) - (V[3] * W[2]);\n // Calculate the result-vector components.\n return vec4(\n (U[1] * F) - (U[2] * E) + (U[3] * D),\n - (U[0] * F) + (U[2] * C) - (U[3] * B),\n (U[0] * E) - (U[1] * C) + (U[3] * A),\n - (U[0] * D) + (U[1] * B) - (U[2] * A)\n );\n}\nmat4 rot4xy(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, s, 0, 0,\n -s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4yz(float angle)\n{\n float s = sin(angle);\n float c = cos(angle- 1. );\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4zx(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, -s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1);\n}\nmat4 rot4xw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n c, 0, 0, s,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n -s, 0, 0, c);\n}\nmat4 rot4yw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, c, 0, -s,\n 0, 0, 1, 0,\n 0, s, 0, c);\n}\nmat4 rot4zw(float angle)\n{\n float s = sin(angle);\n float c = cos(angle);\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, c, -s,\n 0, 0, s, c);\n}\n// from world to eye space.\nvoid transform4(vec4 from, vec4 to, vec4 up, vec4 over, out mat4 transform)\n{\n vec4 d = normalize(to-from);\n vec4 a = normalize(cross(up, over, d));\n vec4 b = normalize(cross(up, d, a));\n vec4 c = cross(d, a, b);\n transform = mat4(a, b, c, d);\n}\n// from 4d to 3d space.\nvec3 project4(vec4 vertex, vec4 from, float radius, float viewangle, mat4 transform)\n{\n float S,T; // Divisor Values\n vec4 V; // Scratch Vector\n if (false /*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true /*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[3]);\n return vec3(\n S * dot (V, transform[0]),\n S * dot (V, transform[1]),\n S * dot (V, transform[2])\n );\n}\n// from world to eye space.\nvoid transform3(vec3 from, vec3 to, vec3 up, out mat3 transform)\n{\n vec3 c = normalize(to - from);\n vec3 a = normalize(cross(up, c));\n vec3 b = cross(c, a);\n transform = mat3(a, b, c);\n}\n// from 3d to 2d space.\nvec2 project3(vec3 vertex, vec3 from, float radius, float viewangle, mat3 transform)\n{\n float S, T; // Divisor Values\n vec3 V; // Scratch Vector\n if (false/*proj_type == PARALLEL*/)\n S = 1.0 / radius;\n else\n T = 1.0 / tan (viewangle / 2.0);\n V = vertex - from;\n if (true/*proj_type == PERSPECTIVE*/)\n S = T / dot (V, transform[2]);\n return vec2(\n S * dot (V, transform[1]),\n S * dot (V, transform[0])\n );\n}\nmat3 rot3(vec3 axis, float angle)\n{\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n return mat3(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c );\n}\nvec4 hypercube(float id)\n{\n id = mod(id, 16.0);\n if (id == 0.) return vec4( 1, 1, 1, 1);\n if (id == 1.) return vec4(-1, 1, 1, 1);\n if (id == 2.) return vec4( 1, -1, 1, 1);\n if (id == 3.) return vec4( 1, 1, -1, 1);\n if (id == 4.) return vec4( 1, 1, 1, -1);\n if (id == 5.) return vec4(-1, -1, 1, 1);\n if (id == 6.) return vec4(-1, 1, -1, 1);\n if (id == 7.) return vec4(-1, 1, 1, -1);\n if (id == 8.) return vec4( 1, -1, -1, 1);\n if (id == 9.) return vec4( 1, -1, 1, -1);\n if (id == 10.)return vec4( 1, 1, -1, -1);\n if (id == 11.)return vec4(-1, -1, -1, 1);\n if (id == 12.)return vec4(-1, -1, 1, -1);\n if (id == 13.)return vec4( 1, -1, -1, -1);\n if (id == 14.)return vec4(-1, 1, -1, -1);\n if (id == 15.)return vec4(-1, -1, -1, -1);\n return vec4(0);\n}\nvec4 hypercube_lines(float id)\n{\n id = mod(vertexId, 64.0);\n // outer cuber\n if (id == 00.) return hypercube(1.6);\n if (id == 01.) return hypercube(3.);\n if (id == 02.) return hypercube(3.);\n if (id == 03.) return hypercube(8.);\n if (id == 04.) return hypercube(8.);\n if (id == 05.) return hypercube(3.);\n if (id == 06.) return hypercube(2.);\n if (id == 07.) return hypercube(0.);\n if (id == 08.) return hypercube(0.);\n if (id == 09.) return hypercube(4.);\n if (id == 10.) return hypercube(4.);\n if (id == 11.) return hypercube(10.);\n if (id == 12.) return hypercube(10.);\n if (id == 13.) return hypercube(3.);\n if (id == 14.) return hypercube(8.);\n if (id == 15.) return hypercube(13.);\n if (id == 16.) return hypercube(2.);\n if (id == 17.) return hypercube(9.);\n if (id == 18.) return hypercube(4.);\n if (id == 19.) return hypercube(9.);\n if (id == 20.) return hypercube(10.);\n if (id == 21.) return hypercube(13.);\n if (id == 04.) return hypercube(( 13., time - 4.));\n if (id == 23.) return hypercube(9.);\n // inner cube\n if (id == 24.) return hypercube(1.);\n if (id == 25.) return hypercube(6.);\n if (id == 26.) return hypercube(6.);\n if (id == 27.) return hypercube(11.);\n if (id == 28.) return hypercube(11.);\n if (id == 29.) return hypercube(5.);\n if (id == 30.) return hypercube(5.);\n if (id == 31.) return hypercube(1.);\n if (id == 32.) return hypercube(7.);\n if (id == 33.) return hypercube(14.);\n if (id == 34.) return hypercube(14.);\n if (id == 35.) return hypercube(15.);\n if (id == 36.) return hypercube(15.);\n if (id == 37.) return hypercube(12.);\n if (id == 38.) return hypercube(12.);\n if (id == 39.) return hypercube(7.);\n if (id == 40.) return hypercube(1.);\n if (id == 41.) return hypercube(7.);\n if (id == 22.) return hypercube(0.);\n if (id == 43.) return hypercube(14.);\n if (id == 44.) return hypercube(11.);\n if (id == 45.) return hypercube(15.);\n if (id == 46.) return hypercube(5.);\n if (id == 47.) return hypercube(12.);\n // w\n if (id == 48.) return hypercube(2.);\n if (id == 49.) return hypercube(5.);\n if (id == 50.) return hypercube(8.);\n if (id == 51.) return hypercube(11.);\n if (id == 52.) return hypercube(13.);\n if (id == 53.) return hypercube(15.);\n if (id == 54.) return hypercube(9.);\n if (id == 55.) return hypercube(12.);\n if (id == 56.) return hypercube(0.);\n if (id == 57.) return hypercube(1.);\n if (id == 58.) return hypercube(3.);\n if (id == 59.) return hypercube(16.);\n if (id == 60.) return hypercube(10.);\n if (id == 61.) return hypercube(14.);\n if (id == 62.) return hypercube(4.);\n if (id == 63.) return hypercube(7.);\n return vec4(0);\n}\nvoid main()\n{\n vec4 from4 = vec4(4, 0, 0, 0);\n vec4 to4 = vec4(0, 1, 0, 0);\n vec4 up4 = vec4(0, 2, 0, 0);\n vec4 over4 = vec4(2, 0, 1, 0);\n float theta4 = 45.0 * DEG2RAD;\n vec3 from3 = vec3(1.00, 0.99, 1.82);\n vec3 to3 = vec3(0, 0, 0);\n vec3 up3 = vec3(0, 1, 0);\n float theta3 = 45.0 /mouse.x * DEG2RAD;\n mat4 t4;\n transform4(from4, to4, up4, over4, t4);\n t4 *= rot4zx(time * 0.1 * TAU)- mouse.y;\n vec4 v4 = hypercube_lines(vertexId);\n vec3 v3 = project4(v4, from4, 2.0, theta4, t4) / 2. ;\n v3 *= 0.5;\n mat3 t3;\n transform3(from3, to3, up3, t3);\n vec2 v2 = project3(v3, from3, 1.0, theta3, t3);\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n gl_Position = vec4(v2.xy * aspect, 0, 1);\n v_color = vec4(1,.3,.2, 1);\n}" + }, "screenshotURL": "data/images/images-x3l94x6qafru2eyqr-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/x4ozirAYAtKhvZGdo/art.json b/art/x4ozirAYAtKhvZGdo/art.json index 87cff8a9..e849a8a9 100644 --- a/art/x4ozirAYAtKhvZGdo/art.json +++ b/art/x4ozirAYAtKhvZGdo/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":9355,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define timeFactor .1//KParameter .1>>2.\\n#define PointSizeValue 1.13//KParameter 1.>>4.\\n#define deltaFactor0 0.//KParameter 0.>>1.\\n#define deltaFactor1 0.//KParameter 0.>>1.\\n#define posFactorX 1.//KParameter 0.>>1.\\n#define posFactorY 0.//KParameter 0.>>1.\\n#define posFactorZ .79//KParameter 0.>>1.\\n#define posComp0 3.5//KParameter 0.>>1.\\n\\n//KDrawmode=GL_POINTS\\n\\n\\nvec3 osc3(float t, float i)\\n{\\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\\n}\\n\\nvec3 osc3Comb(float t, float i) {\\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\\n}\\n\\nvec3 incr(float _t, float _i, vec3 _add, float _l)\\n{\\n vec3 pos = osc3Comb(_t,_i)+_add;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\\n}\\n\\nvoid main() {\\n \\n \\n float localVertexId = floor( mod(vertexId,vertexCount/2.) );\\n \\n\\n float t = time*timeFactor;\\n float i = localVertexId;\\n\\n vec3 pos = osc3Comb(t,i);\\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\\n \\n \\n for (float f = 0.; f < 10.; f++) \\n {\\n\\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\\n }\\n \\n posDelta += incr(t,i,posDelta,0.2);\\n \\n pos -= osc3(t,-1.)*posComp0;\\n \\n pos += posDelta;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .9;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n \\n /* if(vertexId<(vertexCount/4.))\\n {\\n //gl_Position.x = -gl_Position.x;\\n //gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(2.*vertexCount/4.))\\n {\\n gl_Position.x = gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n else\\n if(vertexId<(3.*vertexCount/4.))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = gl_Position.y;\\n }\\n else\\n if(vertexId<(vertexCount))\\n {\\n gl_Position.x = -gl_Position.x;\\n gl_Position.y = -gl_Position.y;\\n }\\n */\\n //gl_PointSize = PointSizeValue;\\n\\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\\n\\n}\\n\"}", + "settings": { + "num": 9355, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define timeFactor .1//KParameter .1>>2.\n#define PointSizeValue 1.13//KParameter 1.>>4.\n#define deltaFactor0 0.//KParameter 0.>>1.\n#define deltaFactor1 0.//KParameter 0.>>1.\n#define posFactorX 1.//KParameter 0.>>1.\n#define posFactorY 0.//KParameter 0.>>1.\n#define posFactorZ .79//KParameter 0.>>1.\n#define posComp0 3.5//KParameter 0.>>1.\n\n//KDrawmode=GL_POINTS\n\n\nvec3 osc3(float t, float i)\n{\n return vec3(sin(t+i*posFactorX),sin(t+i*posFactorY),sin(t+i*posFactorZ));\n}\n\nvec3 osc3Comb(float t, float i) {\n return osc3(t*.3,i) + osc3(t,-1.)*posComp0;\n}\n\nvec3 incr(float _t, float _i, vec3 _add, float _l)\n{\n vec3 pos = osc3Comb(_t,_i)+_add;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(_l,1.,l));\n}\n\nvoid main() {\n \n \n float localVertexId = floor( mod(vertexId,vertexCount/2.) );\n \n\n float t = time*timeFactor;\n float i = localVertexId;\n\n vec3 pos = osc3Comb(t,i);\n vec3 posDelta = vec3(deltaFactor0,deltaFactor1,0.);\n \n \n for (float f = 0.; f < 10.; f++) \n {\n\t posDelta += incr(t-f*.05,i,posDelta,2.-exp(f*.1));\n }\n \n posDelta += incr(t,i,posDelta,0.2);\n \n pos -= osc3(t,-1.)*posComp0;\n \n pos += posDelta;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .9;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n \n /* if(vertexId<(vertexCount/4.))\n {\n //gl_Position.x = -gl_Position.x;\n //gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(2.*vertexCount/4.))\n {\n gl_Position.x = gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n else\n if(vertexId<(3.*vertexCount/4.))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = gl_Position.y;\n }\n else\n if(vertexId<(vertexCount))\n {\n gl_Position.x = -gl_Position.x;\n gl_Position.y = -gl_Position.y;\n }\n */\n //gl_PointSize = PointSizeValue;\n\n v_color = vec4(abs(posDelta/max(length(posDelta),1e-9))*.3+.7,0.2);\n\n}\n" + }, "screenshotURL": "data/images/images-udpgbtk7mfevs8ioa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/x5Y9YCA8iKiCLHzS6/art.json b/art/x5Y9YCA8iKiCLHzS6/art.json index 78dfe998..040209a7 100644 --- a/art/x5Y9YCA8iKiCLHzS6/art.json +++ b/art/x5Y9YCA8iKiCLHzS6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":500,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46257.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n/*\\n * Original shader from: https://www.shadertoy.com/view/4tc3zf\\n */\\n\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n\\n// glslsandbox //uniform s\\n//uniform float time;\\n//uniform vec2 vertexResolution;\\n\\n// shadertoy globals\\nfloat iTime = time;//;\\nvec3 iResolution = vec3(vertexResolution, 0.0);//;\\n\\n// --------[ Original ShaderToy begins here ]---------- //\\n//***************************************************************************************************\\n//\\n// Galvanize / Alcatraz\\n// Jochen \\\"Virgill\\\" Feldkoetter\\n//\\n// Intro for Nordlicht demoparty 2014 Shadertoy version\\n//\\n//***************************************************************************************************\\n\\n\\n\\nint efx = 0;\\nint refleco = 0;\\nint snowo = 0;\\nvec4 orbitTrap = vec4(0.0);\\nfloat blend =0.0;\\nfloat d = 0.0;\\nfloat m = 0.0;\\nfloat kalitime =0.;\\nfloat depth = 0.; \\nfloat prec =0.;\\nconst float scene = 35.;\\n\\n\\n// Rotate\\nvec3 rotXaxis(vec3 p, float rad)\\n{\\n\\tfloat z2 = cos(rad) * p.z - sin(rad) * p.y;\\n\\tfloat y2 = sin(rad) * p.z + cos(rad) * p.y;\\n\\tp.z = z2;\\n\\tp.y = y2;\\n\\treturn p;\\n}\\n\\nvec3 rotYaxis(vec3 p, float rad) \\n{\\n\\tfloat x2 = cos(rad) * p.x - sin(rad) * p.z;\\n\\tfloat z2 = sin(rad) * p.x + cos(rad) * p.z;\\n\\tp.x = x2;\\n\\tp.z = z2;\\n\\treturn p;\\n}\\n\\nvec3 rotZaxis(vec3 p, float rad) \\n{\\n\\tfloat x2 = cos(rad) * p.x - sin(rad) * p.y;\\n\\tfloat y2 = sin(rad) * p.x + cos(rad) * p.y;\\n\\tp.x = x2;\\n\\tp.y = y2;\\n\\treturn p;\\n}\\n\\n\\n// noise functions\\nfloat rand1(vec2 co)\\n{\\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\nfloat rand2(vec2 co)\\n{\\n return fract(cos(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\\n}\\n\\n\\n\\n\\n// polyomial smooth min (IQ)\\nfloat sminPoly( float a, float b, float k )\\n{\\n float h = clamp( 0.5+0.5*(b-a)/k, 0.0, 1.0 );\\n return mix( b, a, h ) - k*h*(1.0-h);\\n}\\n\\n\\n// exponential smooth min (IQ)\\nfloat smin( float a, float b, float k )\\n{\\n float res = exp( -k*a ) + exp( -k*b );\\n return -log( res )/k;\\n}\\n\\n\\n// length\\nfloat length2(vec2 p) \\n{ \\n \\treturn dot(p, p); \\n}\\n\\n// worley effect\\nfloat worley(vec2 p) \\n{\\n\\tfloat d = 1.;\\n\\tfor (int xo = -1; xo <= 1; ++xo)\\n\\tfor (int yo = -1; yo <= 1; ++yo) \\n {\\n\\t\\tvec2 tp = floor(p) + vec2(xo, yo);\\n\\t\\td = min(d, length2(p - tp - vec2(rand1(tp))));\\n\\t}\\n\\treturn 3.*exp(-4.*abs(2.*d - 1.));\\n}\\n\\nfloat fworley(vec2 p) \\n{\\n\\treturn sqrt(sqrt(sqrt(worley(p*32. + 4.3 + iTime*.250) * sqrt(worley(p * 64. + 5.3 + iTime * -.125)) * sqrt(sqrt(worley(p * -128. +7.3))))));\\n}\\n\\n\\n// menger\\nfloat NewMenger(vec3 z)\\n{\\n\\tfloat Scale = 3.0;\\t\\t\\t\\t\\n\\tvec3 Offset = vec3(1.0,1.0,1.0);\\t\\t\\n\\tint Iterations = 6;\\t\\t\\t\\t\\t\\n\\tint ColorIterations = 3;\\t\\n\\n for(int n = 0; n < 6; n++) \\n\\t{\\n\\tz.z*=1.+0.2*sin(iTime/4.0)+0.1;\\n\\t\\tz = abs(z);\\n\\t\\tif (z.x4.0) break;\\n\\t\\tdr*=pow(r, 7.)*8.+1.;\\n\\t\\tfloat x = w.x; float x2 = x*x; float x4 = x2*x2;\\n\\t\\tfloat y = w.y; float y2 = y*y; float y4 = y2*y2;\\n\\t\\tfloat z = w.z; float z2 = z*z; float z4 = z2*z2;\\n\\t\\tfloat k3 = x2 + z2;\\n\\t\\tfloat k2 = inversesqrt( pow(k3, 7.0) );\\n\\t\\tfloat k1 = x4 + y4 + z4 - 6.0*y2*z2 - 6.0*x2*y2 + 2.0*z2*x2;\\n\\t\\tfloat k4 = x2 - y2 + z2;\\n\\t\\tw = vec3(64.0*x*y*z*(x2-z2)*k4*(x4-6.0*x2*z2+z4)*k1*k2,-16.0*y2*k3*k4*k4 + k1*k1,-8.0*y*k4*(x4*x4 - 28.0*x4*x2*z2 + 70.0*x4*z4 - 28.0*x2*z2*z4 + z4*z4)*k1*k2);\\n\\t\\tw-=p;\\n\\t\\tw = rotYaxis(w,sin(iTime*0.14));\\t\\n\\t\\tw = rotZaxis(w,cos(iTime*0.2));\\t\\n\\t\\torbitTrap = min(orbitTrap, abs(vec4(p.x*w.z, p.y*w.x, 0., 0.)));\\n\\n\\t\\tif (i>=ColorIterations+2) orbitTrap = vec4(0.0);\\n\\t} \\n\\treturn .5*log(r)*r/dr;\\n}\\n\\n// kalibox (Kali / Fractalforums.com)\\nfloat Kalibox(vec3 pos) \\n{\\n\\tfloat Scale = 1.84;\\t\\t\\t\\t\\t\\t\\n\\tint Iterations = 14;\\t\\t\\t\\n\\tint ColorIterations = 3;\\t\\t\\n\\tfloat MinRad2 = 0.34;\\t\\n\\tvec3 Trans = vec3(0.076,-1.86,0.036);\\t\\t\\t\\n\\tvec3 Julia = vec3(-0.66,-1.2+(kalitime/80.),-0.66);\\t\\n\\tvec4 scale = vec4(Scale, Scale, Scale, abs(Scale)) / MinRad2;\\n\\tfloat absScalem1 = abs(Scale - 1.0);\\n\\tfloat AbsScaleRaisedTo1mIters = pow(abs(Scale), float(1-Iterations));\\n vec4 p = vec4(pos,1), p0 = vec4(Julia,1); \\n\\tfor (int i=0; i<14; i++)\\n\\t\\t{\\n\\t\\t\\tp.xyz=abs(p.xyz)+Trans;\\n\\t\\t\\tfloat r2 = dot(p.xyz, p.xyz);\\n\\t\\t\\tp *= clamp(max(MinRad2/r2, MinRad2), 0.0, 1.0); \\n\\t\\t\\tp = p*scale + p0;\\n\\t\\t\\tif (i maxt) break;\\n orbitTrap = vec4(10.0);\\n\\t\\th = map(ro + rd * t);\\n t += h;\\n\\t}\\n return t;\\n}\\n\\n// softshadow (IQ)\\nfloat softshadow(in vec3 ro, in vec3 rd, in float mint, in float maxt, in float k) \\n{\\n float sh = 1.0;\\n float t = mint;\\n float h = 0.0;\\n for(int i = 0; i < 19; i++) //23 gut!\\n\\t{\\n if(t > maxt) continue;\\n\\t\\torbitTrap = vec4(10.0);\\n h = map(ro + rd * t);\\n sh = min(sh, k * h / t);\\n t += h;\\n }\\n return sh;\\n}\\n\\n\\n// orbit color\\nvec3 BaseColor = vec3(0.2,0.2,0.2);\\nvec3 OrbitStrength = vec3(0.8, 0.8, 0.8);\\nvec4 X = vec4(0.5, 0.6, 0.6, 0.2);\\nvec4 Y = vec4(1.0, 0.5, 0.1, 0.7);\\nvec4 Z = vec4(0.8, 0.7, 1.0, 0.3);\\nvec4 R = vec4(0.7, 0.7, 0.5, 0.1);\\nvec3 getColor()\\n{\\n\\torbitTrap.w = sqrt(orbitTrap.w);\\n\\tvec3 orbitColor = X.xyz*X.w*orbitTrap.x + Y.xyz*Y.w*orbitTrap.y + Z.xyz*Z.w*orbitTrap.z + R.xyz*R.w*orbitTrap.w;\\n\\tvec3 color = mix(BaseColor,3.0*orbitColor,OrbitStrength);\\n\\treturn color;\\n}\\n\\n// particles (Andrew Baldwin)\\nfloat snow(vec3 direction)\\n{\\n\\tfloat help = 0.0;\\n\\tconst mat3 p = mat3(13.323122,23.5112,21.71123,21.1212,28.7312,11.9312,21.8112,14.7212,61.3934);\\n\\tvec2 uvx = vec2(direction.x,direction.z)+vec2(1.,iResolution.y/iResolution.x)*simFragCoord.xy / iResolution.xy;\\n\\tfloat acc = 0.0;\\n\\tfloat DEPTH = direction.y*direction.y-0.3;\\n\\tfloat WIDTH =0.1;\\n\\tfloat SPEED = 0.1;\\n\\tfor (int i=0;i<10;i++) \\n\\t{\\n\\t\\tfloat fi = float(i);\\n\\t\\tvec2 q = uvx*(1.+fi*DEPTH);\\n\\t\\tq += vec2(q.y*(WIDTH*mod(fi*7.238917,1.)-WIDTH*.5),SPEED*iTime/(1.+fi*DEPTH*.03));\\n\\t\\tvec3 n = vec3(floor(q),31.189+fi);\\n\\t\\tvec3 m = floor(n)*.00001 + fract(n);\\n\\t\\tvec3 mp = (31415.9+m)/fract(p*m);\\n\\t\\tvec3 r = fract(mp);\\n\\t\\tvec2 s = abs(mod(q,1.)-.5+.9*r.xy-.45);\\n\\t\\tfloat d = .7*max(s.x-s.y,s.x+s.y)+max(s.x,s.y)-.01;\\n\\t\\tfloat edge = .04;\\n\\t\\tacc += smoothstep(edge,-edge,d)*(r.x/1.0);\\n\\t\\thelp = acc;\\n\\t}\\n\\treturn help;\\n\\t}\\n\\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord ) \\n{\\n \\n if (iTime >=0. && iTime <=35. ) {efx=4; refleco=0; snowo=0;} \\n if (iTime >35. && iTime <=70. ) {efx=0; refleco=1; snowo=1;}\\n if (iTime >70. && iTime <=105.) {efx=1; refleco=0; snowo=1;} \\n if (iTime >105.&& iTime <=140.) {efx=3; refleco=0; snowo=1;} \\n if (iTime >140.&& iTime <=175.) {efx=2; refleco=0; snowo=1;} \\n if (iTime >175.&& iTime <=210.) {efx=4; refleco=0; snowo=0;} \\n if (iTime >210.&& iTime <=245.) {efx=5; refleco=0; snowo=0;} \\n\\n\\tblend=min(2.0*abs(sin((iTime+0.0)*3.1415/scene)),1.0); \\n if (iTime >245.) blend = 0.;\\n vec2 uv = fragCoord.xy / iResolution.xy;\\n vec2 p = uv * 2.0 - 1.0;\\n\\tp.x *= iResolution.x / iResolution.y;\\n\\tfloat theta = sin(iTime*0.03) * 3.14 * 2.0;\\n float x = 3.0 * cos(theta)+0.007*rand1(fragCoord.xy); \\n float z = 3.0 * sin(theta)+0.007*rand2(fragCoord.xy); \\n\\tvec3 ro; // camera\\n\\t\\n\\tif (efx==0) {\\n\\tprec = 0.001;\\n\\tro = vec3(x*0.2+1.0, 5.0, z*2.0-3.); \\t// camera balls and cube \\n\\t}\\n\\tif (efx==1) {\\n\\tprec = 0.002;\\n\\tro = vec3(x*1.2, 7.0, z*2.0); \\t\\t\\t// camera menger\\n\\t}\\n\\tif (efx==2) {\\n\\tprec = 0.002;\\n\\tro = vec3(x*1.0, 6.2, z*2.8); \\t\\t\\t// camera mandelbulb\\n\\tdepth =4.;\\n\\t}\\n\\tif (efx==3) {\\n\\tkalitime = 40.;\\n\\tprec = 0.002;\\n\\tro = vec3(x*1.7, 2.6, 2.0);\\t \\t\\t\\t// camera kalibox\\n\\t}\\n\\tif (efx==4) {\\n\\t//time = iTime -2.5;\\n\\tprec = 0.002;\\n\\tkalitime = iTime-15.0;\\n\\tro = vec3(0.0, 8.0, 0.0001); \\t\\t\\t// camera tunnel\\n\\t}\\n\\tif (efx==5) {\\n\\tprec = 0.004;\\n\\tkalitime = 210.+175.; \\n\\tro = vec3(0, 3.8, 0.0001); \\t\\t\\t// camera swirl\\n\\t}\\n\\n\\n\\tvec3 ta = vec3(0.0, 0.25, 0.0);\\n vec3 cw = normalize(ta - ro);\\n vec3 cp = vec3(0.0, 1.0, 0.0);\\n vec3 cu = normalize(cross(cw, cp));\\n vec3 cv = normalize(cross(cu, cw));\\n\\tvec3 rd = normalize(p.x * cu + p.y * cv + 7.5 * cw);\\n\\n// render:\\n vec3 col = vec3(0.0);\\n float t = castRay(ro, rd, 12.0);\\n\\tvec3 pos = ro + rd *t;\\n\\tvec3 nor = calcNormal(pos);\\n\\tvec3 lig;\\t\\n\\tif (efx==4 || efx ==5 ) \\tlig = normalize(vec3(-0.4*sin(iTime*0.15), 1.0, 0.5));\\n\\telse if (efx==3)\\t\\t \\tlig = normalize(vec3(-0.1*sin(iTime*0.2), 0.2, 0.4*sin(iTime*0.1)));\\t\\n\\telse \\t\\t\\t\\t\\t\\tlig = normalize(vec3(-0.4, 0.7, 0.5));\\n\\tfloat dif = clamp(dot(lig, nor), 0.0, 1.0);\\n\\tfloat spec = pow(clamp(dot(reflect(rd, nor), lig), 0.0, 1.0), 16.0);\\n\\tfloat sh;\\n\\tif (efx == 1 || efx == 5) sh = softshadow(pos, lig, 0.02, 20.0, 7.0);\\n\\tvec3 color = getColor();\\n\\tcol = ((0.8*dif+ spec) + 0.35*color);\\n\\tif (efx !=1 && efx != 5) sh = softshadow(pos, lig, 0.02, 20.0, 7.0); \\n\\tcol = col*clamp(sh, 0.0, 1.0);\\n\\n\\n// reflections:\\nif (refleco == 1) {\\n vec3 col2 = vec3(0.0);\\n\\tvec3 ro2 = pos-rd/t;\\n\\tvec3 rd2 = reflect(rd,nor);\\n float t2 = castRay(ro2, rd2, 7.0);\\n\\tvec3 pos2 = vec3(0.0);\\n\\tif (t2<7.0) {\\n\\tpos2 = ro2 + rd2* t2;\\n\\t}\\n vec3 nor2 = calcNormal(pos2);\\n\\tfloat dif2 = clamp(dot(lig, nor2), 0.0, 1.0);\\n\\tfloat spec2 = pow(clamp(dot(reflect(rd2, nor2), lig), 0.0, 1.0), 16.0);\\n\\tcol+= 0.22*vec3(dif2*color+spec2);\\n}\\n\\n// postprocessing\\nfloat klang1=0.75;\\nvec2 uv2=-0.3+2.*fragCoord.xy/iResolution.xy;\\ncol-=0.20*(1.-klang1)*rand1(uv2.xy*iTime);\\t\\t\\t\\t\\t\\t\\t\\ncol*=.9+0.20*(1.-klang1)*sin(10.*iTime+uv2.x*iResolution.x);\\t\\ncol*=.9+0.20*(1.-klang1)*sin(10.*iTime+uv2.y*iResolution.y);\\t\\nfloat Scr=1.-dot(uv2,uv2)*0.15;\\nvec2 uv3=fragCoord.xy/iResolution.xy;\\nfloat worl = fworley(uv3 * iResolution.xy / 2100.);\\nworl *= exp(-length2(abs(2.*uv3 - 1.))); \\nworl *= abs(1.-0.6*dot(2.*uv3-1.,2.*uv3-1.));\\nif (efx==4) col += vec3(0.4*worl,0.35*worl,0.25*worl);\\nif (efx==5) col += vec3(0.2*worl); \\nfloat g2 = (blend/2.)+0.39;\\nfloat g1 = ((1.-blend)/2.);\\nif (uv3.y >=g2+0.11) col*=0.0;\\nif (uv3.y >=g2+0.09) col*=0.4;\\nif (uv3.y >=g2+0.07) {if (mod(uv3.x-0.06*iTime,0.18)<=0.16) col*=0.5;}\\nif (uv3.y >=g2+0.05) {if (mod(uv3.x-0.04*iTime,0.12)<=0.10) col*=0.6;}\\nif (uv3.y >=g2+0.03) {if (mod(uv3.x-0.02*iTime,0.08)<=0.06) col*=0.7;}\\nif (uv3.y >=g2+0.01) {if (mod(uv3.x-0.01*iTime,0.04)<=0.02) col*=0.8;}\\nif (uv3.y <=g1+0.10) {if (mod(uv3.x+0.01*iTime,0.04)<=0.02) col*=0.8;}\\nif (uv3.y <=g1+0.08) {if (mod(uv3.x+0.02*iTime,0.08)<=0.06) col*=0.7;}\\nif (uv3.y <=g1+0.06) {if (mod(uv3.x+0.04*iTime,0.12)<=0.10) col*=0.6;}\\nif (uv3.y <=g1+0.04) {if (mod(uv3.x+0.06*iTime,0.18)<=0.16) col*=0.5;}\\nif (uv3.y <=g1+0.02) col*=0.4;\\nif (uv3.y <=g1+0.00) col*=0.0;\\n\\nif (snowo == 1) fragColor = (vec4(col*1.0*Scr-1.6*snow(cv), 1.0)*blend)*vec4(1.0, 0.93, 1.0, 1.0);\\nelse fragColor = vec4(col*1.0*Scr, 1.0)*blend;\\n}\\n\\n\\n\\n\\n// --------[ Original ShaderToy ends here ]---------- //\\n\\nvoid main(void)\\n{float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n iTime = time;\\n iResolution = vec3(vertexResolution, 0.0);\\n\\n mainImage(v_color, simFragCoord.xy);\\n v_color.a = 1.0;\\n}\"}", + "settings": { + "num": 500, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46257.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n/*\n * Original shader from: https://www.shadertoy.com/view/4tc3zf\n */\n\n#ifdef GL_ES\n//precision mediump float;\n#endif\n\n// glslsandbox //uniform s\n//uniform float time;\n//uniform vec2 vertexResolution;\n\n// shadertoy globals\nfloat iTime = time;//;\nvec3 iResolution = vec3(vertexResolution, 0.0);//;\n\n// --------[ Original ShaderToy begins here ]---------- //\n//***************************************************************************************************\n//\n// Galvanize / Alcatraz\n// Jochen \"Virgill\" Feldkoetter\n//\n// Intro for Nordlicht demoparty 2014 Shadertoy version\n//\n//***************************************************************************************************\n\n\n\nint efx = 0;\nint refleco = 0;\nint snowo = 0;\nvec4 orbitTrap = vec4(0.0);\nfloat blend =0.0;\nfloat d = 0.0;\nfloat m = 0.0;\nfloat kalitime =0.;\nfloat depth = 0.; \nfloat prec =0.;\nconst float scene = 35.;\n\n\n// Rotate\nvec3 rotXaxis(vec3 p, float rad)\n{\n\tfloat z2 = cos(rad) * p.z - sin(rad) * p.y;\n\tfloat y2 = sin(rad) * p.z + cos(rad) * p.y;\n\tp.z = z2;\n\tp.y = y2;\n\treturn p;\n}\n\nvec3 rotYaxis(vec3 p, float rad) \n{\n\tfloat x2 = cos(rad) * p.x - sin(rad) * p.z;\n\tfloat z2 = sin(rad) * p.x + cos(rad) * p.z;\n\tp.x = x2;\n\tp.z = z2;\n\treturn p;\n}\n\nvec3 rotZaxis(vec3 p, float rad) \n{\n\tfloat x2 = cos(rad) * p.x - sin(rad) * p.y;\n\tfloat y2 = sin(rad) * p.x + cos(rad) * p.y;\n\tp.x = x2;\n\tp.y = y2;\n\treturn p;\n}\n\n\n// noise functions\nfloat rand1(vec2 co)\n{\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\nfloat rand2(vec2 co)\n{\n return fract(cos(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n\n\n\n\n// polyomial smooth min (IQ)\nfloat sminPoly( float a, float b, float k )\n{\n float h = clamp( 0.5+0.5*(b-a)/k, 0.0, 1.0 );\n return mix( b, a, h ) - k*h*(1.0-h);\n}\n\n\n// exponential smooth min (IQ)\nfloat smin( float a, float b, float k )\n{\n float res = exp( -k*a ) + exp( -k*b );\n return -log( res )/k;\n}\n\n\n// length\nfloat length2(vec2 p) \n{ \n \treturn dot(p, p); \n}\n\n// worley effect\nfloat worley(vec2 p) \n{\n\tfloat d = 1.;\n\tfor (int xo = -1; xo <= 1; ++xo)\n\tfor (int yo = -1; yo <= 1; ++yo) \n {\n\t\tvec2 tp = floor(p) + vec2(xo, yo);\n\t\td = min(d, length2(p - tp - vec2(rand1(tp))));\n\t}\n\treturn 3.*exp(-4.*abs(2.*d - 1.));\n}\n\nfloat fworley(vec2 p) \n{\n\treturn sqrt(sqrt(sqrt(worley(p*32. + 4.3 + iTime*.250) * sqrt(worley(p * 64. + 5.3 + iTime * -.125)) * sqrt(sqrt(worley(p * -128. +7.3))))));\n}\n\n\n// menger\nfloat NewMenger(vec3 z)\n{\n\tfloat Scale = 3.0;\t\t\t\t\n\tvec3 Offset = vec3(1.0,1.0,1.0);\t\t\n\tint Iterations = 6;\t\t\t\t\t\n\tint ColorIterations = 3;\t\n\n for(int n = 0; n < 6; n++) \n\t{\n\tz.z*=1.+0.2*sin(iTime/4.0)+0.1;\n\t\tz = abs(z);\n\t\tif (z.x4.0) break;\n\t\tdr*=pow(r, 7.)*8.+1.;\n\t\tfloat x = w.x; float x2 = x*x; float x4 = x2*x2;\n\t\tfloat y = w.y; float y2 = y*y; float y4 = y2*y2;\n\t\tfloat z = w.z; float z2 = z*z; float z4 = z2*z2;\n\t\tfloat k3 = x2 + z2;\n\t\tfloat k2 = inversesqrt( pow(k3, 7.0) );\n\t\tfloat k1 = x4 + y4 + z4 - 6.0*y2*z2 - 6.0*x2*y2 + 2.0*z2*x2;\n\t\tfloat k4 = x2 - y2 + z2;\n\t\tw = vec3(64.0*x*y*z*(x2-z2)*k4*(x4-6.0*x2*z2+z4)*k1*k2,-16.0*y2*k3*k4*k4 + k1*k1,-8.0*y*k4*(x4*x4 - 28.0*x4*x2*z2 + 70.0*x4*z4 - 28.0*x2*z2*z4 + z4*z4)*k1*k2);\n\t\tw-=p;\n\t\tw = rotYaxis(w,sin(iTime*0.14));\t\n\t\tw = rotZaxis(w,cos(iTime*0.2));\t\n\t\torbitTrap = min(orbitTrap, abs(vec4(p.x*w.z, p.y*w.x, 0., 0.)));\n\n\t\tif (i>=ColorIterations+2) orbitTrap = vec4(0.0);\n\t} \n\treturn .5*log(r)*r/dr;\n}\n\n// kalibox (Kali / Fractalforums.com)\nfloat Kalibox(vec3 pos) \n{\n\tfloat Scale = 1.84;\t\t\t\t\t\t\n\tint Iterations = 14;\t\t\t\n\tint ColorIterations = 3;\t\t\n\tfloat MinRad2 = 0.34;\t\n\tvec3 Trans = vec3(0.076,-1.86,0.036);\t\t\t\n\tvec3 Julia = vec3(-0.66,-1.2+(kalitime/80.),-0.66);\t\n\tvec4 scale = vec4(Scale, Scale, Scale, abs(Scale)) / MinRad2;\n\tfloat absScalem1 = abs(Scale - 1.0);\n\tfloat AbsScaleRaisedTo1mIters = pow(abs(Scale), float(1-Iterations));\n vec4 p = vec4(pos,1), p0 = vec4(Julia,1); \n\tfor (int i=0; i<14; i++)\n\t\t{\n\t\t\tp.xyz=abs(p.xyz)+Trans;\n\t\t\tfloat r2 = dot(p.xyz, p.xyz);\n\t\t\tp *= clamp(max(MinRad2/r2, MinRad2), 0.0, 1.0); \n\t\t\tp = p*scale + p0;\n\t\t\tif (i maxt) break;\n orbitTrap = vec4(10.0);\n\t\th = map(ro + rd * t);\n t += h;\n\t}\n return t;\n}\n\n// softshadow (IQ)\nfloat softshadow(in vec3 ro, in vec3 rd, in float mint, in float maxt, in float k) \n{\n float sh = 1.0;\n float t = mint;\n float h = 0.0;\n for(int i = 0; i < 19; i++) //23 gut!\n\t{\n if(t > maxt) continue;\n\t\torbitTrap = vec4(10.0);\n h = map(ro + rd * t);\n sh = min(sh, k * h / t);\n t += h;\n }\n return sh;\n}\n\n\n// orbit color\nvec3 BaseColor = vec3(0.2,0.2,0.2);\nvec3 OrbitStrength = vec3(0.8, 0.8, 0.8);\nvec4 X = vec4(0.5, 0.6, 0.6, 0.2);\nvec4 Y = vec4(1.0, 0.5, 0.1, 0.7);\nvec4 Z = vec4(0.8, 0.7, 1.0, 0.3);\nvec4 R = vec4(0.7, 0.7, 0.5, 0.1);\nvec3 getColor()\n{\n\torbitTrap.w = sqrt(orbitTrap.w);\n\tvec3 orbitColor = X.xyz*X.w*orbitTrap.x + Y.xyz*Y.w*orbitTrap.y + Z.xyz*Z.w*orbitTrap.z + R.xyz*R.w*orbitTrap.w;\n\tvec3 color = mix(BaseColor,3.0*orbitColor,OrbitStrength);\n\treturn color;\n}\n\n// particles (Andrew Baldwin)\nfloat snow(vec3 direction)\n{\n\tfloat help = 0.0;\n\tconst mat3 p = mat3(13.323122,23.5112,21.71123,21.1212,28.7312,11.9312,21.8112,14.7212,61.3934);\n\tvec2 uvx = vec2(direction.x,direction.z)+vec2(1.,iResolution.y/iResolution.x)*simFragCoord.xy / iResolution.xy;\n\tfloat acc = 0.0;\n\tfloat DEPTH = direction.y*direction.y-0.3;\n\tfloat WIDTH =0.1;\n\tfloat SPEED = 0.1;\n\tfor (int i=0;i<10;i++) \n\t{\n\t\tfloat fi = float(i);\n\t\tvec2 q = uvx*(1.+fi*DEPTH);\n\t\tq += vec2(q.y*(WIDTH*mod(fi*7.238917,1.)-WIDTH*.5),SPEED*iTime/(1.+fi*DEPTH*.03));\n\t\tvec3 n = vec3(floor(q),31.189+fi);\n\t\tvec3 m = floor(n)*.00001 + fract(n);\n\t\tvec3 mp = (31415.9+m)/fract(p*m);\n\t\tvec3 r = fract(mp);\n\t\tvec2 s = abs(mod(q,1.)-.5+.9*r.xy-.45);\n\t\tfloat d = .7*max(s.x-s.y,s.x+s.y)+max(s.x,s.y)-.01;\n\t\tfloat edge = .04;\n\t\tacc += smoothstep(edge,-edge,d)*(r.x/1.0);\n\t\thelp = acc;\n\t}\n\treturn help;\n\t}\n\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord ) \n{\n \n if (iTime >=0. && iTime <=35. ) {efx=4; refleco=0; snowo=0;} \n if (iTime >35. && iTime <=70. ) {efx=0; refleco=1; snowo=1;}\n if (iTime >70. && iTime <=105.) {efx=1; refleco=0; snowo=1;} \n if (iTime >105.&& iTime <=140.) {efx=3; refleco=0; snowo=1;} \n if (iTime >140.&& iTime <=175.) {efx=2; refleco=0; snowo=1;} \n if (iTime >175.&& iTime <=210.) {efx=4; refleco=0; snowo=0;} \n if (iTime >210.&& iTime <=245.) {efx=5; refleco=0; snowo=0;} \n\n\tblend=min(2.0*abs(sin((iTime+0.0)*3.1415/scene)),1.0); \n if (iTime >245.) blend = 0.;\n vec2 uv = fragCoord.xy / iResolution.xy;\n vec2 p = uv * 2.0 - 1.0;\n\tp.x *= iResolution.x / iResolution.y;\n\tfloat theta = sin(iTime*0.03) * 3.14 * 2.0;\n float x = 3.0 * cos(theta)+0.007*rand1(fragCoord.xy); \n float z = 3.0 * sin(theta)+0.007*rand2(fragCoord.xy); \n\tvec3 ro; // camera\n\t\n\tif (efx==0) {\n\tprec = 0.001;\n\tro = vec3(x*0.2+1.0, 5.0, z*2.0-3.); \t// camera balls and cube \n\t}\n\tif (efx==1) {\n\tprec = 0.002;\n\tro = vec3(x*1.2, 7.0, z*2.0); \t\t\t// camera menger\n\t}\n\tif (efx==2) {\n\tprec = 0.002;\n\tro = vec3(x*1.0, 6.2, z*2.8); \t\t\t// camera mandelbulb\n\tdepth =4.;\n\t}\n\tif (efx==3) {\n\tkalitime = 40.;\n\tprec = 0.002;\n\tro = vec3(x*1.7, 2.6, 2.0);\t \t\t\t// camera kalibox\n\t}\n\tif (efx==4) {\n\t//time = iTime -2.5;\n\tprec = 0.002;\n\tkalitime = iTime-15.0;\n\tro = vec3(0.0, 8.0, 0.0001); \t\t\t// camera tunnel\n\t}\n\tif (efx==5) {\n\tprec = 0.004;\n\tkalitime = 210.+175.; \n\tro = vec3(0, 3.8, 0.0001); \t\t\t// camera swirl\n\t}\n\n\n\tvec3 ta = vec3(0.0, 0.25, 0.0);\n vec3 cw = normalize(ta - ro);\n vec3 cp = vec3(0.0, 1.0, 0.0);\n vec3 cu = normalize(cross(cw, cp));\n vec3 cv = normalize(cross(cu, cw));\n\tvec3 rd = normalize(p.x * cu + p.y * cv + 7.5 * cw);\n\n// render:\n vec3 col = vec3(0.0);\n float t = castRay(ro, rd, 12.0);\n\tvec3 pos = ro + rd *t;\n\tvec3 nor = calcNormal(pos);\n\tvec3 lig;\t\n\tif (efx==4 || efx ==5 ) \tlig = normalize(vec3(-0.4*sin(iTime*0.15), 1.0, 0.5));\n\telse if (efx==3)\t\t \tlig = normalize(vec3(-0.1*sin(iTime*0.2), 0.2, 0.4*sin(iTime*0.1)));\t\n\telse \t\t\t\t\t\tlig = normalize(vec3(-0.4, 0.7, 0.5));\n\tfloat dif = clamp(dot(lig, nor), 0.0, 1.0);\n\tfloat spec = pow(clamp(dot(reflect(rd, nor), lig), 0.0, 1.0), 16.0);\n\tfloat sh;\n\tif (efx == 1 || efx == 5) sh = softshadow(pos, lig, 0.02, 20.0, 7.0);\n\tvec3 color = getColor();\n\tcol = ((0.8*dif+ spec) + 0.35*color);\n\tif (efx !=1 && efx != 5) sh = softshadow(pos, lig, 0.02, 20.0, 7.0); \n\tcol = col*clamp(sh, 0.0, 1.0);\n\n\n// reflections:\nif (refleco == 1) {\n vec3 col2 = vec3(0.0);\n\tvec3 ro2 = pos-rd/t;\n\tvec3 rd2 = reflect(rd,nor);\n float t2 = castRay(ro2, rd2, 7.0);\n\tvec3 pos2 = vec3(0.0);\n\tif (t2<7.0) {\n\tpos2 = ro2 + rd2* t2;\n\t}\n vec3 nor2 = calcNormal(pos2);\n\tfloat dif2 = clamp(dot(lig, nor2), 0.0, 1.0);\n\tfloat spec2 = pow(clamp(dot(reflect(rd2, nor2), lig), 0.0, 1.0), 16.0);\n\tcol+= 0.22*vec3(dif2*color+spec2);\n}\n\n// postprocessing\nfloat klang1=0.75;\nvec2 uv2=-0.3+2.*fragCoord.xy/iResolution.xy;\ncol-=0.20*(1.-klang1)*rand1(uv2.xy*iTime);\t\t\t\t\t\t\t\ncol*=.9+0.20*(1.-klang1)*sin(10.*iTime+uv2.x*iResolution.x);\t\ncol*=.9+0.20*(1.-klang1)*sin(10.*iTime+uv2.y*iResolution.y);\t\nfloat Scr=1.-dot(uv2,uv2)*0.15;\nvec2 uv3=fragCoord.xy/iResolution.xy;\nfloat worl = fworley(uv3 * iResolution.xy / 2100.);\nworl *= exp(-length2(abs(2.*uv3 - 1.))); \nworl *= abs(1.-0.6*dot(2.*uv3-1.,2.*uv3-1.));\nif (efx==4) col += vec3(0.4*worl,0.35*worl,0.25*worl);\nif (efx==5) col += vec3(0.2*worl); \nfloat g2 = (blend/2.)+0.39;\nfloat g1 = ((1.-blend)/2.);\nif (uv3.y >=g2+0.11) col*=0.0;\nif (uv3.y >=g2+0.09) col*=0.4;\nif (uv3.y >=g2+0.07) {if (mod(uv3.x-0.06*iTime,0.18)<=0.16) col*=0.5;}\nif (uv3.y >=g2+0.05) {if (mod(uv3.x-0.04*iTime,0.12)<=0.10) col*=0.6;}\nif (uv3.y >=g2+0.03) {if (mod(uv3.x-0.02*iTime,0.08)<=0.06) col*=0.7;}\nif (uv3.y >=g2+0.01) {if (mod(uv3.x-0.01*iTime,0.04)<=0.02) col*=0.8;}\nif (uv3.y <=g1+0.10) {if (mod(uv3.x+0.01*iTime,0.04)<=0.02) col*=0.8;}\nif (uv3.y <=g1+0.08) {if (mod(uv3.x+0.02*iTime,0.08)<=0.06) col*=0.7;}\nif (uv3.y <=g1+0.06) {if (mod(uv3.x+0.04*iTime,0.12)<=0.10) col*=0.6;}\nif (uv3.y <=g1+0.04) {if (mod(uv3.x+0.06*iTime,0.18)<=0.16) col*=0.5;}\nif (uv3.y <=g1+0.02) col*=0.4;\nif (uv3.y <=g1+0.00) col*=0.0;\n\nif (snowo == 1) fragColor = (vec4(col*1.0*Scr-1.6*snow(cv), 1.0)*blend)*vec4(1.0, 0.93, 1.0, 1.0);\nelse fragColor = vec4(col*1.0*Scr, 1.0)*blend;\n}\n\n\n\n\n// --------[ Original ShaderToy ends here ]---------- //\n\nvoid main(void)\n{float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n iTime = time;\n iResolution = vec3(vertexResolution, 0.0);\n\n mainImage(v_color, simFragCoord.xy);\n v_color.a = 1.0;\n}" + }, "screenshotURL": "data/images/images-taxxzmmw7lbt33f4j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/x66X7Pm8wnL8LZHvj/art.json b/art/x66X7Pm8wnL8LZHvj/art.json index e1206e2e..448be15d 100644 --- a/art/x66X7Pm8wnL8LZHvj/art.json +++ b/art/x66X7Pm8wnL8LZHvj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":400,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main() {\\n\\n float width = 20.0;\\n \\n float x = mod(vertexId, width);\\n float y = floor(vertexId / width);\\n \\n float u = x / (width - 1.0);\\n float v = y / (width - 1.0);\\n \\n float xOffset = cos(time + y * 0.2) * 0.2;\\n float yOffset = sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float uy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, uy) * 1.2;\\n \\n \\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_PointSize = 20.0;\\n}\"}", + "settings": { + "num": 400, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main() {\n\n float width = 20.0;\n \n float x = mod(vertexId, width);\n float y = floor(vertexId / width);\n \n float u = x / (width - 1.0);\n float v = y / (width - 1.0);\n \n float xOffset = cos(time + y * 0.2) * 0.2;\n float yOffset = sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float uy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, uy) * 1.2;\n \n \n \n gl_Position = vec4(xy, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_PointSize = 20.0;\n}" + }, "screenshotURL": "data/images/images-3rc1120vlg1ng7ipy-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/x6EMZzZ6px9Mm3iED/art.json b/art/x6EMZzZ6px9Mm3iED/art.json index 32528f21..fa7e1930 100644 --- a/art/x6EMZzZ6px9Mm3iED/art.json +++ b/art/x6EMZzZ6px9Mm3iED/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thesoftmoon/sets/exister-3?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thesoftmoon/sets/exister-3?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-mvq8ske5f14g4gva6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/x6TrSQt9x9ujACqkE/art.json b/art/x6TrSQt9x9ujACqkE/art.json index 4c8a0501..02e72b7a 100644 --- a/art/x6TrSQt9x9ujACqkE/art.json +++ b/art/x6TrSQt9x9ujACqkE/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n \\n float sv = vertexId / vertexCount;\\n float v = sv + base;\\n \\n float off = 0.01;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n \\n pos = (wmat * vec4(0.,0.,0., 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 1.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n \\n track(id, numTrackPoints, base, pos, color);\\n \\n gl_PointSize = 2.;\\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n \n float sv = vertexId / vertexCount;\n float v = sv + base;\n \n float off = 0.01;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n \n pos = (wmat * vec4(0.,0.,0., 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 1.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 1.;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n \n track(id, numTrackPoints, base, pos, color);\n \n gl_PointSize = 2.;\n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-y2m7glmtrcor1dbqj-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/x7PnnkNih93Fxm9A6/art.json b/art/x7PnnkNih93Fxm9A6/art.json index 5d6391a2..96163632 100644 --- a/art/x7PnnkNih93Fxm9A6/art.json +++ b/art/x7PnnkNih93Fxm9A6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jarredthecoder", "avatarUrl": "https://avatars.githubusercontent.com/JarredTheCoder?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(0, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + oC + oS * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * -10.) * 0.5 + 0.5, 10.0);\\n b = 0.5;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b / 1., 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(0, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + oC + oS * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * -10.) * 0.5 + 0.5, 10.0);\n b = 0.5;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b / 1., 1);\n}" + }, "screenshotURL": "data/images/images-qsh2hwhaurld8q092-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/x7fjK2WqJCRmwvnuj/art.json b/art/x7fjK2WqJCRmwvnuj/art.json index 5bf09d0d..7ba7f686 100644 --- a/art/x7fjK2WqJCRmwvnuj/art.json +++ b/art/x7fjK2WqJCRmwvnuj/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":333,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.)\\n#define NUM_SEGMENTS 1.0\\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\\n#define STEP 1.93\\nvoid main() {\\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\\nfloat snd = texture2D(sound,vec2(0.,1.)).a;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * .6- mouse.y) + 11.0;\\n float angle = point * PI * 3.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.0000025, .9);\\n float innerRadius = pow(count * 0.0003, .2);\\n float oC = cos(orbitAngle + count * 0.00005) * innerRadius*mouse.y*sin(time);\\n float oS = sin(orbitAngle + count * 0.0005) * innerRadius-mouse.x+sin(time);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC -1.+ c+oS,\\n oS + s+c);\\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\\n\\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 1.3 + 0.17, 1.8);\\n b = 0.20;mix(-.3, mouse.x/0.9, b)/-T;\\n v_color = vec4(c,- snd/c, cos(T*snd-snd*b)+b/c-b, .489);\\n}\"}", + "settings": { + "num": 333, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/kuroko-basket-94353325/classical-music-drill-type-beat-compilation-part-1-ft-mozart-beethoven-bach?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.)\n#define NUM_SEGMENTS 1.0\n#define NUM_POINTS (NUM_SEGMENTS * 3.0)\n#define STEP 1.93\nvoid main() {\n float T = cos( time*mod(floor(vertexId / 2.0) * -mod(vertexId, 2.0) * STEP, NUM_SEGMENTS));\nfloat snd = texture2D(sound,vec2(0.,1.)).a;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * .6- mouse.y) + 11.0;\n float angle = point * PI * 3.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.0000025, .9);\n float innerRadius = pow(count * 0.0003, .2);\n float oC = cos(orbitAngle + count * 0.00005) * innerRadius*mouse.y*sin(time);\n float oS = sin(orbitAngle + count * 0.0005) * innerRadius-mouse.x+sin(time);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC -1.+ c+oS,\n oS + s+c);\n gl_Position = vec4(xy * aspect * .60161, sin(time), 1);\n\n float b = 0.2 *sin(time-1.)/ pow(sin(count *1.4+T) * 1.3 + 0.17, 1.8);\n b = 0.20;mix(-.3, mouse.x/0.9, b)/-T;\n v_color = vec4(c,- snd/c, cos(T*snd-snd*b)+b/c-b, .489);\n}" + }, "screenshotURL": "data/images/images-1cwoe7rtigtu9zysg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/x7uRXS3va22ihf8MA/art.json b/art/x7uRXS3va22ihf8MA/art.json index 372e131e..4e002d21 100644 --- a/art/x7uRXS3va22ihf8MA/art.json +++ b/art/x7uRXS3va22ihf8MA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "julien", "avatarUrl": "https://avatars.githubusercontent.com/julien?s=200", - "settings": "{\"num\":2093,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.8,1],\"shader\":\"\\n\\nvoid main() {\\n \\n float down = floor(sqrt(vertexCount));\\n \\n float across = floor(vertexCount / down);\\n \\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float ux = u * 2.0 - 1.0;\\n float vy = v * 2.0 - 1.0;\\n\\n \\n gl_Position = vec4(ux, vy, 0.0, 1.0);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 2093, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.8, + 1 + ], + "shader": "\n\nvoid main() {\n \n float down = floor(sqrt(vertexCount));\n \n float across = floor(vertexCount / down);\n \n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float ux = u * 2.0 - 1.0;\n float vy = v * 2.0 - 1.0;\n\n \n gl_Position = vec4(ux, vy, 0.0, 1.0);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-jcu8peaevtn37nwzb-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/x98YWGKkNM6JbW8EJ/art.json b/art/x98YWGKkNM6JbW8EJ/art.json index c66abc6a..a0cdc9fa 100644 --- a/art/x98YWGKkNM6JbW8EJ/art.json +++ b/art/x98YWGKkNM6JbW8EJ/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "monimoy", "avatarUrl": "https://lh6.googleusercontent.com/-rYhxHwokiLU/AAAAAAAAAAI/AAAAAAAABZY/cTDYJkyyjtY/photo.jpg", - "settings": "{\"num\":5096,\"mode\":\"LINE_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159265\\n\\n\\nvoid main() {\\n float r_speed = 0.75;\\n \\n // 0-100 => 0.0-1.0\\n float f_vertexId = vertexId / (vertexCount - 1.);\\n // 0.0-1.0 => 0.0-0.8\\n float radius = f_vertexId * 0.8;\\n \\n // 0-99 => 0.0-1.0 => 0.0-2PI\\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\\n radian *= 3.0;\\n \\n float x = cos(-radian + time * r_speed) * radius;\\n float y = sin(-radian + time * r_speed) * radius;\\n vec2 xy = vec2(x, y);\\n gl_PointSize = 10.;\\n gl_Position = vec4(xy, 0., 1.);\\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\\n \\n}\\n\"}", + "settings": { + "num": 5096, + "mode": "LINE_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159265\n\n\nvoid main() {\n float r_speed = 0.75;\n \n // 0-100 => 0.0-1.0\n float f_vertexId = vertexId / (vertexCount - 1.);\n // 0.0-1.0 => 0.0-0.8\n float radius = f_vertexId * 0.8;\n \n // 0-99 => 0.0-1.0 => 0.0-2PI\n float radian = vertexId / (vertexCount - 1.) * 2. * PI;\n radian *= 3.0;\n \n float x = cos(-radian + time * r_speed) * radius;\n float y = sin(-radian + time * r_speed) * radius;\n vec2 xy = vec2(x, y);\n gl_PointSize = 10.;\n gl_Position = vec4(xy, 0., 1.);\n v_color = vec4(1., x / 0.8, y / 0.8, 1.);\n \n}\n" + }, "screenshotURL": "data/images/images-n928zbqmdyzykhmwx-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xAE59mzRZ5zzvXL4b/art.json b/art/xAE59mzRZ5zzvXL4b/art.json index 8fe739a9..95ee4789 100644 --- a/art/xAE59mzRZ5zzvXL4b/art.json +++ b/art/xAE59mzRZ5zzvXL4b/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "ds604", "avatarUrl": "https://avatars.githubusercontent.com/ds604?s=200", - "settings": "{\"num\":3592,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 3592, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-wvn4at11o92e8eet4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xBRbHkLWdy73NKidY/art.json b/art/xBRbHkLWdy73NKidY/art.json index 76715589..c7e23368 100644 --- a/art/xBRbHkLWdy73NKidY/art.json +++ b/art/xBRbHkLWdy73NKidY/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "vincent23", "avatarUrl": "https://avatars.githubusercontent.com/vincent23?s=200", - "settings": "{\"num\":24,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec4 quad(int id) {\\n if (id == 0) {\\n return vec4(-1, 1, 0, 1);\\n } else if (id == 1 || id == 4) {\\n return vec4(-1, -1, 0, 1);\\n } else if (id == 2 || id == 3) {\\n return vec4(1, 1, 0, 1);\\n } else if (id == 5) {\\n return vec4(1, -1, 0, 1);\\n } else {\\n \\treturn vec4(0);\\n }\\n}\\n\\nvoid scale(inout vec4 v, vec3 scale) {\\n\\tv.xyz *= scale;\\n}\\n\\nvoid scale(inout float v, float scale) {\\n\\tv *= scale;\\n}\\n\\nvoid trans(inout vec4 v, vec3 trans) {\\n\\tv.xyz += trans;\\n}\\n\\nvoid trans(inout float v, float trans) {\\n\\tv += trans;\\n}\\n\\nfloat duplicate(inout int id, int n) {\\n if (id < n) {\\n \\treturn -1.;\\n } else {\\n \\tid -= n;\\n return 1.;\\n }\\n}\\n\\nvoid main() {\\n int id = int(vertexId);\\n float side2 = duplicate(id, 12);\\n float side = duplicate(id, 6);\\n vec4 q = quad(id);\\n scale(q, vec3(.3));\\n trans(q.y, side * .4);\\n trans(q.x, side2 * .4);\\n trans(q.x, sin(time));\\n scale(q.x, resolution.y / resolution.x);\\n gl_Position = q;\\n v_color = vec4(1);\\n}\"}", + "settings": { + "num": 24, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec4 quad(int id) {\n if (id == 0) {\n return vec4(-1, 1, 0, 1);\n } else if (id == 1 || id == 4) {\n return vec4(-1, -1, 0, 1);\n } else if (id == 2 || id == 3) {\n return vec4(1, 1, 0, 1);\n } else if (id == 5) {\n return vec4(1, -1, 0, 1);\n } else {\n \treturn vec4(0);\n }\n}\n\nvoid scale(inout vec4 v, vec3 scale) {\n\tv.xyz *= scale;\n}\n\nvoid scale(inout float v, float scale) {\n\tv *= scale;\n}\n\nvoid trans(inout vec4 v, vec3 trans) {\n\tv.xyz += trans;\n}\n\nvoid trans(inout float v, float trans) {\n\tv += trans;\n}\n\nfloat duplicate(inout int id, int n) {\n if (id < n) {\n \treturn -1.;\n } else {\n \tid -= n;\n return 1.;\n }\n}\n\nvoid main() {\n int id = int(vertexId);\n float side2 = duplicate(id, 12);\n float side = duplicate(id, 6);\n vec4 q = quad(id);\n scale(q, vec3(.3));\n trans(q.y, side * .4);\n trans(q.x, side2 * .4);\n trans(q.x, sin(time));\n scale(q.x, resolution.y / resolution.x);\n gl_Position = q;\n v_color = vec4(1);\n}" + }, "screenshotURL": "data/images/images-j1ekwaw2srvnhdd6t-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xBdqEmtgfPSxao97G/art.json b/art/xBdqEmtgfPSxao97G/art.json index 5534c822..0196c682 100644 --- a/art/xBdqEmtgfPSxao97G/art.json +++ b/art/xBdqEmtgfPSxao97G/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "katan", "avatarUrl": "https://secure.gravatar.com/avatar/20ec10de55ec7b1e8677ddea2080bb16?default=retro&size=200", - "settings": "{\"num\":3605,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 3605, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n \n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-rec0ed0m424emv7c3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xC9mkxRGvdyco7QbM/art.json b/art/xC9mkxRGvdyco7QbM/art.json index fb05fd18..f01424d6 100644 --- a/art/xC9mkxRGvdyco7QbM/art.json +++ b/art/xC9mkxRGvdyco7QbM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/billx/tandava-billx-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define RESOLUTION_MIN\\tmin(resolution.x, resolution.y)\\n#define ASPECT\\t\\t(resolution.xy/RESOLUTION_MIN)\\n\\n//Shader funcitons\\nvec2 v(vec2 p,float s){\\n\\treturn vec2(sin(s*p.y),cos(s*p.x));\\t//advection vector field\\n}\\n\\nvec2 RK4(vec2 p,float s, float h){\\n\\tvec2 k1 = v(p,s);\\n\\tvec2 k2 = v(p+10.5*h*k1,s);\\n\\tvec2 k3 = v(p+0.5*h*k2,s);\\n\\tvec2 k4 = v(p+h*k3,s);\\n\\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\\n}\\n\\nvec3 rainbow(float hue){\\n\\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\\n}\\n\\n//End shader functions\\n\\n\\n//functions for the shader\\nfloat random(in vec2 st) {\\n\\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\\n}\\n\\nfloat noise1(vec2 st) {\\n\\tvec2 i = floor(st);\\n\\tvec2 f = fract(st);\\n\\tvec2 u = f * f * (3.0 - 2.0 * f);\\n\\treturn mix(mix(random(i + vec2(0.0, 0.0)), \\n\\t\\t\\t random(i + vec2(1.0, 0.0)), u.x), \\n\\t\\t mix(random(i + vec2(0.0, 1.0)), \\n\\t\\t\\t random(i + vec2(1.0, 1.0)), u.x), u.y);\\n}\\n\\nfloat lines(in vec2 pos, float b) {\\n\\tfloat scale = 10.0;\\n\\tpos *= scale;\\n\\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\\n}\\n\\nmat2 rotate2d(float angle) {\\n\\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n//end functions for the shader\\n\\n\\n//Functions used for camera\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\n\\nvec2 rotate(vec2 f, float deg) \\n{\\n\\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\\n}\\n\\n//End functions used for camera\\n\\n\\nvoid main ()\\n{\\n float finalDesiredPointSize = 3.;\\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\n \\n //first the number of elements in a line\\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\n finalDesiredPointSize = resolution.x/across;\\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\\n //across = across*resolution.x/resolution.y;\\n \\n //then the number of possible lines with the given vertexCount\\n float down = floor(finalMaxVertexCount / across);\\n \\n //we can now calculate the final number of elements\\n float finalVertexCount = across*down;\\n \\n //and the consequent finalVertexId\\n float finalVertexId = mod(vertexId,finalVertexCount);\\n \\n //Now we calculate the position of the elements based on their finalVertexId\\n float x = mod(finalVertexId, across);\\n float y = floor(finalVertexId / across);\\n \\n float u = (x /across);\\n float v = (y /down);\\n \\n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\\n \\n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\\n \\n // if(u>0.5)\\n // u = 1.-u;\\n\\t\\n \\n float udnd = u;\\n if(u>0.5)\\n udnd = 1.-u;\\n \\n float snd = texture2D(sound, vec2(0., udnd)).a;\\n \\n \\n\\tvec2 fragcoord = vec2(x,y);\\n vec2 newResolution = vec2(across, down);\\n \\n \\n vec2 aspect = resolution/min(resolution.x, resolution.y);\\n vec2 uv = vec2(u,v);\\n vec2 FragCoord = vec2(u,v);\\n\\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\\n\\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\\n \\tfloat s = 2.;\\n\\tfloat h = 1.0;\\n\\tvec2 range = aspect * sqrt(2.);\\n \\tfor(int i = 0; i<5*8; i++) {\\n\\t\\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\\n \\t\\tuv+=RK4(uv,s,hh);\\n\\t\\ts*=1.25;\\n\\t\\th/=1.25;\\n\\t }\\n\\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\\n\\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1.); //centered rainbow with 10 visible rings\\n\\t\\n //camera\\n float r = 0.9;\\n float tm = 1.5*time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n\\n \\n gl_PointSize = 4.;//finalDesiredPointSize;\\n\\n //v_color = vec4(col, 1);\\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\\n float depthFactor = 0.;\\n \\n //if(depth>=0.5)\\n {\\n depthFactor = depth;\\n }\\n \\n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/10., 1.);\\n \\n gl_Position = mat*finalPos;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/billx/tandava-billx-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define RESOLUTION_MIN\tmin(resolution.x, resolution.y)\n#define ASPECT\t\t(resolution.xy/RESOLUTION_MIN)\n\n//Shader funcitons\nvec2 v(vec2 p,float s){\n\treturn vec2(sin(s*p.y),cos(s*p.x));\t//advection vector field\n}\n\nvec2 RK4(vec2 p,float s, float h){\n\tvec2 k1 = v(p,s);\n\tvec2 k2 = v(p+10.5*h*k1,s);\n\tvec2 k3 = v(p+0.5*h*k2,s);\n\tvec2 k4 = v(p+h*k3,s);\n\treturn h/3.*(0.5*k1+k2+k3+0.5*k4);\n}\n\nvec3 rainbow(float hue){\n\treturn abs(mod(hue * 6.0 + vec3(0.0, 4.0, 2.0), 6.0) - 3.0) - 1.0;\n}\n\n//End shader functions\n\n\n//functions for the shader\nfloat random(in vec2 st) {\n\treturn fract(sin(dot(st, vec2(12.9898, 78.233))) * 43758.545123);\n}\n\nfloat noise1(vec2 st) {\n\tvec2 i = floor(st);\n\tvec2 f = fract(st);\n\tvec2 u = f * f * (3.0 - 2.0 * f);\n\treturn mix(mix(random(i + vec2(0.0, 0.0)), \n\t\t\t random(i + vec2(1.0, 0.0)), u.x), \n\t\t mix(random(i + vec2(0.0, 1.0)), \n\t\t\t random(i + vec2(1.0, 1.0)), u.x), u.y);\n}\n\nfloat lines(in vec2 pos, float b) {\n\tfloat scale = 10.0;\n\tpos *= scale;\n\treturn smoothstep(0.0, 0.5 + b * 0.5, abs(sin(pos.x * 3.1415) + b * 2.0) * .5);\n}\n\nmat2 rotate2d(float angle) {\n\treturn mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n//end functions for the shader\n\n\n//Functions used for camera\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\n\nvec2 rotate(vec2 f, float deg) \n{\n\treturn vec2(f.x * cos(deg) - f.y * sin(deg), f.x * sin(deg) + f.y * cos(deg));\n}\n\n//End functions used for camera\n\n\nvoid main ()\n{\n float finalDesiredPointSize = 3.;\n float maxFinalSquareSideSize = floor(sqrt(vertexCount));\n float finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\n \n //first the number of elements in a line\n float across = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\n finalDesiredPointSize = resolution.x/across;\n //we want to keep the resolution >> across/down must be the same as resolution.x/resolution.y\n //across = across*resolution.x/resolution.y;\n \n //then the number of possible lines with the given vertexCount\n float down = floor(finalMaxVertexCount / across);\n \n //we can now calculate the final number of elements\n float finalVertexCount = across*down;\n \n //and the consequent finalVertexId\n float finalVertexId = mod(vertexId,finalVertexCount);\n \n //Now we calculate the position of the elements based on their finalVertexId\n float x = mod(finalVertexId, across);\n float y = floor(finalVertexId / across);\n \n float u = (x /across);\n float v = (y /down);\n \n float u0 = (u * (across*finalDesiredPointSize/resolution.x));\n float v0 = (v * (across*finalDesiredPointSize/resolution.x ));\n \n float ux = u0 - 0.5*(across*finalDesiredPointSize/resolution.x);\n float vy = v0- 0.5*(across*finalDesiredPointSize/resolution.x);;\n \n // if(u>0.5)\n // u = 1.-u;\n\t\n \n float udnd = u;\n if(u>0.5)\n udnd = 1.-u;\n \n float snd = texture2D(sound, vec2(0., udnd)).a;\n \n \n\tvec2 fragcoord = vec2(x,y);\n vec2 newResolution = vec2(across, down);\n \n \n vec2 aspect = resolution/min(resolution.x, resolution.y);\n vec2 uv = vec2(u,v);\n vec2 FragCoord = vec2(u,v);\n\t//vec2 uv = 2.*gl_FragCoord.xy/resolution.y-vec2(resolution.x/resolution.y,1);\n\tvec2 pos = vec2(u,v);//gl_FragCoord.xy/resolution.xy;\n \tfloat s = 2.;\n\tfloat h = 1.0;\n\tvec2 range = aspect * sqrt(2.);\n \tfor(int i = 0; i<5*8; i++) {\n\t\tfloat hh = h * log(1./(exp(2.*sin(time*0.5 + pos.x*aspect.x + pos.y*aspect.y + float(i) * 0.1))))/5.;\n \t\tuv+=RK4(uv,s,hh);\n\t\ts*=1.25;\n\t\th/=1.25;\n\t }\n\t//gl_FragColor = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1); //centered rainbow with 10 visible rings\n\n v_color = vec4(rainbow(time*0.1 + floor(length(uv)*10.)/10.),1.); //centered rainbow with 10 visible rings\n\t\n //camera\n float r = 0.9;\n float tm = 1.5*time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n\n \n gl_PointSize = 4.;//finalDesiredPointSize;\n\n //v_color = vec4(col, 1);\n float depth = (v_color.x+v_color.y+v_color.z)/3.;\n float depthFactor = 0.;\n \n //if(depth>=0.5)\n {\n depthFactor = depth;\n }\n \n vec4 finalPos = vec4(ux, vy, 0.+v_color.x/10., 1.);\n \n gl_Position = mat*finalPos;\n}\n\n" + }, "screenshotURL": "data/images/images-gffajkg4hfq2w5c9t-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xCGKaZubja8uuYkJH/art.json b/art/xCGKaZubja8uuYkJH/art.json index e895166d..20410e55 100644 --- a/art/xCGKaZubja8uuYkJH/art.json +++ b/art/xCGKaZubja8uuYkJH/art.json @@ -27,7 +27,19 @@ "name": "Sky", "private": true, "username": "P_Malin", - "settings": "{\"num\":16384,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"// Sky - @P_Malin\\n\\nfloat g_cameraFar = 8000.0;\\n\\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\\nvec3 g_skyTop = vec3( 0.01, 0.6, 1.0 ) * 0.1;\\nvec3 g_skyBottom = vec3( 0.01, 0.8, 0.8 ) * 1.0;\\n\\n\\n#define PI radians( 180.0 )\\n\\nvec3 g_sunDir = vec3( 0.0, 0.1, 1.0 );\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( g_sunDir );\\n}\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.0001;\\n}\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n\\tfloat fGloss;\\n};\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = surfaceInfo.fGloss;\\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\\n}\\n\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n AddDirectionalLight( GetSunDir(), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\\n \\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor, float fExposure )\\n{\\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n\\tfloat fAlpha;\\n};\\n\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / pow(fShade, 1.5);\\n \\n \\tvec3 vColor = mix( g_skyBottom, g_skyTop, vViewDir.y * 0.5 + 0.5 );\\n \\n vColor += vec3( fShade * g_sunColor );\\n return vColor;\\n}\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t32.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vQuadTileIndex.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos, vCameraPos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat fOrbitDistance = 10.0;\\n\\n \\tfloat orbitAngle = mouse.x * PI * 2.0;\\n \\n \\tvec3 vCameraPos = vec3( sin(orbitAngle), 0.0, cos(orbitAngle) ) * fOrbitDistance;\\n \\tvec3 vCameraTarget = vec3( 0.0, vMouse.y * 10.5, 0.0 );\\n \\tvec3 vCameraUp = vec3( 0.0, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\t// Backdrop\\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n\\n \\tif ( vertexIndex >= 0.0 )\\n {\\n sceneVertex.vWorldPos = vec3(0.0);\\n sceneVertex.vColor = vec3(0.0);\\n sceneVertex.fAlpha = 0.0;\\n }\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tvec3 vFinalColor = sceneVertex.vColor;\\n \\n \\t//vFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \\n \\n \\tfloat VdotL = dot( vCameraForwards, -GetSunDir() );\\n \\n \\t// Adjust exposure if we are looking towards the sun\\n \\tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\\n \\n \\tfExposure = 1.0;\\n \\n \\tfExposure += 0.5;\\n \\n \\tfExposure *= min( 1.0, time / 5.0 );\\n \\n \\tvFinalColor = PostProcess( vFinalColor, fExposure );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\\n\"}", + "settings": { + "num": 16384, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "// Sky - @P_Malin\n\nfloat g_cameraFar = 8000.0;\n\nvec3 g_sunColor = vec3( 1.0, 0.8, 0.5 ) * 100.0;\nvec3 g_skyTop = vec3( 0.01, 0.6, 1.0 ) * 0.1;\nvec3 g_skyBottom = vec3( 0.01, 0.8, 0.8 ) * 1.0;\n\n\n#define PI radians( 180.0 )\n\nvec3 g_sunDir = vec3( 0.0, 0.1, 1.0 );\n\nvec3 GetSunDir()\n{\n \treturn normalize( g_sunDir );\n}\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.0001;\n}\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n\tfloat fGloss;\n};\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, const vec3 vCameraPos, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = surfaceInfo.fGloss;\n vSpecular += pow( NdotH, fPower ) * 2.0 * NdotL * vLightColor;\n}\n\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vCameraPos, const vec3 vAlbedo, float fShadow )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n AddDirectionalLight( GetSunDir(), g_sunColor * 0.01 * fShadow, surfaceInfo, vCameraPos, vDiffuseLight, vSpecLight );\n \n vec3 vViewDir = normalize(vCameraPos-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0); \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor, float fExposure )\n{\n vColor = vec3(1.0) - exp2( vColor * -fExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(max(0.0, 1.0 - fDist), kPower));\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n\tfloat fAlpha;\n};\n\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\nvec3 GetBackdropColor( vec3 vViewDir, vec3 vCameraPos )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / pow(fShade, 1.5);\n \n \tvec3 vColor = mix( g_skyBottom, g_skyTop, vViewDir.y * 0.5 + 0.5 );\n \n vColor += vec3( fShade * g_sunColor );\n return vColor;\n}\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t32.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vQuadTileIndex.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos, vCameraPos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat fOrbitDistance = 10.0;\n\n \tfloat orbitAngle = mouse.x * PI * 2.0;\n \n \tvec3 vCameraPos = vec3( sin(orbitAngle), 0.0, cos(orbitAngle) ) * fOrbitDistance;\n \tvec3 vCameraTarget = vec3( 0.0, vMouse.y * 10.5, 0.0 );\n \tvec3 vCameraUp = vec3( 0.0, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \t// Backdrop\n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n\n \tif ( vertexIndex >= 0.0 )\n {\n sceneVertex.vWorldPos = vec3(0.0);\n sceneVertex.vColor = vec3(0.0);\n sceneVertex.fAlpha = 0.0;\n }\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tvec3 vFinalColor = sceneVertex.vColor;\n \n \t//vFinalColor = ApplyVignetting( (gl_Position.xy / gl_Position.w) * 0.5 + 0.5, vFinalColor ); \n \n \tfloat VdotL = dot( vCameraForwards, -GetSunDir() );\n \n \t// Adjust exposure if we are looking towards the sun\n \tfloat fExposure = (0.5 + VdotL * 0.5) * 5.0;\n \n \tfExposure = 1.0;\n \n \tfExposure += 0.5;\n \n \tfExposure *= min( 1.0, time / 5.0 );\n \n \tvFinalColor = PostProcess( vFinalColor, fExposure );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}\n" + }, "screenshotURL": "data/images/images-7lcv6r9ndjifq0bz4-thumbnail.jpg", "views": { "$numberInt": "4" diff --git a/art/xCT9GJqCjqMs5Zj3m/art.json b/art/xCT9GJqCjqMs5Zj3m/art.json index 7e7035b7..6a51956d 100644 --- a/art/xCT9GJqCjqMs5Zj3m/art.json +++ b/art/xCT9GJqCjqMs5Zj3m/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "tjak", "avatarUrl": "https://secure.gravatar.com/avatar/1a86b3500dea44608fae35d58b17a5ce?default=retro&size=200", - "settings": "{\"num\":180,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0392156862745098,0.0392156862745098,0.0392156862745098,1],\"shader\":\"#define PI radians(180.0)\\n\\nmat4 proj() {\\n return mat4(\\n vec4(1.0, 0.0, 0.0, 0.0),\\n vec4(0.0, 1.0, 0.0, 0.0),\\n vec4(0.0, 0.0, 1.0, 0.0),\\n vec4(0.0, 0.0, 0.0, 1.0)\\n );\\n}\\n\\nvoid main() {\\n float pointId = vertexId;\\n float t = abs(0.01 * time) + (vertexId / vertexCount);\\n \\n \\n float theta = 37.*(PI) * t;\\n float phi = 71.*PI * t; \\n float r = 0.5;\\n\\n float x = r * sin(theta) * cos(phi);\\n float y = r * cos(theta) * cos(phi);\\n \\n\\n y *= resolution.x/resolution.y;\\n vec3 pos = vec3(x, y, 0.0);\\n gl_Position = proj() * vec4(pos, 1.0);\\n gl_PointSize = 4.0;\\n\\n v_color = mix(\\n vec4(1.0, 0.0, 0.0, 1.0),\\n vec4(0.0, 1.0, 0.0, 1.0),\\n fract(t)\\n );\\n} \"}", + "settings": { + "num": 180, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0392156862745098, + 0.0392156862745098, + 0.0392156862745098, + 1 + ], + "shader": "#define PI radians(180.0)\n\nmat4 proj() {\n return mat4(\n vec4(1.0, 0.0, 0.0, 0.0),\n vec4(0.0, 1.0, 0.0, 0.0),\n vec4(0.0, 0.0, 1.0, 0.0),\n vec4(0.0, 0.0, 0.0, 1.0)\n );\n}\n\nvoid main() {\n float pointId = vertexId;\n float t = abs(0.01 * time) + (vertexId / vertexCount);\n \n \n float theta = 37.*(PI) * t;\n float phi = 71.*PI * t; \n float r = 0.5;\n\n float x = r * sin(theta) * cos(phi);\n float y = r * cos(theta) * cos(phi);\n \n\n y *= resolution.x/resolution.y;\n vec3 pos = vec3(x, y, 0.0);\n gl_Position = proj() * vec4(pos, 1.0);\n gl_PointSize = 4.0;\n\n v_color = mix(\n vec4(1.0, 0.0, 0.0, 1.0),\n vec4(0.0, 1.0, 0.0, 1.0),\n fract(t)\n );\n} " + }, "screenshotURL": "data/images/images-vvi9acz2ifc9fg3h5-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xDh7mGTSuEc3dohm4/art.json b/art/xDh7mGTSuEc3dohm4/art.json index af7aea70..89d7bde1 100644 --- a/art/xDh7mGTSuEc3dohm4/art.json +++ b/art/xDh7mGTSuEc3dohm4/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "zach", "avatarUrl": "https://lh3.googleusercontent.com/a-/AOh14GjSu-FKN5gL_Js9LaWAksIXTLt8FE8JhRtiWe8XJQ=s96-c", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-234697785/sets/future-funk\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\n \\n int numShapes = 3;\\n \\n // Shape 1\\n float a1 = 1.0;\\n float b1 = 2.0;\\n float c1 = 4.36;\\n float d1 = -3.0;\\n \\n // Shape 2\\n float a2 = 2.53;\\n float b2 = 1.67;\\n float c2 = 1.26;\\n float d2 = 2.24;\\n \\n // Shape 3\\n float a3 = -1.54;\\n float b3 = 4.21;\\n float c3 = 1.53;\\n float d3 = 1.04;\\n \\n float s = texture2D(sound, vec2(3./5., 1./ 5.)).a;\\n \\n // Spread between the bands. KEEP BETWEEN 0-1\\n float spread = mix(0., 1., mouse.y);\\n \\n \\n float cycleTime = 3.;\\n float stage = mod(time/20., cycleTime);\\n \\n float a, b, c, d;\\n \\n // Mix between first and second shape.\\n if(stage < (cycleTime / float(numShapes))) {\\n a = mix(a1, a2, stage);\\n b = mix(b1, b2, stage);\\n c = mix(c1, c2, stage);\\n d = mix(d1, d2, stage); \\n } else if (stage < 2. * (cycleTime / float(numShapes))) {\\n a = mix(a2, a3, mod(stage, (cycleTime / float(numShapes))));\\n b = mix(b2, b3, mod(stage, (cycleTime / float(numShapes))));\\n c = mix(c2, c3, mod(stage, (cycleTime / float(numShapes))));\\n d = mix(d2, d3, mod(stage, (cycleTime / float(numShapes))));\\n } else {\\n a = mix(a3, a1, mod(stage, (cycleTime / float(numShapes))));\\n b = mix(b3, b1, mod(stage, (cycleTime / float(numShapes))));\\n c = mix(c3, c1, mod(stage, (cycleTime / float(numShapes))));\\n d = mix(d3, d1, mod(stage, (cycleTime / float(numShapes))));\\n }\\n \\n gl_PointSize = 0.5; \\n \\n // Find pixel coordinates\\n float x = mod(vertexId, 25.);\\n float y = floor(vertexId/ 25.);\\n \\n // Used in calculating future point\\n float tmpX;\\n float tmpY;\\n \\n for (int i = 0; i < 5; i++) {\\n tmpX = x; tmpY = y;\\n x = (sin(a * tmpY) - cos(b * tmpX));\\n y = (sin(c * tmpX) - cos(d * tmpY));\\n }\\n \\n int band = int(mod(vertexId, 3.));\\n \\n \\n if(band == 0) {\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n gl_Position = vec4(x / 5., y / 5. - (0.1 * spread), 0., 0.7);\\n } else if(band == 1) {\\n v_color = vec4(0.0, 1.0, 0.0, 1.0);\\n \\tgl_Position = vec4(x / 5., y / 5., 0., 0.7);\\n } else {\\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\\n \\tgl_Position = vec4(x / 5., y / 5. + (0.1 * spread), 0., 0.7);\\n }\\n \\n //gl_Position = vec4(x / 5., y / 5., 0., 0.7);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-234697785/sets/future-funk", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \n \n int numShapes = 3;\n \n // Shape 1\n float a1 = 1.0;\n float b1 = 2.0;\n float c1 = 4.36;\n float d1 = -3.0;\n \n // Shape 2\n float a2 = 2.53;\n float b2 = 1.67;\n float c2 = 1.26;\n float d2 = 2.24;\n \n // Shape 3\n float a3 = -1.54;\n float b3 = 4.21;\n float c3 = 1.53;\n float d3 = 1.04;\n \n float s = texture2D(sound, vec2(3./5., 1./ 5.)).a;\n \n // Spread between the bands. KEEP BETWEEN 0-1\n float spread = mix(0., 1., mouse.y);\n \n \n float cycleTime = 3.;\n float stage = mod(time/20., cycleTime);\n \n float a, b, c, d;\n \n // Mix between first and second shape.\n if(stage < (cycleTime / float(numShapes))) {\n a = mix(a1, a2, stage);\n b = mix(b1, b2, stage);\n c = mix(c1, c2, stage);\n d = mix(d1, d2, stage); \n } else if (stage < 2. * (cycleTime / float(numShapes))) {\n a = mix(a2, a3, mod(stage, (cycleTime / float(numShapes))));\n b = mix(b2, b3, mod(stage, (cycleTime / float(numShapes))));\n c = mix(c2, c3, mod(stage, (cycleTime / float(numShapes))));\n d = mix(d2, d3, mod(stage, (cycleTime / float(numShapes))));\n } else {\n a = mix(a3, a1, mod(stage, (cycleTime / float(numShapes))));\n b = mix(b3, b1, mod(stage, (cycleTime / float(numShapes))));\n c = mix(c3, c1, mod(stage, (cycleTime / float(numShapes))));\n d = mix(d3, d1, mod(stage, (cycleTime / float(numShapes))));\n }\n \n gl_PointSize = 0.5; \n \n // Find pixel coordinates\n float x = mod(vertexId, 25.);\n float y = floor(vertexId/ 25.);\n \n // Used in calculating future point\n float tmpX;\n float tmpY;\n \n for (int i = 0; i < 5; i++) {\n tmpX = x; tmpY = y;\n x = (sin(a * tmpY) - cos(b * tmpX));\n y = (sin(c * tmpX) - cos(d * tmpY));\n }\n \n int band = int(mod(vertexId, 3.));\n \n \n if(band == 0) {\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n gl_Position = vec4(x / 5., y / 5. - (0.1 * spread), 0., 0.7);\n } else if(band == 1) {\n v_color = vec4(0.0, 1.0, 0.0, 1.0);\n \tgl_Position = vec4(x / 5., y / 5., 0., 0.7);\n } else {\n v_color = vec4(0.0, 0.0, 1.0, 1.0);\n \tgl_Position = vec4(x / 5., y / 5. + (0.1 * spread), 0., 0.7);\n }\n \n //gl_Position = vec4(x / 5., y / 5., 0., 0.7);\n}" + }, "screenshotURL": "data/images/images-patj5a013yz61fk1n-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xEptEPstqgQAypqks/art.json b/art/xEptEPstqgQAypqks/art.json index faf6cf61..0fd9f364 100644 --- a/art/xEptEPstqgQAypqks/art.json +++ b/art/xEptEPstqgQAypqks/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1891,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(120.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 2.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\\n}\"}", + "settings": { + "num": 1891, + "mode": "LINES", + "sound": "https://soundcloud.com/sash_liq/sash-liq-20180504_4_st3", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(120.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 2.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 0, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-s67r2412iy97671m5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xG6tZRJFAL9i7pWED/art.json b/art/xG6tZRJFAL9i7pWED/art.json index 6d468e57..16a5495a 100644 --- a/art/xG6tZRJFAL9i7pWED/art.json +++ b/art/xG6tZRJFAL9i7pWED/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/jacklndn/jacklndn-play-it-back-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_POINTS_PER_GROUP 30.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float groupId = floor(vertexId / NUM_POINTS_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_GROUP);\\n float ps = pointId / NUM_POINTS_PER_GROUP;\\n float numGroups = floor(vertexCount / NUM_POINTS_PER_GROUP);\\n float down = floor(sqrt(numGroups));\\n float across = floor(numGroups / down);\\n\\n float px = mod(groupId, across);\\n float py = floor(groupId / across);\\n float pu = px / across;\\n float pv = py / down;\\n \\n float t = time + 9500.0;\\n float snd = texture2D(sound, vec2(pu * 0.01, abs(pv * 2. - 1.) * 0.4)).a;\\n float tm = t * 0.5 - ps * 0.8 * (sin(t + pu * 3. * pv * 4.) * 0.5 + 0.5);\\n vec2 xy = vec2(\\n pu * 2. - 1. + sin(tm + px * 0.1) * 0.1 + cos(tm * px * py * 0.000009) * 0.1,\\n pv * 2. - 1. + sin(tm * 0.77 + py * 0.1) * cos(tm + px * 0.011) * 0.1\\n );\\n gl_Position = vec4(xy * 1.2, ps, 1);\\n gl_PointSize = 2.0 + sin(time * px * py * 0.001) * 40.;\\n gl_PointSize *= resolution.x / 1600.;\\n\\n float hue = (time * 0.01 + pu * 0.1 + pow(snd, 5.) * .2);\\n v_color = vec4(hsv2rgb(vec3(hue, mix(0.5, 1.0, pow(snd, 5.)), 0.25 + pow(snd, 10.0) * 0.5)), mix(0.9, 0., ps));\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/jacklndn/jacklndn-play-it-back-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_POINTS_PER_GROUP 30.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float groupId = floor(vertexId / NUM_POINTS_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_GROUP);\n float ps = pointId / NUM_POINTS_PER_GROUP;\n float numGroups = floor(vertexCount / NUM_POINTS_PER_GROUP);\n float down = floor(sqrt(numGroups));\n float across = floor(numGroups / down);\n\n float px = mod(groupId, across);\n float py = floor(groupId / across);\n float pu = px / across;\n float pv = py / down;\n \n float t = time + 9500.0;\n float snd = texture2D(sound, vec2(pu * 0.01, abs(pv * 2. - 1.) * 0.4)).a;\n float tm = t * 0.5 - ps * 0.8 * (sin(t + pu * 3. * pv * 4.) * 0.5 + 0.5);\n vec2 xy = vec2(\n pu * 2. - 1. + sin(tm + px * 0.1) * 0.1 + cos(tm * px * py * 0.000009) * 0.1,\n pv * 2. - 1. + sin(tm * 0.77 + py * 0.1) * cos(tm + px * 0.011) * 0.1\n );\n gl_Position = vec4(xy * 1.2, ps, 1);\n gl_PointSize = 2.0 + sin(time * px * py * 0.001) * 40.;\n gl_PointSize *= resolution.x / 1600.;\n\n float hue = (time * 0.01 + pu * 0.1 + pow(snd, 5.) * .2);\n v_color = vec4(hsv2rgb(vec3(hue, mix(0.5, 1.0, pow(snd, 5.)), 0.25 + pow(snd, 10.0) * 0.5)), mix(0.9, 0., ps));\n}" + }, "screenshotURL": "data/images/images-as21cf4f53bkqwnlw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xJtSaCNJTKWjZF5jp/art.json b/art/xJtSaCNJTKWjZF5jp/art.json index 3060e0bb..9aedb820 100644 --- a/art/xJtSaCNJTKWjZF5jp/art.json +++ b/art/xJtSaCNJTKWjZF5jp/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "chriscamplin", "avatarUrl": "https://secure.gravatar.com/avatar/5798c9f697b3fea48de32ade2ba3e54c?default=retro&size=200", - "settings": "{\"num\":3182,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/bottomforty/bottom-forty-mix-038-chris-camplin\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvoid main() {\\n \\tfloat rows = floor(sqrt(vertexCount));\\n \\tfloat cols = floor(vertexCount / rows);\\n \\t// vertex ID is number of the vertex\\n \\tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \\n \\tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\\n \\tfloat s = sin(PI * time + y * 0.25);\\n \\tfloat xOff = sin(time + y * 0.025) * 0.1;\\n \\tfloat yOff = sin(time - x * 0.25) + s * 0.1;\\n \\n \\tfloat u = x /(rows - 1.);\\n \\tfloat v = y / (rows - 1.);\\n \\tfloat ux = u * 2. - 1. + xOff;\\n \\tfloat vy = v * 2. - 1. + yOff;\\n \\tfloat soff = sin(time + x * y * 0.05) * mouse.x;\\n\\tgl_Position = vec4(ux, vy, 0, 1);\\n \\tgl_PointSize = 4.0 - soff; \\n \\tgl_PointSize *= 20.0 / cols; \\n \\tgl_PointSize *= resolution.x / 600.; \\n \\tv_color = vec4(yOff-s, 0.0666, s+xOff, 1);\\n}\"}", + "settings": { + "num": 3182, + "mode": "POINTS", + "sound": "https://soundcloud.com/bottomforty/bottom-forty-mix-038-chris-camplin", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvoid main() {\n \tfloat rows = floor(sqrt(vertexCount));\n \tfloat cols = floor(vertexCount / rows);\n \t// vertex ID is number of the vertex\n \tfloat x = mod(vertexId, rows); // divide by 10 keep the remainder, \n \tfloat y = floor(vertexId / rows); //. floor throws away the remainder 0000 1111 2222\n \tfloat s = sin(PI * time + y * 0.25);\n \tfloat xOff = sin(time + y * 0.025) * 0.1;\n \tfloat yOff = sin(time - x * 0.25) + s * 0.1;\n \n \tfloat u = x /(rows - 1.);\n \tfloat v = y / (rows - 1.);\n \tfloat ux = u * 2. - 1. + xOff;\n \tfloat vy = v * 2. - 1. + yOff;\n \tfloat soff = sin(time + x * y * 0.05) * mouse.x;\n\tgl_Position = vec4(ux, vy, 0, 1);\n \tgl_PointSize = 4.0 - soff; \n \tgl_PointSize *= 20.0 / cols; \n \tgl_PointSize *= resolution.x / 600.; \n \tv_color = vec4(yOff-s, 0.0666, s+xOff, 1);\n}" + }, "screenshotURL": "data/images/images-xaxeb3eyozituvadl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xJxsMsamoRikshwtQ/art.json b/art/xJxsMsamoRikshwtQ/art.json index 75d4126b..51040213 100644 --- a/art/xJxsMsamoRikshwtQ/art.json +++ b/art/xJxsMsamoRikshwtQ/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sangbeom.kim", "avatarUrl": "https://secure.gravatar.com/avatar/c99736a57abb90e7c8205e5c912ade03?default=retro&size=200", - "settings": "{\"num\":19864,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//CS250 Spring 2022\\n//Sangbeom Kim\\n//Exercise - Vertexshaderart : Audio Reactive\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat2 rotate(float angle) {\\n return mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n xy = rotate(time) * xy;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(av * .04, au * .25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n \\n gl_PointSize = pow(snd + 0.2, 10.) * 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 1000.;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + cos(time + snd);\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 19864, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//CS250 Spring 2022\n//Sangbeom Kim\n//Exercise - Vertexshaderart : Audio Reactive\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat2 rotate(float angle) {\n return mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n xy = rotate(time) * xy;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(av * .04, au * .25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n \n gl_PointSize = pow(snd + 0.2, 10.) * 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 1000.;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + cos(time + snd);\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-wc0vujger3got96xo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xL2Gh9RJscrvhfwE9/art.json b/art/xL2Gh9RJscrvhfwE9/art.json index 8e35a432..84d87453 100644 --- a/art/xL2Gh9RJscrvhfwE9/art.json +++ b/art/xL2Gh9RJscrvhfwE9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n gl_Position.x = floor(vertexId / 2.);\\n gl_Position.y = floor(mod(vertexId, 2.));\\n gl_Position.z = 0.25;\\n gl_Position.w = 1.;\\n \\n gl_PointSize = 20.0;\\n \\n v_color = vec4(0,1,0,1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n gl_Position.x = floor(vertexId / 2.);\n gl_Position.y = floor(mod(vertexId, 2.));\n gl_Position.z = 0.25;\n gl_Position.w = 1.;\n \n gl_PointSize = 20.0;\n \n v_color = vec4(0,1,0,1);\n}" + }, "screenshotURL": "data/images/images-ay1j6e88yjizseq3i-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xLrHnki5affkbQiFT/art.json b/art/xLrHnki5affkbQiFT/art.json index 93b4784a..55a1dd0e 100644 --- a/art/xLrHnki5affkbQiFT/art.json +++ b/art/xLrHnki5affkbQiFT/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=100000\\n\\n#define speedFactor 0.//KParameter0 -2>>2.\\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\\n#define cubeRotFactor 1.//KParameter2 1.>>15.\\n#define eyeY 0.7//KParameter3 0.1>>2.\\n#define eyeX 0.//KParameter4 -1.>>1.\\n#define colorGFactor 0.0//KParameter5 0.>>1.\\n#define colorRFactor 1.0//KParameter6 0.>>1.\\n#define sndFactor 4.//KParameter7 0.>>3.\\n\\n#define HPI 1.570796326795\\n\\n\\n#define PI 3.14159265358988\\n\\nvec3 noise(vec3 _v) {\\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.y = _v.y * f.y + _v.z * -f.x;\\n r.z = _v.y * f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotY(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.y + _v.z * f.x;\\n r.z = _v.x * -f.x + _v.z * f.y;\\n return r;\\n}\\n\\nvec3 rotZ(vec3 _v, float _rad) {\\n vec2 f = sin(vec2(_rad, _rad + HPI));\\n vec3 r = _v;\\n r.x = _v.x * f.x + _v.y * f.y;\\n r.y = _v.x * -f.y + _v.y * f.x;\\n return r;\\n}\\n\\n\\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\\n vec4 r = vec4(_v, -_v.z);\\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\\n return r;\\n}\\n\\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\\n vec3 z = normalize(_eye - _look);\\n vec3 x = normalize(cross(_up, z));\\n vec3 y = cross(z, x);\\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\\n return r.xyz;\\n}\\n\\n\\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\\n{\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\\n \\n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\\n \\n vec3 h = normalize(normalize(_eye - _p) + lit);\\n float specular = 1.0;\\n if(diffuse > 0.0) {\\n specular = max(0.1,dot(_n, h));\\n }\\n \\n rgb = diffuse * _dfscol + specular * _spec.y;\\n \\n return rgb;\\n}\\n\\n#define kShapeVertexCount 36.0\\n#define kVertexPerShape 6.0\\n\\n\\nvec3 shapeVertex(float _vId, out vec4 _nI)\\n{\\n float faceId = floor(_vId / kVertexPerShape);\\n float vtxId = mod(_vId, kVertexPerShape);\\n vec2 fp;\\n vec3 v;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n \\n v = vec3(fp.x, fp.y, 1.0);\\n _nI = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n \\n v = vec3(-fp.x, fp.y, -1.0);\\n _nI = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n \\n v = vec3(fp.x, 1.0, -fp.y);\\n _nI = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n \\n v = vec3(fp.x, -1.0, fp.y);\\n _nI = vec4(0.0, -1.0, 0.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n \\n v = vec3(-1.0, fp.y, -fp.x);\\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n \\n v = vec3(1.0, fp.y, fp.x);\\n _nI = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return v;\\n}\\n\\n\\n\\nvoid main() {\\n \\n float shapeCount = floor(vertexCount / kShapeVertexCount);\\n float shapeId = floor(vertexId / kShapeVertexCount);\\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\\n \\n float shapeRelId = shapeId/shapeCount;\\n \\n \\n float numberOfElement = 15.;\\n float numberOfLines = shapeCount/numberOfElement;\\n \\n float lineId = floor(shapeId/numberOfElement);\\n \\n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\\n float normXid = xPos/2.;\\n //xPos = xPos*2.-1.;\\n \\n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\\n \\n \\n float aspect = resolution.y / resolution.x;\\n vec4 cbNi;\\n \\n \\n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\\n \\n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\\n \\n vec3 color = vec3(1., 1., 1.);\\n \\n //lineId+=mod(time*10.,1.);\\n //lineId/=numberOfElement;\\n\\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\\n \\n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\\n \\n \\n cubep = vec3(cubep.x, cubep.y, cubep.z);//position\\n //float deltaZ = mod(time,4.);\\n //cubep.z+= deltaZ;\\n //if(cubep.z>4.)\\n // cubep.z-= cubep.z;\\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\\n \\n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\\n //cubep .x*=aspect;\\n \\n vec3 circleCenter = vec3(-1.5,0.,0.);\\n \\n //float xcircleRadius = 0.4;\\n //circleCenter.x -= 1.;\\n\\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\\n //cubep.z += sin(lineId*2.*PI);\\n //cubep = rot(circleCenter,PI/10.);\\n //cubep.x -= circleCenter.x;\\n \\n \\n cubep.x += (1.+sndFactor*snd)*cos(xPos*2.*PI)/10.;\\n cubep.y += (1.+sndFactor*snd)*sin(xPos*2.*PI)/10.;\\n cubep += circleCenter;\\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines+time/2.);\\n cubep -= circleCenter;\\n\\n /*\\n cubep.x+= mod(time,2.);\\n if(cubep.x>2.)\\n {\\n cubep.x-=4.;\\n }\\n */\\n\\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\\n \\n //cubep.z+=lineId;\\n //cubep.z+= mod(time/10.,10.);\\n \\n float eyeZ = sin(time/10.)*topZPos;\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\\n vec3 eye = vec3(0., 0., .2);//29./2.*abs(cos(time/5.))\\n \\n //eye += circleCenter;\\n //eye = rotY(eye,time);\\n //eye -= circleCenter;\\n \\n //eye = vec3(-1., 3., -1.);\\n //cubep += distance(cubep, eye)/7.;\\n \\n //cubep.x += 0.2;\\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\\n \\n float redComp = mod(lineId,2.);\\n color.r = redComp;\\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color, 1.0);\\n \\n \\n}\\n\\n\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=100000\n\n#define speedFactor 0.//KParameter0 -2>>2.\n#define sizeFactor1 0.02//KParameter1 0.01>>0.02\n#define cubeRotFactor 1.//KParameter2 1.>>15.\n#define eyeY 0.7//KParameter3 0.1>>2.\n#define eyeX 0.//KParameter4 -1.>>1.\n#define colorGFactor 0.0//KParameter5 0.>>1.\n#define colorRFactor 1.0//KParameter6 0.>>1.\n#define sndFactor 4.//KParameter7 0.>>3.\n\n#define HPI 1.570796326795\n\n\n#define PI 3.14159265358988\n\nvec3 noise(vec3 _v) {\n return fract(sin(_v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.y = _v.y * f.y + _v.z * -f.x;\n r.z = _v.y * f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotY(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.y + _v.z * f.x;\n r.z = _v.x * -f.x + _v.z * f.y;\n return r;\n}\n\nvec3 rotZ(vec3 _v, float _rad) {\n vec2 f = sin(vec2(_rad, _rad + HPI));\n vec3 r = _v;\n r.x = _v.x * f.x + _v.y * f.y;\n r.y = _v.x * -f.y + _v.y * f.x;\n return r;\n}\n\n\nvec4 perspective(vec3 _v, float _fov, float _near, float _far, vec2 _res) {\n vec4 r = vec4(_v, -_v.z);\n r.xy *= vec2(_res.y / _res.x, 1.0) / tan(radians(_fov * 0.5));\n r.z = (-_v.z * (_far + _near) - 2.0 * _far * _near) / (_far - _near);\n return r;\n}\n\nvec3 lookAt(vec3 _v, vec3 _eye, vec3 _look, vec3 _up) {\n vec3 z = normalize(_eye - _look);\n vec3 x = normalize(cross(_up, z));\n vec3 y = cross(z, x);\n vec4 r = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) *mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -_eye.x, -_eye.y, -_eye.z, 1.0)* vec4(_v, 1.0);\n return r.xyz;\n}\n\n\nvec3 shade(vec3 _eye, vec3 _p, vec3 _n, vec3 _dfscol, float _amb, vec2 _spec)\n{\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 1.0, 4.0));\n \n float diffuse = max(0.0, dot(_n, lit)) * (1.0 - _amb) + _amb;\n \n vec3 h = normalize(normalize(_eye - _p) + lit);\n float specular = 1.0;\n if(diffuse > 0.0) {\n specular = max(0.1,dot(_n, h));\n }\n \n rgb = diffuse * _dfscol + specular * _spec.y;\n \n return rgb;\n}\n\n#define kShapeVertexCount 36.0\n#define kVertexPerShape 6.0\n\n\nvec3 shapeVertex(float _vId, out vec4 _nI)\n{\n float faceId = floor(_vId / kVertexPerShape);\n float vtxId = mod(_vId, kVertexPerShape);\n vec2 fp;\n vec3 v;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n \n v = vec3(fp.x, fp.y, 1.0);\n _nI = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n \n v = vec3(-fp.x, fp.y, -1.0);\n _nI = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n \n v = vec3(fp.x, 1.0, -fp.y);\n _nI = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n \n v = vec3(fp.x, -1.0, fp.y);\n _nI = vec4(0.0, -1.0, 0.0, faceId);\n }\n else if(faceId == 4.0) {\n \n v = vec3(-1.0, fp.y, -fp.x);\n _nI = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n \n v = vec3(1.0, fp.y, fp.x);\n _nI = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return v;\n}\n\n\n\nvoid main() {\n \n float shapeCount = floor(vertexCount / kShapeVertexCount);\n float shapeId = floor(vertexId / kShapeVertexCount);\n float shapeVertexId = mod(vertexId, kShapeVertexCount);\n \n float shapeRelId = shapeId/shapeCount;\n \n \n float numberOfElement = 15.;\n float numberOfLines = shapeCount/numberOfElement;\n \n float lineId = floor(shapeId/numberOfElement);\n \n float xPos = mod(shapeId,numberOfElement)/numberOfElement;\n float normXid = xPos/2.;\n //xPos = xPos*2.-1.;\n \n float soundFactor = texture2D(sound,vec2(xPos,shapeRelId)).a;\n \n \n float aspect = resolution.y / resolution.x;\n vec4 cbNi;\n \n \n //vec3 cubep = shapeVertex(shapeVertexId, cbNi) * 1./(2.*numberOfElement);\n \n vec3 cubep = shapeVertex(shapeVertexId, cbNi);// * min(lineId/10., 0.9)*1./(2.*numberOfElement);\n \n vec3 color = vec3(1., 1., 1.);\n \n //lineId+=mod(time*10.,1.);\n //lineId/=numberOfElement;\n\n cubep*=0.01;// min(lineId/2., 0.9)/(2.*numberOfElement);\n \n float snd = texture2D(sound, vec2(normXid, shapeRelId)).a/2.;\n \n \n cubep = vec3(cubep.x, cubep.y, cubep.z);//position\n //float deltaZ = mod(time,4.);\n //cubep.z+= deltaZ;\n //if(cubep.z>4.)\n // cubep.z-= cubep.z;\n cbNi.xyz= vec3(cbNi.x, cbNi.y, cbNi.z);//normals\n \n float topZPos = cubep.z;//+5.;//numberOfLines*line/10.;\n //cubep .x*=aspect;\n \n vec3 circleCenter = vec3(-1.5,0.,0.);\n \n //float xcircleRadius = 0.4;\n //circleCenter.x -= 1.;\n\n //cubep.x += cos(lineId*2.*PI);//circleCenter.x;\n //cubep.z += sin(lineId*2.*PI);\n //cubep = rot(circleCenter,PI/10.);\n //cubep.x -= circleCenter.x;\n \n \n cubep.x += (1.+sndFactor*snd)*cos(xPos*2.*PI)/10.;\n cubep.y += (1.+sndFactor*snd)*sin(xPos*2.*PI)/10.;\n cubep += circleCenter;\n cubep = rotY(cubep,lineId*2.*PI/numberOfLines+time/2.);\n cubep -= circleCenter;\n\n /*\n cubep.x+= mod(time,2.);\n if(cubep.x>2.)\n {\n cubep.x-=4.;\n }\n */\n\n //cubep = rotZ(cubep, mouse.x*PI*lineId/10.);\n \n //cubep.z+=lineId;\n //cubep.z+= mod(time/10.,10.);\n \n float eyeZ = sin(time/10.)*topZPos;\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 29.*abs(cos(time/5.)));\n //vec3 eye = vec3(sin(time/1.3), sin(time/1.), 0.5);//29./2.*abs(cos(time/5.))\n vec3 eye = vec3(0., 0., .2);//29./2.*abs(cos(time/5.))\n \n //eye += circleCenter;\n //eye = rotY(eye,time);\n //eye -= circleCenter;\n \n //eye = vec3(-1., 3., -1.);\n //cubep += distance(cubep, eye)/7.;\n \n //cubep.x += 0.2;\n color = shade(eye, cubep, cbNi.xyz, color, 0.6, vec2(64.0, .8));\n \n float redComp = mod(lineId,2.);\n color.r = redComp;\n vec3 p = lookAt(cubep, eye, vec3(0.0, 0., 0.), vec3(0.0, 01.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0, resolution);\n gl_PointSize = 20.0;\n \n v_color = vec4(color, 1.0);\n \n \n}\n\n\n\n" + }, "screenshotURL": "data/images/images-tgtnvgnkeypece5pg-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xMtRaWRFbCx6TD3qF/art.json b/art/xMtRaWRFbCx6TD3qF/art.json index 85aa915e..10f86f08 100644 --- a/art/xMtRaWRFbCx6TD3qF/art.json +++ b/art/xMtRaWRFbCx6TD3qF/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 100.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n \\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n\\n color = vec4(1.,1.,1., 1);\\n\\n}\\n\\n\\nvoid main() {\\n \\n float base = time * 1.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n //track(vertexId, vertexCount, base, pos, color);\\n //TRACK\\n float sv = vertexId/vertexCount;\\n float v = sv + base;\\n \\n float off = 0.14;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(czaxis, 0),\\n vec4(cxaxis, 0),\\n vec4(czaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n\\n vec3 pre = vec3(0.,0.,0.);\\n pos = (wmat * vec4(pre, 1)).xyz;\\n color = vec4(1.,1.,1.,1.);\\n //END TRACK\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 100.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n \n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n\n color = vec4(1.,1.,1., 1);\n\n}\n\n\nvoid main() {\n \n float base = time * 1.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n //track(vertexId, vertexCount, base, pos, color);\n //TRACK\n float sv = vertexId/vertexCount;\n float v = sv + base;\n \n float off = 0.14;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(czaxis, 0),\n vec4(cxaxis, 0),\n vec4(czaxis, 0),\n vec4(r0 * expand, 1)); \n\n\n vec3 pre = vec3(0.,0.,0.);\n pos = (wmat * vec4(pre, 1)).xyz;\n color = vec4(1.,1.,1.,1.);\n //END TRACK\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-04qa4n7cz7fdpyjz8-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xPP9fDv73GJbsTxGE/art.json b/art/xPP9fDv73GJbsTxGE/art.json index 2b371354..e8514dfe 100644 --- a/art/xPP9fDv73GJbsTxGE/art.json +++ b/art/xPP9fDv73GJbsTxGE/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-s79ae195nd6pn437h-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xPppoX27MZEgtBYyX/art.json b/art/xPppoX27MZEgtBYyX/art.json index bbcde0b4..7fa76e18 100644 --- a/art/xPppoX27MZEgtBYyX/art.json +++ b/art/xPppoX27MZEgtBYyX/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trevor", "avatarUrl": "https://lh6.googleusercontent.com/-5kLKsPjdMwg/AAAAAAAAAAI/AAAAAAAABpc/UHOkxSB_ZkQ/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/tennysonmusic/with-you?in=trevor-drury/sets/stuff\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n \\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x,y);\\n}\\n\\nvoid main() {\\n \\n float numCircleSegments = 6.;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n \\n float numPointsPerCircle = numCircleSegments * 6.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + x * u) * 0.1;\\n float yoff = 0.;//sin(time + y * v) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su,sv));\\n float snd = texture2D(sound, vec2(au * .125, av * .25)).a;\\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.);\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1,aspect,1));\\n mat *= trans(vec3(ux,vy,0));\\n mat *= rotZ(snd * 20. * sign(ux));\\n mat *= uniformScale(0.02 * sc);\\n \\n //vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\\n \\n \\n float pump = step(0.8,snd);\\n float hue = u * .1 + snd * .02 + time * .15;\\n float sat = mix(0.,1.,pump);//1. - av;\\n float val = 1.;//mix(.1, pow(snd + 0.2, 5.), pump);\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n \\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/tennysonmusic/with-you?in=trevor-drury/sets/stuff", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n \n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x,y);\n}\n\nvoid main() {\n \n float numCircleSegments = 6.;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n \n float numPointsPerCircle = numCircleSegments * 6.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + x * u) * 0.1;\n float yoff = 0.;//sin(time + y * v) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su,sv));\n float snd = texture2D(sound, vec2(au * .125, av * .25)).a;\n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.);\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1,aspect,1));\n mat *= trans(vec3(ux,vy,0));\n mat *= rotZ(snd * 20. * sign(ux));\n mat *= uniformScale(0.02 * sc);\n \n //vec2 xy = circleXY * 0.1 * sc + vec2(ux,vy) * 1.3;\n \n gl_Position = mat * pos;\n \n float soff = 0.;//sin(time + x * y * 0.02) * 5.;\n \n \n float pump = step(0.8,snd);\n float hue = u * .1 + snd * .02 + time * .15;\n float sat = mix(0.,1.,pump);//1. - av;\n float val = 1.;//mix(.1, pow(snd + 0.2, 5.), pump);\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n \n}" + }, "screenshotURL": "data/images/images-oya5uojq1jh2fe0vw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xTf82BxK4LCcHNgq6/art.json b/art/xTf82BxK4LCcHNgq6/art.json index 5d218b03..70c5d150 100644 --- a/art/xTf82BxK4LCcHNgq6/art.json +++ b/art/xTf82BxK4LCcHNgq6/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "Shadertoy Adapter", "username": "P_Malin", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n// Silly Shadertoy adapter \\n\\n// based on https://www.shadertoy.com/view/Msl3Rn\\n// chains and gears - @P_Malin\\n\\n// Shadertoy variables:\\n#define iResolution vec2(1024.0, 1024.0)\\n#define iGlobalTime time\\n\\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord );\\n\\n//#define RANDOM_POSITIONS\\n\\n#ifdef RANDOM_POSITIONS\\n\\n#define MOD3 vec3(.1031,.11369,.13787)\\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\\n\\nvec2 hash21(float p)\\n{\\n\\tvec3 p3 = fract(vec3(p) * MOD3);\\n\\tp3 += dot(p3, p3.yzx + 19.19);\\n\\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\\n}\\n\\n#endif // RANDOM_POSITIONS\\n\\nvoid main() \\n{ \\n\\tvec2 vDim = vec2( 160.0, 100.0 );\\n\\n\\tfloat fQuadIndex = floor(vertexId / 6.0);\\n\\n\\tvec2 vUV;\\n\\n\\tvUV.x = mod( fQuadIndex, vDim.x );\\n\\tvUV.y = fQuadIndex / vDim.x;\\n\\n\\tvUV = vUV / vDim;\\n \\n#ifdef RANDOM_POSITIONS\\n \\tvUV = hash21( fQuadIndex );\\n#endif // RANDOM_POSITIONS \\n\\n\\tfloat triVert = mod( vertexId, 6.0 );\\n\\tfloat quadVert = mod( vertexId, 3.0 );\\n\\n\\tif( triVert >= 3.0 )\\n\\t{\\n quadVert = quadVert + 1.0;\\n\\t}\\n\\n\\tvec2 vSize = 1.0 / vDim;\\n\\tif( quadVert < 0.5 )\\n\\t{\\n vUV += vec2(0.0, 0.0);\\n\\t}\\n\\telse if( quadVert < 1.5 )\\n\\t{\\n vUV += vec2(vSize.x, 0.0);\\n\\t}\\n\\telse if( quadVert < 2.5 )\\n\\t{\\n vUV += vec2(0.0, vSize.y);\\n\\t}\\n\\telse if( quadVert < 3.5 )\\n\\t{\\n vUV += vec2(vSize.x, vSize.y);\\n\\t}\\n \\n\\tmainImage( v_color, vUV * iResolution );\\n\\n gl_Position = vec4(vUV * 2.0 - 1.0, 0, 1); \\n}\\n\\n// Pasted shadertoy code here\\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \\n\\n// Shadertoy adapter \\n\\n// based on https://www.shadertoy.com/view/Msl3Rn\\n// chains and gears - @P_Malin\\n\\n#define ENABLE_AMBIENT_OCCLUSION\\n#define ENABLE_SPECULAR\\n#define ENABLE_REFLECTIONS\\n#define ENABLE_SHADOWS\\n#define ENABLE_FOG\\n\\n//#define ENABLE_DIRECTIONAL_LIGHT\\n//#define ENABLE_DIRECTIONAL_LIGHT_FLARE\\n\\n#define ENABLE_POINT_LIGHT\\n//#define ENABLE_POINT_LIGHT_FLARE\\n\\n#define kRaymarchMaxIter 28\\n\\nconst float kPI = 3.141592654;\\nconst float kTwoPI = kPI * 2.0;\\n\\nstruct C_Ray\\n{\\n vec3 vOrigin;\\n vec3 vDir;\\n float fStartDistance;\\n float fLength;\\n};\\n\\nstruct C_HitInfo\\n{\\n vec3 vPos;\\n float fDistance;\\n vec3 vObjectId;\\n};\\n \\nstruct C_Surface\\n{\\n vec3 vNormal;\\n vec3 cReflection;\\n vec3 cTransmission; \\n};\\n\\nstruct C_Material\\n{\\n vec3 cAlbedo;\\n float fR0;\\n float fSmoothness;\\n vec2 vParam;\\n};\\n\\nstruct C_Shading\\n{\\n vec3 cDiffuse;\\n vec3 cSpecular;\\n};\\n\\nstruct C_PointLight\\n{\\n vec3 vPos;\\n vec3 cColour;\\n};\\n\\nstruct C_DirectionalLight\\n{\\n vec3 vDir;\\n vec3 cColour;\\n};\\n\\nvec3 RotateX( const in vec3 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec3 vResult = vec3( vPos.x, c * vPos.y + s * vPos.z, -s * vPos.y + c * vPos.z);\\n \\n return vResult;\\n}\\n\\nvec3 RotateY( const in vec3 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec3 vResult = vec3( c * vPos.x + s * vPos.z, vPos.y, -s * vPos.x + c * vPos.z);\\n \\n return vResult;\\n}\\n\\nvec3 RotateZ( const in vec3 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec3 vResult = vec3( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y, vPos.z);\\n \\n return vResult;\\n}\\n\\n/////////////////////////////////////\\n// Distance Field CSG\\n// These carry with them the material parameters in yzw\\n\\nvec4 DistCombineUnion( const in vec4 v1, const in vec4 v2 )\\n{\\n //if(v1.x < v2.x) return v1; else return v2;\\n return mix(v1, v2, step(v2.x, v1.x));\\n}\\n\\nvec4 DistCombineUnionConditional( const in vec4 v1, const in vec4 v2, const in float fCondition )\\n{ \\n\\t//if( fCondition < 0.0 )\\n\\t// return v1;\\n \\n return mix(v1, v2, step(v2.x, v1.x) * step(0.0, fCondition));\\n}\\n\\nvec4 DistCombineIntersect( const in vec4 v1, const in vec4 v2 )\\n{\\n return mix(v2, v1, step(v2.x,v1.x));\\n}\\n\\nvec4 DistCombineSubtract( const in vec4 v1, const in vec4 v2 )\\n{\\n return DistCombineIntersect(v1, vec4(-v2.x, v2.yzw));\\n}\\n\\nvec3 DomainRepeatXZGetTile( const in vec3 vPos, const in vec2 vRepeat, out vec2 vTile )\\n{\\n\\tvec3 vResult = vPos;\\n\\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\\n\\tvTile = floor(vTilePos + 1000.0);\\n\\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\\n\\treturn vResult;\\n}\\n\\nvec3 DomainRepeatXZ( const in vec3 vPos, const in vec2 vRepeat )\\n{\\n\\tvec3 vResult = vPos;\\n\\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\\n\\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\\n\\treturn vResult;\\n}\\n\\nvec3 DomainRepeatY( const in vec3 vPos, const in float fSize )\\n{\\n\\tvec3 vResult = vPos;\\n\\tvResult.y = (fract(vPos.y / fSize + 0.5) - 0.5) * fSize;\\n\\treturn vResult;\\n}\\n\\nvec3 DomainRotateSymmetry( const in vec3 vPos, const in float fSteps )\\n{\\n\\tfloat angle = atan( vPos.x, vPos.z );\\n\\t\\n\\tfloat fScale = fSteps / (kPI * 2.0);\\n\\tfloat steppedAngle = (floor(angle * fScale + 0.5)) / fScale;\\n\\t\\n\\tfloat s = sin(-steppedAngle);\\n\\tfloat c = cos(-steppedAngle);\\n\\t\\n\\tvec3 vResult = vec3( c * vPos.x + s * vPos.z, \\n\\t\\t\\t vPos.y,\\n\\t\\t\\t -s * vPos.x + c * vPos.z);\\n\\t\\n\\treturn vResult;\\n}\\n\\nfloat GetDistanceXYTorus( const in vec3 p, const in float r1, const in float r2 )\\n{\\n vec2 q = vec2(length(p.xy)-r1,p.z);\\n return length(q)-r2;\\n}\\n\\nfloat GetDistanceYZTorus( const in vec3 p, const in float r1, const in float r2 )\\n{\\n vec2 q = vec2(length(p.yz)-r1,p.x);\\n return length(q)-r2;\\n}\\n\\nfloat GetDistanceCylinderY(const in vec3 vPos, const in float r)\\n{\\n\\treturn length(vPos.xz) - r;\\n}\\n\\nfloat GetDistanceChain( const in vec3 vPos )\\n{\\n\\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\\n\\tif(fOuterCylinder > 0.5)\\n\\t{\\n\\t\\treturn fOuterCylinder;\\n\\t}\\n\\t\\n\\tvec3 vChainDomain = vPos;\\n\\t\\n\\tvChainDomain.y = fract(vChainDomain.y + 0.5) - 0.5;\\t\\t\\n\\tfloat fDistTorus1 = GetDistanceXYTorus(vChainDomain, 0.35, 0.1);\\n\\t\\n\\tvChainDomain.y = fract(vChainDomain.y + 1.0) - 0.5;\\t\\t\\n\\tfloat fDistTorus2 = GetDistanceYZTorus(vChainDomain, 0.35, 0.1);\\n\\t\\n\\tfloat fDist = min(fDistTorus1, fDistTorus2);\\n\\n\\treturn fDist;\\n}\\n\\nfloat GetDistanceGear( const in vec3 vPos )\\n{\\n\\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\\n\\tif(fOuterCylinder > 0.5)\\n\\t{\\n\\t\\treturn fOuterCylinder;\\n\\t}\\n\\t\\n\\tvec3 vToothDomain = DomainRotateSymmetry(vPos, 16.0);\\n\\tvToothDomain.xz = abs(vToothDomain.xz);\\n\\tfloat fGearDist = dot(vToothDomain.xz,normalize(vec2(1.0, 0.55))) - 0.55;\\n\\tfloat fSlabDist = abs(vPos.y + 0.1) - 0.15;\\n\\t\\n\\tvec3 vHoleDomain = abs(vPos);\\n\\tvHoleDomain -= 0.35;\\n\\tfloat fHoleDist = length(vHoleDomain.xz) - 0.2;\\n\\t\\n\\tfloat fBarDist =vToothDomain.z - 0.15;\\n\\tfBarDist = max(vPos.y - 0.1, fBarDist);\\n\\t\\n\\tfloat fResult = fGearDist;\\n\\tfResult = max(fResult, fSlabDist);\\n\\tfResult = max(fResult, fOuterCylinder);\\n\\tfResult = max(fResult, -fHoleDist);\\n\\tfResult = min(fResult, fBarDist);\\n\\treturn fResult;\\n}\\n\\nvec4 GetDistanceScene( const in vec3 vPos )\\n{ \\t\\n\\tvec2 vChainTile;\\n\\tvec2 vRepeat = vec2(4.0, 8.0);\\n\\tvec3 vRepeatDomain = DomainRepeatXZGetTile(vPos, vRepeat, vChainTile);\\n\\t\\t\\n\\tvec4 vDistFloor = vec4(vPos.y + 0.5, 1.0, vec2(0.0));\\n\\tvec4 vResult = vDistFloor;\\n\\t{\\n\\t\\tvec3 vGearDomain1 = DomainRepeatXZ(vPos+vec3(0.0, 0.0, 4.0), vRepeat);\\n\\t\\tvGearDomain1 = RotateY( vGearDomain1, iGlobalTime);\\n\\t\\tvec4 vDistGear = vec4(GetDistanceGear(vGearDomain1), 3.0, vec2(0.0));\\n\\t\\tvResult = DistCombineUnion( vResult, vDistGear );\\n\\t\\t\\n\\t\\tvec3 vGearDomain2 = DomainRepeatXZ(vPos+vec3(2.0, 0.0, 4.0), vRepeat);\\n\\t\\tvGearDomain2 = RotateY( vGearDomain2, -iGlobalTime + (2.0 * kPI / 32.0));\\n\\t\\tvec4 vDistGear2 = vec4(GetDistanceGear(vGearDomain2), 3.0, vec2(0.0));\\t\\t\\n\\t\\tvResult = DistCombineUnion( vResult, vDistGear2 );\\n\\t\\t\\n\\t}\\n\\n\\t{\\n\\t\\tvec4 vDistChainHole = vec4( GetDistanceCylinderY(vRepeatDomain, 0.7), 2.0, vec2(0.0));\\n\\t\\tvResult = DistCombineSubtract( vResult, vDistChainHole );\\n\\n\\t\\tvec3 vChainDomain = vRepeatDomain;\\n\\t\\tfloat fSpeed = (sin(vChainTile.y + vChainTile.x) + 1.1) * 0.5;\\n\\t\\tvChainDomain.y += sin(iGlobalTime * fSpeed);\\n\\t\\tvec4 vDistChain = vec4( GetDistanceChain(vChainDomain), 4.0, vec2(0.0));\\n\\t\\tvResult = DistCombineUnion( vResult, vDistChain );\\n\\t}\\n\\treturn vResult;\\n}\\n\\nC_Material GetObjectMaterial( const in C_HitInfo hitInfo )\\n{\\n\\tC_Material mat;\\n\\n\\tif(hitInfo.vObjectId.x < 1.5)\\n\\t{\\n\\t\\t// floor\\n\\t\\tmat.fR0 = 0.02;\\n\\t\\tmat.fSmoothness = 0.8;\\n\\t\\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\\n\\t}\\n\\telse\\n\\tif(hitInfo.vObjectId.x < 2.5)\\n\\t{\\n\\t\\t// hole interior\\n\\t\\tmat.fR0 = 0.0;\\n\\t\\tmat.fSmoothness = 0.0;\\n\\t\\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\\n\\t}\\n\\telse\\n\\tif(hitInfo.vObjectId.x < 3.5)\\n\\t{\\n\\t\\t// gear\\n\\t\\tmat.fR0 = 0.4;\\n\\t\\tmat.fSmoothness = 0.7;\\n\\t\\tmat.cAlbedo = vec3(0.5, 0.6, 0.6);\\n\\t}\\n\\telse\\n\\t{\\n\\t\\t// chain\\n\\t\\tmat.fR0 = 0.2;\\n\\t\\tmat.fSmoothness = 0.1;\\n\\t\\tmat.cAlbedo = vec3(0.15, 0.125, 0.1);\\n\\t}\\n\\t\\n\\treturn mat;\\n}\\n\\nfloat GetRayFirstStep( const in C_Ray ray )\\n{\\n return ray.fStartDistance; \\n}\\n\\n\\nvec3 GetSkyGradient( const in vec3 vDir )\\n{\\n const vec3 cColourTop = vec3(0.7, 0.9, 1.0);\\n const vec3 cColourHorizon = vec3(0.2, 0.3, 0.4);\\n\\n float fBlend = clamp(vDir.y, 0.0, 1.0);\\n return mix(cColourHorizon, cColourTop, fBlend);\\n}\\n\\nC_PointLight GetPointLight()\\n{\\n C_PointLight result;\\n\\n result.vPos = vec3(sin(iGlobalTime), 2.0 + cos(iGlobalTime * 1.231), cos(iGlobalTime));\\n result.cColour = vec3(32.0, 6.0, 1.0);\\n\\n return result;\\n}\\n\\nC_DirectionalLight GetDirectionalLight()\\n{\\n C_DirectionalLight result;\\n\\n result.vDir = normalize(vec3(-0.2, -0.3, 0.5));\\n result.cColour = vec3(8.0, 7.5, 7.0);\\n\\n return result;\\n}\\n\\nvec3 GetAmbientLight(const in vec3 vNormal)\\n{\\n return GetSkyGradient(vNormal);\\n}\\n\\n/////////////////////////////////////\\n// Raymarching \\n\\nvec3 GetSceneNormal( const in vec3 vPos )\\n{\\n // tetrahedron normal\\n const float fDelta = 0.01;\\n\\n vec3 vOffset1 = vec3( fDelta, -fDelta, -fDelta);\\n vec3 vOffset2 = vec3(-fDelta, -fDelta, fDelta);\\n vec3 vOffset3 = vec3(-fDelta, fDelta, -fDelta);\\n vec3 vOffset4 = vec3( fDelta, fDelta, fDelta);\\n\\n float f1 = GetDistanceScene( vPos + vOffset1 ).x;\\n float f2 = GetDistanceScene( vPos + vOffset2 ).x;\\n float f3 = GetDistanceScene( vPos + vOffset3 ).x;\\n float f4 = GetDistanceScene( vPos + vOffset4 ).x;\\n\\n vec3 vNormal = vOffset1 * f1 + vOffset2 * f2 + vOffset3 * f3 + vOffset4 * f4;\\n\\n return normalize( vNormal );\\n}\\n\\n#define kRaymarchEpsilon 0.01\\n// This is an excellent resource on ray marching -> http://www.iquilezles.org/www/articles/distfunctions/distfunctions.htm\\nvoid Raymarch( const in C_Ray ray, out C_HitInfo result, const int maxIter )\\n{ \\n result.fDistance = GetRayFirstStep( ray );\\n result.vObjectId.x = 0.0;\\n \\n for(int i=0;i<=kRaymarchMaxIter;i++) \\n {\\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\\n vec4 vSceneDist = GetDistanceScene( result.vPos );\\n result.vObjectId = vSceneDist.yzw;\\n \\n // abs allows backward stepping - should only be necessary for non uniform distance functions\\n if((abs(vSceneDist.x) <= kRaymarchEpsilon) || (result.fDistance >= ray.fLength) || (i > maxIter))\\n {\\n break;\\n } \\n\\n result.fDistance = result.fDistance + vSceneDist.x; \\n }\\n\\n\\n if(result.fDistance >= ray.fLength)\\n {\\n result.fDistance = 1000.0;\\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\\n result.vObjectId.x = 0.0;\\n }\\n}\\n\\nfloat GetShadow( const in vec3 vPos, const in vec3 vNormal, const in vec3 vLightDir, const in float fLightDistance )\\n{\\n #ifdef ENABLE_SHADOWS\\n\\t\\tC_Ray shadowRay;\\n\\t\\tshadowRay.vDir = vLightDir;\\n\\t\\tshadowRay.vOrigin = vPos;\\n\\t\\tconst float fShadowBias = 0.05;\\n\\t\\tshadowRay.fStartDistance = fShadowBias / abs(dot(vLightDir, vNormal));\\n\\t\\tshadowRay.fLength = fLightDistance - shadowRay.fStartDistance;\\n\\t\\n\\t\\tC_HitInfo shadowIntersect;\\n\\t\\tRaymarch(shadowRay, shadowIntersect, 32);\\n\\t\\t\\n\\t\\tfloat fShadow = step(0.0, shadowIntersect.fDistance) * step(fLightDistance, shadowIntersect.fDistance );\\n\\t\\t\\n\\t\\treturn fShadow; \\n #else\\n \\treturn 1.0;\\n #endif\\n}\\n\\n// use distance field to evaluate ambient occlusion\\nfloat GetAmbientOcclusion(const in C_HitInfo intersection, const in C_Surface surface)\\n{\\n #ifdef ENABLE_AMBIENT_OCCLUSION \\n\\t\\tvec3 vPos = intersection.vPos;\\n\\t\\tvec3 vNormal = surface.vNormal;\\n\\t\\n\\t\\tfloat fAmbientOcclusion = 1.0;\\n\\t\\n\\t\\tfloat fDist = 0.0;\\n\\t\\tfor(int i=0; i<=5; i++)\\n\\t\\t{\\n\\t\\t\\tfDist += 0.1;\\n\\t\\n\\t\\t\\tvec4 vSceneDist = GetDistanceScene(vPos + vNormal * fDist);\\n\\t\\n\\t\\t\\tfAmbientOcclusion *= 1.0 - max(0.0, (fDist - vSceneDist.x) * 0.2 / fDist ); \\n\\t\\t}\\n\\t\\n\\t\\treturn fAmbientOcclusion;\\n #else\\n\\t return 1.0;\\n #endif \\n}\\n\\n/////////////////////////////////////\\n// Lighting and Shading\\n\\n#define kFogDensity 0.1\\n\\nvoid ApplyAtmosphere(inout vec3 col, const in C_Ray ray, const in C_HitInfo hitInfo)\\n{\\n #ifdef ENABLE_FOG\\n // fog\\n float fFogAmount = exp(hitInfo.fDistance * -kFogDensity);\\n vec3 cFog = GetSkyGradient(ray.vDir);\\n\\n #ifdef ENABLE_DIRECTIONAL_LIGHT_FLARE\\n C_DirectionalLight directionalLight = GetDirectionalLight();\\n float fDirDot = clamp(dot(-directionalLight.vDir, ray.vDir), 0.0, 1.0);\\n cFog += directionalLight.cColour * pow(fDirDot, 10.0);\\n #endif \\n\\n col = mix(cFog, col, fFogAmount);\\n #endif\\n\\n // glare from light (a bit hacky - use length of closest approach from ray to light)\\n #ifdef ENABLE_POINT_LIGHT_FLARE\\n C_PointLight pointLight = GetPointLight();\\n\\n vec3 vToLight = pointLight.vPos - ray.vOrigin;\\n float fPointDot = dot(vToLight, ray.vDir);\\n fPointDot = clamp(fPointDot, 0.0, hitInfo.fDistance);\\n\\n vec3 vClosestPoint = ray.vOrigin + ray.vDir * fPointDot;\\n float fDist = length(vClosestPoint - pointLight.vPos);\\n col += pointLight.cColour * 0.01/ (fDist * fDist);\\n #endif \\n}\\n\\n// http://en.wikipedia.org/wiki/Schlick's_approximation\\nfloat Schlick( const in vec3 vNormal, const in vec3 vView, const in float fR0, const in float fSmoothFactor)\\n{\\n float fDot = dot(vNormal, -vView);\\n fDot = clamp((1.0 - fDot), 0.0, 1.0);\\n float fDotPow = pow(fDot, 5.0);\\n return fR0 + (1.0 - fR0) * fDotPow * fSmoothFactor;\\n}\\n\\nvec3 ApplyFresnel(const in vec3 vDiffuse, const in vec3 vSpecular, const in vec3 vNormal, const in vec3 vView, const in C_Material material)\\n{\\n float fFresnel = Schlick(vNormal, vView, material.fR0, material.fSmoothness * 0.9 + 0.1);\\n return mix(vDiffuse, vSpecular, fFresnel); \\n}\\n\\nfloat GetBlinnPhongIntensity(const in vec3 vIncidentDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness)\\n{ \\n vec3 vHalf = normalize(vLightDir - vIncidentDir);\\n float fNdotH = max(0.0, dot(vHalf, vNormal));\\n\\n float fSpecPower = exp2(4.0 + 6.0 * fSmoothness);\\n float fSpecIntensity = (fSpecPower + 2.0) * 0.125;\\n\\n return pow(fNdotH, fSpecPower) * fSpecIntensity;\\n}\\n\\nC_Shading ApplyPointLight( const in C_PointLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\\n{\\n C_Shading shading;\\n \\n vec3 vToLight = light.vPos - vSurfacePos;\\n vec3 vLightDir = normalize(vToLight);\\n float fLightDistance = length(vToLight);\\n \\n float fAttenuation = 1.0 / (fLightDistance * fLightDistance);\\n \\n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, fLightDistance );\\n vec3 vIncidentLight = light.cColour * fShadowFactor * fAttenuation * max(0.0, dot(vLightDir, vNormal));\\n \\n shading.cDiffuse = vIncidentLight; \\n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\\n \\n return shading;\\n} \\n\\nC_Shading ApplyDirectionalLight( const in C_DirectionalLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\\n{\\n C_Shading shading;\\n\\n const float kShadowRayLength = 10.0; \\n vec3 vLightDir = -light.vDir;\\n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, kShadowRayLength );\\n vec3 vIncidentLight = light.cColour * fShadowFactor * max(0.0, dot(vLightDir, vNormal));\\n \\n shading.cDiffuse = vIncidentLight; \\n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\\n \\n return shading;\\n} \\n\\n\\nvec3 ShadeSurface(const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface, const in C_Material material)\\n{\\n vec3 cScene;\\n \\n C_Shading shading;\\n\\n shading.cDiffuse = vec3(0.0);\\n shading.cSpecular = vec3(0.0);\\n \\n float fAmbientOcclusion = GetAmbientOcclusion(hitInfo, surface);\\n vec3 vAmbientLight = GetAmbientLight(surface.vNormal) * fAmbientOcclusion;\\n \\n shading.cDiffuse += vAmbientLight;\\n shading.cSpecular += surface.cReflection;\\n \\n #ifdef ENABLE_POINT_LIGHT\\n C_PointLight pointLight = GetPointLight(); \\n C_Shading pointLighting = ApplyPointLight(pointLight, hitInfo.vPos,ray.vDir, surface.vNormal, material);\\n shading.cDiffuse += pointLighting.cDiffuse;\\n shading.cSpecular += pointLighting.cSpecular;\\n #endif\\n\\n #ifdef ENABLE_DIRECTIONAL_LIGHT\\n\\tC_DirectionalLight directionalLight = GetDirectionalLight();\\n C_Shading directionLighting = ApplyDirectionalLight(directionalLight, hitInfo.vPos, ray.vDir, surface.vNormal, material);\\n shading.cDiffuse += directionLighting.cDiffuse;\\n shading.cSpecular += directionLighting.cSpecular;\\n #endif\\n\\t\\n\\t// fire in the hole\\n\\tshading.cDiffuse += clamp(-hitInfo.vPos.y - 0.5, 0.0, 1.0) * vec3(5.0, 0.25, 0.05);\\n\\n vec3 vDiffuseReflection = shading.cDiffuse * material.cAlbedo; \\n\\n #ifdef ENABLE_SPECULAR\\n cScene = ApplyFresnel(vDiffuseReflection , shading.cSpecular, surface.vNormal, ray.vDir, material);\\n #else\\n cScene = vDiffuseReflection;\\n #endif\\n \\n return cScene;\\n}\\n\\nvec3 GetSceneColourSecondary( const in C_Ray ray );\\n\\nvec3 GetReflection( const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface )\\n{\\n #ifdef ENABLE_REFLECTIONS \\n {\\n // get colour from reflected ray\\n const float fSeparation = 0.1;\\n\\n C_Ray reflectRay;\\n reflectRay.vDir = reflect(ray.vDir, surface.vNormal);\\n reflectRay.vOrigin = hitInfo.vPos;\\n reflectRay.fLength = 16.0;\\n reflectRay.fStartDistance = fSeparation / abs(dot(reflectRay.vDir, surface.vNormal));\\n \\n return GetSceneColourSecondary(reflectRay); \\n }\\n #else\\n return GetSkyGradient(reflect(ray.vDir, surface.vNormal)); \\n #endif\\n}\\n\\n// no reflections, no transparency, used for secondary rays\\nvec3 GetSceneColourSecondary( const in C_Ray ray )\\n{\\n C_HitInfo hitInfo;\\n Raymarch(ray, hitInfo, 32);\\n \\n vec3 cScene;\\n\\n if(hitInfo.vObjectId.x < 0.5)\\n {\\n cScene = GetSkyGradient(ray.vDir);\\n }\\n else\\n {\\n C_Surface surface; \\n surface.vNormal = GetSceneNormal(hitInfo.vPos);\\n\\n C_Material material = GetObjectMaterial(hitInfo);\\n\\n // use sky gradient instead of reflection\\n surface.cReflection = GetSkyGradient(reflect(ray.vDir, surface.vNormal));\\n\\n // apply lighting\\n cScene = ShadeSurface(ray, hitInfo, surface, material);\\n }\\n\\n ApplyAtmosphere(cScene, ray, hitInfo);\\n\\n return cScene;\\n}\\n\\nvec3 GetSceneColourPrimary( const in C_Ray ray )\\n{ \\n C_HitInfo intersection;\\n Raymarch(ray, intersection, 256);\\n \\n vec3 cScene;\\n\\n if(intersection.vObjectId.x < 0.5)\\n {\\n cScene = GetSkyGradient(ray.vDir);\\n }\\n else\\n {\\n C_Surface surface;\\n \\n surface.vNormal = GetSceneNormal(intersection.vPos);\\n\\n C_Material material = GetObjectMaterial(intersection);\\n\\n surface.cReflection = GetReflection(ray, intersection, surface);\\n\\n // apply lighting\\n cScene = ShadeSurface(ray, intersection, surface, material);\\n }\\n\\n ApplyAtmosphere(cScene, ray, intersection);\\n\\n return cScene;\\n}\\n\\nfloat kFarClip = 30.0;\\n\\nvoid GetCameraRay( const in vec3 vPos, const in vec3 vForwards, const in vec3 vWorldUp, const in vec2 fragCoord, out C_Ray ray)\\n{\\n vec2 vUV = ( fragCoord.xy / iResolution.xy );\\n vec2 vViewCoord = vUV * 2.0 - 1.0;\\n\\n float fRatio = iResolution.x / iResolution.y;\\n vViewCoord.y /= fRatio; \\n\\n ray.vOrigin = vPos;\\n\\n vec3 vRight = normalize(cross(vForwards, vWorldUp));\\n vec3 vUp = cross(vRight, vForwards);\\n \\n ray.vDir = normalize( vRight * vViewCoord.x + vUp * vViewCoord.y + vForwards); \\n ray.fStartDistance = 0.0;\\n ray.fLength = kFarClip; \\n}\\n\\nvoid GetCameraRayLookat( const in vec3 vPos, const in vec3 vInterest, const in vec2 fragCoord, out C_Ray ray)\\n{\\n vec3 vForwards = normalize(vInterest - vPos);\\n vec3 vUp = vec3(0.0, 1.0, 0.0);\\n\\n GetCameraRay(vPos, vForwards, vUp, fragCoord, ray);\\n}\\n\\nvec3 OrbitPoint( const in float fHeading, const in float fElevation )\\n{\\n return vec3(sin(fHeading) * cos(fElevation), sin(fElevation), cos(fHeading) * cos(fElevation));\\n}\\n\\nvec3 Gamma( const in vec3 cCol )\\n{\\n return sqrt(cCol);\\n}\\n\\nvec3 Tonemap( const in vec3 cCol )\\n{\\n vec3 vResult = 1.0 - exp2(-cCol);\\n\\n return vResult;\\n}\\n\\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord )\\n{\\n C_Ray ray;\\n\\n \\tGetCameraRayLookat( OrbitPoint(iGlobalTime * 0.3, cos(iGlobalTime * 0.2) * 0.3 + 0.4) * 7.0, vec3(0.0, 0.0, 0.0), fragCoord, ray);\\n\\n vec3 cScene = GetSceneColourPrimary( ray ); \\n\\n const float fExposure = 1.5; \\n fragColor = vec4( Tonemap(cScene * fExposure), 1.0 );\\n}\\n\\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \\n// End pasted shadertoy code\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n// Silly Shadertoy adapter \n\n// based on https://www.shadertoy.com/view/Msl3Rn\n// chains and gears - @P_Malin\n\n// Shadertoy variables:\n#define iResolution vec2(1024.0, 1024.0)\n#define iGlobalTime time\n\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord );\n\n//#define RANDOM_POSITIONS\n\n#ifdef RANDOM_POSITIONS\n\n#define MOD3 vec3(.1031,.11369,.13787)\n#define MOD4 vec4(.1031,.11369,.13787, .09987)\n\nvec2 hash21(float p)\n{\n\tvec3 p3 = fract(vec3(p) * MOD3);\n\tp3 += dot(p3, p3.yzx + 19.19);\n\treturn fract(vec2((p3.x + p3.y)*p3.z, (p3.x+p3.z)*p3.y));\n}\n\n#endif // RANDOM_POSITIONS\n\nvoid main() \n{ \n\tvec2 vDim = vec2( 160.0, 100.0 );\n\n\tfloat fQuadIndex = floor(vertexId / 6.0);\n\n\tvec2 vUV;\n\n\tvUV.x = mod( fQuadIndex, vDim.x );\n\tvUV.y = fQuadIndex / vDim.x;\n\n\tvUV = vUV / vDim;\n \n#ifdef RANDOM_POSITIONS\n \tvUV = hash21( fQuadIndex );\n#endif // RANDOM_POSITIONS \n\n\tfloat triVert = mod( vertexId, 6.0 );\n\tfloat quadVert = mod( vertexId, 3.0 );\n\n\tif( triVert >= 3.0 )\n\t{\n quadVert = quadVert + 1.0;\n\t}\n\n\tvec2 vSize = 1.0 / vDim;\n\tif( quadVert < 0.5 )\n\t{\n vUV += vec2(0.0, 0.0);\n\t}\n\telse if( quadVert < 1.5 )\n\t{\n vUV += vec2(vSize.x, 0.0);\n\t}\n\telse if( quadVert < 2.5 )\n\t{\n vUV += vec2(0.0, vSize.y);\n\t}\n\telse if( quadVert < 3.5 )\n\t{\n vUV += vec2(vSize.x, vSize.y);\n\t}\n \n\tmainImage( v_color, vUV * iResolution );\n\n gl_Position = vec4(vUV * 2.0 - 1.0, 0, 1); \n}\n\n// Pasted shadertoy code here\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \n\n// Shadertoy adapter \n\n// based on https://www.shadertoy.com/view/Msl3Rn\n// chains and gears - @P_Malin\n\n#define ENABLE_AMBIENT_OCCLUSION\n#define ENABLE_SPECULAR\n#define ENABLE_REFLECTIONS\n#define ENABLE_SHADOWS\n#define ENABLE_FOG\n\n//#define ENABLE_DIRECTIONAL_LIGHT\n//#define ENABLE_DIRECTIONAL_LIGHT_FLARE\n\n#define ENABLE_POINT_LIGHT\n//#define ENABLE_POINT_LIGHT_FLARE\n\n#define kRaymarchMaxIter 28\n\nconst float kPI = 3.141592654;\nconst float kTwoPI = kPI * 2.0;\n\nstruct C_Ray\n{\n vec3 vOrigin;\n vec3 vDir;\n float fStartDistance;\n float fLength;\n};\n\nstruct C_HitInfo\n{\n vec3 vPos;\n float fDistance;\n vec3 vObjectId;\n};\n \nstruct C_Surface\n{\n vec3 vNormal;\n vec3 cReflection;\n vec3 cTransmission; \n};\n\nstruct C_Material\n{\n vec3 cAlbedo;\n float fR0;\n float fSmoothness;\n vec2 vParam;\n};\n\nstruct C_Shading\n{\n vec3 cDiffuse;\n vec3 cSpecular;\n};\n\nstruct C_PointLight\n{\n vec3 vPos;\n vec3 cColour;\n};\n\nstruct C_DirectionalLight\n{\n vec3 vDir;\n vec3 cColour;\n};\n\nvec3 RotateX( const in vec3 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec3 vResult = vec3( vPos.x, c * vPos.y + s * vPos.z, -s * vPos.y + c * vPos.z);\n \n return vResult;\n}\n\nvec3 RotateY( const in vec3 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec3 vResult = vec3( c * vPos.x + s * vPos.z, vPos.y, -s * vPos.x + c * vPos.z);\n \n return vResult;\n}\n\nvec3 RotateZ( const in vec3 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec3 vResult = vec3( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y, vPos.z);\n \n return vResult;\n}\n\n/////////////////////////////////////\n// Distance Field CSG\n// These carry with them the material parameters in yzw\n\nvec4 DistCombineUnion( const in vec4 v1, const in vec4 v2 )\n{\n //if(v1.x < v2.x) return v1; else return v2;\n return mix(v1, v2, step(v2.x, v1.x));\n}\n\nvec4 DistCombineUnionConditional( const in vec4 v1, const in vec4 v2, const in float fCondition )\n{ \n\t//if( fCondition < 0.0 )\n\t// return v1;\n \n return mix(v1, v2, step(v2.x, v1.x) * step(0.0, fCondition));\n}\n\nvec4 DistCombineIntersect( const in vec4 v1, const in vec4 v2 )\n{\n return mix(v2, v1, step(v2.x,v1.x));\n}\n\nvec4 DistCombineSubtract( const in vec4 v1, const in vec4 v2 )\n{\n return DistCombineIntersect(v1, vec4(-v2.x, v2.yzw));\n}\n\nvec3 DomainRepeatXZGetTile( const in vec3 vPos, const in vec2 vRepeat, out vec2 vTile )\n{\n\tvec3 vResult = vPos;\n\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\n\tvTile = floor(vTilePos + 1000.0);\n\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\n\treturn vResult;\n}\n\nvec3 DomainRepeatXZ( const in vec3 vPos, const in vec2 vRepeat )\n{\n\tvec3 vResult = vPos;\n\tvec2 vTilePos = (vPos.xz / vRepeat) + 0.5;\n\tvResult.xz = (fract(vTilePos) - 0.5) * vRepeat;\n\treturn vResult;\n}\n\nvec3 DomainRepeatY( const in vec3 vPos, const in float fSize )\n{\n\tvec3 vResult = vPos;\n\tvResult.y = (fract(vPos.y / fSize + 0.5) - 0.5) * fSize;\n\treturn vResult;\n}\n\nvec3 DomainRotateSymmetry( const in vec3 vPos, const in float fSteps )\n{\n\tfloat angle = atan( vPos.x, vPos.z );\n\t\n\tfloat fScale = fSteps / (kPI * 2.0);\n\tfloat steppedAngle = (floor(angle * fScale + 0.5)) / fScale;\n\t\n\tfloat s = sin(-steppedAngle);\n\tfloat c = cos(-steppedAngle);\n\t\n\tvec3 vResult = vec3( c * vPos.x + s * vPos.z, \n\t\t\t vPos.y,\n\t\t\t -s * vPos.x + c * vPos.z);\n\t\n\treturn vResult;\n}\n\nfloat GetDistanceXYTorus( const in vec3 p, const in float r1, const in float r2 )\n{\n vec2 q = vec2(length(p.xy)-r1,p.z);\n return length(q)-r2;\n}\n\nfloat GetDistanceYZTorus( const in vec3 p, const in float r1, const in float r2 )\n{\n vec2 q = vec2(length(p.yz)-r1,p.x);\n return length(q)-r2;\n}\n\nfloat GetDistanceCylinderY(const in vec3 vPos, const in float r)\n{\n\treturn length(vPos.xz) - r;\n}\n\nfloat GetDistanceChain( const in vec3 vPos )\n{\n\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\n\tif(fOuterCylinder > 0.5)\n\t{\n\t\treturn fOuterCylinder;\n\t}\n\t\n\tvec3 vChainDomain = vPos;\n\t\n\tvChainDomain.y = fract(vChainDomain.y + 0.5) - 0.5;\t\t\n\tfloat fDistTorus1 = GetDistanceXYTorus(vChainDomain, 0.35, 0.1);\n\t\n\tvChainDomain.y = fract(vChainDomain.y + 1.0) - 0.5;\t\t\n\tfloat fDistTorus2 = GetDistanceYZTorus(vChainDomain, 0.35, 0.1);\n\t\n\tfloat fDist = min(fDistTorus1, fDistTorus2);\n\n\treturn fDist;\n}\n\nfloat GetDistanceGear( const in vec3 vPos )\n{\n\tfloat fOuterCylinder = length(vPos.xz) - 1.05;\n\tif(fOuterCylinder > 0.5)\n\t{\n\t\treturn fOuterCylinder;\n\t}\n\t\n\tvec3 vToothDomain = DomainRotateSymmetry(vPos, 16.0);\n\tvToothDomain.xz = abs(vToothDomain.xz);\n\tfloat fGearDist = dot(vToothDomain.xz,normalize(vec2(1.0, 0.55))) - 0.55;\n\tfloat fSlabDist = abs(vPos.y + 0.1) - 0.15;\n\t\n\tvec3 vHoleDomain = abs(vPos);\n\tvHoleDomain -= 0.35;\n\tfloat fHoleDist = length(vHoleDomain.xz) - 0.2;\n\t\n\tfloat fBarDist =vToothDomain.z - 0.15;\n\tfBarDist = max(vPos.y - 0.1, fBarDist);\n\t\n\tfloat fResult = fGearDist;\n\tfResult = max(fResult, fSlabDist);\n\tfResult = max(fResult, fOuterCylinder);\n\tfResult = max(fResult, -fHoleDist);\n\tfResult = min(fResult, fBarDist);\n\treturn fResult;\n}\n\nvec4 GetDistanceScene( const in vec3 vPos )\n{ \t\n\tvec2 vChainTile;\n\tvec2 vRepeat = vec2(4.0, 8.0);\n\tvec3 vRepeatDomain = DomainRepeatXZGetTile(vPos, vRepeat, vChainTile);\n\t\t\n\tvec4 vDistFloor = vec4(vPos.y + 0.5, 1.0, vec2(0.0));\n\tvec4 vResult = vDistFloor;\n\t{\n\t\tvec3 vGearDomain1 = DomainRepeatXZ(vPos+vec3(0.0, 0.0, 4.0), vRepeat);\n\t\tvGearDomain1 = RotateY( vGearDomain1, iGlobalTime);\n\t\tvec4 vDistGear = vec4(GetDistanceGear(vGearDomain1), 3.0, vec2(0.0));\n\t\tvResult = DistCombineUnion( vResult, vDistGear );\n\t\t\n\t\tvec3 vGearDomain2 = DomainRepeatXZ(vPos+vec3(2.0, 0.0, 4.0), vRepeat);\n\t\tvGearDomain2 = RotateY( vGearDomain2, -iGlobalTime + (2.0 * kPI / 32.0));\n\t\tvec4 vDistGear2 = vec4(GetDistanceGear(vGearDomain2), 3.0, vec2(0.0));\t\t\n\t\tvResult = DistCombineUnion( vResult, vDistGear2 );\n\t\t\n\t}\n\n\t{\n\t\tvec4 vDistChainHole = vec4( GetDistanceCylinderY(vRepeatDomain, 0.7), 2.0, vec2(0.0));\n\t\tvResult = DistCombineSubtract( vResult, vDistChainHole );\n\n\t\tvec3 vChainDomain = vRepeatDomain;\n\t\tfloat fSpeed = (sin(vChainTile.y + vChainTile.x) + 1.1) * 0.5;\n\t\tvChainDomain.y += sin(iGlobalTime * fSpeed);\n\t\tvec4 vDistChain = vec4( GetDistanceChain(vChainDomain), 4.0, vec2(0.0));\n\t\tvResult = DistCombineUnion( vResult, vDistChain );\n\t}\n\treturn vResult;\n}\n\nC_Material GetObjectMaterial( const in C_HitInfo hitInfo )\n{\n\tC_Material mat;\n\n\tif(hitInfo.vObjectId.x < 1.5)\n\t{\n\t\t// floor\n\t\tmat.fR0 = 0.02;\n\t\tmat.fSmoothness = 0.8;\n\t\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\n\t}\n\telse\n\tif(hitInfo.vObjectId.x < 2.5)\n\t{\n\t\t// hole interior\n\t\tmat.fR0 = 0.0;\n\t\tmat.fSmoothness = 0.0;\n\t\tmat.cAlbedo = vec3(0.7, 0.8, 0.3);\n\t}\n\telse\n\tif(hitInfo.vObjectId.x < 3.5)\n\t{\n\t\t// gear\n\t\tmat.fR0 = 0.4;\n\t\tmat.fSmoothness = 0.7;\n\t\tmat.cAlbedo = vec3(0.5, 0.6, 0.6);\n\t}\n\telse\n\t{\n\t\t// chain\n\t\tmat.fR0 = 0.2;\n\t\tmat.fSmoothness = 0.1;\n\t\tmat.cAlbedo = vec3(0.15, 0.125, 0.1);\n\t}\n\t\n\treturn mat;\n}\n\nfloat GetRayFirstStep( const in C_Ray ray )\n{\n return ray.fStartDistance; \n}\n\n\nvec3 GetSkyGradient( const in vec3 vDir )\n{\n const vec3 cColourTop = vec3(0.7, 0.9, 1.0);\n const vec3 cColourHorizon = vec3(0.2, 0.3, 0.4);\n\n float fBlend = clamp(vDir.y, 0.0, 1.0);\n return mix(cColourHorizon, cColourTop, fBlend);\n}\n\nC_PointLight GetPointLight()\n{\n C_PointLight result;\n\n result.vPos = vec3(sin(iGlobalTime), 2.0 + cos(iGlobalTime * 1.231), cos(iGlobalTime));\n result.cColour = vec3(32.0, 6.0, 1.0);\n\n return result;\n}\n\nC_DirectionalLight GetDirectionalLight()\n{\n C_DirectionalLight result;\n\n result.vDir = normalize(vec3(-0.2, -0.3, 0.5));\n result.cColour = vec3(8.0, 7.5, 7.0);\n\n return result;\n}\n\nvec3 GetAmbientLight(const in vec3 vNormal)\n{\n return GetSkyGradient(vNormal);\n}\n\n/////////////////////////////////////\n// Raymarching \n\nvec3 GetSceneNormal( const in vec3 vPos )\n{\n // tetrahedron normal\n const float fDelta = 0.01;\n\n vec3 vOffset1 = vec3( fDelta, -fDelta, -fDelta);\n vec3 vOffset2 = vec3(-fDelta, -fDelta, fDelta);\n vec3 vOffset3 = vec3(-fDelta, fDelta, -fDelta);\n vec3 vOffset4 = vec3( fDelta, fDelta, fDelta);\n\n float f1 = GetDistanceScene( vPos + vOffset1 ).x;\n float f2 = GetDistanceScene( vPos + vOffset2 ).x;\n float f3 = GetDistanceScene( vPos + vOffset3 ).x;\n float f4 = GetDistanceScene( vPos + vOffset4 ).x;\n\n vec3 vNormal = vOffset1 * f1 + vOffset2 * f2 + vOffset3 * f3 + vOffset4 * f4;\n\n return normalize( vNormal );\n}\n\n#define kRaymarchEpsilon 0.01\n// This is an excellent resource on ray marching -> http://www.iquilezles.org/www/articles/distfunctions/distfunctions.htm\nvoid Raymarch( const in C_Ray ray, out C_HitInfo result, const int maxIter )\n{ \n result.fDistance = GetRayFirstStep( ray );\n result.vObjectId.x = 0.0;\n \n for(int i=0;i<=kRaymarchMaxIter;i++) \n {\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\n vec4 vSceneDist = GetDistanceScene( result.vPos );\n result.vObjectId = vSceneDist.yzw;\n \n // abs allows backward stepping - should only be necessary for non uniform distance functions\n if((abs(vSceneDist.x) <= kRaymarchEpsilon) || (result.fDistance >= ray.fLength) || (i > maxIter))\n {\n break;\n } \n\n result.fDistance = result.fDistance + vSceneDist.x; \n }\n\n\n if(result.fDistance >= ray.fLength)\n {\n result.fDistance = 1000.0;\n result.vPos = ray.vOrigin + ray.vDir * result.fDistance;\n result.vObjectId.x = 0.0;\n }\n}\n\nfloat GetShadow( const in vec3 vPos, const in vec3 vNormal, const in vec3 vLightDir, const in float fLightDistance )\n{\n #ifdef ENABLE_SHADOWS\n\t\tC_Ray shadowRay;\n\t\tshadowRay.vDir = vLightDir;\n\t\tshadowRay.vOrigin = vPos;\n\t\tconst float fShadowBias = 0.05;\n\t\tshadowRay.fStartDistance = fShadowBias / abs(dot(vLightDir, vNormal));\n\t\tshadowRay.fLength = fLightDistance - shadowRay.fStartDistance;\n\t\n\t\tC_HitInfo shadowIntersect;\n\t\tRaymarch(shadowRay, shadowIntersect, 32);\n\t\t\n\t\tfloat fShadow = step(0.0, shadowIntersect.fDistance) * step(fLightDistance, shadowIntersect.fDistance );\n\t\t\n\t\treturn fShadow; \n #else\n \treturn 1.0;\n #endif\n}\n\n// use distance field to evaluate ambient occlusion\nfloat GetAmbientOcclusion(const in C_HitInfo intersection, const in C_Surface surface)\n{\n #ifdef ENABLE_AMBIENT_OCCLUSION \n\t\tvec3 vPos = intersection.vPos;\n\t\tvec3 vNormal = surface.vNormal;\n\t\n\t\tfloat fAmbientOcclusion = 1.0;\n\t\n\t\tfloat fDist = 0.0;\n\t\tfor(int i=0; i<=5; i++)\n\t\t{\n\t\t\tfDist += 0.1;\n\t\n\t\t\tvec4 vSceneDist = GetDistanceScene(vPos + vNormal * fDist);\n\t\n\t\t\tfAmbientOcclusion *= 1.0 - max(0.0, (fDist - vSceneDist.x) * 0.2 / fDist ); \n\t\t}\n\t\n\t\treturn fAmbientOcclusion;\n #else\n\t return 1.0;\n #endif \n}\n\n/////////////////////////////////////\n// Lighting and Shading\n\n#define kFogDensity 0.1\n\nvoid ApplyAtmosphere(inout vec3 col, const in C_Ray ray, const in C_HitInfo hitInfo)\n{\n #ifdef ENABLE_FOG\n // fog\n float fFogAmount = exp(hitInfo.fDistance * -kFogDensity);\n vec3 cFog = GetSkyGradient(ray.vDir);\n\n #ifdef ENABLE_DIRECTIONAL_LIGHT_FLARE\n C_DirectionalLight directionalLight = GetDirectionalLight();\n float fDirDot = clamp(dot(-directionalLight.vDir, ray.vDir), 0.0, 1.0);\n cFog += directionalLight.cColour * pow(fDirDot, 10.0);\n #endif \n\n col = mix(cFog, col, fFogAmount);\n #endif\n\n // glare from light (a bit hacky - use length of closest approach from ray to light)\n #ifdef ENABLE_POINT_LIGHT_FLARE\n C_PointLight pointLight = GetPointLight();\n\n vec3 vToLight = pointLight.vPos - ray.vOrigin;\n float fPointDot = dot(vToLight, ray.vDir);\n fPointDot = clamp(fPointDot, 0.0, hitInfo.fDistance);\n\n vec3 vClosestPoint = ray.vOrigin + ray.vDir * fPointDot;\n float fDist = length(vClosestPoint - pointLight.vPos);\n col += pointLight.cColour * 0.01/ (fDist * fDist);\n #endif \n}\n\n// http://en.wikipedia.org/wiki/Schlick's_approximation\nfloat Schlick( const in vec3 vNormal, const in vec3 vView, const in float fR0, const in float fSmoothFactor)\n{\n float fDot = dot(vNormal, -vView);\n fDot = clamp((1.0 - fDot), 0.0, 1.0);\n float fDotPow = pow(fDot, 5.0);\n return fR0 + (1.0 - fR0) * fDotPow * fSmoothFactor;\n}\n\nvec3 ApplyFresnel(const in vec3 vDiffuse, const in vec3 vSpecular, const in vec3 vNormal, const in vec3 vView, const in C_Material material)\n{\n float fFresnel = Schlick(vNormal, vView, material.fR0, material.fSmoothness * 0.9 + 0.1);\n return mix(vDiffuse, vSpecular, fFresnel); \n}\n\nfloat GetBlinnPhongIntensity(const in vec3 vIncidentDir, const in vec3 vLightDir, const in vec3 vNormal, const in float fSmoothness)\n{ \n vec3 vHalf = normalize(vLightDir - vIncidentDir);\n float fNdotH = max(0.0, dot(vHalf, vNormal));\n\n float fSpecPower = exp2(4.0 + 6.0 * fSmoothness);\n float fSpecIntensity = (fSpecPower + 2.0) * 0.125;\n\n return pow(fNdotH, fSpecPower) * fSpecIntensity;\n}\n\nC_Shading ApplyPointLight( const in C_PointLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\n{\n C_Shading shading;\n \n vec3 vToLight = light.vPos - vSurfacePos;\n vec3 vLightDir = normalize(vToLight);\n float fLightDistance = length(vToLight);\n \n float fAttenuation = 1.0 / (fLightDistance * fLightDistance);\n \n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, fLightDistance );\n vec3 vIncidentLight = light.cColour * fShadowFactor * fAttenuation * max(0.0, dot(vLightDir, vNormal));\n \n shading.cDiffuse = vIncidentLight; \n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\n \n return shading;\n} \n\nC_Shading ApplyDirectionalLight( const in C_DirectionalLight light, const in vec3 vSurfacePos, const in vec3 vIncidentDir, const in vec3 vNormal, const in C_Material material )\n{\n C_Shading shading;\n\n const float kShadowRayLength = 10.0; \n vec3 vLightDir = -light.vDir;\n float fShadowFactor = GetShadow( vSurfacePos, vNormal, vLightDir, kShadowRayLength );\n vec3 vIncidentLight = light.cColour * fShadowFactor * max(0.0, dot(vLightDir, vNormal));\n \n shading.cDiffuse = vIncidentLight; \n shading.cSpecular = GetBlinnPhongIntensity( vIncidentDir, vLightDir, vNormal, material.fSmoothness ) * vIncidentLight;\n \n return shading;\n} \n\n\nvec3 ShadeSurface(const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface, const in C_Material material)\n{\n vec3 cScene;\n \n C_Shading shading;\n\n shading.cDiffuse = vec3(0.0);\n shading.cSpecular = vec3(0.0);\n \n float fAmbientOcclusion = GetAmbientOcclusion(hitInfo, surface);\n vec3 vAmbientLight = GetAmbientLight(surface.vNormal) * fAmbientOcclusion;\n \n shading.cDiffuse += vAmbientLight;\n shading.cSpecular += surface.cReflection;\n \n #ifdef ENABLE_POINT_LIGHT\n C_PointLight pointLight = GetPointLight(); \n C_Shading pointLighting = ApplyPointLight(pointLight, hitInfo.vPos,ray.vDir, surface.vNormal, material);\n shading.cDiffuse += pointLighting.cDiffuse;\n shading.cSpecular += pointLighting.cSpecular;\n #endif\n\n #ifdef ENABLE_DIRECTIONAL_LIGHT\n\tC_DirectionalLight directionalLight = GetDirectionalLight();\n C_Shading directionLighting = ApplyDirectionalLight(directionalLight, hitInfo.vPos, ray.vDir, surface.vNormal, material);\n shading.cDiffuse += directionLighting.cDiffuse;\n shading.cSpecular += directionLighting.cSpecular;\n #endif\n\t\n\t// fire in the hole\n\tshading.cDiffuse += clamp(-hitInfo.vPos.y - 0.5, 0.0, 1.0) * vec3(5.0, 0.25, 0.05);\n\n vec3 vDiffuseReflection = shading.cDiffuse * material.cAlbedo; \n\n #ifdef ENABLE_SPECULAR\n cScene = ApplyFresnel(vDiffuseReflection , shading.cSpecular, surface.vNormal, ray.vDir, material);\n #else\n cScene = vDiffuseReflection;\n #endif\n \n return cScene;\n}\n\nvec3 GetSceneColourSecondary( const in C_Ray ray );\n\nvec3 GetReflection( const in C_Ray ray, const in C_HitInfo hitInfo, const in C_Surface surface )\n{\n #ifdef ENABLE_REFLECTIONS \n {\n // get colour from reflected ray\n const float fSeparation = 0.1;\n\n C_Ray reflectRay;\n reflectRay.vDir = reflect(ray.vDir, surface.vNormal);\n reflectRay.vOrigin = hitInfo.vPos;\n reflectRay.fLength = 16.0;\n reflectRay.fStartDistance = fSeparation / abs(dot(reflectRay.vDir, surface.vNormal));\n \n return GetSceneColourSecondary(reflectRay); \n }\n #else\n return GetSkyGradient(reflect(ray.vDir, surface.vNormal)); \n #endif\n}\n\n// no reflections, no transparency, used for secondary rays\nvec3 GetSceneColourSecondary( const in C_Ray ray )\n{\n C_HitInfo hitInfo;\n Raymarch(ray, hitInfo, 32);\n \n vec3 cScene;\n\n if(hitInfo.vObjectId.x < 0.5)\n {\n cScene = GetSkyGradient(ray.vDir);\n }\n else\n {\n C_Surface surface; \n surface.vNormal = GetSceneNormal(hitInfo.vPos);\n\n C_Material material = GetObjectMaterial(hitInfo);\n\n // use sky gradient instead of reflection\n surface.cReflection = GetSkyGradient(reflect(ray.vDir, surface.vNormal));\n\n // apply lighting\n cScene = ShadeSurface(ray, hitInfo, surface, material);\n }\n\n ApplyAtmosphere(cScene, ray, hitInfo);\n\n return cScene;\n}\n\nvec3 GetSceneColourPrimary( const in C_Ray ray )\n{ \n C_HitInfo intersection;\n Raymarch(ray, intersection, 256);\n \n vec3 cScene;\n\n if(intersection.vObjectId.x < 0.5)\n {\n cScene = GetSkyGradient(ray.vDir);\n }\n else\n {\n C_Surface surface;\n \n surface.vNormal = GetSceneNormal(intersection.vPos);\n\n C_Material material = GetObjectMaterial(intersection);\n\n surface.cReflection = GetReflection(ray, intersection, surface);\n\n // apply lighting\n cScene = ShadeSurface(ray, intersection, surface, material);\n }\n\n ApplyAtmosphere(cScene, ray, intersection);\n\n return cScene;\n}\n\nfloat kFarClip = 30.0;\n\nvoid GetCameraRay( const in vec3 vPos, const in vec3 vForwards, const in vec3 vWorldUp, const in vec2 fragCoord, out C_Ray ray)\n{\n vec2 vUV = ( fragCoord.xy / iResolution.xy );\n vec2 vViewCoord = vUV * 2.0 - 1.0;\n\n float fRatio = iResolution.x / iResolution.y;\n vViewCoord.y /= fRatio; \n\n ray.vOrigin = vPos;\n\n vec3 vRight = normalize(cross(vForwards, vWorldUp));\n vec3 vUp = cross(vRight, vForwards);\n \n ray.vDir = normalize( vRight * vViewCoord.x + vUp * vViewCoord.y + vForwards); \n ray.fStartDistance = 0.0;\n ray.fLength = kFarClip; \n}\n\nvoid GetCameraRayLookat( const in vec3 vPos, const in vec3 vInterest, const in vec2 fragCoord, out C_Ray ray)\n{\n vec3 vForwards = normalize(vInterest - vPos);\n vec3 vUp = vec3(0.0, 1.0, 0.0);\n\n GetCameraRay(vPos, vForwards, vUp, fragCoord, ray);\n}\n\nvec3 OrbitPoint( const in float fHeading, const in float fElevation )\n{\n return vec3(sin(fHeading) * cos(fElevation), sin(fElevation), cos(fHeading) * cos(fElevation));\n}\n\nvec3 Gamma( const in vec3 cCol )\n{\n return sqrt(cCol);\n}\n\nvec3 Tonemap( const in vec3 cCol )\n{\n vec3 vResult = 1.0 - exp2(-cCol);\n\n return vResult;\n}\n\nvoid mainImage( out vec4 fragColor, in vec2 fragCoord )\n{\n C_Ray ray;\n\n \tGetCameraRayLookat( OrbitPoint(iGlobalTime * 0.3, cos(iGlobalTime * 0.2) * 0.3 + 0.4) * 7.0, vec3(0.0, 0.0, 0.0), fragCoord, ray);\n\n vec3 cScene = GetSceneColourPrimary( ray ); \n\n const float fExposure = 1.5; \n fragColor = vec4( Tonemap(cScene * fExposure), 1.0 );\n}\n\n// -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- 8< -------- \n// End pasted shadertoy code\n\n" + }, "screenshotDataId": "QXPY4MpY3jC7xdnPj", "views": { "$numberInt": "5927" diff --git a/art/xTioxG2q3bibRu5j8/art.json b/art/xTioxG2q3bibRu5j8/art.json index 8f1067eb..d40c8508 100644 --- a/art/xTioxG2q3bibRu5j8/art.json +++ b/art/xTioxG2q3bibRu5j8/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":99999,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\n#define RATE 2.9\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n fract(t+i*.18293) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.844+i*.76),\\n sin(t+i*.74553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n tan(t+i*1.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*fract(0.1492)*fract(0.999992);\\n}\\n\\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\\nvec3 posf(float t, float i) { return posf2(t*1.3*mouse.y,i) + posf0(t);}\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5*mouse.x));\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() { // more or less random movement\\n float t = time*.010;\\n float i = fract(240000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.799);\\n pos -= posf0(t);\\n pos += ofs;\\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n pos *=1.*atan(mouse.x-.6);\\n pos.z += 0.7;\\n pos.xy *= 0.6/pos.z-cos(mouse.y);\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 13.0/pos.z* 0.09;\\n\\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\\n}\"}", + "settings": { + "num": 99999, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\n#define RATE 2.9\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n fract(t+i*.18293) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.844+i*.76),\n sin(t+i*.74553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n tan(t+i*1.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*fract(0.1492)*fract(0.999992);\n}\n\nvec3 posf0(float t) { return posf2(t,-1.)*RATE;}\nvec3 posf(float t, float i) { return posf2(t*1.3*mouse.y,i) + posf0(t);}\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n vec3 posf = fract(pos+0.5)-0.5*atan(9000000.2);\n float l = length(posf)/fract(1.15*sin(.2)/tan(-0.5*mouse.x));\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() { // more or less random movement\n float t = time*.010;\n float i = fract(240000.6/vertexId*sin(vertexId))+tan(vertexId)*0.90+atan(-.5);\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.105,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.799);\n pos -= posf0(t);\n pos += ofs;\n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n pos *=1.*atan(mouse.x-.6);\n pos.z += 0.7;\n pos.xy *= 0.6/pos.z-cos(mouse.y);\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 13.0/pos.z* 0.09;\n\n v_color = vec4(fract(ofs/max(length(ofs),1e-9))*.3+.7,1)*vec4(0.357, 0.670, 0.97, 0.003);\n}" + }, "screenshotURL": "data/images/images-u3zz5zb0k6owsvpb2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xWrTfrQ2whCaGaGWK/art.json b/art/xWrTfrQ2whCaGaGWK/art.json index 4638e2c3..f9916288 100644 --- a/art/xWrTfrQ2whCaGaGWK/art.json +++ b/art/xWrTfrQ2whCaGaGWK/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":24542,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/non-records-1/1127-it-never-drops\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c =cos( angle );\\n \\t\\n return mat4( \\n c, 0, s, 0,\\n 0, 1, 0, 0,\\n s, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle * 33. );\\n float c = tan( angle /72. );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 10, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, -1, 0,\\n -1, 1, -0.5, 0,\\n2, 1, 0, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 1, 0,\\n 0, 1, 0, 0,\\n 0, -1, 1, -0.9,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.5, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0.5, 0,\\n 0, s, s-mouse.x, .31,\\n s-0.5, 0, s, 0,\\n 1, 0.5, 0, 0);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\\n\\treturn fract(p2.x / p2.y * 165.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.6;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 2., v- 11.1;\\n}\\n\\nfloat inv(float v) {\\n return 10. * v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\\n float s = sin(a);\\n float c = cos(v-a);\\n float x = c -v;\\n float y = s * v;\\n float z = -0.015;\\n pos = vec3(x, y, z); \\n uv = vec2(u, level);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sideId = floor(circleId / 3.0);\\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\\n float end = start + 5.;\\n //start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\\n offset.y += goop(circleId * time + 10.13) - 0.31;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\\n gl_PointSize = 5. -snd;\\n\\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\\n float sat = 1.5 + snd;\\n float val = 0.3 + snd * 3.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\\n}\"}", + "settings": { + "num": 24542, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/non-records-1/1127-it-never-drops", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 8.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.5, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c =cos( angle );\n \t\n return mat4( \n c, 0, s, 0,\n 0, 1, 0, 0,\n s, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle * 33. );\n float c = tan( angle /72. );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 10, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, -1, 0,\n -1, 1, -0.5, 0,\n2, 1, 0, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 1, 0,\n 0, 1, 0, 0,\n 0, -1, 1, -0.9,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.5, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0.5, 0,\n 0, s, s-mouse.x, .31,\n s-0.5, 0, s, 0,\n 1, 0.5, 0, 0);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 26.3983, p * 15.4427));\n p2 += dot(p2.yx, p2.xy - vec2(21.5351, 4.3137));\n\treturn fract(p2.x / p2.y * 165.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.6;\n}\n\nfloat p1m1(float v) {\n return v * 2., v- 11.1;\n}\n\nfloat inv(float v) {\n return 10. * v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 12.);\n float vy = mod(floor(id / 4.) - floor(id / 6.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 2.71);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 12.4);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) + tan(PI + 11.2 - PI) + (2.0 /v);\n float s = sin(a);\n float c = cos(v-a);\n float x = c -v;\n float y = s * v;\n float z = -0.015;\n pos = vec3(x, y, z); \n uv = vec2(u, level);\n}\n\nfloat goop(float t) {\n return sin(t) - sin(t * 0.07) + tan((t * 0.013) + mouse.y /t) * sin(t * 0.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sideId = floor(circleId / 3.0);\n float side = mix(-11., 5.3, step(0.1, mod(circleId, 1.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(1.3, 1.1, p1m1(sin(goop(circleId) * time - 3.1)));\n float start = fract(hash(circleId * 0.33) + cos(time * .83 + circleId) *2.1 +mouse.x);\n float end = start + 5.;\n //start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu - abs(uv.x * 11.8 - 10.3)/7.) * 0.5, uv.y * 0.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * .5, m1p1(hash(circleId - 1.7)), m1p1(circleId / numCircles));\n offset.x += goop(circleId + time - mouse.x + 0.103) * 0.4;\n offset.y += goop(circleId * time + 10.13) - 0.31;\n vec3 aspect = vec3(1, resolution.x / resolution.y, -11.51);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(.1, .2, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.15)).xyz, 13.3 -mouse.y -(circleId + mouse.x));\n gl_PointSize = 5. -snd;\n\n float hue = mix(1.01 *snd , 1.9 *mouse.x/ circleId-snd , fract(circleId * 1.79 - snd));\n float sat = 1.5 + snd;\n float val = 0.3 + snd * 3.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (1. - uv.y) * pow(snd * 2.51, -snd*6.));\n v_color = vec4(v_color.rgb * v_color.a*1.2, v_color.a /2.0);\n}" + }, "screenshotURL": "data/images/images-ul6ulypkf8ht9prkc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xX4FaCRBAKRKxwQ5k/art.json b/art/xX4FaCRBAKRKxwQ5k/art.json index 96f32769..07700a5c 100644 --- a/art/xX4FaCRBAKRKxwQ5k/art.json +++ b/art/xX4FaCRBAKRKxwQ5k/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":8,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n \\t\\n gl_PointSize = 20.0;\\n \\n//divide vertex id number by a number\\n vec2 xy = vec2(vertexId / 8.0, vertexId /8.0);\\n \\n \\n//alpha changed distance between vertices\\n //xy is a variable dividing each vertex by a number\\n gl_Position = vec4(xy, 0.0, 2.5);\\n \\n//add vertexcolor to the shader \\n v_color = vec4 (0.5, 0.0, 1.0, 1.0);\\n \\n // vec2 xy = vec2(-0.5, 0.0);\\n \\n if (vertexId == 1.0)\\n {\\n xy = vec2(0, 0.5);\\n \\n }\\n else if (vertexId == 2.0)\\n {\\n xy + vec2(0.5, 0);\\n }\\n \\n //xy += vec2(0, sin(time));\\n \\n gl_Position =vec4(xy, 0.0, 1.0);\\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 8, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n \t\n gl_PointSize = 20.0;\n \n//divide vertex id number by a number\n vec2 xy = vec2(vertexId / 8.0, vertexId /8.0);\n \n \n//alpha changed distance between vertices\n //xy is a variable dividing each vertex by a number\n gl_Position = vec4(xy, 0.0, 2.5);\n \n//add vertexcolor to the shader \n v_color = vec4 (0.5, 0.0, 1.0, 1.0);\n \n // vec2 xy = vec2(-0.5, 0.0);\n \n if (vertexId == 1.0)\n {\n xy = vec2(0, 0.5);\n \n }\n else if (vertexId == 2.0)\n {\n xy + vec2(0.5, 0);\n }\n \n //xy += vec2(0, sin(time));\n \n gl_Position =vec4(xy, 0.0, 1.0);\n gl_PointSize = 10.0;\n \n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-e0ckwlaoke2twq0q9-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xXCPLBuMgorE5wvmd/art.json b/art/xXCPLBuMgorE5wvmd/art.json index 1468aca1..f0680f19 100644 --- a/art/xXCPLBuMgorE5wvmd/art.json +++ b/art/xXCPLBuMgorE5wvmd/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.1607843137254902,0.24705882352941178,0.8117647058823529,1],\"shader\":\"void main()\\n{\\n \\n}\"}", + "settings": { + "num": 3, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.1607843137254902, + 0.24705882352941178, + 0.8117647058823529, + 1 + ], + "shader": "void main()\n{\n \n}" + }, "screenshotURL": "data/images/images-4ps12krs1czt0fkku-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xZSZbju6uJBkBHGed/art.json b/art/xZSZbju6uJBkBHGed/art.json index 73a2e826..8e2b5ea4 100644 --- a/art/xZSZbju6uJBkBHGed/art.json +++ b/art/xZSZbju6uJBkBHGed/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "aleon", "avatarUrl": "https://secure.gravatar.com/avatar/ed3bcd978a61b62a2de04577302ee1f8?default=retro&size=200", - "settings": "{\"num\":46443,\"mode\":\"LINE_LOOP\",\"sound\":\"https://soundcloud.com/lofi-hip-hop-music/lofi-hip-hop\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 4.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.01;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.3;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.01;\\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 46443, + "mode": "LINE_LOOP", + "sound": "https://soundcloud.com/lofi-hip-hop-music/lofi-hip-hop", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 4.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.01;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.3;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.01;\n float oC = cos(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n float oS = sin(orbitAngle + time * count * 0.01) * sin(orbitAngle);\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-wo7j9rxz5xkp5sf21-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xbnz2uAnWG7hSF8jC/art.json b/art/xbnz2uAnWG7hSF8jC/art.json index 5a6fac10..c2bec0a8 100644 --- a/art/xbnz2uAnWG7hSF8jC/art.json +++ b/art/xbnz2uAnWG7hSF8jC/art.json @@ -31,7 +31,19 @@ "private": false, "unlisted": true, "username": "gman", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mogueheart/contact-part-2\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n point cloud vs spheres by Kabuto\\n\\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\\n*/\\n\\nvec3 posf2(float t, float i) {\\n\\treturn vec3(\\n sin(t+i*.9553) +\\n sin(t*1.311+i) +\\n sin(t*1.4+i*1.53) +\\n sin(t*1.84+i*.76),\\n sin(t+i*.79553+2.1) +\\n sin(t*1.311+i*1.1311+2.1) +\\n sin(t*1.4+i*1.353-2.1) +\\n sin(t*1.84+i*.476-2.1),\\n sin(t+i*.5553-2.1) +\\n sin(t*1.311+i*1.1-2.1) +\\n sin(t*1.4+i*1.23+2.1) +\\n sin(t*1.84+i*.36+2.1)\\n\\t)*.2;\\n}\\n\\nvec3 posf0(float t) {\\n return posf2(t,-1.)*3.5;\\n}\\n\\nvec3 posf(float t, float i) {\\n return posf2(t*.3,i) + posf0(t);\\n}\\n\\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\\n vec3 pos = posf(t,i)+ofs;\\n \\n vec3 posf = fract(pos+.5)-.5;\\n \\n float l = length(posf)*2.;\\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\\n}\\n\\nvoid main() {\\n // more or less random movement\\n float t = time*.20;\\n float i = vertexId+sin(vertexId)*100.;\\n\\n vec3 pos = posf(t,i);\\n vec3 ofs = vec3(0);\\n for (float f = -10.; f < 0.; f++) {\\n\\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\\n }\\n ofs += push(t,i,ofs,.999);\\n \\n pos -= posf0(t);\\n \\n pos += ofs;\\n \\n \\n pos.yz *= mat2(.8,.6,-.6,.8);\\n pos.xz *= mat2(.8,.6,-.6,.8);\\n \\n pos *= 1.;\\n \\n\\n pos.z += .7;\\n \\n pos.xy *= .6/pos.z;\\n \\n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\\n gl_PointSize = 1./pos.z;\\n\\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\\n gl_PointSize *= resolution.x / 1600.0;\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/mogueheart/contact-part-2", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n point cloud vs spheres by Kabuto\n\n Recreated this well-known demo effect. A bit tricky without being able to store history for points, so it's just computed again and again for each render pass\n*/\n\nvec3 posf2(float t, float i) {\n\treturn vec3(\n sin(t+i*.9553) +\n sin(t*1.311+i) +\n sin(t*1.4+i*1.53) +\n sin(t*1.84+i*.76),\n sin(t+i*.79553+2.1) +\n sin(t*1.311+i*1.1311+2.1) +\n sin(t*1.4+i*1.353-2.1) +\n sin(t*1.84+i*.476-2.1),\n sin(t+i*.5553-2.1) +\n sin(t*1.311+i*1.1-2.1) +\n sin(t*1.4+i*1.23+2.1) +\n sin(t*1.84+i*.36+2.1)\n\t)*.2;\n}\n\nvec3 posf0(float t) {\n return posf2(t,-1.)*3.5;\n}\n\nvec3 posf(float t, float i) {\n return posf2(t*.3,i) + posf0(t);\n}\n\nvec3 push(float t, float i, vec3 ofs, float lerpEnd) {\n vec3 pos = posf(t,i)+ofs;\n \n vec3 posf = fract(pos+.5)-.5;\n \n float l = length(posf)*2.;\n return (- posf + posf/l)*(1.-smoothstep(lerpEnd,1.,l));\n}\n\nvoid main() {\n // more or less random movement\n float t = time*.20;\n float i = vertexId+sin(vertexId)*100.;\n\n vec3 pos = posf(t,i);\n vec3 ofs = vec3(0);\n for (float f = -10.; f < 0.; f++) {\n\t ofs += push(t+f*.05,i,ofs,2.-exp(-f*.1));\n }\n ofs += push(t,i,ofs,.999);\n \n pos -= posf0(t);\n \n pos += ofs;\n \n \n pos.yz *= mat2(.8,.6,-.6,.8);\n pos.xz *= mat2(.8,.6,-.6,.8);\n \n pos *= 1.;\n \n\n pos.z += .7;\n \n pos.xy *= .6/pos.z;\n \n gl_Position = vec4(pos.x, pos.y*resolution.x/resolution.y, pos.z*.1, 1);\n gl_PointSize = 1./pos.z;\n\n v_color = vec4(abs(ofs/max(length(ofs),1e-9))*.3+.7,1);\n gl_PointSize *= resolution.x / 1600.0;\n}" + }, "screenshotURL": "data/images/images-ko6hozqgok7d3xj7u-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xc49q3XhWdr4G5g3Y/art.json b/art/xc49q3XhWdr4G5g3Y/art.json index 07a83ce0..184ca7e4 100644 --- a/art/xc49q3XhWdr4G5g3Y/art.json +++ b/art/xc49q3XhWdr4G5g3Y/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "joonho.hwang", "avatarUrl": "https://secure.gravatar.com/avatar/71946ad0898d0a3558af0dc283a4b9c2?default=retro&size=200", - "settings": "{\"num\":3358,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Joonho Hwang\\n// Exercise Colors\\n// CS250 Spring 2022\\n\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xOffset = sin(time + y * 0.2) * 0.1;\\n float yOffset = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xOffset;\\n float vy = v * 2.0 - 1.0 + yOffset;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0.0, 1.0);\\n \\n float sizeOffset = sin(time * 1.2 + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 10.0 + sizeOffset;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = sin(time * u * v) * 0.5 + 0.5;\\n float saturation = sin(time * length(vec2(x, y))) * 0.5 + 0.5;\\n float value = 1.0;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\\n}\"}", + "settings": { + "num": 3358, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Joonho Hwang\n// Exercise Colors\n// CS250 Spring 2022\n\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xOffset = sin(time + y * 0.2) * 0.1;\n float yOffset = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xOffset;\n float vy = v * 2.0 - 1.0 + yOffset;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0.0, 1.0);\n \n float sizeOffset = sin(time * 1.2 + x * y * 0.02) * 5.0;\n \n gl_PointSize = 10.0 + sizeOffset;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = sin(time * u * v) * 0.5 + 0.5;\n float saturation = sin(time * length(vec2(x, y))) * 0.5 + 0.5;\n float value = 1.0;\n \n v_color = vec4(hsv2rgb(vec3(hue, saturation, value)), 1);\n}" + }, "screenshotURL": "data/images/images-5q32kcrorh0o1v59z-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xdFdZbdmwquvYTuRo/art.json b/art/xdFdZbdmwquvYTuRo/art.json index 317096fb..b62350ec 100644 --- a/art/xdFdZbdmwquvYTuRo/art.json +++ b/art/xdFdZbdmwquvYTuRo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "serdar2", "avatarUrl": "https://lh3.googleusercontent.com/a/AAcHTtcr8OLY4PHhjXfZ85YOTN46nqHnfmZkTLoNu6Hn6vAL=s96-c", - "settings": "{\"num\":96384,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.5882352941176471,0.09411764705882353,0.00392156862745098,1],\"shader\":\"// classic retro effect\\n// rotate and scale by moving mouse\\n// \\n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\\n// (a little slower)\\n//\\n// update:\\n// enlarged points for better visibility\\n//\\n\\n\\n#define POINTSIZE 2.0\\nfloat SCALE = 2.0 * (mouse.y+1.0);\\nfloat SIZE = floor( sqrt( vertexCount ) );\\nfloat TSCALE = 0.2 * 4096./vertexCount;\\nfloat MSCALE = 0.12 * 64.0/SIZE;\\n\\nvec3 rotateY( vec3 p, float a )\\n{\\n float sa = sin(a);\\n float ca = cos(a);\\n vec3 r;\\n r.x = ca*p.x + sa*p.z;\\n r.y = p.y;\\n r.z = -sa*p.x + ca*p.z;\\n return r;\\n}\\n\\n// terrain function from mars shader by reider\\n// https://www.shadertoy.com/view/XdsGWH\\nconst mat2 mr = mat2 (0.84147, 0.530,\\n\\t\\t\\t\\t\\t 0.54030, -0.84147 );\\nfloat hash( in float n )\\n{\\n\\treturn fract(sin(n)*43758.5453);\\n}\\nfloat noise(in vec2 x)\\n{\\n\\tvec2 p = floor(x);\\n\\tvec2 f = fract(x);\\n\\t\\t\\n\\tf = f*f*(3.0-2.0*f);\\t\\n\\tfloat n = p.x + p.y*57.0;\\n\\t\\n\\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\\n\\t\\t\\t\\t\\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\\n\\treturn res;\\n}\\nfloat fbm( in vec2 p )\\n{\\n\\tfloat f;\\n\\tf = 0.5000*noise( p ); p = mr*p*2.02;\\n\\tf += 0.2500*noise( p ); p = mr*p*2.33;\\n\\tf += 0.1250*noise( p ); p = mr*p*2.01;\\n\\tf += 0.0625*noise( p ); p = mr*p*5.21;\\n\\t\\n\\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\\n}\\n\\nvec3 GetPoint( float vertexid )\\n{\\n float SPACING = 16.0 / SIZE;\\n float x = mod( vertexid, SIZE );\\n if (x==SIZE-1.) // last in 'line'\\n {\\n \\t//x = SIZE-2.; // equals previous\\n }\\n float y = floor( vertexid / SIZE );\\n if (mod(y,2.)>0.0)\\n {\\n // odd - change direction\\n x = SIZE - 1. - x;\\n }\\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/3.0 + y) * SPACING );\\n}\\n\\nvoid main()\\n{\\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\\n vec3 p = GetPoint( vertexId );\\n float fov = 3.1;\\n p = rotateY( p, -mouse.x*2.0 );\\n float origz = p.z;\\n p += vec3( 0.0, -5.0, 15.0 );\\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \\n gl_PointSize = POINTSIZE;\\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\\n}\"}", + "settings": { + "num": 96384, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.5882352941176471, + 0.09411764705882353, + 0.00392156862745098, + 1 + ], + "shader": "// classic retro effect\n// rotate and scale by moving mouse\n// \n// pixel shader version: https://www.shadertoy.com/view/lt2SWc\n// (a little slower)\n//\n// update:\n// enlarged points for better visibility\n//\n\n\n#define POINTSIZE 2.0\nfloat SCALE = 2.0 * (mouse.y+1.0);\nfloat SIZE = floor( sqrt( vertexCount ) );\nfloat TSCALE = 0.2 * 4096./vertexCount;\nfloat MSCALE = 0.12 * 64.0/SIZE;\n\nvec3 rotateY( vec3 p, float a )\n{\n float sa = sin(a);\n float ca = cos(a);\n vec3 r;\n r.x = ca*p.x + sa*p.z;\n r.y = p.y;\n r.z = -sa*p.x + ca*p.z;\n return r;\n}\n\n// terrain function from mars shader by reider\n// https://www.shadertoy.com/view/XdsGWH\nconst mat2 mr = mat2 (0.84147, 0.530,\n\t\t\t\t\t 0.54030, -0.84147 );\nfloat hash( in float n )\n{\n\treturn fract(sin(n)*43758.5453);\n}\nfloat noise(in vec2 x)\n{\n\tvec2 p = floor(x);\n\tvec2 f = fract(x);\n\t\t\n\tf = f*f*(3.0-2.0*f);\t\n\tfloat n = p.x + p.y*57.0;\n\t\n\tfloat res = mix(mix( hash(n+ 0.0), hash(n+ 1.0),f.x),\n\t\t\t\t\tmix( hash(n+ 57.0), hash(n+ 58.0),f.x),f.y);\n\treturn res;\n}\nfloat fbm( in vec2 p )\n{\n\tfloat f;\n\tf = 0.5000*noise( p ); p = mr*p*2.02;\n\tf += 0.2500*noise( p ); p = mr*p*2.33;\n\tf += 0.1250*noise( p ); p = mr*p*2.01;\n\tf += 0.0625*noise( p ); p = mr*p*5.21;\n\t\n\treturn f/(0.9375)*smoothstep( 260., 768., p.y ); // flat at beginning\n}\n\nvec3 GetPoint( float vertexid )\n{\n float SPACING = 16.0 / SIZE;\n float x = mod( vertexid, SIZE );\n if (x==SIZE-1.) // last in 'line'\n {\n \t//x = SIZE-2.; // equals previous\n }\n float y = floor( vertexid / SIZE );\n if (mod(y,2.)>0.0)\n {\n // odd - change direction\n x = SIZE - 1. - x;\n }\n vec2 trans = vec2( time * 16., time * 23.0 ) * MSCALE;\n return vec3( (-SIZE/2.0 + x) * SPACING, fbm( vec2( x, y ) * TSCALE + trans ) * SCALE, (-SIZE/3.0 + y) * SPACING );\n}\n\nvoid main()\n{\n if (mod(SIZE,2.)>0.) SIZE += 1.; // need even number of points on side\n vec3 p = GetPoint( vertexId );\n float fov = 3.1;\n p = rotateY( p, -mouse.x*2.0 );\n float origz = p.z;\n p += vec3( 0.0, -5.0, 15.0 );\n gl_Position = vec4( p.xy*fov, 1.0/(p.z-0.0), p.z ); \n gl_PointSize = POINTSIZE;\n v_color = vec4(max( 0.0, 1.0 - p.z/24. ) );\n}" + }, "screenshotURL": "data/images/images-knb8tebdhg1v3wnpc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xdgnE3FvNBNtDFynG/art.json b/art/xdgnE3FvNBNtDFynG/art.json index d773d29f..075550f0 100644 --- a/art/xdgnE3FvNBNtDFynG/art.json +++ b/art/xdgnE3FvNBNtDFynG/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/neokontrol/popek-vs-neokontrol-ufos-are-real-176bpm\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46283.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n\\n//precision mediump float;\\n\\n\\n//uniform float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\n////CAMERA\\n//Functions used for camera\\n#define PI radians(180.)\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n //#if 1\\n return inverse(lookAt(eye, target, up));\\n /*#else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif*/\\n \\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n//END CAMERA\\n\\nvec2 R = vertexResolution;\\nvec2 Offset;\\nvec2 Scale=vec2(0.001,0.002);\\nfloat Saturation = 0.8; // 0 - 1;\\n\\n\\nvec3 lungth(vec2 x,vec3 c){\\n return vec3(length(x+c.r),length(x+c.g),length(c.b));\\n}\\n\\nvoid main( void ) {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n\\t\\n\\tvec2 position = (simFragCoord.xy - vertexResolution * .5) / vertexResolution.yy;\\n\\tfloat th = atan(position.y, position.x) / (1.0 * 3.1415926);\\n\\tfloat dd = length(position) + 0.005;\\n\\tfloat d = 0.5 / dd + time;\\n\\t\\n \\tvec2 x2 = simFragCoord.xy;\\n \\tx2=x2*Scale*R/R.x;\\n \\tx2+sin(x2.yx*sqrt(vec2(1,9)))/1.;\\n\\tx2+=sin(x2.yx*sqrt(vec2(73,5)))/5.;\\n \\tx2+=sin(x2.yx*sqrt(vec2(93,7)))/3.;\\n\\t\\n\\tvec3 uv = vec3(th + d, th - d, th + sin(d) * 0.45);\\n\\tfloat a = 0.5 + cos(uv.x * 3.1415926 * 2.0) * 0.5;\\n\\tfloat b = 0.5 + cos(uv.y * 3.1415926 * 2.0) * 0.5;\\n\\tfloat c = 0.5 + cos(uv.z * 3.1415926 * 6.0) * 0.5;\\n\\tvec3 color = \\tmix(vec3(0.1, 0.5, 0.5), \\tvec3(0.1, 0.1, 0.2), pow(a, 0.2)) * 3.;\\n\\tcolor += \\tmix(vec3(0.8, 0.2, 1.0), \\tvec3(0.1, 0.1, 0.2), pow(b, 0.1)) * 0.75;\\n\\t//color += \\tmix(c2, \\t\\t\\tvec3(0.1, 0.2, 0.2), pow(c, 0.1)) * 0.75;\\n\\n\\tv_color = vec4( (color * dd), 1.0);\\n \\n //gl_Position.x-= v_color.r/5.;\\n //gl_Position.y-= v_color.g/5.;\\n gl_Position.z-= v_color.b/2.;\\n \\n //camera\\n float r = 0.9;\\n float tm = 1.5;//*time;\\n float tm2 = 0.05*time;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\ngl_Position*=mat;\\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/neokontrol/popek-vs-neokontrol-ufos-are-real-176bpm", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46283.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n\n//precision mediump float;\n\n\n//uniform float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\n////CAMERA\n//Functions used for camera\n#define PI radians(180.)\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n //#if 1\n return inverse(lookAt(eye, target, up));\n /*#else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif*/\n \n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n//END CAMERA\n\nvec2 R = vertexResolution;\nvec2 Offset;\nvec2 Scale=vec2(0.001,0.002);\nfloat Saturation = 0.8; // 0 - 1;\n\n\nvec3 lungth(vec2 x,vec3 c){\n return vec3(length(x+c.r),length(x+c.g),length(c.b));\n}\n\nvoid main( void ) {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n\t\n\tvec2 position = (simFragCoord.xy - vertexResolution * .5) / vertexResolution.yy;\n\tfloat th = atan(position.y, position.x) / (1.0 * 3.1415926);\n\tfloat dd = length(position) + 0.005;\n\tfloat d = 0.5 / dd + time;\n\t\n \tvec2 x2 = simFragCoord.xy;\n \tx2=x2*Scale*R/R.x;\n \tx2+sin(x2.yx*sqrt(vec2(1,9)))/1.;\n\tx2+=sin(x2.yx*sqrt(vec2(73,5)))/5.;\n \tx2+=sin(x2.yx*sqrt(vec2(93,7)))/3.;\n\t\n\tvec3 uv = vec3(th + d, th - d, th + sin(d) * 0.45);\n\tfloat a = 0.5 + cos(uv.x * 3.1415926 * 2.0) * 0.5;\n\tfloat b = 0.5 + cos(uv.y * 3.1415926 * 2.0) * 0.5;\n\tfloat c = 0.5 + cos(uv.z * 3.1415926 * 6.0) * 0.5;\n\tvec3 color = \tmix(vec3(0.1, 0.5, 0.5), \tvec3(0.1, 0.1, 0.2), pow(a, 0.2)) * 3.;\n\tcolor += \tmix(vec3(0.8, 0.2, 1.0), \tvec3(0.1, 0.1, 0.2), pow(b, 0.1)) * 0.75;\n\t//color += \tmix(c2, \t\t\tvec3(0.1, 0.2, 0.2), pow(c, 0.1)) * 0.75;\n\n\tv_color = vec4( (color * dd), 1.0);\n \n //gl_Position.x-= v_color.r/5.;\n //gl_Position.y-= v_color.g/5.;\n gl_Position.z-= v_color.b/2.;\n \n //camera\n float r = 0.9;\n float tm = 1.5;//*time;\n float tm2 = 0.05*time;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\ngl_Position*=mat;\n}" + }, "screenshotURL": "data/images/images-ca9pl9hkltleuvfs5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xgQQX7WZ4GhGTRqMt/art.json b/art/xgQQX7WZ4GhGTRqMt/art.json index 3f299529..df6a1666 100644 --- a/art/xgQQX7WZ4GhGTRqMt/art.json +++ b/art/xgQQX7WZ4GhGTRqMt/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "minjae-yu", "avatarUrl": "https://avatars.githubusercontent.com/minjae-yu?s=200", - "settings": "{\"num\":4928,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.11764705882352941,0.11372549019607843,0.3254901960784314,1],\"shader\":\"//Name : MINJAE YU\\n//Assignment : Making a Grid\\n//Course : CS250\\n//Term : Spring 2023\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux * cos(time), vy * sin(time), 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(cos(time), sin(time), cos(time), 1);\\n}\"}", + "settings": { + "num": 4928, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.11764705882352941, + 0.11372549019607843, + 0.3254901960784314, + 1 + ], + "shader": "//Name : MINJAE YU\n//Assignment : Making a Grid\n//Course : CS250\n//Term : Spring 2023\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux * cos(time), vy * sin(time), 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(cos(time), sin(time), cos(time), 1);\n}" + }, "screenshotURL": "data/images/images-9c15t0i18lx7j0cff-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xgrH8Ga7yhuDYom6t/art.json b/art/xgrH8Ga7yhuDYom6t/art.json index 8a58adb9..792971b5 100644 --- a/art/xgrH8Ga7yhuDYom6t/art.json +++ b/art/xgrH8Ga7yhuDYom6t/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "athega", "avatarUrl": "https://secure.gravatar.com/avatar/ac866057ea99c21292a071d08fadd152?default=retro&size=200", - "settings": "{\"num\":54268,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/robundchris/eminem-vs-zombie-nation-without-kernkraft-400-rob-chris-bootleg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// johan\\n\\n#define PI radians(180.)\\n\\nvoid main() {\\n \\n float aspect = resolution.x / resolution.y;\\n\\n float cPoints = 64.;\\n float circles = ceil(vertexCount / cPoints);\\n float cId = floor(vertexId / cPoints);\\n float cNorm = cId / circles;\\n float vId = mod(vertexId, cPoints);\\n \\n\\n float a = 2. * PI * vId / (cPoints - 1.);\\n\\n float snd = pow(texture2D(sound, vec2(0.05, cNorm * .125)).a, 4.);\\n \\n float rad = 0.05 + 0.1 * (1. - cNorm) + sin(a * 10.) * (0.05 + 0.3 * snd);\\n float x = sin(a) * rad;\\n float y = cos(a) * rad;\\n \\n \\n x += sin(time * 1.23 + cId / 133.3) * .3;\\n y += cos(time * 1.09 - cId / 159.2) * .3 / aspect;\\n \\n x += sin(time * 1.31 + cId / 171.3) * .4;\\n y += cos(time * 1.49 - cId / 147.2) * .4 / aspect;\\n \\n\\n gl_Position = vec4(x, y * aspect, 0, 1);\\n \\n float r = sin(time * 1.42 - cNorm * 8.) * .5 + .5;\\n float g = sin(time * 1.27 + a) * .5 + .5;\\n float b = sin(time * 1.12 + cNorm * 6.) * .5 + .5;\\n\\n v_color = vec4(r, g, b, 1);\\n}\"}", + "settings": { + "num": 54268, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/robundchris/eminem-vs-zombie-nation-without-kernkraft-400-rob-chris-bootleg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// johan\n\n#define PI radians(180.)\n\nvoid main() {\n \n float aspect = resolution.x / resolution.y;\n\n float cPoints = 64.;\n float circles = ceil(vertexCount / cPoints);\n float cId = floor(vertexId / cPoints);\n float cNorm = cId / circles;\n float vId = mod(vertexId, cPoints);\n \n\n float a = 2. * PI * vId / (cPoints - 1.);\n\n float snd = pow(texture2D(sound, vec2(0.05, cNorm * .125)).a, 4.);\n \n float rad = 0.05 + 0.1 * (1. - cNorm) + sin(a * 10.) * (0.05 + 0.3 * snd);\n float x = sin(a) * rad;\n float y = cos(a) * rad;\n \n \n x += sin(time * 1.23 + cId / 133.3) * .3;\n y += cos(time * 1.09 - cId / 159.2) * .3 / aspect;\n \n x += sin(time * 1.31 + cId / 171.3) * .4;\n y += cos(time * 1.49 - cId / 147.2) * .4 / aspect;\n \n\n gl_Position = vec4(x, y * aspect, 0, 1);\n \n float r = sin(time * 1.42 - cNorm * 8.) * .5 + .5;\n float g = sin(time * 1.27 + a) * .5 + .5;\n float b = sin(time * 1.12 + cNorm * 6.) * .5 + .5;\n\n v_color = vec4(r, g, b, 1);\n}" + }, "screenshotURL": "data/images/images-wxka8k2x30de5c2kx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xizoh3Kx86QeHAyuc/art.json b/art/xizoh3Kx86QeHAyuc/art.json index e264c417..02225e5e 100644 --- a/art/xizoh3Kx86QeHAyuc/art.json +++ b/art/xizoh3Kx86QeHAyuc/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-zq96xq6jdt5kdfjrj-thumbnail.jpg", "views": { "$numberInt": "74" diff --git a/art/xnpXYa6wYgG6TyR5m/art.json b/art/xnpXYa6wYgG6TyR5m/art.json index ea81ceee..6214665c 100644 --- a/art/xnpXYa6wYgG6TyR5m/art.json +++ b/art/xnpXYa6wYgG6TyR5m/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spinninrecords/alok-alan-walker-headlights-feat-kiddo-listen-link\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\\n//Course : CS250\\n//Term : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n \\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n \\n \\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au*.05, av*.25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;//sin(time + 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = pow(snd+0.2,5.)* 30.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd*0.2+time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\\n float sat = mix(0., 1., pump);//mix(1., -10., av);\\n float val = mix(.1, pow(snd+0.2,5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n \\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spinninrecords/alok-alan-walker-headlights-feat-kiddo-listen-link", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Audio Reactive\n//Course : CS250\n//Term : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n \n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n \n \n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au*.05, av*.25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;//sin(time + 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = pow(snd+0.2,5.)* 30.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd*0.2+time * .1;//sin(time * 1.3 + v * 20.) * 0.05;\n float sat = mix(0., 1., pump);//mix(1., -10., av);\n float val = mix(.1, pow(snd+0.2,5.), pump);//sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n \n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-lrbggnybfcqar1mvb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xqkoSeG72cxgJNEqr/art.json b/art/xqkoSeG72cxgJNEqr/art.json index 3f5c8015..f86f0cb6 100644 --- a/art/xqkoSeG72cxgJNEqr/art.json +++ b/art/xqkoSeG72cxgJNEqr/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"// I HAD TO STEAL THIS !!!!!\\n\\nvoid main(){\\n float across = 10.;\\n \\n float x = mod(vertexId, across );\\n float y = floor(vertexId / across);\\n \\n float u = x / (across -1.);\\n float v = y / (across -1.);\\n \\n float ux = u * 2. -1.;\\n float vy = v * 2. -1.;\\n \\n \\n gl_Position = vec4(ux,vy,0,1);\\n \\n gl_PointSize = 10.0;\\n \\n v_color = vec4(1,0,0,1);\\n \\n \\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "// I HAD TO STEAL THIS !!!!!\n\nvoid main(){\n float across = 10.;\n \n float x = mod(vertexId, across );\n float y = floor(vertexId / across);\n \n float u = x / (across -1.);\n float v = y / (across -1.);\n \n float ux = u * 2. -1.;\n float vy = v * 2. -1.;\n \n \n gl_Position = vec4(ux,vy,0,1);\n \n gl_PointSize = 10.0;\n \n v_color = vec4(1,0,0,1);\n \n \n}" + }, "screenshotURL": "data/images/images-4w9ro44c5u8lnu5au-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xqxGcpS5Ny2RtAwpm/art.json b/art/xqxGcpS5Ny2RtAwpm/art.json index ca874cc4..11c065e5 100644 --- a/art/xqxGcpS5Ny2RtAwpm/art.json +++ b/art/xqxGcpS5Ny2RtAwpm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7558,\"mode\":\"TRI_STRIP\",\"sound\":\"mic\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// 💙💙💙💙💙\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define P1 3.//KParameter0 0.>>6.\\n\\n\\n\\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\\\\n//define snd \\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvec3 rgb2hsv(vec3 c) {\\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\\n\\n float d = q.x - min(q.w, q.y);\\n float e = 1.0e-10;\\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\\n}\\n\\n#define PI radians(180.)\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0.2, 0, \\n s, c, 1, 0,\\n 0, 0, 0.1, 0,\\n 0, 1, 2, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1.2);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], -.1, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0.2*sin(time), s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 6.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 0.2;\\n float c = cos(angle);\\n float s = sin(angle);\\n float snd = texture2D(sound,vec2(0.,0.)).a;\\n float radius = mix(0.5,1.30 * P1, vy);\\n float x = c * radius;\\n float y = s * radius/snd;\\n \\n return vec2(x, y);\\n}\\n\\n\\nvoid main() {\\n float S = texture2D(sound,vec2(0.,0.)).a;\\n float numCircleSegments = 8.0;\\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 6.;\\n \\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 2.);\\n float oddSlice = mod(sliceId, 12.);\\n \\n float down = sqrt(numCircles);\\n float across = floor(numCircles / down);\\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n float sn = texture2D(sound,vec2(0.,0.)).a;\\n float su = abs(u - .5) * 2.;\\n float sv = abs(v - 1.5) * 2.*S;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n const int spots = 40;\\n float snd = 0.01;\\n float totalSnd = 0.14;\\n vec3 color = vec3(0);\\n for (int sp = 0; sp < spots; ++sp) {\\n float spf = float(sp + 2)-clamp(S,0.1,0.3);\\n float spx = hash(spf *- 0.123);\\n float spy = hash(spf / .317);\\n float sps = hash(spf - 3.411);\\n \\n float sds = distance(vec2(u*step(11.9,snd*2.), -v+snd), vec2(spx, spy));\\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\\n totalSnd += invSds;\\n snd += texture2D(sound, vec2(mix(0.001, 0.511/S, sps), sds * .09)).a *\\n mix(2.95, 1.7*2., sps) * invSds;\\n \\n color = mix(color, hsv2rgb(vec3(sps, .3, 1.)), pow(invSds, 2.));\\n } \\n snd /= totalSnd;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n float sc = pow(snd, 4.) * 0.1 +snd *\\n oddSlice * 0.03;\\n float aspect = resolution.x / resolution.y;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 0.61));\\n //mat *= rotZ(time * 0.);\\n mat *= trans(vec3(ux, vy, 0.10));\\n mat *= uniformScale(0.2 * sc * 5. / across);\\n mat *= rotZ(snd * 2. * sign(ux));\\n \\n gl_Position = mat * pos;\\n \\n float soff = sin(time + x * y * 11.02) * 5.; \\n \\n float pump = step(11.17, snd);\\n \\n vec3 hsv = rgb2hsv(color);\\n hsv.x = mix(0., 0.2, hsv.x) + time * 1.1 + pump * .33;\\n hsv.z = mix(0.5, 1., pump);\\n v_color = vec4(hsv2rgb(hsv), 1);;\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 7558, + "mode": "TRI_STRIP", + "sound": "mic", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// 💙💙💙💙💙\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define P1 3.//KParameter0 0.>>6.\n\n\n\n // from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\\n//define snd \nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvec3 rgb2hsv(vec3 c) {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));\n vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / sin(6.0 * d + e)), d / (q.x + e), q.x);\n}\n\n#define PI radians(180.)\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0.2, 0, \n s, c, 1, 0,\n 0, 0, 0.1, 0,\n 0, 1, 2, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1.2);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], -.1, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0.2*sin(time), s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 6.), 2.);\n \n float angle = ux / numCircleSegments * PI * 0.2;\n float c = cos(angle);\n float s = sin(angle);\n float snd = texture2D(sound,vec2(0.,0.)).a;\n float radius = mix(0.5,1.30 * P1, vy);\n float x = c * radius;\n float y = s * radius/snd;\n \n return vec2(x, y);\n}\n\n\nvoid main() {\n float S = texture2D(sound,vec2(0.,0.)).a;\n float numCircleSegments = 8.0;\n vec2 circleXY = getCirclePoint(vertexId, numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 6.;\n \n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 2.);\n float oddSlice = mod(sliceId, 12.);\n \n float down = sqrt(numCircles);\n float across = floor(numCircles / down);\n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n float sn = texture2D(sound,vec2(0.,0.)).a;\n float su = abs(u - .5) * 2.;\n float sv = abs(v - 1.5) * 2.*S;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n const int spots = 40;\n float snd = 0.01;\n float totalSnd = 0.14;\n vec3 color = vec3(0);\n for (int sp = 0; sp < spots; ++sp) {\n float spf = float(sp + 2)-clamp(S,0.1,0.3);\n float spx = hash(spf *- 0.123);\n float spy = hash(spf / .317);\n float sps = hash(spf - 3.411);\n \n float sds = distance(vec2(u*step(11.9,snd*2.), -v+snd), vec2(spx, spy));\n float invSds = pow(clamp(1. - sds, 0., 2.), 2.);\n totalSnd += invSds;\n snd += texture2D(sound, vec2(mix(0.001, 0.511/S, sps), sds * .09)).a *\n mix(2.95, 1.7*2., sps) * invSds;\n \n color = mix(color, hsv2rgb(vec3(sps, .3, 1.)), pow(invSds, 2.));\n } \n snd /= totalSnd;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n float sc = pow(snd, 4.) * 0.1 +snd *\n oddSlice * 0.03;\n float aspect = resolution.x / resolution.y;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 0.61));\n //mat *= rotZ(time * 0.);\n mat *= trans(vec3(ux, vy, 0.10));\n mat *= uniformScale(0.2 * sc * 5. / across);\n mat *= rotZ(snd * 2. * sign(ux));\n \n gl_Position = mat * pos;\n \n float soff = sin(time + x * y * 11.02) * 5.; \n \n float pump = step(11.17, snd);\n \n vec3 hsv = rgb2hsv(color);\n hsv.x = mix(0., 0.2, hsv.x) + time * 1.1 + pump * .33;\n hsv.z = mix(0.5, 1., pump);\n v_color = vec4(hsv2rgb(hsv), 1);;\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-nzd47e78my7mq3qua-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xrRijEDXFe2NwH79m/art.json b/art/xrRijEDXFe2NwH79m/art.json index d5ad1c9e..b8797e29 100644 --- a/art/xrRijEDXFe2NwH79m/art.json +++ b/art/xrRijEDXFe2NwH79m/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n}" + }, "screenshotURL": "data/images/images-q9k2xzpbxula5yhub-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xsSZN6pMk7iANGyTE/art.json b/art/xsSZN6pMk7iANGyTE/art.json index 43543a96..e82ef4ca 100644 --- a/art/xsSZN6pMk7iANGyTE/art.json +++ b/art/xsSZN6pMk7iANGyTE/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "macro", "avatarUrl": "https://lh3.googleusercontent.com/-hZKcNaW8AT0/AAAAAAAAAAI/AAAAAAAAEGM/geaXegN2s9U/photo.jpg", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.25098039215686274,1],\"shader\":\"void main() {\\n float aspect = resolution.x / resolution.y;\\n float across = (sqrt(vertexCount) * aspect);\\n float down = (vertexCount / across);\\n float x = mod(vertexId, across);\\n float y = (vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (down - 1.);\\n\\n float ux = u * 2. - 1.;\\n float vy = v * 2. - 1.;\\n \\n float pointScale = min(\\n 20. / across * resolution.x / 600.0,\\n 20. / down * resolution.y / 600.0);\\n \\n gl_Position = vec4(vec2(ux, vy) * .75, 0, 1);\\n gl_PointSize = 15.0;\\n gl_PointSize *= pointScale;\\n\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.25098039215686274, + 1 + ], + "shader": "void main() {\n float aspect = resolution.x / resolution.y;\n float across = (sqrt(vertexCount) * aspect);\n float down = (vertexCount / across);\n float x = mod(vertexId, across);\n float y = (vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (down - 1.);\n\n float ux = u * 2. - 1.;\n float vy = v * 2. - 1.;\n \n float pointScale = min(\n 20. / across * resolution.x / 600.0,\n 20. / down * resolution.y / 600.0);\n \n gl_Position = vec4(vec2(ux, vy) * .75, 0, 1);\n gl_PointSize = 15.0;\n gl_PointSize *= pointScale;\n\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-thsxs95ewyyaxfipf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xuJ6P4ivzQ3KERCwG/art.json b/art/xuJ6P4ivzQ3KERCwG/art.json index 6b026ae7..f5a1dbbe 100644 --- a/art/xuJ6P4ivzQ3KERCwG/art.json +++ b/art/xuJ6P4ivzQ3KERCwG/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jc", "avatarUrl": "https://lh6.googleusercontent.com/-wxkmpL8A-s0/AAAAAAAAAAI/AAAAAAAAAFg/cZuqYtkpOCI/photo.jpg", - "settings": "{\"num\":21,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\\n \\n float x = ux;\\n float y = vy;\\n \\n vec2 xy = vec2(x,y);\\n \\n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 21, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float ux = floor(vertexId / 6.0) + mod(vertexId, 2.0);\n float vy = mod(floor(vertexId / 2.0) + floor(vertexId / 3.0), 2.0);\n \n float x = ux;\n float y = vy;\n \n vec2 xy = vec2(x,y);\n \n gl_Position = vec4(xy * 0.1, 0.0, 1.0);\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-f17nqjog0vwdybhy8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xuuAHAN2frEuP9Tt8/art.json b/art/xuuAHAN2frEuP9Tt8/art.json index 1d2fd16b..20022e40 100644 --- a/art/xuuAHAN2frEuP9Tt8/art.json +++ b/art/xuuAHAN2frEuP9Tt8/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "leeland", "avatarUrl": "https://lh6.googleusercontent.com/-qXvI68G6vJA/AAAAAAAAAAI/AAAAAAAABXE/f-2nfTklzoo/photo.jpg", - "settings": "{\"num\":4372,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 21.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n \\n}\"}", + "settings": { + "num": 4372, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 21.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n \n}" + }, "screenshotURL": "data/images/images-dfdq5vsaorl4p5ypq-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/xvg4vyvfWjCvKZQfW/art.json b/art/xvg4vyvfWjCvKZQfW/art.json index e8b4825c..ac4ce38d 100644 --- a/art/xvg4vyvfWjCvKZQfW/art.json +++ b/art/xvg4vyvfWjCvKZQfW/art.json @@ -30,7 +30,19 @@ }, "private": false, "username": "gman", - "settings": "{\"num\":21600,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/anamanaguchi/everyday-everynight-feat-planet1999\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.08235294117647059,0.1568627450980392,0.7803921568627451,1],\"shader\":\"// _ _ _ _ \\n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \\n// \\\\ \\\\ / / _ \\\\ '__| __/ _ \\\\ \\\\/ / __| '_ \\\\ / _` |/ _` |/ _ \\\\ '__/ _` | '__| __|\\n// \\\\ V / __/ | | || __/> <\\\\__ \\\\ | | | (_| | (_| | __/ | | (_| | | | |_ \\n// \\\\_/ \\\\___|_| \\\\__\\\\___/_/\\\\_\\\\___/_| |_|\\\\__,_|\\\\__,_|\\\\___|_| \\\\__,_|_| \\\\__|\\n//\\n\\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.0;\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0., 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n #if 0\\n \\tv0 = (vec4(v0, 1) * mat).xyz;\\n \\tv1 = (vec4(v1, 1) * mat).xyz;\\n \\tv2 = (vec4(v2, 1) * mat).xyz;\\n \\tv3 = (vec4(v3, 1) * mat).xyz;\\n #else\\n \\tv0 = (mat * vec4(v0, 1)).xyz;\\n \\tv1 = (mat * vec4(v1, 1)).xyz;\\n \\tv2 = (mat * vec4(v2, 1)).xyz;\\n \\tv3 = (mat * vec4(v3, 1)).xyz;\\n #endif\\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n vec3 vNormal;\\n\\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\\n\\n outSceneVertex.vColor = vec3( 0.0 );\\n\\n outSceneVertex.fAlpha = 1.0; \\n\\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n outSceneVertex.vColor += GetSkyLighting( vNormal );\\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n\\n outSceneVertex.vColor += GetSunLighting( vNormal );\\n\\n outSceneVertex.vColor *= vCubeCol; \\n\\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n \\tfloat fSize = 1.0;\\n\\n \\tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\\n \\n float across = 32.;\\n float down = 20.;\\n float u = mod(fCubeId, across) / across;\\n float v = floor(fCubeId / across) / down;\\n float lng = u * PI * 2.;\\n float lat = v * PI;\\n\\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\\n \\n vCubeOrigin.z += pow(snd, 8.0) * 8.0;\\n float fScale = mix(0.1, 0.6, sin(lat)) * mix(0.7, 2.0, pow(snd, 8.0)) * snd;\\n \\n mat = ident();\\n \\tmat *= rotZ(lng);\\n \\tmat *= rotY(lat);\\n mat *= trans(vCubeOrigin);\\n mat *= uniformScale(fScale);\\n \\n \\tvec3 vRandCol;\\n\\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\\n \\n vCubeCol = mix(hsv2rgb(vec3(time + 0.5, 0., 0.2)) * pow(s2 + 0.25, 90.), vec3(1,1,1), pow(s2, 40.0)); \\n vCubeCol = mix(vCubeCol, hsv2rgb(vec3(time * 1.,1,1)), step(0.8,s2));\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n mat4 mCube;\\n vec3 vCubeCol;\\n\\n GetCubePosition( fCubeId, mCube, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 21600, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/anamanaguchi/everyday-everynight-feat-planet1999", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.08235294117647059, + 0.1568627450980392, + 0.7803921568627451, + 1 + ], + "shader": "// _ _ _ _ \n// __ _____ _ __| |_ _____ _____| |__ __ _ __| | ___ _ __ __ _ _ __| |_ \n// \\ \\ / / _ \\ '__| __/ _ \\ \\/ / __| '_ \\ / _` |/ _` |/ _ \\ '__/ _` | '__| __|\n// \\ V / __/ | | || __/> <\\__ \\ | | | (_| | (_| | __/ | | (_| | | | |_ \n// \\_/ \\___|_| \\__\\___/_/\\_\\___/_| |_|\\__,_|\\__,_|\\___|_| \\__,_|_| \\__|\n//\n\nvec3 gSunColor = vec3(1.0, 1.0, 1.0) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nvec3 gCubeColor = vec3(1.0, 1.0, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.0;\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0., 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat4 mat, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n #if 0\n \tv0 = (vec4(v0, 1) * mat).xyz;\n \tv1 = (vec4(v1, 1) * mat).xyz;\n \tv2 = (vec4(v2, 1) * mat).xyz;\n \tv3 = (vec4(v3, 1) * mat).xyz;\n #else\n \tv0 = (mat * vec4(v0, 1)).xyz;\n \tv1 = (mat * vec4(v1, 1)).xyz;\n \tv2 = (mat * vec4(v2, 1)).xyz;\n \tv3 = (mat * vec4(v3, 1)).xyz;\n #endif\n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat4 mat, const vec3 vCubeCol, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n vec3 vNormal;\n\n GetCubeVertex( vertexIndex, mat, outSceneVertex.vWorldPos, vNormal );\n\n outSceneVertex.vColor = vec3( 0.0 );\n\n outSceneVertex.fAlpha = 1.0; \n\n float h = outSceneVertex.vWorldPos.y - gFloorHeight;\n outSceneVertex.vColor += GetSkyLighting( vNormal );\n outSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n\n outSceneVertex.vColor += GetSunLighting( vNormal );\n\n outSceneVertex.vColor *= vCubeCol; \n\n outSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvoid GetCubePosition( float fCubeId, out mat4 mat, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n \tfloat fSize = 1.0;\n\n \tvec3 vCubeOrigin = vec3( 0.0, 0.0, 4.0 );\n \n float across = 32.;\n float down = 20.;\n float u = mod(fCubeId, across) / across;\n float v = floor(fCubeId / across) / down;\n float lng = u * PI * 2.;\n float lat = v * PI;\n\n float snd = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\n \n vCubeOrigin.z += pow(snd, 8.0) * 8.0;\n float fScale = mix(0.1, 0.6, sin(lat)) * mix(0.7, 2.0, pow(snd, 8.0)) * snd;\n \n mat = ident();\n \tmat *= rotZ(lng);\n \tmat *= rotY(lat);\n mat *= trans(vCubeOrigin);\n mat *= uniformScale(fScale);\n \n \tvec3 vRandCol;\n\n float s2 = texture2D(sound, vec2(mix(0.015, 0.015, u), v * 0.25)).a;\n \n vCubeCol = mix(hsv2rgb(vec3(time + 0.5, 0., 0.2)) * pow(s2 + 0.25, 90.), vec3(1,1,1), pow(s2, 40.0)); \n vCubeCol = mix(vCubeCol, hsv2rgb(vec3(time * 1.,1,1)), step(0.8,s2));\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -2.2 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 25.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 10.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation * 1.11), cos(orbitAngle * 0.97) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n float fCubeId = floor( vertexIndex / g_cubeVertexCount );\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n mat4 mCube;\n vec3 vCubeCol;\n\n GetCubePosition( fCubeId, mCube, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeCol, vCameraPos, sceneVertex );\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, 1.);//sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-6lhwgmyfp2swf2n4k-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xvh5kBvczrdcehxxG/art.json b/art/xvh5kBvczrdcehxxG/art.json index 7a8cc835..64bafe3e 100644 --- a/art/xvh5kBvczrdcehxxG/art.json +++ b/art/xvh5kBvczrdcehxxG/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/droplexofficial/armin-van-buuren-vini-vici-great-spirit-droplex-strong-r-bootleg\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nWait for the music to pump \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nmat4 mixm(mat4 m1, mat4 m2, float m) {\\n return mat4(\\n mix(m1[0], m2[0], m),\\n mix(m1[1], m2[1], m),\\n mix(m1[2], m2[2], m),\\n mix(m1[3], m2[3], m));\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float elemId = floor(pointId / 36.);\\n float numElems = floor(vertexCount / 36.);\\n float cubeId = floor(elemId / 3.);\\n float numCubes = floor(numElems / 3.);\\n float down = floor(sqrt(numCubes) * .5);\\n float across = floor(numCubes / down);\\n\\n float uu = mod(cubeId, across);\\n float vv = floor(cubeId / across);\\n vec2 uv = (vec2(uu, vv) + .0) / vec2(across, down);\\n \\n float tm = time * 0.1;\\n mat4 vpmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n vpmat *= cameraLookAt(eye, target, up);\\n \\n float groupId = mod(elemId, 3.);\\n// float s = texture2D(sound, vec2(uv.y, 0.)).a;\\n float s = texture2D(sound, vec2(groupId / 3. * 0.1, 0.)).a;\\n \\n float h1 = .65;\\n mat4 m1 = rotX(uv.y * PI);\\n m1 *= rotY(uv.x * PI * 2.);\\n m1 *= trans(vec3(6. * s, 0, 0));\\n \\n float h2 = 0.;\\n float axisX = step(0.5, mod(cubeId + 0., 3.));\\n float axisY = step(0.5, mod(cubeId + 1., 3.));\\n float axisZ = step(0.5, mod(cubeId + 2., 3.));\\n vec3 p2 = vec3(axisX, axisY, axisZ);\\n mat4 m2 = trans(((vec3(1) - p2) * mix(-1., 1., mod(cubeId, 2.)) + (p2 * vec3(\\n t2m1(hash(cubeId * 0.123)), \\n t2m1(hash(cubeId * .345)), \\n t2m1(hash(cubeId * .712))))) * 6. * s); \\n \\n float h3 = .5;\\n mat4 m3 = rotY(uv.x * PI * 2.); \\n m3 *= trans((vec3(\\n 1.,\\n t2m1(uv.y),\\n 0)) * 6. * s);\\n \\n \\n float mode = mod(elemId, 3.);\\n \\n float m1m = (1. - clamp(abs(mode - 0.), 0., 1.));\\n float m2m = (1. - clamp(abs(mode - 1.), 0., 1.));\\n float m3m = (1. - clamp(abs(mode - 2.), 0., 1.));\\n \\n float hue = h1 * m1m + h2 * m2m + h3 * m3m;\\n float sat = 1.;//mix(0.9, 1., step(0.8, s));\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n\\n \\n \\n mat4 smat = uniformScale(0.5);\\n\\n mat4 mat = m1 * m1m +\\n m2 * m2m + \\n m3 * m3m;\\n \\n gl_Position = vpmat * mat * smat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/droplexofficial/armin-van-buuren-vini-vici-great-spirit-droplex-strong-r-bootleg", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nWait for the music to pump \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nmat4 mixm(mat4 m1, mat4 m2, float m) {\n return mat4(\n mix(m1[0], m2[0], m),\n mix(m1[1], m2[1], m),\n mix(m1[2], m2[2], m),\n mix(m1[3], m2[3], m));\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float elemId = floor(pointId / 36.);\n float numElems = floor(vertexCount / 36.);\n float cubeId = floor(elemId / 3.);\n float numCubes = floor(numElems / 3.);\n float down = floor(sqrt(numCubes) * .5);\n float across = floor(numCubes / down);\n\n float uu = mod(cubeId, across);\n float vv = floor(cubeId / across);\n vec2 uv = (vec2(uu, vv) + .0) / vec2(across, down);\n \n float tm = time * 0.1;\n mat4 vpmat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * 24., sin(tm * 0.9) * 14.5 + 1., sin(tm) * 24.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n vpmat *= cameraLookAt(eye, target, up);\n \n float groupId = mod(elemId, 3.);\n// float s = texture2D(sound, vec2(uv.y, 0.)).a;\n float s = texture2D(sound, vec2(groupId / 3. * 0.1, 0.)).a;\n \n float h1 = .65;\n mat4 m1 = rotX(uv.y * PI);\n m1 *= rotY(uv.x * PI * 2.);\n m1 *= trans(vec3(6. * s, 0, 0));\n \n float h2 = 0.;\n float axisX = step(0.5, mod(cubeId + 0., 3.));\n float axisY = step(0.5, mod(cubeId + 1., 3.));\n float axisZ = step(0.5, mod(cubeId + 2., 3.));\n vec3 p2 = vec3(axisX, axisY, axisZ);\n mat4 m2 = trans(((vec3(1) - p2) * mix(-1., 1., mod(cubeId, 2.)) + (p2 * vec3(\n t2m1(hash(cubeId * 0.123)), \n t2m1(hash(cubeId * .345)), \n t2m1(hash(cubeId * .712))))) * 6. * s); \n \n float h3 = .5;\n mat4 m3 = rotY(uv.x * PI * 2.); \n m3 *= trans((vec3(\n 1.,\n t2m1(uv.y),\n 0)) * 6. * s);\n \n \n float mode = mod(elemId, 3.);\n \n float m1m = (1. - clamp(abs(mode - 0.), 0., 1.));\n float m2m = (1. - clamp(abs(mode - 1.), 0., 1.));\n float m3m = (1. - clamp(abs(mode - 2.), 0., 1.));\n \n float hue = h1 * m1m + h2 * m2m + h3 * m3m;\n float sat = 1.;//mix(0.9, 1., step(0.8, s));\n float val = 1.;//mix(1., 1., step(0.8, s));\n\n \n \n mat4 smat = uniformScale(0.5);\n\n mat4 mat = m1 * m1m +\n m2 * m2m + \n m3 * m3m;\n \n gl_Position = vpmat * mat * smat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n}\n\n" + }, "screenshotURL": "data/images/images-ddyd3ov9bz46jn9xp-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xxhTPvXjTWPCPLM2v/art.json b/art/xxhTPvXjTWPCPLM2v/art.json index f69f98c8..319617f7 100644 --- a/art/xxhTPvXjTWPCPLM2v/art.json +++ b/art/xxhTPvXjTWPCPLM2v/art.json @@ -21,7 +21,19 @@ "origId": null, "name": "Knotted Candy", "username": "P_Malin", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.001;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.001;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotDataId": "vSHM8AAguEtw5qoi3", "views": { "$numberInt": "7907" diff --git a/art/xyMYnHS29GDusyzJp/art.json b/art/xyMYnHS29GDusyzJp/art.json index 07a9711f..f059a649 100644 --- a/art/xyMYnHS29GDusyzJp/art.json +++ b/art/xyMYnHS29GDusyzJp/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gerrygoo", "avatarUrl": "https://avatars.githubusercontent.com/gerrygoo?s=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define two_pi radians(360.0) \\n#define rot_x mat3(1, 0, 0, 0, cos(time), -sin(time), 0, sin(time), cos(time))\\n#define rot_z mat3(cos(time), -sin(time), 0, sin(time), cos(time), 0, 0, 0, 1)\\n\\nvoid main() {\\n\\n float\\t\\n per_circle = 100.0,\\n r = 0.8,\\n \\n x = mod(vertexId, per_circle),\\n y = floor(vertexId / per_circle),\\n \\n ph = x / per_circle * two_pi,\\n th = y / per_circle * two_pi;\\n \\n vec3 pos = vec3(\\n \\tr * sin(ph) * cos(th),\\n r * sin(ph) * sin(th),\\n r * cos(ph)\\n );\\n \\n \\n \\n \\n gl_Position = vec4(\\n rot_x * rot_z * pos,\\n 1\\n );\\n \\n gl_PointSize = 5.0;\\n v_color = vec4(0, 0.8, 1, 1);\\n \\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define two_pi radians(360.0) \n#define rot_x mat3(1, 0, 0, 0, cos(time), -sin(time), 0, sin(time), cos(time))\n#define rot_z mat3(cos(time), -sin(time), 0, sin(time), cos(time), 0, 0, 0, 1)\n\nvoid main() {\n\n float\t\n per_circle = 100.0,\n r = 0.8,\n \n x = mod(vertexId, per_circle),\n y = floor(vertexId / per_circle),\n \n ph = x / per_circle * two_pi,\n th = y / per_circle * two_pi;\n \n vec3 pos = vec3(\n \tr * sin(ph) * cos(th),\n r * sin(ph) * sin(th),\n r * cos(ph)\n );\n \n \n \n \n gl_Position = vec4(\n rot_x * rot_z * pos,\n 1\n );\n \n gl_PointSize = 5.0;\n v_color = vec4(0, 0.8, 1, 1);\n \n}" + }, "screenshotURL": "data/images/images-g276co5zitkjxzfbm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/xzFWA2bkiC4v8p9oX/art.json b/art/xzFWA2bkiC4v8p9oX/art.json index e845492f..66704232 100644 --- a/art/xzFWA2bkiC4v8p9oX/art.json +++ b/art/xzFWA2bkiC4v8p9oX/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "iguacel", "avatarUrl": "https://avatars.githubusercontent.com/iguacel?s=200", - "settings": "{\"num\":100,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.043137254901960784,0.0784313725490196,0.1568627450980392,1],\"shader\":\"void main() {\\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 10.0;\\n v_color = vec4(0,1,0,1);\\n}\"}", + "settings": { + "num": 100, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.043137254901960784, + 0.0784313725490196, + 0.1568627450980392, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 10.0;\n v_color = vec4(0,1,0,1);\n}" + }, "screenshotURL": "data/images/images-g8vnu8gx6whue078i-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/y2BcbbWxcksEGQYhq/art.json b/art/y2BcbbWxcksEGQYhq/art.json index 56d4c2d0..89b62ccf 100644 --- a/art/y2BcbbWxcksEGQYhq/art.json +++ b/art/y2BcbbWxcksEGQYhq/art.json @@ -27,7 +27,19 @@ "name": "sleep", "private": false, "username": "spotline", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/spotline/unpeuderepos\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main()\\n{\\n float x = vertexId * 0.025;\\n x = mod(x,2.0);\\n x-= 1.0;\\n float y = texture2D(sound,vec2(pow(vertexId/soundRes.x,2.0)*0.25,0.0)).a*0.5;\\n y*= 1.0 + vertexId * 0.025;\\n float instantY = y;\\n int smoothCount = 20;\\n for ( int i=0; i <= 20; i++)\\n {\\n y+=texture2D(sound,vec2(pow(vertexId/soundRes.x,2.0),float(i)/float(smoothCount)/64.0)).a;\\n }\\n y/=float(smoothCount+1);\\n float lum = clamp(instantY-y,0.0,0.5)*0.1;\\n\\n y = pow(y,2.0)-0.7;\\n gl_Position = vec4(x,y,0,1);\\n gl_PointSize = 44.0;\\n instantY = pow(instantY,0.5);\\n v_color = vec4((0.2+lum)*instantY,(0.2+lum+vertexId*0.0005)*instantY,(0.8+lum)*instantY,instantY);\\n}\\n\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/spotline/unpeuderepos", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main()\n{\n float x = vertexId * 0.025;\n x = mod(x,2.0);\n x-= 1.0;\n float y = texture2D(sound,vec2(pow(vertexId/soundRes.x,2.0)*0.25,0.0)).a*0.5;\n y*= 1.0 + vertexId * 0.025;\n float instantY = y;\n int smoothCount = 20;\n for ( int i=0; i <= 20; i++)\n {\n y+=texture2D(sound,vec2(pow(vertexId/soundRes.x,2.0),float(i)/float(smoothCount)/64.0)).a;\n }\n y/=float(smoothCount+1);\n float lum = clamp(instantY-y,0.0,0.5)*0.1;\n\n y = pow(y,2.0)-0.7;\n gl_Position = vec4(x,y,0,1);\n gl_PointSize = 44.0;\n instantY = pow(instantY,0.5);\n v_color = vec4((0.2+lum)*instantY,(0.2+lum+vertexId*0.0005)*instantY,(0.8+lum)*instantY,instantY);\n}\n" + }, "screenshotURL": "data/images/images-zoron4bjebo5tpvwo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/y2RHXZfCXZm9N45hp/art.json b/art/y2RHXZfCXZm9N45hp/art.json index 272aaf7f..8a06cace 100644 --- a/art/y2RHXZfCXZm9N45hp/art.json +++ b/art/y2RHXZfCXZm9N45hp/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-9k315owwhuoeqjd75-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/y2qQtMPftsgG9GmSw/art.json b/art/y2qQtMPftsgG9GmSw/art.json index cd2c057b..a6c5b38c 100644 --- a/art/y2qQtMPftsgG9GmSw/art.json +++ b/art/y2qQtMPftsgG9GmSw/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "andris", "avatarUrl": "https://lh5.googleusercontent.com/-NGcfEagpVJU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nBr6ANtWGgvfguJmVugmcp6_jd6hw/photo.jpg", - "settings": "{\"num\":1250,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n#define N 25.\\n#define NN N*N\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 zigzag(float j) {\\n j=floor(j);\\n j=mod(j,NN);\\n\\n bool h = j < NN / 2.;\\n float n = h ? j : NN - j - 1.;\\n float m = floor((sqrt(8. * n + 1.) - 1.) / 2.);\\n float t = n - m * (m + 1.) / 2.;\\n float even = floor(mod(m,2.));\\n float i = even*t + (1.-even)*(m - t);\\n vec2 outx = h ? \\n vec2(-i, m - i) \\n : vec2(1.-N+i, N - 1. - m + i);\\n return outx;\\n }\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 zz = zigzag(vertexId/2.)*0.05-.5;\\n oC=zz.x+1.;\\n oS=zz.y;\\n \\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c*0.2,\\n oS + s*0.2);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 1250, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n#define N 25.\n#define NN N*N\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 zigzag(float j) {\n j=floor(j);\n j=mod(j,NN);\n\n bool h = j < NN / 2.;\n float n = h ? j : NN - j - 1.;\n float m = floor((sqrt(8. * n + 1.) - 1.) / 2.);\n float t = n - m * (m + 1.) / 2.;\n float even = floor(mod(m,2.));\n float i = even*t + (1.-even)*(m - t);\n vec2 outx = h ? \n vec2(-i, m - i) \n : vec2(1.-N+i, N - 1. - m + i);\n return outx;\n }\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 zz = zigzag(vertexId/2.)*0.05-.5;\n oC=zz.x+1.;\n oS=zz.y;\n \n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c*0.2,\n oS + s*0.2);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-br69rn0woj3okh6sk-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/y37cKaKLxW7FgiTXm/art.json b/art/y37cKaKLxW7FgiTXm/art.json index d170911b..1b3addb2 100644 --- a/art/y37cKaKLxW7FgiTXm/art.json +++ b/art/y37cKaKLxW7FgiTXm/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "geumbi.yeo", "avatarUrl": "https://secure.gravatar.com/avatar/49f1da513e8353e36dc25636ecdb29d6?default=retro&size=200", - "settings": "{\"num\":16384,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/7z3dqybmtuda/queencard\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.8235294117647058,0.6745098039215687,0.6745098039215687,1],\"shader\":\"// Name : Geumbi Yeo\\n// Assignment : Circles from Triangles - Geumbi Yeo\\n// Course : CS250\\n// Term & Year : Spring 2023\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n} \\n\\n#define PI radians(180.0)\\n\\nmat4 rotZ(float angleInRadians)\\n{\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\n return mat4(\\n c,-s, 0, 0,\\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 trans(vec3 trans)\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident()\\n{\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0, \\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s)\\n{\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s)\\n{\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nvec2 getCirclePoint(float id, float numCircleSegments)\\n{ \\n float ux = floor(id / 6.) + mod(id, 2.); \\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n \\n float angle = ux / numCircleSegments * PI * 2.;\\n float c = cos(angle);\\n float s = sin(angle);\\n \\n float radius = vy + 1.;\\n \\n float x = c * radius;\\n float y = s * radius;\\n \\n return vec2(x, y);\\n\\n}\\n\\nvoid main()\\n{\\n float numCircleSegments = 10.;\\n vec2 circleXY = getCirclePoint(vertexId, \\n numCircleSegments);\\n float numPointsPerCircle = numCircleSegments * 15.;\\n float circleId = floor(vertexId / numPointsPerCircle);\\n float numCircles = floor(vertexCount / numPointsPerCircle);\\n \\n float sliceId = floor(vertexId / 3.0);\\n float oddSlice = mod(sliceId, 8.);\\n \\n float down = floor(sqrt(numCircles));\\n float across = floor(numCircles / down);\\n \\n float x = mod(circleId, across);\\n float y = floor(circleId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; \\n \\n float aspect = resolution.x / resolution.y;\\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\\n \\n sc *= sin(time) * across / 8.;\\n \\n vec4 pos = vec4(circleXY, 0, 1);\\n mat4 mat = ident();\\n mat *= scale(vec3(1, aspect, 1));\\n mat *= rotZ(time) + (mouse.x / 10.);\\n mat *= trans(vec3(ux, vy, 0) * 1.);\\n mat *= uniformScale(0.03 * sc);\\n \\n gl_Position = mat * pos;\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n float pump = step(0.1, snd);\\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\\n float sat = 1.; //mix(0.5, 1., pump); //mix(1., -10., av);\\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\\n \\n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\\n val += oddSlice * pump;\\n v_color = vec4(hsv2rgb(vec3(hue * cos(time / 10.), sat, val)), 1);\\n}\"}", + "settings": { + "num": 16384, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/7z3dqybmtuda/queencard", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.8235294117647058, + 0.6745098039215687, + 0.6745098039215687, + 1 + ], + "shader": "// Name : Geumbi Yeo\n// Assignment : Circles from Triangles - Geumbi Yeo\n// Course : CS250\n// Term & Year : Spring 2023\n\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n} \n\n#define PI radians(180.0)\n\nmat4 rotZ(float angleInRadians)\n{\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \n return mat4(\n c,-s, 0, 0,\n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 trans(vec3 trans)\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident()\n{\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0, \n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s)\n{\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s)\n{\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nvec2 getCirclePoint(float id, float numCircleSegments)\n{ \n float ux = floor(id / 6.) + mod(id, 2.); \n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n \n float angle = ux / numCircleSegments * PI * 2.;\n float c = cos(angle);\n float s = sin(angle);\n \n float radius = vy + 1.;\n \n float x = c * radius;\n float y = s * radius;\n \n return vec2(x, y);\n\n}\n\nvoid main()\n{\n float numCircleSegments = 10.;\n vec2 circleXY = getCirclePoint(vertexId, \n numCircleSegments);\n float numPointsPerCircle = numCircleSegments * 15.;\n float circleId = floor(vertexId / numPointsPerCircle);\n float numCircles = floor(vertexCount / numPointsPerCircle);\n \n float sliceId = floor(vertexId / 3.0);\n float oddSlice = mod(sliceId, 8.);\n \n float down = floor(sqrt(numCircles));\n float across = floor(numCircles / down);\n \n float x = mod(circleId, across);\n float y = floor(circleId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * .05, av * .25)).a; \n \n float aspect = resolution.x / resolution.y;\n float sc = pow(snd + 0.2, 5.) * mix(1., 1., oddSlice);\n \n sc *= sin(time) * across / 8.;\n \n vec4 pos = vec4(circleXY, 0, 1);\n mat4 mat = ident();\n mat *= scale(vec3(1, aspect, 1));\n mat *= rotZ(time) + (mouse.x / 10.);\n mat *= trans(vec3(ux, vy, 0) * 1.);\n mat *= uniformScale(0.03 * sc);\n \n gl_Position = mat * pos;\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n float pump = step(0.1, snd);\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * 0.05;\n float sat = 1.; //mix(0.5, 1., pump); //mix(1., -10., av);\n float val = mix(.4, pow(snd + 0.2, 5.), pump); //sin(time + v * u * 20.0) * .5 + .5;\n \n hue = hue + pump * oddSlice * 0.5 + pump * 0.33;\n val += oddSlice * pump;\n v_color = vec4(hsv2rgb(vec3(hue * cos(time / 10.), sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-eay5lolm6y4ej8fja-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/y3CAW8hkHFwKx9Lct/art.json b/art/y3CAW8hkHFwKx9Lct/art.json index 7b9d0900..ef478fbf 100644 --- a/art/y3CAW8hkHFwKx9Lct/art.json +++ b/art/y3CAW8hkHFwKx9Lct/art.json @@ -17,7 +17,19 @@ "name": "unnamed", "private": false, "username": "-anon-", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n//#define FIT_VERTICAL\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float localTime = time + 20.0;\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + localTime) * radius;\\n float s = sin(angle + localTime) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (localTime * 0.01 + count * .999);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n//#define FIT_VERTICAL\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float localTime = time + 20.0;\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + localTime) * radius;\n float s = sin(angle + localTime) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + localTime * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + localTime + count * 0.1) * innerRadius;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (localTime * 0.01 + count * .999);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-xbeoqdrn0rqzyvj4j-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/y3d4oox3xc3yNEGzi/art.json b/art/y3d4oox3xc3yNEGzi/art.json index e61bd04a..22725cf5 100644 --- a/art/y3d4oox3xc3yNEGzi/art.json +++ b/art/y3d4oox3xc3yNEGzi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() { \\n float aspect = resolution.x / resolution.y;\\n vec2 dim = floor(vec2(sqrt(vertexCount*aspect) ,sqrt(vertexCount/aspect)));\\n vec2 p = vec2(mod(vertexId, dim.x), mod(floor(vertexId/ dim.x),dim.y));\\n p /= dim;\\n p = p * 2.0 - 1.0;\\n gl_Position = vec4(p, 0.0, 1.0); \\n gl_PointSize=resolution.y / dim.y;\\n //p.x *= aspect;\\n vec3 col = texture2D(sound, p * 0.5 + 0.5).rgb;\\n v_color = vec4(col, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/naturaviva/dantiez-saunderson-john-norman-get-back-original-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() { \n float aspect = resolution.x / resolution.y;\n vec2 dim = floor(vec2(sqrt(vertexCount*aspect) ,sqrt(vertexCount/aspect)));\n vec2 p = vec2(mod(vertexId, dim.x), mod(floor(vertexId/ dim.x),dim.y));\n p /= dim;\n p = p * 2.0 - 1.0;\n gl_Position = vec4(p, 0.0, 1.0); \n gl_PointSize=resolution.y / dim.y;\n //p.x *= aspect;\n vec3 col = texture2D(sound, p * 0.5 + 0.5).rgb;\n v_color = vec4(col, 1.0);\n}" + }, "screenshotURL": "data/images/images-5g7zjf6aq3b15rmfz-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/y5x2iTpL5qQdipiKy/art.json b/art/y5x2iTpL5qQdipiKy/art.json index 20328266..b9a58ac7 100644 --- a/art/y5x2iTpL5qQdipiKy/art.json +++ b/art/y5x2iTpL5qQdipiKy/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"http://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* thank you GMAN! */\\n\\n//KDrawmode=GL_TRIANGLES\\n#define kp1 1.//KParameter 0.>>10.\\n#define kp2 2.//KParameter 0.>>5.\\n#define kp3 -.5//KParameter -4.>>22.\\n#define P4 1.//KParameter -1.>>8.\\n//KVertices_Number=10000\\n\\n#define PI radians(222.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, -1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = .3 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 3., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, .71);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis)*P4;\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0.201/sin(kp1*snd),\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\\n\\treturn fract(p2.x * p2.y * 95.4337)*12.;\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s +v-s;\\n float z = 0.;\\n pos = vec3(x, y, z-0.25)*s; \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(1.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 3.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 3.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 1.5);\\n mat *= rotZ(ud * PI * 0.4);\\n position = (mat * vec4(p,2)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\n#if 1\\nvoid main() {\\n float pointId = vertexId; \\n float vertexCount = 16677. *kp1;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes));\\n float across = floor(numCubes / down);\\n \\n float cx = mod(cubeId, across);\\n float cy = floor(cubeId / across);\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down + 1.3);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n \\n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\\n \\n float tm = time * 0.31;\\n float r = mix(1.0, .60, snd);\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .91 + 0.5, sin(tm) * 1.) * r;\\n vec3 target = vec3(-eye.x, -0.4, -eye.z*.76) * 8.5;\\n vec3 up = vec3(0,0.6,0);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= trans(vec3(ca, 0, cd) * 2.);\\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 7.);\\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * .5);\\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -0.7));\\n \\n\\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\\n float sat = pow(snd + 0.4, 15.);\\n float val = mix(1.1, 0.5, abs(cd));\\n vec3 color = hsv2rgb(vec3(hue*0.4, sat*snd, val*snd));\\n v_color = vec4(color * (dot(n, lightDir) * 0.165 + 0.5), pow(snd, 3.*P4));\\n v_color.rgb /= v_color.a;\\n}\\n#endif\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "http://soundcloud.com/themusicofma/japanese-bones-royalston-remix-across-the-city-and-into-your-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* thank you GMAN! */\n\n//KDrawmode=GL_TRIANGLES\n#define kp1 1.//KParameter 0.>>10.\n#define kp2 2.//KParameter 0.>>5.\n#define kp3 -.5//KParameter -4.>>22.\n#define P4 1.//KParameter -1.>>8.\n//KVertices_Number=10000\n\n#define PI radians(222.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, -1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = .3 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 3., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, .71);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis)*P4;\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0.201/sin(kp1*snd),\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye-kp3+snd), 2); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 4.3137*kp3));\n\treturn fract(p2.x * p2.y * 95.4337)*12.;\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s +v-s;\n float z = 0.;\n pos = vec3(x, y, z-0.25)*s; \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(1.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2.5*kp3 / 4. + PI * 3.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 3.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 1.5);\n mat *= rotZ(ud * PI * 0.4);\n position = (mat * vec4(p,2)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\n#if 1\nvoid main() {\n float pointId = vertexId; \n float vertexCount = 16677. *kp1;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes));\n float across = floor(numCubes / down);\n \n float cx = mod(cubeId, across);\n float cy = floor(cubeId / across);\n \n float cu = cx / (across - 1.);\n float cv = cy / (down + 1.3);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n \n float snd = texture2D(sound, vec2(mix(0.42, 0.3, abs(atan(ca, cd)) / PI), length(vec2(ca,cd))) * .1).a;\n \n float tm = time * 0.31;\n float r = mix(1.0, .60, snd);\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 1000.0);\n vec3 eye = vec3(cos(tm) * 1.3, sin(tm * 1.5*kp2) * .91 + 0.5, sin(tm) * 1.) * r;\n vec3 target = vec3(-eye.x, -0.4, -eye.z*.76) * 8.5;\n vec3 up = vec3(0,0.6,0);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= trans(vec3(ca, 0, cd) * 2.);\n mat *= rotX(pow(snd + .3, 5.) * 2. + abs(ca) * 7.);\n mat *= rotZ(pow(snd + .8, 5.5) * 1. + abs(cd) * .5);\n float sc = mix(0.02, 0.25, pow(snd +.1, 5.));\n mat *= scale(vec3(0.3 * sc, sc, 0.31 * sc));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -0.7));\n \n\n float hue = floor(time) * 0.5 + floor(time * 0.42 - length(vec2(ca, cd)) / 1.0) * 0.5; //abs(ca * cd) * 2.;\n float sat = pow(snd + 0.4, 15.);\n float val = mix(1.1, 0.5, abs(cd));\n vec3 color = hsv2rgb(vec3(hue*0.4, sat*snd, val*snd));\n v_color = vec4(color * (dot(n, lightDir) * 0.165 + 0.5), pow(snd, 3.*P4));\n v_color.rgb /= v_color.a;\n}\n#endif\n\n" + }, "screenshotURL": "data/images/images-mromo8j39eqa9ohuo-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/y6pAr7bDAF5LM9LLi/art.json b/art/y6pAr7bDAF5LM9LLi/art.json index d6f5b995..9028050d 100644 --- a/art/y6pAr7bDAF5LM9LLi/art.json +++ b/art/y6pAr7bDAF5LM9LLi/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/protector-101/protector-101-a-dancing-comet\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nconst float edgePointsPerCircle = 128.;\\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\\n\\nvoid main() {\\n float pointId = mod(vertexId, pointsPerCircle); \\n float pId = floor(pointId / 2.) + mod(pointId, 2.);\\n float numCircles = floor(vertexCount / pointsPerCircle);\\n float circleId = floor(vertexId / pointsPerCircle);\\n float numPairs = floor(numCircles / 2.);\\n float pairId = floor(circleId / 2.);\\n float pairV = pairId / numPairs;\\n float pairA = t2m1(pairV);\\n float odd = mod(pairId, 2.);\\n \\n float pV = pId / edgePointsPerCircle;\\n float cV = circleId / numCircles;\\n float cA = t2m1(cV);\\n \\n float a = pV * PI * 2.;\\n float x = cos(a);\\n float z = sin(a);\\n \\n vec3 pos = vec3(x, 0, z);\\n vec3 normal;\\n \\n float tm = time * 0.1;\\n float tm2 = time * 0.13;\\n\\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\\n wmat *= uniformScale(sin(pairA * PI));\\n vec4 wp = wmat * vec4(pos, 1.);\\n \\n float su = abs(atan(wp.x, wp.z)) / PI;\\n float sv = abs(wp.y) * 1.;\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\\n \\n float r = 2.5;\\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0., sin(tm2), cos(tm2));\\n \\n \\n mat *= cameraLookAt(eye, target, up);\\n \\n gl_Position = mat * wp;\\n\\n vec3 color = mix(\\n vec3(0.5, 0, 0),\\n vec3(0, 0, 0.5),\\n gl_Position.x);\\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\\n v_color.rgb *= v_color.a;\\n}\\n\\n\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/protector-101/protector-101-a-dancing-comet", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nconst float edgePointsPerCircle = 128.;\nconst float pointsPerCircle = edgePointsPerCircle * 2.;\n\nvoid main() {\n float pointId = mod(vertexId, pointsPerCircle); \n float pId = floor(pointId / 2.) + mod(pointId, 2.);\n float numCircles = floor(vertexCount / pointsPerCircle);\n float circleId = floor(vertexId / pointsPerCircle);\n float numPairs = floor(numCircles / 2.);\n float pairId = floor(circleId / 2.);\n float pairV = pairId / numPairs;\n float pairA = t2m1(pairV);\n float odd = mod(pairId, 2.);\n \n float pV = pId / edgePointsPerCircle;\n float cV = circleId / numCircles;\n float cA = t2m1(cV);\n \n float a = pV * PI * 2.;\n float x = cos(a);\n float z = sin(a);\n \n vec3 pos = vec3(x, 0, z);\n vec3 normal;\n \n float tm = time * 0.1;\n float tm2 = time * 0.13;\n\n mat4 wmat = rotZ(odd * PI * .5 + sin(tm));\n wmat *= trans(vec3(0, cos(pairA * PI), 0));\n wmat *= uniformScale(sin(pairA * PI));\n vec4 wp = wmat * vec4(pos, 1.);\n \n float su = abs(atan(wp.x, wp.z)) / PI;\n float sv = abs(wp.y) * 1.;\n float s = texture2D(sound, vec2(mix(0.1, 0.5, su), sv)).a;\n// float s = texture2D(sound, vec2(pairV, cV)).a;//\n wp.xyz *= mix(0.8, 1.2, pow(s, 1.));\n \n float r = 2.5;\n mat4 mat = persp(radians(60.0), resolution.x / resolution.y, 0.1, 10.0);\n vec3 eye = vec3(cos(tm) * r, sin(tm * 0.93) * r, sin(tm) * r);\n vec3 target = vec3(0);\n vec3 up = vec3(0., sin(tm2), cos(tm2));\n \n \n mat *= cameraLookAt(eye, target, up);\n \n gl_Position = mat * wp;\n\n vec3 color = mix(\n vec3(0.5, 0, 0),\n vec3(0, 0, 0.5),\n gl_Position.x);\n v_color = vec4(color, mix(.0, 1., pow(1. -sv, 2.)));\n v_color.rgb *= v_color.a;\n}\n\n" + }, "screenshotURL": "data/images/images-x5zxbkah1frvooizs-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yAwn2hvbxQLFnF3yv/art.json b/art/yAwn2hvbxQLFnF3yv/art.json index a2774d19..6405c7f8 100644 --- a/art/yAwn2hvbxQLFnF3yv/art.json +++ b/art/yAwn2hvbxQLFnF3yv/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tapos", "avatarUrl": "https://lh3.googleusercontent.com/a/ACg8ocLcSqwSc82VQduMzLtVzzfGNr9fy1Y-vHBpYEpqyKQiDA=s96-c", - "settings": "{\"num\":12189,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/zackofficial/zk-x-jw-bom-diggy\",\"lineSize\":\"CSS\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n#define NUM_SEGMENTS 51.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS - offset;\\n// float rPulse = pow(sin(time * 3. + -count * 0.05), 4.0);\\n float spread = 0.01;\\n float off = 0.1;\\n float speed = count * 0.004;\\n float snd = (\\n texture2D(sound, vec2(off + spread * 0., speed)).a +\\n texture2D(sound, vec2(off + spread * 1., speed)).a / 3. + \\n texture2D(sound, vec2(off + spread * 2., speed)).a) / 2.;\\n// radius = radius + pow(snd, 5.0) * 0.1;\\n// float radius = count * 0.02 + rPlus * 0.2 + 0.0;\\n float rPulse = pow(snd, 5.0);\\n float radius = count * 0.02 + rPulse * 0.2;\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(c, s);\\n gl_Position = vec4(xy * aspect, 0, 1);\\n gl_PointSize = 2.0 + length(xy) * 20. * resolution.x / 1600.0;\\n\\n float hue = (time * 0.003 - snd * 1.001);\\n float cPulse = pow(rPulse, 4.0);\\n float invCPulse = 1. - cPulse;\\n v_color = mix(vec4(hsv2rgb(vec3(hue, invCPulse, 1.)), 1), background, radius - cPulse);\\n}\"}", + "settings": { + "num": 12189, + "mode": "POINTS", + "sound": "https://soundcloud.com/zackofficial/zk-x-jw-bom-diggy", + "lineSize": "CSS", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n#define NUM_SEGMENTS 51.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS - offset;\n// float rPulse = pow(sin(time * 3. + -count * 0.05), 4.0);\n float spread = 0.01;\n float off = 0.1;\n float speed = count * 0.004;\n float snd = (\n texture2D(sound, vec2(off + spread * 0., speed)).a +\n texture2D(sound, vec2(off + spread * 1., speed)).a / 3. + \n texture2D(sound, vec2(off + spread * 2., speed)).a) / 2.;\n// radius = radius + pow(snd, 5.0) * 0.1;\n// float radius = count * 0.02 + rPlus * 0.2 + 0.0;\n float rPulse = pow(snd, 5.0);\n float radius = count * 0.02 + rPulse * 0.2;\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(c, s);\n gl_Position = vec4(xy * aspect, 0, 1);\n gl_PointSize = 2.0 + length(xy) * 20. * resolution.x / 1600.0;\n\n float hue = (time * 0.003 - snd * 1.001);\n float cPulse = pow(rPulse, 4.0);\n float invCPulse = 1. - cPulse;\n v_color = mix(vec4(hsv2rgb(vec3(hue, invCPulse, 1.)), 1), background, radius - cPulse);\n}" + }, "screenshotURL": "data/images/images-1dqpdaz21n1vt7x7f-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yAxcaQPNpt4jDhpQJ/art.json b/art/yAxcaQPNpt4jDhpQJ/art.json index 3ea95882..3253a948 100644 --- a/art/yAxcaQPNpt4jDhpQJ/art.json +++ b/art/yAxcaQPNpt4jDhpQJ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "bleedinqtiqer", "avatarUrl": "https://lh6.googleusercontent.com/-A8vXonWuy1Q/AAAAAAAAAAI/AAAAAAAAAAc/YnjEb9fs2_g/photo.jpg", - "settings": "{\"num\":360,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/umbleby/sets/ummmm\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.9803921568627451,0.9411764705882353,0.9803921568627451,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(4.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\\n float x = (u*60.0)-1.0;\\n float y = ((v+vold)*0.5);//*osc;\\n gl_PointSize = 10.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\\n v_color = vec4(0, 0, 0, 1);\\n}\"}", + "settings": { + "num": 360, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/umbleby/sets/ummmm", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.9803921568627451, + 0.9411764705882353, + 0.9803921568627451, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(4.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\n float x = (u*60.0)-1.0;\n float y = ((v+vold)*0.5);//*osc;\n gl_PointSize = 10.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\n v_color = vec4(0, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-kv9vturfnoq061tbc-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yCjeKmDJjLWcwymYt/art.json b/art/yCjeKmDJjLWcwymYt/art.json index a90d3df3..6b12110c 100644 --- a/art/yCjeKmDJjLWcwymYt/art.json +++ b/art/yCjeKmDJjLWcwymYt/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "minseok.kim", "avatarUrl": "https://secure.gravatar.com/avatar/9dbf6d7b52812c1307f1a8c8f4872756?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : minseok kim\\n//Assignment : Exercise - Vertexshaderart : Motion\\n//Course : CS250\\n//Term : Spring 2023\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.1) * 0.9;\\n float yoff = sin(time + x * 0.1) * 0.7;\\n \\n float ux = u * 2. - 1. + xoff;\\n \\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.009) * 20.;\\n \\n gl_PointSize = 1.0 + soff;\\n gl_PointSize *= 10. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(sin(time),1,cos(time),1);\\n}\\n\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : minseok kim\n//Assignment : Exercise - Vertexshaderart : Motion\n//Course : CS250\n//Term : Spring 2023\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.1) * 0.9;\n float yoff = sin(time + x * 0.1) * 0.7;\n \n float ux = u * 2. - 1. + xoff;\n \n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.009) * 20.;\n \n gl_PointSize = 1.0 + soff;\n gl_PointSize *= 10. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(sin(time),1,cos(time),1);\n}\n" + }, "screenshotURL": "data/images/images-f2dnzi7bngizeh0u8-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yF4vdFqXorG76fRmR/art.json b/art/yF4vdFqXorG76fRmR/art.json index b764a26b..d44c139d 100644 --- a/art/yF4vdFqXorG76fRmR/art.json +++ b/art/yF4vdFqXorG76fRmR/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "rus-abd", "avatarUrl": "https://avatars.githubusercontent.com/Rus-Abd?s=200", - "settings": "{\"num\":54954,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/joker-killer-535317309/timur-mutsuraev-izmena\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.0196078431372549,0.0196078431372549,0.0196078431372549,1],\"shader\":\"\\nvec4 permute(vec4 x){return mod(((x*34.)+1.)*x,289.);}\\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159-.85373472095314*r;}\\n\\nfloat snoise(vec3 v){\\n const vec2 C=vec2(1./6.,1./3.);\\n const vec4 D=vec4(0.,.5,1.,2.);\\n \\n vec3 i=floor(v+dot(v,C.yyy));\\n vec3 x0=v-i+dot(i,C.xxx);\\n \\n vec3 g=step(x0.yzx,x0.xyz);\\n vec3 l=1.-g;\\n vec3 i1=min(g.xyz,l.zxy);\\n vec3 i2=max(g.xyz,l.zxy);\\n \\n vec3 x1=x0-i1+1.*C.xxx;\\n vec3 x2=x0-i2+2.*C.xxx;\\n vec3 x3=x0-1.+3.*C.xxx;\\n \\n i=mod(i,289.);\\n vec4 p=permute(permute(permute(\\n i.z+vec4(0.,i1.z,i2.z,1.))\\n +i.y+vec4(0.,i1.y,i2.y,1.))\\n +i.x+vec4(0.,i1.x,i2.x,1.));\\n \\n float n_=1./7.;\\n vec3 ns=n_*D.wyz-D.xzx;\\n \\n vec4 j=p-49.*floor(p*ns.z*ns.z);\\n \\n vec4 x_=floor(j*ns.z);\\n vec4 y_=floor(j-7.*x_);\\n \\n vec4 x=x_*ns.x+ns.yyyy;\\n vec4 y=y_*ns.x+ns.yyyy;\\n vec4 h=1.-abs(x)-abs(y);\\n \\n vec4 b0=vec4(x.xy,y.xy);\\n vec4 b1=vec4(x.zw,y.zw);\\n \\n vec4 s0=floor(b0)*2.+1.;\\n vec4 s1=floor(b1)*2.+1.;\\n vec4 sh=-step(h,vec4(0.));\\n \\n vec4 a0=b0.xzyw+s0.xzyw*sh.xxyy;\\n vec4 a1=b1.xzyw+s1.xzyw*sh.zzww;\\n \\n vec3 p0=vec3(a0.xy,h.x);\\n vec3 p1=vec3(a0.zw,h.y);\\n vec3 p2=vec3(a1.xy,h.z);\\n vec3 p3=vec3(a1.zw,h.w);\\n \\n vec4 norm=taylorInvSqrt(vec4(dot(p0,p0),dot(p1,p1),dot(p2,p2),dot(p3,p3)));\\n p0*=norm.x;\\n p1*=norm.y;\\n p2*=norm.z;\\n p3*=norm.w;\\n \\n vec4 m=max(.6-vec4(dot(x0,x0),dot(x1,x1),dot(x2,x2),dot(x3,x3)),0.);\\n m=m*m;\\n return 42.*dot(m*m,vec4(dot(p0,x0),dot(p1,x1),\\n dot(p2,x2),dot(p3,x3)));\\n }\\n \\n vec3 snoiseVec3(vec3 x){\\n \\n float s=snoise(vec3(x));\\n float s1=snoise(vec3(x.y-19.1,x.z+33.4,x.x+47.2));\\n float s2=snoise(vec3(x.z+74.2,x.x-124.5,x.y+99.4));\\n vec3 c=vec3(s,s1,s2);\\n return c;\\n \\n }\\n \\n vec3 curlNoise(vec3 p){\\n \\n const float e=.1;\\n vec3 dx=vec3(e,0.,0.);\\n vec3 dy=vec3(0.,e,0.);\\n vec3 dz=vec3(0.,0.,e);\\n \\n vec3 p_x0=snoiseVec3(p-dx);\\n vec3 p_x1=snoiseVec3(p+dx);\\n vec3 p_y0=snoiseVec3(p-dy);\\n vec3 p_y1=snoiseVec3(p+dy);\\n vec3 p_z0=snoiseVec3(p-dz);\\n vec3 p_z1=snoiseVec3(p+dz);\\n \\n float x=p_y1.z-p_y0.z-p_z1.y+p_z0.y;\\n float y=p_z1.x-p_z0.x-p_x1.z+p_x0.z;\\n float z=p_x1.y-p_x0.y-p_y1.x+p_y0.x;\\n \\n const float divisor=1./(3.*e);\\n return normalize(vec3(x,y,z)*divisor);\\n \\n }\\n\\nvec2 getPosition(){\\n \\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount/down);\\n \\n \\tfloat x = mod(vertexId,across);\\n \\tfloat y = floor(vertexId/across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n \\tvec2 res = (vec2(u,v) - .5) *2.;\\n\\treturn vec2(res);\\n}\\n\\nvoid main() {\\n \\n vec3 position = vec3(getPosition(),.1);\\n \\n float theta = 3.1415*time;\\n \\n //position.y = sin(theta+position.x)/2.;\\n vec3 curlPosition = vec3(mod(position.x,1.),position.y+time/31.,position.y);\\n position = curlNoise(curlPosition);\\n\\n\\n \\n gl_PointSize = 2. * (1.)*600./resolution.x;\\n \\n \\n \\n \\n gl_Position = vec4(position,1.);\\n v_color = vec4(1.,0.,0.,1.);\\n}\"}", + "settings": { + "num": 54954, + "mode": "POINTS", + "sound": "https://soundcloud.com/joker-killer-535317309/timur-mutsuraev-izmena", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.0196078431372549, + 0.0196078431372549, + 0.0196078431372549, + 1 + ], + "shader": "\nvec4 permute(vec4 x){return mod(((x*34.)+1.)*x,289.);}\nvec4 taylorInvSqrt(vec4 r){return 1.79284291400159-.85373472095314*r;}\n\nfloat snoise(vec3 v){\n const vec2 C=vec2(1./6.,1./3.);\n const vec4 D=vec4(0.,.5,1.,2.);\n \n vec3 i=floor(v+dot(v,C.yyy));\n vec3 x0=v-i+dot(i,C.xxx);\n \n vec3 g=step(x0.yzx,x0.xyz);\n vec3 l=1.-g;\n vec3 i1=min(g.xyz,l.zxy);\n vec3 i2=max(g.xyz,l.zxy);\n \n vec3 x1=x0-i1+1.*C.xxx;\n vec3 x2=x0-i2+2.*C.xxx;\n vec3 x3=x0-1.+3.*C.xxx;\n \n i=mod(i,289.);\n vec4 p=permute(permute(permute(\n i.z+vec4(0.,i1.z,i2.z,1.))\n +i.y+vec4(0.,i1.y,i2.y,1.))\n +i.x+vec4(0.,i1.x,i2.x,1.));\n \n float n_=1./7.;\n vec3 ns=n_*D.wyz-D.xzx;\n \n vec4 j=p-49.*floor(p*ns.z*ns.z);\n \n vec4 x_=floor(j*ns.z);\n vec4 y_=floor(j-7.*x_);\n \n vec4 x=x_*ns.x+ns.yyyy;\n vec4 y=y_*ns.x+ns.yyyy;\n vec4 h=1.-abs(x)-abs(y);\n \n vec4 b0=vec4(x.xy,y.xy);\n vec4 b1=vec4(x.zw,y.zw);\n \n vec4 s0=floor(b0)*2.+1.;\n vec4 s1=floor(b1)*2.+1.;\n vec4 sh=-step(h,vec4(0.));\n \n vec4 a0=b0.xzyw+s0.xzyw*sh.xxyy;\n vec4 a1=b1.xzyw+s1.xzyw*sh.zzww;\n \n vec3 p0=vec3(a0.xy,h.x);\n vec3 p1=vec3(a0.zw,h.y);\n vec3 p2=vec3(a1.xy,h.z);\n vec3 p3=vec3(a1.zw,h.w);\n \n vec4 norm=taylorInvSqrt(vec4(dot(p0,p0),dot(p1,p1),dot(p2,p2),dot(p3,p3)));\n p0*=norm.x;\n p1*=norm.y;\n p2*=norm.z;\n p3*=norm.w;\n \n vec4 m=max(.6-vec4(dot(x0,x0),dot(x1,x1),dot(x2,x2),dot(x3,x3)),0.);\n m=m*m;\n return 42.*dot(m*m,vec4(dot(p0,x0),dot(p1,x1),\n dot(p2,x2),dot(p3,x3)));\n }\n \n vec3 snoiseVec3(vec3 x){\n \n float s=snoise(vec3(x));\n float s1=snoise(vec3(x.y-19.1,x.z+33.4,x.x+47.2));\n float s2=snoise(vec3(x.z+74.2,x.x-124.5,x.y+99.4));\n vec3 c=vec3(s,s1,s2);\n return c;\n \n }\n \n vec3 curlNoise(vec3 p){\n \n const float e=.1;\n vec3 dx=vec3(e,0.,0.);\n vec3 dy=vec3(0.,e,0.);\n vec3 dz=vec3(0.,0.,e);\n \n vec3 p_x0=snoiseVec3(p-dx);\n vec3 p_x1=snoiseVec3(p+dx);\n vec3 p_y0=snoiseVec3(p-dy);\n vec3 p_y1=snoiseVec3(p+dy);\n vec3 p_z0=snoiseVec3(p-dz);\n vec3 p_z1=snoiseVec3(p+dz);\n \n float x=p_y1.z-p_y0.z-p_z1.y+p_z0.y;\n float y=p_z1.x-p_z0.x-p_x1.z+p_x0.z;\n float z=p_x1.y-p_x0.y-p_y1.x+p_y0.x;\n \n const float divisor=1./(3.*e);\n return normalize(vec3(x,y,z)*divisor);\n \n }\n\nvec2 getPosition(){\n \tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount/down);\n \n \tfloat x = mod(vertexId,across);\n \tfloat y = floor(vertexId/across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n \tvec2 res = (vec2(u,v) - .5) *2.;\n\treturn vec2(res);\n}\n\nvoid main() {\n \n vec3 position = vec3(getPosition(),.1);\n \n float theta = 3.1415*time;\n \n //position.y = sin(theta+position.x)/2.;\n vec3 curlPosition = vec3(mod(position.x,1.),position.y+time/31.,position.y);\n position = curlNoise(curlPosition);\n\n\n \n gl_PointSize = 2. * (1.)*600./resolution.x;\n \n \n \n \n gl_Position = vec4(position,1.);\n v_color = vec4(1.,0.,0.,1.);\n}" + }, "screenshotURL": "data/images/images-0b5tshfd5rx5p5b42-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yHrv6nf5GNziSJHX5/art.json b/art/yHrv6nf5GNziSJHX5/art.json index a0941b56..c526fe90 100644 --- a/art/yHrv6nf5GNziSJHX5/art.json +++ b/art/yHrv6nf5GNziSJHX5/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":99066,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/sevdaliza/that-other-girl-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n \\n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \\n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \\n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \\n \\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 3.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle / 12.);\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, -0.1, 1, 0,\\n s, 0, c, -0.3,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle -3.);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0.2,\\n 0, 0, 0, 1) * 2.0; \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 1.1,\\n 0, -0.4, 1, 0,\\n trans-.1, 1.2) ;\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0.1, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.2;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., level);\\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\\n float s = sin(a);\\n float c = cos(a /s);\\n float x = c -mod( s, v);\\n float y = s = v + 12./ s *.04;\\n float z = 0.7;\\n pos = vec3(x, y, z -1. ); \\n uv = vec2(u, level);\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cu = circleId / numCircles;\\n vec3 pos;\\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\\n float end = start - .3 +time ;//start + hash(sideId + 1.);\\n vec2 uv;\\n getCirclePoint(pointId, inner, start, end, pos, uv); \\n \\n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\\n \\n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\\n offset.x += goop(circleId + time * 0.203) * 0.4;\\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(offset);\\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\\n gl_PointSize = sin(5. *snd);\\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\\n float sat = 2.9 / circleId;\\n float val = .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 99066, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/sevdaliza/that-other-girl-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n \n. . .-. .-. .-. .-. . . .-. . . .-. .-. .-. .-. .-. .-. .-. \n| | |- |( | |- )( `-. |-| |-| | )|- |( |-| |( | \n`.' `-' ' ' ' `-' ' ` `-' ' ` ` ' `-' `-' ' ' ` ' ' ' ' \n \n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 3.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 18.0 * K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, -0.2, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle / 12.);\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, -0.1, 1, 0,\n s, 0, c, -0.3,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle -3.);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0.2,\n 0, 0, 0, 1) * 2.0; \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 1.1,\n 0, -0.4, 1, 0,\n trans-.1, 1.2) ;\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0.1, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.2;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_SUBDIVISIONS_PER_CIRCLE 16.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec2 uv) {\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 3.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 13.), 4.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.2);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., level);\n float a = mix(start, end, u) * PI * 3. + PI * 0.1;\n float s = sin(a);\n float c = cos(a /s);\n float x = c -mod( s, v);\n float y = s = v + 12./ s *.04;\n float z = 0.7;\n pos = vec3(x, y, z -1. ); \n uv = vec2(u, level);\n}\n\n\nfloat goop(float t) {\n return sin(t) + sin(t * 1.27) + tan(t * 0.3+mouse.x) + cos(t- 1.73);\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE); float sideId = floor(circleId + 4.);\n float side = mix(-1., 1., step(0.2, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cu = circleId / numCircles;\n vec3 pos;\n float inner = mix(0.073, 2.2, p1m1(sin(goop(circleId) + time * 3.1)));\n float start = fract(hash(circleId * 2.33) + sin(time * .3 + circleId) * .1);\n float end = start - .3 +time ;//start + hash(sideId + 1.);\n vec2 uv;\n getCirclePoint(pointId, inner, start, end, pos, uv); \n \n float snd = texture2D(sound, vec2((cu + abs(uv.x * 0.8 )) * 0.025, uv.y - 2.4)).a;\n \n vec3 offset = vec3(m1p1(hash(circleId)) * 0.5, m1p1(hash(circleId - 1.37)), -m1p1(circleId / numCircles));\n offset.x += goop(circleId + time * 0.203) * 0.4;\n offset.y += goop(circleId + time * 0.13) * 0.31-mouse.y;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 2);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(offset);\n mat *= uniformScale(mix(0.1, 0.4, hash(circleId)));\n gl_Position = vec4((mat * vec4(pos, 0.2)).xyz, 1.2);\n gl_PointSize = sin(5. *snd);\n float hue = mix(0.3-snd, 2.6/snd, fract(circleId - .79));\n float sat = 2.9 / circleId;\n float val = .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), (2. - uv.y) * pow(snd + .01, 7.));\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-kvv2iwsh00f4ft2hv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yJStxdpLgCWHmBA7n/art.json b/art/yJStxdpLgCWHmBA7n/art.json index 0cc41982..b3650262 100644 --- a/art/yJStxdpLgCWHmBA7n/art.json +++ b/art/yJStxdpLgCWHmBA7n/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1360,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\" void main() {\\n \\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n // float pointSize = 5.;\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId /across);\\n \\n float u = x/(across-1.);\\n float v = y/(across-1.);\\n \\n float yoff = sin(time + x * 0.1);\\n float xoff = sin(time + y * 0.1);\\n\\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n // float vy = v * 2. - 1.;\\n \\n gl_Position = vec4(ux,vy,0,1);\\n gl_PointSize = 10.;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(1,0,0,1);\\n \\n}\"}", + "settings": { + "num": 1360, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": " void main() {\n \n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n // float pointSize = 5.;\n \n float x = mod(vertexId, across);\n float y = floor(vertexId /across);\n \n float u = x/(across-1.);\n float v = y/(across-1.);\n \n float yoff = sin(time + x * 0.1);\n float xoff = sin(time + y * 0.1);\n\n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n // float vy = v * 2. - 1.;\n \n gl_Position = vec4(ux,vy,0,1);\n gl_PointSize = 10.;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(1,0,0,1);\n \n}" + }, "screenshotURL": "data/images/images-l3yqem4dorrunlng2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yKbsMohpXxZXWLHSm/art.json b/art/yKbsMohpXxZXWLHSm/art.json index 27d1b95c..f067710c 100644 --- a/art/yKbsMohpXxZXWLHSm/art.json +++ b/art/yKbsMohpXxZXWLHSm/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":576,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/nightclubband/freak-like-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\nJust wanted to see if I could kind of make a VU meter with max levels\\nThere's 3 parts to each column\\n\\n1. The top: Max for last few moments. Currently 1/3 second (20 frames)\\n2. The red line: The instantaneous average for all frequenies in that column\\n3. The column itself: The instantaneous max\\n\\nI'm a little surprised: It reads 20*64 (1280) per vertex. Setting it to 100k\\nstill runs at 60fps on my NVidia GeForce GT 750M\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n// adapted from http://stackoverflow.com/a/26127012/128511\\n\\nvec3 fibonacciSphere(float samples, float i) {\\n float rnd = 1.;\\n float offset = 2. / samples;\\n float increment = PI * (3. - sqrt(5.));\\n\\n // for i in range(samples):\\n float y = ((i * offset) - 1.) + (offset / 2.);\\n float r = sqrt(1. - pow(y ,2.));\\n\\n float phi = mod(i + rnd, samples) * increment;\\n\\n float x = cos(phi) * r;\\n float z = sin(phi) * r;\\n\\n return vec3(x, y, z);\\n}\\n\\n\\nfloat easeInOutPow(float pos, float pw) {\\n if ((pos /= 0.5) < 1.) {\\n return 0.5 * pow(pos, pw);\\n }\\n return 0.5 * (pow((pos - 2.), pw) + 2.);\\n}\\n\\n\\nvoid main() {\\n float vId = mod(vertexId, 6.);\\n float ux = floor(vId / 6.) + mod(vId, 2.);\\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \\n \\n float quadsPerArea = 3.;\\n float pointsPerArea = quadsPerArea * 6.;\\n float areaId = floor(vertexId / pointsPerArea);\\n float numAreas = floor(vertexCount / pointsPerArea);\\n float areaV = areaId / numAreas;\\n float areaVertId = mod(vertexId, pointsPerArea);\\n float rowId = floor(areaVertId / 6.);\\n \\n float maxBarHeight = 0.025;\\n const int numSamples = 20; // number of history samples to read. So 30 = 1/2 second\\n const int samplesPerArea = 64; // samples across a row. There are 4096 samples I think\\n // 128 would be 32 area\\n \\n \\n float sampleRangePerArea = soundRes.x / float(samplesPerArea);\\n float sampleRangeMult = sampleRangePerArea / float(samplesPerArea) / soundRes.x; \\n \\n float timeMaxS = 0.0;\\n float instMaxS = 0.0;\\n float avgS = 0.0;\\n for (int j = 0; j < samplesPerArea; ++j) {\\n float su = areaV + float(j) * sampleRangeMult;\\n float s = texture2D(sound, vec2(su, 0)).a;\\n avgS += s;\\n instMaxS = max(s, instMaxS);\\n timeMaxS = max(s, timeMaxS);\\n for (int i = 1; i < numSamples; ++i) {\\n s = texture2D(sound, vec2(su, (float(i) + .5) / soundRes.y)).a;\\n timeMaxS = max(s, timeMaxS);\\n }\\n } \\n \\n avgS /= float(samplesPerArea);\\n \\n float isRow2 = step(1.5, rowId);\\n \\n vec3 pos = vec3(ux, vy, rowId * -.1);\\n mat4 mat = trans(vec3(-1, -1, 0));\\n mat *= uniformScale(2.0);\\n\\n float row0 = 0.;\\n float row1 = timeMaxS - maxBarHeight * .5;\\n float row2 = avgS - maxBarHeight * .5;\\n mat *= trans(vec3(\\n 0, \\n mix(mix(row0, row1, step(0.5, rowId)), row2, isRow2),\\n 0));\\n mat *= scale(vec3(1. / numAreas * .9, mix(instMaxS, maxBarHeight, step(0.5, rowId)), 1));\\n mat *= trans(vec3(areaId * 1.1, 0, 0));\\n \\n gl_Position = mat * vec4(pos, 1);\\n\\n float hue = areaV * .2 + .6 + rowId * .9 + step(1.5, rowId) * .5;\\n float sat = instMaxS;\\n float val = mix(mix(0.2, 1.0, pow(instMaxS, 3.)), mix(0.2, 1.0, timeMaxS), rowId);\\n val = mix(val, mix(0.4, 1.0, avgS), isRow2);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 576, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/nightclubband/freak-like-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\nJust wanted to see if I could kind of make a VU meter with max levels\nThere's 3 parts to each column\n\n1. The top: Max for last few moments. Currently 1/3 second (20 frames)\n2. The red line: The instantaneous average for all frequenies in that column\n3. The column itself: The instantaneous max\n\nI'm a little surprised: It reads 20*64 (1280) per vertex. Setting it to 100k\nstill runs at 60fps on my NVidia GeForce GT 750M\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n// adapted from http://stackoverflow.com/a/26127012/128511\n\nvec3 fibonacciSphere(float samples, float i) {\n float rnd = 1.;\n float offset = 2. / samples;\n float increment = PI * (3. - sqrt(5.));\n\n // for i in range(samples):\n float y = ((i * offset) - 1.) + (offset / 2.);\n float r = sqrt(1. - pow(y ,2.));\n\n float phi = mod(i + rnd, samples) * increment;\n\n float x = cos(phi) * r;\n float z = sin(phi) * r;\n\n return vec3(x, y, z);\n}\n\n\nfloat easeInOutPow(float pos, float pw) {\n if ((pos /= 0.5) < 1.) {\n return 0.5 * pow(pos, pw);\n }\n return 0.5 * (pow((pos - 2.), pw) + 2.);\n}\n\n\nvoid main() {\n float vId = mod(vertexId, 6.);\n float ux = floor(vId / 6.) + mod(vId, 2.);\n float vy = mod(floor(vId / 2.) + floor(vId / 3.), 2.); \n \n float quadsPerArea = 3.;\n float pointsPerArea = quadsPerArea * 6.;\n float areaId = floor(vertexId / pointsPerArea);\n float numAreas = floor(vertexCount / pointsPerArea);\n float areaV = areaId / numAreas;\n float areaVertId = mod(vertexId, pointsPerArea);\n float rowId = floor(areaVertId / 6.);\n \n float maxBarHeight = 0.025;\n const int numSamples = 20; // number of history samples to read. So 30 = 1/2 second\n const int samplesPerArea = 64; // samples across a row. There are 4096 samples I think\n // 128 would be 32 area\n \n \n float sampleRangePerArea = soundRes.x / float(samplesPerArea);\n float sampleRangeMult = sampleRangePerArea / float(samplesPerArea) / soundRes.x; \n \n float timeMaxS = 0.0;\n float instMaxS = 0.0;\n float avgS = 0.0;\n for (int j = 0; j < samplesPerArea; ++j) {\n float su = areaV + float(j) * sampleRangeMult;\n float s = texture2D(sound, vec2(su, 0)).a;\n avgS += s;\n instMaxS = max(s, instMaxS);\n timeMaxS = max(s, timeMaxS);\n for (int i = 1; i < numSamples; ++i) {\n s = texture2D(sound, vec2(su, (float(i) + .5) / soundRes.y)).a;\n timeMaxS = max(s, timeMaxS);\n }\n } \n \n avgS /= float(samplesPerArea);\n \n float isRow2 = step(1.5, rowId);\n \n vec3 pos = vec3(ux, vy, rowId * -.1);\n mat4 mat = trans(vec3(-1, -1, 0));\n mat *= uniformScale(2.0);\n\n float row0 = 0.;\n float row1 = timeMaxS - maxBarHeight * .5;\n float row2 = avgS - maxBarHeight * .5;\n mat *= trans(vec3(\n 0, \n mix(mix(row0, row1, step(0.5, rowId)), row2, isRow2),\n 0));\n mat *= scale(vec3(1. / numAreas * .9, mix(instMaxS, maxBarHeight, step(0.5, rowId)), 1));\n mat *= trans(vec3(areaId * 1.1, 0, 0));\n \n gl_Position = mat * vec4(pos, 1);\n\n float hue = areaV * .2 + .6 + rowId * .9 + step(1.5, rowId) * .5;\n float sat = instMaxS;\n float val = mix(mix(0.2, 1.0, pow(instMaxS, 3.)), mix(0.2, 1.0, timeMaxS), rowId);\n val = mix(val, mix(0.4, 1.0, avgS), isRow2);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-7f8p3jlah9ehualv6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yKgYMBxcoK34ebwHv/art.json b/art/yKgYMBxcoK34ebwHv/art.json index 41c71d6e..d05c5057 100644 --- a/art/yKgYMBxcoK34ebwHv/art.json +++ b/art/yKgYMBxcoK34ebwHv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "jaeyeong-an", "avatarUrl": "https://avatars.githubusercontent.com/Jaeyeong-An?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/thecoldvirgin/haon-vinxen-prod-groovyroom?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name : Jaeyeong An\\n//Assignment : Exercise - Vertexshaderart : Making a Grid\\n//Course : CS250\\n//Term : 2023 Fall\\n\\nvoid main()\\n{\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float ux = u * 2. -1. * sin(time);\\n float vy = v * 2. -1. * cos(time);\\n \\n gl_Position = vec4(ux, vy, 0, 1);\\n \\n gl_PointSize = 10.0;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 500. ;\\n \\n v_color = vec4(1, 1, 0, 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/thecoldvirgin/haon-vinxen-prod-groovyroom?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name : Jaeyeong An\n//Assignment : Exercise - Vertexshaderart : Making a Grid\n//Course : CS250\n//Term : 2023 Fall\n\nvoid main()\n{\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float ux = u * 2. -1. * sin(time);\n float vy = v * 2. -1. * cos(time);\n \n gl_Position = vec4(ux, vy, 0, 1);\n \n gl_PointSize = 10.0;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 500. ;\n \n v_color = vec4(1, 1, 0, 1);\n \n}" + }, "screenshotURL": "data/images/images-1v8987n3z4xoegaso-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yLbydHYz2jYr6t9DH/art.json b/art/yLbydHYz2jYr6t9DH/art.json index 5186c807..ebf999b6 100644 --- a/art/yLbydHYz2jYr6t9DH/art.json +++ b/art/yLbydHYz2jYr6t9DH/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":28423,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/spiritedlabel/in-my-head\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"// POST-ITs\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#if 1\\n\\nvoid main() {\\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(3., 8., fract(time * 0.1)));\\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\\n float NUM_CIRCLES_PER_GROUP = 2.0;\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = 64.;\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time * 0.1;// - cgv * 0.2;\\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.121, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.205, 0.001, gy / gDown), \\n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\\n \\n\\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cu * 0.001;\\n \\n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\\n \\n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \\n// mat *= cameraLookAt(eye, target, up);\\n// mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\\n float sp = pow(snd, 5.0);\\n\\n mat *= trans(vec3(cgv * -0.3 * snd, cgv * 0.2 * snd, -2. + gv + cgId * 0.01));\\n // mat *= rotZ(time * hash(gv * 0.124));// * 0.01 * gy * 0.1 + PI * 0.5);\\n // mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\\n // mat *= rotZ(gx / gAcross * PI * 2.);\\n // mat *= rotY(PI * 0.5);\\n mat *= rotZ(hash(groupId * 0.3412) * PI * 2.);\\n mat *= trans(vec3(\\n fract(t2m1(hash(gv) + tm * 0.1 * hash(gv * 0.12))) * 20. - 10. , \\n t2m1(hash(gv * .123)) * 3., 0.));\\n mat *= rotZ(PI * .25 + time * hash(groupId * 0.712));\\n mat *= uniformScale(snd * mix(0.5, 1., sliceId));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * 0.01 + sp * 0.2;//groupId * 0.1;\\n float sat = 0.3;\\n float val = mix(0., 1., cgId);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(.5, 1., cgId));\\n v_color.rgb *= v_color.a;\\n}\\n\\n#endif\"}", + "settings": { + "num": 28423, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/spiritedlabel/in-my-head", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "// POST-ITs\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#if 1\n\nvoid main() {\n float NUM_EDGE_POINTS_PER_CIRCLE = floor(mix(3., 8., fract(time * 0.1)));\n float NUM_POINTS_PER_CIRCLE = (NUM_EDGE_POINTS_PER_CIRCLE * 6.0);\n float NUM_CIRCLES_PER_GROUP = 2.0;\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = 64.;\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time * 0.1;// - cgv * 0.2;\n float snd2 = texture2D(sound, vec2(mix(0.001, 0.121, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.205, 0.001, gy / gDown), \n abs(gx / gAcross - 0.5) * 2. * 0.2)).a;\n \n\n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cu * 0.001;\n \n vec3 eye = vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(sin(time * 0.3) * 0.2, 1, 0);\n \n mat4 mat = persp(120. * PI / 180., resolution.x / resolution.y, 0.1, 100.); \n// mat *= cameraLookAt(eye, target, up);\n// mat *= rotZ(time * 0.0 * mix(-1., 1., mod(circleId, 2.)) + gy * 0.0 * sin(time * 0.1));//sign(offset.x));\n float sp = pow(snd, 5.0);\n\n mat *= trans(vec3(cgv * -0.3 * snd, cgv * 0.2 * snd, -2. + gv + cgId * 0.01));\n // mat *= rotZ(time * hash(gv * 0.124));// * 0.01 * gy * 0.1 + PI * 0.5);\n // mat *= trans(vec3(0, 0, gy * 0.1 + mod(circleId, 2.0) * 0.05));\n // mat *= rotZ(gx / gAcross * PI * 2.);\n // mat *= rotY(PI * 0.5);\n mat *= rotZ(hash(groupId * 0.3412) * PI * 2.);\n mat *= trans(vec3(\n fract(t2m1(hash(gv) + tm * 0.1 * hash(gv * 0.12))) * 20. - 10. , \n t2m1(hash(gv * .123)) * 3., 0.));\n mat *= rotZ(PI * .25 + time * hash(groupId * 0.712));\n mat *= uniformScale(snd * mix(0.5, 1., sliceId));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * 0.01 + sp * 0.2;//groupId * 0.1;\n float sat = 0.3;\n float val = mix(0., 1., cgId);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), mix(.5, 1., cgId));\n v_color.rgb *= v_color.a;\n}\n\n#endif" + }, "screenshotURL": "data/images/images-ji1oe1r7b91fk7v3i-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yMrRxwDvaoSaokXzo/art.json b/art/yMrRxwDvaoSaokXzo/art.json index 3a261ee6..19725f01 100644 --- a/art/yMrRxwDvaoSaokXzo/art.json +++ b/art/yMrRxwDvaoSaokXzo/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "mv10", "avatarUrl": "https://secure.gravatar.com/avatar/ae371690b3859dd1515ccf3e9ddc2ec8?default=retro&size=200", - "settings": "{\"num\":10000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// very long playlist:\\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\\n\\n// lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c)\\n{\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main () {\\n \\n // same as Sound Basics 1\\n float norm = (vertexId / vertexCount);\\n float x = (norm - 0.5) * 2.0;\\n \\n // this time we use the frequency (first sound-texture component)\\n // and leave history (second component) at 0.0 which is \\\"now\\\"; bass\\n // is the most interesting area, so we stick to the first 20% only;\\n // also, add a very tiny offset, the data seems to clip around zero\\n float freq = norm * 0.2 + 0.004;\\n float y = (texture2D(sound, vec2(freq, 0.0)).a - 0.5);\\n\\n // grab the volume (single value, no frequency) and use that as the\\n // color hue; small multiplier, volume almost never gets near 1.0\\n float vol = texture2D(volume, vec2(0.0, 0.0)).a * 2.0;\\n vec3 hsv = vec3(vol, 1.0, 1.0);\\n \\n gl_Position = vec4(x, y, 0.0, 1.0);\\n v_color = vec4(hsv2rgb(hsv), 1.0);\\n\\n gl_PointSize = 5.0;\\n\\n}\"}", + "settings": { + "num": 10000, + "mode": "POINTS", + "sound": "https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// very long playlist:\n// https://soundcloud.com/owen-fullerton-1/sets/dj-icey-dj-baby-anne-move\n\n// lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c)\n{\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main () {\n \n // same as Sound Basics 1\n float norm = (vertexId / vertexCount);\n float x = (norm - 0.5) * 2.0;\n \n // this time we use the frequency (first sound-texture component)\n // and leave history (second component) at 0.0 which is \"now\"; bass\n // is the most interesting area, so we stick to the first 20% only;\n // also, add a very tiny offset, the data seems to clip around zero\n float freq = norm * 0.2 + 0.004;\n float y = (texture2D(sound, vec2(freq, 0.0)).a - 0.5);\n\n // grab the volume (single value, no frequency) and use that as the\n // color hue; small multiplier, volume almost never gets near 1.0\n float vol = texture2D(volume, vec2(0.0, 0.0)).a * 2.0;\n vec3 hsv = vec3(vol, 1.0, 1.0);\n \n gl_Position = vec4(x, y, 0.0, 1.0);\n v_color = vec4(hsv2rgb(hsv), 1.0);\n\n gl_PointSize = 5.0;\n\n}" + }, "screenshotURL": "data/images/images-yoxjqmao8yxtj3up1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yPDzQv2JwJ9p4NCgQ/art.json b/art/yPDzQv2JwJ9p4NCgQ/art.json index 0c9a3328..e2cb0522 100644 --- a/art/yPDzQv2JwJ9p4NCgQ/art.json +++ b/art/yPDzQv2JwJ9p4NCgQ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/alvaro-macip/kiss-the-rain-yiruma\",\"lineSize\":\"CSS\",\"backgroundColor\":[0.00784313725490196,0.18823529411764706,0.8431372549019608,1],\"shader\":\"#define PI radians(180.0)\\n#define NUM_SEGMENTS 200.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float v = count / (vertexCount / NUM_SEGMENTS);\\n vec2 m = texture2D(touch, vec2(0, v)).xy;\\n float snd = texture2D(sound, vec2(0.05, v * 1.)).a;\\n float orbitAngle = snd * PI * 2.;//pow(time + count * 0.25, 0.8);\\n float innerRadius = pow(count * 0.00007, 1.2);\\n float oC = cos(orbitAngle + count * 0.003 + time) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.004 + time * 0.01) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect * 40. * mix(0.9, 1.1, snd), 0, 1);\\n\\n v_color = vec4(0.3, 0.6, 1, 1. - v);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINES", + "sound": "https://soundcloud.com/alvaro-macip/kiss-the-rain-yiruma", + "lineSize": "CSS", + "backgroundColor": [ + 0.00784313725490196, + 0.18823529411764706, + 0.8431372549019608, + 1 + ], + "shader": "#define PI radians(180.0)\n#define NUM_SEGMENTS 200.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float v = count / (vertexCount / NUM_SEGMENTS);\n vec2 m = texture2D(touch, vec2(0, v)).xy;\n float snd = texture2D(sound, vec2(0.05, v * 1.)).a;\n float orbitAngle = snd * PI * 2.;//pow(time + count * 0.25, 0.8);\n float innerRadius = pow(count * 0.00007, 1.2);\n float oC = cos(orbitAngle + count * 0.003 + time) * innerRadius;\n float oS = sin(orbitAngle + count * 0.004 + time * 0.01) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect * 40. * mix(0.9, 1.1, snd), 0, 1);\n\n v_color = vec4(0.3, 0.6, 1, 1. - v);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-k4u64p7tdpveznjs6-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yQpwAFYqRp4knnezc/art.json b/art/yQpwAFYqRp4knnezc/art.json index f40040fe..c852ba2a 100644 --- a/art/yQpwAFYqRp4knnezc/art.json +++ b/art/yQpwAFYqRp4knnezc/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.2980392156862745,0.2235294117647059,0.7254901960784313,1],\"shader\":\"/* ☀️\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n#define KP0 1.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(2.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, tan(1.-c), 0,\\n 0, c, 1, 0,\\n 0, 0, c, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1.1, 0, 0, 0,\\n 0, 1, 0, -0.2,\\n 0, 0.3, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, -0.3,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov)-(0.93);\\n float rangeInv = f / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0.2, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1.1,\\n 1, 0.1, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][1], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[0][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[2], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 2, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[1][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 - b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 * a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 / b01 + a22 - b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 2,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), dot(zAxis, eye), .1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 15.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 1.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 2. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 4.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI *1.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 1.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 12.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * 0.4 * v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * 1.2;\\n float sat = mix(.5, 1., mod(floor(time * 6. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 0. + length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (0.1 - length(p)) * sz * 0.1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / .5);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1164.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4, -1));\\n vec3 lightPos = vec3(500, 1000, -200);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 0.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 22.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 1.5 + 0.5), 11); \\n color = vec4(tcolor * light + vec3(specular), 2.3); \\n \\n // color.a = mix(1., 15., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = 2.5 + (pow(s1, 1.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId;\\n const float numCubePoints = 90000.0;\\n const float numSunPoints = 111.;//1000.0;\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 1.91, 4000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * 1.05;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, 1., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 2., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, sin(1.1*-time)+1.);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.2980392156862745, + 0.2235294117647059, + 0.7254901960784313, + 1 + ], + "shader": "/* ☀️\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n#define KP0 1.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(2.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, tan(1.-c), 0,\n 0, c, 1, 0,\n 0, 0, c, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1.1, 0, 0, 0,\n 0, 1, 0, -0.2,\n 0, 0.3, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, -0.3,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov)-(0.93);\n float rangeInv = f / (zNear - zFar);\n\n return mat4(\n f / aspect, 0.2, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1.1,\n 1, 0.1, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][1], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[0][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[2], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 2, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[1][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 - b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 * a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 / b01 + a22 - b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 2,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), dot(zAxis, eye), .1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 15.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 1.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 2. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 4.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI *1.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 1.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 12.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * 0.4 * v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * 1.2;\n float sat = mix(.5, 1., mod(floor(time * 6. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 0. + length(p));\n// color.rgb *= color.a;\n gl_PointSize = (0.1 - length(p)) * sz * 0.1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / .5);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1164.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 1.4, -1));\n vec3 lightPos = vec3(500, 1000, -200);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 0.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 22.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 1.5 + 0.5), 11); \n color = vec4(tcolor * light + vec3(specular), 2.3); \n \n // color.a = mix(1., 15., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = 2.5 + (pow(s1, 1.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId;\n const float numCubePoints = 90000.0;\n const float numSunPoints = 111.;//1000.0;\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, 1.91, 4000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * 1.05;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 2000.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, 0., cmat, vmat, pos, color);\n } else {\n id -= numSunPoints;\n if (id < numCubePoints) {\n cube(id, vertexCount, 1., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 2., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, sin(1.1*-time)+1.);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-nprj4o8zu2m6h8fbw-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yQxBYWw4sFSMS2gsp/art.json b/art/yQxBYWw4sFSMS2gsp/art.json index 17e77043..37042298 100644 --- a/art/yQxBYWw4sFSMS2gsp/art.json +++ b/art/yQxBYWw4sFSMS2gsp/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "jshrake", "avatarUrl": "https://avatars.githubusercontent.com/jshrake?s=200", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Hexagon Tile Strings by Justin Shrake (https://twitter.com/j2rgb)\\n// Inspired by https://twitter.com/etiennejcb/status/974037218330382336?s=20\\n// CC BY-NC 4.0 https://creativecommons.org/licenses/by-nc/4.0/\\n\\n// Submission for https://twitter.com/sableRaph #WCCChallenge\\n// Topic: non-rectangular tiles\\n// https://www.twitch.tv/sableraph\\n\\n\\n#ifndef TAU\\n#define TAU 6.28318530718\\n#endif\\n#ifndef PI\\n#define PI 3.14159265359\\n#endif\\n\\n\\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\\n// Licensed under CC BY-SA 3.0\\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\\nvec2 parametric_ngon(float n, float theta) {\\n theta = mod(TAU * theta, TAU);\\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\\n float x = r * cos(theta);\\n float y = r * sin(theta);\\n return vec2(x, y);\\n}\\n\\nvec4 grid2(float id, float w, float h) {\\n float ux = w == 1.0 ? 0.0 : mod(id, w);\\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\\n return vec4(x, y, ux, uy);\\n}\\n\\nmat2 rot2(float t) {\\n float ct = cos(t);\\n float st = sin(t);\\n return mat2(ct, -st, st, ct);\\n}\\n\\nmat4 frustum(float left, float right, float bottom, float top, float near,\\n float far) {\\n float x = 2.0 * near / (right - left);\\n float y = 2.0 * near / (top - bottom);\\n float A = (right + left) / (right - left);\\n float B = (top + bottom) / (top - bottom);\\n float C = -(far + near) / (far - near);\\n float D = -2.0 * far * near / (far - near);\\n // clang-format off\\n return mat4(\\n x, 0, 0, 0,\\n 0, y, 0, 0,\\n A, B, C, -1,\\n 0, 0, D, 0\\n );\\n // clang-format on\\n}\\n\\nmat4 perspective(float hfov_deg, float aspect, float near, float far) {\\n float hfov_rad = radians(hfov_deg);\\n float vfov_rad = 2.0 * atan(tan(hfov_rad * 0.5) / aspect);\\n // Tangent of half-FOV\\n float tangent = tan(0.5 * vfov_rad);\\n // Half the height of the near plane\\n float height = near * tangent;\\n // Half the width of the near plane\\n float width = height * aspect;\\n return frustum(-width, width, -height, height, near, far);\\n}\\n\\n\\nfloat quadraticInOut(float t) {\\n float p = 2.0 * t * t;\\n return t < 0.5 ? p : -p + (4.0 * t) - 1.0;\\n}\\n\\n//\\n// GLSL textureless classic 2D noise \\\"cnoise\\\",\\n// with an RSL-style periodic variant \\\"pnoise\\\".\\n// Author: Stefan Gustavson (stefan.gustavson@liu.se)\\n// Version: 2011-08-22\\n//\\n// Many thanks to Ian McEwan of Ashima Arts for the\\n// ideas for permutation and gradient selection.\\n//\\n// Copyright (c) 2011 Stefan Gustavson. All rights reserved.\\n// Distributed under the MIT license. See LICENSE file.\\n// https://github.com/stegu/webgl-noise\\n//\\n\\nvec4 mod289(vec4 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\\n\\nvec4 permute(vec4 x) { return mod289(((x * 34.0) + 10.0) * x); }\\n\\nvec4 taylorInvSqrt(vec4 r) { return 1.79284291400159 - 0.85373472095314 * r; }\\n\\nvec2 fade(vec2 t) { return t * t * t * (t * (t * 6.0 - 15.0) + 10.0); }\\n\\n// Classic Perlin noise\\nfloat perlin(vec2 P) {\\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\\n Pi = mod289(Pi); // To avoid truncation effects in permutation\\n vec4 ix = Pi.xzxz;\\n vec4 iy = Pi.yyww;\\n vec4 fx = Pf.xzxz;\\n vec4 fy = Pf.yyww;\\n\\n vec4 i = permute(permute(ix) + iy);\\n\\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\\n vec4 gy = abs(gx) - 0.5;\\n vec4 tx = floor(gx + 0.5);\\n gx = gx - tx;\\n\\n vec2 g00 = vec2(gx.x, gy.x);\\n vec2 g10 = vec2(gx.y, gy.y);\\n vec2 g01 = vec2(gx.z, gy.z);\\n vec2 g11 = vec2(gx.w, gy.w);\\n\\n vec4 norm = taylorInvSqrt(\\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\\n g00 *= norm.x;\\n g01 *= norm.y;\\n g10 *= norm.z;\\n g11 *= norm.w;\\n\\n float n00 = dot(g00, vec2(fx.x, fy.x));\\n float n10 = dot(g10, vec2(fx.y, fy.y));\\n float n01 = dot(g01, vec2(fx.z, fy.z));\\n float n11 = dot(g11, vec2(fx.w, fy.w));\\n\\n vec2 fade_xy = fade(Pf.xy);\\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\\n return 2.3 * n_xy;\\n}\\n\\n// Classic Perlin noise, periodic variant\\nfloat pnoise(vec2 P, vec2 rep) {\\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\\n Pi = mod(Pi, rep.xyxy); // To create noise with explicit period\\n Pi = mod289(Pi); // To avoid truncation effects in permutation\\n vec4 ix = Pi.xzxz;\\n vec4 iy = Pi.yyww;\\n vec4 fx = Pf.xzxz;\\n vec4 fy = Pf.yyww;\\n\\n vec4 i = permute(permute(ix) + iy);\\n\\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\\n vec4 gy = abs(gx) - 0.5;\\n vec4 tx = floor(gx + 0.5);\\n gx = gx - tx;\\n\\n vec2 g00 = vec2(gx.x, gy.x);\\n vec2 g10 = vec2(gx.y, gy.y);\\n vec2 g01 = vec2(gx.z, gy.z);\\n vec2 g11 = vec2(gx.w, gy.w);\\n\\n vec4 norm = taylorInvSqrt(\\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\\n g00 *= norm.x;\\n g01 *= norm.y;\\n g10 *= norm.z;\\n g11 *= norm.w;\\n\\n float n00 = dot(g00, vec2(fx.x, fy.x));\\n float n10 = dot(g10, vec2(fx.y, fy.y));\\n float n01 = dot(g01, vec2(fx.z, fy.z));\\n float n11 = dot(g11, vec2(fx.w, fy.w));\\n\\n vec2 fade_xy = fade(Pf.xy);\\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\\n return 2.3 * n_xy;\\n}\\n\\n\\nmat4 rot3(vec3 axis, float angle) {\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n\\n return mat4(\\n oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s,\\n oc * axis.z * axis.x + axis.y * s, 0.0, oc * axis.x * axis.y + axis.z * s,\\n oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s,\\n oc * axis.z * axis.z + c, 0.0, 0.0, 0.0, 0.0, 1.0);\\n}\\n\\n\\nvoid main() {\\n // Loop timings\\n float loop_len = 4.0;\\n float time_off = 0.0;\\n float loop_pct = mod(time + time_off, loop_len) / (loop_len);\\n // The size of the hexagon tile grid\\n float gridw = 20.;\\n float gridh = 20.;\\n // The number of particles per hexagon\\n float particles_per_tile = 250.0;\\n // The particle index\\n float i = vertexId;\\n // The particle perctange\\n float pct = i / (vertexCount - 1.0);\\n\\n // The hexagon index\\n float tile_i = floor(i / particles_per_tile);\\n // The total number of hexagons\\n float tile_count = gridw * gridh;\\n\\n // The particle index wrt the hexagon\\n float tile_pi = mod(i, particles_per_tile);\\n // The particle percentage wrt the hexagon\\n float tile_ppct = tile_pi / particles_per_tile;\\n\\n \\n float row = floor(tile_i/gridw);\\n float col = mod(tile_i, gridw);\\n float eo = mod(row, 2.0);\\n \\n float ar = resolution.y < resolution.x ? resolution.x/resolution.y : resolution.y/resolution.x;\\n\\n\\n // Hexagon tile size\\n float size = 1.0/(gridw - 1.0);\\n // padding between hexagons, 1.0 for no padding\\n float padding = 1.2;\\n // hexagon math courtesy of https://www.redblobgames.com/grids/hexagons/\\n vec2 grid_scale = padding*vec2(1.0*sqrt(3.0)*size, 1.5*ar*size);\\n vec2 tile_scale = vec2(size, size*ar);\\n // The center of the hexagon\\n vec2 tile_center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\\n tile_center.y += 2.5;\\n // Calculate the position of each particle in the tile\\n float ngon = 6.0;\\n float swirl = 0.5;\\n // The animation interpolates a point in the hexagon to another point in the hexagon\\n vec2 tile_a = parametric_ngon(ngon, tile_ppct);\\n float pn = 0.5*perlin(vec2(3.3)*tile_center) + 0.5;\\n float anim_delay = mix(0.0, 0.7, pn) + mix(0.0, 0.1, tile_ppct);\\n float anim_len = 0.2;\\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\\n vec3 tile = vec3(tile_a, 0.0);\\n tile.xy = rot2(0.25*TAU)*tile.xy;\\n tile.xy *= tile_scale;\\n tile.x += 1.0 * eo * tile_scale.x;\\n tile.y += 1.0*size;\\n float amt = 1.0;\\n float start_z = -0.6;\\n tile.z = mix(start_z, start_z - amt, quadraticInOut(m));\\n tile.z += mix(0.0, amt, (loop_pct));\\n \\n // Outputs\\n vec4 pos;\\n pos.xyz = vec3(tile_center, 0.0) + tile;\\n pos.w = 1.0;\\n pos = rot3(vec3(1.0, 0.0, 0.0), 0.75*0.25*TAU)*rot3(vec3(0.0, 0.0, 1.0), 0.0*TAU)*pos;\\n mat4 p = perspective(60.0, 1.0, 0.01, 10.0);\\n gl_Position = p * pos;\\n gl_PointSize = 3.0;\\n v_color = vec4(1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Hexagon Tile Strings by Justin Shrake (https://twitter.com/j2rgb)\n// Inspired by https://twitter.com/etiennejcb/status/974037218330382336?s=20\n// CC BY-NC 4.0 https://creativecommons.org/licenses/by-nc/4.0/\n\n// Submission for https://twitter.com/sableRaph #WCCChallenge\n// Topic: non-rectangular tiles\n// https://www.twitch.tv/sableraph\n\n\n#ifndef TAU\n#define TAU 6.28318530718\n#endif\n#ifndef PI\n#define PI 3.14159265359\n#endif\n\n\n// Raskolnikov (https://math.stackexchange.com/users/3567/raskolnikov), Is there\n// an equation to describe regular polygons?, URL (version: 2016-06-18):\n// https://math.stackexchange.com/q/41954 https://math.stackexchange.com/a/41954\n// Licensed under CC BY-SA 3.0\nfloat mmod(float x, float m) { return mod(mod(x, m) + m, m); }\nvec2 parametric_ngon(float n, float theta) {\n theta = mod(TAU * theta, TAU);\n float r = cos(PI / n) / cos(mmod(theta, 2.0 * PI / n) - PI / n);\n float x = r * cos(theta);\n float y = r * sin(theta);\n return vec2(x, y);\n}\n\nvec4 grid2(float id, float w, float h) {\n float ux = w == 1.0 ? 0.0 : mod(id, w);\n float uy = h == 1.0 ? 0.0 : mod(floor(id / w), h);\n float x = w == 1.0 ? 0.0 : 2.0 * ux / (w - 1.0) - 1.0;\n float y = h == 1.0 ? 0.0 : 2.0 * uy / (h - 1.0) - 1.0;\n return vec4(x, y, ux, uy);\n}\n\nmat2 rot2(float t) {\n float ct = cos(t);\n float st = sin(t);\n return mat2(ct, -st, st, ct);\n}\n\nmat4 frustum(float left, float right, float bottom, float top, float near,\n float far) {\n float x = 2.0 * near / (right - left);\n float y = 2.0 * near / (top - bottom);\n float A = (right + left) / (right - left);\n float B = (top + bottom) / (top - bottom);\n float C = -(far + near) / (far - near);\n float D = -2.0 * far * near / (far - near);\n // clang-format off\n return mat4(\n x, 0, 0, 0,\n 0, y, 0, 0,\n A, B, C, -1,\n 0, 0, D, 0\n );\n // clang-format on\n}\n\nmat4 perspective(float hfov_deg, float aspect, float near, float far) {\n float hfov_rad = radians(hfov_deg);\n float vfov_rad = 2.0 * atan(tan(hfov_rad * 0.5) / aspect);\n // Tangent of half-FOV\n float tangent = tan(0.5 * vfov_rad);\n // Half the height of the near plane\n float height = near * tangent;\n // Half the width of the near plane\n float width = height * aspect;\n return frustum(-width, width, -height, height, near, far);\n}\n\n\nfloat quadraticInOut(float t) {\n float p = 2.0 * t * t;\n return t < 0.5 ? p : -p + (4.0 * t) - 1.0;\n}\n\n//\n// GLSL textureless classic 2D noise \"cnoise\",\n// with an RSL-style periodic variant \"pnoise\".\n// Author: Stefan Gustavson (stefan.gustavson@liu.se)\n// Version: 2011-08-22\n//\n// Many thanks to Ian McEwan of Ashima Arts for the\n// ideas for permutation and gradient selection.\n//\n// Copyright (c) 2011 Stefan Gustavson. All rights reserved.\n// Distributed under the MIT license. See LICENSE file.\n// https://github.com/stegu/webgl-noise\n//\n\nvec4 mod289(vec4 x) { return x - floor(x * (1.0 / 289.0)) * 289.0; }\n\nvec4 permute(vec4 x) { return mod289(((x * 34.0) + 10.0) * x); }\n\nvec4 taylorInvSqrt(vec4 r) { return 1.79284291400159 - 0.85373472095314 * r; }\n\nvec2 fade(vec2 t) { return t * t * t * (t * (t * 6.0 - 15.0) + 10.0); }\n\n// Classic Perlin noise\nfloat perlin(vec2 P) {\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\n Pi = mod289(Pi); // To avoid truncation effects in permutation\n vec4 ix = Pi.xzxz;\n vec4 iy = Pi.yyww;\n vec4 fx = Pf.xzxz;\n vec4 fy = Pf.yyww;\n\n vec4 i = permute(permute(ix) + iy);\n\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\n vec4 gy = abs(gx) - 0.5;\n vec4 tx = floor(gx + 0.5);\n gx = gx - tx;\n\n vec2 g00 = vec2(gx.x, gy.x);\n vec2 g10 = vec2(gx.y, gy.y);\n vec2 g01 = vec2(gx.z, gy.z);\n vec2 g11 = vec2(gx.w, gy.w);\n\n vec4 norm = taylorInvSqrt(\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\n g00 *= norm.x;\n g01 *= norm.y;\n g10 *= norm.z;\n g11 *= norm.w;\n\n float n00 = dot(g00, vec2(fx.x, fy.x));\n float n10 = dot(g10, vec2(fx.y, fy.y));\n float n01 = dot(g01, vec2(fx.z, fy.z));\n float n11 = dot(g11, vec2(fx.w, fy.w));\n\n vec2 fade_xy = fade(Pf.xy);\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\n return 2.3 * n_xy;\n}\n\n// Classic Perlin noise, periodic variant\nfloat pnoise(vec2 P, vec2 rep) {\n vec4 Pi = floor(P.xyxy) + vec4(0.0, 0.0, 1.0, 1.0);\n vec4 Pf = fract(P.xyxy) - vec4(0.0, 0.0, 1.0, 1.0);\n Pi = mod(Pi, rep.xyxy); // To create noise with explicit period\n Pi = mod289(Pi); // To avoid truncation effects in permutation\n vec4 ix = Pi.xzxz;\n vec4 iy = Pi.yyww;\n vec4 fx = Pf.xzxz;\n vec4 fy = Pf.yyww;\n\n vec4 i = permute(permute(ix) + iy);\n\n vec4 gx = fract(i * (1.0 / 41.0)) * 2.0 - 1.0;\n vec4 gy = abs(gx) - 0.5;\n vec4 tx = floor(gx + 0.5);\n gx = gx - tx;\n\n vec2 g00 = vec2(gx.x, gy.x);\n vec2 g10 = vec2(gx.y, gy.y);\n vec2 g01 = vec2(gx.z, gy.z);\n vec2 g11 = vec2(gx.w, gy.w);\n\n vec4 norm = taylorInvSqrt(\n vec4(dot(g00, g00), dot(g01, g01), dot(g10, g10), dot(g11, g11)));\n g00 *= norm.x;\n g01 *= norm.y;\n g10 *= norm.z;\n g11 *= norm.w;\n\n float n00 = dot(g00, vec2(fx.x, fy.x));\n float n10 = dot(g10, vec2(fx.y, fy.y));\n float n01 = dot(g01, vec2(fx.z, fy.z));\n float n11 = dot(g11, vec2(fx.w, fy.w));\n\n vec2 fade_xy = fade(Pf.xy);\n vec2 n_x = mix(vec2(n00, n01), vec2(n10, n11), fade_xy.x);\n float n_xy = mix(n_x.x, n_x.y, fade_xy.y);\n return 2.3 * n_xy;\n}\n\n\nmat4 rot3(vec3 axis, float angle) {\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n\n return mat4(\n oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s,\n oc * axis.z * axis.x + axis.y * s, 0.0, oc * axis.x * axis.y + axis.z * s,\n oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s,\n oc * axis.z * axis.z + c, 0.0, 0.0, 0.0, 0.0, 1.0);\n}\n\n\nvoid main() {\n // Loop timings\n float loop_len = 4.0;\n float time_off = 0.0;\n float loop_pct = mod(time + time_off, loop_len) / (loop_len);\n // The size of the hexagon tile grid\n float gridw = 20.;\n float gridh = 20.;\n // The number of particles per hexagon\n float particles_per_tile = 250.0;\n // The particle index\n float i = vertexId;\n // The particle perctange\n float pct = i / (vertexCount - 1.0);\n\n // The hexagon index\n float tile_i = floor(i / particles_per_tile);\n // The total number of hexagons\n float tile_count = gridw * gridh;\n\n // The particle index wrt the hexagon\n float tile_pi = mod(i, particles_per_tile);\n // The particle percentage wrt the hexagon\n float tile_ppct = tile_pi / particles_per_tile;\n\n \n float row = floor(tile_i/gridw);\n float col = mod(tile_i, gridw);\n float eo = mod(row, 2.0);\n \n float ar = resolution.y < resolution.x ? resolution.x/resolution.y : resolution.y/resolution.x;\n\n\n // Hexagon tile size\n float size = 1.0/(gridw - 1.0);\n // padding between hexagons, 1.0 for no padding\n float padding = 1.2;\n // hexagon math courtesy of https://www.redblobgames.com/grids/hexagons/\n vec2 grid_scale = padding*vec2(1.0*sqrt(3.0)*size, 1.5*ar*size);\n vec2 tile_scale = vec2(size, size*ar);\n // The center of the hexagon\n vec2 tile_center = grid_scale*(grid2(tile_i, gridw, gridh).zw - 0.5*vec2(gridw, gridh));\n tile_center.y += 2.5;\n // Calculate the position of each particle in the tile\n float ngon = 6.0;\n float swirl = 0.5;\n // The animation interpolates a point in the hexagon to another point in the hexagon\n vec2 tile_a = parametric_ngon(ngon, tile_ppct);\n float pn = 0.5*perlin(vec2(3.3)*tile_center) + 0.5;\n float anim_delay = mix(0.0, 0.7, pn) + mix(0.0, 0.1, tile_ppct);\n float anim_len = 0.2;\n float m = smoothstep(0.0 + anim_delay, 0.0 + anim_delay + anim_len, loop_pct);\n vec3 tile = vec3(tile_a, 0.0);\n tile.xy = rot2(0.25*TAU)*tile.xy;\n tile.xy *= tile_scale;\n tile.x += 1.0 * eo * tile_scale.x;\n tile.y += 1.0*size;\n float amt = 1.0;\n float start_z = -0.6;\n tile.z = mix(start_z, start_z - amt, quadraticInOut(m));\n tile.z += mix(0.0, amt, (loop_pct));\n \n // Outputs\n vec4 pos;\n pos.xyz = vec3(tile_center, 0.0) + tile;\n pos.w = 1.0;\n pos = rot3(vec3(1.0, 0.0, 0.0), 0.75*0.25*TAU)*rot3(vec3(0.0, 0.0, 1.0), 0.0*TAU)*pos;\n mat4 p = perspective(60.0, 1.0, 0.01, 10.0);\n gl_Position = p * pos;\n gl_PointSize = 3.0;\n v_color = vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-go2w1b1vibry40xk3-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yRohe8v2Duig5qBiY/art.json b/art/yRohe8v2Duig5qBiY/art.json index 4c6de236..7b4d2a50 100644 --- a/art/yRohe8v2Duig5qBiY/art.json +++ b/art/yRohe8v2Duig5qBiY/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":32400,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.01568627450980392,0.2,1,1],\"shader\":\"\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float cv = circleId / numCircles;\\n \\n vec3 pos;\\n float inner = 0.;\\n float start = 0.;\\n float end = 1.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, vertexId, inner, start, end, pos);\\n\\n float t = time * 0.03;\\n float r = 0. + circleId * 0.01;\\n float a = t * circleId * 0.61;\\n\\n float c = cos(a);\\n float s = sin(a);\\n \\n mat4 mat = scale(vec3(1, resolution.x / resolution.y, 1) * 0.5);\\n mat *= trans(vec3(c * r, s * r, -cv) );\\n mat *= uniformScale(0.25 * r + 0.01);\\n gl_Position = mat * vec4(pos, 1);\\n\\n float hue = 1.;\\n float sat = mix(0., 1., mod(circleId, 3.) / 3.);\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 32400, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.01568627450980392, + 0.2, + 1, + 1 + ], + "shader": "\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 36.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float cv = circleId / numCircles;\n \n vec3 pos;\n float inner = 0.;\n float start = 0.;\n float end = 1.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, vertexId, inner, start, end, pos);\n\n float t = time * 0.03;\n float r = 0. + circleId * 0.01;\n float a = t * circleId * 0.61;\n\n float c = cos(a);\n float s = sin(a);\n \n mat4 mat = scale(vec3(1, resolution.x / resolution.y, 1) * 0.5);\n mat *= trans(vec3(c * r, s * r, -cv) );\n mat *= uniformScale(0.25 * r + 0.01);\n gl_Position = mat * vec4(pos, 1);\n\n float hue = 1.;\n float sat = mix(0., 1., mod(circleId, 3.) / 3.);\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-zpbonrmatqqvaueav-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ySwXopuyaNQWbLnt6/art.json b/art/ySwXopuyaNQWbLnt6/art.json index a4c20f57..0d0e2e81 100644 --- a/art/ySwXopuyaNQWbLnt6/art.json +++ b/art/ySwXopuyaNQWbLnt6/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "serdar2", "avatarUrl": "https://lh3.googleusercontent.com/a/AAcHTtcr8OLY4PHhjXfZ85YOTN46nqHnfmZkTLoNu6Hn6vAL=s96-c", - "settings": "{\"num\":9999,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.7529411764705882,0.1568627450980392,0.03529411764705882,1],\"shader\":\"#define PI radians(6890.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 3.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\\n vec4 K = vec4 (1.0,3.0 / 32.0, 73.0 / 2.9, 2.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 3128.0), fract(count / 20000.0))).a;\\n \\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 23.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.2;\\n float innerRadius = count * 0.00022223;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 1.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 4,1)), 3);\\n}\"}", + "settings": { + "num": 9999, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.7529411764705882, + 0.1568627450980392, + 0.03529411764705882, + 1 + ], + "shader": "#define PI radians(6890.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 3.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 5.0, 1.0));\n vec4 K = vec4 (1.0,3.0 / 32.0, 73.0 / 2.9, 2.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 3128.0), fract(count / 20000.0))).a;\n \n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 23.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.2;\n float innerRadius = count * 0.00022223;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 1.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 4,1)), 3);\n}" + }, "screenshotURL": "data/images/images-mwapw5umnx1p2phpt-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yWSCEoXnFJxXAZyBo/art.json b/art/yWSCEoXnFJxXAZyBo/art.json index a851daa6..6c8f21f5 100644 --- a/art/yWSCEoXnFJxXAZyBo/art.json +++ b/art/yWSCEoXnFJxXAZyBo/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-breaker-original-mix-apulia-records\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.011764705882352941,0.16470588235294117,0.8431372549019608,1],\"shader\":\"/*\\n\\n ___ __ _ \\n / \\\\\\\\ \\\\ /_\\\\ _ __ ___ __ _ _ __ __ _ \\n / /\\\\ / \\\\ \\\\ //_\\\\\\\\| '_ \\\\/ __|/ _` | '__/ _` |\\n / /_//\\\\_/ / / _ \\\\ |_) \\\\__ \\\\ (_| | | | (_| |\\n/___,'\\\\___/ \\\\_/ \\\\_/ .__/|___/\\\\__,_|_| \\\\__,_|\\n |_| \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nmat4 rotX(float angle) {\\n\\n float s = sin( angle );\\n float c = cos( angle );\\n\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0,-s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n #if 0\\n return mat4(\\n 1, 0, 0, trans[0],\\n 0, 1, 0, trans[1],\\n 0, 0, 1, trans[2],\\n 0, 0, 0, 1);\\n #else\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n #endif\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + .5;\\n}\\n\\nfloat inRange(float v, float minV, float maxV) {\\n return step(minV, v) * step(v, maxV);\\n}\\n\\nfloat at(float v, float target) {\\n return inRange(v, target - 0.1, target + 0.1);\\n}\\n\\nfloat hashp(float p) {\\n return m1p1(hash(p));\\n}\\n\\n\\n#define SEGS 16.\\nvoid main() {\\n float pointsPerSphere = SEGS * (SEGS * 0.5) * 6.;\\n float sphereId = floor(vertexId / pointsPerSphere);\\n float numSpheres = floor(vertexCount / pointsPerSphere);\\n float su = sphereId / numSpheres;\\n \\n float v = mod(vertexId, pointsPerSphere);\\n float vertex = mod(v, 6.);\\n v = (v-vertex)/6.;\\n float a1 = mod(v, SEGS);\\n v = (v-a1)/SEGS;\\n float a2 = v-(SEGS / 4.);\\n \\n float a1n = (a1+.5)/SEGS*2.*PI;\\n float a2n = (a2+.5)/SEGS*2.*PI;\\n \\n a1 += mod(vertex,2.);\\n a2 += vertex==2.||vertex>=4.?1.:0.;\\n \\n a1 = a1/SEGS*2.*PI;\\n a2 = a2/SEGS*2.*PI;\\n \\n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\\n \\n float snd0 = texture2D(sound, vec2(su * 0.2 + 0.05, 0)).a;\\n /*\\n #define NUM_SAMPLES 8\\n float csnd = 0.;\\n for (int i = 0; i < NUM_SAMPLES; ++i) {\\n csnd += texture2D(sound, vec2(0.05, float(i) / float(NUM_SAMPLES) * 0.1)).a;\\n }\\n csnd /= float(NUM_SAMPLES);\\n */\\n float csnd = 0.;\\n float cangle = time + csnd * PI * 2.;\\n float c = cos(cangle);\\n float s = sin(cangle);\\n float r = 1.5;\\n vec3 cameraPos = vec3(c * r, sin(time * 0.57), s * r);\\n vec3 cameraTarget = vec3(0, 0, 0);\\n vec3 cameraUp = vec3(0, 1, 0);\\n \\n mat4 p = persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\\n mat4 cam = lookAt(cameraPos, cameraTarget, cameraUp);\\n mat4 view = inverse(cam);\\n \\n mat4 w = trans(vec3(hashp(sphereId * 0.43), hashp(sphereId * 1.39), hashp(sphereId * 2.11)));\\n w *= uniformScale(mix(1.1, 2.5, hash(sphereId * 0.37)) * pow(snd0, 5.)) ;\\n w *= rotX(hash(sphereId * 0.791) * PI * 2.);\\n gl_Position = p * view * w * vec4(pos, 1);\\n\\n vec3 lightDir = normalize(vec3(1.1, 2.0, 2.0));\\n lightDir = normalize((cam * vec4(lightDir, 0)).xyz);\\n norm = normalize((w * vec4(norm, 0)).xyz);\\n float light = mix(0.5, 1., abs(dot(norm, lightDir)));\\n \\n float hue = mix(0.95, 1.00, hash(sphereId));\\n float sat = mix(1.4, 1.7, hash(sphereId * 6.131));\\n float val = light;\\n v_color = vec4(\\n mix(hsv2rgb(vec3(hue, sat, val)),\\n vec3(1,1,1),\\n step(10.9, snd0)), 1);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-breaker-original-mix-apulia-records", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.011764705882352941, + 0.16470588235294117, + 0.8431372549019608, + 1 + ], + "shader": "/*\n\n ___ __ _ \n / \\\\ \\ /_\\ _ __ ___ __ _ _ __ __ _ \n / /\\ / \\ \\ //_\\\\| '_ \\/ __|/ _` | '__/ _` |\n / /_//\\_/ / / _ \\ |_) \\__ \\ (_| | | | (_| |\n/___,'\\___/ \\_/ \\_/ .__/|___/\\__,_|_| \\__,_|\n |_| \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nmat4 rotX(float angle) {\n\n float s = sin( angle );\n float c = cos( angle );\n\n return mat4(\n 1, 0, 0, 0,\n 0, c, s, 0,\n 0,-s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n #if 0\n return mat4(\n 1, 0, 0, trans[0],\n 0, 1, 0, trans[1],\n 0, 0, 1, trans[2],\n 0, 0, 0, 1);\n #else\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n #endif\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + .5;\n}\n\nfloat inRange(float v, float minV, float maxV) {\n return step(minV, v) * step(v, maxV);\n}\n\nfloat at(float v, float target) {\n return inRange(v, target - 0.1, target + 0.1);\n}\n\nfloat hashp(float p) {\n return m1p1(hash(p));\n}\n\n\n#define SEGS 16.\nvoid main() {\n float pointsPerSphere = SEGS * (SEGS * 0.5) * 6.;\n float sphereId = floor(vertexId / pointsPerSphere);\n float numSpheres = floor(vertexCount / pointsPerSphere);\n float su = sphereId / numSpheres;\n \n float v = mod(vertexId, pointsPerSphere);\n float vertex = mod(v, 6.);\n v = (v-vertex)/6.;\n float a1 = mod(v, SEGS);\n v = (v-a1)/SEGS;\n float a2 = v-(SEGS / 4.);\n \n float a1n = (a1+.5)/SEGS*2.*PI;\n float a2n = (a2+.5)/SEGS*2.*PI;\n \n a1 += mod(vertex,2.);\n a2 += vertex==2.||vertex>=4.?1.:0.;\n \n a1 = a1/SEGS*2.*PI;\n a2 = a2/SEGS*2.*PI;\n \n vec3 pos = vec3(cos(a1)*cos(a2),sin(a2),sin(a1)*cos(a2));\n vec3 norm = vec3(cos(a1n)*cos(a2n),sin(a2n),sin(a1n)*cos(a2n));\n \n float snd0 = texture2D(sound, vec2(su * 0.2 + 0.05, 0)).a;\n /*\n #define NUM_SAMPLES 8\n float csnd = 0.;\n for (int i = 0; i < NUM_SAMPLES; ++i) {\n csnd += texture2D(sound, vec2(0.05, float(i) / float(NUM_SAMPLES) * 0.1)).a;\n }\n csnd /= float(NUM_SAMPLES);\n */\n float csnd = 0.;\n float cangle = time + csnd * PI * 2.;\n float c = cos(cangle);\n float s = sin(cangle);\n float r = 1.5;\n vec3 cameraPos = vec3(c * r, sin(time * 0.57), s * r);\n vec3 cameraTarget = vec3(0, 0, 0);\n vec3 cameraUp = vec3(0, 1, 0);\n \n mat4 p = persp(radians(65.), resolution.x / resolution.y, 0.1, 100.);\n mat4 cam = lookAt(cameraPos, cameraTarget, cameraUp);\n mat4 view = inverse(cam);\n \n mat4 w = trans(vec3(hashp(sphereId * 0.43), hashp(sphereId * 1.39), hashp(sphereId * 2.11)));\n w *= uniformScale(mix(1.1, 2.5, hash(sphereId * 0.37)) * pow(snd0, 5.)) ;\n w *= rotX(hash(sphereId * 0.791) * PI * 2.);\n gl_Position = p * view * w * vec4(pos, 1);\n\n vec3 lightDir = normalize(vec3(1.1, 2.0, 2.0));\n lightDir = normalize((cam * vec4(lightDir, 0)).xyz);\n norm = normalize((w * vec4(norm, 0)).xyz);\n float light = mix(0.5, 1., abs(dot(norm, lightDir)));\n \n float hue = mix(0.95, 1.00, hash(sphereId));\n float sat = mix(1.4, 1.7, hash(sphereId * 6.131));\n float val = light;\n v_color = vec4(\n mix(hsv2rgb(vec3(hue, sat, val)),\n vec3(1,1,1),\n step(10.9, snd0)), 1);\n}" + }, "screenshotURL": "data/images/images-q6rkf9vyy5rlvfuc4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yX9SGHv6RPPqcsXvh/art.json b/art/yX9SGHv6RPPqcsXvh/art.json index 7263788c..039ad7c4 100644 --- a/art/yX9SGHv6RPPqcsXvh/art.json +++ b/art/yX9SGHv6RPPqcsXvh/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 2.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd = texture2D(sound, vec2(mix(0.01, 0.14, su), gv * 0.05)).a;\\n \\n //snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n vec3 pos;\\n float inner = mix(0.0, 1. - pow(snd, 4.), cgId);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n float gDown = floor(sqrt(numGroups));\\n float gAcross = floor(numGroups / gDown);\\n vec3 offset0 = vec3(\\n mod(groupId, gAcross) - (gAcross - 1.) / 2.,\\n floor(groupId / gAcross) - (gDown - 1.) / 2.,\\n 0) * 0.2;\\n \\n // ----\\n float ang = gv * 10.0;\\n vec3 offset1 = vec3(cos(ang), sin(ang), 0) * gv * 0.5;\\n\\n // ----\\n vec3 offset2 = (vec3(hash(groupId), hash(groupId * 0.37), 0) * 2. - 1.) * 0.8;\\n \\n // ----\\n ang = gv * 20.0;\\n float rad = floor(groupId / pow(2., gv + 3.));\\n vec3 offset3 = vec3(cos(ang), sin(ang), 0) * mix(0.3, 0.7, rad);\\n \\n // 0-6 \\n float m = 0.;tm; //mod(tm, 4. * 3.);\\n float mix01 = mixer(m, 0., 3.);\\n float mix23 = mixer(m, 0., 3.);\\n float mix0123 = mixer(m, 0., 6.);\\n vec3 offset = \\n mix(\\n mix(offset0, offset1, mix01),\\n mix(offset2, offset3, mix23),\\n mix0123);\\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n mat *= trans(vec3(0.25,0,0));\\n mat *= rotZ(-time * 0.5);\\n mat *= trans(offset);\\n float sp = pow(snd, 5.0);\\n \\n mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.1 + sliceId * 0.0);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = tm * 0.0 + mix(0., 20.2, hash(groupId * 0.23));\\n float sat = 1. - pow(snd, 5.);\\n float val = step(0.8, snd);//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/cuttinheadzmusic/stuff-in-the-trunk-the-martinez-brothers-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 48.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 2.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd = texture2D(sound, vec2(mix(0.01, 0.14, su), gv * 0.05)).a;\n \n //snd = pow(snd, mix(2., 0.5, su));\n \n \n vec3 pos;\n float inner = mix(0.0, 1. - pow(snd, 4.), cgId);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n float gDown = floor(sqrt(numGroups));\n float gAcross = floor(numGroups / gDown);\n vec3 offset0 = vec3(\n mod(groupId, gAcross) - (gAcross - 1.) / 2.,\n floor(groupId / gAcross) - (gDown - 1.) / 2.,\n 0) * 0.2;\n \n // ----\n float ang = gv * 10.0;\n vec3 offset1 = vec3(cos(ang), sin(ang), 0) * gv * 0.5;\n\n // ----\n vec3 offset2 = (vec3(hash(groupId), hash(groupId * 0.37), 0) * 2. - 1.) * 0.8;\n \n // ----\n ang = gv * 20.0;\n float rad = floor(groupId / pow(2., gv + 3.));\n vec3 offset3 = vec3(cos(ang), sin(ang), 0) * mix(0.3, 0.7, rad);\n \n // 0-6 \n float m = 0.;tm; //mod(tm, 4. * 3.);\n float mix01 = mixer(m, 0., 3.);\n float mix23 = mixer(m, 0., 3.);\n float mix0123 = mixer(m, 0., 6.);\n vec3 offset = \n mix(\n mix(offset0, offset1, mix01),\n mix(offset2, offset3, mix23),\n mix0123);\n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n mat *= trans(vec3(0.25,0,0));\n mat *= rotZ(-time * 0.5);\n mat *= trans(offset);\n float sp = pow(snd, 5.0);\n \n mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.1 + sliceId * 0.0);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = tm * 0.0 + mix(0., 20.2, hash(groupId * 0.23));\n float sat = 1. - pow(snd, 5.);\n float val = step(0.8, snd);//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-fjx0vwok3a8qb4msd-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yXNXFmLjcRjjYtgze/art.json b/art/yXNXFmLjcRjjYtgze/art.json index c574b2d2..65dea3c7 100644 --- a/art/yXNXFmLjcRjjYtgze/art.json +++ b/art/yXNXFmLjcRjjYtgze/art.json @@ -17,7 +17,19 @@ "name": "residualfillattack", "private": false, "username": "-anon-", - "settings": "{\"num\":3000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/spotline/residual-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.00784313725490196,0.09019607843137255,1],\"shader\":\"#define NUM_POINTS 5000.0\\n#define K 1.059463094359295264561825294946\\n#define FIT_VERTICAL\\n\\n\\nvoid main() \\n{\\n\\n float u = vertexId/soundRes.x;\\n float v = 0.0;\\n float osc = sin(4.0*time+u*250.0);\\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\\n float x = (u*60.0)-1.0;\\n float y = ((v+vold)*0.5);//*osc;\\n gl_PointSize = 20.0;\\n gl_Position = vec4(x,y,0,1);\\n float lum = floor(v *10.0 + 0.5)/5.0;\\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\\n v_color = vec4((lum-lumOld*1.5)*0.6,(lum-lumOld)*0.6,(lum-lumOld*0.2)*1.0,v);\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/spotline/residual-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.00784313725490196, + 0.09019607843137255, + 1 + ], + "shader": "#define NUM_POINTS 5000.0\n#define K 1.059463094359295264561825294946\n#define FIT_VERTICAL\n\n\nvoid main() \n{\n\n float u = vertexId/soundRes.x;\n float v = 0.0;\n float osc = sin(4.0*time+u*250.0);\n v+= 2.0*pow(texture2D(sound,vec2(u,0.0)).a,6.0);\n float vold = 1.0*pow(texture2D(sound,vec2(u,0.04)).a,7.0);\n float x = (u*60.0)-1.0;\n float y = ((v+vold)*0.5);//*osc;\n gl_PointSize = 20.0;\n gl_Position = vec4(x,y,0,1);\n float lum = floor(v *10.0 + 0.5)/5.0;\n float lumOld = floor(vold *10.0 + 0.5)/5.0;\n v_color = vec4((lum-lumOld*1.5)*0.6,(lum-lumOld)*0.6,(lum-lumOld*0.2)*1.0,v);\n}" + }, "screenshotURL": "data/images/images-6b02jz4hsi46kwu3q-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yXyfMG3k8JMQsDgDm/art.json b/art/yXyfMG3k8JMQsDgDm/art.json index d9571852..6ba38740 100644 --- a/art/yXyfMG3k8JMQsDgDm/art.json +++ b/art/yXyfMG3k8JMQsDgDm/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "kcha", "avatarUrl": "https://secure.gravatar.com/avatar/393683f94ba2c18293b67ab3d3eb6f10?default=retro&size=200", - "settings": "{\"num\":1057,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0.14901960784313725,0.3764705882352941,1],\"shader\":\"vec3 hsv2rgb(vec3 c){\\n c = vec3(c.x, clamp(c.yz, 0., 1.));\\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\\n}\\n\\nvoid main(){\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across); // 0, 1, 2, ..., 9, 0, 1, ...\\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\\n \\n // 0.0 - 1.0\\n float u = x / (across - 1.); // .0, .1, ... , .9, .0, .1, ...\\n float v = y / (across - 1.); // .0, .0, ... , .1, .1, ... \\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u * .1 + sin(time * 1.3 + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); \\n}\\n\"}", + "settings": { + "num": 1057, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0.14901960784313725, + 0.3764705882352941, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c){\n c = vec3(c.x, clamp(c.yz, 0., 1.));\n vec4 K = vec4(1., 2. / 3., 1. / 3., 3.);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6. - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0., 1.), c.y);\n}\n\nvoid main(){\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across); // 0, 1, 2, ..., 9, 0, 1, ...\n float y = floor(vertexId / across); // 0,0,...0, 1,1,1\n \n // 0.0 - 1.0\n float u = x / (across - 1.); // .0, .1, ... , .9, .0, .1, ...\n float v = y / (across - 1.); // .0, .0, ... , .1, .1, ... \n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time * 1.1 + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time * 1.2 + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u * .1 + sin(time * 1.3 + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time * 1.4 + v * u * 20.0) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1); \n}\n" + }, "screenshotURL": "data/images/images-rbt5h4zciub65pln9-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yYj8r42nj2y6GRBEi/art.json b/art/yYj8r42nj2y6GRBEi/art.json index 2f4a7835..e2320073 100644 --- a/art/yYj8r42nj2y6GRBEi/art.json +++ b/art/yYj8r42nj2y6GRBEi/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "sylistine", "avatarUrl": "https://secure.gravatar.com/avatar/3a93b17a430d08943deebdfb93d4cef3?default=retro&size=200", - "settings": "{\"num\":13786,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/aivisura/love-like-you\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"#define PI radians(180.)\\n#define TAU radians(360.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvec3 hsv2rgb(vec3 c)\\n{\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec3 hsv2rgb(float h, float s, float v) {\\n return hsv2rgb(vec3(h, s, v));\\n}\\n\\nmat4 rotX( float angle) {\\n float s = sin( angle );\\n float c = cos( angle );\\n return mat4(\\n 1, 0, 0, 0,\\n 0, c, -s, 0,\\n 0, s, c, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - fov * 0.5);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nvoid main() {\\n float unitPentagonSideLength = sqrt(pow(cos(TAU/5.)-1., 2.)+pow(sin(TAU/5.), 2.));\\n \\n float vertsInIco = 20. * 3.;\\n \\n float icoId = floor(vertexId / vertsInIco);\\n float icoVertexId = mod(vertexId, vertsInIco);\\n \\n float triId = floor(icoVertexId / 3.);\\n float triVertexId = mod(vertexId, 3.);\\n float halfPi = PI * 0.5;\\n float triRads = triVertexId * 0.3333 * PI * 2. + halfPi;\\n float bottom = mod(triId, 2.);\\n float top = 1. - bottom;\\n float pairId = floor(triId / 2.);\\n triRads += bottom * PI;\\n vec4 pos = vec4(cos(triRads)/sqrt(3.), sin(triRads)/sqrt(3.), -1., 1.);\\n pos.y += 0.15 - 0.3 * top;\\n //pos *= rotX(PI/12. - PI/6. * (1. - bottom));\\n pos *= rotY(PI/5. * triId + time);\\n //pos.y += 1./sqrt(3.) - bottom / sqrt(3.);\\n float width = 16.;\\n pos.x += mod(icoId, width) * 4.;\\n pos.y += floor(icoId / width) * 3.;\\n \\n /*\\n float rowId = floor(pairId / 5.);\\n float rowPos = mod(pairId, 5.);\\n pos.x += rowPos - rowId * 0.5;\\n pos.y -= rowId * sqrt(3.)/2.;\\n */\\n \\n vec3 cameraPos = vec3(-32., -14., sin(time)-5.);\\n mat4 cameraTransform = trans(cameraPos);\\n \\n \\n mat4 P = persp(PI/2., resolution.x / resolution.y, 0.1, 100.);\\n gl_Position = P * cameraTransform * pos;\\n v_color = vec4(hsv2rgb(pos.x/5., 1., 1.), 1.);\\n gl_PointSize = 10.;\\n}\"}", + "settings": { + "num": 13786, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/aivisura/love-like-you", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "#define PI radians(180.)\n#define TAU radians(360.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvec3 hsv2rgb(vec3 c)\n{\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec3 hsv2rgb(float h, float s, float v) {\n return hsv2rgb(vec3(h, s, v));\n}\n\nmat4 rotX( float angle) {\n float s = sin( angle );\n float c = cos( angle );\n return mat4(\n 1, 0, 0, 0,\n 0, c, -s, 0,\n 0, s, c, 0,\n 0, 0, 0, 1);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - fov * 0.5);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nvoid main() {\n float unitPentagonSideLength = sqrt(pow(cos(TAU/5.)-1., 2.)+pow(sin(TAU/5.), 2.));\n \n float vertsInIco = 20. * 3.;\n \n float icoId = floor(vertexId / vertsInIco);\n float icoVertexId = mod(vertexId, vertsInIco);\n \n float triId = floor(icoVertexId / 3.);\n float triVertexId = mod(vertexId, 3.);\n float halfPi = PI * 0.5;\n float triRads = triVertexId * 0.3333 * PI * 2. + halfPi;\n float bottom = mod(triId, 2.);\n float top = 1. - bottom;\n float pairId = floor(triId / 2.);\n triRads += bottom * PI;\n vec4 pos = vec4(cos(triRads)/sqrt(3.), sin(triRads)/sqrt(3.), -1., 1.);\n pos.y += 0.15 - 0.3 * top;\n //pos *= rotX(PI/12. - PI/6. * (1. - bottom));\n pos *= rotY(PI/5. * triId + time);\n //pos.y += 1./sqrt(3.) - bottom / sqrt(3.);\n float width = 16.;\n pos.x += mod(icoId, width) * 4.;\n pos.y += floor(icoId / width) * 3.;\n \n /*\n float rowId = floor(pairId / 5.);\n float rowPos = mod(pairId, 5.);\n pos.x += rowPos - rowId * 0.5;\n pos.y -= rowId * sqrt(3.)/2.;\n */\n \n vec3 cameraPos = vec3(-32., -14., sin(time)-5.);\n mat4 cameraTransform = trans(cameraPos);\n \n \n mat4 P = persp(PI/2., resolution.x / resolution.y, 0.1, 100.);\n gl_Position = P * cameraTransform * pos;\n v_color = vec4(hsv2rgb(pos.x/5., 1., 1.), 1.);\n gl_PointSize = 10.;\n}" + }, "screenshotURL": "data/images/images-i3rdltjk23xbme9dy-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ycNiGDhLy59Wqt9qN/art.json b/art/ycNiGDhLy59Wqt9qN/art.json index 6196b7a1..06d545ae 100644 --- a/art/ycNiGDhLy59Wqt9qN/art.json +++ b/art/ycNiGDhLy59Wqt9qN/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":61924,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/hobac/just-once-james-ingram?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.38823529411764707,0.28627450980392155,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00014, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 0.025, 0.8);\\n float innerRadius = pow(count * 0.0005, 1.2);\\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\\n float ci = cos(0.00001 * 1.0) + tan(0.01 * oC * oS);\\n \\n\\n vec2 aspect = vec2(2, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s + ci);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 1);\\n \\n}\"}", + "settings": { + "num": 61924, + "mode": "LINES", + "sound": "https://soundcloud.com/hobac/just-once-james-ingram?utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.38823529411764707, + 0.28627450980392155, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00014, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 0.025, 0.8);\n float innerRadius = pow(count * 0.0005, 1.2);\n float oC = cos(orbitAngle + count * 0.0001) * innerRadius;\n float oS = sin(orbitAngle + count * 0.0001) * innerRadius;\n float ci = cos(0.00001 * 1.0) + tan(0.01 * oC * oS);\n \n\n vec2 aspect = vec2(2, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s + ci);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float b = 1.0 - pow(sin(count * 0.4) * 0.5 + 0.5, 10.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 1);\n \n}" + }, "screenshotURL": "data/images/images-ug26wkfn5k2mmo07o-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yeHYiFzE9scyMHnSv/art.json b/art/yeHYiFzE9scyMHnSv/art.json index efb3c3c2..61734c92 100644 --- a/art/yeHYiFzE9scyMHnSv/art.json +++ b/art/yeHYiFzE9scyMHnSv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "shortwavedave", "avatarUrl": "https://secure.gravatar.com/avatar/5999d47c7003bd60c3f1bfd965a79666?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.047058823529411764,0.06274509803921569,0.29411764705882354,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId,across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across-1.);\\n float v = y / (across-1.);\\n \\n float xoff = sin(time + y * 0.2) * .1;\\n float yoff = sin(time*1.1 + x * 0.2) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy,0,1);\\n \\n float soff = sin(time*1.2+x*y*0.02) * 5.;\\n \\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u*.1 + sin(time*.13 + v * 20.)*0.05;\\n float sat = 1.;\\n float val = sin(time*1.4 + v*u*20.)*.5 +.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.047058823529411764, + 0.06274509803921569, + 0.29411764705882354, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId,across);\n float y = floor(vertexId / across);\n \n float u = x / (across-1.);\n float v = y / (across-1.);\n \n float xoff = sin(time + y * 0.2) * .1;\n float yoff = sin(time*1.1 + x * 0.2) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy,0,1);\n \n float soff = sin(time*1.2+x*y*0.02) * 5.;\n \n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u*.1 + sin(time*.13 + v * 20.)*0.05;\n float sat = 1.;\n float val = sin(time*1.4 + v*u*20.)*.5 +.5;\n \n v_color = vec4(hsv2rgb(vec3(hue,sat,val)),1);\n}" + }, "screenshotURL": "data/images/images-wcqix3iu72gr7rpx6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yey7qrMtmhZZhq2K6/art.json b/art/yey7qrMtmhZZhq2K6/art.json index 1f75487d..86e82e51 100644 --- a/art/yey7qrMtmhZZhq2K6/art.json +++ b/art/yey7qrMtmhZZhq2K6/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/bit-shifter/units-warm-moving-bodies\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n \\n ,--. ,--. ,--. ,--. \\n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \\n \\\\ `' /| .-. :| .--''-. .-'| .-. : \\\\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \\n \\\\ / \\\\ --.| | | | \\\\ --. / /. \\\\ .-' `)| | | |\\\\ '-' |\\\\ `-' |\\\\ --.| | \\\\ '-' || | | | \\n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \\n#define NUM_CIRCLES_PER_GROUP 2.\\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat easeInOutSine(float t) {\\n return (-0.5 * (cos(PI * t) - 1.));\\n}\\n\\nfloat mixer(float t, float timeOff, float duration) {\\n t = mod(t, duration * 2.0);\\n t = t - timeOff;\\n if (t > duration) {\\n t = duration + 1. - t;\\n }\\n return easeInOutSine(clamp(t, 0., 1.));\\n}\\n\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n //snd = pow(snd, mix(2., 0.5, su));\\n \\n \\n vec3 pos;\\n float inner = 0.;//mix(0.0, 1. - pow(snd, 4.), cgId);\\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\\n float end = 1.; //start + hash(sideId + 1.);\\n getCirclePoint(pointId, inner, start, end, pos); \\n pos.z = cgv;\\n \\n// float historyX = mix(0.01, 0.14, u);\\n// snd = pow(snd, mix(2., 0.5, u));\\n \\n \\n\\n // ----\\n float gDown = floor(sqrt(numGroups));\\n float gAcross = floor(numGroups / gDown);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * 0.17;\\n\\n float tm = time - cgv * 0.2;\\n float su = hash(groupId);\\n float snd = texture2D(sound, vec2(mix(0.001, 0.015, su), length(offset) * 0.05)).a;\\n \\n\\n \\n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\\n// offset.y += goop(groupId + time * 0.) * 0.1;\\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect * 0.4);\\n mat *= trans(vec3(0.25,0,0));\\n mat *= rotZ(-time * 0. + snd * .0);\\n mat *= trans(offset);\\n float sp = pow(snd, 5.0);\\n \\n mat *= rotZ(snd * 3.);\\n mat *= uniformScale(0.1 * pow(snd, 0.));// + -sin((time + 0.5) * 6.) * 0.01);\\n //mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.1 + sliceId * 0.0);\\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\\n gl_PointSize = 4.;\\n\\n float hue = tm * 0.05 + fract(snd * 2.5) * 0.2 + 0.3 + mix(0., .02, length(offset));\\n float sat = pow(snd, 5.);\\n float val = mix(hash(groupId), 1.0, step(0.98, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/bit-shifter/units-warm-moving-bodies", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n \n ,--. ,--. ,--. ,--. \n,--. ,--.,---. ,--.--.,-' '-. ,---. ,--. ,--. ,---. | ,---. ,--,--. ,-| | ,---. ,--.--. ,--,--.,--.--.,-' '-. \n \\ `' /| .-. :| .--''-. .-'| .-. : \\ `' / ( .-' | .-. |' ,-. |' .-. || .-. :| .--'' ,-. || .--''-. .-' \n \\ / \\ --.| | | | \\ --. / /. \\ .-' `)| | | |\\ '-' |\\ `-' |\\ --.| | \\ '-' || | | | \n `--' `----'`--' `--' `----''--' '--'`----' `--' `--' `--`--' `---' `----'`--' `--`--'`--' `--' \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 6.\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.) \n#define NUM_CIRCLES_PER_GROUP 2.\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat easeInOutSine(float t) {\n return (-0.5 * (cos(PI * t) - 1.));\n}\n\nfloat mixer(float t, float timeOff, float duration) {\n t = mod(t, duration * 2.0);\n t = t - timeOff;\n if (t > duration) {\n t = duration + 1. - t;\n }\n return easeInOutSine(clamp(t, 0., 1.));\n}\n\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n //snd = pow(snd, mix(2., 0.5, su));\n \n \n vec3 pos;\n float inner = 0.;//mix(0.0, 1. - pow(snd, 4.), cgId);\n float start = 0.;//fract(hash(sideId * 0.33) + sin(time * 0.1 + sideId) * 1.1);\n float end = 1.; //start + hash(sideId + 1.);\n getCirclePoint(pointId, inner, start, end, pos); \n pos.z = cgv;\n \n// float historyX = mix(0.01, 0.14, u);\n// snd = pow(snd, mix(2., 0.5, u));\n \n \n\n // ----\n float gDown = floor(sqrt(numGroups));\n float gAcross = floor(numGroups / gDown);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2. + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * 0.17;\n\n float tm = time - cgv * 0.2;\n float su = hash(groupId);\n float snd = texture2D(sound, vec2(mix(0.001, 0.015, su), length(offset) * 0.05)).a;\n \n\n \n// vec3 offset = vec3(hash(groupId) * 0.8, m1p1(hash(groupId * 0.37)), cgv);\n// offset.x += m1p1(pow(snd, 5.0) + goop(groupId + time * 0.) * 0.1);\n// offset.y += goop(groupId + time * 0.) * 0.1;\n vec3 aspect = vec3(1, resolution.x / resolution.y, 1);\n \n mat4 mat = ident(); \n mat *= scale(aspect * 0.4);\n mat *= trans(vec3(0.25,0,0));\n mat *= rotZ(-time * 0. + snd * .0);\n mat *= trans(offset);\n float sp = pow(snd, 5.0);\n \n mat *= rotZ(snd * 3.);\n mat *= uniformScale(0.1 * pow(snd, 0.));// + -sin((time + 0.5) * 6.) * 0.01);\n //mat *= uniformScale(mix(sp, 1. - sp, cgId) * 0.1 + sliceId * 0.0);\n gl_Position = vec4((mat * vec4(pos, 1)).xyz, 1);\n gl_PointSize = 4.;\n\n float hue = tm * 0.05 + fract(snd * 2.5) * 0.2 + 0.3 + mix(0., .02, length(offset));\n float sat = pow(snd, 5.);\n float val = mix(hash(groupId), 1.0, step(0.98, snd));//ncgv;//1.;//mix(0.0, 0.0, fract(circleId * 0.79)) + sliceId * .65;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-2qmqzc0hzw52dl256-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yfhr4C9ihGC54WwZ4/art.json b/art/yfhr4C9ihGC54WwZ4/art.json index 63b5cf32..e29abcdf 100644 --- a/art/yfhr4C9ihGC54WwZ4/art.json +++ b/art/yfhr4C9ihGC54WwZ4/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":7491,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Block Party - @P_Malin\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.21, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 0.4, 1.0);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = .150;\\n\\n \\tfShade = acos( VdotL ) * (1.70 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.00010, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t12.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 3.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = 0.1;\\n float spread = 0.3; \\n float speed = 0.002;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.0 / 240.0);\\n \\n \\tv = v - 0.1;\\n \\ta = a * 1.5;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 6.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 6.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.51 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 7491, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Block Party - @P_Malin\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.21, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 0.4, 1.0);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = .150;\n\n \tfShade = acos( VdotL ) * (1.70 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.00010, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t12.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 3.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = 0.1;\n float spread = 0.3; \n float speed = 0.002;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.0 / 240.0);\n \n \tv = v - 0.1;\n \ta = a * 1.5;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 6.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 6.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.51 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-02ag42uhfgbxn62pb-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ygbdEzp2iTmLeNyu8/art.json b/art/ygbdEzp2iTmLeNyu8/art.json index fb9d5661..32afcfd3 100644 --- a/art/ygbdEzp2iTmLeNyu8/art.json +++ b/art/ygbdEzp2iTmLeNyu8/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "mol", "avatarUrl": "https://secure.gravatar.com/avatar/fe5b47f4d74c95c9b38908469761a86d?default=retro&size=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.19215686274509805,0.2,0.26666666666666666,1],\"shader\":\"// handle points to create a rectangle\\nvec2 calcRect(vec2 dimensions)\\n{\\n return vec2(\\n // generate x coordinates based on which vertex this is\\n mod(floor(vertexId / 2.0), 2.0) * dimensions.x,\\n // generate y coordinates based on which vertex this is\\n mod(floor((vertexId + 1.0) / 2.0), 2.0) * dimensions.y);\\n}\\n\\nvoid main()\\n{\\n gl_PointSize = 5.0;\\n \\n v_color = vec4(1, 0, 0, 1);\\n \\n // calculate scaling to adjust for resolution aspect ratio\\n vec2 scale = min(\\n vec2(resolution.y / resolution.x, 1.0), vec2(1.0, resolution.x / resolution.y));\\n \\n vec2 rect = calcRect(vec2(0.1, 0.1));\\n \\n gl_Position = vec4(\\n rect.x + floor(vertexId / 4.0) * 0.2 * sin(time),\\n rect.y + floor(vertexId / 4.0) * 0.2 * cos(time),\\n 0.0, 1.0);\\n // apply aspect ratio scale\\n gl_Position.xy *= scale;\\n}\\n\\n\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.19215686274509805, + 0.2, + 0.26666666666666666, + 1 + ], + "shader": "// handle points to create a rectangle\nvec2 calcRect(vec2 dimensions)\n{\n return vec2(\n // generate x coordinates based on which vertex this is\n mod(floor(vertexId / 2.0), 2.0) * dimensions.x,\n // generate y coordinates based on which vertex this is\n mod(floor((vertexId + 1.0) / 2.0), 2.0) * dimensions.y);\n}\n\nvoid main()\n{\n gl_PointSize = 5.0;\n \n v_color = vec4(1, 0, 0, 1);\n \n // calculate scaling to adjust for resolution aspect ratio\n vec2 scale = min(\n vec2(resolution.y / resolution.x, 1.0), vec2(1.0, resolution.x / resolution.y));\n \n vec2 rect = calcRect(vec2(0.1, 0.1));\n \n gl_Position = vec4(\n rect.x + floor(vertexId / 4.0) * 0.2 * sin(time),\n rect.y + floor(vertexId / 4.0) * 0.2 * cos(time),\n 0.0, 1.0);\n // apply aspect ratio scale\n gl_Position.xy *= scale;\n}\n\n" + }, "screenshotURL": "data/images/images-lxees43v4vgcfh5sv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yjv7hpNd3R3aGwGPp/art.json b/art/yjv7hpNd3R3aGwGPp/art.json index 3d0853de..0063a1ac 100644 --- a/art/yjv7hpNd3R3aGwGPp/art.json +++ b/art/yjv7hpNd3R3aGwGPp/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "juhong.mo", "avatarUrl": "https://secure.gravatar.com/avatar/5702c3c22d87785b338833aa80bfbb1c?default=retro&size=200", - "settings": "{\"num\":256,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n v_color = vec4(0.4, 0, 0.7, 1) + vec4(time + x * y * 0.01, 0, time + x * y * 0.02, 1);\\n}\"}", + "settings": { + "num": 256, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n v_color = vec4(0.4, 0, 0.7, 1) + vec4(time + x * y * 0.01, 0, time + x * y * 0.02, 1);\n}" + }, "screenshotURL": "data/images/images-h6otjd20lodim1w9k-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yjygGt83hjC8LDH7Z/art.json b/art/yjygGt83hjC8LDH7Z/art.json index 4e41cb15..9ed89854 100644 --- a/art/yjygGt83hjC8LDH7Z/art.json +++ b/art/yjygGt83hjC8LDH7Z/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/hugdealer/rtype-and-666gangstaz-john-wayne\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/*\\n\\n . . \\n .-. ...;....;. _ .; .' ...;... \\n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \\n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \\n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \\n ' \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define KP0 mouse.x * 3.3\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 11.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( s -angle *2.);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 2,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1)*2.5;\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[1], 0,\\n 0, 0, 0, 2);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 1, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 2)*1.5;\\n}\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 952.4337)-12.;\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1. +v;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id; + seed.x;\\n float a1 = id; + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\\n 0) / 8.;\\n}\\n\\n\\n#define POINTS_PER_LINE 100.0\\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\\nvoid main() {\\n float quadCount = POINTS_PER_LINE / 3.; \\n float v = vertexId / vertexCount;\\n float invV = 2. - v;\\n vec3 pos;\\n vec2 uv;\\n \\n float spread = tan(vertexId* 75.) / 1200. *mouse.y;\\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\\n float snd1 = texture2D(sound, vec2(mix(0.0, 10.61, spread), mix(0.25, 10.1, v))).a;\\n \\n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 1.3 + vertexId / 2.1), goop(time * .11 + vertexId * 0.01)), 0);\\n \\n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\\n time-sin(snd0*KP0);\\n \\n mat4 mat = ident(); \\n mat *= scale(aspect);\\n gl_Position = vec4((mat * vec4(pos, 5.4)).xyz, 1.82);\\n gl_Position.z = -m1p1(v*snd1);\\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 2.1;\\n gl_PointSize = 5.;\\n\\n float hue = mix(0.185, snd1 *.8, pow(snd1, 11.));\\n float sat = 0.2 * pow(snd0 * 8.2, 1.);\\n float val = -0.15 +snd0;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), .62);\\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/hugdealer/rtype-and-666gangstaz-john-wayne", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/*\n\n . . \n .-. ...;....;. _ .; .' ...;... \n_.; : .-. .;.::..'.-. `.,' ' . ;;-. .-. .-..' .-. .;.::..-. .;.::..' \n ; ;.;.-' .; .;.;.-' ,'`. .'; ;; ;; : : ; .;.-' .; ; : .; .; \n `._.' `:::'.;' .; `:::' -' `._..' .'.;` ``:::'-'`:::'`.`:::'.;' `:::'-'.;' .; \n ' \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n#define KP0 mouse.x * 3.3\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 11.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( s -angle *2.);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 2,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1)*2.5;\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[1], 0,\n 0, 0, 0, 2);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 1, 0,\n 0, 0, s, 0,\n 0, 0, 0, 2)*1.5;\n}\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 952.4337)-12.;\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1. +v;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return sin(t) * sin(t * 0.27) * sin(t * 0.13) * sin(t * 1.73);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id; + seed.x;\n float a1 = id; + seed.y;\n return vec3(\n (sin(a0 * 0.39) * 4. + tan(a0 * 0.73) * 2. + sin(a0 * 0.27)) ,\n (sin(a1 * 0.43) * 4. + sin(a1 * 1.37) *1.7, 2. + cos(a1 * 0.73)) ,\n 0) / 8.;\n}\n\n\n#define POINTS_PER_LINE 100.0\n#define QUADS_PER_LINE (POINTS_PER_LINE / 32.)\nvoid main() {\n float quadCount = POINTS_PER_LINE / 3.; \n float v = vertexId / vertexCount;\n float invV = 2. - v;\n vec3 pos;\n vec2 uv;\n \n float spread = tan(vertexId* 75.) / 1200. *mouse.y;\n float snd0 = texture2D(sound, vec2(mix(0.05, 0.51, spread), step(10.25, v))).a;\n float snd1 = texture2D(sound, vec2(mix(0.0, 10.61, spread), mix(0.25, 10.1, v))).a;\n \n pos = getCenterPoint(time * 4.*mouse.x + vertexId * 0.0001, vec2(-0.6,0));\n pos += vec3(pow(snd1, 3.0) * .8 * v * vec2(goop(time * 1.3 + vertexId / 2.1), goop(time * .11 + vertexId * 0.01)), 0);\n \n vec3 aspect = vec3(resolution.y / resolution.x, 2, 2)/\n time-sin(snd0*KP0);\n \n mat4 mat = ident(); \n mat *= scale(aspect);\n gl_Position = vec4((mat * vec4(pos, 5.4)).xyz, 1.82);\n gl_Position.z = -m1p1(v*snd1);\n //gl_Position.x += m1p1(lineId / 10.) * 0.4 + (snd1 * snd0) * 2.1;\n gl_PointSize = 5.;\n\n float hue = mix(0.185, snd1 *.8, pow(snd1, 11.));\n float sat = 0.2 * pow(snd0 * 8.2, 1.);\n float val = -0.15 +snd0;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), .62);\n v_color = vec4(v_color.rgb * v_color.a, v_color.a);\n}" + }, "screenshotURL": "data/images/images-z56kzg0iij262ty90-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ynpWP4AEw3HbibsqM/art.json b/art/ynpWP4AEw3HbibsqM/art.json index 2700d3ec..8dc1e22b 100644 --- a/art/ynpWP4AEw3HbibsqM/art.json +++ b/art/ynpWP4AEw3HbibsqM/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.09019607843137255,0.09019607843137255,0.09019607843137255,1],\"shader\":\"#define PI05 1.570796326795\\n#define PI 3.1415926535898\\n#define KP0 mouse.x + 1.1\\nvec3 hash3(vec3 v) {\\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\\n}\\n\\nvec3 rotX(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.y = p.y * sc.y + p.z * -sc.x *mouse.y; rp.z = p.y * sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotY(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.y + p.z * sc.x;\\n rp.z = p.x * -sc.x + p.z * sc.y;\\n return rp;\\n}\\n\\nvec3 rotZ(vec3 p, float rad) {\\n vec2 sc = sin(vec2(rad, rad + PI05));\\n vec3 rp = p;\\n rp.x = p.x * sc.x + p.y * sc.y;\\n rp.y = p.x * -sc.y + p.y * sc.x * mouse.x;\\n return rp;\\n}\\n\\nvec4 perspective(vec3 p, float fov, float near, float far) {\\n vec4 pp = vec4(p, -p.z);\\n pp.xy *= vec2(resolution.y / resolution.x, 0.80) / tan(radians(fov * 0.5));\\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\\n return pp;\\n}\\n\\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\\n vec3 z = normalize(eye - look);\\n vec3 x = normalize(cross(up, z));\\n vec3 y = cross(z, x);\\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \\n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\\n * vec4(p, 1.0);\\n return pp.xyz;\\n}\\n\\nvec3 lissajous(vec3 a, float t) {\\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\\n}\\n\\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\\n#define kCubeVertexCount 36.0\\nvec3 cubeVertex(float vid, out vec4 ni) {\\n float faceId = floor(vid / 6.0);\\n float vtxId = mod(vid, 6.0);\\n vec2 fp;\\n vec3 p;\\n \\n if(vtxId <= 1.0) {\\n fp = vec2(1.0, 1.0);\\n }\\n else if(vtxId == 2.0) {\\n fp = vec2(-1.0, 1.0);\\n }\\n else if(vtxId == 3.0) {\\n fp = vec2(1.0, -1.0);\\n }\\n else {\\n fp = vec2(-1.0, -1.0);\\n }\\n \\n if(faceId == 0.0) {\\n // front\\n p = vec3(fp.x, fp.y, 1.0);\\n ni = vec4(0.0, 0.0, 1.0, faceId);\\n }\\n else if(faceId == 1.0) {\\n // back\\n p = vec3(-fp.x, fp.y, -1.0);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 2.0) {\\n // top\\n p = vec3(fp.x, 1.0, -fp.y);\\n ni = vec4(0.0, 1.0, 0.0, faceId);\\n }\\n else if(faceId == 3.0) {\\n // bottom\\n p = vec3(fp.x, -1.0, fp.y);\\n ni = vec4(0.0, 0.0, -1.0, faceId);\\n }\\n else if(faceId == 4.0) {\\n // right\\n p = vec3(-1.0, fp.y, -fp.x);\\n ni = vec4(-1.0, 0.0, 0.0, faceId);\\n }\\n else {\\n // left\\n p = vec3(1.0, fp.y, fp.x);\\n ni = vec4(1.0, 0.0, 0.0, faceId);\\n }\\n \\n return p;\\n}\\n\\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\\n vec3 rgb;\\n vec3 lit = normalize(vec3(1.0, 0.4, 4.0));\\n \\n float diffuse = max(0.0, dot(n, lit)) * (2.0 - amb) + amb;\\n \\n vec3 h = normalize(normalize(eye - p) + lit);\\n float specular = 0.0;\\n if(diffuse > 0.0) {\\n specular = max(0.0, pow(dot(n, h), spec.x));\\n }\\n \\n rgb = diffuse * dfscol + 2.0 / specular * spec.y;\\n \\n return rgb;\\n}\\n\\nvoid main() {\\n float shapeCount = floor(vertexCount / kCubeVertexCount);\\n float shapeId = floor(vertexId / kCubeVertexCount);\\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\\n float lineId = mod(shapeId, 3.0);\\n \\n vec3 lineFactor;\\n vec3 color;\\n \\n if(lineId == 1.0) {\\n lineFactor = vec3(1.1, 6.7, 2.3);\\n color = vec3(1.0, 1.0, 1.0);\\n }\\n else if(lineId == 1.0) {\\n lineFactor = vec3(4.8, 5.2, 8.3);\\n color = vec3(0.0, 1.0, 0.0);\\n }\\n else {\\n lineFactor = vec3(6.1, 1.2, 3.6);\\n color = vec3(22.0, 3.4, 1.0);\\n }\\n \\n float t = shapeId / shapeCount;\\n \\n float aspect = resolution.x / resolution.y;\\n vec4 cubeni;\\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.14;\\n \\n vec3 cubeHash = hash3(vec3(log(shapeId)));\\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\\n \\n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\\n \\n cubep = lissajous(lineFactor, (t + time * 0.0 + KP0) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\\n \\n /*\\n if(cubeni.w == 0.1) {\\n color = vec3(1.0, 0.0, 1.0);\\n }\\n else if(cubeni.w == 0.3) {\\n color = vec3(0.0, 1.0, 0.3);\\n } else if(cubeni.w =- 2.0) {\\n color = vec3(0.55, 0.6, 1.0) * 2.0;\\n }\\n else if(cubeni.w == 3.0) {\\n color = vec3(1.0, 1.0, 0.0);\\n }\\n else if(cubeni.w < 4.0) {\\n color = vec3(-10.0, -1.0, 0.0);\\n }\\n else {\\n color = vec3(0.0, 1.0, 1.0);\\n }\\n */\\n \\n //vec3 eye = rotX(rotY(vec3(0.0, 1.0, 3.0), -mouse.x * 2.0), mouse.y);\\n vec3 eye = vec3(0.0, 0.0, 3.0);\\n \\n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.005), 0.01, vec2(64.0, 0.8));\\n \\n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.10, 1.0, 0.0));\\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\\n gl_PointSize = 20.0;\\n \\n v_color = vec4(color/3., 1.6);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.09019607843137255, + 0.09019607843137255, + 0.09019607843137255, + 1 + ], + "shader": "#define PI05 1.570796326795\n#define PI 3.1415926535898\n#define KP0 mouse.x + 1.1\nvec3 hash3(vec3 v) {\n return fract(sin(v * vec3(43758.5453123, 12345.6789012,76543.2109876)));\n}\n\nvec3 rotX(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.y = p.y * sc.y + p.z * -sc.x *mouse.y; rp.z = p.y * sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotY(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.y + p.z * sc.x;\n rp.z = p.x * -sc.x + p.z * sc.y;\n return rp;\n}\n\nvec3 rotZ(vec3 p, float rad) {\n vec2 sc = sin(vec2(rad, rad + PI05));\n vec3 rp = p;\n rp.x = p.x * sc.x + p.y * sc.y;\n rp.y = p.x * -sc.y + p.y * sc.x * mouse.x;\n return rp;\n}\n\nvec4 perspective(vec3 p, float fov, float near, float far) {\n vec4 pp = vec4(p, -p.z);\n pp.xy *= vec2(resolution.y / resolution.x, 0.80) / tan(radians(fov * 0.5));\n pp.z = (-p.z * (far + near) - 2.0 * far * near) / (far - near);\n return pp;\n}\n\nvec3 lookat(vec3 p, vec3 eye, vec3 look, vec3 up) {\n vec3 z = normalize(eye - look);\n vec3 x = normalize(cross(up, z));\n vec3 y = cross(z, x);\n vec4 pp = mat4(x.x, y.x, z.x, 0.0, x.y, y.y, z.y, 0.0, x.z, y.z, z.z, 0.0, 0.0, 0.0, 0.0, 1.0) * \n mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, -eye.x, -eye.y, -eye.z, 1.0)\n * vec4(p, 1.0);\n return pp.xyz;\n}\n\nvec3 lissajous(vec3 a, float t) {\n return vec3(sin(t * a.x), sin(t * a.y), cos(t * a.z));\n}\n\n// vid : 0 to 36 (6 faces * 6 vertices), ni: (normal.xyz, faceId)\n#define kCubeVertexCount 36.0\nvec3 cubeVertex(float vid, out vec4 ni) {\n float faceId = floor(vid / 6.0);\n float vtxId = mod(vid, 6.0);\n vec2 fp;\n vec3 p;\n \n if(vtxId <= 1.0) {\n fp = vec2(1.0, 1.0);\n }\n else if(vtxId == 2.0) {\n fp = vec2(-1.0, 1.0);\n }\n else if(vtxId == 3.0) {\n fp = vec2(1.0, -1.0);\n }\n else {\n fp = vec2(-1.0, -1.0);\n }\n \n if(faceId == 0.0) {\n // front\n p = vec3(fp.x, fp.y, 1.0);\n ni = vec4(0.0, 0.0, 1.0, faceId);\n }\n else if(faceId == 1.0) {\n // back\n p = vec3(-fp.x, fp.y, -1.0);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 2.0) {\n // top\n p = vec3(fp.x, 1.0, -fp.y);\n ni = vec4(0.0, 1.0, 0.0, faceId);\n }\n else if(faceId == 3.0) {\n // bottom\n p = vec3(fp.x, -1.0, fp.y);\n ni = vec4(0.0, 0.0, -1.0, faceId);\n }\n else if(faceId == 4.0) {\n // right\n p = vec3(-1.0, fp.y, -fp.x);\n ni = vec4(-1.0, 0.0, 0.0, faceId);\n }\n else {\n // left\n p = vec3(1.0, fp.y, fp.x);\n ni = vec4(1.0, 0.0, 0.0, faceId);\n }\n \n return p;\n}\n\nvec3 shade(vec3 eye, vec3 p, vec3 n, vec3 dfscol, float amb, vec2 spec) {\n vec3 rgb;\n vec3 lit = normalize(vec3(1.0, 0.4, 4.0));\n \n float diffuse = max(0.0, dot(n, lit)) * (2.0 - amb) + amb;\n \n vec3 h = normalize(normalize(eye - p) + lit);\n float specular = 0.0;\n if(diffuse > 0.0) {\n specular = max(0.0, pow(dot(n, h), spec.x));\n }\n \n rgb = diffuse * dfscol + 2.0 / specular * spec.y;\n \n return rgb;\n}\n\nvoid main() {\n float shapeCount = floor(vertexCount / kCubeVertexCount);\n float shapeId = floor(vertexId / kCubeVertexCount);\n float shapeVertexId = mod(vertexId, kCubeVertexCount);\n float lineId = mod(shapeId, 3.0);\n \n vec3 lineFactor;\n vec3 color;\n \n if(lineId == 1.0) {\n lineFactor = vec3(1.1, 6.7, 2.3);\n color = vec3(1.0, 1.0, 1.0);\n }\n else if(lineId == 1.0) {\n lineFactor = vec3(4.8, 5.2, 8.3);\n color = vec3(0.0, 1.0, 0.0);\n }\n else {\n lineFactor = vec3(6.1, 1.2, 3.6);\n color = vec3(22.0, 3.4, 1.0);\n }\n \n float t = shapeId / shapeCount;\n \n float aspect = resolution.x / resolution.y;\n vec4 cubeni;\n vec3 cubep = cubeVertex(shapeVertexId, cubeni) * 0.14;\n \n vec3 cubeHash = hash3(vec3(log(shapeId)));\n vec3 cubeOffset = (cubeHash * 2.0 - 1.0) * 0.1;\n vec3 cubeRot = hash3(cubeHash) * time * 2.0;\n \n cubep = rotX(rotY(rotZ(cubep, cubeRot.z), cubeRot.y), cubeRot.z);\n cubeni.xyz = rotX(rotY(rotZ(cubeni.xyz, cubeRot.z), cubeRot.y), cubeRot.z);\n \n cubep = lissajous(lineFactor, (t + time * 0.0 + KP0) * 2.0) * vec3(aspect, 1.0, aspect) + (cubep + cubeOffset);\n \n /*\n if(cubeni.w == 0.1) {\n color = vec3(1.0, 0.0, 1.0);\n }\n else if(cubeni.w == 0.3) {\n color = vec3(0.0, 1.0, 0.3);\n } else if(cubeni.w =- 2.0) {\n color = vec3(0.55, 0.6, 1.0) * 2.0;\n }\n else if(cubeni.w == 3.0) {\n color = vec3(1.0, 1.0, 0.0);\n }\n else if(cubeni.w < 4.0) {\n color = vec3(-10.0, -1.0, 0.0);\n }\n else {\n color = vec3(0.0, 1.0, 1.0);\n }\n */\n \n //vec3 eye = rotX(rotY(vec3(0.0, 1.0, 3.0), -mouse.x * 2.0), mouse.y);\n vec3 eye = vec3(0.0, 0.0, 3.0);\n \n color = shade(eye, cubep, cubeni.xyz, vec3(0.5 + cubeHash * 0.005), 0.01, vec2(64.0, 0.8));\n \n vec3 p = lookat(cubep, eye, vec3(0.0), vec3(0.10, 1.0, 0.0));\n gl_Position = perspective(p, 60.0, 0.1, 10.0);\n gl_PointSize = 20.0;\n \n v_color = vec4(color/3., 1.6);\n}" + }, "screenshotURL": "data/images/images-t69dm189s669r44dc-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yqxy757eFpwGqJu5k/art.json b/art/yqxy757eFpwGqJu5k/art.json index 55b574f5..73d5c19c 100644 --- a/art/yqxy757eFpwGqJu5k/art.json +++ b/art/yqxy757eFpwGqJu5k/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "mehran7kl", "avatarUrl": "https://avatars.githubusercontent.com/Mehran7kl?s=200", - "settings": "{\"num\":20000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"void main(){\\n gl_PointSize=1.0;\\n gl_Position=vec4(1,0,0,1);\\n}\"}", + "settings": { + "num": 20000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "void main(){\n gl_PointSize=1.0;\n gl_Position=vec4(1,0,0,1);\n}" + }, "screenshotURL": "data/images/images-l7mz6p1spvgqcteir-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yrXnJnTbLipbKFdcc/art.json b/art/yrXnJnTbLipbKFdcc/art.json index bde75852..4af46e7e 100644 --- a/art/yrXnJnTbLipbKFdcc/art.json +++ b/art/yrXnJnTbLipbKFdcc/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "janalex", "avatarUrl": "https://secure.gravatar.com/avatar/d3da53f9bbb18316fd80884d9d495947?default=retro&size=200", - "settings": "{\"num\":2218,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,0.9882352941176471,1,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = 8.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * 0.1 + sin(time + v * 20.0) * 0.12 + sin(time * 0.1);\\n float sat = v;\\n float val = 1.0;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\\n}\"}", + "settings": { + "num": 2218, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 0.9882352941176471, + 1, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = 8.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * 0.1 + sin(time + v * 20.0) * 0.12 + sin(time * 0.1);\n float sat = v;\n float val = 1.0;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.0);\n}" + }, "screenshotURL": "data/images/images-ciynm6rng3kb5xq6c-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ysQvrP3pZcBzuC2YL/art.json b/art/ysQvrP3pZcBzuC2YL/art.json index 2094bbf2..7828c5c7 100644 --- a/art/ysQvrP3pZcBzuC2YL/art.json +++ b/art/ysQvrP3pZcBzuC2YL/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/florandfaun/alone\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n//KDrawmode=GL_LINE_STRIP\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotY( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\n\\nmat4 rotZ( float angle ) {\\n float s = sin( angle );\\n float c = cos( angle );\\n \\t\\n return mat4( \\n c,-s, 1, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0.07,\\n zAxis, 0.01,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 - b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0.6,\\n zAxis, 0.3,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nfloat m1p1(float v) {\\n return v * 2. - 1.;\\n}\\n\\nfloat p1m1(float v) {\\n return v * .5 + 5.;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\nfloat goop(float t) {\\n return (sin(t) * 8. + sin(t * 0.27) * 4. + sin(t * 0.13) * 2. + sin(t * 0.73)) / 15.0;\\n}\\n\\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\\n\\nfloat noise(vec3 p){\\n vec3 a = floor(p);\\n vec3 d = p - a;\\n d = d * d * (3.0 - 2.0 * d);\\n\\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\\n vec4 k1 = perm(b.xyxy);\\n vec4 k2 = perm(k1.xyxy + b.zzww);\\n\\n vec4 c = k2 + a.zzzz;\\n vec4 k3 = perm(c);\\n vec4 k4 = perm(c + 1.0);\\n\\n vec4 o1 = fract(k3 * (.0 / 41.0));\\n vec4 o2 = fract(k4 * (1.0 / 41.0));\\n\\n vec4 o3 = o2 * d.z + o1 * (0.4 - d.z);\\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\\n\\n return o4.y * d.y + o4.x * (3.0 - d.y);\\n}\\n\\nvec3 getCenterPoint(const float id, vec2 seed) {\\n float a0 = id + seed.x;\\n float a1 = id + seed.y;\\n return vec3(\\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\\n (sin(a1 * 0.43) + sin(a1 * 0.37) + tan(a1 * 1.73)) / 2.,\\n 0);\\n}\\n\\n#define POINTS_PER_LINE 50.\\nvoid main() {\\n float lineId = floor(vertexId / POINTS_PER_LINE);\\n float pointId = mod(vertexId, POINTS_PER_LINE);\\n float numLines = floor(vertexCount / POINTS_PER_LINE);\\n vec2 uv = vec2(\\n pointId / POINTS_PER_LINE, \\n lineId / numLines);\\n\\n float ang = uv.x * PI * 2. + uv.y * mix(10., 100., sin(time * 0.1));\\n vec3 pos = vec3(\\n cos(ang),\\n sin(ang),\\n uv.y * 10.\\n );\\n \\n vec3 eye = vec3(0, 0, 0.0);\\n vec3 target = vec3(0, 0, 1);\\n vec3 up = vec3(0, 1, 0);\\n \\n float sa = abs(atan(uv.x, uv.y) / PI);\\n float snd = texture2D(sound, vec2(0.02, mix(1.0, 0.0, uv.y))).a;\\n \\n pos.xy *= mix(1., 2.2, pow(snd, 5.));\\n float tm = time - uv.y * 15.;\\n pos.xy += vec2(sin(tm), cos(tm * 1.11)) * -0.2;\\n float aspect = resolution.x / resolution.y;\\n \\n mat4 mat = persp(radians(140.), 1., 0.1, 200.); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= scale(vec3(0.5, 0.4, 1));\\n gl_Position = mat * vec4(pos, 1);\\n float clipZ = gl_Position.z / gl_Position.w;\\n gl_PointSize = mix(0.7, 50., pow(1. - uv.y, 50.));\\n gl_PointSize *= resolution.x / 1400.;\\n\\n float hue = pos.z* 0.02 + time * (0.01 + mouse.y);\\n float sat = 1.;\\n float val = 1.;\\n float alp = noise(pos * 3. + time * vec3(.7,0.3,5.));//clamp(goop(uv.x * 20. + time) + goop(uv.y * 20.123 + time), 0., 1.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alp);\\n v_color.rgb *= v_color.a;\\n}\"}", + "settings": { + "num": 100000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/florandfaun/alone", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n//KDrawmode=GL_LINE_STRIP\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotY( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\n\nmat4 rotZ( float angle ) {\n float s = sin( angle );\n float c = cos( angle );\n \t\n return mat4( \n c,-s, 1, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0.07,\n zAxis, 0.01,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 - b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0.6,\n zAxis, 0.3,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nfloat m1p1(float v) {\n return v * 2. - 1.;\n}\n\nfloat p1m1(float v) {\n return v * .5 + 5.;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\nfloat goop(float t) {\n return (sin(t) * 8. + sin(t * 0.27) * 4. + sin(t * 0.13) * 2. + sin(t * 0.73)) / 15.0;\n}\n\nfloat mod289(float x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 mod289(vec4 x){return x - floor(x * (1.0 / 289.0)) * 289.0;}\nvec4 perm(vec4 x){return mod289(((x * 34.0) + 1.0) * x);}\n\nfloat noise(vec3 p){\n vec3 a = floor(p);\n vec3 d = p - a;\n d = d * d * (3.0 - 2.0 * d);\n\n vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);\n vec4 k1 = perm(b.xyxy);\n vec4 k2 = perm(k1.xyxy + b.zzww);\n\n vec4 c = k2 + a.zzzz;\n vec4 k3 = perm(c);\n vec4 k4 = perm(c + 1.0);\n\n vec4 o1 = fract(k3 * (.0 / 41.0));\n vec4 o2 = fract(k4 * (1.0 / 41.0));\n\n vec4 o3 = o2 * d.z + o1 * (0.4 - d.z);\n vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);\n\n return o4.y * d.y + o4.x * (3.0 - d.y);\n}\n\nvec3 getCenterPoint(const float id, vec2 seed) {\n float a0 = id + seed.x;\n float a1 = id + seed.y;\n return vec3(\n (sin(a0 * 0.39) + sin(a0 * 0.73) + sin(a0 * 1.27)) / 3.,\n (sin(a1 * 0.43) + sin(a1 * 0.37) + tan(a1 * 1.73)) / 2.,\n 0);\n}\n\n#define POINTS_PER_LINE 50.\nvoid main() {\n float lineId = floor(vertexId / POINTS_PER_LINE);\n float pointId = mod(vertexId, POINTS_PER_LINE);\n float numLines = floor(vertexCount / POINTS_PER_LINE);\n vec2 uv = vec2(\n pointId / POINTS_PER_LINE, \n lineId / numLines);\n\n float ang = uv.x * PI * 2. + uv.y * mix(10., 100., sin(time * 0.1));\n vec3 pos = vec3(\n cos(ang),\n sin(ang),\n uv.y * 10.\n );\n \n vec3 eye = vec3(0, 0, 0.0);\n vec3 target = vec3(0, 0, 1);\n vec3 up = vec3(0, 1, 0);\n \n float sa = abs(atan(uv.x, uv.y) / PI);\n float snd = texture2D(sound, vec2(0.02, mix(1.0, 0.0, uv.y))).a;\n \n pos.xy *= mix(1., 2.2, pow(snd, 5.));\n float tm = time - uv.y * 15.;\n pos.xy += vec2(sin(tm), cos(tm * 1.11)) * -0.2;\n float aspect = resolution.x / resolution.y;\n \n mat4 mat = persp(radians(140.), 1., 0.1, 200.); \n mat *= cameraLookAt(eye, target, up);\n mat *= scale(vec3(0.5, 0.4, 1));\n gl_Position = mat * vec4(pos, 1);\n float clipZ = gl_Position.z / gl_Position.w;\n gl_PointSize = mix(0.7, 50., pow(1. - uv.y, 50.));\n gl_PointSize *= resolution.x / 1400.;\n\n float hue = pos.z* 0.02 + time * (0.01 + mouse.y);\n float sat = 1.;\n float val = 1.;\n float alp = noise(pos * 3. + time * vec3(.7,0.3,5.));//clamp(goop(uv.x * 20. + time) + goop(uv.y * 20.123 + time), 0., 1.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), alp);\n v_color.rgb *= v_color.a;\n}" + }, "screenshotURL": "data/images/images-2h6b0axs64rlhi9r1-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ysh84kFrt5dxksGM9/art.json b/art/ysh84kFrt5dxksGM9/art.json index 42236a63..b2b3847b 100644 --- a/art/ysh84kFrt5dxksGM9/art.json +++ b/art/ysh84kFrt5dxksGM9/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":97200,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-027\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"/*\\n\\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \\n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \\nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\\n float v = 1.;//mix(inner, 1., level);\\n float ringId = sub + vy;\\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\\n \\n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\\n float s = sin(a);\\n float c = cos(a);\\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\\n float x = c * v * z;\\n float y = s * v * z;\\n pos = vec3(x, y, 0.); \\n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\\n}\\n\\nfloat goop(float t) {\\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\\n}\\n\\nfloat modStep(float count, float steps) {\\n return mod(count, steps) / steps;\\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 180.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n vec3 nrm = vec3(\\n cos((qx + .5) / around * PI * 2.),\\n cos((qy + .5) / down * PI),\\n sin((qx + .5) / around * PI * 2.)\\n );\\n \\n float tm = time * 0.1;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,sin(tm),cos(tm));\\n \\n float s = texture2D(sound, vec2(mix(0.001, .5, hash(qu*qv)), mix(0., .012, hash(qv)))).a;\\n \\n mat *= cameraLookAt(eye, target, up); \\n mat *= uniformScale(mix(0.5, 1.5, pow(s, 5.)));\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = time * .1 +s *.25;\\n float sat = .5;mix(0.5, 1., mod(quadId, 2.));\\n float val = 1.;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\\n \\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n float lt = (dot(nrm, lightDir) * 0.25 + 0.75);\\n v_color = vec4(v_color.rgb * lt, 1); \\n \\n v_color.rgb *= v_color.a;\\n \\n \\n \\n}\"}", + "settings": { + "num": 97200, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-027", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "/*\n\n┬ ┬┌─┐┬─┐┌┬┐┌─┐─┐ ┬┌─┐┬ ┬┌─┐┌┬┐┌─┐┬─┐┌─┐┬─┐┌┬┐\n└┐┌┘├┤ ├┬┘ │ ├┤ ┌┴┬┘└─┐├─┤├─┤ ││├┤ ├┬┘├─┤├┬┘ │ \n └┘ └─┘┴└─ ┴ └─┘┴ └─└─┘┴ ┴┴ ┴─┴┘└─┘┴└─┴ ┴┴└─ ┴ \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 100.\n#define NUM_POINTS_PER_DIVISION (NUM_EDGE_POINTS_PER_CIRCLE * 6.)\n#define NUM_POINTS_PER_CIRCLE (NUM_SUBDIVISIONS_PER_CIRCLE * NUM_POINTS_PER_DIVISION) \nvoid getCirclePoint(const float id, const float inner, const float start, const float end, out vec3 pos, out vec4 uvf, out float snd) {\n float NUM_SUBDIVISIONS_PER_CIRCLE = floor(vertexCount / NUM_POINTS_PER_DIVISION);\n float edgeId = mod(id, NUM_POINTS_PER_DIVISION);\n float ux = floor(edgeId / 6.) + mod(edgeId, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float sub = floor(id / NUM_POINTS_PER_DIVISION);\n float subV = sub / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float level = subV + vy / (NUM_SUBDIVISIONS_PER_CIRCLE - 1.);\n float u = ux / NUM_EDGE_POINTS_PER_CIRCLE;\n float v = 1.;//mix(inner, 1., level);\n float ringId = sub + vy;\n float ringV = ringId / NUM_SUBDIVISIONS_PER_CIRCLE;\n float numRings = vertexCount / NUM_SUBDIVISIONS_PER_CIRCLE;\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float skew = 1. - step(0.5, mod(ringId - 2., 3.));\n float su = fract(abs(u * 2. - 1.) + time * 0.1);\n \n a += 1. / NUM_EDGE_POINTS_PER_CIRCLE * PI * 2.;// * 20. * sin(time * 1.) + snd * 1.5;\n float s = sin(a);\n float c = cos(a);\n float z = mix(inner, 2., level) - vy / NUM_SUBDIVISIONS_PER_CIRCLE * 0.;\n float x = c * v * z;\n float y = s * v * z;\n pos = vec3(x, y, 0.); \n uvf = vec4(floor(edgeId / 6.) / NUM_EDGE_POINTS_PER_CIRCLE, subV, floor(id / 6.), sub);\n}\n\nfloat goop(float t) {\n return sin(t) + sin(t * 0.27) + sin(t * 0.13) + sin(t * 0.73);\n}\n\nfloat modStep(float count, float steps) {\n return mod(count, steps) / steps;\n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 180.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n vec3 nrm = vec3(\n cos((qx + .5) / around * PI * 2.),\n cos((qy + .5) / down * PI),\n sin((qx + .5) / around * PI * 2.)\n );\n \n float tm = time * 0.1;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * .0 + 0., sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,sin(tm),cos(tm));\n \n float s = texture2D(sound, vec2(mix(0.001, .5, hash(qu*qv)), mix(0., .012, hash(qv)))).a;\n \n mat *= cameraLookAt(eye, target, up); \n mat *= uniformScale(mix(0.5, 1.5, pow(s, 5.)));\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = time * .1 +s *.25;\n float sat = .5;mix(0.5, 1., mod(quadId, 2.));\n float val = 1.;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1.);\n \n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n float lt = (dot(nrm, lightDir) * 0.25 + 0.75);\n v_color = vec4(v_color.rgb * lt, 1); \n \n v_color.rgb *= v_color.a;\n \n \n \n}" + }, "screenshotURL": "data/images/images-puebuqv85xb5s9pai-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yuDv9cWYxgd33kjQ7/art.json b/art/yuDv9cWYxgd33kjQ7/art.json index 27131fbb..5dc8f5bc 100644 --- a/art/yuDv9cWYxgd33kjQ7/art.json +++ b/art/yuDv9cWYxgd33kjQ7/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":98784,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[1,1,1,1],\"shader\":\"\\n/*\\n\\nWait for the music to pump \\n\\n*/\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 3.//KParameter0 0.>>1.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 1.//KParameter3 0.5>>3.\\n#define parameter4 1.//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>2.\\n#define parameter7 1.//KParameter7 0.>>2.\\n\\n\\n\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.4, tan(3.0 / 5.)));\\n vec4 K = vec4(1.0* parameter2, 2.0 / 3.0 / parameter1, 0.0 / 4.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * (parameter5 - 6.0) - K.www);\\n return c.z * mix(K.xxx, clamp(sin(p * c * .2 ) + K.xxx, 0.4, parameter7), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, parameter2, 0, 2,\\n parameter3, -c, -s, 1,\\n 0, -s, c, 0,\\n 0, parameter4, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians * 2.);\\n \\t\\n return mat4( \\n -c, 0, 2. - s, s * c,\\n 0.2, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 1, \\n s, -1, 0, 1,\\n 0, s*parameter4, 1, 0,\\n 0, 0, 0, 0); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 2, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 4., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a03 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.2,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 75.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / (2. * parameter3 )) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a - v);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 8.\\n#define FACES_PER_CUBE 8.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nmat4 mixm(mat4 m1, mat4 m2, float m) {\\n return mat4(\\n mix(m1[0], m2[0], m),\\n mix(m1[1], m2[1], m),\\n mix(m1[2], m2[2], m),\\n mix(m1[3], m2[3], m));\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(sqrt(numCubes) * .5);\\n float across = floor(numCubes / down);\\n float cv = cubeId / numCubes;\\n\\n float uu = mod(cubeId, across);\\n float vv = floor(cubeId / across);\\n vec2 uv = vec2(uu, vv) / vec2(across, down);\\n \\n// const int hist = 10;\\n// float s = 0.;\\n// for (int i = 0; i < hist; ++i) {\\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \\n// 1.;//float(hist - i);\\n// }\\n//// s /= float(hist * (hist - 1)) / 2.;\\n// s /= float(hist);\\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\\n \\n float tm = time * (1. - parameter3);\\n float rd = 9.;\\n mat4 pmat = persp(radians(110.0), resolution.x / resolution.y, 0.1, 100.0);\\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat4 vmat = cameraLookAt(eye, target, up); \\n \\n mat4 mat = rotY(time * .1);\\n mat *= lookAt(\\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \\n mix(20., 24.1, s),\\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\\n vec3(0, 1, 0));\\n \\n mat4 mvmat = vmat * mat;\\n \\n vec3 npos = normalize(mvmat[3].xyz);\\n \\n float hue = mix(.0, time * 10., step(.8, s));\\n float sat = mix(-1.0, 2.2, s);\\n float val = 1.;//mix(1., 1., step(0.8, s));\\n\\n \\n float areaS = 1. - (npos.z * .5 + .5);\\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\\n smat *= uniformScale(0.5);\\n smat *= trans(vec3(0, 0, -1));\\n \\n \\n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1, 0.1, 1));\\n\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\\n v_color.a = mix(0., 2., s);\\n}\\n\\n\"}", + "settings": { + "num": 98784, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/featurepr/morganj-boothed-like-the-best-feature088", + "lineSize": "NATIVE", + "backgroundColor": [ + 1, + 1, + 1, + 1 + ], + "shader": "\n/*\n\nWait for the music to pump \n\n*/\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 3.//KParameter0 0.>>1.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 1.//KParameter3 0.5>>3.\n#define parameter4 1.//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>2.\n#define parameter7 1.//KParameter7 0.>>2.\n\n\n\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.4, tan(3.0 / 5.)));\n vec4 K = vec4(1.0* parameter2, 2.0 / 3.0 / parameter1, 0.0 / 4.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * (parameter5 - 6.0) - K.www);\n return c.z * mix(K.xxx, clamp(sin(p * c * .2 ) + K.xxx, 0.4, parameter7), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, parameter2, 0, 2,\n parameter3, -c, -s, 1,\n 0, -s, c, 0,\n 0, parameter4, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians * 2.);\n \t\n return mat4( \n -c, 0, 2. - s, s * c,\n 0.2, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 1, \n s, -1, 0, 1,\n 0, s*parameter4, 1, 0,\n 0, 0, 0, 0); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 2, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 4., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a03 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.2,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 75.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / (2. * parameter3 )) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a - v);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 8.\n#define FACES_PER_CUBE 8.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nmat4 mixm(mat4 m1, mat4 m2, float m) {\n return mat4(\n mix(m1[0], m2[0], m),\n mix(m1[1], m2[1], m),\n mix(m1[2], m2[2], m),\n mix(m1[3], m2[3], m));\n}\n\nvoid main() {\n float pointId = vertexId; \n\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(sqrt(numCubes) * .5);\n float across = floor(numCubes / down);\n float cv = cubeId / numCubes;\n\n float uu = mod(cubeId, across);\n float vv = floor(cubeId / across);\n vec2 uv = vec2(uu, vv) / vec2(across, down);\n \n// const int hist = 10;\n// float s = 0.;\n// for (int i = 0; i < hist; ++i) {\n// s += texture2D(volume, vec2((2. + .5) / 4., (float(i) + .5) / soundRes.y)).a * \n// 1.;//float(hist - i);\n// }\n//// s /= float(hist * (hist - 1)) / 2.;\n// s /= float(hist);\n float s = texture2D(sound, vec2(mix(0.05, .5, hash(cubeId * .723)), 0.)).a;\n \n float tm = time * (1. - parameter3);\n float rd = 9.;\n mat4 pmat = persp(radians(110.0), resolution.x / resolution.y, 0.1, 100.0);\n vec3 eye = vec3(cos(tm) * rd, sin(tm * 0.9) * rd * 0.6, sin(tm) * rd);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat4 vmat = cameraLookAt(eye, target, up); \n \n mat4 mat = rotY(time * .1);\n mat *= lookAt(\n normalize(vec3(t2m1(hash(cubeId * 0.123)), t2m1(hash(cubeId * 1.632)), t2m1(hash(cubeId * 0.327)))) * \n mix(20., 24.1, s),\n vec3(sin(time * 4.), sin(time * 3.17), 0.) * 10. * s,\n vec3(0, 1, 0));\n \n mat4 mvmat = vmat * mat;\n \n vec3 npos = normalize(mvmat[3].xyz);\n \n float hue = mix(.0, time * 10., step(.8, s));\n float sat = mix(-1.0, 2.2, s);\n float val = 1.;//mix(1., 1., step(0.8, s));\n\n \n float areaS = 1. - (npos.z * .5 + .5);\n mat4 smat = scale(vec3(2, 2, pow(s, 5.) * 100. * areaS + 0.01));\n smat *= uniformScale(0.5);\n smat *= trans(vec3(0, 0, -1));\n \n \n gl_Position = pmat * mvmat * smat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1, 0.1, 1));\n\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.5 + 0.5), 1);\n v_color.a = mix(0., 2., s);\n}\n\n" + }, "screenshotURL": "data/images/images-tqopftfc5r6pp1yfv-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yvHEThAy6Yvf5mRjp/art.json b/art/yvHEThAy6Yvf5mRjp/art.json index 4323a211..1596c4a1 100644 --- a/art/yvHEThAy6Yvf5mRjp/art.json +++ b/art/yvHEThAy6Yvf5mRjp/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "robsouthgate4", "avatarUrl": "https://avatars.githubusercontent.com/robsouthgate4?s=200", - "settings": "{\"num\":3925,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,1,1],\"shader\":\"\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvec2 vec2Random(vec2 st) {\\n st = vec2(dot(st, vec2(0.040,-0.250)),\\n dot(st, vec2(269.5,183.3)));\\n return -1.0 + 2.0 * fract(sin(st) * 43758.633);\\n}\\n\\nfloat gradientNoise(vec2 st) {\\n vec2 i = floor(st);\\n vec2 f = fract(st);\\n\\n vec2 u = smoothstep(0.0, 1.0, f);\\n\\n return mix(mix(dot(vec2Random(i + vec2(0.0,0.0)), f - vec2(0.0,0.0)),\\n dot(vec2Random(i + vec2(1.0,0.0)), f - vec2(1.0,0.0)), u.x),\\n mix(dot(vec2Random(i + vec2(0.0,1.0)), f - vec2(0.0,1.0)),\\n dot(vec2Random(i + vec2(1.0,1.0)), f - vec2(1.0,1.0)), u.x), u.y);\\n}\\n\\nfloat ran(float x) {\\n return gradientNoise(vec2(x, 1.0));\\n}\\n\\nvoid main() {\\n \\tfloat down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\tvec2 snd = texture2D(sound, vec2(1.0)).xy;\\n \\n \\tfloat x = mod(vertexId, across); \\n float y = floor(vertexId / across);\\n \\n \\tfloat u = x / (across -1.);\\n float v = y / (across - 1.);\\n \\n float xoff = ran(time + y * 0.9);\\n float yoff = fract(time + x * 0.3);\\n \\n \\tfloat ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 0.9;\\n \\n\\tgl_Position = vec4(xy * 1., 0, 1);\\n gl_PointSize = 10.;\\n \\tgl_PointSize *= 20. / down;\\n \\tgl_PointSize *= resolution.x / 600.;\\n \\tv_color = vec4(1,vy,0,1);\\n}\"}", + "settings": { + "num": 3925, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 1, + 1 + ], + "shader": "\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvec2 vec2Random(vec2 st) {\n st = vec2(dot(st, vec2(0.040,-0.250)),\n dot(st, vec2(269.5,183.3)));\n return -1.0 + 2.0 * fract(sin(st) * 43758.633);\n}\n\nfloat gradientNoise(vec2 st) {\n vec2 i = floor(st);\n vec2 f = fract(st);\n\n vec2 u = smoothstep(0.0, 1.0, f);\n\n return mix(mix(dot(vec2Random(i + vec2(0.0,0.0)), f - vec2(0.0,0.0)),\n dot(vec2Random(i + vec2(1.0,0.0)), f - vec2(1.0,0.0)), u.x),\n mix(dot(vec2Random(i + vec2(0.0,1.0)), f - vec2(0.0,1.0)),\n dot(vec2Random(i + vec2(1.0,1.0)), f - vec2(1.0,1.0)), u.x), u.y);\n}\n\nfloat ran(float x) {\n return gradientNoise(vec2(x, 1.0));\n}\n\nvoid main() {\n \tfloat down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \tvec2 snd = texture2D(sound, vec2(1.0)).xy;\n \n \tfloat x = mod(vertexId, across); \n float y = floor(vertexId / across);\n \n \tfloat u = x / (across -1.);\n float v = y / (across - 1.);\n \n float xoff = ran(time + y * 0.9);\n float yoff = fract(time + x * 0.3);\n \n \tfloat ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 0.9;\n \n\tgl_Position = vec4(xy * 1., 0, 1);\n gl_PointSize = 10.;\n \tgl_PointSize *= 20. / down;\n \tgl_PointSize *= resolution.x / 600.;\n \tv_color = vec4(1,vy,0,1);\n}" + }, "screenshotURL": "data/images/images-whsya2nj975d5tt3v-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yva6wZBxMPvZtC8iA/art.json b/art/yva6wZBxMPvZtC8iA/art.json index 5c666777..372927ee 100644 --- a/art/yva6wZBxMPvZtC8iA/art.json +++ b/art/yva6wZBxMPvZtC8iA/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46343.0\\nvec2 surfacePosition;\\nvec4 simFragCoord;\\nvec2 vertexResolution = resolution;\\n#ifdef GL_ES\\n//precision mediump float;\\n#endif\\n\\n//#extension GL_OES_standard_derivatives : enable\\n\\n//uniform //float time;\\n//uniform vec2 mouse;\\n//uniform vec2 vertexResolution;\\n\\nfloat extract_bit(float n, float e)\\n{\\n\\treturn fract(n/exp2(e+1.));\\n}\\n\\n\\nfloat sprite(float n, vec2 p)\\n{\\n\\tp \\t\\t= floor(p);\\n\\tfloat bounds \\t= float(all(bvec2(p.x < 3., p.y < 5.)) && all(bvec2(p.x >= 0., p.y >= 0.)));\\n\\treturn extract_bit(n, (2. - p.x) + 3. * p.y) * bounds;\\n}\\n\\n\\t\\t\\t\\t\\nfloat digit(float n, vec2 p)\\n{\\n\\treturn (n == 1.) ? sprite( 9362., p) \\n\\t\\t: (n == 2.) ? sprite(29671., p) \\n\\t\\t: (n == 3.) ? sprite(29391., p) \\n\\t\\t: (n == 4.) ? sprite(23497., p) \\n\\t\\t: (n == 5.) ? sprite(31183., p) \\n\\t\\t: (n == 6.) ? sprite(31215., p) \\n\\t\\t: (n == 7.) ? sprite(29257., p) \\n\\t\\t: (n == 8.) ? sprite(31727., p) \\n\\t\\t: (n == 9.) ? sprite(31695., p) \\n\\t\\t: \\t sprite(31599., p);\\n}\\n\\nfloat badlog10(float i)\\n{\\n\\treturn (i >= 1000000000.) ? 9. \\n\\t\\t: (i >= 100000000.) ? 8. \\n\\t\\t: (i >= 10000000.) ? 7. \\n\\t\\t: (i >= 1000000.) ? 6. \\n\\t\\t: (i >= 100000.) ? 5. \\n\\t\\t: (i >= 10000.) ? 4. \\n\\t\\t: (i >= 1000.) ? 3. \\n\\t\\t: (i >= 100.) ? 2. \\n\\t\\t: (i >= 10.) ? 1. \\n\\t\\t: \\t\\t 0.;\\t\\n}\\n\\t\\n\\n\\nfloat print(float n, vec2 position)\\n{\\t\\n\\tfloat offset\\t= 4.;\\n\\tfloat result\\t= 0.;\\n\\n\\tfor(int i = 0; i < 8; i++)\\n\\t{\\n\\t\\tfloat place = pow(10., float(i));\\n\\t\\t\\n\\t\\tif(n >= place || i == 0)\\n\\t\\t{\\n\\t\\t\\tresult\\t \\t+= digit(floor(mod(floor(n/place)+.5, 10.)), position);\\t\\t\\n\\t\\t\\tposition.x\\t+= 4.;\\n\\t\\t}\\n\\t\\telse\\n\\t\\t{\\n\\t\\t\\tbreak;\\n\\t\\t}\\n\\t\\t\\n\\t}\\n\\t\\n\\treturn floor(result + .5);\\n}\\n\\n\\nfloat center_print(float n, vec2 position)\\n{\\n\\treturn print(n, position - vec2(4. * badlog10(n) * .5 - 2., -2.));\\n}\\n\\n\\nvoid main( void ) {float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nsurfacePosition = vec2(ux,vy);\\n\\n\\n\\tvec2 uv\\t\\t= simFragCoord.xy / vertexResolution.xy - .5;\\n\\tvec2 print_uv\\t= floor(uv * 64.);\\n\\t\\n\\tfloat text\\t= center_print(12345678., print_uv);\\n\\tfloat axis \\t= float(abs(uv.x) < 1./vertexResolution.x || abs(uv.y) < 1./vertexResolution.y) * .25;\\n\\tv_color \\t+= text + axis;\\n\\n}\\n\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46343.0\nvec2 surfacePosition;\nvec4 simFragCoord;\nvec2 vertexResolution = resolution;\n#ifdef GL_ES\n//precision mediump float;\n#endif\n\n//#extension GL_OES_standard_derivatives : enable\n\n//uniform //float time;\n//uniform vec2 mouse;\n//uniform vec2 vertexResolution;\n\nfloat extract_bit(float n, float e)\n{\n\treturn fract(n/exp2(e+1.));\n}\n\n\nfloat sprite(float n, vec2 p)\n{\n\tp \t\t= floor(p);\n\tfloat bounds \t= float(all(bvec2(p.x < 3., p.y < 5.)) && all(bvec2(p.x >= 0., p.y >= 0.)));\n\treturn extract_bit(n, (2. - p.x) + 3. * p.y) * bounds;\n}\n\n\t\t\t\t\nfloat digit(float n, vec2 p)\n{\n\treturn (n == 1.) ? sprite( 9362., p) \n\t\t: (n == 2.) ? sprite(29671., p) \n\t\t: (n == 3.) ? sprite(29391., p) \n\t\t: (n == 4.) ? sprite(23497., p) \n\t\t: (n == 5.) ? sprite(31183., p) \n\t\t: (n == 6.) ? sprite(31215., p) \n\t\t: (n == 7.) ? sprite(29257., p) \n\t\t: (n == 8.) ? sprite(31727., p) \n\t\t: (n == 9.) ? sprite(31695., p) \n\t\t: \t sprite(31599., p);\n}\n\nfloat badlog10(float i)\n{\n\treturn (i >= 1000000000.) ? 9. \n\t\t: (i >= 100000000.) ? 8. \n\t\t: (i >= 10000000.) ? 7. \n\t\t: (i >= 1000000.) ? 6. \n\t\t: (i >= 100000.) ? 5. \n\t\t: (i >= 10000.) ? 4. \n\t\t: (i >= 1000.) ? 3. \n\t\t: (i >= 100.) ? 2. \n\t\t: (i >= 10.) ? 1. \n\t\t: \t\t 0.;\t\n}\n\t\n\n\nfloat print(float n, vec2 position)\n{\t\n\tfloat offset\t= 4.;\n\tfloat result\t= 0.;\n\n\tfor(int i = 0; i < 8; i++)\n\t{\n\t\tfloat place = pow(10., float(i));\n\t\t\n\t\tif(n >= place || i == 0)\n\t\t{\n\t\t\tresult\t \t+= digit(floor(mod(floor(n/place)+.5, 10.)), position);\t\t\n\t\t\tposition.x\t+= 4.;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tbreak;\n\t\t}\n\t\t\n\t}\n\t\n\treturn floor(result + .5);\n}\n\n\nfloat center_print(float n, vec2 position)\n{\n\treturn print(n, position - vec2(4. * badlog10(n) * .5 - 2., -2.));\n}\n\n\nvoid main( void ) {float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nsimFragCoord = vec4(x,y,1.,1.);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nsurfacePosition = vec2(ux,vy);\n\n\n\tvec2 uv\t\t= simFragCoord.xy / vertexResolution.xy - .5;\n\tvec2 print_uv\t= floor(uv * 64.);\n\t\n\tfloat text\t= center_print(12345678., print_uv);\n\tfloat axis \t= float(abs(uv.x) < 1./vertexResolution.x || abs(uv.y) < 1./vertexResolution.y) * .25;\n\tv_color \t+= text + axis;\n\n}\n" + }, "screenshotURL": "data/images/images-x0glh34ebpjwfodon-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/ywWngPQ5Zn8DxNM24/art.json b/art/ywWngPQ5Zn8DxNM24/art.json index 27349dca..d9b55d67 100644 --- a/art/ywWngPQ5Zn8DxNM24/art.json +++ b/art/ywWngPQ5Zn8DxNM24/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "trip-les-ix", "avatarUrl": "https://avatars.githubusercontent.com/trip-les-ix?s=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//time vertexId gl_Position v_color resolution\\n\\n// 3d plasma\\n// maybe I wil polygonize this in my next code\\n#define kp1 -.2\\n#define width 384.\\n#define height 512.\\n\\nfloat plasma(vec2 pos)\\n{\\n float c = 0.20;\\n float spd = 4.96;\\n float tm = time * spd;\\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \\n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \\n sin(pos.x + sin(pos.y + 2.0 * tm))) + \\n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\\n return c;\\n}\\n\\nvoid main() {\\n float ratio = resolution.x / resolution.y;\\n float w = width;\\n float h = height / ratio;\\n\\n float vId = float(vertexId);\\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\\n \\n //gl_Position = vec4(px, py, 0, 1);\\n float y = -0.75 + py;\\n float c = sin(plasma(vec2(px*2., py) * 4.60)) * 0.5 + 0.25;\\n gl_Position = vec4(px / py, (y + c * 0.615+kp1) / py, 0.0, 1);\\n gl_PointSize = 2.0;\\n\\n \\n v_color = vec4(2.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//time vertexId gl_Position v_color resolution\n\n// 3d plasma\n// maybe I wil polygonize this in my next code\n#define kp1 -.2\n#define width 384.\n#define height 512.\n\nfloat plasma(vec2 pos)\n{\n float c = 0.20;\n float spd = 4.96;\n float tm = time * spd;\n c = sin(tan(pos.x) + tan(3.4 * pos.y) + \n sin(3.0 * pos.x + pos.y + 3.0 * tm) + \n sin(pos.x + sin(pos.y + 2.0 * tm))) + \n (sin(pos.x * pos.y - 3.0 * tm) * 0.5 + 0.25);\n return c;\n}\n\nvoid main() {\n float ratio = resolution.x / resolution.y;\n float w = width;\n float h = height / ratio;\n\n float vId = float(vertexId);\n float px = (mod(vId, w) - w / 2.0) / (w / 2.0);\n float py = (floor(vId / w) - h / 2.0) / (h / 0.5) + 0.5;\n \n //gl_Position = vec4(px, py, 0, 1);\n float y = -0.75 + py;\n float c = sin(plasma(vec2(px*2., py) * 4.60)) * 0.5 + 0.25;\n gl_Position = vec4(px / py, (y + c * 0.615+kp1) / py, 0.0, 1);\n gl_PointSize = 2.0;\n\n \n v_color = vec4(2.2 + c, 0.4 + c, 1.7 + c, 1) * 0.75;\n}" + }, "screenshotURL": "data/images/images-9bo862efqktfyg91d-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/yxx6Qzd29foXStAvK/art.json b/art/yxx6Qzd29foXStAvK/art.json index 4b4438ac..cadf3ba6 100644 --- a/art/yxx6Qzd29foXStAvK/art.json +++ b/art/yxx6Qzd29foXStAvK/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "samthrasher", "avatarUrl": "https://avatars.githubusercontent.com/samthrasher?s=200", - "settings": "{\"num\":1000,\"mode\":\"LINE_STRIP\",\"sound\":\"https://soundcloud.com/cultbabies/wait\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define GAMMA 0.454545\\n\\n\\nfloat soundIntensity(float frq){\\n\\treturn texture2D(sound, vec2(frq, 0)).a;\\n}\\n\\nfloat meanIntensity(){\\n \\tconst float samples = 0.;\\n \\tfloat intensity;\\n for(float i = 0.; i < samples; i+=1./samples){\\n \\tintensity += soundIntensity(i);\\n }\\n\\treturn intensity/samples;\\n}\\n\\nfloat maxIntensity(){\\n \\tconst float samples = 50.;\\n \\tfloat intensity;\\n for(float i = 0.; i < samples; i+=1./samples){\\n \\tintensity = max(intensity, soundIntensity(i));\\n }\\n\\treturn intensity;\\n}\\n\\n\\nvec3 getVertexColor(){\\n float phase = mod(time / 2.0, 1.0);\\n\\tfloat vertexRatio = vertexId/vertexCount;\\n \\tfloat r = 0.5 * mod(0.24321 * vertexRatio + phase, 1.0);\\n\\tfloat g = 0.5 * mod(0.13433 * vertexRatio + phase, 1.0);\\n float b = 0.5 * mod(0.09001 * vertexRatio + phase, 1.0);\\n return vec3(r, g, b);\\n}\\n\\n\\nvoid main(){\\n \\tfloat aspect = resolution.x / resolution.y;\\n float n_y = floor(sqrt(vertexCount));\\n float n_phi = n_y;\\n float rad = 0.6;\\n\\tfloat i_y = floor(vertexId/n_y);\\n \\tfloat i_phi = floor(vertexId - i_y);\\n float theta = -PI * (-1.0 + 2.0 * i_y / (n_y - 1.0));\\n float phi = 2.0 * PI * (-1.0 + 2.0 * i_phi / (n_phi - 1.0));\\n \\n float phase = mod(time + 0.01*i_phi, 2.0 * PI);\\n \\n phi = mod(phi + phase, 2.0 * PI);\\n \\tfloat y = cos(theta);\\n float x = sin(theta) * cos(phi);\\n float z = sin(theta) * sin(phi); \\n \\n \\n \\tfloat vertexRatio = vertexId/vertexCount;\\n float vertexRadians = vertexRatio * PI * 2.;\\n \\t\\n //float x = cos(vertexRadians);\\n //float y = sin(vertexRadians);\\n //float z = vertexRatio;\\n\\n \\n vec4 position = vec4(\\n x,\\n y * aspect,\\n z,\\n\\t 1.0\\n );\\n \\n \\n gl_Position = vec4(\\n x,\\n y * aspect,\\n z,\\n 1./soundIntensity(cos(theta)*cos(phi))\\n );\\n \\n \\tv_color = vec4(getVertexColor(), 0.5);\\n \\n \\tfloat frequencyScale = 6.;\\n \\t//gl_PointSize = pow(soundIntensity(0.075*pow(vertexRatio+0.5,frequencyScale))+1.1, 7.);\\n gl_PointSize = 8.0;\\n}\"}", + "settings": { + "num": 1000, + "mode": "LINE_STRIP", + "sound": "https://soundcloud.com/cultbabies/wait", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define GAMMA 0.454545\n\n\nfloat soundIntensity(float frq){\n\treturn texture2D(sound, vec2(frq, 0)).a;\n}\n\nfloat meanIntensity(){\n \tconst float samples = 0.;\n \tfloat intensity;\n for(float i = 0.; i < samples; i+=1./samples){\n \tintensity += soundIntensity(i);\n }\n\treturn intensity/samples;\n}\n\nfloat maxIntensity(){\n \tconst float samples = 50.;\n \tfloat intensity;\n for(float i = 0.; i < samples; i+=1./samples){\n \tintensity = max(intensity, soundIntensity(i));\n }\n\treturn intensity;\n}\n\n\nvec3 getVertexColor(){\n float phase = mod(time / 2.0, 1.0);\n\tfloat vertexRatio = vertexId/vertexCount;\n \tfloat r = 0.5 * mod(0.24321 * vertexRatio + phase, 1.0);\n\tfloat g = 0.5 * mod(0.13433 * vertexRatio + phase, 1.0);\n float b = 0.5 * mod(0.09001 * vertexRatio + phase, 1.0);\n return vec3(r, g, b);\n}\n\n\nvoid main(){\n \tfloat aspect = resolution.x / resolution.y;\n float n_y = floor(sqrt(vertexCount));\n float n_phi = n_y;\n float rad = 0.6;\n\tfloat i_y = floor(vertexId/n_y);\n \tfloat i_phi = floor(vertexId - i_y);\n float theta = -PI * (-1.0 + 2.0 * i_y / (n_y - 1.0));\n float phi = 2.0 * PI * (-1.0 + 2.0 * i_phi / (n_phi - 1.0));\n \n float phase = mod(time + 0.01*i_phi, 2.0 * PI);\n \n phi = mod(phi + phase, 2.0 * PI);\n \tfloat y = cos(theta);\n float x = sin(theta) * cos(phi);\n float z = sin(theta) * sin(phi); \n \n \n \tfloat vertexRatio = vertexId/vertexCount;\n float vertexRadians = vertexRatio * PI * 2.;\n \t\n //float x = cos(vertexRadians);\n //float y = sin(vertexRadians);\n //float z = vertexRatio;\n\n \n vec4 position = vec4(\n x,\n y * aspect,\n z,\n\t 1.0\n );\n \n \n gl_Position = vec4(\n x,\n y * aspect,\n z,\n 1./soundIntensity(cos(theta)*cos(phi))\n );\n \n \tv_color = vec4(getVertexColor(), 0.5);\n \n \tfloat frequencyScale = 6.;\n \t//gl_PointSize = pow(soundIntensity(0.075*pow(vertexRatio+0.5,frequencyScale))+1.1, 7.);\n gl_PointSize = 8.0;\n}" + }, "screenshotURL": "data/images/images-op7jaflfesgfojan4-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/yz73Hm3Fq5SyrZppP/art.json b/art/yz73Hm3Fq5SyrZppP/art.json index 1ce74d6f..613cf3ab 100644 --- a/art/yz73Hm3Fq5SyrZppP/art.json +++ b/art/yz73Hm3Fq5SyrZppP/art.json @@ -22,7 +22,19 @@ "origId": null, "name": "rings 2", "username": "mark", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user9196240/bt-flaming-june-reuben-halsey-chillout-mix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI 3.14159\\n\\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\\n \\nvoid main () {\\n float x, y, z;\\n \\n float i = hash(vertexId);\\n \\n if (mod(vertexId, 2.) > 0.) {\\n // RIPPLES\\n float snd = texture2D(sound, vec2(.7, i)).a;\\n \\n float rad = .6 * i;\\n rad += (snd / rad) * .01;\\n float move = (time * .2) + .2 * snd;\\n \\n float ang = vertexId / (PI * 2.) + move;\\n ang *= sin(PI * .5 - rad * PI);\\n \\n x = rad * cos(ang);\\n y = rad * sin(ang) * .7;\\n \\n v_color = vec4(sin(i * PI), cos(i * PI), i, 1.);\\n gl_Position = vec4(x, y, z, 1.);\\n } else {\\n // RING\\n \\n z = .1;\\n float snd = texture2D(sound, vec2(hash(i), 0.)).a;\\n float rad = .6 + .2 * snd;\\n \\n x = rad * sin(.7 * time + i * PI * 2.);\\n y = rad * cos(time + i * PI * 2.);\\n \\n v_color = vec4(sin(2. * i * PI), cos(2. * i * PI), .5, 1.);\\n gl_Position = vec4(x, y, z, 1.);\\n }\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user9196240/bt-flaming-june-reuben-halsey-chillout-mix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI 3.14159\n\nfloat hash( float n ) { return fract(sin(n)*753.5453123); }\n \nvoid main () {\n float x, y, z;\n \n float i = hash(vertexId);\n \n if (mod(vertexId, 2.) > 0.) {\n // RIPPLES\n float snd = texture2D(sound, vec2(.7, i)).a;\n \n float rad = .6 * i;\n rad += (snd / rad) * .01;\n float move = (time * .2) + .2 * snd;\n \n float ang = vertexId / (PI * 2.) + move;\n ang *= sin(PI * .5 - rad * PI);\n \n x = rad * cos(ang);\n y = rad * sin(ang) * .7;\n \n v_color = vec4(sin(i * PI), cos(i * PI), i, 1.);\n gl_Position = vec4(x, y, z, 1.);\n } else {\n // RING\n \n z = .1;\n float snd = texture2D(sound, vec2(hash(i), 0.)).a;\n float rad = .6 + .2 * snd;\n \n x = rad * sin(.7 * time + i * PI * 2.);\n y = rad * cos(time + i * PI * 2.);\n \n v_color = vec4(sin(2. * i * PI), cos(2. * i * PI), .5, 1.);\n gl_Position = vec4(x, y, z, 1.);\n }\n}" + }, "screenshotURL": "data/images/images-2uja5t1v2hdxj03qf-thumbnail.jpg", "views": { "$numberInt": "178" diff --git a/art/z4BHgWLrPnZbRvude/art.json b/art/z4BHgWLrPnZbRvude/art.json index 6cad6733..92889c73 100644 --- a/art/z4BHgWLrPnZbRvude/art.json +++ b/art/z4BHgWLrPnZbRvude/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6525,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rot(vec3 axis, float angle) {\\n \\n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n \\n mat4 mr = rot(vec3(0.019, 0.2, atan(time * 10.0) +0.3), time);\\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 7.0; \\n\\n v_color = vec4(gl_Position.z,(vertexId / vertexCount),0.0,1.0);\\n}\"}", + "settings": { + "num": 6525, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rot(vec3 axis, float angle) {\n \n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n \n mat4 mr = rot(vec3(0.019, 0.2, atan(time * 10.0) +0.3), time);\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 7.0; \n\n v_color = vec4(gl_Position.z,(vertexId / vertexCount),0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-m4ny7amzso1m0ldpd-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/z5Wj5jyFwYiwezjLv/art.json b/art/z5Wj5jyFwYiwezjLv/art.json index 49a222c4..ba73b018 100644 --- a/art/z5Wj5jyFwYiwezjLv/art.json +++ b/art/z5Wj5jyFwYiwezjLv/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":45000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n//KDrawmode=GL_TRIANGLE_STRIP\\n//KVerticesNumber=45000\\n\\n#define numTrackPoints 30000//KParameter0 100.>>30000.0\\n#define numFunkPoints 3600.0//KParameter1 100.>>3600.0\\n#define sectionsAcross 10.//KParameter2 5.>>100.0\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n //float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId + next) / (numSections - 1.);\\n float v = sv * 4. + base;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n #if 0\\n s = .5;\\n s2 = 0.5;\\n #endif\\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n //float width = mix(1., 2., pow(s2, .5));\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre * .4, 1)).xyz;\\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \\n \\n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n float pump = step(0.5, s2);\\n sat = mix(sat, 1., vert * pump);\\n val = mix(val, 1., vert * pump);\\n hue = mix(hue, hue + .15, vert * pump);\\n \\n //hue += sign(pre.x) * .25;\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\\n \\n //color.rgb = zaxis * .5 + .5; \\n color.a = 1. - pow(sv, 20.0);\\n color.rgb *= color.a;\\n}\\n\\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n //float sectionsAcross = 30.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float sideV = sideSectionId / halfSectionsAcross;\\n \\n float lr = mod(vertexId, 2.);\\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n \\n float sv = (sectionId + next * .4) / (numSections - 1.);\\n float v = sv * .2 + base + .1;\\n \\n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 tzaxis = normalize(s1 - s0);\\n vec3 txaxis = normalize(cross(s0, s1));\\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\\n \\n const float height = .05;\\n const float period = 2.;\\n const float speed = 2.;\\n const float lPeriod = 0.5;\\n \\n float sx = (sideV + lr / halfSectionsAcross);\\n float bt = sx * period + time * speed + sv * lPeriod;\\n float bh = sin(bt) * height;\\n \\n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\\n float unit = 1. / halfSectionsAcross;\\n \\n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\\n \\n r0 += tzaxis * -.01;\\n \\n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\\n \\n vec3 sb0 = normalize(rb1 - rb0);\\n vec3 sb1 = normalize(rb2 - rb1);\\n \\n vec3 zaxis = normalize(sb1 - sb0);\\n vec3 xaxis = normalize(cross(sb0, sb1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(rb0 * expand, 1)); \\n\\n #if 0\\n s = 1.;\\n s2 = 1.;\\n #endif\\n \\n float su = (sideSectionId + lr) / halfSectionsAcross;\\n\\n float width = 1.; \\n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\\n vec3 nrm = vec3(0, 1, 0);\\n \\n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = 0.3;\\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0., 1.0, abs(dot(n, lightDir))), 1);\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * 2. * step(0.5, pId);\\n pos += cmat[1].xyz * 2. * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n //const float numTrackPoints = 30000.0;\\n float finalNumFunkPoints = 3.*numFunkPoints; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n if (id < finalNumFunkPoints) {\\n track(id, finalNumFunkPoints, base, pos, color);\\n } else {\\n id -= finalNumFunkPoints;\\n if (id < numFunkPoints) {\\n funk(id, numFunkPoints, base, pos, color);\\n } else {\\n id -= numFunkPoints;\\n sky(id, base, cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 45000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n//KDrawmode=GL_TRIANGLE_STRIP\n//KVerticesNumber=45000\n\n#define numTrackPoints 30000//KParameter0 100.>>30000.0\n#define numFunkPoints 3600.0//KParameter1 100.>>3600.0\n#define sectionsAcross 10.//KParameter2 5.>>100.0\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n //float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId + next) / (numSections - 1.);\n float v = sv * 4. + base;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n #if 0\n s = .5;\n s2 = 0.5;\n #endif\n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n //float width = mix(1., 2., pow(s2, .5));\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre * .4, 1)).xyz;\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \n \n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n float pump = step(0.5, s2);\n sat = mix(sat, 1., vert * pump);\n val = mix(val, 1., vert * pump);\n hue = mix(hue, hue + .15, vert * pump);\n \n //hue += sign(pre.x) * .25;\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\n \n //color.rgb = zaxis * .5 + .5; \n color.a = 1. - pow(sv, 20.0);\n color.rgb *= color.a;\n}\n\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n //float sectionsAcross = 30.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float sideV = sideSectionId / halfSectionsAcross;\n \n float lr = mod(vertexId, 2.);\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n \n float sv = (sectionId + next * .4) / (numSections - 1.);\n float v = sv * .2 + base + .1;\n \n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 tzaxis = normalize(s1 - s0);\n vec3 txaxis = normalize(cross(s0, s1));\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\n \n const float height = .05;\n const float period = 2.;\n const float speed = 2.;\n const float lPeriod = 0.5;\n \n float sx = (sideV + lr / halfSectionsAcross);\n float bt = sx * period + time * speed + sv * lPeriod;\n float bh = sin(bt) * height;\n \n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\n float unit = 1. / halfSectionsAcross;\n \n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\n \n r0 += tzaxis * -.01;\n \n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\n \n vec3 sb0 = normalize(rb1 - rb0);\n vec3 sb1 = normalize(rb2 - rb1);\n \n vec3 zaxis = normalize(sb1 - sb0);\n vec3 xaxis = normalize(cross(sb0, sb1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(rb0 * expand, 1)); \n\n #if 0\n s = 1.;\n s2 = 1.;\n #endif\n \n float su = (sideSectionId + lr) / halfSectionsAcross;\n\n float width = 1.; \n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\n vec3 nrm = vec3(0, 1, 0);\n \n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\n float sat = 0.3;\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0., 1.0, abs(dot(n, lightDir))), 1);\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * 2. * step(0.5, pId);\n pos += cmat[1].xyz * 2. * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n //const float numTrackPoints = 30000.0;\n float finalNumFunkPoints = 3.*numFunkPoints; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n if (id < finalNumFunkPoints) {\n track(id, finalNumFunkPoints, base, pos, color);\n } else {\n id -= finalNumFunkPoints;\n if (id < numFunkPoints) {\n funk(id, numFunkPoints, base, pos, color);\n } else {\n id -= numFunkPoints;\n sky(id, base, cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-mm9ouz23izd7d93sl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/z5fvZCjBmkRpsSaxD/art.json b/art/z5fvZCjBmkRpsSaxD/art.json index 6402a69a..bebacde4 100644 --- a/art/z5fvZCjBmkRpsSaxD/art.json +++ b/art/z5fvZCjBmkRpsSaxD/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "hyosang_jung", "avatarUrl": "https://secure.gravatar.com/avatar/012973e43b86800472c970853da48caf?default=retro&size=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/graham-panter/fly-by-light\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Name: Hyosang Jung\\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive\\n//Course Name: CS250\\n//Term&Year: 2022&Fall\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float su = abs(u - 0.5) * 2.;\\n float sv = abs(v - 0.5) * 2.;\\n \\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n \\n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\\n\\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 1.;//sin(time + x * y * .02) * 5.; \\n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n \\n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\\n float sat = mix(0., 1., pump);\\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "https://soundcloud.com/graham-panter/fly-by-light", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Name: Hyosang Jung\n//Assignment Name: Exercise - Vertexshaderart : Audio Reactive\n//Course Name: CS250\n//Term&Year: 2022&Fall\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float su = abs(u - 0.5) * 2.;\n float sv = abs(v - 0.5) * 2.;\n \n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n \n float snd = texture2D(sound, vec2(au * 0.05, av * .25)).a;\n\n float xoff = 0.;//sin(time + y * 0.2) * 0.1;\n float yoff = 0.;//sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 1.;//sin(time + x * y * .02) * 5.; \n gl_PointSize = pow(snd + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n \n float hue = u * .1 + snd * 0.2 + time * .1; //sin(time + v * 20.) * .05;\n float sat = mix(0., 1., pump);\n float val = mix(.1, pow(snd + 0.2, 5.0), pump);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-1c3eerh7a9z8kx4pl-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/z7C9Xwr9PtGmofB9B/art.json b/art/z7C9Xwr9PtGmofB9B/art.json index f051347a..d64124fc 100644 --- a/art/z7C9Xwr9PtGmofB9B/art.json +++ b/art/z7C9Xwr9PtGmofB9B/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n s, 0, 0, c,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n c, 0, 0, s); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, s, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, s); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 1,\\n 0, s[1], 0, 0,\\n 0, 1, s[2], 0,\\n 2, 0, 0, s);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 1,\\n 0, f, 0, 0,\\n f, 1, (zNear + zFar) * rangeInv, -1,\\n 2, f, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][1], m[2][2], \\n m[0][0], m[1][1], m[2][2], \\n m[0][0], m[1][1], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][1], m[2][2], m[3][3], \\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3],\\n m[0][0], m[1][1], m[2][2], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 2);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.;\\n\\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 10.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\\n \\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n \\n float sv = (sectionId + next) / (numSections - 1.);\\n float v = sv * 4. + base;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 zaxis = normalize(s1 - s0);\\n vec3 xaxis = normalize(cross(s0, s1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(r0 * expand, 1)); \\n\\n float lr = mod(vertexId, 2.);\\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\\n \\n #if 0\\n s = .5;\\n s2 = 0.5;\\n #endif\\n \\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\\n\\n float width = 1.; \\n //float width = mix(1., 2., pow(s2, .5));\\n vec3 pre = mix(\\n vec3(su * halfSectionsAcross * side * width, 0, 0), \\n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \\n vert); \\n pos = (wmat * vec4(pre * .4, 1)).xyz;\\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \\n \\n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n float pump = step(0.5, s2);\\n sat = mix(sat, 1., vert * pump);\\n val = mix(val, 1., vert * pump);\\n hue = mix(hue, hue + .15, vert * pump);\\n \\n //hue += sign(pre.x) * .25;\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\\n \\n //color.rgb = zaxis * .5 + .5; \\n color.a = 1. - pow(sv, 20.0);\\n color.rgb *= color.a;\\n}\\n\\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\\n float sectionsAcross = 30.;\\n float halfSectionsAcross = sectionsAcross / 2.;\\n float pointsPerSection = sectionsAcross * 6.;\\n float sectionPointId = mod(vertexId, pointsPerSection); \\n float sectionId = floor(vertexId / pointsPerSection);\\n float quadId = floor(sectionPointId / 6.);\\n float numSections = (vertexCount / pointsPerSection);\\n \\n float sideSectionId = mod(quadId, halfSectionsAcross);\\n float sideV = sideSectionId / halfSectionsAcross;\\n \\n float lr = mod(vertexId, 2.);\\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\\n \\n float sv = (sectionId + next * .4) / (numSections - 1.);\\n float v = sv * .2 + base + .1;\\n \\n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\\n \\n float off = 0.2;\\n \\n vec3 r0 = getCurvePoint(v + off * 0.);\\n vec3 r1 = getCurvePoint(v + off * 1.);\\n vec3 r2 = getCurvePoint(v + off * 2.);\\n \\n vec3 s0 = normalize(r1 - r0);\\n vec3 s1 = normalize(r2 - r1);\\n \\n vec3 tzaxis = normalize(s1 - s0);\\n vec3 txaxis = normalize(cross(s0, s1));\\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\\n \\n const float height = .05;\\n const float period = 2.;\\n const float speed = 2.;\\n const float lPeriod = 0.5;\\n \\n float sx = (sideV + lr / halfSectionsAcross);\\n float bt = sx * period + time * speed + sv * lPeriod;\\n float bh = sin(bt) * height;\\n \\n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\\n float unit = 1. / halfSectionsAcross;\\n \\n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\\n \\n r0 += tzaxis * -.01;\\n \\n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\\n \\n vec3 sb0 = normalize(rb1 - rb0);\\n vec3 sb1 = normalize(rb2 - rb1);\\n \\n vec3 zaxis = normalize(sb1 - sb0);\\n vec3 xaxis = normalize(cross(sb0, sb1));\\n vec3 yaxis = normalize(cross(zaxis, xaxis));\\n \\n mat4 wmat = mat4(\\n vec4(xaxis, 0),\\n vec4(yaxis, 0),\\n vec4(zaxis, 0),\\n vec4(rb0 * expand, 1)); \\n\\n #if 0\\n s = 1.;\\n s2 = 1.;\\n #endif\\n \\n float su = (sideSectionId + lr) / halfSectionsAcross;\\n\\n float width = 1.; \\n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\\n vec3 nrm = vec3(0, 1, 0);\\n \\n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\\n float sat = 0.3;\\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\\n \\n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\\n\\n vec3 c = hsv2rgb(vec3(hue, sat, val));\\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\\n}\\n\\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \\n float starId = floor(vertexId / 3.);\\n float pId = mod(vertexId, 3.);\\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500.;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n float c = hash(starId * 0.017);\\n color = vec4(c, c, c, 1);\\n}\\n\\nvoid main() {\\n const float numTrackPoints = 30000.0;\\n const float numFunkPoints = 3600.0; // must be multiple of 3\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.5;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n float id = vertexId;\\n if (id < numTrackPoints) {\\n track(id, numTrackPoints, base, pos, color);\\n } else {\\n id -= numTrackPoints;\\n if (id < numFunkPoints) {\\n funk(id, numFunkPoints, base, pos, color);\\n } else {\\n id -= numFunkPoints;\\n sky(id, base, cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/djapsara/apsara-afterdark-031-on-frisky-radio-may-2017", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* \n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n s, 0, 0, c,\n 0, c, s, 0,\n 0, -s, c, 0,\n c, 0, 0, s); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, s, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, s); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 1,\n 0, s[1], 0, 0,\n 0, 1, s[2], 0,\n 2, 0, 0, s);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 1,\n 0, f, 0, 0,\n f, 1, (zNear + zFar) * rangeInv, -1,\n 2, f, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][1], m[2][2], \n m[0][0], m[1][1], m[2][2], \n m[0][0], m[1][1], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][1], m[2][2], m[3][3], \n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3],\n m[0][0], m[1][1], m[2][2], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 2);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.;\n\nvoid track(float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 10.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float vert = step(halfSectionsAcross - 1.1, sideSectionId);\n \n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n \n float sv = (sectionId + next) / (numSections - 1.);\n float v = sv * 4. + base;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 zaxis = normalize(s1 - s0);\n vec3 xaxis = normalize(cross(s0, s1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(r0 * expand, 1)); \n\n float lr = mod(vertexId, 2.);\n float asuc = (sideSectionId + lr) / halfSectionsAcross;;\n float s = texture2D(sound, vec2(.1, 1. - sv)).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, asuc), (1. - sv) * .4)).a;\n \n #if 0\n s = .5;\n s2 = 0.5;\n #endif\n \n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n float su = (sideSectionId + lr * s) / halfSectionsAcross;\n\n float width = 1.; \n //float width = mix(1., 2., pow(s2, .5));\n vec3 pre = mix(\n vec3(su * halfSectionsAcross * side * width, 0, 0), \n vec3((halfSectionsAcross - 1.) * side * width, lr * 5. * s, 0), \n vert); \n pos = (wmat * vec4(pre * .4, 1)).xyz;\n vec3 nrm = mix(vec3(0, 1, 0), vec3(sign(pos.x), 0, 0), vert); \n \n float hue = asuc * .1 + pow(s2, 5.) + time * 0.1;\n float sat = mix(1.2, 0.2, vert);// + (sin(sv * 20.) * 1.5);\n float val = mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n float pump = step(0.5, s2);\n sat = mix(sat, 1., vert * pump);\n val = mix(val, 1., vert * pump);\n hue = mix(hue, hue + .15, vert * pump);\n \n //hue += sign(pre.x) * .25;\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0.5, 1.0, abs(dot(n, lightDir))), 1);\n \n //color.rgb = zaxis * .5 + .5; \n color.a = 1. - pow(sv, 20.0);\n color.rgb *= color.a;\n}\n\nvoid funk(const float vertexId, float vertexCount, float base, out vec3 pos, out vec4 color) {\n float sectionsAcross = 30.;\n float halfSectionsAcross = sectionsAcross / 2.;\n float pointsPerSection = sectionsAcross * 6.;\n float sectionPointId = mod(vertexId, pointsPerSection); \n float sectionId = floor(vertexId / pointsPerSection);\n float quadId = floor(sectionPointId / 6.);\n float numSections = (vertexCount / pointsPerSection);\n \n float sideSectionId = mod(quadId, halfSectionsAcross);\n float sideV = sideSectionId / halfSectionsAcross;\n \n float lr = mod(vertexId, 2.);\n float next = mod(floor(vertexId / 2.) + floor(vertexId / 3.), 2.);\n float side = mix(-1., 1., step(halfSectionsAcross, quadId));\n \n float sv = (sectionId + next * .4) / (numSections - 1.);\n float v = sv * .2 + base + .1;\n \n float s = texture2D(sound, vec2(.1, mix(0.9, 1.0, (1. - sv)))).a;\n float s2 = texture2D(sound, vec2(mix(0.05, 0.5, sideV), (1. - sv) * .4)).a;\n \n float off = 0.2;\n \n vec3 r0 = getCurvePoint(v + off * 0.);\n vec3 r1 = getCurvePoint(v + off * 1.);\n vec3 r2 = getCurvePoint(v + off * 2.);\n \n vec3 s0 = normalize(r1 - r0);\n vec3 s1 = normalize(r2 - r1);\n \n vec3 tzaxis = normalize(s1 - s0);\n vec3 txaxis = normalize(cross(s0, s1));\n vec3 tyaxis = normalize(cross(tzaxis, txaxis));\n \n const float height = .05;\n const float period = 2.;\n const float speed = 2.;\n const float lPeriod = 0.5;\n \n float sx = (sideV + lr / halfSectionsAcross);\n float bt = sx * period + time * speed + sv * lPeriod;\n float bh = sin(bt) * height;\n \n vec3 foff = tyaxis * bh;// - tyaxis * height * 0. + txaxis * side * sin(sx * PI) * 0.;\n float unit = 1. / halfSectionsAcross;\n \n float y0 = sin((sx + unit * 1. + sv * lPeriod) * period + time * speed);\n float y1 = sin((sx + unit * 2. + sv * lPeriod) * period + time * speed);\n float y2 = sin((sx + unit * 3. + sv * lPeriod) * period + time * speed);\n \n r0 += tzaxis * -.01;\n \n vec3 rb0 = r0 + tzaxis * (-1. + y0) * height + txaxis * 1. * side * .1 * sx * cos(y0);\n vec3 rb1 = r0 + tzaxis * (-1. + y1) * height + txaxis * 1. * side * .1 * sx * cos(y1);\n vec3 rb2 = r0 + tzaxis * (-1. + y2) * height + txaxis * 1. * side * .1 * sx * cos(y2);\n \n vec3 sb0 = normalize(rb1 - rb0);\n vec3 sb1 = normalize(rb2 - rb1);\n \n vec3 zaxis = normalize(sb1 - sb0);\n vec3 xaxis = normalize(cross(sb0, sb1));\n vec3 yaxis = normalize(cross(zaxis, xaxis));\n \n mat4 wmat = mat4(\n vec4(xaxis, 0),\n vec4(yaxis, 0),\n vec4(zaxis, 0),\n vec4(rb0 * expand, 1)); \n\n #if 0\n s = 1.;\n s2 = 1.;\n #endif\n \n float su = (sideSectionId + lr) / halfSectionsAcross;\n\n float width = 1.; \n pos = (wmat * vec4(0, next * s, 0, 1)).xyz;\n vec3 nrm = vec3(0, 1, 0);\n \n float hue = sideV * .2 + time * .1; //sideV * .1 + pow(s2, 5.) + time * 0.1;\n float sat = 0.3;\n float val = s;1.;//mix(0.25, 1., pow(s2 + .4, 15.) * pow(s + .4, 15.)) + abs(sin(sv * 40.) * .25);\n \n vec3 n = normalize((wmat * vec4(nrm, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(-0.3, .3, 0.2));\n\n vec3 c = hsv2rgb(vec3(hue, sat, val));\n color = vec4(c * mix(0., 1.0, pow(abs(dot(n, lightDir)) + .5, 5.)), 1);\n}\n\nvoid sky(const float vertexId, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float sz = clamp(2000.0 / min(resolution.x, resolution.y), 2., 200.); \n float starId = floor(vertexId / 3.);\n float pId = mod(vertexId, 3.);\n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500.;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n float c = hash(starId * 0.017);\n color = vec4(c, c, c, 1);\n}\n\nvoid main() {\n const float numTrackPoints = 30000.0;\n const float numFunkPoints = 3600.0; // must be multiple of 3\n \n //float base = 15.; // good place to adjust\n float base = time * 0.5;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n float id = vertexId;\n if (id < numTrackPoints) {\n track(id, numTrackPoints, base, pos, color);\n } else {\n id -= numTrackPoints;\n if (id < numFunkPoints) {\n funk(id, numFunkPoints, base, pos, color);\n } else {\n id -= numFunkPoints;\n sky(id, base, cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n}\n" + }, "screenshotURL": "data/images/images-s3seabh7yi7ubc472-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zAa7gfsGaLGjPw6Wt/art.json b/art/zAa7gfsGaLGjPw6Wt/art.json index 1eff93e2..fa09053d 100644 --- a/art/zAa7gfsGaLGjPw6Wt/art.json +++ b/art/zAa7gfsGaLGjPw6Wt/art.json @@ -35,7 +35,19 @@ "unlisted": true, "username": "archer", "avatarUrl": "https://lh5.googleusercontent.com/-yNdyToHV35U/AAAAAAAAAAI/AAAAAAAABxw/qQAHdzq4gr8/photo.jpg", - "settings": "{\"num\":30000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/home-2001/resonance\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.0);\\n float v = y / (across - 1.0);\\n \\n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\\n float yoff = 0.0; //sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2.0 - 1.0 + xoff;\\n float vy = v * 2.0 - 1.0 + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n float su = abs(u - 0.5) * 2.0;\\n float sv = abs(v - 0.5) * 2.0;\\n float au = abs(atan(su, sv)) / PI;\\n float av = length(vec2(su, sv));\\n float snd = texture2D(sound, vec2(au * 0.125, av * 0.25)).a;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\\n \\n gl_PointSize = pow(snd / 1.1 + 0.2, 5.0) * 30.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float pump = step(0.8, snd);\\n float hue = u * .1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\\n float sat = mix(0.0, 1.0, pump);\\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time + u * v * 20.0) * 0.5 + 0.5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 30000, + "mode": "POINTS", + "sound": "https://soundcloud.com/home-2001/resonance", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.0);\n float v = y / (across - 1.0);\n \n float xoff = 0.0; //sin(time + y * 0.2) * 0.1;\n float yoff = 0.0; //sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2.0 - 1.0 + xoff;\n float vy = v * 2.0 - 1.0 + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n float su = abs(u - 0.5) * 2.0;\n float sv = abs(v - 0.5) * 2.0;\n float au = abs(atan(su, sv)) / PI;\n float av = length(vec2(su, sv));\n float snd = texture2D(sound, vec2(au * 0.125, av * 0.25)).a;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.0; //sin(time + x * y * 0.02) * 5.0;\n \n gl_PointSize = pow(snd / 1.1 + 0.2, 5.0) * 30.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float pump = step(0.8, snd);\n float hue = u * .1 + snd * 0.2 + time * 0.1; //sin(time + v * 20.0) * 0.05;\n float sat = mix(0.0, 1.0, pump);\n float val = mix(0.1, pow(snd + 0.2, 5.0), pump); //sin(time + u * v * 20.0) * 0.5 + 0.5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-lfccmty0e7bjkme39-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zB3fsZSeqTdYCbzGZ/art.json b/art/zB3fsZSeqTdYCbzGZ/art.json index 51b200f8..e7235741 100644 --- a/art/zB3fsZSeqTdYCbzGZ/art.json +++ b/art/zB3fsZSeqTdYCbzGZ/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "athega", "avatarUrl": "https://secure.gravatar.com/avatar/ac866057ea99c21292a071d08fadd152?default=retro&size=200", - "settings": "{\"num\":1914,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/mickenilsson/ut-ni-on\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// mats\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n#define PI radians(180.0)\\nvoid main() {\\n\\tfloat down = floor(sqrt(vertexCount));\\n \\tfloat across = floor(vertexCount/ down);\\n \\n\\tfloat x = mod(vertexId, across);\\n\\tfloat y = floor(vertexId / across);\\n\\n \\tfloat u = x / (across - 1.);\\n \\tfloat v = y / (across - 1.);\\n\\n \\tfloat xoff = sin(time + y * .2) * 0.1;\\n \\tfloat yoff = sin(time + x * .3) * 0.2;\\n\\n \\t\\n \\tfloat ux = u * 2. - 1. + xoff;\\n \\tfloat vy = v * 2. - 1. + yoff;\\n \\n\\tvec2 xy = vec2(ux,vy) * 1.3;\\n \\n\\n float sv = abs(v - 0.5) * 2.;\\n \\tfloat su = abs(u - 0.5) * 2.;\\n \\tfloat au = abs(atan(su,sv)) / PI;\\n \\tfloat av = length(vec2(su, sv));\\n\\n\\tfloat snd = texture2D(sound, vec2(su * .125, sv * .25)).a;\\n \\t\\n \\tgl_Position = vec4(xy, 0, 1);\\n \\n \\tfloat soff = sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = snd * 30. + soff;\\n gl_PointSize *= 20. /across;\\n gl_PointSize *= resolution.x /600.;\\n\\n \\tfloat pump= step(0.8, snd);\\n \\tfloat hue = u * .1 + snd * 0.2 + time; // u * .1 + sin(time + v * 20.) * 0.05;\\n \\tfloat sat = mix(0., 1., pump); // mix(1., -10., av);\\n \\tfloat val = pow(snd + 0.2, 5.); // 1.; // sin(time + v * u *20.0) * .5 + .5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\\n \\n}\"}", + "settings": { + "num": 1914, + "mode": "POINTS", + "sound": "https://soundcloud.com/mickenilsson/ut-ni-on", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// mats\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n#define PI radians(180.0)\nvoid main() {\n\tfloat down = floor(sqrt(vertexCount));\n \tfloat across = floor(vertexCount/ down);\n \n\tfloat x = mod(vertexId, across);\n\tfloat y = floor(vertexId / across);\n\n \tfloat u = x / (across - 1.);\n \tfloat v = y / (across - 1.);\n\n \tfloat xoff = sin(time + y * .2) * 0.1;\n \tfloat yoff = sin(time + x * .3) * 0.2;\n\n \t\n \tfloat ux = u * 2. - 1. + xoff;\n \tfloat vy = v * 2. - 1. + yoff;\n \n\tvec2 xy = vec2(ux,vy) * 1.3;\n \n\n float sv = abs(v - 0.5) * 2.;\n \tfloat su = abs(u - 0.5) * 2.;\n \tfloat au = abs(atan(su,sv)) / PI;\n \tfloat av = length(vec2(su, sv));\n\n\tfloat snd = texture2D(sound, vec2(su * .125, sv * .25)).a;\n \t\n \tgl_Position = vec4(xy, 0, 1);\n \n \tfloat soff = sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = snd * 30. + soff;\n gl_PointSize *= 20. /across;\n gl_PointSize *= resolution.x /600.;\n\n \tfloat pump= step(0.8, snd);\n \tfloat hue = u * .1 + snd * 0.2 + time; // u * .1 + sin(time + v * 20.) * 0.05;\n \tfloat sat = mix(0., 1., pump); // mix(1., -10., av);\n \tfloat val = pow(snd + 0.2, 5.); // 1.; // sin(time + v * u *20.0) * .5 + .5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)),1);\n \n}" + }, "screenshotURL": "data/images/images-1maml5lww0hiuzztq-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zBAYmes3sMdFCHEcM/art.json b/art/zBAYmes3sMdFCHEcM/art.json index 1460dd19..035dac6e 100644 --- a/art/zBAYmes3sMdFCHEcM/art.json +++ b/art/zBAYmes3sMdFCHEcM/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "zug", "avatarUrl": "https://lh3.googleusercontent.com/-ic9UqwOeGYY/AAAAAAAAAAI/AAAAAAAAABU/vJK2D-kzm0k/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/ellen-allien/ellen-allien-butterfly\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLES\\n\\n\\n#define parameter0 0.//KParameter0 0.>>3.\\n#define parameter1 2.//KParameter1 0.1>>3.\\n#define parameter2 1.//KParameter2 -1.>>1.\\n#define parameter3 -0.1//KParameter3 -0.5>2.\\n#define parameter4 1.3//KParameter4 0.5>>2.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n#define KP0 1.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(2.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, tan(1.-c), 0,\\n 0, c, 1, 0,\\n 0, 0, c, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1.1, 0, 0, 0,\\n 0, 1, 0, -0.2,\\n 0, 0.3, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, -0.3,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov)-(0.93);\\n float rangeInv = f / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0.2, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1.1,\\n 1, 0.1, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][1], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[0][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[2], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 2, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[1][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0.0005 *mouse.x,\\n yAxis, 0.0005 *mouse.y,\\n zAxis, -0.0,\\n eye, 1.21 * KP0 );\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 - b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 * a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 / b01 + a22 - b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 1,\\n yAxis, 2,\\n zAxis, 1,\\n -dot(xAxis, eye), -dot(yAxis, eye), dot(zAxis, eye), .1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 15.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 2.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 1.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 2. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 4.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI *1.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 1.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (.0-12.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.3)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.1* parameter4;\\n v += noise(p*1.0)*.15;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v *0.023));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\nreturn vec3(sin(-t), sin(t * 10.8), sin(t * 0.6)); return vec3( mod(t, 2.) * 0.101, 0, mod(t, 441.1));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id *1.199),\\n sin(id * .43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 0.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 1.);\\n float numStars = floor(vertexCount / 1.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 1.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n \\n gl_PointSize = 1.;\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n float t = vertexId;\\n vec3 p = normalize(vec3(\\n hash(t),\\n hash(t * 1.71),\\n hash(t * 12.39)\\n ) * 2. - 1.);\\n float v = vertexId / vertexCount;\\n p *= fract(time * 0.4 * v);\\n float sz = 100.;\\n pos = vec3(p * sz);\\n float hue = hash(vertexId * 0.123) * 1.2;\\n float sat = mix(.5, 1., mod(floor(time * 6. + v), 2.));\\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 0. + length(p));\\n// color.rgb *= color.a;\\n gl_PointSize = (0.1 - length(p)) * sz * 0.1;\\n \\n \\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n \\n float id = mod(vertexId, 1.);\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.);\\n \\n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\\n vec3 cnormal = vec3(0,0,-1);\\n \\n float cubeId = floor(vertexId / 1.);\\n float numCubes = floor(vertexCount / .5);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 1164.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n t = vec3(ca, cd, ce);\\n t = normalize(t);// * hash(cubeId * 0.413);\\n \\n \\n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\\n\\n float pump = step(1.7, s3+s1);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\\n mat *= uniformScale(2.);\\n #else\\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n float hue = time * .03 + mix(1., 1.1, pump);\\n abs(ca * cd) * 2.;\\n hue = time * .3 + (s1 + s2 + s3) / 6.;\\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\\n float val = mix(.25, 0.75, s1 * s2 * s3);\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 1.4, -1));\\n vec3 lightPos = vec3(500, 1000, -200);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = abs(dot(n, surfaceToLight)) + 0.2;\\n float specular = clamp(pow(abs(dot(n, halfVector)), 22.), 0., 1.);\\n \\n color = vec4(tcolor * (dot(n, lightDir) * 1.5 + 0.5), 11); \\n color = vec4(tcolor * light + vec3(specular), 2.3); \\n \\n color.a = mix(1., 15., pump);\\n color.rgb *= color.a;\\n \\n \\n gl_PointSize = 2.5 + (pow(s1, 1.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\\n}\\n\\nvoid main() {\\n float id = vertexId+1.;\\n const float numCubePoints = 190000.0;\\n const float numSunPoints = 11100.;//1000.0;\\n \\n mat4 pmat = persp(radians(120.0), resolution.x / resolution.y, 011.91,630.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n \\n float sp = time * 2.05* parameter0;\\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 200.00);\\n vec3 target = vec3(mod(11.1/time, 3.0));\\n vec3 up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (id < numSunPoints) {\\n sun(id, numSunPoints, -2.5, cmat, vmat, pos, color);\\n } else {\\n id -= numSunPoints\\n +3.;\\n if (id < numCubePoints) {\\n cube(id, vertexCount, -1., cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, 2., cmat, pos, color);\\n }\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos*3., sin(1.11*-time)+1.);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * 1.5 + 3.5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/ellen-allien/ellen-allien-butterfly", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLES\n\n\n#define parameter0 0.//KParameter0 0.>>3.\n#define parameter1 2.//KParameter1 0.1>>3.\n#define parameter2 1.//KParameter2 -1.>>1.\n#define parameter3 -0.1//KParameter3 -0.5>2.\n#define parameter4 1.3//KParameter4 0.5>>2.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n#define KP0 1.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(2.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, tan(1.-c), 0,\n 0, c, 1, 0,\n 0, 0, c, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1.1, 0, 0, 0,\n 0, 1, 0, -0.2,\n 0, 0.3, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, -0.3,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov)-(0.93);\n float rangeInv = f / (zNear - zFar);\n\n return mat4(\n f / aspect, 0.2, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1.1,\n 1, 0.1, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][1], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[0][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[2], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 2, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[1][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0.0005 *mouse.x,\n yAxis, 0.0005 *mouse.y,\n zAxis, -0.0,\n eye, 1.21 * KP0 );\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 - b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 * a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 / b01 + a22 - b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 1,\n yAxis, 2,\n zAxis, 1,\n -dot(xAxis, eye), -dot(yAxis, eye), dot(zAxis, eye), .1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 15.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 2.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 1.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 2. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 4.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI *1.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 1.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (.0-12.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.3)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,2.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.1* parameter4;\n v += noise(p*1.0)*.15;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v *0.023));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\nreturn vec3(sin(-t), sin(t * 10.8), sin(t * 0.6)); return vec3( mod(t, 2.) * 0.101, 0, mod(t, 441.1));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id *1.199),\n sin(id * .43),\n sin(id * 1.57));\n}\n\nconst float expand = 0.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 1.);\n float numStars = floor(vertexCount / 1.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 1.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n \n gl_PointSize = 1.;\n \n color = vec4(h, h, h, 1);\n}\n\nvoid sun(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n float t = vertexId;\n vec3 p = normalize(vec3(\n hash(t),\n hash(t * 1.71),\n hash(t * 12.39)\n ) * 2. - 1.);\n float v = vertexId / vertexCount;\n p *= fract(time * 0.4 * v);\n float sz = 100.;\n pos = vec3(p * sz);\n float hue = hash(vertexId * 0.123) * 1.2;\n float sat = mix(.5, 1., mod(floor(time * 6. + v), 2.));\n float val = mix(.9, 1., mod(tan(time * (mouse.x*10.2) * 60. + v), 2.));\n color = vec4(hsv2rgb(vec3(hue, sat, val)), 0. + length(p));\n// color.rgb *= color.a;\n gl_PointSize = (0.1 - length(p)) * sz * 0.1;\n \n \n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n \n float id = mod(vertexId, 1.);\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 3.);\n \n vec3 cpos = vec3(ux, vy, 0) * 3. - 1.;\n vec3 cnormal = vec3(0,0,-1);\n \n float cubeId = floor(vertexId / 1.);\n float numCubes = floor(vertexCount / .5);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 1164.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n t = vec3(ca, cd, ce);\n t = normalize(t);// * hash(cubeId * 0.413);\n \n \n float s1 = texture2D(sound, vec2(mix(0.01, 2.1, abs(t.x)), abs(t.x) * 1.)).a;\n float s2 = texture2D(sound, vec2(mix(0.01, 0.001, abs(t.y+t.x)), (1. - abs(t.y)) * 1.)).a;\n float s3 = texture2D(sound, vec2(mix(0.01, 0.1, abs(t.z+2.)), abs(t.z) * 1.)).a;\n\n float pump = step(1.7, s3+s1);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0 );\n mat *= uniformScale(2.);\n #else\n mat *= lookAt(t * dim * .5, vec3(0), vec3(0, 1, 0));\n //mat *= trans(t * dim * .5 + normalize(t) * pow(s, 5.) * 80.);\n //mat *= rotX(time * 1. + hash(cubeId * 0.717));\n //mat *= rotZ(time * 1.1 + hash(cubeId * 0.911));\n mat *= uniformScale(mix(8., 8. + pump * 0., pow(s1, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n float hue = time * .03 + mix(1., 1.1, pump);\n abs(ca * cd) * 2.;\n hue = time * .3 + (s1 + s2 + s3) / 6.;\n float sat = 1.;//pow(max(s1, max(s2, s3)), 50.);\n float val = mix(.25, 0.75, s1 * s2 * s3);\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 1.4, -1));\n vec3 lightPos = vec3(500, 1000, -200);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = abs(dot(n, surfaceToLight)) + 0.2;\n float specular = clamp(pow(abs(dot(n, halfVector)), 22.), 0., 1.);\n \n color = vec4(tcolor * (dot(n, lightDir) * 1.5 + 0.5), 11); \n color = vec4(tcolor * light + vec3(specular), 2.3); \n \n color.a = mix(1., 15., pump);\n color.rgb *= color.a;\n \n \n gl_PointSize = 2.5 + (pow(s1, 1.) + pow(s2, 5.) + pow(s3, 5.)) / 3.;\n}\n\nvoid main() {\n float id = vertexId+1.;\n const float numCubePoints = 190000.0;\n const float numSunPoints = 11100.;//1000.0;\n \n mat4 pmat = persp(radians(120.0), resolution.x / resolution.y, 011.91,630.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n \n float sp = time * 2.05* parameter0;\n vec3 eye = vec3(2000. * sin(sp), sin(sp * .82) * 1000. , cos(sp) * 200.00);\n vec3 target = vec3(mod(11.1/time, 3.0));\n vec3 up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (id < numSunPoints) {\n sun(id, numSunPoints, -2.5, cmat, vmat, pos, color);\n } else {\n id -= numSunPoints\n +3.;\n if (id < numCubePoints) {\n cube(id, vertexCount, -1., cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, 2., cmat, pos, color);\n }\n }\n \n gl_Position = pmat * vmat * vec4(pos*3., sin(1.11*-time)+1.);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * 1.5 + 3.5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 1., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-r6q25mnps7kj4cijt-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zBGJ6RhGK6EAJvuHL/art.json b/art/zBGJ6RhGK6EAJvuHL/art.json index c669286b..a0595197 100644 --- a/art/zBGJ6RhGK6EAJvuHL/art.json +++ b/art/zBGJ6RhGK6EAJvuHL/art.json @@ -11,7 +11,19 @@ "origId": "xxhTPvXjTWPCPLM2v", "name": "Knotted Candy", "username": "-anon-", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.10196078431372549,0.19607843137254902,0.25098039215686274,1],\"shader\":\"// Knotted Candy - @P_Malin\\n\\n// Some different shapes...\\n\\n#define SHAPE_TWO_BRAIDS\\n//#define SHAPE_THREE_BRAIDS\\n//#define SHAPE_TORUS\\n//#define SHAPE_MOBIUS\\n\\n\\n//#define RIBBON \\n\\n#ifdef SHAPE_TWO_BRAIDS \\n float twist = 3.0;\\n float radius1 = 0.25;\\n float radius2 = 3.0;\\n float radius3 = 0.4;\\n \\n float waves = 4.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_THREE_BRAIDS)\\n float twist = 5.0;\\n float radius1 = 0.15;\\n float radius2 = 3.0;\\n float radius3 = 0.5;\\n \\n float waves = 4.0;\\n float braids = 3.0;\\n\\n vec2 vShapeDim = vec2( 24.0, 192.0 );\\n#elif defined(SHAPE_TORUS)\\n // Torus\\n float twist = 0.0;\\n float radius1 = 1.0;\\n float radius2 = 3.0;\\n float radius3 = 0.0;\\n \\n float waves = 3.0;\\n float braids = 2.0;\\n\\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#elif defined(SHAPE_MOBIUS)\\n // Torus\\n float twist = 2.0;\\n float radius1 = 1.0;\\n float radius2 = 2.0;\\n float radius3 = 0.0;\\n \\n float waves = 0.0;\\n float braids = 2.0;\\n\\n #define RIBBON \\n vec2 vShapeDim = vec2( 32.0, 256.0 );\\n#else\\n#error INVALID SHAPE DEFINE\\n#endif\\n\\n// Inputs:\\n// vertexId\\n// time\\n// resolution\\n\\n// Outputs:\\n// gl_Position\\n// v_color\\n\\n#define PI radians( 180.0 )\\n\\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n float quadVertexIndex = triVertexIndex;\\n if ( twoTriVertexIndex >= 3.0 )\\n {\\n quadVertexIndex ++;\\n }\\n \\n if ( quadVertexIndex < 0.5 )\\n {\\n x = 0.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 1.5 )\\n {\\n x = 1.0;\\n y = 0.0;\\n }\\n else if ( quadVertexIndex < 2.5 )\\n {\\n x = 0.0;\\n y = 1.0;\\n }\\n else if ( quadVertexIndex < 3.5 )\\n {\\n x = 1.0;\\n y = 1.0;\\n }\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\\n{\\n float s = sin(fAngle);\\n float c = cos(fAngle);\\n \\n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\\n \\n return vResult;\\n}\\n\\nstruct SurfaceInfo\\n{\\n\\tvec3 vPos;\\n \\tvec3 vNormal;\\n};\\n\\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\\n{\\n\\tvPos += vTranslation;\\n}\\n \\nvoid RotateX( float theta, inout vec3 vPos )\\n{\\n \\tvPos.yz = Rotate( vPos.yz, theta );\\n}\\n\\nvoid RotateY( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xz = Rotate( vPos.xz, theta );\\n}\\n\\nvoid RotateZ( float theta, inout vec3 vPos )\\n{\\n \\tvPos.xy = Rotate( vPos.xy, theta );\\n}\\n\\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\\n{\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\\n \\n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\\n\\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\\n \\n vDiffuse += NdotL * vLightColor;\\n\\n float fPower = 80.0;\\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\\n}\\n\\nvec3 GetSkyColor( vec3 vDir )\\n{\\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\\n}\\n\\n\\n\\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\\n{ \\n vec3 vDiffuseLight = vec3(0.0);\\n vec3 vSpecLight = vec3(0.0);\\n\\n // use background color\\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\\n vDiffuseLight += vAmbient;\\n vSpecLight += vAmbient;\\n\\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\\n\\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\\n \\n // viewer is at origin\\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\\n \\n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\\n vec3 vR0 = vec3(0.04);\\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\\n \\n \\n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\\n \\n return vColor;\\n}\\n\\nvec3 PostProcess( vec3 vColor )\\n{\\n float kExposure = 1.0;\\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\\n\\n vColor = pow( vColor, vec3(1.0 / 2.2) );\\n\\n return vColor;\\n}\\n\\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\\n{\\n\\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\\n\\t\\n\\tfloat fDist = dot(vOffset, vOffset);\\n\\t\\n\\tconst float kStrength = 0.95;\\n\\tconst float kPower = 1.5;\\n\\n\\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\\n}\\n\\nvoid ProcessBackdrop( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId );\\n\\n vec2 vDim = vec2( 8.0, 8.0 );\\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vDim.x);\\n quadTile.y = floor(quadId / vDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vDim);\\n \\n \\n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\\n\\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\\n vPos.y *= resolution.x / resolution.y;\\n \\n vec3 vColor = GetSkyColor( normalize( vPos ) );\\n \\n vColor = ApplyVignetting( vUV.xy, vColor );\\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4( vColor, 1.0 );\\n}\\n\\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\\n{ \\n vPos += vec3(0.0, radius1, 0.0);\\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\\n \\n#ifdef RIBBON \\n vPos.y *= 0.1;\\n#endif \\n \\n vPos += vec3(-radius3, 0.0, 0.0);\\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\\n\\n vPos += vec3(-radius2, 0.0, 0.0); \\n \\n RotateY( vUV.y * PI * 2.0, vPos );\\n \\n // animated spin\\n RotateY( t * 0.5, vPos ); \\n RotateX( t, vPos ); \\n\\n vPos += vec3(0.0, 0.0, 30.0); \\n}\\n\\nvoid ProcessShape( float vertexIndex )\\n{\\n float quadX, quadY, quadId;\\n \\n GetQuadInfo( vertexId, quadX, quadY, quadId ); \\n \\n vec2 vUV;\\n \\n vec2 quadTile;\\n quadTile.x = mod(quadId, vShapeDim.x);\\n quadTile.y = floor(quadId / vShapeDim.x);\\n \\n vUV.x = quadX + quadTile.x;\\n vUV.y = quadY + quadTile.y;\\n\\n vUV = vUV * (1.0 / vShapeDim); \\n\\n vec3 vPos = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPos, vUV, time );\\n\\n // Lazy normal calculation\\n \\n float fDelta = 0.0021;\\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\\n\\n SurfaceInfo surfaceInfo; \\n surfaceInfo.vPos = vPos;\\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\\n\\n vec3 vViewPos = surfaceInfo.vPos;\\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\\n vec2 vScreenPos = vViewPos.xy * vFov;\\n \\n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\\n\\n float stripes = 4.0;\\n vec3 vAlbedo = vec3(1.0);\\n\\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\\n \\n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \\n\\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \\n \\n vColor = PostProcess( vColor );\\n \\n v_color = vec4(vColor, 1.0);\\n}\\n\\nvoid main() \\n{ \\n\\tif( vertexId < 64.0 * 6.0 )\\n {\\n\\t\\tProcessBackdrop(vertexId); \\n }\\n else\\n {\\n\\t\\tProcessShape(vertexId - 64.0 * 6.0);\\n }\\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.10196078431372549, + 0.19607843137254902, + 0.25098039215686274, + 1 + ], + "shader": "// Knotted Candy - @P_Malin\n\n// Some different shapes...\n\n#define SHAPE_TWO_BRAIDS\n//#define SHAPE_THREE_BRAIDS\n//#define SHAPE_TORUS\n//#define SHAPE_MOBIUS\n\n\n//#define RIBBON \n\n#ifdef SHAPE_TWO_BRAIDS \n float twist = 3.0;\n float radius1 = 0.25;\n float radius2 = 3.0;\n float radius3 = 0.4;\n \n float waves = 4.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_THREE_BRAIDS)\n float twist = 5.0;\n float radius1 = 0.15;\n float radius2 = 3.0;\n float radius3 = 0.5;\n \n float waves = 4.0;\n float braids = 3.0;\n\n vec2 vShapeDim = vec2( 24.0, 192.0 );\n#elif defined(SHAPE_TORUS)\n // Torus\n float twist = 0.0;\n float radius1 = 1.0;\n float radius2 = 3.0;\n float radius3 = 0.0;\n \n float waves = 3.0;\n float braids = 2.0;\n\n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#elif defined(SHAPE_MOBIUS)\n // Torus\n float twist = 2.0;\n float radius1 = 1.0;\n float radius2 = 2.0;\n float radius3 = 0.0;\n \n float waves = 0.0;\n float braids = 2.0;\n\n #define RIBBON \n vec2 vShapeDim = vec2( 32.0, 256.0 );\n#else\n#error INVALID SHAPE DEFINE\n#endif\n\n// Inputs:\n// vertexId\n// time\n// resolution\n\n// Outputs:\n// gl_Position\n// v_color\n\n#define PI radians( 180.0 )\n\nvoid GetQuadInfo( const float vertexIndex, out float x, out float y, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n float quadVertexIndex = triVertexIndex;\n if ( twoTriVertexIndex >= 3.0 )\n {\n quadVertexIndex ++;\n }\n \n if ( quadVertexIndex < 0.5 )\n {\n x = 0.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 1.5 )\n {\n x = 1.0;\n y = 0.0;\n }\n else if ( quadVertexIndex < 2.5 )\n {\n x = 0.0;\n y = 1.0;\n }\n else if ( quadVertexIndex < 3.5 )\n {\n x = 1.0;\n y = 1.0;\n }\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\nvec2 Rotate( const in vec2 vPos, const in float fAngle )\n{\n float s = sin(fAngle);\n float c = cos(fAngle);\n \n vec2 vResult = vec2( c * vPos.x + s * vPos.y, -s * vPos.x + c * vPos.y);\n \n return vResult;\n}\n\nstruct SurfaceInfo\n{\n\tvec3 vPos;\n \tvec3 vNormal;\n};\n\nvoid Translate( vec3 vTranslation, inout vec3 vPos )\n{\n\tvPos += vTranslation;\n}\n \nvoid RotateX( float theta, inout vec3 vPos )\n{\n \tvPos.yz = Rotate( vPos.yz, theta );\n}\n\nvoid RotateY( float theta, inout vec3 vPos )\n{\n \tvPos.xz = Rotate( vPos.xz, theta );\n}\n\nvoid RotateZ( float theta, inout vec3 vPos )\n{\n \tvPos.xy = Rotate( vPos.xy, theta );\n}\n\nvoid AddPointLight( vec3 vLightPos, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vLightDir = normalize(vLightPos - surfaceInfo.vPos);\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvoid AddDirectionalLight( vec3 vLightDir, vec3 vLightColor, const SurfaceInfo surfaceInfo, inout vec3 vDiffuse, inout vec3 vSpecular )\n{\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float NdotL = max( 0.0, dot( vLightDir, surfaceInfo.vNormal ) );\n \n vec3 vHalfAngle = normalize( vViewDir + vLightDir );\n\n float NdotH = max( 0.0, dot( vHalfAngle, surfaceInfo.vNormal ) );\n \n vDiffuse += NdotL * vLightColor;\n\n float fPower = 80.0;\n vSpecular += pow( NdotH, fPower ) * (fPower * 8.0 * PI) * NdotL * vLightColor;\n}\n\nvec3 GetSkyColor( vec3 vDir )\n{\n return mix( vec3(0.01, 0.1, 0.4), vec3(0.2, 0.5, 0.6) * 5.0, vDir.y * 0.5 + 0.5 );\n}\n\n\n\nvec3 LightSurface( const SurfaceInfo surfaceInfo, const vec3 vAlbedo )\n{ \n vec3 vDiffuseLight = vec3(0.0);\n vec3 vSpecLight = vec3(0.0);\n\n // use background color\n vec3 vAmbient = GetSkyColor( surfaceInfo.vNormal );\n vDiffuseLight += vAmbient;\n vSpecLight += vAmbient;\n\n AddPointLight( vec3(3.0, 2.0, 30.0), vec3( 0.5, 1.0, 1.0), surfaceInfo, vDiffuseLight, vSpecLight );\n AddDirectionalLight( normalize(vec3(0.0, 1.0, 0.0)), vec3( 3.0, 2.9, 1.5), surfaceInfo, vDiffuseLight, vSpecLight );\n\n //AddDirectionalLight( normalize(vec3(0.0, -1.0, 0.0)), vAmbient * 0.1, surfaceInfo, vDiffuseLight, vSpecLight );\n \n // viewer is at origin\n vec3 vViewDir = normalize(-surfaceInfo.vPos);\n \n float fNdotD = clamp(dot(surfaceInfo.vNormal, vViewDir), 0.0, 1.0);\n vec3 vR0 = vec3(0.04);\n vec3 vFresnel = vR0 + (1.0 - vR0) * pow(1.0 - fNdotD, 5.0);\n \n \n vec3 vColor = mix( vDiffuseLight * vAlbedo, vSpecLight, vFresnel );\n \n return vColor;\n}\n\nvec3 PostProcess( vec3 vColor )\n{\n float kExposure = 1.0;\n vColor = vec3(1.0) - exp2( vColor * -kExposure );\n\n vColor = pow( vColor, vec3(1.0 / 2.2) );\n\n return vColor;\n}\n\nvec3 ApplyVignetting( const in vec2 vUV, const in vec3 vInput )\n{\n\tvec2 vOffset = (vUV - 0.5) * sqrt(2.0);\n\t\n\tfloat fDist = dot(vOffset, vOffset);\n\t\n\tconst float kStrength = 0.95;\n\tconst float kPower = 1.5;\n\n\treturn vInput * ((1.0 - kStrength) + kStrength * pow(1.0 - fDist, kPower));\n}\n\nvoid ProcessBackdrop( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId );\n\n vec2 vDim = vec2( 8.0, 8.0 );\n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vDim.x);\n quadTile.y = floor(quadId / vDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vDim);\n \n \n gl_Position = vec4( vUV.xy * 2.0 - 1.0, 0.0, 1.0 );\n\n vec3 vPos = vec3( vUV.xy * 2.0 - 1.0, 2.0 );\n vPos.y *= resolution.x / resolution.y;\n \n vec3 vColor = GetSkyColor( normalize( vPos ) );\n \n vColor = ApplyVignetting( vUV.xy, vColor );\n \n vColor = PostProcess( vColor );\n \n v_color = vec4( vColor, 1.0 );\n}\n\nvoid TransformPoint( inout vec3 vPos, vec2 vUV, float t )\n{ \n vPos += vec3(0.0, radius1, 0.0);\n RotateZ( vUV.x * PI * 2.0 + vUV.y * PI * 2.0 * twist, vPos );\n \n#ifdef RIBBON \n vPos.y *= 0.1;\n#endif \n \n vPos += vec3(-radius3, 0.0, 0.0);\n RotateZ( vUV.y * PI * 2.0 * (waves + 1.0 / braids), vPos );\n\n vPos += vec3(-radius2, 0.0, 0.0); \n \n RotateY( vUV.y * PI * 2.0, vPos );\n \n // animated spin\n RotateY( t * 0.5, vPos ); \n RotateX( t, vPos ); \n\n vPos += vec3(0.0, 0.0, 30.0); \n}\n\nvoid ProcessShape( float vertexIndex )\n{\n float quadX, quadY, quadId;\n \n GetQuadInfo( vertexId, quadX, quadY, quadId ); \n \n vec2 vUV;\n \n vec2 quadTile;\n quadTile.x = mod(quadId, vShapeDim.x);\n quadTile.y = floor(quadId / vShapeDim.x);\n \n vUV.x = quadX + quadTile.x;\n vUV.y = quadY + quadTile.y;\n\n vUV = vUV * (1.0 / vShapeDim); \n\n vec3 vPos = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPos, vUV, time );\n\n // Lazy normal calculation\n \n float fDelta = 0.0021;\n vec3 vPosdU = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdU, vUV + vec2(fDelta, 0.0), time );\n vec3 vPosdV = vec3(0.0, 0.0, 0.0);\n TransformPoint( vPosdV, vUV + vec2(0.0, fDelta), time );\n\n SurfaceInfo surfaceInfo; \n surfaceInfo.vPos = vPos;\n surfaceInfo.vNormal = normalize(cross(vPosdV - vPos, vPosdU - vPos));\n\n vec3 vViewPos = surfaceInfo.vPos;\n vec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * 4.0;\n vec2 vScreenPos = vViewPos.xy * vFov;\n \n gl_Position = vec4( vScreenPos.xy, (1.0 / -vViewPos.z), vViewPos.z );\n\n float stripes = 4.0;\n vec3 vAlbedo = vec3(1.0);\n\n float fTile = step( 0.5, fract( (quadTile.x * stripes / vShapeDim.x) ));\n vAlbedo = mix( vec3(1.0, 0.01, 0.01), vec3(0.8, 0.8, 0.8), fTile );\n \n vec3 vColor = LightSurface( surfaceInfo, vAlbedo ); \n\n vColor = ApplyVignetting( (vScreenPos.xy / vViewPos.z) * 0.5 + 0.5, vColor ); \n \n vColor = PostProcess( vColor );\n \n v_color = vec4(vColor, 1.0);\n}\n\nvoid main() \n{ \n\tif( vertexId < 64.0 * 6.0 )\n {\n\t\tProcessBackdrop(vertexId); \n }\n else\n {\n\t\tProcessShape(vertexId - 64.0 * 6.0);\n }\n \n}\n" + }, "screenshotURL": "data/images/images-ff44ywavd9pekey1z-thumbnail.jpg", "views": { "$numberInt": "60" diff --git a/art/zFRiazFDjmFNzD8ia/art.json b/art/zFRiazFDjmFNzD8ia/art.json index e0a687cc..c317582b 100644 --- a/art/zFRiazFDjmFNzD8ia/art.json +++ b/art/zFRiazFDjmFNzD8ia/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":6525,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rot(vec3 axis, float angle) {\\n \\n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\\n axis = normalize(axis);\\n float s = sin(angle);\\n float c = cos(angle);\\n float oc = 1.0 - c;\\n \\n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\\n 0.0, 0.0, 0.0, 1.0);\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvoid main() {\\n \\n mat4 mr = rot(vec3(0.019, 0.2, atan(time * 10.0) +0.3), time);\\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + rotY(mod(time * 0.05,-1.0)) * 1.0 * vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 7.0; \\n\\n v_color = vec4(gl_Position.z,(vertexId / vertexCount),0.0,1.0);\\n}\"}", + "settings": { + "num": 6525, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rot(vec3 axis, float angle) {\n \n // source: https://gist.github.com/yiwenl/3f804e80d0930e34a0b33359259b556c\n axis = normalize(axis);\n float s = sin(angle);\n float c = cos(angle);\n float oc = 1.0 - c;\n \n return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,\n oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,\n oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,\n 0.0, 0.0, 0.0, 1.0);\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvoid main() {\n \n mat4 mr = rot(vec3(0.019, 0.2, atan(time * 10.0) +0.3), time);\n vec4 vertPos = mr *rotY(time*0.1) * vec4(SampleSpherePos(vertexId, vertexCount), 1.0) + rotY(mod(time * 0.05,-1.0)) * 1.0 * vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 7.0; \n\n v_color = vec4(gl_Position.z,(vertexId / vertexCount),0.0,1.0);\n}" + }, "screenshotURL": "data/images/images-qj85ud6swzl2jpmhv-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zFsctippt7CPRwvWh/art.json b/art/zFsctippt7CPRwvWh/art.json index 82bf1890..4ba5b3dc 100644 --- a/art/zFsctippt7CPRwvWh/art.json +++ b/art/zFsctippt7CPRwvWh/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":73803,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/xlr8r/gazelle-twin-belly-of-the\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(120.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0.1, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-0.5, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians ) * 2.;\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, s, 0.2, 0, \\n s, c, 1, 0,\\n 0.2, 0, 1, 0,\\n 0, s, 0, 0.1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 0, 0, -1,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 1, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0.3, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0.1, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 5.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 11.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n v += noise(p*2.)*.25;\\n v += noise(p*14.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvoid main() {\\n float pointId = vertexId; \\n const float numGroups = 600.;\\n vec3 pos;\\n vec3 normal;\\n getCubePoint(pointId, pos, normal);\\n float cId = floor(pointId / 36.);\\n float groupId = mod(cId, numGroups);\\n float numCubes = floor(vertexCount / 36.);\\n float numPerGroup = floor(numCubes / numGroups);\\n float cubeId = floor(cId / numGroups);\\n float down = floor(sqrt(numPerGroup));\\n float across = floor(numPerGroup / down);\\n float cu = cubeId / (numPerGroup - 1.);\\n float gv = groupId / numGroups;\\n \\n float cv = cu *2. + gv *2.06 * time * .13 + floor(time);\\n vec3 p2 = (vec3(\\n crv(cv),\\n crv(cv * .13),\\n crv(cv * .6)\\n )) * 2. - 1.;\\n float cv2 = cv + 0.01;\\n vec3 p3 = (vec3(\\n crv(cv2),\\n crv(cv2 + .23),\\n crv(cv2 * 1.6)\\n )) * 2. - 1.;\\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.1, 0.5, gv),\\n cu * 0.4)\\n ).a;\\n \\n float tm = time * 2.1;\\n mat4 mat = persp(radians(45.0), resolution.x / resolution.y, 0.21, 666.0);\\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 + 1., sin(tm) * 1.);\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0.0 - gv);\\n \\n mat4 p4 = lookAt(p2 * 2., p3 * (tm * 2.), tm - gv * up);\\n \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(gv);\\n// \\n mat *= trans(p2 * 4.5);\\n mat *= p4;\\n mat *= uniformScale(mix(0.1, 0.301, pow(s + gv + .2, 10.)));\\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\\n \\n \\n gl_Position = mat * vec4(pos, 1);\\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\\n \\n vec3 lightDir = normalize(vec3(1.3, 0.4, -1));\\n\\n float hue = gv * .1 + .9 + time * gv + .1;\\n float sat = mix(0., 1.5, pow(s + .3, 15.));\\n\\n float val = pow(s + .6, 5.);\\n vec3 color = hsv2rgb(vec3(hue, sat, val));\\n v_color = vec4(color * (dot(n, lightDir) * 0.2 + 0.2 * n), ( - 2.2 , \\n- 3. * color -val ));\\n}\\n\"}", + "settings": { + "num": 73803, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/xlr8r/gazelle-twin-belly-of-the", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(120.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.2, 1.0));\n vec4 K = vec4((.3 * c.y) , 2.0 /(c.x - 3.0), 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 2.8 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, (c.z * 0.02), 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0.1, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-0.5, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians ) * 2.;\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, s, 0.2, 0, \n s, c, 1, 0,\n 0.2, 0, 1, 0,\n 0, s, 0, 0.1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 0, 0, -1,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 1, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0.3, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0.1, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 5.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 11.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n v += noise(p*2.)*.25;\n v += noise(p*14.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 14.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvoid main() {\n float pointId = vertexId; \n const float numGroups = 600.;\n vec3 pos;\n vec3 normal;\n getCubePoint(pointId, pos, normal);\n float cId = floor(pointId / 36.);\n float groupId = mod(cId, numGroups);\n float numCubes = floor(vertexCount / 36.);\n float numPerGroup = floor(numCubes / numGroups);\n float cubeId = floor(cId / numGroups);\n float down = floor(sqrt(numPerGroup));\n float across = floor(numPerGroup / down);\n float cu = cubeId / (numPerGroup - 1.);\n float gv = groupId / numGroups;\n \n float cv = cu *2. + gv *2.06 * time * .13 + floor(time);\n vec3 p2 = (vec3(\n crv(cv),\n crv(cv * .13),\n crv(cv * .6)\n )) * 2. - 1.;\n float cv2 = cv + 0.01;\n vec3 p3 = (vec3(\n crv(cv2),\n crv(cv2 + .23),\n crv(cv2 * 1.6)\n )) * 2. - 1.;\n \n \n float s = texture2D(sound, vec2(\n mix(0.1, 0.5, gv),\n cu * 0.4)\n ).a;\n \n float tm = time * 2.1;\n mat4 mat = persp(radians(45.0), resolution.x / resolution.y, 0.21, 666.0);\n vec3 eye = vec3(cos(tm) * 1., sin(tm * 1.9) * .1 + 1., sin(tm) * 1.);\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0.0 - gv);\n \n mat4 p4 = lookAt(p2 * 2., p3 * (tm * 2.), tm - gv * up);\n \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(gv);\n// \n mat *= trans(p2 * 4.5);\n mat *= p4;\n mat *= uniformScale(mix(0.1, 0.301, pow(s + gv + .2, 10.)));\n mat *= scale(vec3(1, 1, distance(p2, p3) * 1000.));\n \n \n gl_Position = mat * vec4(pos, 1);\n vec3 n = normalize((mat * vec4(normal, 0)).xyz);\n \n vec3 lightDir = normalize(vec3(1.3, 0.4, -1));\n\n float hue = gv * .1 + .9 + time * gv + .1;\n float sat = mix(0., 1.5, pow(s + .3, 15.));\n\n float val = pow(s + .6, 5.);\n vec3 color = hsv2rgb(vec3(hue, sat, val));\n v_color = vec4(color * (dot(n, lightDir) * 0.2 + 0.2 * n), ( - 2.2 , \n- 3. * color -val ));\n}\n" + }, "screenshotURL": "data/images/images-wmgb4w3al8oij4ebe-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zGGRYEyPC9E6CWEWD/art.json b/art/zGGRYEyPC9E6CWEWD/art.json index 182b2948..a26ffb2b 100644 --- a/art/zGGRYEyPC9E6CWEWD/art.json +++ b/art/zGGRYEyPC9E6CWEWD/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":4335,\"mode\":\"TRI_STRIP\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//KDrawmode=GL_TRIANGLE_FAN \\n#define parameter0 5.//KParameter0 -8.>>15.\\n#define parameter1 1.//KParameter1 0.1>>1.\\n#define parameter2 1.//KParameter2 0.>>1.\\n#define parameter3 4.//KParameter3 -4.5>>4.\\n#define parameter4 0.2//KParameter4 0.>>1.\\n#define parameter5 1.//KParameter5 0.>>3.\\n#define parameter6 1.//KParameter6 0.>>1.\\n#define parameter7 1.//KParameter7 0.>>1.\\n\\n\\n\\n\\n#define PI 3.14159\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n cos(i*4.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76)* i,\\n sin(i*.79553+2.1) +\\n tan(i*1.1311+2.1) +\\n abs(i*1.353-2.1) +\\n sin(i*.476/2.1) * cos(i * 3.0),\\n mod(i*4.5553, i *0.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*2.36*10.1)\\n\\t)* parameter3;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n tan(i*.553)*.9553 +\\n cos(i) +\\n cos(i*1.53)/1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*4.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*11.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n tan(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*3.2;\\n}\\n\\nvec3 hilbert(float s) {\\n\\t\\t vec3 p;\\n\\t\\t {\\n\\t\\t\\t float zi = mod(s, parameter0 *2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,3.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\t\\t p = vec3(xi,yi,zi);\\n\\t\\t }\\n\\tfloat n = 2. - parameter5;\\n\\t\\t for (int i = 1; i < 7; i++) {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,2.2 *parameter2);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\n\\t \\n\\tif (xi > .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z/parameter4;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < .5) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0)-parameter5);\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*510.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = sin(t- .5);\\n \\n vec3 colour = vec3( 0.0);\\n//vec3 colour = vec3(parameter6* .003)\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*0.2+parameter7, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n\\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/180.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,-22.);\\n}\"}", + "settings": { + "num": 4335, + "mode": "TRI_STRIP", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//KDrawmode=GL_TRIANGLE_FAN \n#define parameter0 5.//KParameter0 -8.>>15.\n#define parameter1 1.//KParameter1 0.1>>1.\n#define parameter2 1.//KParameter2 0.>>1.\n#define parameter3 4.//KParameter3 -4.5>>4.\n#define parameter4 0.2//KParameter4 0.>>1.\n#define parameter5 1.//KParameter5 0.>>3.\n#define parameter6 1.//KParameter6 0.>>1.\n#define parameter7 1.//KParameter7 0.>>1.\n\n\n\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n cos(i*4.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76)* i,\n sin(i*.79553+2.1) +\n tan(i*1.1311+2.1) +\n abs(i*1.353-2.1) +\n sin(i*.476/2.1) * cos(i * 3.0),\n mod(i*4.5553, i *0.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*2.36*10.1)\n\t)* parameter3;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n tan(i*.553)*.9553 +\n cos(i) +\n cos(i*1.53)/1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*4.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*11.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n tan(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*3.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s, parameter0 *2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,3.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2. - parameter5;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.2 *parameter2);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z/parameter4;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < .5) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0)-parameter5);\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*510.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = sin(t- .5);\n \n vec3 colour = vec3( 0.0);\n//vec3 colour = vec3(parameter6* .003)\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*0.2+parameter7, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n\n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/180.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,-22.);\n}" + }, "screenshotURL": "data/images/images-qxz9v9vqe2djeo16x-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zGqZP2vWAf3ByWFKk/art.json b/art/zGqZP2vWAf3ByWFKk/art.json index 3b7adfc3..a7b65ccc 100644 --- a/art/zGqZP2vWAf3ByWFKk/art.json +++ b/art/zGqZP2vWAf3ByWFKk/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":5000,\"mode\":\"LINES\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xxx) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\\n float offset = count * 0.02;\\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\\n float radius = 0.2 * pow(snd, 5.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = count * 0.0;\\n float innerRadius = count * 0.001;\\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\\n\\n float hue = (time * 0.01 + count * 1.001);\\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\\n}\"}", + "settings": { + "num": 5000, + "mode": "LINES", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xxx) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = mod(floor(vertexId / 2.0) + mod(vertexId, 2.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float snd = texture2D(sound, vec2(fract(count / 128.0), fract(count / 20000.0))).a;\n float offset = count * 0.02;\n float angle = point * PI * 2.0 / NUM_SEGMENTS + offset;\n float radius = 0.2 * pow(snd, 5.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = count * 0.0;\n float innerRadius = count * 0.001;\n float oC = cos(orbitAngle + time * 0.4 + count * 0.1) * innerRadius;\n float oS = sin(orbitAngle + time + count * 0.1) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.1, 0, 1);\n\n float hue = (time * 0.01 + count * 1.001);\n v_color = vec4(hsv2rgb(vec3(hue, 1, 1)), 1);\n}" + }, "screenshotURL": "data/images/images-ir899a0g2ct9xz9xa-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zHorsBAipg3PMpwaL/art.json b/art/zHorsBAipg3PMpwaL/art.json index b4397050..bbb4ee7f 100644 --- a/art/zHorsBAipg3PMpwaL/art.json +++ b/art/zHorsBAipg3PMpwaL/art.json @@ -27,7 +27,19 @@ "name": "Barnsley Fern", "private": false, "username": "P_Malin", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.42745098039215684,0.49019607843137253,0.5529411764705883,1],\"shader\":\"// Barnsley Fern - @P_Malin\\n// https://en.wikipedia.org/wiki/Barnsley_fern\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\nvoid main() \\n{ \\n \\tvec3 p = vec3( 0.01, 0.86, 0.93 ); // p = probability thresholds. Individual probabilities for each transform = 0.01, 0.85, 0.07, 0.07\\n \\n \\tvec3 vColor = vec3( 0.0 );\\n \\tvec2 vPos = vec2( 0.0 );\\n \\tfloat fRandomSeed = vertexId + time;\\n \\tfor ( int i=0; i<32; i++ )\\n { \\n\\t\\tfloat fSelection = hash( fRandomSeed );\\n \\tfRandomSeed += 12.3456;\\n \\n \\tif ( fSelection < p.x )\\n {\\n \\tvPos = vPos * mat2( 0.0, 0.0, 0.0, 0.16 ) + vec2( 0.0, 0.0 );\\n \\tvColor.r += 0.3;\\n }\\n \\telse if ( fSelection < p.y )\\n {\\n \\tfloat fRot = sin(time) * 0.01;\\n \\tvPos = vPos * mat2( 0.85, 0.04, -0.04, 0.85 ) * mat2( cos(fRot), sin(fRot), -sin(fRot), cos(fRot) ) + vec2( 0.0, 1.6 );\\n \\tvColor -= 0.005;\\n }\\n \\telse if ( fSelection < p.z )\\n {\\n \\tvPos = vPos * mat2( 0.20, -0.26, 0.23, 0.22 ) + vec2( 0.0, 1.6 );\\n \\tvColor.g += 0.05;\\n }\\n \\telse\\n {\\n \\tvPos = vPos * mat2( -0.15, 0.28, 0.26, 0.24 ) + vec2( 0.0, 0.44 );\\n \\tvColor.g += 0.1;\\n }\\n }\\n \\n \\tvPos = vPos * 0.1 + vec2(0.0, -0.5);\\n\\n \\tgl_PointSize = max( 1.0, resolution.x / 600.0 );\\n \\tgl_Position = vec4( vPos * vec2(1.0, resolution.x / resolution.y) , 0, 1 );\\n\\n \\tv_color = vec4( vColor, 1.0 );\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.42745098039215684, + 0.49019607843137253, + 0.5529411764705883, + 1 + ], + "shader": "// Barnsley Fern - @P_Malin\n// https://en.wikipedia.org/wiki/Barnsley_fern\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\nvoid main() \n{ \n \tvec3 p = vec3( 0.01, 0.86, 0.93 ); // p = probability thresholds. Individual probabilities for each transform = 0.01, 0.85, 0.07, 0.07\n \n \tvec3 vColor = vec3( 0.0 );\n \tvec2 vPos = vec2( 0.0 );\n \tfloat fRandomSeed = vertexId + time;\n \tfor ( int i=0; i<32; i++ )\n { \n\t\tfloat fSelection = hash( fRandomSeed );\n \tfRandomSeed += 12.3456;\n \n \tif ( fSelection < p.x )\n {\n \tvPos = vPos * mat2( 0.0, 0.0, 0.0, 0.16 ) + vec2( 0.0, 0.0 );\n \tvColor.r += 0.3;\n }\n \telse if ( fSelection < p.y )\n {\n \tfloat fRot = sin(time) * 0.01;\n \tvPos = vPos * mat2( 0.85, 0.04, -0.04, 0.85 ) * mat2( cos(fRot), sin(fRot), -sin(fRot), cos(fRot) ) + vec2( 0.0, 1.6 );\n \tvColor -= 0.005;\n }\n \telse if ( fSelection < p.z )\n {\n \tvPos = vPos * mat2( 0.20, -0.26, 0.23, 0.22 ) + vec2( 0.0, 1.6 );\n \tvColor.g += 0.05;\n }\n \telse\n {\n \tvPos = vPos * mat2( -0.15, 0.28, 0.26, 0.24 ) + vec2( 0.0, 0.44 );\n \tvColor.g += 0.1;\n }\n }\n \n \tvPos = vPos * 0.1 + vec2(0.0, -0.5);\n\n \tgl_PointSize = max( 1.0, resolution.x / 600.0 );\n \tgl_Position = vec4( vPos * vec2(1.0, resolution.x / resolution.y) , 0, 1 );\n\n \tv_color = vec4( vColor, 1.0 );\n}" + }, "screenshotURL": "data/images/images-x3v98ibaibctnbdoe-thumbnail.jpg", "views": { "$numberInt": "1124" diff --git a/art/zLw84GEutsZbMdZ3e/art.json b/art/zLw84GEutsZbMdZ3e/art.json index ea515e84..e83e3168 100644 --- a/art/zLw84GEutsZbMdZ3e/art.json +++ b/art/zLw84GEutsZbMdZ3e/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "daehyeon.kim", "avatarUrl": "https://secure.gravatar.com/avatar/59274acb019bdbbf608d3ecc06a7b8c8?default=retro&size=200", - "settings": "{\"num\":1681,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n \\n float hue = u * .1 + sin(time + v * 20.) * .05;\\n float sat = 1.;\\n float val = sin(time + v * u * 20.) * .5 + 0.5;\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\\n\"}", + "settings": { + "num": 1681, + "mode": "POINTS", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// from: http://lolengine.net/blog/2013/07/27/rgb-to-hsv-in-glsl\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n \n float hue = u * .1 + sin(time + v * 20.) * .05;\n float sat = 1.;\n float val = sin(time + v * u * 20.) * .5 + 0.5;\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}\n" + }, "screenshotURL": "data/images/images-1y0hsxvfclzlwoulu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zNMwxDHLmvHRPQBpm/art.json b/art/zNMwxDHLmvHRPQBpm/art.json index d76fb311..b3552b3e 100644 --- a/art/zNMwxDHLmvHRPQBpm/art.json +++ b/art/zNMwxDHLmvHRPQBpm/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":1,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"attribute vec3 a_position;\\nvarying vec3 v_pos;\\nvarying float v_alpha;\\nuniform mat4 u_modelViewMatrix;\\nuniform mat4 u_projectionMatrix;\\nuniform vec2 u_resolution;\\nuniform float u_amount;\\nuniform float u_time;\\nuniform float u_twirl;\\nuniform float u_noise_time;\\n//\\n// Description : Array and textureless GLSL 2D simplex noise function.\\n// Author : Ian McEwan, Ashima Arts.\\n// Maintainer : ijm\\n// Lastmod : 20110822 (ijm)\\n// License : Copyright (C) 2011 Ashima Arts. All rights reserved.\\n// Distributed under the MIT License. See LICENSE file.\\n// https://github.com/ashima/webgl-noise\\n//\\n\\nvec3 mod289(vec3 x) {\\n return x - floor(x * (1.0 / 289.0)) * 289.0;\\n}\\nvec2 mod289(vec2 x) {\\n return x - floor(x * (1.0 / 289.0)) * 289.0;\\n}\\nvec3 permute(vec3 x) {\\n return mod289(((x*34.0)+1.0)*x);\\n}\\nfloat snoise(vec2 v) {\\n const vec4 C = vec4(0.211324865405187, // (3.0-sqrt(3.0))/6.0\\n 0.366025403784439, // 0.5*(sqrt(3.0)-1.0)\\n -0.577350269189626, // -1.0 + 2.0 * C.x\\n 0.024390243902439);\\n // 1.0 / 41.0\\n // First corner\\n vec2 i = floor(v + dot(v, C.yy) );\\n vec2 x0 = v - i + dot(i, C.xx);\\n // Other corners\\n vec2 i1;\\n //i1.x = step( x0.y, x0.x ); // x0.x > x0.y ? 1.0 : 0.0\\n //i1.y = 1.0 - i1.x;\\n i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);\\n // x0 = x0 - 0.0 + 0.0 * C.xx ;\\n // x1 = x0 - i1 + 1.0 * C.xx ;\\n // x2 = x0 - 1.0 + 2.0 * C.xx ;\\n vec4 x12 = x0.xyxy + C.xxzz;\\n x12.xy -= i1;\\n // Permutations\\n i = mod289(i);\\n // Avoid truncation effects in permutation\\n vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))\\n + i.x + vec3(0.0, i1.x, 1.0 ));\\n vec3 m = max(0.5 - vec3(dot(x0, x0), dot(x12.xy, x12.xy), dot(x12.zw, x12.zw)), 0.0);\\n m = m*m ;\\n m = m*m ;\\n // Gradients: 41 points uniformly over a line, mapped onto a diamond.\\n // The ring size 17*17 = 289 is close to a multiple of 41 (41*7 = 287)\\n \\n vec3 x = 2.0 * fract(p * C.www) - 1.0;\\n vec3 h = abs(x) - 0.5;\\n vec3 ox = floor(x + 0.5);\\n vec3 a0 = x - ox;\\n // Normalise gradients implicitly by scaling m\\n // Approximation of: m *= inversesqrt( a0*a0 + h*h )[[[semicolonReplacementKey]]]\\n m *= 1.79284291400159 - 0.85373472095314 * ( a0*a0 + h*h );\\n // Compute final noise value at P\\n vec3 g;\\n g.x = a0.x * x0.x + h.x * x0.y;\\n g.yz = a0.yz * x12.xz + h.yz * x12.yw;\\n return 130.0 * dot(m, g);\\n}\\nfloat clampNorm(float val, float min, float max) {\\n return clamp((val - min) / (max - min), 0.0, 1.0);\\n}\\nconst float PI = 3.14159265358979323846264;\\n \\nvoid main(void) {\\n gl_PointSize = 2.0;\\n vec3 pos = a_position;\\n float index = pos.z;\\n pos.z = 0.0;\\n v_alpha = 1.0;\\n // 9 groups \\n float group = mod(floor(index / 360.0), 9.0);\\n float angle = index / 180.0 * PI;\\n float radius = 300.0 + floor(index / 360.0) * 3.0;\\n float toCenter = clamp(radius / 600.0, 0.0, 1.0);\\n vec3 basePos = pos;\\n basePos.x = sin(angle) * radius;\\n basePos.y = cos(angle) * radius;\\n angle += u_time * (1.0 + group * .1) * 0.015;\\n angle += u_twirl * pow(sin(angle * (1.0 - u_twirl * 0.01)), 3.0) * 0.7;\\n pos.x = sin(angle) * radius;\\n pos.y = cos(angle) * radius;\\n vec3 finalPos = pos;\\n finalPos.x = pos.x + snoise(basePos.xy * 1. + u_noise_time * .03 ) * 50.0;\\n finalPos.y = pos.y + snoise(basePos.xy * 1. + u_noise_time * .03 + 3.0 ) * 50.0;\\n v_alpha = toCenter - (sin(pow(toCenter, 1.2) * 60.0) + 1.0) / 2.0 * 0.5;\\n finalPos.x /= u_resolution.x;\\n finalPos.y /= u_resolution.y;\\n v_pos = finalPos;\\n gl_Position = u_projectionMatrix * u_modelViewMatrix * vec4(finalPos, 1.0);\\n}\\n\\n\\n\"}", + "settings": { + "num": 1, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "attribute vec3 a_position;\nvarying vec3 v_pos;\nvarying float v_alpha;\nuniform mat4 u_modelViewMatrix;\nuniform mat4 u_projectionMatrix;\nuniform vec2 u_resolution;\nuniform float u_amount;\nuniform float u_time;\nuniform float u_twirl;\nuniform float u_noise_time;\n//\n// Description : Array and textureless GLSL 2D simplex noise function.\n// Author : Ian McEwan, Ashima Arts.\n// Maintainer : ijm\n// Lastmod : 20110822 (ijm)\n// License : Copyright (C) 2011 Ashima Arts. All rights reserved.\n// Distributed under the MIT License. See LICENSE file.\n// https://github.com/ashima/webgl-noise\n//\n\nvec3 mod289(vec3 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n}\nvec2 mod289(vec2 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n}\nvec3 permute(vec3 x) {\n return mod289(((x*34.0)+1.0)*x);\n}\nfloat snoise(vec2 v) {\n const vec4 C = vec4(0.211324865405187, // (3.0-sqrt(3.0))/6.0\n 0.366025403784439, // 0.5*(sqrt(3.0)-1.0)\n -0.577350269189626, // -1.0 + 2.0 * C.x\n 0.024390243902439);\n // 1.0 / 41.0\n // First corner\n vec2 i = floor(v + dot(v, C.yy) );\n vec2 x0 = v - i + dot(i, C.xx);\n // Other corners\n vec2 i1;\n //i1.x = step( x0.y, x0.x ); // x0.x > x0.y ? 1.0 : 0.0\n //i1.y = 1.0 - i1.x;\n i1 = (x0.x > x0.y) ? vec2(1.0, 0.0) : vec2(0.0, 1.0);\n // x0 = x0 - 0.0 + 0.0 * C.xx ;\n // x1 = x0 - i1 + 1.0 * C.xx ;\n // x2 = x0 - 1.0 + 2.0 * C.xx ;\n vec4 x12 = x0.xyxy + C.xxzz;\n x12.xy -= i1;\n // Permutations\n i = mod289(i);\n // Avoid truncation effects in permutation\n vec3 p = permute( permute( i.y + vec3(0.0, i1.y, 1.0 ))\n + i.x + vec3(0.0, i1.x, 1.0 ));\n vec3 m = max(0.5 - vec3(dot(x0, x0), dot(x12.xy, x12.xy), dot(x12.zw, x12.zw)), 0.0);\n m = m*m ;\n m = m*m ;\n // Gradients: 41 points uniformly over a line, mapped onto a diamond.\n // The ring size 17*17 = 289 is close to a multiple of 41 (41*7 = 287)\n \n vec3 x = 2.0 * fract(p * C.www) - 1.0;\n vec3 h = abs(x) - 0.5;\n vec3 ox = floor(x + 0.5);\n vec3 a0 = x - ox;\n // Normalise gradients implicitly by scaling m\n // Approximation of: m *= inversesqrt( a0*a0 + h*h )[[[semicolonReplacementKey]]]\n m *= 1.79284291400159 - 0.85373472095314 * ( a0*a0 + h*h );\n // Compute final noise value at P\n vec3 g;\n g.x = a0.x * x0.x + h.x * x0.y;\n g.yz = a0.yz * x12.xz + h.yz * x12.yw;\n return 130.0 * dot(m, g);\n}\nfloat clampNorm(float val, float min, float max) {\n return clamp((val - min) / (max - min), 0.0, 1.0);\n}\nconst float PI = 3.14159265358979323846264;\n \nvoid main(void) {\n gl_PointSize = 2.0;\n vec3 pos = a_position;\n float index = pos.z;\n pos.z = 0.0;\n v_alpha = 1.0;\n // 9 groups \n float group = mod(floor(index / 360.0), 9.0);\n float angle = index / 180.0 * PI;\n float radius = 300.0 + floor(index / 360.0) * 3.0;\n float toCenter = clamp(radius / 600.0, 0.0, 1.0);\n vec3 basePos = pos;\n basePos.x = sin(angle) * radius;\n basePos.y = cos(angle) * radius;\n angle += u_time * (1.0 + group * .1) * 0.015;\n angle += u_twirl * pow(sin(angle * (1.0 - u_twirl * 0.01)), 3.0) * 0.7;\n pos.x = sin(angle) * radius;\n pos.y = cos(angle) * radius;\n vec3 finalPos = pos;\n finalPos.x = pos.x + snoise(basePos.xy * 1. + u_noise_time * .03 ) * 50.0;\n finalPos.y = pos.y + snoise(basePos.xy * 1. + u_noise_time * .03 + 3.0 ) * 50.0;\n v_alpha = toCenter - (sin(pow(toCenter, 1.2) * 60.0) + 1.0) / 2.0 * 0.5;\n finalPos.x /= u_resolution.x;\n finalPos.y /= u_resolution.y;\n v_pos = finalPos;\n gl_Position = u_projectionMatrix * u_modelViewMatrix * vec4(finalPos, 1.0);\n}\n\n\n" + }, "screenshotURL": "data/images/images-xui6xluvw9me8sjmp-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zPWNwEXsnYqAjv9as/art.json b/art/zPWNwEXsnYqAjv9as/art.json index 084593b6..cc9cbf4c 100644 --- a/art/zPWNwEXsnYqAjv9as/art.json +++ b/art/zPWNwEXsnYqAjv9as/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "sehoonkim-digipen", "avatarUrl": "https://avatars.githubusercontent.com/SehoonKim-digipen?s=200", - "settings": "{\"num\":10000,\"mode\":\"LINES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main() {\\n float down = sqrt(vertexCount);\\n float across = floor(vertexCount / down);\\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n\\n float xoff = sin(time + y * 0.2) * 0.1;\\n float yoff = sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = sin(time + x * y * .02) * 5.; \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20.0 / across;\\n gl_PointSize *= resolution.x / 600.0;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 10000, + "mode": "LINES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main() {\n float down = sqrt(vertexCount);\n float across = floor(vertexCount / down);\n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n\n float xoff = sin(time + y * 0.2) * 0.1;\n float yoff = sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = sin(time + x * y * .02) * 5.; \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20.0 / across;\n gl_PointSize *= resolution.x / 600.0;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-sptq889z4hbc30ev1-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zQMGMroYDChPD5qbu/art.json b/art/zQMGMroYDChPD5qbu/art.json index 0e07ef37..b3cc4b44 100644 --- a/art/zQMGMroYDChPD5qbu/art.json +++ b/art/zQMGMroYDChPD5qbu/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "tdhooper", "avatarUrl": "https://avatars.githubusercontent.com/tdhooper?s=200", - "settings": "{\"num\":50000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// --------------------------------------------------------\\n// Spectrum colour palette\\n// IQ https://www.shadertoy.com/view/ll2GD3\\n// --------------------------------------------------------\\n\\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\\n return a + b*cos( 6.28318*(c*t+d) );\\n}\\n\\nvec3 spectrum(float n) {\\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\\n}\\n\\n\\n// --------------------------------------------------------\\n// HG_SDF https://www.shadertoy.com/view/Xs3GRB\\n// --------------------------------------------------------\\n\\nfloat vmax(vec3 v) {\\n\\treturn max(max(v.x, v.y), v.z);\\n}\\n\\n// Box: correct distance to corners\\nfloat fBox(vec3 p, vec3 b) {\\n\\tvec3 d = abs(p) - b;\\n\\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\\n}\\n\\nvoid pR(inout vec2 p, float a) {\\n\\tp = cos(a)*p + sin(a)*vec2(p.y, -p.x);\\n}\\n\\n\\n// --------------------------------------------------------\\n// Geometry\\n// --------------------------------------------------------\\n\\nfloat map(vec3 p) {\\n \\tvec3 offset = vec3(\\n \\tcos(time),\\n \\tsin(time),\\n \\tcos(time * 2.)\\n );\\n \\tp -= offset * .25; \\n \\tpR(p.xy, time);\\n \\tpR(p.zx, time * .5); \\t\\n\\n \\treturn -fBox(p, vec3(.7));\\n}\\n\\n\\n// --------------------------------------------------------\\n// Raymarch\\n// --------------------------------------------------------\\n\\nconst float MAX_TRACE_DISTANCE = 10.;\\nconst float INTERSECTION_PRECISION = .001;\\nconst int NUM_OF_TRACE_STEPS = 10;\\n\\n\\nfloat trace(vec3 rayDir) {\\n\\n \\tfloat currentDist = INTERSECTION_PRECISION * 2.;\\n \\tfloat rayLen = 0.;\\n \\n\\tfor(int i=0; i< NUM_OF_TRACE_STEPS ; i++ ){\\n\\t\\tif (currentDist < INTERSECTION_PRECISION || rayLen > MAX_TRACE_DISTANCE) {\\n break;\\n }\\n \\tcurrentDist = map(rayDir * rayLen);\\n \\trayLen += currentDist;\\n\\t}\\n \\n \\treturn rayLen;\\n}\\n\\n\\n// --------------------------------------------------------\\n// Seed points, camera, and display\\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\\n// --------------------------------------------------------\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\nvoid main() {\\n float numQuads = floor(vertexCount / 6.);\\n float around = 100.;\\n float down = numQuads / around;\\n float quadId = floor(vertexId / 6.);\\n \\n float qx = mod(quadId, around);\\n float qy = floor(quadId / around);\\n \\n // 0--1 3\\n // | / /|\\n // |/ / |\\n // 2 4--5\\n //\\n // 0 1 0 1 0 1\\n // 0 0 1 0 1 1\\n \\n float edgeId = mod(vertexId, 6.);\\n float ux = mod(edgeId, 2.);\\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \\n \\n float qu = (qx + ux) / around;\\n float qv = (qy + vy) / down;\\n \\n float r = sin(qv * PI);\\n float x = cos(qu * PI * 2.) * r;\\n float z = sin(qu * PI * 2.) * r;\\n \\n vec3 pos = vec3(x, cos(qv * PI), z);\\n \\n pos *= trace(pos);\\n \\n float tm = time * .5;\\n float rd = 3.;\\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\\n vec3 eye = vec3(\\n cos(tm) * rd,\\n cos(tm) * rd,\\n sin(tm) * rd\\n );\\n vec3 target = vec3(0);\\n vec3 up = vec3(0,1,0);\\n \\n mat *= cameraLookAt(eye, target, up); \\n \\n vec4 pos4 = mat * vec4(pos, 1);\\n \\n gl_Position = pos4;\\n gl_PointSize = 4.;\\n\\n vec3 col = vec3(spectrum(vertexId / vertexCount));\\n col *= smoothstep(rd*2., rd, pos4.z);\\n v_color = vec4(col, 1.);\\n \\n \\n}\"}", + "settings": { + "num": 50000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// --------------------------------------------------------\n// Spectrum colour palette\n// IQ https://www.shadertoy.com/view/ll2GD3\n// --------------------------------------------------------\n\nvec3 pal( in float t, in vec3 a, in vec3 b, in vec3 c, in vec3 d ) {\n return a + b*cos( 6.28318*(c*t+d) );\n}\n\nvec3 spectrum(float n) {\n return pal( n, vec3(0.5,0.5,0.5),vec3(0.5,0.5,0.5),vec3(1.0,1.0,1.0),vec3(0.0,0.33,0.67) );\n}\n\n\n// --------------------------------------------------------\n// HG_SDF https://www.shadertoy.com/view/Xs3GRB\n// --------------------------------------------------------\n\nfloat vmax(vec3 v) {\n\treturn max(max(v.x, v.y), v.z);\n}\n\n// Box: correct distance to corners\nfloat fBox(vec3 p, vec3 b) {\n\tvec3 d = abs(p) - b;\n\treturn length(max(d, vec3(0))) + vmax(min(d, vec3(0)));\n}\n\nvoid pR(inout vec2 p, float a) {\n\tp = cos(a)*p + sin(a)*vec2(p.y, -p.x);\n}\n\n\n// --------------------------------------------------------\n// Geometry\n// --------------------------------------------------------\n\nfloat map(vec3 p) {\n \tvec3 offset = vec3(\n \tcos(time),\n \tsin(time),\n \tcos(time * 2.)\n );\n \tp -= offset * .25; \n \tpR(p.xy, time);\n \tpR(p.zx, time * .5); \t\n\n \treturn -fBox(p, vec3(.7));\n}\n\n\n// --------------------------------------------------------\n// Raymarch\n// --------------------------------------------------------\n\nconst float MAX_TRACE_DISTANCE = 10.;\nconst float INTERSECTION_PRECISION = .001;\nconst int NUM_OF_TRACE_STEPS = 10;\n\n\nfloat trace(vec3 rayDir) {\n\n \tfloat currentDist = INTERSECTION_PRECISION * 2.;\n \tfloat rayLen = 0.;\n \n\tfor(int i=0; i< NUM_OF_TRACE_STEPS ; i++ ){\n\t\tif (currentDist < INTERSECTION_PRECISION || rayLen > MAX_TRACE_DISTANCE) {\n break;\n }\n \tcurrentDist = map(rayDir * rayLen);\n \trayLen += currentDist;\n\t}\n \n \treturn rayLen;\n}\n\n\n// --------------------------------------------------------\n// Seed points, camera, and display\n// gman https://www.vertexshaderart.com/art/7TrYkuK4aHzLqvZ7r\n// --------------------------------------------------------\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\nvoid main() {\n float numQuads = floor(vertexCount / 6.);\n float around = 100.;\n float down = numQuads / around;\n float quadId = floor(vertexId / 6.);\n \n float qx = mod(quadId, around);\n float qy = floor(quadId / around);\n \n // 0--1 3\n // | / /|\n // |/ / |\n // 2 4--5\n //\n // 0 1 0 1 0 1\n // 0 0 1 0 1 1\n \n float edgeId = mod(vertexId, 6.);\n float ux = mod(edgeId, 2.);\n float vy = mod(floor(edgeId / 2.) + floor(edgeId / 3.), 2.); \n \n float qu = (qx + ux) / around;\n float qv = (qy + vy) / down;\n \n float r = sin(qv * PI);\n float x = cos(qu * PI * 2.) * r;\n float z = sin(qu * PI * 2.) * r;\n \n vec3 pos = vec3(x, cos(qv * PI), z);\n \n pos *= trace(pos);\n \n float tm = time * .5;\n float rd = 3.;\n mat4 mat = persp(PI * 0.25, resolution.x / resolution.y, 0.1, 100.);\n vec3 eye = vec3(\n cos(tm) * rd,\n cos(tm) * rd,\n sin(tm) * rd\n );\n vec3 target = vec3(0);\n vec3 up = vec3(0,1,0);\n \n mat *= cameraLookAt(eye, target, up); \n \n vec4 pos4 = mat * vec4(pos, 1);\n \n gl_Position = pos4;\n gl_PointSize = 4.;\n\n vec3 col = vec3(spectrum(vertexId / vertexCount));\n col *= smoothstep(rd*2., rd, pos4.z);\n v_color = vec4(col, 1.);\n \n \n}" + }, "screenshotURL": "data/images/images-k8eljnva3nai95w1j-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zQsoSnJjbCQY2Zq83/art.json b/art/zQsoSnJjbCQY2Zq83/art.json index 5498247f..bc615769 100644 --- a/art/zQsoSnJjbCQY2Zq83/art.json +++ b/art/zQsoSnJjbCQY2Zq83/art.json @@ -34,7 +34,19 @@ "unlisted": false, "username": "tomoya", "avatarUrl": "https://graph.facebook.com/1240617289365712/picture?type=large", - "settings": "{\"num\":3185,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"vec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y /(across - 1.);\\n \\n float xoff = 0.; // sin(time + y * 0.2) * 0.1;\\n float yoff = 0.; //sin(time + x * 0.3) * 0.1;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.3;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15. + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = 1.; //u * .1 + sin(time + v * 20.) * 0.05;\\n float sat = 1.;\\n float val = 1.; //sin(time + v * u * 20.0) * .5 + .5;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n}\"}", + "settings": { + "num": 3185, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "vec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 P = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(P - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y /(across - 1.);\n \n float xoff = 0.; // sin(time + y * 0.2) * 0.1;\n float yoff = 0.; //sin(time + x * 0.3) * 0.1;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.3;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.; //sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15. + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = 1.; //u * .1 + sin(time + v * 20.) * 0.05;\n float sat = 1.;\n float val = 1.; //sin(time + v * u * 20.0) * .5 + .5;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n}" + }, "screenshotURL": "data/images/images-5dtsmd5hb5cduhoz4-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zRecXKb9NuCfmnWv4/art.json b/art/zRecXKb9NuCfmnWv4/art.json index 3b60dc50..46a64296 100644 --- a/art/zRecXKb9NuCfmnWv4/art.json +++ b/art/zRecXKb9NuCfmnWv4/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "richtowns", "avatarUrl": "https://avatars.githubusercontent.com/richtowns?s=200", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0.6274509803921569,1],\"shader\":\"void main() {\\n gl_Position = vec4(0, 0, 0, 1);\\n gl_PointSize = 40.;\\n v_color = vec4(1, 0, 0, 1);\\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0.6274509803921569, + 1 + ], + "shader": "void main() {\n gl_Position = vec4(0, 0, 0, 1);\n gl_PointSize = 40.;\n v_color = vec4(1, 0, 0, 1);\n}" + }, "screenshotURL": "data/images/images-7bmizxwjtimhrr3wf-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zS5Nx6iwJqiQDQRap/art.json b/art/zS5Nx6iwJqiQDQRap/art.json index a903f000..e20163ba 100644 --- a/art/zS5Nx6iwJqiQDQRap/art.json +++ b/art/zS5Nx6iwJqiQDQRap/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "ersh", "avatarUrl": "https://secure.gravatar.com/avatar/a55f941068214979f79e0d64d5062a5d?default=retro&size=200", - "settings": "{\"num\":24,\"mode\":\"TRI_FAN\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float point = vertexId / (vertexCount-2.);\\n float angle = point * PI * 2.0;\\n float radius = 0.8;\\n float t = time * 0.5;\\n float c = cos(angle + t) * radius;\\n float s = sin(angle + t) * radius;\\n\\n float p0 = clamp(vertexId, 0., 1.);\\n //vec2 aspect = vec2(1, resolution.x / resolution.y);\\n //float x = c, y = s, z = 1.1, sz = 1./z;\\n float fov = 1. + (clamp(mouse.x, -1., 1.) + 1.); // 1.4;\\n float x = c, y = s * mouse.y * -0.9, z = (fov + 1.) + s, sz = 1./z;\\n float fovxy = fov;\\n gl_Position = vec4(vec2(x, y)*fovxy*p0, -sz*p0, z);\\n gl_PointSize = resolution.x/15.*sz;\\n\\n float hue = (time * 0.01 + point * 1.001);\\n float accent = clamp(1./(z-fov), 0., 1.);\\n v_color = vec4(hsv2rgb(vec3(hue, accent, accent)), 1);\\n}\"}", + "settings": { + "num": 24, + "mode": "TRI_FAN", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float point = vertexId / (vertexCount-2.);\n float angle = point * PI * 2.0;\n float radius = 0.8;\n float t = time * 0.5;\n float c = cos(angle + t) * radius;\n float s = sin(angle + t) * radius;\n\n float p0 = clamp(vertexId, 0., 1.);\n //vec2 aspect = vec2(1, resolution.x / resolution.y);\n //float x = c, y = s, z = 1.1, sz = 1./z;\n float fov = 1. + (clamp(mouse.x, -1., 1.) + 1.); // 1.4;\n float x = c, y = s * mouse.y * -0.9, z = (fov + 1.) + s, sz = 1./z;\n float fovxy = fov;\n gl_Position = vec4(vec2(x, y)*fovxy*p0, -sz*p0, z);\n gl_PointSize = resolution.x/15.*sz;\n\n float hue = (time * 0.01 + point * 1.001);\n float accent = clamp(1./(z-fov), 0., 1.);\n v_color = vec4(hsv2rgb(vec3(hue, accent, accent)), 1);\n}" + }, "screenshotURL": "data/images/images-tfo63vu5w0ysw7kk6-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zSahx3yerpFqrYbQM/art.json b/art/zSahx3yerpFqrYbQM/art.json index cd677f84..ab4315e1 100644 --- a/art/zSahx3yerpFqrYbQM/art.json +++ b/art/zSahx3yerpFqrYbQM/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/chibi-tech/lolitazia-season\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define NUM_SEGMENTS 128.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n\\n\\n// simple xmas tree\\n// just customize with some presents!\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n if (vertexId < 90000.) {\\n float needleId = floor(vertexId/6.);\\n float subId = vertexId - needleId*6.;\\n float branch = floor(sqrt(needleId+0.5));\\n needleId -= branch*branch;\\n\\n float y = .9-branch*.01-needleId*.005 - (1.-abs(mod(subId,3.)-1.))*.06;\\n float l = needleId*.003+mod(subId,3.)*.005;\\n float a = branch * 3.88 + time + (1.-abs(mod(subId,3.)-1.))*.05/l * sign(subId-2.5);\\n\\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\\n\\n\\n gl_Position = vec4(p.xy, p.z+.5, 1);\\n\\n v_color = vec4(vec3(.3,.8,.2)*(sin(needleId*.07)*.5+2.)*.2,1);\\n } else if (vertexId < 90090.) {\\n float id = vertexId - 90000.;\\n float needleId = floor(id/3.);\\n float subId = id - needleId*3.;\\n\\n float y = .9- abs(mod(subId,3.)-1.)*1.9;\\n float l = abs(mod(subId,3.)-1.)*.03;\\n float a = time + (needleId + floor(subId*.5))*.21;\\n\\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\\n\\n\\n gl_Position = vec4(p.xy, p.z+.5, 1);\\n\\n v_color = vec4(vec3(.5,.2,0.)*(sin(needleId*.7)*.5+2.)*.2,1);\\n \\n } else {\\n float id = vertexId - 90090.;\\n float sphereId = floor(id/300.);\\n float subId = id - sphereId*300.;\\n\\n float y = sqrt(sqrt((sin(sphereId)+1.)*.5));\\n float l = (sin(sphereId*3.7)*.1+1.)*y*.45;\\n float a = y*100.+l*312. + time;\\n \\n y = .85-y*1.5;\\n\\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\\n p += vec3(cos(subId*2.3)*.6,sin(subId*2.3)-.9,0)*.08*exp(subId*subId*-.00008)+vec3(0,0,subId*-.0001);\\n\\n\\n gl_Position = vec4(p.xy, p.z+.5, 1);\\n\\n float v = vertexId*.002;\\n vec3 vc = vec3(cos(v),cos(v+2.1),cos(v-2.1))*.2+.5+subId*subId*.00002;\\n \\n v_color = vec4(vc*vc,1.);\\n \\n }\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/chibi-tech/lolitazia-season", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define NUM_SEGMENTS 128.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n\n\n// simple xmas tree\n// just customize with some presents!\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n if (vertexId < 90000.) {\n float needleId = floor(vertexId/6.);\n float subId = vertexId - needleId*6.;\n float branch = floor(sqrt(needleId+0.5));\n needleId -= branch*branch;\n\n float y = .9-branch*.01-needleId*.005 - (1.-abs(mod(subId,3.)-1.))*.06;\n float l = needleId*.003+mod(subId,3.)*.005;\n float a = branch * 3.88 + time + (1.-abs(mod(subId,3.)-1.))*.05/l * sign(subId-2.5);\n\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\n\n\n gl_Position = vec4(p.xy, p.z+.5, 1);\n\n v_color = vec4(vec3(.3,.8,.2)*(sin(needleId*.07)*.5+2.)*.2,1);\n } else if (vertexId < 90090.) {\n float id = vertexId - 90000.;\n float needleId = floor(id/3.);\n float subId = id - needleId*3.;\n\n float y = .9- abs(mod(subId,3.)-1.)*1.9;\n float l = abs(mod(subId,3.)-1.)*.03;\n float a = time + (needleId + floor(subId*.5))*.21;\n\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\n\n\n gl_Position = vec4(p.xy, p.z+.5, 1);\n\n v_color = vec4(vec3(.5,.2,0.)*(sin(needleId*.7)*.5+2.)*.2,1);\n \n } else {\n float id = vertexId - 90090.;\n float sphereId = floor(id/300.);\n float subId = id - sphereId*300.;\n\n float y = sqrt(sqrt((sin(sphereId)+1.)*.5));\n float l = (sin(sphereId*3.7)*.1+1.)*y*.45;\n float a = y*100.+l*312. + time;\n \n y = .85-y*1.5;\n\n vec3 p = vec3(cos(a)*l, y, sin(a)*l);\n p += vec3(cos(subId*2.3)*.6,sin(subId*2.3)-.9,0)*.08*exp(subId*subId*-.00008)+vec3(0,0,subId*-.0001);\n\n\n gl_Position = vec4(p.xy, p.z+.5, 1);\n\n float v = vertexId*.002;\n vec3 vc = vec3(cos(v),cos(v+2.1),cos(v-2.1))*.2+.5+subId*subId*.00002;\n \n v_color = vec4(vc*vc,1.);\n \n }\n}" + }, "screenshotURL": "data/images/images-vdys8384bv8axgl31-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zTFEangj5PduTYF4e/art.json b/art/zTFEangj5PduTYF4e/art.json index 55ec764b..c65c28ca 100644 --- a/art/zTFEangj5PduTYF4e/art.json +++ b/art/zTFEangj5PduTYF4e/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "ben2", "avatarUrl": "https://lh5.googleusercontent.com/-i_jGrme9wbE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcJDIE0ag9n4_5FBVfRmXI2kKiHSA/photo.jpg", - "settings": "{\"num\":41432,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/feuerhaus/donauwalzer-1\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// Block Orchestra\\n\\n//#define WALK\\n\\n//#define COLOR_PASTEL\\n//#define COLOR_VIVID\\n#define COLOR_SUNSET\\n\\n#ifdef COLOR_PASTEL\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\\n\\nfloat gFogDensity = 0.01;\\n\\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.4;\\n\\n#endif\\n\\n#ifdef COLOR_VIVID\\n\\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.9;\\n\\n#endif\\n\\n#ifdef COLOR_SUNSET\\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \\n\\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\\n\\nfloat gFogDensity = 0.05;\\n\\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\\nfloat gExposure = 1.0;\\n\\nfloat gCubeColorRandom = 0.5;\\n\\n#endif\\n\\n#define MOVE_OUTWARDS\\n\\nfloat fAOAmount = 0.8;\\nfloat gFloorHeight = -1.0;\\nfloat g_cameraFar = 1000.0;\\n\\n#define PI radians( 180.0 )\\n\\n\\nvec3 GetSunDir()\\n{\\n \\treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\\n}\\n\\n\\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\\n{\\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\\n float triVertexIndex = mod( vertexIndex, 3.0 );\\n \\n if \\t\\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\\n else if\\t( twoTriVertexIndex < 1.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 2.5 )\\tquadVertId = vec2( 0.0, 1.0 );\\n else if ( twoTriVertexIndex < 3.5 )\\tquadVertId = vec2( 1.0, 0.0 );\\n else if ( twoTriVertexIndex < 4.5 )\\tquadVertId = vec2( 1.0, 1.0 );\\n else \\t\\t\\t\\t\\t\\t\\t\\tquadVertId = vec2( 0.0, 1.0 );\\n\\n quadId = floor( vertexIndex / 6.0 );\\n}\\n\\n\\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\\n vQuadTileIndex.y = floor( quadId / vDim.x );\\n\\n \\tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\\n\\n vQuadUV = vQuadUV * (1.0 / vDim);\\n}\\n\\n\\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\\n{\\n \\tvec2 quadVertId;\\n \\tfloat quadId;\\n\\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \\n \\tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \\n}\\n\\n\\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\\n{\\n vec3 vX = normalize( cross( vY, vZ ) );\\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\\n m[0] = vX;\\n m[1] = vOrthoY;\\n m[2] = vZ;\\n}\\n\\n\\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\\n{\\n \\tvec3 vZ = normalize(vZAxis);\\n \\tvec3 vY = vec3( 0.0, 1.0, 0.0 );\\n \\tif ( abs(vZ.y) > 0.99 )\\n {\\n vY = vec3( 1.0, 0.0, 0.0 );\\n }\\n \\tGetMatrixFromZY( vZ, vY, m );\\n}\\n\\n\\nstruct SceneVertex\\n{\\n \\tvec3 vWorldPos;\\n \\tvec3 vColor;\\n \\tfloat fAlpha;\\n};\\n\\n\\nfloat GetCosSunRadius()\\n{\\n return 0.01;\\n}\\n\\n\\nfloat GetSunIntensity()\\n{ \\t\\n \\treturn 0.001;\\n}\\n\\n\\nvec3 GetSkyColor( vec3 vViewDir )\\n{\\n\\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\\n}\\n\\n\\nvec3 GetBackdropColor( vec3 vViewDir )\\n{\\n \\tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\\n \\n \\tVdotL = clamp( VdotL, 0.0, 1.0 );\\n \\n \\tfloat fShade = 0.0;\\n\\n \\tfShade = acos( VdotL ) * (1.0 / PI);\\n \\n \\tfloat fCosSunRadius = GetCosSunRadius();\\n \\n \\tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \\n \\n \\tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\\n \\n \\tvec3 vColor = vec3(0.0);\\n vColor += GetSkyColor( vViewDir );\\n \\n vColor += vec3( fShade * gSunColor );\\n return vColor;\\n}\\n\\n\\n#define g_backdropSegments \\t\\t\\t32.0\\n#define g_backdropSlices \\t\\t\\t16.0\\n#define g_backdropQuads \\t\\t\\t( g_backdropSegments * g_backdropSlices )\\n#define g_backdropVertexCount \\t\\t( g_backdropQuads * 6.0 )\\n\\n\\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{\\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\\n \\n \\tvec2 vQuadTileIndex;\\n vec2 vUV; \\n \\tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\\n\\n float fSlicePos = 0.0;\\n \\n \\tfloat fSunMeshPinch = 5.0;\\n \\n \\tif (vUV.y > 0.0)\\n {\\n \\tfloat t = pow( vUV.y, fSunMeshPinch );\\n \\t\\tfloat fCosSunRadius = GetCosSunRadius();\\n \\tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\\n }\\n \\n \\tvec3 vSpherePos;\\n \\tfloat fElevation = fSlicePos * PI;\\n \\tvSpherePos.z = cos( fElevation );\\n\\n \\tfloat fHeading = vUV.x * PI * 2.0;\\n \\tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\\n \\tvSpherePos.x = sin( fHeading ) * fSliceRadius;\\n \\tvSpherePos.y = cos( fHeading ) * fSliceRadius;\\n \\n\\tmat3 m;\\n \\n \\tGetMatrixFromZ( GetSunDir(), m );\\n \\n \\tvec3 vLocalSpherePos = m * vSpherePos;\\n\\n \\tfloat fBackdropDistance = g_cameraFar; \\n \\tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\\n\\n \\tvWorldSpherePos += vCameraPos;\\n \\n outSceneVertex.vWorldPos = vWorldSpherePos;\\n \\n \\toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\\n\\n \\toutSceneVertex.fAlpha = 1.0;\\n} \\n\\n\\n#define g_cubeFaces\\t\\t\\t\\t\\t6.0\\n#define g_cubeVerticesPerFace\\t\\t( g_cubeFaces * 2.0 * 3.0 )\\n#define g_cubeVertexCount \\t\\t\\t( g_cubeVerticesPerFace * g_cubeFaces )\\n\\n// 6 7\\n// +----------+\\n// /| /|\\n// 2 / | 3/ |\\n// +----------+ |\\n// | | | |\\n// Y Z | 4| | 5|\\n// | +-------|--+\\n// ^ / | / | /\\n// |/ 0|/ 1|/\\n// +--> X +----------+\\n \\nvec3 GetCubeVertex( float fVertexIndex )\\n{\\n\\tvec3 fResult = vec3( 1.0 );\\n \\n \\tfloat f = fVertexIndex / 8.0;\\n \\tif ( fract( f * 4.0 ) < 0.5 )\\n {\\n \\tfResult.x = -fResult.x;\\n }\\n \\n \\tif ( fract( f * 2.0 ) < 0.5 )\\n {\\n \\tfResult.y = -fResult.y;\\n }\\n\\n \\tif ( fract( f ) < 0.5 )\\n {\\n \\tfResult.z = -fResult.z;\\n }\\n \\n \\treturn fResult;\\n}\\n\\n\\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\\n{\\n \\tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\\n\\n \\tvec3 v0, v1, v2, v3;\\n \\n \\tif ( fFaceIndex < 0.5 )\\n {\\n \\tv0 = GetCubeVertex( 0.0 );\\n \\tv1 = GetCubeVertex( 2.0 );\\n \\tv2 = GetCubeVertex( 3.0 );\\n \\tv3 = GetCubeVertex( 1.0 );\\n }\\n \\telse if ( fFaceIndex < 1.5 )\\n {\\n \\tv0 = GetCubeVertex( 5.0 );\\n \\tv1 = GetCubeVertex( 7.0 );\\n \\tv2 = GetCubeVertex( 6.0 );\\n \\tv3 = GetCubeVertex( 4.0 );\\n }\\n \\telse if ( fFaceIndex < 2.5 )\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 3.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 5.0 );\\n }\\n \\telse if ( fFaceIndex < 3.5 )\\n {\\n \\tv0 = GetCubeVertex( 4.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 2.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\telse if ( fFaceIndex < 4.5 )\\n {\\n \\tv0 = GetCubeVertex( 2.0 );\\n \\tv1 = GetCubeVertex( 6.0 );\\n \\tv2 = GetCubeVertex( 7.0 );\\n \\tv3 = GetCubeVertex( 3.0 );\\n }\\n \\telse\\n {\\n \\tv0 = GetCubeVertex( 1.0 );\\n \\tv1 = GetCubeVertex( 5.0 );\\n \\tv2 = GetCubeVertex( 4.0 );\\n \\tv3 = GetCubeVertex( 0.0 );\\n }\\n \\n \\tv0 = v0 * mRot + vTrans;\\n \\tv1 = v1 * mRot + vTrans;\\n \\tv2 = v2 * mRot + vTrans;\\n \\tv3 = v3 * mRot + vTrans;\\n \\n \\tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\\n \\n \\tif ( fFaceVertexIndex < 0.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 1.5 )\\n {\\n\\t \\tvWorldPos = v1;\\n }\\n \\telse if ( fFaceVertexIndex < 2.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse if ( fFaceVertexIndex < 3.5 )\\n {\\n\\t \\tvWorldPos = v0;\\n }\\n \\telse if ( fFaceVertexIndex < 4.5 )\\n {\\n\\t \\tvWorldPos = v2;\\n }\\n \\telse\\n {\\n\\t \\tvWorldPos = v3;\\n }\\n \\n \\tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \\n}\\n\\n\\nvec3 GetSunLighting( const vec3 vNormal )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n \\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\t \\n \\treturn gSunColor * NdotL;\\n}\\n\\n\\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\\n{\\n \\tvec3 vLight = -GetSunDir();\\n\\n \\tvec3 vView = normalize( vCameraPos - vPos );\\n \\n \\tvec3 vH = normalize( vView - vLight );\\n \\n \\tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\\n \\tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\\n \\n \\tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\\n \\n \\treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\\n}\\n\\n\\nvec3 GetSkyLighting( const vec3 vNormal )\\n{\\n \\tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\\n \\n \\tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\\n \\n \\treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\\n}\\n\\n\\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\\n{ \\n \\tvec3 vNormal;\\n \\n\\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\\n \\n \\toutSceneVertex.vColor = vec3( 0.0 );\\n \\n \\toutSceneVertex.fAlpha = 1.0; \\n \\n \\tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\\n \\tif ( fStage < 0.5 )\\n {\\n\\t outSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\\n \\n \\t\\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= vCubeCol; \\n \\n \\toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\\n }\\n \\telse\\n {\\n \\tvec3 vSunDir = GetSunDir();\\n \\toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\\n \\toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight;\\n \\n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\\n\\n \\toutSceneVertex.vColor *= gFloorColor;\\n } \\n}\\n\\n\\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\\n{\\n \\tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\\n \\tfloat fDist = length( vViewOffset );\\n \\n \\tvec3 vViewDir = normalize( vViewOffset );\\n \\n \\tfloat fFogBlend = exp2( fDist * -gFogDensity );\\n \\n \\tvec3 vFogColor = GetBackdropColor( vViewDir );\\n \\n \\tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\\n}\\n\\n\\n#define g_floorTileX 16.0\\n#define g_floorTileY 16.0\\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\\n\\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\\n{\\n \\tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\\n \\tvec2 vQuadTileIndex;\\n \\tvec2 vQuadUV;\\n \\n\\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \\n\\n \\toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\\n \\toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\\n \\toutSceneVertex.fAlpha = 1.0;\\n \\toutSceneVertex.vColor = vec3(0.0);\\n\\n \\tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\\n \\toutSceneVertex.vColor += GetSkyLighting( vNormal );\\n \\toutSceneVertex.vColor += GetSunLighting( vNormal );\\n \\n \\toutSceneVertex.vColor *= gFloorColor;\\n}\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p)\\n{\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n\\nmat3 RotMatrixY( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, 0.0, s, \\n 0.0, 1.0, 0.0,\\n -s, 0.0, c );\\n \\n}\\n\\n\\nmat3 RotMatrixZ( float fAngle )\\n{\\n float s = sin( fAngle );\\n float c = cos( fAngle );\\n \\t\\n return mat3( c, s, 0.0, \\n -s, c, 0.0,\\n 0.0, 0.0, 1.0 );\\n \\n}\\n\\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\\n{ \\n \\tfloat fSeed = fCubeId;\\n \\tfloat fPositionBase = fCubeId;\\n#ifdef MOVE_OUTWARDS\\n \\tfSeed -= floor(time);\\n \\tfPositionBase += mod(time, 1.0);\\n#endif \\n \\tfloat fSize = hash(fSeed * 1.234);\\n \\tfSize = fSize * fSize;\\n\\n \\tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\\n\\n\\t\\n float r = sqrt(fPositionBase) * 1.987;\\n \\tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\\n vCubeOrigin.x = sin(fTheta) * r;\\n vCubeOrigin.z = cos(fTheta) * r;\\n \\n float fScale = fSize * 0.5 + 0.5;\\n \\n#ifdef MOVE_OUTWARDS\\n \\tfScale *= clamp(r , 0.0, 1.0);\\n#endif \\n \\n \\tfloat roll = 0.0;\\n#ifdef WALK\\n \\troll = r * PI * 2.0 * fScale;\\n#endif\\n \\n \\tmCubeRot = RotMatrixZ(roll);\\n \\tmCubeRot *= RotMatrixY(fTheta);\\n mCubeRot *= fScale;\\n \\t\\n \\tfloat fMinY = 10.0;\\n \\t\\n \\tfloat f = 0.0;\\n \\tfor( int i=0; i<8; i++)\\n {\\n \\tvec3 vert = GetCubeVertex(f) * mCubeRot;\\n\\t \\tfMinY = min( fMinY, vert.y );\\n \\tf+= 1.0;\\n }\\n \\n \\tvCubeOrigin.y = gFloorHeight;\\n \\tvCubeOrigin.y += -fMinY;\\n \\n \\tfloat jump = 0.0;\\n\\n \\tfloat o = 10.0 / 240.0;\\n \\tfloat v = 0.0;\\n float a = 0.011;\\n \\n \\tfor(int i=0; i<10; i++)\\n {\\n float off = -0.1;\\n float spread = 0.4; \\n float speed = 0.001;\\n \\n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\\n\\n \\tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\\n \\n \\to = o - (1.5 / 240.0);\\n \\n \\tv = v - 0.04;\\n \\ta = a * 1.4;\\n \\tv += snd * a;\\n \\tjump = jump + v;\\n \\n \\tif( jump < 0.0)\\n {\\n \\tv = 0.0;\\n \\tjump = 0.0;\\n }\\n }\\n\\n \\tvCubeOrigin.y += jump * 8.0;\\n \\n \\tvec3 vRandCol;\\n \\tvRandCol.x = hash( fSeed );\\n \\tvRandCol.y = hash( fSeed * 1.234);\\n \\tvRandCol.z = hash( fSeed * 2.345);\\n \\n \\tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\\n}\\n\\n\\nvoid main()\\n{ \\n \\tSceneVertex sceneVertex;\\n \\n \\tvec2 vMouse = mouse;\\n \\n \\tfloat fov = 1.5;\\n \\n \\tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\\n \\tfMouseX = fMouseX * fMouseX;\\n \\n \\tfloat animTime = time;\\n \\n \\tfloat orbitAngle = animTime * 0.3456 + 4.0;\\n \\tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\\n \\tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\\n \\n \\tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\\n \\tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\\n \\tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\\n \\n \\tif( false )\\n {\\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\\n vCameraUp = vec3( 0.0, 1.0, 0.0);\\n }\\n \\n \\tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\\n \\n \\tmat3 mCamera;\\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\\n \\n \\tfloat vertexIndex = vertexId;\\n \\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\\n {\\n \\tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_backdropVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\\n {\\n \\tGenerateFloorVertex( vertexIndex, sceneVertex );\\n\\t \\tApplyFog( vCameraPos, sceneVertex );\\n }\\n \\tvertexIndex -= g_floorVertexCount;\\n \\n \\tif ( vertexIndex >= 0.0 )\\n {\\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\\n float fCubeStage = mod( fCubeIndex, 2.0 );\\n float fCubeId = floor(fCubeIndex / 2.0);\\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\\n\\n {\\n \\tmat3 mCube;\\n \\tvec3 vCubeOrigin;\\n \\tvec3 vCubeCol;\\n \\t\\n\\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\\n\\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\\n\\t\\t \\tApplyFog( vCameraPos, sceneVertex );\\n\\n fCubeId += 1.0;\\n }\\n }\\n\\n\\n // Fianl output position\\n\\tvec3 vViewPos = sceneVertex.vWorldPos;\\n vViewPos -= vCameraPos;\\n \\tvViewPos = vViewPos * mCamera;\\n \\t\\n \\tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\\n \\tvec2 vScreenPos = vViewPos.xy * vFov;\\n\\n\\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\\n \\n \\t// Final output color\\n \\tfloat fExposure = min( gExposure, time * 0.1 );\\n \\tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\\n \\n \\tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \\n}\"}", + "settings": { + "num": 41432, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/feuerhaus/donauwalzer-1", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// Block Orchestra\n\n//#define WALK\n\n//#define COLOR_PASTEL\n//#define COLOR_VIVID\n#define COLOR_SUNSET\n\n#ifdef COLOR_PASTEL\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 4.0;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 5.0;\n\nfloat gFogDensity = 0.01;\n\nvec3 gFloorColor = vec3(0.8, 1.0, 0.8);\nvec3 gCubeColor = vec3(1.0, 0.8, 0.8);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.4;\n\n#endif\n\n#ifdef COLOR_VIVID\n\nvec3 gSunColor = vec3(1.0, 0.9, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 0.1, 0.2, 0.8 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.5, 0.8, 1.0 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(0.4, 1.0, 0.4);\nvec3 gCubeColor = vec3(1.0, 0.1, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.9;\n\n#endif\n\n#ifdef COLOR_SUNSET\nvec3 gSunColor = vec3(1.0, 0.2, 0.1) * 10.0; \n\nvec3 gSkyTop = vec3( 1.0, 0.8, 0.5 ) * 0.5;\nvec3 gSkyBottom = vec3( 0.8, 0.2, 0.1 ) * 1.5;\n\nfloat gFogDensity = 0.05;\n\nvec3 gFloorColor = vec3(1.0, 0.5, 0.5);\nvec3 gCubeColor = vec3(1.0, 0.5, 1.0);\nfloat gExposure = 1.0;\n\nfloat gCubeColorRandom = 0.5;\n\n#endif\n\n#define MOVE_OUTWARDS\n\nfloat fAOAmount = 0.8;\nfloat gFloorHeight = -1.0;\nfloat g_cameraFar = 1000.0;\n\n#define PI radians( 180.0 )\n\n\nvec3 GetSunDir()\n{\n \treturn normalize( vec3( 1.0, 0.3, -0.5 ) );\n}\n\n\nvoid GetQuadInfo( const float vertexIndex, out vec2 quadVertId, out float quadId )\n{\n float twoTriVertexIndex = mod( vertexIndex, 6.0 );\n float triVertexIndex = mod( vertexIndex, 3.0 );\n \n if \t\t( twoTriVertexIndex < 0.5 ) quadVertId = vec2( 0.0, 0.0 );\n else if\t( twoTriVertexIndex < 1.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 2.5 )\tquadVertId = vec2( 0.0, 1.0 );\n else if ( twoTriVertexIndex < 3.5 )\tquadVertId = vec2( 1.0, 0.0 );\n else if ( twoTriVertexIndex < 4.5 )\tquadVertId = vec2( 1.0, 1.0 );\n else \t\t\t\t\t\t\t\tquadVertId = vec2( 0.0, 1.0 );\n\n quadId = floor( vertexIndex / 6.0 );\n}\n\n\nvoid GetQuadTileInfo( const vec2 quadVertId, const float quadId, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n vQuadTileIndex.x = floor( mod( quadId, vDim.x ) );\n vQuadTileIndex.y = floor( quadId / vDim.x );\n\n \tvQuadUV.x = floor(quadVertId.x + vQuadTileIndex.x);\n vQuadUV.y = floor(quadVertId.y + vQuadTileIndex.y);\n\n vQuadUV = vQuadUV * (1.0 / vDim);\n}\n\n\nvoid GetQuadTileInfo( const float vertexIndex, const vec2 vDim, out vec2 vQuadTileIndex, out vec2 vQuadUV )\n{\n \tvec2 quadVertId;\n \tfloat quadId;\n\tGetQuadInfo( vertexIndex, quadVertId, quadId ); \n \tGetQuadTileInfo( quadVertId, quadId, vDim, vQuadTileIndex, vQuadUV ); \n}\n\n\nvoid GetMatrixFromZY( const vec3 vZ, const vec3 vY, out mat3 m )\n{\n vec3 vX = normalize( cross( vY, vZ ) );\n vec3 vOrthoY = normalize( cross( vZ, vX ) );\n m[0] = vX;\n m[1] = vOrthoY;\n m[2] = vZ;\n}\n\n\nvoid GetMatrixFromZ( vec3 vZAxis, out mat3 m )\n{\n \tvec3 vZ = normalize(vZAxis);\n \tvec3 vY = vec3( 0.0, 1.0, 0.0 );\n \tif ( abs(vZ.y) > 0.99 )\n {\n vY = vec3( 1.0, 0.0, 0.0 );\n }\n \tGetMatrixFromZY( vZ, vY, m );\n}\n\n\nstruct SceneVertex\n{\n \tvec3 vWorldPos;\n \tvec3 vColor;\n \tfloat fAlpha;\n};\n\n\nfloat GetCosSunRadius()\n{\n return 0.01;\n}\n\n\nfloat GetSunIntensity()\n{ \t\n \treturn 0.001;\n}\n\n\nvec3 GetSkyColor( vec3 vViewDir )\n{\n\treturn mix( gSkyBottom, gSkyTop, max( 0.0, vViewDir.y ) );\n}\n\n\nvec3 GetBackdropColor( vec3 vViewDir )\n{\n \tfloat VdotL = dot( normalize(vViewDir), GetSunDir() );\n \n \tVdotL = clamp( VdotL, 0.0, 1.0 );\n \n \tfloat fShade = 0.0;\n\n \tfShade = acos( VdotL ) * (1.0 / PI);\n \n \tfloat fCosSunRadius = GetCosSunRadius();\n \n \tfShade = max( 0.0, (fShade - fCosSunRadius) / (1.0 - fCosSunRadius) ); \n \n \tfShade = GetSunIntensity() / max( 0.0001, pow(fShade, 1.5) );\n \n \tvec3 vColor = vec3(0.0);\n vColor += GetSkyColor( vViewDir );\n \n vColor += vec3( fShade * gSunColor );\n return vColor;\n}\n\n\n#define g_backdropSegments \t\t\t32.0\n#define g_backdropSlices \t\t\t16.0\n#define g_backdropQuads \t\t\t( g_backdropSegments * g_backdropSlices )\n#define g_backdropVertexCount \t\t( g_backdropQuads * 6.0 )\n\n\nvoid GenerateBackdropVertex( const float vertexIndex, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{\n vec2 vBackdropDim = vec2( g_backdropSegments, g_backdropSlices );\n \n \tvec2 vQuadTileIndex;\n vec2 vUV; \n \tGetQuadTileInfo( vertexIndex, vBackdropDim, vQuadTileIndex, vUV );\n\n float fSlicePos = 0.0;\n \n \tfloat fSunMeshPinch = 5.0;\n \n \tif (vUV.y > 0.0)\n {\n \tfloat t = pow( vUV.y, fSunMeshPinch );\n \t\tfloat fCosSunRadius = GetCosSunRadius();\n \tfSlicePos = fCosSunRadius + t * (1.0- fCosSunRadius);\n }\n \n \tvec3 vSpherePos;\n \tfloat fElevation = fSlicePos * PI;\n \tvSpherePos.z = cos( fElevation );\n\n \tfloat fHeading = vUV.x * PI * 2.0;\n \tfloat fSliceRadius = sqrt( 1.0 - vSpherePos.z * vSpherePos.z );\n \tvSpherePos.x = sin( fHeading ) * fSliceRadius;\n \tvSpherePos.y = cos( fHeading ) * fSliceRadius;\n \n\tmat3 m;\n \n \tGetMatrixFromZ( GetSunDir(), m );\n \n \tvec3 vLocalSpherePos = m * vSpherePos;\n\n \tfloat fBackdropDistance = g_cameraFar; \n \tvec3 vWorldSpherePos = vLocalSpherePos * fBackdropDistance;\n\n \tvWorldSpherePos += vCameraPos;\n \n outSceneVertex.vWorldPos = vWorldSpherePos;\n \n \toutSceneVertex.vColor = GetBackdropColor( vLocalSpherePos );\n\n \toutSceneVertex.fAlpha = 1.0;\n} \n\n\n#define g_cubeFaces\t\t\t\t\t6.0\n#define g_cubeVerticesPerFace\t\t( g_cubeFaces * 2.0 * 3.0 )\n#define g_cubeVertexCount \t\t\t( g_cubeVerticesPerFace * g_cubeFaces )\n\n// 6 7\n// +----------+\n// /| /|\n// 2 / | 3/ |\n// +----------+ |\n// | | | |\n// Y Z | 4| | 5|\n// | +-------|--+\n// ^ / | / | /\n// |/ 0|/ 1|/\n// +--> X +----------+\n \nvec3 GetCubeVertex( float fVertexIndex )\n{\n\tvec3 fResult = vec3( 1.0 );\n \n \tfloat f = fVertexIndex / 8.0;\n \tif ( fract( f * 4.0 ) < 0.5 )\n {\n \tfResult.x = -fResult.x;\n }\n \n \tif ( fract( f * 2.0 ) < 0.5 )\n {\n \tfResult.y = -fResult.y;\n }\n\n \tif ( fract( f ) < 0.5 )\n {\n \tfResult.z = -fResult.z;\n }\n \n \treturn fResult;\n}\n\n\nvoid GetCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, out vec3 vWorldPos, out vec3 vWorldNormal )\n{\n \tfloat fFaceIndex = floor( vertexIndex / g_cubeFaces );\n\n \tvec3 v0, v1, v2, v3;\n \n \tif ( fFaceIndex < 0.5 )\n {\n \tv0 = GetCubeVertex( 0.0 );\n \tv1 = GetCubeVertex( 2.0 );\n \tv2 = GetCubeVertex( 3.0 );\n \tv3 = GetCubeVertex( 1.0 );\n }\n \telse if ( fFaceIndex < 1.5 )\n {\n \tv0 = GetCubeVertex( 5.0 );\n \tv1 = GetCubeVertex( 7.0 );\n \tv2 = GetCubeVertex( 6.0 );\n \tv3 = GetCubeVertex( 4.0 );\n }\n \telse if ( fFaceIndex < 2.5 )\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 3.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 5.0 );\n }\n \telse if ( fFaceIndex < 3.5 )\n {\n \tv0 = GetCubeVertex( 4.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 2.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \telse if ( fFaceIndex < 4.5 )\n {\n \tv0 = GetCubeVertex( 2.0 );\n \tv1 = GetCubeVertex( 6.0 );\n \tv2 = GetCubeVertex( 7.0 );\n \tv3 = GetCubeVertex( 3.0 );\n }\n \telse\n {\n \tv0 = GetCubeVertex( 1.0 );\n \tv1 = GetCubeVertex( 5.0 );\n \tv2 = GetCubeVertex( 4.0 );\n \tv3 = GetCubeVertex( 0.0 );\n }\n \n \tv0 = v0 * mRot + vTrans;\n \tv1 = v1 * mRot + vTrans;\n \tv2 = v2 * mRot + vTrans;\n \tv3 = v3 * mRot + vTrans;\n \n \tfloat fFaceVertexIndex = mod( vertexIndex, 6.0 );\n \n \tif ( fFaceVertexIndex < 0.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 1.5 )\n {\n\t \tvWorldPos = v1;\n }\n \telse if ( fFaceVertexIndex < 2.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse if ( fFaceVertexIndex < 3.5 )\n {\n\t \tvWorldPos = v0;\n }\n \telse if ( fFaceVertexIndex < 4.5 )\n {\n\t \tvWorldPos = v2;\n }\n \telse\n {\n\t \tvWorldPos = v3;\n }\n \n \tvWorldNormal = normalize( cross( v1 - v0, v2 - v0 ) ); \n}\n\n\nvec3 GetSunLighting( const vec3 vNormal )\n{\n \tvec3 vLight = -GetSunDir();\n \n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \t \n \treturn gSunColor * NdotL;\n}\n\n\nvec3 GetSunSpec( const vec3 vPos, const vec3 vNormal, const vec3 vCameraPos )\n{\n \tvec3 vLight = -GetSunDir();\n\n \tvec3 vView = normalize( vCameraPos - vPos );\n \n \tvec3 vH = normalize( vView - vLight );\n \n \tfloat NdotH = max( 0.0, dot( vNormal, vH ) );\n \tfloat NdotL = max( 0.0, dot( vNormal, -vLight ) );\n \n \tfloat f = mix( 0.01, 1.0, pow( 1.0 - NdotL, 5.0 ) );\n \n \treturn gSunColor * pow( NdotH, 20.0 ) * NdotL * f * 4.0;\n}\n\n\nvec3 GetSkyLighting( const vec3 vNormal )\n{\n \tvec3 vSkyLight = normalize( vec3( -1.0, -2.0, -0.5 ) );\n \n \tfloat fSkyBlend = vNormal.y * 0.5 + 0.5;\n \n \treturn mix( gSkyBottom, gSkyTop, fSkyBlend );\n}\n\n\nvoid GenerateCubeVertex( const float vertexIndex, const mat3 mRot, const vec3 vTrans, const vec3 vCubeCol, const float fStage, const vec3 vCameraPos, out SceneVertex outSceneVertex )\n{ \n \tvec3 vNormal;\n \n\tGetCubeVertex( vertexIndex, mRot, vTrans, outSceneVertex.vWorldPos, vNormal );\n \n \toutSceneVertex.vColor = vec3( 0.0 );\n \n \toutSceneVertex.fAlpha = 1.0; \n \n \tfloat h = outSceneVertex.vWorldPos.y - gFloorHeight;\n \tif ( fStage < 0.5 )\n {\n\t outSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor *= mix( 1.0, fAOAmount, clamp( h, 0.0, 1.0 ) );\n \n \t\toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= vCubeCol; \n \n \toutSceneVertex.vColor += GetSunSpec( outSceneVertex.vWorldPos, vNormal, vCameraPos );\n }\n \telse\n {\n \tvec3 vSunDir = GetSunDir();\n \toutSceneVertex.vWorldPos.x += h * -vSunDir.x;\n \toutSceneVertex.vWorldPos.z += h * -vSunDir.z;\n \toutSceneVertex.vWorldPos.y = gFloorHeight;\n \n outSceneVertex.vColor += GetSkyLighting( normalize(vec3(1.0, 1.0, 0.0)) );\n\n \toutSceneVertex.vColor *= gFloorColor;\n } \n}\n\n\nvoid ApplyFog( const vec3 vCameraPos, inout SceneVertex sceneVertex )\n{\n \tvec3 vViewOffset = sceneVertex.vWorldPos - vCameraPos;\n \tfloat fDist = length( vViewOffset );\n \n \tvec3 vViewDir = normalize( vViewOffset );\n \n \tfloat fFogBlend = exp2( fDist * -gFogDensity );\n \n \tvec3 vFogColor = GetBackdropColor( vViewDir );\n \n \tsceneVertex.vColor = mix( vFogColor, sceneVertex.vColor, fFogBlend );\n}\n\n\n#define g_floorTileX 16.0\n#define g_floorTileY 16.0\n#define g_floorTileCount ( g_floorTileX * g_floorTileY )\n#define g_floorVertexCount ( g_floorTileCount * 6.0 )\n\nvoid GenerateFloorVertex( const float vertexIndex, out SceneVertex outSceneVertex )\n{\n \tvec2 vDim = vec2( g_floorTileX, g_floorTileY );\n \tvec2 vQuadTileIndex;\n \tvec2 vQuadUV;\n \n\tGetQuadTileInfo( vertexIndex, vDim, vQuadTileIndex, vQuadUV ); \n\n \toutSceneVertex.vWorldPos.xz = (vQuadUV * 2.0 - 1.0) * 1000.0;\n \toutSceneVertex.vWorldPos.y = gFloorHeight - 0.01;\n \toutSceneVertex.fAlpha = 1.0;\n \toutSceneVertex.vColor = vec3(0.0);\n\n \tvec3 vNormal = vec3( 0.0, 1.0, 0.0 );\n \toutSceneVertex.vColor += GetSkyLighting( vNormal );\n \toutSceneVertex.vColor += GetSunLighting( vNormal );\n \n \toutSceneVertex.vColor *= gFloorColor;\n}\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p)\n{\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n\nmat3 RotMatrixY( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, 0.0, s, \n 0.0, 1.0, 0.0,\n -s, 0.0, c );\n \n}\n\n\nmat3 RotMatrixZ( float fAngle )\n{\n float s = sin( fAngle );\n float c = cos( fAngle );\n \t\n return mat3( c, s, 0.0, \n -s, c, 0.0,\n 0.0, 0.0, 1.0 );\n \n}\n\nvoid GetCubePosition( float fCubeId, out mat3 mCubeRot, out vec3 vCubeOrigin, out vec3 vCubeCol )\n{ \n \tfloat fSeed = fCubeId;\n \tfloat fPositionBase = fCubeId;\n#ifdef MOVE_OUTWARDS\n \tfSeed -= floor(time);\n \tfPositionBase += mod(time, 1.0);\n#endif \n \tfloat fSize = hash(fSeed * 1.234);\n \tfSize = fSize * fSize;\n\n \tvCubeOrigin = vec3( 0.0, 0.0, 0.0 );\n\n\t\n float r = sqrt(fPositionBase) * 1.987;\n \tfloat fTheta = r * (0.3 * PI * 2.0);//log2(r) * 10.0;\n vCubeOrigin.x = sin(fTheta) * r;\n vCubeOrigin.z = cos(fTheta) * r;\n \n float fScale = fSize * 0.5 + 0.5;\n \n#ifdef MOVE_OUTWARDS\n \tfScale *= clamp(r , 0.0, 1.0);\n#endif \n \n \tfloat roll = 0.0;\n#ifdef WALK\n \troll = r * PI * 2.0 * fScale;\n#endif\n \n \tmCubeRot = RotMatrixZ(roll);\n \tmCubeRot *= RotMatrixY(fTheta);\n mCubeRot *= fScale;\n \t\n \tfloat fMinY = 10.0;\n \t\n \tfloat f = 0.0;\n \tfor( int i=0; i<8; i++)\n {\n \tvec3 vert = GetCubeVertex(f) * mCubeRot;\n\t \tfMinY = min( fMinY, vert.y );\n \tf+= 1.0;\n }\n \n \tvCubeOrigin.y = gFloorHeight;\n \tvCubeOrigin.y += -fMinY;\n \n \tfloat jump = 0.0;\n\n \tfloat o = 10.0 / 240.0;\n \tfloat v = 0.0;\n float a = 0.011;\n \n \tfor(int i=0; i<10; i++)\n {\n float off = -0.1;\n float spread = 0.4; \n float speed = 0.001;\n \n float snd = texture2D(sound, vec2(off + spread * fSize, r * speed + o)).a;\n\n \tsnd = snd * snd * (1.0 + 0.5 * (1.0 - fSize));\n \n \to = o - (1.5 / 240.0);\n \n \tv = v - 0.04;\n \ta = a * 1.4;\n \tv += snd * a;\n \tjump = jump + v;\n \n \tif( jump < 0.0)\n {\n \tv = 0.0;\n \tjump = 0.0;\n }\n }\n\n \tvCubeOrigin.y += jump * 8.0;\n \n \tvec3 vRandCol;\n \tvRandCol.x = hash( fSeed );\n \tvRandCol.y = hash( fSeed * 1.234);\n \tvRandCol.z = hash( fSeed * 2.345);\n \n \tvCubeCol = mix( gCubeColor, vRandCol, gCubeColorRandom );\n}\n\n\nvoid main()\n{ \n \tSceneVertex sceneVertex;\n \n \tvec2 vMouse = mouse;\n \n \tfloat fov = 1.5;\n \n \tfloat fMouseX = (vMouse.x * 0.5 + 0.5);\n \tfMouseX = fMouseX * fMouseX;\n \n \tfloat animTime = time;\n \n \tfloat orbitAngle = animTime * 0.3456 + 4.0;\n \tfloat elevation = -0.02 + (sin(animTime * 0.223 - PI * 0.5) * 0.5 + 0.5) * 0.5;\n \tfloat fOrbitDistance = 5.0 + (cos(animTime * 0.2345) * 0.5 + 0.5 ) * 40.0;\n \n \tvec3 vCameraTarget = vec3( 0.0, 1.0, 0.0 );\n \tvec3 vCameraPos = vCameraTarget + vec3( sin(orbitAngle) * cos(elevation), sin(elevation), cos(orbitAngle) * cos(elevation) ) * fOrbitDistance;\n \tvec3 vCameraUp = vec3( 0.1, 1.0, 0.0 );\n \n \tif( false )\n {\n vCameraPos = vec3( 10.0, 8.0, 30.0 );\n vCameraTarget = vec3( 0.0, 0.0, 0.0 );\n vCameraUp = vec3( 0.0, 1.0, 0.0);\n }\n \n \tvec3 vCameraForwards = normalize(vCameraTarget - vCameraPos);\n \n \tmat3 mCamera;\n GetMatrixFromZY( vCameraForwards, normalize(vCameraUp), mCamera );\n \n \tfloat vertexIndex = vertexId;\n \n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_backdropVertexCount )\n {\n \tGenerateBackdropVertex( vertexIndex, vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_backdropVertexCount;\n \n \tif ( vertexIndex >= 0.0 && vertexIndex < g_floorVertexCount )\n {\n \tGenerateFloorVertex( vertexIndex, sceneVertex );\n\t \tApplyFog( vCameraPos, sceneVertex );\n }\n \tvertexIndex -= g_floorVertexCount;\n \n \tif ( vertexIndex >= 0.0 )\n {\n float fCubeIndex = floor( vertexIndex / g_cubeVertexCount );\n float fCubeStage = mod( fCubeIndex, 2.0 );\n float fCubeId = floor(fCubeIndex / 2.0);\n float fCubeVertex = mod( vertexIndex, g_cubeVertexCount );\n\n {\n \tmat3 mCube;\n \tvec3 vCubeOrigin;\n \tvec3 vCubeCol;\n \t\n\t GetCubePosition( fCubeId, mCube, vCubeOrigin, vCubeCol );\n\n GenerateCubeVertex( fCubeVertex, mCube, vCubeOrigin, vCubeCol, fCubeStage, vCameraPos, sceneVertex );\n\t\t \tApplyFog( vCameraPos, sceneVertex );\n\n fCubeId += 1.0;\n }\n }\n\n\n // Fianl output position\n\tvec3 vViewPos = sceneVertex.vWorldPos;\n vViewPos -= vCameraPos;\n \tvViewPos = vViewPos * mCamera;\n \t\n \tvec2 vFov = vec2( 1.0, resolution.x / resolution.y ) * fov;\n \tvec2 vScreenPos = vViewPos.xy * vFov;\n\n\tgl_Position = vec4( vScreenPos.xy, -1.0, vViewPos.z );\n \n \t// Final output color\n \tfloat fExposure = min( gExposure, time * 0.1 );\n \tvec3 vFinalColor = sqrt( vec3(1.0) - exp2( sceneVertex.vColor * -fExposure ) );\n \n \tv_color = vec4(vFinalColor * sceneVertex.fAlpha, sceneVertex.fAlpha); \n}" + }, "screenshotURL": "data/images/images-r5sbnqd4l5gnfjql2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zWDcosC8feevNhZNA/art.json b/art/zWDcosC8feevNhZNA/art.json index 79fd2c9e..9fd37c11 100644 --- a/art/zWDcosC8feevNhZNA/art.json +++ b/art/zWDcosC8feevNhZNA/art.json @@ -32,7 +32,19 @@ "unlisted": true, "username": "zugzwang404", "avatarUrl": "https://secure.gravatar.com/avatar/fec4f7164a172e58419d6bff6d7368b3?default=retro&size=200", - "settings": "{\"num\":78100,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/firstedition/ronzel-touch-me\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// inspired by ??\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0.2,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, s-1.,\\n 0.3, 1, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 1, 1, 0, 0,\\n 1.2, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 1, -1, 0, 0,\\n 0, 0.1, 1, 0,\\n 0, 0, 0, 4.1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0.1, 0.1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0.6,\\n 0, -\\n s, 0.04, 0,\\n 0, 1, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 1.5 - 0.5 * fov);\\n float rangeInv = 2.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 1, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 1,\\n zAxis, 1,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 - b08 * a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 / a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 / a32 * b00,\\n a20 / b03 - a21 * b01 + a22 * b01) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, -0.2,\\n yAxis, 0.03,\\n zAxis, 0.002,\\n -dot(xAxis, eye /84.), -dot(yAxis, eye -2.), -dot(zAxis * mouse.x, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.2 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 0.2, vy);\\n float a = mix(start, end, u) * PI * 13. - PI * 1.20;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s - v;\\n float z = -0.2;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 12.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-2., 1., step(0.5, mod(circleId, 4.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = 1. - cgv;\\n \\n \\n float gAcross = floor(sqrt(numGroups));\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.5) / 2.6,// + mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.4) / 2.1,\\n cgv) * 0.7;\\n\\n float tm = time - cgv * 1.2;\\n float su = hash(groupId);\\n float snd2 = 0.1; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\\n float snd = texture2D(sound, vec2(\\n mix(0.5, 0.02, gv), \\n cgv * 0.25)).a;\\n \\n\\n vec3 pos;\\n float inner = .95;\\n float start = 1.2;\\n float end = 5.;\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n \\n float aspect = resolution.y / resolution.x;\\n mat4 mat = ident();\\n mat *= scale(vec3(aspect, 0.9, 0.01) * .3*snd);\\n mat *= rotZ(time * 0.1 * mix(1., 0.3, mod(groupId, 3.)));\\n mat *= trans(vec3(offset));\\n float gt = time - gv * PI * 9.;\\n mat *= trans(vec3(sin(gt), cos(gt), 1.31) * .095 * (2.3 - cgv * 1.25));\\n mat *= uniformScale(0.13 * cgv + snd * 1.1);\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 0.83 + snd);\\n gl_PointSize = 4.;\\n \\n float pump = step(1.5, snd);\\n float hue = 1. + cgId * 1.6 + pump * 10.7;\\n float sat = mod(cgId, 1.) + pump;\\n float val = 1. - mod(cgId + .5, 3.);\\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\\n v_color.rgb = mix(v_color.rgb, vec3(0.84)+pump, 5.*pump);\\n v_color.rgb *= v_color.a /1./snd;\\n}\\n\\n\"}", + "settings": { + "num": 78100, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/firstedition/ronzel-touch-me", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// inspired by ??\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0.2,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, s-1.,\n 0.3, 1, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 1, 1, 0, 0,\n 1.2, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 1, -1, 0, 0,\n 0, 0.1, 1, 0,\n 0, 0, 0, 4.1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0.1, 0.1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0.6,\n 0, -\n s, 0.04, 0,\n 0, 1, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 1.5 - 0.5 * fov);\n float rangeInv = 2.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 1, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 1,\n zAxis, 1,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 - b08 * a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 / a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 / a32 * b00,\n a20 / b03 - a21 * b01 + a22 * b01) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, -0.2,\n yAxis, 0.03,\n zAxis, 0.002,\n -dot(xAxis, eye /84.), -dot(yAxis, eye -2.), -dot(zAxis * mouse.x, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.2 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 0.2, vy);\n float a = mix(start, end, u) * PI * 13. - PI * 1.20;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s - v;\n float z = -0.2;\n pos = vec3(x, y, z); \n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 12.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-2., 1., step(0.5, mod(circleId, 4.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = 1. - cgv;\n \n \n float gAcross = floor(sqrt(numGroups));\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.5) / 2.6,// + mod(gy, 2.) * 0.5,\n gy - (gDown - 1.4) / 2.1,\n cgv) * 0.7;\n\n float tm = time - cgv * 1.2;\n float su = hash(groupId);\n float snd2 = 0.1; //texture2D(sound, vec2(mix(0.001, 0.021, abs(atan(offset.x, offset.y) / PI )), length(offset) * 0.1)).a;\n float snd = texture2D(sound, vec2(\n mix(0.5, 0.02, gv), \n cgv * 0.25)).a;\n \n\n vec3 pos;\n float inner = .95;\n float start = 1.2;\n float end = 5.;\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n \n float aspect = resolution.y / resolution.x;\n mat4 mat = ident();\n mat *= scale(vec3(aspect, 0.9, 0.01) * .3*snd);\n mat *= rotZ(time * 0.1 * mix(1., 0.3, mod(groupId, 3.)));\n mat *= trans(vec3(offset));\n float gt = time - gv * PI * 9.;\n mat *= trans(vec3(sin(gt), cos(gt), 1.31) * .095 * (2.3 - cgv * 1.25));\n mat *= uniformScale(0.13 * cgv + snd * 1.1);\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 0.83 + snd);\n gl_PointSize = 4.;\n \n float pump = step(1.5, snd);\n float hue = 1. + cgId * 1.6 + pump * 10.7;\n float sat = mod(cgId, 1.) + pump;\n float val = 1. - mod(cgId + .5, 3.);\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 0.5);\n v_color.rgb = mix(v_color.rgb, vec3(0.84)+pump, 5.*pump);\n v_color.rgb *= v_color.a /1./snd;\n}\n\n" + }, "screenshotURL": "data/images/images-mn76s9i2o68uzy9u5-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zbFojAK3PQ5p2yLSM/art.json b/art/zbFojAK3PQ5p2yLSM/art.json index 325ead31..600c4ee6 100644 --- a/art/zbFojAK3PQ5p2yLSM/art.json +++ b/art/zbFojAK3PQ5p2yLSM/art.json @@ -32,7 +32,19 @@ "unlisted": false, "username": "leodars", "avatarUrl": "https://secure.gravatar.com/avatar/4cb6f7468a7063cf9d0e6efeaa134438?default=retro&size=200&d=https%3A%2F%2Fsecure.gravatar.com%2Favatar%2F4b7261fd1e30fe7006e6eb1c0300c662", - "settings": "{\"num\":1000,\"mode\":\"POINTS\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\n\\nvoid main() {\\n float down = floor(sqrt(vertexCount));\\n float across = floor(vertexCount / down);\\n \\n \\n float x = mod(vertexId, across);\\n float y = floor(vertexId / across);\\n \\n float u = x / (across - 1.);\\n float v = y / (across - 1.);\\n \\n float xoff = 0.;\\t\\t// sin(time + y * 0.2) * 0.1;\\n float yoff = 0.;\\t\\t// sin(time + x * 0.3) * 0.2;\\n \\n float ux = u * 2. - 1. + xoff;\\n float vy = v * 2. - 1. + yoff;\\n \\n vec2 xy = vec2(ux, vy) * 1.0;\\n \\n gl_Position = vec4(xy, 0, 1);\\n \\n float soff = 0.;\\t\\t// sin(time + x * y * 0.02) * 5.;\\n \\n gl_PointSize = 15.0 + soff;\\n gl_PointSize *= 20. / across;\\n gl_PointSize *= resolution.x / 600.;\\n \\n float hue = u;\\n float sat = 1.;\\n float val = 1.;\\n \\n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\\n \\n}\"}", + "settings": { + "num": 1000, + "mode": "POINTS", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\n\nvoid main() {\n float down = floor(sqrt(vertexCount));\n float across = floor(vertexCount / down);\n \n \n float x = mod(vertexId, across);\n float y = floor(vertexId / across);\n \n float u = x / (across - 1.);\n float v = y / (across - 1.);\n \n float xoff = 0.;\t\t// sin(time + y * 0.2) * 0.1;\n float yoff = 0.;\t\t// sin(time + x * 0.3) * 0.2;\n \n float ux = u * 2. - 1. + xoff;\n float vy = v * 2. - 1. + yoff;\n \n vec2 xy = vec2(ux, vy) * 1.0;\n \n gl_Position = vec4(xy, 0, 1);\n \n float soff = 0.;\t\t// sin(time + x * y * 0.02) * 5.;\n \n gl_PointSize = 15.0 + soff;\n gl_PointSize *= 20. / across;\n gl_PointSize *= resolution.x / 600.;\n \n float hue = u;\n float sat = 1.;\n float val = 1.;\n \n v_color = vec4(hsv2rgb(vec3(hue, sat, val)), 1);\n \n}" + }, "screenshotURL": "data/images/images-yzxwy965gh6cahy7u-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zd2E5vCZduc5JeoFz/art.json b/art/zd2E5vCZduc5JeoFz/art.json index 84dbb355..88b5cee3 100644 --- a/art/zd2E5vCZduc5JeoFz/art.json +++ b/art/zd2E5vCZduc5JeoFz/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "gman", "avatarUrl": "https://secure.gravatar.com/avatar/dcc0309895c3d6db087631813efaa9d1?default=retro&size=200", - "settings": "{\"num\":100000,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/wearethebraveofficial/alan-fitzpatrick-friday-night-dancing-skream-remix\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/* 🐧\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n*/\\n\\n\\n\\n\\n#define PI radians(180.0)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvec3 getQuadStripPoint(const float id) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\\n return vec3(ux, vy, 0);\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5);\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0)).xyz;\\n}\\n\\nfloat Hash( vec2 p) {\\n vec3 p2 = vec3(p.xy,1.0);\\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\\n}\\n\\nfloat noise(in vec2 p) {\\n vec2 i = floor(p);\\n vec2 f = fract(p);\\n f *= f * (3.0-2.0*f);\\n\\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\\n f.y);\\n}\\n\\nfloat fbm(vec2 p) {\\n float v = 0.0;\\n v += noise(p*1.0)*.5;\\n// v += noise(p*2.)*.25;\\n// v += noise(p*4.)*.125;\\n return v;\\n}\\n\\nfloat crv(float v) {\\n return fbm(vec2(v, v * 1.23));\\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \\n //return o / 4.;\\n}\\n\\nvec3 fgetCurvePoint(float t) {\\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\\n return vec3(\\n crv(t),\\n crv(t + .3),\\n crv(t + .6)\\n ) * 2. - 1.;\\n} \\n\\nvec3 getCurvePoint(const float id) {\\n return vec3(\\n sin(id * 0.99),\\n sin(id * 2.43),\\n sin(id * 1.57));\\n}\\n\\nconst float expand = 80.0;\\n\\n\\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\\n float starId = floor(vertexId / 3.);\\n float numStars = floor(vertexCount / 3.);\\n float starV = starId / numStars;\\n \\n float h = hash(starId * 0.017);\\n \\n \\n float pId = mod(vertexId, 3.);\\n //float sz = h * 2.;\\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \\n \\n pos = normalize(vec3(\\n t2m1(hash(starId * 0.123)),\\n t2m1(hash(starId * 0.353)),\\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\\n pos += cmat[0].xyz * sz * step(0.5, pId);\\n pos += cmat[1].xyz * sz * step(1.5, pId);\\n \\n color = vec4(h, h, h, 1);\\n}\\n\\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\\n vec3 cpos;\\n vec3 cnormal;\\n \\n float pointId = vertexId;\\n getCubePoint(pointId, cpos, cnormal);\\n float cubeId = floor(pointId / 36.);\\n float numCubes = floor(vertexCount / 36.);\\n float down = floor(pow(numCubes, .333));\\n float across = floor(floor(numCubes / down) / down);\\n float deep = floor(numCubes / (down * across));\\n \\n float cx = mod(cubeId, across);\\n float cy = mod(floor(cubeId / across) , down);\\n float cz = floor(cubeId / (across * down));\\n \\n float cu = cx / (across - 1.);\\n float cv = cy / (down - 1.);\\n float cw = cz / (deep - 1.);\\n \\n float ca = cu * 2. - 1.;\\n float cd = cv * 2. - 1.;\\n float ce = cw * 2. - 1.;\\n \\n float tm = time * 0.1;\\n mat4 mat = ident();\\n \\n const float dim = 640.0;\\n vec3 t = vec3(\\n hash(cubeId * 0.123),\\n hash(cubeId * 0.719),\\n hash(cubeId * 0.347)) * 2. - 1.;\\n \\n \\n \\n float s = texture2D(sound, vec2(\\n mix(0.01, 0.5, hash(cubeId * 0.379)),\\n length(t) * .05)).a;\\n\\n float pump = step(0.7, s);\\n \\n \\n \\n #if 0\\n mat *= trans(vec3(ca, ce, cd) * 120.0);\\n mat *= uniformScale(2.);\\n #else\\n mat *= trans(t * dim * .5);\\n mat *= rotX(time * 1. + cubeId);\\n mat *= rotZ(time * 1.1 + cubeId);\\n mat *= uniformScale(mix(4., 20. + pump * 20., pow(s, 5.)));\\n #endif\\n \\n pos = (mat * vec4(cpos, 1)).xyz;\\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\\n \\n \\n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\\n float sat = 1.;mix(1., 0., abs(ca));\\n float val = 1.;mix(1., 0.5, abs(cd));\\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\\n \\n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\\n vec3 lightPos = vec3(0);\\n vec3 surfaceToLight = normalize(lightPos - pos);\\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\\n \\n float light = dot(n, surfaceToLight);\\n float specular = pow(clamp(dot(n, halfVector), 0., 1.), 20.);\\n \\n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \\n color = vec4(tcolor * light + vec3(specular), 1); \\n \\n color.a = mix(1., 10., pump);\\n color.rgb *= color.a;\\n}\\n\\nvoid main() {\\n const float numCubePoints = 90000.0;\\n \\n //float base = 15.; // good place to adjust\\n float base = time * 0.125;\\n\\n const float coff = 0.14;\\n \\n vec3 b0 = getCurvePoint(base + coff * 0.);\\n vec3 b1 = getCurvePoint(base + coff * 1.);\\n vec3 b2 = getCurvePoint(base + coff * 2.);\\n \\n vec3 c0 = normalize(b1 - b0);\\n vec3 c1 = normalize(b2 - b1);\\n \\n vec3 czaxis = normalize(c1 - c0);\\n vec3 cxaxis = normalize(cross(c0, c1));\\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\\n \\n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\\n\\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \\n \\n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\\n vec3 up = cyaxis;\\n \\n // eye = vec3(1, 1, 1);\\n// target = vec3(0);\\n// up = vec3(0,1,0);\\n \\n mat4 cmat = lookAt(eye, target, up);\\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\\n \\n vec3 pos;\\n vec4 color;\\n \\n if (vertexId < numCubePoints) {\\n cube(vertexId, vertexCount, base, cmat, vmat, pos, color);\\n } else {\\n sky(vertexId, vertexCount, base, cmat, pos, color);\\n }\\n \\n gl_Position = pmat * vmat * vec4(pos, 1);\\n v_color = color;\\n \\n float cz = gl_Position.z / gl_Position.w * .5 + .5;\\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \\n \\n}\\n\"}", + "settings": { + "num": 100000, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/wearethebraveofficial/alan-fitzpatrick-friday-night-dancing-skream-remix", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/* 🐧\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n*/\n\n\n\n\n#define PI radians(180.0)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvec3 getQuadStripPoint(const float id) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.);\n return vec3(ux, vy, 0);\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5);\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0)).xyz;\n}\n\nfloat Hash( vec2 p) {\n vec3 p2 = vec3(p.xy,1.0);\n return fract(sin(dot(p2,vec3(37.1,61.7, 12.4)))*3758.5453123);\n}\n\nfloat noise(in vec2 p) {\n vec2 i = floor(p);\n vec2 f = fract(p);\n f *= f * (3.0-2.0*f);\n\n return mix(mix(Hash(i + vec2(0.,0.)), Hash(i + vec2(1.,0.)),f.x),\n mix(Hash(i + vec2(0.,1.)), Hash(i + vec2(1.,1.)),f.x),\n f.y);\n}\n\nfloat fbm(vec2 p) {\n float v = 0.0;\n v += noise(p*1.0)*.5;\n// v += noise(p*2.)*.25;\n// v += noise(p*4.)*.125;\n return v;\n}\n\nfloat crv(float v) {\n return fbm(vec2(v, v * 1.23));\n //float o = sin(v) + sin(v * 2.1) + sin(v * 4.2) + sin(v * 8.9); \n //return o / 4.;\n}\n\nvec3 fgetCurvePoint(float t) {\n// return vec3(sin(-t), sin(t * 0.8), sin(t * 0.6));\n// return vec3( mod(t, 1.) * 0.01, 0, mod(t, 1.));\n return vec3(\n crv(t),\n crv(t + .3),\n crv(t + .6)\n ) * 2. - 1.;\n} \n\nvec3 getCurvePoint(const float id) {\n return vec3(\n sin(id * 0.99),\n sin(id * 2.43),\n sin(id * 1.57));\n}\n\nconst float expand = 80.0;\n\n\nvoid sky(const float vertexId, const float vertexCount, float base, const mat4 cmat, out vec3 pos, out vec4 color) {\n float starId = floor(vertexId / 3.);\n float numStars = floor(vertexCount / 3.);\n float starV = starId / numStars;\n \n float h = hash(starId * 0.017);\n \n \n float pId = mod(vertexId, 3.);\n //float sz = h * 2.;\n float sz = clamp(500.0 / min(resolution.x, resolution.y), 2., 200.); \n \n pos = normalize(vec3(\n t2m1(hash(starId * 0.123)),\n t2m1(hash(starId * 0.353)),\n t2m1(hash(starId * 0.627)))) * 500. + cmat[3].xyz;\n pos += cmat[0].xyz * sz * step(0.5, pId);\n pos += cmat[1].xyz * sz * step(1.5, pId);\n \n color = vec4(h, h, h, 1);\n}\n\nvoid cube(const float vertexId, const float vertexCount, const float base, const mat4 cmat, const mat4 vmat, out vec3 pos, out vec4 color) {\n vec3 cpos;\n vec3 cnormal;\n \n float pointId = vertexId;\n getCubePoint(pointId, cpos, cnormal);\n float cubeId = floor(pointId / 36.);\n float numCubes = floor(vertexCount / 36.);\n float down = floor(pow(numCubes, .333));\n float across = floor(floor(numCubes / down) / down);\n float deep = floor(numCubes / (down * across));\n \n float cx = mod(cubeId, across);\n float cy = mod(floor(cubeId / across) , down);\n float cz = floor(cubeId / (across * down));\n \n float cu = cx / (across - 1.);\n float cv = cy / (down - 1.);\n float cw = cz / (deep - 1.);\n \n float ca = cu * 2. - 1.;\n float cd = cv * 2. - 1.;\n float ce = cw * 2. - 1.;\n \n float tm = time * 0.1;\n mat4 mat = ident();\n \n const float dim = 640.0;\n vec3 t = vec3(\n hash(cubeId * 0.123),\n hash(cubeId * 0.719),\n hash(cubeId * 0.347)) * 2. - 1.;\n \n \n \n float s = texture2D(sound, vec2(\n mix(0.01, 0.5, hash(cubeId * 0.379)),\n length(t) * .05)).a;\n\n float pump = step(0.7, s);\n \n \n \n #if 0\n mat *= trans(vec3(ca, ce, cd) * 120.0);\n mat *= uniformScale(2.);\n #else\n mat *= trans(t * dim * .5);\n mat *= rotX(time * 1. + cubeId);\n mat *= rotZ(time * 1.1 + cubeId);\n mat *= uniformScale(mix(4., 20. + pump * 20., pow(s, 5.)));\n #endif\n \n pos = (mat * vec4(cpos, 1)).xyz;\n vec3 n = normalize((mat * vec4(cnormal, 0)).xyz);\n \n \n float hue = time * .03 + mix(1., 1.1, pump);//abs(ca * cd) * 2.;\n float sat = 1.;mix(1., 0., abs(ca));\n float val = 1.;mix(1., 0.5, abs(cd));\n vec3 tcolor = hsv2rgb(vec3(hue, sat, val));\n \n vec3 lightDir = normalize(vec3(0.3, 0.4, -1));\n vec3 lightPos = vec3(0);\n vec3 surfaceToLight = normalize(lightPos - pos);\n vec3 surfaceToView = normalize(cmat[3].xyz - pos);\n vec3 halfVector = normalize(surfaceToLight + surfaceToView);\n \n float light = dot(n, surfaceToLight);\n float specular = pow(clamp(dot(n, halfVector), 0., 1.), 20.);\n \n //color = vec4(tcolor * (dot(n, lightDir) * 0.5 + 0.5), 1); \n color = vec4(tcolor * light + vec3(specular), 1); \n \n color.a = mix(1., 10., pump);\n color.rgb *= color.a;\n}\n\nvoid main() {\n const float numCubePoints = 90000.0;\n \n //float base = 15.; // good place to adjust\n float base = time * 0.125;\n\n const float coff = 0.14;\n \n vec3 b0 = getCurvePoint(base + coff * 0.);\n vec3 b1 = getCurvePoint(base + coff * 1.);\n vec3 b2 = getCurvePoint(base + coff * 2.);\n \n vec3 c0 = normalize(b1 - b0);\n vec3 c1 = normalize(b2 - b1);\n \n vec3 czaxis = normalize(c1 - c0);\n vec3 cxaxis = normalize(cross(c0, c1));\n vec3 cyaxis = normalize(cross(czaxis, cxaxis));\n \n mat4 pmat = persp(radians(60.0), resolution.x / resolution.y, .1, 1000.0);\n\n vec2 ms = vec2(0); //texture2D(touch, vec2(0, 0)).xy + vec2(0, 1); \n \n vec3 eye = b0 * expand + cyaxis * .001 + czaxis * 2.2;\n vec3 target = b1 * expand + cyaxis * .002 + czaxis + ms.x * cxaxis * 2. + ms.y * cyaxis * 40.;\n vec3 up = cyaxis;\n \n // eye = vec3(1, 1, 1);\n// target = vec3(0);\n// up = vec3(0,1,0);\n \n mat4 cmat = lookAt(eye, target, up);\n mat4 vmat = rotZ(asin(up.y) * 1.) * inverse(cmat);\n \n vec3 pos;\n vec4 color;\n \n if (vertexId < numCubePoints) {\n cube(vertexId, vertexCount, base, cmat, vmat, pos, color);\n } else {\n sky(vertexId, vertexCount, base, cmat, pos, color);\n }\n \n gl_Position = pmat * vmat * vec4(pos, 1);\n v_color = color;\n \n float cz = gl_Position.z / gl_Position.w * .5 + .5;\n v_color.rgb = mix(v_color.rgb, background.rgb, mix(4., 0., cz)); \n \n}\n" + }, "screenshotURL": "data/images/images-92yttslpq6f0cneok-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zddxPxkny7JNAE7jK/art.json b/art/zddxPxkny7JNAE7jK/art.json index 159848b5..8a652d51 100644 --- a/art/zddxPxkny7JNAE7jK/art.json +++ b/art/zddxPxkny7JNAE7jK/art.json @@ -34,7 +34,19 @@ "unlisted": true, "username": "anuar", "avatarUrl": "https://graph.facebook.com/1812741555404077/picture?type=large", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/botanicsage/gooddaychr\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"void main()\\n{\\n float angleOffset = 5.0;\\n float theta = radians(mod(vertexId * angleOffset, 180.0));\\n float fi = radians(mod(floor(vertexId / (180.0 / angleOffset)) * angleOffset, 360.0));\\n \\n float x = sin(theta) * cos(fi);\\n float y = sin(theta) * sin(fi);\\n float z = cos(theta);\\n \\n vec3 pos = vec3(x, y, z) * (texture2D(sound, vec2(0.225, 0)).a);\\n \\n mat4 rotx = mat4(1.0);\\n rotx[1][1] = cos(time);\\n rotx[2][1] = -sin(time);\\n rotx[1][2] = sin(time);\\n rotx[2][2] = cos(time);\\n \\n mat4 rotz = mat4(1.0);\\n rotz[0][0] = cos(time);\\n rotz[1][0] = -sin(time);\\n rotz[0][1] = sin(time);\\n rotz[1][1] = cos(time);\\n \\n \\n gl_Position = rotz * rotx * vec4(pos, 1.0);\\n gl_PointSize = 2.0;\\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/botanicsage/gooddaychr", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "void main()\n{\n float angleOffset = 5.0;\n float theta = radians(mod(vertexId * angleOffset, 180.0));\n float fi = radians(mod(floor(vertexId / (180.0 / angleOffset)) * angleOffset, 360.0));\n \n float x = sin(theta) * cos(fi);\n float y = sin(theta) * sin(fi);\n float z = cos(theta);\n \n vec3 pos = vec3(x, y, z) * (texture2D(sound, vec2(0.225, 0)).a);\n \n mat4 rotx = mat4(1.0);\n rotx[1][1] = cos(time);\n rotx[2][1] = -sin(time);\n rotx[1][2] = sin(time);\n rotx[2][2] = cos(time);\n \n mat4 rotz = mat4(1.0);\n rotz[0][0] = cos(time);\n rotz[1][0] = -sin(time);\n rotz[0][1] = sin(time);\n rotz[1][1] = cos(time);\n \n \n gl_Position = rotz * rotx * vec4(pos, 1.0);\n gl_PointSize = 2.0;\n v_color = vec4(1.0, 0.0, 0.0, 1.0);\n}" + }, "screenshotURL": "data/images/images-m42fxiizo4pqj1hsu-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zmcNCBEkGnxZeWcer/art.json b/art/zmcNCBEkGnxZeWcer/art.json index 5a8b4bad..25e488c5 100644 --- a/art/zmcNCBEkGnxZeWcer/art.json +++ b/art/zmcNCBEkGnxZeWcer/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":15328,\"mode\":\"TRIANGLES\",\"sound\":\"https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\n\\n//KDrawmode=GL_TRIANGLES \\n//KVerticesNumber=38000\\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\\n#define KP2 2.//KParameter2 0.0>>5.\\n#define KP3 0.000//KParameter3 0.000>>0.5\\n#define KP4 0.0//KParameter4 0.000>>2.0\\n\\n#define PI radians(180.)\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nmat4 rotX(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n 1, 0, 0, 0,\\n 0, c, s, 0,\\n 0, -s, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 rotZ(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c,-s, 0, 0, \\n s, c, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1); \\n}\\n\\nmat4 trans(vec3 trans) {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n trans, 1);\\n}\\n\\nmat4 ident() {\\n return mat4(\\n 1, 0, 0, 0,\\n 0, 1, 0, 0,\\n 0, 0, 1, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 scale(vec3 s) {\\n return mat4(\\n s[0], 0, 0, 0,\\n 0, s[1], 0, 0,\\n 0, 0, s[2], 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 uniformScale(float s) {\\n return mat4(\\n s, 0, 0, 0,\\n 0, s, 0, 0,\\n 0, 0, s, 0,\\n 0, 0, 0, 1);\\n}\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 trInv(mat4 m) {\\n mat3 i = mat3(\\n m[0][0], m[1][0], m[2][0], \\n m[0][1], m[1][1], m[2][1], \\n m[0][2], m[1][2], m[2][2]);\\n vec3 t = -i * m[3].xyz;\\n \\n return mat4(\\n i[0], t[0], \\n i[1], t[1],\\n i[2], t[2],\\n 0, 0, 0, 1);\\n}\\n\\nmat4 transpose(mat4 m) {\\n return mat4(\\n m[0][0], m[1][0], m[2][0], m[3][0], \\n m[0][1], m[1][1], m[2][1], m[3][1],\\n m[0][2], m[1][2], m[2][2], m[3][2],\\n m[0][3], m[1][3], m[2][3], m[3][3]);\\n}\\n\\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\\n vec3 zAxis = normalize(eye - target);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n eye, 1);\\n}\\n\\nmat4 inverse(mat4 m) {\\n float\\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\\n\\n b00 = a00 * a11 - a01 * a10,\\n b01 = a00 * a12 - a02 * a10,\\n b02 = a00 * a13 - a03 * a10,\\n b03 = a01 * a12 - a02 * a11,\\n b04 = a01 * a13 - a03 * a11,\\n b05 = a02 * a13 - a03 * a12,\\n b06 = a20 * a31 - a21 * a30,\\n b07 = a20 * a32 - a22 * a30,\\n b08 = a20 * a33 - a23 * a30,\\n b09 = a21 * a32 - a22 * a31,\\n b10 = a21 * a33 - a23 * a31,\\n b11 = a22 * a33 - a23 * a32,\\n\\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\\n\\n return mat4(\\n a11 * b11 - a12 * b10 + a13 * b09,\\n a02 * b10 - a01 * b11 - a03 * b09,\\n a31 * b05 - a32 * b04 + a33 * b03,\\n a22 * b04 - a21 * b05 - a23 * b03,\\n a12 * b08 - a10 * b11 - a13 * b07,\\n a00 * b11 - a02 * b08 + a03 * b07,\\n a32 * b02 - a30 * b05 - a33 * b01,\\n a20 * b05 - a22 * b02 + a23 * b01,\\n a10 * b10 - a11 * b08 + a13 * b06,\\n a01 * b08 - a00 * b10 - a03 * b06,\\n a30 * b04 - a31 * b02 + a33 * b00,\\n a21 * b02 - a20 * b04 - a23 * b00,\\n a11 * b07 - a10 * b09 - a12 * b06,\\n a00 * b09 - a01 * b07 + a02 * b06,\\n a31 * b01 - a30 * b03 - a32 * b00,\\n a20 * b03 - a21 * b01 + a22 * b00) / det;\\n}\\n\\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\\n #if 1\\n return inverse(lookAt(eye, target, up));\\n #else\\n vec3 zAxis = normalize(target - eye);\\n vec3 xAxis = normalize(cross(up, zAxis));\\n vec3 yAxis = cross(zAxis, xAxis);\\n\\n return mat4(\\n xAxis, 0,\\n yAxis, 0,\\n zAxis, 0,\\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \\n #endif\\n \\n}\\n\\n\\n\\n// hash function from https://www.shadertoy.com/view/4djSRW\\nfloat hash(float p) {\\n\\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\\n\\treturn fract(p2.x * p2.y * 95.4337);\\n}\\n\\n// times 2 minus 1\\nfloat t2m1(float v) {\\n return v * 2. - 1.;\\n}\\n\\n// times .5 plus .5\\nfloat t5p5(float v) {\\n return v * 0.5 + 0.5;\\n}\\n\\nfloat inv(float v) {\\n return 1. - v;\\n}\\n\\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\\n float ux = floor(id / 6.) + mod(id, 2.);\\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\\n float u = ux / numEdgePointsPerCircle;\\n float v = mix(inner, 1., vy);\\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\\n float s = sin(a);\\n float c = cos(a +2. * KP1);\\n float x = c * v;\\n float y = s * v;\\n float z = 0.;\\n pos = vec3(x, y, z); \\n}\\n\\n\\n#define CUBE_POINTS_PER_FACE 6.\\n#define FACES_PER_CUBE 6.\\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\\n float sideId = mod(quadId, 3.);\\n float flip = mix(1., -1., step(2.5, quadId));\\n // 0 1 2 1 2 3\\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\\n float a = pointId * PI * 2. / 4. + PI * 0.25;\\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\\n vec3 n = vec3(0, 1, 0) * flip;\\n float lr = mod(sideId, 2.);\\n float ud = step(2., sideId);\\n mat4 mat = rotX(lr * PI * 0.5);\\n mat *= rotZ(ud * PI * 0.5) ;\\n position = (mat * vec4(p, 1)).xyz;\\n normal = (mat * vec4(n, 0.5)).xyz;\\n}\\n\\n\\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\\n#define NUM_CIRCLES_PER_GROUP 1.0\\nvoid main() {\\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\\n float sliceId = mod(floor(vertexId / 6.), 2.);\\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \\n float cu = circleId / numCircles;\\n float gv = groupId / numGroups/KP2;\\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\\n float ncgv = sin(.0 - cgv )/cu;\\n \\n float aspect = resolution.x / resolution.y;\\n float gAcross = floor(sqrt(numCircles) * aspect);\\n float gDown = floor(numGroups / gAcross);\\n float gx = mod(groupId, gAcross);\\n float gy = floor(groupId / gAcross);\\n vec3 offset = vec3(\\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\\n gy - (gDown - 1.) / 2.,\\n 0) * cos(0.17 + KP1);\\n \\n float gs = gx / gAcross-KP2;\\n float gt = (gy / gDown);\\n\\n float tm = time - cgv * (0.2 * KP3);\\n float su = hash(groupId);\\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \\n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \\n \\n \\n vec3 pos;\\n float inner = 0.+KP2;\\n float start = 0.;\\n float end = 1./sin(KP0-2.);\\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \\n pos.z = cgv,mouse.xy;\\n \\n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\\n \\n mat4 mat = scale(vec3(1, aspect, 1) * .2); \\n mat *= cameraLookAt(eye, target, up);\\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\\n \\n \\n mat *= trans(offset);\\n float h = t2m1(hash(gv));\\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\\n mat *= rotZ(PI * .25);\\n \\n gl_Position = mat * vec4(pos, 1);\\n gl_PointSize = 4.;\\n\\n float hue = 1. + cgId * 0.4;\\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\\n float val = 0.9;\\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\\n v_color.rgb *= v_color.a;\\n}\\n\"}", + "settings": { + "num": 15328, + "mode": "TRIANGLES", + "sound": "https://soundcloud.com/oktored/no-ref-v2?in=oktored/sets/rinse-n-repeat", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\n\n//KDrawmode=GL_TRIANGLES \n//KVerticesNumber=38000\n#define KP0 10.0 *mouse.x//KParameter0 0.>>10.\n#define KP1 3.0 * mouse.y//KParameter1 0.0>>5.\n#define KP2 2.//KParameter2 0.0>>5.\n#define KP3 0.000//KParameter3 0.000>>0.5\n#define KP4 0.0//KParameter4 0.000>>2.0\n\n#define PI radians(180.)\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nmat4 rotX(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n 1, 0, 0, 0,\n 0, c, s, 0,\n 0, -s, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nmat4 rotZ(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c,-s, 0, 0, \n s, c, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1); \n}\n\nmat4 trans(vec3 trans) {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n trans, 1);\n}\n\nmat4 ident() {\n return mat4(\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1);\n}\n\nmat4 scale(vec3 s) {\n return mat4(\n s[0], 0, 0, 0,\n 0, s[1], 0, 0,\n 0, 0, s[2], 0,\n 0, 0, 0, 1);\n}\n\nmat4 uniformScale(float s) {\n return mat4(\n s, 0, 0, 0,\n 0, s, 0, 0,\n 0, 0, s, 0,\n 0, 0, 0, 1);\n}\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 trInv(mat4 m) {\n mat3 i = mat3(\n m[0][0], m[1][0], m[2][0], \n m[0][1], m[1][1], m[2][1], \n m[0][2], m[1][2], m[2][2]);\n vec3 t = -i * m[3].xyz;\n \n return mat4(\n i[0], t[0], \n i[1], t[1],\n i[2], t[2],\n 0, 0, 0, 1);\n}\n\nmat4 transpose(mat4 m) {\n return mat4(\n m[0][0], m[1][0], m[2][0], m[3][0], \n m[0][1], m[1][1], m[2][1], m[3][1],\n m[0][2], m[1][2], m[2][2], m[3][2],\n m[0][3], m[1][3], m[2][3], m[3][3]);\n}\n\nmat4 lookAt(vec3 eye, vec3 target, vec3 up) {\n vec3 zAxis = normalize(eye - target);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n eye, 1);\n}\n\nmat4 inverse(mat4 m) {\n float\n a00 = m[0][0], a01 = m[0][1], a02 = m[0][2], a03 = m[0][3],\n a10 = m[1][0], a11 = m[1][1], a12 = m[1][2], a13 = m[1][3],\n a20 = m[2][0], a21 = m[2][1], a22 = m[2][2], a23 = m[2][3],\n a30 = m[3][0], a31 = m[3][1], a32 = m[3][2], a33 = m[3][3],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n return mat4(\n a11 * b11 - a12 * b10 + a13 * b09,\n a02 * b10 - a01 * b11 - a03 * b09,\n a31 * b05 - a32 * b04 + a33 * b03,\n a22 * b04 - a21 * b05 - a23 * b03,\n a12 * b08 - a10 * b11 - a13 * b07,\n a00 * b11 - a02 * b08 + a03 * b07,\n a32 * b02 - a30 * b05 - a33 * b01,\n a20 * b05 - a22 * b02 + a23 * b01,\n a10 * b10 - a11 * b08 + a13 * b06,\n a01 * b08 - a00 * b10 - a03 * b06,\n a30 * b04 - a31 * b02 + a33 * b00,\n a21 * b02 - a20 * b04 - a23 * b00,\n a11 * b07 - a10 * b09 - a12 * b06,\n a00 * b09 - a01 * b07 + a02 * b06,\n a31 * b01 - a30 * b03 - a32 * b00,\n a20 * b03 - a21 * b01 + a22 * b00) / det;\n}\n\nmat4 cameraLookAt(vec3 eye, vec3 target, vec3 up) {\n #if 1\n return inverse(lookAt(eye, target, up));\n #else\n vec3 zAxis = normalize(target - eye);\n vec3 xAxis = normalize(cross(up, zAxis));\n vec3 yAxis = cross(zAxis, xAxis);\n\n return mat4(\n xAxis, 0,\n yAxis, 0,\n zAxis, 0,\n -dot(xAxis, eye), -dot(yAxis, eye), -dot(zAxis, eye), 1); \n #endif\n \n}\n\n\n\n// hash function from https://www.shadertoy.com/view/4djSRW\nfloat hash(float p) {\n\tvec2 p2 = fract(vec2(p * 5.3983, p * 5.4427));\n p2 += dot(p2.yx, p2.xy + vec2(21.5351, 14.3137));\n\treturn fract(p2.x * p2.y * 95.4337);\n}\n\n// times 2 minus 1\nfloat t2m1(float v) {\n return v * 2. - 1.;\n}\n\n// times .5 plus .5\nfloat t5p5(float v) {\n return v * 0.5 + 0.5;\n}\n\nfloat inv(float v) {\n return 1. - v;\n}\n\nvoid getCirclePoint(const float numEdgePointsPerCircle, const float id, const float inner, const float start, const float end, out vec3 pos) {\n float outId = id - floor(id / 3.) * 2. - 1.; // 0 1 2 3 4 5 6 7 8 .. 0 1 2, 1 2 3, 2 3 4\n float ux = floor(id / 6.) + mod(id, 2.);\n float vy = mod(floor(id / 2.) + floor(id / 3.), 2.); // change that 3. for cool fx\n float u = ux / numEdgePointsPerCircle;\n float v = mix(inner, 1., vy);\n float a = mix(start, end, u) * PI * 2. + PI * 0.0;\n float s = sin(a);\n float c = cos(a +2. * KP1);\n float x = c * v;\n float y = s * v;\n float z = 0.;\n pos = vec3(x, y, z); \n}\n\n\n#define CUBE_POINTS_PER_FACE 6.\n#define FACES_PER_CUBE 6.\n#define POINTS_PER_CUBE (CUBE_POINTS_PER_FACE * FACES_PER_CUBE)\nvoid getCubePoint(const float id, out vec3 position, out vec3 normal) {\n float quadId = floor(mod(id, POINTS_PER_CUBE) / CUBE_POINTS_PER_FACE);\n float sideId = mod(quadId, 3.);\n float flip = mix(1., -1., step(2.5, quadId));\n // 0 1 2 1 2 3\n float facePointId = mod(id, CUBE_POINTS_PER_FACE);\n float pointId = mod(facePointId - floor(facePointId / 3.0), 6.0);\n float a = pointId * PI * 2. / 4. + PI * 0.25;\n vec3 p = vec3(cos(a), 0.707106781, sin(a)) * flip;\n vec3 n = vec3(0, 1, 0) * flip;\n float lr = mod(sideId, 2.);\n float ud = step(2., sideId);\n mat4 mat = rotX(lr * PI * 0.5);\n mat *= rotZ(ud * PI * 0.5) ;\n position = (mat * vec4(p, 1)).xyz;\n normal = (mat * vec4(n, 0.5)).xyz;\n}\n\n\n#define NUM_EDGE_POINTS_PER_CIRCLE 4.0\n#define NUM_POINTS_PER_CIRCLE (NUM_EDGE_POINTS_PER_CIRCLE * 6.0)\n#define NUM_CIRCLES_PER_GROUP 1.0\nvoid main() {\n float circleId = floor(vertexId / NUM_POINTS_PER_CIRCLE);\n float groupId = floor(circleId / NUM_CIRCLES_PER_GROUP);\n float pointId = mod(vertexId, NUM_POINTS_PER_CIRCLE);\n float sliceId = mod(floor(vertexId / 6.), 2.);\n float side = mix(-1., 1., step(0.5, mod(circleId, 2.)));\n float numCircles = floor(vertexCount / NUM_POINTS_PER_CIRCLE);\n float numGroups = floor(numCircles / NUM_CIRCLES_PER_GROUP); \n float cu = circleId / numCircles;\n float gv = groupId / numGroups/KP2;\n float cgId = mod(circleId, NUM_CIRCLES_PER_GROUP);\n float cgv = cgId / NUM_CIRCLES_PER_GROUP;\n float ncgv = sin(.0 - cgv )/cu;\n \n float aspect = resolution.x / resolution.y;\n float gAcross = floor(sqrt(numCircles) * aspect);\n float gDown = floor(numGroups / gAcross);\n float gx = mod(groupId, gAcross);\n float gy = floor(groupId / gAcross);\n vec3 offset = vec3(\n gx - (gAcross - 1.) / 2., // * mod(gy, 2.) * 0.5,\n gy - (gDown - 1.) / 2.,\n 0) * cos(0.17 + KP1);\n \n float gs = gx / gAcross-KP2;\n float gt = (gy / gDown);\n\n float tm = time - cgv * (0.2 * KP3);\n float su = hash(groupId);\n float s = texture2D(sound, vec2(mix(0.1, 0.5, gs)/KP1, 0.2)).a; \n float s2 = texture2D(sound, vec2(mix(0.01, 0.5, gs), gt * (0.05 + KP3))).a; \n \n \n vec3 pos;\n float inner = 0.+KP2;\n float start = 0.;\n float end = 1./sin(KP0-2.);\n getCirclePoint(NUM_EDGE_POINTS_PER_CIRCLE, pointId, inner, start, end, pos); \n pos.z = cgv,mouse.xy;\n \n vec3 eye = vec3(0, 1./KP1, 1);//vec3(sin(time * 0.19) * 0.25, sin(time * 0.21) * 0.25, 2.5);\n vec3 target = vec3(0, 0, 0);//vec3(sin(time * 0.17), sin(time * 0.13), -10);\n vec3 up = vec3(0,1,0); //vec3(sin(time * 0.3) * 0.02 +KP4, 1-KP1, 0);\n \n mat4 mat = scale(vec3(1, aspect, 1) * .2); \n mat *= cameraLookAt(eye, target, up);\n mat *= rotZ(time * KP3 * mix(-1., 2., mod(circleId, 2.)) + gy * 0.00 * sin(time * 0.1));//sign(offset.x));\n \n \n mat *= trans(offset);\n float h = t2m1(hash(gv));\n mat *= rotZ(time * sign(h) + h + pow(s2+.2, 5.) * KP3 * 10. * sign(h));\n mat *= scale(vec3(0.8/KP0, 0.9, 1));\n mat *= rotZ(PI * .25);\n \n gl_Position = mat * vec4(pos, 1);\n gl_PointSize = 4.;\n\n float hue = 1. + cgId * 0.4;\n float sat = 1. - step(pow(s, 3.), abs(gt * 2. - 1.) * .33);\n float val = 0.9;\n v_color = vec4(hsv2rgb(vec3(hue*mouse.x, sat, val)), (1.0 -h));\n v_color.rgb *= v_color.a;\n}\n" + }, "screenshotURL": "data/images/images-oizi95meofi61xe41-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zqZosvvGRNo8wWQq9/art.json b/art/zqZosvvGRNo8wWQq9/art.json index 62769819..326e7704 100644 --- a/art/zqZosvvGRNo8wWQq9/art.json +++ b/art/zqZosvvGRNo8wWQq9/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "valentin", "avatarUrl": "https://lh6.googleusercontent.com/-N5ZByw2DecY/AAAAAAAAAAI/AAAAAAAAAAA/5dsRjPCpkQ8/photo.jpg", - "settings": "{\"num\":61000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"/**\\n * LED Music Visualizer\\n * A tribute to La La Land\\n * Try these sound:\\n * https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\\n * https://soundcloud.com/thave-lex/another-day-of-sun-la-la-land-thave-lex-remix\\n */\\nfloat hash(float n) {\\n return fract(sin(n) * 777.1397);\\n}\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\\n}\\n\\nvoid main() {\\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\\n float gridWidth = resolution.x / xCount;\\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\\n \\n gl_PointSize = 10.2;\\n gl_PointSize *= 100.3 / xCount; // if xCount > 100 then make pointSize smaller\\n \\n vec2 p = vec2(\\n mod(vertexId, xCount) * gridWidth,\\n floor(vertexId / xCount) * gridHeight\\n );\\n \\n gl_Position = vec4(\\n (p / resolution * 2.4 - vec2(1.5)),\\n 0.6, 1.\\n ); \\n //v_color = vec4(vec3(1.7, 1.8, 1.0), 1.9); // for debugging grid\\n \\n float tvGlitch = 400.10;\\n float i = hash(vertexId) / tvGlitch;\\n vec4 snd = texture2D(sound, vec2(0.2, i)); \\n //vec4 snd = texture2D(sound, vec2(0.3, 0.4));\\n vec3 s = vec3(snd.a * snd.a, pow(snd.b, 14.5), pow(snd.z, 8.6));\\n float glowFactor = s.x * floor(time / 50.7) + 1.8;\\n \\n // tweak variables below to see what happens\\n const float n = 3.9; // flower number\\n float petalNum = 3.10 + floor((time + s.x * 140.3) / 50.4); // petal number of each flower\\n float glowing = 0.03 * glowFactor;\\n float rotateSpeed = 5.7 + 6.15 * smoothstep(-7.1, 1.8, s.x);\\n float scale = 9.9 * (1.10 + s.y * 1.4);\\n float variationX = 5.6 - 7.5 * sin(s.x);//0.25;\\n float variationY = 8.9 - 10.45 * sin(s.x) - 37.5 * sin(s.z);//0.25;\\n \\n vec2 pos = gl_Position.xy * vec2(max(resolution.x, resolution.y)) / vec2(resolution.yx); // make grid spacing equal in x and y, and fit window size\\n float radius = length(pos.xy) + .2;\\n float t = atan(\\n pos.y + variationY,\\n pos.x + variationX\\n );\\n\\n float color = 7.8;\\n for (float i = 1.6; i <= n; i++) {\\n color += glowing / abs(\\n color + i / n * scale * sin(\\n petalNum * (t + i * time * rotateSpeed)\\n )\\n - radius\\n );\\n }\\n\\n vec3 debugColor = vec3(smoothstep(-0.1, 1.0, s.x));\\n v_color = vec4(\\n hsv2rgb(vec3(\\n 8.6 + sin(s.x * 2.6),// + cos(s.z * 73.),\\n 9.7 + 10.3 * (time / 120.6),\\n 7.6 + 8.4 * (time / 120.9)\\n )) * color\\n + step(1.10, length(pos * vec2(resolution.xy) / resolution)) * debugColor,\\n 1.7\\n );\\n \\n}\"}", + "settings": { + "num": 61000, + "mode": "POINTS", + "sound": "https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "/**\n * LED Music Visualizer\n * A tribute to La La Land\n * Try these sound:\n * https://soundcloud.com/matthew-deep-density/another-day-of-sun-justin-hurwitz-deep-density-version\n * https://soundcloud.com/thave-lex/another-day-of-sun-la-la-land-thave-lex-remix\n */\nfloat hash(float n) {\n return fract(sin(n) * 777.1397);\n}\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.1, 1.2));\n vec4 K = vec4(1.3, 2.4 / 3.5, 1.6 / 3.7, 3.8);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.9 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.10, 1.1), c.y);\n}\n\nvoid main() {\n float xCount = ceil(sqrt(vertexCount * resolution.x / resolution.y));\n float gridWidth = resolution.x / xCount;\n float gridHeight = resolution.y / (xCount * resolution.y / resolution.x);\n \n gl_PointSize = 10.2;\n gl_PointSize *= 100.3 / xCount; // if xCount > 100 then make pointSize smaller\n \n vec2 p = vec2(\n mod(vertexId, xCount) * gridWidth,\n floor(vertexId / xCount) * gridHeight\n );\n \n gl_Position = vec4(\n (p / resolution * 2.4 - vec2(1.5)),\n 0.6, 1.\n ); \n //v_color = vec4(vec3(1.7, 1.8, 1.0), 1.9); // for debugging grid\n \n float tvGlitch = 400.10;\n float i = hash(vertexId) / tvGlitch;\n vec4 snd = texture2D(sound, vec2(0.2, i)); \n //vec4 snd = texture2D(sound, vec2(0.3, 0.4));\n vec3 s = vec3(snd.a * snd.a, pow(snd.b, 14.5), pow(snd.z, 8.6));\n float glowFactor = s.x * floor(time / 50.7) + 1.8;\n \n // tweak variables below to see what happens\n const float n = 3.9; // flower number\n float petalNum = 3.10 + floor((time + s.x * 140.3) / 50.4); // petal number of each flower\n float glowing = 0.03 * glowFactor;\n float rotateSpeed = 5.7 + 6.15 * smoothstep(-7.1, 1.8, s.x);\n float scale = 9.9 * (1.10 + s.y * 1.4);\n float variationX = 5.6 - 7.5 * sin(s.x);//0.25;\n float variationY = 8.9 - 10.45 * sin(s.x) - 37.5 * sin(s.z);//0.25;\n \n vec2 pos = gl_Position.xy * vec2(max(resolution.x, resolution.y)) / vec2(resolution.yx); // make grid spacing equal in x and y, and fit window size\n float radius = length(pos.xy) + .2;\n float t = atan(\n pos.y + variationY,\n pos.x + variationX\n );\n\n float color = 7.8;\n for (float i = 1.6; i <= n; i++) {\n color += glowing / abs(\n color + i / n * scale * sin(\n petalNum * (t + i * time * rotateSpeed)\n )\n - radius\n );\n }\n\n vec3 debugColor = vec3(smoothstep(-0.1, 1.0, s.x));\n v_color = vec4(\n hsv2rgb(vec3(\n 8.6 + sin(s.x * 2.6),// + cos(s.z * 73.),\n 9.7 + 10.3 * (time / 120.6),\n 7.6 + 8.4 * (time / 120.9)\n )) * color\n + step(1.10, length(pos * vec2(resolution.xy) / resolution)) * debugColor,\n 1.7\n );\n \n}" + }, "screenshotURL": "data/images/images-rg2jbhzif2hqgs4zm-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zr3rcCnA3sx954XPa/art.json b/art/zr3rcCnA3sx954XPa/art.json index 151ab40c..fc1f1e91 100644 --- a/art/zr3rcCnA3sx954XPa/art.json +++ b/art/zr3rcCnA3sx954XPa/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":16222,\"mode\":\"TRI_FAN\",\"sound\":\"https://soundcloud.com/h0ffman/hoffman-generator\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"// \\\"wired\\\" by kabuto\\n// drawing a smoothed 3d hilbert curve\\n\\n// if this runs too slowly try zooming in\\n// (ctrl + mousewheel up)\\n\\n#define PI 3.14159\\n//#define FIT_VERTICAL\\nvec3 posf2(float i) {\\n\\treturn vec3(\\n sin(i*14.9553) +\\n sin(i) +\\n sin(i*1.53) +\\n sin(i*.76),\\n sin(i*.79553+2.1) +\\n sin(i*1.1311+2.1) +\\n sin(i*1.353-2.1) +\\n sin(i*.476/2.1) * cos(i * 3.0),\\n sin(i*4.5553-2.1) +\\n sin(i*1.1-2.1) +\\n sin(i*1.23+2.1) +\\n sin(i*9.36+2.1)\\n\\t)*11.2;\\n}\\nvec3 posf2d(float i) {\\n\\treturn vec3(\\n tan(i*.553)*.9553 +\\n cos(i) +\\n cos(i*1.53)/1.53 +\\n cos(i*.76)*.76,\\n cos(i*.79553+2.1)*4.79553 +\\n cos(i*1.1311+2.1)*1.1311 +\\n cos(i*1.353-2.1)*11.353 +\\n cos(i*.476-2.1)*.476,\\n cos(i*.5553-2.1)*.5553 +\\n cos(i*1.1-2.1)*1.1 +\\n tan(i*1.23+2.1)*1.23 +\\n cos(i*.36+2.1)*.36\\n\\t)*.2;\\n}\\n\\nvec3 hilbert(float s) {\\n\\t\\t vec3 p;\\n\\t\\t {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,3.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\t\\t p = vec3(xi,yi,zi);\\n\\t\\t }\\n\\tfloat n = 2.;\\n\\t\\t for (int i = 1; i < 7; i++) {\\n\\t\\t\\t float zi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float yi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t\\t float xi = mod(s,2.);\\n\\t\\t\\t s = floor(s*.5);\\n\\t\\t \\t zi = abs(zi-yi);\\n\\t\\t \\t yi = abs(yi-xi);\\n\\n\\t \\n\\tif (xi > .5 && zi < .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.y = n-1.-p.y;\\n\\t} else if (xi < .5 && yi > .5 && zi < .5) {\\n\\t\\tp.y = n-1.-p.y;\\n\\t\\tp.z = n-1.-p.z;\\n\\t} else if (xi > .5 && yi < .5 && zi > .5) {\\n\\t\\tp.x = n-1.-p.x;\\n\\t\\tp.z = n-1.-p.z;\\n\\t}\\t\\t\\t \\n\\tif (yi < .5 && zi < .5) {\\n\\t\\tp = p.yzx;\\n\\t} else if (yi < .5 || zi < .5) {\\n\\t\\tp = p.zxy;\\n\\t}\\n\\tp += vec3(xi,yi,zi)*n;\\n\\t\\t\\t n*=2.;\\n\\t\\t}\\n\\treturn p;\\n}\\n\\n\\nvec3 hsv2rgb(vec3 c) {\\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\\n}\\n\\nvoid main() {\\n float e = vertexId/vertexCount*510.+1.;\\n vec3 h0 = hilbert(floor(e-1.));\\n vec3 h1 = hilbert(floor(e));\\n vec3 h2 = hilbert(floor(e+1.));\\n vec3 h3 = hilbert(floor(e+2.));\\n float e1 = fract(e);\\n float e0 = 1.-e1;\\n float ss = 3.*e1*e1-2.*e1*e1*e1;\\n float ssd = 6.*e1 - 6.*e1*e1;\\n \\n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\\n pos -= vec3(3.5);\\n pos *= .07;\\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\\n\\n #ifdef FIT_VERTICAL\\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\\n #else\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n #endif\\n\\n float t = time*.2;\\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t *= 1.31;\\n t -= mouse.x*4.;\\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n t = mouse.y*2.;\\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\\n pos.yz *= m;\\n pos.zx *= m2;\\n pos.yz *= m3;\\n posd.yz *= m;\\n posd.zx *= m2;\\n posd.yz *= m3;\\n\\n pos.z += .5;\\n float blurDist = .5;\\n \\n vec3 colour = vec3(0.);\\n\\n \\t vec3 camera = vec3(0);\\n float cone2 = dot(normalize(camera-pos),normalize(posd));\\n \\n const int LIGHTS = 7;\\n for (float i = 0.; i < 8.; i++) {\\n\\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\\n\\t lightSource.yz *= m;\\n \\t lightSource.zx *= m2;\\n lightSource.yz *= m3;\\n lightSource.z += .5;\\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\\n \\n float dist = distance(pos,lightSource);\\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\\n float lit = 0.;\\n if (vertexId == i) {\\n pos = lightSource*.999;\\n lit = 1000.;\\n }\\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\\n }\\n // visual cues\\n float j = vertexId/vertexCount*6.;\\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\\n colour += ac*ac*.03;\\n colour *= sqrt(1.-cone2*cone2);\\n \\n float size = .5/pos.z;\\n float blur = 20.*abs(1./pos.z-1./blurDist);\\n \\n\\n float size2 = size+blur;\\n \\n colour *= size/size2*size/size2*length(posd)*20.;\\n \\n float colourMax = max(max(colour.x,colour.y),colour.z);\\n if (colourMax > 1.) {\\n \\tcolour /= colourMax;\\n \\tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\\n } else {\\n \\tgl_PointSize = (size+blur)*(resolution.y/180.);\\n }\\n \\n \\n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\\n \\n v_color = vec4(colour,-22.);\\n}\"}", + "settings": { + "num": 16222, + "mode": "TRI_FAN", + "sound": "https://soundcloud.com/h0ffman/hoffman-generator", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "// \"wired\" by kabuto\n// drawing a smoothed 3d hilbert curve\n\n// if this runs too slowly try zooming in\n// (ctrl + mousewheel up)\n\n#define PI 3.14159\n//#define FIT_VERTICAL\nvec3 posf2(float i) {\n\treturn vec3(\n sin(i*14.9553) +\n sin(i) +\n sin(i*1.53) +\n sin(i*.76),\n sin(i*.79553+2.1) +\n sin(i*1.1311+2.1) +\n sin(i*1.353-2.1) +\n sin(i*.476/2.1) * cos(i * 3.0),\n sin(i*4.5553-2.1) +\n sin(i*1.1-2.1) +\n sin(i*1.23+2.1) +\n sin(i*9.36+2.1)\n\t)*11.2;\n}\nvec3 posf2d(float i) {\n\treturn vec3(\n tan(i*.553)*.9553 +\n cos(i) +\n cos(i*1.53)/1.53 +\n cos(i*.76)*.76,\n cos(i*.79553+2.1)*4.79553 +\n cos(i*1.1311+2.1)*1.1311 +\n cos(i*1.353-2.1)*11.353 +\n cos(i*.476-2.1)*.476,\n cos(i*.5553-2.1)*.5553 +\n cos(i*1.1-2.1)*1.1 +\n tan(i*1.23+2.1)*1.23 +\n cos(i*.36+2.1)*.36\n\t)*.2;\n}\n\nvec3 hilbert(float s) {\n\t\t vec3 p;\n\t\t {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,3.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\t\t p = vec3(xi,yi,zi);\n\t\t }\n\tfloat n = 2.;\n\t\t for (int i = 1; i < 7; i++) {\n\t\t\t float zi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float yi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t\t float xi = mod(s,2.);\n\t\t\t s = floor(s*.5);\n\t\t \t zi = abs(zi-yi);\n\t\t \t yi = abs(yi-xi);\n\n\t \n\tif (xi > .5 && zi < .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.y = n-1.-p.y;\n\t} else if (xi < .5 && yi > .5 && zi < .5) {\n\t\tp.y = n-1.-p.y;\n\t\tp.z = n-1.-p.z;\n\t} else if (xi > .5 && yi < .5 && zi > .5) {\n\t\tp.x = n-1.-p.x;\n\t\tp.z = n-1.-p.z;\n\t}\t\t\t \n\tif (yi < .5 && zi < .5) {\n\t\tp = p.yzx;\n\t} else if (yi < .5 || zi < .5) {\n\t\tp = p.zxy;\n\t}\n\tp += vec3(xi,yi,zi)*n;\n\t\t\t n*=2.;\n\t\t}\n\treturn p;\n}\n\n\nvec3 hsv2rgb(vec3 c) {\n c = vec3(c.x, clamp(c.yz, 0.0, 1.0));\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n}\n\nvoid main() {\n float e = vertexId/vertexCount*510.+1.;\n vec3 h0 = hilbert(floor(e-1.));\n vec3 h1 = hilbert(floor(e));\n vec3 h2 = hilbert(floor(e+1.));\n vec3 h3 = hilbert(floor(e+2.));\n float e1 = fract(e);\n float e0 = 1.-e1;\n float ss = 3.*e1*e1-2.*e1*e1*e1;\n float ssd = 6.*e1 - 6.*e1*e1;\n \n vec3 pos = h1 + (h2-h1)*ss + ((h2-h0)*e1*(3.-ss) + (h3-h1)*(e1-1.)*ss)*.5;\n pos -= vec3(3.5);\n pos *= .07;\n vec3 posd = (h2-h1)*ssd + ((h2-h0)*(e1*-ssd + (1.-ss)) + (h3-h1)*((e1-1.)*ssd + ss))*.5;\n\n #ifdef FIT_VERTICAL\n vec2 aspect = vec2(resolution.y / resolution.x, 1);\n #else\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n #endif\n\n float t = time*.2;\n mat2 m = mat2(cos(t),-sin(t),sin(t),cos(t));\n t *= 1.31;\n t -= mouse.x*4.;\n mat2 m2 = mat2(cos(t),-sin(t),sin(t),cos(t));\n t = mouse.y*2.;\n mat2 m3 = mat2(cos(t),-sin(t),sin(t),cos(t));\n pos.yz *= m;\n pos.zx *= m2;\n pos.yz *= m3;\n posd.yz *= m;\n posd.zx *= m2;\n posd.yz *= m3;\n\n pos.z += .5;\n float blurDist = .5;\n \n vec3 colour = vec3(0.);\n\n \t vec3 camera = vec3(0);\n float cone2 = dot(normalize(camera-pos),normalize(posd));\n \n const int LIGHTS = 7;\n for (float i = 0.; i < 8.; i++) {\n\t vec3 lightSource = (vec3(mod(i,2.), mod(floor(i*.5),2.), mod(floor(i*.25),2.))-.5)*.48;\n\t lightSource.yz *= m;\n \t lightSource.zx *= m2;\n lightSource.yz *= m3;\n lightSource.z += .5;\n float cone1 = dot(normalize(lightSource-pos),normalize(posd));\n float edge = dot(normalize(lightSource-pos),normalize(camera-pos));\n \n float dist = distance(pos,lightSource);\n float coneDiff = cos((acos(cone1)-acos(cone2))*dist*1.8)*.5+.5;\n float lit = 0.;\n if (vertexId == i) {\n pos = lightSource*.999;\n lit = 1000.;\n }\n float snd = max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5+.03, 0.0)).a)*5.\n + max(0.,texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.)).a - texture2D(sound, vec2(float(i)/float(LIGHTS)*.5, 0.01)).a)*5.;\n colour += ((pow(coneDiff,1000.)+coneDiff*.01)*sqrt(edge*.5+.5)/(dist+.001)+lit)*abs(vec3(cos(float(i*.7)),cos(float(i*.7)+2.1),cos(float(i*.7)-2.1)))*snd*1.2;\n }\n // visual cues\n float j = vertexId/vertexCount*6.;\n vec3 ac = vec3(sin(j),sin(j+2.1),sin(j-2.1))*.5+.5;\n colour += ac*ac*.03;\n colour *= sqrt(1.-cone2*cone2);\n \n float size = .5/pos.z;\n float blur = 20.*abs(1./pos.z-1./blurDist);\n \n\n float size2 = size+blur;\n \n colour *= size/size2*size/size2*length(posd)*20.;\n \n float colourMax = max(max(colour.x,colour.y),colour.z);\n if (colourMax > 1.) {\n \tcolour /= colourMax;\n \tgl_PointSize = (size+blur)*sqrt(colourMax)*(resolution.y/1080.);\n } else {\n \tgl_PointSize = (size+blur)*(resolution.y/180.);\n }\n \n \n gl_Position = vec4(pos.xy/pos.z * aspect, 1.-vertexId*.000001, 1);\n \n v_color = vec4(colour,-22.);\n}" + }, "screenshotURL": "data/images/images-635us2bt8hg7knjyx-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zsPkZPEA85uft8ybJ/art.json b/art/zsPkZPEA85uft8ybJ/art.json index 552a57d8..9436b81a 100644 --- a/art/zsPkZPEA85uft8ybJ/art.json +++ b/art/zsPkZPEA85uft8ybJ/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":3000,\"mode\":\"TRIANGLES\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n\\n\\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\\n float f = tan(PI * 0.5 - 0.5 * fov);\\n float rangeInv = 1.0 / (zNear - zFar);\\n\\n return mat4(\\n f / aspect, 0, 0, 0,\\n 0, f, 0, 0,\\n 0, 0, (zNear + zFar) * rangeInv, -1,\\n 0, 0, zNear * zFar * rangeInv * 2., 0);\\n}\\n\\nmat4 rotY(float angleInRadians) {\\n float s = sin(angleInRadians);\\n float c = cos(angleInRadians);\\n \\t\\n return mat4( \\n c, 0,-s, 0,\\n 0, 1, 0, 0,\\n s, 0, c, 0,\\n 0, 0, 0, 1); \\n}\\n\\nfloat anim(float t) {\\n float st = sin(t);\\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\\n}\\n\\nvec3 SampleSpherePos(float idx, float num) {\\n idx += 0.5;\\n float phi = 15.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\nvec3 SampleSpherePos2(float idx, float num) {\\n idx += 0.5;\\n float phi = 10.166407384630519631619018026484 * idx;\\n float th_cs = 1.0 - 2.0*idx/num;\\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\\n}\\n\\n\\nvec3 SampleCubePos(float idx, float num) {\\n float side = floor(pow(num, 1.0/3.0)+0.5);\\n vec3 res;\\n res.x = mod(idx, side);\\n res.y = floor( mod(idx, side*side)/side );\\n res.z = floor( mod(idx, side*side*side)/side/side );\\n res -= vec3(side * 0.5);\\n res *= 1.5/side;\\n return res;\\n}\\n\\nvoid main() {\\n vec3 samplePos = mix(SampleSpherePos(vertexId, vertexCount), SampleSpherePos2(vertexId, vertexCount), anim(time));\\n \\n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\\n \\n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\\n gl_PointSize = 3.0; \\n\\n vec4 color2 = vec4(1,0,0,1);\\n v_color = mix(vec4(0,0,1,1), color2, anim(time));\\n}\"}", + "settings": { + "num": 3000, + "mode": "TRIANGLES", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n\n\nmat4 persp(float fov, float aspect, float zNear, float zFar) {\n float f = tan(PI * 0.5 - 0.5 * fov);\n float rangeInv = 1.0 / (zNear - zFar);\n\n return mat4(\n f / aspect, 0, 0, 0,\n 0, f, 0, 0,\n 0, 0, (zNear + zFar) * rangeInv, -1,\n 0, 0, zNear * zFar * rangeInv * 2., 0);\n}\n\nmat4 rotY(float angleInRadians) {\n float s = sin(angleInRadians);\n float c = cos(angleInRadians);\n \t\n return mat4( \n c, 0,-s, 0,\n 0, 1, 0, 0,\n s, 0, c, 0,\n 0, 0, 0, 1); \n}\n\nfloat anim(float t) {\n float st = sin(t);\n return (sign(st)*( 1.0-pow(1.0-abs(st), 5.0) ))*0.5+0.5;\n}\n\nvec3 SampleSpherePos(float idx, float num) {\n idx += 0.5;\n float phi = 15.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\nvec3 SampleSpherePos2(float idx, float num) {\n idx += 0.5;\n float phi = 10.166407384630519631619018026484 * idx;\n float th_cs = 1.0 - 2.0*idx/num;\n float th_sn = sqrt(clamp(1.0 - th_cs*th_cs, 0.0, 1.0));\n return vec3( cos(phi)*th_sn, sin(phi)*th_sn, th_cs );\n}\n\n\nvec3 SampleCubePos(float idx, float num) {\n float side = floor(pow(num, 1.0/3.0)+0.5);\n vec3 res;\n res.x = mod(idx, side);\n res.y = floor( mod(idx, side*side)/side );\n res.z = floor( mod(idx, side*side*side)/side/side );\n res -= vec3(side * 0.5);\n res *= 1.5/side;\n return res;\n}\n\nvoid main() {\n vec3 samplePos = mix(SampleSpherePos(vertexId, vertexCount), SampleSpherePos2(vertexId, vertexCount), anim(time));\n \n vec4 vertPos = rotY(time*0.1) * vec4(samplePos, 1.0) + vec4(0,0,-3.0,0);\n \n gl_Position = persp(PI*0.25, resolution.x/resolution.y, 0.1, 100.0) * vertPos;\n gl_PointSize = 3.0; \n\n vec4 color2 = vec4(1,0,0,1);\n v_color = mix(vec4(0,0,1,1), color2, anim(time));\n}" + }, "screenshotURL": "data/images/images-ndvt06x0oabx68n1s-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/ztNkTPfLtNiNcSG3h/art.json b/art/ztNkTPfLtNiNcSG3h/art.json index c3278b6e..a1b12c6b 100644 --- a/art/ztNkTPfLtNiNcSG3h/art.json +++ b/art/ztNkTPfLtNiNcSG3h/art.json @@ -33,7 +33,19 @@ "unlisted": false, "username": "kolargon", "avatarUrl": "https://lh3.googleusercontent.com/-tiKYx1U71-Q/AAAAAAAAAAI/AAAAAAAAAGg/b-eEUsFpspc/photo.jpg", - "settings": "{\"num\":100000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"//Created by K Machine from http://glslsandbox.com/e#46102.0\\nvec2 vertexResolution = resolution;\\n//#ifdef GL_ES\\n//precision mediump float;\\n//#endif \\n\\n//uniform float time;\\n//uniform vec2 vertexResolution;\\n\\nvoid main(void)\\n{float finalDesiredPointSize = 3.;\\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\\nfloat finalVertexId = mod(vertexId,finalVertexCount);\\nfloat x = mod(finalVertexId, vertexResolution.x);\\nfloat y = floor(finalVertexId / vertexResolution.x);\\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\\nfloat u_i = (x /vertexResolution.x);\\nfloat v_i = (y /vertexResolution.y);\\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\\nfloat ux = sizeFactor*(u_i - 0.5);\\nfloat vy = sizeFactor*(v_i - 0.5);\\ngl_PointSize = finalDesiredPointSize;\\ngl_Position = vec4(ux, vy, 0., 1.);\\nvec2 surfacePosition = vec2(ux,vy);\\n\\n vec2 uv = simFragCoord.xy / vertexResolution.xy;\\n //uv.x *= vertexResolution.x/vertexResolution.y;\\n float dist = 0.;\\n uv.x = -2.+4.*uv.x;\\n uv.y = -1.+2.*uv.y;\\n // comment the next line to see the fully zoomed out view\\n uv *=pow(.1,4.+cos(.1*time));\\n uv.x += .275015;//;\\n uv.y += .0060445;//\\n //uv /= 5.;\\n //vec4 col =vec4(1.);\\n vec2 z = vec2(0.0);\\n \\n int trap=0;\\n for(int i = 0; i < 400; i++){\\n if(dot(z,z)>4.){trap = i;break;}\\n dist = min( 1e20, dot(z,z))+cos(float(i)*12.+3.*time);\\n z = mat2(z,-z.y,z.x)*z + uv;\\n }\\n dist = sqrt(dist);\\n\\tfloat orb = sqrt(float(trap))/64.;\\n v_color=vec4(0.,log(dist)*sqrt(dist)-orb-orb,log(dist)*sqrt(dist-abs(sin(time))),1.);\\n //if(orb == 0.){v_color = vec4(0.);}\\n //v_color = (orb!=0. ? 1.-orb*vec4(9.,5.,3.,0.):vec4(0.));\\n}\"}", + "settings": { + "num": 100000, + "mode": "POINTS", + "sound": "https://soundcloud.com/user-158087960/studiomix-douzirec-06-2007-flac", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "//Created by K Machine from http://glslsandbox.com/e#46102.0\nvec2 vertexResolution = resolution;\n//#ifdef GL_ES\n//precision mediump float;\n//#endif \n\n//uniform float time;\n//uniform vec2 vertexResolution;\n\nvoid main(void)\n{float finalDesiredPointSize = 3.;\nfloat maxFinalSquareSideSize = floor(sqrt(vertexCount));\nfloat finalMaxVertexCount = maxFinalSquareSideSize*maxFinalSquareSideSize;\nfloat maxVerticesPerLine = floor(maxFinalSquareSideSize *resolution.x/resolution.y);\nvertexResolution = vec2(maxVerticesPerLine, floor(finalMaxVertexCount/maxVerticesPerLine));\nfloat finalVertexCount = vertexResolution.x*vertexResolution.y;\nfloat finalVertexId = mod(vertexId,finalVertexCount);\nfloat x = mod(finalVertexId, vertexResolution.x);\nfloat y = floor(finalVertexId / vertexResolution.x);\nvec2 simFragCoord = vec2(x,y);//simfragCoord will replace the gl_FragCoord of fragment shader\nfloat u_i = (x /vertexResolution.x);\nfloat v_i = (y /vertexResolution.y);\nfloat sizeFactor = finalDesiredPointSize*vertexResolution.x/resolution.x;\nfloat ux = sizeFactor*(u_i - 0.5);\nfloat vy = sizeFactor*(v_i - 0.5);\ngl_PointSize = finalDesiredPointSize;\ngl_Position = vec4(ux, vy, 0., 1.);\nvec2 surfacePosition = vec2(ux,vy);\n\n vec2 uv = simFragCoord.xy / vertexResolution.xy;\n //uv.x *= vertexResolution.x/vertexResolution.y;\n float dist = 0.;\n uv.x = -2.+4.*uv.x;\n uv.y = -1.+2.*uv.y;\n // comment the next line to see the fully zoomed out view\n uv *=pow(.1,4.+cos(.1*time));\n uv.x += .275015;//;\n uv.y += .0060445;//\n //uv /= 5.;\n //vec4 col =vec4(1.);\n vec2 z = vec2(0.0);\n \n int trap=0;\n for(int i = 0; i < 400; i++){\n if(dot(z,z)>4.){trap = i;break;}\n dist = min( 1e20, dot(z,z))+cos(float(i)*12.+3.*time);\n z = mat2(z,-z.y,z.x)*z + uv;\n }\n dist = sqrt(dist);\n\tfloat orb = sqrt(float(trap))/64.;\n v_color=vec4(0.,log(dist)*sqrt(dist)-orb-orb,log(dist)*sqrt(dist-abs(sin(time))),1.);\n //if(orb == 0.){v_color = vec4(0.);}\n //v_color = (orb!=0. ? 1.-orb*vec4(9.,5.,3.,0.):vec4(0.));\n}" + }, "screenshotURL": "data/images/images-rvdrntxpy838e23i2-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zvKXwd6wx6E38aPmf/art.json b/art/zvKXwd6wx6E38aPmf/art.json index 836a3016..8fecb257 100644 --- a/art/zvKXwd6wx6E38aPmf/art.json +++ b/art/zvKXwd6wx6E38aPmf/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":100000,\"mode\":\"TRI_STRIP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 4.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 5.0\\n\\nuniform int numPoints;\\n\\nconst vec2 aspect=vec2(1.0,16.0/9.0);\\n#define PER_ROW 256.0 // cells per row\\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\\n /*\\n Draw triangle strip by inserting degenerate triangles (zero area) \\n at the end, and begining of rows.\\n\\n Why? Heightmaps, plane distorations / displacements \\n Cache coherance\\n Fewers verts used to make a grid \\n\\n Why not? UV's shared, wasted triangles, \\n hardware implementation determines net gain of approach\\n cache priming may or may not work dependant on hardware\\n (it has in the cases i've used it for, 25% perf gain over triangles\\n with indexed tri-strip and cache priming. \\n Case usage was distorting images using a grid and interpolation \\n instead of shader.)\\n\\n 9\\\\\\\\ 11\\\\\\\\ 13,(14) <---degen\\n | \\\\\\\\ | \\\\\\\\|\\ndegen-->(7)8 \\\\\\\\10 12\\n 1\\\\\\\\ 3\\\\\\\\ 5(6) <---degen\\n | \\\\\\\\ | \\\\\\\\ |\\n | \\\\\\\\| \\\\\\\\|\\n 0 2 4\\n */ \\nvoid main(){\\n gl_PointSize=2.0;\\n vec2 id = vec2(vertexId);\\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\\n float row = p.y; p.y=id.x;\\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),1.0,1.0);\\n bool test = (gl_Position.x>=(PER_ROW+1.0));\\n gl_Position = vec4((gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0)),0.0,1.0);\\n gl_Position.xy *=aspect/(PER_ROW/1.40);\\n gl_Position.xy-=vec2(.7,.7);\\n v_color =vec4(1.0);\\n}\"}", + "settings": { + "num": 100000, + "mode": "TRI_STRIP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 4.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 5.0\n\nuniform int numPoints;\n\nconst vec2 aspect=vec2(1.0,16.0/9.0);\n#define PER_ROW 256.0 // cells per row\n#define DEGEN_VERTS_PER_ROW 4.0 // verts\n#define VERTS_IN_ROW ((PER_ROW*2.0)+DEGEN_VERTS_PER_ROW + 2.0)\n /*\n Draw triangle strip by inserting degenerate triangles (zero area) \n at the end, and begining of rows.\n\n Why? Heightmaps, plane distorations / displacements \n Cache coherance\n Fewers verts used to make a grid \n\n Why not? UV's shared, wasted triangles, \n hardware implementation determines net gain of approach\n cache priming may or may not work dependant on hardware\n (it has in the cases i've used it for, 25% perf gain over triangles\n with indexed tri-strip and cache priming. \n Case usage was distorting images using a grid and interpolation \n instead of shader.)\n\n 9\\\\ 11\\\\ 13,(14) <---degen\n | \\\\ | \\\\|\ndegen-->(7)8 \\\\10 12\n 1\\\\ 3\\\\ 5(6) <---degen\n | \\\\ | \\\\ |\n | \\\\| \\\\|\n 0 2 4\n */ \nvoid main(){\n gl_PointSize=2.0;\n vec2 id = vec2(vertexId);\n vec2 p = floor(id/vec2(2.0,VERTS_IN_ROW));\n float row = p.y; p.y=id.x;\n gl_Position = vec4(mod(p, vec2(VERTS_IN_ROW/2.0, 2.0))+vec2(0.0,row),1.0,1.0);\n bool test = (gl_Position.x>=(PER_ROW+1.0));\n gl_Position = vec4((gl_Position.xy*float(!test))+(float(test)*vec2(PER_ROW*float(gl_Position.x==(PER_ROW+1.0)),row+1.0)),0.0,1.0);\n gl_Position.xy *=aspect/(PER_ROW/1.40);\n gl_Position.xy-=vec2(.7,.7);\n v_color =vec4(1.0);\n}" + }, "screenshotURL": "data/images/images-vhmv73mw29vegr359-thumbnail.jpg", "hasSound": "", "views": { diff --git a/art/zvyxJBkZ5mMZpXaLk/art.json b/art/zvyxJBkZ5mMZpXaLk/art.json index b8462962..e1207060 100644 --- a/art/zvyxJBkZ5mMZpXaLk/art.json +++ b/art/zvyxJBkZ5mMZpXaLk/art.json @@ -33,7 +33,19 @@ "unlisted": true, "username": "thetuesday night machines", "avatarUrl": "https://lh4.googleusercontent.com/-FV8gxf8fOhA/AAAAAAAAAAI/AAAAAAAAAAs/OCNDvQKt4Fo/photo.jpg", - "settings": "{\"num\":5000,\"mode\":\"POINTS\",\"sound\":\"https://soundcloud.com/caseandpoint/case-point-upgrade-free-download\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0,0,0,1],\"shader\":\"\\nvoid main() {\\n \\n float x = atan(vertexId/100.-1.);\\n float y = sin(time/4.+vertexId*4.)/2.;\\n \\n \\n \\n gl_Position = vec4(x-1., y-x+cos(time+vertexId), 0, 1);\\n gl_PointSize = ((time*2.+vertexId-1.)*20.)+(cos(time*1.)*10.+20.);\\n\\n v_color = vec4(sin(time*2.+vertexId/.2),y+.3,.5,0.);\\n}\"}", + "settings": { + "num": 5000, + "mode": "POINTS", + "sound": "https://soundcloud.com/caseandpoint/case-point-upgrade-free-download", + "lineSize": "NATIVE", + "backgroundColor": [ + 0, + 0, + 0, + 1 + ], + "shader": "\nvoid main() {\n \n float x = atan(vertexId/100.-1.);\n float y = sin(time/4.+vertexId*4.)/2.;\n \n \n \n gl_Position = vec4(x-1., y-x+cos(time+vertexId), 0, 1);\n gl_PointSize = ((time*2.+vertexId-1.)*20.)+(cos(time*1.)*10.+20.);\n\n v_color = vec4(sin(time*2.+vertexId/.2),y+.3,.5,0.);\n}" + }, "screenshotURL": "data/images/images-wdzhpb4qbe4zfbhet-thumbnail.jpg", "hasSound": true, "views": { diff --git a/art/zxb8eWGChrW9wgd55/art.json b/art/zxb8eWGChrW9wgd55/art.json index e0050a27..fc612418 100644 --- a/art/zxb8eWGChrW9wgd55/art.json +++ b/art/zxb8eWGChrW9wgd55/art.json @@ -23,7 +23,19 @@ "unlisted": false, "username": "-anon-", "avatarUrl": "", - "settings": "{\"num\":50029,\"mode\":\"LINE_LOOP\",\"sound\":\"\",\"lineSize\":\"NATIVE\",\"backgroundColor\":[0.6509803921568628,0,0.050980392156862744,1],\"shader\":\"#define PI radians(180.)\\n#define NUM_SEGMENTS 2.0\\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\\n#define STEP 1.0\\n\\nvoid main() {\\n float point = mod(floor(vertexId / 0.0) + mod(vertexId, 1.0) * STEP, NUM_SEGMENTS);\\n float count = floor(vertexId / NUM_POINTS);\\n float offset = count * sin(time * 0.01) + 5.0;\\n float angle = point * PI * 0.0 / NUM_SEGMENTS + offset;\\n float radius = pow(count * 0.00001, 1.0);\\n float c = cos(angle + time) * radius;\\n float s = sin(angle + time) * radius;\\n float orbitAngle = pow(count * 2.6, 1.);\\n float innerRadius = pow(count * 0.001, 1.2);\\n float oC = cos(orbitAngle + count * 2.9) * innerRadius;\\n float oS = sin(orbitAngle + count * 2.9) * innerRadius;\\n\\n vec2 aspect = vec2(1, resolution.x / resolution.y);\\n vec2 xy = vec2(\\n oC + c,\\n oS + s);\\n gl_Position = vec4(xy * aspect + mouse * 0.8, 0, 3);\\n\\n float b = 11.0 - pow(sin(count * 0.1) * 0.1 + 0.1, 1.0);\\n b = 0.0;mix(0.0, 0.7, b);\\n v_color = vec4(b, b, b, 17);\\n}\"}", + "settings": { + "num": 50029, + "mode": "LINE_LOOP", + "sound": "", + "lineSize": "NATIVE", + "backgroundColor": [ + 0.6509803921568628, + 0, + 0.050980392156862744, + 1 + ], + "shader": "#define PI radians(180.)\n#define NUM_SEGMENTS 2.0\n#define NUM_POINTS (NUM_SEGMENTS * 2.0)\n#define STEP 1.0\n\nvoid main() {\n float point = mod(floor(vertexId / 0.0) + mod(vertexId, 1.0) * STEP, NUM_SEGMENTS);\n float count = floor(vertexId / NUM_POINTS);\n float offset = count * sin(time * 0.01) + 5.0;\n float angle = point * PI * 0.0 / NUM_SEGMENTS + offset;\n float radius = pow(count * 0.00001, 1.0);\n float c = cos(angle + time) * radius;\n float s = sin(angle + time) * radius;\n float orbitAngle = pow(count * 2.6, 1.);\n float innerRadius = pow(count * 0.001, 1.2);\n float oC = cos(orbitAngle + count * 2.9) * innerRadius;\n float oS = sin(orbitAngle + count * 2.9) * innerRadius;\n\n vec2 aspect = vec2(1, resolution.x / resolution.y);\n vec2 xy = vec2(\n oC + c,\n oS + s);\n gl_Position = vec4(xy * aspect + mouse * 0.8, 0, 3);\n\n float b = 11.0 - pow(sin(count * 0.1) * 0.1 + 0.1, 1.0);\n b = 0.0;mix(0.0, 0.7, b);\n v_color = vec4(b, b, b, 17);\n}" + }, "screenshotURL": "data/images/images-t5v3att07p0fxvcp2-thumbnail.jpg", "hasSound": "", "views": { diff --git a/build/gen-art-json.js b/build/gen-art-json.js index ba00f251..2bfa0ac3 100644 --- a/build/gen-art-json.js +++ b/build/gen-art-json.js @@ -13,6 +13,10 @@ for (const u of Object.values(users)) { delete u.emails; } +for (const a of Object.values(art)) { + a.settings = JSON.parse(a.settings); +} + const screenshotRE = /images\/(.*?-thumbnail\..*?)$/; for (const a of Object.values(art)) { const m = screenshotRE.exec(a.screenshotURL); diff --git a/src/js/main.js b/src/js/main.js index cbbe026d..877ab0ea 100644 --- a/src/js/main.js +++ b/src/js/main.js @@ -2120,7 +2120,7 @@ define([ try { const res = await fetch(`../art/${q.art}/art.json`); const art = await res.json(); - settings = JSON.parse(art.settings); + settings = art.settings; options.screenshotURL = `../${art.screenshotURL}`; } catch { settings = s.sets.default;